/* =====================================================================
   Physiotrix — Design System
   Minimalist, medical-premium. Teal healing palette + warm accent.
   ===================================================================== */
:root{
  /* Brand palette — World Physiotherapy inspired (blue + teal + lime).
     The --teal-* names are kept as the PRIMARY ramp but now hold BLUE
     values, so the whole UI re-themes from one place. Real teal lives in
     --heal-* (healing accents / spine) and the accent colour is --lime. */
  --teal-900:#0a1f63; --teal-800:#12329c; --teal-700:#1b45d6; --teal-600:#2358ef;
  --teal-500:#3f6dff; --teal-300:#9fb7ff; --teal-100:#dce4ff; --teal-50:#eef3ff;
  --heal-700:#0f766e; --heal-500:#14b8a6; --heal-300:#5eead4;
  --lime:#cddc39; --lime-600:#aec326;
  --ink:#0e1430; --ink-2:#37406b; --muted:#5c6788; --line:#e4e8f5;
  --bg:#ffffff; --bg-tint:#f4f7ff; --bg-deep:#0a1330;
  --amber:#f5a524; --coral:#ff7a59;
  --radius:18px; --radius-sm:12px; --radius-lg:28px;
  --shadow-sm:0 1px 2px rgba(6,40,38,.06),0 4px 14px rgba(6,40,38,.05);
  --shadow:0 10px 30px -12px rgba(6,40,38,.18),0 4px 10px rgba(6,40,38,.05);
  --shadow-lg:0 30px 60px -22px rgba(6,40,38,.28);
  /* Libre Franklin applied site-wide (headings + body). */
  --font-body:'Libre Franklin',Arial,system-ui,-apple-system,Segoe UI,sans-serif;
  --font-head:'Libre Franklin',Arial,system-ui,-apple-system,Segoe UI,sans-serif;
  --maxw:1360px; --gutter:clamp(20px,4vw,44px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--bg);
  font-size:clamp(16px,1.05vw,17px);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--ink);margin:0}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:3px solid var(--teal-500);outline-offset:2px;border-radius:4px}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--teal-700);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.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}
em{font-style:italic;color:var(--teal-700)}
.grad-text{background:linear-gradient(120deg,var(--heal-500),var(--teal-600) 55%,var(--teal-800));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-weight:700;font-size:.98rem;padding:.85em 1.5em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;white-space:nowrap}
.btn svg{width:1.15em;height:1.15em}
.btn--primary{background:linear-gradient(120deg,var(--teal-600),var(--teal-800));color:#fff;box-shadow:0 10px 22px -8px rgba(15,118,110,.6)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(15,118,110,.7)}
.btn--ghost{background:rgba(255,255,255,.7);color:var(--teal-800);border-color:var(--line);backdrop-filter:blur(6px)}
.btn--ghost:hover{background:#fff;border-color:var(--teal-300);transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--teal-700);border-color:var(--teal-300)}
.btn--outline:hover{background:var(--teal-50);transform:translateY(-2px)}
.btn--lg{padding:1.05em 1.9em;font-size:1.05rem}
.btn--sm{padding:.62em 1.15em;font-size:.9rem}
.btn--block{width:100%}

/* ---------- Topbar ---------- */
.topbar{background:var(--bg-deep);color:#bfeee6;font-size:.82rem}
.topbar__inner{display:flex;align-items:center;gap:18px;height:40px}
.topbar__item{display:inline-flex;align-items:center;gap:7px;color:#a9e6dd}
.topbar__item svg{width:15px;height:15px;opacity:.85}
.topbar__phone{margin-left:auto;font-weight:700;color:#fff}
.topbar__sep{width:1px;height:16px;background:rgba(255,255,255,.16)}
@media(max-width:720px){.topbar__item:not(.topbar__phone){display:none}.topbar__phone{margin:0}.topbar__inner{justify-content:center}}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s,background .3s}
.site-header.is-scrolled{box-shadow:var(--shadow-sm);border-color:var(--line)}
.site-header__inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-size:1.4rem;font-weight:600}
.brand__mark{width:34px;height:34px;display:grid;place-items:center;filter:drop-shadow(0 6px 10px rgba(15,118,110,.35))}
.brand__text span{color:var(--teal-600)}
.nav{margin-left:auto}
.nav__list{display:flex;gap:6px}
.nav__link{position:relative;padding:.55em .9em;border-radius:999px;font-weight:600;font-size:.96rem;color:var(--ink-2);transition:color .2s,background .2s}
.nav__link:hover{color:var(--teal-800);background:var(--teal-50)}
.nav__link.is-active{color:var(--teal-800)}
.nav__link.is-active::after{content:"";position:absolute;left:50%;bottom:2px;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--lime)}
.site-header__cta{display:flex}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:0;background:transparent;cursor:pointer;padding:10px}
.nav-toggle span{height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
.nav-toggle[aria-expanded=true] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded=true] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobile-nav{padding:12px var(--gutter) 26px;border-top:1px solid var(--line);background:#fff;display:grid;gap:8px}
.mobile-nav[hidden]{display:none}
.mobile-nav ul{display:grid;gap:2px;margin-bottom:10px}
.mobile-nav a{display:block;padding:.85em .6em;font-weight:600;font-size:1.05rem;border-radius:10px}
.mobile-nav ul a:hover{background:var(--teal-50)}
@media(max-width:900px){.nav,.site-header__cta{display:none}.nav-toggle{display:flex}}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 82% 10%,#e6ecff 0%,#f3f6ff 42%,#ffffff 72%);
  padding:clamp(48px,8vw,96px) 0 clamp(60px,9vw,110px);isolation:isolate}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:-1}
.hero__glow{position:absolute;right:-10%;top:-15%;width:60vw;height:60vw;max-width:760px;max-height:760px;
  background:radial-gradient(circle,rgba(20,184,166,.28),transparent 62%);filter:blur(10px);z-index:-2;pointer-events:none;animation:floaty 9s ease-in-out infinite}
.hero__inner{position:relative;min-height:min(72vh,620px);display:flex;align-items:center}
.hero__content{max-width:640px}
.hero__eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-700);background:rgba(255,255,255,.7);border:1px solid var(--teal-100);padding:.5em 1em;border-radius:999px;box-shadow:var(--shadow-sm)}
.pulse-dot{width:9px;height:9px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(205,220,57,.6);animation:pulse 2s infinite}
.hero__title{font-size:clamp(2.5rem,6.2vw,4.4rem);font-weight:600;margin:.5em 0 .35em;letter-spacing:-.02em}
.hero__lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--ink-2);max-width:36ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin:2em 0 1.6em}
.hero__badges{display:flex;flex-wrap:wrap;gap:10px 20px;color:var(--ink-2);font-weight:600;font-size:.92rem}
.hero__badges li{display:inline-flex;align-items:center;gap:8px}
.hero__badges svg{width:18px;height:18px;color:var(--teal-600)}
.hero__scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.hero__scroll span{width:22px;height:34px;border:2px solid var(--teal-300);border-radius:12px;position:relative}
.hero__scroll span::after{content:"";position:absolute;left:50%;top:6px;transform:translateX(-50%);width:4px;height:7px;border-radius:2px;background:var(--teal-500);animation:scrolldot 1.8s infinite}
/* Medium/narrow widths: kill the empty right/bottom void — center the
   hero content and let it size to content instead of a fixed tall block. */
@media(max-width:1080px){
  .hero{padding-bottom:clamp(44px,7vw,76px)}
  .hero__inner{min-height:auto}
  .hero__content{max-width:640px;margin-inline:auto;text-align:center}
  .hero__eyebrow{margin-inline:auto}
  .hero__lead{margin-inline:auto;max-width:52ch}
  .hero__actions,.hero__badges{justify-content:center}
  .hero__canvas{opacity:.4}
  .hero__scroll{display:none}
}
@media(max-width:760px){.hero__canvas{opacity:.32}}

/* ---------- Stats / results panel ---------- */
.statbar{position:relative;z-index:3}
.statbar--overlap{margin-top:-52px}
.statbar__panel{position:relative;overflow:hidden;border-radius:var(--radius-lg);
  padding:clamp(28px,3.6vw,42px) clamp(6px,0.8vw,12px);
  background:
    radial-gradient(120% 140% at 12% -10%,rgba(20,184,166,.34),transparent 55%),
    linear-gradient(135deg,#0a1f63 0%,#173db0 52%,#0a1c58 100%);
  border:1px solid rgba(94,234,212,.16);
  box-shadow:0 34px 70px -26px rgba(6,40,38,.6),inset 0 1px 0 rgba(255,255,255,.05)}
/* moving light sweep */
.statbar__panel::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(100deg,transparent 42%,rgba(126,255,230,.10) 50%,transparent 58%);
  transform:translateX(-120%);animation:sweep 7.5s ease-in-out infinite}
/* soft floating glow blobs */
.statbar__glow{position:absolute;border-radius:50%;filter:blur(14px);pointer-events:none;opacity:.5}
.statbar__glow--a{width:260px;height:260px;top:-120px;right:8%;background:radial-gradient(circle,rgba(94,234,212,.5),transparent 65%);animation:floaty 8s ease-in-out infinite}
.statbar__glow--b{width:220px;height:220px;bottom:-130px;left:4%;background:radial-gradient(circle,rgba(20,184,166,.45),transparent 65%);animation:floaty 10s ease-in-out infinite reverse}
/* ECG heartbeat line */
.statbar__ecg{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);width:100%;height:90px;pointer-events:none;opacity:.9}
.statbar__ecg path{fill:none;stroke:rgba(126,255,230,.55);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:140 1400;filter:drop-shadow(0 0 6px rgba(126,255,230,.6));animation:ecg 4.5s linear infinite}

.statbar__grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr)}
.statcard{position:relative;text-align:center;padding:16px 18px}
.statcard:not(:last-child)::after{content:"";position:absolute;right:0;top:16%;height:68%;width:1px;
  background:linear-gradient(180deg,transparent,rgba(94,234,212,.3),transparent)}
.statcard__icon{display:grid;place-items:center;width:48px;height:48px;margin:0 auto 16px;border-radius:15px;
  background:rgba(94,234,212,.1);border:1px solid rgba(94,234,212,.24);color:#7effe6;transition:transform .35s var(--ease),box-shadow .35s,background .35s}
.statcard__icon svg{width:24px;height:24px}
.statcard:hover .statcard__icon{transform:translateY(-4px);background:rgba(94,234,212,.2);box-shadow:0 0 28px -4px rgba(94,234,212,.55)}
.statcard__value{display:inline-flex;align-items:baseline;gap:5px;font-family:var(--font-head);font-weight:800;
  font-size:clamp(2rem,3.7vw,3rem);line-height:1;letter-spacing:-.03em;
  background:linear-gradient(180deg,#ffffff,#b8f2e8);-webkit-background-clip:text;background-clip:text;color:transparent}
.statcard__star{align-self:center}
.statcard__star svg{width:.62em;height:.62em;color:var(--amber);fill:var(--amber);stroke:var(--amber);filter:drop-shadow(0 0 7px rgba(245,165,36,.6))}
.statcard__label{display:block;margin-top:12px;font-size:.9rem;font-weight:600;color:#a9d6cf}
@media(max-width:720px){
  .statbar__grid{grid-template-columns:1fr 1fr;gap:26px 0}
  .statcard:nth-child(2)::after{display:none}
  .statcard:nth-child(1)::before,.statcard:nth-child(2)::before{content:"";position:absolute;left:14%;bottom:-13px;width:72%;height:1px;background:linear-gradient(90deg,transparent,rgba(94,234,212,.28),transparent)}
}
@keyframes sweep{0%{transform:translateX(-120%)}55%,100%{transform:translateX(120%)}}
@keyframes ecg{to{stroke-dashoffset:-1540}}
@media(prefers-reduced-motion:reduce){
  .statbar__panel::after,.statbar__ecg path,.statbar__glow{animation:none}
}

/* ---------- Why-choose feature band (full-bleed 3-up) ---------- */
.why-band{position:relative;z-index:3}
.why-band__grid{display:grid;grid-template-columns:repeat(3,1fr)}
.why-card{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:15px;
  padding:clamp(38px,4.4vw,62px) clamp(26px,3vw,52px) clamp(32px,3.6vw,50px)}
.why-card__icon{width:64px;height:64px;border-radius:16px;background:#fff;display:grid;place-items:center;
  box-shadow:0 14px 30px -14px rgba(6,20,48,.5);margin-bottom:4px}
.why-card__icon svg{width:30px;height:30px}
.why-card__title{font-size:clamp(1.35rem,1.9vw,1.7rem);line-height:1.15;font-weight:700}
.why-card__text{font-size:.98rem;line-height:1.6;max-width:34ch;flex:1;opacity:.92}
.why-card__link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.96rem;margin-top:8px}
.why-card__link span{transition:transform .25s var(--ease)}
.why-card__link:hover span{transform:translateX(5px)}
/* top accent tab (echoes the reference blocks) */
.why-card::before{content:"";position:absolute;top:0;left:clamp(26px,3vw,52px);width:60px;height:6px;border-radius:0 0 4px 4px;z-index:2}
/* hover: deepen each card within its OWN colour (overlay fades in) */
.why-card::after{content:"";position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .4s var(--ease)}
.why-card--blue::after{background:linear-gradient(160deg,#1636b0,#0a2170)}
.why-card--teal::after{background:linear-gradient(160deg,#0f9e8e,#0a5852)}
.why-card--lime::after{background:linear-gradient(160deg,#c6d52a,#a7ba18)}
.why-card__icon,.why-card__title,.why-card__text,.why-card__link{position:relative;z-index:1}
.why-card__icon{transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.why-card:hover::after{opacity:1}
.why-card:hover .why-card__icon{transform:translateY(-6px);box-shadow:0 22px 40px -16px rgba(6,20,48,.4)}
/* tones — Physiotrix blue / teal / lime */
.why-card--blue{background:linear-gradient(160deg,#1f4ee0,#12329c);color:#e8eeff}
.why-card--blue .why-card__title{color:#fff}
.why-card--blue .why-card__icon{color:#1b45d6}
.why-card--blue::before{background:var(--lime)}
.why-card--teal{background:linear-gradient(160deg,#17c2ae,#0f766e);color:#eafffb}
.why-card--teal .why-card__title{color:#fff}
.why-card--teal .why-card__icon{color:#0f766e}
.why-card--teal::before{background:rgba(255,255,255,.6)}
.why-card--lime{background:linear-gradient(160deg,#d7e34e,#c3d422);color:#2b3405}
.why-card--lime .why-card__title{color:#1e260a}
.why-card--lime .why-card__icon{color:#5f6c12}
.why-card--lime::before{background:#1b45d6}
@media(max-width:820px){.why-band__grid{grid-template-columns:1fr}}

/* ---------- Section scaffolding ---------- */
.section{padding:clamp(60px,9vw,112px) 0}
.section--tint{background:var(--bg-tint)}
.section--deep{background:var(--bg-deep);color:#dff3ef}
.section__head{max-width:660px;margin:0 auto clamp(36px,5vw,56px);text-align:center}
.section__head--left{margin-inline:0;text-align:left}
.section__eyebrow{font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-600);margin-bottom:.6em}
.section__title{font-size:clamp(1.9rem,3.8vw,2.9rem);font-weight:700}
.section__sub{margin-top:.9em;color:var(--ink-2);font-size:1.08rem}
.section__foot{text-align:center;margin-top:clamp(30px,4vw,46px)}

/* ---------- Cards / services ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1000px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
.cards--auto{grid-template-columns:repeat(auto-fit,minmax(248px,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;position:relative;overflow:hidden}
.card--compact{padding:22px 22px}
.card--compact .card__icon{width:46px;height:46px;margin-bottom:13px}
.card--compact .card__title{font-size:1.1rem}
.card--compact .card__text{margin-bottom:0}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--teal-500),var(--teal-300));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card__icon{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--teal-50),var(--teal-100));color:var(--teal-700);margin-bottom:16px}
.card__icon svg{width:26px;height:26px}
.card__title{font-size:1.22rem;font-weight:600;margin-bottom:.5em}
.card__text{color:var(--muted);font-size:.96rem;margin-bottom:1em}
.card__points{display:grid;gap:7px}
.card__points li{display:flex;gap:8px;align-items:flex-start;font-size:.9rem;color:var(--ink-2);font-weight:600}
.card__points svg{width:16px;height:16px;color:var(--teal-500);flex:0 0 auto;margin-top:3px}

/* ---------- Process ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
@media(max-width:900px){.process{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.process{grid-template-columns:1fr}}
.process__step{position:relative;padding:28px 22px;background:#fff;border-radius:var(--radius);border:1px solid var(--line)}
.process__num{font-family:var(--font-head);font-size:2.4rem;font-weight:600;color:var(--teal-200,#9be3d7);line-height:1;background:linear-gradient(120deg,var(--teal-400,#2dd4bf),var(--teal-600));-webkit-background-clip:text;background-clip:text;color:transparent;opacity:.55}
.process__title{font-size:1.15rem;font-weight:600;margin:.5em 0 .4em}
.process__text{color:var(--muted);font-size:.94rem}

/* ---------- Why / split ---------- */
.why{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,64px);align-items:center}
@media(max-width:900px){.why{grid-template-columns:1fr}}
.why__media{position:relative}
.why__card{position:relative;background:linear-gradient(160deg,var(--teal-700),var(--teal-900));color:#eafffb;border-radius:var(--radius-lg);padding:clamp(28px,4vw,44px);overflow:hidden;box-shadow:var(--shadow-lg)}
.why__card h3{color:#fff;font-size:1.5rem;margin-bottom:.4em}
.why__card p{color:#bfeee6}
.why__card ul{margin-top:1.4em;display:grid;gap:11px}
.why__card li{display:flex;gap:10px;align-items:center;font-weight:600}
.why__card svg{width:18px;height:18px;color:var(--teal-300)}
.why__pulse{position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(94,234,212,.5),transparent 65%);animation:floaty 7s ease-in-out infinite}
.why__content h2{margin-bottom:.5em}
.ticklist{display:grid;gap:13px;margin:1.5em 0 1.8em}
.ticklist li{display:flex;gap:11px;align-items:flex-start;color:var(--ink-2)}
.ticklist svg{width:20px;height:20px;color:var(--teal-500);flex:0 0 auto;margin-top:3px}

/* ---------- Reviews ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.reviews{grid-template-columns:1fr}}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow-sm)}
.review__stars{display:flex;gap:2px;margin-bottom:12px}
.review__stars svg{width:18px;height:18px;color:var(--amber);fill:var(--amber);stroke:var(--amber)}
.review blockquote{margin:0 0 16px;font-size:1.02rem;color:var(--ink-2);line-height:1.6}
.review figcaption{display:flex;flex-direction:column}
.review figcaption strong{color:var(--ink)}
.review figcaption span{font-size:.85rem;color:var(--muted)}

/* ---------- FAQ ---------- */
.faq{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,5vw,56px);align-items:start}
@media(max-width:860px){.faq{grid-template-columns:1fr}}
.faq__list{display:grid;gap:12px}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .25s,box-shadow .25s}
.faq__item[open]{border-color:var(--teal-300);box-shadow:var(--shadow)}
.faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;font-weight:700;font-size:1.02rem;color:var(--ink)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary i{position:relative;width:18px;height:18px;flex:0 0 auto}
.faq__item summary i::before,.faq__item summary i::after{content:"";position:absolute;background:var(--teal-600);border-radius:2px;transition:transform .3s}
.faq__item summary i::before{left:0;top:8px;width:18px;height:2.5px}
.faq__item summary i::after{left:8px;top:0;width:2.5px;height:18px}
.faq__item[open] summary i::after{transform:scaleY(0)}
.faq__answer{padding:0 20px 20px;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--teal-800),var(--teal-900));color:#eafffb;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;left:-10%;bottom:-60%;width:50vw;height:50vw;max-width:560px;max-height:560px;background:radial-gradient(circle,rgba(94,234,212,.25),transparent 60%)}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:clamp(40px,6vw,68px) 0;flex-wrap:wrap;position:relative}
.cta-band__title{color:#fff;font-size:clamp(1.7rem,3.2vw,2.5rem)}
.cta-band__text{color:#bfeee6;max-width:46ch;margin-top:.5em}
.cta-band__actions{display:flex;gap:14px;flex-wrap:wrap}
.cta-band .btn--ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.28)}
.cta-band .btn--ghost:hover{background:rgba(255,255,255,.2)}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg-deep);color:#a9cec8;font-size:.94rem}
.site-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:40px;padding:clamp(48px,6vw,72px) var(--gutter) 40px}
@media(max-width:900px){.site-footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.site-footer__grid{grid-template-columns:1fr}}
.brand--footer{color:#fff;font-size:1.35rem}
.site-footer__desc{margin:16px 0 20px;max-width:36ch;color:#8fb8b2}
.site-footer__head{color:#fff;font-family:var(--font-body);font-weight:700;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px}
.site-footer__col ul{display:grid;gap:10px}
.site-footer__col a:hover{color:var(--teal-300)}
.site-footer__contact address{font-style:normal;display:grid;gap:14px}
.site-footer__contact p{display:flex;gap:10px;align-items:flex-start;margin:0}
.site-footer__contact svg{width:18px;height:18px;color:var(--teal-400,#2dd4bf);flex:0 0 auto;margin-top:2px}
.social{display:flex;gap:10px}
.social a{width:38px;height:38px;display:grid;place-items:center;border-radius:10px;background:rgba(255,255,255,.07);color:#cfeee8;transition:.25s}
.social a:hover{background:var(--teal-600);color:#fff;transform:translateY(-2px)}
.social svg{width:19px;height:19px}
.site-footer__bottom{border-top:1px solid rgba(255,255,255,.09)}
.site-footer__bottom-inner{display:flex;justify-content:space-between;gap:14px;padding:20px 0;flex-wrap:wrap;font-size:.85rem;color:#7ea7a1}
.site-footer__made a:hover{color:var(--teal-300)}

/* ---------- WhatsApp FAB ---------- */
.whatsapp-fab{position:fixed;right:20px;bottom:20px;z-index:90;width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;box-shadow:0 12px 26px -8px rgba(37,211,102,.7);transition:transform .25s}
.whatsapp-fab:hover{transform:scale(1.08)}
.whatsapp-fab svg{width:30px;height:30px}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:radial-gradient(120% 100% at 80% 0%,#e6ecff,#f3f6ff 60%,#fff);padding:clamp(40px,6vw,72px) 0 clamp(30px,4vw,50px);border-bottom:1px solid var(--line)}
.breadcrumb{display:flex;gap:8px;font-size:.85rem;color:var(--muted);margin-bottom:16px;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--teal-700)}
.breadcrumb span{color:var(--teal-700);font-weight:600}
.page-hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:600;max-width:16ch}
.page-hero p{margin-top:.8em;color:var(--ink-2);font-size:1.1rem;max-width:56ch}

/* ---------- Prose / About ---------- */
.prose{max-width:70ch;margin-inline:auto}
.prose h2{font-size:clamp(1.5rem,2.6vw,2rem);margin:1.6em 0 .5em}
.prose h3{font-size:1.25rem;margin:1.4em 0 .4em;font-weight:600}
.prose p{color:var(--ink-2);margin-bottom:1em}
.prose ul.dots{display:grid;gap:10px;margin:1em 0 1.4em}
.prose ul.dots li{display:flex;gap:11px;color:var(--ink-2)}
.prose ul.dots svg{width:19px;height:19px;color:var(--teal-500);flex:0 0 auto;margin-top:3px}

/* ---------- Conditions chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.55em 1.05em;font-weight:600;font-size:.92rem;color:var(--ink-2);transition:.25s}
.chip:hover{border-color:var(--teal-300);color:var(--teal-800);background:var(--teal-50)}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(28px,5vw,52px);align-items:start}
@media(max-width:860px){.contact{grid-template-columns:1fr}}
.contact__info{display:grid;gap:18px}
.info-card{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px}
.info-card__icon{width:44px;height:44px;border-radius:12px;background:var(--teal-50);color:var(--teal-700);display:grid;place-items:center;flex:0 0 auto}
.info-card__icon svg{width:22px;height:22px}
.info-card h3{font-size:1.05rem;font-weight:600;margin-bottom:.25em}
.info-card p,.info-card a{color:var(--muted);font-size:.96rem}
.info-card a:hover{color:var(--teal-700)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3.5vw,38px);box-shadow:var(--shadow)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:520px){.form__row{grid-template-columns:1fr}}
.field{display:grid;gap:7px;margin-bottom:16px}
.field label{font-weight:600;font-size:.9rem;color:var(--ink-2)}
.field input,.field select,.field textarea{font:inherit;padding:.85em 1em;border:1.5px solid var(--line);border-radius:12px;background:var(--bg-tint);transition:border-color .2s,background .2s;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal-500);background:#fff}
.field textarea{resize:vertical;min-height:120px}
.form__note{font-size:.82rem;color:var(--muted);margin-top:6px}
.map-embed{border:0;width:100%;height:100%;min-height:340px;border-radius:var(--radius);filter:saturate(1.05)}
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);height:100%}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:800px){.team{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.team{grid-template-columns:1fr}}
.member{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;text-align:center}
.member__avatar{width:84px;height:84px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;font-family:var(--font-head);font-size:1.8rem;color:#fff;background:linear-gradient(135deg,var(--teal-500),var(--teal-800))}
.member h3{font-size:1.15rem;font-weight:600}
.member__role{color:var(--teal-700);font-weight:600;font-size:.9rem;margin:.2em 0 .6em}
.member p{color:var(--muted);font-size:.92rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Keyframes ---------- */
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(205,220,57,.55)}70%{box-shadow:0 0 0 12px rgba(205,220,57,0)}100%{box-shadow:0 0 0 0 rgba(205,220,57,0)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes scrolldot{0%{opacity:1;transform:translate(-50%,0)}60%{opacity:0;transform:translate(-50%,10px)}100%{opacity:0}}
