/* ==========================================================================
   eVisitNB — powered by ThinkNew  |  Design System
   Modern healthcare refresh: trustworthy teal/blue + warm coral, soft depth.
   ========================================================================== */

:root{
  /* Brand — matched to eVisitNB logo: navy / teal / red */
  --teal-900:#001a3d;     /* deep navy (headings, footer, dark sections) */
  --teal-800:#06305c;     /* navy (nav text, gradients) */
  --teal-700:#0a7b73;     /* deep teal */
  --primary:#009c93;      /* brand teal */
  --primary-600:#067e76;
  --teal-400:#16b1a6;     /* bright teal accent */
  --teal-300:#57cec4;
  --mint-100:#e4f4f1;
  --mint-200:#c9e9e4;
  --coral:#e43030;        /* brand red (CTAs) */
  --coral-600:#c21f1f;
  --amber:#ffb74d;        /* star ratings */
  --ink:#10263f;          /* navy-slate body text */
  --muted:#5a6e83;
  --line:#dde7ec;
  --white:#ffffff;
  --bg:#f6fafb;
  --bg-soft:#edf6f5;

  /* Effects */
  --radius:18px;
  --radius-lg:28px;
  --radius-sm:12px;
  --shadow-sm:0 2px 8px rgba(0,26,61,.07);
  --shadow:0 12px 30px rgba(0,26,61,.12);
  --shadow-lg:0 28px 60px rgba(0,26,61,.18);
  --ring:0 0 0 4px rgba(0,156,147,.28);
  --maxw:1160px;
  --ease:cubic-bezier(.22,.61,.36,1);

  /* Type */
  --font-head:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);background:var(--bg);
  line-height:1.65;font-size:clamp(16px,1.05vw,17px);overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--primary-600);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--coral-600)}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.12;color:var(--teal-900);font-weight:700;letter-spacing:-.02em;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5vw,3.6rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.5rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1.1em}
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(18px,4vw,28px)}
.section{padding:clamp(56px,8vw,104px) 0}
.eyebrow{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-head);font-weight:700;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);
  background:var(--mint-100);padding:.45em .9em;border-radius:999px;margin-bottom:1.05rem}
.hero .eyebrow{font-size:.7rem;padding:.38em .8em;letter-spacing:.12em}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--muted);max-width:62ch}
.center{text-align:center}.center .lead{margin-inline:auto}
.muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font-head);font-weight:700;
  font-size:1rem;padding:.95em 1.6em;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease);
  position:relative;will-change:transform}
.btn svg{transition:transform .25s var(--ease)}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 10px 24px rgba(228,48,48,.32)}
.btn-primary:hover{background:var(--coral-600);color:#fff;transform:translateY(-3px);box-shadow:0 16px 32px rgba(228,48,48,.40)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{background:#fff;color:var(--teal-800);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--teal-400);color:var(--teal-800);transform:translateY(-3px);box-shadow:var(--shadow)}
.btn-on-dark{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.32);backdrop-filter:blur(6px)}
.btn-on-dark:hover{background:#fff;color:var(--teal-800);transform:translateY(-3px)}
.btn-lg{font-size:1.08rem;padding:1.05em 1.9em}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(247,251,251,.82);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s,background .3s}
.site-header.scrolled{border-color:var(--line);box-shadow:var(--shadow-sm);background:rgba(255,255,255,.9)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:74px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-head);font-weight:800;
  font-size:1.18rem;color:var(--teal-900);letter-spacing:-.02em}
.brand .logo{width:38px;height:38px;flex:0 0 38px}
.brand-logo{height:42px;width:auto;display:block;transform-origin:18px center;will-change:transform,filter;transition:filter .3s ease}
.foot-brand .brand-logo{height:40px}
@media (max-width:560px){.brand-logo{height:34px}}
/* easter egg: the logo gets a heartbeat + soft teal glow on hover (lub-dub from the petal mark) */
.site-header .brand:hover .brand-logo{animation:ev-heartbeat 1.3s ease-in-out infinite;filter:drop-shadow(0 0 5px rgba(0,156,147,.45))}
@keyframes ev-heartbeat{
  0%{transform:scale(1);filter:drop-shadow(0 0 3px rgba(0,156,147,.30))}
  10%{transform:scale(1.11);filter:drop-shadow(0 0 8px rgba(0,156,147,.55))}
  20%{transform:scale(1);filter:drop-shadow(0 0 3px rgba(0,156,147,.30))}
  32%{transform:scale(1.15);filter:drop-shadow(0 0 11px rgba(0,156,147,.65))}
  46%{transform:scale(1);filter:drop-shadow(0 0 3px rgba(0,156,147,.30))}
  100%{transform:scale(1);filter:drop-shadow(0 0 3px rgba(0,156,147,.30))}
}
.brand small{display:block;font-size:.62rem;font-weight:600;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:.4rem;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--font-head);font-weight:600;font-size:.96rem;color:var(--teal-800);
  padding:.55em .8em;border-radius:10px;position:relative;transition:color .2s,background .2s}
.nav-links a::after{content:"";position:absolute;left:.8em;right:.8em;bottom:.32em;height:2px;
  background:var(--coral);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);border-radius:2px}
.nav-links a:hover{color:var(--teal-900)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.nav-cta .btn{font-size:.9rem;padding:.6em 1.2em}
.lang{font-family:var(--font-head);font-weight:700;font-size:.82rem;color:var(--muted);border:1px solid var(--line);
  border-radius:999px;padding:.35em .7em;background:#fff}
.lang:hover{color:var(--primary);border-color:var(--teal-400)}
.menu-btn{display:none;background:#fff;border:1px solid var(--line);border-radius:12px;width:46px;height:46px;
  cursor:pointer;align-items:center;justify-content:center}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{content:"";display:block;width:20px;height:2px;
  background:var(--teal-900);border-radius:2px;position:relative;transition:.3s var(--ease)}
.menu-btn span::before{position:absolute;top:-6px}.menu-btn span::after{position:absolute;top:6px}
.menu-btn[aria-expanded="true"] span{background:transparent}
.menu-btn[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.menu-btn[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1200px 600px at 80% -10%,rgba(22,177,166,.26),transparent 60%),
  radial-gradient(900px 500px at -10% 20%,rgba(228,48,48,.10),transparent 55%),
  linear-gradient(180deg,#eef8f6 0%,#f6fafb 100%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center;
  padding:clamp(48px,7vw,96px) 0 clamp(56px,8vw,104px)}
.hero h1 .hl{position:relative;white-space:nowrap;color:var(--primary)}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.32em;background:rgba(228,48,48,.20);
  z-index:-1;border-radius:4px;transform:scaleX(0);transform-origin:left;animation:underline 1s .5s var(--ease) forwards}
@keyframes underline{to{transform:scaleX(1)}}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:2rem;align-items:center}
.hero-trust .t{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--muted);font-weight:600}
.hero-trust .t svg{color:var(--teal-400);flex:0 0 auto}
/* Hero card / device mock */
.hero-art{position:relative}
.device{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:18px;
  position:relative;z-index:2;border:1px solid var(--line);animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.device-bar{display:flex;align-items:center;gap:6px;padding:0 6px 14px}
.device-bar i{width:10px;height:10px;border-radius:50%;background:var(--mint-200);display:inline-block}
.device-bar i:nth-child(1){background:#ffd1cb}.device-bar i:nth-child(2){background:#ffe6b8}.device-bar i:nth-child(3){background:#c7ecdf}
.consult{display:flex;gap:12px;align-items:center;padding:14px;border-radius:16px;background:var(--mint-100);margin-bottom:12px}
.consult .av{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--teal-400),var(--primary));flex:0 0 48px;
  display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-head);font-weight:800}
.consult .meta b{display:block;font-family:var(--font-head);color:var(--teal-900)}
.consult .meta span{font-size:.82rem;color:var(--muted)}
.consult .live{margin-left:auto;font-size:.72rem;font-weight:700;color:#0a8f5b;background:#e2f6ec;padding:.3em .7em;border-radius:999px;display:flex;align-items:center;gap:.4em}
.consult .live::before{content:"";width:8px;height:8px;border-radius:50%;background:#11b06a;box-shadow:0 0 0 0 rgba(17,176,106,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(17,176,106,.55)}70%{box-shadow:0 0 0 10px rgba(17,176,106,0)}100%{box-shadow:0 0 0 0 rgba(17,176,106,0)}}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-size:.8rem;font-weight:600;color:var(--teal-800);background:#fff;border:1px solid var(--line);
  padding:.5em .85em;border-radius:999px;transition:.2s var(--ease)}
.chip:hover{border-color:var(--teal-400);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.float-badge{position:absolute;background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:12px 16px;z-index:3;
  display:flex;align-items:center;gap:10px;font-weight:700;font-family:var(--font-head);color:var(--teal-900);font-size:.9rem;border:1px solid var(--line)}
.float-badge .ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}
.fb-1{top:8%;right:-18px;animation:floaty 5s ease-in-out infinite}
.fb-2{bottom:10%;left:-26px;animation:floaty 7s ease-in-out .5s infinite}
.blob{position:absolute;inset:auto;width:120%;height:120%;top:-10%;left:-10%;z-index:1;
  background:radial-gradient(closest-side,rgba(22,177,166,.25),transparent);filter:blur(8px)}

/* ---------- Marquee / banner ---------- */
.alert-banner{background:linear-gradient(90deg,var(--teal-800),var(--primary));color:#fff;font-size:clamp(.72rem,1.02vw,.92rem);font-weight:600}
.alert-banner .container{display:flex;gap:.8rem;align-items:center;justify-content:center;padding-block:.7rem;text-align:center;flex-wrap:nowrap;max-width:1440px}
.alert-banner a{color:#fff;text-decoration:underline;font-weight:700}
.alert-banner .pill{background:rgba(255,255,255,.18);padding:.2em .7em;border-radius:999px;font-weight:700}
.alert-banner .pill,.alert-banner>.container>span,.alert-banner a{white-space:nowrap}
@media (max-width:1000px){
  .alert-banner .container{flex-wrap:wrap;gap:.45rem}
  .alert-banner .pill,.alert-banner>.container>span,.alert-banner a{white-space:normal}
  .alert-banner{font-size:.84rem}
}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,26px)}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,3vw,30px);text-align:center;
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.stat:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.stat b{display:block;font-family:var(--font-head);font-weight:800;font-size:clamp(1.9rem,4vw,2.8rem);
  color:var(--primary);letter-spacing:-.03em;line-height:1}
.stat span{font-size:.92rem;color:var(--muted);font-weight:600}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:clamp(18px,2.4vw,28px)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,2.6vw,30px);
  box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(20,160,166,.06),transparent 50%);opacity:0;transition:opacity .3s}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--mint-200)}
.card:hover::before{opacity:1}
.card .ic{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:var(--mint-100);color:var(--primary);margin-bottom:1rem;transition:.35s var(--ease)}
.card:hover .ic{transform:rotate(-6deg) scale(1.06);background:var(--primary);color:#fff}
/* ---- animated feature icons ---- */
.aic{overflow:visible}
.aic-check{stroke-dasharray:1;stroke-dashoffset:0}
@media (prefers-reduced-motion:no-preference){
  .card .aic-rec{animation:aic-blink 1.5s ease-in-out infinite}
  .card .aic-sec{transform-box:view-box;transform-origin:12px 12px;animation:aic-rotate 3.2s linear infinite}
  .card .aic-min{transform-box:view-box;transform-origin:12px 12px;animation:aic-rotate 20s linear infinite}
  .card .aic-coin{transform-box:fill-box;transform-origin:center;animation:aic-flip 4.6s ease-in-out infinite}
  .card .aic-check{animation:aic-draw 3.4s ease-in-out infinite}
  .card .aic-pill{transform-box:fill-box;transform-origin:center;animation:aic-wiggle 3.8s ease-in-out infinite}
  .card .aic-merid{transform-box:view-box;transform-origin:12px 12px;animation:aic-spin 4.2s ease-in-out infinite}
  .card:hover .aic-sec{animation-duration:1.1s}
  .card:hover .aic-coin{animation-duration:1.7s}
  .card:hover .aic-pill{animation-duration:1.2s}
  .card:hover .aic-merid{animation-duration:2s}
}
@keyframes aic-blink{0%,100%{opacity:1}50%{opacity:.12}}
@keyframes aic-rotate{to{transform:rotate(360deg)}}
@keyframes aic-flip{0%,66%{transform:scaleX(1)}83%{transform:scaleX(.06)}100%{transform:scaleX(1)}}
@keyframes aic-draw{0%{stroke-dashoffset:1}30%{stroke-dashoffset:0}80%{stroke-dashoffset:0}100%{stroke-dashoffset:1}}
@keyframes aic-wiggle{0%,52%,100%{transform:rotate(0)}63%{transform:rotate(-10deg)}76%{transform:rotate(8deg)}88%{transform:rotate(-3deg)}}
@keyframes aic-spin{0%{transform:scaleX(1)}50%{transform:scaleX(.16)}100%{transform:scaleX(1)}}

/* ===== How-it-works animated step scenes ===== */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,24px)}
.proc-step{position:relative}
.proc-stage{height:140px;border-radius:16px;background:linear-gradient(180deg,#eff9f7,#dff1ed);border:1px solid var(--mint-200);overflow:hidden;margin-bottom:1.1rem}
.proc-stage svg{width:100%;height:100%;display:block}
.proc-head{display:flex;align-items:center;gap:.55rem;margin-bottom:.3rem}
.proc-num{flex:0 0 auto;width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--primary),var(--teal-400));color:#fff;font-family:var(--font-head);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:.95rem;box-shadow:var(--shadow-sm)}
.proc-step h3{margin:0;font-size:1.1rem}
.proc-step p{color:var(--muted);font-size:.94rem;margin:.3rem 0 0}
.proc-step:hover .proc-stage{box-shadow:var(--shadow);transition:box-shadow .3s var(--ease)}
@media (max-width:980px){.proc{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.proc{grid-template-columns:1fr}}
/* static (resting) states so reduced-motion shows a complete scene */
.s1-fill{transform-box:fill-box;transform-origin:left center}
.s1-check{transform-box:fill-box;transform-origin:center}
.s4-check{stroke-dasharray:1;stroke-dashoffset:0}
.s4-plane{opacity:0}
@media (prefers-reduced-motion:no-preference){
  .s1-f1{animation:s1f1 4.6s ease-in-out infinite}
  .s1-f2{animation:s1f2 4.6s ease-in-out infinite}
  .s1-check{animation:s1ck 4.6s ease-in-out infinite}
  .s2-sel{animation:s2move 5s cubic-bezier(.6,0,.2,1) infinite}
  .s3-m1{animation:s3a 5.4s ease-in-out infinite}
  .s3-m2{animation:s3b 5.4s ease-in-out infinite}
  .s3-m3{animation:s3c 5.4s ease-in-out infinite}
  .s3-dot{animation:s3dot 1.1s ease-in-out infinite}
  .s3-dot.d2{animation-delay:.16s}.s3-dot.d3{animation-delay:.32s}
  .s4-c1{animation:s4d1 5s ease-in-out infinite}
  .s4-c2{animation:s4d2 5s ease-in-out infinite}
  .s4-c3{animation:s4d3 5s ease-in-out infinite}
  .s4-plane{animation:s4send 5s ease-in-out infinite}
}
@keyframes s1f1{0%,4%{transform:scaleX(0)}16%,90%{transform:scaleX(1)}100%{transform:scaleX(0)}}
@keyframes s1f2{0%,20%{transform:scaleX(0)}32%,90%{transform:scaleX(1)}100%{transform:scaleX(0)}}
@keyframes s1ck{0%,42%{transform:scale(0)}52%,90%{transform:scale(1)}100%{transform:scale(0)}}
@keyframes s2move{0%,26%{transform:translateX(0)}33%,59%{transform:translateX(52px)}66%,93%{transform:translateX(104px)}100%{transform:translateX(0)}}
@keyframes s3a{0%,5%{opacity:0;transform:translateY(8px)}13%,93%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(8px)}}
@keyframes s3b{0%,24%{opacity:0;transform:translateY(8px)}32%,93%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(8px)}}
@keyframes s3c{0%,44%{opacity:0;transform:translateY(8px)}52%,93%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(8px)}}
@keyframes s3dot{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes s4d1{0%,12%{stroke-dashoffset:1}24%,90%{stroke-dashoffset:0}100%{stroke-dashoffset:1}}
@keyframes s4d2{0%,26%{stroke-dashoffset:1}38%,90%{stroke-dashoffset:0}100%{stroke-dashoffset:1}}
@keyframes s4d3{0%,40%{stroke-dashoffset:1}52%,90%{stroke-dashoffset:0}100%{stroke-dashoffset:1}}
@keyframes s4send{0%,58%{opacity:0;transform:translate(0,0)}66%,84%{opacity:1;transform:translate(8px,-10px)}94%{opacity:0;transform:translate(22px,-30px)}100%{opacity:0}}
.card h3{margin-bottom:.4rem}
.card p{margin-bottom:0;color:var(--muted);font-size:.97rem}
.card .more{display:inline-flex;align-items:center;gap:.35em;margin-top:1rem;font-weight:700;font-family:var(--font-head);font-size:.92rem}
.card .more svg{transition:transform .25s var(--ease)}
.card:hover .more svg{transform:translateX(4px)}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,26px);counter-reset:s}
.step{position:relative}
.step .n{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--teal-400));
  color:#fff;font-family:var(--font-head);font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);margin-bottom:1.1rem}
.step h3{font-size:1.16rem;margin-bottom:.3rem}
.step p{color:var(--muted);font-size:.95rem;margin:0}
.step::after{content:"";position:absolute;top:23px;left:58px;right:-14px;height:2px;
  background:repeating-linear-gradient(90deg,var(--teal-300) 0 6px,transparent 6px 12px);opacity:.6}
.step:last-child::after{display:none}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);align-items:center}
.split.rev .split-media{order:-1}
.media-card{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);position:relative;background:#fff}
.media-card img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.check-list{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:.85rem}
.check-list li{display:flex;gap:.7rem;align-items:flex-start;font-weight:500}
.check-list svg{flex:0 0 24px;color:#11b06a;margin-top:2px}

/* ---------- Condition finder (interactive) ---------- */
.finder{background:linear-gradient(135deg,var(--teal-900),var(--primary-600));border-radius:var(--radius-lg);
  padding:clamp(28px,4vw,48px);color:#fff;position:relative;overflow:hidden}
.finder::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;right:-120px;top:-120px;
  background:radial-gradient(closest-side,rgba(22,177,166,.4),transparent);pointer-events:none}
.finder h2{color:#fff}.finder .lead{color:rgba(255,255,255,.82)}
.finder-search{display:flex;gap:.6rem;flex-wrap:wrap;margin:1.4rem 0 1rem;position:relative;z-index:2}
.finder-search input{flex:1;min-width:220px;border:none;border-radius:14px;padding:1em 1.2em;font-size:1rem;font-family:var(--font-body);
  background:rgba(255,255,255,.95);color:var(--ink)}
.finder-search input:focus{outline:none;box-shadow:var(--ring)}
.finder-go{flex:0 0 auto;border:none;cursor:pointer;border-radius:14px;width:56px;display:flex;align-items:center;justify-content:center;
  background:var(--coral);color:#fff;box-shadow:0 8px 18px rgba(228,48,48,.34);transition:transform .2s var(--ease),background .2s}
.finder-go:hover{background:var(--coral-600);transform:translateY(-2px)}
.finder-go svg{width:22px;height:22px}
.finder-tags{display:flex;flex-wrap:wrap;gap:.5rem;position:relative;z-index:2}
.finder-tags button{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;font-weight:600;
  font-family:var(--font-head);font-size:.86rem;padding:.5em .9em;border-radius:999px;cursor:pointer;transition:.2s var(--ease)}
.finder-tags button:hover{background:#fff;color:var(--teal-800);transform:translateY(-2px)}
.finder-result{margin-top:1.2rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:16px;
  padding:1rem 1.2rem;position:relative;z-index:2;display:none}
.finder-result.show{display:block;animation:fadeUp .4s var(--ease)}
.finder-result.treatable{border-color:rgba(120,240,180,.5)}
.finder-result.emergency{background:rgba(255,111,94,.18);border-color:rgba(255,111,94,.6)}
.finder-result.inperson{background:rgba(255,179,77,.14);border-color:rgba(255,179,77,.55)}
.finder-result.loading{display:flex;align-items:center;gap:.6em;color:rgba(255,255,255,.85)}
.finder-result a{color:#fff;text-decoration:underline;font-weight:700}
.finder-result .finder-link{display:inline-block;margin-top:.4rem}
.finder-result .finder-book{margin-top:.8rem;text-decoration:none}
.finder-disc{margin-top:.7rem;font-size:.78rem;color:rgba(255,255,255,.6);font-style:italic}
.finder-spin{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:ev-spin .7s linear infinite}
@keyframes ev-spin{to{transform:rotate(360deg)}}

/* ---------- Pricing ---------- */
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(28px,3.4vw,44px);
  box-shadow:var(--shadow);position:relative;overflow:hidden;max-width:460px;margin-inline:auto}
.price-card.feature{border:2px solid var(--teal-400);box-shadow:var(--shadow-lg)}
.price-tag{font-family:var(--font-head);font-weight:800;color:var(--teal-900);display:flex;align-items:flex-start;gap:.15em;line-height:1}
.price-tag .cur{font-size:1.4rem;margin-top:.5rem}
.price-tag .amt{font-size:clamp(3rem,7vw,4.4rem);letter-spacing:-.04em}
.price-tag .per{font-size:1rem;color:var(--muted);align-self:flex-end;margin-bottom:.7rem;margin-left:.3em}
.ribbon{position:absolute;top:18px;right:-42px;transform:rotate(45deg);background:var(--coral);color:#fff;
  font-family:var(--font-head);font-weight:700;font-size:.74rem;padding:.4em 3em;box-shadow:var(--shadow-sm)}

/* ---------- Testimonials ---------- */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,2.6vw,30px);box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease),box-shadow .3s}
.quote:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.quote .stars{color:var(--amber);letter-spacing:2px;margin-bottom:.6rem}
.quote p{font-size:1.02rem;color:var(--ink)}
.quote .who{display:flex;align-items:center;gap:.7rem;margin-top:1rem}
.quote .who .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--teal-400),var(--primary));
  color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800}
.quote .who b{font-family:var(--font-head);color:var(--teal-900);display:block;font-size:.95rem}
.quote .who span{font-size:.84rem;color:var(--muted)}

/* ---------- FAQ accordion ---------- */
.faq{max-width:820px;margin-inline:auto;display:grid;gap:.8rem}
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:box-shadow .3s,border-color .3s}
.faq details[open]{box-shadow:var(--shadow);border-color:var(--mint-200)}
.faq summary{cursor:pointer;list-style:none;padding:1.1em 1.3em;font-family:var(--font-head);font-weight:700;color:var(--teal-900);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:1.04rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:0 0 26px;width:26px;height:26px;border-radius:50%;background:var(--mint-100);position:relative;transition:.3s var(--ease)}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--primary);border-radius:2px;
  top:50%;left:50%;transform:translate(-50%,-50%);transition:.3s var(--ease)}
.faq summary .pm::before{width:12px;height:2px}.faq summary .pm::after{width:2px;height:12px}
.faq details[open] summary .pm{background:var(--primary)}
.faq details[open] summary .pm::before,.faq details[open] summary .pm::after{background:#fff}
.faq details[open] summary .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq .ans{padding:0 1.3em 1.3em;color:var(--muted)}
.faq .ans p:last-child{margin-bottom:0}
.faq summary .pill-ic{display:inline-flex;color:var(--primary);flex:0 0 auto}
.faq summary .pill-ic svg{width:20px;height:20px}
.faq details[open] summary .pill-ic{color:var(--primary)}

/* ---------- CTA band ---------- */
.cta-band{background:
  radial-gradient(700px 360px at 90% 10%,rgba(228,48,48,.20),transparent 60%),
  linear-gradient(135deg,var(--teal-900),var(--primary-600));border-radius:var(--radius-lg);
  padding:clamp(36px,5vw,64px);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:#fff}.cta-band .lead{color:rgba(255,255,255,.85);margin-inline:auto}
.cta-band .hero-cta{justify-content:center}

/* ---------- Footer ---------- */
.site-footer{background:var(--teal-900);color:rgba(255,255,255,.78);margin-top:clamp(40px,6vw,80px)}
.site-footer .container{padding-block:clamp(44px,6vw,72px)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(24px,3vw,40px)}
.site-footer h4{color:#fff;font-size:.92rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1rem}
.site-footer a{color:rgba(255,255,255,.78);display:block;padding:.28em 0;font-size:.94rem}
.site-footer a:hover{color:#fff;transform:translateX(3px)}
.foot-brand .brand{color:#fff}.foot-brand .brand small{color:rgba(255,255,255,.6)}
.foot-brand p{font-size:.92rem;color:rgba(255,255,255,.6);max-width:34ch;margin-top:1rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.4rem;padding-top:1.6rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.86rem;color:rgba(255,255,255,.6)}
.powered{display:inline-flex;align-items:center;gap:.45em;font-weight:600;color:rgba(255,255,255,.8)}
.powered b{color:var(--teal-300)}
.emergency-note{background:rgba(255,111,94,.16);border:1px solid rgba(255,111,94,.4);border-radius:14px;
  padding:1rem 1.2rem;margin-bottom:2rem;font-size:.9rem;color:#fff;display:flex;gap:.7rem;align-items:flex-start}
.emergency-note svg{flex:0 0 auto;color:var(--coral)}

/* ---------- Article / content ---------- */
.article-hero{background:linear-gradient(180deg,#f1faf8,#f7fbfb);padding:clamp(36px,5vw,64px) 0 clamp(20px,3vw,32px)}
.breadcrumb{font-size:.84rem;color:var(--muted);margin-bottom:1rem;display:flex;gap:.5em;flex-wrap:wrap}
.breadcrumb a{color:var(--primary-600);font-weight:600}
.cluster-tag{display:inline-block;font-family:var(--font-head);font-weight:700;font-size:.76rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--primary);background:var(--mint-100);padding:.4em .9em;border-radius:999px;margin-bottom:1rem}
.article-meta{display:flex;gap:1.2rem;flex-wrap:wrap;color:var(--muted);font-size:.88rem;margin-top:1rem}
.article-meta span{display:flex;align-items:center;gap:.4em}
.prose{max-width:760px;margin-inline:auto}
.prose>*{margin-bottom:1.2em}
.prose h2{margin-top:2em;font-size:clamp(1.4rem,2.6vw,1.9rem)}
.prose h3{margin-top:1.4em}
.prose ul,.prose ol{padding-left:1.3em;color:var(--ink)}
.prose li{margin-bottom:.5em}
.prose .callout{background:var(--mint-100);border-left:4px solid var(--teal-400);border-radius:0 14px 14px 0;
  padding:1.1em 1.3em;color:var(--teal-900)}
.prose .callout.warn{background:#fff4f1;border-color:var(--coral)}
.prose .callout strong{color:var(--teal-900)}
.prose blockquote{margin:0;padding:1em 1.3em;border-left:4px solid var(--teal-300);background:#fff;border-radius:0 14px 14px 0;font-style:italic;color:var(--ink)}
.prose .key-takeaways{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.4em 1.6em;box-shadow:var(--shadow-sm)}
.prose .key-takeaways h3{margin-top:0}
.toc{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.2em 1.4em;box-shadow:var(--shadow-sm);font-size:.94rem}
.toc b{font-family:var(--font-head);color:var(--teal-900)}
.toc a{display:block;padding:.3em 0;color:var(--muted)}
.toc a:hover{color:var(--primary)}
.article-cta{background:linear-gradient(135deg,var(--mint-100),#fff);border:1px solid var(--mint-200);border-radius:var(--radius);
  padding:1.6em 1.8em;text-align:center;box-shadow:var(--shadow-sm)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* article listing cards */
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.post-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.post-card .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--teal-400),var(--primary));position:relative;overflow:hidden}
.post-card .thumb .thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease)}
.post-card:hover .thumb .thumb-img{transform:scale(1.05)}
.article-hero-img{display:block;width:100%;aspect-ratio:24/7;object-fit:cover;border-radius:18px;box-shadow:var(--shadow);margin-top:1.6rem}
@media (max-width:560px){.article-hero-img{aspect-ratio:16/9}}

/* ===== Accessibility widget ===== */
.a11y{position:fixed;left:20px;bottom:20px;z-index:76}
.a11y-fab{width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;background:var(--teal-800);color:#fff;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:.3s var(--ease)}
.a11y-fab:hover{background:var(--primary);transform:translateY(-3px)}
.a11y-panel{position:absolute;left:0;bottom:60px;width:266px;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-lg);padding:14px;display:none;animation:fadeUp .25s var(--ease)}
.a11y.open .a11y-panel{display:block}
.a11y-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.a11y-head strong{font-family:var(--font-head);color:var(--teal-900)}
.a11y-x{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--muted);padding:0 .2em}
.a11y-opt{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.6rem;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:11px;padding:.6em .8em;margin-bottom:.5rem;cursor:pointer;font-family:var(--font-head);
  font-weight:600;font-size:.92rem;color:var(--ink);transition:.2s var(--ease);text-align:left}
.a11y-opt:hover{border-color:var(--teal-400)}
.a11y-sw{flex:0 0 auto;width:38px;height:22px;border-radius:999px;background:var(--line);position:relative;transition:.2s var(--ease)}
.a11y-sw::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:.2s var(--ease)}
.a11y-opt[aria-pressed="true"] .a11y-sw{background:var(--primary)}
.a11y-opt[aria-pressed="true"] .a11y-sw::after{transform:translateX(16px)}
.a11y-reset{width:100%;border:none;background:none;color:var(--primary-600);font-weight:700;font-family:var(--font-head);cursor:pointer;padding:.4em;margin-top:.2rem}
.a11y-note{font-size:.72rem;color:var(--muted);margin:.5rem 0 0;text-align:center}
@media (max-width:560px){.a11y-panel{width:240px}}
/* ----- a11y modes ----- */
html.a11y-bigtext{font-size:118%}
html.a11y-contrast{--muted:#33454f;--line:#8aa0ac;--ink:#05111c;--bg:#ffffff;--bg-soft:#eef3f5}
html.a11y-contrast .lead,html.a11y-contrast .card p,html.a11y-contrast .post-card p,html.a11y-contrast .step p{color:#2a3b46}
html.a11y-contrast a:not(.btn):not(.lang):not(.brand){text-decoration:underline}
html.a11y-motion *,html.a11y-motion *::before,html.a11y-motion *::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
/* colour-vision-friendly: recolour status/verdict signals to a CVD-safe palette (Okabe-Ito); meaning is also carried by icons/text, not colour alone */
html.a11y-cvd .finder-result.treatable{border-color:#7ab8f0;background:rgba(0,114,178,.24)}
html.a11y-cvd .finder-result.emergency{background:rgba(213,94,0,.24);border-color:#d55e00}
html.a11y-cvd .finder-result.inperson{background:rgba(230,159,0,.18);border-color:#e69f00}
html.a11y-cvd .check-list svg{color:#0072B2}
html.a11y-cvd .consult .live{color:#08518f;background:#dbeafe}
html.a11y-cvd .consult .live::before{background:#0072B2}
html.a11y-cvd .float-badge .ic[style*="11b06a"]{background:#0072B2!important}
html.a11y-cvd .stat b{color:#0a5a93}
html.a11y-cvd .card.warn,html.a11y-cvd .callout.warn{background:#fff2e3;border-color:#e69f00}
html.a11y-cvd .quote .stars{color:#0072B2}
.post-card .thumb .em{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3.4rem;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.18))}
.post-card .body{padding:1.3em 1.4em;display:flex;flex-direction:column;flex:1}
.post-card .tag{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:.5rem}
.post-card h3{font-size:1.12rem;margin-bottom:.4rem}
.post-card p{font-size:.92rem;color:var(--muted);margin-bottom:1rem}
.post-card .more{margin-top:auto;font-weight:700;font-family:var(--font-head);font-size:.9rem;display:inline-flex;align-items:center;gap:.35em}
.post-card .more svg{transition:transform .25s var(--ease)}.post-card:hover .more svg{transform:translateX(4px)}

/* cluster header */
.cluster-block{margin-bottom:clamp(36px,5vw,64px)}
.cluster-head{display:flex;align-items:center;gap:1rem;margin-bottom:1.4rem;flex-wrap:wrap}
.cluster-head .ic{width:52px;height:52px;border-radius:14px;background:var(--mint-100);color:var(--primary);
  display:flex;align-items:center;justify-content:center;flex:0 0 52px}
.cluster-head h2{margin:0}
.cluster-head p{margin:.2rem 0 0;color:var(--muted);font-size:.95rem;width:100%}

/* filter pills */
.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2.4rem}
.filter-bar button{font-family:var(--font-head);font-weight:600;font-size:.9rem;border:1px solid var(--line);background:#fff;
  color:var(--teal-800);padding:.55em 1.1em;border-radius:999px;cursor:pointer;transition:.2s var(--ease)}
.filter-bar button:hover{border-color:var(--teal-400);transform:translateY(-2px)}
.filter-bar button.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* contact form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field.full{grid-column:1/-1}
.field label{font-family:var(--font-head);font-weight:600;font-size:.9rem;color:var(--teal-900)}
.field input,.field select,.field textarea{border:1px solid var(--line);border-radius:12px;padding:.85em 1em;font-size:1rem;
  font-family:var(--font-body);background:#fff;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal-400);box-shadow:var(--ring)}

/* ---------- Reveal animations ---------- */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-stagger]>*{opacity:0;transform:translateY(28px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-reveal-stagger].in>*{opacity:1;transform:none}
[data-reveal-stagger].in>*:nth-child(2){transition-delay:.08s}
[data-reveal-stagger].in>*:nth-child(3){transition-delay:.16s}
[data-reveal-stagger].in>*:nth-child(4){transition-delay:.24s}
[data-reveal-stagger].in>*:nth-child(5){transition-delay:.32s}
[data-reveal-stagger].in>*:nth-child(6){transition-delay:.40s}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* progress bar */
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:80;
  background:linear-gradient(90deg,var(--teal-400),var(--coral));transition:width .1s linear}

/* back to top */
.to-top{position:fixed;right:20px;bottom:20px;width:48px;height:48px;border-radius:50%;background:var(--primary);color:#fff;
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);z-index:70;
  opacity:0;transform:translateY(20px) scale(.8);transition:.3s var(--ease)}
.to-top.show{opacity:1;transform:none}
.to-top:hover{background:var(--coral);transform:translateY(-3px)}

/* skip link */
.skip{position:absolute;left:-999px;top:0;background:#fff;color:var(--teal-900);padding:.7em 1.2em;border-radius:0 0 12px 0;
  z-index:200;font-weight:700}
.skip:focus{left:0}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-art{max-width:460px;margin-inline:auto;order:-1}
  .stats{grid-template-columns:repeat(2,1fr)}
  .grid-3,.grid-4,.related-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step::after{display:none}
  .split{grid-template-columns:1fr}.split.rev .split-media{order:0}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links,.nav-cta .btn{display:none}
  .nav-cta{margin-left:auto;gap:.5rem}
  .menu-btn{display:flex}
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:stretch;
    background:#fff;padding:1rem;gap:.2rem;box-shadow:var(--shadow-lg);border-top:1px solid var(--line);animation:fadeUp .25s var(--ease)}
  .nav-links.open a{padding:.9em 1em;border-radius:12px}
  .nav-links.open a:hover{background:var(--mint-100)}
}
@media (max-width:560px){
  .stats,.grid-3,.grid-4,.grid-2,.related-grid,.steps,.form-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero-trust{gap:.8rem 1.2rem}
  .float-badge{display:none}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  [data-reveal],[data-reveal-stagger]>*{opacity:1!important;transform:none!important}
  .device,.fb-1,.fb-2{animation:none!important}
}
