/* ModeSurvie.org — style.css — Mobile first, ultra léger */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:wght@700;900&family=Figtree:wght@400;600;700&display=swap');

:root {
  --bleu:  #0d1b2a;
  --bleu2: #1a3050;
  --acc:   #1d6ef5;
  --or:    #f59e0b;
  --vert:  #059669;
  --creme: #f7f5f0;
  --bord:  #e8e4dc;
  --gris:  #6b7280;
  --gl:    #d1cdc5;
  --txt:   #111827;
  --blanc: #fff;
  --r:     12px;
  --sh:    0 2px 10px rgba(0,0,0,.07);
  --sh2:   0 6px 24px rgba(0,0,0,.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Figtree',sans-serif;background:var(--creme);color:var(--txt);overflow-x:hidden;padding-bottom:72px}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font-family:'Figtree',sans-serif}
img{max-width:100%;display:block}

/* ── HEADER ── */
.hdr{background:var(--bleu);position:sticky;top:0;z-index:300}
.hdr-top{display:flex;align-items:center;justify-content:space-between;padding:0 .9rem;height:50px}
.logo{display:flex;align-items:baseline;gap:.2rem;font-family:'Fraunces',serif;font-size:1.15rem;font-weight:900;color:#fff;letter-spacing:-.5px}
.logo-org{font-family:'Figtree',sans-serif;font-size:.55rem;font-weight:700;color:var(--or);letter-spacing:1.5px;text-transform:uppercase}
.hdr-btns{display:flex;gap:.35rem;align-items:center}
.bxs{height:32px;padding:0 .75rem;border-radius:7px;border:none;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}
.b-ghost{background:rgba(255,255,255,.08);color:rgba(255,255,255,.7)}
.b-ghost:hover{background:rgba(255,255,255,.14)}
.b-acc{background:var(--acc);color:#fff}
.b-acc:hover{opacity:.9}
.b-lang{display:flex;align-items:center;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:7px;padding:0 .6rem;height:32px;font-size:.7rem;font-weight:700;color:rgba(255,255,255,.65)}
.b-lang:hover{background:rgba(255,255,255,.13)}

/* ── SEARCH ── */
.hdr-search{padding:0 .9rem .7rem;display:flex;gap:.4rem}
.sbox{flex:1;display:flex;align-items:center;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.1);border-radius:9px;padding:0 .8rem;gap:.4rem;transition:border-color .15s}
.sbox:focus-within{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.12)}
.sbox input{flex:1;border:none;outline:none;background:transparent;color:#fff;font-size:.85rem;padding:.58rem 0}
.sbox input::placeholder{color:rgba(255,255,255,.28)}
.sico{font-size:.9rem;opacity:.4}
.b-loc{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:9px;padding:0 .7rem;color:rgba(255,255,255,.55);font-size:.7rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.25rem;height:38px;white-space:nowrap}

/* ── LIEU BAR ── */
.lieu{background:var(--bleu2);padding:.5rem .9rem;display:flex;gap:.4rem;align-items:center;overflow-x:auto;scrollbar-width:none}
.lieu::-webkit-scrollbar{display:none}
.lsel{border:1px solid rgba(255,255,255,.15);border-radius:7px;padding:.38rem .6rem;font-size:.72rem;font-weight:600;color:#fff;background:rgba(255,255,255,.08);outline:none;cursor:pointer;flex-shrink:0;max-width:130px}
.lsel:focus{border-color:rgba(255,255,255,.35)}
.larr{color:rgba(255,255,255,.25);font-size:.75rem;flex-shrink:0}

/* ── ONGLETS ── */
.tabs{background:var(--blanc);border-bottom:1px solid var(--bord);overflow-x:auto;scrollbar-width:none;position:sticky;top:118px;z-index:200}
.tabs::-webkit-scrollbar{display:none}
.tabs-list{display:flex;padding:0 .4rem;min-width:max-content}
.tab{height:42px;padding:0 .85rem;display:flex;align-items:center;gap:.35rem;font-size:.76rem;font-weight:600;color:var(--gris);border:none;background:none;border-bottom:2.5px solid transparent;cursor:pointer;white-space:nowrap;transition:color .15s}
.tab:hover{color:var(--txt)}
.tab.on{color:var(--bleu);border-bottom-color:var(--bleu)}
.tab-i{font-size:.95rem}

/* ── PANELS ── */
.panel{display:none}
.panel.on{display:block}

/* ── HERO ── */
.hero{background:var(--bleu);padding:1.8rem .9rem 2rem;position:relative;overflow:hidden;text-align:center}
.hero-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:38px 38px}
.hero-glow{position:absolute;top:-60px;right:-50px;width:260px;height:260px;background:radial-gradient(ellipse,rgba(29,110,245,.18) 0%,transparent 65%);pointer-events:none}
.hero-in{position:relative;z-index:1}
.hero-pill{display:inline-flex;align-items:center;gap:.35rem;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.22);border-radius:100px;padding:.25rem .75rem;font-size:.63rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--or);margin-bottom:1rem;animation:up .4s ease both}
.hero h1{font-family:'Fraunces',serif;font-size:clamp(1.8rem,7.5vw,3rem);font-weight:900;color:#fff;line-height:1.06;letter-spacing:-1.5px;margin-bottom:.75rem;animation:up .4s .07s ease both}
.hero h1 mark{background:none;color:var(--or)}
.hero-sub{font-size:.82rem;color:rgba(255,255,255,.4);max-width:300px;margin:0 auto 1.4rem;line-height:1.6;animation:up .4s .13s ease both}
.hero-pills{display:flex;gap:.4rem;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:2px;animation:up .4s .18s ease both}
.hero-pills::-webkit-scrollbar{display:none}
.hpill{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.09);border-radius:100px;padding:.3rem .72rem;font-size:.68rem;color:rgba(255,255,255,.5);white-space:nowrap;cursor:pointer;flex-shrink:0;transition:all .15s}
.hpill:hover{background:rgba(255,255,255,.12);color:#fff}
.hero-stats{display:flex;justify-content:center;gap:1.5rem;margin-top:1.6rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.06);animation:up .4s .23s ease both}
.hs{text-align:center}
.hs strong{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:900;color:#fff;letter-spacing:-.5px;display:block}
.hs span{font-size:.58rem;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.28)}

/* ── SECTIONS ── */
.sec{padding:1.2rem .9rem}
.sh{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.85rem}
.sh h2{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:900;letter-spacing:-.3px}
.lien{font-size:.72rem;color:var(--acc);font-weight:600;cursor:pointer}

/* ── GROUPES CATÉGORIES ── */
.cat-groupe{margin-bottom:1.2rem}
.cat-groupe-titre{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--gris);margin-bottom:.5rem;padding:0 .1rem}
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:.45rem}
.cat{background:var(--blanc);border:1.5px solid var(--bord);border-radius:10px;padding:.75rem .3rem .65rem;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.22rem;transition:all .15s;position:relative;overflow:hidden}
.cat::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--cc,var(--acc));transform:scaleX(0);transition:transform .15s}
.cat:hover{border-color:var(--cc,var(--acc));transform:translateY(-2px);box-shadow:var(--sh)}
.cat:hover::after{transform:scaleX(1)}
.cat:active{transform:scale(.95)}
.ci{font-size:1.35rem;line-height:1}
.cn{font-size:.6rem;font-weight:700;line-height:1.2}
.cnb{font-size:.55rem;color:#bbb}
.cat-new{border-style:dashed;border-color:var(--gl);background:transparent;color:var(--gris)}
.cat-new .ci{font-size:.9rem;opacity:.45}
.cat-new:hover{border-color:var(--acc);color:var(--acc);background:#eff6ff;box-shadow:none;transform:none}
.cat-new:hover::after{display:none}

/* ── SCROLL FICHES ── */
.scx{display:flex;gap:.6rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:3px}
.scx::-webkit-scrollbar{display:none}
.fc{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);min-width:200px;max-width:220px;flex-shrink:0;overflow:hidden;cursor:pointer;transition:all .15s}
.fc:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.fc-top{padding:.8rem;display:flex;gap:.6rem;align-items:flex-start}
.fav{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.fm h4{font-weight:700;font-size:.8rem;margin-bottom:.08rem;line-height:1.25}
.fmloc{font-size:.6rem;color:#aaa;font-weight:500}
.fc-desc{padding:0 .8rem .65rem;font-size:.7rem;color:#555;line-height:1.5;border-top:1px solid var(--bord);padding-top:.6rem}
.fc-foot{padding:.45rem .8rem;border-top:1px solid var(--bord);display:flex;align-items:center;justify-content:space-between}
.stars{color:var(--or);font-size:.65rem}
.anb{font-size:.6rem;color:#bbb;margin-left:.18rem}
.bdg{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:.08rem .38rem;border-radius:4px}
.bdg-w{background:#d1fae5;color:var(--vert)}
.bdg-v{background:#fef3c7;color:#92400e}
.bdg-n{background:#dbeafe;color:var(--acc)}

/* ── ANNONCES ── */
.ann-list{display:flex;flex-direction:column;gap:.5rem}
.ann{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);padding:.8rem;display:flex;align-items:flex-start;gap:.65rem;cursor:pointer;transition:all .15s}
.ann:hover{border-color:#bbb;box-shadow:var(--sh)}
.ann-ico{width:38px;height:38px;border-radius:9px;background:var(--creme);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.ann-b{flex:1;min-width:0}
.ann-b h4{font-weight:700;font-size:.82rem;margin-bottom:.15rem;line-height:1.3}
.ann-b p{font-size:.7rem;color:var(--gris);line-height:1.35}
.ann-meta{display:flex;gap:.35rem;align-items:center;margin-top:.3rem;flex-wrap:wrap}
.tag{font-size:.58rem;font-weight:600;background:var(--creme);border-radius:4px;padding:.08rem .38rem;color:var(--gris)}
.ann-loc{font-size:.6rem;color:#bbb}
.ann-px{font-family:'Fraunces',serif;font-size:.9rem;font-weight:900;letter-spacing:-.2px;flex-shrink:0}
.ann-px.free{font-size:.7rem;color:var(--vert);font-family:'Figtree',sans-serif;font-weight:700}

/* ── FILTRES ── */
.filtres{display:flex;gap:.38rem;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:.9rem .9rem .5rem}
.filtres::-webkit-scrollbar{display:none}
.fil{background:var(--blanc);border:1.5px solid var(--bord);border-radius:100px;padding:.32rem .8rem;font-size:.7rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;color:var(--gris)}
.fil.on{background:var(--bleu);color:#fff;border-color:var(--bleu)}
.fil:hover:not(.on){border-color:#aaa;color:var(--txt)}

/* ── CATÉGORIES FULL ── */
.cats-full{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;padding:.9rem}
.catf{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);padding:.8rem;display:flex;align-items:center;gap:.65rem;cursor:pointer;transition:all .15s}
.catf:hover{border-color:var(--cc,var(--acc));box-shadow:var(--sh)}
.catf:active{transform:scale(.97)}
.cfi{width:38px;height:38px;border-radius:9px;background:var(--creme);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.cfb{flex:1;min-width:0}
.cfb strong{display:block;font-weight:700;font-size:.8rem;margin-bottom:.1rem}
.cfb span{font-size:.62rem;color:#bbb}
.cfarr{color:var(--gl);font-size:.8rem}
.catf-new{border-style:dashed;border-color:var(--gl);background:transparent;color:var(--gris);grid-column:1/-1;justify-content:center;gap:.5rem}
.catf-new:hover{border-color:var(--acc);color:var(--acc);background:#eff6ff;box-shadow:none}

/* ── RÉGIONS ── */
.prov-tabs{display:flex;overflow-x:auto;scrollbar-width:none;background:var(--blanc);border-bottom:1px solid var(--bord)}
.prov-tabs::-webkit-scrollbar{display:none}
.ptab{padding:.65rem .85rem;font-size:.72rem;font-weight:600;color:var(--gris);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;white-space:nowrap;transition:all .15s}
.ptab.on{color:var(--bleu);border-bottom-color:var(--bleu)}
.reg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.45rem;padding:.9rem}
.reg{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);padding:.8rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .15s}
.reg:hover{border-color:var(--bleu);box-shadow:var(--sh)}
.reg:active{transform:scale(.97)}
.reg strong{font-weight:700;font-size:.8rem}
.reg span{font-size:.6rem;color:#bbb}

/* ── COMPTE ── */
.cpt{padding:1.2rem .9rem}
.cpt-hero{background:linear-gradient(135deg,var(--bleu),var(--bleu2));border-radius:var(--r);padding:1.3rem;text-align:center;margin-bottom:1.1rem}
.cpt-hero h2{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:900;color:#fff;letter-spacing:-.4px;margin-bottom:.3rem}
.cpt-hero p{font-size:.76rem;color:rgba(255,255,255,.4);line-height:1.5;margin-bottom:1rem}
.btns-row{display:flex;gap:.5rem}
.b-out{flex:1;padding:.72rem .5rem;border-radius:9px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:rgba(255,255,255,.75);font-weight:700;font-size:.78rem;cursor:pointer}
.b-fill{flex:1;padding:.72rem .5rem;border-radius:9px;border:none;background:var(--acc);color:#fff;font-weight:700;font-size:.78rem;cursor:pointer}
.b-fill:hover{opacity:.9}
.st{font-family:'Fraunces',serif;font-size:.95rem;font-weight:900;letter-spacing:-.3px;margin-bottom:.7rem}
.types{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.2rem}
.typr{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);padding:.9rem;display:flex;gap:.8rem;align-items:flex-start;cursor:pointer;transition:all .15s}
.typr:hover{border-color:var(--acc);box-shadow:var(--sh)}
.typi{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.typb h4{font-weight:700;font-size:.84rem;margin-bottom:.15rem}
.typb p{font-size:.71rem;color:var(--gris);line-height:1.4}
.perms{display:flex;flex-wrap:wrap;gap:.28rem;margin-top:.4rem}
.pm{font-size:.58rem;font-weight:700;padding:.08rem .38rem;border-radius:4px}
.pm-o{background:#d1fae5;color:#065f46}
.pm-n{background:#fee2e2;color:#991b1b}
.plans{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.2rem}
.plan{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);padding:.95rem;position:relative}
.plan.star{border-color:var(--or);background:linear-gradient(160deg,#fffdf5,#fff8e7)}
.plan-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.5rem}
.plan-top h4{font-weight:700;font-size:.86rem}
.plan-px{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:900;letter-spacing:-.4px}
.plan-px sub{font-family:'Figtree',sans-serif;font-size:.6rem;font-weight:500;letter-spacing:0}
.plan-bdg{position:absolute;top:-8px;right:.9rem;background:var(--or);color:var(--bleu);font-size:.55rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;padding:.12rem .45rem;border-radius:100px}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:.25rem;margin-bottom:.7rem}
.plan ul li{font-size:.71rem;color:#444;display:flex;gap:.35rem}
.plan ul li::before{content:'✓';color:var(--vert);font-weight:700;flex-shrink:0}
.btn-plan{width:100%;padding:.65rem;border-radius:9px;border:none;font-weight:700;font-size:.77rem;cursor:pointer;transition:all .15s}
.bpg{background:var(--creme);color:var(--txt)}
.bpg:hover{background:#ddd8ce}
.bpb{background:var(--bleu);color:#fff}
.bpb:hover{opacity:.9}
.revs{display:flex;flex-direction:column;gap:.5rem}
.rev{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);padding:.8rem;display:flex;gap:.65rem;align-items:center}
.revi{width:36px;height:36px;border-radius:9px;background:var(--creme);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.revb strong{display:block;font-weight:700;font-size:.8rem;margin-bottom:.1rem}
.revb p{font-size:.69rem;color:var(--gris);line-height:1.35}

/* ── MODAL ── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:500;display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .2s}
.overlay.on{opacity:1;pointer-events:all}
.modal{background:var(--blanc);border-radius:18px 18px 0 0;padding:1.1rem 1rem 2rem;width:100%;max-height:85vh;overflow-y:auto;transform:translateY(100%);transition:transform .25s cubic-bezier(.34,1.3,.64,1)}
.overlay.on .modal{transform:translateY(0)}
.mhandle{width:34px;height:4px;background:var(--bord);border-radius:2px;margin:0 auto 1rem}
.modal h3{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:900;letter-spacing:-.3px;margin-bottom:.2rem}
.msub{font-size:.75rem;color:var(--gris);margin-bottom:1.1rem}
.fg{margin-bottom:.8rem}
.fg label{display:block;font-size:.71rem;font-weight:700;color:#333;margin-bottom:.3rem}
.fg input,.fg textarea,.fg select{width:100%;padding:.67rem .85rem;border:1.5px solid var(--bord);border-radius:9px;font-size:.84rem;color:var(--txt);background:var(--creme);outline:none;transition:border-color .15s}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--acc);background:#fff}
.fg textarea{resize:vertical;min-height:66px}
.emo-row{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}
.emo{width:34px;height:34px;border-radius:7px;border:1.5px solid var(--bord);background:var(--blanc);font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .13s}
.emo:hover,.emo.on{border-color:var(--acc);background:#eff6ff}
.mfoot{display:flex;gap:.45rem;margin-top:1rem}
.b-ann{flex:1;padding:.75rem;border-radius:9px;border:1.5px solid var(--bord);background:transparent;font-weight:700;font-size:.8rem;cursor:pointer;color:var(--gris)}
.b-sub{flex:2;padding:.75rem;border-radius:9px;border:none;background:var(--bleu);color:#fff;font-weight:700;font-size:.8rem;cursor:pointer;transition:opacity .15s}
.b-sub:hover{opacity:.9}

/* ── BTN FULL ── */
.btn-full{width:100%;padding:.82rem;border-radius:var(--r);border:none;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:.4rem}
.b-bleu{background:var(--bleu);color:#fff}
.b-bleu:hover{opacity:.9}
.b-outline{background:transparent;color:var(--bleu);border:1.5px solid var(--bleu);margin-top:.45rem}

/* ── FICHE ── */
.fiche-hdr{background:var(--bleu);padding:1.2rem .9rem;color:#fff}
.fiche-top{display:flex;gap:.8rem;align-items:flex-start}
.fiche-logo{width:52px;height:52px;border-radius:11px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:1.7rem;flex-shrink:0}
.fiche-t h1{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:900;letter-spacing:-.4px;margin-bottom:.18rem}
.fcat-bdg{display:inline-block;background:rgba(255,255,255,.11);border-radius:4px;padding:.1rem .45rem;font-size:.62rem;font-weight:600;color:rgba(255,255,255,.65)}
.floc{font-size:.68rem;color:rgba(255,255,255,.4);margin-top:.25rem}
.fstars{display:flex;align-items:center;gap:.35rem;margin-top:.55rem}
.stars-lg{color:var(--or);font-size:.82rem}
.avis-txt{font-size:.68rem;color:rgba(255,255,255,.4)}
.fbody{padding:.9rem}
.fsec{background:var(--blanc);border:1.5px solid var(--bord);border-radius:var(--r);padding:.9rem;margin-bottom:.65rem}
.fsec h3{font-family:'Fraunces',serif;font-size:.9rem;font-weight:900;letter-spacing:-.2px;margin-bottom:.7rem}
.irow{display:flex;gap:.55rem;align-items:flex-start;margin-bottom:.5rem}
.iico{font-size:.9rem;flex-shrink:0;margin-top:.03rem}
.itxt{font-size:.77rem;color:#444;line-height:1.4}
.itxt strong{color:var(--txt)}
.tags-w{display:flex;flex-wrap:wrap;gap:.32rem}
.ftag{background:var(--creme);border-radius:6px;padding:.2rem .55rem;font-size:.65rem;font-weight:600;color:var(--gris)}
.contrib-row{display:flex;align-items:center;gap:.45rem;padding-top:.65rem;border-top:1px solid var(--bord);margin-top:.65rem}
.avs{display:flex}
.av-sm{width:22px;height:22px;border-radius:50%;border:2px solid var(--blanc);display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;color:#fff;margin-left:-5px}
.av-sm:first-child{margin-left:0}
.ctxt{font-size:.67rem;color:var(--gris)}

/* ── BOTTOM NAV ── */
.bnav{position:fixed;bottom:0;left:0;right:0;height:68px;background:var(--blanc);border-top:1px solid var(--bord);display:flex;z-index:400;box-shadow:0 -2px 12px rgba(0,0,0,.06)}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;cursor:pointer;border:none;background:none;transition:all .13s}
.bni{font-size:1.18rem;line-height:1}
.bnl{font-size:.57rem;font-weight:600;color:var(--gris)}
.bn.on .bnl{color:var(--bleu)}
.bn.on .bni{transform:scale(1.08)}
.bn-mid{flex:0 0 62px;position:relative}
.fab{position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:48px;height:48px;background:var(--bleu);border-radius:50%;border:3px solid var(--blanc);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;cursor:pointer;box-shadow:0 4px 16px rgba(13,27,42,.38);transition:all .15s}
.fab:hover{opacity:.9;transform:translateX(-50%) scale(1.05)}
.fabl{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);font-size:.55rem;font-weight:700;color:var(--bleu);white-space:nowrap}

/* ── TOAST ── */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(8px);background:var(--bleu);color:#fff;padding:.58rem 1.1rem;border-radius:100px;font-size:.76rem;font-weight:600;opacity:0;transition:all .22s;z-index:600;white-space:nowrap;pointer-events:none;box-shadow:0 4px 18px rgba(0,0,0,.22)}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── ANIMATIONS ── */
@keyframes up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* ── DESKTOP 768px+ ── */
@media(min-width:768px){
  body{padding-bottom:0}
  .bnav{display:none}
  .hdr-top{height:56px;padding:0 1.8rem}
  .hdr-search{padding:0 1.8rem .8rem}
  .lieu{padding:.5rem 1.8rem}
  .tabs{top:114px}
  .tabs-list{padding:0 1.4rem}
  .tab{height:44px;padding:0 1rem;font-size:.78rem}
  .hero{padding:3rem 2rem 2.6rem}
  .hero h1{font-size:3rem}
  .hero-sub{max-width:400px}
  .hero-pills{justify-content:center}
  .hero-stats{gap:2.8rem}
  .sec{padding:1.8rem;max-width:1080px;margin:0 auto}
  .cats{grid-template-columns:repeat(8,1fr)}
  .scx{flex-wrap:wrap;overflow:visible}
  .fc{min-width:240px}
  .cats-full{grid-template-columns:repeat(3,1fr);padding:1.4rem 1.8rem;max-width:1080px;margin:0 auto}
  .reg-grid{grid-template-columns:repeat(4,1fr);padding:1.4rem 1.8rem;max-width:1080px;margin:0 auto}
  .cpt{padding:1.8rem;max-width:820px;margin:0 auto}
  .types{display:grid;grid-template-columns:repeat(3,1fr)}
  .plans{display:grid;grid-template-columns:repeat(3,1fr)}
  .overlay{align-items:center}
  .modal{border-radius:14px;max-width:480px;margin:auto;max-height:78vh}
  .filtres{padding:.9rem 1.8rem .5rem;max-width:1080px;margin:0 auto}
  .fbody{max-width:680px;margin:0 auto;padding:1.4rem}
  .fiche-hdr{padding:1.8rem}
}
