/* Grenco Medical launch stylesheet
   Tokens grounded in the current live brand, elevated. See design/01-design-system.md */

:root{
  /* Brand */
  --c-primary-700:#134746; --c-primary-600:#1c6160; --c-primary-300:#7fb3b2;
  --c-primary-100:#cee8d8; --c-primary-050:#eef6f2;
  --c-accent-400:#f8af91; --c-accent-600:#e07a52;
  /* Ink */
  --c-ink-900:#14201f; --c-ink-700:#2c3a39; --c-ink-500:#5f6f6e;
  --c-ink-300:#aab5b4; --c-ink-100:#e7eceb;
  /* Surfaces */
  --c-bg:#fff; --c-surface:#f6f6f6; --c-surface-2:#fbfcfc; --c-on-dark:#fff;
  --c-focus:#1c6160;

  --font-display:"Poppins",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-accent:"Telugu MN","Marcellus Sans","Marcellus","DM Sans",system-ui,serif;
  --font-body:"DM Sans",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  --sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;
  --sp-7:1.75rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--sp-24:6rem;--sp-32:8rem;
  --container:1180px;--narrow:760px;--hdr:92px;
  --radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(20,32,31,.06);
  --shadow-md:0 8px 24px -12px rgba(20,32,31,.18);
  --ease:cubic-bezier(.2,.6,.2,1);--dur:220ms;
  /* Subtle brand "+" micro-pattern (from the Mood State / Grenco brochure) */
  --plus:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30'%3E%3Cpath d='M15 10v10M10 15h10' stroke='%23ffffff' stroke-width='1.2' stroke-linecap='round' opacity='0.08'/%3E%3C/svg%3E");
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--font-body);font-size:1.0625rem;line-height:1.7;
  color:var(--c-ink-700);background:var(--c-bg);text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;overflow-wrap:break-word;overflow-x:hidden}
img,svg{max-width:100%;display:block}
input,select,textarea,button{max-width:100%;min-width:0}
a{color:var(--c-primary-600);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--c-primary-700)}
h1,h2,h3{color:var(--c-primary-700);font-weight:700;letter-spacing:-.01em;line-height:1.15;
  text-wrap:balance}
h1{font-family:var(--font-display);font-size:clamp(2.6rem,5vw,4.5rem);line-height:1.04;
  max-width:18ch}
h2{font-family:var(--font-accent);font-weight:400;
  font-size:clamp(2.1rem,3.4vw,3.4rem);letter-spacing:0;line-height:1.12;
  margin-bottom:var(--sp-6);max-width:20ch}
h3{font-family:var(--font-display);font-size:1.375rem;font-weight:600;max-width:26ch}
.center h1,.center h2,.center h3,
.band__in h1,.band__in h2,.cta-band h2{margin-inline:auto}
p{max-width:66ch;text-wrap:pretty}

:focus-visible{outline:3px solid var(--c-focus);outline-offset:2px;border-radius:4px}
.skip{position:absolute;left:-999px}
.skip:focus{left:var(--sp-4);top:var(--sp-4);z-index:200;background:#fff;
  padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}

.wrap{max-width:var(--container);margin-inline:auto;padding-inline:var(--sp-6);min-width:0}
.narrow{max-width:var(--narrow);margin-inline:auto}
.section{padding-block:var(--sp-24)}
.section--tint{background:var(--c-primary-050)}
.section--tight-top{padding-top:var(--sp-10)}
.section--tight-bottom{padding-bottom:var(--sp-12)}
.section--surface{background:var(--c-surface)}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-body);
  font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-primary-600);font-weight:600;margin-bottom:var(--sp-4);max-width:100%}
.eyebrow::before{content:"";width:26px;height:3px;border-radius:3px;
  background:var(--c-accent-400);flex:none}
.lead{font-family:var(--font-accent);font-size:1.35rem;line-height:1.55;
  font-weight:400;color:var(--c-ink-700)}
.center{text-align:center}.center p{margin-inline:auto}

.trust-strip{display:flex;flex-wrap:wrap;gap:var(--sp-3);justify-content:center;
  border-block:1px solid var(--c-ink-100);padding:var(--sp-4) var(--sp-6);
  background:#fff;color:var(--c-primary-700);font-size:.86rem;font-weight:700}
.trust-strip span,.trust-strip a{border:1px solid var(--c-ink-100);border-radius:var(--radius-pill);
  padding:.45rem .75rem;background:var(--c-surface-2);text-decoration:none}
.practitioner-notice{display:grid;gap:var(--sp-2);padding:var(--sp-4) var(--sp-6);
  background:var(--c-primary-700);color:#fff;text-align:center}
.practitioner-notice strong{font-family:var(--font-display)}
.practitioner-notice span{color:#d7e8e5}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--font-body);
  font-weight:700;font-size:1rem;padding:.85rem 1.6rem;border-radius:var(--radius-pill);
  border:2px solid transparent;cursor:pointer;text-decoration:none;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),
  border-color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.btn--primary{background:var(--c-primary-600);color:var(--c-on-dark)}
.btn--primary:hover{background:var(--c-primary-700);color:#fff}
.btn--ghost{border-color:var(--c-primary-600);color:var(--c-primary-600);background:transparent}
.btn--ghost:hover{background:var(--c-primary-600);color:#fff}
.btn--on-dark{background:#fff;color:var(--c-primary-700)}
.btn--on-dark:hover{background:var(--c-primary-100)}
@media (prefers-reduced-motion:no-preference){.btn:hover{transform:translateY(-1px)}}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:var(--c-primary-700);
  color:var(--c-on-dark);transition:background .28s var(--ease),box-shadow .28s var(--ease)}
.site-header.is-scrolled{box-shadow:0 10px 30px -20px rgba(20,32,31,.6)}
.site-header .wrap{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;
  align-items:center;gap:clamp(var(--sp-4),3vw,var(--sp-8));padding-block:var(--sp-4)}
.brand img{height:38px;width:auto}
.nav{display:flex;align-items:center;justify-content:center;gap:clamp(1.15rem,2.1vw,var(--sp-8));list-style:none}
.nav a{color:#dcebe9;font-size:.96rem;font-weight:600;text-decoration:none;white-space:nowrap}
.nav a:hover,.nav a[aria-current]{color:#fff}
.header-cta{font-size:.92rem;padding:.68rem 1.25rem;white-space:nowrap}
.navtoggle{display:none;background:none;border:1px solid #ffffff44;color:#fff;
  padding:.5rem .7rem;border-radius:var(--radius-sm);font-size:.9rem}

/* Overlay header (home): transparent over the light hero, inverts to teal on scroll */
.site-header--overlay{background:transparent}
.site-header--overlay:not(.is-scrolled){color:var(--c-ink-900)}
.site-header--overlay:not(.is-scrolled) .nav a{color:var(--c-ink-700)}
.site-header--overlay:not(.is-scrolled) .nav a:hover,
.site-header--overlay:not(.is-scrolled) .nav a[aria-current]{color:var(--c-primary-700)}
.site-header--overlay:not(.is-scrolled) .navtoggle{color:var(--c-ink-900);
  border-color:var(--c-ink-300)}
.site-header--overlay:not(.is-scrolled) .header-cta{background:var(--c-primary-600);
  color:#fff;border-color:transparent}
.site-header--overlay:not(.is-scrolled) .header-cta:hover{background:var(--c-primary-700)}
.site-header--overlay.is-scrolled{background:var(--c-primary-700)}

/* Logo swap is CSS-driven (no JS): light on teal, dark on the transparent overlay */
.brand-logo{height:38px;width:auto;display:none}
.site-header:not(.site-header--overlay) .brand-logo--light{display:block}
.site-header--overlay .brand-logo--dark{display:block}
.site-header--overlay.is-scrolled .brand-logo--dark{display:none}
.site-header--overlay.is-scrolled .brand-logo--light{display:block}
@media (max-width:900px){
  /* Mobile: overlay header behaves as the solid teal bar (stacked hero below it) */
  .site-header--overlay{background:var(--c-primary-700);color:var(--c-on-dark)}
  .site-header--overlay .brand-logo--dark{display:none}
  .site-header--overlay .brand-logo--light{display:block}
  .site-header--overlay:not(.is-scrolled) .nav a{color:#dcebe9}
  .site-header--overlay:not(.is-scrolled) .nav a:hover,
  .site-header--overlay:not(.is-scrolled) .nav a[aria-current]{color:#fff}
  .site-header--overlay:not(.is-scrolled) .navtoggle{color:#fff;border-color:#ffffff44}
  .site-header--overlay:not(.is-scrolled) .header-cta{background:#fff;color:var(--c-primary-700)}
}

/* Hero */
.hero{background:var(--plus),
  linear-gradient(180deg,var(--c-primary-700),var(--c-primary-600));
  color:var(--c-on-dark);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:auto -10% -40% auto;width:560px;height:560px;
  background:radial-gradient(circle,var(--c-accent-400)0,transparent 62%);opacity:.34}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;
  gap:var(--sp-16);align-items:center;padding-block:var(--sp-32)}
.hero .wrap>*{min-width:0}
.hero h1{color:#fff;max-width:18ch;font-family:var(--font-accent);
  font-weight:400;letter-spacing:0;line-height:1.07}
.hero .lead{color:#d6e7e5;margin-block:var(--sp-6)}
.hero--access h1{font-size:clamp(2.65rem,4.2vw,3.85rem);max-width:12ch}
.hero--access .lead{max-width:42ch}
.hero .eyebrow{color:var(--c-primary-100)}
.hero-actions{display:flex;gap:var(--sp-4);flex-wrap:wrap;margin-top:var(--sp-8)}
.hero-figure{position:relative;z-index:1;min-height:clamp(400px,50vh,600px);
  border-radius:var(--radius-lg);background:linear-gradient(160deg,#ffffff18,#ffffff05);
  border:1px solid #ffffff22;display:grid;place-items:center;color:#bcd6d4;
  text-align:center;padding:var(--sp-8)}
/* Brochure arc — large rounded shape rising behind the hero */
.hero::before{content:"";position:absolute;left:50%;bottom:-60%;
  transform:translateX(-50%);width:155%;max-width:1700px;aspect-ratio:1;
  border-radius:50%;background:rgba(206,232,216,.055);
  border:1px solid rgba(255,255,255,.07);z-index:0}
.placeholder-note{font-size:.8rem;color:var(--c-ink-500);font-style:italic}
/* External-link note — shown wherever the site links out to the sponsor */
.ext-note{font-size:.82rem;color:var(--c-ink-500);margin-top:var(--sp-3);max-width:48ch}
.ext-note--on-dark{color:#bcd6d4}
.band .ext-note{margin-inline:auto}
.hero-figure .placeholder-note{color:#9fc1bf}
/* Hero figure with real product photography */
.hero-figure.has-photo{background:#eef3f1 url("elite-upright.jpg") center 42%/cover no-repeat;
  border:none;padding:0}
.hero-figure.has-photo>*{display:none}
.hero-figure.has-photo.hero-figure--patient{background-image:url("band-everyday.jpg");
  background-position:center 30%}
.hero-figure.has-photo.hero-figure--support{background-image:url("support-care.jpg");
  background-position:center 22%}
.hero-figure.has-photo.hero-figure--registration{background-image:url("device-marble.jpg");
  background-position:center 42%}
.hero--knowledge .hero-figure.has-photo{background-image:url("owner-desk.jpg");
  background-position:center 24%}

/* Full-bleed image banner hero (home) — image covers full width; header + text sit on top */
.lhero{position:relative;min-height:92vh;display:flex;align-items:center;
  margin-top:calc(-1 * var(--hdr));padding-top:var(--hdr);
  background:
    linear-gradient(180deg,rgba(255,255,255,.80) 0,rgba(255,255,255,0) 140px),
    linear-gradient(90deg,rgba(255,255,255,.95) 24%,rgba(255,255,255,.62) 46%,rgba(255,255,255,0) 66%),
    #f3f6f5 url("home-hero.png") center center/cover no-repeat}
.lhero .wrap{position:relative;z-index:1;width:100%}
.lhero__inner{max-width:520px;padding-block:var(--sp-16)}
.lhero h1{color:var(--c-primary-700);font-family:var(--font-accent);font-weight:400;
  font-size:clamp(2.65rem,4.25vw,3.9rem);line-height:1.08;letter-spacing:0;
  margin-bottom:var(--sp-6);max-width:15ch}
.lhero .eyebrow{margin-bottom:var(--sp-4)}
.lhero .lead{color:var(--c-ink-700);font-size:1.12rem;max-width:40ch}
.lhero .hero-actions{display:flex;gap:var(--sp-4);flex-wrap:wrap;margin-top:var(--sp-8)}
@media (max-width:900px){
  /* Mobile: stacked — image banner block on top, text below (option a) */
  .lhero{display:block;min-height:auto;margin-top:0;padding-top:0;background:#fff}
  .lhero::before{content:"";display:block;width:100%;height:36vh;min-height:230px;max-height:360px;
    background:#eef3f1 url("home-hero.png") center 24%/cover no-repeat}
  .lhero .wrap{padding-block:var(--sp-8) var(--sp-12)}
  .lhero__inner{max-width:none}
}

/* Badge row */
.badges{display:flex;flex-wrap:wrap;gap:var(--sp-3);list-style:none;margin-top:var(--sp-8)}
.badges li{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;
  font-weight:600;color:#cfe3e1;border:1px solid #ffffff2e;
  padding:.4rem .85rem;border-radius:var(--radius-pill);min-width:0}
.badges li::before{content:"";width:6px;height:6px;border-radius:50%;
  background:var(--c-accent-400);flex:none}
.badges--light li{color:var(--c-ink-500);border-color:var(--c-ink-100);background:#fff}

/* Peach as the consistent interaction accent */
main a:hover{text-decoration-color:var(--c-accent-400)}
.nav a:hover,.nav a[aria-current]{text-decoration:underline;
  text-decoration-color:var(--c-accent-400);text-underline-offset:6px;
  text-decoration-thickness:2px}
.site-footer a:hover{text-decoration:underline;
  text-decoration-color:var(--c-accent-400);text-underline-offset:4px}

/* Grid + cards */
.grid{display:grid;gap:var(--sp-6)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  padding:var(--sp-8);box-shadow:var(--shadow-sm);border-top:3px solid var(--c-accent-400);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
@media (prefers-reduced-motion:no-preference){
  .card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}}
.card h3{margin-bottom:var(--sp-3)}
/* Soft, friendly icon in a large mint circle with a peach accent ring */
.card .ico{width:108px;height:108px;border-radius:50%;background:var(--c-primary-100);
  display:grid;place-items:center;margin-bottom:var(--sp-6);position:relative}
.card .ico::after{content:"";position:absolute;inset:-9px;border-radius:50%;
  border:2px solid var(--c-accent-400);opacity:.65}
.card .ico svg{width:50px;height:50px;fill:none;stroke:var(--c-primary-600);
  stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

/* "What sets it apart" feature cards — centred, peach-glass, bar accent */
.card--feature{position:relative;overflow:hidden;text-align:center;
  border:1px solid rgba(255,255,255,.65);border-top:1px solid rgba(255,255,255,.65);
  background:rgba(255,255,255,.5);-webkit-backdrop-filter:blur(12px);
  backdrop-filter:blur(12px);box-shadow:0 14px 36px -22px rgba(20,32,31,.22);
  padding-bottom:var(--sp-12)}
.card--feature::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(248,175,145,.12),rgba(248,175,145,0) 58%)}
.card--feature::after{content:"";position:absolute;left:50%;bottom:var(--sp-6);
  transform:translateX(-50%);width:44px;height:3px;border-radius:3px;
  background:var(--c-accent-400)}
.card--feature>*{position:relative;z-index:1}
.card--feature .ico{margin-inline:auto;background:var(--c-primary-100)}
.card--feature .ico::after{display:none}
.card--feature .ico svg{width:66px;height:66px}

/* Spec table */
.spec{width:100%;border-collapse:collapse;margin-top:var(--sp-4)}
.spec caption{text-align:left;color:var(--c-ink-500);font-size:.9rem;
  margin-bottom:var(--sp-4)}
.spec th,.spec td{text-align:left;padding:var(--sp-4) var(--sp-2);
  border-bottom:1px solid var(--c-ink-100);vertical-align:top}
.spec th{font-family:var(--font-body);font-weight:600;color:var(--c-ink-900);width:38%}
.spec td{color:var(--c-ink-700);font-variant-numeric:tabular-nums}

/* Practitioner CTA banner */
.cta-band{background:
  var(--plus),
  linear-gradient(rgba(19,71,70,.78),rgba(19,71,70,.86)),
  #134746 url("cta-conversation.jpg") center/cover no-repeat;
  color:#fff;border-radius:var(--radius-lg);padding:var(--sp-24) var(--sp-16);
  text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:-30% auto auto -10%;width:420px;
  height:420px;background:radial-gradient(circle,var(--c-accent-400)0,transparent 60%);
  opacity:.22}
.cta-band h2{color:#fff;position:relative}
.cta-band p{color:#d6e7e5;margin:0 auto var(--sp-8);position:relative}
.cta-band .hero-actions{justify-content:center;position:relative}

/* Step list (patient journey) */
.steps{counter-reset:s;list-style:none;display:grid;gap:var(--sp-6);margin-top:var(--sp-4)}
.steps li{background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  padding:var(--sp-8);position:relative;padding-left:var(--sp-24)}
.steps li::before{counter-increment:s;content:counter(s);position:absolute;
  left:var(--sp-8);top:var(--sp-8);width:42px;height:42px;border-radius:50%;
  background:var(--c-primary-600);color:#fff;font-family:var(--font-display);
  font-weight:700;display:grid;place-items:center;
  box-shadow:0 0 0 5px var(--c-primary-100),0 0 0 7px var(--c-accent-400)}

/* Warm "approach" intro — circular visual left, text right (desktop); stacked on mobile */
.approach{display:grid;grid-template-columns:.95fr 1.05fr;gap:var(--sp-16);
  align-items:center}
.approach__visual{order:-1}
.approach__copy{max-width:34rem}
.approach p:not(.eyebrow){font-family:var(--font-accent);font-size:1.4rem;
  line-height:1.55;color:var(--c-ink-700);max-width:42ch}
.approach__visual{justify-self:center;width:min(440px,34vw);aspect-ratio:1;
  border-radius:50%;position:relative;overflow:hidden;display:grid;
  place-items:center;text-align:center;padding:var(--sp-16);
  border:1px solid var(--c-ink-100);
  background:var(--plus),linear-gradient(155deg,var(--c-primary-100),var(--c-primary-050))}
.approach__visual::after{content:"";position:absolute;inset:auto -22% -26% auto;
  width:62%;aspect-ratio:1;
  background:radial-gradient(circle,var(--c-accent-400)0,transparent 62%);opacity:.3}
.approach__visual>div{position:relative;z-index:1}
.approach__visual .mk{font-family:var(--font-accent);color:var(--c-ink-700);
  font-size:1.05rem;margin-bottom:var(--sp-2)}
.approach__visual .placeholder-note{color:var(--c-ink-500);font-size:.78rem}
.approach__visual.has-photo{background:#eef3f1 url("everyday-outdoor.jpg") center/cover no-repeat;padding:0}
.approach__visual.has-photo::after,.approach__visual.has-photo>div{display:none}
@media (max-width:900px){
  .approach{grid-template-columns:1fr;gap:var(--sp-12);text-align:center}
  .approach__copy{max-width:none}
  .approach__copy .eyebrow{justify-content:center}
  .approach__copy h2,.approach p:not(.eyebrow){margin-inline:auto}
  .approach__visual{order:-1;width:min(420px,84vw)}
}

/* Lifestyle / media placeholder (light) */
.media{border-radius:var(--radius-lg);background:
  linear-gradient(160deg,var(--c-primary-100),var(--c-primary-050));
  border:1px solid var(--c-ink-100);min-height:clamp(380px,46vh,560px);
  display:grid;place-items:center;
  text-align:center;padding:var(--sp-8);position:relative;overflow:hidden}
.media--tall{min-height:clamp(460px,64vh,680px)}
.media.has-photo{background:#eef3f1 url("glance-palm.png") center/cover no-repeat;padding:0}
.media.has-photo::after,.media.has-photo>div{display:none}
.media.has-photo.media--quality{background-image:url("quality-detail.jpg")}
.media.has-photo.media--handover{background-image:url("approach-handover.jpg")}
.media.has-photo.media--everyday{background-image:url("travel-ready-pocket.png");background-position:35% 45%}
.media.has-photo.media--access{background-image:url("handover-care.jpg")}
.media.has-photo.media--heat{background-image:url("controls-detail.jpg")}
.media.has-photo.media--care{background-image:url("device-marble.jpg")}
.media.has-photo.media--build{background-image:url("device-inhand.jpg")}
.media.has-photo.media--warranty{background-image:url("owner-desk.jpg");background-position:center 25%}

/* Product kit */
.box-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);
  gap:var(--sp-16);align-items:center}
.box-photo{border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  background:#fff;box-shadow:0 24px 70px -44px rgba(20,32,31,.28);overflow:hidden}
.box-photo img{width:100%;height:auto}
.included-list{display:grid;gap:var(--sp-3);margin:var(--sp-8) 0;list-style:none}
.included-list li{display:grid;grid-template-columns:auto 1fr;gap:var(--sp-4);align-items:center;
  border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);background:#fff;
  padding:var(--sp-4) var(--sp-6)}
.included-list span{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;
  background:var(--c-primary-050);color:var(--c-primary-700);font-size:.78rem;font-weight:800}
.included-list strong{color:var(--c-primary-700);font-family:var(--font-display);font-size:1.02rem}
.note{color:var(--c-ink-500);font-size:.9rem}

/* Slim, understated trust marks line (replaces the heavy badge block) */
.marks{font-size:.82rem;color:var(--c-ink-500);letter-spacing:.02em;line-height:1.7;
  margin-top:var(--sp-6);padding-top:var(--sp-4);border-top:1px solid var(--c-ink-100)}

/* Full-bleed image band (large, immersive — replaces small contained cards) */
.band{position:relative;overflow:hidden;color:#fff;text-align:center;
  min-height:66vh;display:grid;place-items:center;padding:var(--sp-24) var(--sp-6);
  background:var(--plus),linear-gradient(160deg,var(--c-primary-700),var(--c-primary-600))}
.band::after{content:"";position:absolute;inset:auto -8% -36% auto;width:520px;
  height:520px;background:radial-gradient(circle,var(--c-accent-400)0,transparent 62%);
  opacity:.26}
.band__in{position:relative;z-index:1;max-width:var(--narrow);margin-inline:auto}
.band .eyebrow{color:var(--c-primary-100);justify-content:center}
.band h2{color:#fff}
.band p{color:#d6e7e5;margin-inline:auto;max-width:46ch}
.band .placeholder-note{color:#9fc1bf;margin-top:var(--sp-6)}
.band .hero-actions{justify-content:center}
/* CTA variant — "conversation" photo; light NEUTRAL darken (no green cast) for white-text legibility */
.band--cta{min-height:54vh;background:
  linear-gradient(rgba(17,22,22,.34),rgba(17,22,22,.56)),
  #1b2120
  url("cta-consult.jpg")
  center 40%/cover no-repeat}
.band--cta p{color:#e7efed}
.band--cta.band--cta-consider{background:
  linear-gradient(rgba(17,22,22,.34),rgba(17,22,22,.56)),
  #1b2120 url("cta-consider.jpg") center 62%/cover no-repeat}
.band--cta.band--cta-support{background:
  linear-gradient(rgba(17,22,22,.38),rgba(17,22,22,.58)),
  #1b2120 url("support-consult.png") center 45%/cover no-repeat}
/* "Made for everyday life" — full-bleed lifestyle photo, teal scrim for legibility */
.band--life{background:
  linear-gradient(rgba(19,71,70,.72),rgba(19,71,70,.85)),
  #134746 url("everyday-living.jpg") center 78%/cover no-repeat}
.band--life p{color:#eef3f1}
.band--life .placeholder-note{display:none}

/* Big statement "beat" — oversized type, brand mark, overlaps the band above */
.statement{position:relative;overflow:hidden;background:#fff;text-align:center;
  padding-block:10rem 14rem;margin-top:calc(-1 * var(--sp-24));z-index:2;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  box-shadow:0 -34px 60px -42px rgba(20,32,31,.4)}
.statement__mark{position:absolute;left:50%;top:45%;transform:translate(-50%,-50%);
  width:min(420px,46vw);color:var(--c-primary-100);opacity:.42;
  pointer-events:none;z-index:0}
.statement__mark svg{width:100%;height:auto;fill:currentColor;stroke:none;display:block}
.statement .wrap{position:relative;z-index:1}
.statement__in{max-width:min(54rem,90vw);margin-inline:auto}
.statement .eyebrow{justify-content:center;margin-bottom:var(--sp-6)}
.statement__lead{font-family:var(--font-accent);color:var(--c-primary-700);
  font-size:clamp(2.2rem,5vw,4.2rem);line-height:1.08;letter-spacing:0;
  text-wrap:balance;overflow-wrap:normal;word-break:keep-all}
@media (max-width:900px){
  .statement{margin-top:0;border-radius:0;box-shadow:none;
    padding-block:6rem 9rem}
  .statement__mark{opacity:.32;width:min(260px,58vw)}
}

/* Circular trust seals (brochure device) */
.seals{display:flex;flex-wrap:wrap;gap:var(--sp-12) var(--sp-8);
  justify-content:center;align-items:flex-start;list-style:none}
.seal{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);
  width:150px;text-align:center}
.seal .ring{width:92px;height:92px;border-radius:50%;background:var(--c-primary-100);
  display:grid;place-items:center;font-family:var(--font-accent);
  color:var(--c-primary-700);font-size:1.65rem;letter-spacing:.02em;
  box-shadow:0 0 0 6px var(--c-primary-050)}
.seal b{font-family:var(--font-body);font-weight:600;color:var(--c-ink-900);
  font-size:.95rem}
.seal small{color:var(--c-ink-500);font-size:.82rem;line-height:1.45}
.media::after{content:"";position:absolute;inset:auto -12% -30% auto;width:300px;
  height:300px;background:radial-gradient(circle,var(--c-accent-400)0,transparent 62%);
  opacity:.3}
.media .mk{font-family:var(--font-accent);font-size:1.2rem;color:var(--c-ink-700);
  margin-bottom:var(--sp-2);position:relative}
.media .placeholder-note{color:var(--c-ink-500);position:relative}

/* Feature list — Elite II at a glance */
.flist{list-style:none;display:grid;gap:var(--sp-6);margin-top:var(--sp-4)}
.flist li{display:flex;gap:var(--sp-4);align-items:flex-start}
.flist .fi{flex:none;width:64px;height:64px;border-radius:50%;
  background:var(--c-primary-100);display:grid;place-items:center;
  box-shadow:0 0 0 6px var(--c-primary-050)}
.flist .fi svg{width:32px;height:32px;fill:none;stroke:var(--c-primary-600);
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.flist h3{font-family:var(--font-display);font-size:1.08rem;margin-bottom:2px}
.flist p{color:var(--c-ink-500);font-size:.98rem;max-width:48ch}

/* Pharmacy locator (For patients) — focused, contained column */
.locator,.locator__direct{max-width:40rem;margin-inline:auto}
.locator{margin-top:var(--sp-8)}
.locator__search{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-6)}
.locator__field{flex:1;min-width:220px;
  padding:.85rem 1.2rem .85rem 3rem;font-family:var(--font-body);
  font-size:1rem;color:var(--c-ink-700);
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%235f6f6e' stroke-width='1.8' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='M20 20l-4.3-4.3'/%3E%3C/svg%3E") no-repeat left 1.1rem center;
  border:1px solid var(--c-ink-100);border-radius:var(--radius-pill)}
.locator__results{list-style:none;display:grid;gap:var(--sp-3)}
.stockist,.availability-card{display:flex;align-items:center;gap:var(--sp-4);
  background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  padding:var(--sp-4) var(--sp-6);box-shadow:var(--shadow-sm)}
.availability-card{align-items:flex-start;border-top:3px solid var(--c-accent-400);
  padding:var(--sp-6)}
.availability-card h3{max-width:none;margin-bottom:var(--sp-2)}
.availability-card p{color:var(--c-ink-500);font-size:.98rem;max-width:56ch}
.stockist__pin{flex:none;width:44px;height:44px;border-radius:50%;
  background:var(--c-primary-100);display:grid;place-items:center}
.stockist__pin svg{width:22px;height:22px;fill:none;stroke:var(--c-primary-600);
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.stockist__body{flex:1;min-width:0}
.stockist h3{font-family:var(--font-display);font-size:1.05rem;margin-bottom:1px;max-width:none}
.stockist p{font-size:.92rem;color:var(--c-ink-500);max-width:none}
.stockist__dist{flex:none;font-size:.85rem;font-weight:600;color:var(--c-primary-600);
  white-space:nowrap}
.locator .placeholder-note{margin-top:var(--sp-6)}
.locator__direct{margin-top:var(--sp-12);padding-top:var(--sp-8);
  border-top:1px solid var(--c-ink-100)}
.locator__direct .btn{margin-top:var(--sp-2)}

/* Gate cards */
.gate-card{position:relative;background:#fff;color:var(--c-ink-700);
  border:1px solid var(--c-ink-100);border-radius:var(--radius-lg);
  padding:var(--sp-12);box-shadow:0 18px 44px -28px rgba(20,32,31,.22);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
@media (prefers-reduced-motion:no-preference){
  .gate-card:hover{transform:translateY(-3px);
    box-shadow:0 28px 60px -30px rgba(20,32,31,.28)}}
.gate-card .gico{width:66px;height:66px;border-radius:50%;
  background:var(--c-primary-100);display:grid;place-items:center;
  margin-bottom:var(--sp-6);box-shadow:0 0 0 6px var(--c-primary-050)}
.gate-card .gico svg{width:32px;height:32px;fill:none;stroke:var(--c-primary-600);
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.gate-card .eyebrow{margin-bottom:var(--sp-3)}
.gate-card h3{color:var(--c-primary-700);font-size:1.5rem;margin-bottom:var(--sp-4)}
.gate-card p{color:var(--c-ink-500);margin-bottom:var(--sp-8)}
.gate-card .btn{margin-top:0}

/* Product registration */
.hero--registration .wrap{grid-template-columns:1fr .88fr}
.registration-layout{display:grid;grid-template-columns:minmax(280px,.68fr) minmax(0,1.32fr);
  gap:var(--sp-16);align-items:start}
.registration-aside{position:sticky;top:calc(var(--hdr) + var(--sp-8))}
.registration-aside h2{max-width:12ch}
.registration-form{display:grid;gap:var(--sp-8);background:#fff;border:1px solid var(--c-ink-100);
  border-radius:var(--radius-lg);padding:clamp(var(--sp-6),4vw,var(--sp-12));
  box-shadow:0 24px 70px -42px rgba(20,32,31,.32)}
.registration-form fieldset{border:0;display:grid;gap:var(--sp-5,1.25rem)}
.registration-form fieldset+fieldset{border-top:1px solid var(--c-ink-100);
  padding-top:var(--sp-8)}
.registration-form legend{font-family:var(--font-display);font-size:1.28rem;
  font-weight:700;color:var(--c-primary-700);margin-bottom:var(--sp-2)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-5,1.25rem)}
.registration-form label{display:grid;gap:.45rem;color:var(--c-primary-700);
  font-size:.82rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.registration-form label span{color:var(--c-ink-500);font-weight:600;letter-spacing:0;
  text-transform:none}
.registration-form input:not([type="checkbox"]),
.registration-form select{min-height:54px;width:100%;border:1px solid var(--c-ink-100);
  border-radius:var(--radius-sm);padding:0 var(--sp-4);background:#fff;color:var(--c-ink-900);
  font:inherit;font-size:1rem;font-weight:500;letter-spacing:0;text-transform:none;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.registration-form select{appearance:none;background:
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23134746' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")
  no-repeat right 1rem center/18px,#fff;padding-right:3rem}
.registration-form input:focus,.registration-form select:focus{border-color:var(--c-primary-600);
  outline:none;box-shadow:0 0 0 4px rgba(127,179,178,.2)}
.registration-form input[aria-invalid="true"],
.registration-form select[aria-invalid="true"]{border-color:#a83a2a;
  box-shadow:0 0 0 4px rgba(168,58,42,.12)}
.check-row{display:grid!important;grid-template-columns:auto 1fr;align-items:start;
  gap:var(--sp-3)!important;color:var(--c-ink-700)!important;font-size:.96rem!important;
  font-weight:500!important;letter-spacing:0!important;text-transform:none!important}
.check-row input{width:20px;height:20px;margin-top:.2rem;accent-color:var(--c-primary-600)}
.form-status{border-radius:var(--radius-sm);padding:var(--sp-4) var(--sp-5,1.25rem);
  font-size:.94rem;font-weight:700;line-height:1.55}
.form-status--info{background:var(--c-primary-050);color:var(--c-primary-700);
  border:1px solid var(--c-primary-100)}
.form-status--success{background:#eef8f1;color:#236238;border:1px solid #bde3c9}
.form-status--error{background:#fff4f1;color:#913226;border:1px solid #f1c5ba}
.form-actions{display:flex;align-items:center;gap:var(--sp-6);flex-wrap:wrap;
  border-top:1px solid var(--c-ink-100);padding-top:var(--sp-8)}
.form-actions p{color:var(--c-ink-500);font-size:.92rem;max-width:42ch}

/* Contact */
.contact-layout{display:grid;grid-template-columns:minmax(280px,.84fr) minmax(0,1.16fr);
  gap:var(--sp-16);align-items:start}
.contact-aside{position:sticky;top:calc(var(--hdr) + var(--sp-8))}
.contact-card{background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-lg);
  padding:clamp(var(--sp-6),4vw,var(--sp-12));box-shadow:0 24px 70px -42px rgba(20,32,31,.32)}
.hubspot-embed{margin-top:var(--sp-8);min-height:520px}
.hubspot-embed form{font-family:var(--font-body)!important}
.hubspot-embed label{color:var(--c-primary-700)!important;font-weight:700!important}
.hubspot-embed input,
.hubspot-embed textarea,
.hubspot-embed select{border-radius:var(--radius-sm)!important;border:1px solid var(--c-ink-100)!important}
.hubspot-embed input[type="submit"]{border:0!important;border-radius:var(--radius-pill)!important;
  background:var(--c-primary-600)!important;color:#fff!important;font-family:var(--font-display)!important;
  font-weight:700!important;padding:.9rem 1.5rem!important}
.contact-methods{margin-top:var(--sp-8);border-top:1px solid var(--c-ink-100);padding-top:var(--sp-6)}
.contact-methods h3{margin-bottom:var(--sp-4)}
.contact-methods p{font-size:.94rem;color:var(--c-ink-500);margin-top:var(--sp-4)}

/* Compliance / mandatory block */
.mandatory{background:transparent;border:none;
  border-left:4px solid var(--c-primary-600);border-radius:0;
  padding:var(--sp-2) var(--sp-8);font-size:.9rem;color:var(--c-ink-500);margin-top:var(--sp-12)}
.mandatory strong{color:var(--c-ink-700)}
.cert-list{display:grid;gap:var(--sp-3);list-style:none;margin-top:var(--sp-6);max-width:46rem}
.cert-list li{border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);
  background:#fff;padding:var(--sp-3) var(--sp-4);color:var(--c-ink-700);
  box-shadow:var(--shadow-sm)}
.cert-list strong{color:var(--c-primary-700);font-family:var(--font-display)}
.flag{background:#fff5ef;border:1px dashed var(--c-accent-600);color:#8a4a2e;
  padding:.15rem .5rem;border-radius:4px;font-size:.78rem;font-weight:600;
  font-style:normal;white-space:normal;display:inline-block}
.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}

.resource-head{display:grid;gap:var(--sp-8);align-items:end;margin-bottom:var(--sp-10)}
.resource-head>.btn{justify-self:start}
.resource-head h2{max-width:none}
.resource-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-6);
  margin-top:var(--sp-8)}
.resource-grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}
.resource-card{display:flex;min-height:100%;flex-direction:column;gap:var(--sp-4);
  border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);padding:var(--sp-8);
  background:#fff;box-shadow:var(--shadow-sm)}
.resource-card h3{font-size:1.25rem}
.resource-card p{color:var(--c-ink-500);font-size:.96rem}
.resource-card a{margin-top:auto;font-weight:700;text-decoration:none;color:var(--c-primary-600)}
.resource-card a:hover{color:var(--c-primary-700)}
.resource-kicker{width:max-content;max-width:100%;border-radius:var(--radius-pill);
  background:var(--c-primary-050);padding:.35rem .7rem;color:var(--c-primary-700);
  font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}

/* Owner video guides */
.video-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-6);
  margin-top:var(--sp-8)}
.video-card{background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  overflow:hidden;box-shadow:0 18px 54px -36px rgba(20,32,31,.34)}
.video-grid--inline{margin-top:var(--sp-5)}
.video-card--inline{margin-top:var(--sp-5);box-shadow:0 16px 42px -34px rgba(20,32,31,.28)}
.guide-video-card{grid-column:1/-1;display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.62fr);
  align-items:stretch;margin-top:0}
.guide-video-card .video-frame{height:100%}
.guide-video-card .video-card__body{align-content:center}
.video-frame{position:relative;aspect-ratio:16/9;background:var(--c-primary-700)}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-load{position:absolute;inset:0;width:100%;height:100%;border:0;cursor:pointer;appearance:none;
  background-color:#dfe3e1;background-position:center;background-size:cover;background-repeat:no-repeat}
.video-load--use{background-image:linear-gradient(180deg,rgba(255,255,255,.1),rgba(20,32,31,.12)),url("device-inhand.jpg")}
.video-load--clean{background-image:linear-gradient(180deg,rgba(255,255,255,.06),rgba(20,32,31,.14)),url("device-examine.jpg")}
.video-load::after{content:"";position:absolute;inset:0;background:rgba(255,255,255,.12);transition:background .2s ease}
.video-load__play{position:absolute;left:50%;top:50%;z-index:1;width:0;height:0;
  transform:translate(-38%,-50%);border-top:clamp(30px,4.8vw,46px) solid transparent;
  border-bottom:clamp(30px,4.8vw,46px) solid transparent;
  border-left:clamp(48px,7.4vw,76px) solid rgba(255,255,255,.72);
  filter:drop-shadow(0 16px 22px rgba(20,32,31,.24));transition:transform .2s ease,border-left-color .2s ease}
.video-load__play::before{content:"";position:absolute;left:calc(clamp(48px,7.4vw,76px) * -1);top:calc(clamp(30px,4.8vw,46px) * -1);
  width:0;height:0;border-top:clamp(30px,4.8vw,46px) solid transparent;
  border-bottom:clamp(30px,4.8vw,46px) solid transparent;border-left:clamp(48px,7.4vw,76px) solid rgba(255,255,255,.24)}
.video-load:hover::after,.video-load:focus-visible::after{background:rgba(255,255,255,.05)}
.video-load:hover .video-load__play,.video-load:focus-visible .video-load__play{transform:translate(-38%,-50%) scale(1.06);
  border-left-color:rgba(255,255,255,.86)}
.video-card__body{display:grid;gap:var(--sp-3);padding:var(--sp-6)}
.video-card__body h3{max-width:none;font-size:1.35rem}
.video-card--inline .video-card__body{padding:var(--sp-4)}
.video-card--inline .video-card__body h3{font-size:1.08rem}
.guide-video-card .video-card__body{padding:var(--sp-6) var(--sp-12)}
.guide-video-card .video-card__body h3{font-size:1.35rem}
.video-card__body p{color:var(--c-ink-500);font-size:.96rem}

/* Compact horizontal video card — for repeated/secondary placements */
.video-card.video-card--compact{display:grid;
  grid-template-columns:minmax(180px,220px) minmax(0,1fr);align-items:stretch;
  overflow:hidden;margin-top:var(--sp-5);max-width:520px}
.video-card.video-card--compact .video-frame{aspect-ratio:4/3;background:var(--c-primary-700)}
.video-card.video-card--compact .video-card__body{padding:var(--sp-4) var(--sp-5);
  align-content:center;gap:var(--sp-2)}
.video-card.video-card--compact .video-card__body h3{font-size:1.05rem;line-height:1.25;
  margin-bottom:0}
.video-card.video-card--compact .resource-kicker{font-size:.78rem}
@media (max-width:560px){
  .video-card.video-card--compact{grid-template-columns:1fr}
  .video-card.video-card--compact .video-frame{aspect-ratio:16/9}
}

/* Inline document download card — for IFU / supporting PDFs in body copy */
.doc-card{display:inline-flex;align-items:center;gap:var(--sp-4);
  margin-top:var(--sp-6);padding:.75rem 1.1rem .75rem .85rem;
  background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-pill);
  text-decoration:none;color:var(--c-ink-700);
  box-shadow:0 10px 28px -20px rgba(20,32,31,.22);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
  max-width:100%}
.doc-card:hover,.doc-card:focus-visible{border-color:var(--c-primary-600);
  transform:translateY(-1px);
  box-shadow:0 16px 36px -22px rgba(20,32,31,.3)}
.doc-card__icon{flex:0 0 44px;width:44px;height:44px;
  display:grid;place-items:center;border-radius:50%;background:var(--c-primary-050)}
.doc-card__icon svg{width:22px;height:22px;stroke:var(--c-primary-700);
  stroke-width:1.6;fill:none;stroke-linejoin:round;stroke-linecap:round}
.doc-card__text{display:grid;gap:1px;line-height:1.2}
.doc-card__text strong{font-family:var(--font-display);font-weight:700;
  color:var(--c-primary-700);font-size:1rem}
.doc-card__text span{color:var(--c-ink-500);font-size:.82rem;font-weight:500}
.doc-card__arrow{flex:0 0 auto;color:var(--c-primary-600);font-weight:700;font-size:1.05rem}

/* Care & cleaning section media stack — photo above, compact video below */
.care-media-stack{display:grid;gap:var(--sp-4);align-content:start}
.care-media-stack .media--care-photo{aspect-ratio:4/5;min-height:0;border-radius:var(--radius-md);
  background-position:center 38%}
.video-card.video-card--compact.care-media-stack__video{margin-top:0;max-width:none;width:100%;
  grid-template-columns:minmax(200px,240px) minmax(0,1fr);column-gap:0;
  box-shadow:0 10px 28px -20px rgba(20,32,31,.22)}
.video-card.video-card--compact.care-media-stack__video .video-frame{aspect-ratio:16/9}
.video-card.video-card--compact.care-media-stack__video .video-card__body{
  padding:var(--sp-4) var(--sp-6) var(--sp-4) var(--sp-8)}
@media (max-width:900px){
  .care-media-stack .media--care-photo{aspect-ratio:16/10}
}

/* Softer kicker variant — for recall/secondary cards */
.resource-kicker--soft{background:transparent;border:none;padding:0;
  color:var(--c-primary-600);letter-spacing:.08em;font-weight:700;font-size:.74rem;
  text-transform:uppercase}

.video-modal{position:fixed;inset:0;z-index:300;display:grid;place-items:center;
  padding:clamp(var(--sp-4),4vw,var(--sp-8));background:rgba(20,32,31,.74)}
.video-modal[aria-hidden="true"]{display:none}
.video-modal-open{overflow:hidden}
.video-modal__backdrop{position:absolute;inset:0}
.video-modal__panel{position:relative;width:min(1180px,96vw);background:#071615;
  border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-md);
  box-shadow:0 30px 100px -30px rgba(0,0,0,.72);overflow:hidden}
.video-modal__bar{display:flex;align-items:center;justify-content:space-between;
  gap:var(--sp-4);padding:var(--sp-4) var(--sp-5,1.25rem);background:var(--c-primary-700)}
.video-modal__title{font-family:var(--font-display);font-size:1rem;font-weight:700;
  color:#fff;margin:0;max-width:none;line-height:1.35}
.video-modal__actions{display:flex;gap:var(--sp-2);flex:none}
.video-modal__fullscreen,.video-modal__close{border:1px solid #ffffff3d;border-radius:var(--radius-pill);
  background:#ffffff12;color:#fff;font:inherit;font-size:.9rem;font-weight:800;
  padding:.55rem .9rem;cursor:pointer}
.video-modal__fullscreen:hover,.video-modal__close:hover{background:#fff;color:var(--c-primary-700)}
.video-modal__frame{position:relative;aspect-ratio:16/9;background:#000}
.video-modal__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

.trade-modal{position:fixed;inset:0;z-index:320;display:grid;place-items:center;
  padding:clamp(var(--sp-4),4vw,var(--sp-8));background:rgba(20,32,31,.72)}
.trade-modal[aria-hidden="true"]{display:none}
.trade-modal__backdrop{position:absolute;inset:0}
.trade-modal__panel{position:relative;width:min(100%,560px);background:#fff;
  border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  box-shadow:0 30px 100px -30px rgba(0,0,0,.55);padding:clamp(var(--sp-6),4vw,var(--sp-10,2.5rem))}
.trade-modal__panel h2{font-size:clamp(2rem,4vw,3rem);max-width:none}
.trade-modal__close{position:absolute;right:var(--sp-4);top:var(--sp-4);
  border:1px solid var(--c-ink-100);border-radius:var(--radius-pill);
  background:#fff;color:var(--c-primary-700);font:inherit;font-size:.85rem;font-weight:800;
  padding:.45rem .75rem;cursor:pointer}
.trade-form{display:grid;gap:var(--sp-4);margin-top:var(--sp-6)}
.trade-form label{display:grid;gap:var(--sp-2);color:var(--c-primary-700);
  font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.trade-form input{min-height:50px;border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);
  padding:0 var(--sp-4);font:inherit;color:var(--c-ink-900);letter-spacing:0;text-transform:none}
.trade-form input:focus{border-color:var(--c-primary-600);outline:none;
  box-shadow:0 0 0 4px rgba(127,179,178,.2)}
.trade-form .btn{justify-content:center}

/* QR getting-started guide */
.quick-guide .section{scroll-margin-top:var(--hdr)}
.quick-guide p,.quick-guide li{overflow-wrap:break-word}
.guide-hero{background:linear-gradient(135deg,var(--c-primary-050),#fff 58%);
  border-bottom:1px solid var(--c-ink-100)}
.guide-hero__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,420px);
  gap:var(--sp-16);align-items:center;padding-block:var(--sp-24)}
.guide-hero__copy h1{font-family:var(--font-accent);font-weight:400;
  color:var(--c-primary-700);letter-spacing:0;max-width:14ch}
.guide-hero__copy .lead{color:var(--c-primary-700);margin-bottom:var(--sp-3)}
.guide-actions{display:flex;flex-wrap:wrap;gap:var(--sp-3);margin-top:var(--sp-8)}
.guide-actions a{border:1px solid rgba(28,97,96,.22);border-radius:var(--radius-pill);
  background:#fff;color:var(--c-primary-700);font-weight:800;padding:.65rem 1rem;text-decoration:none}
.guide-actions a:hover{background:var(--c-primary-600);border-color:var(--c-primary-600);color:#fff}
.guide-device-panel{display:grid;gap:var(--sp-6);align-content:start}
.guide-device-panel>img{width:min(100%,300px);margin-inline:auto;border-radius:var(--radius-md);
  background:#f2f5f4;box-shadow:0 28px 80px -48px rgba(20,32,31,.5)}
.guide-simple-steps{display:grid;gap:var(--sp-4);list-style:none;padding:var(--sp-6);
  background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm)}
.guide-simple-steps li{display:grid;grid-template-columns:56px minmax(0,1fr);gap:var(--sp-4);
  align-items:center}
.guide-simple-steps span{display:grid;place-items:center;width:54px;height:54px;
  border-radius:50%;background:var(--c-primary-700);color:#fff;font-family:var(--font-display);
  font-size:1.6rem;font-weight:800;line-height:1}
.guide-simple-steps p{font-family:var(--font-display);font-weight:700;line-height:1.3;
  color:var(--c-ink-700);max-width:none}
.guide-alert{display:grid;grid-template-columns:auto minmax(0,1fr);gap:var(--sp-5);
  align-items:center;margin-bottom:var(--sp-12);padding:var(--sp-6);
  border:1px solid rgba(248,175,145,.55);border-left:6px solid var(--c-accent-400);
  border-radius:var(--radius-md);background:#fff8f4;box-shadow:var(--shadow-sm)}
.guide-alert span{font-family:var(--font-display);font-size:.78rem;font-weight:800;
  letter-spacing:.16em;text-transform:uppercase;color:#9c5738}
.guide-alert p{font-family:var(--font-accent);font-size:clamp(1.35rem,3vw,2rem);
  line-height:1.28;color:var(--c-primary-700);max-width:42ch}
.step-grid+.guide-alert{margin-top:var(--sp-8);margin-bottom:0}
.quickstart-reference{width:min(100%,780px);margin:var(--sp-10) auto 0;
  border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  background:var(--c-primary-050);box-shadow:0 24px 80px -44px rgba(20,32,31,.34);
  overflow:hidden}
.quickstart-reference img{display:block;width:100%;height:auto}
.step-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-6);
  margin-top:var(--sp-16)}
.step-card,.guide-panel,.tip-grid article,.parts-list{background:#fff;border:1px solid var(--c-ink-100);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}
.step-card{padding:var(--sp-8)}
.step-card--accent{background:linear-gradient(180deg,#fff8f4,#fff)}
.guide-illo{width:min(100%,210px);margin:0 auto var(--sp-6)}
.guide-illo svg{width:100%;height:auto;overflow:visible}
.guide-illo img{display:block;width:100%;height:auto;border-radius:50%}
.guide-illo circle,.guide-illo path{fill:none;stroke:#6e7675;stroke-width:4;
  stroke-linecap:round;stroke-linejoin:round}
.guide-illo .accent-line{stroke:var(--c-primary-600);stroke-width:6}
.visual-guide-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-4);
  margin-top:var(--sp-16)}
.visual-guide-card{position:relative;display:grid;align-content:start;gap:var(--sp-3);min-width:0;
  min-height:100%;padding:var(--sp-6) var(--sp-8);border:1px solid var(--c-primary-100);
  border-radius:var(--radius-sm);background:var(--c-primary-050);box-shadow:none}
.visual-guide-card__num{order:2;justify-self:start;
  display:inline-flex;
  font-size:.76rem;font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:var(--c-primary-700);
  padding:.3rem .7rem;border-radius:var(--radius-pill);
  margin-bottom:var(--sp-2)}
.visual-guide-card__num::before{content:"Step\00a0"}
.visual-guide-card .guide-illo{order:1;width:min(100%,160px);height:auto;
  margin:0 auto var(--sp-2);background:transparent;border-radius:0;padding:0;overflow:visible;
  display:block}
.visual-guide-card .guide-illo img,
.visual-guide-card .guide-illo svg{display:block;width:100%;height:auto;
  max-height:none;border-radius:0}
.visual-guide-card h3{order:3;font-family:var(--font-accent);font-size:clamp(1.35rem,2.2vw,1.75rem);
  font-weight:400;letter-spacing:0;line-height:1.15;margin-bottom:0}
.visual-guide-card ul{order:4}
.visual-guide-card ul{display:grid;gap:var(--sp-3);padding-left:1.2rem;color:var(--c-ink-700);
  font-size:.92rem;line-height:1.3}
.visual-guide-card li{line-height:1.3}
.visual-guide-card p,.visual-guide-card li{color:var(--c-ink-700);overflow-wrap:anywhere;word-break:break-word}
.guide-url{display:block}
.visual-guide-card--wide{grid-column:span 2;grid-template-columns:170px minmax(0,1fr);
  align-items:center;background:#fff}
.visual-guide-card--wide .guide-illo{margin:0}
.visual-guide-card--alert{grid-template-columns:1fr;align-content:center;gap:var(--sp-3);
  border-color:rgba(248,175,145,.55);border-left:6px solid var(--c-accent-400);background:#fff8f4}
.visual-guide-card--alert h3{font-family:var(--font-display);font-size:clamp(1rem,1.8vw,1.25rem);
  font-weight:800;letter-spacing:.08em;line-height:1.2;text-transform:uppercase;color:#9c5738}
.visual-guide-card--alert p{font-family:var(--font-accent);font-size:clamp(1.25rem,2.2vw,1.75rem);
  line-height:1.3;color:var(--c-primary-700);max-width:36ch}
.visual-guide-card--recap{grid-column:1/-1;grid-template-columns:auto minmax(0,1fr);
  align-items:center;gap:var(--sp-6);min-height:0;padding:var(--sp-5) var(--sp-8);
  margin-top:var(--sp-8);
  background:var(--c-primary-600);color:#fff;border:none}
.visual-guide-card--recap h3{color:#fff;font-family:var(--font-accent);font-size:clamp(1.25rem,2.1vw,1.75rem);
  font-weight:400;line-height:1.05;white-space:nowrap}
.visual-guide-card--recap ul{display:flex;flex-wrap:wrap;gap:var(--sp-2);list-style:none;
  justify-content:flex-start;padding-left:0;color:#dcebe9}
.visual-guide-card--recap li{border:none;border-radius:var(--radius-pill);
  background:rgba(255,255,255,.08);
  padding:.45rem .85rem;text-align:center;font-size:clamp(.85rem,1.15vw,.95rem);line-height:1.25;
  color:#eaf3f1;font-weight:500}
.step-card span,.tip-grid span{display:inline-flex;margin-bottom:var(--sp-4);border-radius:var(--radius-pill);
  background:var(--c-primary-700);color:#fff;font-size:.76rem;font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;padding:.3rem .7rem}
.step-card h2{font-family:var(--font-display);font-size:1.32rem;font-weight:700;max-width:none;
  margin-bottom:var(--sp-4)}
.step-card ul,.guide-panel ul,.tip-grid ul,.recap ul{display:grid;gap:var(--sp-3);padding-left:1.2rem;color:var(--c-ink-500)}
.guide-two{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:var(--sp-8);
  align-items:start}
.guide-panel{padding:var(--sp-8)}
.guide-panel h3{font-size:1.22rem;margin-bottom:var(--sp-4);max-width:none}
.guide-panel--warning{border-left:5px solid var(--c-accent-400)}
.tip-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-5);
  margin-top:var(--sp-12)}
.tip-grid article{padding:var(--sp-6)}
.tip-grid h3{font-size:1.1rem;margin-bottom:var(--sp-3)}
.tip-grid p{color:var(--c-ink-500);font-size:.95rem}
.recap{margin-top:var(--sp-8);padding:var(--sp-6);border-radius:var(--radius-md);
  background:var(--c-primary-700);color:#fff}
.recap h3{color:#fff;margin-bottom:var(--sp-4)}
.recap ul{grid-template-columns:repeat(5,minmax(0,1fr));list-style:none;padding-left:0;color:#dcebe9}
.recap li{border:1px solid #ffffff22;border-radius:var(--radius-pill);padding:.55rem .8rem;text-align:center}
.device-intro{margin-bottom:var(--sp-12)}
.device-two{align-items:start}
.cleaning-intro{margin-bottom:var(--sp-12);max-width:calc(50% - var(--sp-3))}
@media (max-width:900px){
  .cleaning-intro{max-width:none}
}
#temperature{padding-bottom:var(--sp-16)}
.temperature-grid{display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(200px,250px) minmax(0,1fr);
  gap:var(--sp-8);align-items:start}
.temperature-intro h2{font-size:clamp(1.85rem,2.6vw,2.5rem);max-width:none}
.temperature-photo{align-self:center}
.temperature-photo img{display:block;width:100%;height:auto;
  border-radius:var(--radius-md);box-shadow:0 18px 38px -22px rgba(20,32,31,.28)}
@media (max-width:900px){
  .temperature-grid{grid-template-columns:1fr;gap:var(--sp-6)}
  .temperature-photo{max-width:300px;margin-inline:auto}
}
.cleaning-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-6);
  align-items:stretch}
.cleaning-grid__full{grid-column:1/-1}
.cleaning-grid .guide-panel--warning{background:transparent;border:none;box-shadow:none;
  border-left:5px solid var(--c-accent-400);border-radius:0;padding:var(--sp-5) var(--sp-6)}
.cleaning-grid .guide-panel--warning ul{display:block;columns:2;column-gap:var(--sp-8);gap:0}
.cleaning-grid .guide-panel--warning li{break-inside:avoid;margin-bottom:var(--sp-3)}
@media (max-width:900px){
  .cleaning-grid{grid-template-columns:1fr}
  .cleaning-grid .guide-panel--warning ul{columns:1}
}
.device-right{display:flex;flex-direction:column;gap:var(--sp-6)}
.guide-panel__icon{display:inline-grid;place-items:center;width:32px;height:32px;
  border-radius:50%;background:var(--c-primary-050);color:var(--c-primary-700);
  margin-right:var(--sp-3);flex:0 0 auto;vertical-align:middle;
  font-family:var(--font-display);font-size:1.1rem;font-weight:800;line-height:1;
  padding-bottom:2px}
.guide-panel__icon--danger{background:#fde2d4;color:var(--c-primary-700)}
.guide-panel h3:has(.guide-panel__icon){display:flex;align-items:center;gap:0}
.guide-panel--warning ul{font-size:.92rem;line-height:1.4}
.guide-panel--warning li{margin-bottom:var(--sp-3)}
.parts-list{grid-column:span 1;padding:var(--sp-8);columns:2;column-gap:var(--sp-8);
  color:var(--c-ink-500);list-style:none;counter-reset:part}
.parts-list li{break-inside:avoid;margin:0 0 var(--sp-6);
  padding-left:calc(28px + var(--sp-3));position:relative;counter-increment:part;
  font-size:.94rem;line-height:1.4}
.parts-list li::before{content:counter(part);position:absolute;left:0;top:.1rem;
  display:grid;place-items:center;width:26px;height:26px;border-radius:50%;
  background:var(--c-primary-700);color:#fff;font-family:var(--font-display);
  font-size:.78rem;font-weight:800;line-height:1}
.parts-list li strong{display:block;color:var(--c-primary-700);font-family:var(--font-display);
  font-size:1rem;font-weight:700;margin-bottom:.2rem;line-height:1.2}
.device-closeup{display:block;width:100%;max-width:520px;margin:0 auto;
  border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  background:var(--c-primary-050);box-shadow:var(--shadow-sm)}

/* Research & education */
.research-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-6)}
.research-card{display:grid;gap:var(--sp-4);align-content:start;min-height:100%;
  background:#fff;border:1px solid var(--c-ink-100);border-top:3px solid var(--c-accent-400);
  border-radius:var(--radius-sm);padding:var(--sp-8);box-shadow:var(--shadow-sm)}
.research-card__media{display:block;margin:calc(-1 * var(--sp-8)) calc(-1 * var(--sp-8)) var(--sp-3);
  aspect-ratio:16/10;overflow:hidden;border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:var(--c-primary-050)}
.research-card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur) var(--ease)}
.research-card:hover .research-card__media img{transform:scale(1.03)}
.research-card h3{font-size:1.28rem;max-width:none}
.research-card h3 a{text-decoration:none;color:var(--c-primary-700)}
.research-card h3 a:hover{color:var(--c-primary-600);text-decoration:underline;
  text-decoration-color:var(--c-accent-400)}
.research-card p{color:var(--c-ink-500);font-size:.98rem}
.research-meta{color:var(--c-ink-500);font-size:.82rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;margin-top:auto}
.article-shell{background:linear-gradient(180deg,var(--c-primary-050),#fff 420px)}
.article-hero{padding-block:var(--sp-24) var(--sp-12)}
.article-hero .wrap{max-width:940px}
.article-hero h1{font-family:var(--font-accent);font-weight:400;letter-spacing:0;
  max-width:18ch;color:var(--c-primary-700)}
.article-dek{font-family:var(--font-accent);font-size:1.32rem;line-height:1.55;
  color:var(--c-ink-700);margin-top:var(--sp-6);max-width:58ch}
.article-meta{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-8);
  color:var(--c-ink-500);font-size:.86rem;font-weight:700}
.article-meta span{border:1px solid var(--c-ink-100);border-radius:var(--radius-pill);
  background:#fff;padding:.38rem .75rem}
.spec-callout-section{background:var(--c-primary-050);border-top:12px solid var(--c-primary-700);
  overflow:hidden}
.spec-device-heading{text-align:center;margin-bottom:var(--sp-12)}
.spec-device-heading .eyebrow{display:flex;justify-content:flex-start;margin-bottom:var(--sp-4)}
.spec-device-heading .eyebrow::before{width:8px;height:40px;border-radius:1px}
.spec-device-heading h2{font-size:clamp(2.6rem,5.4vw,5rem);max-width:none;
  margin-inline:auto;margin-bottom:var(--sp-3)}
.spec-device-heading p{margin-inline:auto;color:var(--c-primary-600);
  font-size:clamp(1.2rem,2vw,1.7rem);max-width:46ch}
.spec-device{display:grid;grid-template-columns:minmax(220px,300px) minmax(220px,280px) minmax(220px,300px);
  gap:clamp(var(--sp-3),1.4vw,var(--sp-6));align-items:center;justify-content:center;
  max-width:880px;margin-inline:auto}
.spec-device__figure{display:flex;justify-content:center;align-items:center;min-height:620px}
.spec-device__figure img{height:620px;width:auto;max-width:100%;filter:drop-shadow(0 28px 32px rgba(20,32,31,.18))}
.spec-callouts{display:grid;gap:clamp(var(--sp-16),8vw,var(--sp-24))}
.spec-callout{display:grid;align-items:center;gap:var(--sp-4)}
.spec-callout--left{grid-template-columns:minmax(0,1fr) 90px;text-align:right}
.spec-callout--right{grid-template-columns:90px minmax(0,1fr);text-align:left}
.spec-callout span{position:relative;height:2px;background:var(--c-primary-600);display:block}
.spec-callout span::after{content:"";position:absolute;top:50%;width:14px;height:14px;
  border-radius:50%;background:var(--c-primary-600);transform:translateY(-50%)}
.spec-callout--left span::after{right:0}
.spec-callout--right span::after{left:0}
.spec-callout h3{font-family:var(--font-accent);font-weight:400;
  max-width:none;font-size:1.42rem;line-height:1.15;color:var(--c-primary-700);
  margin-bottom:.55rem}
.spec-callout p{max-width:26ch;color:var(--c-ink-500);font-size:.95rem;font-weight:500;
  line-height:1.4}
.spec-callout--left p{margin-left:auto}
.article-layout{display:grid;grid-template-columns:minmax(200px,.32fr) minmax(0,.68fr);
  gap:var(--sp-16);align-items:start;padding-block:0 var(--sp-24)}
.article-toc{position:sticky;top:calc(var(--hdr) + var(--sp-8));
  border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);background:#fff;
  padding:var(--sp-6);box-shadow:var(--shadow-sm)}
.article-toc h2{font-family:var(--font-display);font-size:.88rem;font-weight:800;
  letter-spacing:.1em;text-transform:uppercase;margin:0 0 var(--sp-3);max-width:none}
.article-toc ol{display:grid;gap:var(--sp-2);padding-left:1.1rem;color:var(--c-ink-500);
  font-size:.92rem;line-height:1.45}
.article-toc a{text-decoration:none;font-weight:700}
.article-body{background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-md);
  padding:clamp(var(--sp-6),4vw,var(--sp-12));box-shadow:0 18px 54px -34px rgba(20,32,31,.24)}
.article-body h2{font-size:clamp(1.8rem,2.7vw,2.7rem);max-width:22ch;margin-top:var(--sp-12)}
.article-body h2:first-child{margin-top:0}
.article-body h3{margin-top:var(--sp-8);font-size:1.28rem}
.article-body p,.article-body li{color:var(--c-ink-700)}
.article-body p+p{margin-top:var(--sp-4)}
.article-body ul,.article-body ol{display:grid;gap:var(--sp-3);padding-left:1.25rem;margin-block:var(--sp-4)}
.article-visual{margin:var(--sp-8) 0;border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--c-ink-100);background:var(--c-primary-050)}
.article-visual img{width:100%;height:auto}
.article-visual figcaption{padding:var(--sp-4);font-size:.88rem;color:var(--c-ink-500)}
.article-callout{border-left:4px solid var(--c-primary-600);background:var(--c-primary-050);
  border-radius:var(--radius-sm);padding:var(--sp-6);margin:var(--sp-8) 0}
.article-callout strong{color:var(--c-primary-700)}
.source-list{border-top:1px solid var(--c-ink-100);margin-top:var(--sp-12);
  padding-top:var(--sp-8)}
.source-list h2{font-family:var(--font-display);font-size:1.1rem;font-weight:800;
  letter-spacing:.08em;text-transform:uppercase;margin:0 0 var(--sp-4);max-width:none}
.source-list li{font-size:.94rem;color:var(--c-ink-500)}
.related-articles{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-4);
  margin-top:var(--sp-6)}
.related-articles a{display:block;border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);
  padding:var(--sp-4);text-decoration:none;font-weight:800;background:var(--c-surface-2)}
@media (max-width:900px){
  .video-grid{grid-template-columns:1fr}
  .research-grid,.article-layout,.related-articles{grid-template-columns:1fr}
  .article-toc{position:static}
}

/* Knowledge base */
.hero--assistant .wrap{grid-template-columns:minmax(0,980px);justify-content:center;text-align:center}
.hero--assistant h1{max-width:14ch;margin-inline:auto}
.hero--assistant .lead{margin-inline:auto;max-width:62ch}
.kb-assistant{width:min(100%,900px);margin:var(--sp-16) auto 0;background:rgba(255,255,255,.98);
  color:var(--c-ink-700);border:1px solid rgba(255,255,255,.42);
  border-radius:var(--radius-lg);padding:clamp(1.25rem,3vw,2.5rem);
  box-shadow:0 32px 90px -36px rgba(0,0,0,.62);
  text-align:left;min-width:0}
.kb-ask{display:grid;gap:var(--sp-3);min-width:0}
.kb-ask span{color:var(--c-primary-700);font-size:.8rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase}
.kb-ask input,.kb-ask__input{display:block;width:100%;min-height:86px;
  -webkit-appearance:none;appearance:none;border:2px solid var(--c-primary-100);
  border-radius:22px;padding:0 clamp(1.1rem,3vw,2rem);font:inherit;
  font-size:clamp(1.15rem,2.2vw,1.5rem);font-weight:700;color:var(--c-ink-900);
  background:#fff;box-shadow:0 14px 34px -24px rgba(20,32,31,.5)}
.kb-ask input::placeholder{color:var(--c-ink-300);opacity:1}
.kb-ask input::-webkit-search-decoration,
.kb-ask input::-webkit-search-cancel-button{transform:scale(1.25)}
.kb-ask input:focus{border-color:var(--c-primary-600);outline:none;
  box-shadow:0 0 0 5px rgba(127,179,178,.24),0 18px 40px -26px rgba(20,32,31,.55)}
.kb-suggestions{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-4)}
.kb-suggestions button{border:1px solid var(--c-ink-100);border-radius:var(--radius-pill);
  background:var(--c-primary-050);color:var(--c-primary-700);font:inherit;font-size:.88rem;
  font-weight:700;padding:.62rem .95rem;cursor:pointer}
.kb-suggestions button:hover{background:var(--c-primary-600);border-color:var(--c-primary-600);
  color:#fff}
.kb-answer{margin-top:var(--sp-5,1.25rem);border-top:1px solid var(--c-ink-100);
  padding-top:var(--sp-5,1.25rem)}
.kb-answer__status{color:var(--c-ink-500);font-size:.95rem;max-width:none}
.kb-answer__results{display:grid;gap:var(--sp-3);margin-top:var(--sp-4)}
.kb-answer-card{display:grid;gap:.35rem;border:1px solid var(--c-ink-100);
  border-radius:var(--radius-sm);padding:var(--sp-4);background:#fff;text-decoration:none;
  box-shadow:var(--shadow-sm)}
.kb-answer-card:hover{border-color:var(--c-primary-300);background:var(--c-primary-050)}
.kb-answer-card span{width:max-content;max-width:100%;border-radius:var(--radius-pill);
  background:var(--c-primary-050);padding:.2rem .55rem;color:var(--c-primary-700);
  font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.kb-answer-card strong{color:var(--c-primary-700);font-family:var(--font-display);line-height:1.25}
.kb-answer-card p{max-width:none;color:var(--c-ink-500);font-size:.92rem;line-height:1.55}
.kb-toolbar{display:block;margin:var(--sp-8) 0 var(--sp-12)}
.kb-search{display:grid;gap:var(--sp-2);font-size:.84rem;font-weight:700;
  color:var(--c-primary-700);letter-spacing:.04em;text-transform:uppercase}
.kb-search input{min-height:54px;border:1px solid var(--c-ink-100);
  border-radius:var(--radius-pill);padding:0 var(--sp-6);font:inherit;
  font-size:1rem;font-weight:500;letter-spacing:0;text-transform:none;color:var(--c-ink-900);
  background:#fff;box-shadow:var(--shadow-sm)}
.kb-search input:focus{border-color:var(--c-primary-600);outline:none;
  box-shadow:0 0 0 4px rgba(127,179,178,.2)}
.kb-tabs{display:flex;flex-wrap:wrap;gap:var(--sp-2);justify-content:flex-start}
.kb-tab{border:1px solid var(--c-ink-100);border-radius:var(--radius-pill);
  background:#fff;color:var(--c-primary-700);font:inherit;font-size:.9rem;font-weight:700;
  padding:.72rem 1rem;cursor:pointer;transition:background var(--dur) var(--ease),
  color var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.kb-tab:hover,.kb-tab.is-active{background:var(--c-primary-600);border-color:var(--c-primary-600);
  color:#fff}
.kb-empty{border:1px dashed var(--c-ink-300);border-radius:var(--radius-sm);
  padding:var(--sp-8);background:#fff;color:var(--c-ink-500);text-align:center;
  margin-bottom:var(--sp-8)}
.kb-section{margin-top:var(--sp-16)}
.kb-section[hidden]{display:none}
.kb-section__head{display:grid;grid-template-columns:minmax(0,1fr) auto;
  column-gap:var(--sp-6);row-gap:var(--sp-2);align-items:center;
  border-bottom:1px solid var(--c-ink-100);padding-bottom:var(--sp-4);
  margin-bottom:var(--sp-4)}
.kb-section__head .resource-kicker{grid-column:1;grid-row:1;justify-self:start;
  background:transparent;padding-inline:0;font-size:.78rem;letter-spacing:.1em}
.kb-section__head h3{grid-column:1;grid-row:2;
  font-family:var(--font-accent);font-weight:400;
  max-width:none;font-size:1.85rem;line-height:1.15;color:var(--c-primary-700)}
.kb-section__head a{grid-column:2;grid-row:1/span 2;align-self:center;
  font-weight:700;text-decoration:none;white-space:nowrap}
.kb-list{display:grid;gap:var(--sp-3)}
.kb-item{background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);overflow:hidden}
.kb-item[hidden]{display:none}
.kb-item summary{display:flex;align-items:center;justify-content:space-between;
  gap:var(--sp-6);padding:var(--sp-5,1.25rem) var(--sp-6);
  color:var(--c-primary-700);font-family:var(--font-display);font-size:1.05rem;
  font-weight:700;line-height:1.35;cursor:pointer;list-style:none}
.kb-item summary::-webkit-details-marker{display:none}
.kb-item summary::after{content:"+";flex:none;width:32px;height:32px;border-radius:50%;
  display:grid;place-items:center;background:var(--c-primary-050);color:var(--c-primary-600);
  font-family:var(--font-body);font-size:1.35rem;line-height:1}
.kb-item[open] summary{background:var(--c-primary-050)}
.kb-item[open] summary::after{content:"−";background:var(--c-accent-400);color:var(--c-primary-700)}
.kb-item p{max-width:76ch;color:var(--c-ink-500);padding:0 var(--sp-6) var(--sp-5,1.25rem)}
.kb-item p:first-of-type{padding-top:var(--sp-5,1.25rem)}
.kb-item p+p{padding-top:0}
.kb-item a{font-weight:700;text-decoration:none}
.kb-data-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--sp-4);
  margin:var(--sp-6) 0}
.kb-data-card{background:#fff;border:1px solid var(--c-ink-100);border-radius:var(--radius-sm);
  padding:var(--sp-6);box-shadow:var(--shadow-sm);border-top:3px solid var(--c-accent-400)}
.kb-data-card[hidden]{display:none}
.kb-data-card span{display:block;color:var(--c-primary-600);font-family:var(--font-display);
  font-size:1.45rem;font-weight:700;line-height:1.1;margin-bottom:var(--sp-3)}
.kb-data-card h4{font-family:var(--font-display);color:var(--c-primary-700);
  font-size:1rem;margin-bottom:var(--sp-2)}
.kb-data-card p{color:var(--c-ink-500);font-size:.92rem;line-height:1.55}

/* Footer */
.site-footer{background:var(--c-surface);color:var(--c-ink-500);
  border-top:1px solid var(--c-ink-100);padding-block:var(--sp-24) var(--sp-12);
  font-size:.92rem}
.site-footer a{color:var(--c-primary-600);text-decoration:none}
.site-footer a:hover{color:var(--c-primary-700)}
.foot-grid{display:grid;grid-template-columns:minmax(260px,1.4fr) repeat(3,minmax(150px,.8fr));
  gap:clamp(var(--sp-8),5vw,var(--sp-16));
  padding-bottom:var(--sp-12);border-bottom:1px solid var(--c-ink-100)}
.site-footer img{height:34px;margin-bottom:var(--sp-6)}
.site-footer p{max-width:34rem}
.site-footer h4{color:var(--c-ink-900);font-family:var(--font-accent);font-size:.95rem;
  margin-bottom:var(--sp-4);text-transform:uppercase;letter-spacing:.1em}
.site-footer ul{list-style:none}
.site-footer li{break-inside:avoid;margin:0 0 var(--sp-2)}
.site-footer li a{display:inline-block;padding:.1rem 0;font-weight:700}
.legal{padding-top:var(--sp-8);font-size:.82rem;color:var(--c-ink-500);line-height:1.7}

/* Scroll reveal — subtle fade + rise. Only when JS present AND motion allowed;
   no-JS or reduced-motion = fully visible, no animation. transform/opacity only (no CLS). */
@media (prefers-reduced-motion:no-preference){
  .js .lhero__inner,
  .js .band .band__in,
  .js .card--feature,
  .js .statement__in,
  .js main>section.section>.wrap>*:not(.grid-3){
    opacity:0;transform:translateY(26px);
    transition:opacity .6s var(--ease),transform .6s var(--ease)}
  .js .lhero__inner.is-in,
  .js .band .band__in.is-in,
  .js .card--feature.is-in,
  .js .statement__in.is-in,
  .js main>section.section>.wrap>.is-in{opacity:1;transform:none}
}

/* Responsive */
@media (max-width:900px){
  .js .lhero__inner{opacity:1;transform:none;transition:none}
  .hero .wrap{grid-template-columns:1fr;gap:var(--sp-12);padding-block:var(--sp-24)}
  .hero h1,.hero h2,.hero h3,.hero p,.hero .lead,
  .lhero h1,.lhero h2,.lhero h3,.lhero p{
    max-width:100%;text-wrap:wrap;overflow-wrap:break-word}
  .hero-actions,.badges{max-width:100%;min-width:0}
  .btn{white-space:normal;text-align:center;justify-content:center}
  .hero--registration .wrap,.registration-layout,.contact-layout{grid-template-columns:1fr}
  .registration-aside,.contact-aside{position:static}
  .grid-3,.grid-2,.foot-grid,.resource-grid,.resource-grid--three,.box-layout{grid-template-columns:1fr}
  .spec-device{grid-template-columns:1fr;gap:var(--sp-8)}
  .spec-device-heading{text-align:left;margin-bottom:var(--sp-8)}
  .spec-device-heading .eyebrow{justify-content:flex-start}
  .spec-device-heading h2{font-size:clamp(2.4rem,12vw,3.6rem);margin-inline:0}
  .spec-device-heading p{margin-inline:0;font-size:1.15rem}
  .spec-device__figure{order:-1;min-height:auto}
  .spec-device__figure img{height:min(60vh,420px);width:auto;max-width:100%}
  .spec-callouts{gap:var(--sp-4)}
  .spec-callout,.spec-callout--left,.spec-callout--right{grid-template-columns:1fr;text-align:left;
    padding:var(--sp-4);background:#fff;border:1px solid var(--c-ink-100);
    border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}
  .spec-callout span{display:none}
  .spec-callout--left p{margin-left:0}
  .guide-hero__grid,.step-grid,.guide-two,.tip-grid,.visual-guide-grid{grid-template-columns:1fr}
  .guide-hero__grid{gap:var(--sp-8);padding-block:var(--sp-16)}
  .guide-hero__copy p{max-width:32ch}
  .guide-simple-steps{padding:var(--sp-4)}
  .guide-simple-steps li{grid-template-columns:44px minmax(0,1fr);gap:var(--sp-3)}
  .guide-simple-steps span{width:44px;height:44px;font-size:1.25rem}
  .guide-simple-steps p{font-size:1rem;line-height:1.28;max-width:24ch}
  .guide-alert{grid-template-columns:1fr}
  .visual-guide-grid{width:100%;max-width:100%;overflow:hidden}
  .visual-guide-card{width:100%;max-width:100%;min-width:0;padding:var(--sp-5);overflow:hidden}
  .visual-guide-card .guide-illo{width:min(68vw,190px)}
  .visual-guide-card h3,.visual-guide-card ul,.visual-guide-card li{min-width:0}
  .visual-guide-card--wide,.visual-guide-card--alert{grid-column:auto;grid-template-columns:minmax(0,1fr)}
  .visual-guide-card--recap{grid-template-columns:1fr;padding:var(--sp-6)}
  .visual-guide-card--recap h3{white-space:normal}
  .visual-guide-card--recap ul{display:grid;grid-template-columns:1fr;justify-content:stretch}
  .visual-guide-card--recap li{text-align:left}
  .guide-video-card{grid-template-columns:1fr}
  .parts-list{columns:1}
  .recap ul{grid-template-columns:1fr 1fr}
  .site-footer ul{columns:1}
  .box-layout{gap:var(--sp-8)}
  .hero--assistant .wrap{text-align:left}
  .hero--assistant h1,.hero--assistant .lead{margin-inline:0}
  .kb-assistant{width:100%;max-width:calc(100vw - 3rem);padding:var(--sp-4)}
  .kb-ask input,.kb-ask__input{min-height:70px;border-radius:16px;padding:0 var(--sp-4);
    font-size:1.05rem}
  .kb-answer__status,.kb-answer-card p,.kb-data-card p{overflow-wrap:anywhere;text-wrap:wrap}
  .kb-toolbar{display:block}
  .kb-tabs{justify-content:flex-start}
  .kb-section__head{grid-template-columns:1fr;row-gap:var(--sp-3)}
  .kb-section__head .resource-kicker{grid-column:1;grid-row:1}
  .kb-section__head h3{grid-column:1;grid-row:2}
  .kb-section__head a{grid-column:1;grid-row:3;white-space:normal;justify-self:start}
  .kb-data-grid{grid-template-columns:1fr 1fr}
  .nav,.header-cta{display:none}
  .navtoggle{display:inline-block}
  .site-header .wrap{display:flex}
  /* Mobile nav — dropdown panel below the header bar */
  .site-header.is-nav-open .nav{display:flex;flex-direction:column;
    align-items:stretch;gap:0;position:absolute;left:0;right:0;top:100%;
    background:var(--c-primary-700);padding:0 var(--sp-6) var(--sp-4);
    box-shadow:0 22px 34px -24px rgba(0,0,0,.65)}
  .site-header.is-nav-open .nav a{display:block;padding:var(--sp-3) 0;
    font-size:1rem;border-top:1px solid #ffffff22}
  .section{padding-block:var(--sp-16)}
  .cta-band{padding:var(--sp-12) var(--sp-6)}
  .video-modal__bar{align-items:flex-start;display:grid}
  .video-modal__actions{width:100%;justify-content:space-between}
}
@media (max-width:560px){
  .wrap{padding-inline:1.5rem}
  h1{font-size:clamp(2.15rem,9vw,2.8rem)}
  h2{font-size:clamp(1.7rem,7vw,2.2rem)}
  .hero .wrap{padding-block:var(--sp-16)}
  .section{padding-block:var(--sp-12)}
  .card,.gate-card{padding:var(--sp-6)}
  .mandatory{padding:var(--sp-2) var(--sp-6)}
  .registration-form{padding:var(--sp-6);border-radius:var(--radius-md)}
  .form-grid{grid-template-columns:1fr}
  .form-actions{display:grid}
  .cta-band{padding:var(--sp-8) var(--sp-4)}
  /* Stack the spec table — no horizontal overflow on phones */
  .spec,.spec tbody,.spec tr,.spec th,.spec td{display:block;width:auto}
  .spec tr{border-bottom:1px solid var(--c-ink-100);padding:var(--sp-3) 0}
  .spec th,.spec td{border:0;padding:var(--sp-1) 0}
  .spec th{color:var(--c-primary-700)}
  /* Steps: move the number inline so it never collides at tiny widths */
  .steps li{padding:var(--sp-6);padding-top:var(--sp-16)}
  .steps li::before{left:var(--sp-6);top:var(--sp-6);width:34px;height:34px;font-size:.95rem}
  .btn{padding:.8rem 1.2rem;font-size:.95rem}
  .kb-data-grid{grid-template-columns:1fr}
  .visual-guide-card{padding:var(--sp-4)}
  .visual-guide-card__num{width:auto;height:auto;font-size:.76rem;padding:.3rem .7rem}
  .visual-guide-card .guide-illo{width:min(64vw,170px)}
  .visual-guide-card h3{font-size:clamp(1.35rem,7vw,1.75rem)}
  .visual-guide-card--recap li{font-size:.95rem}
}
