
/* ===== Divinitel — nocturne céleste, ni slop ni cliché violet ===== */
:root{
  --bg:#0b0d24; --bg2:#11143a; --panel:#15193f; --panel2:#1b1f4d;
  --ink:#f3eee2; --muted:#b9b7c9; --line:rgba(232,200,126,.16);
  --gold:#e8c87e; --gold2:#d4af5f; --rose:#e9a6a0; --aurora:#7fd6c2;
  --live:#5be0a0; --maxw:1160px; --r:18px;
  --shadow:0 20px 60px -25px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(1200px 700px at 78% -8%, rgba(232,200,126,.10), transparent 60%),
    radial-gradient(900px 600px at 8% 12%, rgba(127,214,194,.07), transparent 55%),
    linear-gradient(180deg,#0a0c20,#0b0d24 30%,#0c0f2b);
  color:var(--ink);
  font-family:"Spline Sans",system-ui,sans-serif;
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{ /* poussière d'étoiles */
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:
    radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.7),transparent),
    radial-gradient(1px 1px at 70% 60%,rgba(255,255,255,.5),transparent),
    radial-gradient(1px 1px at 40% 80%,rgba(232,200,126,.6),transparent),
    radial-gradient(1px 1px at 85% 20%,rgba(255,255,255,.45),transparent),
    radial-gradient(1px 1px at 55% 15%,rgba(255,255,255,.4),transparent);
  background-size:auto;
}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:22px;position:relative;z-index:1}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,5vw,3.6rem);font-weight:600}
h2{font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:.6em}
h3{font-size:1.2rem}
p{margin-bottom:1em;color:var(--muted)}
strong{color:var(--ink)}
em{color:var(--gold);font-style:normal}
.gold{color:var(--gold)}

/* ---- top bar live ---- */
.topbar{background:linear-gradient(90deg,rgba(91,224,160,.12),transparent);
  border-bottom:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.topbar .wrap{display:flex;gap:18px;align-items:center;justify-content:space-between;padding-block:7px;flex-wrap:wrap}
.dot{width:8px;height:8px;border-radius:50%;background:var(--live);display:inline-block;
  box-shadow:0 0 0 0 rgba(91,224,160,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(91,224,160,.55)}70%{box-shadow:0 0 0 9px rgba(91,224,160,0)}100%{box-shadow:0 0 0 0 rgba(91,224,160,0)}}
.live-badge{display:inline-flex;gap:7px;align-items:center;color:var(--live);font-weight:600}

/* ---- header ---- */
header.site{position:sticky;top:0;z-index:40;backdrop-filter:blur(12px);
  background:rgba(11,13,36,.72);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;padding-block:14px;gap:16px}
.logo{font-family:"Fraunces",serif;font-size:1.5rem;font-weight:600;letter-spacing:.02em;display:flex;align-items:center;gap:9px}
.logo b{color:var(--gold)}
.logo .moon{width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#fff,#e8c87e 60%,#b88f3a);
  box-shadow:0 0 18px rgba(232,200,126,.5)}
nav.main{display:flex;gap:24px;font-size:.95rem}
nav.main a{color:var(--muted);transition:color .2s}
nav.main a:hover{color:var(--gold)}
nav.main .navcall{display:none}
.hcall{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#1a1402;font-weight:700;padding:10px 18px;border-radius:999px;font-size:.95rem;white-space:nowrap;
  box-shadow:0 10px 24px -10px rgba(232,200,126,.7)}
/* bouton hamburger (caché en desktop) */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;
  padding:10px;border:1px solid var(--line);border-radius:12px;cursor:pointer;background:rgba(255,255,255,.03)}
.burger span{display:block;height:2px;width:100%;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .25s}
@media(max-width:860px){
  .burger{display:flex}
  .hcall{display:none}
  header.site .wrap{flex-wrap:wrap}
  nav.main{display:none;flex-basis:100%;flex-direction:column;gap:0;margin-top:8px;
    border-top:1px solid var(--line)}
  nav.main a{padding:14px 4px;border-bottom:1px solid var(--line);color:var(--ink);font-size:1.05rem}
  nav.main .navcall{display:block;color:var(--gold);font-weight:700;border-bottom:none}
  .navtog:checked ~ nav.main{display:flex}
  .navtog:checked ~ .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .navtog:checked ~ .burger span:nth-child(2){opacity:0}
  .navtog:checked ~ .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---- hero ---- */
.hero{padding:64px 0 40px;position:relative}
.hero .eyebrow{color:var(--gold);text-transform:uppercase;letter-spacing:.28em;font-size:.74rem;font-weight:600;margin-bottom:18px}
.hero h1{max-width:16ch}
.hero h1 .loc{color:var(--gold)}
.hero .lead{font-size:1.18rem;max-width:54ch;margin:20px 0 28px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:stretch}
.cta{display:flex;flex-direction:column;gap:2px;padding:16px 26px;border-radius:16px;min-width:240px;transition:transform .18s,box-shadow .18s}
.cta:hover{transform:translateY(-3px)}
.cta .num{font-family:"Fraunces",serif;font-size:1.7rem;font-weight:600;letter-spacing:.02em}
.cta small{font-size:.78rem;opacity:.9;letter-spacing:.02em}
.cta-primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#1a1402;box-shadow:var(--shadow)}
.cta-primary small{color:#3a2c05}
.cta-secondary{background:var(--panel);border:1px solid var(--line);color:var(--ink)}
.cta-secondary .num{color:var(--gold)}
.trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;font-size:.86rem;color:var(--muted)}
.trust span{display:inline-flex;gap:7px;align-items:center}
.trust b{color:var(--gold)}

/* live panel */
.livepanel{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-top:36px}
.livecard{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:16px;padding:18px 20px}
.livecard .k{font-family:"Fraunces",serif;font-size:2rem;color:var(--gold);line-height:1}
.livecard .l{font-size:.8rem;color:var(--muted);margin-top:6px}

/* ticker */
.ticker{margin-top:22px;background:rgba(127,214,194,.07);border:1px solid var(--line);border-radius:14px;
  padding:11px 16px;font-size:.9rem;color:var(--muted);display:flex;align-items:center;gap:10px;overflow:hidden}
.ticker .dot{flex:none}
#tickmsg{white-space:nowrap;animation:slidein .5s ease}
@keyframes slidein{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:none}}

/* sections */
section{padding:44px 0;position:relative}
.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.card{background:linear-gradient(180deg,var(--panel),rgba(21,25,63,.5));border:1px solid var(--line);
  border-radius:var(--r);padding:26px;transition:border-color .2s,transform .2s}
.card:hover{border-color:rgba(232,200,126,.4);transform:translateY(-3px)}
.card .ic{font-size:1.5rem;margin-bottom:12px}
.card h3{margin-bottom:8px}
.card p{font-size:.96rem;margin:0}
.lede{font-size:1.12rem;color:var(--muted);max-width:62ch}
.prose p{margin-bottom:1.05em}
.prose h2{margin-top:1.4em}

/* steps */
.steps{counter-reset:s;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.step{position:relative;padding:26px 22px 22px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r)}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-16px;left:22px;
  width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-family:"Fraunces",serif;
  background:linear-gradient(135deg,var(--gold),var(--gold2));color:#1a1402;font-weight:700}

/* breadcrumb */
.bc{font-size:.84rem;color:var(--muted);padding:18px 0 0}
.bc a:hover{color:var(--gold)}
.bc span{opacity:.5;margin:0 6px}

/* mesh / links */
.linkgrid{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px}
.linkgrid a{background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:.9rem;color:var(--ink);transition:.18s;display:inline-flex;align-items:center;gap:8px}
.linkgrid a:hover{color:var(--gold);border-color:rgba(232,200,126,.45)}
.linkgrid .km{font-size:.74rem;font-weight:600;color:var(--muted);background:rgba(255,255,255,.06);border-radius:999px;padding:1px 8px}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.chip{background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:.9rem;color:var(--muted);transition:.18s}
.chip:hover{color:var(--gold);border-color:rgba(232,200,126,.4)}
.chips a{background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:.92rem;color:var(--ink);transition:.18s;display:inline-flex;align-items:center;gap:8px}
.chips a:hover{color:var(--gold);border-color:rgba(232,200,126,.45)}
.chips-km .km{font-size:.76rem;font-weight:600;color:var(--muted);background:rgba(255,255,255,.06);border-radius:999px;padding:1px 8px}
.sva-badge{display:inline-block;text-align:center;font-family:"Spline Sans",sans-serif;margin-bottom:14px}
.sva-badge .sva-num{display:block;color:#d23bb0;font-weight:800;font-size:1.55rem;letter-spacing:.06em;margin-bottom:5px}
.sva-badge .sva-tarif{display:block;background:#9c1a8c;color:#fff;font-weight:700;font-size:1.02rem;line-height:1.22;padding:9px 20px 9px 30px;clip-path:polygon(0 0,100% 0,100% 100%,0 100%,15px 50%)}

/* faq */
.faq details{border:1px solid var(--line);border-radius:14px;padding:4px 20px;margin-bottom:12px;background:var(--panel)}
.faq summary{cursor:pointer;padding:16px 0;font-weight:600;color:var(--ink);font-family:"Fraunces",serif;font-size:1.05rem;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold);font-size:1.3rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{padding-bottom:16px;margin:0}

/* big CTA band */
.band{background:
  radial-gradient(600px 300px at 80% 0,rgba(232,200,126,.16),transparent 60%),
  linear-gradient(135deg,#16193f,#0e1130);
  border:1px solid var(--line);border-radius:26px;padding:46px;text-align:center;margin:30px 0}
.band h2{margin-bottom:.3em}
.band .cta-row{justify-content:center}

/* footer */
footer.site{margin-top:50px;border-top:1px solid var(--line);background:rgba(8,10,28,.6);padding:48px 0 28px}
.fcols{display:grid;grid-template-columns:1.6fr 1fr 1.3fr 1fr;gap:36px}
footer h4{font-family:"Fraunces",serif;color:var(--gold);font-size:1rem;margin-bottom:14px}
.fcol a{color:var(--muted);font-size:.92rem;display:block;padding:4px 0;transition:color .18s}
.fcol a:hover{color:var(--gold)}
.fbrand .logo{font-size:1.35rem;margin-bottom:12px}
.fbrand p{font-size:.9rem;color:var(--muted);line-height:1.6;max-width:34ch;margin-bottom:16px}
.ftel{display:flex;flex-direction:column;gap:8px}
.ftel a{display:inline-flex;flex-direction:column;color:var(--gold);font-weight:700;font-size:1rem;line-height:1.2}
.ftel a small{color:var(--muted);font-weight:400;font-size:.78rem;margin-top:1px}
.freg{column-count:2;column-gap:20px}
.freg a{display:block;padding:4px 0;break-inside:avoid;color:var(--muted);font-size:.9rem;transition:color .18s}
.freg a:hover{color:var(--gold)}
.legal{margin-top:38px;padding-top:26px;border-top:1px solid var(--line)}
.legal-bar{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.legal-bar .sva-badge{margin:0;flex:0 0 auto}
.legal-bar .disc{flex:1;min-width:260px;margin:0;font-size:.8rem;color:rgba(185,183,201,.75);line-height:1.65}
.legal-foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:24px;padding-top:18px;border-top:1px solid var(--line);font-size:.82rem;color:rgba(185,183,201,.6)}
.legal-links{display:flex;gap:20px}
.legal-links a{display:inline;color:rgba(185,183,201,.8);font-size:.82rem;padding:0}
.legal-links a:hover{color:var(--gold)}
@media(max-width:860px){
  .fcols{grid-template-columns:1fr 1fr;gap:28px 24px}
  .fbrand{grid-column:1 / -1}
  .legal-bar{flex-direction:column;align-items:center;text-align:center;gap:18px}
  .legal-bar .disc{min-width:0}
  .legal-foot{flex-direction:column;text-align:center;gap:14px}
}
@media(max-width:480px){
  .fcols{grid-template-columns:1fr}
  .freg{grid-template-columns:1fr 1fr}
}

/* sticky mobile call bar */
.callbar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:none;gap:0;
  background:rgba(8,10,28,.95);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.callbar a{flex:1;text-align:center;padding:13px 6px;font-weight:700;font-size:.92rem;display:flex;flex-direction:column;gap:1px}
.callbar a small{font-weight:500;font-size:.68rem;opacity:.85}
.callbar .cb{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#1a1402}
.callbar .nocb{color:var(--gold)}
@media(max-width:860px){.callbar{display:flex}body{padding-bottom:62px}}

.fadein{opacity:0;transform:translateY(16px);animation:fade .7s ease forwards}
@keyframes fade{to{opacity:1;transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.13s}.d3{animation-delay:.22s}.d4{animation-delay:.32s}

/* encart repères INSEE */
.facts{max-width:var(--maxw);margin:-26px auto 8px;padding:0 22px}
.facts-h{font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 2px 10px}
.facts-h small{text-transform:none;letter-spacing:0;opacity:.7}
.facts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.fact{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:14px 12px;text-align:center}
.fact b{display:block;font-family:'Fraunces',serif;font-size:1.5rem;color:var(--gold);line-height:1.1}
.fact span{display:block;font-size:.78rem;color:var(--muted);margin-top:3px}
@media(max-width:640px){.facts-grid{grid-template-columns:repeat(2,1fr)}.fact b{font-size:1.3rem}}
