@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ============================================================
   NEOSPIDERS TECHNOLOGIES — v11.0
   Mobile-First | NTT DATA style nav | No Products
   ============================================================ */

:root {
  --primary:#1D4ED8;--primary-l:#3B82F6;--primary-ll:#60A5FA;--primary-lll:#93C5FD;
  --accent:#06B6D4;--accent-l:#22D3EE;
  --bg:#020814;--bg2:#030C1A;--bg3:#050F22;
  --card:rgba(29,78,216,0.05);--card-h:rgba(29,78,216,0.12);
  --border:rgba(59,130,246,0.12);--border-b:rgba(59,130,246,0.38);
  --green:#10B981;--white:#FFFFFF;
  --g300:#CBD5E1;--g400:#94A3B8;--g500:#64748B;--g600:#475569;
  --grad1:linear-gradient(135deg,#1D4ED8 0%,#3B82F6 50%,#06B6D4 100%);
  --grad2:linear-gradient(135deg,#1E3A8A 0%,#2563EB 100%);
  --grad3:linear-gradient(135deg,#0369A1 0%,#0EA5E9 100%);
  --font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --r:12px;--r2:18px;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --sh-b:0 8px 48px rgba(29,78,216,.25);
  --hdr-h:64px;
}

/* ── RESET & BASE ────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--font);background:var(--bg);color:var(--g400);font-size:16px;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--primary-ll);text-decoration:none;transition:color .2s}
a:hover{color:var(--white)}
ul{list-style:none}
button{font-family:var(--font);cursor:pointer;border:none;background:none;padding:0}
input,textarea,select{font-family:var(--font)}

/* ── LAYOUT ─────────────────────────────────────────────── */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 clamp(24px,4vw,48px)}}

.section{padding:clamp(48px,8vw,96px) 0}
.section-sm{padding:clamp(32px,5vw,56px) 0}

/* Mobile-first grids — stack by default, expand on larger screens */
.grid-2{display:grid;grid-template-columns:1fr;gap:clamp(24px,4vw,40px)}
.grid-3{display:grid;grid-template-columns:1fr;gap:clamp(16px,3vw,24px)}
.grid-4{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,2vw,20px)}
@media(min-width:640px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.grid-4{grid-template-columns:repeat(4,1fr)}}

/* Feature grids (with center alignment) */
.grid-2--feature{align-items:center;gap:clamp(24px,5vw,56px)}
.grid-2--contact{align-items:start;gap:clamp(24px,5vw,48px)}
.grid-2--stats{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
@media(max-width:480px){.grid-2--stats{grid-template-columns:1fr}}

.text-center{text-align:center}

/* ── TYPOGRAPHY ─────────────────────────────────────────── */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent-l);margin-bottom:18px}
.eyebrow::before{content:'';width:24px;height:1.5px;background:linear-gradient(90deg,var(--primary-l),var(--accent))}
.eyebrow.center{justify-content:center}

.h1{font-size:clamp(1.7rem,5.5vw,3.8rem);font-weight:800;line-height:1.1;letter-spacing:-.03em;color:var(--white)}
.h2{font-size:clamp(1.4rem,3.5vw,2.6rem);font-weight:700;line-height:1.2;letter-spacing:-.025em;color:var(--white)}
.h3{font-size:clamp(.95rem,2vw,1.1rem);font-weight:600;color:var(--white);line-height:1.4}
.lead{font-size:clamp(.88rem,2vw,1.05rem);color:var(--g400);line-height:1.8;max-width:620px}
.lead.c{margin:0 auto}
.gt{background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 24px;border-radius:var(--r);
  font-size:14px;font-weight:700;letter-spacing:.3px;
  transition:all .25s var(--ease);white-space:nowrap;
  cursor:pointer;text-align:center;min-height:48px;
  border:none;
}
.btn svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}
.btn-p{background:var(--grad1);color:#fff;box-shadow:0 0 0 1px rgba(29,78,216,.5),0 4px 20px rgba(29,78,216,.4)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(59,130,246,.6),0 8px 32px rgba(29,78,216,.6);color:#fff}
.btn-p:active{transform:none}
.btn-o{background:transparent;color:var(--white);border:1px solid rgba(59,130,246,.35)}
.btn-o:hover{border-color:var(--primary-ll);color:var(--primary-ll);background:rgba(59,130,246,.08)}
.btn-g{background:rgba(255,255,255,.05);color:var(--white);border:1px solid rgba(255,255,255,.1)}
.btn-g:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}

/* ── CARDS ───────────────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:clamp(16px,3vw,28px);transition:all .3s var(--ease);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.5),transparent);opacity:0;transition:opacity .3s}
.card:hover{background:var(--card-h);border-color:var(--border-b);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.4),var(--sh-b)}
.card:hover::before{opacity:1}

/* ============================================================
   HEADER — v11
   ============================================================ */
#hdr{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--hdr-h);
  transition:background .3s,border-color .3s;
  background:transparent;
}
#hdr.scrolled{background:rgba(2,8,20,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--hdr-h);gap:8px}

/* Logo */
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;min-height:48px}
.logo-icon{width:36px;height:36px;border-radius:9px;background:var(--grad1);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 20px rgba(29,78,216,.5)}
.logo-icon svg{width:18px;height:18px;fill:#fff}
.logo-name{font-size:14px;font-weight:700;color:var(--white);line-height:1.2;white-space:nowrap}
.logo-name small{display:block;font-size:8.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-top:1px}

/* Desktop nav links */
.nav-links{display:none;align-items:center;gap:2px}
@media(min-width:900px){.nav-links{display:flex}}
.nav-links a{font-size:14px;font-weight:500;color:var(--g400);padding:8px 12px;border-radius:8px;transition:.2s;white-space:nowrap;min-height:40px;display:flex;align-items:center}
.nav-links a:hover,.nav-links a.active{color:var(--white);background:rgba(59,130,246,.1)}

/* Desktop CTA */
.nav-cta{display:none;font-size:13px !important;padding:10px 20px !important;min-height:40px !important}
@media(min-width:900px){.nav-cta{display:inline-flex}}

/* Hamburger — 3 lines, clean */
.ham{
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  width:44px;height:44px;border-radius:8px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.04);
  transition:border-color .2s,background .2s;
  flex-shrink:0;
}
@media(min-width:900px){.ham{display:none}}
.ham:hover{border-color:var(--primary-ll);background:rgba(59,130,246,.1)}
.ham span{display:block;width:20px;height:2px;background:var(--white);border-radius:2px;transition:transform .3s,opacity .3s}
.ham.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.ham.is-open span:nth-child(2){opacity:0}
.ham.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ============================================================
   MOBILE MENU — NTT DATA style
   Full-screen overlay, clean large links, X top right
   ============================================================ */
.mob-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:1098;
  opacity:0;transition:opacity .3s;
}
.mob-overlay.active{display:block;opacity:1}

.mob{
  position:fixed;top:0;right:0;bottom:0;
  width:min(360px,100vw);
  background:#020c1e;
  z-index:1099;
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s var(--ease);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.mob.is-open{transform:translateX(0)}

/* Mobile menu header row — logo left, X right */
.mob-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;
  height:var(--hdr-h);
  border-bottom:1px solid rgba(59,130,246,.12);
  flex-shrink:0;
}
.mob-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.mob-logo-name{font-size:14px;font-weight:700;color:var(--white);white-space:nowrap}
.mob-close{
  width:44px;height:44px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--white);background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  transition:.2s;flex-shrink:0;
}
.mob-close:hover{background:rgba(59,130,246,.2);border-color:var(--primary-ll)}

/* Nav links — full width rows with bottom borders like NTT DATA */
.mob-nav{display:flex;flex-direction:column;flex:1;padding:8px 0}
.mob-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px;
  font-size:1.1rem;font-weight:600;
  color:var(--g300);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:color .2s,background .2s,padding-left .2s;
  min-height:60px;
  text-decoration:none;
}
.mob-link:hover{color:var(--white);background:rgba(59,130,246,.08);padding-left:30px}
.mob-link:last-child{
  margin:20px 20px 0;
  background:var(--grad1);color:#fff;
  border-radius:var(--r);border:none;
  justify-content:center;
  min-height:52px;font-size:1rem;
  box-shadow:0 4px 20px rgba(29,78,216,.5);
}
.mob-link:last-child:hover{padding-left:24px;transform:translateY(-2px);box-shadow:0 8px 28px rgba(29,78,216,.7)}

/* Safe area for iPhone notch */
@supports(padding:max(0px)){
  .mob{padding-bottom:env(safe-area-inset-bottom)}
  .container{
    padding-left:max(20px,env(safe-area-inset-left));
    padding-right:max(20px,env(safe-area-inset-right));
  }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100svh;display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:calc(var(--hdr-h) + 40px) 0 clamp(48px,8vw,80px);
}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(29,78,216,.05)1px,transparent 1px),linear-gradient(90deg,rgba(29,78,216,.05)1px,transparent 1px);
  background-size:64px 64px;animation:grid 24s linear infinite;
}
.hero-bg::after{
  content:'';position:absolute;
  width:min(700px,100vw);height:min(700px,100vw);
  top:-200px;right:-150px;
  background:radial-gradient(circle,rgba(29,78,216,.18)0%,rgba(6,182,212,.06)50%,transparent 70%);
}
.hero-glow2{position:absolute;width:min(600px,100vw);height:min(600px,100vw);bottom:-150px;left:-100px;background:radial-gradient(circle,rgba(15,23,42,.15)0%,transparent 70%)}
@keyframes grid{0%{background-position:0 0}100%{background-position:64px 64px}}

.hero-wrap{position:relative;z-index:1}
.hero-pill{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(29,78,216,.12);border:1px solid rgba(59,130,246,.3);
  border-radius:30px;padding:6px 16px 6px 10px;
  font-size:12px;font-weight:600;color:var(--primary-lll);
  margin-bottom:clamp(14px,3vw,24px);letter-spacing:.4px;
}
.hero-pill .dot{width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,var(--primary-l),var(--accent));animation:blink 2s ease-in-out infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1;box-shadow:0 0 8px rgba(6,182,212,.6)}50%{opacity:.3;box-shadow:none}}

.hero-h{font-size:clamp(1.9rem,6vw,4rem);font-weight:800;line-height:1.09;letter-spacing:-.03em;color:var(--white);margin-bottom:clamp(14px,2.5vw,24px)}
.hero-h .line2{display:block}
.hero-sub{font-size:clamp(.88rem,2vw,1.05rem);color:var(--g400);line-height:1.8;margin-bottom:clamp(24px,4vw,40px);max-width:600px}

/* Hero buttons — stack on mobile, row on desktop */
.hero-btns{display:flex;flex-direction:column;gap:12px;margin-bottom:clamp(28px,5vw,48px)}
.hero-btns .btn{width:100%;justify-content:center}
@media(min-width:540px){
  .hero-btns{flex-direction:row;flex-wrap:wrap}
  .hero-btns .btn{width:auto}
}

/* Stats — 2x2 grid on mobile */
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:640px){
  .hero-stats{
    grid-template-columns:repeat(4,1fr);
    border:1px solid var(--border);border-radius:var(--r);
    overflow:hidden;background:rgba(255,255,255,.018);
    gap:0;
  }
  .stat-cell{border-right:1px solid var(--border);border-radius:0;background:transparent}
  .stat-cell:last-child{border-right:none}
}
.stat-cell{padding:clamp(12px,2vw,18px) clamp(12px,2vw,16px);border:1px solid var(--border);border-radius:var(--r);background:rgba(29,78,216,.04)}
.stat-cell .n{font-size:clamp(1.2rem,3vw,1.7rem);font-weight:800;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;letter-spacing:-.02em}
.stat-cell .l{font-size:10px;color:var(--g500);letter-spacing:1.5px;text-transform:uppercase;margin-top:5px;font-weight:600}

/* Hero panel (code block) — desktop only */
.hero-panel-wrap{display:none}
@media(min-width:900px){.hero-panel-wrap{display:block;position:relative}}
.hero-panel{background:rgba(255,255,255,.028);border:1px solid rgba(59,130,246,.2);border-radius:var(--r2);padding:28px;position:relative;overflow:hidden;box-shadow:0 0 80px rgba(29,78,216,.1)}
.hero-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.7),transparent)}
.panel-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.panel-dots{display:flex;gap:7px}
.panel-dots span{width:11px;height:11px;border-radius:50%}
.pd1{background:#FF5F57}.pd2{background:#FFBD2E}.pd3{background:#27C93F}
.panel-title{font-size:11px;color:var(--g500);font-weight:600;letter-spacing:.5px}
.code{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:18px;font-family:'JetBrains Mono','Fira Code','Courier New',monospace;font-size:12px;line-height:1.75;margin-bottom:18px;overflow-x:auto}
.cc{color:var(--g500)}.ck{color:#60A5FA}.cs{color:#34D399}.cp{color:#FCD34D}.cw{color:var(--white)}.cn{color:#93C5FD}
.panel-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.pchip{display:flex;align-items:center;gap:7px;padding:5px 13px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;color:var(--g400);transition:.2s}
.pchip .cd{width:6px;height:6px;border-radius:50%}
.status-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(16,185,129,.07);border:1px solid rgba(16,185,129,.2);border-radius:9px}
.status-bar .sd{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;box-shadow:0 0 8px rgba(16,185,129,.5)}
.status-bar span{font-size:12px;font-weight:600;color:var(--green);letter-spacing:.3px}
.fc{position:absolute;background:rgba(5,15,35,.95);border:1px solid rgba(59,130,246,.28);border-radius:var(--r);padding:11px 15px;display:flex;align-items:center;gap:11px;backdrop-filter:blur(16px);animation:fy 3.5s ease-in-out infinite;z-index:2}
.fc:nth-child(2){animation-duration:4.2s;animation-delay:.8s}
.fc-ico{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fc-ico svg{width:15px;height:15px;fill:#fff}
.fc-txt{font-size:11px;font-weight:600;color:var(--white);line-height:1.3}
.fc-txt small{display:block;font-size:10px;color:var(--g500);font-weight:400}
.fc1{top:-18px;right:-18px}.fc2{bottom:-18px;left:-18px}
@keyframes fy{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* Desktop 2-col hero */
@media(min-width:900px){
  .hero-wrap{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(32px,5vw,64px)}
}

/* ============================================================
   TICKER
   ============================================================ */
.ticker{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:13px 0;background:rgba(29,78,216,.03)}
.ticker-t{display:flex;gap:44px;width:max-content;animation:tick 28s linear infinite}
.ticker-item{display:flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g500);white-space:nowrap}
.ticker-item .td{width:4px;height:4px;border-radius:50%;background:var(--primary-ll)}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================================
   SECTION HEADS
   ============================================================ */
.sh{margin-bottom:clamp(24px,5vw,48px)}
.sh.c{text-align:center}
.sh .h2{margin-bottom:12px}

/* ============================================================
   SERVICES
   ============================================================ */
.svc .sn{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px;display:block}
.svc-icon{width:46px;height:46px;border-radius:12px;border:1px solid rgba(59,130,246,.2);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:.3s;background:rgba(29,78,216,.06)}
.svc-icon svg{width:22px;height:22px;fill:var(--primary-ll);transition:.3s}
.svc:hover .svc-icon{background:var(--grad1);border-color:transparent;box-shadow:0 0 20px rgba(29,78,216,.5)}
.svc:hover .svc-icon svg{fill:#fff}
.svc .h3{margin-bottom:9px}
.svc p{font-size:.9rem;color:var(--g400);line-height:1.75}
.svc-link{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-top:18px;transition:gap .2s}
.svc-link svg{width:11px;height:11px;fill:var(--primary-ll)}
.svc:hover .svc-link{gap:10px}

/* ============================================================
   WHY US
   ============================================================ */
.fi{display:flex;gap:16px;padding:clamp(14px,2vw,20px);border:1px solid var(--border);border-radius:var(--r);background:var(--card);transition:.3s}
.fi:hover{border-color:var(--border-b);background:var(--card-h)}
.fi-ico{width:42px;height:42px;border-radius:10px;border:1px solid rgba(59,130,246,.2);background:rgba(29,78,216,.07);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.3s}
.fi-ico svg{width:20px;height:20px;fill:var(--primary-ll)}
.fi:hover .fi-ico{background:var(--grad1);border-color:transparent}
.fi:hover .fi-ico svg{fill:#fff}
.fi h4{font-size:14px;font-weight:600;color:var(--white);margin-bottom:4px}
.fi p{font-size:.85rem;color:var(--g400);line-height:1.6}
.tech-b{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:9px;padding:9px 14px;font-size:13px;font-weight:500;color:var(--g400);transition:.2s;white-space:nowrap}
.tech-b:hover{border-color:var(--border-b);color:var(--white);background:var(--card-h)}
.tech-b span{width:7px;height:7px;border-radius:3px;flex-shrink:0}
.tech-row{display:flex;gap:8px;flex-wrap:wrap}

/* ============================================================
   ABOUT
   ============================================================ */
.abox{border-radius:var(--r2);overflow:hidden;border:1px solid var(--border);background:var(--bg3);display:flex;align-items:center;justify-content:center;aspect-ratio:4/3}
.abox img{width:100%;height:100%;object-fit:cover}
.aphold{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--g500);text-align:center;font-size:12px;font-weight:500;padding:20px}
.aphold svg{width:48px;height:48px;fill:var(--g500);opacity:.4}
.exp-b{background:var(--grad1);border-radius:var(--r);padding:18px 22px;text-align:center;box-shadow:0 8px 32px rgba(29,78,216,.5);display:inline-block;margin-top:20px}
@media(min-width:900px){.exp-b{position:absolute;bottom:-14px;right:-14px;margin-top:0}}
.exp-b .en{font-size:2rem;font-weight:800;color:#fff;line-height:1}
.exp-b .el{font-size:10px;color:rgba(255,255,255,.8);letter-spacing:1.5px;text-transform:uppercase;margin-top:4px;font-weight:600}
.vals{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:22px}
@media(max-width:400px){.vals{grid-template-columns:1fr}}
.vi{display:flex;align-items:flex-start;gap:10px;padding:11px 13px;background:var(--card);border:1px solid var(--border);border-radius:9px;transition:.2s}
.vi:hover{border-color:var(--border-b)}
.vi-ck{width:20px;height:20px;border-radius:50%;background:var(--grad1);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.vi-ck svg{width:11px;height:11px;fill:#fff}
.vi span{font-size:13px;font-weight:500;color:var(--white);line-height:1.4}

/* ============================================================
   TEAM
   ============================================================ */
.tcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:.3s}
.tcard:hover{border-color:var(--border-b);transform:translateY(-4px);box-shadow:var(--sh-b)}
.tphoto{aspect-ratio:1;background:var(--bg3);display:flex;align-items:center;justify-content:center}
.tphoto img{width:100%;height:100%;object-fit:cover}
.tph{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--g500)}
.tph svg{width:48px;height:48px;fill:var(--g500);opacity:.3}
.tph span{font-size:11px;font-weight:500}
.tbody{padding:16px 18px}
.tbody h4{font-size:14px;font-weight:700;color:var(--white);margin-bottom:2px}
.tbody .role{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}
.tsoc{display:flex;gap:7px}
.tsoc a{min-width:44px;min-height:44px;border-radius:7px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:.2s}
.tsoc a svg{width:12px;height:12px;fill:var(--g500);transition:.2s}
.tsoc a:hover{border-color:var(--primary-ll)}
.tsoc a:hover svg{fill:var(--primary-ll)}

/* ============================================================
   CONTACT
   ============================================================ */
.fw{background:rgba(29,78,216,.04);border:1px solid rgba(59,130,246,.15);border-radius:var(--r2);padding:clamp(20px,4vw,36px);position:relative;overflow:hidden}
.fw::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad1)}
.fg{margin-bottom:18px}
.fg label{display:block;font-size:12px;font-weight:700;color:var(--white);margin-bottom:7px;letter-spacing:.3px}
.fg input,.fg textarea,.fg select{
  width:100%;padding:13px 16px;
  background:rgba(255,255,255,.04);border:1px solid rgba(59,130,246,.15);
  border-radius:var(--r);color:var(--white);
  font-size:16px; /* CRITICAL: prevents iOS zoom */
  transition:.2s;outline:none;
  -webkit-appearance:none;
  min-height:48px;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--primary-ll);box-shadow:0 0 0 3px rgba(59,130,246,.15);background:rgba(29,78,216,.06)}
.fg textarea{min-height:130px;resize:vertical}
.fg select option{background:#061228;color:var(--white)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--g600)}
.fr{display:grid;grid-template-columns:1fr;gap:0}
@media(min-width:540px){.fr{grid-template-columns:1fr 1fr;gap:16px}}
.iitem{display:flex;gap:14px;align-items:flex-start;margin-bottom:24px}
.iico{width:42px;height:42px;border-radius:10px;border:1px solid rgba(59,130,246,.2);background:rgba(29,78,216,.07);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.iico svg{width:20px;height:20px;fill:var(--primary-ll)}
.iitem h5{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g400);margin-bottom:4px}
.iitem p{font-size:13px;color:var(--g400);line-height:1.6}
.iitem a{color:var(--g400)}.iitem a:hover{color:var(--primary-ll)}
.fm{display:none;padding:12px 16px;border-radius:9px;font-size:13px;font-weight:600;margin-bottom:14px}
.fm.ok{background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.25);color:var(--green)}
.fm.err{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:#EF4444}
.contact-info-card{background:rgba(29,78,216,.04);border:1px solid rgba(59,130,246,.12);border-radius:var(--r2);padding:clamp(20px,4vw,32px)}

/* ============================================================
   PAGE BANNER
   ============================================================ */
.pbanner{padding:calc(var(--hdr-h) + clamp(40px,6vw,80px)) 0 clamp(36px,5vw,60px);position:relative;overflow:hidden;text-align:center}
.pbanner::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(29,78,216,.04)1px,transparent 1px),linear-gradient(90deg,rgba(29,78,216,.04)1px,transparent 1px);background-size:64px 64px}
.pbanner::after{content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:min(700px,100vw);height:400px;background:radial-gradient(ellipse,rgba(29,78,216,.18),rgba(6,182,212,.06)40%,transparent 70%)}
.pbanner .container{position:relative;z-index:1}
.pbanner .h1{margin-bottom:14px}
.bc{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--g500);margin-bottom:18px;flex-wrap:wrap;justify-content:center}
.bc a{color:var(--g500)}.bc a:hover{color:var(--primary-ll)}
.bc .sep{color:var(--border-b)}.bc .cur{color:var(--primary-ll)}

/* ============================================================
   CTA
   ============================================================ */
.cta{background:linear-gradient(135deg,rgba(29,78,216,.12),rgba(6,182,212,.05));border:1px solid rgba(59,130,246,.18);border-radius:var(--r2);padding:clamp(32px,5vw,52px) clamp(20px,5vw,48px);text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.6),var(--accent),rgba(59,130,246,.6),transparent)}
.cta .h2{margin-bottom:12px}
.cta .lead{margin:0 auto 28px;max-width:540px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;flex-direction:column;align-items:center}
@media(min-width:480px){.cta-btns{flex-direction:row}}
.cta-btns .btn{width:100%;max-width:280px}
@media(min-width:480px){.cta-btns .btn{width:auto;max-width:none}}

/* ============================================================
   FOOTER — 3 columns (no products)
   ============================================================ */
#ftr{background:var(--bg2);border-top:1px solid var(--border)}
.fgrid{display:grid;grid-template-columns:1fr;gap:24px;padding:clamp(36px,6vw,60px) 0 clamp(24px,4vw,40px)}
@media(min-width:540px){.fgrid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.fgrid{grid-template-columns:2fr 1fr 1fr 1.2fr;gap:clamp(24px,4vw,48px)}}
.fbrand p{font-size:13px;color:var(--g500);line-height:1.75;margin-top:12px;max-width:280px}
.fsoc{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.fsoc a{min-width:44px;min-height:44px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:.2s}
.fsoc a svg{width:14px;height:14px;fill:var(--g500);transition:.2s}
.fsoc a:hover{border-color:var(--primary-ll);background:rgba(29,78,216,.1)}
.fsoc a:hover svg{fill:var(--primary-ll)}
.fcol h5{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--white);margin-bottom:16px}
.fcol ul{display:flex;flex-direction:column;gap:8px}
.fcol ul li a,.fcol ul li span{font-size:13px;color:var(--g500);display:flex;align-items:center;gap:6px;transition:.2s;min-height:36px}
.fcol ul li a::before{content:'›';color:var(--primary-ll);font-size:16px}
.fcol ul li a:hover{color:var(--white);padding-left:4px}
.fbot{border-top:1px solid var(--border);padding:18px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.fbot p,.fbot a{font-size:12px;color:var(--g500);font-weight:500}
.fbot a:hover{color:var(--primary-ll)}
.fleg{display:flex;gap:20px;flex-wrap:wrap}

/* Back to top */
.btt{position:fixed;bottom:max(20px,env(safe-area-inset-bottom,20px));right:20px;width:44px;height:44px;border-radius:10px;background:var(--grad1);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(29,78,216,.5);opacity:0;transform:translateY(14px);transition:.3s;z-index:997;border:none}
.btt.show{opacity:1;transform:translateY(0)}
.btt svg{width:16px;height:16px;fill:#fff}

/* ============================================================
   ANIMATIONS
   ============================================================ */
.rv{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.rv.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.06s}.d2{transition-delay:.12s}.d3{transition-delay:.18s}
.d4{transition-delay:.24s}.d5{transition-delay:.30s}.d6{transition-delay:.36s}

/* ============================================================
   CANVAS / PARTICLES
   ============================================================ */
#ns-particles,[id^="ns-ojt-"]{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero{position:relative;overflow:hidden}
.hero .container,.hero .hero-bg{position:relative;z-index:1}

/* ============================================================
   TRAINING
   ============================================================ */
.training-section{position:relative;background:linear-gradient(135deg,#010a18 0%,#030e20 50%,#061228 100%);overflow:hidden;isolation:isolate}
.training-section .container{position:relative;z-index:1}
.training-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 20% 40%,rgba(29,78,216,.2) 0%,transparent 60%),radial-gradient(ellipse 50% 60% at 80% 60%,rgba(6,182,212,.1) 0%,transparent 60%);z-index:0}
.training-grid{display:grid;grid-template-columns:1fr;gap:clamp(14px,2.5vw,20px);align-items:stretch}
@media(min-width:640px){.training-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.training-grid{grid-template-columns:1fr 1.1fr 1fr}}
.training-card{background:rgba(29,78,216,.05);border:1px solid rgba(59,130,246,.12);border-radius:18px;padding:clamp(18px,3vw,28px) clamp(16px,3vw,24px);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:transform .3s,border-color .3s,box-shadow .3s}
.training-card:hover{transform:translateY(-4px);border-color:rgba(59,130,246,.4);box-shadow:0 16px 48px rgba(29,78,216,.2)}
.tc-label{display:flex;align-items:center;gap:9px;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid rgba(59,130,246,.1)}
.tc-label svg{fill:var(--primary-ll);flex-shrink:0}
.tc-label-gold{background:linear-gradient(135deg,#F59E0B,#FCD34D);-webkit-background-clip:text;background-clip:text}
.tc-label-gold svg{fill:#F59E0B}
.tc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.tc-list li{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.85);font-size:14px;font-weight:500}
.tc-list li svg{width:20px;height:20px;fill:var(--primary-ll);flex-shrink:0}
.tc-benefits{display:flex;flex-direction:column;gap:10px}
.tcb,.tcb-mini{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:11px;font-weight:600;font-size:14px}
.tcb{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);color:var(--white)}
.tcb svg{fill:#F59E0B;width:18px;height:18px;flex-shrink:0}
.tcb-mini{background:rgba(29,78,216,.08);border:1px solid rgba(59,130,246,.18);color:rgba(255,255,255,.8)}
.tcb-mini svg{fill:var(--primary-ll);width:18px;height:18px;flex-shrink:0}
.tc-center{background:rgba(245,158,11,.05);border-color:rgba(245,158,11,.18)}
.tc-right{background:rgba(29,78,216,.07);border-color:rgba(59,130,246,.2)}
.tc-fee{text-align:center;padding:clamp(14px,2vw,20px);background:linear-gradient(135deg,rgba(29,78,216,.22),rgba(6,182,212,.12));border-radius:14px;border:1px solid rgba(59,130,246,.3)}
.tc-fee-amt{font-size:clamp(1.8rem,4vw,2.4rem);font-weight:800;background:var(--grad1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;letter-spacing:-.03em}
.tc-fee-dur{font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--g500);margin-top:6px}

/* ============================================================
   PRODUCT PAGE (kept as standalone page, just removed from nav)
   ============================================================ */
.pcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:all .3s;position:relative}
.pcard:hover{border-color:var(--border-b);transform:translateY(-5px);box-shadow:0 20px 56px rgba(0,0,0,.4),var(--sh-b)}
.pcard-top{padding:clamp(18px,3vw,32px);position:relative;overflow:hidden}
.pcard-top::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.pcard:nth-child(1) .pcard-top::before{background:var(--grad1)}
.pcard:nth-child(2) .pcard-top::before{background:var(--grad2)}
.pcard:nth-child(3) .pcard-top::before{background:var(--grad3)}
.plabel{display:inline-block;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:14px;border:1px solid}
.pname{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:800;color:var(--white);margin-bottom:10px;letter-spacing:-.02em}
.pdesc{font-size:.9rem;color:var(--g400);line-height:1.75}
.pcard-bot{padding:16px clamp(18px,3vw,32px) clamp(18px,3vw,24px);border-top:1px solid var(--border)}
.ptags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.ptag{font-size:11px;font-weight:500;padding:4px 10px;border-radius:5px;background:rgba(29,78,216,.07);border:1px solid rgba(59,130,246,.15);color:var(--g500)}
.prod-showcase{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:var(--r2);padding:clamp(24px,4vw,44px) clamp(20px,4vw,36px);text-align:center;position:relative;overflow:hidden}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:24px}
@media(max-width:400px){.feat-grid{grid-template-columns:1fr}}

/* ============================================================
   TOUCH DEVICES
   ============================================================ */
@media(hover:none){
  .card:hover,.pcard:hover,.tcard:hover,.training-card:hover,.fi:hover{transform:none !important;box-shadow:none !important}
}
:focus-visible{outline:2px solid var(--primary-ll);outline-offset:3px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}}

/* ============================================================

/* ============================================================
   v13 — PREMIUM XPRESSBUDDY COLOR SCHEME
   Light azure bg · Navy headings · Vibrant blue accents
   ============================================================ */
:root {
  --xb-bg:       #EBF3FF;
  --xb-bg2:      #DDEAFF;
  --xb-navy:     #0A1464;
  --xb-blue:     #2563EB;
  --xb-blue2:    #1D4ED8;
  --xb-tab-bg:   #D5E5FF;
  --xb-hex-bg:   #FFFFFF;
  --xb-hex-sh:   rgba(37,99,235,0.13);
  --xb-text:     #1E293B;
  --xb-muted:    #4A5568;
}

/* ── Light section pages ── */
.pbanner--light,
.tech-section { background: var(--xb-bg) !important; }

.pbanner--light::before {
  background-image:
    linear-gradient(rgba(37,99,235,.05) 1px, transparent 1px),
    linear-gradient(90deg,rgba(37,99,235,.05) 1px, transparent 1px) !important;
}
.pbanner--light::after {
  background: radial-gradient(ellipse,rgba(37,99,235,.14),rgba(96,165,250,.05) 40%,transparent 70%) !important;
}

/* heading/text overrides on light bg */
.h1--dark        { color: var(--xb-navy) !important; -webkit-text-fill-color: var(--xb-navy); }
.gt--blue        { background: linear-gradient(135deg,#1E40AF,#3B82F6); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.lead--dark      { color: var(--xb-muted) !important; }
.eyebrow--dark   { color: var(--xb-blue) !important; }
.eyebrow--dark::before { background: linear-gradient(90deg,var(--xb-blue),#60A5FA) !important; }
.bc--light a, .bc--light { color: var(--xb-muted) !important; }
.bc--light .cur  { color: var(--xb-blue) !important; }
.bc--light .sep  { color: rgba(37,99,235,.35) !important; }

/* ── Home tech section light bg ── */
.tech-section-home { background: var(--xb-bg) !important; }
.tech-section-home .sh .h2 { color: var(--xb-navy) !important; }
.tech-section-home .eyebrow { color: var(--xb-blue) !important; }
.tech-section-home .lead    { color: var(--xb-muted) !important; }
.tech-section-home .tech-b  {
  background: #fff !important; border-color: rgba(37,99,235,.18) !important;
  color: var(--xb-navy) !important; box-shadow: 0 2px 8px var(--xb-hex-sh);
}
.tech-section-home .tech-b:hover {
  background: var(--xb-blue) !important; color: #fff !important;
  border-color: var(--xb-blue) !important;
}
.tech-section-home .btn-g {
  background: var(--xb-blue) !important; color: #fff !important;
  border-color: var(--xb-blue) !important;
}

/* ============================================================
   TECH TABS — Premium pill style
   ============================================================ */
.tech-tabs-wrap {
  position: relative;
  margin-bottom: clamp(28px,4vw,48px);
}
.tech-tabs {
  display: flex;
  align-items: center;
  gap: 4px;
  background: var(--xb-tab-bg);
  border-radius: 60px;
  padding: 6px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  scroll-snap-type: x mandatory;
}
.tech-tabs::-webkit-scrollbar { display: none; }

.tech-tab {
  flex-shrink: 0;
  scroll-snap-align: start;
  padding: 10px clamp(14px,2.5vw,24px);
  border-radius: 60px;
  font-size: clamp(12px,1.8vw,14px);
  font-weight: 600;
  color: var(--xb-navy);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all .22s ease;
  white-space: nowrap;
  min-height: 44px;
  display: flex;
  align-items: center;
  letter-spacing: .01em;
}
.tech-tab:hover:not(.active) {
  background: rgba(37,99,235,.1);
  color: var(--xb-blue2);
}
.tech-tab.active {
  background: #ffffff;
  color: var(--xb-navy);
  font-weight: 700;
  box-shadow: 0 2px 14px rgba(37,99,235,.18);
}

/* Fade-out scroll hint on mobile */
@media(max-width:640px) {
  .tech-tabs-wrap::after {
    content: '';
    position: absolute;
    right: 0; top: 0; bottom: 0; width: 48px;
    background: linear-gradient(to right,transparent,var(--xb-bg));
    pointer-events: none; border-radius: 0 60px 60px 0; z-index: 1;
  }
}

/* ============================================================
   TECH PANELS
   ============================================================ */
.tech-panel {
  display: none;
  animation: techFadeIn .3s ease forwards;
}
.tech-panel.active { display: block; }
@keyframes techFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}

/* ============================================================
   HEX GRID — Premium hexagon cards
   ============================================================ */
.hex-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px,1fr));
  gap: clamp(16px,3vw,28px);
  justify-items: center;
}
@media(min-width:480px)  { .hex-grid { grid-template-columns: repeat(auto-fill,minmax(120px,1fr)); } }
@media(min-width:768px)  { .hex-grid { grid-template-columns: repeat(5,1fr); gap: 24px; } }
@media(min-width:1024px) { .hex-grid { grid-template-columns: repeat(6,1fr); gap: 28px; } }

.hex-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  cursor: default;
  transition: transform .25s ease;
}
.hex-item:hover { transform: translateY(-8px); }
.hex-item:focus-visible { outline: 2px solid var(--xb-blue); outline-offset: 4px; border-radius: 4px; }

/* Hexagon via clip-path */
.hex-shape {
  width: clamp(72px,14vw,92px);
  height: clamp(72px,14vw,92px);
  background: var(--xb-hex-bg);
  clip-path: polygon(50% 0%,93.3% 25%,93.3% 75%,50% 100%,6.7% 75%,6.7% 25%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px var(--xb-hex-sh), 0 1px 3px rgba(0,0,0,.06);
  transition: box-shadow .25s ease, transform .25s ease;
  position: relative;
}
.hex-item:hover .hex-shape {
  box-shadow: 0 10px 36px rgba(37,99,235,.24), 0 2px 6px rgba(0,0,0,.08);
}
/* Inner centering div for the icon */
.hex-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.hex-icon {
  width: clamp(32px,6vw,44px);
  height: clamp(32px,6vw,44px);
  display: block;
  flex-shrink: 0;
}
.hex-label {
  font-size: clamp(11px,1.6vw,13px);
  font-weight: 600;
  color: var(--xb-navy);
  text-align: center;
  line-height: 1.3;
  letter-spacing: .01em;
}

/* ============================================================
   v13 GRID & LAYOUT FIXES (contact, feature sections)
   ============================================================ */
.grid-2--feature { align-items: center; gap: clamp(24px,5vw,56px); }
.grid-2--contact { align-items: start; gap: clamp(24px,5vw,48px); }
.grid-2--stats   { grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 18px; }
.prod-showcase   { background:rgba(255,255,255,.02); border:1px solid var(--border); border-radius:var(--r2); padding:clamp(24px,4vw,44px); text-align:center; position:relative; overflow:hidden; }
.feat-grid       { display:grid; grid-template-columns:1fr 1fr; gap:9px; margin-bottom:24px; }
.abox--md        { min-height: clamp(200px,35vw,320px); }
.abox--lg        { min-height: clamp(220px,38vw,340px); }

@media(max-width:768px) {
  .grid-2--feature { grid-template-columns:1fr !important; gap:clamp(20px,6vw,32px) !important; direction:ltr !important; }
  .grid-2--contact { grid-template-columns:1fr !important; gap:24px !important; }
  .grid-2--stats   { grid-template-columns:1fr 1fr !important; }
  .feat-grid       { grid-template-columns:1fr !important; }
  .prod-showcase   { padding:22px 18px !important; }
  .abox--md,.abox--lg { min-height:200px !important; aspect-ratio:16/9 !important; }
  .exp-b { position:static !important; display:inline-block; margin-top:20px; }
}
@media(max-width:480px) {
  .grid-2--stats   { grid-template-columns:1fr !important; }
  .hex-grid        { grid-template-columns:repeat(3,1fr) !important; gap:12px !important; }
  .hex-shape       { width:62px; height:62px; }
  .hex-icon        { width:28px; height:28px; }
  .hex-label       { font-size:10px; }
}
@media(max-width:360px) {
  .hex-grid        { grid-template-columns:repeat(3,1fr) !important; }
}

/* ============================================================
   iPhone notch safe areas
   ============================================================ */
@supports(padding:max(0px)) {
  .container {
    padding-left:  max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
  }
  .mob  { padding-bottom: env(safe-area-inset-bottom); }
  .btt  { bottom: max(20px, env(safe-area-inset-bottom, 20px)); right: max(20px, env(safe-area-inset-right, 20px)); }
}

/* ============================================================
   OVERFLOW GUARD — no horizontal scroll on any device
   ============================================================ */
html,body { overflow-x:hidden; max-width:100%; }
.hero,.pbanner,section { overflow-x:hidden; }
.hero-bg::before,.hero-bg::after,.hero-glow2,.pbanner::before,.pbanner::after { pointer-events:none; max-width:100vw; }
