*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0a0a;--deep:#0c1a2e;--surface:#0e1520;--surface2:#131c2a;
  --card:#111a26;--border:#1a2a3a;--border-l:#243344;
  --text:#d0dce8;--dim:#5a6a7a;--dim2:#3a4a5a;
  --cyan:#00e5ff;--green:#22c55e;--amber:#eab308;--red:#ef4444;--purple:#a855f7;
  --orange:#f97316;
  --font:'Chakra Petch',sans-serif;--mono:'Fira Mono',monospace;--pixel:'Press Start 2P',monospace;
  --container:1100px;
}
html{scroll-behavior:auto;overflow-x:hidden}
body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.loading{overflow:hidden}
/* ── Loader ── */
.loader{position:fixed;inset:0;z-index:90;background:rgba(0,0,168,.9);display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease;overflow:hidden}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader__glitch-line{position:absolute;left:0;right:0;height:3px;background:rgba(255,255,255,.2);pointer-events:none;opacity:0}
.loader__glitch-line:nth-child(1){top:12%}.loader__glitch-line:nth-child(2){top:38%}.loader__glitch-line:nth-child(3){top:62%}.loader__glitch-line:nth-child(4){top:85%}
.loader__glitch-text{position:absolute;font-family:var(--pixel);font-size:11px;color:rgba(255,255,255,.2);pointer-events:none;opacity:0;white-space:nowrap;letter-spacing:1px;text-shadow:0 0 8px rgba(255,255,255,.2)}
.loader__glitch-text:nth-of-type(5){top:10%;left:5%}.loader__glitch-text:nth-of-type(6){top:30%;right:6%;left:auto}.loader__glitch-text:nth-of-type(7){top:55%;left:8%}.loader__glitch-text:nth-of-type(8){top:78%;right:4%;left:auto}
.loader__inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px;padding:20px;position:relative;z-index:2}
.loader__logo{width:clamp(180px,30vw,280px);image-rendering:pixelated;animation:loaderPulse 3s ease-in-out infinite;filter:drop-shadow(0 0 30px rgba(255,255,255,.15));margin-bottom:16px}
@keyframes loaderPulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}
.loader__sos{font-family:var(--pixel);font-size:clamp(8px,1.4vw,11px);color:#fff;letter-spacing:3px;opacity:.7;animation:sosBlink 1.5s step-end infinite}
@keyframes sosBlink{0%,100%{opacity:.7}50%{opacity:.3}}
.loader__msg{font-family:var(--mono);font-size:clamp(11px,1.4vw,14px);color:rgba(255,255,255,.6);line-height:2;max-width:460px;letter-spacing:.5px}
.loader__progress{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:12px}
.loader__bar-wrap{width:clamp(180px,30vw,260px);height:6px;background:rgba(255,255,255,.1);border-radius:0;overflow:hidden;border:1px solid rgba(255,255,255,.2)}
.loader__bar{height:100%;width:0%;background:#a8a8a8;border-radius:0;transition:width .3s ease;box-shadow:0 0 8px rgba(255,255,255,.3)}
.loader__percent{font-family:var(--pixel);font-size:9px;color:rgba(255,255,255,.5);letter-spacing:2px}
.loader__btn{display:none;font-family:var(--pixel);font-size:10px;color:#0000a8;background:#a8a8a8;border:none;padding:14px 36px;border-radius:0;cursor:pointer;letter-spacing:2px;transition:all .3s;box-shadow:2px 2px 0 rgba(0,0,0,.3)}
.loader__btn:hover{background:#c0c0c0;transform:scale(1.05);box-shadow:0 0 20px rgba(255,255,255,.2)}
.loader__btns{display:inline-grid;gap:12px}
.loader__btns>*{text-align:center;box-sizing:border-box}
.loader__btn-secondary{display:none;font-family:var(--pixel);font-size:10px;color:rgba(255,255,255,.6);background:transparent;border:1px solid rgba(255,255,255,.25);padding:14px 36px;cursor:pointer;letter-spacing:2px;transition:all .3s;text-decoration:none}
.loader__btn-secondary:hover{color:#fff;border-color:rgba(255,255,255,.5);box-shadow:0 0 12px rgba(255,255,255,.1)}
.loader__btn-secondary.show{display:block;animation:loaderBtnIn .5s ease .15s both}
.loader__btn.show{display:block;animation:loaderBtnIn .5s ease}
@keyframes loaderBtnIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
body.loading .footer-bar__surface,body.loading .footer-bar__surface--nav,body.loading .footer-bar__surface-row{display:none}
body.loading .topbar{z-index:95;justify-content:flex-end}
body.loading .topbar .steam-logo,body.loading .topbar__btn--discord,body.loading .topbar__btn--sound,body.loading .steam-cta,body.loading .bottom-bar{display:none}
body.loading .topbar__lang-menu{background:rgba(0,0,168,.95);border-color:rgba(255,255,255,.2)}
body.loading .topbar__lang-opt{color:rgba(255,255,255,.6)}
body.loading .topbar__lang-opt:hover{color:#fff;background:rgba(255,255,255,.1)}
body.loading .topbar__lang-opt.active{color:#fff}
body.loading .footer-bar{z-index:95}
body.loading .footer-bar,body.loading .footer-bar__nav,body.loading .statusbar{background:#0000a8;border-color:rgba(255,255,255,.15)}
body.loading .statusbar{border-bottom:1px solid rgba(255,255,255,.15)}

/* ── Pixel grid subtle bg (disabled for uniform dark bg) ── */

/* ── Top Bar (fixed) ── */
.topbar{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:12px clamp(16px,3vw,32px);z-index:60;pointer-events:none}
.topbar .steam-logo{pointer-events:auto;width:64px;height:64px;display:block;transition:transform .2s ease}
.topbar .steam-logo:hover{transform:scale(1.15)}
.topbar .steam-logo__img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated;border-radius:8px}
.topbar__right{display:flex;gap:8px;align-items:center}
.topbar__btn{pointer-events:auto;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;min-height:36px;font-family:var(--pixel);font-size:10px;letter-spacing:1px;border:none;border-radius:6px;cursor:pointer;transition:all .3s;text-decoration:none}
.topbar__btn:active{transform:scale(.95)}
.topbar__btn--discord{background:#2DD4BF;color:#0a0a0a;font-weight:700;box-shadow:0 0 12px rgba(45,212,191,.4)}
.topbar__btn--discord:hover{background:#14b8a6;box-shadow:0 0 20px rgba(45,212,191,.7);transform:scale(1.05)}
.topbar__btn--discord:active{background:#0d9488;box-shadow:0 0 8px rgba(45,212,191,.3);transform:scale(.95)}
.topbar__btn--lang,.topbar__btn--sound{background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.04);backdrop-filter:blur(8px);box-shadow:0 0 8px rgba(255,255,255,.05)}
.topbar__btn--lang:hover,.topbar__btn--sound:hover{border-color:var(--cyan);color:var(--text);box-shadow:0 0 16px rgba(0,229,255,.3);transform:scale(1.05)}
.topbar__btn--lang:active,.topbar__btn--sound:active{box-shadow:0 0 6px rgba(0,229,255,.2);transform:scale(.95)}
.topbar__lang-wrap{position:relative;pointer-events:auto}
.topbar__lang-arrow{display:inline-block;width:0;height:0;margin-left:6px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;vertical-align:middle;position:relative;top:0px}
.topbar__lang-menu{position:absolute;top:calc(100% + 6px);right:0;white-space:nowrap;background:rgba(14,21,32,.95);border:1px solid var(--border-l);border-radius:6px;padding:4px 0;opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .2s ease;backdrop-filter:blur(12px);pointer-events:none}
.topbar__lang-wrap.open .topbar__lang-menu{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.topbar__lang-opt{display:block;width:100%;padding:8px 14px;background:none;border:none;font-family:var(--mono);font-size:12px;color:var(--dim);text-align:right;cursor:pointer;transition:background .15s,color .15s}
.topbar__lang-opt:hover{background:rgba(0,229,255,.08);color:var(--text)}
.topbar__lang-opt.active{color:var(--cyan)}
.topbar__btn--sound{padding:8px 10px;min-width:36px}
.topbar__btn--sound:not(.muted){border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 14px rgba(0,229,255,.25)}
.topbar__icon{display:block}
.topbar__icon--off{display:none}
.topbar__btn--sound.muted .topbar__icon--on{display:none}
.topbar__btn--sound.muted .topbar__icon--off{display:block}

/* Evidence flicker */
/* Evidence — entrance + idle */
.evidence-flicker{opacity:0;transform:translateY(30px) scale(.9);animation:none;width:180px;height:180px;image-rendering:pixelated;margin-bottom:16px}
.evidence-flicker.visible{animation:evEnter .8s cubic-bezier(.2,.8,.3,1) forwards, evFloat 4s ease-in-out 1s infinite, evFlicker 3s ease-in-out 1s infinite}
@keyframes evEnter{
  0%{opacity:0;transform:translateY(30px) scale(.9);filter:drop-shadow(0 0 0 transparent) blur(2px)}
  40%{opacity:.4;transform:translateY(10px) scale(.95);filter:drop-shadow(0 0 20px rgba(94,234,212,.6)) blur(1px)}
  60%{opacity:1;transform:translateY(-4px) scale(1.02);filter:drop-shadow(0 0 24px rgba(94,234,212,.8)) blur(0)}
  80%{opacity:.7;filter:drop-shadow(0 0 8px rgba(94,234,212,.3))}
  100%{opacity:1;transform:translateY(0) scale(1);filter:drop-shadow(0 0 12px rgba(94,234,212,.4))}
}
@keyframes evFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
@keyframes evFlicker{0%,100%{opacity:1;filter:drop-shadow(0 0 12px rgba(94,234,212,.4))}30%{opacity:.7;filter:drop-shadow(0 0 6px rgba(94,234,212,.2))}35%{opacity:1;filter:drop-shadow(0 0 16px rgba(94,234,212,.6))}70%{opacity:.85;filter:drop-shadow(0 0 8px rgba(94,234,212,.3))}75%{opacity:1;filter:drop-shadow(0 0 14px rgba(94,234,212,.5))}}

/* ── Particles ── */
.particles{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.p{position:absolute;background:var(--cyan);border-radius:0;opacity:0}
.p:nth-child(odd){width:2px;height:2px}
.p:nth-child(even){width:3px;height:3px;background:var(--green)}
.p:nth-child(1){left:8%;top:15%;animation:fp 14s ease-in-out infinite}
.p:nth-child(2){left:22%;top:55%;animation:fp 18s ease-in-out infinite 2s}
.p:nth-child(3){left:40%;top:25%;animation:fp 16s ease-in-out infinite 4s}
.p:nth-child(4){left:62%;top:70%;animation:fp 12s ease-in-out infinite 1s}
.p:nth-child(5){left:78%;top:35%;animation:fp 15s ease-in-out infinite 6s}
.p:nth-child(6){left:15%;top:80%;animation:fp 17s ease-in-out infinite 3s}
.p:nth-child(7){left:50%;top:10%;animation:fp 13s ease-in-out infinite 8s}
.p:nth-child(8){left:88%;top:50%;animation:fp 19s ease-in-out infinite 5s}
.p:nth-child(9){left:35%;top:90%;animation:fp 14s ease-in-out infinite 7s}
.p:nth-child(10){left:70%;top:5%;animation:fp 16s ease-in-out infinite 9s}
@keyframes fp{0%,100%{transform:translateY(0);opacity:0}15%{opacity:.5}50%{transform:translateY(-60px) translateX(15px);opacity:.2}85%{opacity:.4}}

/* ── Sections ── */
.sect{position:relative;z-index:2}

/* ═══════════════════════════════
   INTRO — Logo + Background
   ═══════════════════════════════ */
.intro{position:relative;z-index:3;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}
.intro__bg{position:absolute;inset:0;background:url('assets/img/background/fondo.webp') center/cover no-repeat;z-index:0}
.intro__bg::after{content:'';position:absolute;inset:0;background:#083344;mix-blend-mode:multiply}
.intro__bg-fade{position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to bottom,transparent,#0a0a0a);z-index:1}
/* Underwater caustic light rays — below multiply overlay */
.intro__caustics{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;opacity:.7}
.caustic-ray{position:absolute;top:-20%;width:8%;height:130%;background:linear-gradient(180deg,rgba(150,235,255,.9),rgba(120,220,255,.3) 60%,transparent);border-radius:0 0 50% 50%;filter:blur(10px);transform-origin:top center}
.caustic-ray:nth-child(1){left:8%;animation:caustic1 8s ease-in-out infinite;transform:rotate(-8deg)}
.caustic-ray:nth-child(2){left:22%;width:6%;animation:caustic2 10s ease-in-out infinite 1s;transform:rotate(4deg)}
.caustic-ray:nth-child(3){left:38%;width:10%;animation:caustic3 9s ease-in-out infinite 2.5s;transform:rotate(-3deg)}
.caustic-ray:nth-child(4){left:55%;width:7%;animation:caustic1 11s ease-in-out infinite 3s;transform:rotate(6deg)}
.caustic-ray:nth-child(5){left:70%;width:9%;animation:caustic2 8.5s ease-in-out infinite 1.5s;transform:rotate(-5deg)}
.caustic-ray:nth-child(6){left:85%;width:5%;animation:caustic3 10s ease-in-out infinite 4s;transform:rotate(3deg)}
.caustic-ray:nth-child(7){left:15%;width:4%;animation:caustic2 12s ease-in-out infinite 5s;transform:rotate(-2deg);opacity:.6}
.caustic-ray:nth-child(8){left:48%;width:6%;animation:caustic1 9.5s ease-in-out infinite 2s;transform:rotate(7deg);opacity:.5}
@keyframes caustic1{
  0%,100%{transform:rotate(-8deg) scaleX(1);opacity:1}
  25%{transform:rotate(-2deg) scaleX(1.3);opacity:.7}
  50%{transform:rotate(5deg) scaleX(.8);opacity:1}
  75%{transform:rotate(1deg) scaleX(1.1);opacity:.6}
}
@keyframes caustic2{
  0%,100%{transform:rotate(4deg) scaleX(1);opacity:.8}
  30%{transform:rotate(-3deg) scaleX(1.4);opacity:1}
  60%{transform:rotate(6deg) scaleX(.7);opacity:.5}
  80%{transform:rotate(0deg) scaleX(1.2);opacity:.9}
}
@keyframes caustic3{
  0%,100%{transform:rotate(-3deg) scaleX(.9);opacity:.7}
  35%{transform:rotate(4deg) scaleX(1.3);opacity:1}
  65%{transform:rotate(-6deg) scaleX(1);opacity:.6}
  85%{transform:rotate(2deg) scaleX(.8);opacity:.9}
}
.intro__content{position:relative;z-index:4;text-align:center;display:flex;flex-direction:column;align-items:center}
.intro__logo{width:clamp(200px,40vw,400px);margin-bottom:40px;opacity:0}
.intro__logo.show{animation:logoIn .8s cubic-bezier(.2,.8,.3,1) forwards}
@keyframes logoIn{0%{opacity:0;transform:scale(.3)}60%{opacity:1;transform:scale(1.05)}100%{opacity:1;transform:scale(1)}}
/* Explosion spritesheet — 7 frames */
.intro__explosion{position:absolute;width:clamp(250px,45vw,450px);height:clamp(250px,45vw,450px);background:url('assets/img/effects/explotion.webp') 0 0/700% 100%;image-rendering:pixelated;pointer-events:none;opacity:0;z-index:5}
.intro__explosion.play{opacity:1;animation:explode .6s steps(6) forwards}
@keyframes explode{0%{background-position:0 0}100%{background-position:-600% 0}}
.intro__cd-spacer{height:220px;margin-bottom:40px}

/* Fish swimming animation (4-frame spritesheet @ 8fps) */
.fish{position:absolute;width:160px;height:160px;background:url('assets/img/creatures/fish/spritesheet.webp') 0 0/400% 100%;image-rendering:pixelated;pointer-events:none;animation:fishFrames .5s steps(4) infinite}
@keyframes fishFrames{from{background-position:0 0}to{background-position:-400% 0}}
/* Individual fish — unique size, speed, depth, vertical path */
.fish-1{z-index:7;width:180px;height:180px;animation:fishFrames .25s steps(4) infinite,swimR1 2.5s linear infinite}
.fish-2{z-index:2;width:150px;height:150px;animation:fishFrames .25s steps(4) infinite,swimL1 5s linear infinite;transform:scaleX(-1);animation-delay:0s,-2s}
.fish-3{z-index:7;width:200px;height:200px;animation:fishFrames .25s steps(4) infinite,swimR2 4s linear infinite;animation-delay:0s,-5s}
.fish-4{z-index:2;width:140px;height:140px;animation:fishFrames .25s steps(4) infinite,swimL2 2.2s linear infinite;transform:scaleX(-1);animation-delay:0s,-4s}
@keyframes swimR1{
  0%{left:-200px;top:35%}25%{top:31%}50%{top:37%}75%{top:33%}100%{left:calc(100% + 200px);top:35%}
}
@keyframes swimL1{
  0%{left:calc(100% + 180px);top:55%}25%{top:51%}50%{top:57%}75%{top:53%}100%{left:-180px;top:55%}
}
@keyframes swimR2{
  0%{left:-220px;top:68%}25%{top:64%}50%{top:70%}75%{top:66%}100%{left:calc(100% + 220px);top:68%}
}
@keyframes swimL2{
  0%{left:calc(100% + 170px);top:25%}25%{top:21%}50%{top:27%}75%{top:23%}100%{left:-170px;top:25%}
}

/* Floating weapons in battle section */
.battle-weapon{position:absolute;image-rendering:pixelated;pointer-events:none;z-index:1;opacity:.7;transition:opacity .5s ease}
.bw-r1{width:50px;height:50px;animation:wpnR1 2s linear infinite}
.bw-l1{width:80px;height:80px;animation:wpnL1 2.5s linear infinite;transform:scaleX(-1)}
.bw-r2{width:42px;height:42px;animation:wpnR2 1.8s linear infinite;animation-delay:-.8s}
.bw-l2{width:75px;height:75px;animation:wpnL2 2.2s linear infinite;transform:scaleX(-1);animation-delay:-.5s}
.bw-r3{width:65px;height:65px;animation:wpnR3 2.3s linear infinite;animation-delay:-1.2s}
.bw-l3{width:55px;height:55px;animation:wpnL3 1.9s linear infinite;transform:scaleX(-1);animation-delay:-.3s}
@keyframes wpnR1{0%{left:-100px;top:20%}50%{top:24%}100%{left:calc(100% + 100px);top:20%}}
@keyframes wpnL1{0%{left:calc(100% + 100px);top:45%}50%{top:41%}100%{left:-100px;top:45%}}
@keyframes wpnR2{0%{left:-80px;top:70%}50%{top:66%}100%{left:calc(100% + 80px);top:70%}}
@keyframes wpnL2{0%{left:calc(100% + 90px);top:30%}50%{top:34%}100%{left:-90px;top:30%}}
@keyframes wpnR3{0%{left:-90px;top:55%}50%{top:51%}100%{left:calc(100% + 90px);top:55%}}
@keyframes wpnL3{0%{left:calc(100% + 100px);top:80%}50%{top:76%}100%{left:-100px;top:80%}}

/* Achievement icon — above statusbar */
/* Bottom bar — fixed container for CTA + achievements */
.bottom-bar{position:fixed;bottom:72px;right:16px;z-index:45;display:flex;align-items:center;gap:12px;flex-direction:row-reverse}
.achievement{pointer-events:auto;cursor:default;opacity:0;transform:scale(0);transition:opacity .3s ease,transform .3s ease}
.achievement.show{opacity:1;transform:scale(1)}
.achievement__icon{width:48px;height:48px;border-radius:6px;image-rendering:pixelated;border:2px solid var(--amber);box-shadow:0 0 12px rgba(234,179,8,.3);display:block;transition:box-shadow .3s;object-fit:cover;background:#0a0a0a;padding:0}
.achievement__icon-wrap:hover .achievement__icon{box-shadow:0 0 20px rgba(234,179,8,.6)}
.achievement__icon-wrap{position:relative}
.achievement__tooltip{position:absolute;bottom:calc(100% + 8px);right:0;background:rgba(10,10,10,.95);border:1px solid var(--amber);border-radius:6px;padding:10px 14px;white-space:nowrap;opacity:0;transform:translateY(4px);transition:all .25s ease;pointer-events:none;backdrop-filter:blur(8px)}
.achievement__icon-wrap:hover .achievement__tooltip{opacity:1;transform:translateY(0)}
.achievement__label{font-family:var(--pixel);font-size:7px;color:var(--amber);letter-spacing:1px;display:block;margin-bottom:4px}
.achievement__name{font-family:var(--mono);font-size:12px;color:var(--text);font-weight:700}
.achievement__icon--cyan{border-color:var(--cyan);box-shadow:0 0 12px rgba(0,229,255,.3)}
.achievement__icon-wrap:hover .achievement__icon--cyan{box-shadow:0 0 20px rgba(0,229,255,.6)}
.achievement__label--cyan{color:var(--cyan)}
#achievement-weapons .achievement__icon,#achievement-emp .achievement__icon{object-fit:contain}
/* Steam CTA — always fixed */
.steam-cta{display:inline-flex;align-items:center;gap:14px;font-family:var(--pixel);font-size:12px;color:#000;background:var(--amber);padding:0 22px;height:56px;border-radius:6px;text-decoration:none;white-space:nowrap;box-shadow:0 0 12px rgba(234,179,8,.4);transition:all .3s;pointer-events:auto;border:none}
.steam-cta:hover{box-shadow:0 0 24px rgba(234,179,8,.7);transform:scale(1.05) translateY(-2px)}
.steam-cta__icon{width:24px;height:24px;flex-shrink:0}
.steam-cta__content{display:flex;flex-direction:column;align-items:flex-start;gap:2px}
.steam-cta__label{font-size:11px;letter-spacing:1px;display:block}
.steam-cta__sublabel{font-family:var(--mono);font-size:9px;font-weight:700;opacity:.7;letter-spacing:0.5px}

/* Submarine debris parts */
.sub-part{position:absolute;image-rendering:pixelated;pointer-events:none;opacity:0;will-change:transform,opacity;transform:scale(1.2)}
.sp-19{z-index:3;width:170px;left:19%;top:35%}
.sp-1{z-index:6;width:120px;left:82%;top:18%}
.sp-18{z-index:3;width:140px;left:75%;top:65%}
.sp-13{z-index:6;width:80px;left:3%;top:65%}
.sp-15{z-index:3;width:110px;left:88%;top:42%}
.sp-16{z-index:6;width:90px;left:15%;top:15%}
.sp-2{z-index:3;width:70px;left:30%;top:65%}
.sp-17{z-index:6;width:60px;left:35%;top:12%}
.sp-5{z-index:3;width:35px;left:65%;top:20%}
.sp-8{z-index:6;width:40px;left:25%;top:80%}
.sp-7{z-index:3;width:30px;left:25%;top:45%}

.intro__logo-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.intro__scroll{font-family:var(--mono);font-size:13px;color:rgba(255,255,255,.5);letter-spacing:.15em;text-transform:uppercase;animation:scrollPulse 2s ease-in-out infinite;opacity:0}
#intro-typewriter{font-family:var(--mono);font-size:clamp(12px,1.8vw,15px);color:var(--amber);text-align:center;margin-top:24px;height:5.4em;line-height:1.8;opacity:0;letter-spacing:.02em;white-space:pre-wrap}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:.7}}
.intro__scroll::after{content:'';display:block;width:1px;height:32px;background:linear-gradient(rgba(255,255,255,.3),transparent);margin:10px auto 0}

/* ═══════════════════════════════
   CONSOLE — Signal Message
   ═══════════════════════════════ */
.console-sect{position:relative;z-index:3;background:#0a0a0a;padding:60px 32px 80px;min-height:80vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.console__inner{max-width:var(--container);width:100%;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.console__left{}
.console__text{font-family:var(--mono);font-size:18px;color:#c0c0c0;line-height:1.9;white-space:pre-wrap}
.console__right{display:flex;align-items:center;justify-content:flex-end;margin-right:-10%}

/* Solo CD — one element that travels from intro to console */
.solo-cd-layer{position:absolute;top:0;left:0;width:100%;height:0;z-index:40;pointer-events:none}
.solo-cd{position:absolute;width:220px;height:220px;object-fit:contain;pointer-events:none;filter:drop-shadow(0 0 24px rgba(234,179,8,.5)) drop-shadow(0 0 60px rgba(234,179,8,.2))}
.solo-cd-glow{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(234,179,8,.2) 0%,rgba(234,179,8,.08) 40%,transparent 70%);pointer-events:none;opacity:0}
@keyframes glowPulse{0%,100%{transform:scale(1) rotate(0deg);opacity:.5}25%{transform:scale(1.15) rotate(3deg);opacity:.8}50%{transform:scale(1.3) rotate(0deg);opacity:1}75%{transform:scale(1.15) rotate(-3deg);opacity:.8}}
/* Placeholder space in console where CD lands (2x = 440px) */
.console__cd-space{width:440px;height:440px}
.console__btn{margin-top:20px;font-family:var(--mono);font-size:18px;padding:0;background:transparent;border:none;color:var(--amber);cursor:pointer;opacity:0;transition:opacity .3s;display:flex;align-items:center;gap:6px;text-decoration:none}
.console__btn.show{opacity:1;animation:btnPulse 2s ease-in-out infinite}
.console__btn:hover{color:#fbbf24;text-shadow:0 0 8px rgba(234,179,8,.5)}
.console__btn::before{content:'▸';font-size:16px}
@keyframes btnPulse{0%,100%{opacity:.6}50%{opacity:1}}

/* ═══════════════════════════════
   HERO — The Message
   ═══════════════════════════════ */
.hero{min-height:100vh;display:flex;align-items:center;padding:100px 24px 80px;position:relative;overflow:hidden}
.hero__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hero__left{}
.hero__tag{font-family:var(--pixel);font-size:8px;color:var(--amber);letter-spacing:1px;margin-bottom:16px;opacity:.7}
.hero__title{font-size:clamp(32px,5vw,56px);font-weight:700;line-height:1.1;margin-bottom:20px;letter-spacing:-.02em}
.hero__title span{color:var(--cyan)}
.hero__desc{font-size:16px;color:var(--dim);line-height:1.8;margin-bottom:28px;max-width:480px}
.hero__ctas{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.btn-primary{font-family:var(--font);font-size:14px;font-weight:700;padding:14px 32px;background:var(--cyan);color:var(--bg);border:none;border-radius:4px;cursor:pointer;letter-spacing:.05em;transition:all .3s;text-decoration:none}
.btn-primary:hover{box-shadow:0 0 30px rgba(0,229,255,.3);transform:translateY(-2px)}
.btn-ghost{font-family:var(--mono);font-size:12px;padding:12px 24px;background:transparent;border:1px solid var(--border-l);color:var(--dim);cursor:pointer;border-radius:4px;transition:all .3s;text-decoration:none}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan)}
/* Right: Waveform + transcript */
.hero__right{position:relative}
.hero__terminal{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.hero__terminal-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--surface2);border-bottom:1px solid var(--border)}
.hero__terminal-dot{width:8px;height:8px;border-radius:50%}
.hero__terminal-label{font-family:var(--mono);font-size:10px;color:var(--dim);margin-left:auto;letter-spacing:.05em}
.hero__terminal-body{padding:20px;font-family:var(--mono);font-size:13px;line-height:2;color:var(--green)}
.hero__terminal-body .ln{color:var(--dim2);user-select:none;display:inline-block;width:24px;text-align:right;margin-right:12px;font-size:11px}
.hero__waveform{display:flex;gap:3px;align-items:center;height:32px;margin-bottom:16px;padding:0 20px}
.wbar{width:3px;background:var(--cyan);border-radius:0;opacity:.5;animation:wb 1.4s ease-in-out infinite}
@keyframes wb{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.25)}}

/* ═══════════════════════════════
   SUBMARINE — FTL Cross Section
   ═══════════════════════════════ */
.sub-section{padding:80px 24px 100px;text-align:center;overflow:hidden}
.sub-section__label{font-family:var(--pixel);font-size:9px;color:var(--cyan);letter-spacing:2px;margin-bottom:8px}
#evidence-label{margin-bottom:24px;font-size:clamp(12px,1.8vw,15px)}
.sub-section__title{font-size:clamp(24px,4vw,40px);font-weight:700;margin-bottom:12px}
.sub-section__desc{font-size:15px;color:var(--dim);max-width:550px;margin:0 auto 48px;line-height:1.7}

/* FTL Ship */
.ftl-ship{max-width:900px;margin:0 auto;position:relative}
.ftl-hull{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;background:var(--border);border:3px solid var(--dim2);border-radius:8px 32px 32px 8px;padding:3px;position:relative;overflow:hidden}
.ftl-hull::before{content:'';position:absolute;left:-20px;top:50%;width:20px;height:40px;background:var(--dim2);transform:translateY(-50%);border-radius:4px 0 0 4px}
.ftl-hull::after{content:'';position:absolute;right:-16px;top:50%;width:20px;height:24px;background:var(--dim2);transform:translateY(-50%);border-radius:0 8px 8px 0;border:2px solid var(--dim2)}
.ftl-room{background:var(--surface);border-radius:4px;padding:16px 8px;text-align:center;position:relative;transition:all .3s;cursor:default;min-height:110px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.ftl-room:hover{background:var(--surface2);border-color:var(--cyan)}
.ftl-room svg{width:32px;height:32px;image-rendering:auto}
.ftl-room__name{font-family:var(--pixel);font-size:7px;color:var(--dim);letter-spacing:.5px}
.ftl-room__status{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.05em}
.st-online{color:var(--green)}
.st-damaged{color:var(--amber)}
.st-critical{color:var(--red)}
.st-offline{color:var(--red);opacity:.5}
.ftl-room--damaged{border:1px solid rgba(234,179,8,.2)}
.ftl-room--damaged::after{content:'';position:absolute;top:5px;right:5px;width:6px;height:6px;background:var(--amber);border-radius:0;animation:pdot 1.5s ease-in-out infinite}
.ftl-room--offline{opacity:.4;border:1px solid rgba(239,68,68,.15)}
.ftl-room--critical{border:1px solid rgba(239,68,68,.3)}
.ftl-room--critical::after{content:'';position:absolute;top:5px;right:5px;width:6px;height:6px;background:var(--red);border-radius:0;animation:pdot 1s ease-in-out infinite}
/* Crew dots */
.crew-dots{display:flex;gap:3px;justify-content:center;margin-top:4px}
.crew-dot{width:4px;height:4px;border-radius:0;background:var(--green)}
.crew-dot--dead{background:var(--red);opacity:.4}

/* ═══════════════════════════════
   DECISION — Transfer Panel
   ═══════════════════════════════ */
.salvage-intro{text-align:center;max-width:var(--container);margin:220px auto 0}
.salvage-section{max-width:var(--container);margin:80px auto 0}
#r-fleet{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;align-items:stretch}
#s-decision{max-width:100%;margin:80px auto 0}
#decision-img{width:180px;height:180px;image-rendering:pixelated;margin:0 auto 8px;display:block;filter:drop-shadow(0 0 12px rgba(234,179,8,.4));opacity:0}
#record-img{width:180px;height:180px;image-rendering:pixelated;margin-bottom:16px;filter:drop-shadow(0 0 12px rgba(234,179,8,.4))}
.decision-sect{padding:60px 24px 100px;overflow:hidden}
.decision__inner{max-width:100%;margin:0 auto;display:grid;grid-template-columns:1fr;text-align:center;gap:48px;align-items:center}
.decision__text{}
.decision__text h2{font-size:clamp(22px,3.5vw,34px);font-weight:700;line-height:1.2;margin-bottom:16px}
.decision__text h2 em{font-style:normal;color:var(--amber)}
.decision__text p{font-size:14px;color:var(--dim);line-height:1.8;margin-bottom:12px}
.decision__text .navcom-q{font-family:var(--mono);font-size:12px;color:var(--green);border-left:2px solid var(--green);padding-left:12px;margin-top:20px;opacity:.7}
.decision__panel{background:linear-gradient(180deg,#000842 0%,#000630 40%,#000420 100%);border:none;border-radius:0;padding:0;position:relative;overflow:hidden;transform:none;box-shadow:none}
.decision__panel::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,100,255,.03) 2px,rgba(0,100,255,.03) 3px);pointer-events:none;z-index:1}
.decision__panel::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(0,120,255,.08) 0%,transparent 70%);pointer-events:none;animation:panelPulseBlue 3s ease-in-out infinite}
@keyframes panelPulseBlue{0%,100%{opacity:.6}50%{opacity:1}}
/* Panel titlebar */
.dp__titlebar{background:linear-gradient(90deg,#000a30,#001050,#000a30);border-bottom:1px solid rgba(0,120,255,.3);padding:10px 20px;display:flex;align-items:center;justify-content:space-between;position:relative}
.dp__titlebar::after{content:'';position:absolute;bottom:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(0,120,255,.3),transparent)}
.dp__titlebar-label{font-family:var(--pixel);font-size:7px;color:rgba(0,180,255,.7);letter-spacing:3px}
.dp__titlebar-status{font-family:var(--mono);font-size:9px;color:rgba(0,180,255,.8);animation:lbk 2.3s ease-in-out infinite}
/* Panel body */
/* Monitor frame overlay */
.monitor-wrap{position:relative;aspect-ratio:400/155;width:90vw;max-width:1400px;margin:0 auto}
.monitor-frame{position:absolute;inset:0;width:100%;height:100%;z-index:3;pointer-events:none;image-rendering:pixelated;object-fit:fill;opacity:.5}
.decision__panel{position:absolute;top:16%;bottom:10%;left:23.5%;right:23.5%;z-index:2;display:flex;flex-direction:column}
.dp__titlebar{background:linear-gradient(90deg,#000a30,#001050,#000a30);border-bottom:1px solid rgba(0,120,255,.3);padding:6px 14px;display:flex;align-items:center;justify-content:space-between;position:relative;flex-shrink:0}
.dp__body{padding:4px 20px 12px;position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center}
/* Transfer file list */
.tf__list{font-family:var(--mono);font-size:10px;color:rgba(0,180,255,.8);line-height:2;margin-bottom:8px;text-align:left;padding:0 8px}
.tf__line{display:flex;justify-content:space-between;align-items:center;gap:8px;border-bottom:1px solid rgba(0,120,255,.06)}
.tf__file{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tf__size{color:rgba(0,180,255,.4);font-size:9px;flex-shrink:0}
.tf__progress{margin:8px 0;padding:0 8px}
.tf__progress-label{font-family:var(--pixel);font-size:7px;color:rgba(0,180,255,.5);letter-spacing:2px;margin-bottom:4px;display:flex;justify-content:space-between}
.tf__progress-bar{height:6px;background:rgba(0,80,180,.15);border:1px solid rgba(0,120,255,.2);overflow:hidden;image-rendering:pixelated}
.tf__progress-fill{height:100%;background:linear-gradient(90deg,#0044cc,#0088ff,#0044cc);background-size:200% 100%;animation:tfFill 8s linear infinite,tfShimmer 1.5s linear infinite;width:0%}
@keyframes tfFill{0%{width:0%}15%{width:23%}30%{width:24%}32%{width:45%}50%{width:46%}65%{width:72%}70%{width:72%}85%{width:89%}90%{width:89%}95%{width:97%}100%{width:97%}}
@keyframes tfShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.tf__status{font-family:var(--mono);font-size:9px;color:rgba(0,180,255,.5);text-align:center;margin-top:4px;letter-spacing:1px}
.tf__status span{color:var(--amber);animation:lbk 2s ease-in-out infinite}
.tf__status{margin-bottom:12px}
/* Pixel blocks decoration */
.tf__blocks{display:flex;gap:2px;justify-content:center;margin:6px 0}
.tf__block{width:6px;height:6px;background:rgba(0,120,255,.3);animation:tfBlock 2s ease-in-out infinite}
.tf__block:nth-child(2){animation-delay:.15s}
.tf__block:nth-child(3){animation-delay:.3s}
.tf__block:nth-child(4){animation-delay:.45s}
.tf__block:nth-child(5){animation-delay:.6s}
.tf__block:nth-child(6){animation-delay:.75s}
.tf__block:nth-child(7){animation-delay:.9s}
.tf__block:nth-child(8){animation-delay:1.05s}
@keyframes tfBlock{0%,100%{opacity:.2}50%{opacity:1;background:rgba(0,180,255,.7)}}
@keyframes barPulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes lbk{0%,20%,50%,80%,100%{opacity:.15}10%,60%{opacity:1}}
/* Buttons */
.dp__btns{display:flex;gap:16px}
.dp__btn{flex:1;font-family:var(--pixel);font-size:10px;padding:10px 12px;border:none;border-radius:6px;cursor:pointer;letter-spacing:1px;transition:all .3s;position:relative;overflow:hidden}
.dp__btn::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .3s}
.dp__btn--insert{background:rgba(0,229,255,.06);border:2px solid rgba(0,229,255,.3);color:var(--cyan);animation:fkbtn 3.5s ease-in-out infinite;box-shadow:0 0 20px rgba(0,229,255,.08),inset 0 0 20px rgba(0,229,255,.03)}
.dp__btn--insert::before{background:radial-gradient(ellipse at center,rgba(0,229,255,.15),transparent 70%)}
.dp__btn--insert:hover{border-color:rgba(0,229,255,.6);box-shadow:0 0 30px rgba(0,229,255,.2),inset 0 0 30px rgba(0,229,255,.06);transform:scale(1.03)}
.dp__btn--insert:hover::before{opacity:1}
.dp__btn--eject{background:rgba(239,68,68,.04);border:2px solid rgba(239,68,68,.2);color:rgba(239,68,68,.6);box-shadow:inset 0 0 20px rgba(239,68,68,.02)}
.dp__btn--eject::before{background:radial-gradient(ellipse at center,rgba(239,68,68,.12),transparent 70%)}
.dp__btn--eject:hover{border-color:rgba(239,68,68,.5);box-shadow:0 0 25px rgba(239,68,68,.15),inset 0 0 25px rgba(239,68,68,.05);color:rgba(239,68,68,.9);transform:scale(1.03)}
.dp__btn--eject:hover::before{opacity:1}
@keyframes fkbtn{0%,100%{opacity:1}50%{opacity:.55}52%{opacity:1}}
.dp__btn-sub{display:block;font-family:var(--mono);font-size:10px;margin-top:10px;opacity:.45;letter-spacing:0;line-height:1.5}

/* ═══════════════════════════════
   ARSENAL — Recovered Inventory
   ═══════════════════════════════ */
.arsenal-sect{padding:80px 24px 100px}
.arsenal__inner{max-width:var(--container);margin:0 auto}
.arsenal__header{text-align:center;margin-bottom:56px}
.arsenal__header h2{font-size:clamp(24px,4vw,38px);font-weight:700;margin-bottom:8px}
.arsenal__header p{font-size:14px;color:var(--dim)}
.arsenal__header .evidence{font-family:var(--pixel);font-size:7px;color:var(--amber);letter-spacing:2px;margin-bottom:8px;opacity:.5}

/* Fleet row */
.a-row{margin-bottom:56px;opacity:0;transform:translateY(40px)}
.a-row__label{font-family:var(--pixel);font-size:9px;color:var(--cyan);letter-spacing:1.5px;margin-bottom:20px;text-align:center}
.fleet-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.fleet-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:20px 16px;text-align:center;transition:all .3s;position:relative;overflow:hidden}
.fleet-card:hover{border-color:var(--cyan);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.fleet-card svg,.fleet-card img{width:100%;height:48px;margin-bottom:12px;object-fit:contain;image-rendering:pixelated}
.fleet-card__name{font-family:var(--pixel);font-size:8px;margin-bottom:6px;letter-spacing:.5px}
.fleet-card__desc{font-size:11px;color:var(--dim);line-height:1.5;margin-bottom:10px}
.fleet-card__status{font-family:var(--mono);font-size:9px;font-weight:700;padding:3px 10px;border-radius:3px;display:inline-block;letter-spacing:.05em}
.fs-intact{color:var(--green);border:1px solid rgba(34,197,94,.3);background:rgba(34,197,94,.06)}
.fs-destroyed{color:var(--red);border:1px solid rgba(239,68,68,.3);background:rgba(239,68,68,.06)}
.fs-missing{color:var(--purple);border:1px solid rgba(168,85,247,.3);background:rgba(168,85,247,.06)}
.fs-damaged{color:var(--amber);border:1px solid rgba(234,179,8,.3);background:rgba(234,179,8,.06)}
.fleet-card--destroyed{opacity:.45}
.fleet-card--missing{opacity:.2}
.fleet-card--damaged{opacity:.65}

/* Weapons row */
.wpn-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:stretch}
.wpn-grid .wpn-card{display:flex;flex-direction:column;justify-content:center;height:160px}
.wpn-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:24px 20px;text-align:center;transition:all .3s;width:160px;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.wpn-card:hover{border-color:var(--cyan)}
.wpn-card svg,.wpn-card img{width:80px;height:80px;margin:0 auto 12px;display:block;object-fit:contain;image-rendering:pixelated}
.wpn-card__name{font-family:var(--pixel);font-size:9px;color:var(--dim);margin-bottom:6px;letter-spacing:.5px}
.wpn-card__ammo{font-family:var(--mono);font-size:13px;font-weight:700}
.ammo-ok{color:var(--dim)}
.ammo-low{color:var(--amber)}
.ammo-empty{color:var(--red);opacity:.5}
.wpn-card--empty{opacity:.35}
.wpn-card--empty img{opacity:.4;filter:grayscale(1)}
.wpn-card__status{font-family:var(--pixel);font-size:7px;letter-spacing:1px;margin-top:4px}
.wpn-card__status--ok{color:var(--green)}
.wpn-card__status--off{color:var(--red);opacity:.7}

.arsenal__navcom{text-align:center;font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:32px;font-style:italic;opacity:.5}
.arsenal__cta{text-align:center;margin-top:28px}

/* ═══════════════════════════════
   BLACKBOX — Trailer
   ═══════════════════════════════ */
.bb-sect{padding:80px 24px 24px;text-align:center}
.bb-sect__label{font-family:var(--pixel);font-size:8px;color:var(--amber);letter-spacing:2px;margin-bottom:24px;opacity:.6}
.bb-sect__title{font-size:clamp(22px,3.5vw,34px);font-weight:700;margin-bottom:40px}
.blackbox{width:100%;max-width:700px;aspect-ratio:16/9;margin:0 auto;background:linear-gradient(160deg,#1a1008,#100a04);border:4px solid var(--orange);border-radius:8px;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .5s;overflow:hidden;box-shadow:0 0 40px rgba(249,115,22,.08)}
.blackbox:hover{box-shadow:0 0 40px rgba(249,115,22,.3),0 0 80px rgba(249,115,22,.15);border-color:var(--amber);transform:scale(1.02)}
.blackbox__stencil{position:absolute;top:14px;left:18px;font-family:var(--pixel);font-size:7px;color:var(--orange);opacity:.4;letter-spacing:1px}
.blackbox__serial{position:absolute;bottom:14px;right:18px;font-family:var(--mono);font-size:9px;color:var(--orange);opacity:.25}
.blackbox__play{width:56px;height:56px;border:2px solid var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s}
.blackbox__play svg{width:20px;height:20px;margin-left:3px}
.blackbox__play polygon{fill:var(--orange)}
.blackbox:hover .blackbox__play{transform:scale(1.15);border-color:var(--amber);box-shadow:0 0 20px rgba(234,179,8,.3)}
.blackbox__screen{display:none;text-align:center;font-family:var(--mono);font-size:14px;color:var(--dim)}
.blackbox.open{background:var(--surface);border-color:var(--border)}
.blackbox.open .blackbox__play,.blackbox.open .blackbox__stencil,.blackbox.open .blackbox__serial{display:none}
.blackbox.open .blackbox__screen{display:flex;flex-direction:column;align-items:center;gap:8px}
.blackbox__screen .rec{color:var(--red);font-family:var(--pixel);font-size:8px;animation:blink 1s step-end infinite}
@keyframes blink{50%{opacity:0}}
.video-overlay{position:fixed;inset:0;background:rgba(120,60,0,.85);z-index:80;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s ease}
.video-overlay.active{opacity:1;pointer-events:auto}
.video-overlay__inner{width:85vw;max-width:1100px;aspect-ratio:16/9;position:relative}
.video-overlay__inner video,.video-overlay__inner iframe{width:100%;height:100%;border:4px solid var(--orange);border-radius:8px;background:#000}
.video-overlay__close{position:absolute;top:-40px;right:0;font-family:var(--pixel);font-size:14px;color:#fff;cursor:pointer;opacity:.7;transition:opacity .2s}
.video-overlay__close:hover{opacity:1}

/* ═══════════════════════════════
   TRANSMISSIONS
   ═══════════════════════════════ */
.tx-sect{padding:0 24px 100px}
.tx-inner{max-width:700px;margin:0 auto;border:1px solid rgba(0,140,255,.2);border-radius:6px;padding:0 20px;background:linear-gradient(180deg,rgba(0,60,140,.06) 0%,rgba(0,20,60,.03) 100%);box-shadow:0 0 30px rgba(0,120,255,.04),inset 0 1px 0 rgba(0,180,255,.08)}
.tx-inner__title{font-family:var(--mono);font-size:clamp(11px,1.5vw,13px);color:rgba(0,160,255,.7);letter-spacing:.08em;text-align:center;padding:16px 20px 12px;border-bottom:1px solid rgba(0,140,255,.12);margin:0 -20px;background:linear-gradient(180deg,rgba(0,80,180,.08) 0%,transparent 100%)}
.tx-header{font-family:var(--pixel);font-size:8px;color:var(--dim);letter-spacing:1.5px;margin-bottom:36px}
.tx-entry{padding:0;margin:0 -20px;border-bottom:1px solid rgba(0,229,255,.15);opacity:0;transform:translateY(20px)}
.tx-entry:last-of-type{border-bottom:none}
.tx-head{display:grid;grid-template-columns:80px 1fr;gap:16px;align-items:start;padding:20px 20px 12px}
.tx-thumb{width:80px;height:80px;border-radius:4px;overflow:hidden;border:1px solid var(--border);flex-shrink:0}
.tx-thumb img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated;filter:saturate(.7) brightness(.85);transition:filter .3s}
.tx-entry:hover .tx-thumb img{filter:saturate(1) brightness(1)}
.tx-meta{display:flex;align-items:center;gap:0;margin-bottom:6px}
.tx-date{font-family:var(--pixel);font-size:7px;color:var(--cyan);letter-spacing:1.5px;opacity:.6;white-space:nowrap}
.tx-meta__sep{font-family:var(--pixel);font-size:7px;color:var(--cyan);opacity:.6;margin:0 6px}
.tx-version{font-family:var(--pixel);font-size:7px;color:var(--cyan);letter-spacing:1.5px;opacity:.6}
.tx-body{}
.tx-title{font-size:15px;font-weight:700;margin-bottom:4px}
.tx-intro{font-size:12px;color:rgba(255,255,255,.8);line-height:1.7;font-family:var(--mono)}
.tx-sections{padding:0 20px 20px;display:flex;flex-direction:column;gap:12px}
.tx-section{border:1px solid rgba(0,229,255,.1);border-radius:4px;padding:12px 14px;background:rgba(0,229,255,.02)}
.tx-section__head{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.tx-section__icon{font-size:13px;width:20px;text-align:center;flex-shrink:0}
.tx-section__label{font-family:var(--pixel);font-size:7px;color:var(--cyan);letter-spacing:1.5px;text-transform:uppercase}
.tx-section:hover{border-color:rgba(0,229,255,.3);background:rgba(0,229,255,.05);transition:border-color .2s,background .2s}
.tx--urgent .tx-section:hover{border-color:rgba(245,158,11,.3);background:rgba(245,158,11,.06)}
.tx--cut .tx-section:hover{border-color:rgba(239,68,68,.2);background:rgba(239,68,68,.05)}
.tx-section__arrow{margin-left:auto;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;opacity:.4;transition:transform .25s ease}
.tx-section.open .tx-section__arrow{transform:rotate(180deg)}
.tx-section__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;max-height:0;overflow:hidden;transition:max-height .3s ease,margin .3s ease}
.tx-section.open .tx-section__list{margin-top:8px}
.tx-section__list li{font-size:12px;color:rgba(255,255,255,.8);font-family:var(--mono);line-height:1.6;padding-left:14px;position:relative}
.tx-section__list li::before{content:'›';position:absolute;left:0;color:var(--cyan);opacity:.5}
.tx--urgent .tx-title{color:var(--amber)}
.tx--urgent .tx-section{border-color:rgba(245,158,11,.15);background:rgba(245,158,11,.03)}
.tx--urgent .tx-section__label{color:var(--amber)}
.tx--urgent .tx-section__list li::before{color:var(--amber)}
.tx--cut .tx-title{color:var(--red)}
.tx--cut .tx-intro{color:rgba(239,68,68,.5)}
.tx--cut .tx-section{border-color:rgba(239,68,68,.1);background:rgba(239,68,68,.02)}
.tx--cut .tx-section__label{color:var(--red)}
.tx--cut .tx-section__list li{color:rgba(239,68,68,.5)}
.tx--cut .tx-section__list li::before{color:var(--red)}
.glch{animation:gc 2.5s ease-in-out infinite}
@keyframes gc{0%,80%,100%{opacity:1}85%{opacity:.2}92%{opacity:.7}}
/* TX expand button */
.tx-expand{margin:0 -20px;border-top:1px solid rgba(0,229,255,.15)}
.tx-expand__btn{font-family:var(--mono);font-size:11px;padding:14px 20px;background:rgba(0,229,255,.04);border:none;color:var(--cyan);cursor:pointer;transition:all .3s;letter-spacing:.5px;width:100%;text-align:center;border-radius:0 0 4px 4px;text-decoration:none;display:block;box-sizing:border-box}
.tx-expand__btn:hover{background:rgba(0,229,255,.08);border-color:rgba(0,229,255,.4);box-shadow:0 0 12px rgba(0,229,255,.15)}

/* ═══════════════════════════════
   FOOTER — Signal Returns
   ═══════════════════════════════ */
/* CTA Final */
.cta-final{background:#0000a8;padding:80px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;min-height:50vh;position:relative;z-index:5;overflow:hidden;font-family:var(--pixel)}
.cta-final__header{font-family:var(--pixel);font-size:clamp(14px,2vw,18px);color:#0000a8;background:#a8a8a8;padding:4px 12px;letter-spacing:2px;opacity:0}
.cta-final__text{font-family:var(--pixel);font-size:clamp(13px,1.8vw,16px);font-weight:400;color:#fff;line-height:2;max-width:600px;margin:0 auto;opacity:0;letter-spacing:.5px}
.cta-final__btn{opacity:0}
.cta-final__btn .btn-primary{font-family:var(--pixel);background:#a8a8a8;color:#0000a8;box-shadow:var(--bevel-out);border:none;border-radius:0;font-size:14px;letter-spacing:1px;padding:12px 40px}
.cta-final__btn .btn-primary:hover{background:#c0c0c0;box-shadow:var(--bevel-out)}
/* BSOD Glitch */
.cta-final__glitch-line{position:absolute;left:0;right:0;height:3px;background:rgba(255,255,255,.25);pointer-events:none;opacity:0}
.cta-final__glitch-line:nth-child(1){top:15%}
.cta-final__glitch-line:nth-child(2){top:35%}
.cta-final__glitch-line:nth-child(3){top:60%}
.cta-final__glitch-line:nth-child(4){top:82%}
.cta-final__glitch-text{position:absolute;font-family:var(--pixel);font-size:12px;color:rgba(255,255,255,.35);pointer-events:none;opacity:0;white-space:nowrap;letter-spacing:1px;text-shadow:0 0 8px rgba(255,255,255,.3)}
.cta-final__glitch-text:nth-of-type(1){top:12%;left:5%}
.cta-final__glitch-text:nth-of-type(2){top:28%;right:8%;left:auto}
.cta-final__glitch-text:nth-of-type(3){top:55%;left:10%}
.cta-final__glitch-text:nth-of-type(4){top:72%;right:5%;left:auto}
.cta-final__glitch-text:nth-of-type(5){top:88%;left:15%}
@keyframes bsodGlitch{0%,100%{transform:translate(0,0)}20%{transform:translate(-3px,0)}40%{transform:translate(2px,-1px)}60%{transform:translate(-1px,2px)}80%{transform:translate(3px,-1px)}}
@keyframes bsodFlicker{0%,100%{opacity:0}5%{opacity:1}8%{opacity:0}50%{opacity:0}52%{opacity:.7}55%{opacity:0}}
.footer-logo-wrap{position:relative;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}
.footer__logo{width:140px;height:auto;image-rendering:pixelated;opacity:0;filter:drop-shadow(0 0 12px rgba(0,229,255,.3));z-index:2}
.footer__logo.show{animation:logoIn .8s cubic-bezier(.2,.8,.3,1) forwards}
.footer__explosion{position:absolute;width:200px;height:200px;background:url('assets/img/effects/explotion.webp') 0 0/700% 100%;image-rendering:pixelated;pointer-events:none;opacity:0;z-index:3}
.footer__explosion.play{opacity:1;animation:explode .6s steps(6) forwards}
.footer-sect{padding:120px 24px 100px;text-align:center;position:relative;overflow:hidden}
.footer-sect__sub{position:absolute;bottom:-120px;left:-40px;width:450px;height:auto;image-rendering:pixelated;z-index:4;opacity:0;filter:drop-shadow(0 0 16px rgba(0,229,255,.3));transform:translateX(-100%)}
.footer-sect__sub.floating{animation:subFloat 3s ease-in-out infinite}
@keyframes subFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.footer-sect__siren{position:absolute;bottom:-120px;right:-20px;width:320px;height:320px;z-index:4;opacity:0;image-rendering:pixelated;filter:drop-shadow(0 0 16px rgba(168,85,247,.4));transform:translateX(100%)}
.footer-sect__algas{position:absolute;bottom:-40px;left:0;right:0;z-index:5;pointer-events:none;display:flex;justify-content:space-around;align-items:flex-end;padding:0 20px}
.footer-sect__algas img{width:80px;height:auto;image-rendering:pixelated;opacity:1;flex-shrink:0}
.footer-sect__algas img:nth-child(even){transform:scaleX(-1)}
.footer-sect__algas img:nth-child(1){width:85px}
.footer-sect__algas img:nth-child(2){width:70px}
.footer-sect__algas img:nth-child(3){width:95px}
.footer-sect__algas img:nth-child(4){width:75px}
.footer-sect__algas img:nth-child(5){width:100px}
.footer-sect__algas img:nth-child(6){width:70px}
.footer-sect__algas img:nth-child(7){width:90px}
.footer-sect__algas img:nth-child(8){width:75px}
.footer-sect__algas img:nth-child(9){width:100px}
.footer-sect__algas img:nth-child(10){width:80px}
.footer-sect__algas img:nth-child(11){width:70px}
.footer-sect__algas img:nth-child(12){width:95px}
.footer-sect__algas .alga-coral{margin-bottom:30px}
.footer-sect__algas .alga-coral:nth-of-type(1){width:90px}
.footer-sect__algas .alga-coral:nth-of-type(2){width:75px}
.footer-sect__algas .alga-coral:nth-of-type(3){width:100px}
.footer-sect__siren img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated}
.footer-sect__bg{position:absolute;inset:0;background:url('assets/img/background/fondo2.webp') center bottom/cover no-repeat;opacity:.4;z-index:1;pointer-events:none}
.footer-sect__bg::after{content:'';position:absolute;inset:0;background:#083344;mix-blend-mode:multiply}
.footer-sect__fade{position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(180deg,var(--bg) 0%,transparent 100%);z-index:2;pointer-events:none}
.footer-sect>*:not(.footer-sect__bg):not(.footer-sect__fade):not(.footer-sect__sub):not(.footer-sect__siren):not(.footer-sect__algas){position:relative;z-index:3}
.sr__dot{width:4px;height:4px;background:var(--cyan);margin:0 auto 36px;box-shadow:0 0 12px var(--cyan);animation:pdot 2.5s ease-in-out infinite}
.sr__line{font-size:18px;color:var(--text);margin-bottom:10px;opacity:0;line-height:1.6}
.sr__q{font-size:clamp(22px,3.5vw,32px);font-weight:700;color:var(--cyan);margin:28px 0;opacity:0}
.sr__cta{opacity:0;margin-bottom:20px;display:inline-block}
.sr__navcom{font-family:var(--mono);font-size:12px;color:var(--dim);opacity:0;margin-top:12px}
.footer-bottom{max-width:var(--container);margin:60px auto 0;padding:20px 0;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.f-links{display:flex;gap:20px}
.f-links a{font-family:var(--mono);font-size:11px;color:var(--dim);text-decoration:none;transition:color .2s}
.f-links a:hover{color:var(--cyan)}
.f-surface{font-family:var(--pixel);font-size:8px;color:var(--cyan);background:none;border:1px solid rgba(0,229,255,.25);padding:6px 14px;cursor:pointer;transition:all .3s;letter-spacing:.5px}
.f-surface:hover{background:rgba(0,229,255,.06)}

/* ═══ Status Bar ═══ */
.footer-bar{position:fixed;bottom:0;left:0;right:0;z-index:50;font-family:var(--mono);font-size:12px}
.footer-bar__nav{background:rgba(6,10,16,.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:8px 16px;display:flex;justify-content:space-between;align-items:center;position:relative}
.footer-bar__credit{font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.8);position:absolute;left:50%;transform:translateX(-50%);white-space:nowrap}
.footer-bar__credit a{color:rgba(255,255,255,.8);text-decoration:none;transition:color .2s}
.footer-bar__credit a:hover{color:var(--cyan)}
.footer-bar__links{display:flex;gap:16px}
.footer-bar__links a{font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.8);text-decoration:none;transition:color .2s}
.footer-bar__links a:hover{color:var(--cyan)}
.footer-bar__surface-row{display:none;background:rgba(6,10,16,.97);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.15);padding:8px 12px;justify-content:center;align-items:center}
.footer-bar__surface{font-family:var(--mono);font-size:12px;color:rgba(255,255,255,.8);text-decoration:none;background:none;border:none;cursor:pointer;transition:color .2s;padding:0}
.footer-bar__surface:hover{color:var(--cyan)}
.statusbar{background:rgba(6,10,16,.95);backdrop-filter:blur(8px);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;padding:6px 16px}
.sb__left{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.8);font-family:var(--mono);font-size:12px}
.sb__dot{width:4px;height:4px;background:var(--red);animation:lbk 2s ease-in-out infinite}
.sb__right{color:rgba(255,255,255,.4);letter-spacing:.05em;font-family:var(--mono);font-size:12px}

/* Fragment tag */
.frag-tag{font-family:var(--mono);font-size:clamp(12px,1.8vw,15px);color:var(--amber);letter-spacing:.02em;margin-bottom:20px;opacity:.6;min-height:1.4em;line-height:1.8;white-space:pre-wrap}
#frag1{margin-bottom:80px}
#frag-salvage{margin-bottom:0}
#frag3{margin-bottom:30px}
#frag-footer{margin-bottom:60px}

/* Win98 room modals */
.room-modals{position:absolute;inset:0;z-index:20;pointer-events:none}
.room-modal{pointer-events:auto;position:absolute;background:#c0c0c0;border:2px solid;border-color:#fff #808080 #808080 #fff;box-shadow:2px 2px 0 #000;width:clamp(170px,20vw,220px);opacity:0;transform:scale(0);z-index:10;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .3s ease,box-shadow .3s ease}
.room-modal:hover,.room-modal.glow{box-shadow:0 0 20px rgba(234,179,8,.6),0 0 40px rgba(234,179,8,.2),2px 2px 0 #000}
.room-modal--4{width:clamp(200px,24vw,260px);box-shadow:0 0 18px rgba(220,38,38,.6),0 0 40px rgba(220,38,38,.25),2px 2px 0 #000}
.room-modal--4.show{animation:oxygenPulse 2s ease-in-out infinite}
.room-modal--4 .room-modal__titlebar{background:#dc2626}
.room-modal--4:hover,.room-modal--4.glow{box-shadow:0 0 30px rgba(220,38,38,.8),0 0 60px rgba(220,38,38,.4),2px 2px 0 #000}
@keyframes oxygenPulse{0%,100%{box-shadow:0 0 18px rgba(220,38,38,.6),0 0 40px rgba(220,38,38,.25),2px 2px 0 #000}50%{box-shadow:0 0 28px rgba(220,38,38,.8),0 0 60px rgba(220,38,38,.4),2px 2px 0 #000}}
.room-modal.show{opacity:1;transform:scale(1)}
.room-modal.hiding{opacity:0!important;transform:scale(0)!important;transition:transform .2s ease-in,opacity .2s ease-in;animation:none!important}
.room-modal--4:not(.show):not(.hiding){opacity:0;transform:scale(0)}
.room-modal__titlebar{background:#0000a8;padding:3px 6px;display:flex;align-items:center;justify-content:space-between}
.room-modal__titlebar span{color:#fff;font-family:var(--mono);font-size:10px;font-weight:700;white-space:nowrap}
.room-modal__close{background:#c0c0c0;border:2px solid;border-color:#fff #808080 #808080 #fff;width:20px;height:20px;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;cursor:pointer;color:#000;padding:0}
.room-modal__close:active{border-color:#808080 #fff #fff #808080}
.room-modal__icon{width:auto;height:48px;image-rendering:pixelated;margin:0 auto 6px;display:block;object-fit:contain}
.room-modal__body{padding:10px;font-family:var(--mono);font-size:10px;color:#000;line-height:1.5;text-align:center}
.room-modal__status{font-weight:700;margin-bottom:4px}
.room-modal__status--online{color:#16a34a}
.room-modal__status--damaged{color:#d97706}
.room-modal__status--offline{color:#808080}
.room-modal__status--critical{color:#dc2626}
.room-modal__status--destroyed{color:#dc2626}
/* Modal positions — arc around submarine, inside scene */
/* Modales cerca de su cuadro (coords relativas al sub) */
.room-modal--1{top:0%;left:52%}      /* PUENTE — bridge 55%,38% */
.room-modal--2{top:14%;left:85%}    /* MOTOR — engine 87%,54% */
.room-modal--3{top:34%;left:-5%}    /* HOSPITAL — hospital 23%,54% */
.room-modal--4{top:78%;left:58%;z-index:12}    /* OXIGENO — encima de shield */
.room-modal--5{top:5%;left:5%}      /* RADAR — sin cuadro */
.room-modal--6{top:98%;left:45%}    /* ESCUDO — debajo de oxygen */
.room-modal--7{top:8%;left:30%}     /* ARMA — weapons 44.2%,38% */

/* Battle scene — sub + shark */
.battle-scene{position:relative;width:90%;max-width:1100px;margin:0 auto 48px;overflow-y:visible;display:flex;align-items:center;justify-content:center}
.battle-scene__sub{display:block;width:100%;max-width:1000px;image-rendering:pixelated;position:relative;z-index:2;animation:subFloatBattle 4s ease-in-out infinite}
@keyframes subFloatBattle{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.battle-scene__shark{position:absolute;right:-40%;top:50%;transform:translateY(-50%) scaleX(-1);width:45%;max-width:420px;height:auto;aspect-ratio:1/1;image-rendering:pixelated;z-index:30;opacity:0;pointer-events:none;
  background:url('assets/img/creatures/shark_attack_final_assets.webp') 0 0/400% 100%;
  animation:sharkAtk .6s steps(4) infinite}
@keyframes sharkAtk{from{background-position:0 0}to{background-position:-400% 0}}
.battle-scene__explosion{position:absolute;width:clamp(120px,22vw,220px);height:clamp(120px,22vw,220px);background:url('assets/img/effects/explotion.webp') 0 0/700% 100%;image-rendering:pixelated;pointer-events:none;opacity:0;z-index:25;transform:translateY(-50%)}
.battle-scene__explosion--1{right:35%;top:40%}
.battle-scene__explosion--2{right:25%;top:65%;animation-delay:.3s}
.battle-scene__explosion.play{opacity:1;animation:explode .6s steps(6) infinite}
/* Room damage/flood overlays on submarine */
.sub-wrap{position:relative;display:inline-block;z-index:2;animation:subFloatBattle 4s ease-in-out infinite}
.sub-wrap .battle-scene__sub{animation:none}
.sub-rooms{position:absolute;top:0;left:0;width:100%;height:100%;z-index:19;pointer-events:none}
.sub-room{pointer-events:auto}
.sub-room{position:absolute;border:2px solid transparent;overflow:hidden;border-radius:2px;aspect-ratio:1/1;opacity:0;transition:opacity .5s ease,border-color .3s ease,box-shadow .3s ease;cursor:pointer}
.sub-room:hover{border-color:var(--amber);border-width:3px}
.sub-room--oxygen{border-color:rgba(220,38,38,.8);border-width:3px;box-shadow:0 0 18px rgba(220,38,38,.6),0 0 40px rgba(220,38,38,.25)}
.sub-room--oxygen:hover{border-color:var(--amber);box-shadow:0 0 18px rgba(234,179,8,.5)}
.sub-room__damage{position:absolute;top:0;left:0;right:0;height:0;background:rgba(220,38,38,.35);transition:height 1.5s ease}
.sub-room__flood{position:absolute;bottom:0;left:0;right:0;height:0;background:rgba(56,189,248,.3);transition:height 1.5s ease .3s}
/* 5 rooms mapped to sub-destroid layout — adjust positions here */
/* Weapons inside sub */
.sub-weapon{position:absolute;width:10%;image-rendering:pixelated;pointer-events:none;z-index:5;opacity:0;filter:drop-shadow(0 0 8px rgba(0,229,255,.5));transition:opacity .8s ease,z-index 0s}
.sub-weapon.flying{z-index:35;filter:drop-shadow(0 0 16px rgba(0,229,255,.8))}
.sub-weapon.visible{opacity:.9}
.sub-weapon--harpoon{left:35%;top:80%}
.sub-weapon--emp{left:72%;top:78%}

.sub-room--bridge{left:55%;top:38%;width:11%}
.sub-room--engine{left:87%;top:54%;width:11%}
.sub-room--hospital{left:23%;top:54%;width:11%}
.sub-room--weapons{left:44.2%;top:38%;width:11%}
.sub-room--oxygen{left:65.7%;top:54%;width:11%}

/* Sub damage explosions — scattered on submarine, play once */
.sub-explosion{position:absolute;background:url('assets/img/effects/explotion.webp') 0 0/700% 100%;image-rendering:pixelated;pointer-events:none;opacity:0;z-index:25}
.sub-explosion.play{opacity:1;animation:explode .6s steps(6) infinite}
.sub-explosion--1{width:100px;height:100px;left:30%;top:30%}
.sub-explosion--2{width:140px;height:140px;left:50%;top:25%;animation-delay:.2s}
.sub-explosion--3{width:80px;height:80px;left:65%;top:55%;animation-delay:.5s}
.sub-explosion--4{width:120px;height:120px;left:35%;top:60%;animation-delay:.35s}

/* Blackbox video */
.blackbox__video{width:100%;height:100%;object-fit:cover;border-radius:4px;display:none}
.blackbox.open{padding:0}

/* Decision reveal (inline in reporte) */
.decision-reveal{display:none}

/* ── Win98 Decision Modal ── */
.w98-overlay{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .3s ease}
.w98-overlay.active{opacity:1;pointer-events:auto}
.w98-modal{background:#c0c0c0;border:2px solid;border-color:#fff #808080 #808080 #fff;box-shadow:4px 4px 0 #000;min-width:340px;max-width:420px;position:absolute;transform:scale(.8);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.w98-overlay.active .w98-modal{transform:scale(1)}
.w98-modal__titlebar{background:#0000a8;padding:3px 6px;display:flex;align-items:center;justify-content:space-between;cursor:default}
.w98-modal__titlebar--red{background:#dc2626}
.w98-modal__titlebar span{color:#fff;font-family:var(--mono);font-size:11px;font-weight:700}
.w98-modal__close{background:#c0c0c0;border:2px solid;border-color:#fff #808080 #808080 #fff;width:20px;height:20px;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#000;padding:0;line-height:1}
.w98-modal__close:active{border-color:#808080 #fff #fff #808080}
.w98-modal__body{padding:16px 20px;font-family:var(--mono);font-size:12px;color:#000;line-height:1.6;display:flex;gap:14px;align-items:flex-start}
.w98-modal__icon-warn{font-size:32px;flex-shrink:0;line-height:1}
/* NAVCOM Toast */
.navcom-toast{position:fixed;bottom:82px;left:24px;z-index:85;background:#0a0e14;border:1px solid rgba(0,229,255,.25);border-radius:8px;padding:10px 14px 10px 12px;max-width:380px;display:flex;gap:10px;align-items:flex-start;box-shadow:0 0 24px rgba(0,229,255,.12),0 8px 32px rgba(0,0,0,.5);transform:translateX(-120%);opacity:0;transition:transform .5s cubic-bezier(.34,1.56,.64,1),opacity .4s ease}
.navcom-toast.show{transform:translateX(0);opacity:1}
.navcom-toast__badge{flex-shrink:0;width:36px;height:36px;border-radius:6px;overflow:hidden;box-shadow:0 0 8px rgba(0,229,255,.15)}
.navcom-toast__badge img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated}
.navcom-toast__content{flex:1;min-width:0}
.navcom-toast__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.navcom-toast__label{font-family:var(--pixel);font-size:10px;color:#59f850;letter-spacing:2px;text-shadow:0 0 6px rgba(89,248,80,.3)}
.navcom-toast__text{font-family:var(--mono);font-size:12px;color:var(--cyan);line-height:1.6;opacity:.9}
.navcom-toast__cursor{display:inline-block;width:6px;height:11px;background:var(--cyan);margin-left:2px;vertical-align:text-bottom;animation:lbk 1s step-end infinite}
.navcom-toast__close{background:rgba(0,229,255,.06);border:1px solid rgba(0,229,255,.2);border-radius:4px;color:var(--cyan);font-family:var(--mono);font-size:12px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.6;transition:all .2s;padding:0;line-height:1}
.navcom-toast__close:hover{opacity:1;background:rgba(0,229,255,.12);border-color:rgba(0,229,255,.4);box-shadow:0 0 8px rgba(0,229,255,.2)}
.w98-modal__btns{padding:6px 20px 16px;display:flex;gap:10px;justify-content:center}
.w98-modal__btn{font-family:var(--mono);font-size:11px;padding:4px 20px;background:#c0c0c0;border:2px solid;border-color:#fff #808080 #808080 #fff;cursor:pointer;color:#000;min-width:80px}
.w98-modal__btn:active{border-color:#808080 #fff #fff #808080}
.w98-modal__btn--primary{font-weight:700;outline:1px dotted #000;outline-offset:-4px}
/* Cascade offset for stacked modals */
.w98-modal--cascade-1{top:calc(50% - 120px);left:calc(50% - 170px)}
.w98-modal--cascade-2{top:calc(50% - 90px);left:calc(50% - 140px)}
.w98-modal--cascade-3{top:calc(50% - 60px);left:calc(50% - 110px)}
/* Screen shake */
@keyframes screenShake{0%{transform:translate(0)}10%{transform:translate(-6px,3px)}20%{transform:translate(5px,-4px)}30%{transform:translate(-4px,5px)}40%{transform:translate(4px,-2px)}50%{transform:translate(-3px,4px)}60%{transform:translate(3px,-3px)}70%{transform:translate(-2px,2px)}80%{transform:translate(2px,-1px)}90%{transform:translate(-1px,1px)}100%{transform:translate(0)}}
.screen-shake{animation:screenShake .5s ease-out}
/* Screen flash */
.screen-flash{position:fixed;inset:0;z-index:70;pointer-events:none;opacity:0}
.screen-flash.flash-red{background:rgba(220,38,38,.15);animation:flashFade .4s ease-out forwards}
.screen-flash.flash-cyan{background:rgba(0,229,255,.12);animation:flashFade .4s ease-out forwards}
@keyframes flashFade{0%{opacity:1}100%{opacity:0}}

/* ═══ Responsive ═══ */

/* ── 1280px — small laptops / short screens ── */
@media(max-width:1280px){
  .intro__logo{width:clamp(200px,30vw,320px)}
  .intro__scroll{margin-top:-8px}
  .intro__cd-spacer{height:180px;margin-bottom:32px}
  #intro-typewriter{font-size:13px}
  .topbar__btn--discord,.topbar__btn--lang,.topbar__btn--sound{font-size:9px;padding:6px 12px;min-height:32px;height:32px;line-height:1;box-sizing:border-box}
  .steam-cta{font-size:10px;padding:14px 18px;height:auto}
  .console__text{font-size:15px}
  .console__btn{font-size:15px}
  .bottom-bar{bottom:70px;gap:6px}
  .achievement__icon{width:38px;height:38px}
  .navcom-toast{bottom:70px}
  .frag-tag{font-size:13px}
  .dp__btn-sub{margin-top:4px}
}

/* ── 1240px — hide decision subtexts ── */
@media(max-width:1240px){
  .dp__btn-sub{display:none}
  .tf__line:nth-child(2){display:none}
}

/* ── 1200px — large tablets / small laptops ── */
@media(max-width:1200px){
  .console__cd-space{width:360px;height:360px}
  .solo-cd{width:180px;height:180px}
  .solo-cd-glow{width:260px;height:260px}
  .footer-sect__sub{width:350px}
  .footer-sect__siren{width:260px;height:260px}
  .sub-part{transform:scale(1.15)}
}

/* ── 1018px — hide transfer blocks ── */
@media(max-width:1018px){
  .tf__blocks{display:none}
  .dp__titlebar-status{display:none}
}

/* ── 1024px — tablets ── */
@media(max-width:1024px){
  .topbar .steam-logo{width:52px;height:52px}
  .intro{justify-content:flex-start;padding-top:220px}
  .intro__logo{width:clamp(180px,28vw,280px)}
  .console-sect{padding:48px 24px 40px;justify-content:flex-start}
  .console__inner{grid-template-columns:1fr;gap:24px;max-width:none;padding-left:clamp(16px,3vw,32px)}
  .console__right{justify-content:center;margin-right:-30%}
  .console__cd-space{width:100px;height:100px}
  .solo-cd{width:150px;height:150px}
  .solo-cd-glow{width:220px;height:220px}
  .console__text{font-size:16px}
  .hero__grid{grid-template-columns:1fr;gap:32px}
  .decision__inner{grid-template-columns:1fr;gap:24px}
  .ftl-hull{grid-template-columns:repeat(4,1fr)}
  .fleet-grid{grid-template-columns:repeat(2,1fr)}
  .sub-section{padding:40px 24px 80px}
  .bb-sect{padding:60px 24px 24px}
  .footer-sect{padding:80px 24px 80px}
  .cta-final{padding:60px 24px 100px}
  .battle-scene__shark{right:-30%;width:40%}
  .footer-sect__sub{width:300px;bottom:-80px}
  .footer-sect__siren{width:220px;height:220px;bottom:-80px}
  .footer-sect__algas img{width:60px}
  .footer-sect__algas img:nth-child(1){width:65px}
  .footer-sect__algas img:nth-child(3){width:75px}
  .footer-sect__algas img:nth-child(5){width:80px}
  .footer-sect__algas img:nth-child(7){width:70px}
  .footer-sect__algas img:nth-child(9){width:80px}
  .footer-sect__algas .alga-coral{margin-bottom:20px}
  #intro-typewriter{font-size:12px}
  .intro__scroll{font-size:11px}
  .frag-tag{font-size:12px}
  .sub-section__label{font-size:11px}
  #frag1{margin-bottom:20px}
  .battle-scene{transform:scale(.8);transform-origin:center center}
  .salvage-intro{margin-top:120px}
  .wpn-card{width:144px;min-height:144px;padding:20px 16px}
  .wpn-grid .wpn-card{height:144px}
  .wpn-card svg,.wpn-card img{width:70px;height:70px}
  .wpn-card__name{font-size:8px}
  .wpn-card__ammo{font-size:12px}
  .wpn-card__status{font-size:6px}
  .sub-part{transform:scale(.9)}
  .fish{width:130px;height:130px}
  .fish-1{width:145px;height:145px}
  .fish-2{width:120px;height:120px}
  .fish-3{width:160px;height:160px}
  .fish-4{width:112px;height:112px}
  .monitor-wrap{transform:scale(1.15);transform-origin:center center}
  .tf__line:nth-child(2),.tf__line:nth-child(3){display:none}
  .dp__btn-sub{display:none}
  .dp__btn{font-size:9px}
  .evidence-flicker{width:144px;height:144px}
  #decision-img{width:144px;height:144px}
  #record-img{width:144px;height:144px}
  .cta-final__header{font-size:clamp(11px,1.6vw,14px)}
  .cta-final__text{font-size:clamp(10px,1.4vw,13px)}
  .cta-final__btn .btn-primary{font-size:11px}
}

/* ── 830px — r-fleet card split fix ── */
@media(max-width:830px){
  .intro__logo{width:clamp(220px,35vw,320px)}
  .a-row{margin-bottom:10px}
  .tf__line:nth-child(1){display:none}
  #frag1{margin-bottom:20px}
}

/* ── 768px — small tablets / large phones landscape ── */
@media(max-width:768px){
  .topbar{padding:12px}
  .intro{justify-content:center;padding-top:0}
  .intro__logo{width:clamp(200px,35vw,300px)}
  .console__right{margin-right:-50%}
  #frag1{margin-bottom:40px}
  #decision-img{width:170px;height:170px}
  .monitor-wrap{transform:scale(1.3);transform-origin:center center}
  .tf__line:nth-child(1),.tf__line:nth-child(5){display:none}
  .decision__text{margin-bottom:32px}
  .intro__cd-spacer{height:260px;margin-bottom:40px}
  .console__cd-space{width:240px;height:240px}
  .solo-cd{width:120px;height:120px}
  .solo-cd-glow{width:180px;height:180px}
  .console__text{font-size:14px}
  .console__btn{font-size:15px}
  .ftl-hull{grid-template-columns:repeat(4,1fr);gap:2px;padding:2px}
  .ftl-room{padding:10px 6px;min-height:90px;gap:4px}
  .ftl-room svg{width:24px;height:24px}
  .ftl-room__name{font-size:6px}
  .ftl-room__status{font-size:8px}
  .fleet-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .fleet-card{padding:14px 12px}
  .wpn-card{width:130px;min-height:130px;padding:16px 14px}
  .wpn-card svg,.wpn-card img{width:60px;height:60px}
  .battle-scene__shark{right:-25%;width:45%}
  .room-modal{width:clamp(140px,22vw,180px)}
  .room-modal__body{padding:8px;font-size:9px}
  .room-modal__icon{height:36px}
  .room-modal__titlebar span{font-size:8px}
  .room-modal--4{width:clamp(160px,26vw,210px)}
  .w98-modal{min-width:280px;max-width:90vw}
  .w98-modal__body{padding:12px 14px;font-size:11px}
  .monitor-wrap{transform:scale(1.45);transform-origin:center center}
  .dp__btn{font-size:6px;padding:8px 8px}
  .dp__btn-sub{font-size:8px;margin-top:6px}
  .dp__titlebar-label{font-size:6px;letter-spacing:2px}
  .dp__titlebar-status{font-size:8px}
  .tf__list{font-size:9px;line-height:1.8}
  .tf__progress-label{font-size:6px}
  .tf__status{font-size:8px}
  .sub-section{padding:48px 16px 60px}
  .bb-sect{padding:48px 16px 16px}
  .footer-sect{padding:60px 16px 60px}
  .cta-final{padding:48px 16px 100px;min-height:40vh}
  .cta-final__header{font-size:clamp(12px,2vw,16px)}
  .cta-final__text{font-size:clamp(11px,1.6vw,14px);max-width:90%}
  .footer-sect__sub{width:240px;bottom:-60px;left:-20px}
  .footer-sect__siren{width:180px;height:180px;bottom:-60px;right:-10px}
  .navcom-toast{max-width:320px;left:16px;bottom:98px}
  .bottom-bar{bottom:98px;right:12px;gap:8px}
  .topbar__right{gap:6px}
  .achievement__icon{width:40px;height:40px}
  .steam-cta{font-size:10px;padding:0 16px;height:48px}
  .footer-bar__nav{padding:8px 12px 8px;flex-wrap:wrap;gap:0;align-items:center;justify-content:space-between}
  .footer-bar__links{gap:12px}
  .footer-bar__links a{font-size:11px}
  .footer-bar__credit{position:static;transform:none;font-size:11px}
  .footer-bar__surface-row{display:flex}
  .footer-bar__surface--nav{display:none}
  .footer-bar__links{gap:12px}
  .footer-bar__links a{font-size:11px}
  .footer-bar__surface{font-size:11px}
  .statusbar{padding:4px 12px}
  .sb__left{font-size:11px}
  .sb__right{font-size:11px}
  .tx-inner{padding:0 14px}
  .tx-head{grid-template-columns:60px 1fr;gap:12px;padding:16px 14px 10px}
  .tx-thumb{width:60px;height:60px}
  .tx-sections{padding:0 14px 16px;gap:10px}
  .tx-section{padding:10px 12px}
  .intro__cd-spacer{height:160px;margin-bottom:24px}
  .evidence-flicker{width:140px;height:140px}
}

/* ── 620px ── */
@media(max-width:620px){
  .tf__status{margin-bottom:6px}
}

/* ── 560px — phones portrait ── */
@media(max-width:560px){
  .topbar__btn--discord{padding:6px 12px;font-size:9px}
  .topbar__btn--lang,.topbar__btn--sound{padding:6px 8px;min-height:32px}
  .topbar .steam-logo{width:48px;height:48px}
  .console__cd-space{width:200px;height:200px}
  .solo-cd{width:100px;height:100px}
  .solo-cd-glow{width:150px;height:150px}
  .console__text{font-size:13px;line-height:1.7}
  .console__btn{font-size:14px}
  .ftl-hull{grid-template-columns:repeat(3,1fr)}
  .ftl-room{padding:8px 4px;min-height:80px}
  .fleet-grid{grid-template-columns:1fr}
  .fleet-card{padding:16px 14px}
  .wpn-grid{gap:10px}
  .wpn-card{width:120px;min-height:120px;padding:14px 10px}
  .wpn-card svg,.wpn-card img{width:50px;height:50px;margin-bottom:8px}
  .dp__btns{gap:10px}
  .dp__btn{padding:6px 6px}
  .dp__body{padding:4px 10px 8px}
  .tf__list{padding:0 4px;font-size:8px;line-height:1.6}
  .tf__size{font-size:8px}
  .tf__progress{padding:0 4px}
  .battle-scene__sub{width:100%}
  .battle-scene__shark{right:-20%;width:50%}
  .room-modal{width:clamp(120px,30vw,160px)}
  .room-modal__body{padding:6px;font-size:8px}
  .room-modal__icon{height:28px;margin-bottom:4px}
  .room-modal__titlebar{padding:2px 4px}
  .room-modal__titlebar span{font-size:7px}
  .room-modal__close{width:16px;height:16px;font-size:14px}
  .room-modal--4{width:clamp(140px,34vw,180px)}
  .w98-modal{min-width:auto;width:90vw;max-width:340px}
  .sub-section{padding:0 12px 48px}
  .sub-section__label{margin-bottom:12px}
  #frag1{margin-bottom:10px}
  .bb-sect{padding:40px 12px 12px}
  .room-modal--1,.room-modal--5,.room-modal--7{display:none}
  .wpn-card{width:100px;min-height:100px;padding:10px 8px}
  .wpn-card svg,.wpn-card img{width:40px;height:40px;margin-bottom:6px}
  .salvage-section{margin-top:40px}
  .a-row{margin-bottom:10px}
  #r-fleet{gap:0;max-height:200px}
  .intro__logo{width:clamp(220px,45vw,320px)}
  #decision-img{width:120px;height:120px}
  #record-img{width:120px;height:120px}
  .footer-sect{padding:48px 12px 48px}
  .cta-final{padding:40px 12px;gap:16px}
  .cta-final__text{max-width:95%;line-height:1.8}
  .footer-sect__sub{width:180px;bottom:-40px;left:-10px}
  .footer-sect__siren{width:140px;height:140px;bottom:-40px;right:0}
  .footer-sect__algas img{width:40px}
  .footer-sect__algas img:nth-child(1){width:45px}
  .footer-sect__algas img:nth-child(3){width:50px}
  .footer-sect__algas img:nth-child(5){width:55px}
  .footer-sect__algas img:nth-child(7){width:45px}
  .footer-sect__algas img:nth-child(9){width:55px}
  .footer-sect__algas .alga-coral{margin-bottom:15px}
  .footer-sect__algas .alga-coral:nth-of-type(1){width:50px}
  .footer-sect__algas .alga-coral:nth-of-type(2){width:45px}
  .footer-sect__algas .alga-coral:nth-of-type(3){width:55px}
  .navcom-toast{max-width:calc(100vw - 32px);left:16px;right:16px;bottom:150px}
  .navcom-toast__text{font-size:11px}
  .bottom-bar{bottom:92px;right:8px;gap:6px}
  .achievement__icon{width:36px;height:36px}
  .achievement__tooltip{display:none}
  .steam-cta{font-size:9px;padding:0 14px;height:44px}
  .blackbox{border-width:3px}
  .blackbox__stencil{font-size:6px;top:8px;left:10px}
  .blackbox__serial{font-size:8px;bottom:8px;right:10px}
  .blackbox__play{width:44px;height:44px}
  .blackbox__play svg{width:16px;height:16px}
  .tx-inner{padding:0 10px}
  .tx-inner__title{font-size:10px;padding:12px 10px 10px;margin:0 -10px}
  .tx-head{grid-template-columns:48px 1fr;gap:10px;padding:12px 10px 8px}
  .tx-thumb{width:48px;height:48px}
  .tx-title{font-size:13px}
  .tx-intro{font-size:11px}
  .tx-sections{padding:0 10px 14px;gap:8px}
  .tx-section{padding:8px 10px}
  .tx-section__label{font-size:6px}
  .tx-section__list li{font-size:11px}
  .tx-expand__btn{font-size:10px;padding:12px 10px}
  .intro__cd-spacer{height:120px;margin-bottom:16px}
  .evidence-flicker{width:120px;height:120px}
  .frag-tag{font-size:clamp(11px,1.6vw,13px)}
  .monitor-wrap{width:95vw}
  .video-overlay__inner{width:95vw}
  .video-overlay__close{font-size:12px;top:-32px}
  .footer-bar__links{gap:8px;flex-wrap:wrap}
  .footer-bar__links a{font-size:10px}
  .footer-bar__links a:nth-child(3){display:none}
  .footer-bar__surface{font-size:10px}
}

/* ── 490px ── */
@media(max-width:490px){
  .dp__body{display:block}
  .tf__progress-label{font-size:5px}
  .dp__titlebar-label{font-size:5px;letter-spacing:1px}
  .tf__status{font-size:7px}
  .sub-part{transform:scale(.75)}
  .sp-2,.sp-18,.sp-13{display:none}
  .sp-19{left:3%}
  .bottom-bar{bottom:94px}
  .fish{width:110px;height:110px}
  .fish-1{width:125px;height:125px}
  .fish-2{width:105px;height:105px}
  .fish-3{width:140px;height:140px}
  .fish-4{width:98px;height:98px}
  .wpn-grid .wpn-card{height:120px}
  .decision__inner{margin-top:190px}
  .bb-sect{padding:90px 12px 12px}
  .tx-sect{padding:0 12px 100px}
  .footer-sect{padding:48px 12px 108px}
  .cta-final{min-height:80vh;justify-content:flex-start;padding:100px 12px}
  .cta-final__text{line-height:2}
}

/* ── 400px — small phones ── */
@media(max-width:400px){
  .sp-8{display:none}
  .topbar{padding:10px clamp(8px,2vw,16px)}
  .topbar .steam-logo{width:40px;height:40px}
  .topbar__btn--discord{padding:5px 10px;font-size:8px}
  .topbar__btn--lang,.topbar__btn--sound{padding:5px 6px;min-height:28px;font-size:9px}
  .topbar__right{gap:4px}
  .console__cd-space{width:160px;height:160px}
  .solo-cd{width:80px;height:80px}
  .solo-cd-glow{width:120px;height:120px}
  .console-sect{padding:32px 12px 40px}
  .console__text{font-size:12px;line-height:1.6}
  .console__btn{font-size:13px}
  .ftl-hull{grid-template-columns:repeat(3,1fr);gap:1px;padding:1px}
  .ftl-room{padding:6px 3px;min-height:70px;gap:2px}
  .ftl-room svg{width:20px;height:20px}
  .ftl-room__name{font-size:5px}
  .ftl-room__status{font-size:7px}
  .wpn-card{width:100px;min-height:100px;padding:10px 8px}
  .wpn-card svg,.wpn-card img{width:40px;height:40px;margin-bottom:6px}
  .wpn-card__name{font-size:7px}
  .wpn-card__ammo{font-size:11px}
  .wpn-card__status{font-size:6px}
  .battle-scene__shark{right:-15%;width:55%}
  .room-modal{width:clamp(100px,32vw,130px)}
  .room-modal__body{padding:4px;font-size:7px}
  .room-modal__icon{height:22px;margin-bottom:2px}
  .room-modal__titlebar span{font-size:6px}
  .room-modal--4{width:clamp(110px,36vw,150px)}
  .sub-section{padding:32px 8px 40px}
  .bb-sect{padding:32px 8px 8px}
  .footer-sect{padding:40px 8px 40px}
  .cta-final{padding:100px 12px;gap:12px;min-height:80vh;justify-content:flex-start}
  .cta-final__text{line-height:2}
  .cta-final__btn .btn-primary{font-size:12px;padding:10px 28px}
  .footer-sect__sub{width:140px;bottom:-30px}
  .footer-sect__siren{width:110px;height:110px;bottom:-30px}
  .footer-sect__algas img{width:30px}
  .footer-sect__algas img:nth-child(odd){width:35px}
  .footer-sect__algas .alga-coral{margin-bottom:10px;width:40px}
  .steam-cta{font-size:8px;padding:0 10px;height:40px}
  .achievement__icon{width:32px;height:32px}
  .bottom-bar{bottom:54px;right:6px;gap:4px}
  .navcom-toast{font-size:11px;padding:8px 10px 8px 10px}
  .navcom-toast__badge{width:28px;height:28px}
  .navcom-toast__text{font-size:11px}
  .navcom-toast__label{font-size:8px}
  .intro__cd-spacer{height:100px;margin-bottom:12px}
  .evidence-flicker{width:100px;height:100px}
  .intro__logo{margin-bottom:24px}
  .dp__btns{gap:6px}
  .dp__btn{font-size:7px;padding:8px 6px}
  .dp__btn-sub{font-size:7px;margin-top:4px}
  .dp__titlebar{padding:3px 8px}
  .dp__titlebar-label{font-size:5px;letter-spacing:1px}
  .dp__titlebar-status{font-size:7px}
  .dp__body{padding:2px 6px 6px}
  .tf__list{font-size:7px;line-height:1.5;padding:0 2px}
  .tf__size{font-size:7px}
  .tf__progress{margin:4px 0;padding:0 2px}
  .tf__progress-label{font-size:5px}
  .tf__progress-bar{height:4px}
  .tf__status{font-size:7px}
  .tf__blocks{gap:1px}
  .tf__block{width:4px;height:4px}
  .tx-head{grid-template-columns:40px 1fr;gap:8px;padding:10px 8px 6px}
  .tx-thumb{width:40px;height:40px}
  .tx-title{font-size:12px}
  .tx-intro{font-size:10px}
  .tx-sections{padding:0 8px 12px}
  .tx-section__list li{font-size:10px}
  .frag-tag{font-size:11px}
}

/* ── 370px ── */
@media(max-width:370px){
  .dp__btn{font-size:5px;padding:4px 4px}
  .bottom-bar{bottom:94px}
  .sub-part{transform:scale(.6)}
  .intro__logo{width:clamp(180px,45vw,250px)}
  .fish{width:95px;height:95px}
  .fish-1{width:108px;height:108px}
  .fish-2{width:90px;height:90px}
  .fish-3{width:120px;height:120px}
  .fish-4{width:84px;height:84px}
  .topbar__right{gap:8px}
  .intro__scroll::after{height:8px}
  .bb-sect{padding:100px 8px 8px}
  .footer-sect{padding:40px 8px 90px}
  .cta-final{padding:100px 12px;gap:12px;min-height:80vh;justify-content:flex-start}
  .cta-final__text{line-height:2}
}

/* ── 330px ── */
@media(max-width:330px){
  .tf__status[data-i18n-html="tf_operator"]{display:none}
  .cta-final{padding:100px 12px;gap:12px;min-height:80vh;justify-content:flex-start}
  .cta-final__text{line-height:2}
}

/* ── Reduced motion — only when user has enabled "reduce motion" in device settings ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .loader{transition:none}
  .fish,.caustic-ray,.sub-part,.battle-weapon,.p,.evidence-flicker,.footer-sect__sub,.solo-cd{animation:none!important;opacity:1;transform:none}
  .caustic-ray{opacity:.4}
  .sub-part{opacity:.6}
  .fish{display:none}
}
