:root{--bg:#08080c;--surface:#14141d;--surface-2:#191922;--border:#24242f;--border-2:#2f2f3d;--text:#ededf2;--text-dim:#aeaebc;--text-mute:#75758a;--text-faint:#54546a;--accent:#646cff;--accent-2:#a78bfa;--accent-soft:#646cff18;--r-sm:10px;--r-md:14px;--r-lg:20px;--shadow-soft:0 18px 50px -20px #000000b3;--shadow-card:0 18px 50px -20px #000000b3;--shadow-glow:0 22px 60px -18px #646cff3a;--font-sans:"Inter", system-ui, "Segoe UI", Roboto, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;line-height:1.6}body:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:56px 56px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,#0000 80%);mask-image:radial-gradient(circle at 50% 30%,#000 0%,#0000 80%)}a{color:inherit;text-decoration:none}button{font-family:inherit}section{z-index:1;position:relative}h1,h2,h3{letter-spacing:-.02em}::selection{color:#fff;background:#646cff55}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{border:2px solid var(--bg);background:#24242f;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#34344a}.main-content{z-index:1;margin-left:220px;padding-right:56px;position:relative}.sidebar{border-right:1px solid var(--border);z-index:100;background:#0b0b13;flex-direction:column;width:220px;height:100vh;display:flex;position:fixed;top:0;left:0}.mobile-header{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);z-index:150;background:#0a0a12cc;justify-content:space-between;align-items:center;width:100%;height:56px;padding:0 1.25rem;display:none;position:fixed;top:0;left:0}.sidebar-social{color:var(--text-mute);border-radius:var(--r-sm);align-items:center;gap:.5rem;margin-bottom:.15rem;padding:.5rem 1rem;font-size:.82rem;transition:color .2s,background .2s;display:flex}.sidebar-social:hover{color:var(--text);background:var(--accent-soft)}.eyebrow{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:.85rem;font-size:.72rem;font-weight:600;display:inline-block}.eyebrow:before{content:"// ";color:var(--text-faint)}.section-title{color:var(--text);margin-bottom:.85rem;font-size:clamp(1.7rem,3vw,2.1rem);font-weight:800}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.type-cursor{color:var(--accent);margin-left:2px;font-weight:400;animation:1s step-end infinite blink;display:inline-block}.section-sub{color:var(--text-mute);max-width:560px;margin:-1.5rem 0 2.25rem;font-size:.98rem;line-height:1.7}.section-sub.center{text-align:center;margin-left:auto;margin-right:auto}.social-btn{width:44px;height:44px;color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:50%;justify-content:center;align-items:center;transition:color .2s,border-color .2s,transform .2s,box-shadow .2s;display:inline-flex}.social-btn:hover{color:#fff;border-color:var(--accent);transform:translateY(-3px);box-shadow:0 10px 24px -10px #646cff88}.tech-strip{flex-wrap:wrap;justify-content:center;gap:.55rem;display:flex}.tech-chip{border:1px solid var(--border);color:var(--text-dim);background:#12121b;border-radius:999px;align-items:center;gap:.45rem;padding:.4rem .85rem .4rem .7rem;font-size:.82rem;transition:border-color .2s,transform .2s,background .2s;display:inline-flex}.tech-chip:hover{background:#16161f;border-color:#646cff66;transform:translateY(-2px)}.tech-chip i{font-size:1.15rem;line-height:1}.tech-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:7px;height:7px}@keyframes fadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.animate-hidden{opacity:0;transform:translateY(28px)}.animate-visible{animation:.7s cubic-bezier(.22,1,.36,1) forwards fadeUp}.section-next-wrap{justify-content:center;margin-top:3rem;display:flex}.section-next{letter-spacing:.12em;color:var(--text-mute);border:1px solid var(--border-2);background:#0c0c14;border-radius:999px;align-items:center;gap:.4rem;padding:.6rem 1.4rem;font-size:.6rem;transition:color .2s,border-color .2s,box-shadow .2s,transform .2s;display:inline-flex}.section-next:hover{color:var(--neon-cyan);border-color:var(--neon-cyan);box-shadow:0 0 16px -4px var(--neon-cyan);transform:translateY(-2px)}.hero-bg-video{z-index:-1;pointer-events:none;position:absolute;inset:0;overflow:hidden}.hero-bg-video video{object-fit:contain;object-position:center top;opacity:.38;width:100%;height:100%;-webkit-mask-image:linear-gradient(#000 0% 38%,#0000 75%);mask-image:linear-gradient(#000 0% 38%,#0000 75%)}@media (prefers-reduced-motion:reduce){.hero-bg-video{display:none}}@keyframes heroFade{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.hero-text{animation:.8s cubic-bezier(.22,1,.36,1) .1s both heroFade}.hero-img{animation:.8s cubic-bezier(.22,1,.36,1) .3s both heroFade}@keyframes wave{0%,60%,to{transform:rotate(0)}10%,30%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}.wave{transform-origin:70% 70%;animation:2.6s ease-in-out infinite wave;display:inline-block}@keyframes bounce{0%,to{opacity:.5;transform:translateY(0)}50%{opacity:1;transform:translateY(7px)}}.scroll-indicator{animation:1.8s ease-in-out infinite bounce}.scroll-indicator:hover{opacity:.7}.section-divider{background:var(--accent);border-radius:2px;width:44px;height:3px;margin-bottom:2.5rem}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--r-sm);padding:.72rem 1.75rem;font-size:.92rem;font-weight:700;transition:background .2s,transform .15s;display:inline-block}.btn-primary:hover{background:#535bf2;transform:translateY(-2px)}.btn-secondary{color:#b8bcff;border-radius:var(--r-sm);background:#646cff10;border:1px solid #646cff55;padding:.72rem 1.75rem;font-size:.92rem;font-weight:700;transition:background .2s,transform .15s,border-color .2s;display:inline-block}.btn-secondary:hover{border-color:var(--accent);background:#646cff22;transform:translateY(-2px)}.project-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-soft);flex-direction:column;gap:1rem;padding:1.75rem;transition:border-color .25s,transform .25s,box-shadow .25s;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--accent);transform-origin:0;height:2px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:hover{box-shadow:var(--shadow-glow);border-color:#646cff66;transform:translateY(-5px)}.project-card:hover:before{transform:scaleX(1)}.repo-link{color:var(--text-mute);font-size:.8rem;font-family:var(--font-mono);border:1px solid var(--border-2);border-radius:var(--r-sm);align-items:center;gap:.35rem;padding:.3rem .7rem;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.repo-link:hover{color:var(--text);border-color:var(--accent);background:var(--accent-soft)}.form-field{flex-direction:column;gap:.4rem;display:flex}.form-label{font-family:var(--font-mono);letter-spacing:.04em;color:var(--text-mute);font-size:.74rem}.form-input,.form-textarea{border:1px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);font-family:var(--font-sans);background:#12121b;padding:.72rem .9rem;font-size:.92rem;transition:border-color .2s,background .2s}.form-input:focus,.form-textarea:focus{border-color:var(--accent);background:#15151f;outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-faint)}.form-textarea{resize:vertical;min-height:130px;line-height:1.6}.form-status{font-size:.86rem;line-height:1.5}.form-status.ok{color:#5fd38a}.form-status.err{color:#ff7676}.contact-item{color:var(--text-dim);border-radius:var(--r-sm);border:1px solid var(--border-2);background:#0c0c14;align-items:center;gap:.85rem;width:100%;max-width:420px;padding:.7rem .9rem;transition:border-color .2s,color .2s,transform .2s,box-shadow .2s,background .2s;display:flex}.contact-item:hover{color:#fff;border-color:var(--c,var(--neon-cyan));box-shadow:0 0 18px -6px var(--c,var(--neon-cyan));background:#0e0e1a;transform:translate(4px)}.ct-icon{width:38px;height:38px;color:var(--c,var(--neon-cyan));border:1px solid var(--c,var(--neon-cyan));box-shadow:inset 0 0 12px -6px var(--c,var(--neon-cyan)), 0 0 10px -7px var(--c,var(--neon-cyan));background:#05060b;border-radius:8px;flex-shrink:0;place-items:center;display:grid}.ct-svg{width:20px;height:20px}.ct-label{font-size:.92rem;font-family:var(--font-mono);letter-spacing:.01em;flex:1}.ct-arrow{color:var(--c,var(--neon-cyan));opacity:0;font-size:.5rem;transition:opacity .2s,transform .2s;transform:translate(-4px)}.contact-item:hover .ct-arrow{opacity:1;transform:translate(0)}.detail-page section{scroll-snap-align:none}.hgal{position:relative}.hgal-sticky{padding:.5rem 0;position:sticky;overflow:hidden}.hgal-track{will-change:transform;align-items:center;display:flex}.hgal-panel{flex:0 0 100%;min-width:0;padding:0 .4rem}.proj-icon{flex-shrink:0;width:2rem;height:2rem;display:block}.proj-icon-lg{filter:drop-shadow(0 0 10px);flex-shrink:0;width:2.6rem;height:2.6rem;display:block}.proj-icon-sm{flex-shrink:0;width:1.2rem;height:1.2rem}.ann-feature{grid-template-columns:minmax(0,300px) 1fr;align-items:center;gap:1.9rem;display:grid}.ann-feature.rev{grid-template-columns:1fr minmax(0,300px)}.ann-feature.rev .ann-figure{order:2;transform:translate(40px)scale(.97)}.ann-feature.rev .ann-info{order:1}.ann-feature.wide{display:block}.ann-feature.wide .ann-figure{margin-bottom:1.25rem;transform:translateY(40px)scale(.98)}.ann-feature.wide .ann-list{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.6rem 1.4rem;display:grid}.ann-figure{border:1px solid var(--border-2);box-shadow:var(--shadow-soft);opacity:0;background:#0b0b13;border-radius:22px;margin:0;transition:opacity .75s cubic-bezier(.22,1,.36,1),transform .75s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden;transform:translate(-40px)scale(.97)}.ann-feature.in .ann-figure{opacity:1;transform:none}.ann-figure img{width:100%;display:block}.ann-ring{width:30px;height:30px;font-family:var(--font-arcade);color:#05050b;background:var(--neon-cyan);z-index:2;transition:transform .45s cubic-bezier(.34,1.7,.5,1);transition-delay:calc(.45s + var(--i) * .28s);border:2px solid #fff;border-radius:50%;place-items:center;font-size:.6rem;display:grid;position:absolute;transform:translate(-50%,-50%)scale(0);box-shadow:0 0 0 4px #2de2e655,0 0 14px #2de2e6}.ann-feature.in .ann-ring{transform:translate(-50%,-50%)scale(1)}.ann-ring:after{content:"";border:2px solid var(--neon-cyan);opacity:0;border-radius:50%;position:absolute;inset:-6px}.ann-feature.in .ann-ring:after{animation:1.7s ease-out infinite annPing;animation-delay:calc(.9s + var(--i) * .28s)}@keyframes annPing{0%{opacity:.85;transform:scale(.7)}to{opacity:0;transform:scale(1.9)}}.ann-info{flex-direction:column;gap:.5rem;display:flex}.ann-eyebrow{letter-spacing:.1em;color:var(--neon-cyan);text-shadow:0 0 8px #2de2e688;font-size:.55rem}.ann-title{color:#fff;letter-spacing:-.01em;font-size:1.3rem;font-weight:800}.ann-caption{color:#aaa;font-size:.9rem;line-height:1.7}.ann-list{flex-direction:column;gap:.6rem;margin:.5rem 0 0;padding:0;list-style:none;display:flex}.ann-li{color:#cfcfdb;opacity:0;transition:opacity .5s,transform .5s;transition-delay:calc(.55s + var(--i) * .28s);align-items:flex-start;gap:.6rem;font-size:.88rem;line-height:1.55;display:flex;transform:translateY(10px)}.ann-feature.in .ann-li{opacity:1;transform:none}.ann-num{width:22px;height:22px;font-family:var(--font-arcade);color:#05050b;background:var(--neon-cyan);box-shadow:0 0 10px -2px var(--neon-cyan);border-radius:50%;flex-shrink:0;place-items:center;font-size:.55rem;display:grid}@media (width<=700px){.ann-feature,.ann-feature.rev{grid-template-columns:1fr;gap:1.1rem}.ann-feature .ann-figure,.ann-feature.rev .ann-figure{order:0;max-width:300px;margin:0 auto;transform:translateY(30px)scale(.97)}.ann-feature.in .ann-figure{transform:none}.ann-feature.rev .ann-info{order:0}}.video-embed{aspect-ratio:16/9;border:1px solid var(--border-2);width:100%;box-shadow:0 0 30px -16px var(--neon-cyan), var(--shadow-soft);background:#000;border-radius:16px;transition:border-color .25s,box-shadow .25s;position:relative;overflow:hidden}.video-embed:hover{box-shadow:0 0 36px -14px var(--neon-cyan), var(--shadow-soft);border-color:#2de2e666}.video-embed iframe{border:0;width:100%;height:100%;display:block;position:absolute;inset:0}.detail-page{z-index:1;min-height:100vh;padding-bottom:4rem;position:relative}.detail-back{color:var(--text-mute);font-size:.9rem;font-family:var(--font-mono);padding:.4rem 0;transition:color .2s;display:inline-block}.detail-back:hover{color:var(--accent)}.detail-page li:before{content:"▹";color:var(--accent);position:absolute;left:0}.detail-next{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;gap:.3rem;max-width:820px;margin:2rem auto 0;padding:1.5rem 1.75rem;transition:border-color .25s,transform .25s,box-shadow .25s;display:flex}.detail-next:hover{box-shadow:var(--shadow-glow);border-color:#646cff66;transform:translateY(-3px)}.profile-img{z-index:1;object-fit:cover;border:3px solid var(--accent);width:240px;height:240px;box-shadow:var(--shadow-soft);border-radius:50%;position:relative}@media (width<=900px){.sidebar{display:none}.mobile-header{display:flex}.main-content{margin-left:0;padding-top:56px;padding-right:0}.section-nav{display:none}.profile-img{width:160px;height:160px}}@media (width<=480px){.btn-primary,.btn-secondary{text-align:center;width:100%}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}:root{--font-arcade:"Press Start 2P", var(--font-mono);--neon-cyan:#2de2e6;--neon-pink:#ff4d8d;--neon-green:#58ff8c;--neon-yellow:#ffe45e}body:after{content:"";pointer-events:none;z-index:9998;background:repeating-linear-gradient(#0000 0 2px,#0000000d 3px),radial-gradient(circle at 50% 45%,#0000 55%,#00000059 130%);animation:6s steps(60,end) infinite crtFlicker;position:fixed;inset:0}@keyframes crtFlicker{0%,97%,to{opacity:1}98%{opacity:.82}99%{opacity:.94}}.arcade{font-family:var(--font-arcade);letter-spacing:.02em;line-height:1.5}.neon{text-shadow:0 0 5px,0 0 12px,0 0 22px}.neon-cyan{color:var(--neon-cyan)}.neon-pink{color:var(--neon-pink)}.neon-green{color:var(--neon-green)}.neon-yellow{color:var(--neon-yellow)}.hud-frame{border-radius:var(--r-md);background:linear-gradient(#0d1320 0%,#0a0a12 100%);border:1px solid #2de2e655;box-shadow:inset 0 0 0 1px #2de2e618,0 18px 50px -20px #000c}@keyframes arcadeBlink{0%,49%{opacity:1}50%,to{opacity:.15}}.arcade-blink{animation:1.05s step-end infinite arcadeBlink}@keyframes hudScan{0%{background-position:-120% 0}to{background-position:220% 0}}.shooter-arena{border-radius:var(--r-md);width:100%;box-shadow:0 0 30px -12px #2de2e644, var(--shadow-soft);background:radial-gradient(circle at 50% 120%,#1a1140 0%,#0000 60%),linear-gradient(#070711 0%,#05050b 100%);border:1px solid #2de2e633;position:relative;overflow:hidden}.shooter-arena:before{content:"";opacity:.7;background-image:radial-gradient(1px 1px at 20% 30%,#fff6 50%,#0000),radial-gradient(1px 1px at 70% 60%,#fff4 50%,#0000),radial-gradient(1px 1px at 40% 80%,#fff5 50%,#0000),radial-gradient(1px 1px at 88% 20%,#fff4 50%,#0000),radial-gradient(1px 1px at 55% 15%,#fff3 50%,#0000);background-size:200px 200px;animation:8s linear infinite starScroll;position:absolute;inset:0}@keyframes starScroll{0%{background-position:0 0}to{background-position:-200px 0}}.ship-core{filter:drop-shadow(0 0 6px var(--neon-cyan)) drop-shadow(0 0 14px #2de2e688);animation:1.6s ease-in-out infinite shipBob}@keyframes shipBob{0%,to{transform:translateY(-3px)}50%{transform:translateY(3px)}}.bullet-core{background:var(--neon-cyan);box-shadow:0 0 6px 1px var(--neon-cyan), 0 0 12px 2px #2de2e6aa;border-radius:2px}.enemy-chip{white-space:nowrap;background:#1a0f1f;border:1px solid;border-radius:8px;align-items:center;gap:.4rem;padding:.32rem .7rem;font-size:.78rem;font-weight:600;display:inline-flex;box-shadow:0 0 10px -2px}.enemy-chip i{font-size:1rem}.particle-core{border-radius:1px}.skill-cell{color:var(--text-faint);border:1px solid var(--border);filter:grayscale()brightness(.6);background:#0e0e16;border-radius:8px;align-items:center;gap:.45rem;padding:.4rem .8rem;font-size:.82rem;transition:filter .35s,color .35s,border-color .35s,box-shadow .35s,transform .2s;display:inline-flex}.skill-cell i{font-size:1.05rem}.skill-cell.lit{color:var(--text);filter:none;border-color:var(--neon-cyan);box-shadow:0 0 12px -3px var(--neon-cyan);animation:.4s cubic-bezier(.34,1.56,.64,1) skillPop}@keyframes skillPop{0%{transform:scale(.9)}55%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes bannerPop{0%{opacity:0;transform:translate(-50%,-50%)scale(.6)}18%{opacity:1;transform:translate(-50%,-50%)scale(1.05)}82%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-50%)scale(1.1)}}.stage-banner{animation:1.5s forwards bannerPop}.btn-arcade{font-family:var(--font-arcade);letter-spacing:.04em;color:#05050b;background:var(--neon-cyan);box-shadow:0 0 0 2px #05050b, 0 0 16px -2px var(--neon-cyan), 4px 4px 0 0 #11707a;cursor:pointer;border:none;border-radius:4px;padding:.85rem 1.4rem;font-size:.7rem;transition:transform .12s,box-shadow .12s;display:inline-block}.btn-arcade:hover{box-shadow:0 0 0 2px #05050b, 0 0 22px 0 var(--neon-cyan), 6px 6px 0 0 #11707a;transform:translate(-1px,-1px)}.btn-arcade:active{transform:translate(3px,3px);box-shadow:0 0 0 2px #05050b,1px 1px #11707a}.btn-arcade.pink{background:var(--neon-pink);box-shadow:0 0 0 2px #05050b, 0 0 16px -2px var(--neon-pink), 4px 4px 0 0 #8a2350}.btn-arcade.pink:hover{box-shadow:0 0 0 2px #05050b, 0 0 22px 0 var(--neon-pink), 6px 6px 0 0 #8a2350}.btn-arcade.pink:active{box-shadow:0 0 0 2px #05050b,1px 1px #8a2350}.hero-portrait{filter:drop-shadow(0 0 20px #2de2e655)drop-shadow(0 10px 26px #000000a6);width:270px;max-width:62vw;height:auto;animation:4s ease-in-out infinite portraitFloat;display:block}@keyframes portraitFloat{0%,to{transform:translateY(-5px)}50%{transform:translateY(5px)}}@media (width<=900px){.hero-portrait{width:200px}}.inv2{border-radius:var(--r-md);width:100%;box-shadow:0 0 28px -16px var(--neon-cyan), var(--shadow-soft);background:linear-gradient(#0c1018 0%,#08080c 100%);border:1px solid #2de2e633;padding:1.25rem 1.35rem 1.4rem}.inv2-head{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.1rem;display:flex}.inv2-reset{color:var(--neon-pink);cursor:pointer;letter-spacing:.06em;background:#05050b;border:1px solid #ff4d8d66;border-radius:4px;margin-left:auto;padding:.4rem .6rem;font-size:.5rem;transition:background .15s,box-shadow .15s}.inv2-reset:hover{box-shadow:0 0 12px -3px var(--neon-pink);background:#ff4d8d18}.inv2-reset:disabled{opacity:.4;cursor:default;box-shadow:none}.inv-classes{grid-template-columns:repeat(3,1fr);gap:.8rem;display:grid}.inv-class{border-radius:var(--r-sm);border:1px solid var(--cls-faint);box-shadow:inset 0 0 26px -18px var(--cls);background:#07070d;flex-direction:column;gap:.55rem;padding:.85rem .9rem .95rem;transition:border-color .3s,box-shadow .3s;display:flex}.inv-class.done{border-color:var(--cls-soft);box-shadow:0 0 22px -10px var(--cls), inset 0 0 26px -16px var(--cls)}.inv-class-head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.inv-class-name{color:var(--cls);letter-spacing:.08em;text-shadow:0 0 8px var(--cls-soft);font-size:.62rem}.inv-class-badge{color:#05050b;background:var(--cls);box-shadow:0 0 10px -2px var(--cls);border-radius:3px;padding:.25rem .45rem;font-size:.5rem;animation:.4s cubic-bezier(.34,1.56,.64,1) skillPop}.inv-class-slots{flex-direction:column;gap:.4rem;display:flex}.eq-slot{opacity:.5;background:repeating-linear-gradient(45deg,#0a0a12 0 6px,#0c0c16 6px 12px);border:1px dashed #2a2a3d;border-radius:8px;align-items:center;gap:.55rem;min-height:44px;padding:.4rem .55rem;transition:border-color .25s,box-shadow .25s,background .25s,opacity .25s;display:flex}.eq-slot.loading{opacity:1;border-style:solid;border-color:var(--cls-soft);animation:.7s ease-in-out infinite slotPulse}@keyframes slotPulse{0%,to{box-shadow:0 0 #0000}50%{box-shadow:0 0 14px -2px var(--cls)}}.eq-slot.filled{opacity:1;border-style:solid;border-color:var(--cls);box-shadow:0 0 14px -6px var(--cls);background:linear-gradient(#0e1626,#0a0a12);animation:.4s cubic-bezier(.34,1.56,.64,1) skillPop}.eq-icon{border:1px solid var(--cls-faint);width:34px;height:34px;color:var(--cls);background:#05060b;border-radius:6px;flex-shrink:0;place-items:center;display:grid}.eq-num{font-family:var(--font-mono);color:var(--text-faint);font-size:.72rem}.eq-name{color:var(--text);font-size:.78rem;font-weight:600;line-height:1.3}.eq-slot:not(.filled) .eq-name{color:var(--text-faint)}.skill-svg{width:20px;height:20px;color:var(--cls,currentColor)}.cls-bar{border:1px solid var(--cls-faint);background:#0c1018;border-radius:3px;height:8px;margin-top:.1rem;padding:1px;overflow:hidden}.cls-bar-fill{background:linear-gradient(90deg, var(--cls), #fffa, var(--cls));height:100%;box-shadow:0 0 8px -1px var(--cls);background-size:200% 100%;border-radius:2px;transition:width .45s cubic-bezier(.22,1,.36,1);animation:2.4s linear infinite hudScan}.inv-toast{pointer-events:none;font-size:.72rem;animation:1.4s forwards toastUp;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}@keyframes toastUp{0%{opacity:0;transform:translate(-50%,14px)}15%{opacity:1;transform:translate(-50%)}80%{opacity:1;transform:translate(-50%,-6px)}to{opacity:0;transform:translate(-50%,-20px)}}@media (width<=760px){.inv-classes{grid-template-columns:1fr}}.quest-rpg{width:100%}.quest-hud{flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:1rem;display:flex}.quest-hud .inv2-reset{margin-left:auto}.shoot-arena{border-radius:var(--r-md);height:205px;box-shadow:0 0 26px -14px #2de2e644, var(--shadow-soft);background:radial-gradient(circle at 30% 120%,#1a1140 0%,#0000 55%),linear-gradient(#070711 0%,#05050b 100%);border:1px solid #2de2e633;position:relative;overflow:hidden}.shoot-arena:before{content:"";opacity:.6;background-image:radial-gradient(1px 1px at 20% 30%,#fff5 50%,#0000),radial-gradient(1px 1px at 70% 60%,#fff4 50%,#0000),radial-gradient(1px 1px at 45% 80%,#fff4 50%,#0000),radial-gradient(1px 1px at 85% 25%,#fff3 50%,#0000);background-size:200px 200px;animation:9s linear infinite starScroll;position:absolute;inset:0}.turret{z-index:2;width:34px;height:44px;position:absolute;top:50%;left:18px;transform:translateY(-50%)}.turret:before{content:"";border:1px solid var(--neon-cyan);width:28px;height:28px;box-shadow:inset 0 0 10px -4px var(--neon-cyan), 0 0 12px -6px var(--neon-cyan);background:linear-gradient(#14304a,#0a1422);border-radius:7px;position:absolute;top:8px;left:0}.turret:after{content:"";background:var(--neon-cyan);width:18px;height:9px;box-shadow:0 0 10px var(--neon-cyan);border-radius:2px;position:absolute;top:17px;left:22px}.turret.firing:after{animation:.16s steps(2,end) infinite muzzle}@keyframes muzzle{0%,to{width:18px}50%{width:24px}}.turret.t1:before{border-color:var(--neon-green);box-shadow:inset 0 0 12px -3px var(--neon-green), 0 0 16px -5px var(--neon-green)}.turret.t1:after{background:var(--neon-green);box-shadow:0 0 12px var(--neon-green);height:11px}.turret.t2:before{border-color:var(--neon-yellow);box-shadow:inset 0 0 12px -2px var(--neon-yellow), 0 0 18px -4px var(--neon-yellow)}.turret.t2:after{background:var(--neon-yellow);box-shadow:0 0 14px var(--neon-yellow);height:13px;top:16px}.turret.t3:before{box-shadow:inset 0 0 14px -2px #fff, 0 0 22px -3px var(--neon-yellow);border-color:#fff}.turret.t3:after{box-shadow:0 0 16px #fff, 0 0 26px var(--neon-yellow);background:#fff;height:15px;top:15px}.shot{background:var(--neon-cyan);width:16px;height:4px;box-shadow:0 0 6px 1px var(--neon-cyan), 0 0 12px 2px #2de2e6aa;border-radius:2px;animation:.62s linear infinite shotFly;position:absolute;top:calc(50% - 2px)}.shot.t1{background:var(--neon-green);width:20px;height:5px;box-shadow:0 0 7px 1px var(--neon-green), 0 0 14px 2px var(--neon-green)}.shot.t2{background:var(--neon-yellow);width:24px;height:6px;box-shadow:0 0 8px 2px var(--neon-yellow), 0 0 16px 3px #ffe45eaa}.shot.t3{width:30px;height:7px;box-shadow:0 0 10px 2px #fff, 0 0 20px 4px var(--neon-yellow);background:#fff}@keyframes shotFly{0%{opacity:0;left:44px}12%{opacity:1}88%{opacity:1}to{opacity:0;left:60%}}.boss{border-radius:var(--r-md);border:1px solid var(--neon-pink);width:clamp(230px,50%,350px);box-shadow:0 0 20px -6px var(--neon-pink);z-index:2;background:linear-gradient(#1d1020,#0c0c14);padding:.75rem .9rem;position:absolute;top:50%;transform:translateY(-50%)}.boss.incoming{animation:.35s bossFadeIn}@keyframes bossFadeIn{0%{opacity:0}to{opacity:1}}.boss.battle{transition:left 2.6s linear;animation:.14s linear infinite bossShake}@keyframes bossShake{0%,to{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 1.5px))}}.boss.destroyed{animation:.6s forwards bossBoom}@keyframes bossBoom{0%{opacity:1;transform:translateY(-50%)scale(1)}18%{opacity:1;filter:brightness(3);transform:translateY(-50%)scale(1.06)}to{opacity:0;transform:translateY(-50%)scale(.8)}}.boss-top{align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.boss-icon{flex-shrink:0;font-size:1.1rem}.boss-name{color:#fff;font-size:.9rem;font-weight:800}.boss-sub{font-family:var(--font-mono);color:var(--text-mute);white-space:nowrap;margin-left:auto;font-size:.58rem}.boss-role{color:var(--accent-2);margin-bottom:.3rem;font-size:.72rem}.boss-desc{color:var(--text-dim);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.55rem;font-size:.7rem;line-height:1.5;display:-webkit-box;overflow:hidden}.boss-hpbar{background:#2a0f1a;border:1px solid #ff4d8d55;border-radius:3px;height:8px;padding:1px;overflow:hidden}.boss-hpfill{background:linear-gradient(90deg,#ff4d4d,#ffe45e);border-radius:2px;width:100%;height:100%;box-shadow:0 0 8px -1px #ff6b6b}.boss.battle .boss-hpfill,.boss.destroyed .boss-hpfill{width:0;transition:width 2.6s linear}.frag{background:var(--neon-yellow);width:8px;height:8px;box-shadow:0 0 6px var(--neon-yellow);border-radius:1px;animation:.55s ease-out forwards fragFly;position:absolute;top:50%;left:30%}@keyframes fragFly{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(var(--fx), var(--fy)) scale(.3)}}.arena-clear{text-align:center;z-index:3;font-size:clamp(.7rem,2.6vw,1rem);animation:.5s cubic-bezier(.34,1.56,.64,1) skillPop;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.arena-clear small{color:var(--text-mute);font-size:.6rem;font-family:var(--font-mono);margin-top:.5rem;display:block}.qlog{flex-direction:column;gap:.6rem;margin-top:1.1rem;display:flex}.qlog-item{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);opacity:.55;filter:grayscale(.5);align-items:flex-start;gap:.85rem;padding:.85rem 1rem;transition:opacity .4s,filter .4s,border-color .4s,box-shadow .4s,transform .25s;display:flex}.qlog-item.active{border-color:var(--neon-yellow);box-shadow:0 0 16px -6px var(--neon-yellow);opacity:.85}.qlog-item.cleared{opacity:1;filter:none;box-shadow:0 0 16px -10px var(--neon-green);border-color:#58ff8c55}.qlog-item.goal.cleared{border-color:var(--neon-cyan);box-shadow:0 0 16px -8px var(--neon-cyan)}.qlog-icon{border:1px solid var(--border-2);background:#05060b;border-radius:8px;flex-shrink:0;place-items:center;width:38px;height:38px;font-size:1.2rem;display:grid}.qlog-badge{font-family:var(--font-arcade);letter-spacing:.05em;color:var(--text-faint);border:1px solid var(--border-2);white-space:nowrap;border-radius:4px;flex-shrink:0;align-self:center;padding:.35rem .5rem;font-size:.45rem}.qlog-badge.on{color:#05050b;background:var(--neon-green);border-color:var(--neon-green);box-shadow:0 0 10px -2px var(--neon-green)}.qlog-item.goal .qlog-badge.on{background:var(--neon-cyan);border-color:var(--neon-cyan);box-shadow:0 0 10px -2px var(--neon-cyan)}.chatbot{flex-direction:column;width:100%;display:flex;overflow:hidden}.chatbot-head{border-bottom:1px solid #2de2e622;align-items:center;gap:.55rem;padding:.8rem 1rem;display:flex}.chatbot-head-ava{flex-shrink:0;width:30px;height:30px;position:relative}.chatbot-head-ava img{border-radius:50%;width:100%;height:100%;display:block}.chatbot-dot{background:var(--neon-green);width:8px;height:8px;box-shadow:0 0 8px var(--neon-green);border-radius:50%;animation:1.6s step-end infinite arcadeBlink}.chatbot-head-ava .chatbot-dot{border:2px solid #0c1018;position:absolute;bottom:-1px;right:-1px}.chatbot-log{scrollbar-width:thin;flex-direction:column;gap:.7rem;height:300px;padding:1rem;display:flex;overflow-y:auto}.chatbot-log::-webkit-scrollbar{width:6px}.chatbot-log::-webkit-scrollbar-thumb{background:#2de2e644;border-radius:6px}.chat-row{align-items:flex-end;gap:.5rem;max-width:88%;display:flex}.chat-row.user{flex-direction:row-reverse;align-self:flex-end}.chat-row.assistant{align-self:flex-start}.chat-ava{object-fit:cover;border-radius:50%;flex-shrink:0;align-self:flex-end;width:30px;height:30px}.chat-bubble{white-space:pre-wrap;word-break:break-word;border-radius:12px;padding:.6rem .85rem;font-size:.9rem;line-height:1.6}.chat-bubble.assistant{border:1px solid var(--border-2);color:var(--text-dim);background:#12121b;border-bottom-left-radius:3px}.chat-bubble.user{color:var(--text);background:linear-gradient(#1b2740,#142033);border:1px solid #2de2e655;border-bottom-right-radius:3px}.chat-bubble.err{color:#ff9a9a;border-color:#ff767655}.typing{align-items:center;gap:4px;height:1em;display:inline-flex}.typing i{background:var(--neon-cyan);border-radius:50%;width:6px;height:6px;animation:1s ease-in-out infinite typingBounce}.typing i:nth-child(2){animation-delay:.15s}.typing i:nth-child(3){animation-delay:.3s}@keyframes typingBounce{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.chat-suggest{flex-wrap:wrap;gap:.45rem;padding:0 1rem .6rem;display:flex}.chat-chip{color:var(--text-dim);cursor:pointer;background:#0e0e16;border:1px solid #2de2e644;border-radius:999px;padding:.35rem .75rem;font-size:.76rem;transition:border-color .2s,color .2s,background .2s,transform .15s}.chat-chip:hover:not(:disabled){border-color:var(--neon-cyan);color:#fff;transform:translateY(-2px)}.chat-chip:disabled{opacity:.5;cursor:default}.chatbot-input{border-top:1px solid #2de2e622;gap:.6rem;padding:.8rem 1rem 1rem;display:flex}.chatbot-input .form-input{flex:1}.chatbot-input .btn-arcade{align-items:center;padding:0 1rem;font-size:.6rem;display:inline-flex}.chatbot-input .btn-arcade:disabled{opacity:.45;cursor:default;box-shadow:0 0 0 2px #05050b,2px 2px #11707a}.mech-stage{border-radius:var(--r-md);width:100%;height:380px;box-shadow:0 0 28px -14px #2de2e644, var(--shadow-soft);background:radial-gradient(circle at 50% 42%,#1a1140 0%,#0000 58%),linear-gradient(#070711 0%,#05050b 100%);border:1px solid #2de2e633;position:relative;overflow:hidden}@media (width<=560px){.mech-stage{height:320px}}.mech-frame{opacity:0;pointer-events:none;width:100%;height:100%;transition:opacity .7s;position:absolute;inset:0}.mech-frame.on{opacity:.5}.mech-frame line,.mech-frame polyline{fill:none;stroke:var(--neon-cyan);stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 3px var(--neon-cyan))}.mech-core-glow{opacity:0;pointer-events:none;background:radial-gradient(circle,#2de2e655 0%,#0000 70%);border-radius:50%;width:200px;height:200px;transition:opacity .7s;position:absolute;top:42%;left:50%;transform:translate(-50%,-50%)}.mech-core-glow.on{opacity:1}.mech-part{opacity:.55;z-index:1;flex-direction:column;align-items:center;gap:4px;transition:left .6s,top .6s,transform .6s,opacity .45s;display:flex;position:absolute}.mech-part.docked{opacity:1;z-index:2;transition:left .4s cubic-bezier(.34,1.7,.5,1),top .4s cubic-bezier(.34,1.7,.5,1),transform .4s cubic-bezier(.34,1.7,.5,1),opacity .2s}.mech-icon{background:#0b0e16;border:1px solid;border-radius:9px;place-items:center;width:40px;height:40px;display:grid;position:relative;box-shadow:0 0 10px -3px}.mech-part.docked .mech-icon{animation:.42s dockClank;box-shadow:0 0 16px -3px,inset 0 0 12px -6px}.mech-icon:after{content:"";opacity:0;pointer-events:none;border:2px solid;border-radius:12px;position:absolute;inset:-4px}.mech-part.docked .mech-icon:after{animation:.5s dockRing}@keyframes dockClank{0%{filter:brightness(2.4);transform:scale(1.32)}50%{transform:scale(.9)}to{filter:brightness();transform:scale(1)}}@keyframes dockRing{0%{opacity:.9;transform:scale(.55)}to{opacity:0;transform:scale(1.8)}}.mech-label{color:var(--text);white-space:nowrap;opacity:0;text-shadow:0 1px 3px #000;pointer-events:none;margin-top:3px;font-size:.58rem;font-weight:600;transition:opacity .3s;position:absolute;top:100%}.mech-part:hover{z-index:5}.mech-part:hover .mech-label{opacity:1}
