:root{
  --bg:#FFFFFF;
  --paper:#FAFAF7;
  --ink:#1A1820;
  --muted:#6E6A78;
  --line:#ECE9E4;
  --accent:#4B43C4;
  --accent-deep:#3A33A0;
  --accent-soft:#EEEDFB;
  --shadow:0 1px 2px rgba(20,18,40,.03), 0 10px 30px rgba(20,18,40,.06);
  --shadow-soft:0 1px 3px rgba(20,18,40,.05);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg)}
body{font-family:'Newsreader',Georgia,serif;color:var(--ink);-webkit-font-smoothing:antialiased;font-size:16.5px;line-height:1.6}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-deep)}

.shell{max-width:1080px;margin:0 auto;padding:clamp(20px,3.5vw,48px)}

/* ---------- header ---------- */
.hd{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;align-items:flex-end;
  position:relative;padding:22px clamp(18px,3vw,30px);border-radius:22px;margin-bottom:28px;
  background-image:linear-gradient(90deg,rgba(251,248,244,.93) 0%,rgba(251,248,244,.72) 32%,rgba(251,248,244,.72) 68%,rgba(251,248,244,.93) 100%),url("../img/hero-dressing.487a65768423.jpg");
  background-size:cover;background-position:center 42%;
  box-shadow:inset 0 0 0 1px rgba(20,18,40,.06),var(--shadow-soft)}
.brand{display:flex;flex-direction:row;align-items:center;gap:14px;flex-wrap:wrap}
.hd-brandtext{display:flex;flex-direction:column;gap:5px}
.mark{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;font-size:clamp(28px,4vw,40px);
  letter-spacing:-.01em;line-height:1;color:var(--ink)}
.tagline{font-size:13px;color:var(--muted);font-style:italic}
.hd-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.tabs{display:flex;gap:2px;background:var(--paper);padding:4px;border-radius:13px;border:1px solid var(--line)}
.tab{padding:10px 18px;border-radius:9px;font-size:14px;font-weight:500;color:var(--muted);
  display:flex;align-items:center;gap:8px;transition:.18s}
.tab.on{background:var(--bg);color:var(--ink);box-shadow:var(--shadow-soft)}
.tab .badge{font-size:11px;background:var(--accent);color:#fff;border-radius:999px;padding:2px 8px;font-weight:600}
.account{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted)}
.who{font-weight:500;color:var(--ink)}
.link-btn{font-size:13px;color:var(--muted);text-decoration:underline;text-underline-offset:3px}
.link-btn:hover{color:var(--accent)}

/* ---------- views ---------- */
.view{display:none}
.view.on{display:block;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- toolbar ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;margin-bottom:24px}
.filters{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:8px 16px;border-radius:999px;border:1px solid var(--line);font-size:13px;color:var(--muted);
  background:var(--bg);transition:.15s}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;font-weight:500;
  font-size:14px;transition:.18s;letter-spacing:.01em}
.btn.primary{background:var(--ink);color:#fff;padding:13px 22px}
.btn.primary:hover{background:#000;transform:translateY(-1px);box-shadow:var(--shadow-soft)}
.btn.primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn.sm{padding:10px 18px}
.btn.big{width:100%;margin-top:18px;padding:15px}
.btn.block{width:100%;padding:14px}
.btn.ghost{border:1px solid var(--line);background:var(--bg);padding:11px 16px;color:var(--ink)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn.ghost:disabled{opacity:.5;cursor:not-allowed}

/* ---------- add form ---------- */
.addform{background:var(--bg);border:1px solid var(--line);border-radius:22px;padding:26px;margin-bottom:26px;
  display:flex;flex-direction:column;gap:20px;box-shadow:var(--shadow);animation:fade .25s ease}
.field{display:flex;flex-direction:column;gap:9px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
.addform input[type=text]{padding:12px 15px;border:1px solid var(--line);border-radius:11px;font-size:14px;background:var(--paper)}
.addform input[type=file]{font-size:13px;color:var(--muted)}
.addform input[type=text]:focus,.city:focus{outline:none;border-color:var(--accent);background:#fff;
  box-shadow:0 0 0 3px var(--accent-soft)}
.mini-chips{display:flex;gap:8px;flex-wrap:wrap}
.mchip{padding:9px 15px;border-radius:10px;border:1px solid var(--line);font-size:13px;color:var(--muted);
  background:var(--bg);transition:.15s}
.mchip:hover{border-color:var(--accent)}
.mchip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.colors{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.swdot{width:30px;height:30px;border-radius:50%;border:2px solid transparent;transition:.15s;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.swdot.on{border-color:var(--ink);transform:scale(1.1)}
.custom-col{width:30px;height:30px;border-radius:50%;border:1.5px dashed var(--muted);display:flex;
  align-items:center;justify-content:center;position:relative;color:var(--muted);font-size:18px;overflow:hidden}
.custom-col input{position:absolute;inset:0;opacity:0;cursor:pointer}

/* ---------- grid + cards ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:20px}
.card{background:var(--bg);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:.22s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card:hover .del{opacity:1}
.swatch{height:134px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.swatch img{width:100%;height:100%;object-fit:cover}
.cat-ic use{fill:currentColor}
.delform{position:absolute;top:9px;right:9px;margin:0}
.del{width:27px;height:27px;border-radius:50%;background:rgba(255,255,255,.92);color:#1A1820;font-size:18px;
  line-height:1;opacity:0;transition:.15s;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft)}
.del:hover{background:#fff}
.card-body{padding:15px}
.card-name{font-weight:600;font-size:14px;margin-bottom:10px;line-height:1.3}
.card-tags{display:flex;flex-wrap:wrap;gap:5px}
.tag{font-size:11px;padding:3px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent-deep);font-weight:500}
.tag.soft{background:var(--paper);color:var(--muted);border:1px solid var(--line)}

.empty{padding:64px 20px;text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:20px}
.empty code{background:var(--paper);padding:2px 8px;border-radius:6px;font-size:13px}

/* ---------- outfit ---------- */
.outfit-grid{display:grid;grid-template-columns:350px 1fr;gap:28px;align-items:start}
.ctx{display:flex;flex-direction:column;gap:20px}
.block{background:var(--bg);border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:var(--shadow-soft)}
.lab{font-family:'Cormorant Garamond',Georgia,serif;font-size:19px;font-weight:600;margin:0 0 16px;letter-spacing:-.01em}
.wx-row{display:flex;gap:8px;margin-bottom:8px}
.city{flex:1;padding:12px 14px;border:1px solid var(--line);border-radius:11px;font-size:14px;background:var(--paper)}
.note{font-size:12px;color:var(--muted);min-height:16px;margin-bottom:8px}
.temp{display:flex;align-items:center;gap:16px;margin:10px 0 18px}
.deg{font-family:'Cormorant Garamond',Georgia,serif;font-size:34px;font-weight:600;min-width:74px}
#temp{flex:1;-webkit-appearance:none;height:5px;border-radius:999px;background:linear-gradient(90deg,var(--accent),#9b88e6)}
#temp::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;
  border:2.5px solid var(--accent);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.18)}
#temp::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2.5px solid var(--accent);cursor:pointer}
.wrap{gap:8px}

/* ---------- reveal ---------- */
.reveal{min-height:460px;background:var(--paper);border:1px solid var(--line);border-radius:26px;padding:36px;
  display:flex;align-items:center;justify-content:center}
.placeholder{text-align:center;color:var(--muted);max-width:320px}
.placeholder p{margin-top:16px;line-height:1.6}
.ph-ring{width:66px;height:66px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;
  justify-content:center;margin:0 auto;font-size:22px;color:var(--accent);background:var(--bg)}
.pulse{animation:breathe 1.4s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.5}50%{opacity:1}}
.err{color:#b3261e;text-align:center;font-size:14px;max-width:360px;line-height:1.5}

.look{width:100%;animation:fade .4s ease}
.look-head{margin-bottom:24px}
.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:600}
.look-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(26px,3.4vw,38px);font-weight:600;
  letter-spacing:-.01em;margin:8px 0 0;line-height:1.08}
.demo-tag{display:inline-block;vertical-align:middle;margin-left:12px;font-family:'Newsreader',Georgia,serif;
  font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:4px 11px}
.flatlay{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:26px}
.fl-item{display:flex;flex-direction:column;align-items:center;gap:10px;width:110px;animation:rise .45s ease both}
@keyframes rise{from{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}
.fl-swatch{width:98px;height:98px;border-radius:18px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(20,18,40,.12);border:1px solid rgba(0,0,0,.04);overflow:hidden}
.fl-photo{padding:0}
.fl-photo img{width:100%;height:100%;object-fit:cover;display:block}
.fl-name{font-size:12.5px;text-align:center;line-height:1.3;color:var(--muted)}
.look-text{font-size:16px;line-height:1.65;max-width:560px;margin:0 0 18px;color:var(--ink)}
.advice{background:var(--bg);border:1px solid var(--line);border-radius:16px;padding:17px 20px;font-size:14.5px;
  line-height:1.55;color:var(--ink);max-width:560px}
.advice span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.14em;font-weight:700;
  margin-bottom:6px;color:var(--accent)}
.missing{margin-top:14px;font-size:13px;color:var(--muted);border-left:2px solid var(--accent);padding-left:13px}
.regen{margin-top:22px}

.ft{margin-top:40px;padding-top:22px;border-top:1px solid var(--line);text-align:center;font-size:12px;color:var(--muted)}

/* ---------- auth ---------- */
.auth-body{background:transparent}
.auth-body::before{content:"";position:fixed;inset:0;z-index:-1;
  background:linear-gradient(rgba(251,248,244,.56),rgba(251,248,244,.64)),url("../img/hero-dressing.487a65768423.jpg");
  background-size:cover;background-position:center}
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:392px;background:var(--bg);border:1px solid var(--line);border-radius:26px;
  padding:40px 36px;box-shadow:var(--shadow)}
.auth-head{text-align:center;margin-bottom:28px}
.auth-head .mark{display:block;font-size:34px}
.auth-sub{margin:10px 0 0;color:var(--muted);font-size:14px}
.auth-form{display:flex;flex-direction:column;gap:18px}
.auth-form input{width:100%;box-sizing:border-box;padding:13px 15px;border:1px solid var(--line);border-radius:12px;font-size:14px;background:var(--paper)}
.auth-form .two{gap:14px}
.two > .field{min-width:0}
.auth-form input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-soft)}
.auth-form .btn{margin-top:6px}
.auth-hint{font-size:12px;color:var(--muted);line-height:1.5;margin:-4px 0 0}
.auth-error{background:#fdecea;border:1px solid #f5c6c0;color:#9a2a20;font-size:13px;padding:11px 14px;
  border-radius:11px;margin-bottom:20px;text-align:center}
.field-error{font-size:12px;color:#b3261e;line-height:1.4}
.auth-switch{text-align:center;margin:24px 0 0;font-size:14px;color:var(--muted)}

@media (max-width:780px){
  .outfit-grid{grid-template-columns:1fr}
  .reveal{min-height:320px;padding:24px}
  .two{grid-template-columns:1fr}
  .hd{align-items:flex-start}
  .hd-right{align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}

/* ===================== AJOUTS ===================== */
.shell.narrow{max-width:760px}
a.mark{text-decoration:none}

/* messages flash */
.flash{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.flash-item{padding:12px 16px;border-radius:12px;font-size:14px;border:1px solid var(--line);background:var(--paper)}
.flash-item.success{background:#eef7ef;border-color:#cfe6d4;color:#256137}
.flash-item.error{background:#fdecea;border-color:#f5c6c0;color:#9a2a20}
.flash-item.warning{background:#fdf4e3;border-color:#f0dcae;color:#8a6418}
.flash-item.info{background:var(--accent-soft);border-color:#dcd9f7;color:var(--accent-deep)}

/* quota dans l'entête */
.quota{font-size:12px;color:var(--muted);background:var(--paper);border:1px solid var(--line);
  border-radius:999px;padding:4px 11px}

/* ---------- modale ---------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(20,18,28,.45);backdrop-filter:blur(3px);
  display:flex;align-items:flex-start;justify-content:center;padding:5vh 18px;z-index:50;
  animation:fade .2s ease;overflow:auto}
.modal-backdrop[hidden]{display:none}
.modal{position:relative;width:100%;max-width:520px;background:var(--bg);border:1px solid var(--line);
  border-radius:24px;padding:30px;box-shadow:0 30px 70px rgba(20,18,40,.25);animation:pop .25s ease}
@keyframes pop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.modal-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:24px;font-weight:600;margin:0 0 22px}
.modal-close{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;
  background:var(--paper);border:1px solid var(--line);font-size:20px;color:var(--muted);
  display:flex;align-items:center;justify-content:center}
.modal-close:hover{color:var(--ink);border-color:var(--accent)}
.modal .addform{border:none;box-shadow:none;padding:0;margin:0;background:transparent}

/* ---------- landing ---------- */
.landing-body{background:radial-gradient(1100px 460px at 50% -8%, var(--accent-soft), transparent 60%), var(--bg)}
.lp{max-width:1040px;margin:0 auto;padding:clamp(18px,3vw,32px)}
.lp-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.lp-links{display:flex;align-items:center;gap:16px}
.lp-login{font-size:14px;color:var(--ink);text-decoration:none}
.lp-login:hover{color:var(--accent)}
.hero{position:relative;text-align:center;border-radius:30px;overflow:hidden;
  padding:clamp(52px,8vw,104px) clamp(22px,5vw,64px);margin-bottom:8px;
  background-image:
    radial-gradient(135% 110% at 50% 45%, rgba(251,248,244,.92), rgba(251,248,244,.66) 50%, rgba(251,248,244,.40) 100%),
    url("../img/hero-dressing.487a65768423.jpg");
  background-size:cover;background-position:center;
  box-shadow:inset 0 0 0 1px rgba(20,18,40,.06)}
.hero .eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.hero-title{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;font-size:clamp(40px,7vw,76px);
  line-height:1.02;letter-spacing:-.02em;margin:18px 0 0}
.hero-sub{max-width:560px;margin:22px auto 0;font-size:17px;line-height:1.6;color:#403c48}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:20px 0 64px}
.step{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:var(--shadow-soft)}
.step-n{display:inline-flex;width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;
  align-items:center;justify-content:center;font-weight:600;font-size:14px;margin-bottom:14px}
.step h3{font-family:'Cormorant Garamond',Georgia,serif;font-size:18px;margin:0 0 8px;font-weight:600}
.step p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.lp-h2{font-family:'Cormorant Garamond',Georgia,serif;text-align:center;font-size:clamp(26px,4vw,38px);margin:0;font-weight:600}
.lp-h2-sub{text-align:center;color:var(--muted);margin:8px 0 30px}
.lp-note{text-align:center;color:var(--muted);font-size:13px;margin-top:22px}
.lp-foot{text-align:center;color:var(--muted);font-size:12px;margin-top:48px;padding-top:24px;border-top:1px solid var(--line)}

/* ---------- formules ---------- */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.plan-card{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:22px;
  padding:26px 24px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.plan-card.featured{border-color:var(--accent);box-shadow:0 10px 30px rgba(91,83,240,.14)}
.plan-flag{position:absolute;top:-11px;left:24px;background:var(--accent);color:#fff;font-size:11px;
  font-weight:600;letter-spacing:.04em;padding:4px 11px;border-radius:999px}
.plan-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;font-weight:600;margin:0 0 4px}
.plan-price{font-size:30px;font-weight:600;margin:6px 0 16px}
.plan-price span{font-size:14px;color:var(--muted);font-weight:400}
.plan-perks{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:9px;flex:1}
.plan-perks li{font-size:14px;color:var(--ink);padding-left:22px;position:relative}
.plan-perks li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}
.plan-card.selectable{cursor:pointer;transition:.18s}
.plan-card.selectable input{position:absolute;opacity:0}
.plan-card.selectable:has(input:checked){border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.plan-check{display:block;text-align:center;font-size:13px;font-weight:600;color:var(--muted);
  border:1px dashed var(--line);border-radius:10px;padding:9px}
.plan-card.selectable:has(input:checked) .plan-check{color:#fff;background:var(--accent);border-style:solid;border-color:var(--accent)}

/* ---------- abonnement / compte ---------- */
.plain-body{background:var(--bg)}
.mini-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:20px;
  border-bottom:1px solid var(--line);margin-bottom:28px}
.page-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(28px,4vw,40px);font-weight:600;margin:0 0 6px}
.page-sub{color:var(--muted);margin:0 0 28px}
.pay-card{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:24px;margin:26px 0}
.pay-card .field{margin-bottom:14px}
.pay-card input{padding:12px 14px;border:1px solid var(--line);border-radius:11px;font-size:14px;background:#fff;width:100%}
.sub-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.acc-block{background:var(--bg);border:1px solid var(--line);border-radius:22px;padding:24px;margin-bottom:20px;box-shadow:var(--shadow-soft)}
.acc-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.acc-form{display:flex;flex-direction:column;gap:16px;margin-top:16px}
.acc-form input{padding:12px 14px;border:1px solid var(--line);border-radius:11px;font-size:14px;background:var(--paper);width:100%}
.acc-form input:disabled{color:var(--muted)}
.acc-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:6px}
.badges{display:flex;gap:8px;flex-wrap:wrap}
.vbadge{font-size:12px;padding:5px 11px;border-radius:999px;background:var(--paper);border:1px solid var(--line);color:var(--muted)}
.vbadge.ok{background:#eef7ef;border-color:#cfe6d4;color:#256137}
.sub-state{display:flex;justify-content:space-between;align-items:center;margin:6px 0 16px}
.sub-plan{font-family:'Cormorant Garamond',Georgia,serif;font-size:20px;font-weight:600}
.sub-status{font-size:13px;color:var(--muted);margin-top:4px}
.sub-status.s-active{color:#256137}
.sub-status.s-suspended{color:#8a6418}
.btn.danger{background:#b3261e;color:#fff;padding:11px 18px;border-radius:11px}
.btn.danger:hover{background:#8f1d17}
.btn.danger-ghost{border:1px solid #e7b7b3;color:#b3261e;background:#fff;padding:9px 14px;border-radius:10px}
.btn.danger-ghost:hover{background:#fdecea}
.danger-zone{margin-top:14px}
.danger-zone summary{cursor:pointer;color:#b3261e;font-weight:500;font-size:14px}
.danger-zone .note{margin:12px 0}
.confirm-input{padding:11px 14px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:var(--paper)}
.auth-card.wide{max-width:520px}
.acc-form input, .pay-card input{width:100%;box-sizing:border-box}
.demo-codes{background:var(--accent-soft);border:1px solid #dcd9f7;border-radius:12px;padding:14px 16px;
  font-size:13px;line-height:1.6;color:var(--accent-deep);margin-bottom:22px}
.demo-codes .code{font-weight:700;letter-spacing:.12em;background:#fff;padding:2px 8px;border-radius:6px}

@media (max-width:780px){
  .lp-steps,.plan-grid{grid-template-columns:1fr}
}
.field label .opt{color:var(--muted);font-weight:400;text-transform:none;letter-spacing:0}

/* ---------- profil ---------- */
.profile-chip{display:inline-flex;align-items:center;gap:9px;text-decoration:none;padding:4px 12px 4px 4px;
  border:1px solid var(--line);border-radius:999px;background:var(--bg);transition:.15s}
.profile-chip:hover{border-color:var(--accent)}
.avatar-initials{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;
  border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:600;letter-spacing:.02em}
.avatar-img{width:30px;height:30px;border-radius:50%;object-fit:cover}
.profile-name{font-size:13px;font-weight:500;color:var(--ink);max-width:140px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.profile-edit{margin-top:16px;display:flex;flex-direction:column;gap:18px}
.avatar-edit{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.avatar-big{width:76px;height:76px;border-radius:50%;overflow:hidden;display:flex;align-items:center;
  justify-content:center;background:var(--accent);color:#fff;font-size:26px;font-weight:600;flex:0 0 auto}
.avatar-big img{width:100%;height:100%;object-fit:cover}
.avatar-controls{display:flex;flex-direction:column;gap:8px}
.file-btn{cursor:pointer;display:inline-flex}
.rm-avatar{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:7px;cursor:pointer}
.file-name{font-size:12px;color:var(--muted)}
@media (max-width:560px){.profile-name{display:none}}
.logout-form{margin:0}
.logout-form .link-btn{color:var(--muted)}

/* ---------- visionneuse ---------- */
.card .swatch{cursor:zoom-in}
.lightbox{position:fixed;inset:0;background:rgba(18,16,24,.66);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:24px;z-index:60;animation:fade .2s ease}
.lightbox[hidden]{display:none}
.lb-inner{position:relative;background:var(--bg);border-radius:24px;padding:20px;max-width:460px;width:100%;
  box-shadow:0 30px 80px rgba(20,18,40,.4);animation:pop .25s ease}
.lb-visual{border-radius:18px;overflow:hidden;background:var(--paper);display:flex;align-items:center;justify-content:center}
.lb-visual img{width:100%;height:auto;max-height:68vh;object-fit:contain;display:block}
.lb-swatch{width:100%;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.lb-meta{margin-top:18px}
.lb-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;font-weight:600;margin-bottom:10px}
.lb-meta .card-tags{display:flex;flex-wrap:wrap;gap:6px}

/* ---------- bouton modifier ---------- */
.edit-btn{position:absolute;top:9px;left:9px;width:27px;height:27px;border-radius:50%;
  background:rgba(255,255,255,.92);color:#15141A;font-size:14px;line-height:1;opacity:0;transition:.15s;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft);z-index:2}
.edit-btn:hover{background:#fff;color:var(--accent)}
.card:hover .edit-btn{opacity:1}
.cur-photo{width:80px;height:80px;border-radius:12px;overflow:hidden;border:1px solid var(--line);margin-bottom:8px}
.cur-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- sous-filtres ---------- */
.subfilters{display:flex;flex-wrap:wrap;gap:8px;margin:-6px 0 22px}
.subfilters[hidden]{display:none}
.chip.sub{font-size:12px;padding:6px 13px;border-style:dashed}
.chip.sub.on{background:var(--accent);border-color:var(--accent);border-style:solid;color:#fff}
.chip.sub:hover{border-color:var(--accent);color:var(--accent)}
.chip.sub.on:hover{color:#fff}

/* ---------- afficher / masquer le mot de passe ---------- */
.pw-wrap{position:relative;display:block}
.pw-wrap input{width:100%;box-sizing:border-box;padding-right:46px}
.pw-toggle{position:absolute;top:50%;right:8px;transform:translateY(-50%);width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;color:var(--muted);border-radius:8px;background:transparent}
.pw-toggle:hover{color:var(--accent)}
.pw-toggle svg{width:20px;height:20px}
.pw-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:1px}

/* ---------- choix / prise de photo ---------- */
.photo-pick{display:flex;gap:10px;flex-wrap:wrap}
.photo-pick .file-btn{cursor:pointer}
.new-photo{margin-top:12px;display:flex;align-items:center;gap:14px}
.new-photo img{width:84px;height:84px;border-radius:12px;object-fit:cover;border:1px solid var(--line)}
.rm-new{font-size:13px;color:#b3261e;text-decoration:underline;text-underline-offset:3px;background:none}
.rm-new:hover{color:#8f1d17}

/* ---------- fenêtre caméra ---------- */
.cam-modal{max-width:560px}
.cam-stage{border-radius:16px;overflow:hidden;background:#000;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}
.cam-stage video{width:100%;height:100%;object-fit:cover;transform:scaleX(1)}
.cam-actions{display:flex;gap:12px;margin-top:18px}
.cam-actions .btn{flex:1}

/* ===================== AMÉLIORATIONS ===================== */
/* l'attribut hidden doit toujours masquer (corrige .field{display:flex}, etc.) */
[hidden]{display:none !important}

/* espace compte un peu plus large (prénom / nom plus confortables) */
.shell.narrow{max-width:820px}
.profile-edit .two{gap:18px}

/* étiquette couleur sur les vignettes */
.swatch-tag{display:inline-flex;align-items:center;gap:6px}
.cdot{width:11px;height:11px;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12);flex:0 0 auto}

/* ---------- footer élégant ---------- */
.site-foot{background:var(--ink);color:#fff;margin-top:64px;border-radius:30px 30px 0 0;padding:50px 32px 28px}
.foot-inner{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:34px}
.foot-brand .mark{color:#fff;font-size:26px}
.foot-brand p{color:rgba(255,255,255,.62);font-size:14px;line-height:1.65;margin-top:12px;max-width:300px}
.foot-col h4{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.5);margin:0 0 14px;font-weight:600}
.foot-col a{display:block;color:rgba(255,255,255,.85);font-size:14px;text-decoration:none;margin-bottom:10px;transition:.15s}
.foot-col a:hover{color:#fff;transform:translateX(2px)}
.foot-note{color:rgba(255,255,255,.6);font-size:13px;line-height:1.55;margin:0}
.foot-bottom{max-width:1040px;margin:38px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.5);font-size:12px;text-align:center}

/* ---------- page contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:26px;align-items:start;margin-bottom:20px}
.contact-form{background:var(--bg);border:1px solid var(--line);border-radius:22px;padding:26px;box-shadow:var(--shadow-soft);
  display:flex;flex-direction:column;gap:16px}
.contact-form input,.contact-form textarea{width:100%;box-sizing:border-box;padding:12px 14px;border:1px solid var(--line);
  border-radius:11px;font-size:14px;background:var(--paper);font-family:inherit}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-soft)}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-aside{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:24px}
.contact-line{font-size:14px;line-height:1.5;color:var(--ink);margin:0 0 16px}
.contact-line strong{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.contact-note{font-size:12px;color:var(--muted);line-height:1.5;margin:8px 0 0}

@media (max-width:780px){
  .foot-inner{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
}

/* ---------- fenêtre de confirmation ---------- */
.confirm-modal{max-width:420px;text-align:left}
.confirm-text{font-size:15px;line-height:1.6;color:var(--ink);margin:4px 0 22px}
.confirm-actions{display:flex;gap:12px;justify-content:flex-end}
.confirm-modal .modal-title{margin-bottom:14px}

/* lien de l'en-tête (Contact, etc.) */
.account .link-btn{white-space:nowrap}

/* champs du profil identiques à ceux de "Mes informations" (ex. Identifiant) */
.profile-edit input[type=text]{width:100%;box-sizing:border-box;padding:12px 14px;border:1px solid var(--line);
  border-radius:11px;font-size:14px;background:var(--paper)}
.profile-edit input[type=text]:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--accent-soft)}

/* ---------- en-tête commun (topbar) ---------- */
.topbar{border-bottom:1px solid var(--line);background:var(--bg)}
.topbar-inner{max-width:1040px;margin:0 auto;padding:16px clamp(16px,3vw,32px);display:flex;
  justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar-nav{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.topbar-link{font-size:14px;color:var(--ink);text-decoration:none}
.topbar-link:hover{color:var(--accent)}
.topbar .logout-form{margin:0}

/* titre des pages d'authentification */
.auth-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:30px;font-weight:600;margin:0;letter-spacing:-.01em}
.auth-wrap{min-height:60vh;padding:48px 24px}

/* lien "continuer sans abonnement" */
.sub-skip{margin-top:18px;text-align:center}

/* ============================================================
   CHARTE COULEUR — signature dégradée indigo → violet → rose
   ============================================================ */
:root{
  --violet:#8B5CF6;
  --rose:#DD6F95;
  --rose-soft:#FBEDF3;
  --rose-deep:#A23B62;
  --gold:#C2944A;
  --grad:linear-gradient(135deg,#5B53F0,#8B5CF6);
  --grad-tri:linear-gradient(90deg,#5B53F0,#8B5CF6 55%,#DD6F95);
}

/* fine barre d'accent en haut de page */
.accent-bar{height:4px;width:100%;background:var(--grad-tri)}

/* boutons principaux : dégradé de marque (au lieu du noir) */
.btn.primary{background:var(--grad);color:#fff}
.btn.primary:hover{background:var(--grad);filter:brightness(1.06);transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(91,83,240,.28)}
.btn.primary:disabled{filter:none;transform:none;box-shadow:none}

/* filtres de catégorie actifs : couleur d'accent */
.filters .chip.on{background:var(--accent);border-color:var(--accent);color:#fff}

/* badge d'onglet et pastille profil : dégradé */
.tab .badge{background:var(--grad)}
.avatar-initials{background:var(--grad)}
.avatar-big{background:var(--grad)}
.step-n{background:var(--grad)}

/* bloc "Le conseil" : couleur secondaire rose */
.advice{background:var(--rose-soft);border-color:#F1D6E0}
.advice span{color:var(--rose-deep)}

/* titres de section : petit trait dégradé */
.page-title{position:relative;padding-bottom:14px}
.page-title::after{content:"";position:absolute;left:0;bottom:0;width:54px;height:3px;border-radius:999px;background:var(--grad-tri)}
.lp-h2{position:relative}
.lp-h2::after{content:"";display:block;width:54px;height:3px;border-radius:999px;background:var(--grad-tri);margin:14px auto 0}

/* hero : libellé en dégradé */
.hero .eyebrow{background:var(--grad-tri);-webkit-background-clip:text;background-clip:text;color:transparent}

/* pied de page : petit accent dégradé en haut */
.site-foot{position:relative}
.site-foot::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:120px;height:4px;border-radius:0 0 999px 999px;background:var(--grad-tri)}

/* abonnement : prix mis en couleur */
.plan-card.featured .plan-price{color:var(--accent-deep)}

/* étiquette catégorie des vignettes : léger dégradé */
.card-tags .tag{background:var(--accent-soft);color:var(--accent-deep)}

/* champ fichier masqué visuellement mais activable au tap (fiable sur iOS) */
.vhide{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* vérification : indices et renvoi de code */
.field-hint{font-size:12px;color:var(--muted);margin:2px 0 6px}
.resend-row{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.resend-form{margin:0}

/* ===== Pages d'erreur (404 / 500) ===== */
.error-body{background:radial-gradient(1100px 460px at 50% -8%, var(--accent-soft), transparent 60%), var(--bg)}
.error-wrap{min-height:60vh;display:flex;align-items:center;justify-content:center;
  padding:64px 22px 80px}
.error-card{max-width:560px;text-align:center}
.error-eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);
  font-weight:600;margin:0 0 6px}
.error-code{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;line-height:1;
  font-size:clamp(96px,22vw,180px);letter-spacing:-.02em;
  background:var(--grad-tri);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;margin:0}
.error-title{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;color:var(--ink);
  font-size:clamp(22px,4.5vw,30px);letter-spacing:-.01em;margin:14px 0 10px}
.error-text{color:var(--muted);font-size:16px;line-height:1.6;margin:0 auto 26px;max-width:440px}
.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== Autocomplétion d'adresse (Base Adresse Nationale) ===== */
.ban-wrap{position:relative}
.ban-suggest{position:absolute;left:0;right:0;top:calc(100% + 5px);z-index:50;
  background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-soft);
  overflow:hidden;max-height:264px;overflow-y:auto}
.ban-item{display:block;width:100%;text-align:left;padding:10px 14px;border:0;
  border-bottom:1px solid var(--line);background:#fff;cursor:pointer;font:inherit;color:var(--ink)}
.ban-item:last-child{border-bottom:0}
.ban-item:hover,.ban-item.on{background:var(--accent-soft)}
.ban-label{display:block;font-size:14px}
.ban-ctx{display:block;font-size:12px;color:var(--muted);margin-top:1px}

/* ===== Logo Ôtenue (image) ===== */
.mark-logo{display:block;height:30px;width:auto}
.topbar .mark-logo{height:30px}
.lp-nav .mark-logo{height:32px}
.foot-brand .mark-logo{height:26px;margin-bottom:10px}
.app-head .mark-logo,.head .mark-logo{height:30px}
@media (max-width:520px){.mark-logo{height:26px}}

/* ===== Sélecteur mensuel / annuel + éléments de formule ===== */
.cycle-toggle{display:flex;width:max-content;margin:0 auto 28px;padding:4px;border:1px solid var(--line);
  border-radius:999px;background:#fff;gap:4px}
.cyc{font-family:'Newsreader',Georgia,serif;font-size:14px;color:var(--muted);padding:9px 18px;
  border-radius:999px;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.cyc.on{background:var(--ink);color:#fff}
.cyc-save{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--rose-soft);color:var(--rose-deep)}
.cyc.on .cyc-save{background:rgba(255,255,255,.2);color:#fff}
.plan-tagline{color:var(--muted);font-size:13.5px;line-height:1.45;margin:0 0 12px;min-height:36px}
.plan-price .price-amount{font-size:30px;font-weight:600;color:var(--ink)}
.plan-price .price-cycle{font-size:14px;color:var(--muted);font-weight:400}
.sub-freenote{text-align:center;color:var(--muted);font-size:13px;margin-top:14px}

/* ===== Pages légales ===== */
.legal{max-width:760px;margin:0 auto}
.legal h2{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;font-size:24px;margin:28px 0 10px}
.legal p,.legal li{line-height:1.7;color:#39353f}
.legal ul{padding-left:20px;margin:10px 0}
.legal li{margin-bottom:6px}
.legal a{color:var(--accent);text-decoration:underline}
.legal-links{text-align:center;margin:32px 0 8px;color:var(--muted);font-size:14px}
.legal-links a{color:var(--accent)}
.cookie-cta{margin:18px 0 6px}

/* ===== Consentement cookies ===== */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;max-width:920px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 16px 40px rgba(30,20,40,.18);
  padding:18px 20px;display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.cookie-banner-txt{flex:1;min-width:240px}
.cookie-banner-txt strong{font-family:'Cormorant Garamond',Georgia,serif;font-size:20px}
.cookie-banner-txt p{margin:4px 0 0;font-size:14px;color:var(--muted);line-height:1.5}
.cookie-banner-acts{display:flex;gap:8px;flex-wrap:wrap}
.cookie-overlay{position:fixed;inset:0;z-index:210;background:rgba(24,20,30,.5);
  display:flex;align-items:center;justify-content:center;padding:18px}
.cookie-card{background:#fff;border-radius:18px;max-width:520px;width:100%;padding:26px 26px 22px;
  max-height:88vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,.28)}
.cookie-title{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;font-size:26px;margin:0 0 6px}
.cookie-intro{color:var(--muted);font-size:14px;margin:0 0 16px}
.cookie-cat{border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:12px}
.cookie-cat-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.cookie-cat-name{font-weight:600}
.cookie-tag{font-size:12px;color:var(--rose-deep);background:var(--rose-soft);padding:3px 10px;border-radius:999px}
.cookie-cat-desc{font-size:13.5px;color:var(--muted);line-height:1.5;margin:6px 0 0}
.cookie-modal-acts{display:flex;gap:10px;justify-content:flex-end;margin-top:8px;flex-wrap:wrap}
.cookie-switch{position:relative;display:inline-block;width:44px;height:26px;flex:none}
.cookie-switch input{opacity:0;width:0;height:0}
.cookie-slider{position:absolute;inset:0;background:#d7d2cc;border-radius:999px;transition:.2s;cursor:pointer}
.cookie-slider::before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.cookie-switch input:checked + .cookie-slider{background:var(--accent)}
.cookie-switch input:checked + .cookie-slider::before{transform:translateX(18px)}
@media(max-width:560px){.cookie-banner-acts{width:100%}.cookie-banner-acts .btn{flex:1}}

.acc-row-wrap{flex-wrap:wrap;gap:10px}

/* ===== En-tête photo réutilisable (page contact, etc.) ===== */
.page-hero{position:relative;text-align:center;border-radius:24px;overflow:hidden;
  padding:clamp(40px,6vw,72px) clamp(20px,5vw,48px);margin-bottom:26px;
  background-image:radial-gradient(140% 120% at 50% 45%, rgba(251,248,244,.93), rgba(251,248,244,.72) 55%, rgba(251,248,244,.46) 100%),url("../img/hero-dressing.487a65768423.jpg");
  background-size:cover;background-position:center;
  box-shadow:inset 0 0 0 1px rgba(20,18,40,.06)}
.page-hero .page-title{margin:0}
.page-hero .page-title::after{left:50%;transform:translateX(-50%)}
.page-hero .page-sub{margin:12px auto 0;max-width:520px;color:#403c48}

/* ===== Navbar sombre — rappel du pied de page ===== */
.topbar{background:transparent;border-bottom:none;padding:14px clamp(16px,3vw,32px) 0}
.topbar-inner{background:var(--ink);border-radius:18px;padding:14px clamp(16px,3vw,26px);
  box-shadow:0 10px 30px rgba(20,18,40,.10)}
.topbar-link{color:rgba(255,255,255,.85)}
.topbar-link:hover{color:#fff}
.lp-nav{background:var(--ink);border-radius:18px;padding:14px clamp(16px,3vw,26px);
  box-shadow:0 10px 30px rgba(20,18,40,.10)}
.lp-login{color:rgba(255,255,255,.85)}
.lp-login:hover{color:#fff}
/* boutons adaptés au fond sombre */
.topbar-inner .btn.primary,.lp-nav .btn.primary{background:#fff;color:var(--ink)}
.topbar-inner .btn.primary:hover,.lp-nav .btn.primary:hover{background:rgba(255,255,255,.88);color:var(--ink)}
.topbar-inner .btn.ghost,.lp-nav .btn.ghost{background:transparent;border-color:rgba(255,255,255,.38);color:#fff}
.topbar-inner .btn.ghost:hover,.lp-nav .btn.ghost:hover{border-color:#fff;color:#fff}

/* ===== Navbars collantes (sticky) — restent visibles au défilement ===== */
.topbar{position:sticky;top:0;z-index:40;
  background:rgba(251,248,244,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  padding:10px clamp(16px,3vw,32px)}
.lp-nav{position:sticky;top:0;z-index:40}
.hd{position:relative;z-index:auto}

/* ===== Navbars unifiées : barre pleine largeur alignée au pied de page ===== */
.topbar,.lp-nav{position:sticky;top:0;z-index:40;display:block;
  background:var(--ink);border-bottom:none;border-radius:0 0 26px 26px;
  box-shadow:0 10px 28px rgba(20,18,40,.12);
  padding:0 clamp(16px,3vw,32px);margin:0;
  backdrop-filter:none;-webkit-backdrop-filter:none}
.topbar-inner,.lp-nav-inner{max-width:1040px;margin:0 auto;padding:14px 0;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  background:transparent;border-radius:0;box-shadow:none}
.topbar .mark-logo,.lp-nav .mark-logo{height:28px}

/* Réserve toujours la place de la barre de défilement : largeur identique sur toutes les pages */
html{scrollbar-gutter:stable}

/* ===== Menu hamburger (responsive) ===== */
.nav-toggle{display:none;background:transparent;border:0;padding:6px;margin:-6px -2px -6px 0;
  cursor:pointer;color:#fff;border-radius:8px;line-height:0}
.nav-toggle svg{width:26px;height:26px;display:block}
.nav-toggle .ic-close{display:none}
@media(max-width:640px){
  .nav-toggle{display:inline-flex;align-items:center}
  .topbar.open,.lp-nav.open{border-radius:0}
  .topbar.open .nav-toggle .ic-open,.lp-nav.open .nav-toggle .ic-open{display:none}
  .topbar.open .nav-toggle .ic-close,.lp-nav.open .nav-toggle .ic-close{display:block}
  .topbar-nav,.lp-links{display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:4px;
    background:var(--ink);padding:8px 16px 18px;border-radius:0 0 24px 24px;
    box-shadow:0 18px 34px rgba(20,18,40,.30);z-index:5}
  .topbar.open .topbar-nav,.lp-nav.open .lp-links{display:flex}
  .topbar-nav .topbar-link,.lp-links .lp-login{padding:12px 8px;border-radius:8px;font-size:15px}
  .topbar-nav .btn,.lp-links .btn{width:100%;justify-content:center;margin-top:2px}
  .topbar-nav .logout-form,.lp-links form{width:100%}
  .topbar-nav .logout-form .btn{width:100%}
}

/* ===== Titre de l'en-tête photo du vestiaire ===== */
.hd-title{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;
  font-size:clamp(23px,3.5vw,32px);line-height:1.05;margin:0 0 2px;color:var(--ink)}

/* ===== Adoucissement des surfaces sombres (navbar + pied de page) ===== */
:root{--dark:#2C2830;--dark-deep:#232029}
.site-foot{background:var(--dark)}
.topbar,.lp-nav{background:var(--dark)}
@media(max-width:640px){.topbar-nav,.lp-links{background:var(--dark)}}

/* ===== Page contact : même largeur que l'accueil (1040 px) ===== */
.contact-shell{max-width:1040px;padding:clamp(18px,3vw,32px)}

/* Carte de connexion/inscription : ombre renforcée pour flotter sur la photo */
.auth-body .auth-card{box-shadow:0 26px 60px rgba(30,20,40,.22)}

/* ===== Colonne contact enrichie ===== */
.contact-invite{font-size:14px;color:#4a4653;line-height:1.6;margin:18px 0 0;
  padding-top:16px;border-top:1px solid var(--line)}
.contact-links{margin-top:14px;display:flex;gap:16px;flex-wrap:wrap}
.contact-links a{font-size:13px;color:var(--accent);text-decoration:none}
.contact-links a:hover{text-decoration:underline}

/* ===== Message de plafond de suggestions ===== */
.limit-note{background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:22px 24px;color:var(--ink);font-size:15px;line-height:1.6;text-align:center}
.limit-note a{color:var(--accent);font-weight:600;text-decoration:none}
.limit-note a:hover{text-decoration:underline}

/* ===== Case d'acceptation (inscription) ===== */
.auth-check{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted);
  line-height:1.5;margin:4px 0 16px;cursor:pointer}
.auth-check input{margin-top:2px;flex:none;width:16px;height:16px;accent-color:var(--accent)}
.auth-check a{color:var(--accent);text-decoration:none}
.auth-check a:hover{text-decoration:underline}

/* ===== Bouton « Améliorer ma formule » (en-tête vestiaire) ===== */
.hd-upgrade{background:var(--grad-tri);color:#fff;border:0;padding:9px 16px;border-radius:10px;
  font-size:13px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;
  white-space:nowrap;box-shadow:0 6px 16px rgba(91,83,240,.22)}
.hd-upgrade:hover{filter:brightness(1.06);color:#fff}

/* ===== Abonnée déjà active : renvoi vers le portail ===== */
.already-sub{max-width:560px;margin:10px auto 0;text-align:center;background:var(--paper);
  border:1px solid var(--line);border-radius:18px;padding:24px}
.already-sub p{color:#4a4653;line-height:1.6;margin:0 0 16px}

/* « Améliorer ma formule » est placé à côté du titre (voir .brand) ; on le réduit un peu sur petit écran */
@media (max-width:480px){
  .hd-upgrade{padding:7px 12px;font-size:11.5px}
}
