/* ============================================================
   Guichet Domiciliation — Design system
   Direction : éditorial administratif, sobre, confiance.
   ============================================================ */

:root{
  --paper:#f6f4ee;
  --paper-2:#efece2;
  --ink:#16241f;
  --ink-soft:#3a463f;
  --muted:#697069;
  --line:#ddd6c6;
  --white:#ffffff;
  --green:#0f7a52;
  --green-d:#0b5d3e;
  --green-l:#e7f1ea;
  --terra:#c1652a;
  --terra-d:#9c4f1f;
  --gold:#caa64a;
  --shadow:0 1px 0 var(--line), 0 18px 40px -28px rgba(20,40,30,.5);
  --radius:14px;
  --maxw:1180px;
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Hanken Grotesk","Segoe UI",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
}
img{max-width:100%;display:block}
a{color:inherit}

/* texture de fond discrète */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:radial-gradient(rgba(22,36,31,.045) 1px,transparent 1px);
  background-size:22px 22px;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.tac{text-align:center}

/* ---------- bande tricolore fine ---------- */
.flagbar{height:4px;display:flex}
.flagbar i{flex:1}
.flagbar i:nth-child(1){background:#1b2a6b}
.flagbar i:nth-child(2){background:#f3f1ea}
.flagbar i:nth-child(3){background:var(--terra)}

/* ---------- header ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(246,244,238,.92);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:20px;padding:14px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;font-family:var(--font-display);font-weight:600;font-size:1.28rem;color:var(--ink);letter-spacing:-.01em}
.brand .mk{
  width:38px;height:38px;border-radius:9px;background:var(--ink);color:var(--paper);
  display:grid;place-items:center;font-size:1.1rem;flex:none
}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.nav nav{margin-left:auto;display:flex;align-items:center;gap:20px}
.nav nav a{text-decoration:none;font-weight:600;font-size:.95rem;color:var(--ink-soft)}
.nav nav a:hover{color:var(--green)}
.tel{display:flex;align-items:center;gap:7px;font-weight:700;color:var(--ink);text-decoration:none;white-space:nowrap}
.tel span{font-size:1.05rem}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:700;font-size:.97rem;text-decoration:none;cursor:pointer;
  padding:13px 22px;border-radius:10px;border:1.6px solid transparent;
  transition:transform .12s ease,box-shadow .12s ease;line-height:1
}
.btn:active{transform:translateY(1px)}
.btn-green{background:var(--green);color:#fff;box-shadow:0 10px 22px -12px var(--green)}
.btn-green:hover{background:var(--green-d)}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-lg{padding:17px 30px;font-size:1.05rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;margin-left:auto}
.burger i{width:25px;height:2.4px;background:var(--ink);border-radius:2px}

/* ---------- hero ---------- */
.hero{padding:64px 0 30px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.76rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  color:var(--green-d);background:var(--green-l);
  padding:7px 13px;border-radius:999px;margin-bottom:20px
}
h1{
  font-family:var(--font-display);font-weight:550;
  font-size:clamp(2.2rem,4.4vw,3.5rem);line-height:1.06;letter-spacing:-.02em;
  color:var(--ink)
}
h1 .u{
  background:linear-gradient(transparent 62%,var(--gold) 62%,var(--gold) 92%,transparent 92%);
}
.lead{font-size:1.12rem;color:var(--ink-soft);margin:20px 0 26px;max-width:34em}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.reassure{display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;font-size:.92rem;color:var(--muted)}
.reassure b{color:var(--ink)}
.reassure span{display:flex;align-items:center;gap:7px}
.tick{color:var(--green);font-weight:800}

/* carte prix — ticket perforé */
.ticket{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;position:relative
}
.ticket-top{padding:26px 28px 22px;text-align:center;background:var(--ink);color:var(--paper)}
.ticket-top .k{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:700}
.price{font-family:var(--font-display);font-weight:600;font-size:3.4rem;line-height:1;margin:8px 0 2px}
.price sup{font-size:1.3rem;position:relative;top:-0.9rem}
.ticket-top .ttc{font-size:.85rem;color:#b9c2bb}
.perf{height:0;border-top:2px dashed var(--line);position:relative;background:var(--white)}
.perf::before,.perf::after{content:"";position:absolute;top:-11px;width:22px;height:22px;border-radius:50%;background:var(--paper)}
.perf::before{left:-11px}.perf::after{right:-11px}
.ticket-body{padding:24px 28px 28px}
.ticket-body ul{list-style:none;margin-bottom:20px}
.ticket-body li{display:flex;gap:10px;padding:7px 0;font-size:.96rem;border-bottom:1px dashed var(--paper-2)}
.ticket-body li:last-child{border-bottom:0}
.ticket-body .btn{width:100%;justify-content:center}
.ticket-note{text-align:center;font-size:.8rem;color:var(--muted);margin-top:11px}

/* ---------- sections génériques ---------- */
section{padding:54px 0}
.sec-head{max-width:42em;margin:0 auto 38px}
.sec-head.left{margin-left:0}
h2{font-family:var(--font-display);font-weight:550;font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.12;letter-spacing:-.015em}
h2 .u{background:linear-gradient(transparent 62%,var(--gold) 62%,var(--gold) 92%,transparent 92%)}
.sec-head p{color:var(--ink-soft);margin-top:12px}
.kicker{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--terra-d);margin-bottom:10px}

.band-ink{background:var(--ink);color:var(--paper)}
.band-ink h2,.band-ink .kicker{color:var(--paper)}
.band-ink .kicker{color:var(--gold)}
.band-ink p{color:#c3ccc4}

/* étapes */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;position:relative}
.step .n{font-family:var(--font-display);font-size:2.2rem;color:var(--green);font-weight:600;line-height:1}
.step h3{font-size:1.08rem;margin:10px 0 6px}
.step p{font-size:.94rem;color:var(--muted)}

/* cartes features */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px}
.card .ic{width:46px;height:46px;border-radius:11px;background:var(--green-l);color:var(--green-d);display:grid;place-items:center;font-size:1.3rem;margin-bottom:14px}
.card h3{font-size:1.13rem;margin-bottom:7px}
.card p{font-size:.95rem;color:var(--muted)}

/* ---------- page ville : fiche data ---------- */
.city-hero{padding:48px 0 18px}
.crumb{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.crumb a{color:var(--green-d);text-decoration:none}
.crumb a:hover{text-decoration:underline}
.city-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:46px;align-items:start}
.fiche{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.fiche h3{background:var(--paper-2);padding:14px 20px;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;border-bottom:1px solid var(--line)}
.fiche dl{padding:6px 20px 14px}
.fiche div{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px dashed var(--paper-2)}
.fiche div:last-child{border-bottom:0}
.fiche dt{color:var(--muted);font-size:.92rem}
.fiche dd{font-weight:700;text-align:right}
.mini-cta{padding:18px 20px;background:var(--green-l);border-top:1px solid var(--line);text-align:center}
.mini-cta .price-sm{font-family:var(--font-display);font-size:1.7rem;font-weight:600;color:var(--green-d)}
.mini-cta .btn{width:100%;justify-content:center;margin-top:10px}

.prose h2{margin:34px 0 12px}
.prose h2:first-child{margin-top:0}
.prose p{margin-bottom:14px;color:var(--ink-soft)}
.prose ul{margin:0 0 16px 2px;list-style:none}
.prose ul li{padding:5px 0 5px 26px;position:relative}
.prose ul li::before{content:"›";position:absolute;left:6px;color:var(--green);font-weight:800}

/* faq accordéon */
.faq{max-width:780px;margin:0 auto}
.qa{background:var(--white);border:1px solid var(--line);border-radius:11px;margin-bottom:12px;overflow:hidden}
.qa summary{padding:18px 22px;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";font-size:1.5rem;color:var(--green);font-weight:400;flex:none}
.qa[open] summary::after{content:"–"}
.qa .a{padding:0 22px 20px;color:var(--ink-soft)}

/* maillage interne */
.mesh{display:flex;flex-wrap:wrap;gap:9px}
.mesh a{
  background:var(--white);border:1px solid var(--line);border-radius:8px;
  padding:8px 13px;font-size:.9rem;text-decoration:none;color:var(--ink-soft);font-weight:600
}
.mesh a:hover{border-color:var(--green);color:var(--green-d)}

/* grille départements / régions */
.reg-block{margin-bottom:28px}
.reg-block h3{font-family:var(--font-display);font-weight:600;font-size:1.2rem;margin-bottom:10px;color:var(--ink)}

/* CTA final */
.cta-final{background:var(--ink);color:var(--paper);border-radius:18px;padding:48px 40px;text-align:center}
.cta-final h2{color:var(--paper)}
.cta-final p{color:#c3ccc4;margin:12px auto 22px;max-width:36em}

/* ---------- pages légales / contenu ---------- */
.legacy-content{max-width:820px;margin:0 auto}
.legacy-content h1{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:18px}
.legacy-content h2{font-size:1.35rem;margin:28px 0 10px}
.legacy-content h3{font-size:1.1rem;margin:20px 0 8px}
.legacy-content p,.legacy-content li{color:var(--ink-soft)}
.legacy-content p{margin-bottom:13px}
.legacy-content ul,.legacy-content ol{margin:0 0 16px 22px}
.legacy-content li{margin-bottom:5px}
.legacy-content table{width:100%;border-collapse:collapse;margin:16px 0;font-size:.93rem}
.legacy-content th,.legacy-content td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.legacy-content th{background:var(--paper-2)}
.legacy-content a{color:var(--green-d)}

/* ---------- footer ---------- */
footer.site{background:var(--ink);color:#c3ccc4;padding:52px 0 26px;margin-top:30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px}
footer.site h4{color:var(--paper);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
footer.site a{color:#c3ccc4;text-decoration:none;display:block;padding:3px 0;font-size:.94rem}
footer.site a:hover{color:var(--gold)}
footer.site .brand{color:var(--paper);margin-bottom:12px}
footer.site .brand small{color:#8e978f}
.foot-about p{font-size:.93rem;line-height:1.7}
.agr{font-size:.82rem;color:#8e978f;margin-top:10px}
.foot-bottom{border-top:1px solid #2a3a33;margin-top:34px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem;color:#8e978f}

/* bouton appel flottant mobile */
.floatcall{
  position:fixed;right:18px;bottom:18px;z-index:60;display:flex;
  width:58px;height:58px;border-radius:50%;background:var(--green);color:#fff;
  align-items:center;justify-content:center;font-size:1.5rem;text-decoration:none;
  box-shadow:0 12px 26px -8px rgba(15,122,82,.7)
}

/* ============================================================
   CORRECTIFS  —  lisibilite + anti-debordement
   ============================================================ */

/* cartes blanches placees sur fond sombre (.band-ink) :
   forcer un texte fonce, sinon il herite du clair = invisible */
.card{color:var(--ink-soft)}
.card h3{color:var(--ink)}
.qa{color:var(--ink-soft)}
.qa summary{color:var(--ink)}
.qa .a{color:var(--ink-soft)}

/* anti-debordement horizontal.
   overflow-x:clip ne casse pas le header sticky (contrairement a hidden) */
html,body{max-width:100%}
body{overflow-x:clip}
h1,h2,h3,h4,.lead,p,.qa summary,.mesh a,.crumb,
.fiche dt,.fiche dd,.legacy-content a,.legacy-content td,.legacy-content th{
  overflow-wrap:break-word;
}
h1,h2{-webkit-hyphens:auto;hyphens:auto}
.fiche dt,.fiche dd{min-width:0}
.mesh{max-width:100%}
img,svg,table,iframe{max-width:100%}

/* ============================================================
   IMAGES & ICONES
   ============================================================ */

/* pictogramme du logo dans le carre de marque */
.brand .mk svg{width:22px;height:22px;display:block}

/* icones SVG des cartes (trait = couleur heritee) */
.card .ic svg{width:24px;height:24px;display:block}

/* illustration du hero */
.hero-illu{width:100%;height:auto;display:block}

/* section offre : ticket centre sous le hero */
.offer{padding-top:12px}
.offer .ticket{max-width:430px;margin:0 auto}

/* bouton d'appel flottant toujours affiche :
   on degage le bas du footer pour qu'il ne le recouvre pas */
footer.site{padding-bottom:80px}

/* ============================================================
   RESPONSIVE  (du plus large au plus etroit)
   ============================================================ */

/* le menu desktop complet ne tient pas sous ~1100px :
   bascule en menu burger avant que le nav ne deborde */
@media(max-width:1100px){
  .nav nav,.nav .tel{display:none}
  .burger{display:flex}
  .nav nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--paper);border-bottom:1px solid var(--line);padding:16px 24px;gap:14px;
    max-height:calc(100vh - 64px);overflow-y:auto;
    box-shadow:0 18px 30px -22px rgba(20,40,30,.5)}
  .nav nav.open .tel{display:flex}
  .nav nav.open .btn{justify-content:center}
}

@media(max-width:980px){
  .hero-grid,.city-grid{grid-template-columns:1fr;gap:34px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:720px){
  body{font-size:16px}
  section{padding:40px 0}
  .steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .cta-final{padding:36px 22px}
  .legacy-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  footer.site{padding-bottom:96px}
}

@media(max-width:380px){
  .nav{gap:12px;padding:12px 16px}
  .brand{font-size:1.04rem}
  .brand .mk{width:33px;height:33px;font-size:.95rem}
  .wrap{padding:0 16px}
  .price{font-size:2.9rem}
  .cta-final{padding:32px 18px}
}
