/* ============================================================
   WOTO — feuille de style principale
   Extraite de la maquette HTML originale + adaptations Django.
   ============================================================ */
:root{
  --ink:#15211e;
  --ink-2:#2c3a35;
  --paper:#f6f1e8;
  --card:#fffdf8;
  --line:#e4dccb;
  --muted:#7a7565;
  --orange:#f25c0d;
  --orange-d:#d44b06;
  --green:#1f7a52;
  --green-soft:#e3f2ea;
  --gold:#d99b16;
  --shadow:0 1px 2px rgba(21,33,30,.04),0 8px 24px rgba(21,33,30,.06);
  --shadow-lg:0 12px 40px rgba(21,33,30,.14);
  --r:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{
  font-family:'Spline Sans',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;line-height:1.08;letter-spacing:-.02em}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:15px}
a{color:inherit;text-decoration:none;cursor:pointer}
:focus-visible{outline:2px solid var(--orange);outline-offset:2px;border-radius:6px}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* DEMO RIBBON */
.demo-bar{background:var(--ink);color:#cfe6da;font-size:12.5px;text-align:center;padding:7px 14px;letter-spacing:.02em}
.demo-bar b{color:#fff}

/* INFO TICKER */
.info-ticker{
  background:var(--orange);color:#fff;overflow:hidden;position:relative;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.info-ticker[hidden]{display:none!important}
.info-ticker .ticker-track{
  display:inline-flex;align-items:center;gap:64px;white-space:nowrap;
  padding:9px 0;font-size:13.5px;font-weight:600;letter-spacing:.01em;
  animation:tickerScroll 40s linear infinite;will-change:transform;
}
.info-ticker .ticker-track span{display:inline-flex;align-items:center;gap:10px}
.info-ticker .ticker-track .sep{opacity:.65;font-weight:400}
.info-ticker:hover .ticker-track{animation-play-state:paused}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){
  .info-ticker .ticker-track{animation:none;white-space:normal;padding:9px 16px;text-align:center;display:block}
}

/* HEADER */
header{position:sticky;top:0;z-index:50;background:rgba(246,241,232,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:20px;height:68px}
.logo{display:flex;align-items:center;gap:9px;font-family:'Bricolage Grotesque';font-weight:800;font-size:21px;letter-spacing:-.03em;background:none}
.logo .mark{width:34px;height:34px;border-radius:9px;background:var(--ink);display:grid;place-items:center;color:var(--orange);font-size:18px}
.logo b{color:var(--orange)}
.nav-search{flex:1;max-width:430px;display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:9px 14px}
.nav-search input{border:none;outline:none;background:none;width:100%;color:var(--ink)}
.nav-search svg{flex-shrink:0;opacity:.5}
.nav-actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.lnk{font-size:14.5px;font-weight:500;color:var(--ink-2);padding:8px 4px;background:none}
.lnk:hover{color:var(--orange)}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14.5px;padding:11px 18px;border-radius:11px;transition:.16s;white-space:nowrap}
.btn-pri{background:var(--orange);color:#fff;box-shadow:0 6px 16px rgba(242,92,13,.28)}
.btn-pri:hover{background:var(--orange-d);transform:translateY(-1px);color:#fff}
.btn-ghost{border:1px solid var(--line);background:var(--card);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink-2)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#0d1714;color:#fff}
.btn-block{width:100%;justify-content:center;padding:14px}
.burger{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--line);background:var(--card);align-items:center;justify-content:center;flex-shrink:0}
.burger svg{width:18px;height:18px}

/* MOBILE DRAWER */
.drawer{display:none;position:fixed;inset:0;background:rgba(21,33,30,.55);z-index:90;backdrop-filter:blur(3px)}
.drawer.on{display:block;animation:fade .2s ease}
.drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,340px);background:var(--paper);padding:22px;display:flex;flex-direction:column;gap:6px;animation:slidein .25s ease}
@keyframes slidein{from{transform:translateX(100%)}to{transform:none}}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.drawer-panel .lnk-d{display:block;font-size:16px;font-weight:600;padding:14px 6px;border-bottom:1px solid var(--line);text-align:left;width:100%;background:none;color:var(--ink)}
.drawer-panel .lnk-d:hover{color:var(--orange)}
.drawer-panel .nav-search{flex:none}

/* PAGE FADE */
.page-fade{animation:fade .4s ease both}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* HERO */
.hero{padding:54px 0 36px;position:relative;overflow:hidden}
.hero:before{content:"";position:absolute;right:-220px;top:-140px;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(242,92,13,.16),transparent 60%);pointer-events:none}
.hero:after{content:"";position:absolute;left:-180px;bottom:-160px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(31,122,82,.08),transparent 60%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;position:relative;z-index:1}
.hero-text{position:relative}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);padding:7px 13px;border-radius:99px;font-size:12.5px;font-weight:600;letter-spacing:.02em;margin-bottom:16px;box-shadow:var(--shadow)}
.hero-eyebrow .ping{position:relative;width:8px;height:8px;border-radius:50%;background:var(--green)}
.hero-eyebrow .ping:after{content:"";position:absolute;inset:-2px;border-radius:50%;background:var(--green);opacity:.4;animation:ping 1.8s ease-out infinite}
@keyframes ping{0%{transform:scale(1);opacity:.4}100%{transform:scale(2.2);opacity:0}}
.hero h1{font-size:clamp(36px,5.6vw,62px);max-width:14ch;line-height:1.04;letter-spacing:-.025em}
.hero h1 em{font-style:normal;background:linear-gradient(95deg,var(--orange) 0%,var(--gold) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;transition:opacity .28s ease, transform .28s ease;will-change:opacity,transform;min-width:3ch}
.hero h1 em.swap{opacity:0;transform:translateY(-6px)}
.hero p{margin-top:18px;font-size:17px;color:var(--muted);max-width:46ch;line-height:1.55}
.hero-ctas{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}
.hero-rating{display:flex;align-items:center;gap:10px;margin-top:14px;font-size:13px;color:var(--ink-2);flex-wrap:wrap}
.hero-rating .stars{color:var(--gold);font-size:14px;letter-spacing:1px;font-weight:700}
.hero-rating b{font-weight:700;color:var(--ink)}
.hero-rating .avatars{display:flex;margin-right:4px}
.hero-rating .avatars span{width:24px;height:24px;border-radius:50%;border:2px solid var(--paper);display:inline-grid;place-items:center;font-size:11px;font-weight:800;font-family:'Bricolage Grotesque';color:#fff;margin-left:-7px}
.hero-rating .avatars span:first-child{margin-left:0}
.hero-stats{display:flex;gap:32px;margin-top:30px;padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-stats div b{font-family:'Bricolage Grotesque';font-size:24px;font-weight:800;display:block;color:var(--ink);letter-spacing:-.01em}
.hero-stats div small{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;display:block;font-weight:600}

.hero-visual{position:relative;height:440px;perspective:1200px}
.hv-card{position:absolute;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);overflow:hidden}
.hv-card.main{width:78%;right:0;top:30px;z-index:3;transform:rotate(-2deg);transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.hv-card.main:hover{transform:rotate(-1deg) translateY(-4px)}
.hv-card.back{width:62%;left:0;top:0;z-index:1;transform:rotate(4deg);opacity:.92}
.hv-card.back2{width:48%;left:14%;bottom:18px;z-index:2;transform:rotate(-3deg)}
.hv-card .img{aspect-ratio:16/10;position:relative;overflow:hidden;background:var(--paper)}
.hv-card .img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hv-card .img .b{position:absolute;top:11px;left:11px;font-size:11px;font-weight:700;padding:5px 9px;border-radius:7px;text-transform:uppercase;letter-spacing:.04em}
.hv-card .img .b.feat{background:var(--gold);color:#3a2a00}
.hv-card .img .b.new{background:var(--ink);color:#fff}
.hv-card .body{padding:14px 16px}
.hv-card .pr{font-family:'Bricolage Grotesque';font-weight:800;font-size:20px}
.hv-card .nm{font-size:13.5px;font-weight:600;margin-top:2px;color:var(--ink)}
.hv-card .meta{font-size:11.5px;color:var(--muted);margin-top:5px;display:flex;gap:10px;flex-wrap:wrap}
.hv-card.back .body,.hv-card.back2 .body{display:none}
.hv-float{position:absolute;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:10px 14px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;z-index:4;font-size:13px;font-weight:600}
.hv-float.f1{top:14px;right:6%;animation:float 4s ease-in-out infinite}
.hv-float.f2{bottom:30px;left:-6px;animation:float 4.6s ease-in-out -1.2s infinite}
.hv-float .ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;color:#fff}
.hv-float.f1 .ic{background:#1faa53}
.hv-float.f2 .ic{background:var(--orange)}
.hv-float small{display:block;font-size:11px;color:var(--muted);font-weight:500;margin-top:-1px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

.trust{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;background:var(--card);border:1px solid var(--line);padding:8px 13px;border-radius:999px}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--green)}

/* CATEGORY TABS */
.cat-tabs{display:flex;gap:6px;margin:24px 0 14px;padding:4px;background:var(--card);border:1px solid var(--line);border-radius:13px;width:fit-content;max-width:100%;overflow-x:auto;flex-wrap:nowrap}
.cat-tab{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:9px;font-size:14px;font-weight:600;color:var(--ink-2);background:none;cursor:pointer;white-space:nowrap;border:none;transition:.16s}
.cat-tab:hover{color:var(--ink);background:var(--paper)}
.cat-tab.act{background:var(--ink);color:#fff;box-shadow:0 4px 12px rgba(21,33,30,.18)}
.cat-tab .ic{font-size:16px}

/* SEARCH PANEL */
.filters{margin-top:30px;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow)}
.filters .row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px;letter-spacing:.02em;text-transform:uppercase}
.field select,.field input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:var(--paper);outline:none;color:var(--ink)}
.field select:focus,.field input:focus{border-color:var(--orange)}
.filters .go{margin-top:14px;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}

/* SECTION */
.sec{padding:38px 0}
.sec-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:20px;gap:16px}
.sec-head h2{font-size:27px}
.sec-head p{color:var(--muted);font-size:14px;margin-top:5px}
.sec-head .seeall{font-size:14px;font-weight:600;color:var(--orange);background:none}

/* GRID + CARDS */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:.18s;display:flex;flex-direction:column;text-align:left;width:100%;text-decoration:none;color:inherit}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#d8cfb8;color:inherit}
.ph{aspect-ratio:4/3;position:relative;display:grid;place-items:center;overflow:hidden;background:linear-gradient(135deg,#f25c0d14,#c2390226)}
.ph svg{width:62%;opacity:.9}
.ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;background:var(--paper)}
.ph .badge{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;letter-spacing:.04em;padding:5px 9px;border-radius:7px;text-transform:uppercase;z-index:2}
.b-feat{background:var(--gold);color:#3a2a00}
.b-new{background:var(--ink);color:#fff}
.ph .fav{position:absolute;top:9px;right:9px;width:32px;height:32px;border-radius:9px;background:rgba(255,255,255,.85);display:grid;place-items:center;font-size:15px;border:none;cursor:pointer;transition:.16s;z-index:2}
.ph .fav:hover{background:#fff;transform:scale(1.08)}
.ph .fav.on{color:var(--orange);background:#fff}
.card-b{padding:13px 14px 15px}
.card-b .price{font-family:'Bricolage Grotesque';font-weight:800;font-size:19px}
.card-b .price small{font-weight:600;font-size:12px;color:var(--muted)}
.card-b h3{font-size:15.5px;margin:4px 0 2px;font-family:'Spline Sans';font-weight:600;letter-spacing:0}
.meta{display:flex;flex-wrap:wrap;gap:5px 12px;margin-top:9px;font-size:12.5px;color:var(--muted)}
.meta span{display:inline-flex;align-items:center;gap:5px}
.card-loc{display:flex;align-items:center;justify-content:space-between;margin-top:11px;padding-top:11px;border-top:1px dashed var(--line);font-size:12.5px;color:var(--muted)}
.verif{display:inline-flex;align-items:center;gap:5px;color:var(--green);font-weight:600;font-size:12px}
.empty-state{grid-column:1/-1;text-align:center;padding:50px 20px;background:var(--card);border:1px dashed var(--line);border-radius:var(--r);color:var(--muted)}
.empty-state b{display:block;font-size:18px;font-family:'Bricolage Grotesque';color:var(--ink);margin-bottom:6px}

/* HOW */
.how{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.step .n{width:36px;height:36px;border-radius:10px;background:var(--ink);color:var(--orange);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;margin-bottom:14px}
.step h3{font-size:18px;margin-bottom:7px}
.step p{font-size:14px;color:var(--muted)}

/* DETAIL */
.crumb{font-size:13px;color:var(--muted);padding:22px 0 0}
.crumb a{color:var(--orange);font-weight:600}
.detail{display:grid;grid-template-columns:1.7fr 1fr;gap:30px;padding:18px 0 50px;align-items:start}
.gallery .main{aspect-ratio:16/10;border-radius:16px;display:grid;place-items:center;border:1px solid var(--line);overflow:hidden;position:relative;background:linear-gradient(135deg,#f25c0d1f,#c2390233)}
.gallery .main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;background:var(--paper)}
.thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px}
.thumbs button{aspect-ratio:4/3;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;cursor:pointer;padding:0;background:var(--paper);overflow:hidden;position:relative}
.thumbs button img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.thumbs button.act{outline:2px solid var(--orange);outline-offset:1px}
.spec-title{font-size:30px;margin-top:24px}
.spec-price{font-family:'Bricolage Grotesque';font-weight:800;font-size:34px;color:var(--orange);margin:8px 0 4px}
.spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0}
.spec-grid .it{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:13px 14px}
.spec-grid .it small{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.spec-grid .it b{display:block;font-size:16px;margin-top:3px;font-family:'Bricolage Grotesque';font-weight:700}
.desc{font-size:15px;color:var(--ink-2);line-height:1.7}
.desc h4{font-family:'Bricolage Grotesque';font-size:18px;margin:24px 0 8px}

.seller{position:sticky;top:88px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow)}
.seller .who{display:flex;align-items:center;gap:13px}
.seller .av{width:50px;height:50px;border-radius:12px;background:var(--ink);color:var(--orange);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:18px}
.seller .who b{font-size:16px}
.seller .who span{font-size:13px;color:var(--muted)}
.seller .stat{display:flex;gap:18px;margin:18px 0;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.seller .stat div b{font-family:'Bricolage Grotesque';font-size:18px;display:block}
.seller .stat div small{font-size:12px;color:var(--muted)}
.wa{background:#1faa53;color:#fff}
.wa:hover{background:#178f44;color:#fff}
.safe-box{margin-top:16px;background:var(--green-soft);border:1px solid #c7e4d4;border-radius:11px;padding:13px;font-size:12.5px;color:#1a5e3e}
.safe-box b{display:block;margin-bottom:4px}

/* DOCS ZONE */
.doc-zone{margin-top:18px;background:#fdf4ea;border:1px dashed #e4c79a;border-radius:13px;padding:18px}
.doc-zone .doc-title{display:flex;align-items:center;gap:9px;font-weight:700;font-size:15px;color:#7a4a06;margin-bottom:4px;flex-wrap:wrap}
.doc-zone .doc-title .badge-priv{background:#fff;color:#7a4a06;font-size:10.5px;font-weight:800;padding:3px 7px;border-radius:6px;letter-spacing:.04em;border:1px solid #e4c79a}
.doc-zone .doc-sub{color:#7a5a30;font-size:13px;line-height:1.5;margin-bottom:14px}
.doc-uploaders{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.doc-up{background:var(--card);border:1.5px solid var(--line);border-radius:11px;padding:14px;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:5px;transition:.14s}
.doc-up:hover{border-color:var(--orange);background:#fffaf2}
.doc-up.has{border-color:var(--green);background:var(--green-soft)}
.doc-up .lbl{font-weight:700;font-size:14px;color:var(--ink)}
.doc-up small{font-size:12px;color:var(--muted)}
.doc-up.has small{color:var(--green);font-weight:600}
.doc-up .ic{font-size:18px}
@media(max-width:640px){.doc-uploaders{grid-template-columns:1fr}}

/* BADGES */
.badge-verif{background:#1f7a52;color:#fff;display:inline-flex;align-items:center;gap:4px;padding:5px 9px;border-radius:7px;font-size:11px;font-weight:700;letter-spacing:.03em;text-transform:uppercase}
.badge-verif svg{width:11px;height:11px}
.badge-verif.pending{background:var(--gold);color:#3a2a00}

/* DEPOSIT FLOW */
.dep-cat{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.dep-cat-btn{background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:14px 10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;font-size:14.5px;color:var(--ink);transition:.14s;text-align:center}
.dep-cat-btn:hover{border-color:#c9bfa6}
.dep-cat-btn.act{border-color:var(--orange);background:#fdf4ea;box-shadow:0 4px 14px rgba(242,92,13,.16)}
.dep-cat-btn .ic{font-size:22px}
.dep-cat-btn b{font-weight:600}
@media(max-width:560px){.dep-cat-btn{padding:11px 6px;font-size:13px}.dep-cat-btn .ic{font-size:18px}}
.deposit{max-width:760px;margin:0 auto;padding:34px 0 60px}
.steps-bar{display:flex;gap:8px;margin-bottom:30px}
.steps-bar .s{flex:1;text-align:center}
.steps-bar .s .line{height:5px;border-radius:99px;background:var(--line);margin-bottom:9px}
.steps-bar .s.done .line,.steps-bar .s.cur .line{background:var(--orange)}
.steps-bar .s small{font-size:12px;font-weight:600;color:var(--muted)}
.steps-bar .s.cur small{color:var(--orange)}
.panel{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow)}
.panel h2{font-size:24px}
.panel .sub{color:var(--muted);font-size:14px;margin:6px 0 24px}
.frm{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.frm .full{grid-column:1/-1}
.frm label{display:block;font-size:13px;font-weight:600;margin-bottom:7px}
.frm input,.frm select,.frm textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:10px;background:var(--paper);outline:none;color:var(--ink)}
.frm input:focus,.frm select:focus,.frm textarea:focus{border-color:var(--orange)}
.frm input.err,.frm select.err,.frm textarea.err{border-color:#b5121b;background:#fbe9ea}
.frm textarea{min-height:96px;resize:vertical}
.nav-btns{display:flex;justify-content:space-between;margin-top:26px;gap:10px;flex-wrap:wrap}

.dropz{border:2px dashed var(--line);border-radius:14px;padding:34px;text-align:center;background:var(--paper);cursor:pointer;transition:.16s;width:100%;display:block}
.dropz:hover{border-color:var(--orange);background:#fbf6ec}
.dropz .ic{font-size:34px}
.dropz b{display:block;margin-top:8px;font-size:15px}
.dropz small{color:var(--muted);font-size:13px}
.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-top:18px}
.photo-grid .pp{aspect-ratio:4/3;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;position:relative;background:var(--paper);overflow:hidden}
.photo-grid .pp img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.photo-grid .pp .x{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:6px;background:rgba(21,33,30,.7);color:#fff;display:grid;place-items:center;font-size:13px;border:none;cursor:pointer;z-index:2}
.photo-grid .pp.cover:after{content:"Couverture";position:absolute;bottom:5px;left:5px;font-size:10px;font-weight:700;background:var(--orange);color:#fff;padding:3px 6px;border-radius:5px;z-index:2}

/* PLANS */
.plans{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.plan{border:2px solid var(--line);border-radius:16px;padding:24px;cursor:pointer;transition:.16s;position:relative;background:var(--paper);text-align:left;width:100%;display:block}
.plan:hover{border-color:#c9bfa6}
.plan.sel{border-color:var(--orange);background:#fdf4ea}
.plan .tag{position:absolute;top:-12px;right:18px;background:var(--gold);color:#3a2a00;font-size:11px;font-weight:800;padding:5px 10px;border-radius:7px;letter-spacing:.03em}
.plan h3{font-size:20px}
.plan .pp{font-family:'Bricolage Grotesque';font-weight:800;font-size:30px;margin:10px 0 3px}
.plan .pp small{font-size:13px;color:var(--muted);font-weight:600}
.plan ul{list-style:none;margin-top:16px;display:grid;gap:9px}
.plan li{font-size:13.5px;color:var(--ink-2);display:flex;gap:9px}
.plan li .ck{color:var(--green);font-weight:800}

/* PAY */
.pay-box{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:6px 0 22px}
.pmethod{border:2px solid var(--line);border-radius:13px;padding:18px;cursor:pointer;display:flex;align-items:center;gap:13px;transition:.16s;background:var(--paper);text-align:left;width:100%}
.pmethod.sel{border-color:var(--orange);background:#fdf4ea}
.pmethod .om{width:42px;height:42px;border-radius:10px;background:#ff7900;color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;font-family:'Bricolage Grotesque'}
.pmethod .mt{width:42px;height:42px;border-radius:10px;background:#ffcb05;color:#0a0a0a;display:grid;place-items:center;font-weight:800;font-size:12px;font-family:'Bricolage Grotesque'}
.pmethod b{font-size:15px}
.pmethod small{display:block;font-size:12px;color:var(--muted)}
.recap{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:18px;margin-bottom:20px}
.recap .ln{display:flex;justify-content:space-between;font-size:14px;padding:6px 0}
.recap .ln.tot{border-top:1px solid var(--line);margin-top:6px;padding-top:12px;font-family:'Bricolage Grotesque';font-weight:800;font-size:19px}
.pay-note{font-size:12.5px;color:var(--muted);text-align:center;margin-top:14px}
.success{text-align:center;padding:30px 10px}
.success .ok{width:74px;height:74px;border-radius:50%;background:var(--green-soft);color:var(--green);display:grid;place-items:center;font-size:36px;margin:0 auto 18px}
.success h2{font-size:26px}
.success p{color:var(--muted);margin:10px 0 24px;font-size:15px}

/* DASHBOARD */
.dash{padding:34px 0 60px}
.dash-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.dash-head h2{font-size:28px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:26px}
.stat-c{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px}
.stat-c b{font-family:'Bricolage Grotesque';font-size:26px;display:block}
.stat-c small{font-size:13px;color:var(--muted)}
.ann-row{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:13px;padding:14px;margin-bottom:12px}
.ann-row .thmb{width:96px;height:72px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;border:1px solid var(--line);position:relative;overflow:hidden}
.ann-row .thmb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.ann-row .inf{flex:1;min-width:0}
.ann-row .inf b,
.ann-row .inf .pr,
.ann-row .inf .vw{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:100%}
.ann-row .inf b{font-size:clamp(12.5px, 2.4vw, 15.5px)}
.ann-row .inf .pr{color:var(--orange);font-weight:700;font-size:clamp(11.5px, 2.1vw, 14px);margin-top:2px}
.ann-row .inf .vw{font-size:clamp(10.5px, 1.9vw, 12.5px);color:var(--muted);margin-top:4px}
.st{font-size:12px;font-weight:700;padding:6px 11px;border-radius:8px;white-space:nowrap}
.st-act{background:var(--green-soft);color:var(--green)}
.st-wait{background:#fdeccf;color:#92610a}
.st-exp{background:#f0e7d4;color:var(--muted)}
.ann-row .act-btn{font-size:13px;font-weight:600;color:var(--orange);padding:8px 12px;border:1px solid var(--line);border-radius:9px;background:var(--paper);cursor:pointer}

/* EDIT AD */
.edit-page{padding:30px 0 60px;max-width:820px;margin:0 auto}
.edit-head{margin-bottom:22px}
.edit-head .back-link{font-size:13px;color:var(--orange);font-weight:600;background:none;padding:0;margin-bottom:10px;display:inline-flex;align-items:center;gap:5px}
.edit-head h2{font-size:26px}
.edit-head p{color:var(--muted);font-size:14px;margin-top:4px}
.expire-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin:18px 0;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.expire-card .info{display:flex;align-items:center;gap:14px}
.expire-card .ring{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--orange) var(--p,75%),var(--line) 0);position:relative;flex-shrink:0}
.expire-card .ring:after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--card)}
.expire-card .ring b{position:relative;z-index:1;font-family:'Bricolage Grotesque';font-weight:800;font-size:16px}
.expire-card.warn .ring{--p:25%}
.expire-card.warn .ring b{color:#b5121b}
.expire-card .lbl b{display:block;font-size:16px;font-family:'Bricolage Grotesque';font-weight:700}
.expire-card .lbl small{display:block;font-size:12.5px;color:var(--muted);margin-top:2px}
.expire-card .btn{flex-shrink:0}
.edit-section{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:16px}
.edit-section h3{font-size:17px;margin-bottom:6px}
.edit-section .sub{color:var(--muted);font-size:13px;margin-bottom:14px}
.edit-photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.edit-photo-grid .pp{aspect-ratio:4/3;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;position:relative;background:var(--paper);overflow:hidden}
.edit-photo-grid .pp img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.edit-photo-grid .pp .x{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:7px;background:rgba(21,33,30,.78);color:#fff;display:grid;place-items:center;font-size:14px;border:none;cursor:pointer;z-index:2}
.edit-photo-grid .pp .x:hover{background:#b5121b}
.edit-photo-grid .pp.cover:after{content:"Couverture";position:absolute;bottom:5px;left:5px;font-size:10px;font-weight:700;background:var(--orange);color:#fff;padding:3px 6px;border-radius:5px;z-index:2}
.edit-photo-grid .add-pp{aspect-ratio:4/3;border:2px dashed var(--line);border-radius:10px;background:none;display:grid;place-items:center;cursor:pointer;color:var(--muted)}
.edit-photo-grid .add-pp:hover{border-color:var(--orange);color:var(--orange);background:#fbf6ec}
.edit-photo-grid .add-pp .ic{font-size:22px;display:block}
.edit-photo-grid .add-pp small{font-size:11.5px;font-weight:600;display:block;margin-top:3px}
.edit-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.edit-form .full{grid-column:1/-1}
.edit-form label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ink-2)}
.edit-form input,.edit-form select,.edit-form textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:var(--paper);outline:none;font-size:14.5px;color:var(--ink)}
.edit-form input:focus,.edit-form select:focus,.edit-form textarea:focus{border-color:var(--orange)}
.edit-form textarea{min-height:120px;resize:vertical}
.edit-actions{display:flex;justify-content:space-between;gap:10px;margin-top:18px;flex-wrap:wrap}
.edit-actions .right{display:flex;gap:10px}
@media(max-width:680px){
  .edit-photo-grid{grid-template-columns:repeat(3,1fr)}
  .edit-form{grid-template-columns:1fr}
}
@media(max-width:480px){.edit-photo-grid{grid-template-columns:repeat(2,1fr)}}

/* ADMIN */
.admin-page{padding:30px 0 60px}
.admin-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:18px}
.admin-head h2{font-size:26px}
.admin-head p{color:var(--muted);font-size:14px;margin-top:4px}
.admin-head .pill{display:inline-flex;gap:6px;align-items:center;background:#fdeccf;color:#92610a;padding:4px 11px;border-radius:99px;font-size:12px;font-weight:700;letter-spacing:.02em}
.admin-tabs{display:flex;gap:8px;margin-bottom:18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.admin-tabs a, .admin-tabs button{padding:11px 16px;font-size:14px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;background:none;margin-bottom:-1px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.admin-tabs a.act, .admin-tabs button.act{color:var(--ink);border-bottom-color:var(--orange)}
.admin-tabs a:hover, .admin-tabs button:hover{color:var(--ink)}
.adm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.adm-stats .stat-c{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px}
.adm-stats b{font-family:'Bricolage Grotesque';font-size:26px;display:block}
.adm-stats small{font-size:13px;color:var(--muted)}
.adm-table{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.adm-search{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.adm-search input,.adm-search select{padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:var(--paper);outline:none;font-size:13.5px}
.adm-search input{flex:1;min-width:180px}
.adm-list{max-height:62vh;overflow-y:auto}
.adm-row{display:grid;grid-template-columns:42px 1.4fr 1.5fr 1fr .9fr 110px 90px;gap:14px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line);font-size:13.5px}
.adm-row:last-child{border-bottom:none}
.adm-row .av-sm{width:36px;height:36px;border-radius:10px;background:var(--ink);color:var(--orange);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:14px}
.adm-row b{font-size:14px;display:block}
.adm-row small{color:var(--muted);font-size:12px;display:block;margin-top:2px}
.adm-row .pill-role{padding:3px 8px;border-radius:7px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;display:inline-block}
.pill-role.admin{background:#fdeccf;color:#92610a}
.pill-role.user{background:var(--green-soft);color:var(--green)}
.pill-status{padding:3px 8px;border-radius:7px;font-size:11px;font-weight:700;display:inline-block}
.pill-status.active{background:var(--green-soft);color:var(--green)}
.pill-status.suspended{background:#fbe9ea;color:#b5121b}
.adm-row .actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.adm-row .actions button, .adm-row .actions a{padding:7px 10px;border-radius:8px;font-size:12px;font-weight:600;border:1px solid var(--line);background:var(--paper);cursor:pointer;color:var(--ink);text-decoration:none;display:inline-block}
.adm-row .actions button:hover, .adm-row .actions a:hover{border-color:var(--ink-2)}
.adm-row .actions button.del{color:#b5121b;border-color:#f0c8cc}
.adm-row .actions button.del:hover{background:#fbe9ea}
.adm-empty{padding:40px 20px;text-align:center;color:var(--muted)}
.adm-row-h{background:var(--paper);font-weight:700;font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

.rep-row{display:grid;grid-template-columns:60px 1.5fr 1.4fr 1.2fr 100px 200px;gap:14px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line);font-size:13.5px}
.rep-row:last-child{border-bottom:none}
.rep-row .av-sm{width:46px;height:46px;border-radius:9px;background:var(--paper);display:grid;place-items:center;position:relative;overflow:hidden;border:1px solid var(--line)}
.rep-row .av-sm img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.rep-row b{font-size:14px;display:block}
.rep-row small{color:var(--muted);font-size:12px;display:block;margin-top:2px}
.rep-row .reason{font-weight:600;color:#92610a;background:#fdeccf;padding:3px 8px;border-radius:7px;font-size:11.5px;display:inline-block;letter-spacing:.02em}
.rep-row .reason.fraud,.rep-row .reason.stolen{color:#b5121b;background:#fbe9ea}
.rep-row .actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.rep-row .actions button, .rep-row .actions a{padding:7px 10px;border-radius:8px;font-size:12px;font-weight:600;border:1px solid var(--line);background:var(--paper);cursor:pointer;color:var(--ink);text-decoration:none;display:inline-block}
.rep-row .actions button.ok{color:var(--green);border-color:#c7e4d4}
.rep-row .actions button.ok:hover{background:var(--green-soft)}
.rep-row .actions button.dismiss{color:var(--muted)}
.rep-row .actions button.del{color:#b5121b;border-color:#f0c8cc}
.rep-row .actions button.del:hover{background:#fbe9ea}
.pill-rep-status{padding:3px 8px;border-radius:7px;font-size:11px;font-weight:700;display:inline-block}
.pill-rep-status.pending{background:#fdeccf;color:#92610a}
.pill-rep-status.resolved{background:var(--green-soft);color:var(--green)}
.pill-rep-status.dismissed{background:#f0e7d4;color:var(--muted)}
.admin-tabs .tab-badge{display:inline-block;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--orange);color:#fff;font-size:10.5px;font-weight:800;line-height:18px;text-align:center}
@media(max-width:980px){
  .rep-row{grid-template-columns:46px 1fr 100px;font-size:13px}
  .rep-row .col-reporter,.rep-row .col-reason{display:none}
  .rep-row .actions{grid-column:1/-1}
}

.adm-pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.price-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:var(--shadow)}
.price-card h4{font-size:18px;display:flex;justify-content:space-between;align-items:baseline}
.price-card h4 .lvl{font-size:11px;background:var(--paper);color:var(--muted);padding:3px 8px;border-radius:6px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.price-card .sub{color:var(--muted);font-size:13px;margin:5px 0 16px}
.price-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:12px}
.price-grid label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.02em;display:block;margin-bottom:5px}
.price-grid input,.price-grid select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:9px;background:var(--paper);outline:none;font-size:14px}
.price-grid input:focus,.price-grid select:focus{border-color:var(--orange)}
.adm-save-bar{margin-top:18px;padding:16px;background:var(--card);border:1px solid var(--line);border-radius:13px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.adm-save-bar .info{font-size:13px;color:var(--muted)}
@media(max-width:980px){
  .adm-stats{grid-template-columns:1fr 1fr}
  .adm-row{grid-template-columns:42px 1fr 100px;font-size:13px}
  .adm-row .col-phone,.adm-row .col-city,.adm-row .col-role{display:none}
  .adm-row .actions{grid-column:1/-1}
  .adm-row-h{display:none}
  .adm-pricing-grid{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr 1fr}
}

/* PROFILE */
.profile-page{padding:30px 0 60px}
.profile-head{display:flex;align-items:center;gap:18px;margin-bottom:24px;flex-wrap:wrap}
.profile-head .av-big{width:78px;height:78px;border-radius:18px;background:var(--ink);color:var(--orange);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:30px;flex-shrink:0}
.profile-head .who h2{font-size:26px}
.profile-head .who p{color:var(--muted);font-size:14px;margin-top:3px}
.profile-head .verif{margin-top:6px;display:inline-flex;align-items:center;gap:6px;background:var(--green-soft);color:var(--green);padding:4px 10px;border-radius:99px;font-size:12px;font-weight:700}
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.prof-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow)}
.prof-card.full{grid-column:1/-1}
.prof-card h3{font-size:18px;margin-bottom:4px}
.prof-card .sub{color:var(--muted);font-size:13.5px;margin-bottom:16px}
.prof-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.prof-form .full{grid-column:1/-1}
.prof-form label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ink-2)}
.prof-form input,.prof-form select,.prof-form textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:var(--paper);outline:none;font-size:14.5px;color:var(--ink)}
.prof-form input:focus,.prof-form select:focus,.prof-form textarea:focus{border-color:var(--orange)}
.prof-form input[readonly]{background:#f0e8d6;color:var(--muted);cursor:not-allowed}
.prof-form textarea{min-height:70px;resize:vertical}
.prof-actions{margin-top:16px;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.pref-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--line);gap:14px}
.pref-row:last-child{border-bottom:none}
.pref-row .info{flex:1;min-width:0}
.pref-row .info b{font-size:14.5px;display:block}
.pref-row .info small{color:var(--muted);font-size:12.5px;display:block;margin-top:2px}
.switch{position:relative;width:44px;height:24px;flex-shrink:0;cursor:pointer;display:inline-block}
.switch input{position:absolute;opacity:0;pointer-events:none}
.switch .slider{position:absolute;inset:0;background:var(--line);border-radius:99px;transition:.16s}
.switch .slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.16s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.switch input:checked + .slider{background:var(--orange)}
.switch input:checked + .slider:before{transform:translateX(20px)}
.danger-zone{border-color:#f0c8cc;background:#fdf3f3}
.danger-zone h3{color:#9b1119}
.danger-zone p{font-size:13.5px;color:#5e1015}
.btn-danger{background:#b5121b;color:#fff}
.btn-danger:hover{background:#8c0d14;color:#fff}
@media(max-width:780px){.profile-grid{grid-template-columns:1fr}.prof-form{grid-template-columns:1fr}}

/* MESSAGES */
.msg-page{padding:30px 0 60px}
.msg-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}
.msg-head h2{font-size:26px}
.msg-head p{color:var(--muted);font-size:14px;margin-top:5px}
.msg-layout{display:grid;grid-template-columns:340px 1fr;gap:0;background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;min-height:560px}
.conv-list{border-right:1px solid var(--line);overflow-y:auto;max-height:70vh}
.conv-item{display:flex;gap:11px;padding:13px 14px;border-bottom:1px solid var(--line);cursor:pointer;background:none;width:100%;text-align:left;align-items:flex-start;transition:.12s;text-decoration:none;color:inherit;border:0;border-bottom:1px solid var(--line)}
.conv-item:hover{background:var(--paper);color:inherit}
.conv-item.act{background:#fdf4ea;border-left:3px solid var(--orange);padding-left:11px}
.conv-item .av{width:42px;height:42px;border-radius:11px;background:var(--ink);color:var(--orange);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:16px;flex-shrink:0}
.conv-item .body{flex:1;min-width:0}
.conv-item .row1{display:flex;justify-content:space-between;gap:8px;align-items:baseline}
.conv-item .row1 b{font-size:14.5px;font-weight:600}
.conv-item .row1 time{font-size:11.5px;color:var(--muted);flex-shrink:0;white-space:nowrap}
.conv-item .preview{font-size:12.5px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.conv-item .ctx{font-size:11.5px;color:var(--orange);font-weight:600;margin-top:3px;display:flex;align-items:center;gap:5px}
.conv-item .unread{display:inline-block;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--orange);color:#fff;font-size:11px;font-weight:800;line-height:18px;text-align:center;margin-left:6px}
.conv-empty{padding:40px 20px;text-align:center;color:var(--muted);font-size:14px}
.thread{display:flex;flex-direction:column;min-height:560px}
.thread-head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.thread-head .av{width:42px;height:42px;border-radius:11px;background:var(--ink);color:var(--orange);display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:16px}
.thread-head .info b{font-size:15px}
.thread-head .info small{font-size:12px;color:var(--muted);display:block}
.thread-head .back{display:none;width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:none;align-items:center;justify-content:center;color:var(--ink);text-decoration:none}
.thread-head .back svg{width:16px;height:16px}
.thread-body{flex:1;padding:18px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;max-height:60vh;background:var(--paper)}
.bubble{max-width:75%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.45;word-wrap:break-word}
.bubble.them{background:var(--card);border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.bubble.me{background:var(--orange);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.bubble time{display:block;font-size:10.5px;opacity:.7;margin-top:3px}
.day-sep{align-self:center;font-size:11.5px;color:var(--muted);background:var(--card);padding:4px 10px;border-radius:99px;margin:8px 0;border:1px solid var(--line)}
.thread-input{padding:12px;border-top:1px solid var(--line);display:flex;gap:8px;background:var(--card)}
.thread-input input{flex:1;padding:11px 13px;border:1px solid var(--line);border-radius:11px;background:var(--paper);outline:none;font-size:14px}
.thread-input input:focus{border-color:var(--orange)}
.thread-input button{padding:0 16px;border-radius:11px;background:var(--orange);color:#fff;font-weight:600;font-size:14px;border:none;cursor:pointer}
.thread-input button:hover{background:var(--orange-d)}
.thread-empty{flex:1;display:grid;place-items:center;color:var(--muted);font-size:14px;padding:20px;text-align:center}

.bell{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:6px}
.bell .dot-badge{position:absolute;top:0;right:0;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--orange);color:#fff;font-size:10px;font-weight:800;line-height:16px;text-align:center}
.bell .dot-badge[hidden]{display:none}

@media(max-width:780px){
  .msg-layout{grid-template-columns:1fr;min-height:auto}
  .conv-list{max-height:none;border-right:none;border-bottom:1px solid var(--line)}
  .msg-layout.thread-on .conv-list{display:none}
  .msg-layout:not(.thread-on) .thread{display:none}
  .thread-head .back{display:inline-flex}
  .thread-body{max-height:62vh}
}

/* STATIC PAGES */
.static{max-width:820px;margin:0 auto;padding:40px 0 60px}
.static h1{font-size:clamp(28px,4vw,42px);margin-bottom:12px}
.static .lead{font-size:17px;color:var(--muted);margin-bottom:30px;max-width:60ch}
.static h2{font-size:22px;margin:32px 0 12px}
.static p,.static li{font-size:15px;line-height:1.7;color:var(--ink-2)}
.static ul,.static ol{margin:8px 0 14px 22px}
.static li{margin-bottom:8px}
.static .pcard{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;margin:14px 0}
.static .pcard h3{font-size:17px;font-family:'Spline Sans';font-weight:700;margin-bottom:6px}
.static .pcard p{font-size:14px;color:var(--muted);margin:0}
.static .pcard.ok{border-left:4px solid var(--green)}
.static .pcard.warn{border-left:4px solid var(--orange)}
.static .pcard.danger{border-left:4px solid #b5121b}

/* CONTACT FORM */
.ctc-form{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px;margin-top:18px}
.ctc-form label{display:block;font-size:13px;font-weight:600;margin:14px 0 7px}
.ctc-form label:first-of-type{margin-top:0}
.ctc-form input,.ctc-form select,.ctc-form textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:10px;background:var(--paper);outline:none;color:var(--ink)}
.ctc-form input:focus,.ctc-form select:focus,.ctc-form textarea:focus{border-color:var(--orange)}
.ctc-form textarea{min-height:120px;resize:vertical}

/* PRO PRICING */
.pro-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.pro-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px}
.pro-card h3{font-size:20px}
.pro-card .pp{font-family:'Bricolage Grotesque';font-weight:800;font-size:28px;color:var(--orange);margin:10px 0 4px}
.pro-card ul{list-style:none;margin-top:14px}
.pro-card li{font-size:14px;margin-bottom:8px;display:flex;gap:8px;color:var(--ink-2)}
.pro-card li:before{content:"✓";color:var(--green);font-weight:800}

/* MODAL */
.ov{display:none;position:fixed;inset:0;background:rgba(21,33,30,.55);z-index:100;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px)}
.ov.on{display:flex}
.modal{background:var(--card);border-radius:18px;max-width:440px;width:100%;padding:30px;animation:pop .25s ease;position:relative;max-height:92vh;overflow-y:auto}
@keyframes pop{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:none}}
.modal h3{font-size:23px}
.modal p{color:var(--muted);font-size:14px;margin:7px 0 22px}
.modal label{display:block;font-size:13px;font-weight:600;margin:14px 0 7px}
.modal input[type=text],.modal input[type=password],.modal input[type=email],.modal select,.modal textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:10px;background:var(--paper);outline:none;font-size:15px;color:var(--ink);font-family:inherit}
.modal textarea{min-height:90px;resize:vertical}
.modal input:focus,.modal select:focus,.modal textarea:focus{border-color:var(--orange)}
.modal input.err{border-color:#b5121b;background:#fbe9ea}
.modal .alt{text-align:center;font-size:13px;color:var(--muted);margin-top:16px}
.modal .alt a{color:var(--orange);font-weight:600;cursor:pointer}
.auth-err{color:#b5121b;font-size:12.5px;margin-top:6px;font-weight:500}
.pass-wrap{position:relative}
.pass-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:8px;background:transparent;font-size:16px;color:var(--muted);cursor:pointer;display:grid;place-items:center}
.pass-toggle:hover{background:var(--paper);color:var(--ink)}
.auth-row{display:flex;justify-content:space-between;align-items:center;margin-top:14px;font-size:13px;gap:10px;flex-wrap:wrap}
.auth-row .check{display:flex;align-items:center;gap:7px;color:var(--ink-2);cursor:pointer;font-weight:500}
.auth-row .check input{width:16px;height:16px;accent-color:var(--orange)}
.auth-row a{color:var(--orange);font-weight:600;cursor:pointer}
.auth-demo-hint{margin-top:14px;padding:10px 12px;background:var(--green-soft);border:1px solid #c7e4d4;border-radius:9px;font-size:12px;color:#1a5e3e;text-align:center}
.auth-demo-hint code{font-family:ui-monospace,monospace;background:rgba(31,122,82,.12);padding:1px 5px;border-radius:4px;font-size:11.5px}
.closex{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:8px;background:transparent;font-size:20px;color:var(--muted);cursor:pointer;line-height:1;display:grid;place-items:center;z-index:2;border:0}
.closex:hover{background:var(--paper);color:var(--ink)}

/* TOAST */
.toasts{position:fixed;top:88px;right:20px;z-index:200;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:340px}
.toast{background:var(--ink);color:#fff;padding:13px 16px;border-radius:11px;box-shadow:var(--shadow-lg);font-size:14px;font-weight:500;animation:toastIn .25s ease;pointer-events:auto;display:flex;gap:10px;align-items:flex-start}
.toast.ok{background:#1f7a52}
.toast.warn{background:#b5121b}
.toast .ic{font-weight:800}
.toast.out{animation:toastOut .25s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateX(20px)}}

/* BOTTOM NAV MOBILE */
.botnav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;background:rgba(246,241,232,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:6px 8px calc(6px + env(safe-area-inset-bottom));justify-content:space-around;align-items:center}
.botnav a, .botnav button{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;padding:8px 4px;font-size:11px;font-weight:600;color:var(--ink-2);background:none;text-decoration:none}
.botnav svg{width:22px;height:22px}
.botnav .act{color:var(--orange)}
.botnav .fab{flex:0 0 auto;width:54px;height:54px;border-radius:50%;background:var(--orange);color:#fff;margin-top:-22px;box-shadow:0 8px 22px rgba(242,92,13,.36);justify-content:center;font-size:0;padding:0;display:flex;align-items:center}
.botnav .fab svg{width:26px;height:26px;stroke:#fff}
.botnav .fab:hover{background:var(--orange-d);color:#fff}
@media(max-width:980px){
  .botnav{display:flex}
  body{padding-bottom:74px}
  footer{margin-bottom:0}
}

/* FOOTER */
footer{background:var(--ink);color:#b9c7c0;padding:46px 0 30px;margin-top:40px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:30px}
footer .logo{color:#fff;margin-bottom:14px}
footer .logo .mark{background:#23332e}
footer p{font-size:13.5px;line-height:1.65;color:#90a39b}
footer h4{color:#fff;font-size:14px;margin-bottom:13px;font-family:'Spline Sans';font-weight:700}
footer ul{list-style:none}
footer li{font-size:13.5px;margin-bottom:9px}
footer li a{font-size:13.5px;color:#90a39b;text-decoration:none}
footer li a:hover{color:#fff}
.legal{border-top:1px solid #2a3a34;margin-top:34px;padding-top:22px;font-size:12px;color:#7d8f88;line-height:1.7}

/* GATE (zone connectée) */
.gate{padding:42px 0 60px}
.gate-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:38px 30px;text-align:center;max-width:560px;margin:0 auto;box-shadow:var(--shadow)}
.gate-card .lock-ic{width:64px;height:64px;border-radius:50%;background:var(--paper);display:grid;place-items:center;margin:0 auto 18px;color:var(--orange)}
.gate-card h2{font-size:26px;margin-bottom:8px}
.gate-card p{color:var(--muted);font-size:15px;max-width:42ch;margin:0 auto 22px}

/* RESPONSIVE */
@media(max-width:980px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .filters .row{grid-template-columns:repeat(2,1fr)}
  .detail{grid-template-columns:1fr}
  .seller{position:static}
  .how,.stats,.foot-grid,.pro-grid{grid-template-columns:1fr 1fr}
  .nav-search{display:none}
  .plans,.pay-box,.frm{grid-template-columns:1fr}
  .nav-actions .lnk,.nav-actions .btn-pri-d{display:none}
  .burger{display:inline-flex}
  .photo-grid{grid-template-columns:repeat(3,1fr)}
  .hero-grid{grid-template-columns:1fr;gap:24px}
  .hero-visual{display:none}
  .hero-stats{gap:24px}
}
@media(max-width:560px){
  .grid,.stats,.filters .row,.how,.foot-grid,.pro-grid{grid-template-columns:1fr}
  .nav{height:60px;gap:10px}
  .demo-bar{font-size:11.5px}
  .hero{padding:30px 0 18px}
  .panel{padding:20px}
  .deposit{padding:20px 0 50px}
  .steps-bar .s small{font-size:11px}
  .toasts{top:auto;bottom:14px;left:14px;right:14px;max-width:none}
  .thumbs{grid-template-columns:repeat(4,1fr)}
  .photo-grid{grid-template-columns:repeat(2,1fr)}
  .spec-grid{grid-template-columns:1fr 1fr}
}

@media(prefers-reduced-motion:reduce){
  *,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

@keyframes spin{to{transform:rotate(360deg)}}
