/* ============================================================
   NORTHLINE DETAIL — Dark-cinematic showroom-at-night
   Specular product photography WITHOUT photos.
   Display: Space Grotesk (tight, large) · Body: Inter
   Palette: --ink #0A0A0C · --panel #15171C · --chrome #C8CDD4
            --reflect #3E7BFA (electric reflection-blue — HOVER ONLY)
   The whole site is monochrome until you interact, then it
   "lights up" like clear-coat. Signature motion = slow specular sheen.
   ============================================================ */

:root{
  --ink:#0A0A0C;
  --panel:#15171C;
  --chrome:#C8CDD4;
  --reflect:#3E7BFA;

  --ink-2:#101116;
  --panel-2:#1C1F26;
  --panel-3:#24272F;
  --steel:#8C919B;          /* muted body text */
  --steel-dim:#767C87;      /* captions / dim labels — AA 4.7:1 on --ink */
  --line:rgba(200,205,212,.10);   /* hairline on ink */
  --line-strong:rgba(200,205,212,.22);
  --chrome-dim:rgba(200,205,212,.55);
  --reflect-soft:rgba(62,123,250,.14);
  --reflect-glow:rgba(62,123,250,.45);

  --ff:'Inter',system-ui,-apple-system,sans-serif;
  --fd:'Space Grotesk',system-ui,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-spec:cubic-bezier(.4,0,.2,1);
  --gutter:24px;
  --maxw:1280px;
  --hdr-h:80px;

  /* the moving specular highlight gradient reused across panels */
  --sheen:linear-gradient(105deg,
      transparent 0%, transparent 38%,
      rgba(200,205,212,.05) 46%,
      rgba(255,255,255,.42) 50%,
      rgba(200,205,212,.05) 54%,
      transparent 62%, transparent 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{
  margin:0;
  background:var(--ink);
  color:var(--chrome);
  font-family:var(--ff);
  font-size:17px;
  line-height:1.65;
  letter-spacing:-.003em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{margin:0;font-family:var(--fd);font-weight:600;letter-spacing:-.03em;line-height:1.0;overflow-wrap:break-word;hyphens:none;-webkit-hyphens:none}
/* large display headings never split a word mid-stroke */
.wordmark .wm-line,.sec-title,.cta h2,.lead-page h1,.rev-summary .big,.hero .wm-line{overflow-wrap:normal;word-break:normal}
p{margin:0}
img,svg{display:block;max-width:100%}
::selection{background:var(--reflect);color:#fff}

/* tabular figures for all stats / prices */
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* visually hidden, still announced by screen readers */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;border:0}

a:focus-visible,button:focus-visible,summary:focus-visible,
input:focus-visible,textarea:focus-visible,select:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--reflect);
  outline-offset:3px;
}

/* ---------- Layout shell ---------- */
.shell{width:min(var(--maxw),calc(100% - (var(--gutter)*2)));margin-inline:auto}
.grid{display:grid;gap:24px}
.grid>*{min-width:0}

/* skip link */
.skip{
  position:absolute;left:14px;top:-60px;z-index:200;
  background:var(--chrome);color:var(--ink);
  padding:10px 16px;border-radius:2px;font-weight:600;
  transition:top .2s var(--ease);
}
.skip:focus{top:14px}

/* ---------- Spec label system (the gauge voice) ---------- */
.kicker{
  display:inline-flex;align-items:center;gap:11px;
  font-family:var(--fd);font-weight:500;text-transform:uppercase;
  letter-spacing:.32em;font-size:11px;color:var(--steel);
}
.kicker::before{content:"";width:26px;height:1px;background:var(--line-strong);transition:background .4s var(--ease),width .4s var(--ease)}
.kicker:hover::before,section:hover .kicker::before{background:var(--reflect);width:34px}
.kicker .dot{width:5px;height:5px;flex:none;border-radius:50%;background:var(--steel-dim);transition:background .4s var(--ease)}
section:hover .kicker .dot{background:var(--reflect)}

.tag{
  font-family:var(--fd);font-weight:500;text-transform:uppercase;
  letter-spacing:.22em;font-size:10.5px;color:var(--steel-dim);
}
.sec-no{
  font-family:var(--fd);font-weight:600;letter-spacing:.06em;font-size:12px;
  color:var(--steel-dim);font-variant-numeric:tabular-nums;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  min-height:54px;padding:0 30px;position:relative;overflow:hidden;
  font-family:var(--fd);font-weight:500;text-transform:uppercase;
  letter-spacing:.16em;font-size:12px;
  border:1px solid var(--line-strong);
  background:transparent;color:var(--chrome);
  cursor:pointer;border-radius:2px;
  transition:border-color .3s var(--ease),color .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease);
}
/* chrome sheen wipe across the button on hover */
.btn::after{
  content:"";position:absolute;inset:0;background:var(--sheen);
  background-size:280% 100%;background-position:140% 0;
  opacity:0;transition:opacity .2s var(--ease),background-position .7s var(--ease-spec);
  pointer-events:none;mix-blend-mode:screen;
}
.btn:hover::after{opacity:1;background-position:-40% 0}
.btn:hover{border-color:var(--reflect);color:#fff;box-shadow:0 0 0 1px var(--reflect-soft),0 8px 34px -14px var(--reflect-glow)}
.btn:active{transform:translateY(1px)}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}

.btn-solid{background:var(--chrome);color:var(--ink);border-color:var(--chrome)}
.btn-solid:hover{background:var(--reflect);border-color:var(--reflect);color:#fff}
.btn-solid::after{mix-blend-mode:overlay}

.btn-sm{min-height:44px;padding:0 20px;font-size:11px;letter-spacing:.14em}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}
.d4{transition-delay:.28s}.d5{transition-delay:.35s}.d6{transition-delay:.42s}

/* =========================================================
   HEADER — sticky condensing
   ========================================================= */
.site-head{
  position:sticky;top:0;z-index:90;
  height:var(--hdr-h);
  display:flex;align-items:center;
  background:rgba(10,10,12,.62);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line);
  transition:height .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease);
}
.site-head.shrink{height:62px;background:rgba(10,10,12,.86)}
.head-row{display:flex;align-items:center;justify-content:space-between;width:100%}

.brand{display:inline-flex;align-items:center;gap:12px;font-family:var(--fd);font-weight:600;letter-spacing:-.01em}
.brand .mark{
  width:30px;height:30px;flex:none;border-radius:3px;position:relative;overflow:hidden;
  background:linear-gradient(150deg,#2A2D35,#0E0F13);
  border:1px solid var(--line-strong);
}
/* the chrome chevron "N" notch */
.brand .mark::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(115deg,transparent 44%,rgba(200,205,212,.85) 48%,transparent 52%),
    linear-gradient(115deg,transparent 60%,rgba(200,205,212,.4) 63%,transparent 66%);
}
.brand:hover .mark{border-color:var(--reflect)}
.brand:hover .mark::before{background:
    linear-gradient(115deg,transparent 44%,var(--reflect) 48%,transparent 52%),
    linear-gradient(115deg,transparent 60%,rgba(62,123,250,.55) 63%,transparent 66%)}
.brand-name{font-size:17px;line-height:1}
.brand-name b{font-weight:600}
.brand-name span{color:var(--steel-dim);font-weight:500}

.nav-main{display:flex;align-items:center;gap:6px}
.nav-main a{
  font-family:var(--fd);font-size:13px;font-weight:500;letter-spacing:.02em;
  color:var(--chrome-dim);padding:9px 14px;border-radius:2px;position:relative;
  transition:color .25s var(--ease);
}
.nav-main a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:1px;
  background:var(--reflect);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-main a:hover,.nav-main a[aria-current="page"]{color:#fff}
.nav-main a:hover::after,.nav-main a[aria-current="page"]::after{transform:scaleX(1)}
.head-cta{display:flex;align-items:center;gap:14px}

/* burger */
.burger{
  display:none;width:46px;height:46px;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--line-strong);border-radius:3px;cursor:pointer;
}
.burger span{display:block;width:20px;height:1.5px;background:var(--chrome);position:relative;transition:transform .3s var(--ease),opacity .3s var(--ease)}
.burger span+span{margin-top:5px}
.burger[aria-expanded="true"]{border-color:var(--reflect)}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile nav */
.mobile-nav{
  position:fixed;inset:var(--hdr-h) 0 0 0;z-index:80;
  background:rgba(10,10,12,.97);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  padding:34px var(--gutter) 40px;
  transform:translateY(-12px);opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  overflow-y:auto;
}
.mobile-nav.open{opacity:1;transform:none;pointer-events:auto}
.mobile-nav a{
  display:flex;align-items:center;gap:16px;
  font-family:var(--fd);font-size:30px;font-weight:600;letter-spacing:-.02em;
  color:var(--chrome);padding:16px 0;border-bottom:1px solid var(--line);
}
/* spec-readout gauge tick instead of a numbered index — Northline's own idiom */
.mobile-nav a .mn{
  width:24px;height:1px;flex:none;align-self:center;background:var(--line-strong);
  position:relative;transition:background .3s var(--ease),width .3s var(--ease);
}
.mobile-nav a[aria-current="page"] .mn,.mobile-nav a:active .mn{background:var(--reflect);width:32px}
.mobile-nav a:active{color:var(--reflect)}
.mobile-nav .m-foot{margin-top:30px;color:var(--steel);font-size:14px;line-height:1.7}
.mobile-nav .m-foot b{color:var(--chrome);font-weight:600}
body.menu-lock{overflow:hidden}

/* =========================================================
   HERO (index) — centered focal gloss object,
   wordmark NORTHLINE split above/below
   ========================================================= */
.hero{position:relative;overflow:hidden;padding:clamp(40px,7vw,86px) 0 clamp(48px,7vw,96px)}
/* ambient vertical gradient floor + faint grid lines */
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 18%,rgba(200,205,212,.06),transparent 60%),
    radial-gradient(80% 60% at 50% 120%,rgba(62,123,250,.05),transparent 70%),
    linear-gradient(180deg,#0C0D11 0%,#0A0A0C 60%);
}
.hero-inner{position:relative;z-index:2}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:clamp(8px,2vw,18px)}
.hero-top .since{font-family:var(--fd);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-dim)}

/* the split wordmark */
.wordmark{position:relative;text-align:center;isolation:isolate}
.wordmark .wm-line{
  font-family:var(--fd);font-weight:600;line-height:.82;
  font-size:clamp(58px,19vw,250px);letter-spacing:-.04em;
  color:transparent;
  background:linear-gradient(180deg,#EDEFF2 0%,#B7BCC4 38%,#5A5F69 72%,#34373E 100%);
  -webkit-background-clip:text;background-clip:text;
  position:relative;z-index:3;
  overflow-wrap:normal;word-break:keep-all;
}
.wordmark .wm-top{z-index:4}
.wordmark .wm-bot{z-index:2;margin-top:clamp(-22px,-3.6vw,-50px)}

/* the focal gloss object — sits between NORTH and LINE, pierced by both */
.gloss{
  position:relative;z-index:3;
  width:min(560px,84vw);height:clamp(150px,30vw,300px);
  margin:clamp(-34px,-6vw,-82px) auto;
  border-radius:14px;overflow:hidden;
  background:
    radial-gradient(120% 150% at 28% 8%,rgba(255,255,255,.22),transparent 42%),
    radial-gradient(90% 120% at 80% 100%,rgba(62,123,250,.16),transparent 55%),
    linear-gradient(155deg,#2B2E37 0%,#191B21 40%,#0D0E12 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    inset 0 -30px 60px -30px rgba(0,0,0,.8),
    0 40px 90px -40px rgba(0,0,0,.9);
  border:1px solid rgba(200,205,212,.16);
}
/* the moving sheen band — slow specular sweep, blend screen */
.gloss::before{
  content:"";position:absolute;inset:-30% -10%;
  background:
    conic-gradient(from 210deg at 50% 50%,
      transparent 0deg, rgba(200,205,212,.0) 60deg,
      rgba(220,225,232,.5) 120deg, rgba(255,255,255,.85) 150deg,
      rgba(220,225,232,.5) 180deg, transparent 240deg, transparent 360deg);
  mix-blend-mode:screen;
  filter:blur(6px);
  animation:sheen-rotate 9s linear infinite;
  opacity:.6;
}
/* a single static crisp diagonal highlight (no travel) — lets the slow
   conic rotate be the ONE moving specular signature on the focal object */
.gloss::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,
    transparent 34%, rgba(255,255,255,.0) 44%,
    rgba(255,255,255,.4) 50%,
    rgba(255,255,255,.0) 56%, transparent 66%);
  background-size:280% 100%;background-position:42% 0;
  mix-blend-mode:screen;
}
@keyframes sheen-rotate{to{transform:rotate(360deg)}}
@keyframes sheen-travel{
  0%{background-position:160% 0}
  55%{background-position:-60% 0}
  100%{background-position:-60% 0}
}
/* second-read: faint engraved gauge ticks inside the panel */
.gloss .gloss-svg{position:absolute;inset:0;z-index:2;opacity:.5}

.hero-sub{
  max-width:560px;margin:clamp(20px,4vw,42px) auto 0;text-align:center;
  color:var(--steel);font-size:clamp(15px,1.6vw,18px);line-height:1.6;
}
.hero-sub b{color:var(--chrome);font-weight:500}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:clamp(22px,3.4vw,34px)}

/* hero readout strip */
.hero-readout{
  margin-top:clamp(40px,6vw,74px);
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.hero-readout .ro{padding:24px 20px;border-left:1px solid var(--line)}
.hero-readout .ro:first-child{border-left:0;padding-left:0}
.ro .ro-n{font-family:var(--fd);font-weight:600;font-size:clamp(34px,4.4vw,52px);line-height:1;color:var(--chrome)}
.ro .ro-l{margin-top:14px;font-size:12.5px;color:var(--steel-dim);letter-spacing:.02em}
.ro:hover .ro-n{color:#fff}
.ro:hover .ro-n .u{color:var(--reflect)}

/* =========================================================
   SECTION scaffold
   ========================================================= */
section{position:relative}
.band{padding:clamp(64px,9vw,120px) 0}
.band-panel{background:linear-gradient(180deg,var(--ink-2),#0B0C0F);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;flex-wrap:wrap;margin-bottom:clamp(34px,5vw,60px)}
.sec-head .sh-l{max-width:680px}
.sec-title{
  font-size:clamp(30px,5vw,62px);line-height:1.0;letter-spacing:-.03em;margin-top:18px;
  color:var(--chrome);
}
.sec-title em{font-style:normal;color:var(--steel-dim)}
.sec-lead{margin-top:20px;color:var(--steel);font-size:clamp(15px,1.7vw,18.5px);line-height:1.65;max-width:560px}

/* =========================================================
   FEATURE / CAPABILITY cards
   ========================================================= */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cap{
  position:relative;overflow:hidden;border-radius:8px;padding:30px 26px 34px;
  background:linear-gradient(170deg,var(--panel),var(--ink-2));
  border:1px solid var(--line);
  transition:border-color .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease);
}
.cap::before{
  content:"";position:absolute;inset:0;background:var(--sheen);
  background-size:280% 100%;background-position:150% 0;opacity:0;
  mix-blend-mode:screen;pointer-events:none;
  transition:opacity .25s var(--ease),background-position .8s var(--ease-spec);
}
.cap:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 30px 60px -36px rgba(0,0,0,.9)}
.cap:hover::before{opacity:1;background-position:-40% 0}
.cap .cap-ix{font-family:var(--fd);font-size:12px;color:var(--steel-dim);letter-spacing:.06em;font-variant-numeric:tabular-nums}
.cap .cap-ico{width:46px;height:46px;margin:22px 0 18px;color:var(--steel)}
.cap:hover .cap-ico{color:var(--reflect)}
.cap h3{font-size:21px;color:var(--chrome);letter-spacing:-.02em}
.cap p{margin-top:12px;color:var(--steel);font-size:15px;line-height:1.6}
.cap .cap-meta{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-family:var(--fd);font-size:12px;color:var(--steel-dim);letter-spacing:.04em;display:flex;justify-content:space-between}
.cap:hover .cap-meta .v{color:var(--reflect)}

/* =========================================================
   BEFORE / AFTER slider
   ========================================================= */
.ba-wrap{position:relative}
.ba{
  position:relative;width:100%;aspect-ratio:16/9;border-radius:10px;overflow:hidden;
  border:1px solid var(--line-strong);user-select:none;
  box-shadow:0 50px 100px -50px rgba(0,0,0,.95);
}
.ba-layer{position:absolute;inset:0}
/* "before" — dull, oxidized, hazy */
.ba-before{
  background:
    radial-gradient(120% 90% at 30% 0%,rgba(120,124,132,.18),transparent 55%),
    linear-gradient(160deg,#3A3C42 0%,#27282D 45%,#191A1E 100%);
  filter:saturate(.5);
}
.ba-before::after{
  content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;
  background:repeating-linear-gradient(125deg,rgba(255,255,255,.05) 0 2px,transparent 2px 7px);
}
/* "after" — deep wet gloss, blue clearcoat reflection */
.ba-after{
  clip-path:inset(0 0 0 50%);
  background:
    radial-gradient(120% 150% at 24% 6%,rgba(255,255,255,.3),transparent 40%),
    radial-gradient(90% 120% at 82% 104%,rgba(62,123,250,.32),transparent 52%),
    linear-gradient(155deg,#23262F 0%,#14161B 45%,#080A0D 100%);
}
.ba-after::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(102deg,transparent 40%,rgba(255,255,255,.5) 50%,transparent 60%);
  background-size:240% 100%;background-position:120% 0;mix-blend-mode:screen;
  animation:sheen-travel 6s var(--ease-spec) infinite;
}
.ba-label{
  position:absolute;bottom:16px;z-index:4;
  font-family:var(--fd);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--chrome);background:rgba(10,10,12,.55);padding:7px 12px;border-radius:2px;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid var(--line);
}
.ba-label.l-before{left:16px}
.ba-label.l-after{right:16px;color:var(--reflect);border-color:var(--reflect-soft)}
/* divider handle */
.ba-divider{
  position:absolute;top:0;bottom:0;left:50%;width:2px;z-index:5;
  background:linear-gradient(180deg,transparent,var(--chrome),transparent);
  transform:translateX(-50%);pointer-events:none;
}
.ba-handle{
  position:absolute;top:50%;left:50%;z-index:6;
  width:48px;height:48px;transform:translate(-50%,-50%);
  border-radius:50%;background:rgba(10,10,12,.7);border:1px solid var(--chrome);
  display:flex;align-items:center;justify-content:center;color:var(--chrome);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);pointer-events:none;
  transition:border-color .3s var(--ease),color .3s var(--ease),box-shadow .3s var(--ease);
}
.ba:hover .ba-handle,.ba-range:focus-visible+.ba-divider .ba-handle{border-color:var(--reflect);color:var(--reflect);box-shadow:0 0 0 4px var(--reflect-soft)}
.ba-range{
  position:absolute;inset:0;z-index:7;width:100%;height:100%;
  margin:0;opacity:0;cursor:ew-resize;
}
.ba-hint{margin-top:16px;text-align:center;font-family:var(--fd);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-dim)}

/* =========================================================
   PROCESS / steps
   ========================================================= */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.step{background:var(--ink-2);padding:30px 24px 34px;transition:background .4s var(--ease)}
.step:hover{background:var(--panel)}
.step .st-no{font-family:var(--fd);font-weight:600;font-size:13px;color:var(--steel-dim);letter-spacing:.08em}
.step:hover .st-no{color:var(--reflect)}
.step h3{margin-top:30px;font-size:19px;color:var(--chrome)}
.step p{margin-top:12px;color:var(--steel);font-size:14.5px;line-height:1.6}
.step .st-bar{margin-top:22px;height:2px;background:var(--line);position:relative;overflow:hidden}
.step .st-bar i{position:absolute;inset:0;background:var(--reflect);transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.step:hover .st-bar i{transform:scaleX(1)}

/* =========================================================
   PACKAGES — configurator / comparison
   ========================================================= */
.config-bar{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:10px;border:1px solid var(--line);border-radius:100px;
  background:var(--ink-2);margin-bottom:36px;width:fit-content;max-width:100%;
}
.config-bar .cfg-lbl{font-family:var(--fd);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-dim);padding:0 10px 0 14px}
.seg{display:inline-flex;border-radius:100px;overflow:hidden}
.seg button{
  font-family:var(--fd);font-size:12px;font-weight:500;letter-spacing:.04em;
  padding:11px 18px;background:transparent;color:var(--chrome-dim);border:0;cursor:pointer;
  transition:color .25s var(--ease),background .25s var(--ease);
}
.seg button[aria-pressed="true"]{background:var(--reflect);color:#fff}
.seg button:not([aria-pressed="true"]):hover{color:#fff;background:var(--panel-2)}

.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:start}
.pkg{
  position:relative;border:1px solid var(--line);border-radius:10px;overflow:hidden;
  background:linear-gradient(180deg,var(--panel),var(--ink-2));
  transition:border-color .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease),opacity .35s var(--ease);
  display:flex;flex-direction:column;
}
.pkg.is-dim{opacity:.34;filter:saturate(.4)}
.pkg.is-feature{border-color:var(--line-strong)}
.pkg-top{padding:28px 26px 24px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.pkg-top::before{content:"";position:absolute;inset:0;background:var(--sheen);background-size:280% 100%;background-position:150% 0;opacity:0;mix-blend-mode:screen;transition:opacity .25s,background-position .9s var(--ease-spec)}
.pkg:hover{transform:translateY(-5px);border-color:var(--reflect);box-shadow:0 40px 80px -44px rgba(0,0,0,.95),0 0 0 1px var(--reflect-soft)}
.pkg:hover .pkg-top::before{opacity:1;background-position:-40% 0}
.pkg .pk-tier{font-family:var(--fd);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--steel-dim)}
.pkg.is-feature .pk-tier{color:var(--reflect)}
.pkg h3{margin-top:16px;font-size:25px;color:var(--chrome);letter-spacing:-.02em}
.pkg .pk-desc{margin-top:10px;color:var(--steel);font-size:14px;line-height:1.55;min-height:44px}
.pkg .pk-price{margin-top:22px;display:flex;align-items:baseline;gap:6px;font-family:var(--fd)}
.pk-price .pk-cur{font-size:18px;color:var(--steel)}
.pk-price .pk-amt{font-size:42px;font-weight:600;color:var(--chrome);line-height:1}
.pkg:hover .pk-amt{color:#fff}
.pk-price .pk-unit{font-size:12px;color:var(--steel-dim);letter-spacing:.04em}
.pkg .pk-feats{list-style:none;margin:0;padding:24px 26px;display:grid;gap:13px;flex:1}
.pkg .pk-feats li{display:flex;gap:12px;align-items:flex-start;font-size:14.5px;color:var(--steel)}
.pkg .pk-feats li svg{width:16px;height:16px;flex:none;margin-top:3px;color:var(--steel-dim)}
.pkg:hover .pk-feats li svg{color:var(--reflect)}
.pkg .pk-feats li.off{color:var(--steel-dim);opacity:.55}
.pkg .pk-feats li.off svg{color:var(--steel-dim)}
.pkg .pk-foot{padding:0 26px 28px}
.pkg .pk-foot .btn{width:100%}
.pk-flag{position:absolute;top:18px;right:18px;z-index:3;font-family:var(--fd);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--reflect);border:1px solid var(--reflect-soft);background:var(--reflect-soft);padding:5px 10px;border-radius:100px}

/* comparison table */
.cmp{width:100%;border-collapse:collapse;margin-top:8px;font-size:14.5px}
.cmp caption{text-align:left;font-family:var(--fd);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-dim);padding-bottom:18px}
.cmp th,.cmp td{padding:16px 14px;border-bottom:1px solid var(--line);text-align:left}
.cmp thead th{font-family:var(--fd);font-weight:600;color:var(--chrome);font-size:14px;letter-spacing:-.01em;vertical-align:bottom}
.cmp thead th .th-sub{display:block;font-family:var(--ff);font-weight:400;font-size:12px;color:var(--steel-dim);letter-spacing:0;margin-top:4px}
.cmp tbody th{font-weight:500;color:var(--steel);font-family:var(--ff)}
.cmp td{text-align:center;color:var(--steel-dim)}
.cmp td.yes{color:var(--chrome)}
.cmp tbody tr:hover td.yes,.cmp tbody tr:hover{background:rgba(62,123,250,.04)}
.cmp tbody tr:hover td.yes svg{color:var(--reflect)}
.cmp td svg{width:16px;height:16px;color:var(--steel-dim)}
.cmp td.yes svg{color:var(--chrome)}
.cmp .row-price td{color:var(--chrome);font-family:var(--fd);font-weight:600;font-variant-numeric:tabular-nums}
/* horizontal-scroll affordance (only surfaces when the table overflows) */
.cmp-scroll{position:relative}
.cmp-hint{display:none;margin:0 0 14px;font-family:var(--fd);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-dim)}

/* =========================================================
   GALLERY — art-directed CSS cards + lightbox
   ========================================================= */
.gal-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.gal-card{
  position:relative;border-radius:10px;overflow:hidden;cursor:pointer;
  border:1px solid var(--line);min-height:0;
  background:var(--ink-2);
  transition:border-color .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease);
  text-align:left;padding:0;font:inherit;color:inherit;width:100%;display:block;
}
.gal-card:hover{transform:translateY(-4px);border-color:var(--reflect);box-shadow:0 36px 70px -42px rgba(0,0,0,.95)}
.gal-art{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden}
.gal-art svg{position:absolute;inset:0;width:100%;height:100%}
.gal-card.span6{grid-column:span 6}
.gal-card.span4{grid-column:span 4}
.gal-card.span8{grid-column:span 8}
.gal-card.tall .gal-art{aspect-ratio:3/4}
/* sheen on hover only */
.gal-art::after{
  content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.5) 50%,transparent 60%);
  background-size:260% 100%;background-position:140% 0;opacity:0;mix-blend-mode:screen;
  transition:opacity .2s,background-position .9s var(--ease-spec);
}
.gal-card:hover .gal-art::after{opacity:1;background-position:-40% 0}
.gal-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-top:1px solid var(--line)}
.gal-meta .gm-t{font-family:var(--fd);font-size:14.5px;font-weight:500;color:var(--chrome)}
.gal-meta .gm-s{font-size:12px;color:var(--steel-dim);letter-spacing:.02em}
.gal-card:hover .gm-s{color:var(--reflect)}
.gal-plus{width:30px;height:30px;flex:none;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--steel)}
.gal-card:hover .gal-plus{border-color:var(--reflect);color:var(--reflect)}

/* lightbox */
.lightbox{
  position:fixed;inset:0;z-index:150;display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(6,6,8,.86);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease);
}
.lightbox.open{opacity:1;pointer-events:auto}
.lb-dialog{
  width:min(900px,100%);background:linear-gradient(180deg,var(--panel),var(--ink-2));
  border:1px solid var(--line-strong);border-radius:12px;overflow:hidden;
  transform:scale(.97);transition:transform .3s var(--ease);box-shadow:0 60px 120px -50px #000;
}
.lightbox.open .lb-dialog{transform:none}
.lb-art{position:relative;width:100%;aspect-ratio:16/9}
.lb-art svg{position:absolute;inset:0;width:100%;height:100%}
.lb-foot{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:22px 26px 24px;border-top:1px solid var(--line);flex-wrap:wrap}
.lb-foot h3{font-size:23px;color:var(--chrome)}
.lb-foot .lb-s{margin-top:8px;color:var(--steel);font-size:14.5px;max-width:480px}
.lb-foot .lb-tag{font-family:var(--fd);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--reflect);border:1px solid var(--reflect-soft);padding:6px 12px;border-radius:100px;white-space:nowrap}
.lb-close{
  position:absolute;top:16px;right:16px;z-index:5;width:42px;height:42px;border-radius:50%;
  background:rgba(10,10,12,.6);border:1px solid var(--line-strong);color:var(--chrome);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:border-color .25s,color .25s;
}
.lb-close:hover{border-color:var(--reflect);color:var(--reflect)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:46px;height:46px;border-radius:50%;background:rgba(10,10,12,.6);border:1px solid var(--line-strong);color:var(--chrome);cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:border-color .25s,color .25s}
.lb-nav:hover{border-color:var(--reflect);color:var(--reflect)}
.lb-prev{left:16px}.lb-next{right:16px}

/* =========================================================
   REVIEWS / testimonials
   ========================================================= */
.tcar{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,var(--panel),var(--ink-2))}
.tcar-view{overflow:hidden}
.rail{display:flex;transition:transform .6s var(--ease)}
.slide{flex:0 0 100%;padding:clamp(34px,5vw,64px)}
.slide .q{font-family:var(--fd);font-size:clamp(22px,3vw,38px);line-height:1.28;letter-spacing:-.02em;color:var(--chrome);font-weight:500}
.slide .q em{font-style:normal;color:var(--reflect)}
.slide .who{margin-top:28px;display:flex;align-items:center;gap:14px}
.slide .who .av{width:44px;height:44px;flex:none;border-radius:50%;background:linear-gradient(150deg,#2A2D35,#0E0F13);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:600;color:var(--chrome);font-size:15px}
.slide .who .nm{font-family:var(--fd);font-weight:600;color:var(--chrome);font-size:15px}
.slide .who .meta{font-size:12.5px;color:var(--steel-dim)}
.slide .stars{margin-top:18px;display:flex;gap:3px;color:var(--reflect)}
.slide .stars svg{width:15px;height:15px}
.tcar-ctrl{display:flex;align-items:center;justify-content:space-between;padding:16px clamp(34px,5vw,64px) 24px}
.tcar-dots{display:flex;gap:8px}
.tcar-dots button{width:8px;height:8px;border-radius:50%;border:1px solid var(--line-strong);background:transparent;padding:0;cursor:pointer;transition:background .25s,border-color .25s}
.tcar-dots button[aria-current="true"]{background:var(--reflect);border-color:var(--reflect)}
.tcar-arrows{display:flex;gap:8px}
.tcar-arrows button{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-strong);background:transparent;color:var(--chrome);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .25s,color .25s}
.tcar-arrows button:hover{border-color:var(--reflect);color:var(--reflect)}

/* static review grid (reviews.html) */
.rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.rev-card{border:1px solid var(--line);border-radius:10px;padding:30px 28px;background:linear-gradient(180deg,var(--panel),var(--ink-2));transition:border-color .4s var(--ease),transform .4s var(--ease)}
.rev-card:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.rev-card .stars{display:flex;gap:3px;color:var(--steel-dim)}
.rev-card:hover .stars{color:var(--reflect)}
.rev-card .stars svg{width:15px;height:15px}
.rev-card blockquote{margin:18px 0 0;font-size:16.5px;line-height:1.62;color:var(--chrome)}
.rev-card .who{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);display:flex;align-items:center;gap:12px}
.rev-card .who .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(150deg,#2A2D35,#0E0F13);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:600;color:var(--chrome);font-size:14px}
.rev-card .who .nm{font-family:var(--fd);font-weight:600;color:var(--chrome);font-size:14.5px}
.rev-card .who .meta{font-size:12px;color:var(--steel-dim)}
.rev-summary{display:flex;align-items:center;gap:clamp(20px,4vw,52px);flex-wrap:wrap;padding:clamp(28px,4vw,40px);border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,var(--panel),var(--ink-2));margin-bottom:40px}
.rev-summary .big{font-family:var(--fd);font-weight:600;font-size:clamp(54px,8vw,84px);line-height:1;color:var(--chrome)}
.rev-summary .big .u{color:var(--reflect)}
.rev-summary .rs-stars{display:flex;gap:4px;color:var(--reflect)}
.rev-summary .rs-stars svg{width:20px;height:20px}
.rev-summary .rs-l{font-size:14px;color:var(--steel);margin-top:8px}
.rev-summary .rs-div{width:1px;align-self:stretch;background:var(--line)}

/* =========================================================
   CONTACT / booking
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:start}
.info-block{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:linear-gradient(180deg,var(--panel),var(--ink-2))}
.info-row{padding:24px 26px;border-bottom:1px solid var(--line);display:flex;gap:16px;align-items:flex-start}
.info-row:last-child{border-bottom:0}
.info-row .ir-ico{width:22px;height:22px;flex:none;margin-top:2px;color:var(--steel)}
.info-row:hover .ir-ico{color:var(--reflect)}
.info-row .ir-l{font-family:var(--fd);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-dim)}
.info-row .ir-v{margin-top:6px;font-size:16px;color:var(--chrome);line-height:1.5}
.info-row .ir-v a:hover{color:var(--reflect)}
.map-frame{position:relative;margin:18px 0 0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--ink-2)}
.map-frame .map-svg{display:block;width:100%;height:240px}
.map-frame:hover{border-color:var(--line-strong)}
.map-cap{
  position:absolute;left:16px;right:16px;bottom:16px;z-index:2;
  display:flex;flex-direction:column;gap:4px;
  padding:14px 16px;border-radius:8px;
  background:rgba(10,10,12,.62);border:1px solid var(--line);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.map-cap .map-k{font-family:var(--fd);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-dim)}
.map-cap .map-v{font-size:14.5px;color:var(--chrome);line-height:1.45}
.map-cap .map-link{margin-top:4px;display:inline-flex;align-items:center;gap:7px;font-family:var(--fd);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--steel)}
.map-cap .map-link span{transition:transform .3s var(--ease)}
.map-cap .map-link:hover{color:var(--reflect)}
.map-cap .map-link:hover span{transform:translateX(4px)}

.form-card{border:1px solid var(--line);border-radius:12px;padding:clamp(26px,3.4vw,40px);background:linear-gradient(180deg,var(--panel),var(--ink-2))}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--fd);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-dim);margin-bottom:9px}
.field label .req{color:var(--reflect)}
.field input,.field select,.field textarea{
  width:100%;background:var(--ink);border:1px solid var(--line-strong);border-radius:6px;
  color:var(--chrome);font-family:inherit;font-size:15.5px;padding:14px 16px;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.field textarea{resize:vertical;min-height:110px}
.field input::placeholder,.field textarea::placeholder{color:var(--steel-dim)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--reflect);box-shadow:0 0 0 3px var(--reflect-soft)}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--steel) 50%),linear-gradient(135deg,var(--steel) 50%,transparent 50%);background-position:calc(100% - 20px) 22px,calc(100% - 15px) 22px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
.field .err-msg{display:none;margin-top:8px;font-size:12.5px;color:#FF7B7B;font-family:var(--fd);letter-spacing:.02em}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#FF7B7B;box-shadow:0 0 0 3px rgba(255,123,123,.12)}
.field.invalid .err-msg{display:block}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:12.5px;color:var(--steel-dim);margin-top:6px;line-height:1.5}

.form-success{display:none;text-align:center;padding:clamp(30px,5vw,56px) 20px}
.form-success.show{display:block}
.form-success .fs-ico{width:64px;height:64px;margin:0 auto 22px;border-radius:50%;border:1px solid var(--reflect);color:var(--reflect);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 6px var(--reflect-soft)}
.form-success h3{font-size:28px;color:var(--chrome)}
.form-success p{margin-top:14px;color:var(--steel);max-width:380px;margin-inline:auto}
.form-success .fs-ref{margin-top:22px;font-family:var(--fd);font-size:13px;letter-spacing:.14em;color:var(--reflect)}

/* =========================================================
   CTA strip
   ========================================================= */
.cta{position:relative;overflow:hidden;border:1px solid var(--line-strong);border-radius:16px;padding:clamp(40px,6vw,76px);text-align:center;background:linear-gradient(165deg,var(--panel-2),#0B0C0F)}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 120% at 50% -10%,rgba(62,123,250,.14),transparent 55%);pointer-events:none}
.cta h2{position:relative;font-size:clamp(30px,5.5vw,64px);line-height:1;letter-spacing:-.03em;color:var(--chrome)}
.cta p{position:relative;margin:20px auto 0;max-width:520px;color:var(--steel);font-size:clamp(15px,1.7vw,18px)}
.cta .cta-actions{position:relative;margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* =========================================================
   FOOTER
   ========================================================= */
.site-foot{border-top:1px solid var(--line);background:#070709;padding:clamp(56px,7vw,88px) 0 36px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:54px}
.foot-brand .brand{font-size:20px}
.foot-brand p{margin-top:18px;color:var(--steel);font-size:14.5px;line-height:1.7;max-width:300px}
.foot-col h4{font-family:var(--fd);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--steel-dim);font-weight:600;margin-bottom:18px}
.foot-col a,.foot-col p{display:block;color:var(--steel);font-size:14.5px;padding:6px 0;line-height:1.5}
.foot-col a{transition:color .2s var(--ease)}
.foot-col a:hover{color:var(--reflect)}
.foot-bot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--line)}
.foot-bot p{color:var(--steel-dim);font-size:13px}
.made{display:inline-flex;align-items:center;gap:8px;font-family:var(--fd);font-size:12.5px;letter-spacing:.04em;color:var(--steel)}
.made a{color:var(--chrome)}
.made a:hover{color:var(--reflect)}
.made .spark{width:7px;height:7px;border-radius:50%;background:var(--steel-dim)}
.made:hover .spark{background:var(--reflect)}

/* =========================================================
   Generic helpers
   ========================================================= */
.lead-page{position:relative;overflow:hidden;padding:clamp(54px,8vw,104px) 0 clamp(20px,3vw,40px)}
.lead-page::before{content:"";position:absolute;inset:0;background:radial-gradient(100% 70% at 50% 0%,rgba(200,205,212,.05),transparent 60%);pointer-events:none}
.lead-page .lp-inner{position:relative;max-width:760px}
.lead-page h1{font-size:clamp(40px,8vw,96px);line-height:.96;letter-spacing:-.04em;margin-top:22px;color:var(--chrome)}
.lead-page h1 .u{color:var(--steel-dim)}
.lead-page .lp-sub{margin-top:24px;color:var(--steel);font-size:clamp(16px,1.9vw,20px);line-height:1.6;max-width:580px}
.crumbs{display:flex;gap:10px;align-items:center;font-family:var(--fd);font-size:12px;letter-spacing:.06em;color:var(--steel-dim)}
.crumbs a:hover{color:var(--reflect)}
.crumbs .sep{opacity:.5}

.note-strip{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:18px 22px;border:1px solid var(--line);border-radius:10px;background:var(--ink-2);color:var(--steel);font-size:14px}
.note-strip svg{width:20px;height:20px;flex:none;color:var(--steel)}
.note-strip:hover svg{color:var(--reflect)}
.note-strip b{color:var(--chrome);font-weight:500}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:center}
.detail-list{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:2px}
.detail-list li{display:flex;justify-content:space-between;gap:18px;padding:16px 0;border-bottom:1px solid var(--line);font-size:15px}
.detail-list li .dl-k{color:var(--steel)}
.detail-list li .dl-v{font-family:var(--fd);color:var(--chrome);font-variant-numeric:tabular-nums}
.detail-list li:hover .dl-v{color:var(--reflect)}

.spec-panel{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line-strong);aspect-ratio:1/1;background:linear-gradient(155deg,#23262F,#0C0D11)}
.spec-panel svg{position:absolute;inset:0;width:100%;height:100%}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .pkg-grid,.cap-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr;gap:30px 24px}
  .foot-brand{grid-column:1 / -1}
}
@media (max-width:860px){
  .nav-main,.head-cta .btn{display:none}
  .burger{display:flex}
  .contact-grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .rev-grid{grid-template-columns:1fr}
  .hero-readout{grid-template-columns:repeat(2,1fr)}
  .hero-readout .ro:nth-child(3){border-left:0;padding-left:0}
  .hero-readout .ro:nth-child(odd){border-left:0;padding-left:0}
  .gal-card.span6,.gal-card.span4,.gal-card.span8{grid-column:span 12}
  .gal-card.span4{grid-column:span 6}
}
@media (max-width:620px){
  body{font-size:16px}
  .pkg-grid,.cap-grid,.steps{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .gal-card.span4{grid-column:span 12}
  .cmp-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;
    -webkit-mask-image:linear-gradient(90deg,#000 86%,transparent 100%);
    mask-image:linear-gradient(90deg,#000 86%,transparent 100%);}
  .cmp-hint{display:block}
  .cmp{min-width:540px}
  .sec-head{margin-bottom:34px}
}
@media (max-width:360px){
  .hero-readout{grid-template-columns:1fr}
  .hero-readout .ro{border-left:0;padding-left:0;border-top:1px solid var(--line)}
  .hero-readout .ro:first-child{border-top:0}
}

/* =========================================================
   REDUCED MOTION — freeze sheen at best angle
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .gloss::before{transform:rotate(126deg);opacity:.6}
  .gloss::after{background-position:42% 0}
  .ba-after::after{background-position:48% 0}
  .reveal{opacity:1;transform:none}
}
