/* ============================================================================
   zencey.css — single source of truth for the Zencey site
   ----------------------------------------------------------------------------
   Fonts: self-hosted woff2 files in /fonts/ (see fonts/fonts.css).
   Per-page accent: add body.accent-care on the Telehealth page.
   Page-specific component CSS lives in a small <style> block per page.
   ========================================================================== */

@import url('fonts/fonts.css');

:root {
  /* PRIMARY · Zencey Blue */
  --blue-50:#EFEDFE; --blue-100:#DCD7FD; --blue-200:#BCB2FB; --blue-300:#9384F9;
  --blue-400:#6A55F6; --blue-500:#2717F3; --blue-600:#1E10C9; --blue-700:#180CA0;
  --blue-800:#140B79; --blue-900:#100A4E;

  /* INK + NEUTRALS */
  --ink:#0C0A24; --ink-2:#15132f; --paper:#FFFFFF;
  --n-50:#F7F8FC; --n-100:#EFF1F7; --n-200:#E2E5EE; --n-300:#CBD0DC;
  --n-400:#9AA1B4; --n-500:#6C7488; --n-600:#4B5266; --n-700:#313747; --n-800:#1D2230;

  /* PRODUCT LINE BASE ACCENTS */
  --line-a:#2717F3; --line-b:#7C3AED; --line-c:#06B6D4;

  /* ON-DARK ACCENTS — brightened for dark bg. Do NOT "correct" to base. */
  --a-on-dark:#5B45F6; --b-on-dark:#9B6BF2; --c-on-dark:#22C7E0;

  /* WHITE TINTS */
  --w-72:rgba(255,255,255,.72); --w-58:rgba(255,255,255,.58);
  --w-55:rgba(255,255,255,.55); --w-40:rgba(255,255,255,.55); /* alias */
  --hair:rgba(255,255,255,.08); --hair-2:rgba(255,255,255,.12); --fill:rgba(255,255,255,.04);

  /* SEMANTIC */
  --ok:#16A34A; --warn:#D97706; --err:#DC2626;

  /* RADIUS · MOTION */
  --r-md:14px; --r-lg:20px; --r-xl:28px; --r-2xl:36px; --r-pill:999px;
  --ease:cubic-bezier(.22,1,.36,1);

  /* TYPE */
  --f-display:"Plus Jakarta Sans","Segoe UI",system-ui,-apple-system,"Helvetica Neue",sans-serif;
  --f-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --f-mono:"IBM Plex Mono",ui-monospace,"SF Mono","Cascadia Code",Menlo,Consolas,monospace;

  /* PER-PAGE ACCENT — default = brand blue */
  --page-accent:var(--blue-500);
  --page-accent-bright:var(--a-on-dark);
  --focus:rgba(147,132,249,.85);
  --max:1140px;
}

/* Telehealth page: add class="accent-care" to <body> */
body.accent-care {
  --page-accent:var(--line-c);
  --page-accent-bright:var(--c-on-dark);
  --focus:rgba(34,199,224,.85);
}
body.accent-care .eyebrow { color:#9fe6f1 }

/* ============================ BASE ============================ */
*{box-sizing:border-box}
body{margin:0;font-family:var(--f-body);background:var(--ink);color:#fff;-webkit-font-smoothing:antialiased;line-height:1.6}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
.mono{font-family:var(--f-mono)}

.skip{position:absolute;left:-9999px;top:0;background:#fff;color:var(--ink);padding:10px 16px;border-radius:8px;z-index:200;font-family:var(--f-mono);font-size:13px;text-decoration:none}
.skip:focus{left:16px;top:16px}

/* ============================ TYPOGRAPHY ============================ */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#a9aee0}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--page-accent-bright);box-shadow:0 0 0 4px rgba(106,85,246,.22)}
h2{font-family:var(--f-display);font-weight:800;font-size:clamp(24px,3.6vw,38px);line-height:1.06;letter-spacing:-.025em;margin:14px 0 0}
.lede{color:var(--w-72);font-size:clamp(15px,1.6vw,17px);max-width:60ch}

/* ============================ BUTTONS ============================ */
.btn{display:inline-flex;align-items:center;justify-content:center;height:46px;padding:0 24px;border-radius:var(--r-pill);font-family:var(--f-mono);font-size:13px;letter-spacing:.02em;text-decoration:none;border:1.5px solid transparent;cursor:pointer;transition:all var(--ease) .2s;white-space:nowrap}
.btn.solid{background:var(--blue-500);color:#fff;box-shadow:0 10px 26px rgba(39,23,243,.42)}
.btn.solid:hover{background:var(--blue-400);transform:translateY(-1px)}
.btn.ghost{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
.btn.ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}

/* ============================ NAV ============================ */
nav{display:flex;align-items:center;gap:28px;padding:22px 0}
nav .logo{height:30px;display:block}
nav .links{display:flex;gap:26px;margin-left:14px;flex:1}
nav .links a{font-family:var(--f-mono);font-size:13px;color:#c9cce8;text-decoration:none;transition:color var(--ease) .2s;position:relative;padding-bottom:3px}
nav .links a:hover{color:#fff}
nav .links a.active,nav .links a[aria-current="page"]{color:#fff}
nav .links a.active::after,nav .links a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;border-radius:2px;background:var(--page-accent-bright)}
nav .menu{display:none}

/* ============================ HERO SHELL ============================ */
.hero-shell{background:
  radial-gradient(820px 460px at 84% -6%, rgba(39,23,243,.55), transparent 58%),
  radial-gradient(560px 380px at 4% 118%, rgba(6,182,212,.16), transparent 60%),
  var(--ink);}

/* ============================ BANDS ============================ */
section.band{padding:72px 0;border-top:1px solid var(--hair)}
.band-head{max-width:760px}
.band-head .lede{margin-top:14px}

/* ============================ RAIL MOTIF ============================ */
.panel{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--hair-2);border-radius:var(--r-2xl);padding:26px 24px 22px;box-shadow:0 30px 80px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.06)}
svg.rail{display:block;width:100%;height:auto;overflow:visible}
.flow,.flow-l{fill:none;stroke-linecap:round}
.track{stroke:rgba(255,255,255,.12)}
.pulse{fill:none;stroke-linecap:round;stroke-dasharray:7 93}
@keyframes run{to{stroke-dashoffset:-100}}
.pulse.a{stroke:var(--a-on-dark);animation:run 3.4s linear infinite;filter:drop-shadow(0 0 6px rgba(91,69,246,.9))}
.pulse.b{stroke:var(--b-on-dark);animation:run 3.4s linear infinite 1s;filter:drop-shadow(0 0 6px rgba(155,107,242,.85))}
.pulse.c{stroke:var(--c-on-dark);animation:run 3.4s linear infinite 2s;filter:drop-shadow(0 0 6px rgba(34,199,224,.85))}
.node{fill:var(--ink);stroke:rgba(255,255,255,.6);stroke-width:2.5}

/* ============================ FOOTER (main pages) ============================ */
footer{border-top:1px solid var(--hair);padding:54px 0 64px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:30px}
.fbrand .logo{height:26px;margin-bottom:16px}
.fbrand p{color:var(--w-58);font-size:13.5px;max-width:34ch;margin:0 0 10px}
.fbrand .loc{font-family:var(--f-mono);font-size:11.5px;color:var(--w-55)}
.fcol h4{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--w-55);margin:0 0 14px}
.fcol a{display:block;color:var(--w-72);text-decoration:none;font-size:13.5px;margin:9px 0;transition:color var(--ease) .2s}
.fcol a:hover{color:#fff}
.legal{margin-top:40px;padding-top:22px;border-top:1px solid var(--hair);font-family:var(--f-mono);font-size:11.5px;color:var(--w-55);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ============================ FOOTER (legal + contact pages) ============================ */
.footer-legal{font-family:var(--f-mono);font-size:11.5px;color:var(--w-55);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ============================ LEGAL PAGES ============================ */
.legal-hero{padding:54px 0 36px;border-bottom:1px solid var(--hair)}
.legal-hero .eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#a9aee0;margin-bottom:14px}
.legal-hero .eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--blue-400);box-shadow:0 0 0 4px rgba(106,85,246,.22)}
.legal-hero h1{font-family:var(--f-display);font-weight:800;font-size:clamp(26px,4vw,44px);line-height:1.08;letter-spacing:-.03em;margin:0 0 10px}
.legal-hero .meta{font-family:var(--f-mono);font-size:12px;color:var(--w-55);letter-spacing:.04em}

.legal-body{max-width:760px;padding:44px 0 90px}
.legal-body h2{font-family:var(--f-display);font-weight:700;font-size:18px;letter-spacing:-.01em;margin:40px 0 10px;color:#fff}
.legal-body h3{font-family:var(--f-display);font-weight:600;font-size:15px;margin:24px 0 8px;color:var(--w-72)}
.legal-body p{color:var(--w-72);font-size:15px;line-height:1.72;margin:0 0 14px}
.legal-body ul{color:var(--w-72);font-size:15px;line-height:1.72;padding-left:22px;margin:0 0 14px}
.legal-body ul li{margin-bottom:6px}
.legal-body strong{color:#fff;font-weight:600}
.legal-body em{font-style:italic;color:var(--w-72)}
.legal-body a{color:#cbd3ff;text-underline-offset:3px}
.legal-body a:hover{color:#fff}
.legal-body .section-num{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-300);display:block;margin-bottom:4px}
.legal-body .callout{background:rgba(255,255,255,.04);border:1px solid var(--hair-2);border-radius:var(--r-md);padding:16px 20px;margin:16px 0 20px}
.legal-body .callout p{margin:0;font-size:13.5px}
.divider{border:none;border-top:1px solid var(--hair);margin:40px 0}

/* ============================ A11Y ============================ */
a:focus-visible,.btn:focus-visible,button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--focus);border-radius:var(--r-pill)}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ============================ RESPONSIVE ============================ */
@media(max-width:880px){
  nav{position:relative}
  nav .links{display:none}
  nav .menu{display:inline-flex}
  nav .links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:-32px;right:-32px;background:var(--ink-2);padding:16px 32px 24px;gap:16px;border-bottom:1px solid var(--hair);z-index:50}
  .fgrid{grid-template-columns:1fr}
}
