/* ============================================================
   TOKENS — #001520, #fe8fc0, #3cc5f2, #ffffff
============================================================ */
:root{
  --bg:          #001520;
  --bg-2:        #001c2a;
  --bg-3:        #002235;
  --bg-4:        #002840;
  --cyan:        #3cc5f2;
  --cyan-dim:    rgba(60,197,242,.15);
  --cyan-glow:   rgba(60,197,242,.35);
  --pink:        #fe8fc0;
  --purple:      #fe8fc0;
  --purple-dim:  rgba(254,143,192,.15);
  --green:       #3cc5f2;
  --green-dim:   rgba(60,197,242,.12);
  --amber:       #fe8fc0;
  --rose:        #fe8fc0;
  --border:      rgba(60,197,242,.12);
  --border-hi:   rgba(60,197,242,.4);
  --text-1:      #ffffff;
  --text-2:      rgba(255,255,255,.78);
  --text-3:      #ffffff;
  --ff-hud:      'Orbitron', monospace;
  --ff-body:     'Exo 2', sans-serif;
  --ff-mono:     'Share Tech Mono', monospace;
  --r:           8px;
  --ease:        cubic-bezier(.4,0,.2,1);
  --t:           .28s;
}

/* ============================================================
   RESET & BASE
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text-1);
  font-family:var(--ff-body);
  font-size:16px;
  line-height:1.7;
  overflow-x:hidden;
}

/* ============================================================
   SPACE BACKGROUND SYSTEM
============================================================ */
/* Fixed star canvas sits behind everything */
#space-canvas{
  position:fixed;inset:0;z-index:0;pointer-events:none;
}

/* Nebula gradient layers — slow drift */
#nebula{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 45% at 15% 25%, rgba(254,143,192,.14) 0%, transparent 70%),
    radial-gradient(ellipse 50% 60% at 85% 70%, rgba(60,197,242,.14) 0%, transparent 65%),
    radial-gradient(ellipse 40% 35% at 55% 10%, rgba(254,143,192,.1)  0%, transparent 60%),
    radial-gradient(ellipse 35% 50% at 30% 85%, rgba(60,197,242,.1) 0%, transparent 60%);
  animation: nebulaDrift 28s ease-in-out infinite alternate;
}
@keyframes nebulaDrift{
  0%  { transform: scale(1)    translate(0,0)     rotate(0deg); }
  33% { transform: scale(1.04) translate(1%,-1%)  rotate(.4deg); }
  66% { transform: scale(.97)  translate(-1%,2%)  rotate(-.3deg); }
  100%{ transform: scale(1.02) translate(2%,-.5%) rotate(.2deg); }
}

/* All page content sits on top of space layers */
#page-content{position:relative;z-index:2}

/* ============================================================
   LOADING SCREEN
============================================================ */
#loading-screen{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .8s ease, visibility .8s ease;
}
#loading-screen.fade-out{opacity:0;visibility:hidden}

.ls-logo{
  font-family:var(--ff-hud);font-size:clamp(1.6rem,4vw,2.8rem);font-weight:900;
  letter-spacing:.1em;text-align:center;margin-bottom:.5rem;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:lsPulse 2.5s ease-in-out infinite;
}
@keyframes lsPulse{0%,100%{filter:drop-shadow(0 0 16px rgba(60,197,242,.5))} 50%{filter:drop-shadow(0 0 36px rgba(254,143,192,.7))}}

.ls-tagline{
  font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.28em;
  color:var(--text-3);text-transform:uppercase;margin-bottom:3rem;text-align:center;
}

.ls-terminal{
  width:min(480px,88vw);
  background:rgba(0,21,32,.9);border:1px solid rgba(60,197,242,.2);
  border-radius:var(--r);padding:1.4rem 1.6rem;
  font-family:var(--ff-mono);font-size:.75rem;color:var(--green);
  margin-bottom:2rem;
  box-shadow:0 0 40px rgba(60,197,242,.08);
}
.ls-line{
  margin:.22rem 0;opacity:0;
  animation:lsLine .3s ease forwards;
  white-space:nowrap;overflow:hidden;
}
@keyframes lsLine{from{opacity:0;max-height:0}to{opacity:1;max-height:30px}}
.ls-line .lp{color:var(--cyan)}
.ls-line .lok{color:var(--green)}
.ls-line .lw{color:var(--amber)}
.ls-line .lc{color:var(--text-3)}

.ls-bar-wrap{width:min(480px,88vw)}
.ls-bar-labels{
  display:flex;justify-content:space-between;
  font-family:var(--ff-mono);font-size:.68rem;color:var(--text-3);margin-bottom:.4rem;
}
.ls-track{
  height:5px;background:rgba(60,197,242,.08);border-radius:3px;
  border:1px solid rgba(60,197,242,.15);overflow:hidden;
}
.ls-fill{
  height:100%;width:0%;border-radius:3px;
  background:linear-gradient(90deg,var(--cyan),var(--purple));
  box-shadow:0 0 14px var(--cyan);
  transition:width .12s linear;
  position:relative;
}
.ls-fill::after{
  content:'';position:absolute;right:0;top:0;bottom:0;width:20px;
  background:white;opacity:.35;filter:blur(5px);
}

/* ============================================================
   SPACE CHARACTER STICKERS
============================================================ */
.space-char{
  position:fixed;z-index:1;pointer-events:none;
  user-select:none;line-height:1;opacity:.45;
  animation:charFloat var(--dur,6s) var(--delay,0s) ease-in-out infinite;
  filter:drop-shadow(0 0 8px var(--glow,rgba(60,197,242,.6)));
  will-change:transform;
}
/* Drifters move slowly across screen */
.space-char.drifter{
  animation:charDrift var(--drift-dur,40s) var(--delay,0s) linear infinite;
}
.space-char img{
  width:100%;height:auto;display:block;vertical-align:middle;
}

@keyframes charFloat{
  0%,100%{transform:translateY(0)       rotate(var(--rot-start,0deg))}
  50%    {transform:translateY(-18px)   rotate(var(--rot-end,4deg))}
}
@keyframes charDrift{
  0%  {transform:translate(var(--dx-start,-10vw),var(--dy-start,20vh)) rotate(0deg);opacity:0}
    5%  {opacity:.45}
    95% {opacity:.45}
    100%{transform:translate(var(--dx-end,110vw), var(--dy-end,30vh))  rotate(var(--rot-end,20deg));opacity:0}
}

/* ============================================================
   SPACE DUST PARTICLES (canvas overlay above nebula)
============================================================ */
#dust-canvas{
  position:fixed;inset:0;z-index:2;pointer-events:none;
  opacity:.55;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* Hero transparent — space is the bg */
#hero{
  background:
    radial-gradient(ellipse 70% 55% at 65% 45%,rgba(60,197,242,.06) 0%,transparent 70%),
    radial-gradient(ellipse 50% 50% at 20% 75%,rgba(254,143,192,.05) 0%,transparent 65%),
    transparent !important;
}
/* Ticker semi-transparent */
.ticker{background:rgba(0,21,32,.7) !important}
footer{background:rgba(0,21,32,.85) !important}
body::before{
  content:'';
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(60,197,242,.018) 3px,rgba(60,197,242,.018) 4px);
}

/* ============================================================
   UTILITY
============================================================ */
.wrap{max-width:1240px;margin:0 auto;padding:0 1.5rem}

.hud-label{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--cyan);padding:5px 14px;
  border:1px solid rgba(60,197,242,.25);border-radius:30px;
  background:rgba(60,197,242,.06);margin-bottom:1.25rem;
}
.hud-label::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--cyan);animation:dot-blink 1.6s ease-in-out infinite}

.sec-title{
  font-family:var(--ff-hud);
  font-size:clamp(1.7rem,3.8vw,3rem);
  font-weight:700;line-height:1.1;letter-spacing:-.01em;
  color:var(--text-1);
}
.sec-sub{color:var(--text-2);font-size:1.05rem;line-height:1.8;max-width:550px}

/* Buttons */
.btn-neon{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;
  font-family:var(--ff-hud);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--bg);background:var(--cyan);
  border-radius:var(--r);border:none;
  box-shadow:0 0 24px var(--cyan-glow);
  transition:all var(--t) var(--ease);
}
.btn-neon:hover{background:#5dd0ff;box-shadow:0 0 50px var(--cyan-glow),0 0 100px rgba(60,197,242,.15);transform:translateY(-2px);color:var(--bg)}
.btn-neon:active{transform:scale(.97)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 26px;
  font-family:var(--ff-hud);font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-1);background:transparent;
  border:1px solid var(--border-hi);border-radius:var(--r);
  transition:all var(--t) var(--ease);
}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim);box-shadow:0 0 20px rgba(60,197,242,.1)}

/* Cards */
.hud-card{
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  position:relative;overflow:hidden;transition:all var(--t) var(--ease);
}
.hud-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  opacity:0;transition:opacity var(--t) var(--ease);
}
.hud-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--purple),transparent);
  opacity:0;transition:opacity var(--t) var(--ease);
}
.hud-card:hover{border-color:var(--border-hi);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 30px rgba(60,197,242,.06)}
.hud-card:hover::before,.hud-card:hover::after{opacity:1}

/* Corner accents for hud feel */
.hud-corners{position:relative}
.hud-corners::before,.hud-corners::after,
.hud-corners .hc-b::before,.hud-corners .hc-b::after{
  content:'';position:absolute;width:10px;height:10px;
  border-color:var(--cyan);border-style:solid;opacity:.5;
}
.hud-corners::before{top:4px;left:4px;border-width:1px 0 0 1px}
.hud-corners::after{top:4px;right:4px;border-width:1px 1px 0 0}
.hud-corners .hc-b::before{bottom:4px;left:4px;border-width:0 0 1px 1px}
.hud-corners .hc-b::after{bottom:4px;right:4px;border-width:0 1px 1px 0}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.rv2{transition-delay:.1s}
.rv3{transition-delay:.2s}
.rv4{transition-delay:.3s}

/* Animations */
@keyframes dot-blink{0%,100%{opacity:1}50%{opacity:.2}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes pulse-ring{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.35);opacity:0}}
@keyframes scan{0%{background-position:0 0}100%{background-position:0 200px}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes glitch{
  0%,100%{clip-path:inset(0 0 95% 0)}
  20%{clip-path:inset(30% 0 50% 0)}
  40%{clip-path:inset(70% 0 10% 0)}
  60%{clip-path:inset(10% 0 80% 0)}
  80%{clip-path:inset(50% 0 30% 0)}
}
@keyframes borderTrace{
  0%{background-position:0% 0%}
  100%{background-position:200% 0%}
}

/* ============================================================
   NAVBAR
============================================================ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:all var(--t) var(--ease);
  padding:.1rem 0;
}
#nav.scrolled{
  background:rgba(0,21,32,.92);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  box-shadow:0 4px 40px rgba(0,0,0,.5),0 0 1px rgba(60,197,242,.2);
}
.nav-wrap{
  max-width:1240px;margin:0 auto;padding:.9rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  font-family:var(--ff-hud);font-size:1.05rem;font-weight:900;letter-spacing:.1em;
  display:flex;align-items:center;gap:10px;
}
.logo-icon{
  width:34px;height:34px;border-radius:7px;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  display:grid;place-items:center;font-size:.9rem;
  box-shadow:0 0 16px var(--cyan-glow);
}
.nav-logo .c1{color:var(--cyan)}.nav-logo .c2{color:var(--text-2)}

.nav-links{display:flex;align-items:center;gap:.15rem}
.nav-links>li{position:relative}
.nav-links a{
  font-family:var(--ff-body);font-size:.875rem;font-weight:600;
  color:var(--text-2);padding:8px 13px;border-radius:6px;
  transition:all var(--t) var(--ease);display:flex;align-items:center;gap:5px;
}
.nav-links a:hover,.nav-links a.active{color:var(--cyan);background:var(--cyan-dim)}
.nav-links a .arr{font-size:.6rem;opacity:.5;transition:transform var(--t) var(--ease)}
.nav-links li:hover .arr{transform:rotate(180deg)}

/* Dropdown */
.nav-drop{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  padding:.5rem;min-width:210px;z-index:999;
  opacity:0;pointer-events:none;
  transition:all var(--t) var(--ease);
  box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 20px rgba(60,197,242,.05);
}
.nav-links li:hover .nav-drop{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-drop a{
  display:flex;align-items:center;gap:10px;padding:9px 13px;
  border-radius:5px;width:100%;color:var(--text-2);font-size:.85rem;
}
.nav-drop a:hover{color:var(--text-1);background:var(--bg-3)}
.nav-drop a .di{width:20px;text-align:center;font-size:.95rem}

.nav-cta{margin-left:.75rem}
.hamburger{
  display:none;flex-direction:column;gap:5px;padding:8px;
  border:1px solid var(--border);border-radius:6px;
}
.hamburger span{display:block;width:21px;height:1.5px;background:var(--text-1);transition:all var(--t) var(--ease)}

/* Mobile nav */
.mob-nav{
  position:fixed;inset:0;z-index:998;background:var(--bg);
  display:flex;flex-direction:column;padding:5.5rem 1.5rem 2rem;gap:.4rem;
  overflow-y:auto;transform:translateX(100%);transition:transform .35s var(--ease);
}
.mob-nav.open{transform:translateX(0)}
.mob-nav a{
  font-family:var(--ff-body);font-size:1.1rem;font-weight:600;
  color:var(--text-2);padding:14px 16px;border-radius:7px;
  border-bottom:1px solid var(--border);transition:all var(--t) var(--ease);
}
.mob-nav a:hover{color:var(--cyan);padding-left:22px}
.mob-close{
  position:fixed;top:1.1rem;right:1.4rem;z-index:1001;
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:7px;padding:8px 13px;color:var(--text-1);font-size:1.1rem;
  display:none;cursor:pointer;
}

/* ============================================================
   HERO
============================================================ */
#hero{
  min-height:100vh;
  background:
    radial-gradient(ellipse 70% 55% at 65% 45%,rgba(60,197,242,.07) 0%,transparent 70%),
    radial-gradient(ellipse 50% 50% at 20% 75%,rgba(254,143,192,.06) 0%,transparent 65%),
    var(--bg);
  display:flex;align-items:center;
  padding:8rem 0 5rem;position:relative;overflow:hidden;
}
/* Grid bg */
#hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(60,197,242,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(60,197,242,.03) 1px,transparent 1px);
  background-size:50px 50px;
  mask-image:radial-gradient(ellipse 75% 75% at 50% 50%,black,transparent);
}

.hero-inner{
  max-width:1240px;margin:0 auto;padding:0 1.5rem;
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
}
.hero-eyebrow{
  font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.22em;color:var(--cyan);
  text-transform:uppercase;margin-bottom:1.5rem;
  display:flex;align-items:center;gap:12px;animation:fadeUp .6s ease both;
}
.hero-eyebrow::before{content:'';display:block;width:30px;height:1px;background:var(--cyan)}

.hero-title{
  font-family:var(--ff-hud);
  font-size:clamp(2.2rem,5vw,4rem);
  font-weight:900;line-height:1.05;letter-spacing:-.02em;
  margin-bottom:1.5rem;animation:fadeUp .6s .1s ease both;
}
.hero-title .line-cyan{
  background:linear-gradient(90deg,var(--cyan),#ffffff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  position:relative;
}
.hero-title .line-purple{
  background:linear-gradient(90deg,var(--pink),#ffffff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero-tagline{
  font-family:var(--ff-mono);font-size:.85rem;letter-spacing:.18em;
  color:var(--text-2);text-transform:uppercase;
  margin-bottom:1.25rem;padding:.5rem 1rem;
  border-left:2px solid var(--cyan);
  animation:fadeUp .6s .15s ease both;
}

.hero-desc{
  color:var(--text-2);font-size:1.05rem;line-height:1.8;
  max-width:460px;margin-bottom:2.5rem;animation:fadeUp .6s .2s ease both;
}

.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .6s .25s ease both}

.hero-stats{
  display:flex;gap:2rem;margin-top:3rem;padding-top:2rem;
  border-top:1px solid var(--border);flex-wrap:wrap;
  animation:fadeUp .6s .3s ease both;
}
.hstat-num{
  font-family:var(--ff-hud);font-size:1.9rem;font-weight:900;color:var(--cyan);
  line-height:1;
}
.hstat-label{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.12em;color:var(--text-3);margin-top:4px;text-transform:uppercase}

/* Hero visual */
/* ── Hero 3D Viewer ── */
.hero-vis{
  position:relative;
  animation:fadeUp .6s .15s ease both;
  display:flex;align-items:center;justify-content:center;
}

/* The Three.js canvas container */
#hero-3d-container{
  width:480px;height:520px;
  position:relative;
  border-radius:24px;
  overflow:visible;
  /* Transparent so space bg shows through */
  background:transparent;
}
#hero-3d-container canvas{
  border-radius:24px;
  display:block;
}

/* Rim-glow ring behind the 3D canvas */
#hero-3d-container::before{
  content:'';
  position:absolute;inset:-2px;border-radius:26px;z-index:-1;
  background:linear-gradient(135deg,var(--cyan),var(--purple),var(--cyan));
  background-size:300% 300%;
  animation:rimRotate 6s linear infinite;
  opacity:.35;
  filter:blur(12px);
}
@keyframes rimRotate{
  0%  {background-position:0%   50%}
  50% {background-position:100% 50%}
  100%{background-position:0%   50%}
}

/* Ground glow beneath model */
#hero-3d-container::after{
  content:'';
  position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);
  width:60%;height:30px;
  background:radial-gradient(ellipse,rgba(60,197,242,.35),transparent 70%);
  border-radius:50%;
  filter:blur(8px);
  animation:groundPulse 3s ease-in-out infinite;
}
@keyframes groundPulse{0%,100%{opacity:.6;transform:translateX(-50%) scaleX(1)}50%{opacity:1;transform:translateX(-50%) scaleX(1.15)}}

/* HUD data chips floating around the 3D viewer */
.hud-chip{
  position:absolute;
  background:rgba(0,21,32,.88);
  border:1px solid var(--border);
  border-radius:7px;padding:8px 13px;
  font-family:var(--ff-mono);font-size:.68rem;color:var(--text-2);
  white-space:nowrap;box-shadow:0 8px 24px rgba(0,0,0,.4);
  backdrop-filter:blur(8px);
  z-index:10;
}
.hud-chip strong{color:var(--green)}
.hc1{top:6%;  left:-12%; animation:float 5s   0s   ease-in-out infinite}
.hc2{bottom:8%;right:-14%;animation:float 6.5s 1s   ease-in-out infinite}
.hc3{top:46%; left:-20%; animation:float 5.5s .5s  ease-in-out infinite}

/* Crosshair / targeting reticle overlay on viewer */
.viewer-reticle{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:120px;height:120px;pointer-events:none;z-index:5;opacity:.18;
}
.viewer-reticle::before,.viewer-reticle::after{
  content:'';position:absolute;border:1px solid var(--cyan);
}
.viewer-reticle::before{
  top:0;left:50%;transform:translateX(-50%);width:1px;height:100%;
}
.viewer-reticle::after{
  left:0;top:50%;transform:translateY(-50%);height:1px;width:100%;
}

/* Scan line that sweeps over the viewer */
.viewer-scan{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  pointer-events:none;z-index:6;opacity:.4;
  animation:scanSweep 4s ease-in-out infinite;
}
@keyframes scanSweep{
  0%  {top:0%;   opacity:0}
  10% {opacity:.5}
  90% {opacity:.5}
  100%{top:100%; opacity:0}
}

/* Model loading placeholder shown until Three.js is ready */
#hero-3d-placeholder{
  position:absolute;inset:0;border-radius:24px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(0,21,32,.6);backdrop-filter:blur(6px);
  font-family:var(--ff-mono);font-size:.72rem;color:var(--text-2);
  gap:.75rem;z-index:20;transition:opacity .6s ease;
}
#hero-3d-placeholder.hidden{opacity:0;pointer-events:none}
.placeholder-orb{
  width:80px;height:80px;border-radius:50%;
  background:radial-gradient(circle at 40% 40%,rgba(60,197,242,.15),rgba(254,143,192,.08));
  border:1px solid rgba(60,197,242,.2);
  display:grid;place-items:center;font-size:2rem;
  animation:float 3s ease-in-out infinite;
}
.placeholder-spin{
  width:32px;height:32px;border-radius:50%;
  border:2px solid rgba(60,197,242,.2);
  border-top-color:var(--cyan);
  animation:spin3d .9s linear infinite;
}
@keyframes spin3d{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ============================================================
   TICKER
============================================================ */
.ticker{
  background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:12px 0;overflow:hidden;white-space:nowrap;
}
.ticker-track{display:inline-flex;animation:ticker 35s linear infinite}
.ticker-item{
  display:inline-flex;align-items:center;gap:8px;padding:0 2rem;
  font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.1em;color:var(--text-3);
}
.ticker-item .td{width:4px;height:4px;border-radius:50%;background:var(--cyan);flex-shrink:0}

/* ============================================================
   GLOBAL SEARCH (counters)
============================================================ */
#global-search{padding:5rem 0}
.global-search-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
}
@media (max-width:900px){
  .global-search-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .global-search-grid{grid-template-columns:1fr}
}
.global-search-counter{
  text-align:center;padding:2rem 1.25rem;
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  transition:border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.global-search-counter:hover{
  border-color:var(--border-hi);box-shadow:0 12px 40px rgba(0,0,0,.35);
}
.global-search-num{
  display:block;font-family:var(--ff-hud);font-size:clamp(2rem,4vw,3rem);
  font-weight:700;letter-spacing:.04em;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.5rem;line-height:1.2;
}
.global-search-label{
  font-size:.875rem;color:var(--text-2);letter-spacing:.03em;
}

/* ============================================================
   OUR MILESTONES (counters)
============================================================ */
#milestones{padding:5rem 0;}
.milestones-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
@media (max-width:900px){
  .milestones-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .milestones-grid{grid-template-columns:1fr}
}
.milestones-counter{
  text-align:center;padding:2rem 1.25rem;
  background:var(--bg);border:1px solid var(--border);border-radius:var(--r);
  transition:border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.milestones-counter:hover{
  border-color:var(--border-hi);box-shadow:0 12px 40px rgba(0,0,0,.35);
}
.milestones-num{
  display:block;font-family:var(--ff-hud);font-size:clamp(2rem,4vw,3rem);
  font-weight:700;letter-spacing:.04em;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.5rem;line-height:1.2;
}
.milestones-label{
  font-size:.875rem;color:var(--text-2);letter-spacing:.03em;
}

/* ============================================================
   ISO CERTIFICATION
============================================================ */
#iso-certification{padding:5rem 0}
.iso-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
}
@media (max-width:900px){
  .iso-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .iso-grid{grid-template-columns:1fr}
}
.iso-card{
  text-align:center;padding:2rem 1.5rem;
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  transition:border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
  display:flex;flex-direction:column;align-items:center;
}
.iso-card:hover{
  border-color:var(--border-hi);box-shadow:0 12px 40px rgba(0,0,0,.35);
}
.iso-card-img{
  width:120px;height:120px;object-fit:contain;margin-bottom:1.25rem;
  border-radius:var(--r);background:rgba(60,197,242,.06);
}
.iso-card-title{
  font-family:var(--ff-hud);font-size:1rem;font-weight:700;letter-spacing:.05em;
  color:var(--text-1);margin-bottom:.6rem;
}
.iso-card-desc{
  font-size:.875rem;color:var(--text-2);line-height:1.6;margin:0;
}

/* ============================================================
   CTA — Game design
============================================================ */
#cta{padding:5rem 0}
.cta-box{
  position:relative;
  padding:3rem 2.5rem;
  background:linear-gradient(135deg, rgba(0,28,42,.85), rgba(0,33,53,.9));
  border:1px solid var(--border);
  border-radius:var(--r);
  box-shadow:0 0 0 1px rgba(60,197,242,.08), inset 0 1px 0 rgba(255,255,255,.03);
  max-width: 100%;
  margin:0 auto;
}
.cta-row{
  display:grid;grid-template-columns:1fr 2fr;gap:2rem;align-items:center;
}
@media (max-width:768px){
  .cta-row{grid-template-columns:1fr;text-align:center}
}
.cta-col-4{min-width:0}
.cta-col-8{min-width:0}
.cta-col-8 .cta-title,.cta-col-8 .cta-subtitle,.cta-col-8 .cta-body{text-align:left}
.cta-col-8 .cta-body{margin-left:0;margin-right:0}
@media (max-width:768px){
  .cta-col-8 .cta-title,.cta-col-8 .cta-subtitle,.cta-col-8 .cta-body{text-align:center}
}
.cta-box::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg, transparent 0%, rgba(60,197,242,.04) 50%, transparent 100%);
  pointer-events:none;
}
/* Animated globe / radar graphic */
.cta-anim{
  display:flex;align-items:center;justify-content:center;
}
@media (max-width:768px){
  .cta-anim{margin-bottom:.5rem}
}
.cta-anim-globe{
  position:relative;
  width:100px;height:100px;
  margin:0 auto;
  display:flex;align-items:center;justify-content:center;
}
.cta-anim-ring{
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(60,197,242,.35);
  animation:ctaRingPulse 2.5s ease-in-out infinite;
}
.cta-anim-ring-1{width:100%;height:100%;animation-delay:0s}
.cta-anim-ring-2{width:76%;height:76%;animation-delay:.4s}
.cta-anim-ring-3{width:52%;height:52%;animation-delay:.8s}
.cta-anim-core{
  width:20px;height:20px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--cyan), var(--purple));
  box-shadow:0 0 20px rgba(60,197,242,.5), 0 0 40px rgba(254,143,192,.25);
  animation:ctaCorePulse 2s ease-in-out infinite;
}
@keyframes ctaRingPulse{
  0%, 100%{ transform:scale(1); opacity:.6; border-color:rgba(60,197,242,.4); }
  50%{ transform:scale(1.08); opacity:.25; border-color:rgba(60,197,242,.2); }
}
@keyframes ctaCorePulse{
  0%, 100%{ box-shadow:0 0 20px rgba(60,197,242,.5), 0 0 40px rgba(254,143,192,.25); transform:scale(1); }
  50%{ box-shadow:0 0 30px rgba(60,197,242,.7), 0 0 60px rgba(254,143,192,.4); transform:scale(1.1); }
}
.cta-corner{
  position:absolute;width:24px;height:24px;
  border-color:var(--cyan);border-style:solid;border-width:0;
  opacity:.6;
}
.cta-tl{top:12px;left:12px;border-top-width:2px;border-left-width:2px}
.cta-tr{top:12px;right:12px;border-top-width:2px;border-right-width:2px}
.cta-bl{bottom:12px;left:12px;border-bottom-width:2px;border-left-width:2px}
.cta-br{bottom:12px;right:12px;border-bottom-width:2px;border-right-width:2px}
.cta-title{
  font-family:var(--ff-hud);font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:700;
  letter-spacing:.08em;margin-bottom:.5rem;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.cta-subtitle{
  font-family:var(--ff-mono);font-size:.8rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--cyan);margin-bottom:1.5rem;
}
.cta-body{
  font-size:1rem;color:var(--text-2);line-height:1.8;margin-bottom:2rem;max-width:560px;margin-left:auto;margin-right:auto;
}
.cta-body:last-of-type{margin-bottom:2rem}
.cta-btn{margin-top:.5rem}

/* ============================================================
   INDUSTRIES — slider + image cards
============================================================ */
#industries{padding:7rem 0}
.ind-slider-wrap{position:relative;margin-top:3rem}
.ind-slider{
  overflow:hidden;border-radius:var(--r);
}
.ind-slider-track{
  display:flex;gap:1.2rem;transition:transform .4s var(--ease);
  padding:4px 0;
}
/* 4 cards per slide: each card = (100% - 3 gaps) / 4 */
.ind-slider-wrap .ind-card{
  flex:0 0 min(320px, max(220px, calc(25vw - 1rem)));
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  overflow:hidden;transition:all var(--t) var(--ease);position:relative;
  display:flex;flex-direction:column;
}
.ind-card::before{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--ac,var(--cyan));transform:scaleX(0);transition:transform var(--t) var(--ease);transform-origin:left;
  z-index:1;
}
.ind-card:hover{border-color:rgba(60,197,242,.2);transform:translateY(-5px);box-shadow:0 24px 60px rgba(0,0,0,.45)}
.ind-card:hover::before{transform:scaleX(1)}
.ind-img{
  width:100%;height:180px;object-fit:cover;display:block;background:var(--bg-3);
}
.ind-card-body{padding:1.25rem 1.4rem;display:flex;flex-direction:column;flex:1}
.ind-name{font-family:var(--ff-hud);font-size:.78rem;font-weight:700;letter-spacing:.06em;margin-bottom:.6rem}
.ind-desc{font-size:.875rem;color:var(--text-2);line-height:1.65;flex:1}
.ind-tag{
  display:inline-block;margin-top:1rem;
  font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 9px;border-radius:4px;color:var(--cyan);
  background:var(--cyan-dim);border:1px solid rgba(60,197,242,.2);
}
/* Slider nav */
.ind-slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--bg-2);border:1px solid var(--border);
  color:var(--text-1);font-size:1.5rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t) var(--ease);z-index:2;
}
.ind-slider-btn:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 20px rgba(60,197,242,.25)}
.ind-slider-prev{left:-24px}
.ind-slider-next{right:-24px}
@media (max-width:900px){
  .ind-slider-prev{left:8px}
  .ind-slider-next{right:8px}
}
.ind-slider-dots{
  display:flex;justify-content:center;gap:8px;margin-top:1.25rem;flex-wrap:wrap;
}
.ind-slider-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--border);border:none;cursor:pointer;
  transition:background var(--t) var(--ease);
}
.ind-slider-dot.active{background:var(--cyan);box-shadow:0 0 10px rgba(60,197,242,.5)}
.ind-slider-dot:hover{background:var(--border-hi)}

/* Fields page: grid layout + image cards + border */
.ind-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1.5rem;margin-top:3rem;
}
.ind-grid .ind-card{
  display:flex;flex-direction:column;
  padding:0;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
  transition:all var(--t) var(--ease);
}
.ind-grid .ind-card:hover{
  border-color:var(--border-hi);
  box-shadow:0 12px 40px rgba(0,0,0,.3);
}
.ind-grid .ind-card .ind-img{
  width:100%;height:180px;object-fit:cover;display:block;
  background:var(--bg-3);
}
.ind-grid .ind-card .ind-card-body{
  padding:1.5rem 1.4rem;display:flex;flex-direction:column;flex:1;
}
.ind-grid .ind-card .ind-name{margin-bottom:.6rem}
.ind-grid .ind-card .ind-tag{margin-top:1rem}
/* Legacy icon style (e.g. if used elsewhere) */
.ind-card .ind-icon,
.ind-icon{
  width:50px;height:50px;border-radius:11px;
  background:rgba(60,197,242,.07);border:1px solid rgba(60,197,242,.15);
  display:grid;place-items:center;font-size:1.4rem;margin-bottom:1.2rem;
}

/* ============================================================
   SERVICES — game-style tabs + panel animation
============================================================ */
#services{padding:7rem 0;}
.svc-layout{display:grid;grid-template-columns:260px 1fr;gap:2.5rem;margin-top:3rem;align-items:start}
.svc-tabs{display:flex;flex-direction:column;gap:.5rem;position:sticky;top:6rem}
.stab{
  position:relative;
  display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:7px;
  font-family:var(--ff-body);font-size:.88rem;font-weight:600;
  color:var(--text-2);border:1px solid transparent;cursor:pointer;
  transition:color .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), box-shadow .35s var(--ease);
  overflow:hidden;
}
.stab::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--cyan),var(--purple));
  transform:scaleY(0);transform-origin:center;transition:transform .3s var(--ease);
}
.stab:hover{color:var(--text-1);background:rgba(255,255,255,.04)}
.stab:hover::before{transform:scaleY(0.5)}
.stab.active{
  color:var(--text-1);
  background:linear-gradient(135deg, rgba(60,197,242,.12), rgba(254,143,192,.06));
  border-color:rgba(60,197,242,.35);
  box-shadow:0 0 24px rgba(60,197,242,.15), inset 0 1px 0 rgba(255,255,255,.06);
}
.stab.active::before{transform:scaleY(1)}
.stab .si{font-size:1rem;width:22px;text-align:center}
.stab-num{font-family:var(--ff-mono);font-size:.6rem;margin-left:auto;color:var(--text-3)}
.stab.active .stab-num{color:var(--cyan);opacity:.9}

.svc-panels{position:relative;min-height:380px}
.spanel{
  position:absolute;inset:0;left:0;right:0;top:0;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(14px) scale(0.98);
  transition:opacity .35s var(--ease), transform .35s var(--ease), visibility .35s;
  padding:1.5rem;margin:0;
  background:linear-gradient(145deg, rgba(0,28,42,.4), rgba(0,35,55,.5));
  border:1px solid rgba(60,197,242,.15);border-radius:var(--r);
  box-shadow:0 4px 24px rgba(0,0,0,.2);
}
.spanel.active{
  position:relative;opacity:1;visibility:visible;pointer-events:auto;
  transform:translateY(0) scale(1);
  border-color:rgba(60,197,242,.25);
  box-shadow:0 0 30px rgba(60,197,242,.12), 0 4px 24px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.03);
  animation:svcPanelIn .45s var(--ease) forwards;
}
@keyframes svcPanelIn{
  from{ opacity:0; transform:translateY(14px) scale(0.98); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}
.spanel-img{
  width:100%;aspect-ratio:16/7;border-radius:var(--r);overflow:hidden;
  background:var(--bg-3);border:1px solid var(--border);
  display:grid;place-items:center;font-size:4rem;margin-bottom:1.5rem;
  position:relative;
}
.spanel-img::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 60%,rgba(60,197,242,.06));
}
.spanel-title{font-family:var(--ff-hud);font-size:1.5rem;font-weight:700;margin-bottom:.9rem}
.spanel-desc{color:var(--text-2);line-height:1.8;margin-bottom:1.8rem;font-size:.95rem}
.spanel-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.8rem}
.sf{
  display:flex;align-items:flex-start;gap:8px;
  font-size:.862rem;color:var(--text-2);line-height:1.5;
}
.sf::before{content:'▸';color:var(--cyan);flex-shrink:0;margin-top:1px}

/* ============================================================
   LANGUAGE SOLUTIONS
============================================================ */
#languages{padding:7rem 0}
.lang-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}
.lang-search{
  display:flex;align-items:center;gap:10px;
  background:var(--bg-2);border:1px solid var(--border);border-radius:7px;padding:9px 15px;
}
.lang-search input{
  background:none;border:none;outline:none;color:var(--text-1);
  font-family:var(--ff-mono);font-size:.8rem;width:200px;
}
.lang-search input::placeholder{color:var(--text-3)}

.lang-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}
.lf{
  padding:5px 16px;border-radius:20px;
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.1em;
  border:1px solid var(--border);background:transparent;color:var(--text-2);
  cursor:pointer;transition:all var(--t) var(--ease);
}
.lf.on,.lf:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim)}

.lang-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:.9rem}
.lcard{
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  padding:1rem 1.25rem;display:flex;align-items:center;gap:12px;
  transition:all var(--t) var(--ease);
}
.lcard:hover{border-color:var(--border-hi);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.lflag{font-size:1.5rem;flex-shrink:0}
.lname{font-weight:700;font-size:.85rem;color:var(--text-1)}
.lregion{font-family:var(--ff-mono);font-size:.62rem;color:var(--text-3)}
.lbadge{
  margin-left:auto;font-family:var(--ff-mono);font-size:.58rem;letter-spacing:.1em;
  padding:3px 7px;border-radius:4px;flex-shrink:0;
}
.lbadge.p{color:var(--green);background:var(--green-dim);border:1px solid rgba(60,197,242,.2)}
.lbadge.s{color:var(--text-2);background:var(--bg-3);border:1px solid var(--border)}

/* ============================================================
   BREADCRUMB + PAGE HERO (inner pages)
============================================================ */
.page-hero{padding: 10rem 0 2rem;}
.breadcrumb{
  display:flex;align-items:center;gap:.5rem;
  font-family:var(--ff-mono);font-size:.75rem;letter-spacing:.08em;
  color:var(--text-3);margin-bottom:1.25rem;
}
.breadcrumb a{
  color:var(--text-2);text-decoration:none;transition:color var(--t) var(--ease);
}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb-sep{color:var(--text-3);opacity:.7}
.breadcrumb-current{color:var(--cyan);font-weight:600}
.page-hero-title{
  font-family:var(--ff-hud);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;
  letter-spacing:.04em;color:var(--text-1);margin-bottom:1rem;
}
.page-hero-desc{
  font-size:1.05rem;color:var(--text-2);line-height:1.8;max-width:640px;margin:0;
}

/* ============================================================
   GAME-LANG STORY (About page — game style + animation)
============================================================ */
.story-section{padding:5rem 0 4rem}
.story-box{
  position:relative;
  max-width: 100%;
  margin:0 auto;
  padding:3rem 2.5rem;
  background:linear-gradient(145deg, rgba(0,28,42,.9), rgba(0,38,58,.85));
  border:1px solid rgba(60,197,242,.2);
  border-radius:var(--r);
  box-shadow:0 0 0 1px rgba(60,197,242,.06), 0 20px 60px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.03);
  overflow:hidden;
}
.story-box::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg, transparent 0%, rgba(60,197,242,.03) 50%, transparent 100%);
  pointer-events:none;
  animation:storyGlow 4s ease-in-out infinite;
}
@keyframes storyGlow{
  0%, 100%{ opacity:.6; }
  50%{ opacity:1; }
}
.story-scan{
  position:absolute;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, rgba(60,197,242,.5), transparent);
  box-shadow:0 0 12px rgba(60,197,242,.4);
  animation:storyScan 3s linear infinite;
  pointer-events:none;
}
@keyframes storyScan{
  0%{ top:0; opacity:0; }
  5%{ opacity:1; }
  95%{ opacity:1; }
  100%{ top:100%; opacity:0; }
}
.story-corner{
  position:absolute;width:28px;height:28px;
  border-color:var(--cyan);border-style:solid;border-width:0;
  opacity:.7;
}
.story-tl{top:14px;left:14px;border-top-width:2px;border-left-width:2px}
.story-tr{top:14px;right:14px;border-top-width:2px;border-right-width:2px}
.story-bl{bottom:14px;left:14px;border-bottom-width:2px;border-left-width:2px}
.story-br{bottom:14px;right:14px;border-bottom-width:2px;border-right-width:2px}
.story-subtitle{
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.25em;
  text-transform:uppercase;color:var(--cyan);margin-bottom:.75rem;
  position:relative;
}
.story-title{
  font-family:var(--ff-hud);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;
  letter-spacing:.06em;margin-bottom:2rem;line-height:1.25;
  background:linear-gradient(135deg, var(--cyan), var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  position:relative;
}
.story-content{position:relative}
.story-label{
  font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--text-3);margin-bottom:.75rem;
}
.story-body{
  font-size:1.05rem;color:var(--text-2);line-height:1.85;margin:0;
  max-width:640px;
}

/* ============================================================
   OUR POWER-UPS (About page)
============================================================ */
.about-subsection{padding:4rem 0}
.subsection-title{
  font-family:var(--ff-hud);font-size:clamp(1.4rem,3vw,2rem);font-weight:700;
  letter-spacing:.05em;margin-bottom:2rem;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.subsection-subtitle{
  font-size:1.05rem;color:var(--text-2);line-height:1.75;margin-bottom:2.5rem;max-width:640px;
}
.powerups-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
@media (max-width:900px){ .powerups-grid{grid-template-columns:1fr} }
.powerup-card{
  padding:2rem 1.5rem;
  background:var(--bg);border:1px solid var(--border);border-radius:var(--r);
  transition:all var(--t) var(--ease);position:relative;overflow:hidden;
}
.powerup-card::before{
  content:'';position:absolute;top:0;left:0;width:4px;height:100%;
  background:linear-gradient(180deg,var(--cyan),var(--purple));
  transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease);
}
.powerup-card:hover{border-color:var(--border-hi);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.powerup-card:hover::before{transform:scaleY(1)}
.powerup-icon{
  width:52px;height:52px;border-radius:12px;
  background:linear-gradient(135deg,rgba(60,197,242,.12),rgba(254,143,192,.08));
  border:1px solid rgba(60,197,242,.2);
  display:grid;place-items:center;font-size:1.5rem;margin-bottom:1.25rem;
}
.powerup-title{
  font-family:var(--ff-hud);font-size:1rem;font-weight:700;letter-spacing:.04em;
  color:var(--text-1);margin-bottom:.75rem;
}
.powerup-desc,.powerup-list{font-size:.9rem;color:var(--text-2);line-height:1.65;margin:0 0 .5rem}
.powerup-list{list-style:none;padding:0}
.powerup-list li{position:relative;padding-left:1.2rem;margin-bottom:.5rem}
.powerup-list li::before{content:'•';position:absolute;left:0;color:var(--cyan)}

/* ============================================================
   OUR VISION & MISSION (About page)
============================================================ */
.vision-mission-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;
}
@media (max-width:700px){ .vision-mission-grid{grid-template-columns:1fr} }
.vm-card{
  padding:2rem 1.75rem;
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  transition:all var(--t) var(--ease);
  border-left:3px solid var(--cyan);
}
.vm-card:hover{border-color:var(--border-hi);box-shadow:0 12px 40px rgba(0,0,0,.25)}
.vm-title{
  font-family:var(--ff-hud);font-size:1.1rem;font-weight:700;letter-spacing:.04em;
  color:var(--cyan);margin-bottom:1rem;
}
.vm-text{font-size:.95rem;color:var(--text-2);line-height:1.75;margin:0}

/* ============================================================
   OUR PROCESS — Game process design (track + nodes + mission cards)
============================================================ */
#our-process{position:relative}
.process-hud-header{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem;
}
.process-hud-tag{
  font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.25em;
  color:var(--cyan);padding:.35rem .75rem;
  border:1px solid rgba(60,197,242,.4);border-radius:4px;
  background:rgba(60,197,242,.08);
}
.process-levels{
  position:relative;
  display:flex;flex-direction:column;gap:0;
  margin-top:2.5rem;padding-left:0;
}
.process-track{
  position:absolute;
  left:27px;top:2rem;bottom:2rem;
  width:2px;
  background:linear-gradient(180deg,
    rgba(60,197,242,.5) 0%,
    rgba(60,197,242,.25) 25%,
    rgba(254,143,192,.2) 50%,
    rgba(60,197,242,.25) 75%,
    rgba(60,197,242,.6) 100%);
  border-radius:1px;
  animation:processTrackPulse 3s ease-in-out infinite;
}
@keyframes processTrackPulse{
  0%, 100%{ opacity:.8; }
  50%{ opacity:1; box-shadow:0 0 12px rgba(60,197,242,.3); }
}
.process-level{
  display:flex;align-items:flex-start;gap:2rem;
  position:relative;padding:1.5rem 0;
}
.process-level:first-child{padding-top:0}
.process-node{
  flex-shrink:0;
  width:56px;height:56px;
  border-radius:50%;
  background:var(--bg-2);
  border:2px solid rgba(60,197,242,.5);
  box-shadow:0 0 0 4px rgba(0,21,32,1), 0 0 20px rgba(60,197,242,.25);
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:2;
  transition:all .35s var(--ease);
}
.process-level:hover .process-node{
  border-color:var(--cyan);
  box-shadow:0 0 0 4px rgba(0,21,32,1), 0 0 28px rgba(60,197,242,.45);
  transform:scale(1.08);
}
.process-node-num{
  font-family:var(--ff-hud);font-size:1.25rem;font-weight:800;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.process-node-last{border-color:rgba(254,143,192,.5)}
.process-node-last .process-node-num{background:linear-gradient(135deg,var(--cyan),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.process-card{
  flex:1;
  position:relative;
  padding:1.75rem 2rem;
  background:linear-gradient(145deg, rgba(0,28,42,.85), rgba(0,35,52,.9));
  border:1px solid rgba(60,197,242,.25);
  border-radius:var(--r);
  transition:all .35s var(--ease);
  overflow:hidden;
}
.process-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg, rgba(60,197,242,.04) 0%, transparent 35%);
  pointer-events:none;
}
.process-card:hover{
  border-color:rgba(60,197,242,.45);
  box-shadow:0 8px 36px rgba(0,0,0,.35), 0 0 32px rgba(60,197,242,.12);
}
.process-card-corners{pointer-events:none;position:absolute;inset:0}
.pc{
  position:absolute;
  width:14px;height:14px;
  border-color:rgba(60,197,242,.6);border-style:solid;border-width:0;
}
.pctl{top:10px;left:10px;border-top-width:1px;border-left-width:1px}
.pctr{top:10px;right:10px;border-top-width:1px;border-right-width:1px}
.pcbl{bottom:10px;left:10px;border-bottom-width:1px;border-left-width:1px}
.pcbr{bottom:10px;right:10px;border-bottom-width:1px;border-right-width:1px}
.process-card-label{
  font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.2em;
  color:var(--cyan);opacity:.9;margin-bottom:.5rem;display:block;
}
.process-level-title{
  font-family:var(--ff-hud);font-size:1.1rem;font-weight:700;letter-spacing:.03em;
  color:var(--text-1);margin-bottom:.65rem;
}
.process-level-desc{
  font-size:.9rem;color:var(--text-2);line-height:1.7;margin:0;
}
@media (max-width:700px){
  .process-track{left:23px;top:1.5rem;bottom:1.5rem}
  .process-level{flex-direction:column;align-items:center;gap:1rem;padding:1.25rem 0;text-align:center}
  .process-node{width:48px;height:48px}
  .process-node-num{font-size:1.1rem}
  .process-card-label,.process-level-title,.process-level-desc{text-align:left}
}

/* ============================================================
   ABOUT US
============================================================ */
#about{padding:7rem 0;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-top:3rem}

.about-visual{position:relative}
.about-screen{
  background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);
  padding:2rem;font-family:var(--ff-mono);font-size:.78rem;color:var(--green);
  position:relative;overflow:hidden;
}
.about-screen::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:28px;background:var(--bg-4);border-bottom:1px solid var(--border);
  border-radius:var(--r) var(--r) 0 0;
}
.term-dots{
  position:absolute;top:8px;left:12px;display:flex;gap:6px;z-index:1;
}
.term-dots span{width:10px;height:10px;border-radius:50%}
.term-line{margin:.2rem 0;padding-top:.15rem}
.term-line .p{color:var(--cyan)}
.term-line .ok{color:var(--green)}
.term-line .c{color:var(--text-3)}
.term-line .a{color:var(--amber)}
.cursor-blink{display:inline-block;width:8px;height:1em;background:var(--cyan);animation:dot-blink .7s step-end infinite;vertical-align:text-bottom;margin-left:2px}

.about-kpis{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.kpi{
  background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);
  padding:1.2rem;text-align:center;transition:all var(--t) var(--ease);
}
.kpi:hover{border-color:var(--border-hi)}
.kpi-num{font-family:var(--ff-hud);font-size:1.7rem;font-weight:900;color:var(--cyan);line-height:1}
.kpi-label{font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.1em;color:var(--text-3);margin-top:4px;text-transform:uppercase}

.values{display:flex;flex-direction:column;gap:1.25rem}
.val{
  display:flex;gap:1rem;align-items:flex-start;padding:1.25rem;
  border:1px solid var(--border);border-radius:var(--r);
  transition:all var(--t) var(--ease);
}
.val:hover{border-color:rgba(60,197,242,.25);background:rgba(60,197,242,.03)}
.val-icon{font-size:1.4rem;flex-shrink:0;width:36px}
.val-title{font-family:var(--ff-hud);font-size:.78rem;font-weight:700;letter-spacing:.05em;margin-bottom:.3rem}
.val-desc{font-size:.862rem;color:var(--text-2);line-height:1.65}

.team-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2rem}
.tcard{
  background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r);
  padding:1.2rem;text-align:center;transition:all var(--t) var(--ease);
}
.tcard:hover{border-color:var(--border-hi);transform:translateY(-2px)}
.tav{
  width:56px;height:56px;border-radius:50%;margin:0 auto .75rem;
  display:grid;place-items:center;font-size:1.4rem;
  border:1px solid var(--border);
}
.tname{font-weight:700;font-size:.82rem;margin-bottom:.2rem}
.trole{font-family:var(--ff-mono);font-size:.62rem;color:var(--text-3)}

/* ============================================================
   BLOG
============================================================ */
#blog{padding:7rem 0}
.blog-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:3rem}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:1.5rem}

.bcard{
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);
  overflow:hidden;transition:all var(--t) var(--ease);
}
.bcard:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.45);border-color:var(--border-hi)}

.bthumb{
  width:100%;aspect-ratio:16/9;
  display:grid;place-items:center;font-size:2.8rem;position:relative;overflow:hidden;
}
.bthumb::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 4px,rgba(0,0,0,.15) 4px,rgba(0,0,0,.15) 5px);
}

.bbody{padding:1.4rem}
.bmeta{display:flex;align-items:center;gap:.9rem;margin-bottom:.9rem;flex-wrap:wrap}
.btag{
  font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 9px;border-radius:4px;font-weight:700;
}
.bdate{font-family:var(--ff-mono);font-size:.65rem;color:var(--text-3)}
.btitle{
  font-family:var(--ff-hud);font-size:.95rem;font-weight:700;line-height:1.35;
  margin-bottom:.65rem;transition:color var(--t) var(--ease);
}
.bcard:hover .btitle{color:var(--cyan)}
.bexc{font-size:.845rem;color:var(--text-2);line-height:1.65;margin-bottom:1.1rem}
.bauthor{
  display:flex;align-items:center;gap:9px;font-size:.78rem;color:var(--text-2);
  border-top:1px solid var(--border);padding-top:1rem;
}
.bav{
  width:26px;height:26px;border-radius:50%;
  display:grid;place-items:center;font-size:.7rem;flex-shrink:0;
}
.brt{margin-left:auto;font-family:var(--ff-mono);font-size:.62rem;color:var(--text-3)}

/* Single blog post */
.blog-single{max-width:720px;margin:0 auto}
.blog-single .blog-single-hero{
  width:100%;aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;margin-bottom:2rem;
  display:grid;place-items:center;font-size:4rem;
  background:linear-gradient(135deg,rgba(60,197,242,.12),rgba(254,143,192,.08));
  border:1px solid var(--border);
}
.blog-single .blog-single-title{
  font-family:var(--ff-hud);font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:700;line-height:1.25;
  margin-bottom:1rem;color:var(--text-1);
}
.blog-single .blog-single-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}
.blog-single .blog-single-body{
  font-size:1rem;line-height:1.8;color:var(--text-2);
}
.blog-single .blog-single-body p{margin-bottom:1.25rem}
.blog-single .blog-single-body p:last-child{margin-bottom:0}
.blog-single .blog-single-author{
  display:flex;align-items:center;gap:12px;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border);
}
.blog-single .blog-single-author .bav{width:44px;height:44px;font-size:1rem}
.blog-single .blog-single-author span{font-size:.9rem;color:var(--text-2)}
.blog-single .blog-single-author .brt{font-family:var(--ff-mono);font-size:.7rem;color:var(--text-3)}

/* ============================================================
   CONTACT
============================================================ */
#contact{padding:7rem 0;}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;margin-top:3rem}

.cinfo{display:flex;flex-direction:column;gap:1.2rem}
.ci{
  display:flex;gap:1rem;align-items:flex-start;
  padding:1.2rem;border:1px solid var(--border);border-radius:var(--r);
  transition:all var(--t) var(--ease);
}
.ci:hover{border-color:var(--border-hi);background:rgba(60,197,242,.02)}
.ci-icon{font-size:1.2rem;width:32px;flex-shrink:0}
.ci-lbl{font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin-bottom:.2rem}
.ci-val{font-weight:600;font-size:.9rem}

.ctags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.ctag{
  font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.1em;
  padding:4px 11px;border-radius:20px;
}

/* Form */
.cform{display:flex;flex-direction:column;gap:1.1rem}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:5px}
.flbl{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3)}
.finput,.fselect,.ftextarea{
  background:var(--bg-3);border:1px solid var(--border);border-radius:7px;
  padding:11px 14px;color:var(--text-1);font-family:var(--ff-body);font-size:.9rem;
  outline:none;transition:all var(--t) var(--ease);width:100%;
}
.finput:focus,.fselect:focus,.ftextarea:focus{
  border-color:var(--cyan);box-shadow:0 0 0 3px rgba(60,197,242,.08);background:rgba(60,197,242,.03);
}
.finput::placeholder,.ftextarea::placeholder{color:var(--text-3)}
.ftextarea{resize:vertical;min-height:130px;font-family:var(--ff-body)}
.fselect{appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%233d5470' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;
}
.fselect option{background:var(--bg-2)}

/* ============================================================
   FOOTER
============================================================ */
footer{background:var(--bg);border-top:1px solid var(--border);padding:4.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3.5rem}

.flogo{
  font-family:var(--ff-hud);font-size:1.05rem;font-weight:900;letter-spacing:.1em;
  display:flex;align-items:center;gap:10px;margin-bottom:1rem;
}
.flogo .c1{color:var(--cyan)}
.fdesc{font-size:.875rem;color:var(--text-2);line-height:1.75;max-width:270px;margin-bottom:1.5rem}
.fsocials{display:flex;gap:.6rem}
.fsoc{
  width:34px;height:34px;border-radius:7px;
  background:var(--bg-2);border:1px solid var(--border);
  display:grid;place-items:center;font-size:.8rem;
  cursor:pointer;transition:all var(--t) var(--ease);
}
.fsoc:hover{border-color:var(--cyan);background:var(--cyan-dim);box-shadow:0 0 12px var(--cyan-glow)}

.fcol-title{
  font-family:var(--ff-hud);font-size:.68rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--text-1);margin-bottom:1.1rem;
}
.flinks{display:flex;flex-direction:column;gap:.55rem}
.flinks a{font-size:.875rem;color:var(--text-2);transition:color var(--t) var(--ease)}
.flinks a:hover{color:var(--cyan)}

.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;
  padding-top:2rem;border-top:1px solid var(--border);
  font-family:var(--ff-mono);font-size:.68rem;color:var(--text-3);
}
.footer-bottom a{color:var(--text-3);transition:color var(--t) var(--ease)}
.footer-bottom a:hover{color:var(--cyan)}

/* ============================================================
   TOAST
============================================================ */
#toast{
  position:fixed;bottom:2rem;right:2rem;z-index:9999;
  background:var(--bg-2);border:1px solid var(--green);border-radius:var(--r);
  padding:1rem 1.4rem;font-family:var(--ff-mono);font-size:.8rem;color:var(--text-1);
  box-shadow:0 10px 40px rgba(0,0,0,.5),0 0 20px rgba(60,197,242,.1);
  display:flex;align-items:center;gap:12px;max-width:310px;
  transform:translateX(130%);transition:transform .4s cubic-bezier(.22,1,.36,1);
}
#toast.show{transform:translateX(0)}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:991px){
  .hero-inner{grid-template-columns:1fr}
  #hero-3d-container{width:300px;height:340px}
  .hud-chip{display:none}
  .svc-layout{grid-template-columns:1fr}
  .svc-tabs{flex-direction:row;flex-wrap:wrap;position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .team-row{grid-template-columns:repeat(2,1fr)}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .spanel-grid{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
}
@media(max-width:575px){
  #hero{padding:7rem 0 4rem}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  #hero-3d-container{width:240px;height:280px}
  .hero-btns{flex-direction:column}
}