/* devis-forage — design system partagé (from scratch, cf docs/06). Réutilisé par le hub + piliers + villes. */
/* ── Reset & tokens ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg-base:#f2eee4; --bg-surface:#fbf9f4; --bg-elevated:#ffffff; --bg-ink:#14201c;
  --text-primary:#16211d; --text-secondary:#47554e; --text-tertiary:#76847b;
  --accent-600:#16348f; --accent-500:#1d4ed8; --accent-400:#3b82f6; --aqua:#0ea5b7; --clay:#bd6238;
  --border-subtle:rgba(22,33,29,.09); --border-default:rgba(22,33,29,.15);
  --radius-md:10px; --radius-lg:16px; --radius-full:9999px;
  --shadow-card:0 1px 0 var(--border-subtle),0 22px 48px -34px rgba(20,32,28,.55);
}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,-apple-system,sans-serif;background:var(--bg-base);color:var(--text-primary);line-height:1.62;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.06;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.container--narrow{max-width:820px}

/* ── A11y ──────────────────────────────────────────────────────── */
.skip-link{position:absolute;top:-100%;left:16px;z-index:999;padding:8px 16px;background:var(--accent-500);color:#fff;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;transition:top .15s}
.skip-link:focus{top:16px}
.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}
:focus-visible{outline:2px solid var(--accent-500);outline-offset:2px}
@media(prefers-reduced-motion:reduce){.skip-link{transition:none}}

/* ── Reveal ────────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease-out,transform .6s ease-out}
.reveal.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ── Shared ────────────────────────────────────────────────────── */
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--clay)}
.btn{display:inline-flex;align-items:center;gap:.55rem;background:var(--accent-500);color:#fff;font-family:inherit;font-weight:600;font-size:1rem;padding:15px 26px;border-radius:var(--radius-full);border:0;cursor:pointer;transition:transform .15s ease-out,background .15s}
.btn:hover{transform:translateY(-2px);background:var(--accent-600)}
.btn svg{width:18px;height:18px}
@media(prefers-reduced-motion:reduce){.btn:hover{transform:none}}
section{padding:84px 0}
.head{max-width:58ch}
.head h2{font-size:clamp(1.85rem,3.4vw,2.6rem);margin-top:12px}
.head p{color:var(--text-secondary);font-size:1.06rem;margin-top:14px}

/* ── Header ────────────────────────────────────────────────────── */
header{position:sticky;top:0;z-index:40;background:rgba(242,238,228,.84);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle)}
.bar{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{display:flex;align-items:center;gap:9px;font-family:'Fraunces',serif;font-weight:600;font-size:1.24rem;letter-spacing:-.02em}
.logo svg{width:28px;height:28px;flex:none}
.nav-cta{font-size:.92rem;font-weight:600;color:var(--accent-600);display:flex;align-items:center;gap:.45rem;transition:color .15s}
.nav-cta::before{content:"";width:8px;height:8px;border-radius:50%;background:#1aa05f;box-shadow:0 0 0 4px rgba(26,160,95,.16)}
.nav-cta:hover{color:var(--accent-500)}

/* ── Hero ──────────────────────────────────────────────────────── */
.hero{position:relative;padding:60px 0 36px}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:52px;align-items:start}
.hero-copy{position:relative;padding-left:58px}
.gauge{position:absolute;left:0;top:6px;bottom:-12px;width:42px;pointer-events:none}
.gauge svg{height:100%;width:100%;overflow:visible}
.hero h1{font-size:clamp(2.2rem,4.6vw,3.7rem);margin-top:18px}
.hero h1 em{font-style:italic;color:var(--accent-500)}
.lede{font-size:1.16rem;color:var(--text-secondary);max-width:42ch;margin:22px 0 28px}
.points{list-style:none;display:grid;gap:11px}
.points li{display:flex;gap:11px;align-items:flex-start;font-weight:500;font-size:.98rem}
.points svg{width:21px;height:21px;flex:none;color:var(--accent-500);margin-top:2px}
.metrics{display:flex;gap:30px;margin-top:34px;flex-wrap:wrap}
.metric .n{font-family:'Fraunces',serif;font-size:1.85rem;font-weight:600;line-height:1}
.metric .l{font-size:.8rem;color:var(--text-tertiary);max-width:15ch;margin-top:4px}

/* ── Form card ─────────────────────────────────────────────────── */
.form-card{position:relative;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}
.form-card .fc-head{padding:18px 22px 14px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.form-card .fc-head h2{font-size:1.22rem}
.form-card .fc-head p{font-size:.86rem;color:var(--text-secondary);margin-top:3px}
.tag{flex:none;background:var(--clay);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:var(--radius-full)}
.form-card iframe{display:block;width:100%;border:0;background:var(--bg-surface)}

/* ── Strata divider ────────────────────────────────────────────── */
.strata{display:block;width:100%;height:58px}
.band{background:#eae3d4}

/* ── Steps ─────────────────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px;counter-reset:s}
.step{position:relative;padding:24px 20px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:transform .2s ease-out,border-color .2s}
.step:hover{transform:translateY(-3px);border-color:var(--border-default)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'Fraunces',serif;font-size:1.4rem;font-weight:600;color:var(--clay)}
.step h3{font-size:1.1rem;margin:8px 0 5px}
.step p{font-size:.9rem;color:var(--text-secondary)}
@media(prefers-reduced-motion:reduce){.step:hover{transform:none}}

/* ── Services grid ─────────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:42px}
.svc{display:block;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:22px 20px;transition:transform .2s ease-out,border-color .2s}
.svc:hover{transform:translateY(-3px);border-color:var(--accent-400)}
.svc .ic{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;background:rgba(29,78,216,.09);color:var(--accent-500);margin-bottom:13px}
.svc .ic svg{width:21px;height:21px}
.svc h3{font-size:1.02rem}
.svc p{font-size:.87rem;color:var(--text-secondary);margin-top:5px}
.svc .more{font-size:.82rem;font-weight:600;color:var(--accent-500);margin-top:10px;display:inline-block}
@media(prefers-reduced-motion:reduce){.svc:hover{transform:none}}

/* ── Split (pricing + reg) ─────────────────────────────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
.price-list{list-style:none;margin-top:18px}
.price-list li{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--border-subtle)}
.price-list .svcn{font-weight:600}
.price-list .svcn small{display:block;font-weight:400;color:var(--text-tertiary);font-size:.84rem}
.price-list .amt{font-family:'Fraunces',serif;font-weight:600;font-size:1.08rem;white-space:nowrap;color:var(--accent-600)}
.note{font-size:.8rem;color:var(--text-tertiary);margin-top:14px;font-style:italic}
.reg{background:var(--bg-ink);color:#e7eeea;border-radius:var(--radius-lg);padding:32px 30px}
.reg h3{color:#fff;font-size:1.4rem}
.reg ul{list-style:none;margin-top:18px;display:grid;gap:15px}
.reg li{display:flex;gap:12px;font-size:.94rem;color:#bccabf}
.reg li svg{width:19px;height:19px;flex:none;color:var(--aqua);margin-top:3px}
.reg strong{color:#fff;font-weight:600}

/* ── Why ───────────────────────────────────────────────────────── */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.why .ic{font-family:'Fraunces',serif;font-size:1.3rem;color:var(--clay)}
.why h3{font-size:1.15rem;margin:9px 0 5px}
.why p{color:var(--text-secondary);font-size:.93rem}

/* ── FAQ ───────────────────────────────────────────────────────── */
.faq-list{margin-top:34px;border-top:1px solid var(--border-subtle)}
details{border-bottom:1px solid var(--border-subtle)}
summary{cursor:pointer;list-style:none;padding:21px 0;font-family:'Fraunces',serif;font-size:1.14rem;font-weight:500;display:flex;justify-content:space-between;gap:20px;align-items:center}
summary::-webkit-details-marker{display:none}
summary .pm{flex:none;width:25px;height:25px;border:1.5px solid var(--accent-500);border-radius:50%;position:relative;transition:background .2s}
summary .pm::before,summary .pm::after{content:"";position:absolute;inset:0;margin:auto;background:var(--accent-500);transition:.2s}
summary .pm::before{width:10px;height:1.6px}
summary .pm::after{width:1.6px;height:10px}
details[open] summary .pm{background:var(--accent-500)}
details[open] summary .pm::before,details[open] summary .pm::after{background:#fff}
details[open] summary .pm::after{transform:rotate(90deg);opacity:0}
details>p{padding:0 0 23px;color:var(--text-secondary);max-width:76ch}

/* ── Final CTA ─────────────────────────────────────────────────── */
.final{position:relative;overflow:hidden;background:var(--bg-ink);color:#fff;border-radius:22px;padding:58px 32px;text-align:center}
.final h2{color:#fff;font-size:clamp(1.9rem,3.8vw,2.8rem)}
.final p{max-width:46ch;margin:14px auto 28px;color:#b9c7bd;font-size:1.06rem}
.final .btn{background:#fff;color:var(--bg-ink)}
.final .btn:hover{background:#e7eeea}
.final .strata-bg{position:absolute;left:0;right:0;bottom:0;height:46px;opacity:.5}

/* ── Footer ────────────────────────────────────────────────────── */
footer{background:var(--bg-ink);color:#93a399;padding:46px 0 36px;font-size:.9rem}
footer .ft{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
footer .logo{color:#fff}
footer .mentions{max-width:52ch;line-height:1.7;margin-top:12px}
footer .small{font-size:.78rem;color:#6e7e74;display:block;margin-top:12px}
footer nav a{display:block;color:#bccabf;padding:3px 0;transition:color .15s}
footer nav a:hover{color:#fff}

/* ── Breadcrumb (piliers/villes) ───────────────────────────────── */
.crumbs{font-size:.84rem;color:var(--text-tertiary);padding:18px 0 0}
.crumbs a{color:var(--accent-600)}
.crumbs a:hover{text-decoration:underline}
.crumbs span{margin:0 6px;color:var(--text-tertiary)}

/* ── Prose (contenu éditorial des piliers/villes) ──────────────── */
.prose{max-width:72ch}
.prose h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:46px 0 14px}
.prose h3{font-size:1.25rem;margin:30px 0 10px}
.prose p{color:var(--text-secondary);margin:0 0 16px}
.prose ul{margin:0 0 16px 0;padding-left:0;list-style:none;display:grid;gap:10px}
.prose ul li{position:relative;padding-left:28px;color:var(--text-secondary)}
.prose ul li::before{content:"";position:absolute;left:4px;top:9px;width:9px;height:9px;border-radius:50%;background:var(--accent-400)}
.prose strong{color:var(--text-primary);font-weight:600}
.prose .callout{background:var(--bg-surface);border:1px solid var(--border-subtle);border-left:3px solid var(--clay);border-radius:var(--radius-md);padding:18px 20px;margin:22px 0;color:var(--text-secondary)}
.prose .callout strong{color:var(--text-primary)}

/* ── Related (maillage interne) ────────────────────────────────── */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:30px}
.related a{display:block;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:18px 18px;transition:transform .2s,border-color .2s}
.related a:hover{transform:translateY(-3px);border-color:var(--accent-400)}
.related .k{font-family:'Fraunces',serif;font-weight:600;font-size:1.02rem}
.related .d{font-size:.85rem;color:var(--text-secondary);margin-top:4px}
.related .a{font-size:.82rem;font-weight:600;color:var(--accent-500);margin-top:8px;display:inline-block}

/* ── Responsive ────────────────────────────────────────────────── */
@media(max-width:1024px){.steps,.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .split,.why-grid,.related{grid-template-columns:1fr;gap:30px}
  section{padding:64px 0}
}
@media(max-width:560px){
  .steps,.svc-grid{grid-template-columns:1fr}
  .hero-copy{padding-left:46px}
  .metrics{gap:20px}
}
