.tabbar{position:fixed;left:0;right:0;bottom:0;display:flex;justify-content:space-around;align-items:stretch;height:calc(var(--tabbar-h) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--bg-card);border-top:var(--border-hairline);z-index:50}.tabbar-item{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px;min-height:44px;text-decoration:none;color:var(--ink-60);transition:color var(--dur-fast) var(--ease-out-quart)}.tabbar-item:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.tabbar-indicator{position:absolute;top:0;left:50%;transform:translate(-50%) scaleX(0);width:28px;height:2px;background:var(--primary);border-radius:2px;transition:transform var(--dur-base) var(--ease-out-quart)}.tabbar-item--active{color:var(--ink)}.tabbar-item--active .tabbar-indicator{transform:translate(-50%) scaleX(1)}.tabbar-label{font-family:var(--font-display);font-size:var(--fs-caption);font-weight:var(--fw-semi);letter-spacing:var(--ls-caption)}.with-tabbar{padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom,0px) + 8px);min-height:100dvh}:root{--ink: rgba(17, 20, 26, .92);--ink-60: rgba(17, 20, 26, .6);--ink-40: rgba(17, 20, 26, .4);--ink-20: rgba(17, 20, 26, .2);--ink-09: rgba(17, 20, 26, .09);--bg-canvas: #fafbfc;--bg-card: #ffffff;--type-electric: #FAC000;--type-water: #2980EF;--type-grass: #3FA129;--type-psychic: #F584A8;--type-ground: #915121;--type-dragon: #5060E1;--type-electric-surface: rgba(250, 192, 0, .08);--type-water-surface: rgba(41, 128, 239, .08);--type-grass-surface: rgba(63, 161, 41, .08);--type-psychic-surface: rgba(245, 132, 168, .08);--type-ground-surface: rgba(145, 81, 33, .08);--type-dragon-surface: rgba(80, 96, 225, .08);--primary: #2d3a8c;--primary-hover: #252f73;--primary-surface: rgba(45, 58, 140, .06);--success: #3FA129;--success-surface: rgba(63, 161, 41, .08);--danger: #E62829;--danger-surface: rgba(230, 40, 41, .08);--warning: #FAC000;--warning-surface: rgba(250, 192, 0, .1);--font-display: "Pretendard", -apple-system, system-ui, sans-serif;--font-mono: "SF Mono", "Menlo", "Consolas", monospace;--fs-hero: 56px;--fs-title-1: 32px;--fs-title-2: 22px;--fs-body-l: 18px;--fs-body: 15px;--fs-label: 13px;--fs-caption: 11px;--fw-black: 900;--fw-bold: 700;--fw-semi: 600;--fw-medium: 500;--fw-regular: 400;--ls-caption: .6px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 24px;--border-hairline: 1px solid var(--ink-09);--border-strong: 2px solid var(--ink);--shadow-pop: 0 4px 12px rgba(17, 20, 26, .12);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--dur-fast: .15s;--dur-base: .22s;--dur-slow: .32s;--tabbar-h: 60px;--bg: var(--bg-canvas);--text: var(--ink);--text-secondary: var(--ink-60);--text-tertiary: var(--ink-40);--text-on-primary: #ffffff;--border: var(--ink-09);--border-light: var(--ink-09);--radius: var(--r-md);--radius-sm: var(--r-sm);--radius-lg: var(--r-lg);--accent: var(--type-water);--accent-surface: var(--type-water-surface);--primary-light: #4f5cb3;--shadow-sm: var(--shadow-pop);--shadow-md: var(--shadow-pop);--shadow-lg: var(--shadow-pop)}.page-header{padding:var(--sp-6) var(--sp-5) var(--sp-4)}.page-title{margin:0;font-family:var(--font-display);font-size:var(--fs-title-1);font-weight:var(--fw-black);color:var(--ink);letter-spacing:-.01em}.page-subtitle{margin:var(--sp-1) 0 0;font-size:var(--fs-body);color:var(--ink-60)}.page-body{padding:0 var(--sp-5) var(--sp-6)}.card-surface{background:var(--bg-card);border:var(--border-hairline);border-radius:var(--r-lg);padding:var(--sp-5)}.card-label{font-size:var(--fs-caption);font-weight:var(--fw-semi);color:var(--ink-60);letter-spacing:var(--ls-caption);text-transform:uppercase;margin-bottom:var(--sp-2)}.stat-number{font-family:var(--font-display);font-size:var(--fs-title-1);font-weight:var(--fw-black);color:var(--ink);line-height:1;font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum" 1,"lnum" 1}.btn-danger-outline{width:100%;padding:var(--sp-3) var(--sp-4);min-height:48px;background:var(--bg-card);border:1.5px solid var(--danger);border-radius:var(--r-md);color:var(--danger);font-family:var(--font-display);font-size:var(--fs-body);font-weight:var(--fw-semi);cursor:pointer;transition:background var(--dur-fast) var(--ease-out-quart)}.btn-danger-outline:hover{background:var(--danger-surface)}.btn-danger-outline:focus-visible{outline:2px solid var(--danger);outline-offset:2px}.mono-digit,.stat-number{font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum" 1,"lnum" 1}@media (prefers-reduced-motion: reduce){:root{--dur-fast: 0ms;--dur-base: 0ms;--dur-slow: 0ms}}:root{--primary: #2d3a8c;--primary-light: #4f5cb3;--primary-surface: #eef0f8;--primary-hover: #252f73;--accent: #00c4a3;--accent-light: #b2f0e4;--accent-surface: #e8faf6;--bg: #f8f9fb;--bg-card: #ffffff;--bg-elevated: #ffffff;--text: #1a1e2e;--text-secondary: #5e6478;--text-tertiary: #9098ad;--text-on-primary: #ffffff;--border: #e3e6ed;--border-light: #eff1f5;--success: #22a861;--success-surface: #edf9f2;--danger: #ef4444;--danger-surface: #fef2f2;--warning: #f59e0b;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(26,30,46,.06);--shadow-md: 0 4px 16px rgba(26,30,46,.08);--shadow-lg: 0 12px 40px rgba(26,30,46,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input{font-family:inherit}img{max-width:100%;height:auto}.page-center{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px}.loading{color:var(--text-secondary);font-size:16px}.btn-primary{background:var(--primary);color:var(--text-on-primary);border:none;border-radius:var(--radius-sm);padding:12px 24px;min-height:44px;font-size:16px;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary.btn-lg{padding:16px 32px;font-size:18px;border-radius:var(--radius)}.btn-secondary{background:var(--bg);color:var(--primary);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:12px 24px;min-height:44px;font-size:16px;font-weight:600;transition:border-color .15s,background .15s}.btn-secondary:hover{background:var(--primary-surface);border-color:var(--primary-light)}.btn-ghost{background:none;color:var(--text-secondary);border:none;padding:10px 16px;min-height:44px;font-size:15px;font-weight:500;transition:color .15s}.btn-ghost:hover{color:var(--text)}.btn-sm{padding:10px 16px;min-height:40px;font-size:14px}.btn-success{background:var(--success);color:#fff;border:none;border-radius:var(--radius-sm);padding:14px 24px;min-height:48px;font-size:16px;font-weight:600}.btn-fail{background:var(--danger);color:#fff;border:none;border-radius:var(--radius-sm);padding:14px 24px;min-height:48px;font-size:16px;font-weight:600}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px;background:var(--bg)}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:40px 32px;width:100%;max-width:380px;box-shadow:var(--shadow-lg);text-align:center}.login-title{font-size:28px;font-weight:800;color:var(--primary);margin-bottom:4px}.login-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:14px 16px;font-size:16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--primary)}.login-input--pin{text-align:center;font-size:24px;letter-spacing:12px;font-weight:700}.login-error{background:var(--danger-surface);color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;text-align:left}.login-btn{width:100%;padding:16px;font-size:17px;font-weight:700;background:var(--primary);color:var(--text-on-primary);border:none;border-radius:var(--radius-sm);margin-top:8px;transition:background .15s}.login-btn:hover{background:var(--primary-hover)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-academy-select{cursor:pointer;text-align:left;color:var(--text-secondary)}.login-academy-select:not(:empty){color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000073;display:flex;align-items:center;justify-content:center;padding:24px}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:360px;max-height:70vh;box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:18px;font-weight:700;margin:0}.modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;line-height:1}.academy-list{list-style:none;margin:0;padding:8px 0;overflow-y:auto}.academy-item{display:flex;align-items:center;gap:12px;padding:14px 20px;cursor:pointer;transition:background .12s}.academy-item:hover{background:var(--bg-hover, #f5f5f5)}.academy-item.selected{background:var(--primary-surface, #e8f0fe)}.academy-icon{font-size:22px}.academy-name{font-size:16px;font-weight:500}.academy-empty{color:var(--text-secondary);justify-content:center;cursor:default;font-size:14px}.play-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:10}.play-counter{font-size:15px;font-weight:600;color:var(--text-secondary)}.gacha-play-page{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.play-center{flex:1;display:flex;align-items:center;justify-content:center}.play-card{flex:1;display:flex;flex-direction:column;padding:24px 16px;gap:20px}.play-card-badge{align-self:flex-start;background:var(--primary-surface);color:var(--primary);padding:4px 12px;border-radius:var(--radius-full);font-size:13px;font-weight:600}.play-card-question{flex:1;display:flex;align-items:center;justify-content:center;min-height:200px}.play-card-img{max-height:300px;border-radius:var(--radius-sm)}.play-card-text{font-size:20px;line-height:1.6;text-align:center;word-break:break-word}.play-answer-area{display:flex;flex-direction:column;gap:12px}.play-answer-input{width:100%;padding:14px 16px;min-height:48px;font-size:18px;border:2px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);outline:none;text-align:center;transition:border-color .15s}.play-answer-input:focus{border-color:var(--primary)}.play-answer-buttons{display:flex;gap:10px}.play-answer-buttons .btn-primary{flex:1}.play-answer-buttons .btn-ghost{padding:12px 16px;font-size:15px;border:1.5px solid var(--border);border-radius:var(--radius-sm)}.play-reveal{background:var(--accent-surface);border-radius:var(--radius);padding:20px;text-align:center}.play-reveal--small{padding:14px}.play-reveal-label{font-size:13px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.play-reveal-answer{font-size:20px;font-weight:600}.play-self-check{text-align:center}.play-self-check p{font-size:15px;color:var(--text-secondary);margin-bottom:12px}.play-self-buttons{display:flex;gap:10px}.play-self-buttons button{flex:1}.play-feedback{display:flex;align-items:center;justify-content:center;gap:12px;padding:24px;border-radius:var(--radius);font-size:24px;font-weight:800}.play-feedback--correct{background:var(--success-surface);color:var(--success)}.play-feedback--wrong{background:var(--danger-surface);color:var(--danger)}.play-feedback-icon{font-size:36px}.play-card-question-small{text-align:center;font-size:15px;color:var(--text-secondary)}.play-box-change{text-align:center;font-size:15px;font-weight:600;color:var(--text-secondary);padding:8px}.play-next-btn{align-self:stretch}.play-done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;gap:12px;text-align:center}.play-done-icon{font-size:56px}.play-done h2{font-size:22px;font-weight:700}.play-done p{font-size:15px;color:var(--text-secondary)}.play-error{color:var(--danger)}.proof-play-page{max-width:560px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.proof-play-title{padding:20px 16px 0}.proof-play-title h2{font-size:19px;font-weight:700}.proof-play-meta{display:block;font-size:13px;color:var(--text-tertiary);margin-top:4px}.proof-play-desc{padding:8px 16px 0;font-size:15px;color:var(--text-secondary);line-height:1.6}.proof-play-desc-img{margin:12px 16px 0;border-radius:var(--radius-sm);max-height:240px}.proof-play-instruction{padding:16px 16px 8px;font-size:14px;color:var(--text-tertiary);text-align:center;font-weight:500}.proof-play-actions{padding:20px 16px 32px;display:flex;gap:10px;justify-content:center}.proof-play-actions .btn-primary{flex:1;max-width:320px}.proof-play-actions .btn-secondary{flex:1;max-width:160px}.ordering-list{padding:12px 16px;display:flex;flex-direction:column;gap:8px}.ordering-step{display:flex;align-items:center;gap:10px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 12px;box-shadow:var(--shadow-sm);touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab;transition:border-color .15s,box-shadow .15s}.ordering-step:active{cursor:grabbing;border-color:var(--primary-light);box-shadow:var(--shadow-md)}.ordering-step-handle{color:var(--text-tertiary);font-size:18px;flex-shrink:0}.ordering-step-num{background:var(--primary-surface);color:var(--primary);width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.ordering-step-content{flex:1;font-size:15px;line-height:1.5;min-width:0;overflow-wrap:break-word}.ordering-step-img{max-height:120px;border-radius:var(--radius-sm)}.fillblank-steps{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.fillblank-step{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}.fillblank-step--active{border-color:var(--primary-light)}.fillblank-step-num{display:inline-block;font-size:12px;font-weight:700;color:var(--primary);background:var(--primary-surface);padding:2px 10px;border-radius:var(--radius-full);margin-bottom:8px}.fillblank-step-body{font-size:15px;line-height:1.7}.fillblank-step-img{max-height:160px;border-radius:var(--radius-sm);margin-bottom:8px}.fillblank-step-content{display:inline;line-height:2.2}.fillblank-input{display:inline-block;min-width:96px;width:auto;padding:8px 12px;min-height:40px;font-size:16px;font-weight:600;border:none;border-bottom:2.5px solid var(--primary);background:var(--primary-surface);color:var(--primary);text-align:center;outline:none;border-radius:4px 4px 0 0;margin:0 4px;vertical-align:baseline;transition:border-color .15s,background .15s;field-sizing:content}.fillblank-input:focus{background:#dde0f3;border-color:var(--primary-hover)}.fillblank-input::placeholder{color:var(--text-tertiary);font-weight:400}.proof-result{padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:20px}.proof-result-score{font-size:48px;font-weight:800}.proof-result-score.good{color:var(--success)}.proof-result-score.low{color:var(--danger)}.proof-result-detail{text-align:center;font-size:15px;color:var(--text-secondary);display:flex;flex-direction:column;gap:4px}.proof-result-steps{width:100%;display:flex;flex-direction:column;gap:6px}.proof-result-step{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:500}.proof-result-step.correct{background:var(--success-surface);color:var(--success)}.proof-result-step.wrong{background:var(--danger-surface);color:var(--danger)}.proof-result-submitted{max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.katex{font-size:1em}.katex-display{margin:8px 0}@media (max-width: 400px){.login-card{padding:32px 20px}.home-modes{gap:8px}.home-mode-card{padding:16px 8px}.home-proof-item{flex-direction:column;align-items:stretch}.home-proof-actions{justify-content:flex-end}.ordering-step{padding:12px 10px}.fillblank-input{min-width:72px}}
