@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Noto+Sans+JP:wght@400;500;700;900&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #06080f;--bg2: #0b0f1a;--surface: rgba(255, 255, 255, .04);--surface2: rgba(255, 255, 255, .08);--surface3: rgba(255, 255, 255, .12);--border: rgba(255, 255, 255, .08);--text: #e8edf5;--text-dim: #6b7a94;--cyan: #00e5ff;--cyan-dim: rgba(0, 229, 255, .15);--cyan-glow: rgba(0, 229, 255, .4);--purple: #7b61ff;--purple-dim: rgba(123, 97, 255, .15);--green: #00d68f;--green-dim: rgba(0, 214, 143, .12);--red: #ff3b5c;--red-dim: rgba(255, 59, 92, .12);--orange: #ff9f0a;--orange-dim: rgba(255, 159, 10, .12);--radius: 14px;--radius-sm: 8px;--font-body: "Noto Sans JP", -apple-system, sans-serif;--font-mono: "DM Mono", "SF Mono", monospace}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;opacity:0;z-index:0;pointer-events:none}.gate{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:hidden}.gate-scan{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.3;pointer-events:none;transition:top .04s linear}.gate-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.gate-card{position:relative;width:320px;padding:48px 32px 36px;display:flex;flex-direction:column;align-items:center;gap:32px;z-index:1}.gate-card.shake{animation:shakeX .5s cubic-bezier(.36,.07,.19,.97)}.gate-icon{width:80px;height:80px;color:var(--cyan);animation:spinSlow 20s linear infinite}.gate-icon svg{width:100%;height:100%;filter:drop-shadow(0 0 12px var(--cyan-glow))}.gate-title{display:flex;flex-direction:column;align-items:center;gap:6px}.gate-label{font-family:var(--font-mono);font-size:13px;letter-spacing:.3em;color:var(--cyan);text-transform:uppercase}.gate-sub{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase}.gate-form{width:100%;display:flex;flex-direction:column;gap:16px}.gate-input-wrap{position:relative}.gate-input{width:100%;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-mono);font-size:15px;letter-spacing:.05em;outline:none;transition:border-color .2s,box-shadow .2s}.gate-input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-dim),inset 0 0 20px #00e5ff08}.gate-input::placeholder{color:var(--text-dim);font-style:normal;text-transform:uppercase;letter-spacing:.1em;font-size:12px}.gate-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:transparent;border:1px solid var(--cyan);border-radius:var(--radius-sm);color:var(--cyan);font-family:var(--font-mono);font-size:13px;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;transition:all .2s}.gate-btn:hover{background:var(--cyan-dim);box-shadow:0 0 20px var(--cyan-dim)}.gate-footer{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}.gate-blink{width:6px;height:6px;border-radius:50%;background:var(--green);animation:blink 2s ease-in-out infinite}.app{position:relative;z-index:1;max-width:720px;margin:0 auto;padding:0 16px 100px;min-height:100dvh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border);position:sticky;top:0;background:#06080feb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:10}.app-brand{display:flex;align-items:center;gap:10px}.app-logo{color:var(--cyan);opacity:.8}.app-header h1{font-size:16px;font-weight:700;letter-spacing:.02em}.streak-badge{display:flex;align-items:center;gap:4px;padding:3px 10px;background:linear-gradient(135deg,#ff9f0a33,#ff3b5c26);border:1px solid rgba(255,159,10,.3);border-radius:20px;font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--orange);white-space:nowrap}.streak-fire{font-size:14px;animation:fireFlicker 1.5s ease-in-out infinite}@keyframes fireFlicker{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.streak-count{letter-spacing:.03em}.teacher-switch{display:flex;gap:4px}.teacher-btn{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:4px 12px;border-radius:16px;font-size:12px;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:all .2s}.teacher-btn:hover{border-color:var(--surface3);color:var(--text)}.teacher-btn.active{background:var(--teacher-accent);border-color:var(--teacher-accent);color:var(--bg);font-weight:700}.app-nav{display:flex;gap:4px}.app-nav button{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:6px 16px;border-radius:20px;font-size:13px;font-family:var(--font-body);font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.app-nav button:hover{border-color:var(--surface3);color:var(--text)}.app-nav button.active{background:var(--cyan);border-color:var(--cyan);color:var(--bg);font-weight:700}.badge{background:var(--red);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px;font-weight:700;font-family:var(--font-mono)}.app-main{padding-top:24px}.app-footer{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--text-dim);opacity:.4;text-transform:uppercase;background:linear-gradient(transparent,var(--bg));pointer-events:none}.app-footer-dot{width:3px;height:3px;border-radius:50%;background:var(--text-dim)}.game-stage{position:relative;overflow:hidden}.game-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:center center / cover no-repeat;opacity:.3;z-index:0;pointer-events:none}.stage-lights{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 50% 70% at 15% 0%,color-mix(in srgb,var(--accent, #00e5ff) 10%,transparent) 0%,transparent 70%),radial-gradient(ellipse 50% 70% at 85% 0%,rgba(123,97,255,.1) 0%,transparent 70%),radial-gradient(ellipse 80% 40% at 50% 0%,color-mix(in srgb,var(--accent, #00e5ff) 12%,transparent) 0%,transparent 50%),radial-gradient(ellipse 30% 100% at 50% 20%,color-mix(in srgb,var(--accent, #00e5ff) 4%,transparent) 0%,transparent 80%)}.game-hud{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-bottom:2px solid color-mix(in srgb,var(--accent, #00e5ff) 30%,transparent);border-radius:var(--radius-sm);position:relative;z-index:1}.hud-left{display:flex;align-items:center;gap:8px}.hud-id{font-family:var(--font-mono);font-size:11px;color:var(--cyan);background:var(--cyan-dim);padding:2px 8px;border-radius:4px;letter-spacing:.02em}.hud-subject{font-size:12px;color:var(--text-dim);font-weight:500}.hud-mastery{font-size:11px;font-weight:700}.hud-right{display:flex;align-items:center;gap:10px}.hud-progress{font-family:var(--font-mono);font-size:12px;color:var(--text-dim)}.hud-combo{font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:.1em;color:var(--cyan);text-shadow:0 0 12px var(--cyan-dim);animation:comboPulse .5s cubic-bezier(.34,1.56,.64,1)}.hud-combo.fire{color:var(--orange);text-shadow:0 0 12px var(--orange-dim)}.hud-combo.ultra{background:linear-gradient(90deg,var(--red),var(--orange),var(--cyan),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn-bgm-mute{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);font-size:14px;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;flex-shrink:0}.btn-bgm-mute:hover{background:var(--surface3);color:var(--text)}.hud-slevel{display:flex;align-items:center;gap:6px;padding:2px 12px;margin:0 16px 4px}.slevel-indicator{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--slevel-color, var(--cyan));text-shadow:0 0 8px var(--slevel-color, var(--cyan))}.slevel-label{font-size:10px;color:var(--text-dim);letter-spacing:.05em}.hud-xp{display:flex;align-items:center;gap:8px;padding:0 16px;margin-bottom:6px;position:relative}.hud-xp-level{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--purple);min-width:36px}.hud-xp-bar{flex:1;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}.hud-xp-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--cyan));border-radius:3px;transition:width .5s cubic-bezier(.34,1.56,.64,1)}.hud-xp-num{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);min-width:48px;text-align:right}.xp-float{position:absolute;right:60px;top:-14px;font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--purple);text-shadow:0 0 10px rgba(123,97,255,.6);animation:xpFloat 1.2s ease-out forwards;pointer-events:none}@keyframes xpFloat{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-24px)}}.xp-value{color:var(--purple)!important}.stage-area{display:flex;align-items:center;justify-content:center;gap:8px;margin:8px 0;position:relative;z-index:1}.stage-character{flex-shrink:0;position:relative}.stage-standing{height:200px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 30px rgba(0,0,0,.6)) drop-shadow(0 0 20px rgba(0,229,255,.1));animation:standingIdle 3s ease-in-out infinite}@keyframes standingIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.stage-center{display:flex;justify-content:center;flex-shrink:0;position:relative}.countdown{position:relative;width:140px;height:140px;flex-shrink:0}.countdown-svg{width:100%;height:100%}.countdown-track{transition:stroke-dashoffset .1s linear}.countdown-pulse{animation:pulseRing 1s ease-in-out infinite}.countdown-display{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.countdown-num{font-family:var(--font-mono);font-size:60px;font-weight:500;color:var(--text);line-height:1;transition:color .3s,text-shadow .3s;text-shadow:0 0 24px rgba(0,229,255,.4),0 0 60px rgba(0,229,255,.15)}.countdown-unit{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.15em;margin-top:2px}.countdown.urgent .countdown-num{color:var(--orange);text-shadow:0 0 30px rgba(255,159,10,.5)}.countdown.critical .countdown-num{color:var(--red);text-shadow:0 0 40px rgba(255,59,92,.6);animation:pulseText .5s ease-in-out infinite}.countdown.critical .countdown-svg{animation:shakeX .3s ease-in-out infinite}.game-stage:has(.countdown.critical):after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:100;box-shadow:inset 0 0 80px 20px #ff3b5c26;animation:vignetteFlash .8s ease-in-out infinite}@keyframes vignetteFlash{0%,to{opacity:.6}50%{opacity:1}}.stage-area,.quiz-bubble,.quiz-tags{transition:opacity .2s ease-out,max-height .3s ease-out}.phase-result .stage-area,.phase-result .quiz-bubble,.phase-result .quiz-tags{opacity:0;max-height:0;overflow:hidden;margin:0;pointer-events:none}.quiz-bubble{background:linear-gradient(180deg,var(--surface) 0%,rgba(255,255,255,.02) 100%);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px;position:relative;z-index:1;box-shadow:0 4px 24px #0003}.quiz-bubble:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%) rotate(45deg);width:14px;height:14px;background:var(--surface);border-top:1px solid var(--border);border-left:1px solid var(--border)}.quiz-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}.quiz-tag{font-size:11px;color:var(--text-dim);background:var(--surface);padding:3px 10px;border-radius:12px;border:1px solid var(--border)}.quiz-mode-badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 12px;border-radius:12px;margin-bottom:10px;letter-spacing:.5px}.mode-correct{color:#00e5ff;background:#00e5ff1a;border:1px solid rgba(0,229,255,.3)}.mode-incorrect{color:#ff3b5c;background:#ff3b5c1a;border:1px solid rgba(255,59,92,.3)}.quiz-question{font-size:17px;font-weight:700;line-height:1.7;margin-bottom:24px;color:var(--text)}.quiz-choices{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.choice{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:15px;font-family:var(--font-body);text-align:left;cursor:pointer;transition:all .2s;line-height:1.6;position:relative;overflow:hidden}.choice:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 60%,rgba(0,229,255,.03));opacity:0;transition:opacity .2s}.choice:hover:not(:disabled):before{opacity:1}.choice:hover:not(:disabled){border-color:#00e5ff4d;box-shadow:0 0 20px #00e5ff0f}.choice:active:not(:disabled){transform:scale(.97);transition:transform .08s ease-in}.choice:disabled{cursor:default}.choice.selected-judging{border-color:#fff6;box-shadow:0 0 20px #ffffff1a;animation:judgePulse .2s ease-out}@keyframes judgePulse{0%{transform:scale(.97)}50%{transform:scale(1.02);box-shadow:0 0 24px #fff3}to{transform:scale(1)}}.choice.correct{border-color:var(--green);background:var(--green-dim);box-shadow:0 0 24px #00d68f1a}.choice.wrong{border-color:var(--red);background:var(--red-dim)}.choice.dimmed{opacity:.4}.choice-key{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:8px;background:var(--surface2);font-weight:700;font-size:12px;font-family:var(--font-mono);transition:all .2s}.choice.correct .choice-key{background:var(--green);color:var(--bg)}.choice.wrong .choice-key{background:var(--red);color:#fff}.choice-text{flex:1;padding-top:3px}.choice-red .choice-key{background:#ff3b5c40;color:#fff;border:none;box-shadow:0 0 8px #ff3b5c4d}.choice-blue .choice-key{background:#008cff4d;color:#fff;border:none;box-shadow:0 0 8px #008cff4d}.choice-green .choice-key{background:#00d68f40;color:#fff;border:none;box-shadow:0 0 8px #00d68f4d}.choice-red{border-left:3px solid rgba(255,59,92,.5)}.choice-blue{border-left:3px solid rgba(0,140,255,.5)}.choice-green{border-left:3px solid rgba(0,214,143,.5)}.choice-red:hover:not(:disabled){border-color:#ff3b5c66;border-left-color:#ff3b5cb3;box-shadow:0 0 24px #ff3b5c1a}.choice-blue:hover:not(:disabled){border-color:#008cff66;border-left-color:#008cffb3;box-shadow:0 0 24px #008cff1a}.choice-green:hover:not(:disabled){border-color:#00d68f66;border-left-color:#00d68fb3;box-shadow:0 0 24px #00d68f1a}.quiz-result{padding:24px 20px;border-radius:var(--radius);animation:slideUp .35s cubic-bezier(.16,1,.3,1);border:1px solid;text-align:center}.quiz-result.correct{background:var(--green-dim);border-color:#00d68f40}.quiz-result.wrong,.quiz-result.timeout{background:var(--red-dim);border-color:#ff3b5c40}.result-banner{font-family:var(--font-mono);font-size:28px;font-weight:700;letter-spacing:.2em;text-align:center;margin-bottom:4px;animation:bannerPop .4s cubic-bezier(.34,1.56,.64,1)}.quiz-result.correct .result-banner{color:var(--green);text-shadow:0 0 20px rgba(0,214,143,.5),0 0 40px rgba(0,214,143,.2)}.quiz-result.wrong .result-banner,.quiz-result.timeout .result-banner{color:var(--red);text-shadow:0 0 20px rgba(255,59,92,.5),0 0 40px rgba(255,59,92,.2)}.combo-badge{display:inline-block;margin-left:12px;font-size:14px;letter-spacing:.12em;color:var(--cyan);text-shadow:0 0 12px var(--cyan-dim);animation:comboPulse .5s cubic-bezier(.34,1.56,.64,1);vertical-align:middle}.vn-stage{position:relative;margin:12px 0 20px;border-radius:12px;overflow:hidden;background:linear-gradient(180deg,#06080f00,#06080fd9 70%);min-height:320px;display:flex;align-items:flex-end;animation:stageReveal .5s cubic-bezier(.16,1,.3,1)}.vn-standing{position:absolute;bottom:0;left:50%;transform:translate(-50%);height:340px;width:auto;object-fit:contain;filter:drop-shadow(0 0 20px rgba(0,0,0,.6));animation:standingSlide .6s cubic-bezier(.16,1,.3,1);z-index:1}.quiz-result.correct .vn-standing{filter:drop-shadow(0 0 24px rgba(0,214,143,.2))}.quiz-result.wrong .vn-standing,.quiz-result.timeout .vn-standing{filter:drop-shadow(0 0 24px rgba(255,59,92,.15))}.vn-dialogue-box{position:relative;z-index:2;width:100%;padding:16px 20px;background:linear-gradient(180deg,#06080fb3,#06080ff2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.08);animation:dialogueFade .7s cubic-bezier(.16,1,.3,1)}.vn-name{display:inline-block;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--cyan);margin-bottom:6px;padding:2px 8px;border:1px solid rgba(0,229,255,.3);border-radius:4px;background:#00e5ff14}.vn-text{font-size:16px;font-weight:600;color:var(--text);line-height:1.6;margin:0}.result-body{display:flex;flex-direction:column;gap:16px}.result-vn-col{flex-shrink:0}.result-detail-col{flex:1;min-width:0}.result-detail{text-align:left;margin-bottom:16px}.result-answer{display:flex;align-items:baseline;gap:8px;margin-bottom:10px;padding:10px 14px;background:#00d68f14;border-left:3px solid var(--green);border-radius:0 var(--radius-sm) var(--radius-sm) 0;line-height:1.6}.result-answer-label{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--green);white-space:nowrap;flex-shrink:0}.result-answer-label.wrong{color:var(--red)}.result-answer-text{font-size:15px;color:var(--text)}.result-answer-text strong{color:var(--green);font-weight:700}.result-your-answer{display:flex;align-items:baseline;gap:8px;margin-bottom:12px;padding:8px 14px;background:#ff3b5c0f;border-left:3px solid rgba(255,59,92,.4);border-radius:0 var(--radius-sm) var(--radius-sm) 0;line-height:1.6}.result-your-answer .result-answer-text{color:var(--text-dim);font-size:14px;text-decoration:line-through;text-decoration-color:#ff3b5c66}.result-explanation-box{padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.result-explanation{font-size:16px;line-height:1.9;color:var(--text);margin-bottom:12px}.result-practical{font-size:15px;line-height:1.8;color:var(--text-dim);padding:12px 14px;background:#ff9f0a0f;border-radius:var(--radius-sm);margin-bottom:0;border:1px solid rgba(255,159,10,.15)}.result-practical strong{color:var(--orange)}.result-trick{padding:12px 14px;background:#ff3b5c14;border:1px solid rgba(255,59,92,.25);border-radius:var(--radius-sm);margin-bottom:14px}.trick-badge{display:inline-block;font-size:11px;font-weight:700;color:#ff3b5c;background:#ff3b5c26;padding:2px 10px;border-radius:10px;margin-bottom:6px;letter-spacing:.5px}.trick-note{font-size:15px;line-height:1.8;color:var(--text);margin:0}.btn-next{width:100%;padding:14px;margin-top:16px;background:var(--cyan);color:var(--bg);border:none;border-radius:var(--radius);font-size:15px;position:sticky;bottom:12px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .2s;letter-spacing:.05em}.btn-next:hover{box-shadow:0 0 24px var(--cyan-dim);transform:translateY(-1px)}.btn-next:active{transform:translateY(0)}@keyframes bannerPop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes comboPulse{0%{transform:scale(.3);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes stageReveal{0%{opacity:0}to{opacity:1}}@keyframes standingSlide{0%{transform:translate(-50%) translateY(30px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes dialogueFade{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.hud-hearts{display:flex;gap:3px;font-size:18px;line-height:1}.heart{transition:all .3s}.heart-full{color:var(--red);text-shadow:0 0 8px rgba(255,59,92,.5);filter:drop-shadow(0 0 4px rgba(255,59,92,.3))}.heart-empty{color:#ff3b5c33}.hearts-critical .heart-full{animation:heartPulse .6s ease-in-out infinite}@keyframes heartPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.heart-loss{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:8px;animation:heartLossPop .5s cubic-bezier(.34,1.56,.64,1)}.heart-loss-icon{font-size:24px;color:var(--red);opacity:.7}.heart-loss-text{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--red);text-shadow:0 0 12px rgba(255,59,92,.5)}@keyframes heartLossPop{0%{transform:scale(1.8);opacity:0}50%{transform:scale(.9);opacity:1}to{transform:scale(1);opacity:1}}.hud-round{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--cyan);background:var(--cyan-dim);padding:2px 10px;border-radius:4px}.judgment-splash{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:300;pointer-events:none;animation:splashFade .8s cubic-bezier(.16,1,.3,1) forwards}.judgment-correct{background:radial-gradient(ellipse at center,rgba(0,214,143,.15) 0%,transparent 70%)}.judgment-wrong,.judgment-timeout{background:radial-gradient(ellipse at center,rgba(255,59,92,.15) 0%,transparent 70%)}.judgment-text{font-family:var(--font-body);font-size:56px;font-weight:900;letter-spacing:.08em;text-align:center;animation:judgmentSlam .8s cubic-bezier(.16,1,.3,1) forwards}.judgment-correct .judgment-text{color:var(--green);text-shadow:0 0 40px rgba(0,214,143,.6),0 0 80px rgba(0,214,143,.3),0 4px 0 rgba(0,100,60,.5)}.judgment-wrong .judgment-text,.judgment-timeout .judgment-text{color:var(--red);text-shadow:0 0 40px rgba(255,59,92,.6),0 0 80px rgba(255,59,92,.3),0 4px 0 rgba(140,20,40,.5)}@keyframes judgmentSlam{0%{transform:scale(3) rotate(-2deg);opacity:0}15%{transform:scale(1.1) rotate(1deg);opacity:1}25%{transform:scale(.95) rotate(0)}35%{transform:scale(1) rotate(0);opacity:1}75%{transform:scale(1) rotate(0);opacity:1}to{transform:scale(1.05);opacity:0}}@keyframes splashFade{0%{opacity:0}10%{opacity:1}75%{opacity:1}to{opacity:0}}.game-toast{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:200;animation:toastSlide 2s cubic-bezier(.16,1,.3,1) forwards}.game-toast-text{display:inline-block;font-family:var(--font-mono);font-size:16px;font-weight:700;letter-spacing:.15em;color:var(--bg);background:linear-gradient(135deg,var(--cyan),var(--purple));padding:8px 24px;border-radius:24px;box-shadow:0 4px 24px #00e5ff4d,0 0 40px #7b61ff33;white-space:nowrap}@keyframes toastSlide{0%{transform:translate(-50%) translateY(-20px) scale(.8);opacity:0}15%{transform:translate(-50%) translateY(0) scale(1.05);opacity:1}25%{transform:translate(-50%) translateY(0) scale(1);opacity:1}80%{transform:translate(-50%) translateY(0) scale(1);opacity:1}to{transform:translate(-50%) translateY(-10px);opacity:0}}.round-progress{display:flex;justify-content:center;gap:8px;padding:6px 0;position:relative;z-index:1}.round-dot{width:10px;height:10px;border-radius:50%;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.dot-pending{background:var(--surface2);border:1px solid var(--border)}.dot-current{background:var(--cyan);border:1px solid var(--cyan);box-shadow:0 0 8px var(--cyan-dim);animation:dotPulse 1.5s ease-in-out infinite}.dot-correct{background:var(--green);border:1px solid var(--green);box-shadow:0 0 6px #00d68f4d}.dot-wrong{background:var(--red);border:1px solid var(--red);box-shadow:0 0 6px #ff3b5c4d}@keyframes dotPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.8}}.round-progress-result{gap:12px}.round-progress-result .round-dot{width:14px;height:14px}.session-end{text-align:center;padding:32px 16px;animation:slideUp .5s cubic-bezier(.16,1,.3,1)}.session-end-inner{display:flex;flex-direction:column;align-items:center;gap:16px}.session-end-character{height:240px;max-width:200px;object-fit:cover;object-position:center top;border-radius:16px;filter:drop-shadow(0 4px 30px rgba(0,0,0,.5));animation:standingSlide .6s cubic-bezier(.16,1,.3,1)}.session-end-banner{font-family:var(--font-mono);font-size:36px;font-weight:700;letter-spacing:.2em;color:var(--green);text-shadow:0 0 30px rgba(0,214,143,.5),0 0 60px rgba(0,214,143,.2);animation:bannerPop .5s cubic-bezier(.34,1.56,.64,1)}.gameover-banner{color:var(--red);text-shadow:0 0 30px rgba(255,59,92,.5),0 0 60px rgba(255,59,92,.2)}.session-end-dialogue{text-align:center;padding:12px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:320px}.session-end-name{font-size:11px;font-weight:700;color:var(--accent, var(--cyan));text-transform:uppercase;letter-spacing:.1em}.session-end-line{margin-top:4px;font-size:14px;line-height:1.6;color:var(--text)}.session-end-stats{display:flex;align-items:center;gap:20px;padding:16px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.session-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.session-stat-value{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--text)}.session-stat-label{font-size:12px;color:var(--text-dim)}.session-stat-divider{width:1px;height:36px;background:var(--border)}.session-hearts-result{color:var(--red);letter-spacing:.1em}.btn-new-round{width:100%;max-width:320px;padding:16px;margin-top:8px;background:var(--cyan);color:var(--bg);border:none;border-radius:var(--radius);font-size:16px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .2s;letter-spacing:.05em}.btn-new-round:hover{box-shadow:0 0 30px var(--cyan-dim);transform:translateY(-2px)}.btn-new-round:active{transform:translateY(0)}.gameover .btn-new-round{background:var(--red)}.gameover .btn-new-round:hover{box-shadow:0 0 30px #ff3b5c4d}.session-end-actions{display:flex;flex-direction:column;gap:8px;width:100%;max-width:320px}.session-end-actions .btn-new-round{margin-top:0}.btn-weak-drill{width:100%;padding:12px;background:transparent;color:var(--orange);border:1px solid rgba(255,159,10,.4);border-radius:var(--radius);font-size:14px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .2s;letter-spacing:.05em}.btn-weak-drill:hover{background:var(--orange-dim);border-color:var(--orange);box-shadow:0 0 20px #ff9f0a26}.session-missed{width:100%;max-width:400px;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.session-missed h4{font-size:13px;color:var(--orange);margin-bottom:8px;font-weight:700}.missed-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border)}.missed-item:last-child{border-bottom:none}.missed-id{font-family:var(--font-mono);font-size:11px;color:var(--red);min-width:50px}.missed-text{color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quiz-empty{text-align:center;padding:80px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.quiz-empty-icon{color:var(--green);opacity:.6;margin-bottom:8px}.quiz-empty p{font-size:18px;font-weight:700}.quiz-empty-sub{font-size:14px;color:var(--text-dim)}.dashboard h2{font-size:18px;font-weight:700;margin-bottom:20px}.dashboard h3{font-size:13px;font-family:var(--font-mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;margin:28px 0 14px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 16px;text-align:center;transition:border-color .2s}.stat-card:hover{border-color:var(--surface3)}.stat-value{font-family:var(--font-mono);font-size:32px;font-weight:500;color:var(--cyan);line-height:1}.stat-label{font-size:12px;color:var(--text-dim);margin-top:6px;font-weight:500}.stat-sub{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);opacity:.6;margin-top:2px}.mastery-bars{display:flex;flex-direction:column;gap:8px}.mastery-row{display:flex;align-items:center;gap:10px}.mastery-label{width:70px;font-size:12px;font-weight:700;text-align:right}.mastery-bar-bg{flex:1;height:6px;background:var(--surface);border-radius:3px;overflow:hidden}.mastery-bar-fill{height:100%;border-radius:3px;transition:width .5s cubic-bezier(.16,1,.3,1);min-width:2px}.mastery-count{width:30px;font-family:var(--font-mono);font-size:12px;color:var(--text-dim);text-align:right}.question-list{display:flex;flex-direction:column;gap:4px}.question-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);border-radius:var(--radius-sm);font-size:13px;border:1px solid transparent;transition:border-color .15s}.question-row:hover{border-color:var(--border)}.q-mastery-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.q-id{font-family:var(--font-mono);color:var(--text-dim);min-width:64px;font-size:12px}.q-text{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.q-stats{color:var(--text-dim);font-family:var(--font-mono);font-size:12px}.btn-export{margin-top:24px;width:100%;padding:12px;background:transparent;border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius);font-size:13px;font-family:var(--font-mono);letter-spacing:.05em;cursor:pointer;transition:all .2s}.btn-export:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 16px var(--cyan-dim)}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shakeX{0%,to{transform:translate(0)}10%{transform:translate(-8px)}30%{transform:translate(8px)}50%{transform:translate(-6px)}70%{transform:translate(6px)}90%{transform:translate(-2px)}}@keyframes spinSlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}@keyframes pulseRing{0%,to{opacity:.15}50%{opacity:.35}}@keyframes pulseText{0%,to{opacity:1}50%{opacity:.5}}.dashboard-section{margin-top:24px}.dashboard-section h3{font-size:16px;color:var(--text-dim);margin-bottom:12px}.empty-message{color:var(--text-dim);font-size:14px;text-align:center;padding:16px}.dashboard-summary{display:flex;align-items:center;gap:20px;background:var(--surface);border-radius:var(--radius);padding:20px}.accuracy-ring{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.accuracy-ring-arc{transition:stroke-dashoffset .8s ease-out}.accuracy-ring-label{font-size:12px;color:var(--text-dim);margin-top:4px}.summary-stats{flex:1;display:flex;flex-direction:column;gap:10px}.summary-row{display:flex;justify-content:space-between;align-items:center}.summary-label{font-size:13px;color:var(--text-dim)}.summary-value{font-size:15px;font-weight:700;color:var(--text)}.category-chart{display:block}.category-bar-fill{transition:width .5s ease-out}.weekly-trend-legend{display:flex;gap:16px;margin-bottom:8px;font-size:11px;color:var(--text-dim)}.legend-bar:before{content:"";display:inline-block;width:10px;height:10px;border-radius:2px;background:var(--surface2);margin-right:4px;vertical-align:middle}.legend-line:before{content:"";display:inline-block;width:14px;height:2px;background:var(--accent);margin-right:4px;vertical-align:middle}.weekly-trend{display:block}.trend-bar{transition:height .4s ease-out,y .4s ease-out}.trend-line{transition:all .4s ease-out}.weak-empty{text-align:center;padding:20px;background:var(--surface);border-radius:var(--radius)}.weak-empty-text{color:var(--green);font-size:14px;font-weight:600}.weak-list{display:flex;flex-direction:column;gap:8px}.weak-item{background:var(--surface);border-radius:var(--radius);padding:12px 14px;border-left:3px solid var(--red)}.weak-item-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.weak-dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0}.weak-id{font-family:monospace;font-size:12px;color:var(--text-dim)}.weak-accuracy{margin-left:auto;font-size:14px;font-weight:700;color:var(--red)}.weak-item-text{font-size:13px;color:var(--text);line-height:1.5;margin-bottom:4px}.weak-item-meta{font-size:11px;color:var(--text-dim);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.weak-tags{display:flex;gap:4px;flex-wrap:wrap}.weak-tag{background:var(--surface2);padding:1px 6px;border-radius:8px;font-size:10px}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}.badge-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 6px;border-radius:var(--radius);transition:all .2s}.badge-unlocked{background:var(--surface);border:1px solid var(--accent)}.badge-locked{background:var(--surface);border:1px solid var(--surface2);opacity:.45}.badge-icon{font-size:18px;font-weight:800;margin-bottom:4px;line-height:1}.badge-unlocked .badge-icon{color:var(--accent)}.badge-locked .badge-icon{color:var(--text-dim)}.badge-name{font-size:11px;font-weight:600;color:var(--text);margin-bottom:2px}.badge-date{font-size:10px;color:var(--text-dim)}.badge-desc{font-size:9px;color:var(--text-dim);line-height:1.3}@keyframes badgePop{0%{transform:scale(.8);opacity:0}60%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.badge-unlocked{animation:badgePop .4s ease-out}.quiz-result.correct{position:relative;overflow:visible}.quiz-result.correct:before,.quiz-result.correct:after{content:"";position:absolute;top:36px;left:50%;width:6px;height:6px;border-radius:50%;pointer-events:none;opacity:0}.quiz-result.correct:before{box-shadow:-30px -40px 0 var(--green),30px -35px 0 var(--cyan),-50px -10px 0 var(--purple),50px -15px 0 var(--green);animation:particleBurstA .7s cubic-bezier(.16,1,.3,1) forwards}.quiz-result.correct:after{box-shadow:20px -50px 0 var(--cyan),-20px -45px 0 var(--green),45px -30px 0 var(--purple),-45px -25px 0 var(--cyan);animation:particleBurstB .7s .05s cubic-bezier(.16,1,.3,1) forwards}@keyframes particleBurstA{0%{transform:scale(0);opacity:1}60%{opacity:1}to{transform:scale(2.5);opacity:0}}@keyframes particleBurstB{0%{transform:scale(0) rotate(45deg);opacity:1}60%{opacity:1}to{transform:scale(3) rotate(45deg);opacity:0}}.score-float{position:absolute;top:8px;right:24px;font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--green);text-shadow:0 0 12px rgba(0,214,143,.6);pointer-events:none;animation:floatUp 1s cubic-bezier(.16,1,.3,1) forwards}@keyframes floatUp{0%{transform:translateY(0);opacity:1}to{transform:translateY(-40px);opacity:0}}.combo-badge{transition:box-shadow .3s}.combo-badge.fire{box-shadow:0 0 8px #ff9f0a80,0 0 20px #ff9f0a40;animation:comboPulse .5s cubic-bezier(.34,1.56,.64,1),comboFire 1.2s ease-in-out infinite .5s}.combo-badge.ultra{background:linear-gradient(90deg,var(--cyan),var(--purple),var(--orange),var(--cyan));background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;box-shadow:0 0 12px #ff9f0a99,0 0 30px #7b61ff4d;animation:comboPulse .5s cubic-bezier(.34,1.56,.64,1),comboFire 1.2s ease-in-out infinite .5s,rainbowBorder 2s linear infinite;border:1px solid var(--cyan);border-image:linear-gradient(90deg,var(--cyan),var(--purple),var(--orange),var(--cyan)) 1;padding:2px 8px;border-radius:4px}@keyframes comboFire{0%,to{box-shadow:0 0 8px #ff9f0a66,0 0 16px #ff9f0a33}50%{box-shadow:0 0 14px #ff9f0ab3,0 0 28px #ff9f0a59,0 0 4px #ffc83266}}@keyframes rainbowBorder{0%{background-position:0% 50%}to{background-position:300% 50%}}.quiz-result.wrong:after,.quiz-result.timeout:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);background:var(--red);pointer-events:none;animation:redFlash .3s ease-out forwards;z-index:0}.quiz-result.wrong,.quiz-result.timeout{position:relative;overflow:hidden}@keyframes redFlash{0%{opacity:.15}to{opacity:0}}.choice.wrong{animation:shakeX .5s cubic-bezier(.36,.07,.19,.97)}.quiz-result.wrong .game-stage,.quiz-result.timeout .game-stage{animation:comboBreak .5s ease-out}@keyframes comboBreak{0%{filter:saturate(.2) brightness(.8)}to{filter:saturate(1) brightness(1)}}.view-enter{animation:viewFadeIn .3s cubic-bezier(.16,1,.3,1)}@keyframes viewFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.question-card{animation:questionSlideIn .25s cubic-bezier(.16,1,.3,1)}@keyframes questionSlideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.dashboard-actions{display:flex;gap:8px;margin-top:24px}.btn-share{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--cyan-dim);border:1px solid rgba(0,229,255,.3);color:var(--cyan);border-radius:var(--radius);font-size:13px;font-family:var(--font-mono);letter-spacing:.05em;cursor:pointer;transition:all .2s}.btn-share:hover{background:#00e5ff33;border-color:var(--cyan);box-shadow:0 0 20px var(--cyan-dim)}.share-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:fadeIn .2s ease-out}.share-wrapper{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:100%}.share-close-x{position:fixed;top:16px;right:16px;z-index:1001;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;color:var(--text);font-size:20px;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s}.share-close-x:hover{background:#fff3}.share-card{width:1200px;height:675px;background:linear-gradient(135deg,#06080f,#0d1220 40%,#0a0f1c);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;position:relative;flex-shrink:0}.share-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 50%,rgba(0,229,255,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(123,97,255,.04) 0%,transparent 50%);pointer-events:none}.share-card-content{flex:1;display:grid;grid-template-columns:60% 40%;position:relative;z-index:1}.share-stats{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 48px;gap:20px}.share-header{font-family:DM Mono,monospace;font-size:18px;letter-spacing:.2em;color:#00e5ff99;text-transform:uppercase}.share-ring{display:flex;align-items:center;justify-content:center}.share-today-stats{display:flex;align-items:center;gap:24px}.share-stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.share-stat-value{font-family:DM Mono,monospace;font-size:32px;font-weight:500;color:#e8edf5}.share-stat-streak{color:#ff9f0a}.share-stat-label{font-size:12px;color:#6b7a94;letter-spacing:.1em}.share-stat-divider{width:1px;height:40px;background:#ffffff1a}.share-slevel{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.1em}.share-date{font-family:DM Mono,monospace;font-size:13px;color:#6b7a94;letter-spacing:.08em}.share-character{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:24px 32px 0;position:relative}.share-teacher{height:420px;object-fit:contain;filter:drop-shadow(0 0 30px rgba(0,229,255,.15))}.share-bubble{position:absolute;top:32px;right:32px;max-width:220px;background:#00e5ff1a;border:1px solid rgba(0,229,255,.25);border-radius:16px 16px 4px;padding:12px 16px;font-size:14px;color:#e8edf5;line-height:1.6}.share-branding{display:flex;align-items:center;justify-content:space-between;padding:12px 32px;border-top:1px solid rgba(255,255,255,.06);position:relative;z-index:1}.share-brand-name{font-family:DM Mono,monospace;font-size:12px;letter-spacing:.25em;color:#ffffff40}.share-brand-ver{font-family:DM Mono,monospace;font-size:11px;color:#ffffff26}.share-actions{display:flex;gap:12px}.share-btn-save{padding:10px 28px;background:var(--cyan);color:#06080f;border:none;border-radius:8px;font-size:14px;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .2s}.share-btn-save:hover{background:#33ebff;box-shadow:0 0 24px #00e5ff66}.share-btn-save:disabled{opacity:.5;cursor:not-allowed}.share-btn-close{padding:10px 28px;background:transparent;color:#6b7a94;border:1px solid rgba(255,255,255,.12);border-radius:8px;font-size:14px;font-family:var(--font-body);cursor:pointer;transition:all .2s}.share-btn-close:hover{color:#e8edf5;border-color:#ffffff4d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(min-width:769px){.stage-area{gap:24px;margin:16px 0}.stage-standing{height:220px}.countdown{width:160px;height:160px}.countdown-num{font-size:68px}.quiz-bubble{padding:20px 24px}.quiz-question{font-size:18px}.choice{padding:16px 20px}.result-body{flex-direction:row;align-items:flex-start;gap:24px}.result-vn-col{width:320px;position:sticky;top:80px}.result-detail-col{flex:1}.vn-stage{min-height:360px}.vn-standing{height:360px}.result-explanation{font-size:17px;line-height:2}.result-practical{font-size:16px;line-height:1.9}.result-answer-text{font-size:16px}.phase-result .quiz-choices{opacity:0;max-height:0;overflow:hidden;margin:0;pointer-events:none;transition:opacity .2s,max-height .3s}}@media(max-width:768px){.app{max-width:100%;padding:0 16px 80px}.app-header h1{font-size:15px}.app-nav button{padding:5px 12px;font-size:12px}.countdown{width:120px;height:120px}.countdown-num{font-size:48px}.stage-standing{height:170px}.stage-area{gap:6px}.quiz-question{font-size:16px}.quiz-choices{flex-wrap:wrap}.choice{font-size:14px;padding:12px 14px}.vn-standing{height:280px}.vn-stage{min-height:260px}.vn-text{font-size:15px}.session-end-character{height:200px}.session-end-banner{font-size:30px}.result-banner{font-size:24px}.phase-result .quiz-choices{opacity:0;max-height:0;overflow:hidden;margin:0;pointer-events:none;transition:opacity .2s,max-height .3s}.result-explanation{font-size:16px;line-height:1.9}.result-practical{font-size:15px;line-height:1.8}.stats-grid{grid-template-columns:1fr 1fr}.stat-value{font-size:28px}.badge-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.share-card{transform:scale(.55);transform-origin:top center;margin-bottom:-303.75px}.gate-card{width:300px;padding:40px 28px 32px}}@media(max-width:480px){.app{max-width:100%;padding:0 12px 72px}.app-header{padding:10px 0;gap:4px}.app-brand{gap:6px;min-width:0}.app-logo svg{width:20px;height:20px}.app-header h1{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.teacher-switch{gap:3px}.teacher-btn{padding:3px 8px;font-size:11px}.app-nav{gap:3px;flex-shrink:0}.app-nav button{padding:5px 10px;font-size:11px;gap:3px;border-radius:16px}.badge{font-size:9px;padding:1px 5px}.countdown{width:110px;height:110px}.countdown-num{font-size:44px}.countdown-unit{font-size:9px}.judgment-text{font-size:42px}.session-end{padding:24px 12px}.session-end-character{height:180px}.session-end-banner{font-size:26px}.session-end-stats{gap:12px;padding:12px 16px}.session-stat-value{font-size:22px}.btn-new-round{font-size:14px;padding:14px}.hud-hearts{font-size:16px}.game-hud{padding:6px 10px}.hud-id{font-size:10px;padding:2px 6px}.hud-subject{font-size:11px}.stage-area{gap:4px;margin:4px 0}.stage-standing{height:150px}.quiz-bubble{padding:12px 16px}.quiz-question{font-size:17px;line-height:1.75;margin-bottom:20px}.quiz-tags{gap:4px;margin-bottom:16px}.quiz-tag{font-size:10px;padding:2px 8px}.quiz-choices{flex-direction:column;gap:8px;margin-bottom:20px}.choice{padding:12px 14px;font-size:14px;gap:10px;border-radius:12px}.choice-key{width:26px;height:26px;min-width:26px;border-radius:7px;font-size:11px}.choice-text{padding-top:2px}.phase-result .quiz-choices{opacity:0;max-height:0;overflow:hidden;margin:0;pointer-events:none;transition:opacity .2s,max-height .3s}.quiz-result{padding:20px 16px;border-radius:12px}.result-banner{font-size:22px;letter-spacing:.15em}.combo-badge{font-size:12px;margin-left:8px}.result-answer{padding:8px 12px}.result-answer-text{font-size:14px}.result-your-answer{padding:6px 12px}.result-explanation-box{padding:14px}.result-explanation{font-size:15px;line-height:1.85}.result-practical{font-size:14px;line-height:1.75;padding:10px 12px}.btn-next{padding:12px;font-size:14px;border-radius:12px;margin-top:12px}.vn-stage{min-height:240px;margin:10px 0 16px;border-radius:10px}.vn-standing{height:240px}.vn-dialogue-box{padding:12px 14px}.vn-name{font-size:10px;letter-spacing:.12em;padding:2px 6px;margin-bottom:4px}.vn-text{font-size:14px;line-height:1.55}.dashboard h2{font-size:16px;margin-bottom:16px}.dashboard h3{font-size:12px;margin:20px 0 10px}.dashboard-section{margin-top:20px}.dashboard-section h3{font-size:14px;margin-bottom:10px}.dashboard-summary{flex-direction:column;align-items:stretch;gap:16px;padding:16px}.accuracy-ring{align-self:center}.summary-label{font-size:12px}.summary-value{font-size:14px}.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-card{padding:14px 12px}.stat-value{font-size:24px}.stat-label{font-size:11px}.mastery-label{width:56px;font-size:11px}.mastery-count{width:26px;font-size:11px}.question-row{padding:8px 10px;font-size:12px;gap:6px}.q-id{min-width:52px;font-size:11px}.q-stats{font-size:11px}.category-chart,.weekly-trend{max-width:100%;overflow-x:auto}.weekly-trend-legend{gap:10px;font-size:10px}.weak-item{padding:10px 12px}.weak-item-text{font-size:12px}.weak-item-meta{font-size:10px}.weak-id{font-size:11px}.weak-accuracy{font-size:13px}.weak-tag{font-size:9px;padding:1px 5px}.badge-grid{grid-template-columns:repeat(3,1fr);gap:6px}.badge-card{padding:10px 4px}.badge-icon{font-size:16px}.badge-name{font-size:10px}.badge-date{font-size:9px}.badge-desc{font-size:8px}.btn-export{margin-top:0;padding:10px;font-size:12px}.dashboard-actions{flex-direction:column;gap:6px}.btn-share{font-size:12px;padding:10px}.share-overlay{align-items:flex-start;padding:60px 10px 20px}.share-card{transform:scale(.3);transform-origin:top center;margin-bottom:calc(-675px * .7);margin-left:-420px;margin-right:-420px}.share-actions{flex-direction:column;gap:8px;width:100%;max-width:360px}.share-btn-save,.share-btn-close{width:100%;text-align:center}.gate-card{width:100%;max-width:320px;padding:36px 24px 28px;gap:24px}.gate-icon{width:64px;height:64px}.gate-label{font-size:12px;letter-spacing:.25em}.gate-sub{font-size:10px}.gate-input{padding:12px 14px;font-size:14px}.gate-btn{padding:12px;font-size:12px}.gate-footer{font-size:10px}.app-footer{padding:8px;font-size:9px;gap:6px}.quiz-empty{padding:48px 16px;gap:10px}.quiz-empty p{font-size:16px}.quiz-empty-sub{font-size:13px}}@media(max-width:1024px){html{overflow-x:hidden}img,svg,canvas{max-width:100%;height:auto}.category-chart svg,.weekly-trend svg{max-width:100%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.countdown-pulse,.stage-lights,.gate-scan,.streak-fire{display:none}}.costume-manager{max-width:720px;margin:0 auto;padding:16px}.costume-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.costume-manager-header h2{font-size:20px;font-weight:700;color:#e8edf5;margin:0}.costume-xp-display{font-size:14px;color:#8899b0}.costume-xp-display strong{color:var(--accent, #00e5ff);font-family:DM Mono,monospace}.costume-grid{display:flex;flex-direction:column;gap:12px}.costume-card{background:#0f172ab3;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:16px;transition:border-color .2s}.costume-card.active{border-color:var(--accent, #00e5ff);box-shadow:0 0 16px #00e5ff1a}.costume-card.locked{opacity:.55}.costume-card-header{display:flex;gap:16px;align-items:center}.costume-preview{width:80px;height:100px;flex-shrink:0;border-radius:8px;overflow:hidden;background:#ffffff08;display:flex;align-items:center;justify-content:center}.costume-preview-img{width:100%;height:100%;object-fit:cover}.costume-preview-placeholder{font-size:11px;color:#6b7a94;text-align:center;padding:8px}.costume-info{flex:1;min-width:0}.costume-name{font-size:16px;font-weight:600;color:#e8edf5;margin:0 0 8px}.costume-lock-info{font-size:13px;color:#6b7a94;margin:0}.costume-xp-req{font-size:11px;opacity:.7;margin-left:4px}.costume-active-badge{display:inline-block;font-size:12px;font-weight:600;color:var(--accent, #00e5ff);background:#00e5ff1a;padding:4px 12px;border-radius:20px}.costume-equip-btn{font-size:13px;font-weight:600;color:#0f172a;background:var(--accent, #00e5ff);border:none;border-radius:8px;padding:6px 16px;cursor:pointer;transition:opacity .2s}.costume-equip-btn:hover{opacity:.85}.costume-admin-toggle{display:block;width:100%;margin-top:12px;padding:6px;font-size:11px;color:#6b7a94;background:none;border:1px dashed rgba(255,255,255,.08);border-radius:6px;cursor:pointer;transition:color .2s}.costume-admin-toggle:hover{color:#a0aec0}.costume-admin{margin-top:12px;padding:12px;background:#0003;border-radius:8px}.costume-admin-title{font-size:12px;font-weight:600;color:#8899b0;margin:0 0 8px;text-transform:uppercase;letter-spacing:.05em}.costume-file-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;border-bottom:1px solid rgba(255,255,255,.04)}.costume-file-row:last-child{border-bottom:none}.costume-file-label{width:48px;flex-shrink:0;color:#8899b0;font-weight:600}.costume-file-path{flex:1;color:#6b7a94;font-family:DM Mono,monospace;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.costume-file-status{flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}.costume-file-status.ok{color:#00d68f;background:#00d68f1a}.costume-file-status.missing{color:#ff6b6b;background:#ff6b6b1a}.costume-file-status.loading{color:#6b7a94}.progress-overview{background:#0f172ab3;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:16px;margin-bottom:16px}.progress-overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.progress-overview-title{font-size:14px;font-weight:700;color:#e8edf5;margin:0}.progress-overview-global{font-size:13px;color:#8899b0}.progress-overview-global strong{color:var(--accent, #00e5ff);font-family:DM Mono,monospace;font-size:15px}.progress-bar-track{width:100%;height:6px;background:#ffffff0f;border-radius:3px;margin-bottom:14px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent, #00e5ff);border-radius:3px;transition:width .5s ease;min-width:0}.progress-slot-list{display:flex;flex-direction:column;gap:6px}.progress-slot-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;background:#ffffff05;transition:background .2s}.progress-slot-row.done{background:#00d68f0d}.progress-slot-icon{font-size:14px;flex-shrink:0;width:20px;text-align:center}.progress-slot-name{font-size:13px;font-weight:600;color:#e8edf5;min-width:100px;flex-shrink:0}.progress-slot-files{flex:1;display:flex;flex-wrap:wrap;gap:4px}.progress-file-dot{font-size:10px;padding:2px 6px;border-radius:3px;font-weight:500}.progress-file-dot.ok{color:#00d68f;background:#00d68f1f}.progress-file-dot.missing{color:#ff6b6b;background:#ff6b6b1f}.progress-file-dot.loading{color:#6b7a94;background:#ffffff0a}.progress-slot-count{font-size:12px;font-family:DM Mono,monospace;color:#8899b0;flex-shrink:0;min-width:28px;text-align:right}@media(max-width:480px){.costume-manager{padding:12px}.costume-manager-header{flex-direction:column;align-items:flex-start;gap:4px}.costume-preview{width:64px;height:80px}.costume-name{font-size:14px}.costume-file-path{font-size:10px}.progress-overview-header{flex-direction:column;align-items:flex-start;gap:4px}.progress-slot-name{min-width:72px;font-size:12px}.progress-file-dot{font-size:9px;padding:1px 4px}}.game-stage[data-subject=regulation]{--accent: #0099ff}.game-stage[data-subject=regulation]:before{background-image:url(../bg/regulation.jpg)}.game-stage[data-subject=regulation] .stage-lights{background:radial-gradient(ellipse 60% 80% at 20% 0%,rgba(0,153,255,.12) 0%,transparent 70%),radial-gradient(ellipse 60% 80% at 80% 0%,rgba(0,180,255,.08) 0%,transparent 70%),radial-gradient(ellipse 80% 50% at 50% 0%,rgba(0,153,255,.1) 0%,transparent 50%),linear-gradient(180deg,rgba(10,22,40,.8) 0%,transparent 60%)}.game-stage[data-subject=weather-mechanics],.game-stage[data-subject=safety]{--accent: #64b5f6}.game-stage[data-subject=weather-mechanics]:before,.game-stage[data-subject=safety]:before{background-image:url(../bg/weather.jpg)}.game-stage[data-subject=weather-mechanics] .stage-lights,.game-stage[data-subject=safety] .stage-lights{background:radial-gradient(ellipse 70% 60% at 30% 10%,rgba(100,181,246,.1) 0%,transparent 70%),radial-gradient(ellipse 50% 70% at 70% 0%,rgba(144,164,186,.08) 0%,transparent 70%),radial-gradient(ellipse 100% 40% at 50% 0%,rgba(100,140,180,.06) 0%,transparent 50%),linear-gradient(180deg,rgba(15,21,32,.9) 0%,transparent 60%)}.game-stage[data-subject=system-technology]{--accent: #7b61ff}.game-stage[data-subject=system-technology]:before{background-image:url(../bg/system.jpg)}.game-stage[data-subject=system-technology] .stage-lights{background:radial-gradient(ellipse 50% 70% at 15% 0%,rgba(123,97,255,.12) 0%,transparent 70%),radial-gradient(ellipse 50% 70% at 85% 0%,rgba(0,229,255,.08) 0%,transparent 70%),radial-gradient(ellipse 60% 40% at 50% 0%,rgba(123,97,255,.1) 0%,transparent 50%),linear-gradient(180deg,rgba(10,8,24,.8) 0%,transparent 60%)}.game-stage[data-subject=operator-crew]{--accent: #ff9f0a}.game-stage[data-subject=operator-crew]:before{background-image:url(../bg/operator.jpg)}.game-stage[data-subject=operator-crew] .stage-lights{background:radial-gradient(ellipse 60% 70% at 20% 0%,rgba(255,159,10,.1) 0%,transparent 70%),radial-gradient(ellipse 60% 70% at 80% 0%,rgba(255,120,50,.06) 0%,transparent 70%),radial-gradient(ellipse 80% 40% at 50% 0%,rgba(255,159,10,.08) 0%,transparent 50%),linear-gradient(180deg,rgba(15,10,8,.8) 0%,transparent 60%)}.game-stage[data-subject=risk-management]{--accent: #ff3b5c}.game-stage[data-subject=risk-management]:before{background-image:url(../bg/risk.jpg)}.game-stage[data-subject=risk-management] .stage-lights{background:radial-gradient(ellipse 50% 70% at 25% 0%,rgba(255,59,92,.12) 0%,transparent 70%),radial-gradient(ellipse 50% 70% at 75% 0%,rgba(180,40,80,.08) 0%,transparent 70%),radial-gradient(ellipse 70% 40% at 50% 0%,rgba(255,59,92,.08) 0%,transparent 50%),linear-gradient(180deg,rgba(18,8,8,.8) 0%,transparent 60%)}.exam-select{max-width:480px;margin:2rem auto;padding:1.5rem;text-align:center}.exam-select h2{font-size:1.5rem;margin-bottom:.5rem}.exam-desc{color:#fff9;margin-bottom:1.5rem;font-size:.9rem}.exam-cards{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.exam-card{display:flex;flex-direction:column;gap:.3rem;padding:1.2rem;border:1px solid rgba(255,255,255,.15);border-radius:12px;background:#ffffff0d;cursor:pointer;transition:all .2s}.exam-card:hover:not(:disabled){background:#ffffff1a;border-color:var(--accent, #00e5ff)}.exam-card:disabled{opacity:.4;cursor:not-allowed}.exam-card-title{font-size:1.2rem;font-weight:600}.exam-card-detail{font-size:.85rem;color:#fff9}.exam-card-lock{font-size:.75rem;color:#ff3b5c}.exam-back{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:.9rem}.exam-running{max-width:640px;margin:0 auto;padding:0 1rem;display:flex;flex-direction:column;min-height:calc(100dvh - 80px)}.exam-timer{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;background:#14141ef2;border-bottom:1px solid rgba(255,255,255,.1);border-radius:0 0 8px 8px}.exam-timer.warning{border-color:#ff9f0a}.exam-timer.critical{border-color:#ff3b5c;animation:pulse 1s infinite}@keyframes pulse{50%{opacity:.7}}.exam-timer-label{font-size:.8rem;color:#ffffff80}.exam-timer-time{font-size:1.4rem;font-weight:700;font-variant-numeric:tabular-nums}.exam-timer-progress{font-size:.8rem;color:#ffffff80}.exam-nav{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.8rem 0}.exam-nav button{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#fff;font-size:1.1rem;cursor:pointer}.exam-nav button:disabled{opacity:.3;cursor:not-allowed}.exam-nav-current{font-size:.9rem;color:#ffffffb3}.exam-question{flex:1;padding:1rem 0}.exam-question-text{font-size:1rem;line-height:1.7;margin-bottom:1.2rem}.exam-choices{display:flex;flex-direction:column;gap:.6rem}.exam-choice{display:flex;align-items:flex-start;gap:.8rem;padding:.9rem 1rem;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff08;text-align:left;cursor:pointer;transition:all .15s}.exam-choice:hover{background:#ffffff14}.exam-choice.selected{border-color:var(--accent, #00e5ff);background:#00e5ff14}.exam-choice-key{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(255,255,255,.3);font-size:.75rem;font-weight:600}.exam-choice.selected .exam-choice-key{background:var(--accent, #00e5ff);color:#000;border-color:transparent}.exam-choice-text{font-size:.9rem;line-height:1.5}.exam-footer{padding:.8rem 0 1.5rem;display:flex;flex-direction:column;gap:.8rem;align-items:center}.exam-dots{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:100%}.exam-dot{width:8px;height:8px;border-radius:50%;background:#ffffff26;cursor:pointer;transition:all .15s}.exam-dot.answered{background:var(--accent, #00e5ff);opacity:.6}.exam-dot.current{background:#fff;transform:scale(1.4)}.exam-submit{padding:.7rem 2rem;border-radius:8px;border:1px solid var(--accent, #00e5ff);background:#00e5ff1a;color:#fff;font-size:.9rem;cursor:pointer}.exam-submit:disabled{opacity:.3;cursor:not-allowed}.exam-result{max-width:640px;margin:1.5rem auto;padding:0 1rem 3rem}.exam-result-header{text-align:center;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem}.exam-result-header.pass{background:#00c8531a;border:1px solid rgba(0,200,83,.3)}.exam-result-header.fail{background:#ff3b5c1a;border:1px solid rgba(255,59,92,.3)}.exam-result-header h2{font-size:1.8rem;margin-bottom:.5rem}.exam-result-header.pass h2{color:#00c853}.exam-result-header.fail h2{color:#ff3b5c}.exam-score{font-size:1.1rem;margin-bottom:.3rem}.exam-time{font-size:.85rem;color:#ffffff80}.exam-result h3{font-size:1rem;margin:1.5rem 0 .8rem;color:#fffc}.exam-categories{display:flex;flex-direction:column;gap:.5rem}.exam-cat-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.exam-cat-name{flex:0 0 160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffffb3}.exam-cat-score{flex:0 0 80px;text-align:right;font-variant-numeric:tabular-nums}.exam-cat-bar{flex:1;height:6px;border-radius:3px;background:#ffffff1a;overflow:hidden}.exam-cat-fill{height:100%;border-radius:3px;background:var(--accent, #00e5ff);transition:width .4s}.exam-wrong-list{display:flex;flex-direction:column;gap:.5rem}.exam-wrong-item{border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden}.exam-wrong-item summary{padding:.7rem 1rem;cursor:pointer;display:flex;gap:.5rem;align-items:center;font-size:.85rem}.exam-wrong-num{flex-shrink:0;color:#ff3b5c;font-weight:600}.exam-wrong-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffffb3}.exam-wrong-detail{padding:.8rem 1rem;background:#ffffff05;border-top:1px solid rgba(255,255,255,.05)}.exam-wrong-q{font-size:.9rem;margin-bottom:.6rem}.exam-wrong-choices{list-style:none;padding:0;margin:0 0 .8rem;display:flex;flex-direction:column;gap:.3rem;font-size:.85rem}.exam-wrong-choices li{padding:.3rem .5rem;border-radius:4px}.exam-wrong-choices li.correct{background:#00c85326;color:#00c853}.exam-wrong-choices li.wrong{background:#ff3b5c1a;color:#ff3b5c;text-decoration:line-through}.exam-wrong-explain{font-size:.85rem;color:#ffffffb3;line-height:1.6}.exam-wrong-source{font-size:.75rem;color:#fff6;margin-top:.3rem}.exam-result-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.exam-result-actions button{padding:.7rem 1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#fff;cursor:pointer}
