*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --font:'Inter',system-ui,sans-serif;
  --font-pixel:'Press Start 2P',monospace;
  --bg:#060b18;
  --surface:rgba(8,14,30,0.92);
  --border:rgba(0,229,255,0.18);
  --text:#d0dce8;
  --text2:rgba(208,220,232,0.6);
  --accent:#00e5ff;
  --accent2:#ff2d9b;
  --purple:#9b30ff;
  --amber:#ffaa2e;
  --green:#6ee7a0;
  --red:#ff4d6a;
  --radius:4px;
  --transition:.35s cubic-bezier(.4,0,.2,1);
}
html,body{width:100%;height:100%;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
a{color:var(--accent);text-decoration:none}

/* SCANLINES & GLITCH */
.scanlines{position:fixed;inset:0;z-index:9998;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.12) 3px,rgba(0,0,0,.12) 6px);mix-blend-mode:multiply}
.glitch-line{position:fixed;left:0;right:0;height:2px;background:rgba(0,229,255,.15);z-index:9999;pointer-events:none;opacity:0;animation:glitchScan 8s linear infinite}
.glitch-line:nth-child(2){animation-delay:3s;height:1px;background:rgba(255,45,155,.12)}
@keyframes glitchScan{0%{top:-2px;opacity:0}5%{opacity:1}95%{opacity:1}100%{top:100%;opacity:0}}

/* PARTICLES */
.particles-container{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.particle{position:absolute;width:3px;height:3px;background:var(--accent);box-shadow:0 0 8px rgba(0,229,255,.5);animation:particleFly linear infinite}
@keyframes particleFly{0%{transform:translateY(100vh);opacity:0}10%{opacity:.5}90%{opacity:.5}100%{transform:translateY(-10vh);opacity:0}}

/* VIGNETTE */
.vignette{position:fixed;inset:0;z-index:9997;pointer-events:none;background:radial-gradient(circle at center,transparent 30%,rgba(2,2,5,0.8) 100%)}

/* === BACKGROUNDS === */
.bg-base{position:fixed;inset:0;z-index:0;overflow:hidden;background:linear-gradient(180deg,#060b18 0%,#0a1025 50%,#060b18 100%)}
.bg-base::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(0,229,255,.04) 50%,transparent 100%);animation:bgSweep 6s ease-in-out infinite;pointer-events:none}
@keyframes bgSweep{0%,100%{transform:translateX(-100%);opacity:0}50%{transform:translateX(100%);opacity:1}}

.bg-skyline{position:fixed;inset:0;z-index:0;overflow:hidden;background:#020610}
.bg-skyline::before{content:'';position:absolute;bottom:0;left:0;right:0;height:35%;z-index:2;background:linear-gradient(90deg,transparent 2%,rgba(10,18,35,.95) 2%,rgba(10,18,35,.95) 4%,transparent 4%,transparent 6%,rgba(10,18,35,.95) 6%,rgba(10,18,35,.95) 7%,transparent 7%,transparent 10%,rgba(12,20,38,.95) 10%,rgba(12,20,38,.95) 13%,transparent 13%,transparent 16%,rgba(14,22,40,.95) 16%,rgba(14,22,40,.95) 18%,transparent 18%,transparent 25%,rgba(14,22,40,.95) 25%,rgba(14,22,40,.95) 29%,transparent 29%,transparent 38%,rgba(14,22,40,.95) 38%,rgba(14,22,40,.95) 42%,transparent 42%,transparent 50%,rgba(12,20,38,.95) 50%,rgba(12,20,38,.95) 54%,transparent 54%,transparent 62%,rgba(10,18,35,.95) 62%,rgba(10,18,35,.95) 65%,transparent 65%,transparent 74%,rgba(12,20,38,.95) 74%,rgba(12,20,38,.95) 76%,transparent 76%,transparent 86%,rgba(10,18,35,.95) 86%,rgba(10,18,35,.95) 88%,transparent 88%,transparent 97%,rgba(14,22,40,.95) 97%,rgba(14,22,40,.95) 99%,transparent 99%);clip-path:polygon(0% 100%,0% 65%,2% 65%,2% 45%,4% 45%,4% 65%,6% 65%,6% 50%,7% 50%,7% 65%,10% 65%,10% 30%,13% 30%,13% 65%,16% 65%,16% 55%,18% 55%,18% 65%,25% 65%,25% 25%,29% 25%,29% 65%,38% 65%,38% 35%,42% 35%,42% 65%,50% 65%,50% 20%,54% 20%,54% 65%,62% 65%,62% 40%,65% 40%,65% 65%,74% 65%,74% 55%,76% 55%,76% 65%,86% 65%,86% 50%,88% 50%,88% 65%,97% 65%,97% 35%,99% 35%,99% 65%,100% 65%,100% 100%)}
.skyline-glow{position:fixed;bottom:26%;left:0;right:0;height:12px;z-index:3;background:linear-gradient(90deg,transparent 5%,rgba(0,229,255,0.4) 25%,rgba(255,45,155,0.35) 50%,rgba(155,48,255,0.3) 75%,transparent 95%);filter:blur(14px);animation:skylineGlowPulse 3s ease-in-out infinite}
@keyframes skylineGlowPulse{0%,100%{opacity:.7;filter:blur(14px)}50%{opacity:1;filter:blur(18px)}}
.skyline-stars{position:fixed;inset:0;z-index:1}
.skyline-stars span{position:absolute;width:3px;height:3px;background:rgba(200,230,255,0.8);border-radius:50%;box-shadow:0 0 6px rgba(0,229,255,.4);animation:starTwinkle 3s ease-in-out infinite}
.skyline-stars span:nth-child(even){animation-delay:.8s;width:2px;height:2px;background:rgba(255,45,155,.6);box-shadow:0 0 6px rgba(255,45,155,.4)}
@keyframes starTwinkle{0%,100%{opacity:.2;transform:scale(1)}50%{opacity:.9;transform:scale(1.5)}}

/* === VIEWS === */
#teamSelectView,#welcomePackView{display:none}
#teamSelectView.active,#welcomePackView.active{display:block}

/* === TEAM SELECTION === */
.select-screen{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px}
.game-title{text-align:center;margin-bottom:48px}
.game-label{display:block;font-family:var(--font-pixel);font-size:14px;color:var(--accent);letter-spacing:6px;margin-bottom:20px;text-shadow:0 0 8px rgba(0,229,255,.3)}
.game-heading{font-family:var(--font-pixel);font-size:48px;color:#e8ecf1;text-shadow:0 0 12px rgba(0,229,255,.3),0 0 24px rgba(255,45,155,.2),3px 3px 0 rgba(0,0,0,.6);letter-spacing:4px;line-height:1.4;margin-bottom:8px}
.game-year{display:block;font-family:var(--font-pixel);font-size:14px;color:var(--amber);letter-spacing:10px;margin-top:14px;text-shadow:0 0 10px rgba(255,170,46,.3)}
.game-hint{font-family:var(--font-pixel);font-size:12px;color:var(--text2);letter-spacing:4px;margin-top:32px}
.blink{animation:blinkAnim .8s step-end infinite}
.blink-slow{animation:blinkAnim 1.5s step-end infinite}
@keyframes blinkAnim{50%{opacity:0}}

/* TEAM GRID */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;max-width:1100px;width:100%;padding:0 20px}
.team-card{position:relative;padding:20px 16px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all .3s;overflow:hidden;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.team-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--accent2),var(--accent));opacity:.6;transition:opacity .3s}
.team-card::after{content:'';position:absolute;inset:0;background:rgba(0,229,255,.04);opacity:0;transition:opacity .3s}
.team-card:hover{transform:translateY(-6px);box-shadow:0 0 30px rgba(0,229,255,.15),0 8px 32px rgba(0,0,0,.4);border-color:var(--accent)}
.team-card:hover::before{opacity:1}
.team-card:hover::after{opacity:1}
.team-card:hover .team-card__icon{transform:scale(1.1);filter:drop-shadow(0 0 12px rgba(0,229,255,.5))}
.team-card__icon{width:80px;height:80px;object-fit:contain;image-rendering:pixelated;transition:all .35s ease;filter:drop-shadow(0 0 6px rgba(0,229,255,.25))}
.team-card__info{display:flex;flex-direction:column;align-items:center;gap:6px}
.team-card__name{font-family:var(--font-pixel);font-size:13px;color:var(--accent);letter-spacing:2px;text-shadow:0 0 10px rgba(0,229,255,.4)}
.team-card__members{font-family:var(--font-pixel);font-size:10px;color:var(--accent2);letter-spacing:1px}

/* === WELCOME PACK NAV === */
.pack-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;padding:12px 24px;background:rgba(6,11,24,.95);border-bottom:1px solid var(--border);backdrop-filter:blur(8px)}
.back-btn{display:flex;align-items:center;gap:8px;font-family:var(--font-pixel);font-size:11px;color:var(--accent);background:none;border:1px solid var(--accent);padding:8px 16px;cursor:pointer;transition:all .3s;letter-spacing:1px}
.back-btn:hover{background:rgba(0,229,255,.1);box-shadow:0 0 15px rgba(0,229,255,.2)}
.pack-nav__team{margin-left:auto;font-family:var(--font-pixel);font-size:11px;color:var(--accent2);letter-spacing:2px}

/* === SECTIONS === */
.pack-sections{position:relative;z-index:10;padding-top:60px}
.pack-section{display:flex;align-items:center;justify-content:center;position:relative;padding:60px 24px;overflow:hidden}
.pack-section__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.pack-section__content{position:relative;z-index:2;max-width:900px;width:100%}

/* Section backgrounds */
.section-bg-nodes{background:linear-gradient(135deg,#050a15,#0a1228 50%,#0e0c22)}
.section-bg-nodes .net-node{position:absolute;width:8px;height:8px;background:rgba(255,45,155,.5);border-radius:50%;box-shadow:0 0 18px rgba(255,45,155,.35);animation:nodeGlow 3s ease-in-out infinite}
.section-bg-nodes .net-node:nth-child(even){background:rgba(0,229,255,.45);box-shadow:0 0 18px rgba(0,229,255,.3);animation-delay:1.5s}
@keyframes nodeGlow{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.6)}}

.section-bg-terrain{background:linear-gradient(180deg,#060a18,#0b1230 60%,#080e22)}
.section-bg-circuit{background:linear-gradient(180deg,#060a15,#0c1528 50%,#080e22)}
.section-bg-hex{background:linear-gradient(180deg,#0a0810,#12101e 50%,#0a0810)}
.section-bg-boot{background:linear-gradient(180deg,#050810,#0a1018 50%,#060a12)}
.section-bg-dataflow{background:linear-gradient(180deg,#050a15,#091122 50%,#060b1a)}
.section-bg-horizon{background:linear-gradient(180deg,#060a18,#10102a 40%,#181538 55%,#0c0a1c)}
.section-bg-aurora{background:linear-gradient(180deg,#050a17,#0c1230 40%,#0a0e22)}

/* Animated grid overlays */
.wire-grid-bg{position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(0,229,255,.08) 0px,transparent 1px,transparent 60px),repeating-linear-gradient(0deg,rgba(0,229,255,.08) 0px,transparent 1px,transparent 60px);transform:perspective(600px) rotateX(45deg);transform-origin:center 80%;animation:wireShift 6s linear infinite}
@keyframes wireShift{0%{background-position:0 0}100%{background-position:60px 60px}}

.circuit-grid{position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0,transparent 79px,rgba(255,45,155,.08) 79px,rgba(255,45,155,.08) 80px),repeating-linear-gradient(0deg,transparent 0,transparent 79px,rgba(255,45,155,.08) 79px,rgba(255,45,155,.08) 80px);animation:wireShift 10s linear infinite}

.hex-grid{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='100'%3E%3Cpath d='M28 66L0 50L0 16L28 0L56 16L56 50L28 66L28 100' fill='none' stroke='rgba(255,170,46,0.08)' stroke-width='1'/%3E%3C/svg%3E");background-size:56px 100px;animation:hexShift 12s linear infinite}
@keyframes hexShift{0%{background-position:0 0}100%{background-position:56px 100px}}

.boot-lines{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0px,transparent 28px,rgba(0,229,255,.04) 28px,rgba(0,229,255,.04) 29px);animation:bootScroll 10s linear infinite}
@keyframes bootScroll{0%{background-position:0 0}100%{background-position:0 290px}}
.boot-cursor{position:absolute;top:20%;left:8%;width:12px;height:22px;background:rgba(0,229,255,.4);animation:cursorBlink 1s step-end infinite}
@keyframes cursorBlink{0%,100%{opacity:1}50%{opacity:0}}

.dataflow-streams{position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,229,255,.08) 20%,transparent 40%,rgba(0,229,255,.06) 60%,transparent 80%),linear-gradient(180deg,transparent 10%,rgba(255,45,155,.08) 30%,transparent 50%,rgba(255,45,155,.06) 70%,transparent 90%);background-size:4px 100%,4px 100%;background-position:20% 0,45% 0;background-repeat:repeat-y;animation:dataScroll 5s linear infinite}
@keyframes dataScroll{0%{background-position-y:0}100%{background-position-y:100vh}}

.horizon-sun{position:absolute;top:35%;left:50%;transform:translate(-50%,-50%);width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,45,155,.2),rgba(155,48,255,.08) 40%,transparent 70%);box-shadow:0 0 120px rgba(255,45,155,.15);animation:sunPulse 4s ease-in-out infinite}
@keyframes sunPulse{0%,100%{opacity:.8;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.12)}}
.horizon-grid{position:absolute;bottom:0;left:0;right:0;height:45%;background:repeating-linear-gradient(90deg,rgba(155,48,255,.1) 0px,transparent 1px,transparent 80px),repeating-linear-gradient(0deg,rgba(155,48,255,.1) 0px,transparent 1px,transparent 40px);transform:perspective(400px) rotateX(55deg);transform-origin:center top;animation:horizonScroll 8s linear infinite}
@keyframes horizonScroll{0%{background-position:0 0}100%{background-position:80px 40px}}

.section-glow{position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);border-radius:50%;filter:blur(60px);animation:glowPulse 5s ease-in-out infinite}
.glow-cyan{background:radial-gradient(circle,rgba(0,229,255,.1),transparent 70%)}
.glow-magenta{background:radial-gradient(circle,rgba(255,45,155,.1),transparent 70%)}
.glow-purple{background:radial-gradient(circle,rgba(155,48,255,.1),transparent 70%)}
.glow-amber{background:radial-gradient(circle,rgba(255,170,46,.1),transparent 70%)}
.glow-green{background:radial-gradient(circle,rgba(110,231,160,.1),transparent 70%)}
@keyframes glowPulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}

/* === TYPOGRAPHY === */
.pixel-label{display:inline-block;font-family:var(--font-pixel);font-size:11px;color:var(--accent2);letter-spacing:4px;text-transform:uppercase;margin-bottom:16px;padding:6px 16px;border:1px solid rgba(255,45,155,.25);background:rgba(255,45,155,.06);text-shadow:0 0 6px rgba(255,45,155,.3)}
.section-title{font-family:var(--font-pixel);font-size:28px;color:#e8ecf1;line-height:1.4;margin-bottom:24px;text-shadow:0 0 8px rgba(0,229,255,.2);letter-spacing:1px}
.neon-text{color:var(--accent);text-shadow:0 0 6px rgba(0,229,255,.4)}
.lead-text{font-size:18px;line-height:1.7;color:var(--text);margin-bottom:28px;max-width:750px}

/* === TERMINAL PANEL === */
.terminal-panel{background:var(--surface);border:1px solid var(--border);padding:36px 40px;position:relative;box-shadow:0 10px 30px rgba(0,0,0,.5),inset 0 0 20px rgba(0,240,255,.05);backdrop-filter:blur(8px);margin-bottom:24px}
.terminal-panel::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--accent2),var(--accent))}
.terminal-panel::after{content:'';position:absolute;bottom:-1px;right:-1px;width:20px;height:20px;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}

/* === CYBER CARDS === */
.cyber-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.cyber-card{display:flex;gap:18px;align-items:flex-start;padding:20px 24px;background:rgba(0,240,255,.04);border:1px solid rgba(0,240,255,.15);border-left:3px solid var(--accent);backdrop-filter:blur(6px);transition:all .3s;position:relative;overflow:hidden}
.cyber-card::before{content:'';position:absolute;top:0;left:0;width:0;height:100%;background:rgba(0,240,255,.06);transition:width .4s}
.cyber-card:hover::before{width:100%}
.cyber-card:hover{border-left-color:var(--accent);box-shadow:0 0 20px rgba(0,240,255,.1);transform:translateX(4px)}
.cc-icon{font-size:28px;flex-shrink:0}
.cyber-card div>strong{display:block;font-size:16px;margin-bottom:6px;color:#fff}
.cyber-card p{font-size:14px;color:var(--text2);line-height:1.5;margin:0}

/* === CYBER CALLOUT === */
.cyber-callout{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;background:rgba(0,240,255,.05);border:1px solid rgba(0,240,255,.2);border-left:3px solid var(--accent);font-size:15px;color:var(--text);line-height:1.6;margin-bottom:14px}
.cyber-callout span{font-size:20px;flex-shrink:0}
.cyber-callout p{margin:0}
.cyber-callout--amber{background:rgba(255,170,0,.05);border-color:rgba(255,170,0,.2);border-left-color:var(--amber)}
.cyber-callout--red{background:rgba(255,77,106,.05);border-color:rgba(255,77,106,.2);border-left-color:var(--red)}
.cyber-callout--green{background:rgba(110,231,160,.05);border-color:rgba(110,231,160,.2);border-left-color:var(--green)}

/* === SQUAD ROSTER === */
.squad-roster{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.squad-member{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 16px;background:rgba(255,45,155,.04);border:1px solid rgba(255,45,155,.2);position:relative;overflow:hidden;transition:all .3s}
.squad-member::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,rgba(255,45,155,.5),transparent)}
.squad-member:hover{transform:translateY(-4px);box-shadow:0 0 25px rgba(255,45,155,.12)}
.squad-avatar{font-size:36px}
.squad-name{font-family:var(--font-pixel);font-size:11px;color:var(--accent2);letter-spacing:1px;text-shadow:0 0 8px rgba(255,45,155,.4);text-align:center;word-break:break-word}

/* === CYBER STEPS === */
.cyber-steps{display:flex;align-items:stretch;gap:0;margin-bottom:24px;flex-wrap:wrap}
.cyber-step{flex:1;padding:20px;background:rgba(0,0,0,.4);border:1px solid rgba(0,240,255,.15);min-width:140px}
.cs-num{font-family:var(--font-pixel);color:var(--accent2);font-size:20px;margin-bottom:10px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid var(--accent2);background:rgba(255,45,155,.08)}
.cyber-step strong{font-size:15px;display:block;margin-bottom:6px;color:#fff}
.cyber-step p{font-size:13px;color:var(--text2);line-height:1.5;margin:0}
.cs-arrow{display:flex;align-items:center;padding:0 12px;font-family:var(--font-pixel);font-size:20px;color:var(--accent);animation:bounceX 1.5s ease-in-out infinite}
@keyframes bounceX{0%,100%{transform:translateX(0)}50%{transform:translateX(8px)}}

/* === PLAN CARDS === */
.plan-cards{display:flex;gap:20px;margin-bottom:24px}
.plan-card{flex:1;padding:24px;background:rgba(0,0,0,.4);border:1px solid rgba(0,240,255,.2);position:relative}
.plan-card--core{border-top:3px solid var(--accent)}
.plan-card--core .plan-badge{color:var(--accent)}
.plan-card--nice{border-top:3px solid var(--amber)}
.plan-card--nice .plan-badge{color:var(--amber)}
.plan-badge{font-family:var(--font-pixel);font-size:11px;margin-bottom:14px;display:block}
.plan-card h4{font-size:18px;font-weight:700;margin-bottom:8px;color:#fff}
.plan-card p{font-size:14px;color:var(--text2);line-height:1.6}

/* === CYBER GRID === */
.cyber-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}
.cyber-tile{padding:22px;background:rgba(0,0,0,.4);border:1px solid rgba(0,240,255,.15);text-align:center;transition:all .3s;position:relative;overflow:hidden}
.cyber-tile::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s}
.cyber-tile:hover{background:rgba(0,240,255,.06);transform:translateY(-3px)}
.cyber-tile:hover::after{opacity:1}
.ct-icon{font-size:28px;display:block;margin-bottom:12px}
.cyber-tile h4{font-size:15px;font-weight:700;margin-bottom:6px;color:#fff}
.cyber-tile p{font-size:13px;color:var(--text2);line-height:1.5;margin:0}

/* === API KEY === */
.api-key-box{background:rgba(0,0,0,.6);border:2px solid rgba(110,231,160,.3);padding:24px;margin-bottom:20px;position:relative}
.api-key-value{font-family:'Courier New',monospace;font-size:16px;color:var(--green);letter-spacing:1px;word-break:break-all;text-shadow:0 0 8px rgba(110,231,160,.4)}
.api-key-copy{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:10px 20px;font-family:var(--font-pixel);font-size:11px;color:var(--green);background:rgba(110,231,160,.08);border:1px solid rgba(110,231,160,.3);cursor:pointer;transition:all .3s;letter-spacing:1px}
.api-key-copy:hover{background:rgba(110,231,160,.15);box-shadow:0 0 15px rgba(110,231,160,.2)}
.api-key-copy.copied{color:var(--amber);border-color:var(--amber)}

/* === SCREENSHOT === */
.screenshot-wrap{margin:20px 0;border:2px solid rgba(0,229,255,.2);position:relative;overflow:hidden}
.screenshot-wrap::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,229,255,.02) 3px,rgba(0,229,255,.02) 6px);pointer-events:none;z-index:1}
.screenshot-wrap img{display:block;width:100%;height:auto}
.screenshot-label{font-family:var(--font-pixel);font-size:10px;color:var(--accent);letter-spacing:2px;padding:8px 14px;background:rgba(0,0,0,.6);border-top:1px solid rgba(0,229,255,.2)}

/* === COUNTDOWN BADGE === */
.countdown-badge{display:inline-flex;align-items:center;gap:16px;padding:14px 24px;background:rgba(255,45,155,.1);border:1px solid rgba(255,45,155,.3);font-size:16px;color:var(--accent2)}
.countdown-num{font-family:var(--font-pixel);font-size:28px;color:var(--accent2);text-shadow:0 0 12px rgba(255,45,155,.5)}

/* === DOC REQUIREMENTS === */
.doc-requirements{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.doc-requirements li{padding:10px 16px;background:rgba(0,229,255,.04);border-left:3px solid var(--accent);color:var(--text);font-size:15px;letter-spacing:.5px}
.doc-requirements li strong{color:var(--accent)}

/* === DOWNLOAD BUTTON === */
.download-btn{display:inline-flex;align-items:center;gap:12px;padding:14px 28px;font-family:var(--font-pixel);font-size:13px;color:var(--green);background:rgba(110,231,160,.08);border:2px solid rgba(110,231,160,.4);cursor:pointer;transition:all .3s;letter-spacing:1px;text-decoration:none;margin-bottom:24px}
.download-btn:hover{background:rgba(110,231,160,.18);box-shadow:0 0 25px rgba(110,231,160,.25);transform:translateY(-2px)}
.download-btn span{font-size:20px}

/* === SECTION DIVIDER === */
.section-num{font-family:var(--font-pixel);font-size:28px;color:var(--accent2);opacity:.5;margin-bottom:16px;display:block}

/* === ANIMATIONS === */
.fade-in{opacity:0;transform:translateY(20px);transition:all .6s ease-out}
.fade-in.visible{opacity:1;transform:translateY(0)}
.pulse-icon{animation:iconPulse 2.5s ease-in-out infinite}
@keyframes iconPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}

/* === RESPONSIVE === */
@media(max-width:768px){
  .game-heading{font-size:28px}
  .team-grid{grid-template-columns:1fr}
  .section-title{font-size:22px}
  .terminal-panel{padding:24px 20px}
  .cyber-steps{flex-direction:column}
  .cs-arrow{transform:rotate(90deg);padding:8px 0;justify-content:center}
  .plan-cards{flex-direction:column}
  .cyber-grid{grid-template-columns:1fr}
  .squad-roster{grid-template-columns:1fr 1fr}
  .pack-section{padding:60px 16px}
}
