/* =========================================
   Eric Lebon – Infirmier libéral à Rochefort-du-Gard
   Palette fidèle au site original (bleu Kadence)
   ========================================= */

:root{
  /* Palette identitaire — reprise du site existant */
  --c-blue:       #2B6CB0;   /* bleu principal */
  --c-blue-dark:  #215387;   /* bleu hover / foncé */
  --c-blue-deep:  #0d3276;   /* bleu marine profond (CTA, logo) */
  --c-blue-link:  #1159af;
  --c-blue-soft:  #E6EFF8;   /* bleu très clair (fonds) */
  --c-blue-soft2: #F1F6FB;

  /* Gris Kadence (textes) */
  --c-ink:        #1A202C;
  --c-ink-2:      #2D3748;
  --c-muted:      #4A5568;
  --c-muted-2:    #718096;

  /* Fonds */
  --c-bg:         #F7FAFC;
  --c-surface:    #ffffff;
  --c-surface-2:  #EDF2F7;

  /* Lignes */
  --c-line:       #E2E8F0;
  --c-line-2:     #CBD5E0;

  --radius-s: 10px;
  --radius:   14px;
  --radius-l: 22px;

  --shadow-xs: 0 1px 2px rgba(15,32,44,.05);
  --shadow-s:  0 4px 12px rgba(15,32,44,.06);
  --shadow:    0 14px 34px -14px rgba(15,32,44,.20), 0 4px 10px rgba(15,32,44,.05);
  --shadow-l:  0 28px 60px -22px rgba(13,50,118,.28);

  --max: 1180px;

  --ff: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff);
  font-size:16.5px;
  line-height:1.65;
  color:var(--c-ink-2);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}

h1,h2,h3{color:var(--c-ink);line-height:1.2;letter-spacing:-0.015em;font-weight:700;margin:0 0 .4em}
h1{font-size:clamp(2rem, 2vw + 1.4rem, 3.1rem);letter-spacing:-0.02em;line-height:1.1}
h2{font-size:clamp(1.55rem, 1.1vw + 1.05rem, 2.15rem)}
h3{font-size:1.08rem;font-weight:600;letter-spacing:0}
p{margin:0 0 1em}

a{color:var(--c-blue-link);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--c-blue-deep)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 22px;position:relative}

.skip{position:absolute;left:-9999px;top:0;background:#000;color:#fff;padding:8px 12px;z-index:9999}
.skip:focus{left:10px;top:10px}

/* ===== HEADER ===== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(10px);
  -webkit-backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--c-line);
}
.header-inner{display:flex;align-items:center;gap:18px;padding:12px 22px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}
.brand-logo{width:48px;height:48px;border-radius:50%;object-fit:contain;background:#fff;border:1px solid var(--c-line)}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{font-size:1.05rem;font-weight:700;color:var(--c-ink);letter-spacing:-0.01em}
.brand-text small{color:var(--c-muted);font-size:.8rem}

.nav{margin-left:auto}
.nav ul{list-style:none;display:flex;gap:4px;margin:0;padding:0}
.nav a{
  color:var(--c-muted);font-weight:500;font-size:.95rem;
  padding:8px 14px;border-radius:8px;
  transition:background .18s ease, color .18s ease;
}
.nav a:hover{background:var(--c-blue-soft);color:var(--c-blue-deep)}

.cta{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;font-weight:600;text-decoration:none;font-size:.94rem;white-space:nowrap;transition:transform .15s ease, box-shadow .15s ease, background .2s ease}
.cta--phone{background:var(--c-blue-deep);color:#fff;box-shadow:0 8px 20px -10px rgba(13,50,118,.6)}
.cta--phone:hover{background:var(--c-blue-dark);color:#fff;transform:translateY(-1px)}

/* ===== Boutons ===== */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 26px;border-radius:999px;
  font-weight:600;text-decoration:none;font-size:.98rem;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  border:1.5px solid transparent;cursor:pointer;
}
.btn--primary{
  background:var(--c-blue-deep);color:#fff;
  box-shadow:0 12px 26px -12px rgba(13,50,118,.55);
}
.btn--primary:hover{background:var(--c-blue-dark);color:#fff;transform:translateY(-2px);box-shadow:0 18px 36px -14px rgba(13,50,118,.6)}
.btn--ghost{background:transparent;color:var(--c-blue-deep);border-color:var(--c-blue);}
.btn--ghost:hover{background:var(--c-blue-soft);color:var(--c-blue-deep)}
.btn--light{background:#fff;color:var(--c-blue-deep)}
.btn--light:hover{background:var(--c-blue-soft);color:var(--c-blue-deep);transform:translateY(-2px)}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--outline-light:hover{background:rgba(255,255,255,.1);color:#fff;border-color:#fff}

/* ===== HERO ===== */
.hero{
  position:relative;
  padding:clamp(44px, 5.5vw, 72px) 0 clamp(30px, 4vw, 48px);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(900px 380px at -10% 10%, rgba(43,108,176,.10), transparent 60%),
    radial-gradient(700px 340px at 110% 80%, rgba(13,50,118,.07), transparent 60%);
}
.hero-inner{
  display:grid;grid-template-columns:1.1fr .95fr;gap:56px;align-items:center;
  position:relative;z-index:1;
}

.pill{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--c-line);
  color:var(--c-blue-deep);font-size:.82rem;font-weight:600;
  padding:7px 14px;border-radius:999px;
  box-shadow:var(--shadow-xs);
  margin:0 0 20px;letter-spacing:.02em;
}
.pulse{
  width:9px;height:9px;border-radius:50%;background:var(--c-blue);
  box-shadow:0 0 0 0 rgba(43,108,176,.55);
  animation:pulse 2.4s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(43,108,176,.55)}
  70%{box-shadow:0 0 0 10px rgba(43,108,176,0)}
  100%{box-shadow:0 0 0 0 rgba(43,108,176,0)}
}
.accent{color:var(--c-blue-deep)}

.lede{font-size:1.1rem;color:var(--c-muted);max-width:55ch;margin-top:2px}

.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 18px}

.trust{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px 20px;color:var(--c-muted)}
.trust li{display:inline-flex;align-items:center;gap:6px;font-size:.92rem}
.trust svg{color:var(--c-blue);flex-shrink:0}

/* Visuel hero — carte d'infos */
.hero-visual{position:relative;padding:10px}
.portrait-card{
  position:relative;
  border-radius:var(--radius-l);
  box-shadow:var(--shadow-l);
  background:#fff;
  border:1px solid var(--c-line);
}
.info-card{padding:24px 22px 18px;display:flex;flex-direction:column;gap:16px}
.info-card-head{
  display:flex;align-items:center;gap:12px;
  padding-bottom:14px;border-bottom:1px solid var(--c-line);
}
.info-dot{
  width:10px;height:10px;border-radius:50%;background:#22c55e;flex-shrink:0;
  box-shadow:0 0 0 3px rgba(34,197,94,.18);
  animation:info-pulse 2.2s ease-in-out infinite;
}
@keyframes info-pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(34,197,94,.18)}
  50%{box-shadow:0 0 0 6px rgba(34,197,94,.10)}
}
.info-card-head strong{display:block;font-size:1rem;color:var(--c-ink);font-weight:700;line-height:1.2}
.info-card-head small{color:var(--c-muted);font-size:.82rem}
.info-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.info-list li{display:flex;align-items:center;gap:14px}
.info-ico{
  width:40px;height:40px;border-radius:12px;
  background:var(--c-blue-soft);color:var(--c-blue-deep);
  display:grid;place-items:center;flex-shrink:0;
}
.info-list strong{display:block;font-size:.95rem;color:var(--c-ink);font-weight:700;line-height:1.2}
.info-list small{color:var(--c-muted);font-size:.82rem}
.info-ecg{
  width:100%;height:34px;color:var(--c-blue);opacity:.55;
  margin-top:2px;
}

.float-card{
  position:absolute;background:#fff;
  border-radius:12px;padding:11px 14px;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);
  border:1px solid var(--c-line);
  z-index:2;
}
.float-card small{display:block;color:var(--c-muted);font-size:.72rem;line-height:1}
.float-card strong{display:block;font-weight:700;color:var(--c-ink);font-size:.95rem;margin-top:3px}
.float-ico{
  width:34px;height:34px;border-radius:10px;
  background:var(--c-blue-soft);color:var(--c-blue-deep);
  display:grid;place-items:center;flex-shrink:0;
}
.float-card--zone{top:50%;right:-22px;transform:translateY(-50%)}

/* Bande stats */
.stats{
  list-style:none;padding:0;margin:48px 0 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-s);
  overflow:hidden;
  position:relative;z-index:1;
}
.stats li{
  padding:20px 18px;text-align:center;
  border-right:1px solid var(--c-line);
}
.stats li:last-child{border-right:0}
.stats strong{
  display:block;font-size:1.75rem;font-weight:800;
  color:var(--c-blue-deep);line-height:1;letter-spacing:-.02em;
}
.stats span{display:block;color:var(--c-muted);font-size:.86rem;margin-top:6px}

/* ===== Sections ===== */
.section{padding:clamp(58px, 6.5vw, 96px) 0;position:relative}
.section--alt{background:var(--c-surface-2)}
.section-head{max-width:680px;margin:0 auto 40px;text-align:center}
.section-head .eyebrow{justify-content:center}
.section-lede{color:var(--c-muted);font-size:1.04rem}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  text-transform:uppercase;letter-spacing:.14em;font-size:.75rem;
  color:var(--c-blue-deep);font-weight:700;margin:0 0 10px;
}
.eyebrow::before{
  content:"";width:22px;height:1px;background:var(--c-blue);opacity:.7;
}
.eyebrow--light{color:rgba(255,255,255,.85)}
.eyebrow--light::before{background:rgba(255,255,255,.6)}

.grid-2{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center}

/* ===== About ===== */
.about-wrap{max-width:780px}
.about-wrap .eyebrow{justify-content:flex-start}

.badges{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-wrap:wrap;gap:8px}
.badges li{
  background:var(--c-blue-soft);color:var(--c-blue-deep);
  border-radius:999px;padding:7px 14px;font-size:.88rem;font-weight:600;
}

/* ===== IPA (Infirmier en Pratique Avancée) ===== */
.section--ipa{
  background:
    radial-gradient(900px 460px at 50% -10%, rgba(43,108,176,.08), transparent 60%),
    var(--c-surface);
  border-top:1px solid var(--c-line);
  border-bottom:1px solid var(--c-line);
}
.ipa-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:22px;
  margin-bottom:28px;
}
.ipa-card{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-l);
  padding:26px 26px 24px;
  box-shadow:var(--shadow-s);
}
.ipa-ico{
  display:inline-grid;place-items:center;
  width:52px;height:52px;border-radius:14px;
  background:var(--c-blue-soft);color:var(--c-blue-deep);
  margin-bottom:12px;
}
.ipa-card h3{font-size:1.18rem;margin:0 0 8px;color:var(--c-ink)}
.ipa-card p{margin:0;color:var(--c-muted);font-size:.98rem;line-height:1.65}

.ipa-patho{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-l);
  padding:26px 26px 22px;
  box-shadow:var(--shadow-s);
}
.ipa-patho > .eyebrow{margin-bottom:18px}
.patho-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
}
.patho-list li{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  background:var(--c-blue-soft2);
  border:1px solid var(--c-line);
  border-radius:12px;
}
.patho-ico{
  width:38px;height:38px;border-radius:10px;
  background:#fff;color:var(--c-blue-deep);
  display:grid;place-items:center;flex-shrink:0;
  border:1px solid var(--c-line);
}
.patho-list strong{display:block;font-size:.95rem;color:var(--c-ink);line-height:1.2;font-weight:700}
.patho-list small{color:var(--c-muted);font-size:.78rem}
.patho-more{
  color:var(--c-muted);font-size:.9rem;
  margin:16px 2px 0;font-style:italic;
}

.ipa-note{
  display:flex;gap:10px;align-items:flex-start;
  margin:26px auto 0;max-width:820px;
  padding:14px 18px;border-radius:12px;
  background:var(--c-blue-soft);color:var(--c-ink-2);
  font-size:.92rem;line-height:1.55;
}
.ipa-note svg{color:var(--c-blue-deep);margin-top:3px;flex-shrink:0}

/* ===== Services ===== */
.services{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.services li{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius);padding:26px 22px;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  position:relative;
}
.services li:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--c-blue-soft);
}
.svc-ico{
  display:grid;place-items:center;
  width:46px;height:46px;border-radius:12px;
  background:var(--c-blue-soft);color:var(--c-blue-deep);
  margin-bottom:16px;
  transition:background .22s ease, color .22s ease;
}
.services li:hover .svc-ico{background:var(--c-blue-deep);color:#fff}
.services h3{margin:0 0 6px;color:var(--c-ink)}
.services p{margin:0;color:var(--c-muted);font-size:.95rem;line-height:1.55}

/* ===== Zone (une seule commune) ===== */
.zone-single{
  max-width:460px;margin:0 auto;
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius);padding:22px 26px;
  display:flex;align-items:center;gap:18px;
  box-shadow:var(--shadow-s);
  transition:transform .2s ease, box-shadow .2s ease;
}
.zone-single:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.zone-pin{
  display:grid;place-items:center;width:56px;height:56px;border-radius:14px;
  background:var(--c-blue-soft);color:var(--c-blue-deep);flex-shrink:0;
}
.zone-single strong{display:block;font-size:1.25rem;color:var(--c-ink);font-weight:700;letter-spacing:-.01em}
.zone-single span{display:block;color:var(--c-muted);font-size:.95rem;margin-top:2px}
.note{color:var(--c-muted);font-size:.94rem;text-align:center;margin-top:18px}

/* ===== FAQ ===== */
.faq-wrap{max-width:800px;margin:0 auto}
details{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius);padding:18px 22px;margin:12px 0;
  transition:border-color .2s ease, box-shadow .2s ease;
}
details[open]{box-shadow:var(--shadow-s);border-color:var(--c-blue-soft)}
summary{
  cursor:pointer;font-weight:600;color:var(--c-ink);list-style:none;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-size:1.02rem;padding:2px 0;
}
summary::-webkit-details-marker{display:none}
summary::after{
  content:"";width:24px;height:24px;flex-shrink:0;border-radius:50%;
  background:var(--c-blue-soft);
  background-image:
    linear-gradient(var(--c-blue-deep),var(--c-blue-deep)),
    linear-gradient(var(--c-blue-deep),var(--c-blue-deep));
  background-size:10px 2px, 2px 10px;
  background-position:center;background-repeat:no-repeat;
  transition:transform .22s ease;
}
details[open] summary::after{background-size:10px 2px, 0 0;transform:rotate(180deg)}
details p{margin:14px 0 4px;color:var(--c-muted)}

/* ===== Contact ===== */
.section--contact{padding-bottom:clamp(80px, 8vw, 120px)}
.contact-card{
  background:
    radial-gradient(circle at 85% 15%, rgba(255,255,255,.08), transparent 55%),
    linear-gradient(135deg, #0d3276 0%, #215387 55%, #2B6CB0 100%);
  border-radius:var(--radius-l);
  color:#fff;
  display:grid;grid-template-columns:1fr 1.15fr;
  overflow:hidden;
  box-shadow:var(--shadow-l);
  position:relative;
}
.contact-copy{padding:clamp(32px, 4vw, 48px)}
.contact-copy h2{color:#fff;max-width:14ch}
.contact-lede{color:rgba(255,255,255,.85);max-width:40ch}
.contact-block{
  font-style:normal;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius);
  padding:18px 22px;margin:20px 0 22px;
}
.contact-block p{margin:6px 0;color:rgba(255,255,255,.94);font-size:.96rem}
.contact-block a{color:#fff;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
.contact-block a:hover{color:#CDE4FF}

/* ===== Formulaire de contact ===== */
.contact-form-wrap{
  background:#fff;
  padding:clamp(28px, 3.5vw, 44px);
  display:flex;align-items:center;
}
.contact-form{width:100%;max-width:520px;margin:0 auto}
.form-head{margin-bottom:18px}
.form-head h3{font-size:1.25rem;color:var(--c-ink);margin:0 0 4px;font-weight:700}
.form-head p{margin:0;color:var(--c-muted);font-size:.94rem}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:block;margin-bottom:12px}
.field > span{
  display:block;font-size:.82rem;font-weight:600;
  color:var(--c-ink-2);margin-bottom:6px;
}
.field > span em{color:var(--c-blue);font-style:normal;margin-left:2px}
.field input,
.field select,
.field textarea{
  width:100%;
  font-family:inherit;font-size:.96rem;color:var(--c-ink);
  background:var(--c-bg);
  border:1.5px solid var(--c-line);
  border-radius:10px;
  padding:11px 14px;
  transition:border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.field textarea{resize:vertical;min-height:120px;line-height:1.55}
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%234A5568' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1,1 6,6 11,1'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:none;border-color:var(--c-blue);background:#fff;
  box-shadow:0 0 0 4px rgba(43,108,176,.15);
}
.field input:invalid:not(:placeholder-shown),
.field textarea:invalid:not(:placeholder-shown){border-color:#cf2e2e}

/* Honeypot invisible */
.hp-field{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

.check{
  display:flex;gap:10px;align-items:flex-start;
  font-size:.86rem;color:var(--c-muted);line-height:1.5;
  margin:4px 0 18px;cursor:pointer;
}
.check input{
  width:18px;height:18px;margin-top:2px;flex-shrink:0;
  accent-color:var(--c-blue-deep);cursor:pointer;
}

.btn--submit{width:100%;justify-content:center;margin-top:4px;padding:14px 24px;background:var(--c-blue-deep);color:#fff}
.btn--submit:hover{background:var(--c-blue-dark);color:#fff;transform:translateY(-2px)}

.form-foot{
  display:flex;align-items:center;gap:6px;justify-content:center;
  margin:14px 0 0;color:var(--c-muted-2);font-size:.8rem;
}
.form-foot svg{color:var(--c-blue);flex-shrink:0}

/* ===== Footer ===== */
.site-footer{
  background:#0a1d38;color:#B8C6DD;padding:48px 0 24px;margin-top:0;
  border-top:4px solid var(--c-blue-deep);
}
.site-footer a{color:#fff}
.site-footer a:hover{color:#CDE4FF}
.footer-inner{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px 40px;align-items:flex-start;
}
.footer-brand{display:flex;gap:14px;align-items:center}
.footer-logo{width:56px;height:56px;border-radius:50%;background:#fff;padding:6px;border:1px solid rgba(255,255,255,.1)}
.footer-brand strong{display:block;font-size:1.1rem;color:#fff;font-weight:700}
.footer-brand p{margin:4px 0 0;color:#93A7C8;font-size:.92rem}
.footer-contact p{margin:4px 0;font-weight:500}
.site-footer nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.legal{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.08);padding-top:18px;margin-top:12px;color:#7E93B5;font-size:.82rem}

/* ===== Menu mobile (hamburger) ===== */
.menu-toggle-input{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.menu-toggle{display:none}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .hero-inner,.grid-2{grid-template-columns:1fr;gap:40px}
  .hero-visual{max-width:440px;margin:0 auto;width:100%}
  .services{grid-template-columns:repeat(2,1fr)}
  .ipa-grid{grid-template-columns:1fr}
  .patho-list{grid-template-columns:repeat(2,1fr)}
  .contact-card{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}

  .menu-toggle{
    display:flex;
    width:42px;height:42px;
    padding:11px 10px;
    cursor:pointer;
    flex-direction:column;justify-content:center;gap:5px;
    margin-left:auto;
    border-radius:10px;
    color:var(--c-ink);
    transition:background .15s ease;
  }
  .menu-toggle:hover{background:var(--c-blue-soft)}
  .menu-toggle:focus-visible{outline:2px solid var(--c-blue);outline-offset:2px}
  .menu-bar{
    display:block;height:2px;
    background:currentColor;border-radius:2px;
    transition:transform .22s ease, opacity .22s ease;
    transform-origin:center;
  }
  .menu-toggle-input:checked + .menu-toggle .menu-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-toggle-input:checked + .menu-toggle .menu-bar:nth-child(2){opacity:0}
  .menu-toggle-input:checked + .menu-toggle .menu-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .nav{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    margin:0;
    background:#fff;
    border-top:1px solid var(--c-line);
    border-bottom:1px solid var(--c-line);
    box-shadow:0 16px 30px -14px rgba(15,32,44,.18);
    padding:6px 18px;
    max-height:calc(100vh - 70px);
    overflow-y:auto;
  }
  .nav ul{flex-direction:column;align-items:stretch;gap:0}
  .nav li{width:100%}
  .nav a{
    display:block;
    padding:14px 4px;
    border-bottom:1px solid var(--c-line);
    border-radius:0;
    font-size:1rem;
  }
  .nav li:last-child a{border-bottom:0}
  .menu-toggle-input:checked ~ .nav{display:block}
}
@media (max-width: 560px){
  .header-inner{padding:10px 16px;gap:10px}
  .cta--phone{padding:8px 12px;font-size:.85rem}
  .cta--phone svg{width:14px;height:14px}
  .brand-text small{display:none}
  .brand-logo{width:40px;height:40px}
  .services{grid-template-columns:1fr}
  .patho-list{grid-template-columns:1fr}
  .float-card--zone{display:none}
  .stats{grid-template-columns:1fr}
  .stats li{border-right:0;border-bottom:1px solid var(--c-line)}
  .stats li:last-child{border-bottom:0}
  .btn{padding:12px 20px;font-size:.94rem}
  .form-row{grid-template-columns:1fr}
  .zone-single{padding:18px 20px;gap:14px}
  .zone-pin{width:48px;height:48px}
  .ipa-card{padding:22px 20px 20px}
  .ipa-patho{padding:22px 20px 20px}
  .ipa-note{padding:12px 14px;font-size:.88rem}
  .info-card{padding:20px 18px 16px}
}

@media (prefers-reduced-motion: reduce){
  *{transition:none !important;animation:none !important;scroll-behavior:auto}
}
