/*
 * 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;
}
*{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:'JetBrains Mono',ui-monospace,monospace;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:'JetBrains Mono',monospace;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;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:'JetBrains Mono',monospace;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:'JetBrains Mono',monospace;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:'JetBrains Mono',monospace;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:'JetBrains Mono',monospace;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}

/* 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:'JetBrains Mono',monospace;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}

/* 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:2px;transition:all .18s ease;border:1px solid transparent}
.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 */
.telemetry{position:absolute;left:28px;right:28px;bottom:24px;display:flex;justify-content:space-between;align-items:flex-end;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--steel-5);letter-spacing:.04em;pointer-events:none}
.telemetry .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: 1100px; 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: 1100px; 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: 1400px; margin: 0 auto; padding: 96px 28px; 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: 1400px; 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: 'JetBrains Mono', monospace; color: var(--ink); margin: 0; text-align: right; }
  .specs-footer{ max-width: 1400px; 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: 1400px; 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}
}

/* Brand logo — dual-variant with automatic dark/light switching.
   Two <img> tags inside .brand; CSS shows the right one depending on
   whether the nav is over a dark hero and whether it has scrolled. */
.brand-logo{height:22px;width:auto;display:block}
.brand-logo--light{display:none}

/* On pages whose hero is dark (legal pages, news posts, etc.),
   swap to the white logo while the nav is still transparent (pre-scroll). */
body:has(.page-hero--dark) .nav:not(.solid) .brand-logo--dark{display:none}
body:has(.page-hero--dark) .nav:not(.solid) .brand-logo--light{display:block}
body:has(.page-hero--dark) .nav:not(.solid){color:#fff}
body:has(.page-hero--dark) .nav:not(.solid) .brand .dot{background:#fff}



/* ============================================
 * 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:'JetBrains Mono',monospace;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:'JetBrains Mono',monospace;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:'JetBrains Mono',monospace;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:none;margin:0;padding:0;gap:0;flex-direction:column;display:block}
.feature.feature--framed{position:relative;display:block;padding:88px 16px 16px;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-copy{position:static;inset:auto;max-width:760px;margin:0 auto 56px;padding:0 40px;text-align:center;color:var(--ink);display:flex;flex-direction:column;gap:14px;align-items:center !important;box-sizing:content-box}
.feature--framed .feature-copy .overline{color:var(--steel-5);margin:0;display:block}
.feature--framed .feature-copy h2{color:var(--ink);margin:0;max-width:28ch;font-size:clamp(32px,3.6vw,48px);line-height:1.05;font-weight:500;letter-spacing:-0.02em;text-align:center}
.feature--framed .feature-copy p{color:var(--steel-5);margin:0;max-width:60ch;font-size:16.5px;line-height:1.65;text-align:center}
.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 16px 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:8px}
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:1400px;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}
.machine-video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Full-bleed banner strip (product-row / hero-showcase between sections) */
.banner-strip{width:100%;margin:0;padding:0;background:#000;overflow:hidden;position:relative}
.banner-strip img{width:100%;height:auto;display:block;max-height:65vh;object-fit:cover;border-radius:0}
.banner-strip-cap{position:absolute;inset:auto 0 20px;text-align:center;color:rgba(255,255,255,.9);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:0 24px;text-shadow:0 1px 3px rgba(0,0,0,.6)}

/* Ball screws / hardware detail split section (flip of in-the-box) */
.ball-screws{max-width:1400px;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:1400px;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:1400px;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:1/1;background:var(--steel-1)}
.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}.in-the-box-media{aspect-ratio:4/3}}

/* Customer stories grid — shared across applications.html and machine pages */
.case-grid{padding:96px 28px;max-width:1400px;margin:0 auto}
.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}}
