@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;700&family=Inter:wght@300;400;500;600;700&display=swap";[data-source=kpop]{--bg-primary:#07070d;--bg-secondary:#0d0d16;--bg-card:#12121e;--bg-card-hover:#17172a;--bg-input:#15152a;--bg-surface:#0a0a14;--text-primary:#eeeef5;--text-secondary:#9898b0;--text-muted:#555570;--accent-noun:#ff8c42;--accent-noun-dim:#cc7035;--accent-noun-glow:#ff8c421f;--accent-noun-glow-strong:#ff8c4240;--accent-verb:#4ade80;--accent-verb-dim:#38b266;--accent-verb-glow:#4ade801a;--accent-verb-glow-strong:#4ade8038;--accent-blank:#f87171;--accent-blank-glow:#f871712e;--border-color:#ffffff0f;--border-active:#ffffff1f;--border-glow-noun:#ff8c424d;--border-glow-verb:#4ade804d;--btn-primary-bg:linear-gradient(135deg, #ff8c42, #ff6b1a);--btn-primary-bg-flat:#ff8c42;--btn-primary-text:#fff;--btn-primary-shadow:0 4px 20px #ff8c424d;--btn-secondary-bg:#ffffff0a;--btn-secondary-text:#eeeef5;--btn-hover-lift:0 6px 24px #0006;--shadow-card:0 2px 12px #0006, 0 0 1px #ffffff0d;--shadow-glow-noun:0 0 30px #ff8c4214, 0 0 60px #ff8c420a;--shadow-glow-verb:0 0 30px #4ade8014, 0 0 60px #4ade800a;--shadow-header:0 1px 0 #ffffff0a, 0 4px 20px #00000080;--gradient-card-noun:linear-gradient(180deg, #ff8c420a 0%, transparent 60%);--gradient-card-verb:linear-gradient(180deg, #4ade800a 0%, transparent 60%);--gradient-page:radial-gradient(ellipse at 50% 0%, #ff8c4208 0%, transparent 60%)}[data-source=kdrama]{--bg-primary:#0d0609;--bg-secondary:#14090e;--bg-card:#1c1017;--bg-card-hover:#241520;--bg-input:#1e1018;--bg-surface:#100810;--text-primary:#f2e8ec;--text-secondary:#b09098;--text-muted:#6e5058;--accent-noun:#ff8c42;--accent-noun-dim:#cc7035;--accent-noun-glow:#ff8c421f;--accent-noun-glow-strong:#ff8c4240;--accent-verb:#4ade80;--accent-verb-dim:#38b266;--accent-verb-glow:#4ade801a;--accent-verb-glow-strong:#4ade8038;--accent-blank:#f87171;--accent-blank-glow:#f871712e;--border-color:#ffc8b40f;--border-active:#ffc8b41f;--border-glow-noun:#ff8c424d;--border-glow-verb:#4ade804d;--btn-primary-bg:linear-gradient(135deg, #d4a44c, #c0923e);--btn-primary-bg-flat:#d4a44c;--btn-primary-text:#0d0609;--btn-primary-shadow:0 4px 20px #d4a44c40;--btn-secondary-bg:#ffc8b40a;--btn-secondary-text:#f2e8ec;--btn-hover-lift:0 6px 24px #00000080;--shadow-card:0 2px 12px #00000080, 0 0 1px #ffc8b40d;--shadow-glow-noun:0 0 30px #ff8c420f, 0 0 60px #ff8c4208;--shadow-glow-verb:0 0 30px #4ade800f, 0 0 60px #4ade8008;--shadow-header:0 1px 0 #ffc8b408, 0 4px 20px #0009;--gradient-card-noun:linear-gradient(180deg, #d4a44c0a 0%, transparent 60%);--gradient-card-verb:linear-gradient(180deg, #4ade8008 0%, transparent 60%);--gradient-page:radial-gradient(ellipse at 50% 0%, #d4a44c08 0%, transparent 60%)}[data-source=custom]{--bg-primary:#080a12;--bg-secondary:#0c0e18;--bg-card:#111520;--bg-card-hover:#161b2a;--bg-input:#131828;--bg-surface:#0a0c14;--text-primary:#e2e4ef;--text-secondary:#8890a8;--text-muted:#4a5068;--accent-noun:#ff8c42;--accent-noun-dim:#cc7035;--accent-noun-glow:#ff8c421f;--accent-noun-glow-strong:#ff8c4240;--accent-verb:#4ade80;--accent-verb-dim:#38b266;--accent-verb-glow:#4ade801a;--accent-verb-glow-strong:#4ade8038;--accent-blank:#f87171;--accent-blank-glow:#f871712e;--border-color:#8296dc14;--border-active:#8296dc26;--border-glow-noun:#ff8c424d;--border-glow-verb:#4ade804d;--btn-primary-bg:linear-gradient(135deg, #6b9eff, #4a7eef);--btn-primary-bg-flat:#5b8def;--btn-primary-text:#fff;--btn-primary-shadow:0 4px 20px #5b8def40;--btn-secondary-bg:#8296dc0f;--btn-secondary-text:#e2e4ef;--btn-hover-lift:0 6px 24px #0006;--shadow-card:0 2px 12px #0006, 0 0 1px #8296dc0f;--shadow-glow-noun:0 0 30px #ff8c420f, 0 0 60px #ff8c4208;--shadow-glow-verb:0 0 30px #4ade800f, 0 0 60px #4ade8008;--shadow-header:0 1px 0 #8296dc0a, 0 4px 20px #00000080;--gradient-card-noun:linear-gradient(180deg, #5b8def0a 0%, transparent 60%);--gradient-card-verb:linear-gradient(180deg, #4ade8008 0%, transparent 60%);--gradient-page:radial-gradient(ellipse at 50% 0%, #5b8def08 0%, transparent 60%)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);letter-spacing:-.01em;min-height:100vh;font-family:Inter,Noto Sans KR,system-ui,-apple-system,sans-serif;line-height:1.5;transition:background .4s,color .3s;overflow-x:hidden}body:before{content:"";background:var(--gradient-page);pointer-events:none;z-index:0;position:fixed;inset:0}#root{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}[lang=ko],.kr-text,.drill-sentence,.example-kr,.dict-word{font-family:Noto Sans KR,sans-serif}button{cursor:pointer;letter-spacing:inherit;border:none;font-family:inherit}input,select{letter-spacing:inherit;font-family:inherit}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-active);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-noun-glow-strong);color:var(--text-primary)}*,:before,:after{transition-property:background-color,border-color,box-shadow;transition-duration:0s}body.theme-transitioning,body.theme-transitioning *,body.theme-transitioning :before,body.theme-transitioning :after{transition-duration:.4s!important;transition-timing-function:ease!important}.progress-dashboard{max-width:640px;margin:0 auto;padding:2rem 1rem}.progress-dashboard h2{text-align:center;color:var(--text-primary,#f0f0f0);margin-bottom:.25rem;font-size:1.5rem}.progress-subtitle{text-align:center;color:var(--text-secondary,#888);margin-bottom:2rem;font-size:.9rem}.streak-banner{background:var(--card-bg,#ffffff0a);border:1px solid var(--border-color,#ffffff14);border-radius:12px;justify-content:center;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.streak-flame{font-size:2rem;line-height:1}.streak-info{flex-direction:column;display:flex}.streak-count{color:var(--text-primary,#f0f0f0);font-size:1.75rem;font-weight:700;line-height:1.1}.streak-label{color:var(--text-secondary,#888);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.progress-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.progress-card{background:var(--card-bg,#ffffff0a);border:1px solid var(--border-color,#ffffff14);border-radius:10px;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;transition:border-color .2s;display:flex}.progress-card:hover{border-color:var(--accent,#ffffff26)}.progress-card-icon{flex-shrink:0;margin-top:.1rem;font-size:1.5rem;line-height:1}.progress-card-body{flex-direction:column;flex:1;min-width:0;display:flex}.progress-card-label{color:var(--text-secondary,#888);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.15rem;font-size:.8rem}.progress-card-value{color:var(--text-primary,#f0f0f0);margin-bottom:.5rem;font-size:1.5rem;font-weight:700;line-height:1.2}.progress-bar-track{background:#ffffff14;border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:3px;height:100%;transition:width .6s}.progress-type-breakdown{gap:1rem;margin-bottom:1.5rem;display:flex}.progress-type-breakdown .progress-card{flex:1}.progress-loading,.progress-error{text-align:center;color:var(--text-secondary,#888);padding:3rem 1rem}.progress-error{color:var(--error,#e55)}.progress-empty{text-align:center;color:var(--text-secondary,#888);padding:3rem 1rem}.progress-empty p{margin:.5rem 0}.landing-container{justify-content:center;align-items:center;min-height:90vh;padding:2rem;display:flex}.landing-hero{text-align:center;max-width:520px}.landing-title{color:var(--text-primary,#fff);margin:0 0 .25rem;font-size:2.5rem;font-weight:700}.landing-title-kr{opacity:.7;font-weight:400}.landing-tagline{color:var(--text-secondary,#ffffffb3);margin:.5rem 0 2.5rem;font-size:1.1rem}.landing-features{text-align:left;flex-direction:column;gap:1.25rem;margin-bottom:2.5rem;display:flex}.landing-feature{align-items:flex-start;gap:.75rem;display:flex}.landing-feature-icon{color:var(--accent-color,#f97316);flex-shrink:0;margin-top:.1rem;font-size:1.2rem}.landing-feature h3{color:var(--text-primary,#fff);margin:0 0 .2rem;font-size:.95rem;font-weight:600}.landing-feature p{color:var(--text-secondary,#fff9);margin:0;font-size:.85rem;line-height:1.4}.landing-actions{justify-content:center;gap:.75rem;display:flex}.landing-btn{cursor:pointer;border:none;border-radius:8px;padding:.7rem 1.5rem;font-size:.95rem;font-weight:600;transition:opacity .2s}.landing-btn:hover{opacity:.9}.landing-btn-primary{background:var(--accent-color,#f97316);color:#fff}.landing-btn-secondary{color:var(--text-secondary,#ffffffb3);border:1px solid var(--border-color,#fff3);background:0 0}.auth-container{justify-content:center;align-items:center;min-height:80vh;padding:1rem;display:flex}.auth-card{background:var(--card-bg,#ffffff0d);border:1px solid var(--border-color,#ffffff1a);border-radius:12px;width:100%;max-width:400px;padding:2.5rem 2rem}.auth-title{color:var(--text-primary,#fff);margin:0 0 .25rem;font-size:1.5rem;font-weight:600}.auth-subtitle{color:var(--text-secondary,#fff9);margin:0 0 1.5rem;font-size:.9rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-field{flex-direction:column;gap:.35rem;display:flex}.auth-field label{color:var(--text-secondary,#fff9);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.auth-field input{background:var(--input-bg,#ffffff14);border:1px solid var(--border-color,#ffffff26);color:var(--text-primary,#fff);border-radius:8px;outline:none;padding:.65rem .75rem;font-size:.95rem;transition:border-color .2s}.auth-field input:focus{border-color:var(--accent-color,#f97316)}.auth-field input::placeholder{color:var(--text-secondary,#ffffff59)}.auth-error{color:#ef4444;background:#ef44441a;border-radius:6px;margin:0;padding:.5rem .75rem;font-size:.85rem}.auth-submit{background:var(--accent-color,#f97316);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:.5rem;padding:.7rem;font-size:1rem;font-weight:600;transition:opacity .2s}.auth-submit:hover:not(:disabled){opacity:.9}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-switch{text-align:center;color:var(--text-secondary,#fff9);margin-top:1.25rem;font-size:.85rem}.auth-link{color:var(--accent-color,#f97316);cursor:pointer;background:0 0;border:none;padding:0;font-size:.85rem;text-decoration:underline}.auth-link:hover{opacity:.8}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);height:56px;box-shadow:var(--shadow-header);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}.app-title{color:var(--text-primary);letter-spacing:-.02em;align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.app-title-kr{color:var(--text-muted);margin-left:-2px;font-family:Noto Sans KR,sans-serif;font-size:14px;font-weight:400}.app-title:before{content:"";background:var(--btn-primary-bg-flat);width:8px;height:8px;box-shadow:0 0 8px var(--btn-primary-bg-flat);border-radius:50%;display:inline-block}.header-controls{align-items:center;gap:8px;display:flex}.theme-select{appearance:none;background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239898b0' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:8px;padding:6px 28px 6px 12px;font-size:13px;font-weight:500;transition:all .2s}.theme-select:hover{border-color:var(--border-active);color:var(--text-primary)}.theme-select:focus{border-color:var(--border-active);outline:none}.type-filter{background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:8px;gap:2px;padding:2px;display:flex}.type-filter button{color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:500;transition:all .2s}.type-filter button:hover{color:var(--text-secondary)}.type-filter button.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);font-weight:600;box-shadow:0 1px 4px #0000004d}.sidebar-toggle{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s;display:none}.sidebar-toggle:hover{color:var(--text-primary);border-color:var(--border-active)}.app-body{flex:1;min-height:0;display:flex}.main-content{flex:1;justify-content:center;align-items:flex-start;padding:48px 32px 64px;display:flex;overflow-y:auto}.sidebar{border-left:1px solid var(--border-color);background:var(--bg-secondary);width:320px;max-height:calc(100vh - 56px);padding:24px 20px;position:sticky;top:56px;overflow-y:auto}.card-stage{width:100%;max-width:600px}.card-stage.empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:300px;font-size:16px;display:flex}.card-header{text-align:center;margin-bottom:20px}.pattern-badge{text-transform:uppercase;letter-spacing:.08em;border-radius:100px;align-items:center;gap:6px;padding:5px 14px;font-size:11px;font-weight:700;display:inline-flex}.pattern-badge.noun{background:var(--accent-noun-glow);color:var(--accent-noun);border:1px solid #ff8c4226}.pattern-badge.verb{background:var(--accent-verb-glow);color:var(--accent-verb);border:1px solid #4ade8026}.pattern-badge:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.pattern-en{color:var(--text-primary);letter-spacing:-.02em;margin-top:10px;font-size:20px;font-weight:600;display:block}.card-progress{color:var(--text-muted);justify-content:center;align-items:center;gap:12px;margin-bottom:28px;font-size:13px;font-weight:500;display:flex}.pass-indicator{color:var(--text-secondary);background:var(--btn-secondary-bg);border-radius:100px;padding:2px 10px;font-size:12px;font-weight:600}.shuffle-btn{background:var(--btn-secondary-bg);opacity:.6;border:1px solid var(--border-color);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;transition:all .2s;display:flex}.shuffle-btn:hover{opacity:1;border-color:var(--border-active)}.drill-display{background:var(--bg-card);border:1px solid var(--border-color);text-align:center;box-shadow:var(--shadow-card);border-radius:20px;margin-bottom:28px;padding:52px 36px 40px;position:relative;overflow:hidden}.drill-display:before{content:"";pointer-events:none;border-radius:20px;position:absolute;inset:0}.card-stage .drill-display.noun-card:before{background:var(--gradient-card-noun)}.card-stage .drill-display.verb-card:before{background:var(--gradient-card-verb)}.drill-sentence{letter-spacing:.02em;z-index:1;font-family:Noto Sans KR,sans-serif;font-size:38px;font-weight:400;line-height:1.7;position:relative}.blank-slot{min-width:80px;color:var(--accent-blank);border-bottom:3px dashed var(--accent-blank);text-shadow:0 0 20px var(--accent-blank-glow);padding:0 4px 4px;font-weight:700;animation:2s ease-in-out infinite blank-pulse;display:inline-block}@keyframes blank-pulse{0%,to{opacity:1}50%{opacity:.6}}.filled-slot{border-bottom:3px solid;padding:0 2px 4px;font-weight:700;position:relative}.filled-slot.noun{color:var(--accent-noun);border-color:var(--accent-noun);text-shadow:0 0 20px var(--accent-noun-glow-strong)}.filled-slot.verb{color:var(--accent-verb);border-color:var(--accent-verb);text-shadow:0 0 20px var(--accent-verb-glow-strong)}.token{color:var(--text-primary)}.literal-gloss{color:var(--text-muted);letter-spacing:.02em;z-index:1;margin-top:16px;font-size:15px;font-style:italic;font-weight:300;position:relative}.literal-toggle{background:var(--btn-secondary-bg);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--border-color);z-index:1;border-radius:100px;margin-top:10px;padding:4px 12px;font-size:11px;font-weight:600;transition:all .2s;position:relative}.literal-toggle:hover{color:var(--text-secondary);border-color:var(--border-active)}.drill-input{gap:10px;max-width:440px;margin:0 auto;display:flex}.drill-input input{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color);border-radius:14px;outline:none;flex:1;padding:14px 20px;font-family:Noto Sans KR,sans-serif;font-size:18px;transition:all .25s;box-shadow:0 2px 8px #00000026}.drill-input input:focus{border-color:var(--border-active);box-shadow:0 2px 12px #0003, 0 0 0 3px var(--btn-secondary-bg)}.drill-input input::placeholder{color:var(--text-muted);font-weight:400}.submit-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);letter-spacing:.01em;box-shadow:var(--btn-primary-shadow);border-radius:14px;padding:14px 28px;font-size:15px;font-weight:600;transition:all .2s}.submit-btn:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:translateY(-1px)}.submit-btn:active{transform:translateY(0)}.card-result{flex-direction:column;align-items:center;gap:4px;display:flex}.card-note{background:var(--bg-card);border:1px solid var(--border-color);width:100%;color:var(--text-secondary);text-align:left;border-radius:14px;padding:16px 20px;font-size:14px;line-height:1.6}.card-note strong{color:var(--text-primary);font-weight:600}.examples{text-align:left;width:100%;margin:8px 0 20px}.examples h4{text-transform:uppercase;color:var(--text-muted);letter-spacing:.1em;margin-bottom:10px;font-size:11px;font-weight:700}.example{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:3px;margin-bottom:6px;padding:12px 16px;transition:background .2s;display:flex}.example:hover{background:var(--bg-card-hover)}.example-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:17px;font-weight:400}.example-en{color:var(--text-muted);font-size:13px;font-weight:400}.example-literal{color:var(--text-muted);opacity:.65;border-top:1px dashed var(--border-color);margin-top:3px;padding-top:5px;font-size:12px;font-style:italic;font-weight:300}.next-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--btn-primary-shadow);letter-spacing:.01em;border-radius:14px;padding:14px 40px;font-size:15px;font-weight:600;transition:all .2s}.next-btn:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:translateY(-1px)}.next-btn:active{transform:translateY(0)}.rating-section{text-align:center;margin-top:20px}.rating-label{color:var(--text-muted);margin-bottom:10px;font-size:13px;font-weight:500}.rating-buttons{justify-content:center;gap:6px;display:flex}.rating-btn{border:1px solid var(--border-color);background:var(--btn-secondary-bg);max-width:90px;color:var(--text-secondary);border-radius:10px;flex:1;padding:10px 8px;font-size:13px;font-weight:700;transition:all .15s}.rating-btn:hover{box-shadow:var(--btn-hover-lift);transform:translateY(-1px)}.rating-btn:active{transform:translateY(0)}.rating-again{color:var(--accent-blank);border-color:#f8717133}.rating-again:hover{background:#f871711a}.rating-hard{color:var(--accent-noun);border-color:#ff8c4233}.rating-hard:hover{background:var(--accent-noun-glow)}.rating-good{color:var(--accent-verb);border-color:#4ade8033}.rating-good:hover{background:var(--accent-verb-glow)}.rating-easy{color:var(--text-primary);border-color:var(--border-active)}.rating-easy:hover{background:var(--btn-secondary-bg)}.card-assist-btns{justify-content:center;gap:8px;margin:8px 0 4px;display:flex}.assist-btn{background:var(--btn-secondary-bg);color:var(--text-muted);border:1px solid var(--border-color);border-radius:100px;padding:5px 16px;font-size:12px;font-weight:600;transition:all .2s}.assist-btn:hover{color:var(--text-secondary);border-color:var(--border-active)}.pronunciation-section{flex-direction:column;align-items:center;gap:8px;margin:8px 0;display:flex}.logout-btn{background:var(--btn-secondary-bg);color:var(--text-muted);border:1px solid var(--border-color);border-radius:8px;padding:5px 12px;font-size:12px;font-weight:600;transition:all .2s}.logout-btn:hover{color:var(--accent-blank);border-color:var(--accent-blank)}.paste-actions{align-items:center;gap:8px;display:flex}.paste-file-btn{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);white-space:nowrap;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.paste-file-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.lantern-player{flex-direction:column;align-items:center;gap:6px;margin:16px 0;display:flex}.lantern{cursor:pointer;background:0 0;border:none;width:52px;height:72px;padding:0;transition:transform .3s;position:relative}.lantern:hover{transform:scale(1.08)}.lantern:disabled{cursor:default;opacity:.3;transform:none}.lantern-svg{filter:drop-shadow(0 2px 4px #0000004d);width:100%;height:100%}.lantern-hook{fill:var(--text-muted);opacity:.5}.lantern-cap{fill:var(--text-muted);opacity:.4}.lantern-tassel{stroke:var(--text-muted);stroke-width:1.5px;opacity:.4}.lantern-tassel-end{fill:var(--text-muted);opacity:.4}.lantern-char{fill:#00000080;font-family:Inter,sans-serif;font-size:13px;font-weight:700}.lantern.noun .lantern-body{fill:var(--accent-noun);opacity:.15;transition:all .4s}.lantern.verb .lantern-body{fill:var(--accent-verb);opacity:.15;transition:all .4s}.lantern.idle .lantern-body{opacity:.35}.lantern.idle:hover .lantern-body{opacity:.5}.lantern.loading .lantern-body{animation:1.2s ease-in-out infinite lantern-breathe}@keyframes lantern-breathe{0%,to{opacity:.12}50%{opacity:.35}}.lantern.playing .lantern-body{opacity:1;animation:lantern-pulse var(--pulse-duration,1.2s) ease-in-out infinite}.lantern.playing .lantern-svg{filter:drop-shadow(0 2px 4px #0000004d)}.lantern.playing.noun .lantern-svg{filter:drop-shadow(0 0 16px var(--accent-noun-glow-strong)) drop-shadow(0 0 40px var(--accent-noun-glow))}.lantern.playing.verb .lantern-svg{filter:drop-shadow(0 0 16px var(--accent-verb-glow-strong)) drop-shadow(0 0 40px var(--accent-verb-glow))}@keyframes lantern-pulse{0%,to{opacity:.7}50%{opacity:1}}.lantern-controls{align-items:center;gap:6px;display:flex}.speed-btn{background:var(--btn-secondary-bg);color:var(--text-muted);border:1px solid var(--border-color);letter-spacing:.02em;border-radius:100px;padding:3px 10px;font-size:11px;font-weight:700;transition:all .2s}.speed-btn:hover{color:var(--text-secondary);border-color:var(--border-active)}.lantern-error{color:var(--accent-blank);font-size:11px;font-weight:500}.dictionary h3{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:16px;font-size:13px;font-weight:700}.dict-filters{background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:10px;gap:2px;margin-bottom:16px;padding:3px;display:flex}.filter-btn{color:var(--text-muted);background:0 0;border:none;border-radius:8px;flex:1;padding:6px;font-size:12px;font-weight:600;transition:all .2s}.filter-btn:hover{color:var(--text-secondary)}.filter-btn.active{color:var(--text-primary);background:var(--bg-card);box-shadow:0 1px 3px #0003}.filter-btn.active.noun{background:var(--accent-noun-glow);color:var(--accent-noun)}.filter-btn.active.verb{background:var(--accent-verb-glow);color:var(--accent-verb)}.filter-btn .count{opacity:.6;margin-left:3px;font-size:11px}.dict-entries{flex-direction:column;gap:4px;display:flex}.dict-empty{color:var(--text-muted);text-align:center;padding:32px 16px;font-size:13px;font-weight:400;line-height:1.6}.dict-entry{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;align-items:center;gap:8px;padding:10px 12px;transition:all .15s;display:flex}.dict-entry:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.dict-word{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:15px;font-weight:500}.dict-type{text-transform:uppercase;letter-spacing:.06em;border-radius:100px;padding:2px 7px;font-size:9px;font-weight:700}.dict-type.noun{color:var(--accent-noun);background:var(--accent-noun-glow)}.dict-type.verb{color:var(--accent-verb);background:var(--accent-verb-glow)}.dict-base{color:var(--text-muted);margin-left:auto;font-size:12px;font-weight:400}.dict-count{color:var(--text-muted);font-size:11px;font-weight:600}.kb-wrapper{width:100%;max-width:440px;margin:0 auto;position:relative}.kb-input-row{gap:8px;margin-bottom:8px;display:flex}.kb-input-row input{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color);border-radius:14px;outline:none;flex:1;padding:14px 20px;font-family:Noto Sans KR,sans-serif;font-size:18px;transition:all .25s;box-shadow:0 2px 8px #00000026}.kb-input-row input:focus{border-color:var(--border-active);box-shadow:0 2px 12px #0003, 0 0 0 3px var(--btn-secondary-bg)}.kb-input-row input::placeholder{color:var(--text-muted)}.kb-toggle{background:var(--btn-secondary-bg);border:1px solid var(--border-color);width:44px;height:44px;color:var(--text-muted);border-radius:12px;flex-shrink:0;justify-content:center;align-self:center;align-items:center;font-size:18px;transition:all .2s;display:flex}.kb-toggle:hover{color:var(--text-primary);border-color:var(--border-active)}.kb-toggle.active{color:var(--btn-primary-bg-flat);border-color:var(--btn-primary-bg-flat);background:var(--accent-noun-glow)}.korean-keyboard{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;margin-bottom:12px;padding:8px 6px;animation:.2s ease-out kb-slide-in;box-shadow:0 4px 20px #0000004d}@keyframes kb-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kb-row{justify-content:center;gap:4px;margin-bottom:4px;display:flex}.kb-row:last-child{margin-bottom:0}.kb-key{background:var(--bg-card);border:1px solid var(--border-color);min-width:32px;height:40px;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border-radius:8px;flex:1;justify-content:center;align-items:center;max-width:48px;padding:0;font-family:Noto Sans KR,sans-serif;font-size:16px;font-weight:400;transition:all .1s;display:flex}.kb-key:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.kb-key:active{background:var(--border-active);transform:scale(.94)}.kb-key.consonant .kb-jamo{color:var(--text-primary)}.kb-key.vowel .kb-jamo{color:var(--accent-verb)}.kb-shift{background:var(--btn-secondary-bg);max-width:52px;color:var(--text-muted)}.kb-shift.active{background:var(--accent-noun-glow);color:var(--accent-noun);border-color:var(--accent-noun)}.kb-backspace{background:var(--btn-secondary-bg);max-width:52px;color:var(--text-muted)}.kb-backspace:hover{color:var(--accent-blank)}.kb-bottom{gap:6px;margin-top:2px}.kb-space{text-transform:uppercase;letter-spacing:.1em;max-width:none;color:var(--text-muted);flex:3;font-family:Inter,sans-serif;font-size:12px;font-weight:600}.kb-enter{background:var(--btn-primary-bg);max-width:none;color:var(--btn-primary-text);letter-spacing:.02em;box-shadow:var(--btn-primary-shadow);border-color:#0000;flex:1.5;font-family:Inter,sans-serif;font-size:13px;font-weight:700}.kb-enter:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:none}.kb-enter:active{transform:scale(.97)}.nav-bar{background:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-around;align-items:center;height:60px;padding:0 4px;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-tab{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:0 0;border:none;border-radius:10px;flex-direction:column;align-items:center;gap:2px;min-width:56px;padding:6px 12px;font-size:10px;font-weight:600;transition:all .2s;display:flex}.nav-tab:hover{color:var(--text-secondary)}.nav-tab.active{color:var(--btn-primary-bg-flat)}.nav-tab.active .nav-icon{transform:scale(1.1)}.nav-icon{font-size:18px;line-height:1;transition:transform .2s}.nav-label{line-height:1}.app-body-wrapper{flex-direction:column;flex:1;min-height:0;padding-bottom:60px;display:flex}.app-body-wrapper .app-body{flex:1;min-height:0;display:flex}.app-body-wrapper.no-sidebar .main-content{flex:1}.hangul-chart-btn{background:var(--btn-secondary-bg);width:36px;height:36px;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;justify-content:center;align-items:center;font-family:Noto Sans KR,sans-serif;font-size:16px;font-weight:700;transition:all .2s;display:flex}.hangul-chart-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.import-section{flex-direction:column;gap:24px;width:100%;max-width:720px;display:flex}.import-header{text-align:center;margin-bottom:8px}.import-title{color:var(--text-primary);margin:0 0 8px;font-size:22px;font-weight:700}.import-subtitle{color:var(--text-muted);margin:0;font-size:14px;line-height:1.6}.paste-box{flex-direction:column;gap:16px;display:flex}.paste-box-label{color:var(--text-secondary);letter-spacing:.02em;font-size:13px;font-weight:600}.paste-textarea{background:var(--bg-input);width:100%;min-height:180px;color:var(--text-primary);border:1px solid var(--border-color);resize:vertical;box-sizing:border-box;border-radius:12px;padding:16px;font-family:Noto Sans KR,sans-serif;font-size:15px;line-height:1.7;transition:border-color .2s}.paste-textarea:focus{border-color:var(--border-active);outline:none}.paste-textarea::placeholder{color:var(--text-muted);opacity:.6}.paste-textarea:disabled{opacity:.5}.paste-options{flex-wrap:wrap;align-items:flex-end;gap:20px;display:flex}.paste-source-type,.paste-source-label{flex-direction:column;gap:6px;display:flex}.paste-source-label{flex:1;min-width:180px}.paste-option-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.source-type-buttons{background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:8px;gap:2px;padding:2px;display:flex}.source-type-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:500;transition:all .2s}.source-type-btn:hover{color:var(--text-secondary)}.source-type-btn.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);font-weight:600;box-shadow:0 1px 4px #0000004d}.paste-label-input{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;padding:7px 12px;font-size:13px;transition:border-color .2s}.paste-label-input:focus{border-color:var(--border-active);outline:none}.paste-label-input::placeholder{color:var(--text-muted);opacity:.6}.paste-label-input:disabled{opacity:.5}.paste-submit-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);cursor:pointer;box-shadow:var(--btn-primary-shadow);border:none;border-radius:10px;align-self:flex-start;padding:10px 28px;font-size:14px;font-weight:600;transition:all .2s}.paste-submit-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.paste-submit-btn:disabled{opacity:.4;cursor:not-allowed}.import-error{color:#f87171;background:#f871711a;border:1px solid #f8717133;border-radius:10px;padding:12px 16px;font-size:13px}.import-success{color:var(--accent-verb);background:#4ade801a;border:1px solid #4ade8033;border-radius:10px;padding:12px 16px;font-size:13px;font-weight:500}.import-results{flex-direction:column;gap:16px;display:flex}.import-results-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.import-results-title{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.import-results-actions{gap:8px;display:flex}.import-select-btn{background:var(--btn-secondary-bg);color:var(--text-muted);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .2s}.import-select-btn:hover{color:var(--text-secondary);border-color:var(--border-active)}.card-preview-grid{flex-direction:column;gap:12px;display:flex}.card-preview{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px;transition:all .2s}.card-preview.selected{border-color:var(--border-active)}.card-preview.rejected{opacity:.45}.card-preview-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.card-preview-toggle{cursor:pointer;position:relative}.card-preview-toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:10px;width:36px;height:20px;transition:all .2s;display:block;position:relative}.toggle-thumb{background:var(--text-muted);border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;top:2px;left:2px}.card-preview-toggle input:checked+.toggle-track{border-color:var(--accent-verb);background:#4ade8033}.card-preview-toggle input:checked+.toggle-track .toggle-thumb{background:var(--accent-verb);left:18px}.card-preview-pattern{flex-direction:column;gap:2px;margin-bottom:10px;display:flex}.card-preview-en{color:var(--text-primary);font-size:15px;font-weight:600}.card-preview-kr{color:var(--text-muted);font-family:Noto Sans KR,sans-serif;font-size:13px}.card-preview-tokens{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.preview-token{background:var(--btn-secondary-bg);color:var(--text-secondary);border-radius:6px;padding:3px 8px;font-family:Noto Sans KR,sans-serif;font-size:14px}.preview-token.blankable{background:var(--accent-blank-glow);color:var(--accent-blank);font-weight:600}.card-preview-example{color:var(--text-secondary);background:var(--bg-surface);border-radius:6px;margin-bottom:8px;padding:6px 10px;font-family:Noto Sans KR,sans-serif;font-size:13px}.card-preview-note{color:var(--text-muted);font-size:12px;line-height:1.5}.import-footer{justify-content:center;padding-top:8px;display:flex}.import-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);cursor:pointer;box-shadow:var(--btn-primary-shadow);border:none;border-radius:10px;padding:12px 36px;font-size:15px;font-weight:600;transition:all .2s}.import-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.import-btn:disabled{opacity:.4;cursor:not-allowed}.import-empty{text-align:center;color:var(--text-muted);padding:32px 16px}.import-empty-icon{letter-spacing:4px;margin-bottom:12px;font-size:32px;display:block}.import-empty p{margin:0 0 6px;font-size:14px}.import-empty-hint{max-width:400px;margin:8px auto 0;font-size:12px;line-height:1.6}.placeholder-section{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;max-width:480px;margin:0 auto;padding:80px 32px;display:flex}.placeholder-icon{margin-bottom:8px;font-size:48px}.placeholder-section h2{color:var(--text-primary);font-size:22px;font-weight:700}.placeholder-section p{color:var(--text-muted);font-size:14px;line-height:1.6}.placeholder-badge{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:100px;margin-top:8px;padding:4px 14px;font-size:11px;font-weight:700;display:inline-block}.dictionary-full{width:100%;max-width:1000px;margin:0 auto;padding:32px 24px}.dictionary-full .dictionary-page{width:100%}.dict-page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dict-page-title{color:var(--text-primary);letter-spacing:-.02em;font-size:22px;font-weight:700}.dict-quiz-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--btn-primary-shadow);border-radius:100px;padding:8px 20px;font-size:13px;font-weight:600;transition:all .2s}.dict-quiz-btn:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:translateY(-1px)}.dict-search-wrap{margin-bottom:16px}.dict-search{background:var(--bg-input);width:100%;color:var(--text-primary);border:1px solid var(--border-color);border-radius:14px;outline:none;padding:12px 18px;font-family:Noto Sans KR,Inter,sans-serif;font-size:15px;transition:all .25s;box-shadow:0 2px 8px #00000026}.dict-search:focus{border-color:var(--border-active);box-shadow:0 2px 12px #0003, 0 0 0 3px var(--btn-secondary-bg)}.dict-search::placeholder{color:var(--text-muted);font-weight:400}.dict-source-filter{background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:10px;gap:2px;margin-bottom:12px;padding:3px;display:flex}.source-pill{color:var(--text-muted);background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.source-pill:hover{color:var(--text-secondary)}.source-pill.active{color:var(--text-primary);background:var(--bg-card);box-shadow:0 1px 3px #0003}.source-count{background:var(--accent-noun-glow);color:var(--accent-noun);border-radius:100px;padding:1px 6px;font-size:10px;font-weight:700}.category-filter{scrollbar-width:thin;gap:6px;margin-bottom:16px;padding-bottom:4px;display:flex;overflow-x:auto}.category-filter::-webkit-scrollbar{height:3px}.category-pill{background:var(--btn-secondary-bg);color:var(--text-muted);border:1px solid var(--border-color);white-space:nowrap;border-radius:100px;flex-shrink:0;align-items:center;gap:5px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.category-pill:hover{color:var(--text-secondary);border-color:var(--border-active)}.category-pill.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:#0000;box-shadow:0 1px 4px #0000004d}.category-emoji{font-size:14px;line-height:1}.category-label{line-height:1}.dict-count-label{color:var(--text-muted);margin-bottom:12px;font-size:12px;font-weight:500}.dict-tiles-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;display:grid}.dict-tile{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;text-align:center;box-shadow:var(--shadow-card);border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:16px 10px 12px;transition:all .2s;display:flex;position:relative}.dict-tile:hover{background:var(--bg-card-hover);border-color:var(--border-active);transform:translateY(-2px);box-shadow:0 4px 16px #00000040}.dict-tile.personal{border-color:var(--accent-noun);border-style:dashed}.dict-star-badge{color:var(--accent-noun);filter:drop-shadow(0 0 4px var(--accent-noun-glow-strong));font-size:12px;position:absolute;top:6px;right:8px}.dict-tile-emoji{margin-bottom:2px;font-size:32px;line-height:1}.dict-tile-emoji-sm{font-size:16px;line-height:1}.dict-tile-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:17px;font-weight:500}.dict-tile-en{color:var(--text-muted);font-size:12px;font-weight:400;line-height:1.3}.dict-tile-roman{color:var(--text-muted);opacity:.6;font-size:10px;font-style:italic}.dict-tile-type{text-transform:uppercase;letter-spacing:.06em;border-radius:100px;padding:1px 6px;font-size:8px;font-weight:700}.dict-tile-type.noun{color:var(--accent-noun);background:var(--accent-noun-glow)}.dict-tile-type.verb{color:var(--accent-verb);background:var(--accent-verb-glow)}.dict-tile-level{letter-spacing:.04em;border-radius:100px;padding:1px 6px;font-size:9px;font-weight:700}.dict-tile-level.level-1{color:var(--accent-verb);background:var(--accent-verb-glow)}.dict-tile-level.level-2{color:var(--accent-noun);background:var(--accent-noun-glow)}.dict-tile-level.level-3{color:var(--text-muted);background:var(--btn-secondary-bg)}.quiz-mode{width:100%;max-width:720px;margin:0 auto}.quiz-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.quiz-title{color:var(--text-primary);flex:1;font-size:20px;font-weight:700}.quiz-subtitle{color:var(--text-muted);margin-bottom:24px;font-size:14px}.quiz-back-btn{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.quiz-back-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.quiz-category-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;display:grid}.quiz-category-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;box-shadow:var(--shadow-card);border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;transition:all .2s;display:flex}.quiz-category-card:hover{background:var(--bg-card-hover);border-color:var(--border-active);transform:translateY(-2px);box-shadow:0 4px 16px #00000040}.quiz-cat-emoji{font-size:36px;line-height:1}.quiz-cat-label{color:var(--text-primary);font-size:14px;font-weight:600}.quiz-hint-area{margin-left:auto}.quiz-hint-btn{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:100px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .2s}.quiz-hint-btn:hover:not(:disabled){color:var(--accent-noun);border-color:var(--accent-noun)}.quiz-hint-btn:disabled{opacity:.4;cursor:default}.quiz-word-bank{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:24px;padding:16px;display:flex}.quiz-chip{background:var(--btn-secondary-bg);color:var(--text-primary);border:2px solid var(--border-color);cursor:pointer;border-radius:100px;padding:8px 18px;font-family:Noto Sans KR,sans-serif;font-size:16px;font-weight:500;transition:all .2s}.quiz-chip:hover:not(:disabled){border-color:var(--border-active);background:var(--bg-card-hover)}.quiz-chip.selected{border-color:var(--btn-primary-bg-flat);background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:0 0 12px var(--btn-primary-bg-flat)}.quiz-chip.used{opacity:.3;cursor:default;text-decoration:line-through}.quiz-chip.eliminated{opacity:.15;cursor:default;text-decoration:line-through}.quiz-targets{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;display:grid}.quiz-target{background:var(--bg-card);border:2px solid var(--border-color);cursor:default;text-align:center;border-radius:14px;flex-direction:column;align-items:center;gap:6px;min-height:100px;padding:20px 12px 16px;transition:all .2s;display:flex}.quiz-target.selectable{cursor:pointer}.quiz-target.selectable:hover{border-color:var(--border-active);background:var(--bg-card-hover)}.quiz-target.correct{border-color:var(--accent-verb);background:var(--accent-verb-glow)}.quiz-target.wrong{border-color:var(--accent-blank);background:#ef444414}.quiz-target-emoji{font-size:28px;line-height:1}.quiz-target-en{color:var(--text-secondary);font-size:13px;font-weight:500}.quiz-target-matched{color:var(--text-primary);margin-top:2px;font-family:Noto Sans KR,sans-serif;font-size:14px;font-weight:600}.quiz-score-card{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-card);border-radius:20px;flex-direction:column;align-items:center;gap:12px;margin-bottom:24px;padding:32px;display:flex}.quiz-score-circle{background:var(--btn-primary-bg);width:100px;height:100px;box-shadow:0 0 20px var(--btn-primary-bg-flat);border-radius:50%;justify-content:center;align-items:center;display:flex}.quiz-score-pct{color:var(--btn-primary-text);font-size:28px;font-weight:700}.quiz-score-text{color:var(--text-secondary);font-size:16px;font-weight:500}.quiz-perfect{color:var(--accent-verb);text-transform:uppercase;letter-spacing:.08em;font-size:14px;font-weight:700}.quiz-wrong-list{margin-bottom:24px}.quiz-wrong-list h4{text-transform:uppercase;color:var(--text-muted);letter-spacing:.1em;margin-bottom:10px;font-size:12px;font-weight:700}.quiz-wrong-item{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;border-radius:10px;align-items:center;gap:10px;margin-bottom:6px;padding:10px 14px;transition:all .15s;display:flex}.quiz-wrong-item:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.quiz-wrong-emoji{font-size:20px}.quiz-wrong-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:16px;font-weight:500}.quiz-wrong-en{color:var(--text-muted);margin-left:auto;font-size:13px}.quiz-actions{justify-content:center;gap:10px;display:flex}.quiz-retry-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--btn-primary-shadow);border-radius:14px;padding:12px 28px;font-size:15px;font-weight:600;transition:all .2s}.quiz-retry-btn:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:translateY(-1px)}.learn-section{width:100%;max-width:720px;margin:0 auto;padding:32px 24px 48px}.learn-header{margin-bottom:32px}.learn-title{color:var(--text-primary);margin-bottom:8px;font-size:24px;font-weight:700}.learn-subtitle{color:var(--text-muted);font-size:14px;line-height:1.6}.learn-loading{color:var(--text-muted);text-align:center;padding:48px 16px;font-size:14px}.lesson-grid{flex-direction:column;gap:12px;display:flex}.lesson-card{text-align:left;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;align-items:flex-start;gap:6px;padding:20px 24px;transition:all .2s;display:flex}.lesson-card:hover{background:var(--bg-card-hover);border-color:var(--border-active);box-shadow:var(--shadow-card);transform:translateY(-1px)}.lesson-number{text-transform:uppercase;letter-spacing:.08em;color:var(--btn-primary-bg-flat);font-size:11px;font-weight:700}.lesson-card-title{color:var(--text-primary);font-size:17px;font-weight:600}.lesson-card-desc{color:var(--text-muted);font-size:13px;line-height:1.5}.lesson-card-meta{gap:12px;margin-top:4px;display:flex}.lesson-char-count,.lesson-exercise-count{color:var(--text-muted);background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:100px;padding:2px 10px;font-size:11px;font-weight:600}.lesson-char-preview{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.lesson-char-chip{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;padding:2px 8px;font-family:Noto Sans KR,sans-serif;font-size:15px;font-weight:400}.lesson-char-chip.more{color:var(--text-muted);font-size:11px;font-weight:600}.lesson-view{width:100%;max-width:640px;margin:0 auto;padding:24px 24px 48px}.back-btn{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:6px;margin-bottom:20px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.back-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.lesson-view-header{margin-bottom:28px}.lesson-view-title{color:var(--text-primary);margin-top:4px;margin-bottom:8px;font-size:22px;font-weight:700}.lesson-view-desc{color:var(--text-muted);font-size:14px;line-height:1.6}.section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:14px;font-size:11px;font-weight:700}.character-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px;margin-bottom:20px;display:grid}.char-grid-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;transition:all .2s;display:flex}.char-grid-item:hover{background:var(--bg-card-hover);border-color:var(--border-active);transform:translateY(-1px)}.char-grid-item.consonant .char-grid-char{color:#f87171}.char-grid-item.vowel .char-grid-char{color:#60a5fa}.char-grid-char{font-family:Noto Sans KR,sans-serif;font-size:28px;font-weight:400;line-height:1}.char-grid-rom{color:var(--text-muted);font-size:11px;font-weight:500}.start-learning-btn,.start-exercises-btn{background:var(--btn-primary-bg);width:100%;color:var(--btn-primary-text);box-shadow:var(--btn-primary-shadow);border:none;border-radius:14px;margin-top:8px;padding:14px;font-size:15px;font-weight:600;transition:all .2s;display:block}.start-learning-btn:hover,.start-exercises-btn:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:translateY(-1px)}.skip-to-exercises-btn{background:var(--btn-secondary-bg);width:100%;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:12px;margin-top:8px;padding:12px;font-size:13px;font-weight:500;transition:all .2s;display:block}.skip-to-exercises-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.exercises-section{margin-top:32px}.exercises-intro{color:var(--text-muted);margin-bottom:16px;font-size:14px;line-height:1.5}.character-card-view{width:100%;max-width:560px;margin:0 auto;padding:24px 24px 48px}.char-card-nav{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.char-card-progress{color:var(--text-muted);background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:100px;padding:4px 12px;font-size:13px;font-weight:600}.char-display{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-card);border-radius:20px;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px;padding:40px 24px 32px;display:flex}.char-display.consonant .char-large{color:#f87171;text-shadow:0 0 40px #f8717133}.char-display.vowel .char-large{color:#60a5fa;text-shadow:0 0 40px #60a5fa33}.char-large{font-family:Noto Sans KR,sans-serif;font-size:96px;font-weight:400;line-height:1}.char-romanization{color:var(--text-secondary);font-size:20px;font-weight:600}.char-type-badge{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:100px;padding:3px 12px;font-size:10px;font-weight:700}.char-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;margin-bottom:12px;padding:16px 20px}.char-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:700}.char-section-text{color:var(--text-secondary);font-size:14px;line-height:1.6}.char-section.phonetic-bridge{border-color:#4ade8026}.char-section.phonetic-bridge .char-section-label{color:var(--accent-verb)}.char-section.mouth-position{border-color:#ff8c4226}.char-section.mouth-position .char-section-label{color:var(--accent-noun)}.stroke-order-display{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.stroke-number{background:var(--btn-secondary-bg);width:28px;height:28px;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.stroke-hint{color:var(--text-muted);margin-left:4px;font-size:12px}.char-words{flex-direction:column;gap:8px;display:flex}.char-word-item{background:var(--bg-card-hover);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;gap:2px;padding:10px 14px;display:flex}.char-word-top{align-items:baseline;gap:10px;display:flex}.char-word-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:18px;font-weight:500}.char-word-rom{color:var(--text-muted);font-size:12px}.char-word-en{color:var(--text-muted);font-size:13px}.char-word-item .lantern-player{flex-direction:row;gap:8px;margin:4px 0 0}.char-word-item .lantern{width:28px;height:38px}.char-card-actions{gap:10px;margin-top:24px;display:flex}.char-nav-btn{border:none;border-radius:14px;flex:1;padding:14px;font-size:14px;font-weight:600;transition:all .2s}.char-nav-btn.prev{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color)}.char-nav-btn.prev:hover{color:var(--text-primary);border-color:var(--border-active)}.char-nav-btn.next{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--btn-primary-shadow)}.char-nav-btn.next:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:translateY(-1px)}.exercise-view{width:100%;max-width:560px;margin:0 auto;padding:24px 24px 48px}.exercise-top-bar{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.exercise-progress{color:var(--text-muted);background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:100px;padding:4px 12px;font-size:13px;font-weight:600}.exercise-card{background:var(--bg-card);border:1px solid var(--border-color);text-align:center;box-shadow:var(--shadow-card);border-radius:20px;padding:32px 28px}.exercise-type-badge{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:100px;margin-bottom:16px;padding:3px 12px;font-size:10px;font-weight:700;display:inline-block}.exercise-prompt{color:var(--text-primary);margin-bottom:24px;font-size:17px;font-weight:500;line-height:1.5}.exercise-options{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;display:grid}.exercise-option{background:var(--btn-secondary-bg);color:var(--text-primary);border:2px solid var(--border-color);border-radius:14px;padding:16px 12px;font-family:Noto Sans KR,sans-serif;font-size:22px;font-weight:400;transition:all .2s}.exercise-option:hover:not(:disabled){border-color:var(--border-active);background:var(--bg-card-hover)}.exercise-option.selected{border-color:var(--btn-primary-bg-flat)}.exercise-option.correct{border-color:var(--accent-verb);background:var(--accent-verb-glow);color:var(--accent-verb)}.exercise-option.wrong{border-color:var(--accent-blank);background:var(--accent-blank-glow);color:var(--accent-blank)}.exercise-feedback{border-radius:10px;margin-bottom:16px;padding:8px 16px;font-size:15px;font-weight:600}.exercise-feedback.correct{color:var(--accent-verb);background:var(--accent-verb-glow)}.exercise-feedback.wrong{color:var(--accent-blank);background:var(--accent-blank-glow)}.exercise-next-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);box-shadow:var(--btn-primary-shadow);border:none;border-radius:14px;padding:14px 40px;font-size:15px;font-weight:600;transition:all .2s}.exercise-next-btn:hover{box-shadow:var(--btn-hover-lift), var(--btn-primary-shadow);transform:translateY(-1px)}.match-pairs-grid{justify-content:center;gap:20px;margin-bottom:20px;display:flex}.match-column{flex-direction:column;gap:8px;display:flex}.match-item{background:var(--btn-secondary-bg);border:2px solid var(--border-color);color:var(--text-primary);border-radius:12px;min-width:80px;padding:12px 20px;font-family:Noto Sans KR,sans-serif;font-size:18px;transition:all .2s}.match-item.rom{font-family:Inter,sans-serif;font-size:14px;font-weight:500}.match-item:hover:not(:disabled){border-color:var(--border-active)}.match-item.selected{border-color:var(--btn-primary-bg-flat);background:var(--accent-noun-glow)}.match-item.matched{border-color:var(--accent-verb);background:var(--accent-verb-glow);color:var(--accent-verb);opacity:.7}.exercise-complete{text-align:center;padding:48px 24px}.exercise-complete-icon{margin-bottom:16px;font-size:48px}.exercise-complete h3{color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.exercise-complete p{color:var(--text-muted);margin-bottom:24px;font-size:15px}.exercise-complete-actions{flex-direction:column;align-items:center;gap:10px;display:flex}.hangul-chart-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.hangul-chart{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;width:100%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 48px #00000080}.hangul-chart-header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);z-index:1;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.hangul-chart-header h3{color:var(--text-primary);font-size:16px;font-weight:700}.hangul-chart-close{background:var(--btn-secondary-bg);width:32px;height:32px;color:var(--text-muted);border:1px solid var(--border-color);border-radius:8px;justify-content:center;align-items:center;font-size:20px;transition:all .2s;display:flex}.hangul-chart-close:hover{color:var(--text-primary);border-color:var(--border-active)}.hangul-chart-body{padding:20px}.chart-group{margin-bottom:20px}.chart-group-label{text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;font-size:11px;font-weight:700}.consonant-label{color:#f87171}.vowel-label{color:#60a5fa}.chart-grid{grid-template-columns:repeat(auto-fill,minmax(58px,1fr));gap:6px;display:grid}.chart-cell{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:10px 4px;transition:all .15s;display:flex}.chart-cell:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.chart-cell.active{border-color:var(--btn-primary-bg-flat);box-shadow:0 0 12px #ff8c4226}.chart-cell.consonant .chart-char{color:#f87171}.chart-cell.vowel .chart-char{color:#60a5fa}.chart-char{font-family:Noto Sans KR,sans-serif;font-size:22px;font-weight:400;line-height:1}.chart-rom{color:var(--text-muted);font-size:9px;font-weight:500}.chart-detail{background:var(--bg-card);border:1px solid var(--border-color);text-align:center;border-radius:14px;margin-top:12px;padding:20px}.chart-detail-char{margin-bottom:8px;font-family:Noto Sans KR,sans-serif;font-size:48px;font-weight:400}.chart-detail-char.consonant{color:#f87171}.chart-detail-char.vowel{color:#60a5fa}.chart-detail-trick{color:var(--text-secondary);margin-bottom:6px;font-size:13px;line-height:1.5}.chart-detail-bridge{color:var(--accent-verb);margin-bottom:6px;font-size:13px;line-height:1.5}.chart-detail-mouth{color:var(--accent-noun);margin-bottom:6px;font-size:13px;line-height:1.5}.chart-detail-words{flex-wrap:wrap;justify-content:center;gap:6px;margin:8px 0;display:flex}.chart-detail-word{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:100px;padding:3px 10px;font-size:12px}.chart-detail .lantern-player{margin-top:8px}@media (width<=900px){.app-header{height:50px;padding:0 16px}.app-title{font-size:16px}.sidebar{display:none}.sidebar.open{z-index:100;border-left:1px solid var(--border-color);height:100vh;display:block;position:fixed;top:0;right:0;box-shadow:-8px 0 32px #00000080}.sidebar-toggle{display:block}.main-content{padding:32px 16px 48px}.drill-sentence{font-size:30px}.drill-display{border-radius:16px;padding:36px 24px 32px}.drill-input{flex-direction:column;max-width:100%}.submit-btn{width:100%}.character-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.char-large{font-size:72px}.exercise-options{grid-template-columns:1fr 1fr}.hangul-chart{border-radius:16px;max-height:80vh}.chart-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr))}}@media (width<=500px){.type-filter{display:none}.drill-sentence{font-size:26px}.pattern-en{font-size:17px}.nav-tab{min-width:48px;padding:6px;font-size:9px}.nav-icon{font-size:16px}.learn-section{padding:24px 16px 48px}.character-card-view,.exercise-view,.lesson-view{padding:16px 16px 48px}.char-large{font-size:60px}.exercise-option{padding:12px 10px;font-size:18px}.match-pairs-grid{gap:10px}.match-item{min-width:60px;padding:10px 14px;font-size:16px}}.cultural-context{margin-top:12px;position:relative}.cultural-context__trigger{color:var(--text-muted);cursor:pointer;letter-spacing:.02em;opacity:.6;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-size:12px;font-weight:500;transition:all .2s;display:inline-flex}.cultural-context__trigger:hover{opacity:1;background:var(--bg-card-hover,#ffffff0a);color:var(--text-secondary)}.cultural-context--open .cultural-context__trigger{opacity:1;color:var(--text-secondary)}.cultural-context__icon{opacity:.7;flex-shrink:0;transition:opacity .2s}.cultural-context__trigger:hover .cultural-context__icon{opacity:1}.cultural-context__label{white-space:nowrap}.cultural-context__body{background:var(--bg-card,#ffffff08);border:1px solid var(--border-color);border-radius:12px;margin-top:10px;padding:16px 20px;animation:.25s ease-out culturalFadeIn}@keyframes culturalFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cultural-context__title{color:var(--text-primary);letter-spacing:-.01em;margin:0 0 8px;font-size:14px;font-weight:600}.cultural-context__text{color:var(--text-secondary);margin:0 0 10px;font-size:13px;line-height:1.65}.cultural-context__concept{color:var(--text-muted);background:var(--bg-card-hover,#ffffff0a);border-radius:6px;padding:3px 10px;font-family:Noto Sans KR,sans-serif;font-size:13px;font-weight:500;display:inline-block}.cultural-context__concept-en{color:var(--text-muted);opacity:.7;font-family:inherit;font-size:12px;font-weight:400}
