/* =========================================================================
   M2A ANESTESIA — Design System
   Brand: navy #14334B · gradient #91D8F7 → #7ECDCB
   Type:  Schibsted Grotesk (display) · Hanken Grotesk (text)
   ========================================================================= */

:root{
  /* brand */
  --navy:        #14334B;
  --navy-900:    #0C2030;
  --navy-800:    #102B3F;
  --navy-700:    #18435F;
  --blue:        #91D8F7;
  --teal:        #7ECDCB;
  --accent-deep: #2B8A91;   /* accessible teal for small accents/links */

  /* ink + neutrals (cool-tinted) */
  --ink:        #14334B;
  --ink-soft:   #41566A;
  --muted:      #6E8493;
  --line:       #E2EBF0;
  --line-soft:  #EEF4F7;

  /* surfaces */
  --bg:         #FFFFFF;
  --bg-soft:    #F4F8FA;
  --bg-tint:    #EEF6F6;
  --bg-navy:    var(--navy);

  /* gradient */
  --grad:       linear-gradient(142deg, var(--blue) 0%, var(--teal) 100%);
  --grad-soft:  linear-gradient(142deg, rgba(145,216,247,.16) 0%, rgba(126,205,203,.16) 100%);

  /* type */
  --font-display: "Schibsted Grotesk", system-ui, sans-serif;
  --font-text:    "Hanken Grotesk", system-ui, sans-serif;

  /* rhythm */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --section: clamp(72px, 9vw, 132px);
  --radius: 18px;
  --radius-lg: 26px;
  --radius-sm: 12px;

  /* fx */
  --shadow-sm: 0 1px 2px rgba(20,51,75,.06), 0 2px 8px rgba(20,51,75,.05);
  --shadow:    0 8px 30px rgba(20,51,75,.08), 0 2px 8px rgba(20,51,75,.04);
  --shadow-lg: 0 30px 70px -24px rgba(20,51,75,.30), 0 8px 24px rgba(20,51,75,.08);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-text);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.62;
  color:var(--ink-soft);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
::selection{ background:rgba(126,205,203,.35); color:var(--navy); }

/* ---------- type ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--ink);
  line-height:1.04;
  letter-spacing:-.02em;
  font-weight:680;
  margin:0;
  text-wrap:balance;
}
h1{ font-size:clamp(2.7rem,5.4vw,4.5rem); }
h2{ font-size:clamp(2rem,3.6vw,3.15rem); letter-spacing:-.022em; }
h3{ font-size:clamp(1.3rem,1.7vw,1.6rem); letter-spacing:-.015em; font-weight:640; }
p{ margin:0; text-wrap:pretty; }

.eyebrow{
  font-family:var(--font-text);
  font-weight:680;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent-deep);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:26px;height:2px;border-radius:2px;
  background:var(--grad);
}
.eyebrow.center::after{
  content:"";
  width:26px;height:2px;border-radius:2px;
  background:var(--grad);
}

.lead{ font-size:clamp(1.1rem,1.45vw,1.32rem); line-height:1.55; color:var(--ink-soft); }
.gradient-text{
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--section); }
.etb{ /* even top, bigger bottom helper not needed */ }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--navy); --fg:#fff;
  display:inline-flex; align-items:center; gap:.6em;
  padding:.95em 1.5em;
  border-radius:999px;
  font-family:var(--font-text); font-weight:640; font-size:.98rem;
  letter-spacing:.005em;
  border:1px solid transparent;
  background:var(--bg); color:var(--fg);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .25s, color .25s;
  white-space:nowrap;
}
.btn svg{ width:1.1em;height:1.1em; }
.btn--primary{ background:var(--navy); color:#fff; box-shadow:0 10px 24px -10px rgba(20,51,75,.6); }
.btn--primary:hover{ transform:translateY(-2px); box-shadow:0 16px 30px -10px rgba(20,51,75,.55); }
.btn--ghost{ background:transparent; color:var(--navy); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--navy); transform:translateY(-2px); }
.btn--grad{ background:var(--grad); color:var(--navy); box-shadow:0 12px 26px -12px rgba(126,205,203,.9); }
.btn--grad:hover{ transform:translateY(-2px); }
.btn--light{ background:#fff; color:var(--navy); }
.btn--light:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.btn--lg{ padding:1.1em 1.8em; font-size:1.05rem; }

.link-arrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-weight:640; color:var(--navy);
  border-bottom:2px solid transparent;
  transition:gap .3s var(--ease), border-color .3s;
}
.link-arrow svg{ width:1em;height:1em; transition:transform .3s var(--ease); }
.link-arrow:hover{ gap:.8em; }
.link-arrow:hover svg{ transform:translateX(3px); }

/* ---------- chips / pills ---------- */
.pill{
  display:inline-flex; align-items:center; gap:.55em;
  padding:.5em .9em; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  font-size:.86rem; font-weight:560; color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.pill .dot{ width:7px;height:7px;border-radius:50%; background:var(--grad); }

/* ---------- header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.site-header .wrap{ display:flex; align-items:center; gap:2rem; height:84px; }
.site-header.scrolled{
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(1.4) blur(16px);
  -webkit-backdrop-filter:saturate(1.4) blur(16px);
  border-bottom-color:var(--line);
  box-shadow:0 1px 0 rgba(20,51,75,.03);
}
.brand{ display:flex; align-items:center; gap:.7rem; flex-shrink:0; }
.brand img{ height:42px; width:auto; }
.brand .logo-white{ display:none; }
.nav{ display:flex; align-items:center; gap:2rem; margin-left:auto; }
.nav a{
  font-weight:540; font-size:.97rem; color:var(--ink-soft); white-space:nowrap;
  position:relative; padding-block:.4em; transition:color .25s;
}
.nav a::after{
  content:""; position:absolute; left:0; bottom:0; height:2px; width:0;
  background:var(--grad); border-radius:2px; transition:width .3s var(--ease);
}
.nav a:hover{ color:var(--navy); }
.nav a:hover::after{ width:100%; }
.header-cta{ display:flex; align-items:center; gap:1rem; }

.menu-toggle{ display:none; background:none; border:none; padding:8px; color:var(--navy); }
.menu-toggle svg{ width:26px;height:26px; }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:60; background:var(--navy);
  display:flex; flex-direction:column; padding:28px var(--gutter);
  transform:translateY(-100%); transition:transform .5s var(--ease);
  visibility:hidden;
}
.drawer.open{ transform:translateY(0); visibility:visible; }
.drawer-top{ display:flex; align-items:center; justify-content:space-between; }
.drawer-top img{ height:40px; }
.drawer-top .close{ background:none;border:none;color:#fff;padding:8px; }
.drawer-top .close svg{ width:28px;height:28px; }
.drawer nav{ display:flex; flex-direction:column; gap:.2rem; margin-top:8vh; }
.drawer nav a{ color:#fff; font-family:var(--font-display); font-size:2rem; font-weight:600; padding:.5rem 0; border-bottom:1px solid rgba(255,255,255,.12); }
.drawer .btn{ margin-top:auto; }

/* ============================ HERO ============================ */
.hero{ position:relative; padding-top:148px; padding-bottom:var(--section); overflow:hidden; }
.hero::before{
  content:""; position:absolute; z-index:-1;
  width:60vw; height:60vw; max-width:780px; max-height:780px;
  right:-12vw; top:-14vw; border-radius:50%;
  background:var(--grad-soft); filter:blur(10px);
}
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,76px); align-items:center; }
.hero-copy .eyebrow{ margin-bottom:1.5rem; }
.hero h1{ margin-bottom:1.4rem; }
.hero h1 em{ font-style:normal; }
.hero-copy .lead{ max-width:30ch; margin-bottom:2.2rem; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }
.hero-trust{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:2.4rem; }

.hero-visual{ position:relative; }
.hero-visual .frame{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-lg); aspect-ratio:4/5;
}
.hero-visual .frame img{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-visual image-slot{ width:100%; height:100%; }
.hero-badge{
  position:absolute; left:-26px; bottom:34px; z-index:3;
  background:#fff; border-radius:var(--radius); padding:18px 20px;
  box-shadow:var(--shadow-lg); display:flex; gap:14px; align-items:center;
  max-width:248px;
}
.hero-badge .ic{ width:44px;height:44px;border-radius:12px; background:var(--grad); display:grid; place-items:center; flex-shrink:0; color:var(--navy); }
.hero-badge .ic svg{ width:24px;height:24px; }
.hero-badge b{ color:var(--navy); font-family:var(--font-display); display:block; font-size:1.02rem; }
.hero-badge span{ font-size:.84rem; color:var(--muted); line-height:1.35; }

/* hero dark variant */
[data-hero="dark"] .hero{ background:radial-gradient(120% 120% at 80% 0%, var(--navy-700) 0%, var(--navy) 45%, var(--navy-900) 100%); }
[data-hero="dark"] .hero::before{ opacity:.5; }
[data-hero="dark"] .hero h1,[data-hero="dark"] .hero h3{ color:#fff; }
[data-hero="dark"] .hero .lead{ color:rgba(255,255,255,.78); }
[data-hero="dark"] .hero .eyebrow{ color:var(--teal); }
[data-hero="dark"] .hero .pill{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.16); color:#fff; box-shadow:none; }
[data-hero="dark"] .site-header:not(.scrolled) .nav a{ color:rgba(255,255,255,.82); }
[data-hero="dark"] .site-header:not(.scrolled) .nav a:hover{ color:#fff; }
[data-hero="dark"] .site-header:not(.scrolled) .brand .logo-color{ display:none; }
[data-hero="dark"] .site-header:not(.scrolled) .brand .logo-white{ display:block; }
[data-hero="dark"] .site-header:not(.scrolled) .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.28); }
[data-hero="dark"] .site-header:not(.scrolled) .menu-toggle{ color:#fff; }
[data-hero="dark"] .hero .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.30); }
[data-hero="dark"] .hero .btn--ghost:hover{ border-color:#fff; transform:translateY(-2px); }

/* ============================ marquee / trust band ============================ */
.band{ background:var(--navy); border-block:1px solid var(--navy-700); overflow:hidden; }
.marquee{ display:flex; width:100%; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; align-items:center; white-space:nowrap; padding-block:30px; animation:marquee 38s linear infinite; }
.marquee-track span{ font-size:.86rem; font-weight:560; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.82); padding:0 40px; }
.marquee-track i{ width:6px;height:6px;border-radius:50%; background:var(--grad); flex-shrink:0; }
.band:hover .marquee-track{ animation-play-state:paused; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){ .marquee-track{ animation:none; } }

/* ============================ section heading ============================ */
.sec-head{ max-width:680px; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head .eyebrow{ margin-bottom:1.1rem; }
.sec-head h2{ margin-bottom:1.1rem; }
.sec-head p{ color:var(--ink-soft); font-size:1.08rem; }

/* ============================ value / for clinics ============================ */
.value{ background:var(--bg); }
.value-grid{ display:grid; grid-template-columns:1fr 1.02fr; gap:clamp(36px,5vw,72px); align-items:stretch; }
.value-media{ position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); min-height:500px; }
.value-media image-slot,.value-media img{ width:100%;height:100%;object-fit:cover;display:block; }
.value ul{ list-style:none; margin:1.8rem 0 0; padding:0; display:grid; gap:1.1rem; }
.value li{ display:flex; gap:1rem; align-items:flex-start; }
.value li .check{ flex-shrink:0; width:30px;height:30px;border-radius:9px; background:var(--grad-soft); display:grid; place-items:center; color:var(--accent-deep); margin-top:2px; }
.value li .check svg{ width:17px;height:17px; }
.value li b{ color:var(--navy); font-family:var(--font-display); font-weight:600; }

/* ============================ specialties ============================ */
.spec{ background:var(--bg-soft); }
.spec-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:3.2rem; background:var(--line); border:1px solid var(--line); }
.spec-card{ background:var(--bg-soft); padding:42px 36px; position:relative; overflow:hidden; transition:background .4s var(--ease); }
.spec-card::after{ content:""; position:absolute; left:0; top:0; height:2px; width:0; background:var(--grad); transition:width .45s var(--ease); }
.spec-card:hover{ background:#fff; }
.spec-card:hover::after{ width:100%; }
.spec-card .ic{ display:flex; align-items:center; justify-content:center; width:34px; height:34px; color:var(--accent-deep); margin-bottom:18px; }
.spec-card .ic svg{ width:30px;height:30px; }
.spec-card h3{ margin-bottom:.55rem; font-size:1.3rem; letter-spacing:-.02em; }
.spec-card p{ font-size:.96rem; color:var(--muted); }

/* ============================ process ============================ */
.process{ background:var(--navy); color:#fff; position:relative; overflow:hidden; }
.process::before{
  content:""; position:absolute; inset:0; z-index:0; opacity:.5;
  background:radial-gradient(80% 90% at 90% 10%, rgba(126,205,203,.16), transparent 60%);
}
.process .wrap{ position:relative; z-index:1; }
.process h2{ color:#fff; }
.process .sec-head p{ color:rgba(255,255,255,.72); }
.steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; margin-top:3.4rem; counter-reset:step; }
.step{ position:relative; padding-top:34px; }
.step::before{
  counter-increment:step; content:"0" counter(step);
  font-family:var(--font-display); font-size:.92rem; font-weight:600;
  color:var(--navy); background:var(--grad);
  width:38px;height:38px;border-radius:50%; display:grid; place-items:center;
  position:absolute; left:0; top:-4px;
}
.step .bar{ position:absolute; left:46px; top:14px; right:-9px; height:2px; background:rgba(255,255,255,.16); }
.step:last-child .bar{ display:none; }
.step h3{ color:#fff; font-size:1.12rem; margin:14px 0 .5rem; }
.step p{ color:rgba(255,255,255,.66); font-size:.92rem; }

/* ============================ family / about ============================ */
.family-grid{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(36px,5vw,80px); align-items:center; }
.family-media{ position:relative; }
.family-media .frame{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:4/5; }
.family-media image-slot,.family-media .frame img{ width:100%;height:100%; object-fit:cover; display:block; }
.family-media .tag{
  position:absolute; right:-22px; top:36px; background:#fff; border-radius:14px;
  padding:14px 18px; box-shadow:var(--shadow-lg); font-size:.85rem; color:var(--muted); max-width:200px;
}
.family-media .tag b{ display:block; color:var(--navy); font-family:var(--font-display); font-size:1rem; }
.family blockquote{
  margin:0 0 2rem; font-family:var(--font-display); font-weight:500;
  font-size:clamp(1.4rem,2.1vw,1.95rem); line-height:1.28; color:var(--navy); letter-spacing:-.02em;
}
.family blockquote .gradient-text{ font-weight:600; }
.sign{ display:flex; align-items:center; gap:14px; }
.sign .av{ width:46px;height:46px;border-radius:50%; background:var(--grad); }
.sign b{ color:var(--navy); font-family:var(--font-display); display:block; }
.sign span{ font-size:.9rem; color:var(--muted); }

/* ============================ safety / protocols ============================ */
.safety{ background:var(--bg-soft); }
.safety-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; margin-top:3.2rem; background:var(--line); border:1px solid var(--line); counter-reset:saf; }
.safety-card{ background:var(--bg-soft); padding:42px 32px 40px; position:relative; transition:background .4s var(--ease); }
.safety-card:hover{ background:#fff; }
.safety-card .ic{ display:none; }
.safety-card::before{ counter-increment:saf; content:"0" counter(saf); font-family:var(--font-display); font-weight:700; font-size:2.5rem; line-height:1; background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; display:block; margin-bottom:18px; }
.safety-card h3{ font-size:1.12rem; margin-bottom:.45rem; }
.safety-card p{ font-size:.92rem; color:var(--muted); }

/* ============================ manifesto band ============================ */
.manifesto{ background:var(--navy-900); color:#fff; position:relative; overflow:hidden; }
.manifesto::before{ content:""; position:absolute; inset:0; background:var(--grad); opacity:.07; }
.manifesto .wrap{ position:relative; text-align:center; max-width:920px; }
.manifesto .wordmark{ width:clamp(160px,19vw,220px); margin:0 auto 30px; opacity:.96; }
.manifesto p{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.6rem,3vw,2.5rem); line-height:1.22; letter-spacing:-.02em; color:#fff; }

/* ============================ blog ============================ */
.blog-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; flex-wrap:wrap; }
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:3rem; }
.post{ display:flex; flex-direction:column; border-radius:var(--radius); overflow:hidden; background:#fff; border:1px solid var(--line); transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.post:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.post .thumb{ aspect-ratio:16/10; overflow:hidden; }
.post .thumb .ph{ width:100%;height:100%; }
.post .thumb img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s var(--ease); }
.post:hover .thumb img{ transform:scale(1.05); }
.post .body{ padding:24px 24px 28px; display:flex; flex-direction:column; flex:1; }
.post .cat{ font-size:.74rem; font-weight:680; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-deep); margin-bottom:12px; }
.post h3{ font-size:1.18rem; margin-bottom:.6rem; }
.post p{ font-size:.94rem; color:var(--muted); margin-bottom:1.2rem; }
.post .more{ margin-top:auto; }

/* ============================ CTA ============================ */
.cta{ position:relative; }
.cta-card{
  background:radial-gradient(120% 130% at 85% 10%, var(--navy-700), var(--navy) 55%, var(--navy-900));
  border-radius:var(--radius-lg); padding:clamp(40px,6vw,80px); position:relative; overflow:hidden;
  display:grid; grid-template-columns:1.2fr .8fr; gap:48px; align-items:center;
}
.cta-card::before{ content:""; position:absolute; right:-60px; top:-60px; width:320px;height:320px;border-radius:50%; background:var(--grad); opacity:.16; filter:blur(8px); }
.cta-card h2{ color:#fff; position:relative; }
.cta-card p{ color:rgba(255,255,255,.78); margin-top:1rem; position:relative; }
.cta-actions{ display:flex; flex-direction:column; gap:14px; position:relative; }
.cta-actions .btn{ justify-content:center; }
.cta-actions .note{ color:rgba(255,255,255,.55); font-size:.84rem; text-align:center; }

/* ============================ footer ============================ */
.footer{ background:var(--navy-900); color:rgba(255,255,255,.7); padding-block:72px 36px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.1fr; gap:40px; }
.footer .logo-white{ height:46px; margin-bottom:20px; }
.footer p{ font-size:.94rem; line-height:1.6; max-width:30ch; }
.footer h4{ color:#fff; font-family:var(--font-text); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; font-weight:680; margin:0 0 18px; }
.footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.footer ul a{ font-size:.95rem; transition:color .25s; }
.footer ul a:hover{ color:var(--teal); }
.footer .contact-line{ display:flex; gap:.7rem; align-items:flex-start; font-size:.94rem; margin-bottom:14px; }
.footer .contact-line svg{ width:18px;height:18px;color:var(--teal);flex-shrink:0;margin-top:3px; }
.footer-base{ border-top:1px solid rgba(255,255,255,.12); margin-top:54px; padding-top:26px; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; font-size:.85rem; color:rgba(255,255,255,.5); }
.footer-base .socials{ display:flex; gap:12px; }
.footer-base .socials a{ width:38px;height:38px;border-radius:50%; border:1px solid rgba(255,255,255,.16); display:grid;place-items:center; transition:.25s; }
.footer-base .socials a:hover{ background:var(--grad); color:var(--navy); border-color:transparent; }
.footer-base .socials svg{ width:18px;height:18px; }

/* ============================ image placeholders ============================ */
.ph{
  background:
    repeating-linear-gradient(135deg, rgba(20,51,75,.05) 0 12px, rgba(20,51,75,.02) 12px 24px),
    var(--bg-tint);
  display:grid; place-items:center; color:var(--muted);
}
.ph .ph-label{ font-family:"Hanken Grotesk",monospace; font-size:.78rem; letter-spacing:.04em; padding:6px 12px; background:rgba(255,255,255,.7); border-radius:8px; }

/* ============================ reveal animation ============================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }
.no-anim .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
.ph-thumb{ width:100%; height:100%; }

/* ============================ responsive ============================ */
@media (max-width:1080px){
  .spec-grid{ grid-template-columns:repeat(2,1fr); }
  .safety-grid{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); gap:28px; }
  .step .bar{ display:none; }
  .blog-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:900px){
  .nav,.header-cta .btn{ display:none; }
  .menu-toggle{ display:inline-flex; margin-left:auto; }
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ max-width:460px; }
  .value-grid,.family-grid{ grid-template-columns:1fr; }
  .value-media,.family-media{ order:-1; max-width:520px; }
  .cta-card{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:620px){
  .spec-grid,.safety-grid,.blog-grid,.steps{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-badge{ left:0; }
  .band .wrap{ grid-template-columns:repeat(2,1fr); }
  .band .item{ padding:30px 12px; }
  .band .item::after{ display:none; }
}
