/*
 * Universal site CSS — shared across all pages.
 * Edit here to change nav, typography, buttons, responsive rules site-wide.
 */

:root{
  --bg:#ffffff;
  --ink:#0a0a0a;
  --ink-2:#1a1a1c;
  --steel-1:#f4f5f6;
  --steel-2:#e6e7e9;
  --steel-3:#c9ccd0;
  --steel-4:#8a8d92;
  --steel-5:#55585d;
  --accent: oklch(0.62 0.17 45);
  --accent-ink: oklch(0.42 0.14 45);
  --nav-h: 56px;

  /* ----- Width tiers (apply via max-width or width:min(--w-X,calc(100vw - ...))) */
  --w-wide:    1800px;  /* hero banners, case rail, belt-video-row */
  --w-content: 1200px;  /* default page container */
  --w-narrow:   780px;  /* text-heavy: headline-stack, legal */
  --gutter:      28px;  /* horizontal gutter on desktop containers */

  /* ----- Media aspect ratios — referenced by .hero-media et al */
  --ar-hero:  16 / 9;    /* default for hero, banner, feature, scene-tile, tool-step */
  --ar-cine:  16 / 9;    /* legacy alias — kept so existing var(--ar-cine) refs still work */
  --ar-wide:  21 / 9;    /* atmospheric lifestyle shots */
  --ar-tall:   4 / 3;    /* split features that need more vertical room */
  --ar-square: 1 / 1;    /* grid tiles */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Inter Tight',system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
.mono{font-family:'Inter Tight',sans-serif;font-weight:400}
h1,h2,h3,h4{margin:0;font-weight:500;letter-spacing:-0.02em}
h1{font-size:clamp(44px,6.2vw,88px);line-height:1.02}
h2{font-size:clamp(36px,4.8vw,64px);line-height:1.05}
.overline{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.28em;color:var(--steel-5);text-transform:uppercase}
.sub{color:var(--steel-5);max-width:620px;font-size:15px;line-height:1.6}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 28px;z-index:50;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2);transition:background .25s ease,border-color .25s ease}
.nav.solid{background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2)}
.nav .left,.nav .right{display:flex;align-items:center;gap:26px;font-size:13px;font-weight:500;letter-spacing:.02em}
.nav .right{justify-content:flex-end}
.nav a.link{padding:6px 2px;opacity:.85}
.nav a.link:hover{opacity:1}
.nav a.link.active{opacity:1;color:var(--accent-ink);border-bottom:1px solid var(--accent)}
.nav .brand{font-weight:700;letter-spacing:.32em;font-size:15px;display:flex;align-items:center;gap:8px}
.nav .brand .dot{width:6px;height:6px;background:var(--accent);border-radius:50%}
body.dark 

/* ============================================ */
/* RESPONSIVE BREAKPOINT SYSTEM                 */
/* Mobile < 640px | Tablet 640-899 | Desktop 900-1199 | XL 1200+ */
/* ============================================ */

/* HAMBURGER BUTTON */
.hamburger{display:none;position:relative;width:32px;height:32px;padding:0;cursor:pointer;background:none;border:0;margin-left:auto;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--ink);transition:transform .25s ease,opacity .2s ease}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* MOBILE MENU PANEL */
.mobile-menu{position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:#fff;z-index:49;overflow-y:auto;overflow-x:hidden;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);pointer-events:none;-webkit-overflow-scrolling:touch}
.mobile-menu.open{transform:translateX(0);pointer-events:auto}
.mobile-menu-inner{display:flex;flex-direction:column;padding:8px 0 40px;min-height:100%}
.mobile-section{display:flex;flex-direction:column;border-bottom:1px solid var(--steel-2)}
.mobile-section:last-child{border-bottom:0}
.mobile-section-utility{padding:12px 0}
.mobile-section-footer{padding:12px 0;background:#fafafa}
.mobile-link{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;font-size:22px;font-weight:500;letter-spacing:-0.01em;color:var(--ink);border-bottom:1px solid var(--steel-2);background:#fff;text-align:left;width:100%;font-family:inherit}
.mobile-link:last-child{border-bottom:0}
.mobile-expandable{cursor:pointer}
.mobile-expandable svg{transition:transform .22s ease;opacity:.55}
.mobile-expandable.expanded svg{transform:rotate(180deg)}
.mobile-submenu{max-height:0;overflow:hidden;background:#fafafa;transition:max-height .32s cubic-bezier(.4,0,.2,1)}
.mobile-submenu.open{max-height:800px;border-bottom:1px solid var(--steel-2)}
.mobile-sublink{display:flex;flex-direction:column;gap:4px;padding:16px 28px 16px 44px;border-bottom:1px solid var(--steel-2);color:var(--ink)}
.mobile-sublink:last-child{border-bottom:0}
.mobile-sublink-all{font-size:14px;color:var(--accent-ink);letter-spacing:.06em;text-transform:uppercase;font-family:'Inter Tight',sans-serif;padding:14px 28px 14px 44px}
.mobile-sublink-page{font-size:16px;color:var(--ink);padding:14px 28px 14px 44px;display:block;border-bottom:1px solid var(--steel-2)}
.mobile-sublink-page:last-child{border-bottom:0}
.mobile-sublink-name{font-size:17px;font-weight:500}
.mobile-sublink-tag{font-size:11px;color:var(--steel-5);letter-spacing:.04em}
.mobile-link-small{padding:12px 28px;font-size:14px;color:var(--steel-5);letter-spacing:.04em}
.mobile-link-small:hover{color:var(--ink)}

/* BREAKPOINTS — switch nav mode */
@media (max-width:899px){
  .nav .left,.nav .right{display:none}
  .nav .brand{justify-self:start}
  .hamburger{display:inline-flex;justify-self:end;width:32px;height:32px}
  .nav{grid-template-columns:auto 1fr}
  .mega{display:none !important}
}
@media (min-width:900px){
  .mobile-menu{display:none}
  .hamburger{display:none}
}

/* Dark-mode hamburger */
body.dark .hamburger span{background:var(--ink)}
body.dark .mobile-menu{background:var(--bg)}
body.dark .mobile-section-footer{background:var(--steel-1)}
body.dark .mobile-link{background:var(--bg);color:var(--ink);border-color:var(--steel-2)}
body.dark .mobile-submenu{background:var(--steel-1)}

  /* MEGA MENU */
.nav-wrap{position:fixed;top:0;left:0;right:0;z-index:50}
.nav-wrap .nav{position:relative}
.link.with-mega{display:inline-flex;align-items:center;gap:6px}
.link.with-mega .chev-down{transition:transform .2s ease;opacity:.6}
.link.with-mega.open .chev-down{transform:rotate(180deg)}
.mega{position:absolute;left:0;right:0;top:var(--nav-h);background:rgba(255,255,255,0.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2);box-shadow:0 8px 24px rgba(0,0,0,0.06);overflow:hidden;max-height:0;transition:max-height .28s ease;pointer-events:none}
.mega.open{max-height:640px;pointer-events:auto}
.mega-inner{max-width:1280px;margin:0 auto;padding:44px 88px;display:grid;grid-template-columns:1fr 220px;gap:56px;align-items:start}
.mega-main{display:flex;flex-direction:column;gap:20px}
.mega-overline{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.28em;color:var(--steel-5);text-transform:uppercase}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px 20px}
.mega-card{display:flex;flex-direction:column;gap:8px;text-align:center;background:transparent;padding:0;min-height:auto}
.mega-card-media{display:block;aspect-ratio:16/10;background:transparent;position:relative;overflow:hidden;transition:background .18s ease}
.mega-card-media img{width:100%;height:100%;object-fit:contain;padding:10px;box-sizing:border-box}
.mega-media-ph{width:100%;height:100%;background:repeating-linear-gradient(135deg,rgba(0,0,0,0.04) 0 1px,transparent 1px 10px),linear-gradient(180deg,var(--steel-1),var(--steel-2));border:1px solid var(--steel-2)}
.mega-card:hover .mega-card-media{background:rgba(0,0,0,0.02)}
.mega-name{font-size:15px;font-weight:500;letter-spacing:-0.01em;color:var(--ink);margin-top:6px}
.mega-links{display:flex;justify-content:center;gap:18px;margin-top:2px}
.mega-learn{font-size:13px;color:var(--ink-2);text-decoration:underline;text-decoration-color:var(--steel-3);text-underline-offset:3px;transition:color .15s ease,text-decoration-color .15s ease}
.mega-learn:hover{color:var(--ink);text-decoration-color:var(--ink)}

.mega-side{padding:6px 0 6px 32px;border-left:1px solid var(--steel-2);display:flex;flex-direction:column;gap:14px;min-height:280px}
.mega-side-title{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.16em;color:var(--steel-4);text-transform:uppercase;margin-bottom:8px}
.mega-side-link{font-size:14px;color:var(--ink-2);letter-spacing:-0.005em;transition:color .15s ease;padding:2px 0}
.mega-side-link:hover{color:var(--ink)}

/* legacy classes no longer rendered */
.mega-tag,.mega-extras,.mega-extra,.mega-footer,.mega-all,.mega-media{display:none}

@media (max-width: 1200px){
  .mega-inner{padding:40px 56px}
  .mini-mega-inner{padding:36px 56px}
}
@media (max-width: 900px){
  .mega-inner{grid-template-columns:1fr;gap:24px;padding:24px 28px}
  .mini-mega-inner{padding:24px 28px}
  .mega-grid{grid-template-columns:repeat(2,1fr);gap:20px 16px}
  .mega-side{border-left:none;border-top:1px solid var(--steel-2);padding-left:0;padding-top:20px;min-height:auto;flex-direction:row;flex-wrap:wrap;gap:20px}
  .mega-side-title{width:100%;margin-bottom:0}
}
@media (max-width: 640px){.mega-grid{grid-template-columns:repeat(2,1fr)}}

/* Simple text dropdown (Applications, Media, About) */
.mini-mega{position:absolute;left:0;right:0;top:var(--nav-h);background:rgba(255,255,255,0.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2);box-shadow:0 8px 24px rgba(0,0,0,0.06);overflow:hidden;max-height:0;transition:max-height .28s ease;pointer-events:none}
.mini-mega.open{max-height:420px;pointer-events:auto}
.mini-mega-inner{max-width:1280px;margin:0 auto;padding:40px 88px}
.mini-mega-overline{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.28em;color:var(--steel-5);text-transform:uppercase;margin-bottom:18px}
.mini-mega-col{display:flex;flex-direction:column;gap:10px}
.mini-mega-col a{font-size:15px;color:var(--ink-2);letter-spacing:-0.005em;transition:color .15s ease;padding:2px 0}
.mini-mega-col a:hover{color:var(--ink)}
@media (max-width: 860px){.mini-mega{display:none !important}}


/* Sections */
section.stage{position:relative;min-height:100vh;display:flex;flex-direction:column;padding-top:calc(var(--nav-h) + 40px);padding-bottom:48px}
.headline-stack{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;padding:0 24px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:10px}

/* ========================================================
 * Page-width containment. Every direct content child of a
 * content section caps at 1200px. Sections keep full-viewport
 * backgrounds; inner blocks conform. Opt-outs: elements that
 * self-manage width/gutters (hero-banner, banner-strip,
 * content-block, hero-media, machine-video, telemetry).
 * Padding is applied only to non-grid content blocks — grid
 * containers (hero-stats, caps, stats, rail, dealer-list)
 * manage their own internal cell padding, so giving them extra
 * padding would reveal their container background as a stripe.
 * ======================================================== */
/* Width constraint — applies to every child (including grid containers) */
section.stage > :not(.hero-banner):not(.banner-strip):not(.banner-strip--full):not(.content-block):not(.hero-media):not(.machine-video):not(.machine-video--full):not(.telemetry),
section.story > *,
section.page-hero > *,
section.contact-main > *,
section.dealers > *,
section.support-grid > *,
section.escalation > *,
section.legal-body > *,
section.css-featured > *,
section.css-grid-wrap > *,
section.css-submit > *,
section.partners > *,
section.milestones > *{
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  box-sizing:border-box;
  width:100%;
}
/* Padding for text content — excludes grid containers that use the
   gap:1px + background:steel-2 divider pattern. Padding on those
   containers reveals the gray background as side stripes. */
section.stage > :not(.hero-banner):not(.banner-strip):not(.banner-strip--full):not(.content-block):not(.hero-media):not(.machine-video):not(.machine-video--full):not(.telemetry):not(.hero-stats):not(.caps):not(.stats):not(.rail):not(.dealer-list):not(.process):not(.industry-switch),
section.story > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.page-hero > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.contact-main > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.dealers > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.support-grid > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.escalation > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.legal-body > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.css-featured > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.css-grid-wrap > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.css-submit > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.partners > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
section.milestones > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid){
  padding-left:28px;
  padding-right:28px;
}
@media (max-width:900px){
  section.stage > :not(.hero-banner):not(.banner-strip):not(.banner-strip--full):not(.content-block):not(.hero-media):not(.machine-video):not(.machine-video--full):not(.telemetry):not(.hero-stats):not(.caps):not(.stats):not(.rail):not(.dealer-list):not(.process):not(.industry-switch),
  section.story > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.page-hero > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.contact-main > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.dealers > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.support-grid > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.escalation > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.legal-body > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.css-featured > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.css-grid-wrap > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.css-submit > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.partners > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid),
  section.milestones > :not(.support-inner):not(.industry-switch):not(.mm-pubs-grid){
    padding-left:16px;
    padding-right:16px;
  }
}

/* Placeholder */
.ph{position:relative;background:repeating-linear-gradient(135deg,rgba(0,0,0,0.035) 0 1px,transparent 1px 14px),linear-gradient(180deg,var(--steel-1),#eceef0 60%,var(--steel-2));overflow:hidden}
.ph::before{content:'';position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 30%,rgba(255,255,255,0.9),transparent 55%);pointer-events:none}
.ph .cap{position:absolute;left:14px;bottom:12px;right:14px;display:flex;justify-content:space-between;gap:12px;font-family:'Inter Tight',sans-serif;font-size:11px;color:var(--steel-5);letter-spacing:.02em}
.ph .corner{position:absolute;width:10px;height:10px;border:1px solid var(--steel-4)}
.ph .corner.tl{top:10px;left:10px;border-right:0;border-bottom:0}
.ph .corner.tr{top:10px;right:10px;border-left:0;border-bottom:0}
.ph .corner.bl{bottom:10px;left:10px;border-right:0;border-top:0}
.ph .corner.br{bottom:10px;right:10px;border-left:0;border-top:0}
.ph.has-img::before{display:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 28px;min-width:220px;font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;border-radius:4px;transition:all .18s ease;border:1px solid transparent}
.btn.btn--sm{padding:8px 18px;min-width:0;font-size:11px;letter-spacing:.1em}
.btn.primary{background:var(--ink);color:#fff}
.btn.primary:hover{background:#000}
.btn.outline{background:transparent;color:var(--ink);border-color:rgba(10,10,10,0.55)}
.btn.outline:hover{background:var(--ink);color:#fff}
.btn.dark{background:#fff;color:#0a0a0a}
.btn.dark:hover{background:#eaeaea}

/* Telemetry — hidden globally (retired 2026-04-23). Keep markup intact in
   case we want to reinstate; flip display back on by removing the override. */
.telemetry{display:none}
.telemetry-base{position:absolute;left:28px;right:28px;bottom:24px;display:flex;justify-content:space-between;align-items:flex-end;font-family:'Inter Tight',sans-serif;font-size:11px;color:var(--steel-5);letter-spacing:.04em;pointer-events:none}
.telemetry-base .bar{height:1px;background:var(--steel-2);flex:1;margin:0 16px 6px}

/* CTA / Footer */
.cta-section{background:#0a0a0a;color:#fff;text-align:center;min-height:60vh;padding:120px 24px 72px;justify-content:center;align-items:center}
.cta-section .btn.outline{color:#fff;border-color:rgba(255,255,255,0.4)}
.cta-section .btn.outline:hover{background:#fff;color:#0a0a0a}
footer{background:#0a0a0a;color:#8a8d92;padding:36px 28px 24px;font-size:12px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;border-top:1px solid rgba(255,255,255,0.06)}
footer .cols{display:flex;gap:32px;flex-wrap:wrap}
footer a:hover{color:#fff}


/* ============================================ */
/* MOBILE-RESPONSIVE FIXES — applies to all pages */
/* ============================================ */
@media (max-width: 900px){
  /* Nav grid: brand on left, hamburger on right */
  .nav{grid-template-columns:auto 1fr !important;padding:0 20px}
  .nav .brand{justify-self:start}

  /* Kill stage min-height on mobile — otherwise sections eat the whole viewport each */
  section.stage{min-height:auto;padding-top:80px;padding-bottom:48px}

  /* Typography scale down */
  h1{font-size:clamp(32px,9vw,48px) !important}
  h2{font-size:clamp(26px,6vw,36px) !important}
  h3{font-size:20px !important}

  /* HERO */
  .hero{min-height:auto;padding-top:100px;padding-bottom:56px}
  .hero .hero-img{width:100%;height:auto;max-width:420px;position:relative;transform:none;left:auto;bottom:auto}
  .hero .headline-stack{padding:0 20px}

  /* Homepage stats grid (4-col) -> 2-col */
  .stats{grid-template-columns:repeat(2,1fr) !important}
  .stat-cell, .stats > div{min-height:auto}

  /* Homepage process steps (5-col) -> 1-col stacked */
  .process{grid-template-columns:1fr !important}
  .process .step{padding:20px 24px !important;border-bottom:1px solid var(--steel-2);border-right:0 !important}
  .process .step:last-child{border-bottom:0}

  /* Case study layout -> stacked */
  .case{grid-template-columns:1fr !important;gap:0}
  .case .imgwrap{min-height:280px}
  .case .copy{padding:40px 24px !important}
  .case .kv{grid-template-columns:repeat(2,1fr) !important}

  /* Capabilities (4-col) -> 2-col */
  .caps{grid-template-columns:repeat(2,1fr) !important}

  /* Rail/product cards */
  .rail{grid-auto-columns:88vw !important;overflow-x:auto;scroll-snap-type:x mandatory;padding:0 16px}
  .rail > .card{scroll-snap-align:center}

  /* Mega menu (hidden on mobile anyway, but safe) */
  .mega{display:none !important}

  /* Banner */
  .banner{min-height:50vh;padding:48px 0}
  .banner-inner{margin:0 20px !important;padding:28px 24px !important;max-width:none}

  /* Footer CTA */
  .cta-section{min-height:auto;padding:64px 24px}
  .cta-row{flex-direction:column;gap:10px;align-items:stretch}
  .cta-row .btn{width:100%;min-width:auto !important}

  /* Footer */
  footer{flex-direction:column;gap:16px;padding:28px 20px 20px}

  /* MACHINE DETAIL PAGE */
  .machine-hero{min-height:auto;padding-top:96px;padding-bottom:40px;gap:24px}
  .machine-hero .hero-media{min-height:260px;width:94%}
  .hero-stats{grid-template-columns:repeat(2,1fr) !important;width:92%}
  .stat-cell{padding:16px 14px}
  .stat-v{font-size:22px !important}
  .features{padding:56px 20px;gap:64px}
  .feature{grid-template-columns:1fr !important;gap:24px}
  .feature.flip{direction:ltr !important}
  .feature-media{aspect-ratio:4/3}

  /* Specs table */
  .specs-section{padding:56px 20px}
  .specs-grid{gap:36px}
  .specs-dl > div{padding:8px 0;gap:12px}
  .specs-dl dt, .specs-dl dd{font-size:12.5px}

  /* Apps strip */
  .apps-strip{padding:48px 20px}

  /* PRODUCTS PAGE — product rows */
  .prows{padding:48px 20px !important;gap:72px !important}
  .prow{grid-template-columns:1fr !important;gap:24px !important}
  .prow.flip{direction:ltr !important}
  .prow-copy h2{font-size:clamp(28px,7vw,40px) !important}
  .kv{grid-template-columns:repeat(2,1fr) !important}

  /* APPLICATIONS PAGE */
  .industry-switch{grid-template-columns:1fr !important}
  .ind-panel{grid-template-columns:1fr !important}
  .case-grid .grid{grid-template-columns:1fr !important}

  /* CONTACT PAGE */
  .contact-inner{grid-template-columns:1fr !important;gap:48px !important}
  .form-row{grid-template-columns:1fr !important}
  .dealer-list{grid-template-columns:1fr !important}

  /* ABOUT PAGE */
  .milestones{padding:56px 20px}
  .milestones-header{display:none !important}
  .milestones-row{grid-template-columns:80px 1fr !important;gap:12px;padding:14px 0}
  .milestones-row .change{grid-column:1/-1;padding-top:4px;font-size:13px}
  .partners{padding:56px 20px}
  .partner-list{grid-template-columns:1fr !important;gap:32px}
  .story{padding:56px 20px}

  /* SUPPORT PAGE */
  .support-inner{grid-template-columns:1fr !important}
  .support-card{min-height:auto !important;padding:32px 24px !important}
  .escalation{padding:56px 20px}
  .hq-block{padding:24px 28px !important}

  /* ACCOUNT PAGE */
  .account-main{padding:100px 20px 60px}
  .account-card{padding:36px 28px !important}

  /* LEGAL PAGES */
  .legal-hero{min-height:auto;padding:96px 20px 48px}
  .legal-body{padding:48px 20px 72px}
  .legal-inner{font-size:15px}
  .legal-inner .legal-table{grid-template-columns:1fr !important}
  .legal-inner .legal-table > div:nth-child(odd){background:#fafafa}
  .legal-inner .legal-table > div{border-bottom:1px solid var(--steel-2) !important}

  /* NEWS PAGE */
  .featured{grid-template-columns:1fr !important}
  .f-copy{padding:32px 24px !important}
  .n-row{grid-template-columns:1fr !important;gap:8px !important;padding:24px 20px !important}
  .n-date, .n-cat{font-size:11px}
  .n-title{font-size:19px !important}
  .n-arrow{display:none}

  /* Content hero (used on support, contact) */
  .content-hero{min-height:auto !important;padding:96px 20px 48px}
}

@media (max-width: 640px){
  /* Even tighter on narrow phones */
  .stats{grid-template-columns:1fr !important}
  .hero-stats{grid-template-columns:repeat(2,1fr) !important}
  .caps{grid-template-columns:1fr !important}
  .case .kv{grid-template-columns:1fr !important}
  .kv{grid-template-columns:1fr !important}
  .dealer-list{grid-template-columns:1fr !important}
  .mobile-sublink{padding-left:36px !important}
  .nav{padding:0 16px !important}
}


/* ============================================
 * Machine detail pages (shared across all six)
 * ============================================ */

/* Keep ph.has-img rules for images */
  .ph.has-img{ overflow:hidden; background:none; }
  .ph.has-img::before{ display:none; }
  .ph.has-img img{ width:100%; height:100%; object-fit:cover; object-position:center center; display:block; }

  /* MACHINE HERO */
  .machine-hero{
    min-height: 92vh; padding-top: 112px; padding-bottom: 56px;
    background: #fff;
    display: grid;
    grid-template-rows: auto 1fr auto auto;
    gap: 36px;
  }
  .machine-hero .headline-stack{ max-width: 780px; margin: 0 auto; }
  .machine-hero .headline-stack h1{ font-size: clamp(44px, 6vw, 80px); }
  .machine-hero .hero-media{
    position: relative;
    max-width: 1200px; width: 86%;
    margin: 0 auto;
    min-height: 380px;
    flex: 1;
  }
  .machine-hero .hero-media .ph{ position: absolute; inset: 0; }
  .machine-hero .hero-media .ph.has-img img{ object-fit: contain; padding: 24px; box-sizing: border-box; }
  .hero-stats{
    max-width: 1200px; width: 86%;
    margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--steel-2);
    border-top: 1px solid var(--steel-2);
    border-bottom: 1px solid var(--steel-2);
  }
  .stat-cell{ background: #fff; padding: 24px 20px; display: flex; flex-direction: column; gap: 6px; }
  .stat-k{ font-size: 10.5px; color: var(--steel-5); letter-spacing: .18em; text-transform: uppercase; }
  .stat-v{ font-size: 28px; font-weight: 500; letter-spacing: -0.02em; }
  @media (max-width: 900px){ .hero-stats{ grid-template-columns: repeat(2, 1fr); } }

  /* FEATURES */
  .features{ max-width: min(var(--w-content), calc(100vw - 56px)); margin: 0 auto; padding: 96px 0; display: flex; flex-direction: column; gap: 120px; }
  .feature{ display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
  .feature.flip{ direction: rtl; }
  .feature.flip > *{ direction: ltr; }
  .feature-copy h2{ margin: 8px 0 20px; font-size: clamp(32px, 3.6vw, 48px); line-height: 1.05; }
  .feature-copy p{ margin: 0; color: var(--steel-5); font-size: 16px; line-height: 1.65; max-width: 54ch; }
  .feature-media{ aspect-ratio: 4/3; position: relative; }
  .feature-media .ph{ position: absolute; inset: 0; }
  @media (max-width: 900px){ .feature{ grid-template-columns: 1fr; gap: 28px; } .feature.flip{ direction: ltr; } }

  /* SPECS */
  .specs-section{ background: #fafafa; padding: 96px 28px; }
  .specs-section .headline-stack{ max-width: 780px; margin: 0 auto 64px; text-align: center; align-items: center; }
  .specs-grid{
    max-width: 1200px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 48px;
  }
  .specs-group{ display: flex; flex-direction: column; gap: 12px; }
  .specs-title{ font-size: 14px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink); padding-bottom: 12px; border-bottom: 1px solid var(--steel-3); }
  .specs-dl{ margin: 0; display: flex; flex-direction: column; gap: 8px; }
  .specs-dl > div{ display: grid; grid-template-columns: 1fr auto; gap: 16px; padding: 6px 0; border-bottom: 1px solid var(--steel-2); }
  .specs-dl > div:last-child{ border-bottom: 0; }
  .specs-dl dt{ font-size: 13px; color: var(--steel-5); margin: 0; }
  .specs-dl dd{ font-size: 13px; font-family: 'Inter Tight', sans-serif; color: var(--ink); margin: 0; text-align: right; }
  .specs-footer{ max-width: 1200px; margin: 56px auto 0; text-align: center; font-size: 11px; color: var(--steel-4); letter-spacing: .12em; }

  /* APPLICATIONS STRIP */
  .apps-strip{ padding: 64px 28px; max-width: 1200px; margin: 0 auto; text-align: center; }
  .apps-strip .overline{ margin-bottom: 20px; display: block; }
  .apps-list{ display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
  .app-chip{ padding: 8px 16px; border: 1px solid var(--steel-2); border-radius: 2px; font-size: 13px; color: var(--ink-2); background: #fff; }


/* ============================================
 * Unified page hero — replaces .legal-hero, .post-hero,
 * .content-hero, .about-hero, .news-hero, individual .page-hero.
 * Use .page-hero with one of the modifier classes below.
 * ============================================ */
.page-hero{
  position:relative;
  min-height:50vh;
  padding:112px 28px 56px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.page-hero .headline-stack{
  max-width:860px;
  margin:0 auto;
  padding:0 28px;
  text-align:center;
  align-items:center;
}
.page-hero h1{font-size:clamp(40px,5vw,72px);line-height:1.05;margin:0}
.page-hero .sub{margin-top:18px}

/* Dark variant — legal, news post hero, anywhere with a dark header */
.page-hero--dark{background:#0a0a0a;color:#fff;border-bottom:1px solid #1f2024}
.page-hero--dark .overline{color:#a5a8ad}
.page-hero--dark h1{color:#fff}
.page-hero--dark .sub{color:#a5a8ad}

/* Light neutral variant — support, contact, about */
.page-hero--light{background:#fafafa}

/* Radial-gradient variant — products, news listing, marketing pages */
.page-hero--gradient{background:radial-gradient(ellipse 70% 50% at 50% 40%,#f6f7f8 0%,#eef0f2 60%,#e2e4e7 100%)}

/* Extra-tall hero — used on about */
.page-hero--tall{min-height:70vh}
.page-hero--tall h1{font-size:clamp(44px,6vw,80px);line-height:1.02}

/* Mobile */
@media (max-width:900px){
  .page-hero{min-height:auto;padding:96px 20px 48px}
}

/* Full-bleed image banner variant — works with .page-hero--tall. */
section.page-hero.page-hero-banner{
  position:relative;
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  background:#000;
  overflow:hidden;
}
section.page-hero.page-hero-banner .page-hero-banner-img{
  position:absolute !important;
  inset:0 !important;
  width:auto !important;
  max-width:none !important;
  margin:0 !important;
  padding:0 !important;
  background:#000;
}
section.page-hero.page-hero-banner .page-hero-banner-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center center;
  display:block;
}
section.page-hero.page-hero-banner .page-hero-banner-img::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.45) 35%, rgba(0,0,0,0.45) 65%, rgba(0,0,0,0.65) 100%);
  pointer-events:none;
}
section.page-hero.page-hero-banner .headline-stack{position:relative;z-index:2;color:#fff}
section.page-hero.page-hero-banner .headline-stack .overline{color:#fff}
section.page-hero.page-hero-banner .headline-stack h1{color:#fff}
section.page-hero.page-hero-banner .headline-stack .sub{color:#fff}
section.page-hero.page-hero-banner .telemetry{position:relative;z-index:2;color:#fff}
section.page-hero.page-hero-banner .telemetry .bar{background:rgba(255,255,255,0.18)}

/* Brand logo — nav has a permanent white background, so always show the dark logo. */
.brand-logo{height:22px;width:auto;display:block}
.brand-logo--light{display:none}



/* ============================================
 * Expanded footer — 4-column sitemap
 * ============================================ */
footer{background:#0a0a0a;color:#8a8d92;padding:64px 28px 28px;font-size:13px;display:flex;flex-direction:column;gap:40px;border-top:1px solid rgba(255,255,255,0.06)}
.foot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;max-width:1400px;margin:0 auto;width:100%}
.foot-col{display:flex;flex-direction:column;gap:10px}
.foot-title{font-family:'Inter Tight',sans-serif;font-size:10.5px;letter-spacing:.22em;color:#fff;text-transform:uppercase;margin-bottom:10px}
.foot-col a{color:#8a8d92;font-size:13.5px;line-height:1.5;transition:color .18s ease}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;max-width:1400px;margin:0 auto;width:100%;padding-top:24px;border-top:1px solid rgba(255,255,255,0.08);font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.08em;color:#55585d}
@media (max-width:900px){
  .foot-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  footer{padding:48px 20px 20px}
}
@media (max-width:560px){
  .foot-grid{grid-template-columns:1fr}
}

/* Mega-menu extras row — Custom / Refurbished / Financing shortcuts */
.mega-extras{display:flex;gap:24px;padding:12px 0 4px;font-family:'Inter Tight',sans-serif;font-size:12px;letter-spacing:.08em;color:var(--steel-5)}
.mega-extra{color:var(--accent-ink);border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color .18s ease}
.mega-extra:hover{border-color:currentColor}

/* Hide every section/feature/hero overline site-wide. Nav dropdown labels
 * use .mega-overline / .mini-mega-overline and are unaffected. Add a
 * .show-overline class to a specific element to bring one back. */
.overline:not(.show-overline){display:none !important}

/* ===== Framed feature layout — Tesla-style centered header + edge image ===== */
.features.features--framed{max-width:1200px;margin:0 auto;padding:0;gap:0;flex-direction:column;display:block}
@media (max-width:1248px){.features.features--framed{margin-left:24px;margin-right:24px}}
@media (max-width:900px){.features.features--framed{margin-left:16px;margin-right:16px}}
.feature.feature--framed{position:relative;display:flex;flex-direction:column;padding:48px 0 24px;min-height:0;overflow:visible;direction:ltr !important;grid-template-columns:none !important;gap:0 !important;background:#fff}
.feature--framed.feature--alt{background:#fafafa}
.feature--framed.flip{text-align:inherit}
.feature--framed::after{display:none}
.feature--framed > *{direction:ltr}
.feature--framed .feature-media{order:0}
.feature--framed .feature-copy{order:1;position:static;inset:auto;max-width:1200px;margin:24px auto 0;padding:0;text-align:left;color:var(--ink);display:flex;flex-direction:column;gap:8px;align-items:flex-start !important;box-sizing:border-box}
.feature--framed .feature-copy .overline{color:var(--steel-5);margin:0;display:block;text-align:left}
.feature--framed .feature-copy h2{color:var(--ink);margin:0;max-width:24ch;font-size:clamp(24px,2.6vw,32px);line-height:1.15;font-weight:600;letter-spacing:-0.02em;text-align:left}
.feature--framed .feature-copy p{color:var(--steel-5);margin:4px 0 0;max-width:60ch;font-size:15px;line-height:1.6;text-align:left}
.feature--framed .feature-media{position:relative;inset:auto;max-width:none;margin:0;aspect-ratio:21/9;overflow:hidden;background:var(--steel-1)}
.feature--framed .feature-media .ph{position:absolute;inset:0;background:transparent}
.feature--framed .feature-media .ph.has-img{background:#111}
.feature--framed .feature-media .ph.has-img img{width:100%;height:100%;object-fit:cover;object-position:center center;padding:0;display:block}
.feature--framed .feature-media .ph.has-img picture{display:block;width:100%;height:100%}
.feature--framed .feature-media .ph:not(.has-img){background:linear-gradient(180deg,var(--steel-1),var(--steel-2))}

/* Two-column split row — breaks the stacked rhythm with a side-by-side pair */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:88px 0 16px;background:#fff}
.feature-row.feature-row--alt{background:#fafafa}
/* Half-width feature within a feature-row: copy on top, image pinned to bottom
 * so both images align horizontally regardless of headline wrap length. */
.feature--framed.feature--half{padding:0 !important;background:transparent !important;display:flex;flex-direction:column}
.feature--half .feature-copy{max-width:none;padding:0 24px;margin:0 0 32px}
.feature--half .feature-copy h2{font-size:clamp(24px,2.4vw,32px);max-width:22ch}
.feature--half .feature-copy p{font-size:15px}
.feature--half .feature-media{aspect-ratio:3/2;margin-top:auto;width:100%;align-self:stretch}

/* First-feature hero — full-bleed image with centered text overlay */
.feature--framed.feature--hero{position:relative;min-height:72vh;padding:0 !important;overflow:hidden;background:#0a0a0a !important}
.feature--hero .feature-copy{position:absolute !important;left:0;right:0;bottom:0;top:auto;inset:auto 0 0 0 !important;z-index:2;padding:0 40px 72px;margin:0 auto !important;max-width:none;color:#fff;align-items:center !important;text-align:center}
.feature--hero .feature-copy .overline{color:rgba(255,255,255,0.78) !important}
.feature--hero .feature-copy h2{color:#fff !important;max-width:34ch;font-size:clamp(36px,4.8vw,64px) !important}
.feature--hero .feature-copy p{color:rgba(255,255,255,0.9) !important;max-width:58ch}
.feature--hero .feature-media{position:absolute !important;inset:0 !important;margin:0 !important;aspect-ratio:auto !important;max-width:none !important;z-index:0;background:transparent !important}
.feature--hero .feature-media .ph{position:absolute !important;inset:0 !important}
.feature--hero .feature-media .ph.has-img{background:#111 !important}
.feature--hero .feature-media .ph.has-img img{width:100%;height:100%;object-fit:cover;object-position:center center}
.feature--hero .feature-media .ph:not(.has-img){background:linear-gradient(180deg,#2a2c30,#0a0a0a) !important}
.feature--hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,0.3) 0%,transparent 30%,transparent 55%,rgba(0,0,0,0.82) 100%)}
@media (max-width:900px){
  .feature--framed.feature--hero{min-height:64vh}
  .feature--hero .feature-copy{padding:0 24px 48px}
  .feature--hero .feature-copy h2{font-size:clamp(28px,7vw,42px) !important}
}

@media (max-width:900px){
  .feature.feature--framed{padding:64px 10px 10px}
  .feature--framed .feature-copy{margin-bottom:36px;gap:10px;padding:0 20px}
  .feature--framed .feature-copy h2{font-size:clamp(26px,6vw,36px)}
  .feature--framed .feature-media{aspect-ratio:3/2}
  .feature-row{grid-template-columns:1fr;padding:56px 10px 10px;gap:24px}
  .feature--half .feature-media{aspect-ratio:3/2}
}

/* Mega dropdown: stagger fade-in of inner items while the panel expands.
   On close, items revert to hidden state through the same transition (no delay),
   so they fade out together as the panel collapses. */
.mega .mega-overline,
.mega .mega-grid > .mega-card,
.mega .mega-side > *,
.mini-mega .mini-mega-overline,
.mini-mega .mini-mega-col > a{
  opacity:0;transform:translateY(6px);
  transition:opacity .28s ease,transform .28s ease;
}
.mega.open .mega-overline,
.mega.open .mega-grid > .mega-card,
.mega.open .mega-side > *,
.mini-mega.open .mini-mega-overline,
.mini-mega.open .mini-mega-col > a{
  opacity:1;transform:translateY(0);
}
.mega.open .mega-overline                       {transition-delay: 60ms}
.mega.open .mega-grid > .mega-card:nth-child(1) {transition-delay:110ms}
.mega.open .mega-grid > .mega-card:nth-child(2) {transition-delay:150ms}
.mega.open .mega-grid > .mega-card:nth-child(3) {transition-delay:190ms}
.mega.open .mega-grid > .mega-card:nth-child(4) {transition-delay:230ms}
.mega.open .mega-grid > .mega-card:nth-child(5) {transition-delay:270ms}
.mega.open .mega-grid > .mega-card:nth-child(6) {transition-delay:310ms}
.mega.open .mega-side > :nth-child(1) {transition-delay:140ms}
.mega.open .mega-side > :nth-child(2) {transition-delay:180ms}
.mega.open .mega-side > :nth-child(3) {transition-delay:220ms}
.mega.open .mega-side > :nth-child(4) {transition-delay:260ms}
.mega.open .mega-side > :nth-child(5) {transition-delay:300ms}
.mini-mega.open .mini-mega-overline             {transition-delay: 60ms}
.mini-mega.open .mini-mega-col > a:nth-child(1) {transition-delay:120ms}
.mini-mega.open .mini-mega-col > a:nth-child(2) {transition-delay:160ms}
.mini-mega.open .mini-mega-col > a:nth-child(3) {transition-delay:200ms}
.mini-mega.open .mini-mega-col > a:nth-child(4) {transition-delay:240ms}
.mini-mega.open .mini-mega-col > a:nth-child(5) {transition-delay:280ms}
.mini-mega.open .mini-mega-col > a:nth-child(6) {transition-delay:320ms}

@media (prefers-reduced-motion: reduce){
  .mega .mega-overline,
  .mega .mega-grid > .mega-card,
  .mega .mega-side > *,
  .mini-mega .mini-mega-overline,
  .mini-mega .mini-mega-col > a{
    transition:none;transform:none;
  }
  .mega.open .mega-overline,
  .mega.open .mega-grid > .mega-card,
  .mega.open .mega-side > *,
  .mini-mega.open .mini-mega-overline,
  .mini-mega.open .mini-mega-col > a{
    opacity:1;
  }
}

/* Subtle rounded corners on images site-wide (Tesla-style).
   Applied to <img> directly, plus to wrappers that clip with overflow:hidden
   so cover-fit images still show the curve. Logos, the mega placeholder
   pattern, and any element marked .no-radius opt out. */
:root{--img-radius:9px;--banner-radius:12px}
img{border-radius:var(--img-radius)}
.mega-card-media,
.feature-media,
.ph,
.ph.has-img{border-radius:var(--img-radius);overflow:hidden}
.brand-logo,
.mega-media-ph,
.no-radius,
.no-radius img{border-radius:0}
/* Edge-to-edge hero feature stays square — corners otherwise reveal #111 backdrop */
.feature--hero,
.feature--hero .feature-media,
.feature--hero .feature-media .ph,
.feature--hero .feature-media img{border-radius:0}

/* YouTube embed section with centered header */
.machine-video,
.machine-video-pair{padding:96px 28px 0;max-width:1200px;margin:0 auto;background:#fff}
.machine-video-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:900px){.machine-video-grid{grid-template-columns:1fr;gap:16px}}
.machine-video-head{text-align:center;max-width:640px;margin:0 auto 32px}
.machine-video-head h2{font-size:clamp(32px,3.6vw,48px);margin:0 0 12px;letter-spacing:-0.02em}
.machine-video-head p{color:var(--steel-5);font-size:16px;line-height:1.65;margin:0}
.machine-video-frame{position:relative;width:100%;aspect-ratio:16/9;background:#000;overflow:hidden;border-radius:var(--banner-radius)}
.machine-video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.machine-video-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* Edge-to-edge single video (e.g. mira-6s). Keeps head centered, stretches frame.
   Frame inherits .banner-radius from the base .machine-video-frame rule. */
.machine-video--full{max-width:none;padding-left:0;padding-right:0}
.machine-video--full .machine-video-head{max-width:640px;margin:0 auto 32px;padding:0 28px}

/* Content block — generic 1200-wide container with matching gutter behavior
   to .banner-strip. Use for inline sections that need to line up visually
   with banner-strip / hero-media (e.g. the J9 NSK triptych section). */
.content-block{max-width:1200px;margin:0 auto}
@media (max-width:1248px){.content-block{margin-left:24px;margin-right:24px}}
@media (max-width:900px){.content-block{margin-left:16px;margin-right:16px}}

/* Banner strip — constrained product-row / hero-showcase between sections.
   Max-width matches .machine-hero .hero-media (1200px). For edge-to-edge
   video/image placements, apply .banner-strip--full to restore full width. */
.banner-strip{max-width:1200px;margin:64px auto;padding:0;background:#000;overflow:hidden;position:relative;border-radius:var(--banner-radius)}
.banner-strip img{width:100%;height:100%;display:block;object-fit:cover;border-radius:0;position:absolute;inset:0}
.banner-strip-cap{position:absolute;inset:auto 0 20px;text-align:center;color:rgba(255,255,255,.9);font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:0 24px;text-shadow:0 1px 3px rgba(0,0,0,.6)}
.banner-strip--full{max-width:none;margin:0}
@media (max-width:1248px){.banner-strip{margin-left:24px;margin-right:24px}}
@media (max-width:900px){.banner-strip{margin:40px 16px}}

/* Ball screws / hardware detail split section (flip of in-the-box) */
.ball-screws{max-width:1200px;margin:0 auto;padding:96px 28px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;background:#fff}
.ball-screws-copy h2{font-size:clamp(32px,3.6vw,48px);margin:0 0 20px;letter-spacing:-0.02em}
.ball-screws-copy p{color:var(--steel-5);font-size:16px;line-height:1.65;margin:0;max-width:52ch}
.ball-screws-media{aspect-ratio:4/3;background:var(--steel-1)}
.ball-screws-media img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:900px){.ball-screws{grid-template-columns:1fr;gap:32px;padding:72px 24px}.ball-screws-media{aspect-ratio:4/3}}

/* "Why this machine?" icon-card grid */
.why-mira{padding:96px 28px;max-width:1200px;margin:0 auto;background:#fff}
.why-mira-head{text-align:center;max-width:640px;margin:0 auto 48px}
.why-mira-head h2{font-size:clamp(32px,3.6vw,48px);margin:0 0 12px;letter-spacing:-0.02em}
.why-mira-head p{color:var(--steel-5);font-size:16px;line-height:1.65;margin:0}
.why-mira-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px 40px}
.why-card{text-align:center;padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:12px}
.why-card-icon{width:80px;height:80px;object-fit:contain;display:block}
.why-card h3{font-size:18px;font-weight:500;letter-spacing:-0.01em;margin:4px 0 0}
.why-card p{font-size:14px;color:var(--steel-5);line-height:1.6;margin:0;max-width:38ch}
@media (max-width:900px){.why-mira-grid{grid-template-columns:repeat(2,1fr);gap:28px 20px}}
@media (max-width:640px){.why-mira-grid{grid-template-columns:1fr}}

/* "What's in the box" content + image split */
.in-the-box{max-width:1200px;margin:0 auto;padding:96px 28px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;background:#fff}
.in-the-box-copy h2{font-size:clamp(32px,3.6vw,48px);margin:0 0 20px;letter-spacing:-0.02em}
.in-the-box-copy p{color:var(--steel-5);font-size:16px;line-height:1.65;margin:0;max-width:52ch}
.in-the-box-media{aspect-ratio:var(--ar-hero);background:var(--steel-1);border-radius:var(--banner-radius);overflow:hidden}
.in-the-box-media img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:900px){.in-the-box{grid-template-columns:1fr;gap:32px;padding:72px 24px}}

/* Customer stories grid — shared across applications.html and machine pages */
.case-grid{padding:96px 0;max-width:1200px;margin:0 auto}
@media (max-width:1248px){.case-grid{margin-left:24px;margin-right:24px}}
@media (max-width:900px){.case-grid{margin-left:16px;margin-right:16px}}
.case-grid .headline-stack{text-align:center}
.case-grid .headline-stack h2{font-size:clamp(32px,3.6vw,48px);margin:0 0 8px;letter-spacing:-0.02em}
.case-grid .grid{margin-top:40px;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.case{display:flex;flex-direction:column;background:#fff;border:1px solid var(--steel-2);transition:border-color .2s ease,transform .2s ease;text-decoration:none;color:inherit}
.case:hover{border-color:var(--ink);transform:translateY(-2px)}
.case-media{aspect-ratio:16/9;position:relative}
.case-media .ph{position:absolute;inset:0}
.case-body{padding:24px 26px;display:flex;flex-direction:column;gap:8px}
.case-meta{font-size:10.5px;letter-spacing:.16em;color:var(--steel-4);text-transform:uppercase}
.case-t{font-size:22px;font-weight:500;letter-spacing:-0.01em;line-height:1.25}
.case-m{font-size:12px;color:var(--accent-ink);letter-spacing:.04em}
@media (max-width:900px){.case-grid .grid{grid-template-columns:1fr}}

/* ============================================================
   MACHINE-VIDEO — full-bleed YouTube banner pattern.
   Originally lived inline in mira-6s.html; promoted to site.css
   so it's available on any page. Composable modifiers:
     .machine-video--full       base full-bleed sizing
     .machine-video--breakout   break out of .features 1200px cap
     .machine-video--wide       wider cap (1800px)
     .machine-video--short      2.4:1 aspect (vs default 16:9)
     .machine-video--h670       fixed 670px height + cover-overscan
     .machine-video--crop-tb    crop top/bottom baked-in letterbox
     .machine-video--left       overlay text on left (default right)
     .machine-video--square     1:1 frame variant
   ============================================================ */
section.machine-video.machine-video--full .machine-video-frame{
  aspect-ratio:16/9;
  height:auto;
  max-height:none;
  border-radius:0;
}
section.machine-video.machine-video--full{padding-top:0;padding-bottom:0;margin:0}
section.machine-video.machine-video--full .machine-video-frame{position:relative}
section.machine-video.machine-video--full .machine-video-frame::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(270deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.25) 40%, rgba(0,0,0,0) 70%);
  pointer-events:none;
  z-index:1;
}
.machine-video-overlay{
  position:absolute;
  right:max(28px, calc((100vw - 1200px) / 2));
  top:50%;
  transform:translateY(-50%);
  z-index:2;
  max-width:480px;
  text-align:right;
  pointer-events:none;
}
.machine-video-overlay p{max-width:380px;margin-left:auto}

section.machine-video.machine-video--crop-tb .machine-video-frame{overflow:hidden}
section.machine-video.machine-video--crop-tb .machine-video-frame iframe{
  position:absolute;
  top:50%;left:50%;
  width:118%;
  height:118%;
  transform:translate(-50%, -50%);
  border:0;
}

section.machine-video.machine-video--left .machine-video-frame::after{
  background:linear-gradient(90deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.25) 40%, rgba(0,0,0,0) 70%);
}
section.machine-video.machine-video--left .machine-video-overlay{
  left:max(28px, calc((100vw - 1200px) / 2));
  right:auto;
  text-align:left;
}
section.machine-video.machine-video--left .machine-video-overlay h2,
section.machine-video.machine-video--left .machine-video-overlay p{text-align:left}
section.machine-video.machine-video--left .machine-video-overlay p{margin-left:0;margin-right:auto}
.machine-video-overlay h2{
  margin:0;
  color:#fff;
  font-size:clamp(32px,3.6vw,48px);
  line-height:1.05;
  letter-spacing:-0.02em;
  font-weight:500;
  text-align:right;
}
.machine-video-overlay p{
  margin:14px 0 0;
  color:rgba(255,255,255,0.88);
  font-size:15px;
  line-height:1.55;
  text-align:right;
}
@media (max-width:900px){
  .machine-video-overlay{left:16px;right:16px;top:auto;bottom:24px;transform:none;max-width:none;text-align:left}
  .machine-video-overlay h2{text-align:left;font-size:clamp(24px,5vw,36px)}
  .machine-video-overlay p{text-align:left}
  section.machine-video.machine-video--full .machine-video-frame{aspect-ratio:16/9}
}

/* Breakout sizing — all variants render at content tier (1200) × 16:9.
   --square is the one intentional exception (1:1, narrower) for square thumbs. */
.features .machine-video.machine-video--breakout,
.features .machine-video.machine-video--breakout.machine-video--wide{
  width:min(var(--w-content), calc(100vw - 56px));
  max-width:none;
  position:relative;
  left:50%;
  transform:translateX(-50%);
  margin:0 auto 64px;
  padding:0;
  background:transparent;
  border-radius:0;
  overflow:visible;
}
.features .feature--breakout{
  width:min(var(--w-content), calc(100vw - 56px));
  max-width:none;
  position:relative;
  left:50%;
  transform:translateX(-50%);
}
.features .machine-video.machine-video--breakout .machine-video-frame,
.features .machine-video.machine-video--breakout.machine-video--wide .machine-video-frame{
  aspect-ratio:var(--ar-hero);
  height:auto;
  max-height:none;
}
.features .machine-video.machine-video--breakout.machine-video--square{
  width:min(600px, calc(100vw - 56px));
  position:static;
  left:auto;
  transform:none;
  margin:0 auto 64px;
}
.features .machine-video.machine-video--breakout.machine-video--square .machine-video-frame{
  aspect-ratio:var(--ar-square);
  height:auto;
  max-height:none;
}
.features .machine-video.machine-video--breakout.machine-video--square .machine-video-frame iframe{
  width:230%;height:130%;
}

/* Rounded frame + cover-overscan iframe (clips YT chrome off-frame) */
.features .machine-video.machine-video--breakout .machine-video-frame{
  border-radius:var(--banner-radius) !important;
  overflow:hidden !important;
  position:relative !important;
}
.features .machine-video.machine-video--breakout .machine-video-frame iframe{
  position:absolute !important;
  top:50% !important;left:50% !important;
  width:125% !important;height:125% !important;
  transform:translate(-50%,-50%) !important;
  border:0 !important;
  pointer-events:none !important;
}
/* Wide variant: frame is fixed 670px tall, often wider-than-16:9.
   Iframe maintains 16:9 and covers via min-width/min-height. */
.features .machine-video.machine-video--breakout.machine-video--wide .machine-video-frame iframe{
  width:auto !important;
  height:auto !important;
  min-width:100% !important;
  min-height:100% !important;
  aspect-ratio:16/9 !important;
}
.features .machine-video.machine-video--breakout.machine-video--crop-tb .machine-video-frame iframe,
.features .machine-video.machine-video--breakout.machine-video--wide.machine-video--crop-tb .machine-video-frame iframe{
  position:absolute !important;
  top:50% !important;left:50% !important;
  width:118% !important;height:118% !important;
  min-width:0 !important;min-height:0 !important;
  transform:translate(-50%,-50%) !important;
  aspect-ratio:auto !important;
}
.features .feature.feature--banner .feature-media iframe.feature-banner-bg-video{
  position:absolute !important;
  top:50% !important;left:50% !important;
  width:140% !important;height:140% !important;
  transform:translate(-50%,-50%) !important;
  border:0 !important;
  pointer-events:none !important;
  z-index:0;
}
/* Click-blocker over iframe — prevents YT hover chrome + click-through */
.features .machine-video.machine-video--breakout .machine-video-frame::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:auto;
}
.features .machine-video.machine-video--breakout .machine-video-frame::after{display:none !important}

/* Banner-vid-row: split layout with banner-feature + square video side-by-side */
.features .banner-vid-row{
  display:flex;
  gap:24px;
  width:min(1800px, calc(100vw - 56px));
  position:relative;
  left:50%;
  transform:translateX(-50%);
  margin:0 0 64px;
  align-items:flex-start;
}
.features .banner-vid-row > article.feature.feature--banner{
  width:auto !important;
  max-width:none !important;
  flex:1 1 0 !important;
  min-width:0 !important;
  position:static !important;
  left:auto !important;
  transform:none !important;
  margin:0 !important;
}
.features .banner-vid-row > article.feature.feature--banner .feature-media{
  height:auto !important;
  aspect-ratio:16/9 !important;
}
.features .banner-vid-row > section.machine-video.machine-video--breakout.machine-video--square{
  width:auto !important;
  flex:1 1 0 !important;
  min-width:0 !important;
  position:static !important;
  left:auto !important;
  transform:none !important;
  margin:0 !important;
}
.features .banner-vid-row > section.machine-video.machine-video--breakout.machine-video--square .machine-video-frame{
  aspect-ratio:16/9 !important;
}
@media (max-width:900px){
  .features .banner-vid-row{flex-direction:column;gap:32px;width:calc(100vw - 32px)}
}

/* ============================================================
   CASE-RAIL — horizontal scroll-snap banner carousel.
   Default: full-bleed banners with overlay caption.
   --compact: page-flow 1800px banner with caption below (670px tall).
   --light: white background, contained images.
   ============================================================ */
.case-rail{position:relative;background:#000}
.case-rail-track{display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.case-rail-track::-webkit-scrollbar{display:none}
.case-banner{flex:0 0 100%;width:100%;display:block;text-decoration:none;color:inherit;scroll-snap-align:start;position:relative;overflow:hidden;background:#000;height:670px}
.case-banner-media{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;background:#000}
.case-banner-media img{width:100%;height:100%;object-fit:cover;display:block}
.case-banner-media::after{display:none}
.case-banner-cap{position:absolute;top:50%;transform:translateY(-50%);z-index:2;display:flex;flex-direction:column;gap:12px;color:#fff;max-width:520px}
.case-banner--left .case-banner-cap{left:max(28px, calc((100vw - 1200px) / 2));right:auto;text-align:left;align-items:flex-start}
.case-banner--right .case-banner-cap{right:max(28px, calc((100vw - 1200px) / 2));left:auto;text-align:right;align-items:flex-end}
.case-banner-cap .overline{color:rgba(255,255,255,0.78);margin:0;display:block}
.case-banner--left .case-banner-cap .overline{text-align:left}
.case-banner--right .case-banner-cap .overline{text-align:right}
.case-banner-cap h2{margin:0;font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:-0.02em;font-weight:500;color:#fff;max-width:18ch}
.case-banner-cap p{margin:0;color:rgba(255,255,255,0.88);font-size:16px;line-height:1.55;max-width:520px;white-space:pre-line}
.case-banner--right .case-banner-cap p{text-align:right;margin-left:auto}
.case-rail-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:4px;border:1px solid rgba(255,255,255,0.4);background:rgba(0,0,0,0.35);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:opacity .2s ease,background .2s ease;z-index:3;padding:0}
.case-rail-nav:hover{background:rgba(0,0,0,0.55);border-color:rgba(255,255,255,0.6)}
.case-rail-nav:disabled{opacity:0;pointer-events:none}
.case-rail-nav--prev{left:24px}
.case-rail-nav--next{right:24px}

.case-rail.case-rail--compact{width:min(var(--w-content), calc(100vw - 56px));margin:0 auto 64px;background:transparent;overflow:visible}
.case-rail.case-rail--compact .case-banner{height:auto;background:transparent;display:flex;flex-direction:column;overflow:visible}
.case-rail.case-rail--compact .case-banner-media{position:relative;inset:auto;width:100%;aspect-ratio:var(--ar-hero);height:auto;max-height:none;border-radius:var(--banner-radius);overflow:hidden;background:#0a0a0a}
.case-rail.case-rail--compact .case-banner-media iframe{
  position:absolute !important;
  top:50% !important;
  left:50% !important;
  transform:translate(-50%, -50%) !important;
  width:auto !important;
  height:auto !important;
  min-width:100% !important;
  min-height:100% !important;
  aspect-ratio:16/9 !important;
  border:0 !important;
  pointer-events:none !important;
}
.case-rail.case-rail--compact .case-banner-cap{position:static;transform:none;top:auto;left:auto !important;right:auto !important;bottom:auto;margin:18px 0 0;padding:0;align-items:flex-start !important;text-align:left !important;max-width:none;color:var(--ink);gap:6px}
.case-rail.case-rail--compact .case-banner-cap .overline{color:var(--steel-5) !important;text-align:left !important}
.case-rail.case-rail--compact .case-banner-cap h2{color:var(--ink) !important;text-align:left !important;font-size:clamp(24px,2.6vw,32px);font-weight:600;letter-spacing:-0.02em;line-height:1.1;margin:0}
.case-rail.case-rail--compact .case-banner-cap p{color:var(--steel-5) !important;text-align:left !important;font-size:15px;line-height:1.6;margin:4px 0 0}
@media (max-width:900px){
  .case-banner{height:auto;aspect-ratio:16/9}
  .case-banner-cap{top:auto;bottom:32px;transform:none;left:20px !important;right:20px !important;max-width:none;text-align:left !important;align-items:flex-start !important}
  .case-banner-cap .overline,.case-banner-cap h2,.case-banner-cap p{text-align:left !important}
  .case-rail-nav{display:none}
  .case-rail.case-rail--compact{width:calc(100vw - 16px)}
  .case-rail.case-rail--compact .case-banner-media{aspect-ratio:16/9;height:auto;max-height:none;border-radius:var(--img-radius)}
}

.case-rail--light,
.case-rail--light .case-banner,
.case-rail--light .case-banner-media{background:#fff}
.case-rail--light .case-banner-media img{object-fit:contain}
.case-rail--light .case-rail-nav{background:rgba(255,255,255,0.85);border-color:rgba(0,0,0,0.15);color:var(--ink);backdrop-filter:none;-webkit-backdrop-filter:none}
.case-rail--light .case-rail-nav:hover{background:#fff;border-color:rgba(0,0,0,0.35)}

/* Caption below a banner — real DOM, not pseudo. */
.banner-cap{
  margin:18px 0 0 !important;
  padding:0 !important;
  text-align:left;
  grid-column:1 / -1;
}
.banner-cap h3{
  margin:0;
  font-size:clamp(24px,2.6vw,32px);
  font-weight:600;
  letter-spacing:-0.02em;
  line-height:1.1;
  color:var(--ink);
}
.banner-cap p{
  margin:4px 0 0;
  color:var(--steel-5);
  font-size:15px;
  line-height:1.6;
}

/* Scroll-triggered fade-up. Applied by site.js to major content blocks
   below the initial viewport. */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform}
.fade-up.is-visible{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){.fade-up{opacity:1;transform:none;transition:none}}

/* ============================================================
   BELT VIDEO — paired media row with caption below each tile.
   Used on index (peer-reviewed/trusted) and elara-2.
   ============================================================ */
.belt-video{padding:24px 0 88px;background:#fff}
.belt-video-row{display:flex;gap:24px;width:min(var(--w-content), calc(100vw - 56px));margin:0 auto;align-items:flex-start}
.belt-video-row .belt-video-col{flex:1;min-width:0;display:flex;flex-direction:column}
.belt-video-inner{position:relative;width:100%;border-radius:var(--banner-radius);overflow:hidden;background:#0a0a0a}
.belt-video-inner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.belt-video-head--below{max-width:none;margin:18px 0 0;text-align:left;display:flex;flex-direction:column;gap:6px;align-items:flex-start;padding:0}
.belt-video .belt-video-cta{position:absolute;left:20px;bottom:20px;z-index:3}
@media (max-width:780px){.belt-video .belt-video-cta{left:14px;bottom:14px}}
.belt-video-head--below h2{margin:0;font-size:18px;line-height:1.25;letter-spacing:-0.01em;font-weight:600;color:var(--ink);max-width:none}
.belt-video-head--below p{margin:0;color:var(--steel-5);font-size:14px;line-height:1.55;white-space:pre-line}
@media (max-width:900px){
  .belt-video{padding:16px}
  .belt-video-row{flex-direction:column;gap:48px;padding:0 16px}
}

/* ============================================================
   SCENE GRID — horizontal-scroll carousel of media+caption tiles.
   Canonical tile width = content tier; variants override below.
   Layout: section bg + heading + scrolling track + tiles with cap below.
   ============================================================ */
.scene-grid{padding:72px 0 88px;background:#fff;overflow:hidden;position:relative}
.scene-grid .scene-head{max-width:min(var(--w-content), calc(100vw - 56px));margin:0 auto 40px;padding:0;text-align:left;display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.scene-grid .scene-head .overline{color:var(--steel-5);margin:0;display:block}
.scene-grid .scene-head h2{margin:0;font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:-0.02em;font-weight:500;color:var(--ink);max-width:28ch}
.scene-grid .scene-head p{margin:0;color:var(--steel-5);font-size:16px;line-height:1.65;max-width:60ch;white-space:pre-line}
.scene-grid .scene-track{display:flex;gap:16px;overflow-x:auto;overflow-y:hidden;scroll-padding-inline-start:max(28px, calc((100vw - 1200px) / 2));padding:0 max(28px, calc((100vw - 1200px) / 2));scrollbar-width:none;-webkit-overflow-scrolling:touch}
.scene-grid .scene-track::-webkit-scrollbar{display:none}
.scene-grid .scene-tile{
  flex:0 0 auto;
  width:min(var(--w-content), calc(100vw - max(56px, calc((100vw - 1200px))) ));
  display:flex;flex-direction:column;gap:18px;
}
.scene-grid .scene-tile-media{position:relative;background:var(--steel-1);border-radius:var(--banner-radius);overflow:hidden}
.scene-grid .scene-tile-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
.scene-grid .scene-tile-cap{padding:0 4px}
.scene-grid .scene-tile-cap h3{margin:0 0 4px;font-size:clamp(24px,2.6vw,32px);font-weight:600;letter-spacing:-0.02em;line-height:1.1;color:var(--ink)}
.scene-grid .scene-tile-cap p{margin:0;color:var(--steel-5);font-size:15px;line-height:1.6;white-space:pre-line}
.scene-grid .scene-tile-cap .scene-tile-subtitle{margin:0 0 8px;color:var(--ink);font-size:15px;font-weight:600;line-height:1.4;letter-spacing:0;white-space:pre-line}
.scene-grid .scene-tile-cap .scene-tile-bullets{margin:10px 0 0;padding:0 0 0 18px;color:var(--steel-5);font-size:14px;line-height:1.6}
.scene-grid .scene-tile-cap .scene-tile-bullets li{margin:0}
.scene-grid .scene-tile--text{justify-content:center}
.scene-grid .scene-tile--text .scene-tile-cap{padding:0}
.scene-grid .scene-tile--text .scene-tile-cap p{font-size:18px;line-height:1.55;max-width:60ch}

.scene-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:4px;background:rgba(255,255,255,.92);border:1px solid var(--steel-2);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.08);transition:opacity .2s ease,transform .15s ease,background .15s ease;z-index:3;padding:0}
.scene-nav:hover{background:#fff;transform:translateY(-50%) scale(1.05)}
.scene-nav:disabled{opacity:0;pointer-events:none}
.scene-nav svg{width:18px;height:18px;fill:var(--ink)}
.scene-nav--prev{left:max(28px, calc((100vw - 1200px) / 2 - 60px))}
.scene-nav--next{right:max(28px, calc((100vw - 1200px) / 2 - 60px))}
/* variants */
.scene-grid--square .scene-tile{width:min(560px, 72vw)}
.scene-grid--square .scene-tile-media{aspect-ratio:var(--ar-square)}
.scene-grid--stack .scene-tile{flex:initial;width:100%}
.scene-grid--stack .scene-track{display:flex;flex-direction:column;gap:24px;overflow:visible;padding:0 max(28px, calc((100vw - 1200px) / 2));max-width:var(--w-content);margin:0 auto;align-items:center}
.scene-grid--stack .scene-nav{display:none}
.scene-grid--2x2 .scene-tile{width:auto;flex:initial}
.scene-grid--2x2 .scene-track{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;overflow:visible;padding:0 max(28px, calc((100vw - 1200px) / 2));max-width:var(--w-content);margin:0 auto}
.scene-grid--2x2 .scene-tile-media{aspect-ratio:var(--ar-tall);background:#fff}
.scene-grid--2x2 .scene-tile-media img{object-fit:contain}
.scene-grid--2x2 .scene-nav{display:none}
.scene-grid--4x1 .scene-tile{width:auto;flex:initial}
.scene-grid--4x1 .scene-track{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;overflow:visible;padding:0;width:min(var(--w-content), calc(100vw - 56px));margin:0 auto;max-width:none}
.scene-grid--4x1 .scene-tile-media{aspect-ratio:1/2;background:#fff}
.scene-grid--4x1 .scene-tile-media img{object-fit:contain}
.scene-grid--4x1 .scene-nav{display:none}
.scene-grid--3x1 .scene-tile{width:auto;flex:initial}
.scene-grid--3x1 .scene-track{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;overflow:visible;padding:0;width:min(var(--w-content), calc(100vw - 56px));margin:0 auto;max-width:none}
.scene-grid--3x1 .scene-tile-media{aspect-ratio:1/2;background:#fff}
.scene-grid--3x1 .scene-tile-media img{object-fit:contain}
.scene-grid--3x1 .scene-nav{display:none}
.scene-grid--vertical .scene-tile-media{aspect-ratio:1/2;background:#fff}
.scene-grid--vertical .scene-tile-media img{object-fit:contain}
.scene-grid--config-4 .scene-tile{width:auto;flex:initial}
.scene-grid--config-4 .scene-track{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;overflow:visible;padding:0;width:min(var(--w-content), calc(100vw - 56px));margin:0 auto;max-width:none}
.scene-grid--config-4 .scene-tile-media{aspect-ratio:1/1;background:#fff}
.scene-grid--config-4 .scene-tile-media img{object-fit:contain}
.scene-grid--config-4 .scene-nav{display:none}
.scene-grid--full .scene-head{max-width:min(var(--w-content), calc(100vw - 56px));margin:0 auto 40px;padding:0}
.scene-grid--full .scene-head h2{max-width:none}
.scene-grid--full .scene-head p{max-width:none}
.scene-grid--full .scene-track{padding:0 max(28px, calc((100vw - 1200px) / 2));scroll-padding-inline-start:max(28px, calc((100vw - 1200px) / 2))}
.scene-grid--full .scene-tile{width:min(var(--w-content), calc(100vw - 56px))}
.scene-grid .scene-tile.scene-tile--half{width:min(600px, calc(100vw - max(56px, calc((100vw - 1200px))) ))}
.scene-grid .scene-tile.scene-tile--half .scene-tile-media{aspect-ratio:9/10}
@media (max-width:780px){
  .scene-grid{padding:48px 0 64px}
  .scene-grid .scene-head{padding:0 16px;margin-bottom:28px}
  .scene-grid .scene-track{padding:0 16px;gap:12px}
  .scene-grid .scene-tile{width:88vw;gap:14px}
  .scene-grid .scene-tile-cap h3{font-size:22px}
  .scene-nav{display:none}
  .scene-grid--stack .scene-track{padding:0 16px;gap:16px}
  .scene-grid--2x2 .scene-track{grid-template-columns:1fr;padding:0 16px;gap:12px}
  .scene-grid--4x1 .scene-track{grid-template-columns:repeat(2,1fr);padding:0 16px;gap:12px}
  .scene-grid--config-4 .scene-track{grid-template-columns:repeat(2,1fr);padding:0 16px;gap:12px}
  .scene-grid--3x1 .scene-track{grid-template-columns:1fr;padding:0 16px;gap:12px}
}

/* ============================================================
   MACHINE VIDEO CAPTION — text block below a full-width video.
   ============================================================ */
.machine-video.machine-video--full + .machine-video-cap,
.machine-video-cap{max-width:var(--w-content);margin:18px auto 0;padding:0 28px;display:flex;flex-direction:column;gap:6px;text-align:left}
.machine-video-cap .overline{color:var(--steel-5);margin:0;display:block}
.machine-video-cap h3{margin:0;font-size:18px;font-weight:600;letter-spacing:-0.01em;line-height:1.25;color:var(--ink)}
.machine-video-cap p{margin:6px 0 0;color:var(--steel-5);font-size:14px;line-height:1.55;max-width:60ch}

/* ============================================================
   SPINDLE FEATURE — dark stats-driven section used by machine pages.
   ============================================================ */
.spindle-feature{padding:96px 28px 112px;background:#0a0a0a;color:#fff}
.spindle-feature-inner{max-width:var(--w-content);margin:0 auto}
.spindle-feature-head{text-align:center;display:flex;flex-direction:column;gap:14px;align-items:center;margin-bottom:8px}
.spindle-feature-head .overline{color:rgba(255,255,255,0.55);margin:0;display:block}
.spindle-feature-head h2{margin:0;font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:-0.02em;font-weight:500;color:#fff;max-width:24ch}
.spindle-feature-head p{margin:0;color:rgba(255,255,255,0.7);font-size:16px;line-height:1.65;max-width:62ch}
.spindle-stats{display:grid;grid-template-columns:repeat(4,1fr);margin:48px 0;border-top:1px solid rgba(255,255,255,0.12);border-bottom:1px solid rgba(255,255,255,0.12)}
.spindle-stat{text-align:center;padding:28px 16px;border-right:1px solid rgba(255,255,255,0.08)}
.spindle-stat:last-child{border-right:0}
.spindle-stat .v{font-size:clamp(26px,3vw,38px);font-weight:500;letter-spacing:-0.02em;color:#fff;line-height:1}
.spindle-stat .k{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-top:10px}
@media (max-width:780px){
  .spindle-feature{padding:64px 24px 80px}
  .spindle-stats{grid-template-columns:repeat(2,1fr)}
  .spindle-stat{border-right:0;border-bottom:1px solid rgba(255,255,255,0.08);padding:20px 12px}
  .spindle-stat:nth-child(even){border-right:0}
  .spindle-stat:nth-last-child(-n+2){border-bottom:0}
}

/* ============================================================
   TOOL STEPS — numbered alternating feature list.
   ============================================================ */
.tool-steps{padding:88px 28px 96px;background:#fff;max-width:var(--w-content);margin:0 auto}
.tool-steps-head{display:flex;flex-direction:column;gap:14px;margin-bottom:72px;max-width:36ch}
.tool-steps-head .overline{color:var(--steel-5);margin:0;display:block}
.tool-steps-head h2{margin:0;font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:-0.02em;font-weight:500;color:var(--ink)}
.tool-steps-list{display:flex;flex-direction:column;gap:64px}
.tool-step{display:flex;flex-direction:column;gap:20px}
.tool-step-media{border-radius:var(--img-radius);overflow:hidden;background:var(--steel-1)}
.tool-step-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
.tool-step-copy{display:flex;flex-direction:column;gap:8px}
.tool-step-num{font-family:'Inter Tight',sans-serif;font-size:13px;letter-spacing:.18em;color:var(--steel-4);text-transform:uppercase}
.tool-step-copy h3{margin:0;font-size:clamp(24px,2.6vw,32px);line-height:1.1;letter-spacing:-0.02em;font-weight:600;color:var(--ink);max-width:24ch}
.tool-step-copy p{margin:4px 0 0;color:var(--steel-5);font-size:15px;line-height:1.6;max-width:60ch}
@media (max-width:780px){
  .tool-steps{padding:56px 24px 72px}
  .tool-steps-head{margin-bottom:48px}
  .tool-steps-list{gap:40px}
}

/* ============================================================
   FEATURE BANNER — full-bleed product banner with overlay caption.
   Default variant: dark bg, right-aligned white text on a media image.
   --light: white bg, contained product shot, left-aligned dark text.
   --top: nudge below the fixed nav.
   Used by machine page tops (elara-2, lathe-3) as the hero pattern.
   ============================================================ */
.feature-banner{
  position:relative;width:100vw;
  height:auto;
  max-height:calc(100vh - var(--nav-h, 56px) - 80px);
  background:#000;overflow:hidden;
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
}
.feature-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
.feature-banner iframe.feature-banner-video{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:120%;height:120%;border:0;pointer-events:none;z-index:0;
}
.feature-banner-cap{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  right:max(var(--gutter), calc((100vw - var(--w-content)) / 2));left:auto;
  text-align:right;color:#fff;max-width:520px;
  display:flex;flex-direction:column;gap:10px;align-items:flex-end;
}
.feature-banner-cap .overline{color:rgba(255,255,255,0.78);margin:0;display:block;text-align:right}
.feature-banner-cap h2{margin:0;font-size:clamp(32px,3.6vw,48px);line-height:1.05;font-weight:500;letter-spacing:-0.02em;color:#fff;text-align:right}
.feature-banner-cap p{margin:0;color:rgba(255,255,255,0.88);font-size:16px;line-height:1.55;text-align:right}
.feature-banner--top{margin-top:var(--nav-h, 56px)}

.feature-banner--light{background:#fff}
.feature-banner--light .feature-banner-img-wrap{
  position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);
  height:50vh;background:#fff;
}
.feature-banner--light .feature-banner-img-wrap img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:contain;object-position:75% center;background:#fff;
}
.feature-banner--light .feature-banner-cap{
  right:auto;left:max(var(--gutter), calc((100vw - var(--w-content)) / 2));
  text-align:left;align-items:flex-start;
  max-width:520px;
}
.feature-banner--light .feature-banner-cap .overline{color:var(--steel-5);text-align:left}
.feature-banner--light .feature-banner-cap h2{color:var(--ink);text-align:left}
.feature-banner--light .feature-banner-cap p{color:var(--steel-5);text-align:left;font-size:16px;line-height:1.55}
@media (max-width:900px){
  .feature-banner{height:auto}
  .feature-banner-cap{left:16px;right:16px;top:auto;bottom:24px;transform:none;max-width:none;text-align:left;align-items:flex-start}
  .feature-banner-cap .overline,.feature-banner-cap h2,.feature-banner-cap p{text-align:left}
  .feature-banner--light .feature-banner-img-wrap{height:auto;top:0;bottom:auto;transform:none;position:relative}
  .feature-banner--light .feature-banner-cap{position:relative;top:auto;left:0;right:0;transform:none;padding:24px 16px;max-width:none}
}

/* ============================================================
   MEDIA PATTERNS — single source of truth for aspect ratios
   across the site. Per-page <style> blocks should NOT redeclare
   aspect-ratio on these classes; only grid-item classes (which
   live in this file too, near their pattern) define their own.

   16:9 default for everything that isn't a grid:
     hero, banner, carousel tile, inline-split, tool step.
   Grids keep their existing 1:1 / 3:4 / 4:3 ratios.
   ============================================================ */
.hero-media,
.hero-banner,
.feature-banner,
.banner-strip,
.machine-video-frame,
.case-banner-media,
.scene-tile-media,
.feature-media,
.belt-video-inner,
.tool-step-media {
  aspect-ratio: var(--ar-hero);
  height: auto;
  max-height: none;
}
/* Grid-pattern exceptions — keep these aspect ratios */
.scene-grid--2x2 .scene-tile-media,
.scene-grid--square .scene-tile-media,
.scene-grid--config-4 .scene-tile-media,
.scene-tile.scene-tile--half .scene-tile-media,
.elara-card-media,
.elara-holder-tile,
.spindle-media,
.spindle-detail-media,
.mega-card-media,
.image-strip .strip-tile,
.composite-banner .strip-tile,
.box-media,
.ball-screws-media {
  aspect-ratio: revert;
}

/* ============================================================
   UNIFIED PAGE PATTERNS — extracted from per-page <style> blocks
   2026-05-17. Single source of truth. All rules below define
   shared section patterns the JSX components rely on.
   Width tier: var(--w-content)=1200. Caption tier: 18px/14px.
   ============================================================ */

/* ============================================================
   HERO BANNER (homepage) — section.hero.hero--video.hero--split
   Full-bleed YouTube banner with poster, end-card, nav dots,
   and headline/CTA overlay. Used at top of index + capabilities.
   ============================================================ */
section.hero.hero--video{
  padding:0;gap:0;min-height:auto;background:#000;display:block;
}
section.hero.hero--video#top{padding-top:var(--nav-h, 56px)}
.hero-banner{
  position:relative;width:100vw;
  height:calc(100vh - var(--nav-h, 56px) - 80px);
  max-height:none;
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
  background:#000;overflow:hidden;
}
section.hero.hero--video .hero-video{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%, -50%);
  width:max(100%, 177.78vh);
  height:max(100%, 56.25vw);
  border:0;pointer-events:none;z-index:0;
}
section.hero.hero--video .hero-video-poster{
  position:absolute;inset:0;background:#0a0a0a;z-index:2;
  opacity:1;transition:opacity .5s ease;
}
section.hero.hero--video .hero-video-poster.is-hidden{opacity:0;pointer-events:none}
section.hero.hero--video .hero-end-poster{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center 25%;display:block;
  opacity:0;transition:opacity .5s ease;
  z-index:3;border-radius:0;pointer-events:none;
}
section.hero.hero--video .hero-end-poster.is-visible{opacity:1}
section.hero.hero--video .hero-banner::after{
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,0.25) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0) 60%, rgba(0,0,0,0.55) 100%);
}
.hero-overlay{
  position:absolute;left:0;right:0;top:10%;z-index:4;
  display:flex;flex-direction:column;gap:18px;align-items:center;
  padding:0 28px;pointer-events:none;
}
.hero-overlay > *{pointer-events:auto}
.hero-overlay .headline-stack{padding:0;align-items:center;text-align:center;max-width:900px}
.hero-overlay .headline-stack .overline{color:rgba(255,255,255,0.8)}
.hero-overlay .headline-stack h1,
.hero-overlay .hero-headline{
  color:#fff;margin:0;
  font-size:clamp(36px,4.8vw,64px);
  line-height:1.05;letter-spacing:-0.02em;font-weight:500;
}
.hero-overlay .headline-stack .sub{color:rgba(255,255,255,0.92)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.btn.ghost{background:rgba(255,255,255,0.78);color:var(--ink);border-color:rgba(10,10,10,0.18);backdrop-filter:blur(4px)}
.btn.ghost:hover{background:#fff;border-color:rgba(10,10,10,0.55)}
.hero-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:44px;height:44px;border-radius:4px;
  background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.3);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .15s ease,transform .15s ease;padding:0;
}
.hero-nav:hover{background:rgba(255,255,255,0.32);transform:translateY(-50%) scale(1.05)}
.hero-nav svg{width:18px;height:18px;fill:#fff}
.hero-nav--prev{left:24px}
.hero-nav--next{right:24px}
.hero-dots{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:5;
  display:flex;gap:10px;
}
.hero-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,0.4);border:0;cursor:pointer;
  transition:background .15s ease,transform .15s ease;padding:0;
}
.hero-dot:hover{background:rgba(255,255,255,0.7)}
.hero-dot.is-active{background:#fff;transform:scale(1.2)}
@media (max-width:900px){
  .hero-banner{height:auto;aspect-ratio:16/9;max-height:calc(100vh - var(--nav-h, 56px))}
  .hero-nav{width:38px;height:38px}
  .hero-nav--prev{left:12px}
  .hero-nav--next{right:12px}
  .hero-dots{bottom:16px}
  .hero-overlay{top:8%;padding:0 16px;gap:12px}
  .hero-overlay .headline-stack h1,
  .hero-overlay .hero-headline{font-size:clamp(28px,7vw,42px)}
}

/* Contained variant — same banner styling, constrained to content width */
section.hero.hero--video.hero--contained{padding:64px 28px;background:transparent}
section.hero.hero--video.hero--contained .hero-banner{
  width:100%;max-width:var(--w-content);height:auto;aspect-ratio:16/9;
  margin:0 auto;border-radius:var(--banner-radius);
}
section.hero.hero--video.hero--contained .hero-overlay{
  top:50%;bottom:auto;transform:translateY(-50%);padding:0 28px;
}
section.hero.hero--video.hero--contained .hero-banner::after{
  background:radial-gradient(ellipse 70% 50% at 50% 50%, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.15) 60%, rgba(0,0,0,0) 100%);
}
section.hero.hero--video.hero--contained .hero-overlay .hero-headline{
  text-shadow:0 2px 24px rgba(0,0,0,0.6),0 1px 3px rgba(0,0,0,0.5);
}
@media (max-width:900px){
  section.hero.hero--video.hero--contained{padding:40px 16px}
  section.hero.hero--video.hero--contained .hero-banner{border-radius:var(--img-radius)}
  section.hero.hero--video.hero--contained .hero-overlay{top:50%;padding:0 16px}
}

/* ============================================================
   RAIL-SECTION — product lineup row on homepage.
   ============================================================ */
.rail-section{background:#fff}
section.stage.rail-section{min-height:auto;padding-top:96px;padding-bottom:96px}
.rail{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  max-width:calc(var(--w-content) + 56px);margin:36px auto 0;width:100%;padding:0 28px;
  box-sizing:border-box;
}
.rail .card{
  display:flex;flex-direction:column;gap:10px;
  background:#fff;padding:18px;border-radius:14px;
  text-align:center;border:1px solid var(--steel-2);
  transition:transform .18s ease,border-color .18s ease;
}
.rail .card:hover{transform:translateY(-3px);border-color:var(--steel-3)}
.rail .card .media{aspect-ratio:4/3;background:#fff;border-radius:var(--img-radius);overflow:hidden;position:relative}
.rail .card .media .ph,.rail .card .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block;border-radius:0}
.rail .card .info{display:flex;flex-direction:column;gap:4px;margin-top:4px}
.rail .card .info .name{font-size:17px;font-weight:600;letter-spacing:-0.01em;color:var(--ink)}
.rail .card .info .tagline{font-size:13.5px;color:var(--steel-5);line-height:1.45;max-width:24ch;margin:0 auto}
.rail .card .row{display:flex;justify-content:center;margin-top:6px}
.rail .card .row .btn{min-width:auto;padding:8px 18px;font-size:11.5px}
@media (max-width:1100px){.rail{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.rail{grid-template-columns:1fr;padding:0 16px}}

/* ============================================================
   VIDEO PREVIEW GRID — 3-up YT thumbnails with play overlay.
   ============================================================ */
.vid-preview{padding:64px 28px;background:#fff;max-width:var(--w-content);margin:0 auto;box-sizing:border-box}
.vid-preview-head{max-width:780px;margin:0 auto 36px;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}
.vid-preview-head h2{margin:0;font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:-0.02em;font-weight:500;color:var(--ink);max-width:24ch}
.vid-preview-head p{margin:0;color:var(--steel-5);font-size:16px;line-height:1.65;max-width:62ch}
.vid-preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.vid-preview-card{display:flex;flex-direction:column;gap:12px;text-decoration:none;color:inherit;cursor:pointer}
.vid-preview-media{position:relative;aspect-ratio:16/9;border-radius:var(--banner-radius);overflow:hidden;background:#0a0a0a;transition:transform .2s ease}
.vid-preview-card:hover .vid-preview-media{transform:translateY(-2px)}
.vid-preview-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
.vid-preview-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.vid-preview-play svg{width:54px;height:54px;fill:rgba(255,255,255,.94);filter:drop-shadow(0 2px 8px rgba(0,0,0,.45))}
.vid-preview-cap{font-size:18px;font-weight:600;color:var(--ink);padding:0 4px;line-height:1.25;letter-spacing:-0.01em}
.vid-preview-cta{display:flex;justify-content:center;margin-top:32px}
@media (max-width:900px){.vid-preview-grid{grid-template-columns:1fr;gap:16px}.vid-preview{padding:48px 16px}}

/* ============================================================
   SCENE GRID add-ons — CTA tile + overlay + video tile.
   ============================================================ */
.scene-grid .scene-tile--cta .scene-tile-media{
  background:#fff;border:1px solid var(--steel-2);
  display:flex;align-items:center;justify-content:center;text-align:center;padding:28px;
  aspect-ratio:var(--ar-square);
}
.scene-cta-inner{display:flex;flex-direction:column;align-items:center;gap:14px;max-width:340px}
.scene-cta-overline{display:block;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-5);margin:0;font-family:'Inter Tight',sans-serif}
.scene-cta-head{margin:0;font-size:clamp(28px,3.2vw,42px);line-height:1.1;letter-spacing:-0.015em;font-weight:600;color:var(--ink)}
.scene-grid .scene-tile-media iframe.scene-tile-video{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:120%;height:135%;border:0;pointer-events:none;display:block;
}
.scene-grid .scene-tile-cta{position:absolute;left:20px;bottom:20px;z-index:3;display:flex;gap:10px}
@media (max-width:780px){.scene-grid .scene-tile-cta{left:14px;bottom:14px;gap:8px}}
.scene-grid .scene-tile-media .scene-tile-overlay{
  position:absolute;left:48px;right:24px;top:50%;transform:translateY(-50%);
  z-index:3;pointer-events:none;
}
.scene-grid .scene-tile-media .scene-tile-overlay h2{
  margin:0;color:#fff;font-size:clamp(24px,2.6vw,38px);
  line-height:1.1;letter-spacing:-0.015em;font-weight:600;
  text-shadow:0 2px 14px rgba(0,0,0,0.45);text-align:left;max-width:18ch;
}
.scene-grid .scene-tile-media:has(.scene-tile-overlay)::after{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(90deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0) 60%);
}
@media (max-width:780px){
  .scene-grid .scene-tile-media .scene-tile-overlay{left:24px;right:16px}
  .scene-grid .scene-tile-media .scene-tile-overlay h2{font-size:clamp(20px,5vw,28px)}
}

/* ============================================================
   BELT VIDEO frame iframe positioning (cover-overscan).
   ============================================================ */
.belt-video iframe.belt-video-frame-2{
  position:absolute;inset:0;width:100%;height:100%;
  border:0;display:block;border-radius:0;pointer-events:none;
}
.belt-video .belt-video-inner{aspect-ratio:var(--ar-hero)}

/* ============================================================
   CASE BANNER video positioning (cover-overscan inside compact rail).
   ============================================================ */
iframe.case-banner-video{
  position:absolute;inset:0;width:100%;height:100%;border:0;
  display:block;pointer-events:none;
}

/* ============================================================
   SQUARE LOOP VID — used in mira-6s ball-screws tile.
   ============================================================ */
iframe.square-loop-vid{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:auto;height:auto;
  min-width:100%;min-height:100%;
  aspect-ratio:16/9;
  border:0;pointer-events:none;
}

/* ============================================================
   FEATURE--INTRO — text-left, image-right 1200 panel with rounded corners.
   First "feature" on mira-6s/mira-j9 pages.
   ============================================================ */
.features .feature.feature--intro{
  display:grid !important;
  grid-template-columns:1fr 1fr;gap:0;
  width:min(var(--w-content), calc(100vw - 56px));
  max-width:none;
  margin:160px auto 64px;
  padding:0;
  background:#fff;color:var(--ink);
  align-items:stretch;
  border-radius:var(--banner-radius);
  overflow:hidden;
  height:560px;
  direction:ltr;
}
.feature--intro .feature-copy{
  padding:48px 6% 48px 48px;
  display:flex;flex-direction:column;justify-content:center;
  gap:14px;text-align:left;align-items:flex-start;
  position:static;transform:none;margin:0;max-width:none;color:var(--ink);
}
.feature--intro .intro-headline{margin:0;font-size:clamp(28px,3vw,40px);font-weight:500;line-height:1.05;letter-spacing:-0.02em;color:var(--ink)}
.feature--intro .intro-subhead{margin:0;font-size:clamp(18px,1.6vw,22px);font-weight:600;line-height:1.2;letter-spacing:-0.01em;color:var(--ink)}
.feature--intro .feature-copy p{margin:0;color:var(--steel-5);font-size:15px;line-height:1.6;max-width:60ch;text-align:left}
.feature--intro .feature-media{
  position:relative;height:100%;min-height:360px;
  border-radius:0;overflow:hidden;background:#fff;
  aspect-ratio:auto;
}
.feature--intro .feature-media .ph,
.feature--intro .feature-media .ph.has-img{position:absolute;inset:0;background:#fff}
.feature--intro .feature-media .ph.has-img img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;border-radius:0;
}
body[data-page="elara-2"] .feature--intro .feature-media .ph.has-img img{object-fit:contain}
body[data-page="mira-j9"] .feature--intro .feature-media .ph.has-img img{object-fit:contain}
img[src*="banners/03.jpg"],
img[src*="banners/03.webp"]{filter:brightness(1.08)}
body[data-page="lathe-3"] .feature--intro .feature-media .ph.has-img img{filter:brightness(1.03) contrast(1.02);object-fit:contain}
@media (max-width:900px){
  .features .feature.feature--intro{
    grid-template-columns:1fr;
    width:calc(100% - 32px);
    margin:48px auto 32px;
    min-height:0;
  }
  .feature--intro .feature-copy{padding:32px 24px}
  .feature--intro .feature-media{min-height:240px;aspect-ratio:4/3}
}

/* ============================================================
   FEATURE--BANNER — two usages, distinguished by sibling .banner-cap.
   A) With banner-cap inside (mira-6s):
      Tesla-style — media is full-width 16:9 at 1200, caption rendered
      via separate .banner-cap below. Internal .feature-copy is hidden.
   B) Without banner-cap (mira-j9):
      2-column split — media on one side, .feature-copy on the other.
   ============================================================ */
.features .feature.feature--banner{
  width:min(var(--w-content), calc(100vw - 56px));
  max-width:none;
  margin:0 auto 64px;
  padding:0;
  background:transparent;
  border-radius:0;
  overflow:visible;
  position:relative;
  direction:ltr;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}
.features .feature.feature--banner > *{direction:ltr}
.features .feature.feature--banner .feature-media{
  position:relative;width:100%;height:auto;margin:0;
  border-radius:var(--banner-radius);overflow:hidden;background:#0a0a0a;
  aspect-ratio:var(--ar-hero);
}
.features .feature.feature--banner .feature-media .ph,
.features .feature.feature--banner .feature-media .ph.has-img{
  position:absolute;inset:0;background:#0a0a0a;padding:0;
}
.features .feature.feature--banner .feature-media .ph.has-img img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;padding:0;display:block;border-radius:0;
}
.features .feature.feature--banner .feature-media::after{display:none}
.features .feature.feature--banner .feature-copy{
  display:flex;flex-direction:column;gap:14px;
  position:static;transform:none;
  max-width:none;margin:0;padding:0;
  text-align:left;align-items:flex-start;
  color:var(--ink);
}
.features .feature.feature--banner .feature-copy h2{
  color:var(--ink);text-align:left;margin:0;
  font-size:clamp(28px,3vw,40px);font-weight:500;
  line-height:1.1;letter-spacing:-0.02em;
}
.features .feature.feature--banner .feature-copy p{
  color:var(--steel-5);text-align:left;margin:0;
  font-size:15px;line-height:1.6;max-width:60ch;
}
.features .feature.feature--banner .feature-copy .overline{
  color:var(--steel-5);text-align:left;
}
/* Tesla-style variant: when a .banner-cap is present, hide the in-article copy
   and revert to single-column with the media full-width above the cap. */
.features .feature.feature--banner:has(> .banner-cap){
  display:block;grid-template-columns:none;gap:0;
}
.features .feature.feature--banner:has(> .banner-cap) > .feature-copy{display:none}
/* Variant: light bg, image contained (used by feature--banner-light) */
.features .feature.feature--banner.feature--banner-light .feature-media{background:#fff;aspect-ratio:var(--ar-hero)}
.features .feature.feature--banner.feature--banner-light .feature-media .ph,
.features .feature.feature--banner.feature--banner-light .feature-media .ph.has-img{background:#fff}
.features .feature.feature--banner.feature--banner-light .feature-media .ph.has-img img{object-fit:contain;object-position:center}
@media (max-width:900px){
  .features .feature.feature--banner{
    grid-template-columns:1fr;gap:24px;
    width:calc(100% - 32px);
  }
}

/* ============================================================
   FEATURE--SPLIT — dark 2-col panel (image+copy) at 1200.
   ============================================================ */
.features .feature.feature--split{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  width:min(var(--w-content), calc(100vw - 56px));
  max-width:none;
  margin:0 auto 64px;
  padding:0;
  background:#0a0a0a;color:#fff;
  align-items:stretch;
  border-radius:var(--banner-radius);
  overflow:hidden;
  direction:ltr;
}
.features .feature.feature--split > *{direction:ltr}
.features .feature.feature--split .feature-media{
  position:relative;height:auto;margin:0;border-radius:0;background:#0a0a0a;overflow:hidden;
  aspect-ratio:auto;
}
.features .feature.feature--split .feature-media .ph,
.features .feature.feature--split .feature-media .ph.has-img{position:absolute;inset:0;background:#0a0a0a}
.features .feature.feature--split .feature-media .ph.has-img img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;padding:0;display:block;border-radius:0;
}
.features .feature.feature--split .feature-copy{
  padding:48px 8%;
  display:flex;flex-direction:column;justify-content:center;gap:14px;
  position:static;transform:none;max-width:none;margin:0;
}
.features .feature.feature--split .feature-copy h2{
  margin:0;color:#fff;font-size:clamp(32px,3.6vw,48px);
  line-height:1.05;letter-spacing:-0.02em;font-weight:500;max-width:none;
  text-align:left;
}
.features .feature.feature--split .feature-copy p{
  margin:0;color:rgba(255,255,255,0.85);
  font-size:15px;line-height:1.7;max-width:none;text-align:left;
}
@media (max-width:900px){
  .features .feature.feature--split{
    grid-template-columns:1fr;
    width:calc(100% - 32px);
  }
  .features .feature.feature--split .feature-copy{padding:32px 24px}
  .features .feature.feature--split .feature-media{min-height:220px;aspect-ratio:16/9}
}

/* ============================================================
   BOX-CONTENTS — "What's in the box" 2-col panel with bullet list.
   ============================================================ */
.box-contents,
.features .box-contents{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  width:min(var(--w-content), calc(100vw - 56px));
  max-width:none;
  position:relative;left:50%;transform:translateX(-50%);
  margin:0 auto 64px;
  padding:48px;
  aspect-ratio:var(--ar-hero);
  box-sizing:border-box;
  background:#f4f5f6;border-radius:var(--banner-radius);
  align-items:stretch;
}
.box-contents .box-copy{display:flex;flex-direction:column;justify-content:center;height:100%}
.box-contents .box-copy h2{
  margin:0 0 20px;
  font-size:clamp(32px,3.6vw,48px);line-height:1.05;
  letter-spacing:-0.02em;font-weight:500;color:var(--ink);
}
.box-contents .box-copy ul{
  margin:0;padding:0;list-style:none;
  color:var(--steel-5);font-size:16px;line-height:1.65;font-weight:400;
  columns:2;column-gap:32px;
}
.box-contents .box-copy ul li{margin:0 0 8px;padding:0;break-inside:avoid}
.box-contents .box-media{
  position:relative;height:100%;align-self:stretch;
  border-radius:var(--img-radius);overflow:hidden;background:#fff;
}
.box-contents .box-media img{
  width:100%;height:100%;object-fit:cover;display:block;border-radius:0;
}
@media (max-width:900px){
  .box-contents,
  .features .box-contents{
    grid-template-columns:1fr;gap:32px;padding:32px;
    width:calc(100% - 32px);
  }
  .box-contents .box-copy ul{columns:1}
}

/* ============================================================
   LATHE-TRIO — 3-up image grid used on lathe-3.
   ============================================================ */
.lathe-trio{padding:88px 28px;background:#fff;max-width:var(--w-content);margin:0 auto;box-sizing:border-box}
.lathe-trio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.lathe-trio-media{aspect-ratio:var(--ar-square);overflow:hidden;background:var(--steel-1);border-radius:14px;position:relative}
.lathe-trio-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
@media (max-width:900px){
  .lathe-trio{padding:48px 16px}
  .lathe-trio-grid{grid-template-columns:1fr;gap:12px}
}

/* ============================================================
   STATS-SECTION — dark stats block used on mira-j9.
   ============================================================ */
.stats-section{background:#0a0a0a;color:#fff}
section.stage.stats-section{min-height:auto;padding-top:96px;padding-bottom:96px}
.stats-section .overline{color:#6b6e73}
.stats-section h2{color:#fff}
.stats-section .sub{color:#a5a8ad}

/* ============================================================
   FEATURES container — stack rhythm. Banner/split/intro all use
   their own margins so the .features wrapper just acts as a frame.
   ============================================================ */
section.features{padding-top:0;padding-bottom:64px;gap:0}
.features .feature:not(.feature--banner):not(.feature--split):not(.feature--intro){margin-top:96px;margin-bottom:0}
.features .feature:not(.feature--banner):not(.feature--split):not(.feature--intro):first-child{margin-top:0}
.features .feature--banner,
.features .feature--split,
.features .machine-video--breakout{margin-top:0;margin-bottom:64px}
.features .specs-section{
  width:100vw;max-width:none;
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
}
/* Scene-grid inside features: break out to full viewport */
.features > .scene-grid{
  width:100vw;max-width:none;
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
}

/* ============================================================
   FOLDED PER-PAGE STYLES
   Merged 2026-05-17 from <style is:global> blocks that used to
   live in src/pages/*.astro. site.css is now the single CSS
   source per CLAUDE.md.
   Each block is scoped to its page via CSS nesting under
   body[data-page="..."] so selectors only apply where they did
   before. Shared template blocks (news posts, legal pages) are
   scoped to a multi-page :is() selector.
   ============================================================ */

/* --- shared template: news/ethercat-integration-in-ns-cnc-mini-machines, news/mira-j9-5-axis-heavy-duty-mill-with-15-tool-atc, news/montana-tech-installs-two-elara-2-systems --- */
body:is([data-page="news/ethercat-integration-in-ns-cnc-mini-machines"], [data-page="news/mira-j9-5-axis-heavy-duty-mill-with-15-tool-atc"], [data-page="news/montana-tech-installs-two-elara-2-systems"]) {
  .post-image{max-width:1200px;margin:0 auto;padding:0 28px}
  .post-image img{display:block;width:100%;height:auto;max-height:520px;object-fit:contain}

  .post-body{max-width:740px;margin:0 auto;padding:56px 28px 96px;font-size:16px;line-height:1.75;color:var(--ink-2)}
  .post-body p{margin:0 0 16px;white-space:pre-wrap}
  .post-back{max-width:740px;margin:0 auto;padding:0 28px 32px}
  .post-back a{font-family:'Inter Tight',sans-serif;font-size:12px;letter-spacing:.14em;color:var(--accent-ink);text-transform:uppercase}
  @media (max-width: 900px){
    .post-body{padding:40px 20px 72px;font-size:15.5px}
    .post-image{padding:0 20px}
  }
}

/* --- shared template: privacy, terms, warranty --- */
body:is([data-page="privacy"], [data-page="terms"], [data-page="warranty"]) {
  .legal-body{background:#fff;padding:80px 28px 120px}
  .legal-inner{max-width:740px;margin:0 auto;font-size:15.5px;line-height:1.7;color:var(--ink-2)}
  .legal-inner h2{font-size:24px;font-weight:500;letter-spacing:-0.01em;margin:48px 0 14px;color:var(--ink);padding-bottom:10px;border-bottom:1px solid var(--steel-2)}
  .legal-inner h2:first-child{margin-top:0}
  .legal-inner h3{font-size:17px;font-weight:500;margin:28px 0 8px;color:var(--ink)}
  .legal-inner p{margin:0 0 14px}
  .legal-inner p:last-child{margin-bottom:0}
  .legal-inner strong{color:var(--ink);font-weight:500}
  .legal-inner ul{margin:0 0 14px;padding-left:22px}
  .legal-inner ul li{margin-bottom:6px}
  .legal-inner .legal-table{display:grid;grid-template-columns:200px 1fr;gap:0;border:1px solid var(--steel-2);margin:20px 0}
  .legal-inner .legal-table > div{padding:12px 18px;border-bottom:1px solid var(--steel-2)}
  .legal-inner .legal-table > div:nth-last-child(-n+2){border-bottom:0}
  .legal-inner .legal-table > div:nth-child(odd){background:#fafafa;font-weight:500;font-size:14px}
  .legal-inner .legal-table > div:nth-child(even){font-size:14px;color:var(--steel-5)}
  @media (max-width: 640px){.legal-inner .legal-table{grid-template-columns:1fr}.legal-inner .legal-table > div{border-bottom:1px solid var(--steel-2)!important}}
  .legal-updated{margin-top:64px;padding-top:24px;border-top:1px solid var(--steel-2);font-family:'Inter Tight',sans-serif;font-size:11px;color:var(--steel-4);letter-spacing:.12em;text-transform:uppercase}
}

/* === PAGE: about === */
body[data-page="about"] {
  /* ABOUT HERO */

  /* STORY */
  .story{padding:96px 28px;border-top:1px solid var(--steel-2)}
  .story:nth-of-type(odd){background:#fff}
  .story:nth-of-type(even){background:#fafafa}
  .story-inner{max-width:780px;margin:0 auto;text-align:center}
  .story-inner .overline{margin-bottom:14px;display:block}
  .story-inner h2{margin:0 0 28px;font-size:clamp(32px,3.6vw,48px);line-height:1.05}
  .story-body{font-size:16px;line-height:1.7;color:var(--steel-5);max-width:62ch;margin:0 auto;text-align:center}
  .story-body p{margin:0 0 18px}
  .story-body p:last-child{margin:0}
  .story-body em{color:var(--ink);font-style:normal;font-weight:500}

  /* MILESTONES — visual card grid (replaces the old table layout) */
  .milestones{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .milestones-inner{max-width:1200px;margin:0 auto;text-align:center}
  .milestones-inner .overline{display:block;margin-bottom:14px}
  .milestones-inner h2{margin:0 0 12px;font-size:clamp(32px,3.6vw,48px);letter-spacing:-0.02em}
  .milestones-lead{color:var(--steel-5);font-size:16px;max-width:560px;margin:0 auto 48px;line-height:1.6}
  .milestones-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px 24px;text-align:left}
  .milestone-card{background:#fff;border:1px solid var(--steel-2);display:flex;flex-direction:column;transition:border-color .2s ease,transform .2s ease}
  .milestone-card:hover{border-color:var(--ink);transform:translateY(-2px)}
  .milestone-media{aspect-ratio:4/3;background:var(--steel-1);overflow:hidden;position:relative}
  .milestone-media img{width:100%;height:100%;object-fit:cover;display:block}
  .milestone-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:4px}
  .milestone-year{font-size:10.5px;letter-spacing:.18em;color:var(--accent-ink);text-transform:uppercase}
  .milestone-name{font-size:18px;font-weight:500;letter-spacing:-0.01em;color:var(--ink);margin-top:2px}
  .milestone-note{font-size:13.5px;color:var(--steel-5);line-height:1.55;margin-top:4px}
  @media (max-width:1100px){.milestones-grid{grid-template-columns:repeat(3,1fr)}}
  @media (max-width:800px){.milestones-grid{grid-template-columns:repeat(2,1fr);gap:20px 16px}}
  @media (max-width:480px){.milestones-grid{grid-template-columns:1fr}}

  /* PARTNERS */
  .partners{padding:96px 28px;background:#fafafa;border-top:1px solid var(--steel-2)}
  .partners-inner{max-width:var(--w-content);margin:0 auto;text-align:center}
  .partners-inner .overline{display:block;margin-bottom:14px}
  .partners-inner > h2{margin:0 0 18px;font-size:clamp(32px,3.6vw,48px);letter-spacing:-0.02em}
  .partners-inner > div > h2{margin:0 0 18px;font-size:clamp(32px,3.6vw,48px);letter-spacing:-0.02em}
  .partners-lead{margin:0 auto 48px;max-width:62ch;color:var(--steel-5);font-size:16px;line-height:1.7}
  .partner-list{display:grid;grid-template-columns:1fr 1fr;gap:48px;text-align:center}
  .partner{display:flex;flex-direction:column;align-items:center;gap:14px}
  .partner-logo{max-width:200px;max-height:90px;width:auto;height:auto;object-fit:contain;display:block}
  .partner--full{display:flex;flex-direction:column;align-items:stretch;gap:18px;max-width:var(--w-content);margin:0 auto;text-align:left}
  .partner-banner{width:auto;max-width:100%;max-height:600px;height:auto;display:block;margin:0 auto;border-radius:var(--banner-radius);object-fit:contain}
  .partner-cap{padding:24px 0 0;display:flex;flex-direction:column;gap:18px;align-items:center;text-align:center;max-width:780px;margin:0 auto}
  .partner-cap--above{padding:0 0 32px}
  .partner-cap h3{margin:0;font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:-0.02em;font-weight:500;color:var(--ink)}
  .partner-cap p{margin:0;color:var(--steel-5);font-size:16px;line-height:1.7;max-width:62ch}
  .partner h3{font-size:22px;margin:0;font-weight:500;letter-spacing:-0.01em}
  .partner p{font-size:15px;line-height:1.6;color:var(--steel-5);margin:0 auto;max-width:46ch}
  @media (max-width: 900px){.partner-list{grid-template-columns:1fr;gap:32px}}

  /* Force the nav into its solid (white) state — the dark hero makes the
     default transparent nav illegible. */
  .nav-wrap .nav{background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2)}

  section.page-hero.page-hero-banner .page-hero-banner-img img{object-position:center top}

  /* About page hero: full-bleed image with the existing headline overlaid.
     Keeps the page-hero--tall size (70vh min-height). */
  section.page-hero.page-hero--tall.page-hero-banner{
    position:relative;
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    background:#000;
    overflow:hidden;
  }
  section.page-hero.page-hero--tall.page-hero-banner .page-hero-banner-img{
    position:absolute !important;
    inset:0 !important;
    width:auto !important;
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
    background:#000;
  }
  section.page-hero.page-hero--tall.page-hero-banner .page-hero-banner-img img{
    width:100%;height:100%;
    object-fit:cover;object-position:center center;
    display:block;
  }
  section.page-hero.page-hero--tall.page-hero-banner .page-hero-banner-img::after{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.15) 35%, rgba(0,0,0,0.15) 65%, rgba(0,0,0,0.55) 100%);
    pointer-events:none;
  }
  section.page-hero.page-hero--tall.page-hero-banner .headline-stack{position:relative;z-index:2;color:#fff}
  section.page-hero.page-hero--tall.page-hero-banner .headline-stack .overline{color:#fff}
  section.page-hero.page-hero--tall.page-hero-banner .headline-stack h1{color:#fff}
  section.page-hero.page-hero--tall.page-hero-banner .headline-stack .sub{color:#fff}
  section.page-hero.page-hero--tall.page-hero-banner .telemetry{position:relative;z-index:2;color:#fff}
  section.page-hero.page-hero--tall.page-hero-banner .telemetry .bar{background:rgba(255,255,255,0.18)}
}

/* === PAGE: account === */
body[data-page="account"] {
  .account-main{min-height:calc(100vh - var(--nav-h));padding:128px 28px 80px;background:#fafafa;display:flex;align-items:center;justify-content:center}
  .account-card{max-width:420px;width:100%;background:#fff;padding:48px 40px;border:1px solid var(--steel-2);display:flex;flex-direction:column;gap:18px}
  .account-card .overline{display:block;margin-bottom:8px}
  .account-card h1{font-size:32px;line-height:1.1;margin:0;font-weight:500;letter-spacing:-0.02em}
  .account-sub{font-size:14px;color:var(--steel-5);line-height:1.5;margin-bottom:12px}
  .account-form{display:flex;flex-direction:column;gap:14px}
  .account-form label{display:flex;flex-direction:column;gap:6px}
  .account-form label > span{font-size:11px;color:var(--steel-5);letter-spacing:.12em;text-transform:uppercase;font-family:'Inter Tight',sans-serif}
  .account-form input{font-family:inherit;font-size:15px;padding:12px 14px;border:1px solid var(--steel-2);background:#fff;border-radius:2px;transition:border-color .18s ease}
  .account-form input:focus{outline:none;border-color:var(--ink)}
  .account-divider{display:flex;align-items:center;gap:12px;margin:8px 0;color:var(--steel-4);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
  .account-divider::before,.account-divider::after{content:'';flex:1;height:1px;background:var(--steel-2)}
  .account-meta{display:flex;justify-content:space-between;gap:12px;padding-top:16px;border-top:1px solid var(--steel-2);font-size:12px;margin-top:8px}
  .account-meta a{color:var(--steel-5)}
  .account-meta a:hover{color:var(--accent-ink)}
}

/* === PAGE: applications === */
body[data-page="applications"] {
  .app-hero{min-height:50vh;padding-top:112px;padding-bottom:48px;background:radial-gradient(ellipse 70% 50% at 50% 40%,#f6f7f8 0%,#eef0f2 60%,#e2e4e7 100%)}
  .industry-switch{display:grid;grid-template-columns:320px 1fr;gap:1px;background:var(--steel-2);border-top:1px solid var(--steel-2);border-bottom:1px solid var(--steel-2)}
  .ind-list{background:#fff;display:flex;flex-direction:column}
  .ind-item{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:22px 24px;border-bottom:1px solid var(--steel-2);text-align:left;font-size:16px;color:var(--steel-5);transition:all .18s ease;background:#fff}
  .ind-item:last-child{border-bottom:0}
  .ind-item .n{font-size:11px;color:var(--steel-4);letter-spacing:.12em}
  .ind-item .t{font-weight:500;color:var(--ink-2);font-size:17px;letter-spacing:-0.01em}
  .ind-item .k{font-size:10.5px;color:var(--steel-4);letter-spacing:.16em}
  .ind-item:hover{background:#fafafa;color:var(--ink)}
  .ind-item.active{background:#0a0a0a;color:#fff}
  .ind-item.active .t{color:#fff}
  .ind-item.active .n,.ind-item.active .k{color:#a5a8ad}
  .ind-panel{background:#fff;display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:520px}
  .ind-media{position:relative}
  .ind-media .ph{position:absolute;inset:0}
  .ph.has-img{overflow:hidden;background:none}
  .ph.has-img::before{display:none}
  .ph.has-img img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}
  .ind-copy{padding:64px;display:flex;flex-direction:column;gap:14px;justify-content:center}
  .ind-copy h2{font-size:clamp(32px,3.6vw,48px);line-height:1.05}
  .ind-copy p{color:var(--steel-5);font-size:15.5px;line-height:1.65;max-width:52ch;margin:0}
  .ind-copy .chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
  .ind-copy .chip{padding:5px 12px;border:1px solid var(--steel-2);border-radius:99px;font-size:11.5px;font-family:'Inter Tight',sans-serif;letter-spacing:.08em;color:var(--steel-5);background:#fafafa}
  @media (max-width: 900px){.industry-switch{grid-template-columns:1fr}.ind-list{flex-direction:row;overflow-x:auto}.ind-item{flex:0 0 auto;border-bottom:0;border-right:1px solid var(--steel-2)}.ind-panel{grid-template-columns:1fr}.ind-copy{padding:36px 24px}}

  .case-grid{padding:96px 28px;max-width:1200px;margin:0 auto}
  .case-grid .grid{margin-top:40px;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
  @media (max-width: 900px){.case-grid .grid{grid-template-columns:1fr}}
  .case{display:flex;flex-direction:column;background:#fff;border:1px solid var(--steel-2);transition:border-color .2s ease,transform .2s ease}
  .case:hover{border-color:var(--ink);transform:translateY(-2px)}
  .case-media{aspect-ratio:16/9;position:relative}
  .case-media .ph{position:absolute;inset:0}
  .case-body{padding:24px 26px;display:flex;flex-direction:column;gap:8px}
  .case-meta{font-size:10.5px;letter-spacing:.16em;color:var(--steel-4);text-transform:uppercase}
  .case-t{font-size:22px;font-weight:500;letter-spacing:-0.01em;line-height:1.25}
  .case-m{font-size:12px;color:var(--accent-ink);letter-spacing:.04em}
}

/* === PAGE: contact === */
body[data-page="contact"] {
  .contact-main{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .contact-inner{max-width:880px;margin:0 auto}
  .hq-section .overline{display:block;margin-bottom:14px}
  .hq-name-large{font-size:28px;font-weight:500;letter-spacing:-0.02em;margin-bottom:36px}
  .hq-details{display:grid;grid-template-columns:repeat(2,1fr);gap:28px 40px}
  .hq-details > div{display:flex;flex-direction:column;gap:6px}
  .hq-label{font-size:10.5px;color:var(--steel-4);letter-spacing:.18em;text-transform:uppercase}
  .hq-details > div > div:last-child{font-size:15px;line-height:1.5;color:var(--ink)}
  .hq-details a{color:var(--accent-ink);border-bottom:1px solid currentColor}
  .hq-cta{margin-top:48px;padding-top:28px;border-top:1px solid var(--steel-2);font-size:16px;color:var(--steel-5);line-height:1.6}
  @media (max-width: 680px){.hq-details{grid-template-columns:1fr}}

  .dealers{padding:96px 28px;background:#fafafa;border-top:1px solid var(--steel-2)}
  .dealers-inner{max-width:var(--w-content);margin:0 auto;text-align:center}
  .dealers-inner .overline{display:block;margin-bottom:14px}
  .dealers-inner h2{margin:0 0 48px;font-size:clamp(28px,3.2vw,40px)}
  .dealer-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,320px));gap:24px;justify-content:center}
  .dealer{background:#fff;padding:26px 26px 30px;border:1px solid var(--steel-2);display:flex;flex-direction:column;gap:6px;text-align:left;transition:border-color .2s ease,transform .2s ease}
  .dealer:hover{border-color:var(--ink);transform:translateY(-2px)}
  .dealer-region{font-size:10.5px;color:var(--steel-5);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
  .dealer-name{font-size:18px;font-weight:500;letter-spacing:-0.01em}
  .dealer-addr{font-size:14px;color:var(--steel-5);line-height:1.5;margin-top:4px}
  .dealer-contact{font-size:12px;color:var(--ink);line-height:1.6;margin-top:8px;word-break:break-word}

  /* Force the nav into its solid (white) state — the dark banner hero makes
     the default transparent nav illegible. */
  .nav-wrap .nav{background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2)}

  /* Page-hero banner: full-bleed image with the headline-stack overlaid. */
  section.page-hero.page-hero-banner{
    position:relative;
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    padding:var(--nav-h, 56px) 0 0;
    min-height:50vh;
    height:auto;
    max-height:none;
    background:#000;
    overflow:hidden;
    display:block;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img{
    position:absolute !important;
    top:var(--nav-h, 56px) !important;
    left:0 !important;right:0 !important;bottom:0 !important;
    width:auto !important;
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
    background:#000;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img img{
    width:100%;height:100%;
    object-fit:cover;object-position:center center;
    display:block;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img::after{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.15) 35%, rgba(0,0,0,0.15) 65%, rgba(0,0,0,0.55) 100%);
    pointer-events:none;
  }
  section.page-hero.page-hero-banner .headline-stack{
    position:absolute;
    inset:var(--nav-h, 56px) 0 0 0;
    z-index:2;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    gap:14px;
    padding:28px;
    text-align:center;
    color:#fff;
  }
  section.page-hero.page-hero-banner .headline-stack .overline{color:#fff;margin:0;display:block}
  section.page-hero.page-hero-banner .headline-stack h1{color:#fff;margin:0;max-width:24ch}
  section.page-hero.page-hero-banner .headline-stack .sub{color:#fff;margin:0;display:block;max-width:560px}
}

/* === PAGE: custom-machines === */
body[data-page="custom-machines"] {
  .custom-video{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .custom-video-inner{max-width:1200px;margin:0 auto}
  .custom-video-head{text-align:center;margin-bottom:40px}
  .custom-video-head .overline{display:block;margin-bottom:10px}
  .custom-video-head h2{font-size:clamp(28px,3.2vw,40px);margin:0 0 10px;letter-spacing:-0.02em}
  .custom-video-head p{font-size:15px;color:var(--steel-5);margin:0 auto;max-width:60ch;line-height:1.6}
  .machine-video-grid.three{grid-template-columns:repeat(3,1fr)}
  @media (max-width:1100px){.machine-video-grid.three{grid-template-columns:1fr 1fr}}
  @media (max-width:700px){.machine-video-grid.three{grid-template-columns:1fr}}
  .custom-video-label{margin-top:10px;font-size:12px;color:var(--steel-5);letter-spacing:.04em;text-align:center}
  .custom-video-label strong{color:var(--ink);font-weight:500}

  /* Custom-builds page overrides the shared .case-grid from 2-col to a wider
     grid so 7 tiles don't leave an orphan last row. Desktop 4-col → 4+3,
     tablet 2-col → 2+2+2+1 (orphan acceptable at narrow widths where each
     tile is already large). */
  .case-grid.case-grid--wide .grid{grid-template-columns:repeat(4,1fr);gap:20px}
  @media (max-width:1100px){.case-grid.case-grid--wide .grid{grid-template-columns:repeat(3,1fr)}}
  @media (max-width:800px){.case-grid.case-grid--wide .grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:500px){.case-grid.case-grid--wide .grid{grid-template-columns:1fr}}
}

/* === PAGE: customer-story === */
body[data-page="customer-story"] {
  .cs-hero { padding: 128px 4vw 56px; background: radial-gradient(ellipse 70% 50% at 50% 40%,#f6f7f8 0%,#eef0f2 60%,#e2e4e7 100%); }
    .cs-hero-inner { max-width: var(--w-content); margin: 0 auto; }
    .cs-breadcrumbs { font-family: 'Inter Tight', sans-serif; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--steel-4); margin-bottom: 18px; }
    .cs-breadcrumbs a { color: inherit; text-decoration: none; }
    .cs-breadcrumbs a:hover { color: var(--ink); }
    .cs-hero-inner h1 { margin: 0 0 14px; font-size: clamp(32px, 4.2vw, 52px); line-height: 1.05; letter-spacing: -0.01em; }
    .cs-sub { color: var(--steel-5); font-size: 18px; line-height: 1.55; max-width: 640px; }
    .cs-meta-row { display: flex; flex-wrap: wrap; gap: 24px; margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--steel-2); font-family: 'Inter Tight', sans-serif; font-size: 12px; letter-spacing: 0.06em; color: var(--steel-5); }
    .cs-meta-row strong { color: var(--steel-4); margin-right: 10px; font-weight: normal; letter-spacing: 0.14em; text-transform: uppercase; font-size: 11px; }

    .cs-hero-media { margin: 40px auto 0; max-width: var(--w-content); position: relative; background: #eef0f2; border: 1px solid var(--steel-2); aspect-ratio: 16 / 9; }
    .cs-hero-media .ph { position: absolute; inset: 0; }
    .cs-hero-media--portrait { aspect-ratio: 4 / 5; max-width: 720px; }
    .cs-hero-media--contain { background: #0a0a0a; border-color: #0a0a0a; }
    .cs-hero-media--contain .ph.has-img img { object-fit: contain; padding: 8% 12%; box-sizing: border-box; }

    .cs-gallery { padding: 8px 28px 80px; }
    .cs-gallery-inner { max-width: var(--w-content); margin: 0 auto; }
    .cs-gallery .overline { display: block; margin-bottom: 18px; }
    .cs-gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
    .cs-gallery-grid .cs-gallery-item { position: relative; aspect-ratio: 4 / 3; overflow: hidden; border-radius: var(--img-radius); }
    .cs-gallery-grid .cs-gallery-item .ph { position: absolute; inset: 0; }
    .cs-gallery-grid .cs-gallery-item--portrait { aspect-ratio: 3 / 4; }
    .cs-gallery-grid .cs-gallery-item--wide { grid-column: span 2; aspect-ratio: 16 / 9; }
    @media (max-width: 900px) {
      .cs-gallery-grid { grid-template-columns: repeat(2, 1fr); }
      .cs-gallery-grid .cs-gallery-item--wide { grid-column: span 2; }
    }
    @media (max-width: 560px) {
      .cs-gallery { padding: 8px 20px 56px; }
      .cs-gallery-grid { grid-template-columns: 1fr; gap: 12px; }
      .cs-gallery-grid .cs-gallery-item--wide { grid-column: span 1; }
    }

    .cs-body { max-width: 720px; margin: 0 auto; padding: 80px 28px 40px; }
    .cs-section { margin-bottom: 56px; }
    .cs-section:last-child { margin-bottom: 0; }
    .cs-section .overline { display: block; margin-bottom: 14px; }
    .cs-section h2 { margin: 0 0 18px; font-size: clamp(22px, 2.4vw, 30px); line-height: 1.2; letter-spacing: -0.01em; }
    .cs-section p { font-size: 16px; line-height: 1.7; color: var(--ink-2); margin: 0 0 16px; white-space: pre-line; }

    .cs-quote { max-width: 720px; margin: 40px auto 80px; padding: 40px 32px; background: #0a0a0a; color: #fff; border-radius: 4px; }
    .cs-quote blockquote { margin: 0 0 18px; font-size: 22px; line-height: 1.35; font-weight: 500; letter-spacing: -0.01em; }
    .cs-quote blockquote::before { content: '\201C'; color: #6b6e73; font-size: 48px; line-height: 0; vertical-align: -14px; margin-right: 4px; }
    .cs-quote cite { font-family: 'Inter Tight', sans-serif; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: #a5a8ad; font-style: normal; }

    .cs-notfound { padding: 160px 4vw 100px; max-width: 680px; margin: 0 auto; text-align: center; }
    .cs-notfound h1 { margin: 0 0 16px; }

    @media (max-width: 740px) {
      .cs-hero { padding: 110px 5vw 40px; }
      .cs-body { padding: 56px 20px 32px; }
      .cs-quote { margin: 32px 20px 56px; padding: 28px 24px; }
      .cs-quote blockquote { font-size: 18px; }
    }
}

/* === PAGE: customer-success-stories === */
body[data-page="customer-success-stories"] {
  .css-featured{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .css-featured-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .css-featured .overline{display:block;margin-bottom:14px}
  .css-featured h2{margin:0 0 20px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .css-featured p{font-size:16px;line-height:1.7;color:var(--steel-5);margin:0 0 20px}
  .css-featured-media{aspect-ratio:4/3;position:relative;background:#eef0f2;border:1px solid var(--steel-2)}
  .css-featured-media .ph{position:absolute;inset:0}
  .css-featured a.link{color:var(--accent-ink);font-size:14px;border-bottom:1px solid currentColor}
  @media (max-width: 900px){.css-featured-inner{grid-template-columns:1fr;gap:32px}}

  .css-grid-wrap{padding:96px 28px;background:#fafafa;border-top:1px solid var(--steel-2)}
  .css-grid-wrap-inner{max-width:1200px;margin:0 auto}
  .css-grid-wrap .overline{display:block;margin-bottom:14px}
  .css-grid-wrap h2{margin:0 0 16px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .css-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px;font-family:'Inter Tight',sans-serif}
  .css-chip{padding:6px 14px;border:1px solid var(--steel-2);border-radius:99px;font-size:11.5px;letter-spacing:.1em;color:var(--steel-5);background:#fff;cursor:pointer}
  .css-chip.active{background:#0a0a0a;color:#fff;border-color:#0a0a0a}

  .css-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  @media (max-width: 1000px){.css-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width: 640px){.css-grid{grid-template-columns:1fr}}
  .css-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--steel-2);transition:border-color .2s ease,transform .2s ease;text-decoration:none;color:inherit}
  .css-card:hover{border-color:var(--ink);transform:translateY(-2px)}
  .css-card-media{aspect-ratio:4/3;position:relative}
  .css-card-media .ph{position:absolute;inset:0}
  .css-card-body{padding:22px 24px;display:flex;flex-direction:column;gap:8px}
  .css-card-meta{font-size:10.5px;letter-spacing:.16em;color:var(--steel-4);text-transform:uppercase;font-family:'Inter Tight',sans-serif}
  .css-card-name{font-size:18px;font-weight:500;letter-spacing:-0.01em;line-height:1.25}
  .css-card-body p{font-size:14px;line-height:1.6;color:var(--steel-5);margin:0}
  .css-card-more{font-size:12.5px;color:var(--accent-ink);letter-spacing:.04em;margin-top:4px;font-family:'Inter Tight',sans-serif}

  .css-submit{padding:80px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .css-submit-inner{max-width:880px;margin:0 auto;text-align:center}
  .css-submit .overline{display:block;margin-bottom:14px}
  .css-submit p{font-size:16px;line-height:1.65;color:var(--steel-5);margin:0 0 24px}
}

/* === PAGE: events === */
body[data-page="events"] {
  .evt-list{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .evt-list-inner{max-width:var(--w-content);margin:0 auto}
  .evt-list-inner .overline{display:block;margin-bottom:14px}
  .evt-list-inner h2{margin:0 0 48px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .evt-card{display:grid;grid-template-columns:200px 1fr 320px;gap:32px;padding:32px 0;border-top:1px solid var(--steel-2);align-items:start}
  .evt-card:last-child{border-bottom:1px solid var(--steel-2)}
  .evt-date{font-family:'Inter Tight',sans-serif;font-size:13px;color:var(--ink);letter-spacing:.04em;line-height:1.5}
  .evt-date .tag{display:block;font-size:10.5px;letter-spacing:.18em;color:var(--steel-4);text-transform:uppercase;margin-bottom:8px}
  .evt-copy h3{margin:0 0 10px;font-size:22px;font-weight:500;letter-spacing:-0.01em;line-height:1.2}
  .evt-copy p{font-size:15px;line-height:1.65;color:var(--steel-5);margin:0 0 12px}
  .evt-copy a.link{color:var(--accent-ink);font-size:13px;border-bottom:1px solid currentColor;font-family:'Inter Tight',sans-serif}
  .evt-media{aspect-ratio:16/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2)}
  .evt-media .ph{position:absolute;inset:0}
  @media (max-width: 900px){
    .evt-card{grid-template-columns:1fr;gap:16px}
  }
}

/* === PAGE: financing === */
body[data-page="financing"] {
  .fin-section{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .fin-inner{max-width:780px;margin:0 auto}
  .fin-inner .overline{display:block;margin-bottom:14px}
  .fin-inner h2{margin:0 0 24px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .fin-body{font-size:16px;line-height:1.7;color:var(--steel-5)}
  .fin-body p{margin:0 0 18px}
  .fin-body p:last-child{margin:0}
  .fin-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}
  .fin-banner{max-width:1200px;margin:0 auto;padding:0 0 48px}
  @media (max-width:1248px){.fin-banner{margin-left:24px;margin-right:24px}}
  @media (max-width:900px){.fin-banner{margin-left:16px;margin-right:16px}}
  .fin-banner-media{aspect-ratio:21/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2)}
  .fin-banner-media .ph{position:absolute;inset:0}
}

/* === PAGE: gallery === */
body[data-page="gallery"] {
  .gallery-list{padding:32px 0 60px;background:#fff;border-top:1px solid var(--steel-2)}
  .gallery-wrap{max-width:1200px;margin:0 auto;padding:0 28px}
  .gallery-category{margin-top:40px}
  .gallery-category:first-child{margin-top:0}
  .gallery-category-head{margin-bottom:40px;text-align:center}
  .gallery-category-head h2{margin:0;font-size:clamp(24px,2.6vw,34px);font-weight:500;letter-spacing:-0.01em;line-height:1.1}
  .gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
  .g-tile{margin:0;background:#fff;overflow:hidden;aspect-ratio:1;position:relative;cursor:zoom-in;transition:transform .15s ease;border-radius:var(--banner-radius)}
  .g-tile:hover{transform:translateY(-2px)}
  .g-tile .ph{position:absolute;inset:0}
  .g-tile .ph img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
  @media (max-width:1100px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}
  @media (max-width:740px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:6px}.gallery-wrap{padding:0 20px}.gallery-category{margin-top:48px}}
  /* Lightbox — frosted overlay, not full blackout */
  .g-lightbox{position:fixed;inset:0;background:rgba(255,255,255,.72);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:40px;cursor:zoom-out;animation:g-fade .15s ease-out}
  @keyframes g-fade{from{opacity:0}to{opacity:1}}
  .g-lightbox img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;cursor:default;border-radius:var(--banner-radius);box-shadow:0 20px 60px rgba(0,0,0,.25)}
  .g-lightbox-close{position:absolute;top:20px;right:24px;width:44px;height:44px;border:none;background:rgba(10,10,10,.08);color:var(--ink);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;line-height:1;transition:background .15s ease}
  .g-lightbox-close:hover{background:rgba(10,10,10,.15)}
  .g-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border:none;background:rgba(10,10,10,.08);color:var(--ink);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}
  .g-lightbox-nav:hover{background:rgba(10,10,10,.15)}
  .g-lightbox-nav.prev{left:24px}
  .g-lightbox-nav.next{right:24px}
  .g-lightbox-nav svg{width:22px;height:22px;stroke:var(--ink);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
  @media (max-width:740px){
    .g-lightbox{padding:16px}
    .g-lightbox-close{top:12px;right:12px}
    .g-lightbox-nav{width:40px;height:40px}
    .g-lightbox-nav.prev{left:8px}
    .g-lightbox-nav.next{right:8px}
  }
}

/* === PAGE: jewelry-workflow === */
body[data-page="jewelry-workflow"] {
  .wf-banner{max-width:1200px;margin:0 auto;padding:48px 0 0}
  @media (max-width:1248px){.wf-banner{margin-left:24px;margin-right:24px}}
  @media (max-width:900px){.wf-banner{margin-left:16px;margin-right:16px}}
  .wf-banner-media{aspect-ratio:21/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2);border-radius:var(--banner-radius);overflow:hidden}
  .wf-banner-media .ph{position:absolute;inset:0}
  .wf-step{padding:96px 28px;border-top:1px solid var(--steel-2)}
  .wf-step:nth-of-type(odd){background:#fff}
  .wf-step:nth-of-type(even){background:#fafafa}
  .wf-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .wf-step:nth-of-type(even) .wf-inner{direction:rtl}
  .wf-step:nth-of-type(even) .wf-inner > *{direction:ltr}
  .wf-copy .n{font-size:64px;font-weight:500;letter-spacing:-0.03em;color:var(--steel-3);line-height:1;margin-bottom:12px;font-family:'Inter Tight',sans-serif}
  .wf-copy .overline{display:block;margin-bottom:10px}
  .wf-copy h2{margin:0 0 20px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .wf-copy .body{font-size:16px;line-height:1.7;color:var(--steel-5)}
  .wf-copy .body p{margin:0 0 16px}
  .wf-copy .body p:last-child{margin:0}
  .wf-media{aspect-ratio:12/7;position:relative;background:#eef0f2;border:1px solid var(--steel-2);border-radius:var(--banner-radius);overflow:hidden}
  .wf-media .ph{position:absolute;inset:0}
  @media (max-width: 900px){
    .wf-inner{grid-template-columns:1fr;gap:32px}
    .wf-step:nth-of-type(even) .wf-inner{direction:ltr}
    .wf-copy .n{font-size:48px}
  }
}

/* === PAGE: micromachining === */
body[data-page="micromachining"] {
  .mm-stats{padding:28px;background:#0a0a0a;color:#fff;border-top:1px solid var(--steel-2)}
  .mm-stats-inner{max-width:var(--w-content);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .mm-stat{display:flex;flex-direction:column;gap:4px;padding:16px 0}
  .mm-stat .k{font-size:10.5px;letter-spacing:.18em;color:#a5a8ad;text-transform:uppercase;font-family:'Inter Tight',sans-serif}
  .mm-stat .v{font-size:20px;font-weight:500;letter-spacing:-0.01em}
  @media (max-width: 700px){.mm-stats-inner{grid-template-columns:1fr}}

  .mm-section{padding:96px 28px;border-top:1px solid var(--steel-2)}
  .mm-section:nth-of-type(odd){background:#fff}
  .mm-section:nth-of-type(even){background:#fafafa}
  .mm-section-inner{max-width:var(--w-content);margin:0 auto}
  .mm-section-inner .overline{display:block;margin-bottom:14px}
  .mm-section-inner h2{margin:0 0 24px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .mm-body{font-size:16px;line-height:1.7;color:var(--steel-5)}
  .mm-body p{margin:0 0 16px}
  .mm-body p:last-child{margin:0}
  .mm-body em{color:var(--ink);font-style:normal;font-weight:500}
  .mm-body strong{color:var(--ink);font-weight:500}

  .mm-parts{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:14px}
  .mm-parts li{padding:14px 0;border-top:1px solid var(--steel-2);font-size:15px;line-height:1.55;color:var(--steel-5)}
  .mm-parts li strong{color:var(--ink);font-weight:500}

  .mm-links{display:flex;gap:18px;flex-wrap:wrap;margin-top:24px}
  .mm-links a{color:var(--accent-ink);font-size:14px;border-bottom:1px solid currentColor}

  .mm-pubs-grid{margin-top:32px;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1px;background:var(--steel-2);border:1px solid var(--steel-2)}
  .mm-pub{background:#fff;aspect-ratio:4/3;position:relative}
  .mm-pub .ph{position:absolute;inset:0}
  .mm-banner{max-width:1200px;margin:0 auto;padding:48px 0 0}
  @media (max-width:1248px){.mm-banner{margin-left:24px;margin-right:24px}}
  @media (max-width:900px){.mm-banner{margin-left:16px;margin-right:16px}}
  .mm-banner-media{aspect-ratio:21/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2)}
  .mm-banner-media .ph{position:absolute;inset:0}
  .mm-figure{aspect-ratio:16/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2);margin-top:32px}
  .mm-figure .ph{position:absolute;inset:0}
  .mm-caption{margin-top:12px;font-size:14px;color:var(--steel-5);line-height:1.55;text-align:center}
  .mm-pair{margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:24px}
  .mm-pair-tile{aspect-ratio:16/9;position:relative;overflow:hidden;background:#eef0f2;border:1px solid var(--steel-2)}
  .mm-pair-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  .mm-duo{margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:24px}
  .mm-duo-col{display:flex;flex-direction:column}
  .mm-duo .mm-caption{text-align:left}
  @media (max-width:900px){.mm-pair,.mm-duo{grid-template-columns:1fr}}
  .mm-bio{margin-top:32px;display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:48px;align-items:start}
  .mm-bio-media{aspect-ratio:3/4;position:relative;overflow:hidden;background:#eef0f2;border:1px solid var(--steel-2)}
  .mm-bio-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  .mm-bio-copy{margin-top:0}
  @media (max-width:900px){.mm-bio{grid-template-columns:1fr;gap:24px}.mm-bio-media{max-width:420px;margin:0 auto}}
  .mm-logos{margin-top:48px;display:flex;flex-wrap:wrap;gap:48px;align-items:center;justify-content:center;padding:32px 0;border-top:1px solid var(--steel-2)}
  .mm-logos img{max-height:60px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.75;transition:opacity .18s ease,filter .18s ease}
  .mm-logos img:hover{filter:grayscale(0);opacity:1}
  .mm-quad{margin-top:32px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
  .mm-quad-tile{aspect-ratio:16/9;position:relative;overflow:hidden;background:#eef0f2;border:1px solid var(--steel-2)}
  .mm-quad-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  @media (max-width:900px){.mm-quad{grid-template-columns:repeat(2,1fr)}}
}

/* === PAGE: milled-materials === */
body[data-page="milled-materials"] {
  .materials-wrap{max-width:1200px;margin:0 auto;padding:56px 28px 120px}
  .materials-intro{max-width:780px;margin:0 0 48px;color:var(--steel-5);font-size:15.5px;line-height:1.65}
  .materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}
  .material-card{background:#fff;border:1px solid var(--steel-2);transition:border-color .2s ease,transform .2s ease;display:flex;flex-direction:column}
  .material-card:hover{border-color:var(--ink);transform:translateY(-2px)}
  .material-media{aspect-ratio:1;position:relative}
  .material-media .ph{position:absolute;inset:0}
  .material-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:6px}
  .material-name{font-size:17px;font-weight:500;letter-spacing:-0.01em;margin:0}
  .material-cat{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-4);font-family:'Inter Tight',sans-serif}
  .material-axes{font-size:12.5px;color:var(--steel-5);letter-spacing:.02em;font-family:'Inter Tight',sans-serif;margin-top:4px}
}

/* === PAGE: milling-vs-printed === */
body[data-page="milling-vs-printed"] {
  .mvp-section{padding:96px 28px;border-top:1px solid var(--steel-2)}
  .mvp-section:nth-of-type(odd){background:#fff}
  .mvp-section:nth-of-type(even){background:#fafafa}
  .mvp-inner{max-width:var(--w-content);margin:0 auto}
  .mvp-inner .overline{display:block;margin-bottom:14px}
  .mvp-inner h2{margin:0 0 24px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .mvp-body{font-size:16px;line-height:1.7;color:var(--steel-5)}
  .mvp-body p{margin:0 0 16px}
  .mvp-body p:last-child{margin:0}
  .mvp-body strong{color:var(--ink);font-weight:500}

  .mvp-compare{padding:96px 28px;background:#fafafa;border-top:1px solid var(--steel-2)}
  .mvp-compare-inner{max-width:1200px;margin:0 auto}
  .mvp-compare-inner .overline{display:block;margin-bottom:14px}
  .mvp-compare-inner h2{margin:0 0 40px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .mvp-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
  .mvp-tile{display:flex;flex-direction:column;background:#fff;border:1px solid var(--steel-2)}
  .mvp-tile-media{aspect-ratio:4/3;position:relative}
  .mvp-tile-media .ph{position:absolute;inset:0}
  .mvp-tile-cap{padding:20px 24px;border-top:1px solid var(--steel-2);font-family:'Inter Tight',sans-serif;font-size:12px;letter-spacing:.14em;color:var(--ink);text-transform:uppercase}
  .mvp-tile-cap .sub{display:block;margin-top:6px;color:var(--steel-5);letter-spacing:.04em;font-size:12.5px;text-transform:none}
  @media (max-width: 800px){.mvp-grid{grid-template-columns:1fr}}
}

/* === Post timeline — used by news, events, and any page that lists
 *     grouped, image+copy entries. Image left, copy right, year labels. */
.posts-wrap{max-width:var(--w-content);margin:0 auto;padding:72px 28px 96px}
.posts-year{margin-bottom:72px}
.posts-year-label{font-family:'Inter Tight',sans-serif;font-size:15px;letter-spacing:.14em;color:var(--ink);padding-bottom:14px;border-bottom:1px solid var(--steel-3);margin-bottom:36px;font-weight:500}
.post-item{display:grid;grid-template-columns:440px 1fr;gap:48px;padding:38px 0;border-bottom:1px solid var(--steel-2);align-items:start}
.post-item.no-media{grid-template-columns:1fr;max-width:720px}
.post-item:last-child{border-bottom:none}
.post-media{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:var(--img-radius);background:#eef0f2;display:block}
.post-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
.post-media iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.post-media--video{background:#000}
.post-media--gallery{aspect-ratio:auto;display:grid;grid-template-columns:1fr;gap:6px;background:transparent}
.post-media--gallery img{aspect-ratio:16/9;height:auto;border-radius:var(--img-radius)}
.post-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:rgba(220,38,38,0.95);display:flex;align-items:center;justify-content:center;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,0.25);transition:transform .18s ease,background .18s ease}
.post-play::before{content:'';display:block;width:0;height:0;border-left:18px solid #fff;border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:4px}
.post-item:hover .post-play{background:rgba(220,38,38,1);transform:translate(-50%,-50%) scale(1.06)}
.post-copy h3{margin:0 0 10px;font-size:22px;font-weight:500;letter-spacing:-0.012em;line-height:1.25}
.post-date{font-family:'Inter Tight',sans-serif;font-size:12.5px;color:var(--steel-5);margin-bottom:14px;letter-spacing:.02em}
.post-subtitle{margin:0 0 14px;font-size:16px;font-weight:500;color:var(--ink);line-height:1.35;max-width:64ch}
.post-copy p{margin:0 0 14px;font-size:15.5px;line-height:1.65;color:var(--steel-5);max-width:64ch}
.post-links{display:flex;gap:22px;flex-wrap:wrap;margin-top:4px}
.post-links a{font-size:13.5px;color:var(--accent-ink);border-bottom:1px solid currentColor;padding-bottom:1px;transition:color .18s ease}
.post-links a:hover{color:var(--ink)}
.post-refs{display:flex;flex-direction:column;gap:4px;margin-top:14px;font-family:'Inter Tight',sans-serif;font-size:12.5px;word-break:break-all}
.post-refs a{color:var(--steel-5);border-bottom:1px solid var(--steel-3);padding-bottom:1px;transition:color .18s ease}
.post-refs a:hover{color:var(--accent-ink)}
@media (max-width:900px){
  .post-item, .post-item.no-media{grid-template-columns:1fr;gap:16px;padding:28px 0;max-width:none}
  .post-play{width:54px;height:54px}
  .post-play::before{border-left-width:15px;border-top-width:9px;border-bottom-width:9px}
}

/* === PAGE: news === */
body[data-page="news"] {
  .ph.has-img{overflow:hidden;background:none}
  .ph.has-img::before{display:none}
  .ph.has-img img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}

  .sub-form{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center;width:100%;max-width:480px}
  .sub-form input{flex:1;min-width:220px;padding:12px 16px;font-size:14px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.18);color:#fff;border-radius:2px;font-family:inherit;outline:none;transition:border-color .18s ease}
  .sub-form input::placeholder{color:#8a8d92}
  .sub-form input:focus{border-color:#fff}
  .sub-form .btn.dark{min-width:140px;padding:12px 22px}
}

/* === PAGE: products === */
body[data-page="products"] {
  .filter-inner .count{ font-size:11px; color: var(--steel-4); letter-spacing:.12em; }
  .prows{ max-width:1200px; margin: 0 auto; padding: 64px 28px; display:flex; flex-direction:column; gap: 96px; }
  .prows-empty{ text-align:center; color: var(--steel-5); padding: 40px 28px; }
  .prow{ display:grid; grid-template-columns: 1.1fr 1fr; gap: 48px; align-items:center; text-decoration:none; color:inherit; cursor:pointer; padding: 24px; border:1px solid transparent; transition: border-color .2s ease, background .2s ease; }
  .prow:hover{ border-color: var(--steel-2); background: #fafafa; }
  .prow-cta{ display:inline-block; margin-top:20px; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent-ink); border-bottom:1px solid currentColor; padding-bottom:2px; align-self:flex-start; }
  .prow:hover .prow-cta{ color: var(--ink); }
  .prow.flip{ direction: rtl; }
  .prow.flip > *{ direction: ltr; }
  .prow-media{ position:relative; aspect-ratio: 4/3; }
  .prow-media .ph{ position:absolute; inset:0; }
  .ph.has-img{ overflow:hidden; background:none; }
  .ph.has-img::before{ display:none; }
  .ph.has-img img{ width:100%; height:100%; object-fit:cover; object-position:center center; display:block; }
  .prow-media .ph.has-img img{ object-fit:contain; padding:24px; box-sizing:border-box; }
  .prow-media .fam{ position:absolute; top:16px; left:16px; padding: 4px 10px; background: rgba(10,10,10,0.88); color:#fff; font-size:10.5px; letter-spacing:.18em; border-radius:2px; }
  .prow-copy h2{ margin: 6px 0 6px; font-size: clamp(32px, 3.8vw, 52px); font-weight:500; letter-spacing:-0.02em; line-height: 1.05; }
  .prow-copy .tag{ margin:0; color: var(--steel-5); font-size: 14.5px; letter-spacing:.02em; }
  .prow-copy .blurb{ margin: 16px 0 20px; max-width: 46ch; font-size: 15px; line-height: 1.6; color: var(--ink-2); }
  .kv{ margin: 0; padding: 14px 0 6px; border-top: 1px solid var(--steel-2); display:grid; grid-template-columns: repeat(3,1fr); gap: 8px 12px; }
  .kv div{ display:flex; flex-direction:column; gap: 4px; }
  .kv dt{ font-size: 10.5px; letter-spacing:.14em; color: var(--steel-4); text-transform: uppercase; margin:0; }
  .kv dd{ font-size: 19px; font-weight:500; margin:0; letter-spacing:-0.01em; }
  @media (max-width: 900px){ .prow{ grid-template-columns: 1fr; gap: 24px; } .prow.flip{ direction: ltr; } }
}

/* === Publications grid — 2-up tiles of journal covers, mirrors the
 *     index belt-video pairing. Used by science-publications.
 *     Some tiles are <a> with a citation link, others are inert <div>. */
.pubs-wrap{padding:24px 0 88px;background:#fff}
.pubs-grid{display:grid;grid-template-columns:1fr 1fr;gap:96px 24px;width:min(var(--w-content),calc(100vw - 56px));margin:0 auto}
.pub-tile{position:relative;width:100%;aspect-ratio:var(--ar-hero);border-radius:var(--banner-radius);overflow:hidden;background:#0a0a0a;display:block;border:1px solid var(--steel-3);box-shadow:0 1px 2px rgba(0,0,0,0.04);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
a.pub-tile:hover{border-color:var(--ink)}
.pub-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;display:block;border-radius:inherit}
a.pub-tile:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.12)}
@media (max-width:900px){.pubs-grid{grid-template-columns:1fr;gap:16px;width:auto;padding:0 16px}}

/* === PAGE: shop === */
body[data-page="shop"] {
  .shop-hero .sub{max-width:680px}

  .shop-list{padding:80px 0 120px;background:#fff;border-top:1px solid var(--steel-2)}
  .shop-wrap{max-width:1200px;margin:0 auto;padding:0 28px}
  .shop-category{margin-top:72px}
  .shop-category:first-child{margin-top:0}
  .shop-category-head{border-bottom:1px solid var(--steel-2);padding-bottom:14px;margin-bottom:32px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
  .shop-category-head h2{margin:0;font-size:clamp(20px,2.2vw,26px);font-weight:500;letter-spacing:-0.01em;line-height:1.2}
  .shop-category-head .count{color:var(--steel-4);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;font-family:'Inter Tight',sans-serif}
  .shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px}
  .shop-card{background:#fff;border:1px solid var(--steel-2);transition:border-color .2s ease,transform .2s ease;display:flex;flex-direction:column;text-decoration:none;color:inherit;cursor:pointer}
  .shop-card:hover{border-color:var(--ink);transform:translateY(-2px)}
  .shop-card .ph{aspect-ratio:1}
  .shop-card-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:6px}
  .shop-card-name{font-size:15.5px;font-weight:500;letter-spacing:-0.01em;line-height:1.3;margin:0;color:var(--ink)}
  .shop-card-price{color:var(--steel-5);font-size:12.5px;letter-spacing:.04em;font-family:'Inter Tight',sans-serif}
  .shop-card-price.inquiry{color:var(--steel-4);font-style:italic}

  .shop-note{margin-top:80px;padding:24px 28px;background:#fafafa;border:1px solid var(--steel-2);font-size:13px;color:var(--steel-5);line-height:1.65;font-family:'Inter Tight',sans-serif;letter-spacing:.02em}
  .shop-note a{color:var(--ink);border-bottom:1px solid var(--steel-3)}
  .shop-note a:hover{border-bottom-color:var(--ink)}

  .product-detail{max-width:1200px;margin:0 auto;padding:calc(var(--nav-h) + 56px) 28px 96px}
  .product-breadcrumbs{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel-4);margin-bottom:32px}
  .product-breadcrumbs a{color:inherit;text-decoration:none}
  .product-breadcrumbs a:hover{color:var(--ink)}
  .product-top{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
  .product-top .ph{aspect-ratio:4/3;background:var(--steel-1)}
  .product-meta .overline{display:block;margin-bottom:14px}
  .product-meta h1{margin:0 0 14px;font-size:clamp(30px,3.6vw,44px);font-weight:500;line-height:1.1;letter-spacing:-0.01em}
  .product-price{font-size:22px;margin:20px 0 28px;letter-spacing:.01em;color:var(--ink);font-family:'Inter Tight',sans-serif}
  .product-price.inquiry{font-size:14px;color:var(--steel-5);font-style:italic;font-family:inherit}
  .product-cta{margin:28px 0 0;display:flex;gap:12px;flex-wrap:wrap}

  .product-section{margin-top:32px}
  .product-section:first-of-type{margin-top:0}
  .product-section-label{font-family:'Inter Tight',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel-4);margin-bottom:10px;display:block}
  .product-desc{line-height:1.65;color:var(--ink-2);font-size:15px}
  .product-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
  .product-features li{font-size:14.5px;line-height:1.5;color:var(--ink-2);padding-left:18px;position:relative}
  .product-features li::before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;background:var(--ink);border-radius:50%}
  .product-note{font-size:13px;line-height:1.55;color:var(--steel-5);font-style:italic;padding:14px 16px;background:#fafafa;border-left:2px solid var(--steel-3);margin-top:24px}

  @media (max-width:740px){
    .product-detail{padding:88px 20px 64px}
    .product-top{grid-template-columns:1fr;gap:28px}
    .shop-wrap{padding:0 20px}
    .shop-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
    .shop-card-body{padding:14px 16px 18px}
    .shop-card-name{font-size:14px}
  }

  /* Force the nav into its solid (white) state — the dark banner hero makes
     the default transparent nav illegible. */
  .nav-wrap .nav{background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2)}

  /* Page-hero banner: full-bleed image with the headline-stack overlaid. */
  section.page-hero.page-hero-banner{
    position:relative;
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    padding:var(--nav-h, 56px) 0 0 !important;
    min-height:50vh;
    height:auto;
    max-height:none;
    background:#000;
    overflow:hidden;
    display:block;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img{
    position:absolute !important;
    top:var(--nav-h, 56px) !important;
    left:0 !important;right:0 !important;bottom:0 !important;
    width:auto !important;
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
    background:#000;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img img{
    width:100%;height:100%;
    object-fit:cover;object-position:center center;
    display:block;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img::after{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.15) 35%, rgba(0,0,0,0.15) 65%, rgba(0,0,0,0.55) 100%);
    pointer-events:none;
  }
  section.page-hero.page-hero-banner .headline-stack{
    position:absolute;
    inset:var(--nav-h, 56px) 0 0 0;
    z-index:2;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    gap:14px;
    padding:28px;
    text-align:center;
    color:var(--ink);
  }
  section.page-hero.page-hero-banner .headline-stack .overline{color:#fff;margin:0;display:block}
  section.page-hero.page-hero-banner .headline-stack h1{color:#fff;margin:0;max-width:24ch}
  section.page-hero.page-hero-banner .headline-stack .sub{color:#fff;margin:0;display:block;max-width:560px}
  section.page-hero.page-hero-banner .telemetry{
    position:absolute;left:0;right:0;bottom:24px;
    z-index:2;
    margin:0 auto;
    max-width:1200px;
    padding:0 28px;
    color:#fff;
  }
  section.page-hero.page-hero-banner .telemetry .bar{background:rgba(255,255,255,0.18)}
}

/* === PAGE: support === */
body[data-page="support"] {
  .support-grid{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .support-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--steel-2);border:1px solid var(--steel-2)}
  .support-card{background:#fff;padding:40px 36px;display:flex;flex-direction:column;gap:14px;min-height:280px}
  .support-card .overline{display:block;margin-bottom:6px}
  .support-card h3{font-size:24px;font-weight:500;letter-spacing:-0.01em;margin:0}
  .support-card p{margin:0;font-size:15px;line-height:1.6;color:var(--steel-5);flex:1}
  .support-link{font-family:'Inter Tight',sans-serif;font-size:12px;letter-spacing:.08em;color:var(--accent-ink);border-bottom:1px solid currentColor;padding-bottom:2px;align-self:flex-start;margin-top:4px}
  @media (max-width: 900px){.support-inner{grid-template-columns:1fr}}

  .escalation{padding:96px 28px;background:#fafafa;border-top:1px solid var(--steel-2)}
  .escalation-inner{max-width:780px;margin:0 auto;text-align:center}
  .escalation-inner .overline{display:block;margin-bottom:14px}
  .escalation-inner h2{margin:0 0 16px;font-size:clamp(28px,3.2vw,40px)}
  .escalation-inner p{font-size:16px;color:var(--steel-5);margin:0 0 36px;line-height:1.6}
  .hq-block{display:inline-flex;flex-direction:column;gap:12px;padding:32px 40px;border:1px solid var(--steel-2);background:#fff;text-align:left;align-items:flex-start}
  .hq-name{font-weight:500;font-size:17px}
  .hq-addr{font-size:14px;color:var(--steel-5);line-height:1.5}
  .hq-contact{font-size:13px;line-height:1.6;color:var(--ink)}

  /* Force the nav into its solid (white) state — the dark banner hero makes
     the default transparent nav illegible. */
  .nav-wrap .nav{background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--steel-2)}

  /* Page-hero banner: full-bleed image with the headline-stack overlaid. */
  section.page-hero.page-hero-banner{
    position:relative;
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    padding:var(--nav-h, 56px) 0 0 !important;
    min-height:50vh;
    height:auto;
    max-height:none;
    background:#000;
    overflow:hidden;
    display:block;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img{
    position:absolute !important;
    top:var(--nav-h, 56px) !important;
    left:0 !important;right:0 !important;bottom:0 !important;
    width:auto !important;
    max-width:none !important;
    margin:0 !important;
    padding:0 !important;
    background:#000;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img img{
    width:100%;height:100%;
    object-fit:cover;object-position:center center;
    display:block;
  }
  section.page-hero.page-hero-banner .page-hero-banner-img::after{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.15) 35%, rgba(0,0,0,0.15) 65%, rgba(0,0,0,0.55) 100%);
    pointer-events:none;
  }
  section.page-hero.page-hero-banner .headline-stack{
    position:absolute;
    inset:var(--nav-h, 56px) 0 0 0;
    z-index:2;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    gap:14px;
    padding:28px;
    text-align:center;
    color:#fff;
  }
  section.page-hero.page-hero-banner .headline-stack .overline{color:#fff;margin:0;display:block}
  section.page-hero.page-hero-banner .headline-stack h1{color:#fff;margin:0;max-width:24ch}
  section.page-hero.page-hero-banner .headline-stack .sub{color:#fff;margin:0;display:block;max-width:560px}
  section.page-hero.page-hero-banner .telemetry{
    position:absolute;left:0;right:0;bottom:24px;
    z-index:2;
    margin:0 auto;
    max-width:1200px;
    padding:0 28px;
    color:#fff;
  }
  section.page-hero.page-hero-banner .telemetry .bar{background:rgba(255,255,255,0.18)}
}

/* === PAGE: used-machines === */
body[data-page="used-machines"] {
  .paths{padding:96px 28px;background:#fff;border-top:1px solid var(--steel-2)}
  .paths-inner{max-width:var(--w-content);margin:0 auto}
  .paths-inner .overline{display:block;margin-bottom:14px}
  .paths-inner h2{margin:0 0 48px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .paths-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
  .path{background:#fafafa;border:1px solid var(--steel-2);padding:48px 40px;display:flex;flex-direction:column;gap:16px}
  .path h3{font-size:22px;font-weight:500;letter-spacing:-0.01em;margin:0}
  .path p{font-size:15px;line-height:1.65;color:var(--steel-5);margin:0}
  .path .btn{align-self:flex-start;margin-top:8px}
  @media (max-width: 900px){.paths-grid{grid-template-columns:1fr}}
  .um-banner{max-width:1200px;margin:0 auto;padding:0 0 48px}
  @media (max-width:1248px){.um-banner{margin-left:24px;margin-right:24px}}
  @media (max-width:900px){.um-banner{margin-left:16px;margin-right:16px}}
  .um-banner-media{aspect-ratio:21/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2)}
  .um-banner-media .ph{position:absolute;inset:0}
}

/* === PAGE: videos === */
body[data-page="videos"] {
  .vid-cat{padding:80px 28px;border-top:1px solid var(--steel-2)}
  .vid-cat:nth-of-type(odd){background:#fff}
  .vid-cat:nth-of-type(even){background:#fafafa}
  .vid-cat-inner{max-width:1200px;margin:0 auto}
  .vid-cat-head{text-align:center;margin-bottom:40px}
  .vid-cat-head .overline{display:block;margin-bottom:10px}
  .vid-cat-head h2{margin:0;font-size:clamp(24px,2.6vw,34px);line-height:1.1}
  .vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  @media (max-width: 1100px){.vid-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width: 700px){.vid-grid{grid-template-columns:1fr}}
  .vid-card{display:block;background:transparent;text-decoration:none;color:inherit;transition:transform .2s ease;overflow:hidden;border-radius:var(--banner-radius)}
  .vid-card:hover{transform:translateY(-2px)}
  .vid-card:hover .vid-play{background:rgba(0,0,0,0.92);transform:translate(-50%,-50%) scale(1.08)}
  .vid-media{aspect-ratio:16/9;position:relative;background:transparent;overflow:hidden;border-radius:var(--banner-radius)}
  .vid-media .ph{position:absolute;inset:0}
  .vid-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:var(--banner-radius);transform:scale(1.08)}
  .vid-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;background:rgba(0,0,0,0.78);display:flex;align-items:center;justify-content:center;transition:all .18s ease;pointer-events:none}
  .vid-play svg{width:22px;height:22px;fill:#fff;margin-left:3px}
  .vid-cat-count{font-family:'Inter Tight',sans-serif;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-4)}
  .vid-loading{max-width:1200px;margin:0 auto;padding:80px 28px;color:var(--steel-5);font-family:'Inter Tight',sans-serif;font-size:13px;letter-spacing:.08em}

  /* In-page video lightbox */
  .vid-card{appearance:none;border:0;padding:0;width:100%;font:inherit;cursor:pointer;text-align:left}
  .vid-modal{position:fixed;inset:0;z-index:9999;background:rgba(8,9,11,0.92);display:flex;align-items:center;justify-content:center;padding:40px 20px;animation:vidModalFade .2s ease-out}
  .vid-modal-inner{position:relative;width:100%;max-width:1200px;aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,0.6)}
  .vid-modal-inner iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
  .vid-modal-close{position:absolute;top:-44px;right:-4px;background:transparent;border:0;color:#fff;font-size:28px;line-height:1;width:36px;height:36px;cursor:pointer;opacity:.85;transition:opacity .15s ease;padding:0}
  .vid-modal-close:hover{opacity:1}
  @media (max-width:900px){.vid-modal-close{top:-38px;right:0}}
  @keyframes vidModalFade{from{opacity:0}to{opacity:1}}
}

/* === PAGE: watchmaking === */
body[data-page="watchmaking"] {
  .wm-stats{padding:28px;background:#0a0a0a;color:#fff;border-top:1px solid var(--steel-2)}
  .wm-stats-inner{max-width:var(--w-content);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .wm-stat{display:flex;flex-direction:column;gap:4px;padding:16px 0}
  .wm-stat .k{font-size:10.5px;letter-spacing:.18em;color:#a5a8ad;text-transform:uppercase;font-family:'Inter Tight',sans-serif}
  .wm-stat .v{font-size:20px;font-weight:500;letter-spacing:-0.01em}
  @media (max-width: 700px){.wm-stats-inner{grid-template-columns:1fr}}

  .wm-section{padding:96px 28px;border-top:1px solid var(--steel-2)}
  .wm-section:nth-of-type(odd){background:#fff}
  .wm-section:nth-of-type(even){background:#fafafa}
  .wm-inner{max-width:var(--w-content);margin:0 auto}
  .wm-inner .overline{display:block;margin-bottom:14px}
  .wm-inner h2{margin:0 0 24px;font-size:clamp(28px,3.2vw,40px);line-height:1.1}
  .wm-body{font-size:16px;line-height:1.7;color:var(--steel-5)}
  .wm-body p{margin:0 0 16px}
  .wm-body p:last-child{margin:0}
  .wm-body strong{color:var(--ink);font-weight:500}
  .wm-body em{color:var(--ink);font-style:italic}
  .wm-cite{margin-top:24px;font-size:14px;letter-spacing:.08em;color:var(--steel-4);font-family:'Inter Tight',sans-serif}

  .wm-projects{margin-top:16px;display:flex;flex-direction:column;gap:24px}
  .wm-project{padding:20px 0;border-top:1px solid var(--steel-2)}
  .wm-project h3{margin:0 0 10px;font-size:18px;font-weight:500;letter-spacing:-0.01em}
  .wm-project p{font-size:15px;line-height:1.65;color:var(--steel-5);margin:0}

  .wm-cap{display:grid;grid-template-columns:1fr 1fr;gap:20px 40px;margin-top:16px}
  .wm-cap-item{padding:18px 0;border-top:1px solid var(--steel-2);font-size:15px;line-height:1.6;color:var(--steel-5)}
  .wm-cap-item strong{color:var(--ink);font-weight:500}
  @media (max-width: 700px){.wm-cap{grid-template-columns:1fr}}

  .wm-links{margin-top:20px}
  .wm-links a{color:var(--accent-ink);font-size:14px;border-bottom:1px solid currentColor}
  .wm-banner{max-width:1200px;margin:0 auto;padding:48px 0 0}
  @media (max-width:1248px){.wm-banner{margin-left:24px;margin-right:24px}}
  @media (max-width:900px){.wm-banner{margin-left:16px;margin-right:16px}}
  .wm-banner-media{aspect-ratio:21/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2)}
  .wm-banner-media .ph{position:absolute;inset:0}
  .wm-figure{aspect-ratio:16/9;position:relative;background:#eef0f2;border:1px solid var(--steel-2);margin-top:32px}
  .wm-figure .ph{position:absolute;inset:0}
  .mm-parts{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:14px}
  .mm-parts li{padding:14px 0;border-top:1px solid var(--steel-2);font-size:15px;line-height:1.55;color:var(--steel-5)}
  .mm-parts li strong{color:var(--ink);font-weight:500}
}

/* === PAGE: elara-2 — uniform inter-section spacing === */
.elara-2-stack > *{padding-top:0 !important;padding-bottom:0 !important;margin-top:0 !important;margin-bottom:0 !important}
.elara-2-stack > * + *{margin-top:96px !important}
.elara-2-stack .machine-video--breakout{margin-bottom:0 !important;margin-top:0 !important}
@media (max-width:899px){
  .elara-2-stack > * + *{margin-top:56px !important}
}

