/* ============================================
   UniK — Design system
   Services techniques industriels
   ============================================ */

:root{
  --bg:#f5f1e8;
  --bg-grid:#ebe5d4;
  --bg-dark:#0e0e0e;
  --ink:#141414;
  --ink-2:#3b3b3b;
  --ink-3:#6e6a60;
  --paper:#faf7ee;
  --line:#d8d2c0;
  --line-dark:#2a2a2a;
  --accent:#e0871a;
  --accent-deep:#b86c10;
  --accent-soft:#f6e6cf;
  --warning:#d4501a;
  --max:1240px;
  --pad:clamp(20px, 4vw, 56px);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:110px}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:"IBM Plex Sans", system-ui, sans-serif;
  font-size:16.5px;
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  background-image:
    linear-gradient(var(--bg-grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--bg-grid) 1px, transparent 1px);
  background-size: 56px 56px;
  background-position: -1px -1px;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.mono{font-family:"JetBrains Mono", ui-monospace, monospace;letter-spacing:.02em}
.display{font-family:"Bricolage Grotesque", "IBM Plex Sans", sans-serif;letter-spacing:-.02em;line-height:1.02}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* ───────────── NAV ───────────── */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(8px);
  background:color-mix(in oklab, var(--bg) 86%, transparent);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:96px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:72px;width:auto}
.brand-tag{
  font-family:"JetBrains Mono", monospace;
  font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);border-left:1px solid var(--line);padding-left:14px;
  display:none;
}
@media (min-width:780px){ .brand-tag{display:block} }
.nav-links{display:none;gap:32px;align-items:center}
@media (min-width:880px){ .nav-links{display:flex} }
.nav-links a{font-size:14.5px;color:var(--ink-2);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{
  content:"";position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:var(--accent);
}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:500;
  background:var(--ink);color:var(--paper);
  padding:11px 18px;border-radius:2px;
  transition:transform .2s, background .2s;
}
.nav-cta:hover{background:var(--accent);transform:translateY(-1px)}
.nav-cta svg{width:14px;height:14px}

/* Burger button et mobile menu : cachés par défaut (visibles seulement en mobile via media query) */
.nav-burger{ display: none; }
.mobile-menu{ display: none; }

/* ───────────── HERO HOME ───────────── */
.hero{padding:clamp(48px,9vw,120px) 0 clamp(56px,8vw,96px)}
.hero-meta{
  display:flex;gap:20px;align-items:center;flex-wrap:wrap;
  font-family:"JetBrains Mono", monospace;
  font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:36px;
}
.hero-meta .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.hero h1{
  font-family:"Bricolage Grotesque", sans-serif;
  font-weight:700;letter-spacing:-.035em;
  font-size:clamp(40px, 8.4vw, 116px);
  line-height:.96;margin:0 0 0 -.04em;
}
.hero h1 .accent{
  background:linear-gradient(180deg, transparent 62%, var(--accent-soft) 62%);
  padding:0 .05em;
}
.hero h1 .stroke{
  -webkit-text-stroke:1.5px var(--ink);
  color:transparent;
  font-style:italic;
  font-weight:500;
}
.hero-sub{
  margin-top:36px;max-width:640px;
  font-size:clamp(17px, 1.6vw, 20.5px);
  color:var(--ink-2);line-height:1.5;
}
.hero-sub strong{color:var(--ink);font-weight:600}
.hero-actions{
  margin-top:44px;display:flex;flex-wrap:wrap;gap:14px;
}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:15px;font-weight:500;
  padding:15px 24px;border-radius:2px;
  transition:transform .2s ease, background .2s, color .2s;
  border:1px solid transparent;
  cursor:pointer;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.btn svg{width:16px;height:16px}

.hero-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:end;}
@media (min-width:1080px){.hero-grid{grid-template-columns:1fr 280px;gap:64px}}
.hero-card{
  border:1px solid var(--line);background:var(--paper);padding:24px;
  font-family:"JetBrains Mono", monospace;font-size:12px;line-height:1.7;
  color:var(--ink-2);
}
.hero-card .row{display:flex;justify-content:space-between;gap:16px;padding:6px 0;border-bottom:1px dashed var(--line)}
.hero-card .row:last-child{border-bottom:none}
.hero-card .label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.12em;font-size:10.5px}
.hero-card .val{color:var(--ink);font-weight:500}
.hero-card .val.acc{color:var(--accent-deep)}
.hero-card-title{
  font-family:"JetBrains Mono", monospace;
  font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);margin-bottom:14px;
  border-bottom:1.5px solid var(--ink);padding-bottom:10px;
}

/* ───────────── HERO INNER PAGES ───────────── */
.page-hero{
  padding:clamp(56px,7vw,100px) 0 clamp(48px,6vw,80px);
  border-bottom:1px solid var(--line);
}
.page-hero-eyebrow{
  font-family:"JetBrains Mono", monospace;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:24px;
  display:flex;align-items:center;gap:14px;
}
.page-hero-eyebrow::before{content:"";width:36px;height:1.5px;background:var(--accent)}
.page-hero h1{
  font-family:"Bricolage Grotesque", sans-serif;
  font-weight:700;letter-spacing:-.035em;
  font-size:clamp(36px, 6vw, 84px);
  line-height:1;margin:0 0 28px;
  max-width:1100px;
}
.page-hero h1 .acc{
  background:linear-gradient(180deg, transparent 62%, var(--accent-soft) 62%);
  padding:0 .05em;
}
.page-hero-lead{
  font-size:clamp(17px, 1.6vw, 20px);
  color:var(--ink-2);line-height:1.5;max-width:680px;margin:0;
}

/* ───────────── SECTION HEADER UTIL ───────────── */
.section{padding:clamp(64px,9vw,120px) 0;border-top:1px solid var(--line)}
.section-eyebrow{
  font-family:"JetBrains Mono", monospace;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:18px;
  display:flex;align-items:center;gap:14px;
}
.section-eyebrow::before{content:"";width:32px;height:1.5px;background:var(--accent)}
.section-title{
  font-family:"Bricolage Grotesque", sans-serif;
  font-weight:700;letter-spacing:-.025em;
  font-size:clamp(30px, 4.6vw, 58px);
  line-height:1.04;margin:0 0 18px;max-width:880px;
}
.section-lead{
  font-size:clamp(16px, 1.4vw, 18.5px);
  color:var(--ink-2);max-width:640px;margin:0;
}

/* ───────────── SYMPTÔMES ───────────── */
.symptoms{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(64px,9vw,120px) 0}
.symptoms-grid{
  display:grid;grid-template-columns:1fr;gap:0;
  border-top:1px solid var(--line);
  margin-top:48px;
}
@media (min-width:760px){.symptoms-grid{grid-template-columns:1fr 1fr}}
.symptom{
  display:flex;align-items:flex-start;gap:20px;
  padding:28px 0;
  border-bottom:1px solid var(--line);
}
@media (min-width:760px){
  .symptom:nth-child(odd){padding-right:40px;border-right:1px solid var(--line)}
  .symptom:nth-child(even){padding-left:40px}
}
.symptom-num{
  font-family:"JetBrains Mono", monospace;
  font-size:11px;color:var(--ink-3);letter-spacing:.18em;
  flex-shrink:0;padding-top:6px;min-width:28px;
}
.symptom-text{font-size:18px;line-height:1.45;color:var(--ink);font-weight:500}
.symptoms-cta{
  margin-top:48px;font-size:clamp(20px, 2.2vw, 28px);
  font-family:"Bricolage Grotesque",sans-serif;font-weight:500;color:var(--ink);
}
.symptoms-cta .acc{color:var(--accent-deep);background:var(--accent-soft);padding:0 .15em}

/* ───────────── OFFRES ───────────── */
.offers-grid{
  display:grid;grid-template-columns:1fr;gap:0;
  margin-top:56px;border-top:1.5px solid var(--ink);
}
@media (min-width:880px){.offers-grid{grid-template-columns:1fr 1fr}}
.offer{
  padding:36px 0;border-bottom:1px solid var(--line);
  position:relative;transition:background .25s;
}
@media (min-width:880px){
  .offer{padding:40px 36px 40px 0}
  .offer:nth-child(even){padding-right:0;padding-left:36px;border-left:1px solid var(--line)}
}
.offer:hover{background:var(--paper)}
.offer-num{
  font-family:"Bricolage Grotesque", sans-serif;
  font-weight:800;letter-spacing:-.04em;
  font-size:88px;line-height:.85;color:var(--ink);
  display:flex;align-items:baseline;gap:10px;margin-bottom:20px;
}
.offer-num .of{
  font-family:"JetBrains Mono", monospace;font-size:11px;color:var(--ink-3);
  letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  align-self:flex-end;padding-bottom:14px;
}
.offer-num .accent-stripe{
  width:34px;height:6px;background:var(--accent);
  margin-left:4px;align-self:flex-end;margin-bottom:14px;
}
.offer-title{
  font-family:"Bricolage Grotesque", sans-serif;font-weight:700;letter-spacing:-.02em;
  font-size:clamp(22px, 2.5vw, 30px);line-height:1.1;margin:0 0 14px;
}
.offer-desc{font-size:16px;line-height:1.55;color:var(--ink-2);margin:0 0 22px;max-width:520px}
.offer-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.tag{
  font-family:"JetBrains Mono", monospace;
  font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 9px;border:1px solid var(--line);
  color:var(--ink-3);background:transparent;
}
.offer-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:"JetBrains Mono", monospace;font-size:12px;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);font-weight:500;
  border-bottom:1px solid var(--ink);padding-bottom:3px;
  transition:color .2s, border-color .2s, gap .2s;
}
.offer-link:hover{color:var(--accent-deep);border-color:var(--accent);gap:12px}
.offer-link svg{width:13px;height:13px;transition:transform .2s}
.offer-link:hover svg{transform:translateX(3px)}

/* ───────────── METHOD (DARK) ───────────── */
.method{
  background:var(--bg-dark);color:var(--paper);
  border-top:none;border-bottom:none;
  padding:clamp(64px,9vw,120px) 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 56px 56px;
}
.method .section-eyebrow{color:#888}
.method .section-eyebrow::before{background:var(--accent)}
.method .section-title{color:var(--paper)}
.method-grid{
  display:grid;grid-template-columns:1fr;gap:0;
  margin-top:64px;border-top:1px solid var(--line-dark);
}
@media (min-width:880px){.method-grid{grid-template-columns:repeat(4,1fr)}}
.step{padding:36px 0;border-bottom:1px solid var(--line-dark)}
@media (min-width:880px){
  .step{padding:36px 28px 36px 0;border-bottom:none;border-right:1px solid var(--line-dark)}
  .step:last-child{border-right:none;padding-right:0}
  .step:nth-child(n+2){padding-left:28px}
}
.step-num{
  font-family:"JetBrains Mono", monospace;
  font-size:11px;letter-spacing:.2em;
  color:var(--accent);margin-bottom:18px;
}
.step-title{
  font-family:"Bricolage Grotesque", sans-serif;font-weight:700;letter-spacing:-.02em;
  font-size:24px;margin:0 0 12px;color:var(--paper);
}
.step-desc{font-size:14.5px;line-height:1.55;color:#b8b3a4;margin:0}

/* ───────────── CLIENTS ───────────── */
.clients-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:56px}
@media (min-width:780px){.clients-grid{grid-template-columns:repeat(3,1fr)}}
.client{
  background:var(--paper);border:1px solid var(--line);
  padding:32px 28px;position:relative;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.client::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:4px;
  background:var(--ink);transition:background .25s;
}
.client:hover{transform:translateY(-4px);box-shadow:0 12px 0 -6px var(--ink)}
.client:hover::before{background:var(--accent)}
.client-icon{
  font-family:"JetBrains Mono", monospace;font-size:11px;letter-spacing:.2em;
  color:var(--accent-deep);margin-bottom:16px;
}
.client-title{
  font-family:"Bricolage Grotesque", sans-serif;font-weight:700;
  font-size:22px;letter-spacing:-.015em;line-height:1.15;margin:0 0 14px;
}
.client-desc{font-size:15px;line-height:1.55;color:var(--ink-2);margin:0 0 20px}
.client-needs{margin:0;padding:0;list-style:none;border-top:1px solid var(--line);padding-top:16px}
.client-needs li{
  font-size:13.5px;color:var(--ink-2);padding:6px 0;
  display:flex;gap:10px;align-items:baseline;
}
.client-needs li::before{content:"+";color:var(--accent-deep);font-family:"JetBrains Mono",monospace;font-weight:500}

/* ───────────── MANIFESTO ───────────── */
.manifesto{padding:clamp(64px,9vw,120px) 0;background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.manifesto-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media (min-width:880px){.manifesto-grid{grid-template-columns:.7fr 1.3fr;gap:80px;align-items:start}}
.manifesto-eyebrow{
  font-family:"JetBrains Mono", monospace;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);
}
.manifesto-text{
  font-family:"Bricolage Grotesque", sans-serif;font-weight:500;letter-spacing:-.02em;
  font-size:clamp(22px, 2.6vw, 34px);line-height:1.18;color:var(--ink);
}
.manifesto-text p{margin:0 0 22px}
.manifesto-text p:last-child{margin-bottom:0}
.manifesto-text .acc{color:var(--accent-deep)}
.manifesto-text .strike{
  text-decoration:line-through;text-decoration-color:var(--accent);
  text-decoration-thickness:3px;color:var(--ink-3);
}

/* ───────────── FINAL CTA ───────────── */
.final-cta{padding:clamp(72px,11vw,140px) 0;background:var(--bg-dark);color:var(--paper);text-align:left}
.final-cta .container{display:grid;grid-template-columns:1fr;gap:36px;align-items:end}
@media (min-width:880px){.final-cta .container{grid-template-columns:1.4fr .8fr}}
.final-cta h2{
  font-family:"Bricolage Grotesque", sans-serif;font-weight:700;letter-spacing:-.035em;
  font-size:clamp(34px, 5.8vw, 76px);line-height:.98;margin:0;
}
.final-cta h2 .acc{color:var(--accent)}
.final-cta-side{display:flex;flex-direction:column;gap:18px}
.final-cta-side p{margin:0;color:#b8b3a4;font-size:15.5px;line-height:1.5}
.final-cta-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.final-cta-actions .btn-primary{background:var(--accent);color:var(--bg-dark)}
.final-cta-actions .btn-primary:hover{background:var(--paper)}
.final-cta-actions .btn-ghost{border-color:var(--paper);color:var(--paper)}
.final-cta-actions .btn-ghost:hover{background:var(--paper);color:var(--bg-dark)}

/* ───────────── FOOTER ───────────── */
footer{background:var(--bg-dark);color:var(--paper);padding:64px 0 32px;border-top:1px solid var(--line-dark)}
.foot-grid{display:grid;grid-template-columns:1fr;gap:40px}
@media (min-width:780px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.foot-brand img{height:80px;width:auto;background:transparent;padding:0;border-radius:0}
.foot-brand p{margin:18px 0 0;color:#a09b8d;font-size:14px;line-height:1.55;max-width:280px}
.foot-col h4{
  font-family:"JetBrains Mono", monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:#888;margin:0 0 18px;font-weight:500;
}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col li{padding:6px 0}
.foot-col a{font-size:14.5px;color:#d6d2c4;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{
  margin-top:56px;padding-top:24px;border-top:1px solid var(--line-dark);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;
  font-family:"JetBrains Mono", monospace;font-size:11px;letter-spacing:.14em;
  color:#666;text-transform:uppercase;
}

/* ───────────── INTERVENTIONS PAGE ───────────── */
.intervention-detail{
  padding:clamp(56px,7vw,96px) 0;
  border-top:1px solid var(--line);
}
.intervention-detail:nth-of-type(even){background:var(--paper)}
.intervention-grid{
  display:grid;grid-template-columns:1fr;gap:48px;align-items:start;
}
@media (min-width:960px){.intervention-grid{grid-template-columns:.4fr .6fr;gap:72px}}
.intervention-marker{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:800;letter-spacing:-.04em;
  font-size:clamp(80px,14vw,180px);line-height:.85;color:var(--ink);
  display:flex;align-items:flex-start;gap:14px;
}
.intervention-marker .of{
  font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--ink-3);
  letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  padding-top:18px;
}
.intervention-marker .accent-stripe{
  width:48px;height:8px;background:var(--accent);
  align-self:flex-end;margin-bottom:18px;margin-left:6px;
}
.intervention-name{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:-.025em;
  font-size:clamp(28px,3.6vw,44px);line-height:1.05;margin:0 0 28px;
}
.intervention-block{margin-bottom:32px}
.intervention-block h4{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-3);margin:0 0 12px;font-weight:500;
}
.intervention-block p{margin:0;font-size:16px;line-height:1.6;color:var(--ink-2)}
.intervention-list{margin:0;padding:0;list-style:none}
.intervention-list li{
  padding:10px 0;border-bottom:1px solid var(--line);
  font-size:15.5px;color:var(--ink-2);
  display:flex;gap:14px;align-items:baseline;
}
.intervention-list li::before{
  content:"→";color:var(--accent-deep);font-family:"JetBrains Mono",monospace;
  font-size:13px;flex-shrink:0;
}
.intervention-list li:last-child{border-bottom:none}

/* ───────────── PRICING ───────────── */
.pricing{padding:clamp(64px,9vw,120px) 0;background:var(--bg-dark);color:var(--paper)}
.pricing .section-eyebrow{color:#888}
.pricing .section-eyebrow::before{background:var(--accent)}
.pricing .section-title{color:var(--paper)}
.pricing .section-lead{color:#b8b3a4}
.price-grid{display:grid;grid-template-columns:1fr;gap:0;margin-top:56px;border-top:1px solid var(--line-dark)}
@media (min-width:780px){.price-grid{grid-template-columns:repeat(3,1fr)}}
.price{padding:32px 0;border-bottom:1px solid var(--line-dark)}
@media (min-width:780px){
  .price{padding:36px 28px 36px 0;border-bottom:none;border-right:1px solid var(--line-dark)}
  .price:last-child{border-right:none;padding-right:0}
  .price:nth-child(n+2){padding-left:28px}
}
.price-label{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;
  color:var(--accent);text-transform:uppercase;margin-bottom:14px;
}
.price-amount{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:-.03em;
  font-size:48px;line-height:1;color:var(--paper);margin-bottom:6px;
}
.price-amount .unit{font-size:18px;color:#888;font-weight:500;letter-spacing:0}
.price-name{font-size:15px;color:#d6d2c4;margin-bottom:14px;font-weight:500}
.price-desc{font-size:13.5px;color:#a09b8d;line-height:1.55}
.price-note{margin-top:40px;font-family:"JetBrains Mono",monospace;font-size:12px;color:#888;letter-spacing:.06em}

/* ───────────── ABOUT ───────────── */
.about-intro{padding:clamp(56px,7vw,100px) 0;background:var(--paper);border-bottom:1px solid var(--line)}
.about-intro-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:start}
@media (min-width:960px){.about-intro-grid{grid-template-columns:1.3fr .7fr;gap:80px}}
.about-text p{font-size:clamp(17px,1.6vw,20px);line-height:1.55;color:var(--ink-2);margin:0 0 20px}
.about-text p strong{color:var(--ink);font-weight:600}
.about-text p:last-child{margin-bottom:0}

.spec-card{
  border:1px solid var(--ink);background:var(--bg);
  padding:28px;
}
.spec-card h3{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;margin:0 0 18px;padding-bottom:12px;
  border-bottom:1.5px solid var(--ink);
}
.spec-row{display:flex;justify-content:space-between;gap:16px;padding:8px 0;font-family:"JetBrains Mono",monospace;font-size:12.5px;border-bottom:1px dashed var(--line)}
.spec-row:last-child{border-bottom:none}
.spec-row .k{color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;font-size:10.5px}
.spec-row .v{color:var(--ink);font-weight:500}

/* Titre de groupe dans la fiche technique (ex: "Zone d'intervention") */
.spec-row.spec-group-title{
  border-bottom:1px solid var(--ink);
  padding-top:12px;padding-bottom:6px;
  margin-top:6px;
}
.spec-row.spec-group-title .k{
  color:var(--ink);font-weight:700;font-size:11px;
}
/* Sous-lignes (Primaire, Étendue, Régions) */
.spec-row.spec-sub{
  border-bottom:1px dashed var(--line);
  padding:6px 0;
}
.spec-row.spec-sub .k{
  color:var(--ink-3);font-size:10px;text-transform:none;letter-spacing:0;
}
.spec-row.spec-sub .v{
  font-size:12px;
}

/* skills grid */
.skills{padding:clamp(64px,9vw,120px) 0;border-top:1px solid var(--line)}
.skills-grid{display:grid;grid-template-columns:1fr;gap:0;margin-top:56px;border-top:1.5px solid var(--ink)}
@media (min-width:780px){.skills-grid{grid-template-columns:repeat(3,1fr)}}
.skill{
  padding:32px 0;border-bottom:1px solid var(--line);
}
@media (min-width:780px){
  .skill{padding:36px 28px 36px 0;border-bottom:none;border-right:1px solid var(--line)}
  .skill:last-child{border-right:none;padding-right:0}
  .skill:nth-child(n+2){padding-left:28px}
}
.skill-num{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;
  color:var(--accent-deep);margin-bottom:14px;
}
.skill-title{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:-.02em;
  font-size:24px;line-height:1.1;margin:0 0 12px;
}
.skill-desc{font-size:14.5px;line-height:1.55;color:var(--ink-2);margin:0}

/* yes / no list */
.yesno{display:grid;grid-template-columns:1fr;gap:0;margin-top:56px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media (min-width:780px){.yesno{grid-template-columns:1fr 1fr}}
.yesno-col{padding:36px 0}
@media (min-width:780px){
  .yesno-col:first-child{padding-right:40px;border-right:1px solid var(--line)}
  .yesno-col:last-child{padding-left:40px}
}
.yesno-label{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;margin-bottom:24px;display:flex;align-items:center;gap:12px;
}
.yesno-label.yes{color:var(--accent-deep)}
.yesno-label.no{color:var(--ink-3)}
.yesno-label .mark{
  width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:14px;
}
.yesno-label.yes .mark{background:var(--accent);color:var(--bg-dark)}
.yesno-label.no .mark{background:var(--ink);color:var(--paper);text-decoration:line-through}
.yesno-list{margin:0;padding:0;list-style:none}
.yesno-list li{
  padding:14px 0;font-size:16px;color:var(--ink);font-weight:500;line-height:1.4;
  border-bottom:1px solid var(--line);
}
.yesno-list li:last-child{border-bottom:none}
.yesno-col.no .yesno-list li{color:var(--ink-3);font-weight:400}

/* ───────────── REALISATIONS ───────────── */
.case-grid{
  display:grid;grid-template-columns:1fr;gap:0;
  margin-top:56px;border-top:1.5px solid var(--ink);
}
@media (min-width:880px){.case-grid{grid-template-columns:1fr 1fr}}
.case{
  padding:40px 0;border-bottom:1px solid var(--line);
  position:relative;
}
@media (min-width:880px){
  .case{padding:44px 36px 44px 0}
  .case:nth-child(even){padding-right:0;padding-left:36px;border-left:1px solid var(--line)}
}
.case-meta{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);
  display:flex;flex-wrap:wrap;gap:14px;margin-bottom:20px;
}
.case-meta span{padding:4px 10px;border:1px solid var(--line);background:var(--paper)}
.case-meta .type{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.case-title{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:-.02em;
  font-size:clamp(22px,2.4vw,28px);line-height:1.15;margin:0 0 18px;
}
.case-text{font-size:15.5px;line-height:1.6;color:var(--ink-2);margin:0 0 20px}
.case-text strong{color:var(--ink);font-weight:600}
.case-result{
  border-top:1px solid var(--line);padding-top:18px;margin-top:18px;
  font-family:"JetBrains Mono",monospace;font-size:12.5px;color:var(--accent-deep);
  letter-spacing:.06em;line-height:1.55;
}
.case-result::before{content:"→ Résultat ";color:var(--ink-3);text-transform:uppercase;font-size:10.5px;letter-spacing:.18em;display:block;margin-bottom:6px}

/* placeholder note */
.note{
  margin-top:56px;border:1px dashed var(--ink-3);padding:24px;
  background:var(--paper);
  font-family:"JetBrains Mono",monospace;font-size:13px;line-height:1.6;color:var(--ink-2);
}
.note strong{color:var(--ink)}
.note .badge{
  display:inline-block;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  background:var(--accent);color:var(--bg-dark);padding:3px 9px;margin-bottom:12px;font-weight:500;
}

/* ───────────── CONTACT ───────────── */
.contact-grid{
  display:grid;grid-template-columns:1fr;gap:48px;align-items:start;margin-top:56px;
}
@media (min-width:960px){.contact-grid{grid-template-columns:1fr 1fr;gap:72px}}
.contact-block{
  border:1px solid var(--line);background:var(--paper);padding:32px;
  display:flex;flex-direction:column;gap:18px;
}
.contact-block.dark{background:var(--bg-dark);color:var(--paper);border-color:var(--bg-dark)}
.contact-eyebrow{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--accent-deep);
}
.contact-block.dark .contact-eyebrow{color:var(--accent)}
.contact-title{
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;letter-spacing:-.02em;
  font-size:clamp(24px,2.8vw,32px);line-height:1.1;margin:0;
}
.contact-block.dark .contact-title{color:var(--paper)}
.contact-desc{font-size:15.5px;line-height:1.55;color:var(--ink-2);margin:0}
.contact-block.dark .contact-desc{color:#b8b3a4}
.contact-list{list-style:none;margin:8px 0 0;padding:0;border-top:1px solid var(--line);padding-top:18px}
.contact-block.dark .contact-list{border-color:var(--line-dark)}
.contact-list li{
  padding:8px 0;font-size:14.5px;display:flex;justify-content:space-between;gap:14px;
  border-bottom:1px dashed var(--line);
}
.contact-block.dark .contact-list li{border-color:var(--line-dark);color:#d6d2c4}
.contact-list li:last-child{border-bottom:none}
.contact-list .k{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3);
}
.contact-block.dark .contact-list .k{color:#888}
.contact-list .v{color:var(--ink);font-weight:500;text-align:right}
.contact-block.dark .contact-list .v{color:var(--paper)}
.contact-list .v a{color:inherit;border-bottom:1px solid var(--line);padding-bottom:1px;transition:color .2s, border-color .2s}
.contact-list .v a:hover{color:var(--accent-deep);border-color:var(--accent)}
.contact-block.dark .contact-list .v a:hover{color:var(--accent)}

/* Titre de groupe dans la liste contact (ex: Zone d'intervention) */
.contact-list li.contact-group-title{
  border-bottom:1px solid var(--ink);
  padding:14px 0 6px;
  margin-top:6px;
}
.contact-block.dark .contact-list li.contact-group-title{border-bottom-color:var(--paper)}
.contact-list li.contact-group-title .k{
  color:var(--ink);font-weight:700;font-size:11.5px;
}
.contact-block.dark .contact-list li.contact-group-title .k{color:var(--paper)}
/* Sous-lignes du groupe */
.contact-list li.contact-sub{
  padding:6px 0;border-bottom:1px dashed var(--line);
}
.contact-list li.contact-sub .k{
  font-size:10.5px;text-transform:none;letter-spacing:.04em;
}
.contact-list li.contact-sub .v{
  font-size:13.5px;
}
.contact-block .btn{margin-top:8px;align-self:flex-start}
.contact-block.dark .btn-primary{background:var(--accent);color:var(--bg-dark)}
.contact-block.dark .btn-primary:hover{background:var(--paper)}

/* faq */
.faq{padding:clamp(64px,9vw,120px) 0;border-top:1px solid var(--line)}
.faq-list{margin-top:48px;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:24px 0;cursor:pointer;list-style:none;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:600;letter-spacing:-.015em;
  font-size:clamp(18px,1.8vw,21px);color:var(--ink);
  transition:color .2s;
}
.faq-q::-webkit-details-marker{display:none}
.faq-q:hover{color:var(--accent-deep)}
.faq-q::after{
  content:"+";font-family:"JetBrains Mono",monospace;font-size:22px;font-weight:400;
  color:var(--accent-deep);transition:transform .2s;flex-shrink:0;
}
.faq-item[open] .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 0 24px;font-size:16px;line-height:1.6;color:var(--ink-2);max-width:780px}

/* reveal anim */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* selection */
::selection{background:var(--accent);color:var(--bg-dark)}

/* ================================================================
   MOBILE OPTIMIZATIONS — iPhone Safari priority
   Breakpoints : 768px (tablette portrait), 600px (mobile L), 380px (mobile S)
   ================================================================ */

/* ─────────────  Base mobile (<= 768px) ───────────── */
@media (max-width: 768px){
  :root{
    --pad: 22px;  /* marges latérales un peu plus généreuses */
  }

  body{
    font-size: 16px;       /* taille de base lisible */
    line-height: 1.55;
    -webkit-text-size-adjust: 100%; /* empêche iOS d'ajuster auto la taille */
  }

  html{
    scroll-padding-top: 80px;
  }

  /* ─── NAV ─── */
  .nav{
    position: sticky;
  }
  .nav-inner{
    height: 68px;          /* nav plus compacte sur mobile */
  }
  .brand img{
    height: 44px;          /* logo plus petit sur mobile */
  }
  .brand-tag{
    display: none !important;
  }
  /* Cacher les anciens liens nav */
  .nav-links{
    display: none !important;
  }
  /* Bouton CTA plus compact */
  .nav-cta{
    padding: 9px 14px;
    font-size: 13px;
  }
  .nav-cta-text-full{ display: none; }
  .nav-cta svg{ width: 12px; height: 12px; }

  /* ─── MENU HAMBURGER ─── */
  .nav-burger{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: transparent;
    border: 1px solid var(--line);
    border-radius: 4px;
    cursor: pointer;
    padding: 0;
    margin-left: 10px;
    transition: background .2s, border-color .2s;
  }
  .nav-burger:hover, .nav-burger:focus{
    background: var(--paper);
    border-color: var(--ink);
  }
  .nav-burger-icon{
    position: relative;
    width: 18px;
    height: 14px;
  }
  .nav-burger-icon span{
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--ink);
    border-radius: 1px;
    transition: transform .3s, opacity .2s, top .3s;
  }
  .nav-burger-icon span:nth-child(1){ top: 0; }
  .nav-burger-icon span:nth-child(2){ top: 6px; }
  .nav-burger-icon span:nth-child(3){ top: 12px; }
  .nav-burger.open .nav-burger-icon span:nth-child(1){
    top: 6px;
    transform: rotate(45deg);
  }
  .nav-burger.open .nav-burger-icon span:nth-child(2){
    opacity: 0;
  }
  .nav-burger.open .nav-burger-icon span:nth-child(3){
    top: 6px;
    transform: rotate(-45deg);
  }

  /* Menu mobile en plein écran */
  .mobile-menu{
    display: block;
    position: fixed;
    inset: 68px 0 0 0;
    background: var(--bg);
    background-image:
      linear-gradient(var(--bg-grid) 1px, transparent 1px),
      linear-gradient(90deg, var(--bg-grid) 1px, transparent 1px);
    background-size: 40px 40px;
    z-index: 49;
    padding: 32px var(--pad);
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    visibility: hidden;
  }
  .mobile-menu.open{
    transform: translateX(0);
    visibility: visible;
  }
  .mobile-menu-list{
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .mobile-menu-list li{
    border-bottom: 1px solid var(--line);
  }
  .mobile-menu-list a{
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 22px 0;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 24px;
    font-weight: 600;
    letter-spacing: -.02em;
    color: var(--ink);
  }
  .mobile-menu-list a::after{
    content: "→";
    color: var(--accent-deep);
    font-size: 22px;
    font-family: "JetBrains Mono", monospace;
  }
  .mobile-menu-cta{
    margin-top: 32px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .mobile-menu-cta .btn{
    width: 100%;
    justify-content: center;
    padding: 17px 24px;
    font-size: 15px;
  }
  .mobile-menu-info{
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px dashed var(--line);
    font-family: "JetBrains Mono", monospace;
    font-size: 12px;
    letter-spacing: .08em;
    color: var(--ink-3);
    line-height: 1.8;
  }
  .mobile-menu-info a{
    color: var(--ink);
    border-bottom: 1px solid var(--line);
  }

  body.mobile-menu-open{
    overflow: hidden;
  }

  /* ─── HERO ─── */
  .hero{ padding: 36px 0 32px; }
  .hero-grid{
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .hero-meta{
    margin-bottom: 22px;
    font-size: 10.5px;
    gap: 12px;
  }
  .hero h1{
    font-size: clamp(40px, 11vw, 56px);
    line-height: .98;
    margin-left: 0;
    letter-spacing: -.025em;
  }
  .hero-sub{
    margin-top: 24px;
    font-size: 16.5px;
    line-height: 1.55;
  }
  .hero-actions{
    margin-top: 28px;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .hero-card{
    padding: 18px 18px;
    display: none;       /* on cache la fiche technique sur mobile pour gagner du scroll */
  }
  .hero-card-title{ font-size: 9.5px; padding-bottom: 8px; margin-bottom: 10px; }

  /* ─── BOUTONS — confortables au pouce ─── */
  .btn{
    padding: 16px 22px;     /* hauteur ~52px (au-dessus du min 44px d'Apple) */
    font-size: 15px;
    width: 100%;            /* full width par défaut sur mobile */
    justify-content: center;
  }
  .hero-actions .btn,
  .final-cta-actions .btn,
  .form-submit .btn{ width: auto; }
  .form-submit .btn{ width: 100%; }

  /* ─── PAGE HERO (pages internes) ─── */
  .page-hero{ padding: 36px 0 32px; }
  .page-hero h1{
    font-size: clamp(34px, 9vw, 52px);
    line-height: 1;
    margin-bottom: 18px;
  }
  .page-hero-lead{ font-size: 16px; line-height: 1.55; }

  /* ─── SECTIONS — réduire padding vertical ─── */
  .section,
  .symptoms,
  .method,
  .manifesto,
  .skills,
  .faq,
  .pricing,
  .intervention-detail,
  .about-intro{
    padding: 48px 0;
  }
  .final-cta{ padding: 56px 0; }

  .section-title{
    font-size: clamp(26px, 7vw, 36px);
    line-height: 1.1;
    margin-bottom: 14px;
  }
  .section-lead{ font-size: 15.5px; line-height: 1.55; }
  .section-eyebrow{
    font-size: 10px;
    letter-spacing: .18em;
    margin-bottom: 14px;
  }

  /* ─── SYMPTÔMES ─── */
  .symptoms-grid{
    grid-template-columns: 1fr;
    margin-top: 32px;
  }
  .symptom{ padding: 22px 0; }
  .symptom:nth-child(odd),
  .symptom:nth-child(even){
    padding-right: 0;
    padding-left: 0;
    border-right: none;
  }
  .symptom-text{ font-size: 16.5px; line-height: 1.45; }
  .symptoms-cta{
    margin-top: 32px;
    font-size: 19px;
    line-height: 1.3;
  }

  /* ─── OFFRES ─── */
  .offers-grid{
    grid-template-columns: 1fr;
    margin-top: 32px;
  }
  .offer{
    padding: 28px 0 !important;
    border-left: none !important;
  }
  .offer-num{ font-size: 64px; margin-bottom: 14px; }
  .offer-title{ font-size: 22px; line-height: 1.15; }
  .offer-desc{ font-size: 15.5px; }

  /* ─── MÉTHODE ─── */
  .method-grid{
    grid-template-columns: 1fr;
    margin-top: 32px;
  }
  .step{
    padding: 26px 0 !important;
    border-right: none !important;
  }
  .step-title{ font-size: 21px; }

  /* ─── CLIENTS ─── */
  .clients-grid{
    grid-template-columns: 1fr;
    margin-top: 28px;
  }
  .client{ padding: 24px 22px; }
  .client-title{ font-size: 20px; }

  /* ─── MANIFESTO ─── */
  .manifesto-grid{ grid-template-columns: 1fr; gap: 18px; }
  .manifesto-text{
    font-size: 21px;
    line-height: 1.25;
  }
  .manifesto-text p{ margin: 0 0 16px; }

  /* ─── SKILLS ─── */
  .skills-grid{
    grid-template-columns: 1fr;
    margin-top: 32px;
  }
  .skill{
    padding: 24px 0 !important;
    border-right: none !important;
  }
  .skill-title{ font-size: 20px; }

  /* ─── ABOUT INTRO ─── */
  .about-intro-grid{ grid-template-columns: 1fr; gap: 28px; }
  .about-text p{ font-size: 17px; line-height: 1.55; }
  .spec-card{ padding: 22px; }

  /* ─── YES/NO ─── */
  .yesno{ grid-template-columns: 1fr; }
  .yesno-col{ padding: 26px 0; }
  .yesno-col:first-child{
    padding-right: 0;
    border-right: none;
    border-bottom: 1px solid var(--line);
  }
  .yesno-col:last-child{ padding-left: 0; }
  .yesno-list li{ font-size: 15.5px; padding: 12px 0; }

  /* ─── PRICING ─── */
  .price-grid{ grid-template-columns: 1fr; margin-top: 32px; }
  .price{
    padding: 24px 0 !important;
    border-right: none !important;
  }
  .price-amount{ font-size: 38px; }

  /* ─── INTERVENTION DETAIL ─── */
  .intervention-grid{
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .intervention-marker{ font-size: 80px; line-height: .9; }
  .intervention-name{ font-size: 26px; }
  .intervention-block{ margin-bottom: 24px; }

  /* ─── CASE GRID (réalisations) ─── */
  .case-grid{ grid-template-columns: 1fr; margin-top: 32px; }
  .case{
    padding: 28px 0 !important;
    border-left: none !important;
  }
  .case-title{ font-size: 20px; line-height: 1.2; }
  .case-text{ font-size: 15px; line-height: 1.55; }

  /* ─── FINAL CTA ─── */
  .final-cta .container{ grid-template-columns: 1fr; gap: 24px; }
  .final-cta h2{ font-size: clamp(32px, 8.5vw, 48px); line-height: .98; }
  .final-cta-actions{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .final-cta-actions .btn{ width: 100%; }

  /* ─── FOOTER ─── */
  footer{ padding: 48px 0 24px; }
  .foot-grid{ grid-template-columns: 1fr; gap: 28px; }
  .foot-brand img{ height: 64px; }
  .foot-bottom{
    flex-direction: column;
    gap: 8px;
    margin-top: 36px;
  }

  /* ─── FAQ ─── */
  .faq-q{
    padding: 18px 0;
    font-size: 17px;
    gap: 14px;
  }
  .faq-a{ font-size: 15.5px; }

  /* ─── CONTACT ─── */
  .contact-grid{ grid-template-columns: 1fr; gap: 22px; margin-top: 32px; }
  .contact-block{ padding: 24px 22px; }
  .contact-list li{
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 10px 0;
  }
  .contact-list .v{ text-align: left; }

  /* ─── LEGAL PAGES ─── */
  .legal-grid{ grid-template-columns: 1fr; gap: 0; }
  /* On cache le sommaire sur mobile : il prend trop de place et bug en superposition */
  .legal-toc{ display: none !important; }
  .legal-content h2{ font-size: 22px; margin: 32px 0 14px; padding-top: 18px; }

  /* ─── 404 ─── */
  .nf-grid{ grid-template-columns: 1fr; gap: 24px; }
  .nf-code{ font-size: clamp(120px, 32vw, 180px); }
  .nf-title{ font-size: clamp(26px, 6.5vw, 38px); }
  .nf-actions{ flex-direction: column; align-items: stretch; gap: 10px; }
  .nf-actions .btn{ width: 100%; }
}

/* ─────────────  FORMULAIRE RDV — confort de saisie iPhone ───────────── */
@media (max-width: 980px){
  .form-grid{
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .form-aside{
    position: static;
    order: 2;          /* l'aside passe APRÈS le formulaire sur mobile */
  }
  .form-aside-card{ padding: 18px; }
}

@media (max-width: 768px){
  .form-wrap{ padding: 28px 0 56px; }

  form{ gap: 22px; }

  .field{ gap: 7px; }

  .field label{
    font-size: 11.5px;
    letter-spacing: .14em;
  }

  /* Inputs : taille minimum 16px pour empêcher le ZOOM auto d'iOS Safari */
  .field input,
  .field select,
  .field textarea{
    font-size: 16px !important;
    padding: 15px 14px;
    border-radius: 6px;        /* coins arrondis = plus moderne sur mobile */
    -webkit-appearance: none;  /* unifier l'apparence iOS */
    appearance: none;
  }

  /* Select : ajout d'une flèche custom (sinon iOS la cache) */
  .field select{
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3 6l5 5 5-5' fill='none' stroke='%236e6a60' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 14px;
    padding-right: 40px;
  }

  .field textarea{
    min-height: 140px;
    line-height: 1.5;
  }

  .field-row{
    grid-template-columns: 1fr;
    gap: 22px;
  }

  /* Radio cards : pleine largeur, plus aérées */
  .radio-grid{
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .radio-card{
    /* On force avec !important pour ne pas être écrasé par le CSS desktop */
    padding: 18px 18px 18px 72px !important;
    font-size: 15px;
    border-radius: 6px;
    min-height: 70px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    box-sizing: border-box !important;
  }
  .radio-card .t{
    font-size: 16px !important;
    line-height: 1.25 !important;
    display: block !important;
  }
  .radio-card .sub{
    margin-top: 5px !important;
    font-size: 13px !important;
    line-height: 1.4 !important;
    display: block !important;
  }
  .radio-card input{
    left: 16px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 24px !important;
    height: 24px !important;
    /* Apparence custom pour que le coché soit BIEN visible sur iOS Safari */
    -webkit-appearance: none !important;
    appearance: none !important;
    border: 2px solid var(--ink-3) !important;
    border-radius: 50% !important;
    background: var(--paper) !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: border-color .15s, background .15s !important;
  }
  .radio-card input:checked{
    border-color: var(--accent-deep) !important;
    background: radial-gradient(circle, var(--accent-deep) 0 6px, var(--paper) 7px 100%) !important;
  }
  /* SÉLECTION TRÈS VISIBLE : fond légèrement orangé + bordure orange épaisse + bande orange */
  .radio-card:has(input:checked){
    border-color: var(--accent-deep) !important;
    background: var(--accent-soft) !important;
    box-shadow: inset 6px 0 0 var(--accent-deep), 0 0 0 1px var(--accent-deep) !important;
  }
  .radio-card:has(input:checked) .t{
    color: var(--ink) !important;
  }

  /* Checkbox RGPD plus grosse */
  .check{
    font-size: 14px;
    line-height: 1.55;
    gap: 14px;
    padding: 6px 0;
  }
  .check input{
    width: 22px;
    height: 22px;
    margin-top: 1px;
  }

  /* Bouton submit pleine largeur */
  .form-submit{
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    padding-top: 22px;
  }
  .form-submit .btn{
    width: 100%;
    padding: 18px 24px;
    font-size: 16px;
    justify-content: center;
  }
  .form-submit .note{
    text-align: center;
    font-size: 12px;
  }

  /* Message succès */
  .success{ padding: 24px 22px; border-radius: 6px; }
  .success h3{ font-size: 22px; }
}

/* ─────────────  Très petits écrans (iPhone SE, etc.) ───────────── */
@media (max-width: 380px){
  :root{ --pad: 18px; }

  .nav-cta{
    padding: 8px 12px;
    font-size: 12px;
  }
  .nav-cta-text-short{ display: inline; }
  .nav-cta-text-long{ display: none; }
  .nav-cta svg{ display: none; }

  .brand img{ height: 38px; }

  .hero h1{ font-size: clamp(36px, 11vw, 48px); }
  .section-title{ font-size: 24px; }
  .offer-num{ font-size: 56px; }
  .intervention-marker{ font-size: 64px; }
}

/* ─────────────  Améliorations transverses pour zones cliquables ───────────── */
@media (max-width: 768px){
  /* Liens du footer : zone tappable plus grande */
  .foot-col li{ padding: 4px 0; }
  .foot-col a{
    display: block;
    padding: 8px 0;
    font-size: 15px;
  }

  /* Liens d'offre / "En savoir plus" */
  .offer-link{
    padding: 12px 0;
    font-size: 12.5px;
  }

  /* Tags */
  .tag{ font-size: 10.5px; padding: 6px 10px; }

  /* Anti-scroll horizontal accidentel */
  body{ overflow-x: hidden; }
}
