/* ==========================================================
   VIRTUAL ERA — SITE STYLESHEET
   Shared across all inner pages. Homepage has inline variant
   for Phase 1; Phase 3 consolidates everything here.
   ========================================================== */

/* --- DESIGN TOKENS --- */
:root{
  --navy:#1F2A5A;
  --navy-mid:#2E3A8C;
  --navy-soft:#3B47A3;
  --navy-deep:#0B0F19;
  --orange:#FF6A1A;
  --orange-hot:#FF8440;
  --orange-soft:#FFD1B0;
  --grey-dark:#4B5563;
  --grey-mid:#8A8F98;
  --grey-light:#D1D5DB;
  --ink:#0B0F19;
  --ink-soft:#4B5563;
  --silver:#8A8F98;
  --silver-light:#D1D5DB;
  --paper:#FFFFFF;
  --paper-warm:#F5F7FA;
  --grad-hero:linear-gradient(135deg,#1F2A5A 0%,#2E3A8C 55%,#0B0F19 100%);
  --grad-hero-v:linear-gradient(180deg,#1F2A5A 0%,#141B3D 60%,#0B0F19 100%);
  --grad-dark:linear-gradient(180deg,#141B3D 0%,#0B0F19 100%);
  --grad-indigo:linear-gradient(135deg,#2E3A8C 0%,#1F2A5A 100%);
  --grad-glow-orange:radial-gradient(ellipse 60% 50% at 80% 20%,rgba(255,106,26,0.20) 0%,transparent 60%);
  --grad-glow-indigo:radial-gradient(ellipse 70% 50% at 15% 85%,rgba(46,58,140,0.45) 0%,transparent 60%);
  --line:rgba(11,15,25,0.08);
  --line-strong:rgba(11,15,25,0.16);
  --f-display:'Archivo',-apple-system,sans-serif;
  --f-serif:'Instrument Serif',Georgia,serif;
  --f-mono:'JetBrains Mono',ui-monospace,monospace;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{
  font-family:var(--f-display);
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

.container{max-width:1440px;margin:0 auto;padding:0 40px;}
@media (max-width:768px){.container{padding:0 20px;}}

.mono{font-family:var(--f-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;font-weight:500;}
.serif{font-family:var(--f-serif);font-style:italic;font-weight:400;}
.eyebrow{font-family:var(--f-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;color:var(--orange);}
.eyebrow-light{font-family:var(--f-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;color:var(--silver);}

/* --- ANNOUNCEMENT BAR --- */
.announce{background:var(--ink);color:var(--paper);font-size:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.08);}
.announce .container{display:flex;justify-content:space-between;align-items:center;gap:24px;}
.announce-left{display:flex;align-items:center;gap:10px;}
.announce-tag{background:var(--orange);color:var(--ink);padding:2px 8px;border-radius:2px;font-weight:700;font-size:10px;letter-spacing:0.08em;}
.announce-right{display:flex;gap:24px;align-items:center;font-size:11px;color:var(--silver);}
.announce-right a{transition:color .2s;display:flex;align-items:center;gap:6px;}
.announce-right a:hover{color:var(--orange);}
.announce-right .sep{opacity:0.3;}
@media (max-width:900px){.announce-right .hide-sm{display:none;}}

/* --- NAV --- */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,0.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line);transition:all .3s var(--ease);}
.nav.scrolled{background:rgba(255,255,255,0.98);box-shadow:0 2px 20px rgba(11,15,25,0.08);border-bottom-color:rgba(11,15,25,0.06);}
.nav.scrolled .container{height:66px;}
.nav.scrolled .logo img{height:30px;}
.announce{transition:max-height .35s var(--ease), padding .35s var(--ease), opacity .25s var(--ease);max-height:80px;overflow:hidden;}
.announce.hidden{max-height:0;padding-top:0;padding-bottom:0;opacity:0;border-bottom-width:0;}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:76px;position:relative;}
.logo{display:flex;align-items:center;gap:14px;}
.logo img{height:34px;width:auto;}
.logo-tag{font-family:var(--f-mono);font-size:9.5px;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy);padding-left:14px;border-left:1px solid var(--line-strong);line-height:1.4;display:none;}
@media (min-width:1100px){.logo-tag{display:block;}}
.nav-main{display:flex;align-items:center;gap:4px;}
@media (max-width:1100px){.nav-main{display:none;}}

/* CRITICAL FIX: nav-item is position:static so mega menu positions relative to .nav instead */
.nav-item{position:static;}
.nav-link{display:flex;align-items:center;gap:6px;padding:14px 14px;font-size:14px;font-weight:500;color:var(--ink);transition:color .15s;cursor:pointer;}
.nav-link:hover{color:var(--orange);}
.nav-link.active{color:var(--orange);}
.nav-link svg{width:10px;height:10px;opacity:0.5;transition:transform .2s;}
.nav-item:hover .nav-link svg{transform:rotate(180deg);}
.nav-right{display:flex;align-items:center;gap:12px;}
.btn-ghost{font-size:13px;font-weight:500;color:var(--ink);padding:10px 16px;border:1px solid var(--line-strong);border-radius:2px;transition:all .2s;display:inline-flex;align-items:center;gap:8px;}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--paper);}
.btn-primary{font-size:13px;font-weight:600;color:var(--paper);background:var(--navy);padding:11px 20px;border-radius:2px;transition:all .2s;display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden;}
.btn-primary::before{content:'';position:absolute;inset:0;background:var(--orange);transform:translateY(100%);transition:transform .25s var(--ease);}
.btn-primary span{position:relative;z-index:1;}
.btn-primary:hover::before{transform:translateY(0);}
.btn-primary:hover{color:var(--ink);}
.hamburger{display:none;width:40px;height:40px;align-items:center;justify-content:center;}
@media (max-width:1100px){.hamburger{display:flex;}}
.hamburger svg{width:20px;height:20px;}

/* MEGA MENU — full-width panel anchored to .nav, content centered within container */
.mega{
  position:absolute;
  top:100%;
  left:0;
  right:0;
  width:100%;
  background:var(--paper);
  border-top:1px solid var(--line);
  box-shadow:0 24px 60px rgba(11,15,25,0.10);
  opacity:0;
  visibility:hidden;
  transform:translateY(6px);
  transition:opacity .2s var(--ease),visibility .2s,transform .2s var(--ease);
  pointer-events:none;
  z-index:99;
}
.nav-item:hover .mega{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;}
.mega-inner{max-width:1440px;margin:0 auto;padding:40px;}
.mega-grid{display:grid;grid-template-columns:1.2fr 1.2fr 1.2fr 1fr;gap:40px;}
.mega-grid.three-col{grid-template-columns:1fr 1fr 1fr 1.1fr;}
.mega-grid.two-col{grid-template-columns:1fr 1fr 1.1fr;}
.mega-col h4{font-family:var(--f-mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--orange);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--line);}
.mega-link{display:block;padding:7px 0;font-size:13.5px;color:var(--ink);transition:all .15s;font-weight:500;}
.mega-link:hover{color:var(--orange);transform:translateX(3px);}
.mega-link small{display:block;font-size:11px;color:var(--ink-soft);opacity:0.6;font-weight:400;margin-top:1px;}
.mega-feature{background:linear-gradient(135deg,#1F2A5A 0%,#2E3A8C 100%);color:var(--paper);padding:24px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;}
.mega-feature::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;background:radial-gradient(circle,rgba(255,106,26,0.4) 0%,transparent 70%);filter:blur(30px);}
.mega-feature > *{position:relative;z-index:1;}
.mega-feature .eyebrow{color:var(--orange);margin-bottom:10px;}
.mega-feature h5{font-size:20px;font-weight:700;line-height:1.2;margin-bottom:10px;}
.mega-feature p{font-size:12.5px;opacity:0.85;margin-bottom:16px;line-height:1.5;}
.mega-feature a{font-size:12px;color:var(--orange);font-weight:600;display:inline-flex;align-items:center;gap:6px;}

/* --- SHARED BUTTONS --- */
.btn-hero{display:inline-flex;align-items:center;gap:10px;padding:16px 24px;font-size:14px;font-weight:600;border-radius:2px;transition:all .25s var(--ease);}
.btn-hero.primary{background:var(--orange);color:var(--ink);}
.btn-hero.primary:hover{background:var(--orange-hot);transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,106,26,0.35);}
.btn-hero.ghost{color:var(--paper);border:1px solid rgba(255,255,255,0.25);}
.btn-hero.ghost:hover{border-color:var(--orange);color:var(--orange);}
.btn-hero.ghost.dark{color:var(--ink);border-color:var(--line-strong);}
.btn-hero.ghost.dark:hover{border-color:var(--ink);background:var(--ink);color:var(--paper);}
.btn-hero svg{width:16px;height:16px;transition:transform .2s;}
.btn-hero:hover svg{transform:translateX(3px);}

/* --- SHARED LINK ARROW --- */
.link-arrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;font-weight:500;color:var(--ink);padding-bottom:6px;border-bottom:1px solid var(--ink);transition:all .2s;}
.link-arrow.light{color:var(--paper);border-bottom-color:var(--paper);}
.link-arrow:hover{color:var(--orange);border-bottom-color:var(--orange);}
.link-arrow svg{width:12px;height:12px;transition:transform .2s;}
.link-arrow:hover svg{transform:translateX(4px);}

/* --- FOOTER --- */
.footer{background:var(--grad-dark);color:var(--silver-light);padding:90px 0 32px;position:relative;overflow:hidden;}
.footer::after{content:'';position:absolute;top:20%;right:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(46,58,140,0.35) 0%,transparent 70%);filter:blur(60px);pointer-events:none;}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange) 0%,var(--navy) 30%,var(--orange) 60%,var(--navy) 100%);opacity:0.7;}
.footer-top{display:grid;grid-template-columns:1.4fr 3fr;gap:80px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:40px;}
@media (max-width:900px){.footer-top{grid-template-columns:1fr;gap:40px;}}
.footer-brand img{height:38px;margin-bottom:28px;}
.footer-logo-link{display:inline-block;transition:opacity .2s;line-height:0;}
.footer-logo-link:hover{opacity:0.85;}
.logo{cursor:pointer;}
.footer-tagline{font-family:var(--f-serif);font-style:italic;font-size:22px;line-height:1.3;color:var(--paper);margin-bottom:24px;max-width:400px;}
.footer-tagline .accent{color:var(--orange);}
.footer-addr{font-size:13px;line-height:1.7;color:var(--silver);margin-bottom:20px;}
.footer-addr strong{color:var(--paper);font-weight:600;display:block;margin-bottom:4px;font-size:12px;font-family:var(--f-mono);letter-spacing:0.1em;text-transform:uppercase;}
.footer-socials{display:flex;gap:8px;}
.footer-social{width:38px;height:38px;border:1px solid rgba(255,255,255,0.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--silver);transition:all .2s;}
.footer-social:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-2px);}
.footer-social svg{width:15px;height:15px;}
.footer-links{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
@media (max-width:700px){.footer-links{grid-template-columns:repeat(2,1fr);}}
.footer-col h5{font-family:var(--f-mono);font-size:10.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--orange);margin-bottom:18px;font-weight:600;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.footer-col a{font-size:13px;color:var(--silver);transition:color .15s;}
.footer-col a:hover{color:var(--orange);}
.footer-newsletter{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);padding:28px;margin-bottom:40px;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;}
@media (max-width:800px){.footer-newsletter{grid-template-columns:1fr;gap:20px;}}
.footer-newsletter h4{font-size:18px;font-weight:700;color:var(--paper);margin-bottom:6px;letter-spacing:-0.015em;}
.footer-newsletter h4 .accent{font-family:var(--f-serif);font-style:italic;font-weight:400;color:var(--orange);}
.footer-newsletter p{font-size:12.5px;color:var(--silver);opacity:0.8;}
.newsletter-form{display:flex;gap:8px;}
.newsletter-form input{flex:1;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);padding:12px 16px;font-family:inherit;font-size:13px;color:var(--paper);border-radius:2px;transition:border-color .2s;}
.newsletter-form input:focus{outline:none;border-color:var(--orange);}
.newsletter-form input::placeholder{color:var(--silver);opacity:0.6;}
.newsletter-form button{background:var(--orange);color:var(--ink);padding:12px 18px;font-weight:600;font-size:13px;border-radius:2px;transition:background .2s;}
.newsletter-form button:hover{background:var(--orange-hot);}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:20px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,0.1);
  font-size:12px;
  color:var(--silver);
}
.footer-bottom-right{
  display:flex;
  align-items:center;
  gap:22px;
  flex-wrap:wrap;
}
.footer-legal{display:flex;gap:20px;flex-wrap:wrap;}
.footer-legal a{transition:color .15s;color:var(--silver);}
.footer-legal a:hover{color:var(--orange);}
.footer-copy{opacity:0.7;}

/* Powered by NOOX — inline with legal links */
.footer-powered{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding-left:22px;
  border-left:1px solid rgba(255,255,255,0.15);
}
.footer-powered .label{
  font-family:var(--f-mono);
  font-size:9px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--silver);
  opacity:0.5;
}
.footer-powered a{
  display:inline-flex;
  align-items:center;
  transition:opacity .2s;
  opacity:0.75;
}
.footer-powered a:hover{opacity:1;}
.footer-powered a img{
  height:14px;
  width:auto;
  display:block;
  opacity:0.9;
  transition:opacity .2s;
}
.footer-powered a:hover img{opacity:1;}

/* --- REVEAL ANIMATION --- */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(30px);transition:all .8s var(--ease-out);}
  .reveal.in{opacity:1;transform:translateY(0);}
}
.fade-up{opacity:0;transform:translateY(24px);animation:fadeUp 1s var(--ease-out) forwards;}
.fade-up.d1{animation-delay:0.1s;}
.fade-up.d2{animation-delay:0.22s;}
.fade-up.d3{animation-delay:0.34s;}
.fade-up.d4{animation-delay:0.46s;}
.fade-up.d5{animation-delay:0.58s;}
@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}

/* ==========================================================
   GLOBAL MOBILE RESPONSIVE RULES
   Single column ≤ 640px · Horizontal scroll for wide content
   ========================================================== */
html { max-width:100vw; overflow-x:hidden; }
body { max-width:100vw; }
img, svg, video { max-width:100%; height:auto; }

/* Horizontal scroll utility */
.h-scroll{display:flex;gap:16px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scrollbar-width:thin;-webkit-overflow-scrolling:touch;padding-bottom:12px;}
.h-scroll > *{scroll-snap-align:start;flex:0 0 auto;}
.h-scroll::-webkit-scrollbar{height:4px;}
.h-scroll::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:2px;}

/* Mobile drawer navigation */
.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(360px,85vw);background:linear-gradient(180deg,#141B3D 0%,#0B0F19 100%);color:var(--paper);z-index:200;transform:translateX(100%);transition:transform .35s var(--ease);overflow-y:auto;padding:28px 28px 40px;box-shadow:-20px 0 60px rgba(0,0,0,0.4);}
.mobile-drawer.open{transform:translateX(0);}
.mobile-drawer-bg{position:fixed;inset:0;background:rgba(11,15,25,0.5);backdrop-filter:blur(4px);z-index:199;opacity:0;pointer-events:none;transition:opacity .3s;}
.mobile-drawer-bg.open{opacity:1;pointer-events:auto;}
.mobile-close{position:absolute;top:20px;right:22px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(255,255,255,0.15);color:var(--paper);background:none;cursor:pointer;}
.mobile-close svg{width:16px;height:16px;}
.mobile-nav-list{list-style:none;margin:54px 0 28px;padding:0;}
.mobile-nav-list li{border-bottom:1px solid rgba(255,255,255,0.08);}
.mobile-nav-list a{display:block;padding:16px 0;font-size:18px;font-weight:600;color:var(--paper);letter-spacing:-0.01em;transition:color .15s;}
.mobile-nav-list a:hover{color:var(--orange);}
.mobile-nav-list small{display:block;font-family:var(--f-mono);font-size:9.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--silver);margin-top:2px;font-weight:500;}
.mobile-drawer-cta{display:flex;flex-direction:column;gap:10px;margin-top:28px;}
.mobile-drawer-cta a{justify-content:center;width:100%;}
.mobile-drawer-contact{margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.08);font-size:12.5px;color:var(--silver);line-height:1.7;}
.mobile-drawer-contact a{color:var(--paper);font-weight:500;display:block;margin-top:4px;transition:color .15s;}
.mobile-drawer-contact a:hover{color:var(--orange);}

/* Tablet breakpoint */
@media (max-width:1024px){
  .section{padding:72px 0;}
  .container{padding:0 24px;}
}

/* Mobile breakpoint — single column enforced */
@media (max-width:640px){
  .container{padding:0 18px;}
  .section{padding:56px 0;}
  .section-head{margin-bottom:32px;}
  .section-head-row{flex-direction:column;align-items:flex-start;gap:20px;margin-bottom:32px;}

  /* Announcement bar */
  .announce .container{flex-direction:column;align-items:flex-start;gap:10px;}
  .announce-left{font-size:11px;line-height:1.4;}

  /* Hero (homepage + inner) */
  .hero h1{font-size:44px;letter-spacing:-0.025em;}
  .hero-lede{font-size:15px;}
  .hero-ctas{flex-direction:column;align-items:stretch;}
  .hero-ctas .btn-hero{justify-content:center;width:100%;}
  .hero-metrics{grid-template-columns:1fr 1fr;gap:20px;}
  .metric .num{font-size:28px;}

  /* Trust bar — horizontal scroll on mobile */
  .trust-bar{padding:24px 0;}
  .trust-bar .container{flex-direction:column;align-items:flex-start;gap:16px;}
  .trust-logos{display:flex;gap:32px;overflow-x:auto;overflow-y:hidden;width:100%;padding-bottom:8px;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  .trust-logos::-webkit-scrollbar{display:none;}
  .trust-logo{flex-shrink:0;height:22px;}
  .trust-logo.lg{height:26px;}
  .trust-logo.sm{height:18px;}

  /* =============================================================
     MOBILE GRID PATTERN — One card per screen, horizontal swipe
     Whitelisted carousels only. Default is wrap or stack.
     ============================================================= */

  /* Keep footer and hero metrics as stacked columns (not carousels) */
  .footer-top{grid-template-columns:1fr !important;}
  .footer-links{grid-template-columns:1fr 1fr;gap:24px;}
  .platform-hero{grid-template-columns:1fr !important;}

  /* Universal horizontal-scroll carousel for multi-item grids */
  .solutions-grid,
  .cap-row,
  .platform-list,
  .supply-grid,
  .case-grid,
  .insight-grid,
  .certs-grid,
  .ind-grid,
  .tech-row{
    display:flex !important;
    flex-wrap:nowrap;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:14px;
    width:calc(100% + 36px);
    margin-left:-18px;
    padding:0 18px 16px;
  }
  .solutions-grid::-webkit-scrollbar,
  .cap-row::-webkit-scrollbar,
  .platform-list::-webkit-scrollbar,
  .supply-grid::-webkit-scrollbar,
  .case-grid::-webkit-scrollbar,
  .insight-grid::-webkit-scrollbar,
  .certs-grid::-webkit-scrollbar,
  .ind-grid::-webkit-scrollbar,
  .tech-row::-webkit-scrollbar{display:none;}

  /* Each card: ~87% of viewport so next card peeks in (swipe hint) */
  .solutions-grid > *,
  .cap-row > *,
  .platform-list > *,
  .supply-grid > *,
  .case-grid > *,
  .insight-grid > *,
  .certs-grid > *,
  .ind-grid > *{
    flex:0 0 87%;
    scroll-snap-align:start;
    max-width:none;
  }

  /* Tech row (partner logos) — smaller items, multiple per view */
  .tech-row > *{flex:0 0 auto;scroll-snap-align:start;}

  /* Industries keep their taller height for good visual anchor */
  .ind-tile{min-height:200px;}

  /* Cert row inline (certs-right) — horizontal scroll */
  .certs-right{display:flex !important;overflow-x:auto;overflow-y:hidden;gap:1px;width:calc(100% + 36px);margin-left:-18px;padding:0 18px 8px;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  .certs-right::-webkit-scrollbar{display:none;}
  .cert-item{flex:0 0 130px;padding:18px 12px;}

  /* Visual cue: subtle scroll-hint mask under carousels */
  .solutions-grid,
  .cap-row,
  .case-grid,
  .insight-grid{
    -webkit-mask-image:linear-gradient(90deg, #000 88%, rgba(0,0,0,0.1) 100%);
            mask-image:linear-gradient(90deg, #000 88%, rgba(0,0,0,0.1) 100%);
  }

  /* CTA banner */
  .cta-banner{padding:72px 0;}
  .cta-inner h2{font-size:40px;}
  .cta-buttons{flex-direction:column;align-items:stretch;}
  .cta-buttons .btn-hero{justify-content:center;width:100%;}
  .cta-contact-ways{gap:16px;flex-direction:column;align-items:flex-start;}

  /* Footer */
  .footer{padding:56px 0 24px;}
  .footer-top{gap:36px;padding-bottom:40px;}
  .footer-tagline{font-size:20px;}
  .footer-newsletter{grid-template-columns:1fr !important;gap:16px;padding:22px;}
  .newsletter-form{flex-direction:column;}
  .newsletter-form button{width:100%;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:14px;font-size:11px;}
  .footer-legal{flex-wrap:wrap;gap:14px;}
  .footer-powered{padding:14px 0;gap:8px;}
  .footer-powered a img{height:9px;}
  .footer-powered .label{font-size:8.5px;letter-spacing:0.14em;}

  /* Mega menu hidden on mobile — drawer handles nav */
  .mega{display:none !important;}
}

/* Very small screens */
@media (max-width:380px){
  .hero h1{font-size:36px;}
  .section-head h2{font-size:28px;}
  .hero-metrics{grid-template-columns:1fr;}
  .footer-links{grid-template-columns:1fr;}
}


/* ========================================================== */
/* MOBILE NAVIGATION — slide-out panel + header adjustments    */
/* ========================================================== */

@media (max-width:1100px) {
  /* Hide Portal button on mobile — available in hamburger */
  .nav-right .btn-ghost {
    display: none;
  }
  /* Make Book consultation more compact on mobile */
  .btn-primary {
    font-size: 12px;
    padding: 10px 14px;
  }
  .nav-right {
    gap: 8px;
  }
}

/* Mobile slide-out menu overlay */
.mobile-nav-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: min(380px, 100vw);
  height: 100vh;
  background: var(--ink);
  color: var(--paper);
  z-index: 1000;
  overflow-y: auto;
  overflow-x: hidden;
  transform: translateX(100%);
  transition: transform .3s var(--ease);
  box-shadow: -8px 0 40px rgba(0, 0, 0, 0.3);
  padding: 28px 28px 80px 28px;
}
body.mobile-nav-open .mobile-nav-panel {
  transform: translateX(0);
}

/* Backdrop */
.mobile-nav-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
body.mobile-nav-open .mobile-nav-backdrop {
  opacity: 1;
  pointer-events: auto;
}

/* Prevent body scroll when menu open */
body.mobile-nav-open {
  overflow: hidden;
}

/* Close button in panel */
.mobile-nav-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--paper);
  opacity: 0.8;
  cursor: pointer;
  border: 0;
  background: transparent;
}
.mobile-nav-close:hover {
  opacity: 1;
}

/* Logo in panel */
.mobile-nav-panel .mn-logo {
  display: block;
  height: 28px;
  width: auto;
  margin-bottom: 28px;
}

/* Section headings in panel */
.mobile-nav-panel h5 {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--orange);
  margin: 24px 0 10px 0;
  padding-top: 18px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.mobile-nav-panel h5:first-of-type {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

/* Links in panel */
.mobile-nav-panel a {
  display: block;
  padding: 11px 0;
  font-size: 15px;
  color: var(--silver-light);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  transition: color .15s;
}
.mobile-nav-panel a:hover,
.mobile-nav-panel a:focus {
  color: var(--orange);
}

/* Primary CTA in panel */
.mobile-nav-panel .mn-cta {
  display: block;
  background: var(--orange);
  color: var(--ink);
  font-weight: 600;
  text-align: center;
  padding: 14px;
  margin-top: 24px;
  border-radius: 2px;
  border: none;
  font-size: 14px;
}
.mobile-nav-panel .mn-cta:hover {
  background: var(--orange-hot);
  color: var(--ink);
}

/* Secondary ghost button in panel */
.mobile-nav-panel .mn-ghost {
  display: block;
  background: transparent;
  color: var(--paper);
  text-align: center;
  padding: 13px;
  margin-top: 10px;
  border-radius: 2px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  font-size: 14px;
  font-weight: 500;
}
.mobile-nav-panel .mn-ghost:hover {
  border-color: var(--orange);
  color: var(--orange);
}

/* Footer in panel */
.mobile-nav-panel .mn-footer {
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 12px;
  color: var(--silver);
  opacity: 0.7;
  line-height: 1.7;
}
.mobile-nav-panel .mn-footer a {
  display: inline;
  padding: 0;
  border: none;
  color: var(--silver);
}
.mobile-nav-panel .mn-footer a:hover {
  color: var(--orange);
}

/* Hamburger focus state when menu open */
body.mobile-nav-open .hamburger {
  color: var(--orange);
}


/* ============================================================ */
/* POST-LAUNCH FIX v2 — Mobile header layout                    */
/* Logo sizes superseded by v11.6 block below                   */
/* ============================================================ */
@media (max-width:1100px){
  .nav .container{padding:0 16px;}
  .logo{gap:10px;flex-shrink:0;}
  .logo-tag{display:none !important;}
  .nav-right{gap:6px;flex-shrink:0;}
  .btn-ghost{display:none !important;}
  .btn-primary{padding:10px 14px;font-size:12px;white-space:nowrap;}
  .btn-primary span{white-space:nowrap;}
  .btn-primary svg{display:none;}
}
@media (max-width:640px){
  .btn-primary{padding:8px 12px;font-size:11.5px;}
  /* Swap visible text: hide full text, show compact */
  .btn-primary span{font-size:0;}
  .btn-primary span::before{content:"Book";font-size:12px;font-weight:600;letter-spacing:0;}
  .hamburger{width:36px;height:36px;}
  .hamburger svg{width:18px;height:18px;}
}
@media (max-width:420px){
  .btn-primary{padding:7px 10px;}
  .announce{font-size:10px;}
  .announce .container{padding:6px 10px;gap:6px;}
  .announce-left{gap:6px;flex-wrap:wrap;}
  .announce-left span:not(.announce-tag){font-size:10px;line-height:1.3;}
}


/* ===============================================================
   v11.6 MOBILE SCROLL ARCHITECTURE — released 12 May 2026
   Supersedes v11.4 (overflow-x:clip) and v11.5 (touch-action:pan-y),
   neither of which closed the gesture gap on Android Chrome.

   ARCHITECTURAL RULE (codebase standard):
   - Body level: NO horizontal scroll, ever.
   - Section level: horizontal scroll allowed ONLY for specific
     UX-improving content (cards in a row, image strips, comparison
     tables, swipeable filter chip rows). Default elsewhere is
     wrap or stack.

   IMPLEMENTATION:
   - html / body: touch-action:pan-y + overflow-x:hidden + overscroll-behavior-x:none
     (denies all horizontal gesture by default at every layer)
   - Whitelisted carousel containers: explicit touch-action:pan-x
     (opt back into horizontal pan for designated UX surfaces)

   LOGO PRESENCE:
   - ≤1100px: 36px (up from 28)
   - ≤640px:  42px (up from 32)
   - ≤420px:  36px (up from 28)
   - Nav container height bumped accordingly to accommodate.
   =============================================================== */

@media (max-width:1100px){
  .nav .container{height:68px;}
  .logo img{height:36px !important;}
}
@media (max-width:640px){
  .nav .container{height:70px;padding:0 14px;}
  .logo img{height:42px !important;}
}
@media (max-width:420px){
  .nav .container{height:66px;padding:0 12px;}
  .logo img{height:36px !important;}
}

@media (max-width:900px){
  /* Body level: deny horizontal at every layer */
  html{
    touch-action:pan-y;
    overscroll-behavior-x:none;
    overflow-x:hidden;
    max-width:100vw;
  }
  body{
    touch-action:pan-y;
    overscroll-behavior-x:none;
    overflow-x:hidden;
    width:100%;
    max-width:100vw;
    position:relative;
  }

  /* Default for all direct content children: stay within viewport */
  body > *{
    max-width:100vw;
    overflow-x:hidden;
  }

  /* Hero hardening — decorative pseudo-children that previously leaked */
  .hero{
    overflow:hidden;
    max-width:100vw;
  }
  .hero-deco,
  .hero-photo,
  .hero::before,
  .hero::after{
    max-width:100vw;
  }

  /* SECTION-LEVEL OPT-IN: containers that legitimately need
     horizontal scroll for UX reasons. Cards in a row, image
     strips, comparison tables, filter chip rows. Each one
     gets explicit touch-action:pan-x so it works inside the
     body-level pan-y deny. */
  .solutions-grid,
  .cap-row,
  .platform-list,
  .supply-grid,
  .case-grid,
  .insight-grid,
  .certs-grid,
  .ind-grid,
  .tech-row,
  .h-scroll,
  .trust-logos,
  .certs-right{
    touch-action:pan-x;
    overflow-x:auto;
    overscroll-behavior-x:contain;
  }
}
