/* THE HARVESTER v6 — style.css */
:root{
  --cr:#E8DCC8;--cg:rgba(232,220,200,.44);
  --sl:#8A9BB0;--sg:rgba(138,155,176,.4);
  --sa:#8FAF8F;--sag:rgba(143,175,143,.46);
  --gr:#5A9E6F;--gg:rgba(90,158,111,.52);
  --ow:#D8D4CC;
  --da:#C07060;--dg:rgba(192,112,96,.5);
  --wa:#C4A55A;--wg:rgba(196,165,90,.45);
  --pu:#9B8FD0;--pg:rgba(155,143,208,.45);
  --bg:#090C05;--bg2:#0D1009;
  --pn:rgba(9,12,5,.9);--gl:rgba(232,220,200,.04);
  --b1:rgba(232,220,200,.11);--b2:rgba(232,220,200,.22);--b3:rgba(232,220,200,.44);
  --tx:#D8D4CC;--td:rgba(216,212,204,.42);
  --fh:'Orbitron',monospace;--fm:'Share Tech Mono',monospace;--fd:'Cormorant Garamond',serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--tx);font-family:var(--fm);-webkit-font-smoothing:antialiased;touch-action:none;user-select:none;-webkit-user-select:none}

/* TEXTURES */
.intro-grain,.app-grain{position:absolute;inset:0;z-index:50;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:140px;opacity:.025;mix-blend-mode:overlay}
.intro-vignette,.app-vignette{position:absolute;inset:0;z-index:6;pointer-events:none;background:radial-gradient(ellipse at center,transparent 40%,rgba(0,0,0,.88) 100%)}
.intro-scanlines{position:absolute;inset:0;z-index:7;pointer-events:none;background:repeating-linear-gradient(to bottom,transparent 0,transparent 3px,rgba(0,0,0,.06) 3px,rgba(0,0,0,.06) 4px);animation:scan 16s linear infinite}
@keyframes scan{from{background-position:0 0}to{background-position:0 400px}}
.intro-orb{position:absolute;border-radius:50%;pointer-events:none;z-index:2;filter:blur(90px);animation:orb 20s ease-in-out infinite}
.o1{width:520px;height:520px;background:rgba(90,158,111,.07);top:-18%;left:-12%;animation-duration:22s}
.o2{width:380px;height:380px;background:rgba(138,155,176,.06);bottom:-12%;right:-10%;animation-duration:28s;animation-delay:-9s}
.o3{width:280px;height:280px;background:rgba(232,220,200,.04);top:28%;right:18%;animation-duration:16s;animation-delay:-5s}
@keyframes orb{0%,100%{transform:translate(0,0)scale(1)}33%{transform:translate(28px,-22px)scale(1.07)}66%{transform:translate(-18px,28px)scale(.94)}}

/* INTRO */
.intro-screen{position:fixed;inset:0;z-index:300;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden;transition:opacity 1.1s cubic-bezier(.4,0,.2,1)}
.intro-screen.fade-out{opacity:0;pointer-events:none}
#introCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.intro-phase{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:10;opacity:0;pointer-events:none;transition:opacity .7s ease}
.intro-phase.active{opacity:1;pointer-events:all}

/* BOOT */
.boot-box{width:min(680px,90vw);padding:26px 30px;background:rgba(9,12,5,.78);border:1px solid var(--b2);border-radius:3px;backdrop-filter:blur(20px);box-shadow:0 0 80px rgba(90,158,111,.07)}
.boot-hdr{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.boot-hline{flex:1;height:1px;background:var(--b2)}
.boot-hdr span{font-family:var(--fm);font-size:9px;letter-spacing:.26em;color:var(--sa);white-space:nowrap}
.boot-lines{display:flex;flex-direction:column;gap:8px;min-height:190px}
.boot-line{font-family:var(--fm);font-size:12px;color:var(--td);display:flex;gap:12px;align-items:baseline;opacity:0;transform:translateX(-10px);transition:opacity .3s,transform .3s}
.boot-line.visible{opacity:1;transform:none}
.boot-line .bl-p{color:var(--sa);opacity:.55;flex-shrink:0}
.boot-line .bl-ok{margin-left:auto;color:var(--gr);font-size:10px;flex-shrink:0}
.boot-line .bl-w{margin-left:auto;color:var(--wa);font-size:10px;flex-shrink:0}
.boot-line .bl-e{margin-left:auto;color:var(--da);font-size:10px;flex-shrink:0}
.boot-cur{font-family:var(--fm);font-size:14px;color:var(--sa);margin-top:10px;animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* CINEMATIC */
.intro-cin{flex-direction:column;align-items:center;justify-content:center;gap:0;padding:20px}
.cin-topbar{position:absolute;top:0;left:0;right:0;height:32px;display:flex;align-items:center;justify-content:center;gap:16px;background:rgba(9,12,5,.65);border-bottom:1px solid var(--b1);backdrop-filter:blur(8px);opacity:0;transform:translateY(-100%);transition:opacity .6s ease .1s,transform .6s ease .1s}
.intro-phase.active .cin-topbar{opacity:1;transform:none}
.cin-tag{font-family:var(--fm);font-size:8px;letter-spacing:.24em;color:var(--td)}
.cin-dot{color:var(--sa);font-size:7px;opacity:.44}

.cin-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:28px;opacity:0;transform:scale(.93);transition:opacity .9s ease .3s,transform .9s cubic-bezier(.2,1,.4,1) .3s}
.intro-phase.active .cin-logo{opacity:1;transform:none}
.cin-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.cin-el{width:52px;height:1px;background:linear-gradient(90deg,transparent,var(--sl));transform:scaleX(0);transform-origin:right;transition:transform .8s ease .9s}
.cin-el-r{background:linear-gradient(270deg,transparent,var(--sl));transform-origin:left}
.intro-phase.active .cin-el{transform:scaleX(1)}
.cin-eyebrow span{font-family:var(--fm);font-size:9px;letter-spacing:.38em;color:var(--sl);white-space:nowrap}
.cin-title-row{display:flex;align-items:center;gap:22px}
.cin-bv{width:1px;height:84px;background:linear-gradient(to bottom,transparent,var(--b3),transparent);opacity:0;transform:scaleY(0);transition:opacity .6s ease .7s,transform .6s ease .7s}
.cin-bv-r{transform-origin:bottom}
.intro-phase.active .cin-bv{opacity:1;transform:none}
.cin-title-center{text-align:center}
.cin-the{font-family:var(--fd);font-size:clamp(11px,2vw,17px);font-weight:300;letter-spacing:.7em;color:var(--sl);margin-bottom:1px;opacity:0;transform:translateY(6px);transition:opacity .7s ease .5s,transform .7s ease .5s}
.intro-phase.active .cin-the{opacity:1;transform:none}
.cin-name{font-family:var(--fh);font-size:clamp(30px,7vw,78px);font-weight:900;letter-spacing:.2em;color:var(--cr);text-shadow:0 0 40px var(--cg),0 0 90px rgba(232,220,200,.1),0 0 2px rgba(255,255,255,.55);white-space:nowrap;animation:titlehalo 6s ease-in-out infinite 1.5s}
@keyframes titlehalo{0%,100%{text-shadow:0 0 40px var(--cg),0 0 90px rgba(232,220,200,.1),0 0 2px rgba(255,255,255,.55)}50%{text-shadow:0 0 65px var(--cg),0 0 140px rgba(232,220,200,.18),0 0 4px rgba(255,255,255,.8)}}
.cin-rule{width:100%;height:1px;margin:8px 0;background:linear-gradient(90deg,transparent,var(--b3),transparent);transform:scaleX(0);transition:transform .8s ease .8s}
.intro-phase.active .cin-rule{transform:none}
.cin-subt{font-family:var(--fm);font-size:clamp(7px,1vw,10px);letter-spacing:.44em;color:var(--td);opacity:0;transition:opacity .8s ease 1s}
.intro-phase.active .cin-subt{opacity:1}

.cin-cards{display:flex;align-items:stretch;width:min(700px,92vw);background:rgba(9,12,5,.72);border:1px solid var(--b2);border-radius:3px;backdrop-filter:blur(16px);overflow:hidden;margin-bottom:11px;opacity:0;transform:translateY(14px);transition:opacity .7s ease 1.2s,transform .7s ease 1.2s}
.intro-phase.active .cin-cards{opacity:1;transform:none}
.cin-card{flex:1;display:flex;align-items:center;gap:10px;padding:13px 14px}
.cin-danger{background:rgba(192,112,96,.06)}
.cin-csep{width:1px;background:var(--b1);flex-shrink:0}
.cin-cdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;animation:dp 1.4s ease-in-out infinite}
.cdanger{background:var(--da);box-shadow:0 0 10px var(--da)}.cwarn{background:var(--wa);box-shadow:0 0 10px var(--wa)}.cgreen{background:var(--gr);box-shadow:0 0 10px var(--gr)}.cslate{background:var(--sl);box-shadow:0 0 10px var(--sl)}
@keyframes dp{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.65)}}
.cin-clbl{font-family:var(--fm);font-size:7px;letter-spacing:.22em;color:var(--td);margin-bottom:3px}
.cin-cval{font-family:var(--fh);font-size:clamp(9px,1.4vw,12px);font-weight:600;letter-spacing:.1em;color:var(--cr)}

.cin-sub{font-family:var(--fm);font-size:10px;letter-spacing:.12em;color:var(--td);margin-bottom:20px;opacity:0;transition:opacity .7s ease 1.7s}
.intro-phase.active .cin-sub{opacity:1}
.cin-streams{display:flex;gap:18px;margin-bottom:26px;opacity:0;transition:opacity .7s ease 1.9s}
.intro-phase.active .cin-streams{opacity:1}
.cin-stream{font-family:var(--fm);font-size:8px;color:var(--td);opacity:.44;display:flex;flex-direction:column;gap:3px;width:130px;max-height:44px;overflow:hidden}

.cin-skip{display:flex;align-items:center;gap:12px;opacity:0;transition:opacity .6s ease 2.4s;animation:skp 2.5s ease-in-out infinite 2.6s}
.intro-phase.active .cin-skip{opacity:1}
@keyframes skp{0%,100%{opacity:1}50%{opacity:.25}}
.cin-sb{width:34px;height:1px;background:var(--b2)}
.cin-skip span{font-family:var(--fm);font-size:9px;letter-spacing:.26em;color:var(--td);white-space:nowrap}

.cin-c{position:absolute;width:26px;height:26px;z-index:15}
.ctl{top:16px;left:16px}.ctr{top:16px;right:16px}.cbl{bottom:16px;left:16px}.cbr{bottom:16px;right:16px}
.cch,.ccv{position:absolute;background:var(--b3);opacity:0;transition:opacity .6s ease .4s,transform .6s ease .4s}
.cch{width:100%;height:1px;top:0;transform:scaleX(0);transform-origin:left}
.ccv{width:1px;height:100%;left:0;transform:scaleY(0);transform-origin:top}
.ctr .cch{transform-origin:right}.ctr .ccv{left:auto;right:0}
.cbl .cch{top:auto;bottom:0}.cbl .ccv{transform-origin:bottom}
.cbr .cch{top:auto;bottom:0;transform-origin:right}.cbr .ccv{left:auto;right:0;transform-origin:bottom}
.intro-phase.active .cch{opacity:1;transform:scaleX(1)}
.intro-phase.active .ccv{opacity:1;transform:scaleY(1)}

/* MAIN APP */
.main-app{position:fixed;inset:0;z-index:10;opacity:0;pointer-events:none;transition:opacity 1.1s ease}
.main-app.visible{opacity:1;pointer-events:all}
.app-wrap{position:relative;z-index:10;width:100vw;height:100vh;display:grid;grid-template-rows:50px 1fr 80px}

/* TOPBAR */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--pn);border-bottom:1px solid var(--b1);backdrop-filter:blur(16px)}
.tb-l{display:flex;align-items:center;gap:9px;flex:1;min-width:0}
.tb-c{flex:2;text-align:center}
.tb-r{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:10px}
.tb-mark{font-size:15px;color:var(--sa);filter:drop-shadow(0 0 6px var(--gr));animation:mp 3s ease-in-out infinite}
@keyframes mp{0%,100%{opacity:1;filter:drop-shadow(0 0 6px var(--gr))}50%{opacity:.5;filter:drop-shadow(0 0 2px var(--gr))}}
.tb-id{font-family:var(--fm);font-size:10px;letter-spacing:.13em;color:var(--td);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-hl{display:flex;align-items:center;gap:11px}
.tb-hlr{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--b2))}
.tb-headline{font-family:var(--fh);font-size:12px;font-weight:700;letter-spacing:.34em;color:var(--cr);white-space:nowrap;text-shadow:0 0 14px var(--cg);animation:hf 11s ease-in-out infinite}
@keyframes hf{0%,90%,100%{opacity:1}91%{opacity:.48}92%{opacity:1}94%{opacity:.32}95%{opacity:1}}
.live-badge{display:flex;align-items:center;gap:5px;padding:3px 8px;border:1px solid rgba(90,158,111,.28);border-radius:2px;background:rgba(90,158,111,.05);flex-shrink:0}
.live-dot{width:5px;height:5px;border-radius:50%;background:var(--gr);box-shadow:0 0 8px var(--gr);animation:dp 1.2s ease-in-out infinite}
#liveCount{font-family:var(--fh);font-size:11px;color:var(--sa);min-width:20px;text-align:right}
.live-lbl{font-family:var(--fm);font-size:8px;letter-spacing:.17em;color:var(--td)}
.rt-cpu{display:flex;align-items:center;gap:5px;flex-shrink:0}
.rt-lbl{font-family:var(--fm);font-size:7px;letter-spacing:.13em;color:var(--td)}
.rt-bar{width:40px;height:3px;background:rgba(143,175,143,.1);border-radius:2px;overflow:hidden;border:1px solid rgba(143,175,143,.18)}
.rt-fill{height:100%;background:linear-gradient(90deg,var(--gr),var(--sa));border-radius:2px;transition:width .8s ease}
.rt-pct{font-family:var(--fm);font-size:7px;color:var(--sa);min-width:22px}
.sp{display:flex;align-items:center;gap:5px;flex-shrink:0}
.sp-dot{width:6px;height:6px;border-radius:50%;background:var(--wa);box-shadow:0 0 7px var(--wa);animation:dp 1.6s ease-in-out infinite}
.sp-txt{font-family:var(--fm);font-size:9px;letter-spacing:.1em;color:var(--wa)}
.tb-clock{font-family:var(--fh);font-size:11px;color:var(--cr);letter-spacing:.1em;flex-shrink:0}

/* GAME AREA */
.game-area{position:relative;overflow:hidden;background:var(--bg)}
#gameCanvas{display:block;width:100%;height:100%}
.gc{position:absolute;width:20px;height:20px;border-color:var(--b3);border-style:solid;pointer-events:none;z-index:20}
.gc-tl{top:10px;left:10px;border-width:1px 0 0 1px}
.gc-tr{top:10px;right:10px;border-width:1px 1px 0 0}
.gc-bl{bottom:10px;left:10px;border-width:0 0 1px 1px}
.gc-br{bottom:10px;right:10px;border-width:0 1px 1px 0}

/* POWER BAR */
.pwrbar{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:54px;background:var(--pn);border:1px solid var(--b1);border-radius:3px;padding:10px 6px;backdrop-filter:blur(16px);z-index:30;display:flex;flex-direction:column;gap:7px;align-items:center}
.pwr-lbl{font-family:var(--fm);font-size:7px;letter-spacing:.19em;color:var(--sa);opacity:.6}
.pwr-slots{display:flex;flex-direction:column;gap:5px}
.pwr-slot{width:38px;height:38px;border:1px solid var(--b1);border-radius:3px;background:var(--gl);display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;position:relative;transition:all .2s}
.pwr-slot.active{border-color:var(--sa);background:rgba(143,175,143,.1);box-shadow:0 0 12px rgba(143,175,143,.2)}
.pwr-slot.empty{opacity:.18}
.pwr-slot .pc{position:absolute;bottom:1px;right:3px;font-family:var(--fm);font-size:7px;color:var(--cr)}
.pwr-slot .pt{position:absolute;bottom:0;left:0;height:2px;background:var(--sa);border-radius:0 0 2px 2px}
.pwr-keys{display:flex;flex-direction:column;gap:2px;width:100%}
.pwr-kr{font-family:var(--fm);font-size:6px;color:var(--td);display:flex;align-items:center;gap:3px}

/* HUD */
.hud{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:150px;background:var(--pn);border:1px solid var(--b1);border-radius:3px;padding:11px 11px;backdrop-filter:blur(20px);z-index:30;display:flex;flex-direction:column;gap:8px;box-shadow:0 0 40px rgba(90,158,111,.04)}
.hud-brand{display:flex;align-items:center;gap:7px;border-bottom:1px solid var(--b1);padding-bottom:8px}
.hud-bm{font-size:9px;color:var(--sa)}.hud-bt{font-family:var(--fm);font-size:8px;letter-spacing:.2em;color:var(--td)}
.hud-rule{height:1px;background:var(--b1)}
.hud-sec{display:flex;flex-direction:column;gap:4px}
.hud-sec.hud-row{flex-direction:row;justify-content:space-between}
.hud-lbl{font-family:var(--fm);font-size:7px;letter-spacing:.2em;color:var(--td);display:flex;align-items:center;gap:5px}
.hud-val{font-family:var(--fh);font-size:15px;font-weight:700;color:var(--cr);letter-spacing:.05em;text-shadow:0 0 10px var(--cg);transition:all .2s}
.hud-best{color:var(--sa);text-shadow:0 0 10px var(--sag);font-size:12px}
.hud-lives{display:flex;gap:5px}.pip{font-size:12px;color:var(--sa);text-shadow:0 0 8px var(--gg);transition:all .3s}.pip.lost{color:rgba(143,175,143,.1);text-shadow:none}
.hud-combo{display:flex;align-items:center;gap:7px}
.hud-cv{font-family:var(--fh);font-size:16px;font-weight:900;color:var(--wa);text-shadow:0 0 12px var(--wg);min-width:28px}
.hud-ct{flex:1;height:4px;background:rgba(196,165,90,.1);border-radius:2px;overflow:hidden;border:1px solid rgba(196,165,90,.14)}
.hud-cf{height:100%;background:linear-gradient(90deg,var(--wa),rgba(196,165,90,.5));transition:width .3s;box-shadow:0 0 5px var(--wg);width:0%}
.combo-timer-ring{font-size:6px;color:var(--wa);opacity:.7}
.hud-hull{height:5px;background:rgba(90,158,111,.1);border-radius:2px;overflow:hidden;border:1px solid rgba(90,158,111,.17)}
.hud-hf{height:100%;width:100%;background:linear-gradient(90deg,var(--gr),rgba(90,158,111,.55));border-radius:2px;transition:width .4s;box-shadow:0 0 6px var(--gg)}
.hull-pct{font-size:8px;color:var(--sa);margin-left:auto}
.hud-xp{height:3px;background:rgba(155,143,208,.1);border-radius:2px;overflow:hidden;border:1px solid rgba(155,143,208,.15)}
.hud-xf{height:100%;width:0%;background:linear-gradient(90deg,var(--pu),rgba(155,143,208,.5));border-radius:2px;transition:width .5s;box-shadow:0 0 5px var(--pg)}
.xp-lv{font-size:8px;color:var(--pu);margin-left:auto}
.skin-grid{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px}
.sk-dot{width:17px;height:17px;border-radius:3px;border:1px solid var(--b1);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:7px}
.sk-dot.locked{opacity:.2;cursor:not-allowed}
.sk-dot.active{border-color:rgba(255,255,255,.5);transform:scale(1.14);box-shadow:0 0 8px currentColor}
.skin-nm{font-family:var(--fm);font-size:8px;color:var(--sa);letter-spacing:.13em;margin-top:2px;text-align:center}
.hud-foot{display:flex;flex-direction:column;gap:3px;padding-top:4px;border-top:1px solid var(--b1)}
.hud-kr{font-family:var(--fm);font-size:7px;color:var(--td);display:flex;align-items:center;gap:4px}
kbd{font-family:var(--fm);font-size:7px;padding:1px 4px;background:rgba(232,220,200,.06);border:1px solid var(--b2);border-radius:2px;color:var(--cr)}

/* BOSS BAR */
.boss-bar{position:absolute;top:12px;left:50%;transform:translateX(-50%);width:min(460px,68vw);background:var(--pn);border:1px solid rgba(192,112,96,.34);border-radius:3px;padding:8px 14px;backdrop-filter:blur(16px);z-index:35}
.boss-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.boss-lbl{font-family:var(--fh);font-size:10px;letter-spacing:.2em;color:var(--da);text-shadow:0 0 10px var(--da)}
.boss-ph{font-family:var(--fm);font-size:8px;letter-spacing:.17em;color:var(--td)}
.boss-track{height:6px;background:rgba(192,112,96,.1);border-radius:2px;overflow:hidden;border:1px solid rgba(192,112,96,.22);position:relative}
.boss-fill{height:100%;background:linear-gradient(90deg,var(--da),#d48870);transition:width .3s;box-shadow:0 0 8px var(--da)}
.boss-segs{display:flex;gap:0;margin-top:4px}

/* STREAK PANEL */
.streak-panel{position:absolute;top:60px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:8px;background:rgba(9,12,5,.88);border:1px solid rgba(196,165,90,.4);border-radius:3px;padding:7px 16px;backdrop-filter:blur(10px);z-index:38;transition:opacity .3s}
.streak-fire{font-size:22px;animation:sf 0.5s ease-in-out infinite alternate}
@keyframes sf{from{transform:scale(1)}to{transform:scale(1.2)}}
.streak-txt{font-family:var(--fh);font-size:10px;letter-spacing:.18em;color:var(--wa)}
.streak-num{font-family:var(--fh);font-size:20px;font-weight:900;color:var(--cr);text-shadow:0 0 14px var(--cg)}

/* FLOATS */
.floats{position:absolute;left:50%;top:0;transform:translateX(-50%);pointer-events:none;z-index:40;display:flex;flex-direction:column;align-items:center;gap:4px;padding-top:44px}
.fn{font-family:var(--fh);font-size:11px;letter-spacing:.13em;padding:4px 13px;border-radius:2px;background:rgba(9,12,5,.88);border:1px solid;animation:fu 2.4s ease forwards;white-space:nowrap;backdrop-filter:blur(8px)}
.fn.tk{color:var(--sa);border-color:rgba(143,175,143,.3)}.fn.tp{color:var(--sl);border-color:rgba(138,155,176,.3)}.fn.tb{color:var(--da);border-color:rgba(192,112,96,.3)}.fn.ts{color:var(--cr);border-color:var(--b2)}.fn.tw{color:var(--wa);border-color:rgba(196,165,90,.3)}.fn.tpu{color:var(--pu);border-color:rgba(155,143,208,.3)}
@keyframes fu{0%{opacity:0;transform:translateY(16px)scale(.9)}14%{opacity:1;transform:none}80%{opacity:1}100%{opacity:0;transform:translateY(-28px)}}

/* ACHIEVEMENT */
.ach-toast{position:absolute;top:56px;right:14px;display:flex;align-items:center;gap:11px;background:rgba(9,12,5,.92);border:1px solid rgba(196,165,90,.4);border-radius:4px;padding:11px 14px;z-index:45;backdrop-filter:blur(14px);animation:atin .4s ease;box-shadow:0 0 22px rgba(196,165,90,.1)}
@keyframes atin{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}
.ach-icon{font-size:22px}
.ach-title{font-family:var(--fh);font-size:9px;letter-spacing:.17em;color:var(--wa);margin-bottom:3px}
.ach-desc{font-family:var(--fm);font-size:9px;color:var(--td)}

/* LEVEL UP */
.levelup{position:absolute;left:50%;top:35%;transform:translate(-50%,-50%);text-align:center;z-index:46;animation:luanim .5s ease forwards}
@keyframes luanim{0%{opacity:0;transform:translate(-50%,-50%)scale(.7)}50%{opacity:1;transform:translate(-50%,-60%)scale(1.1)}100%{opacity:1;transform:translate(-50%,-55%)scale(1)}}
.lu-txt{font-family:var(--fh);font-size:11px;letter-spacing:.35em;color:var(--pu);text-shadow:0 0 14px var(--pg)}
.lu-lv{font-family:var(--fh);font-size:clamp(32px,6vw,56px);font-weight:900;color:var(--cr);text-shadow:0 0 30px var(--cg),0 0 60px rgba(155,143,208,.3)}
.lu-bonus{font-family:var(--fm);font-size:11px;letter-spacing:.18em;color:var(--sa);margin-top:4px}

/* GAME OVER */
.gameover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:50}
.go-bd{position:absolute;inset:0;background:rgba(9,12,5,.94);backdrop-filter:blur(12px)}
.go-panel{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;gap:14px;align-items:center;padding:34px 42px;background:rgba(12,16,8,.75);border:1px solid var(--b2);border-radius:4px;box-shadow:0 0 60px rgba(192,112,96,.07)}
.go-ey{font-family:var(--fm);font-size:9px;letter-spacing:.28em;color:var(--da)}
.go-title{font-family:var(--fh);font-size:clamp(24px,5vw,40px);font-weight:900;letter-spacing:.12em;color:var(--da);text-shadow:0 0 28px rgba(192,112,96,.5)}
.go-rule{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--b2),transparent)}
.go-stats{display:flex;gap:0;align-items:center}
.go-s{display:flex;flex-direction:column;gap:5px;align-items:center;padding:0 16px}
.go-sv{font-family:var(--fh);font-size:18px;font-weight:700;color:var(--cr)}
.go-sl{font-family:var(--fm);font-size:7px;letter-spacing:.2em;color:var(--td)}
.go-sd{width:1px;background:var(--b1);align-self:stretch}
.go-best{color:var(--sa)}
.go-newbest{font-family:var(--fh);font-size:10px;letter-spacing:.2em;color:var(--wa);text-shadow:0 0 12px var(--wg);animation:bp 1s ease-in-out infinite}
@keyframes bp{0%,100%{opacity:1}50%{opacity:.44}}
.go-achs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;max-width:320px}
.go-ach-chip{font-family:var(--fm);font-size:9px;padding:4px 10px;border:1px solid var(--b1);border-radius:2px;color:var(--td);background:var(--gl)}
.go-btn{font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.24em;color:var(--bg);background:var(--cr);border:none;padding:12px 34px;cursor:pointer;border-radius:2px;transition:all .2s;box-shadow:0 0 22px var(--cg);margin-top:4px}
.go-btn:hover{background:#fff;box-shadow:0 0 36px rgba(255,255,255,.36);transform:scale(1.03)}

/* TOUCH */
.touch{position:absolute;bottom:6px;left:0;right:0;padding:0 12px;pointer-events:none;z-index:35;display:flex;justify-content:space-between;align-items:flex-end;gap:8px}
.t-dpad{pointer-events:all;display:flex;flex-direction:column;gap:3px}.t-row{display:flex;gap:3px;justify-content:center}
.t-btn{width:52px;height:52px;background:rgba(232,220,200,.07);border:1.5px solid rgba(232,220,200,.22);border-radius:10px;color:var(--cr);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation;transition:background .1s,transform .1s;box-shadow:0 4px 12px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.08);-webkit-tap-highlight-color:transparent}
.t-btn:active{background:rgba(232,220,200,.22);transform:scale(.91)}
.t-sp{width:52px;height:52px;pointer-events:none}
.t-ctr{width:52px;height:52px;display:flex;align-items:center;justify-content:center;color:rgba(143,175,143,.25);font-size:13px;border:1px solid rgba(143,175,143,.1);border-radius:50%;pointer-events:none}
.t-actions{pointer-events:all;display:flex;flex-direction:column;align-items:center;gap:6px}
.t-fire{width:74px;height:74px;background:radial-gradient(circle at center,rgba(90,158,111,.24),rgba(90,158,111,.08));border:2px solid var(--gr);border-radius:50%;color:var(--cr);font-family:var(--fh);font-size:10px;letter-spacing:.1em;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation;box-shadow:0 0 20px var(--gg),0 6px 18px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.1);transition:all .1s;-webkit-tap-highlight-color:transparent}
.t-fire:active{background:radial-gradient(circle at center,rgba(90,158,111,.42),rgba(90,158,111,.18));transform:scale(.93)}
.t-bomb,.t-slow,.t-spec{width:48px;height:48px;border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;touch-action:manipulation;transition:all .1s;-webkit-tap-highlight-color:transparent}
.t-bomb{background:rgba(192,112,96,.1);border:1.5px solid rgba(192,112,96,.42);box-shadow:0 0 10px rgba(192,112,96,.14),0 4px 10px rgba(0,0,0,.3)}
.t-bomb:active{background:rgba(192,112,96,.3);transform:scale(.91)}
.t-slow{background:rgba(155,143,208,.1);border:1.5px solid rgba(155,143,208,.36)}
.t-slow:active{background:rgba(155,143,208,.3);transform:scale(.91)}
.t-spec{background:rgba(196,165,90,.1);border:1.5px solid rgba(196,165,90,.36)}
.t-spec:active{background:rgba(196,165,90,.3);transform:scale(.91)}

/* BOTTOM */
.botbar{display:flex;align-items:stretch;background:var(--pn);border-top:1px solid var(--b1);backdrop-filter:blur(14px);overflow:hidden}
.nc{flex:1;padding:7px 13px;border-right:1px solid var(--b1);display:flex;flex-direction:column;gap:4px;overflow:hidden}
.nc-hdr{display:flex;align-items:center;justify-content:space-between}
.nc-lbl{font-family:var(--fm);font-size:8px;letter-spacing:.2em;color:var(--sa);opacity:.6}
.nc-dots{display:flex;gap:3px}
.nc-dots span{width:4px;height:4px;border-radius:50%;background:var(--sa);opacity:.28;animation:nd 1.5s ease-in-out infinite}
.nc-dots span:nth-child(2){animation-delay:.2s}.nc-dots span:nth-child(3){animation-delay:.4s}
@keyframes nd{0%,100%{opacity:.28}50%{opacity:.88}}
.nc-msgs{flex:1;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;gap:2px}
.nc-line{font-family:var(--fm);font-size:10px;color:var(--tx);display:flex;gap:7px;opacity:0;animation:li .3s ease forwards;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nc-line .ts{color:var(--td);flex-shrink:0}.nc-line .pr{color:var(--sa);flex-shrink:0}
.nc-line.ek{color:var(--sa)}.nc-line.ed{color:var(--da)}.nc-line.es{color:var(--cr)}.nc-line.eb{color:var(--td)}.nc-line.ep{color:var(--sl)}
@keyframes li{from{opacity:0;transform:translateX(-5px)}to{opacity:1;transform:none}}
.sys-panel{width:176px;padding:10px 13px;display:flex;flex-direction:column;justify-content:center;gap:6px}
.sys-r{display:flex;align-items:center;gap:7px}
.sys-l{font-family:var(--fm);font-size:8px;letter-spacing:.13em;color:var(--td);width:24px}
.sys-b{flex:1;height:4px;background:rgba(90,158,111,.08);border-radius:2px;overflow:hidden;border:1px solid var(--b1)}
.sys-f{height:100%;background:linear-gradient(90deg,var(--gr),rgba(90,158,111,.5));border-radius:2px;transition:width 1s;box-shadow:0 0 4px var(--gg)}
.sys-p{font-family:var(--fm);font-size:8px;color:var(--td);width:26px;text-align:right}

/* ANIMATIONS */
.score-pop{animation:sp .3s ease}
@keyframes sp{0%{transform:scale(1)}50%{transform:scale(1.22);color:#fff;text-shadow:0 0 20px #fff}100%{transform:scale(1)}}
.combo-pop{animation:cp .18s ease}
@keyframes cp{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}

/* RESPONSIVE */
@media(max-width:768px){
  .app-wrap{grid-template-rows:44px 1fr 60px}
  .tb-id{display:none}.rt-cpu{display:none}
  .tb-headline{font-size:9px;letter-spacing:.14em}
  .pwrbar{display:none}
  .hud{position:absolute;right:unset;top:unset;transform:none;bottom:0;left:0;right:0;width:100%;flex-direction:row;flex-wrap:wrap;gap:5px;padding:5px 10px;border-radius:0;border-top:1px solid var(--b1);border-left:none;border-right:none;border-bottom:none;justify-content:space-between;align-items:center}
  .hud-brand,.hud-rule,.hud-foot,.skin-grid,.skin-nm,.hud-sec:has(.hud-best),.hud-sec:has(.hud-xp){display:none}
  .hud-sec{flex-direction:row;align-items:center;gap:5px}
  .hud-sec.hud-row{gap:10px}.hud-val{font-size:12px}
  .hud-hull,.hud-cf{display:none}
  .botbar{flex-direction:column;height:60px}.sys-panel{display:none}.nc{border-right:none;padding:3px 10px}
  .nc-line{font-size:9px}
  .touch{display:flex!important;bottom:66px}
}
@media(max-width:420px){
  .t-btn{width:46px;height:46px;font-size:16px}.t-sp{width:46px;height:46px}
  .t-fire{width:64px;height:64px;font-size:9px}.t-bomb,.t-slow,.t-spec{width:42px;height:42px;font-size:16px}
}
