:root{--bg: #05050e;--surface: #0a0a1c;--surface-2: #0f102a;--border: #1a2660;--glow: #2244ff;--accent: #4466ff;--accent-2: #7c3aed;--text: #b8ccff;--text-dim: #3a4a7a;--text-bright: #e8f0ff;--hp: #ff2255;--xp: #ffd700;--success: #00ffaa;--fail: #ff4455;--font-hud: "Rajdhani", sans-serif;--font-mono: "Share Tech Mono", monospace;--font-body: "Noto Sans", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;background:var(--bg);color:var(--text);overflow-x:hidden}#root{min-height:100vh}button{cursor:pointer;border:none;background:none;font-family:var(--font-hud);color:var(--text)}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--glow);border-radius:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes glowPulse{0%,to{box-shadow:0 0 8px #4466ff4d,inset 0 0 8px #4466ff0d}50%{box-shadow:0 0 20px #46f9,inset 0 0 16px #4466ff1a}}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes bossFlicker{0%,95%,to{opacity:1}96%{opacity:.4}98%{opacity:.8}}@keyframes xpFill{0%{width:0}}@keyframes gradeReveal{0%{opacity:0;transform:scale(2);letter-spacing:.5em}to{opacity:1;transform:scale(1);letter-spacing:.05em}}@keyframes starFloat{0%{transform:translateY(0) scale(1);opacity:.6}50%{transform:translateY(-8px) scale(1.1);opacity:1}to{transform:translateY(0) scale(1);opacity:.6}}.grid-bg{position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(34,68,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(34,68,255,.06) 1px,transparent 1px);background-size:44px 44px;pointer-events:none;z-index:0}.grid-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(30,50,200,.07) 0%,transparent 70%)}.grid-bg:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(transparent,rgba(68,102,255,.15),transparent);animation:scanline 8s linear infinite;pointer-events:none}.page{position:relative;min-height:100vh;z-index:1}.sys-btn{font-family:var(--font-mono);font-size:.85rem;letter-spacing:.12em;color:var(--accent);border:1px solid var(--accent);padding:10px 28px;background:#4466ff14;transition:background .2s,box-shadow .2s,color .2s}.sys-btn:hover{background:#4466ff2e;box-shadow:0 0 16px #46f6;color:var(--text-bright)}.sys-btn-sec{color:var(--text-dim);border-color:var(--border);background:transparent}.sys-btn-sec:hover{color:var(--text);background:#ffffff0a;box-shadow:none}.sys-notification{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);letter-spacing:.1em;padding:6px 16px;border-left:2px solid var(--accent);background:#4466ff14;animation:fadeIn .6s ease}.sys-bracket{color:var(--text-dim)}.portal-page{composes:page;display:flex;flex-direction:column;min-height:100vh;padding:32px 48px 60px;gap:40px}@media (max-width: 700px){.portal-page{padding:20px 16px 48px}}.portal-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.hunter-card{display:flex;align-items:center;gap:20px;padding:16px 24px;border:1px solid var(--border);background:#0a0a1ccc;animation:fadeIn .5s ease}.hunter-rank{font-family:var(--font-hud);font-size:2.8rem;font-weight:700;line-height:1;min-width:52px;text-align:center;filter:drop-shadow(0 0 10px currentColor)}.hunter-info{display:flex;flex-direction:column;gap:4px}.hunter-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-dim);letter-spacing:.15em}.hunter-name{font-family:var(--font-hud);font-size:1.1rem;font-weight:600;color:var(--text-bright);letter-spacing:.06em}.hunter-xp-wrap{display:flex;flex-direction:column;gap:6px;min-width:140px}.xp-label{font-family:var(--font-mono);font-size:.7rem;color:var(--xp);letter-spacing:.1em}.xp-track{height:4px;background:#ffd7001f;border:1px solid rgba(255,215,0,.2);position:relative;overflow:hidden}.xp-fill{height:100%;background:linear-gradient(90deg,#cc9900,var(--xp));box-shadow:0 0 8px #ffd70080;transition:width .8s ease;animation:xpFill 1.2s ease}.xp-next{font-family:var(--font-mono);font-size:.62rem;color:var(--text-dim)}.portal-title{font-family:var(--font-hud);font-size:1rem;font-weight:600;letter-spacing:.3em;color:var(--text-dim);text-transform:uppercase;margin-bottom:24px}.portal-title .sys-bracket{color:var(--border)}.dungeon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.dungeon-card{position:relative;display:flex;align-items:center;gap:20px;padding:24px 28px;border:1px solid var(--border);background:#0a0a1cb3;text-align:left;transition:border-color .2s,background .2s,box-shadow .2s;animation:fadeIn .5s ease both}.dungeon-card:hover{border-color:var(--glow);background:#0f0f28e6;box-shadow:0 0 24px #24f3,inset 0 0 24px #2244ff08}.dungeon-card.dungeon-cleared{border-color:#00ffaa4d}.dungeon-card.dungeon-cleared:hover{border-color:#00ffaa80;box-shadow:0 0 24px #00ffaa26}.dcard-rank{font-family:var(--font-hud);font-size:2.4rem;font-weight:700;line-height:1;min-width:44px;text-align:center;filter:drop-shadow(0 0 8px currentColor)}.dcard-body{flex:1;display:flex;flex-direction:column;gap:6px}.dcard-title{font-family:var(--font-hud);font-size:1.05rem;font-weight:600;color:var(--text-bright);letter-spacing:.04em}.dcard-meta{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);letter-spacing:.08em}.dcard-badge{position:absolute;top:10px;right:12px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.15em;color:var(--success);border:1px solid rgba(0,255,170,.3);padding:2px 7px}.no-dungeons{font-family:var(--font-mono);color:var(--text-dim);font-size:.85rem;letter-spacing:.08em;padding:40px 0}.map-page{position:relative;min-height:100vh;padding:32px 48px 60px;display:flex;flex-direction:column;gap:32px;z-index:1}@media (max-width: 700px){.map-page{padding:20px 16px 48px}}.back-btn{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.12em;color:var(--text-dim);align-self:flex-start;padding:4px 0;transition:color .2s}.back-btn:hover{color:var(--accent)}.map-header{display:flex;flex-direction:column;gap:10px}.map-rank{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.2em;filter:drop-shadow(0 0 6px currentColor)}.map-title{font-family:var(--font-hud);font-size:2.2rem;font-weight:700;color:var(--text-bright);letter-spacing:.04em}.map-desc{font-family:var(--font-body);font-size:.85rem;color:var(--text-dim);max-width:520px;line-height:1.6}.floor-list{display:flex;flex-direction:column;gap:0;max-width:680px}.floor-item{position:relative;display:flex;align-items:center;gap:20px;padding:20px 28px;border:1px solid var(--border);border-top:none;background:#0a0a1c99;text-align:left;transition:border-color .2s,background .2s,box-shadow .2s;animation:fadeIn .4s ease both}.floor-list .floor-item:first-child{border-top:1px solid var(--border)}.floor-item:hover:not(:disabled){background:#0f0f2ae6;border-color:var(--glow);z-index:1;box-shadow:0 0 20px #2244ff26}.floor-item.floor-cleared{border-color:#0fa3}.floor-item.floor-cleared:hover:not(:disabled){border-color:#0fa6;box-shadow:0 0 20px #00ffaa1a}.floor-item.floor-locked{opacity:.35;cursor:not-allowed}.floor-item.floor-boss{border-color:#ff22554d;background:#14050ab3;animation:bossFlicker 6s ease-in-out infinite}.floor-item.floor-boss:hover:not(:disabled){border-color:#f259;box-shadow:0 0 24px #f253}.floor-num{font-family:var(--font-mono);font-size:.8rem;color:var(--text-dim);min-width:28px}.floor-info{flex:1;display:flex;flex-direction:column;gap:4px}.floor-name{font-family:var(--font-hud);font-size:1rem;font-weight:600;color:var(--text-bright);letter-spacing:.04em}.floor-item.floor-boss .floor-name{color:#f68}.floor-mobs{font-family:var(--font-mono);font-size:.68rem;color:var(--text-dim);letter-spacing:.08em}.floor-status{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;color:var(--text-dim)}.floor-item.floor-cleared .floor-status{color:var(--success)}.floor-item.floor-boss .floor-status{color:#f46}.combat-page{position:relative;min-height:100vh;display:flex;flex-direction:column;padding:0;z-index:1;overflow:hidden}.combat-hud{display:flex;align-items:center;gap:24px;padding:14px 32px;background:#05050ee6;border-bottom:1px solid var(--border);flex-wrap:wrap}.hud-floor{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;color:var(--text-dim);white-space:nowrap}.hud-progress{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);letter-spacing:.1em}.hud-hp-wrap{display:flex;align-items:center;gap:10px;flex:1;min-width:180px}.hud-hp-wrap.shake{animation:shake .45s ease}.hud-label{font-family:var(--font-mono);font-size:.65rem;color:var(--hp);letter-spacing:.12em}.bar-track{flex:1;height:6px;background:#ff22551a;border:1px solid rgba(255,34,85,.25);overflow:hidden}.bar-fill-hp{height:100%;background:linear-gradient(90deg,#cc1133,var(--hp));box-shadow:0 0 8px #f259;transition:width .4s ease}.hud-hp-val{font-family:var(--font-mono);font-size:.7rem;color:var(--hp);min-width:28px}.streak-badge{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;color:var(--xp);border:1px solid rgba(255,215,0,.35);padding:2px 10px;background:#ffd70012;box-shadow:0 0 12px #ffd70033;white-space:nowrap;animation:fadeIn .3s ease}.mob-banner{display:flex;align-items:center;gap:12px;padding:12px 32px;border-bottom:1px solid rgba(68,102,255,.15);background:#0a0c1e99}.mob-tag{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.15em;color:var(--accent)}.mob-name{font-family:var(--font-hud);font-size:.9rem;font-weight:600;color:var(--text);letter-spacing:.06em}.question-panel{flex:1;display:flex;align-items:center;padding:48px 32px 32px;max-width:820px;width:100%;margin:0 auto}.question-text{font-family:var(--font-hud);font-size:1.35rem;font-weight:600;color:var(--text-bright);line-height:1.55;letter-spacing:.02em;animation:fadeIn .4s ease}.choices-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 32px 32px;max-width:820px;width:100%;margin:0 auto}@media (max-width: 600px){.choices-grid{grid-template-columns:1fr}.question-panel{padding:32px 20px 20px}.choices-grid{padding:0 20px 24px}}.choice-btn{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;border:1px solid var(--border);background:#0a0a1cb3;text-align:left;transition:border-color .18s,background .18s,box-shadow .18s;animation:fadeIn .35s ease both}.choice-btn:hover:not(:disabled){border-color:var(--glow);background:#14193ccc;box-shadow:0 0 16px #24f3}.choice-btn:disabled{cursor:default}.choice-btn.choice-correct{border-color:var(--success);background:#00ffaa12;box-shadow:0 0 20px #00ffaa26}.choice-btn.choice-wrong{border-color:var(--fail);background:#ff445512;box-shadow:0 0 20px #ff445526;animation:shake .45s ease}.choice-btn.choice-dim{opacity:.35}.choice-letter{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);min-width:16px;padding-top:1px}.choice-btn.choice-correct .choice-letter{color:var(--success)}.choice-btn.choice-wrong .choice-letter{color:var(--fail)}.choice-text{font-family:var(--font-body);font-size:.9rem;color:var(--text);line-height:1.5}.explanation-panel{padding:24px 32px;border-top:1px solid var(--border);background:#080816f2;max-width:820px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:14px;animation:slideUp .35s ease}.exp-verdict{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.15em}.explanation-panel.exp-correct .exp-verdict{color:var(--success)}.explanation-panel.exp-wrong .exp-verdict{color:var(--fail)}.exp-text{font-family:var(--font-body);font-size:.88rem;color:var(--text);line-height:1.65}.exp-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}.results-page{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;z-index:1}.results-panel{display:flex;flex-direction:column;align-items:center;gap:28px;padding:52px 64px;border:1px solid var(--border);background:#080816f2;max-width:520px;width:100%;opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease}.results-panel.results-show{opacity:1;transform:translateY(0)}.results-header{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.2em;color:var(--text-dim)}.results-grade{font-family:var(--font-hud);font-size:6rem;font-weight:700;line-height:1;animation:gradeReveal .7s cubic-bezier(.22,1,.36,1) .3s both}.results-rank-label{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.2em}.results-stats{display:flex;flex-direction:column;gap:10px;width:100%;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 0}.stat-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em}.stat-row span:first-child{color:var(--text-dim)}.stat-row span:last-child{color:var(--text-bright)}.results-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.code-editor-container{height:280px;border:1px solid var(--border);background:var(--bg)}.code-editor-wrap{padding:0 32px;max-width:820px;width:100%;margin:0 auto}.code-actions{display:flex;align-items:center;gap:12px;padding:12px 32px;max-width:820px;width:100%;margin:0 auto;flex-wrap:wrap}.code-attempts{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);letter-spacing:.08em;margin-left:auto}.code-results-panel{padding:0 32px 24px;max-width:820px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:6px}.code-results-inline{display:flex;flex-direction:column;gap:6px;padding:4px 0 8px}.code-result-row{display:flex;align-items:baseline;gap:10px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;color:var(--text);padding:5px 10px;border:1px solid var(--border);background:#0a0a1c80;flex-wrap:wrap}.code-result-pass{border-color:#00ffaa40;background:#00ffaa0a}.code-result-fail{border-color:#ff445540;background:#ff44550a}.code-result-icon{min-width:14px;flex-shrink:0}.code-result-pass .code-result-icon{color:var(--success)}.code-result-fail .code-result-icon{color:var(--fail)}.code-result-desc{color:var(--text-dim);flex:1;min-width:80px}.code-result-got{color:var(--text)}.code-result-expected{color:var(--fail);width:100%;padding-left:24px}.code-result-error{font-family:var(--font-mono);font-size:.72rem;color:var(--fail);padding:8px 10px;border:1px solid rgba(255,68,85,.3);background:#ff445512}@media (max-width: 768px){.hunter-card{flex-wrap:wrap;padding:12px 16px;gap:12px}.hunter-rank{font-size:2rem;min-width:40px}.portal-topbar{flex-direction:column}.map-title{font-size:1.8rem}.sys-btn{font-size:.78rem}}@media (max-width: 480px){.portal-page{padding:16px 16px 48px}.hunter-rank{font-size:1.8rem}.dungeon-grid{grid-template-columns:minmax(280px,1fr)}.map-page{padding:16px 16px 48px}.map-title{font-size:1.6rem}.floor-item{padding:14px 16px;gap:12px}.floor-status{font-size:.65rem}.question-panel{padding:28px 20px 16px}.question-text{font-size:1.1rem}.choices-grid{padding:0 16px 20px}.choice-btn{min-height:56px}.explanation-panel{padding:16px 20px}.results-panel{padding:32px 24px}.results-grade{font-size:4rem}.code-editor-container{height:200px}.code-editor-wrap{padding:0 16px}.code-actions{padding:10px 16px;flex-direction:column;align-items:stretch}.code-actions .sys-btn{text-align:center}.code-attempts{margin-left:0}.code-results-panel{padding:0 16px 16px}}@media (max-width: 600px){.combat-hud{gap:12px;padding:10px 16px;row-gap:8px}.hud-hp-wrap{min-width:0;flex:1 1 100%;order:3}.hud-floor{order:1}.hud-progress{order:2;margin-left:auto}.streak-badge{order:4}.page{overflow-x:hidden}.sys-btn,.back-btn,.choice-btn,button{min-height:44px}}
