/* =========================================================
   FeelWell Health Ltd — Website Stylesheet
   Brand: Navy / Teal / White · Premium medical-device aesthetic
   Type:  Schibsted Grotesk (display) + Manrope (body)
   ========================================================= */

/* ---------- Tokens ---------- */
:root {
  /* Navy */
  --navy-950:#06182b; --navy-900:#0a2540; --navy-800:#0e3358;
  --navy-700:#154270; --navy-600:#1d5489; --navy-500:#2f6aa3;
  /* Teal */
  --teal-700:#0a7c7c; --teal-600:#0e9596; --teal-500:#16b0ab;
  --teal-400:#43c7bf; --teal-300:#84dcd5; --teal-100:#d7f1ee;
  /* Soft clinical tints */
  --blue-tint-300:#c3d6ec; --blue-tint-100:#e7eef8; --blue-tint-50:#f2f6fc;
  /* Neutrals */
  --white:#ffffff; --paper:#f7fafd; --mist:#eef3f9;
  --ink-900:#0b1b2b; --ink-700:#2c3e50; --ink-500:#5b6b7b;
  --ink-400:#8294a6; --line:#dde6ef;

  /* Semantic */
  --brand:var(--navy-900); --brand-strong:var(--navy-950);
  --accent:var(--teal-600); --accent-strong:var(--teal-700); --accent-soft:var(--teal-100);
  --surface-page:var(--paper); --surface-card:var(--white);
  --surface-muted:var(--mist); --surface-tint:var(--blue-tint-50);
  --surface-invert:var(--navy-900);
  --text-strong:var(--ink-900); --text-body:var(--ink-700);
  --text-muted:var(--ink-500); --text-caption:var(--ink-400);
  --text-on-invert:#eaf2fb; --text-on-accent:#ffffff;
  --border-subtle:var(--line); --border-accent:var(--teal-400);
  --focus-ring:color-mix(in srgb, var(--teal-500) 55%, transparent);

  /* Type */
  --font-display:'Schibsted Grotesk','Helvetica Neue',Arial,sans-serif;
  --font-body:'Manrope','Helvetica Neue',Arial,sans-serif;
  --w-regular:400; --w-medium:500; --w-semibold:600; --w-bold:700; --w-extra:800;
  --fs-display:clamp(2.4rem,1.5rem + 3vw,4.25rem);
  --fs-h1:clamp(2rem,1.4rem + 2vw,3rem);
  --fs-h2:clamp(1.55rem,1.2rem + 1.2vw,2.2rem);
  --fs-h3:1.25rem;
  --fs-lead:clamp(1.05rem,1rem + 0.3vw,1.25rem);
  --fs-body:1.0625rem; --fs-small:0.9375rem;
  --fs-eyebrow:0.8125rem; --fs-caption:0.8125rem;
  --lh-tight:1.05; --lh-snug:1.2; --lh-normal:1.55; --lh-relaxed:1.7;
  --ls-tight:-0.02em; --ls-display:-0.025em; --ls-eyebrow:0.14em;

  /* Spacing */
  --space-1:0.25rem; --space-2:0.5rem; --space-3:0.75rem; --space-4:1rem;
  --space-5:1.5rem; --space-6:2rem; --space-7:3rem; --space-8:4rem;
  --space-9:6rem; --space-10:8rem;
  --section-y:clamp(3.5rem,2.5rem + 4vw,6.5rem);
  --container:1180px; --container-narrow:760px;
  --gutter:clamp(1.25rem,0.75rem + 2vw,2.5rem);

  /* Radii */
  --r-xs:6px; --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-pill:999px;

  /* Shadows */
  --shadow-xs:0 1px 2px rgba(10,37,64,.06);
  --shadow-sm:0 2px 8px rgba(10,37,64,.06),0 1px 2px rgba(10,37,64,.05);
  --shadow-md:0 8px 24px rgba(10,37,64,.08),0 2px 6px rgba(10,37,64,.05);
  --shadow-lg:0 24px 60px rgba(10,37,64,.12),0 6px 16px rgba(10,37,64,.06);
  --shadow-device:0 50px 90px -30px rgba(10,37,64,.35);
  --shadow-accent:0 10px 30px -8px rgba(14,149,150,.45);

  /* Motion */
  --ease:cubic-bezier(0.22,1,0.36,1);
  --dur:240ms;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:var(--lh-normal);
  color:var(--text-body);
  background:var(--surface-page);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,h5{font-family:var(--font-display);color:var(--text-strong);margin:0;line-height:var(--lh-snug);letter-spacing:var(--ls-tight);text-wrap:balance}
p{margin:0;text-wrap:pretty}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
ul,ol{padding:0;margin:0}
button{font-family:inherit}

/* Skip link for accessibility */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy-900);color:#fff;padding:.75rem 1rem;z-index:200}
.skip-link:focus{left:8px;top:8px;border-radius:6px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--section-y)}
.section.muted{background:var(--surface-muted)}
.section.tint{background:linear-gradient(180deg,var(--surface-tint),var(--surface-page))}
.section.dark{background:linear-gradient(160deg,var(--navy-900),var(--navy-950));color:var(--text-on-invert)}
.section.dark h1,.section.dark h2,.section.dark h3{color:#fff}

/* ---------- Atoms ---------- */
.eyebrow{
  font-family:var(--font-body); font-size:var(--fs-eyebrow); font-weight:var(--w-bold);
  letter-spacing:var(--ls-eyebrow); text-transform:uppercase; color:var(--accent-strong);
  display:inline-flex; align-items:center; gap:.55rem;
}
.eyebrow.on-dark{color:var(--teal-300)}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.55}

.section-head{max-width:720px;margin-inline:auto}
.section-head.left{margin-inline:0}
.section-head h2{font-size:var(--fs-h2);margin-top:var(--space-3);font-weight:var(--w-bold)}
.section-head .lead{margin-top:var(--space-4);font-size:var(--fs-lead);color:var(--text-muted);line-height:var(--lh-normal)}
.section.dark .section-head .lead{color:#c5d6e8}
.center{text-align:center}
.center .eyebrow{justify-content:center}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-body);font-weight:var(--w-semibold);font-size:var(--fs-small);
  padding:.9rem 1.55rem;border-radius:var(--r-pill);border:1px solid transparent;
  cursor:pointer; white-space:nowrap;
  transition:transform var(--dur) var(--ease),background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--accent);color:var(--text-on-accent);box-shadow:var(--shadow-accent)}
.btn-primary:hover{background:var(--accent-strong);transform:translateY(-2px)}
.btn-primary:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--text-strong);border-color:var(--border-subtle)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-strong)}
.btn-ghost.on-dark{color:var(--text-on-invert);border-color:rgba(255,255,255,.28)}
.btn-ghost.on-dark:hover{border-color:var(--teal-300);color:#fff;background:rgba(255,255,255,.06)}

.badge{
  display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .8rem;border-radius:var(--r-pill);
  font-size:.76rem;font-weight:var(--w-semibold);letter-spacing:.02em;
  background:var(--accent-soft);color:var(--accent-strong);
}
.badge.ghost-dark{background:rgba(255,255,255,.08);color:var(--teal-300)}
.badge svg{width:14px;height:14px}

/* ---------- Top navigation ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--border-subtle);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);height:74px}
.nav-logo img{height:38px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:var(--space-6);list-style:none}
.nav-links a{
  font-size:.92rem;font-weight:var(--w-medium);color:var(--text-muted);
  transition:color var(--dur) var(--ease); position:relative; padding-block:6px;
  white-space:nowrap;
}
.nav-links a:hover{color:var(--text-strong)}
.nav-links a.active{color:var(--accent-strong)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;border-radius:2px;background:var(--accent);
}
.nav-cta{display:flex;align-items:center;gap:var(--space-4)}
.nav-toggle{
  display:none; background:none;border:1px solid var(--border-subtle);
  width:44px;height:44px;border-radius:12px;cursor:pointer;align-items:center;justify-content:center;color:var(--text-strong);
}
.nav-toggle svg{width:22px;height:22px}

/* Mobile nav drawer */
@media (max-width:1024px){
  .nav-links,.nav-cta .btn-ghost{display:none}
  .nav-toggle{display:inline-flex}
  .nav-drawer{
    position:fixed;inset:74px 0 0 0;z-index:49;
    background:var(--paper); border-top:1px solid var(--border-subtle);
    transform:translateY(-110%); transition:transform var(--dur) var(--ease);
    overflow-y:auto;
  }
  .nav-drawer.open{transform:translateY(0)}
  .nav-drawer ul{list-style:none;padding:var(--space-5) var(--gutter);display:flex;flex-direction:column;gap:var(--space-2)}
  .nav-drawer a{
    display:block;padding:.95rem 1rem;border-radius:var(--r-md);
    font-weight:var(--w-semibold);font-size:1.02rem;color:var(--text-strong);
    border:1px solid transparent;
  }
  .nav-drawer a:hover,.nav-drawer a.active{background:var(--blue-tint-50);border-color:var(--border-subtle);color:var(--accent-strong)}
  .nav-drawer .btn{margin:var(--space-3) 1rem 0;display:flex}
}
@media (min-width:1025px){
  .nav-drawer{display:none}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;color:var(--text-on-invert);isolation:isolate;
  background:
    radial-gradient(900px 520px at 78% 8%,rgba(22,176,171,.20),transparent 60%),
    radial-gradient(700px 600px at 8% 100%,rgba(47,106,163,.28),transparent 55%),
    linear-gradient(165deg,var(--navy-900) 0%,var(--navy-950) 100%);
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:52px 52px;
  mask-image:radial-gradient(80% 80% at 60% 30%,#000,transparent 75%);
}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(2rem,1rem + 3vw,4rem);align-items:center;padding-block:clamp(3rem,2rem + 5vw,6rem)}
.hero h1{color:#fff;font-size:var(--fs-display);font-weight:var(--w-extra);letter-spacing:var(--ls-display);margin-top:var(--space-5);line-height:var(--lh-tight)}
.hero h1 .accent{color:var(--teal-300)}
.hero .sub{margin-top:var(--space-5);font-size:var(--fs-lead);color:#c5d6e8;max-width:44ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-6)}

.hero-device{position:relative;display:grid;place-items:center}
.hero-device .glow{
  position:absolute;width:78%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(67,199,191,.45),transparent 62%);filter:blur(10px);z-index:0;
}
.hero-device img{position:relative;z-index:2;width:112%;max-width:112%;filter:drop-shadow(var(--shadow-device))}

/* Hero photo frame (clinician portrait) */
.hero-photo{position:relative;display:grid;place-items:center;justify-self:center;width:100%}
.hero-photo .glow{
  position:absolute;width:84%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(67,199,191,.40),transparent 64%);filter:blur(16px);z-index:0;
}
.hero-photo img{
  position:relative;z-index:2;display:block;
  width:100%;max-width:460px;margin-inline:auto;
  border-radius:var(--r-xl);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 34px 70px -22px rgba(3,16,30,.72), 0 0 0 1px rgba(67,199,191,.10);
}
.hero-device .platform{
  position:absolute;bottom:8%;width:70%;height:40px;z-index:1;border-radius:50%;
  background:radial-gradient(ellipse,rgba(6,24,43,.6),transparent 70%);filter:blur(6px);
}

/* Page header (lighter hero for inner pages) */
.page-head{
  position:relative;overflow:hidden;color:var(--text-on-invert);
  background:
    radial-gradient(700px 400px at 88% 0%,rgba(22,176,171,.18),transparent 60%),
    linear-gradient(165deg,var(--navy-900) 0%,var(--navy-950) 100%);
  padding-block:clamp(3rem,2rem + 4vw,5.5rem);
}
.page-head h1{color:#fff;font-size:var(--fs-h1);font-weight:var(--w-extra);letter-spacing:var(--ls-display);margin-top:var(--space-4);line-height:var(--lh-snug)}
.page-head .lead{margin-top:var(--space-5);font-size:var(--fs-lead);color:#c5d6e8;max-width:60ch}
.crumbs{display:flex;gap:.5rem;align-items:center;font-size:.82rem;color:#8fa6bd;letter-spacing:.02em}
.crumbs a:hover{color:var(--teal-300)}
.crumbs .sep{opacity:.55}

/* ---------- Event meta row ---------- */
.event-meta{display:flex;flex-wrap:wrap;gap:var(--space-5);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid rgba(255,255,255,.12)}
.meta-item{display:flex;align-items:center;gap:.7rem}
.meta-item .ico{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:var(--teal-300);flex:none}
.meta-item .ico svg{width:19px;height:19px}
.meta-item .k{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:#8fa6bd;font-weight:var(--w-semibold)}
.meta-item .v{font-size:.98rem;color:#fff;font-weight:var(--w-semibold)}

/* ---------- Trust strip ---------- */
.trust{background:var(--navy-950);border-top:1px solid rgba(255,255,255,.07)}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);padding-block:var(--space-6)}
.trust-item{display:flex;flex-direction:column;gap:.25rem}
.trust-item .n{font-family:var(--font-display);font-weight:var(--w-bold);font-size:1.7rem;color:#fff;letter-spacing:-.02em}
.trust-item .n span{color:var(--teal-300)}
.trust-item .l{font-size:.85rem;color:#93a8bf}
.trust-item + .trust-item{padding-left:var(--space-5);border-left:1px solid rgba(255,255,255,.09)}

/* ---------- Grids / cards ---------- */
.grid{display:grid;gap:var(--space-5)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.card{
  background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);
  padding:var(--space-6);box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--teal-400) 50%,var(--border-subtle))}
.card .ico{
  width:50px;height:50px;border-radius:14px;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent-strong);margin-bottom:var(--space-4);
}
.card .ico svg{width:24px;height:24px}
.card h3{font-size:1.15rem;font-weight:var(--w-semibold)}
.card p{margin-top:var(--space-3);color:var(--text-muted);font-size:var(--fs-small)}
.card.invert{background:var(--surface-invert);border-color:transparent;color:var(--text-on-invert)}
.card.invert h3{color:#fff}
.card.invert p{color:#bcd0e6}
.card.invert .ico{background:rgba(255,255,255,.08);color:var(--teal-300)}

/* ---------- Split section (image + copy) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:center}
.split.reverse{grid-template-columns:1fr 1fr}
.device-stage{
  position:relative;border-radius:var(--r-xl);padding:var(--space-7);
  background:radial-gradient(700px 420px at 50% 0%,var(--blue-tint-100),var(--surface-card));
  border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);display:grid;place-items:center;
}
.device-stage img{width:100%;filter:drop-shadow(0 30px 50px rgba(10,37,64,.22))}

.feature-list{display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-5);list-style:none}
.feature-list li{display:flex;gap:.85rem;align-items:flex-start}
.feature-list .tick{flex:none;width:26px;height:26px;border-radius:50%;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;margin-top:2px}
.feature-list .tick svg{width:15px;height:15px}
.feature-list b{color:var(--text-strong);font-weight:var(--w-semibold)}
.feature-list span.muted{color:var(--text-muted)}

/* ---------- Parameter strip ---------- */
.params-head{text-align:center;display:flex;flex-direction:column;align-items:center;margin-top:var(--space-8)}
.params-head .eyebrow{justify-content:center}
.params-head .params-sub{margin-top:var(--space-3);color:var(--text-muted);font-size:var(--fs-lead);max-width:52ch}
.params{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4);margin-top:var(--space-5)}
.params-note{
  margin-top:var(--space-5);display:flex;align-items:center;justify-content:center;gap:.6rem;
  font-size:var(--fs-small);color:var(--text-muted);font-style:normal;text-wrap:pretty;text-align:center;
}
.params-note svg{width:18px;height:18px;color:var(--accent-strong);flex:none}
.param{
  text-align:center;padding:var(--space-5) var(--space-3);border-radius:var(--r-md);
  background:var(--surface-card);border:1px solid var(--border-subtle);box-shadow:var(--shadow-xs);
}
.param .ico{width:44px;height:44px;margin:0 auto var(--space-3);border-radius:12px;background:var(--blue-tint-100);color:var(--navy-700);display:grid;place-items:center}
.param .ico svg{width:22px;height:22px}
.param .name{display:block;font-weight:var(--w-semibold);font-size:.92rem;color:var(--text-strong)}
.param .det{display:block;font-size:.78rem;color:var(--text-caption);margin-top:2px}

/* ---------- Audience ---------- */
.audience{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.aud{
  display:flex;align-items:flex-start;gap:.85rem;padding:var(--space-5);
  background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--r-md);
  box-shadow:var(--shadow-xs);transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.aud:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.aud .dot{flex:none;width:40px;height:40px;border-radius:11px;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;margin-top:2px}
.aud .dot svg{width:19px;height:19px}
.aud-tx{display:flex;flex-direction:column;gap:.25rem}
.aud-t{font-weight:var(--w-semibold);font-size:1rem;color:var(--text-strong);line-height:1.25}
.aud-d{font-size:.85rem;color:var(--text-muted);line-height:1.45}

/* ---------- Highlights / icon rows ---------- */
.highlights{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4)}
.hl{text-align:center;padding:var(--space-5) var(--space-4)}
.hl .ring{
  width:64px;height:64px;margin:0 auto var(--space-4);border-radius:50%;display:grid;place-items:center;
  background:var(--surface-card);border:1px solid var(--border-subtle);color:var(--accent-strong);box-shadow:var(--shadow-sm);
}
.hl .ring svg{width:28px;height:28px}
.hl .t{font-weight:var(--w-semibold);color:var(--text-strong);font-size:.98rem}

/* ---------- About / credibility ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--space-8);align-items:center}
.about-photo{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.08)}
.about-photo img{width:100%;height:100%;object-fit:cover}
.cred{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);margin-top:var(--space-6)}
.cred-item{padding-left:var(--space-4);border-left:2px solid var(--teal-400)}
.cred-item .h{color:#fff;font-weight:var(--w-semibold);font-size:1rem}
.cred-item .p{color:#9fb4ca;font-size:var(--fs-small);margin-top:.3rem}

/* ---------- Video embed ---------- */
.video-wrap{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  background:var(--navy-900);box-shadow:var(--shadow-lg);
  border:1px solid var(--border-subtle); aspect-ratio:16/9;
}
.video-wrap iframe,.video-wrap video{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-poster{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);
  color:#eaf2fb;text-align:center;padding:var(--space-6);
  background:
    radial-gradient(700px 320px at 50% 30%,rgba(22,176,171,.22),transparent 60%),
    linear-gradient(160deg,var(--navy-900),var(--navy-950));
  cursor:pointer;transition:opacity var(--dur) var(--ease);
}
.video-poster.hidden{opacity:0;pointer-events:none}
.video-poster .play{
  width:88px;height:88px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;
  box-shadow:var(--shadow-accent);transition:transform var(--dur) var(--ease);
}
.video-poster:hover .play{transform:scale(1.06)}
.video-poster .play svg{width:36px;height:36px;margin-left:4px}
.video-poster .label{font-family:var(--font-display);font-weight:var(--w-semibold);font-size:1.25rem;color:#fff}
.video-poster .hint{font-size:.92rem;color:#9fb4ca}

/* ---------- Forms ---------- */
.form-card{
  background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);
  box-shadow:var(--shadow-lg);padding:clamp(1.75rem,1rem + 3vw,3rem);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}
.field{display:flex;flex-direction:column;gap:.45rem}
.field.full{grid-column:1/-1}
.field label{font-size:.82rem;font-weight:var(--w-semibold);color:var(--text-strong)}
.field label .req{color:var(--accent-strong)}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:var(--fs-small);color:var(--text-strong);
  padding:.85rem 1rem;border-radius:var(--r-sm);border:1px solid var(--border-subtle);
  background:var(--surface-page);width:100%;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease);
}
.field textarea{min-height:140px;resize:vertical;line-height:1.5}
.field input::placeholder,.field textarea::placeholder{color:var(--text-caption)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--focus-ring);background:#fff}
.checkbox{display:flex;align-items:flex-start;gap:.6rem;font-size:.85rem;color:var(--text-muted);line-height:1.45}
.checkbox input{margin-top:.2rem;accent-color:var(--accent)}
.form-foot{display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);margin-top:var(--space-6);flex-wrap:wrap}
.form-foot .note{font-size:.8rem;color:var(--text-caption);max-width:46ch}
.form-success{display:none;text-align:center;padding:var(--space-7) var(--space-4)}
.form-success.show{display:block}
.form-success .ring{width:64px;height:64px;margin:0 auto var(--space-4);border-radius:50%;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center}
.form-success .ring svg{width:30px;height:30px}
.form-success h3{font-size:1.5rem}
.form-success p{color:var(--text-muted);margin-top:var(--space-3)}

/* ---------- Contact cards ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
.contact-card{
  background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);
  padding:var(--space-6);box-shadow:var(--shadow-sm);text-align:left;display:flex;flex-direction:column;gap:var(--space-3)
}
.contact-card .ico{width:46px;height:46px;border-radius:12px;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center}
.contact-card .ico svg{width:22px;height:22px}
.contact-card h3{font-size:1.1rem;font-weight:var(--w-semibold)}
.contact-card a{color:var(--accent-strong);font-weight:var(--w-semibold);font-size:.95rem;word-break:break-word}
.contact-card p{color:var(--text-muted);font-size:.92rem}

/* ---------- Legal / long-form ---------- */
.legal{padding-block:var(--section-y)}
.legal .prose{max-width:760px;margin-inline:auto;color:var(--text-body);font-size:1rem;line-height:1.7}
.legal .prose h2{font-size:1.45rem;margin-top:var(--space-7);margin-bottom:var(--space-4);font-weight:var(--w-bold);color:var(--text-strong)}
.legal .prose h3{font-size:1.1rem;margin-top:var(--space-6);margin-bottom:var(--space-3);font-weight:var(--w-semibold);color:var(--text-strong)}
.legal .prose p{margin-bottom:var(--space-4)}
.legal .prose ul{padding-left:1.25rem;margin-bottom:var(--space-4)}
.legal .prose li{margin-bottom:.5rem}
.legal .prose a{color:var(--accent-strong);text-decoration:underline;text-underline-offset:3px}
.legal .meta-line{font-size:.85rem;color:var(--text-caption);margin-bottom:var(--space-6)}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(160deg,var(--navy-900),var(--navy-950));color:var(--text-on-invert);padding-block:var(--section-y)}
.cta-band .inner{display:grid;grid-template-columns:1.4fr auto;gap:var(--space-6);align-items:center}
.cta-band h2{color:#fff;font-size:var(--fs-h2);font-weight:var(--w-bold);margin:0}
.cta-band p{color:#c5d6e8;font-size:var(--fs-lead);margin-top:var(--space-3);max-width:54ch}
.cta-band .actions{display:flex;gap:var(--space-4);flex-wrap:wrap}

/* ---------- Footer ---------- */
.footer{background:var(--navy-950);color:#9fb4ca;padding-block:var(--space-8) var(--space-6)}
.footer a:hover{color:var(--teal-300)}
.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-6);
  padding-bottom:var(--space-7);border-bottom:1px solid rgba(255,255,255,.1);
}
.footer h4{color:#fff;font-family:var(--font-body);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;font-weight:var(--w-bold);margin-bottom:var(--space-4)}
.footer-logo{display:inline-flex;background:#fff;border-radius:var(--r-md);padding:12px 16px;box-shadow:var(--shadow-sm)}
.footer-logo img{height:36px;width:auto;display:block}
.footer .blurb{margin-top:var(--space-4);font-size:.92rem;max-width:38ch;line-height:var(--lh-normal)}
.footer .col-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);font-size:.92rem}
.footer-bottom{display:flex;justify-content:space-between;align-items:flex-start;padding-top:var(--space-5);font-size:.82rem;color:#6f86a0;flex-wrap:wrap;gap:var(--space-3)}
.disclaimer{font-size:.76rem;color:#5f7286;max-width:78ch}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
  .card:hover,.aud:hover,.btn-primary:hover,.video-poster:hover .play{transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:var(--space-6)}
  .hero-device,.hero-photo{order:-1;max-width:460px;margin-inline:auto}
  .split,.about-grid,.cta-band .inner{grid-template-columns:1fr;gap:var(--space-6)}
  .about-photo{max-width:460px;margin-inline:auto}
  .grid-3,.grid-4,.contact-grid{grid-template-columns:1fr 1fr}
  .trust-inner{grid-template-columns:1fr 1fr;gap:var(--space-5)}
  .trust-item:nth-child(3){padding-left:0;border-left:none}
  .params{grid-template-columns:repeat(3,1fr)}
  .audience{grid-template-columns:1fr 1fr}
  .highlights{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:var(--space-7)}
}
@media (max-width:640px){
  .grid-3,.grid-4,.grid-2,.form-grid,.cred,.audience,.contact-grid{grid-template-columns:1fr}
  .trust-inner{grid-template-columns:1fr 1fr}
  .trust-item{padding-left:0!important;border-left:none!important}
  .params{grid-template-columns:1fr 1fr}
  .highlights{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr}
  .meta-item .v{font-size:.92rem}
  .cta-band .actions{width:100%}
  .cta-band .actions .btn{flex:1}
}

/* ==========================================================
   ADDITIONS: notice bar · solution cards · connected care
   ========================================================== */

/* ---------- Notice bar ---------- */
.notice-bar{
  background:var(--navy-950);
  border-bottom:1px solid rgba(67,199,191,.18);
  padding:.5rem 0;
  font-size:.8rem;
  color:#8fa6bd;
  position:relative;
  z-index:51;
}
.notice-inner{display:flex;align-items:center;gap:.65rem}
.notice-info-ico{color:var(--teal-300);flex:none}
.notice-info-ico svg{width:14px;height:14px;display:block}
.notice-inner>span{flex:1;line-height:1.4}
.notice-close{
  background:none;border:none;cursor:pointer;color:#5f7286;
  padding:4px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;
  transition:color var(--dur);flex:none;
}
.notice-close:hover{color:#9fb4ca}
.notice-close svg{width:13px;height:13px;display:block}
.notice-bar.dismissed{display:none}

/* ---------- Button: outline (for hero 3rd CTA) ---------- */
.btn-outline{
  background:rgba(67,199,191,.08);
  color:var(--teal-300);
  border-color:rgba(67,199,191,.38);
}
.btn-outline:hover{
  background:rgba(67,199,191,.16);
  border-color:var(--teal-400);
  color:#fff;
  transform:translateY(-2px);
}

/* ---------- Video hero section ---------- */
.video-section{
  background:var(--navy-950);
  padding-block:var(--space-9);
  position:relative;overflow:hidden;
}
.video-section::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(900px 400px at 50% 110%,rgba(22,176,171,.14),transparent 60%);
}
.video-section-head{text-align:center;margin-bottom:var(--space-7)}
.video-section-head .eyebrow{justify-content:center}
.video-section-head h2{color:#fff;margin-top:var(--space-3)}
.video-section-head p{color:#9fb4ca;margin-top:var(--space-3);font-size:var(--fs-lead)}
.video-wrap-outer{max-width:860px;margin-inline:auto}
.video-section-actions{display:flex;justify-content:center;gap:var(--space-4);margin-top:var(--space-6);flex-wrap:wrap}

/* ---------- Solutions grid ---------- */
.solutions-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--space-5);
  margin-top:var(--space-7);
}
.sc-card{
  background:var(--surface-card);border:1px solid var(--border-subtle);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.sc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--teal-400) 55%,var(--border-subtle))}
.sc-card-head{
  background:linear-gradient(140deg,var(--navy-800),var(--navy-900));
  padding:var(--space-6) var(--space-5);display:flex;align-items:center;justify-content:center;min-height:108px;
}
.sc-ico{
  width:58px;height:58px;border-radius:15px;
  background:rgba(67,199,191,.12);border:1px solid rgba(67,199,191,.22);
  color:var(--teal-300);display:grid;place-items:center;
}
.sc-ico svg{width:26px;height:26px}
.sc-body{padding:var(--space-5);flex:1;display:flex;flex-direction:column}
.sc-body h3{font-size:1rem;font-weight:var(--w-semibold);color:var(--text-strong)}
.sc-body p{font-size:.875rem;color:var(--text-muted);margin-top:var(--space-2);flex:1;line-height:var(--lh-normal)}
.sc-link{
  display:inline-flex;align-items:center;gap:.35rem;font-size:.84rem;
  font-weight:var(--w-semibold);color:var(--accent-strong);margin-top:var(--space-4);
  transition:gap .15s ease,color .15s ease;width:fit-content;
}
.sc-link svg{width:15px;height:15px;transition:transform .15s ease}
.sc-link:hover{color:var(--accent)}
.sc-link:hover svg{transform:translateX(3px)}

/* ---------- Connected care (dark) ---------- */
.connected-care{
  background:linear-gradient(158deg,var(--navy-900),var(--navy-950));
  padding-block:var(--section-y);color:var(--text-on-invert);
  position:relative;overflow:hidden;
}
.connected-care::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(900px 500px at 85% 60%,rgba(22,176,171,.16),transparent 60%);
}
.connected-care .section-head{position:relative;z-index:1}
.connected-care h2{color:#fff}
.connected-care .lead{color:#c5d6e8;margin-top:var(--space-4);font-size:var(--fs-lead)}
.cc-items{
  display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4);
  margin-top:var(--space-7);position:relative;z-index:1;
}
.cc-item{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-md);padding:var(--space-5) var(--space-4);text-align:center;
  transition:background var(--dur),border-color var(--dur);
}
.cc-item:hover{background:rgba(255,255,255,.08);border-color:rgba(67,199,191,.3)}
.cc-ico{
  width:50px;height:50px;border-radius:14px;background:rgba(67,199,191,.1);
  border:1px solid rgba(67,199,191,.2);color:var(--teal-300);
  display:grid;place-items:center;margin:0 auto var(--space-3);
}
.cc-ico svg{width:22px;height:22px}
.cc-item h3{font-size:.96rem;font-weight:var(--w-semibold);color:#fff}
.cc-item p{font-size:.8rem;color:#93a8bf;margin-top:var(--space-2);line-height:1.5}

/* ---------- Sector cards (professionals page) ---------- */
.sector-cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-top:var(--space-7);
}
.sector-card{
  background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--r-lg);
  padding:var(--space-5);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.sector-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--teal-400) 40%,var(--border-subtle))}
.sector-card-head{display:flex;align-items:center;gap:var(--space-3)}
.sector-card .s-ico{width:44px;height:44px;border-radius:11px;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;flex:none}
.sector-card .s-ico svg{width:21px;height:21px}
.sector-card h3{font-size:1rem;font-weight:var(--w-semibold)}
.sector-card p{font-size:.875rem;color:var(--text-muted);line-height:1.55;flex:1}
.sector-card .s-link{
  margin-top:auto;font-size:.84rem;font-weight:var(--w-semibold);color:var(--accent-strong);
  display:inline-flex;align-items:center;gap:.3rem;transition:color .15s;
}
.sector-card .s-link svg{width:14px;height:14px}
.sector-card .s-link:hover{color:var(--accent)}

/* ---------- Home user feature steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);margin-top:var(--space-7);position:relative}
.steps::before{
  content:"";position:absolute;top:34px;left:calc(50% / 3);right:calc(50% / 3);
  height:2px;background:linear-gradient(90deg,var(--teal-100),var(--teal-300),var(--teal-100));
  pointer-events:none;z-index:0;
}
.step{text-align:center;padding:var(--space-5) var(--space-4);position:relative;z-index:1}
.step-num{
  width:64px;height:64px;border-radius:50%;margin:0 auto var(--space-4);
  background:var(--navy-900);color:var(--teal-300);
  font-family:var(--font-display);font-size:1.4rem;font-weight:var(--w-bold);
  display:grid;place-items:center;border:2px solid var(--teal-400);box-shadow:0 0 0 6px var(--teal-100);
}
.step h3{font-size:1.05rem;font-weight:var(--w-semibold)}
.step p{font-size:.88rem;color:var(--text-muted);margin-top:var(--space-2)}

/* ---------- Notice box (medical / info) ---------- */
.notice-box{
  background:var(--blue-tint-50);border:1px solid var(--blue-tint-300);border-radius:var(--r-md);
  padding:var(--space-5) var(--space-6);display:flex;gap:var(--space-4);align-items:flex-start;
}
.notice-box.amber{background:#fffbec;border-color:#f0d58c}
.notice-box-ico{flex:none;width:36px;height:36px;border-radius:10px;background:var(--blue-tint-300);color:var(--navy-700);display:grid;place-items:center;margin-top:2px}
.notice-box.amber .notice-box-ico{background:#f0d58c;color:#7a4f00}
.notice-box-ico svg{width:18px;height:18px}
.notice-box-body h4{font-size:1rem;font-weight:var(--w-semibold);color:var(--text-strong)}
.notice-box-body p{font-size:.9rem;color:var(--text-muted);margin-top:.35rem;line-height:1.55}

/* ---------- Page intro split (professional/home-users page) ---------- */
.intro-split{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:start;margin-top:var(--space-7)}
.intro-col .col-ico{width:56px;height:56px;border-radius:15px;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;margin-bottom:var(--space-4)}
.intro-col .col-ico svg{width:26px;height:26px}
.intro-col h3{font-size:1.25rem;font-weight:var(--w-bold)}
.intro-col p{color:var(--text-muted);margin-top:var(--space-3);font-size:var(--fs-small)}
.intro-col .flist{list-style:none;display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}
.intro-col .flist li{display:flex;gap:.7rem;font-size:.9rem;color:var(--text-muted)}
.intro-col .flist .dot{flex:none;width:20px;height:20px;border-radius:50%;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;margin-top:2px}
.intro-col .flist .dot svg{width:11px;height:11px}

/* ---------- Responsive additions ---------- */
@media (max-width:1024px){
  .solutions-grid{grid-template-columns:repeat(3,1fr)}
  .cc-items{grid-template-columns:repeat(3,1fr)}
  .sector-cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .solutions-grid{grid-template-columns:repeat(2,1fr)}
  .cc-items{grid-template-columns:repeat(2,1fr)}
  .intro-split{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .steps::before{display:none}
}
@media (max-width:480px){
  .solutions-grid{grid-template-columns:1fr}
  .sector-cards{grid-template-columns:1fr}
}
@media (max-width:640px){
  .cc-items{grid-template-columns:1fr 1fr}
}
