:root{
  --bleu:#0E2E52; --bleu-soft:#143a66; --teal:#20B9A6; --teal-d:#189c8c; --clair:#57E1CC;
  --ink:#0F2540; --gris:#5B7085; --bord:#E6EDF3; --fond:#F4F9F8; --blanc:#fff;
  --ok:#12A27A; --moyen:#E39A2B; --bas:#E24E2B;
  --grad:linear-gradient(120deg,#0E2E52 0%,#155E7A 55%,#20B9A6 100%);
  --grad-soft:linear-gradient(120deg,#EAF6F3,#E3EEF7);
  --shadow:0 18px 48px rgba(14,46,82,.12); --shadow-s:0 6px 20px rgba(14,46,82,.07);
  --shadow-l:0 30px 80px rgba(14,46,82,.20);
  --r:18px; --r-l:26px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:hidden}
body{font-family:'Poppins','Segoe UI',system-ui,sans-serif;color:var(--ink);background:var(--blanc);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
.hidden{display:none!important}
.muted{color:var(--gris);font-size:14px}
.center{text-align:center}.mt{margin-top:14px}
.display{font-family:'Fraunces','Georgia',serif;font-weight:600;letter-spacing:-.5px}
.gradtext{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Header ---------- */
header{background:rgba(255,255,255,.82);backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid var(--bord);position:sticky;top:0;z-index:1000}
.hd{display:flex;align-items:center;gap:16px;height:72px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:21px;letter-spacing:-.5px}
.logo .badge{width:38px;height:38px;flex:none;filter:drop-shadow(0 4px 10px rgba(32,185,166,.35))}
.logo b{color:var(--bleu)} .logo span{color:var(--teal)}
.hd .grow{flex:1}
.mainnav{display:flex;gap:24px;margin-left:14px}
.mainnav a{font-size:14.5px;font-weight:600;color:var(--ink);opacity:.82;transition:.15s;position:relative}
.mainnav a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--teal);border-radius:2px;transition:right .2s ease}
.mainnav a:hover{opacity:1;color:var(--teal)}
.mainnav a:hover::after{right:0}
@media(max-width:900px){.mainnav{display:none}}
.btn{border:none;cursor:pointer;font-family:inherit;font-weight:600;border-radius:999px;padding:12px 22px;font-size:14px;transition:.18s;white-space:nowrap}
.btn-p{background:var(--teal);color:#fff;box-shadow:0 8px 20px rgba(32,185,166,.32)}
.btn-p:hover{background:var(--teal-d);transform:translateY(-1px)}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 10px 26px rgba(14,46,82,.28)}
.btn-grad:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn-o{background:#fff;border:1.5px solid var(--bord);color:var(--ink)}
.btn-o:hover{border-color:var(--teal);color:var(--teal)}
.btn-ghost{background:transparent;color:var(--ink);padding:12px 14px}
.btn-ghost:hover{color:var(--teal)}
.btn-lg{padding:15px 30px;font-size:15.5px}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
   radial-gradient(1200px 500px at 78% -10%,#E7F6F1 0%,transparent 60%),
   radial-gradient(900px 500px at 5% 10%,#E6EFF8 0%,transparent 55%),
   var(--fond);
  padding:70px 0 78px}
.hero .blob{position:absolute;border-radius:50%;filter:blur(6px);opacity:.55;z-index:0}
.blob1{width:360px;height:360px;background:radial-gradient(circle,#BFF3E8,transparent 70%);top:-130px;left:-90px}
.blob2{width:440px;height:440px;background:radial-gradient(circle,#D6E4F0,transparent 70%);bottom:-230px;right:-140px}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:48px;align-items:center}
@media(max-width:940px){.hero-grid{grid-template-columns:1fr;gap:34px;text-align:center}}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--bord);border-radius:999px;padding:7px 15px;font-size:13px;font-weight:700;color:var(--bleu);box-shadow:var(--shadow-s)}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(32,185,166,.18)}
.hero h1{font-family:'Fraunces','Georgia',serif;font-weight:600;font-size:clamp(38px,5.8vw,64px);line-height:1.04;letter-spacing:-1.4px;color:var(--ink);margin:20px 0 0}
.hero h1 em{font-style:italic;color:var(--teal)}
.hero p.sub{font-size:clamp(16px,2vw,20px);color:var(--gris);margin:18px 0 28px;max-width:520px}
@media(max-width:940px){.hero p.sub{margin-left:auto;margin-right:auto}}
.search{display:flex;align-items:center;gap:6px;background:#fff;border-radius:999px;padding:9px 9px 9px 24px;max-width:560px;box-shadow:var(--shadow);border:1px solid var(--bord)}
@media(max-width:940px){.search{margin:0 auto}}
.search input{flex:1;border:none;outline:none;font-family:inherit;font-size:16px;color:var(--ink);background:transparent}
.search .go{width:52px;height:52px;border-radius:50%;border:none;background:var(--grad);color:#fff;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;flex:none;transition:.15s}
.search .go:hover{filter:brightness(1.08)}
.trust-line{margin-top:20px;font-size:14px;color:var(--gris);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
@media(max-width:940px){.trust-line{justify-content:center}}
.trust-line b{color:var(--ink)}
.avatars{display:flex}
.avatars span{width:32px;height:32px;border-radius:50%;border:2.5px solid #fff;margin-left:-10px;display:flex;align-items:center;justify-content:center;font-size:14px;background:var(--grad-soft)}
.avatars span:first-child{margin-left:0}
.stars-mini{color:#F5B301;letter-spacing:2px;font-size:14px}

/* Hero visual : preview card */
.hero-visual{position:relative}
.preview{background:#fff;border:1px solid var(--bord);border-radius:var(--r-l);box-shadow:var(--shadow-l);padding:20px;position:relative;z-index:2;max-width:420px;margin:0 auto}
.preview .pv-photo{height:130px;border-radius:16px;background:linear-gradient(135deg,#DCF3EC,#D6E4F0);display:flex;align-items:center;justify-content:center;font-size:52px;position:relative;overflow:hidden}
.preview .pv-badge{position:absolute;top:12px;left:12px;background:#fff;border-radius:999px;padding:5px 11px;font-size:11px;font-weight:800;color:var(--ok);box-shadow:var(--shadow-s)}
.preview .pv-head{display:flex;justify-content:space-between;align-items:center;margin:16px 4px 0}
.preview .pv-head h4{font-size:17px;font-weight:800}
.preview .pv-head .psub{font-size:12.5px;color:var(--gris)}
.pv-score{background:var(--ok);color:#fff;border-radius:14px;padding:8px 12px;font-weight:800;font-size:16px;display:flex;align-items:center;gap:4px;flex:none}
.pv-score::before{content:"★";font-size:12px}
.pv-crit{margin:16px 4px 4px;display:flex;flex-direction:column;gap:9px}
.pv-crit .l{display:flex;align-items:center;gap:10px;font-size:12px;color:#40556c;font-weight:600}
.pv-crit .l span{width:96px;flex:none}
.pv-crit .bar{flex:1;height:7px;background:#EDF2F5;border-radius:5px;overflow:hidden}
.pv-crit .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--clair),var(--teal));border-radius:5px}
.pv-float{position:absolute;background:#fff;border:1px solid var(--bord);border-radius:16px;box-shadow:var(--shadow);padding:12px 15px;z-index:3;font-size:13px;font-weight:700;display:flex;align-items:center;gap:9px}
.pv-float .ic{width:34px;height:34px;border-radius:10px;background:var(--grad-soft);display:flex;align-items:center;justify-content:center;font-size:17px}
.pv-float.f1{top:-18px;right:-14px}
.pv-float.f2{bottom:-20px;left:-16px}
/* Sur tablette/mobile la maquette passe en 1 colonne : on masque les badges flottants pour éviter le chevauchement */
@media(max-width:940px){.pv-float{display:none}}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:44px}
@media(max-width:820px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:22px 18px;text-align:center;box-shadow:var(--shadow-s)}
.stat .num{font-family:'Fraunces',serif;font-weight:600;font-size:34px;letter-spacing:-1px;line-height:1;color:var(--bleu)}
.stat .lab{font-size:13px;color:var(--gris);margin-top:7px;font-weight:600}

/* ---------- Sections ---------- */
section.block{padding:64px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;gap:12px;flex-wrap:wrap}
.sec-head h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(24px,3.4vw,34px);letter-spacing:-.8px;color:var(--ink)}
.sec-head p{color:var(--gris);font-size:15px;margin-top:6px;max-width:560px}
.kicker{display:inline-block;font-size:12.5px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);margin-bottom:6px}

/* Categories (illustrated) */
.cats{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
@media(max-width:820px){.cats{grid-template-columns:repeat(2,1fr)}}
.cat{background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:24px 16px;text-align:center;cursor:pointer;transition:.18s;position:relative;overflow:hidden}
.cat::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--grad);opacity:0;transition:.2s}
.cat:hover{border-color:transparent;box-shadow:var(--shadow);transform:translateY(-4px)}
.cat:hover::before{opacity:1}
.cat .ic{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 14px;background:var(--grad-soft)}
.cat .nm{font-weight:700;font-size:15px}
.cat .cc{font-size:12px;color:var(--gris);margin-top:3px}

/* ---------- Discover (map + list) ---------- */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.chip{background:#fff;border:1.5px solid var(--bord);color:var(--ink);border-radius:999px;padding:9px 17px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s}
.chip:hover{border-color:var(--teal)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.cols{display:grid;grid-template-columns:1fr 1.05fr;gap:22px}
@media(max-width:900px){.cols{grid-template-columns:1fr}#map{height:300px}}
#map{height:560px;border-radius:var(--r);border:1px solid var(--bord);z-index:1;box-shadow:var(--shadow-s)}
.list{display:flex;flex-direction:column;gap:12px;max-height:560px;overflow:auto;padding-right:4px}

/* Place card */
.place{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--bord);border-radius:16px;padding:14px 16px;cursor:pointer;transition:.15s}
.place:hover{border-color:var(--teal);box-shadow:var(--shadow-s);transform:translateY(-2px)}
.place .pic{width:52px;height:52px;border-radius:14px;flex:none;display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--grad-soft)}
.place .pmain{flex:1;min-width:0}
.place h3{font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.place .psub{color:var(--gris);font-size:13px}
.tag{display:inline-block;background:#EEF2F5;color:#475569;border-radius:7px;padding:2px 8px;font-size:12px;font-weight:600}
.score{display:inline-flex;align-items:center;gap:5px;font-weight:800;border-radius:12px;padding:7px 12px;color:#fff;font-size:15px;white-space:nowrap;flex:none}
.score::before{content:"★";font-size:13px;opacity:.9}
.score.nostar::before{content:""}
.s-ok{background:var(--ok)} .s-moyen{background:var(--moyen)} .s-bas{background:var(--bas)} .s-none{background:#94A3B8}
.badge-alim{display:inline-block;background:#E7F3DE;color:#3A6B1E;border-radius:8px;padding:3px 9px;font-size:11px;font-weight:700}

/* ---------- Recent reviews strip ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}
.rev{background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-s);transition:.18s;cursor:pointer}
.rev:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--teal)}
.rev .rv-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.rev .rv-place{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rev .rv-txt{color:#3d5169;font-size:14px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.rev .rv-foot{margin-top:12px;font-size:12.5px;color:var(--gris);display:flex;justify-content:space-between}

/* ---------- Testimonials ---------- */
.testis{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.testis{grid-template-columns:1fr}}
.testi{background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-s)}
.testi .quote{font-family:'Fraunces',serif;font-size:40px;line-height:0;color:var(--teal);display:block;height:18px}
.testi p{font-size:15px;color:#33475e;line-height:1.6;margin:6px 0 16px}
.testi .who{display:flex;align-items:center;gap:11px}
.testi .who .av{width:40px;height:40px;border-radius:50%;background:var(--grad-soft);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--bleu)}
.testi .who b{font-size:14px}.testi .who .role{font-size:12.5px;color:var(--gris)}

/* ---------- Fiche ---------- */
.fiche{padding:36px 0}
.fiche .back{color:var(--gris);font-size:14px;font-weight:600}
.fiche .head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:26px;margin:16px 0;box-shadow:var(--shadow-s)}
.fiche h1{font-family:'Fraunces',serif;font-weight:600;font-size:32px;letter-spacing:-.8px}
.bigscore{width:96px;height:96px;border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;flex:none}
.bigscore .n{font-size:30px;font-weight:800;line-height:1}
.bigscore .l{font-size:11px;opacity:.9;margin-top:2px}
.crit{display:flex;flex-direction:column;gap:10px;background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:22px}
.crit .line{display:flex;align-items:center;gap:12px}
.crit .lbl{width:160px;font-size:14px;color:#334155;font-weight:600}
.bar{flex:1;height:10px;background:#EEF2F5;border-radius:6px;overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--clair),var(--teal));border-radius:6px}
.avis{background:#fff;border:1px solid var(--bord);border-radius:14px;padding:16px 18px;margin-bottom:12px}
.avis .top{display:flex;justify-content:space-between;align-items:center;color:var(--gris);font-size:13px;margin-bottom:8px}
.section-t{font-family:'Fraunces',serif;font-weight:600;font-size:22px;margin:26px 0 14px;color:var(--ink);letter-spacing:-.4px}

/* ---------- Modal ---------- */
.overlay{position:fixed;inset:0;background:rgba(14,46,82,.55);display:none;align-items:center;justify-content:center;z-index:2000;padding:16px;backdrop-filter:blur(4px)}
.overlay.on{display:flex}
.modal{background:#fff;border-radius:24px;max-width:460px;width:100%;padding:28px;max-height:90vh;overflow:auto;box-shadow:var(--shadow-l)}
.modal h2{font-family:'Fraunces',serif;font-weight:600;font-size:24px;margin-bottom:6px;color:var(--ink);letter-spacing:-.4px}
.field{margin:14px 0}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:#334155}
.field input,.field textarea,.field select{width:100%;border:1.5px solid var(--bord);border-radius:12px;padding:12px 14px;font-family:inherit;font-size:15px;outline:none;transition:.15s}
.field input:focus,.field textarea:focus{border-color:var(--teal)}
.stars{display:flex;gap:6px}
.star{font-size:30px;cursor:pointer;color:#CBD5E1;line-height:1;transition:.1s}
.star.on{color:#F5B301}
.attest{display:flex;gap:9px;align-items:flex-start;font-size:12.5px;color:var(--gris);line-height:1.45;margin:6px 0 12px;cursor:pointer}
.attest input{margin-top:2px;flex:none;width:16px;height:16px;accent-color:var(--teal)}

/* ===== Responsive : tablette ===== */
@media(max-width:760px){
  .hd{gap:10px}
  .btn{padding:11px 18px}
}
/* ===== Responsive : mobile ===== */
@media(max-width:600px){
  .wrap{padding:0 16px}
  .hd{height:60px;gap:8px}
  .logo{font-size:16.5px;gap:8px}
  .logo .badge{width:32px;height:32px}
  #scrollWrite{display:none}                 /* on masque « Noter un lieu » (secondaire) */
  header .btn-o{padding:9px 16px;font-size:13.5px}
  .hero{padding:34px 0 38px}
  .hero-grid{gap:26px}
  .hero .eyebrow{font-size:11.5px;padding:6px 12px}
  .hero h1{font-size:clamp(29px,8.4vw,40px);letter-spacing:-.8px;line-height:1.06}
  .hero p.sub{font-size:15.5px;margin:14px auto 22px}
  .search{padding:7px 7px 7px 18px}
  .search input{font-size:15px}
  .search .go{width:46px;height:46px;font-size:18px}
  .preview{padding:15px;border-radius:20px}
  .preview .pv-photo{height:110px;font-size:44px}
  .stats{margin-top:32px;gap:12px}
  .stat{padding:18px 12px}
  .stat .num{font-size:27px}
  .stat .lab{font-size:12px}
  section.block{padding:44px 0}
  .sec-head{margin-bottom:22px}
  .sec-head h2{font-size:22px}
  .cat{padding:20px 12px}
  .cat .ic{width:52px;height:52px;font-size:24px}
  .flash{padding:26px 20px;gap:20px}
  .flash h3{font-size:22px}
  .cta{padding:30px 22px}
  .cta h2{font-size:23px}
  .foot-top{gap:22px}
}
@media(max-width:380px){
  .hero h1{font-size:27px}
  .stats{grid-template-columns:1fr 1fr}
}

/* How it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:28px 24px;box-shadow:var(--shadow-s)}
.step .n{width:48px;height:48px;border-radius:14px;background:var(--grad);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:22px;box-shadow:0 8px 18px rgba(32,185,166,.3)}
.step h3{font-size:17px;font-weight:700;margin-bottom:6px}
.step p{color:var(--gris);font-size:14px}

/* Flashcode highlight */
.flash{display:flex;align-items:center;gap:32px;background:var(--grad);color:#fff;border-radius:var(--r-l);padding:38px 42px;margin-top:8px;flex-wrap:wrap;box-shadow:var(--shadow);position:relative;overflow:hidden}
.flash::after{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.08);top:-90px;right:-60px}
.flash .qr{width:140px;height:140px;border-radius:20px;background:#fff;display:flex;align-items:center;justify-content:center;flex:none;padding:12px;position:relative;z-index:1}
.flash .qr img{width:100%;height:100%}
.flash .ft{flex:1;min-width:240px;position:relative;z-index:1}
.flash .kb{display:inline-block;background:rgba(255,255,255,.18);border-radius:999px;padding:5px 13px;font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:10px}
.flash h3{font-family:'Fraunces',serif;font-weight:600;font-size:27px;letter-spacing:-.5px}
.flash p{opacity:.92;margin-top:10px;font-size:15px;max-width:520px}

/* CTA établissements */
.cta{background:var(--ink);color:#fff;border-radius:var(--r-l);padding:44px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(32,185,166,.28),transparent 70%);bottom:-160px;right:-80px}
.cta>div{position:relative;z-index:1}
.cta h2{font-family:'Fraunces',serif;font-weight:600;font-size:27px;letter-spacing:-.5px}
.cta p{opacity:.82;margin-top:8px;font-size:15px;max-width:560px}
.cta a{position:relative;z-index:1}

/* QR modal */
#qrBox{display:flex;justify-content:center;padding:14px}
#qrBox img{border-radius:14px;border:1px solid var(--bord)}

/* ---------- Footer (rich) ---------- */
footer{background:var(--bleu);color:#c8d6e6;padding:56px 0 30px;margin-top:20px;font-size:14px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;margin-bottom:34px}
@media(max-width:820px){.foot-top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-top{grid-template-columns:1fr}}
footer .logo{font-size:19px;margin-bottom:12px;color:#fff}
footer .logo b{color:#fff}footer .logo span{color:var(--clair)}
.foot-about{max-width:280px;line-height:1.6;color:#9fb4ca}
.foot-col h5{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:#7f97b1;margin-bottom:14px;font-weight:700}
.foot-col a{display:block;color:#c8d6e6;padding:6px 0;transition:.15s}
.foot-col a:hover{color:#fff;transform:translateX(3px)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#8ba2ba;font-size:13px}

/* Legal / content pages */
.page{max-width:820px;margin:0 auto;padding:52px 20px 70px}
.page h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(28px,4vw,40px);letter-spacing:-1px;margin-bottom:8px}
.page .lead{color:var(--gris);font-size:16px;margin-bottom:8px}
.page h2{font-family:'Fraunces',serif;font-weight:600;font-size:22px;margin:30px 0 10px;letter-spacing:-.4px}
.page p,.page li{color:#33475e;font-size:15.5px;line-height:1.7}
.page ul{margin:8px 0 8px 20px}
.page a.inl{color:var(--teal);font-weight:600}
.page .updated{font-size:13px;color:var(--gris);margin-top:6px}
.page h3.faq-q{font-family:'Poppins',sans-serif;font-weight:700;font-size:16.5px;margin:24px 0 6px;color:var(--ink)}
.contact-card{display:flex;align-items:center;gap:18px;background:#fff;border:1px solid var(--bord);border-radius:var(--r);padding:22px 24px;box-shadow:var(--shadow-s);margin:18px 0 8px}
.contact-card .cc-ic{width:56px;height:56px;border-radius:16px;background:var(--grad-soft);display:flex;align-items:center;justify-content:center;font-size:26px;flex:none}
.contact-card .cc-lab{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gris)}
.contact-card .cc-mail{font-family:'Fraunces',serif;font-weight:600;font-size:22px;color:var(--teal);letter-spacing:-.3px}

/* ============ Mode maintenance ============ */
.maint{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;background:
  radial-gradient(900px 400px at 50% -10%,#E7F6F1,transparent 60%),var(--fond)}
.maint-badge{width:96px;height:96px;margin-bottom:14px}
.maint-brand{font-size:24px;font-weight:800;letter-spacing:-.5px;margin-bottom:24px}
.maint-brand b{color:var(--bleu)} .maint-brand span{color:var(--teal)}
.maint h1{font-family:'Fraunces',serif;font-weight:600;font-size:36px;letter-spacing:-1px;color:var(--ink)}
.maint p{font-size:17px;color:var(--gris);margin-top:14px;max-width:460px;line-height:1.6}
.maint-foot{margin-top:34px;font-size:14px;color:var(--teal);font-weight:600}
.maint-banner{background:#FEF3C7;color:#8a6d1b;font-size:13.5px;text-align:center;padding:10px 16px;border-bottom:1px solid #F3D98B}
.maint-banner a{color:var(--bleu);font-weight:700;text-decoration:underline;margin-left:6px}

/* ============ Autour de moi (géoloc) ============ */
.near-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:4px 0 6px}
.near-bar .btn-p{padding:12px 22px;font-size:15px}
.near-bar #nearMsg{font-size:14px}
.radius-pick{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--gris)}
.radius-pick select{border:1.5px solid var(--bord);border-radius:999px;padding:9px 14px;font-family:inherit;font-size:14px;font-weight:600;color:var(--ink);background:#fff;cursor:pointer;outline:none;transition:.15s}
.radius-pick select:hover,.radius-pick select:focus{border-color:var(--teal)}
.near-note{font-size:12.5px;color:var(--gris);margin:0 0 14px}

/* ============ Fiche : carte + galerie photos ============ */
.fiche-map{height:240px;border-radius:16px;overflow:hidden;margin:0 0 20px;border:1px solid var(--bord);position:relative;z-index:0}
.fiche-map.placeholder{display:flex;align-items:center;justify-content:center;font-size:64px;background:linear-gradient(135deg,#E1F5EE,#D6E4F0)}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin:12px 0 8px}
.gallery .ph{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;border:1px solid var(--bord);background:#EEF3F6}
.gallery .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.gallery .ph:hover img{transform:scale(1.05)}
.gallery .ph .del{position:absolute;top:6px;right:6px;background:rgba(20,38,63,.72);color:#fff;border:none;border-radius:8px;width:28px;height:28px;cursor:pointer;font-size:14px;line-height:1}
.gallery-empty{color:var(--gris);font-size:14px;margin:8px 0}
.photo-note{font-size:12px;color:var(--gris);margin-top:4px}

/* ============ MOTION — sobre & premium ============ */
.skel{position:relative;overflow:hidden;background:#EEF3F6;border-radius:12px;min-height:16px}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:shimmer 1.4s infinite}
.skel-card{height:150px;border-radius:16px;margin-bottom:12px}
@keyframes shimmer{100%{transform:translateX(100%)}}

@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
  .reveal.in{opacity:1;transform:none}
  .reveal.d1{transition-delay:.07s}.reveal.d2{transition-delay:.14s}.reveal.d3{transition-delay:.21s}.reveal.d4{transition-delay:.28s}.reveal.d5{transition-delay:.35s}

  .hero .eyebrow{animation:fadeUp .7s cubic-bezier(.22,.61,.36,1) both}
  .hero h1{animation:fadeUp .7s .08s cubic-bezier(.22,.61,.36,1) both}
  .hero p.sub{animation:fadeUp .7s .16s cubic-bezier(.22,.61,.36,1) both}
  .hero .search{animation:fadeUp .7s .24s cubic-bezier(.22,.61,.36,1) both}
  .hero .trust-line{animation:fadeUp .7s .32s cubic-bezier(.22,.61,.36,1) both}
  .hero-visual{animation:fadeUp .8s .2s cubic-bezier(.22,.61,.36,1) both}
  .hero .blob{animation:floaty 9s ease-in-out infinite alternate}
  .blob2{animation-duration:11s}
  .pv-float.f1{animation:floaty 5s ease-in-out infinite alternate}
  .pv-float.f2{animation:floaty 6s .5s ease-in-out infinite alternate-reverse}
  @keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
  @keyframes floaty{from{transform:translateY(0)}to{transform:translateY(14px)}}

  .cat,.place,.rev{transition:transform .24s cubic-bezier(.22,.61,.36,1),box-shadow .24s ease,border-color .24s ease}
  .cat:hover,.place:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
  .cat .ic{transition:transform .24s cubic-bezier(.22,1.2,.36,1)}
  .cat:hover .ic{transform:scale(1.12) rotate(-3deg)}
  .btn{transition:transform .16s ease,background .16s ease,box-shadow .16s ease,color .16s ease,filter .16s ease}
  .btn-p:hover,.btn-grad:hover{transform:translateY(-2px)}
  .btn:active{transform:translateY(0) scale(.97)}
  .chip{transition:transform .16s ease,background .16s ease,color .16s ease,border-color .16s ease}
  .chip:hover{transform:translateY(-1px)}
  .step .n{transition:transform .24s cubic-bezier(.22,1.2,.36,1)}
  .step:hover .n{transform:scale(1.08) rotate(-4deg)}

  header{transition:box-shadow .28s ease,backdrop-filter .28s ease}
  .hd{transition:height .28s cubic-bezier(.22,.61,.36,1)}
  header.shrink{box-shadow:0 8px 24px rgba(14,46,82,.09)}
  header.shrink .hd{height:58px}

  .bigscore .n{animation:pop .55s cubic-bezier(.22,1.25,.36,1) both}
  @keyframes pop{from{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}
}
