@media(max-width:768px){*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}}@media(min-width:769px){*{scrollbar-width:thin;scrollbar-color:rgba(99,102,131,.4) transparent}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#5865f259,#8b5cf659);border-radius:3px}*::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#5865f28c,#8b5cf68c)}*::-webkit-scrollbar-corner{background:transparent}}#root{max-width:900px;margin:0 auto;min-height:100vh}html,body{background:#0d1117}.user-info{font-weight:700;font-size:1.1rem;padding:.5rem 1rem;background-color:#daf0f7;border-radius:8px;color:#004d7a}.btn{display:inline-block;font-weight:600;padding:10px 16px;border:none;border-radius:8px;background-color:#5844ff;color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:1rem;transition:background-color .2s ease}.btn.primary{background-color:#5844ff}.btn:hover{background-color:#4536d6}.google-btn{background-color:#db4437;color:#fff;border:none;padding:10px;border-radius:8px;cursor:pointer;font-weight:600;width:100%;font-size:1rem;margin-top:10px}.google-btn:hover{background-color:#c23321}.form{background-color:#fff;padding:1.6rem 2rem;border-radius:8px;box-shadow:0 0 8px #0000001a;max-width:360px;margin:0 auto 20px}.form h2{margin-bottom:1rem;font-weight:700;font-size:1.2rem}.form label{display:block;margin-top:1rem;font-weight:600;font-size:1rem}.form input{width:100%;padding:.5rem .7rem;margin-top:.2rem;font-size:1rem;border-radius:6px;border:1px solid #ccc;box-sizing:border-box;outline-offset:2px;outline-color:#6c63ff}.form input:focus{border-color:#5844ff;outline:none}.form button{margin-top:2rem;width:100%}.error-message{color:#ff3860;font-weight:700;margin-top:10px;text-align:center}:root{--bg-primary: #06080d;--bg-secondary: #0d1117;--bg-card: rgba(13, 17, 23, .85);--border-subtle: rgba(88, 210, 255, .45);--border-glow: rgba(88, 210, 255, .8);--text-bright: #f0f6fc;--text-muted: #8b949e;--accent-blue: #58a6ff;--accent-cyan: #79c0ff;--accent-green: #3fb950;--accent-yellow: #d29922;--accent-orange: #f0883e;--accent-red: #f85149;--accent-purple: #a371f7;--accent-pink: #ff7eb6;--glow-blue: 0 0 30px rgba(88, 166, 255, .3);--glow-cyan: 0 0 25px rgba(121, 192, 255, .25);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans KR,Outfit,ui-sans-serif,system-ui,sans-serif;background:var(--bg-primary);color:var(--text-bright);height:100svh;overflow:hidden}.bg-layer{position:fixed;inset:0;pointer-events:none;z-index:0}.bg-layer:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse 800px 600px at 20% 30%,rgba(88,166,255,.08) 0%,transparent 50%),radial-gradient(ellipse 600px 800px at 80% 70%,rgba(167,113,247,.06) 0%,transparent 50%),radial-gradient(ellipse 500px 500px at 50% 50%,rgba(63,185,80,.04) 0%,transparent 50%);animation:bgShift 30s ease-in-out infinite}@keyframes bgShift{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(2%,-2%) rotate(1deg)}66%{transform:translate(-2%,2%) rotate(-1deg)}}.particles{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:0}.particle{position:absolute;width:4px;height:4px;background:var(--accent-cyan);border-radius:50%;opacity:0;animation:particleFloat 12s infinite}@keyframes particleFloat{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:.6}90%{opacity:.6}to{transform:translateY(-10vh) scale(1);opacity:0}}.app-container{position:relative;z-index:1;height:100svh;display:flex;flex-direction:column;overflow:hidden}header{padding:10px 14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;border-bottom:1px solid var(--border-subtle);background:#0d1117fa;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.logo-icon{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover}.brand-title{font-family:Outfit,sans-serif;font-size:20px;font-weight:800;letter-spacing:.5px;background:linear-gradient(90deg,var(--text-bright),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.day-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 10px;border-radius:var(--radius-md);flex-shrink:0;background:linear-gradient(135deg,var(--accent-green),#2ea043);box-shadow:0 0 20px #3fb9504d}.day-badge.green{background:linear-gradient(135deg,var(--accent-green),#2ea043);box-shadow:0 0 20px #3fb9504d}.day-badge.gray{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 0 20px #6b72804d}.day-badge .day-label{font-size:8px;font-weight:700;letter-spacing:1px;color:#fffc}.day-badge .day-number{font-family:Outfit,sans-serif;font-size:18px;font-weight:800;color:#fff;line-height:1}.header-stats{display:flex;gap:6px;flex-wrap:wrap;flex:1}.header-actions{display:flex;gap:4px;flex-shrink:0;margin-left:auto}.header-actions .btn-icon{background:none;border:1px solid var(--border-subtle);font-size:1.15rem;cursor:pointer;padding:4px 7px;border-radius:var(--radius-sm);transition:background .15s}.header-actions .btn-icon:hover{background:#ffffff14}.header-actions .btn-icon.active{border-color:#58a6ff;box-shadow:0 0 8px #58a6ff80}#logoutBtn{color:#fff}.stat-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:999px;font-size:12px;color:var(--text-muted);white-space:nowrap}.stat-chip b{color:var(--text-bright);font-weight:600}.stat-chip.blue b{color:var(--accent-blue)}.stat-chip.green b{color:var(--accent-green)}.stat-chip.yellow b{color:var(--accent-yellow)}.stat-chip.purple b{color:var(--accent-purple)}.stat-chip.red b{color:var(--accent-red)}main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}main>.panel:first-child{order:2}main>.game-panel{order:1}.panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;overflow:hidden}.panel-header{padding:14px 18px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:10px;background:linear-gradient(180deg,rgba(255,255,255,.03),transparent)}.panel-header h2{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}.panel-body{padding:16px 18px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;flex:1;position:relative}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px}.form-row.single{grid-template-columns:1fr}.form-row.triple{grid-template-columns:repeat(3,1fr)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}input[type=text],input[type=number],select{padding:10px 12px;background:#0000004d;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-bright);font-size:13px;font-family:inherit;transition:border-color .2s,box-shadow .2s}input:focus,select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #58a6ff26}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#0003;border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:14px}.toggle-row.toggle-hint{background:#58d2ff14;border-color:#58d2ff40}.toggle-row.toggle-tts{background:#3fb95014;border-color:#3fb95040}.toggle-row.toggle-ai{background:#a771f714;border-color:#a771f740}input.input-yellow{color:var(--accent-yellow)!important;font-weight:700}input.input-blue{color:var(--accent-blue)!important;font-weight:700}input.input-green{color:var(--accent-green)!important;font-weight:700}.toggle-row .info{display:flex;flex-direction:column;gap:2px}.toggle-row .info b{font-size:13px;font-weight:600}.toggle-row .info span{font-size:11px;color:var(--text-muted)}.switch{position:relative;width:44px;height:24px;cursor:pointer}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;inset:0;background:#ffffff1a;border-radius:999px;transition:.2s}.switch .slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:var(--text-muted);border-radius:50%;transition:.2s}.switch input:checked+.slider{background:var(--accent-blue)}.switch input:checked+.slider:before{transform:translate(20px);background:var(--text-bright)}.btn{padding:10px 16px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:#ffffff0d;color:var(--text-bright);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.btn:hover{background:#ffffff1a;border-color:var(--border-glow)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed;border-color:#ffffff1a;color:#ffffff80}.btn.primary{background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));border:none;box-shadow:var(--glow-blue)}.btn.primary:hover{filter:brightness(1.1)}.btn.danger{border-color:#f8514966;color:var(--accent-red)}.btn.danger:hover{background:#f8514926}.btn.active{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border:none;box-shadow:0 0 25px #79c0ff66}.btn.active:hover{filter:brightness(1.1)}.btn-row{display:flex;gap:10px}.info-box{padding:12px 14px;background:#0003;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.info-box.warning{border-color:#f851494d;background:#f8514914}.info-box .title{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.info-box .title b{font-size:12px}.info-box p{font-size:11px;color:var(--text-muted);line-height:1.6}.kbd{display:inline-block;padding:2px 6px;background:#0006;border:1px solid var(--border-subtle);border-radius:4px;font-family:JetBrains Mono,monospace;font-size:10px}.game-panel{display:flex;flex-direction:column;min-height:0;background:transparent;border:none;border-radius:0;-webkit-backdrop-filter:none;backdrop-filter:none}.game-panel .panel-header{padding:14px 4px;border-bottom:none}.game-panel .panel-body{padding:0 4px!important}.game-hud{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.hud-stats{display:flex;gap:8px;flex-wrap:wrap}.hud-stat{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#0000004d;border:1px solid var(--border-subtle);border-radius:999px;font-size:12px}.hud-stat .icon{font-size:14px}.hud-stat .value{font-weight:700;color:var(--accent-cyan)}.hud-stat.level .value{color:var(--accent-purple)}.hud-stat.combo .value{color:var(--accent-yellow)}.hud-stat.life .value{color:var(--accent-red)}.ai-toggle-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:700;cursor:pointer;border:1px solid var(--border-subtle);background:#0000004d;color:var(--text-muted);transition:all .2s}.ai-toggle-btn:active{transform:scale(.95)}.ai-toggle-btn.on{background:#3fb9502e;border-color:var(--accent-green);color:var(--accent-green)}.ai-toggle-btn .ai-toggle-label,.ai-toggle-btn .ai-toggle-status{pointer-events:none}.canvas-wrapper{flex:1;min-height:400px;max-height:70vh;position:relative;margin:12px 0;overflow:hidden}.brick-canvas-area{flex:1;min-height:300px;max-height:70vh;position:relative;overflow:hidden}canvas{width:100%;height:100%;display:block;touch-action:pan-x;border-radius:var(--radius-md);background:radial-gradient(ellipse 60% 40% at 50% 30%,rgba(88,166,255,.06) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 70% 70%,rgba(167,113,247,.04) 0%,transparent 50%),#0006;border:1px solid var(--border-subtle)}.input-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:0 16px}.input-bar input{flex:1;min-width:200px;padding:14px 18px;font-size:16px;border-radius:var(--radius-md);background:#0006;border:2px solid var(--border-subtle)}.input-bar input:focus{border-color:var(--accent-blue);box-shadow:var(--glow-blue)}.submit-btn,.submit-btn:disabled,.submit-btn:active{padding:14px 20px;font-size:18px;font-weight:700;background:var(--accent-green)!important;border:none;border-radius:var(--radius-md);color:#000!important;cursor:pointer;flex-shrink:0;opacity:1!important}.submit-btn:active{transform:scale(.95)}.mobile-input-overlay{display:none;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);margin:0 auto;width:60%;max-width:224px;z-index:10;gap:6px}.mobile-input-overlay input{flex:1;padding:12px 11px;font-size:14px;border-radius:var(--radius-md);background:#00000026;border:1px solid rgba(255,255,255,.15);color:var(--text-bright);text-align:center}.submit-btn-mobile,.submit-btn-mobile:disabled,.submit-btn-mobile:active{padding:8px 12px;font-size:14px;font-weight:700;background:var(--accent-green)!important;border:none;border-radius:var(--radius-md);color:#000!important;cursor:pointer;flex-shrink:0;opacity:1!important}.submit-btn-mobile:active{transform:scale(.95)}.mobile-input-overlay input::placeholder{color:#fff6}.mobile-input-overlay input:focus{outline:none;border-color:#58a6ff66;background:#0003}.game-controls{display:flex;gap:8px}#startBtn{font-size:1.1em}#nextDayBtn{min-width:80px}.help-bar{display:flex;align-items:center;justify-content:space-between;margin-top:8px;flex-wrap:wrap;gap:8px}.help-text{font-size:11px;color:var(--text-muted)}.toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%) translateY(20px);padding:12px 24px;background:var(--bg-card);border:1px solid var(--border-glow);border-radius:var(--radius-md);font-size:13px;font-weight:600;opacity:0;pointer-events:none;transition:all .3s ease;z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast.success{border-color:var(--accent-green);color:var(--accent-green)}.toast.error{border-color:var(--accent-red);color:var(--accent-red)}.toast.info{border-color:var(--accent-blue);color:var(--accent-blue)}.game-overlay{position:absolute;inset:0;background:#06080deb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:none;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-md);z-index:10}.game-overlay.active{display:flex;animation:fadeIn .3s ease}.game-overlay .btn{font-size:1.1em}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.overlay-content{text-align:center;padding:40px}.overlay-content h2{font-family:Outfit,sans-serif;font-size:42px;font-weight:800;margin-bottom:20px;text-transform:uppercase;letter-spacing:4px}.overlay-content h2.gameover{color:var(--accent-red)}.overlay-content h2.paused{color:var(--accent-yellow)}.overlay-content h2.complete{color:var(--accent-green)}.overlay-stats{margin:24px 0}.overlay-stat{font-size:16px;color:var(--text-muted);margin:10px 0}.overlay-stat span{color:var(--accent-cyan);font-weight:700}.today-words-overlay{position:absolute;inset:0;background:#e8e8c8;border-radius:var(--radius-md);z-index:100;display:none;flex-direction:column;overflow:hidden}.today-words-overlay.active{display:flex;animation:fadeIn .3s ease}.today-words-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:2px solid #c4c4a0;background:#d8d8b8;color:#4a4a2a;font-weight:700;font-size:1rem}.today-words-count{font-size:.9rem;color:#8a8a6a;font-weight:600}#todayWordsHideBtn{background:transparent;color:#6a5a3a;border:1px solid #a09070;padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:4px;cursor:pointer}#todayWordsHideBtn:active{background:#6450321a}#hideMeaningBtn{padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:4px}.today-words-list{flex:1;overflow-y:auto;padding:8px 12px 20px;background-attachment:local}.today-word-item{display:flex;justify-content:space-between;align-items:center;height:clamp(32px,4vw,42px);line-height:clamp(32px,4vw,42px);color:#3a3a2a;font-size:clamp(.95rem,1.8vw,1.2rem);padding:0 8px;margin:0 8px;border-bottom:1px dashed #b8b898;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.today-word-item .score-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-right:10px;border:1px solid rgba(0,0,0,.2)}.today-word-item .score-dot.blink{animation:blink .8s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.today-word-item .word{font-weight:700;font-size:1.05em;color:#2a4a6a;cursor:pointer}.today-word-item .word:active{opacity:.6}.today-word-item .pos{font-size:.75em;font-weight:500;color:#666;margin-left:4px}.today-word-item .meaning{font-size:.9em;color:#5a5a4a;text-align:right;flex:1;margin-left:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.today-words-list.hide-meaning .meaning{color:transparent;background:linear-gradient(90deg,#6478c833,#9664b433);border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .3s}.today-words-list.hide-meaning .meaning:hover{background:linear-gradient(90deg,#6478c84d,#9664b44d)}.today-words-list.hide-meaning .meaning.revealed{color:#5a5a4a;background:#6496c81a}.today-word-item .tip-btn{cursor:pointer;font-size:14px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:10px;margin:-10px -10px -10px -2px;background:#667eea;background-clip:content-box;border-radius:50%;box-sizing:content-box}.today-word-item .tip-btn:active{transform:scale(.9)}.today-word-tip{background:#f5f0e0;color:#5a4a2a;font-size:clamp(13px,1.6vw,16px);padding:8px 12px 8px 28px;border-left:3px solid #d4c090;margin-bottom:4px;border-radius:0 4px 4px 0;white-space:normal;word-wrap:break-word;line-height:1.4}.screen{display:none}.screen.active{display:flex;flex-direction:column;flex:1}@media(max-width:640px){header{padding:8px 10px;gap:6px}main{padding:12px 14px}.panel-body{padding:14px}.canvas-wrapper{min-height:320px}.mobile-input-overlay{display:flex}.input-bar input#typeInput,.brick-input-bar input#brickInput,body.stt-active .mobile-input-overlay{display:none}body.stt-active .input-bar input#typeInput,body.stt-active .brick-input-bar input#brickInput{display:block}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}.falling-word.word-yellow{color:gold!important;text-shadow:0 0 5px rgba(255,215,0,.5)}.falling-word.word-red{color:#f44!important;text-shadow:0 0 5px rgba(255,68,68,.5);font-weight:700}.falling-word.word-red-blink{color:red!important;font-weight:800;animation:blink-red .8s infinite;text-shadow:0 0 10px rgba(255,0,0,.8)}@keyframes blink-red{0%,49%{opacity:1;transform:scale(1)}50%,to{opacity:.3;transform:scale(1.1)}}.study-note-page{display:none;position:fixed;top:0;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:900px;z-index:10000;background:var(--bg-primary);flex-direction:column;overflow:hidden;touch-action:pan-y}.study-note-page.active{display:flex!important}.study-note-header{padding:8px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px;flex-wrap:wrap}.study-note-header h2{font-size:16px;margin:0}.study-note-header .btn{flex-shrink:0;order:99}.study-note-header .btn:first-of-type{margin-left:auto}.overlay-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-subtle);background:var(--bg-primary)}.overlay-header .brand{display:flex;align-items:center;gap:10px}.overlay-header .logo-icon{width:44px;height:44px}.overlay-header .brand-text h1{font-family:Outfit,sans-serif;font-size:20px;font-weight:800;letter-spacing:.5px;margin:0;background:linear-gradient(90deg,var(--text-bright),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.overlay-header .brand-text span{font-size:.75rem;color:var(--text-secondary)}.study-note-tabs-bar{padding:10px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:10px}.study-note-body.hide-meaning .sn-meaning{color:transparent;background:linear-gradient(90deg,#58d2ff26,#a771f726);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .3s}.study-note-body.hide-meaning .sn-meaning:hover{background:linear-gradient(90deg,#58d2ff40,#a771f740)}.study-note-body.hide-meaning .sn-meaning.revealed{color:#b8c0c8;background:#58d2ff14}.study-note-tabs{display:flex;gap:6px;font-size:11px}.sn-tab{padding:6px 12px;border-radius:12px;font-weight:600;cursor:pointer;border:1.5px solid currentColor;transition:background .15s,filter .15s}.sn-tab:hover{filter:brightness(1.1)}.sn-tab.active{filter:brightness(1.3)}.sn-tab[data-filter=all]{background:#ffffff1a;color:#aaa}.sn-tab[data-filter=all].active{background:#ffffff40}.sn-tab[data-filter=yellow]{background:#ffe04026;color:#ffe040}.sn-tab[data-filter=yellow].active{background:#ffe04059}.sn-tab[data-filter=red]{background:#ff8c0026;color:#ff8c00}.sn-tab[data-filter=red].active{background:#ff8c0059}.sn-tab[data-filter=red-blink]{background:#ff202026;color:#ff2020}.sn-tab[data-filter=red-blink].active{background:#ff202059}.study-note-body{padding:12px 0}.study-note-empty{text-align:center;color:var(--text-muted);padding:40px 0}.study-note-group{margin-bottom:20px}.study-note-group-title{font-size:13px;font-weight:700;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border-subtle)}.study-note-group-title.sn-red-blink{color:#ff2020}.study-note-group-title.sn-red{color:#ff8c00}.study-note-group-title.sn-yellow{color:#ffe040}.study-note-list{display:flex;flex-direction:column;gap:0}.study-note-card{display:flex;align-items:center;gap:6px;padding:2px 8px;border-radius:var(--radius-md);background:none;border-left:3px solid transparent;border-bottom:1px dashed rgba(88,210,255,.4);font-size:clamp(.95rem,1.8vw,1.2rem)}.study-note-card.sn-yellow{border-left-color:#ffe040}.study-note-card.sn-red{border-left-color:#ff8c00}.study-note-card.sn-red-blink{border-left-color:#ff2020}.study-note-card .sn-word{font-weight:700;font-size:1.05em;min-width:120px;background:none;padding:2px 8px;cursor:pointer}.study-note-card .sn-word:active{opacity:.6}.study-note-card .sn-meaning{flex:1;color:#b8c0c8;font-size:.9em;padding:6px 4px 6px 12px;border-radius:6px;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.study-note-card .sn-score{font-size:12px;font-weight:600;min-width:40px;text-align:right}.study-note-card.sn-yellow .sn-word{color:#ffe040}.study-note-card.sn-red .sn-word{color:#ff8c00}.study-note-card.sn-red-blink .sn-word{color:#ff2020}.study-note-card.sn-yellow .sn-score{color:#ffe040}.study-note-card.sn-red .sn-score{color:#ff8c00}.study-note-card.sn-red-blink .sn-score{color:#ff2020}.study-note-card .sn-pos{font-size:.75em;font-weight:500;margin-left:4px}.study-note-card.sn-yellow .sn-pos{color:#b8a030}.study-note-card.sn-red .sn-pos{color:#cc6800}.study-note-card.sn-red-blink .sn-pos{color:#cc1818}.study-note-card .sn-tip-btn{margin-left:2px;cursor:pointer;font-size:14px;background:#667eeacc;border-radius:50%;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.study-note-card .sn-tip-btn:active{transform:scale(.9)}.sn-tip-row{background:#fff5dc26;color:#d4c8a0;font-size:clamp(13px,1.6vw,16px);padding:8px 12px 8px 28px;border-left:3px solid #a09060;margin-bottom:4px;border-radius:0 4px 4px 0;white-space:normal;word-wrap:break-word;line-height:1.4}.vocab-selector{background:#fff;border-radius:12px;padding:20px;margin:20px auto;max-width:1400px;box-shadow:0 4px 12px #0000001a}.vocab-selector h3{margin:0 0 16px;font-size:1.3rem;color:#333;display:flex;align-items:center;gap:8px}.vocab-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.vocab-item{display:flex;align-items:center;justify-content:space-between;padding:16px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.vocab-item:hover{border-color:#667eea;background:#f8f9ff}.vocab-item.active{border-color:#667eea;background:linear-gradient(135deg,#667eea10,#764ba210)}.vocab-item-main{flex:1}.vocab-item-title{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:4px}.vocab-item-info{font-size:.9rem;color:#666}.vocab-item-check{width:24px;height:24px;border-radius:50%;border:2px solid #667eea;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}.vocab-item.active .vocab-item-check{background:#667eea}.add-vocab-btn{width:100%;padding:14px;border:2px dashed #ccc;border-radius:8px;background:#fff;color:#666;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.add-vocab-btn:hover{border-color:#667eea;color:#667eea;background:#f8f9ff}.settings-section{margin-bottom:24px}.settings-section h4{margin:0 0 12px;font-size:1rem;color:#555;font-weight:600}.form-row-new{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px}@media(max-width:600px){.form-row-new{grid-template-columns:1fr}}@media(max-height:700px){.game-panel .panel-body{display:flex;flex-direction:column}.game-panel .canvas-wrapper{order:2;min-height:280px}.game-panel .input-bar{order:1;margin-bottom:8px}.game-panel .help-bar{order:3}#brickGamePage{display:flex;flex-direction:column}#brickGamePage .overlay-header{order:1}#brickGamePage .brick-input-bar{order:2;padding:8px 16px}#brickGamePage .study-note-body{order:3;flex:1}}.form-group-new{display:flex;flex-direction:column}.form-group-new label{margin-bottom:6px;font-weight:600;color:#444;font-size:.9rem}.form-group-new input,.form-group-new select{padding:10px;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group-new input:focus,.form-group-new select:focus{outline:none;border-color:#667eea}.checkbox-group{display:flex;align-items:center;gap:8px;padding:10px}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer}.checkbox-group label{cursor:pointer;-webkit-user-select:none;user-select:none}.score-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600}.score-badge.high{background:#e8f5e9;color:#2e7d32}.score-badge.medium{background:#fff3e0;color:#ef6c00}.score-badge.low{background:#ffebee;color:#c62828}.score-badge.zero{background:#f44336;color:#fff;animation:pulse 1s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.loading-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.loading-content{background:#fff;padding:40px;border-radius:16px;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vocab-selector-root{min-height:100vh;background:var(--bg-primary);color:var(--text-primary, #c9d1d9);display:flex;flex-direction:column}.vocab-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted)}.vocab-spinner{width:48px;height:48px;border:4px solid var(--border-subtle, rgba(255,255,255,.1));border-top-color:var(--accent-blue, #58a6ff);border-radius:50%;animation:spin 1s linear infinite}.vocab-header{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border-subtle, rgba(255,255,255,.06));background:#06080dcc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.vocab-header-left{display:flex;align-items:center;gap:10px}.vocab-header-title{margin:0;font-family:Outfit,sans-serif;font-size:16px;font-weight:800;background:linear-gradient(90deg,var(--text-bright, #fff),var(--accent-cyan, #79c0ff));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.vocab-header-user{font-size:11px;color:var(--text-muted, #8b949e)}.vocab-header-actions{display:flex;gap:6px}.vocab-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:20px 16px}.vocab-section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:20px}.vocab-section-header h2{margin:0;font-size:1.3rem;color:var(--text-bright, #fff)}.vocab-action-btns{display:flex;gap:6px;flex-wrap:wrap}.vocab-panel{background:var(--bg-card, rgba(22,27,34,.8));border:1px solid var(--border-subtle, rgba(255,255,255,.06));border-radius:var(--radius-lg, 14px);padding:16px;margin-bottom:20px}.vocab-panel h3{margin:0 0 14px;font-size:1rem;color:var(--text-bright, #fff)}.vocab-list{display:flex;flex-direction:column;gap:10px}.vocab-card{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-card, rgba(22,27,34,.8));border:1px solid var(--border-subtle, rgba(255,255,255,.06));border-radius:var(--radius-md, 10px);transition:border-color .2s,background .2s}.vocab-card.selectable{cursor:pointer}.vocab-card.selectable:hover{border-color:var(--accent-blue, #58a6ff);background:#58a6ff0f}.vocab-card.subscribed{border-color:var(--accent-green, #3fb950)}.vocab-card.current{border-color:var(--accent-cyan, #58a6ff);background:#58a6ff1a;box-shadow:0 0 12px #58a6ff33}.current-badge{display:inline-block;margin-left:8px;padding:2px 8px;font-size:.7rem;font-weight:600;color:var(--accent-cyan, #58a6ff);background:#58a6ff26;border:1px solid rgba(88,166,255,.3);border-radius:4px;vertical-align:middle}.vocab-card h4{margin:0 0 4px;font-size:1rem;color:var(--text-bright, #fff)}.vocab-card-actions{display:flex;gap:6px;flex-shrink:0}.vocab-meta{font-size:.82rem;color:var(--text-muted, #8b949e)}.badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:600}.badge.green{background:#3fb95026;color:var(--accent-green, #3fb950);border:1px solid rgba(63,185,80,.3)}.badge.yellow{background:#ffeb3b26;color:var(--accent-yellow, #FFEB3B);border:1px solid rgba(255,235,59,.3)}.vocab-empty{text-align:center;padding:50px 20px;color:var(--text-muted, #8b949e)}.vocab-input{width:100%;padding:10px 12px;margin-bottom:10px;background:var(--bg-primary);border:1px solid var(--border-subtle, rgba(255,255,255,.1));border-radius:var(--radius-sm, 8px);color:var(--text-primary, #c9d1d9);font-size:.95rem;box-sizing:border-box}.vocab-input:focus{outline:none;border-color:var(--accent-blue, #58a6ff)}.vocab-category-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.vocab-cat-tab{padding:6px 14px;border-radius:999px;border:1px solid var(--border-subtle, rgba(255,255,255,.1));background:transparent;color:var(--text-muted, #8b949e);cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s}.vocab-cat-tab.active{background:var(--accent-blue, #58a6ff);color:#fff;border-color:var(--accent-blue, #58a6ff)}.vocab-template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.vocab-template-card{padding:16px;background:var(--bg-primary);border:1px solid var(--border-subtle, rgba(255,255,255,.1));border-radius:var(--radius-md, 10px);cursor:pointer;transition:transform .2s,border-color .2s}.vocab-template-card:hover:not(.added){transform:translateY(-3px);border-color:var(--accent-blue, #58a6ff)}.vocab-template-card.added{opacity:.5;cursor:not-allowed}.vocab-template-card h4{margin:0 0 6px;font-size:.95rem;color:var(--text-bright, #fff)}.vocab-template-icon{font-size:2rem;margin-bottom:8px}.vocab-template-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.btn.small{padding:5px 12px;font-size:.8rem}.btn.danger{background:#f8514926;color:#f85149;border-color:#f851494d}.btn.danger:hover{background:#f8514940}.words-popup-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:10000;align-items:center;justify-content:center}.words-popup-overlay.active{display:flex}.words-popup{background:#0d1117d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;min-width:280px;max-width:90%;box-shadow:0 8px 32px #00000080}.words-popup-lg{min-width:320px;padding:28px}.words-popup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:700;font-size:15px;color:var(--text-bright)}.words-popup-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px}.words-popup-close:hover{color:var(--text-bright)}.words-popup-msg{text-align:center;font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:16px}.popup-user-name{color:var(--accent-green);font-weight:700}.words-popup-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;transition:opacity .2s}.words-popup-row.locked{opacity:.5;pointer-events:none}.words-popup-label{font-size:14px;font-weight:600;color:var(--text-secondary);min-width:70px}.words-popup-body{display:flex;align-items:center;justify-content:center;gap:12px}.words-spinner-btn{width:36px;height:36px;border-radius:50%;border:2px solid var(--border-subtle);background:#0000004d;color:var(--accent-cyan);font-size:16px;cursor:pointer;transition:all .15s}.words-spinner-btn:hover{background:#58d2ff26;border-color:var(--accent-cyan)}.words-spinner-btn:active{transform:scale(.95)}.words-spinner-value{font-size:36px;font-weight:800;min-width:70px;text-align:center;font-family:Outfit,sans-serif}.words-spinner-value.input-yellow{color:var(--accent-yellow)}.words-spinner-value.input-blue{color:var(--accent-blue)}.words-spinner-value.input-green{color:var(--accent-green)}.words-popup-footer{display:flex;justify-content:center}.words-popup-footer .btn{min-width:120px}.words-popup-xl{min-width:360px;max-width:420px;padding:20px}.day-calendar-section{margin-bottom:20px;padding:16px;background:#0003;border-radius:12px}.day-calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.day-calendar-title{font-size:13px;font-weight:600;color:var(--text-muted)}.day-calendar-selected{font-size:15px;font-weight:700;color:var(--accent-green)}.day-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;max-height:200px;overflow-y:auto;padding-right:4px}.day-calendar-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s;background:#ffffff0d;color:var(--text-muted);border:2px solid transparent}.day-calendar-cell:hover{background:#ffffff1a}.day-calendar-cell.completed{background:#3fb95033;color:var(--accent-green)}.day-calendar-cell.current{background:#58a6ff33;color:var(--accent-blue);border-color:var(--accent-blue)}.day-calendar-cell.selected{background:var(--accent-green);color:#000;border-color:var(--accent-green)}.day-calendar-cell.future{opacity:.3;cursor:not-allowed}.day-calendar-cell.future:hover{background:#ffffff0d}.day-calendar-grid::-webkit-scrollbar{width:4px}.day-calendar-grid::-webkit-scrollbar-track{background:#ffffff0d;border-radius:2px}.day-calendar-grid::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.words-popup-settings{margin-bottom:16px}.bonus-game-overlay{position:fixed;inset:0;background:#000;z-index:9999;display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.bonus-game-overlay.active{opacity:1;visibility:visible}.bonus-game-container{display:flex;flex-direction:column;height:100%;width:100%;max-width:900px;margin:0 auto;padding:8px}.bonus-game-header{display:flex;align-items:center;justify-content:center;gap:12px;padding:4px 0;flex-shrink:0}.bonus-game-title{font-size:1rem;font-weight:700;margin:0;color:gold}.bonus-game-subtitle{display:none}.bonus-game-timer{color:var(--accent-yellow, #f0c000);font-size:.8rem;margin:0;font-weight:600}.bonus-game-content{flex:1;display:flex;align-items:center;justify-content:center;background:#000;border-radius:8px;overflow:hidden;position:relative;min-height:0}.bonus-game-footer{padding:6px 0;text-align:center;flex-shrink:0}.bonus-game-footer .btn{min-width:100px;padding:8px 16px;font-size:.85rem}#bonusGameBtn{transition:all .3s}#bonusGameBtn:disabled{opacity:.3;cursor:not-allowed}#bonusGameBtn:not(:disabled){animation:giftPulse 2s infinite}@keyframes giftPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}#bonusGameBtn.bonus-highlight{animation:bonusHighlight .5s ease-in-out infinite;box-shadow:0 0 20px #ffd700cc}@keyframes bonusHighlight{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.bonus-notification{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:linear-gradient(135deg,gold,orange);color:#1a1a2e;padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;white-space:nowrap;box-shadow:0 4px 12px #ffd70066;animation:notificationPop .3s ease-out,notificationFade 2s ease-in-out;z-index:9999}.bonus-notification:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:gold}@keyframes notificationPop{0%{opacity:0;transform:translate(-50%) translateY(-10px) scale(.8)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes notificationFade{0%,70%{opacity:1}to{opacity:0}}.chase-game-ui{position:absolute;top:5px;left:5px;color:#fff;font-size:11px;text-shadow:1px 1px 2px rgba(0,0,0,.8);z-index:10;background:#0009;padding:6px 10px;border-radius:8px}.chase-ui-stats{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.chase-ui-stats>span{white-space:nowrap}.chase-timer{font-size:13px;color:gold;font-weight:700}.chase-minimap-container{position:absolute;top:5px;right:5px;z-index:10}.chase-minimap{border:1px solid rgba(255,255,255,.4);border-radius:6px;width:80px;height:80px}.chase-start-screen,.chase-gameover-screen{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000f2;padding:20px 32px;border-radius:12px;text-align:center;color:#fff;z-index:20;width:90%;max-width:400px;max-height:90%;overflow:auto}.chase-start-screen{background:transparent;border:2px solid rgba(255,255,255,.6);text-shadow:0 1px 3px rgba(0,0,0,.8)}.chase-start-screen h2,.chase-gameover-screen h2{color:gold;font-size:clamp(16px,5vw,24px);margin:0 0 8px}.chase-start-screen p,.chase-gameover-screen p{margin:4px 0;color:#ccc;font-size:clamp(11px,3vw,14px)}.chase-time-info{background:linear-gradient(135deg,#4a9eff4d,#2d7dd24d);border:1px solid rgba(74,158,255,.5);border-radius:8px;padding:8px 16px;margin:8px 0 12px!important;font-size:clamp(13px,4vw,16px)!important;color:#7ab8ff!important;font-weight:700}.chase-controls-info{margin:12px 0;padding:12px 16px;background:#ffffff1a;border-radius:8px;font-size:clamp(11px,3vw,14px);text-align:left}.chase-controls-info p{margin:5px 0}.chase-time-option{display:flex;align-items:center;justify-content:center;gap:8px;margin:12px 0;padding:8px 16px;background:#ffffff1a;border-radius:8px;cursor:pointer;font-size:.9em;color:#c9d1d9;transition:background .2s}.chase-time-option:hover{background:#ffffff26}.chase-time-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#58a6ff}.chase-time-option span{-webkit-user-select:none;user-select:none}#chaseCurrentTime{color:#8b949e;font-size:.9em}.chase-start-btn,.chase-restart-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;padding:10px 20px;font-size:clamp(12px,3vw,14px);border-radius:8px;cursor:pointer;margin-top:10px;transition:transform .2s}.chase-start-btn:active,.chase-restart-btn:active{transform:scale(.95)}.chase-gameover-screen{display:none;flex-direction:column;align-items:center}.chase-gameover-screen h2{color:#f44}.chase-player-name{font-size:1.1em;color:gold;margin:8px 0 4px}.chase-new-record{color:gold;font-size:1.2em;font-weight:700;animation:pulse .5s ease-in-out infinite alternate;margin:8px 0}@keyframes pulse{0%{transform:scale(1);opacity:.8}to{transform:scale(1.1);opacity:1}}.chase-high-score{color:#888;font-size:.9em;margin:4px 0 8px}.chase-leaderboard{width:100%;max-width:280px;margin:10px auto;background:#0006;border-radius:8px;padding:10px;font-size:.85em}.leaderboard-title{font-size:1.1em;font-weight:700;color:gold;margin-bottom:8px;text-align:center}.leaderboard-top3,.leaderboard-around{display:flex;flex-direction:column;gap:4px}.leaderboard-row{display:flex;align-items:center;padding:4px 8px;border-radius:4px;background:#ffffff0d}.leaderboard-row.me{background:#ffd70033;border:1px solid #FFD700}.leaderboard-row .medal{width:24px;font-size:1.1em}.leaderboard-row .rank{width:40px;color:#aaa;font-size:.9em}.leaderboard-row .name{flex:1;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-row.me .name{color:gold;font-weight:700}.leaderboard-row .score{color:#4fc3f7;font-weight:700;margin-left:8px}.leaderboard-divider{border-top:2px dashed rgba(255,255,255,.3);margin:10px 0}.leaderboard-my-rank{text-align:center;color:#aaa;font-size:.85em;margin-top:8px}.chase-quiz-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.chase-quiz-popup{background:#1e1e32f2;border:2px solid #4a9eff;border-radius:16px;padding:24px 32px;text-align:center;min-width:280px;max-width:90%;box-shadow:0 8px 32px #00000080}.chase-quiz-word{font-size:2rem;font-weight:700;color:#fff;margin-bottom:16px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.chase-quiz-input{width:100%;padding:12px 16px;font-size:1.1rem;border:2px solid #4a9eff;border-radius:8px;background:#ffffff1a;color:#fff;margin-bottom:12px;text-align:center}.chase-quiz-input::placeholder{color:#ffffff80}.chase-quiz-input:focus{outline:none;border-color:#7ab8ff;background:#ffffff26}.chase-quiz-submit{padding:10px 32px;font-size:1rem;font-weight:700;background:linear-gradient(135deg,#4a9eff,#2d7dd2);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:transform .1s,box-shadow .1s}.chase-quiz-submit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4a9eff66}.chase-quiz-result{font-size:1.8rem;font-weight:700;margin-bottom:12px}.chase-quiz-result.correct{color:#4caf50}.chase-quiz-result.wrong{color:#f44336}.chase-quiz-meaning{font-size:1.2rem;color:#ccc;margin-bottom:8px}.chase-quiz-bonus{font-size:1.1rem;color:gold;font-weight:700}.chase-quiz-penalty{font-size:1.1rem;color:#ff6b6b;font-weight:700}.spirit-quiz .quiz-content{background:linear-gradient(135deg,#1a3a5c,#0d2840);border:3px solid #ffd700;border-radius:20px;padding:24px 32px;text-align:center;max-width:320px;box-shadow:0 0 30px #ffd70066}.spirit-title{font-size:2rem;margin-bottom:8px}.spirit-message{color:gold;font-size:1rem;margin-bottom:16px;line-height:1.5}.spirit-quiz .quiz-word{font-size:1.8rem;font-weight:700;color:#fff;margin-bottom:20px;padding:12px;background:#ffffff1a;border-radius:8px}.spirit-quiz .quiz-options{display:flex;flex-direction:column;gap:10px}.spirit-quiz .quiz-option{background:#ffffff1a;border:2px solid rgba(255,215,0,.5);border-radius:8px;padding:12px 16px;color:#fff;font-size:1rem;cursor:pointer;transition:all .2s}.spirit-quiz .quiz-option:hover{background:#ffd70033;border-color:gold}.spirit-quiz .quiz-option.correct{background:#4caf5080;border-color:#4caf50}.spirit-quiz .quiz-option.wrong{background:#f4433680;border-color:#f44336}.chase-time-expired-popup{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:200}.time-expired-message{background:linear-gradient(135deg,#2d3a4f,#1a2433);border:3px solid #4a9eff;border-radius:20px;padding:32px 48px;text-align:center;color:#fff;font-size:1.4rem;line-height:1.8;box-shadow:0 8px 32px #00000080,0 0 20px #4a9eff4d;animation:popupFadeIn .3s ease-out}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.chase-joystick{position:absolute;bottom:15px;right:15px;width:90px;height:90px;background:#ffffff26;border:3px solid rgba(255,255,255,.4);border-radius:50%;z-index:15}.chase-joystick-knob{position:absolute;top:50%;left:50%;width:36px;height:36px;background:#ffffffb3;border:2px solid rgba(255,255,255,.9);border-radius:50%;transform:translate(-50%,-50%)}.chase-poop-btn{position:absolute;bottom:15px;left:15px;width:60px;height:60px;font-size:28px;background:#8b4513cc;border:3px solid rgba(139,69,19,1);border-radius:50%;cursor:pointer;z-index:15;display:flex;align-items:center;justify-content:center;transition:transform .1s;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.chase-poop-btn:active{transform:scale(.9)}.chase-poop-btn:disabled{opacity:.4}.chase-jump-btn{position:absolute;bottom:85px;left:15px;width:60px;height:60px;font-size:24px;background:#4169e1cc;border:3px solid rgba(65,105,225,1);border-radius:50%;cursor:pointer;z-index:15;display:flex;align-items:center;justify-content:center;transition:transform .1s;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;color:#fff;font-weight:700}.chase-jump-btn:active{transform:scale(.9)}.chase-camera-btn{position:absolute;top:75px;left:15px;width:44px;height:44px;font-size:11px;font-weight:700;color:#fff;background:#fff3;border:2px solid rgba(255,255,255,.4);border-radius:50%;cursor:pointer;z-index:15;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .2s;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.chase-camera-btn:active{transform:scale(.9);background:#fff6}.swipe-container{display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;height:100%;flex:1}.swipe-container::-webkit-scrollbar{display:none}.swipe-container.locked{overflow:hidden;touch-action:none}.swipe-container.locked canvas{touch-action:none}#progressPage canvas{touch-action:pan-x pan-y}.swipe-page{flex:0 0 100%;width:100%;min-width:100%;scroll-snap-align:start;scroll-snap-stop:always;height:100%;overflow:hidden;display:flex;flex-direction:column}.swipe-page-inner{display:block;height:100%;padding:12px 4px;box-sizing:border-box;overflow-y:auto;touch-action:pan-x pan-y}.swipe-page-header{display:flex;justify-content:space-between;align-items:center;padding:4px 0 8px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px;background:transparent}.swipe-page-title{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.swipe-page-body{padding-right:4px}.page-indicator{display:flex;justify-content:center;align-items:center;gap:8px;padding:8px 0 12px;flex-shrink:0}.page-dot{width:8px;height:8px;border-radius:50%;background:#ffffff4d;cursor:pointer;transition:all .2s ease}.page-dot:hover{background:#ffffff80;transform:scale(1.2)}.page-dot.active{background:var(--accent-blue);width:24px;border-radius:4px}#gamePage{height:100%;overflow:hidden}#gamePage .game-panel{height:100%;display:flex;flex-direction:column}#gamePage .panel-body{flex:1;display:flex;flex-direction:column;overflow:hidden}#gamePage .canvas-wrapper{flex:1;min-height:0}.plan-confirm-overlay{display:none;position:fixed;inset:0;background:#06080df2;z-index:20000;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.plan-confirm-overlay.active{display:flex}.plan-confirm-modal{max-width:400px;width:90%;padding:32px 24px;text-align:center}.plan-dialog-line{font-size:1.2rem;color:var(--text-bright);margin:0 0 16px;min-height:1.5em;line-height:1.5}.plan-dialog-line.highlight{color:var(--accent-yellow);font-weight:700;font-size:1rem}.target-days-selector{display:flex;flex-direction:column;gap:12px;margin:24px 0;opacity:0;animation:fadeSlideIn .5s ease forwards}.target-days-selector.fade-in{opacity:1}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slider-container{display:flex;flex-direction:column;align-items:center;gap:16px}.slider-value-display{display:flex;align-items:baseline;gap:4px}.slider-days{font-size:3rem;font-weight:900;color:var(--accent-blue);text-shadow:0 0 20px rgba(88,166,255,.5);line-height:1}.slider-days-label{font-size:1.2rem;font-weight:600;color:var(--text-muted)}.target-days-slider{-webkit-appearance:none;appearance:none;width:100%;height:8px;background:linear-gradient(90deg,var(--accent-blue) 0%,var(--accent-purple) 100%);border-radius:4px;outline:none;cursor:pointer}.target-days-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;background:linear-gradient(135deg,#fff,#e0e0e0);border-radius:50%;cursor:grab;box-shadow:0 2px 8px #0000004d,0 0 0 3px #58a6ff4d;transition:transform .15s,box-shadow .15s}.target-days-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 2px 12px #0006,0 0 0 4px #58a6ff80}.target-days-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}.target-days-slider::-moz-range-thumb{width:28px;height:28px;background:linear-gradient(135deg,#fff,#e0e0e0);border-radius:50%;cursor:grab;border:none;box-shadow:0 2px 8px #0000004d,0 0 0 3px #58a6ff4d}.slider-hints{display:flex;justify-content:space-between;width:100%;font-size:.75rem;color:var(--text-muted)}.plan-result-msg{margin:16px 0;font-size:1rem;color:var(--text-muted);line-height:1.6;min-height:3.2em;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease}.plan-result-msg.visible{opacity:1;visibility:visible}.plan-result-msg span{color:var(--accent-cyan);font-weight:700}.plan-confirm-btn{display:inline-block;padding:14px 48px;background:linear-gradient(135deg,var(--accent-green),#2ea043);border:none;border-radius:var(--radius-md);color:#fff;font-size:1.2rem;font-weight:800;cursor:pointer;transition:all .3s ease;box-shadow:0 0 20px #3fb95066;opacity:0;visibility:hidden;transform:translateY(10px)}.plan-confirm-btn.visible{opacity:1;visibility:visible;transform:translateY(0)}.plan-confirm-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.plan-confirm-btn:active{transform:scale(.98)}.encouragement-line{font-size:1.3rem;color:var(--text-bright);margin:0 0 16px;min-height:1.5em;line-height:1.5;text-align:center}.encouragement-line.highlight{color:var(--accent-yellow);font-weight:700;font-family:Nanum Myeongjo,serif;font-size:1.1rem;margin-top:24px}.startup-progress-overlay{display:none;position:fixed;inset:0;background:#06080dfa;z-index:20000;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer}.startup-progress-overlay.pending{display:flex;background:#06080d}.startup-progress-overlay.active{display:flex}.startup-progress-content{max-width:min(90vw,600px);width:90%;padding:clamp(24px,5vw,48px) clamp(16px,4vw,40px);text-align:center}.startup-brand{display:flex;align-items:center;justify-content:center;gap:clamp(12px,3vw,20px);margin-bottom:clamp(20px,4vw,32px)}.startup-logo{width:clamp(48px,12vw,72px);height:clamp(48px,12vw,72px);border-radius:16px;box-shadow:0 4px 20px #0000004d}.startup-app-name{font-size:clamp(1.8rem,6vw,3rem);font-weight:800;color:var(--text-bright);letter-spacing:-.02em}.startup-title{font-size:clamp(1.4rem,4vw,2.4rem);font-weight:900;color:var(--accent-blue);margin:0 0 clamp(16px,3vw,32px) 0;min-height:1.5em;font-family:Nanum Myeongjo,serif;font-style:italic;transition:opacity .3s;text-shadow:0 0 20px rgba(88,166,255,.5)}.progress-bars-container{display:flex;flex-direction:column;gap:clamp(12px,2vw,20px);margin-bottom:clamp(16px,3vw,32px)}.progress-bar-row{display:flex;align-items:center;gap:clamp(8px,2vw,16px)}.bar-label{font-size:clamp(.75rem,2vw,1rem);font-weight:600;color:var(--text-muted);min-width:clamp(36px,8vw,60px);text-align:right}.bar-track{flex:1;height:clamp(20px,4vw,32px);background:#ffffff14;border-radius:12px;overflow:hidden;position:relative}.bar-fill{height:100%;width:0%;border-radius:12px;transition:width 1.2s ease-out}.bar-fill.expected{background:linear-gradient(90deg,var(--accent-purple),#8b5cf6)}.bar-fill.actual{background:linear-gradient(90deg,var(--accent-green),#22c55e)}.bar-count{font-size:clamp(.8rem,2vw,1.1rem);font-weight:700;color:var(--text-bright);min-width:clamp(50px,12vw,80px);text-align:left}.progress-percent{font-size:clamp(2.5rem,8vw,4rem);font-weight:800;color:var(--accent-cyan);margin:0 0 clamp(4px,1vw,12px) 0;font-family:Outfit,sans-serif;opacity:0}.progress-percent.pop-in{animation:popIn .4s ease forwards}@keyframes popIn{0%{opacity:0;transform:scale(.5)}70%{opacity:1;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.progress-msg{font-size:clamp(.9rem,2.5vw,1.2rem);color:var(--text-muted);margin:0 0 clamp(12px,2vw,20px) 0;min-height:1.5em;opacity:0}.progress-msg.fade-in{animation:fadeIn .5s ease forwards}.tap-hint{font-size:clamp(.7rem,1.5vw,.85rem);color:#ffffff4d;margin:clamp(16px,3vw,32px) 0 0 0}.plan-adjust-container{margin-top:clamp(16px,3vw,24px);padding:clamp(16px,3vw,24px);background:#ff646414;border:1px solid rgba(255,100,100,.2);border-radius:16px;text-align:left}.behind-msg{font-size:clamp(.95rem,2.5vw,1.15rem);color:#ff6b6b;font-weight:600;margin:0 0 clamp(12px,2vw,20px) 0;min-height:1.5em;text-align:center}.calc-animation{background:#0000004d;border-radius:12px;padding:clamp(12px,2vw,20px);font-family:Outfit,Consolas,monospace;margin-bottom:clamp(12px,2vw,16px)}.calc-line{font-size:clamp(.8rem,2vw,1rem);color:var(--text-muted);margin:clamp(6px,1vw,10px) 0;min-height:1.3em;opacity:0}.calc-line.visible{animation:calcFadeIn .4s ease forwards}.calc-line .highlight-num{color:var(--accent-cyan);font-weight:700}.calc-result{font-size:clamp(1rem,2.5vw,1.3rem);color:var(--accent-green);font-weight:700;margin:clamp(12px,2vw,16px) 0 0 0;min-height:1.5em;text-align:center;opacity:0}.calc-result.visible{animation:calcResultPop .5s ease forwards}.calc-result .new-amount{font-size:clamp(1.4rem,3.5vw,2rem);color:#22c55e;text-shadow:0 0 15px rgba(34,197,94,.5)}.sync-status{font-size:clamp(.75rem,1.8vw,.9rem);color:var(--text-muted);text-align:center;margin:0;min-height:1.2em;opacity:0}.sync-status.visible{animation:fadeIn .3s ease forwards}.sync-status.syncing:before{content:"⟳ ";animation:spin 1s linear infinite;display:inline-block}.sync-status.done{color:var(--accent-green)}.sync-status.done:before{content:"✓ "}@keyframes calcFadeIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes calcResultPop{0%{opacity:0;transform:scale(.8)}60%{opacity:1;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.comparison-bars-container{display:flex;flex-direction:column;gap:12px;padding:16px;background:#0003;border-radius:var(--radius-md);margin-bottom:16px}.comparison-bar-row{display:flex;align-items:center;gap:12px}.comparison-bar-label{font-size:.85rem;font-weight:600;color:var(--text-muted);min-width:50px}.comparison-bar-track{flex:1;height:20px;background:#ffffff14;border-radius:10px;overflow:hidden}.comparison-bar-fill{height:100%;border-radius:10px;transition:width .8s ease-out}.comparison-bar-fill.expected{background:linear-gradient(90deg,var(--accent-purple),#8b5cf6)}.comparison-bar-fill.actual{background:linear-gradient(90deg,var(--accent-green),#22c55e)}.comparison-bar-value{font-size:.85rem;font-weight:700;color:var(--text-bright);min-width:60px;text-align:right}.welcome-overlay{display:none;position:fixed;inset:0;background:linear-gradient(180deg,#0a0f1a,#060810);z-index:10001;align-items:center;justify-content:center;flex-direction:column;cursor:pointer;opacity:1}.welcome-overlay.active{display:flex}.welcome-content{max-width:min(90vw,500px);width:90%;padding:clamp(32px,6vw,56px) clamp(20px,5vw,40px);text-align:center}.welcome-brand{display:flex;align-items:center;justify-content:center;gap:clamp(12px,3vw,20px);margin-bottom:clamp(32px,6vw,48px);animation:welcomeBrandIn .8s ease-out forwards}@keyframes welcomeBrandIn{0%{opacity:0;transform:scale(.8) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.welcome-logo{width:clamp(56px,14vw,80px);height:clamp(56px,14vw,80px);border-radius:20px;box-shadow:0 8px 32px #58a6ff4d}.welcome-app-name{font-size:clamp(2rem,7vw,3.2rem);font-weight:800;color:var(--text-bright);letter-spacing:-.02em;text-shadow:0 2px 20px rgba(88,166,255,.3)}.welcome-messages{margin-bottom:clamp(24px,5vw,40px)}.welcome-line{margin:0;min-height:1.5em}.welcome-line1{font-size:clamp(1.8rem,5vw,2.8rem);font-weight:800;color:var(--accent-cyan);margin-bottom:clamp(12px,2vw,20px)}.welcome-line2,.welcome-line3{font-size:clamp(1.1rem,3vw,1.5rem);font-weight:500;color:var(--text-secondary)}.welcome-features{display:flex;flex-direction:column;gap:clamp(12px,2vw,16px);margin-bottom:clamp(24px,4vw,36px);padding:clamp(16px,3vw,24px);background:#ffffff08;border-radius:16px;border:1px solid rgba(255,255,255,.06)}.welcome-feature{display:flex;align-items:center;gap:clamp(10px,2vw,16px);text-align:left}.feature-icon{font-size:clamp(1.4rem,4vw,1.8rem);width:clamp(32px,8vw,44px);text-align:center}.feature-text{font-size:clamp(.95rem,2.5vw,1.15rem);color:var(--text-secondary);font-weight:500}.welcome-start{font-size:clamp(.9rem,2.2vw,1.1rem);color:var(--accent-green);margin:0 0 clamp(16px,3vw,24px) 0;min-height:1.5em;font-weight:600}
