@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+KR:wght@300;400;500;700&display=swap";[data-source=kpop]{--bg-primary:#1a1a2e;--bg-secondary:#1a1a2e;--bg-card:#ede8dc;--bg-card-hover:#f4efe3;--bg-input:#e6e0d2;--bg-surface:#ede8dc;--text-primary:#1a1a2e;--text-secondary:#6b6760;--text-muted:#5c5850;--text-title-on-dark:#ede8dc;--text-subtitle-on-dark:#cfc6b2;--meta-pill-bg:#d6d0c0;--meta-pill-text:#5c5850;--card-bg:#ede8dc;--input-bg:#e6e0d2;--accent-color:#f97316;--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-adjective:#a855f7;--accent-adjective-dim:#8b3fd4;--accent-adjective-glow:#a855f71f;--accent-adjective-glow-strong:#a855f740;--accent-blank:#f87171;--accent-blank-glow:#f871712e;--border-color:#1a1a2e1f;--border-active:#1a1a2e38;--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:#d6d0c0;--btn-secondary-text:#1a1a2e;--btn-hover-lift:0 6px 24px #0006;--shadow-card:0 8px 24px #00000038, 0 0 0 1px #1a1a2e0f;--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-card-adjective:linear-gradient(180deg, #a855f70a 0%, transparent 60%);--gradient-page:radial-gradient(ellipse at 50% 0%, #ff8c420f 0%, transparent 60%)}[data-source=kdrama]{--bg-primary:#1a1a2e;--bg-secondary:#1a1a2e;--bg-card:#ede8dc;--bg-card-hover:#f4efe3;--bg-input:#e6e0d2;--bg-surface:#ede8dc;--text-primary:#1a1a2e;--text-secondary:#6b6760;--text-muted:#5c5850;--text-title-on-dark:#ede8dc;--text-subtitle-on-dark:#cfc6b2;--meta-pill-bg:#d6d0c0;--meta-pill-text:#5c5850;--card-bg:#ede8dc;--input-bg:#e6e0d2;--accent-color:#f97316;--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-adjective:#a855f7;--accent-adjective-dim:#8b3fd4;--accent-adjective-glow:#a855f71f;--accent-adjective-glow-strong:#a855f740;--accent-blank:#f87171;--accent-blank-glow:#f871712e;--border-color:#1a1a2e1f;--border-active:#1a1a2e38;--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:#d6d0c0;--btn-secondary-text:#1a1a2e;--btn-hover-lift:0 6px 24px #00000080;--shadow-card:0 8px 24px #00000038, 0 0 0 1px #1a1a2e0f;--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-card-adjective:linear-gradient(180deg, #a855f708 0%, transparent 60%);--gradient-page:radial-gradient(ellipse at 50% 0%, #d4a44c0f 0%, transparent 60%)}[data-source=custom]{--bg-primary:#1a1a2e;--bg-secondary:#1a1a2e;--bg-card:#ede8dc;--bg-card-hover:#f4efe3;--bg-input:#e6e0d2;--bg-surface:#ede8dc;--text-primary:#1a1a2e;--text-secondary:#6b6760;--text-muted:#5c5850;--text-title-on-dark:#ede8dc;--text-subtitle-on-dark:#cfc6b2;--meta-pill-bg:#d6d0c0;--meta-pill-text:#5c5850;--card-bg:#ede8dc;--input-bg:#e6e0d2;--accent-color:#f97316;--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-adjective:#a855f7;--accent-adjective-dim:#8b3fd4;--accent-adjective-glow:#a855f71f;--accent-adjective-glow-strong:#a855f740;--accent-blank:#f87171;--accent-blank-glow:#f871712e;--border-color:#1a1a2e1f;--border-active:#1a1a2e38;--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:#d6d0c0;--btn-secondary-text:#1a1a2e;--btn-hover-lift:0 6px 24px #0006;--shadow-card:0 8px 24px #00000038, 0 0 0 1px #1a1a2e0f;--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-card-adjective:linear-gradient(180deg, #a855f708 0%, transparent 60%);--gradient-page:radial-gradient(ellipse at 50% 0%, #5b8def0f 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}.verb-intro-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;justify-content:center;align-items:center;animation:.3s verb-intro-fade-in;display:flex;position:fixed;inset:0}@keyframes verb-intro-fade-in{0%{opacity:0}to{opacity:1}}.verb-intro-card{background:var(--bg-card);border:1px solid var(--border-color);width:90%;max-width:420px;max-height:85vh;box-shadow:var(--shadow-card);border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:32px 28px;animation:.35s verb-intro-slide-up;display:flex;overflow-y:auto}@keyframes verb-intro-slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.verb-intro-da{letter-spacing:.02em;text-align:center;font-family:Noto Sans KR,sans-serif;font-size:42px;font-weight:700;line-height:1.2}.verb-intro-da.action-verb{color:var(--accent-verb);text-shadow:0 0 24px var(--accent-verb-glow-strong)}.verb-intro-da.adjective{color:var(--accent-adjective);text-shadow:0 0 24px #a855f740}.verb-intro-roman{color:var(--text-muted);letter-spacing:.15em;text-align:center;font-size:16px}.verb-intro-en{color:var(--text-secondary);text-align:center;font-size:18px;font-weight:500}.verb-intro-emoji{font-size:48px;line-height:1}.verb-intro-desc-note{color:var(--text-muted);text-align:center;background:#a855f70f;border:1px solid #a855f726;border-radius:10px;padding:12px 16px;font-size:13px;line-height:1.6}.verb-intro-usage{border-top:1px solid var(--border-color);flex-direction:column;align-items:center;gap:8px;width:100%;padding:16px 0;display:flex}.verb-intro-usage-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:11px}.verb-intro-usage-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:20px;font-weight:500}.verb-intro-usage-en{color:var(--text-secondary);font-size:14px}.verb-intro-usage-source{color:var(--text-muted);font-size:12px;font-style:italic}.verb-intro-tts{justify-content:center;padding:4px 0;display:flex}.verb-intro-conjugations{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.verb-intro-conj-tag{background:var(--btn-secondary-bg);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:6px;padding:3px 10px;font-family:Noto Sans KR,sans-serif;font-size:13px}.verb-intro-actions{gap:10px;width:100%;padding-top:8px;display:flex}.verb-intro-got-it{background:var(--btn-primary-bg);color:var(--btn-primary-text);cursor:pointer;box-shadow:var(--btn-primary-shadow);border:none;border-radius:10px;flex:1;padding:12px 0;font-size:15px;font-weight:600;transition:all .2s}.verb-intro-got-it:hover{box-shadow:var(--btn-hover-lift);transform:translateY(-1px)}.verb-intro-add-dict{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;border-radius:10px;flex:1;padding:12px 0;font-size:15px;font-weight:500;transition:all .2s}.verb-intro-add-dict:hover{color:var(--text-primary);border-color:var(--border-active)}.progress-dashboard{max-width:640px;margin:0 auto;padding:2rem 1rem}.progress-dashboard h2{text-align:center;color:var(--text-title-on-dark,#ede8dc);margin-bottom:.25rem;font-size:1.5rem}.progress-head{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;display:flex}.progress-reset-btn{color:#fecaca;letter-spacing:.03em;background:#ef44441f;border:1px solid #ef444473;border-radius:999px;padding:.35rem .75rem;font-size:.78rem;font-weight:700;transition:all .2s}.progress-reset-btn:hover:not(:disabled){background:#ef444433;border-color:#ef4444a6}.progress-reset-btn:disabled{opacity:.7;cursor:default}.progress-reset-message{text-align:center;color:var(--text-secondary,#888);margin:-1.2rem 0 1.2rem;font-size:.82rem}.progress-subtitle{text-align:center;color:var(--text-subtitle-on-dark,#cfc6b2);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-title-on-dark,#ede8dc);margin:0 0 .25rem;font-size:2.5rem;font-weight:700}.landing-title-kr{opacity:.7;font-weight:400}.landing-tagline{color:var(--text-subtitle-on-dark,#cfc6b2);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-title-on-dark,#ede8dc);margin:0 0 .2rem;font-size:.95rem;font-weight:600}.landing-feature p{color:var(--text-subtitle-on-dark,#cfc6b2);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-title-on-dark,#ede8dc);background:0 0;border:1px solid #ede8dc3d}.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-success{color:#22c55e;background:#22c55e1a;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);height:56px;box-shadow:var(--shadow-header);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #ede8dc29;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}.app-title{color:var(--text-title-on-dark);letter-spacing:-.02em;align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.app-title-kr{color:var(--text-subtitle-on-dark);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(--meta-pill-text);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(--meta-pill-text);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-primary)}.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(--meta-pill-text);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}.section-surface--dictionary,.section-surface--import,.section-surface--lessons,.section-surface--progress,.section-surface--learn{background:var(--bg-primary)}.sidebar{background:var(--bg-secondary);border-left:1px solid #ede8dc1f;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-shell{background:#f5edd8;border-radius:20px;margin-bottom:20px;overflow:hidden;box-shadow:0 8px 32px #00000052}.card-header{background:#2d1f0e;border-bottom:2px solid #e8863a;justify-content:space-between;align-items:center;padding:14px 20px 12px;display:flex}.card-header.verb{background:#0e1f13;border-bottom-color:#4db87a}.card-header.adjective{background:#160e2d;border-bottom-color:#9b7ae8}.pattern-badge{text-transform:uppercase;letter-spacing:.1em;color:#e8863a;align-items:center;gap:6px;font-size:11px;font-weight:700;display:flex}.pattern-badge.verb{color:#4db87a}.pattern-badge.adjective{color:#9b7ae8}.badge-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:7px;height:7px}.card-counter{color:#f5edd866;font-size:12px}.card-body{background:#f5edd8;padding:24px 20px 20px}.pattern-label{text-align:center;color:#7a6845;margin-bottom:18px;font-family:Playfair Display,serif;font-size:15px;font-style:italic}.sentence-area{text-align:center;cursor:pointer;background:#fff;border:1.5px solid #e8dcc4;border-radius:14px;margin-bottom:16px;padding:20px 20px 18px;transition:border-color .2s;position:relative}.sentence-area:hover{border-color:#e8863a}.sentence-area.drag-over{background:#fffaf5;border-style:dashed;border-color:#e8863a;transform:scale(1.01)}.tap-hint{letter-spacing:.12em;color:#e8863a;opacity:.7;justify-content:center;align-items:center;gap:6px;margin-bottom:12px;font-family:Noto Sans KR,sans-serif;font-size:10px;font-weight:700;display:flex}.sentence-display{color:#1a1208;letter-spacing:.04em;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;min-height:50px;font-family:Noto Serif KR,serif;font-size:34px;display:flex}.sentence-translations{margin-top:10px}.sentence-rom{color:#a89060;letter-spacing:.06em;margin-top:4px;font-size:12px}.sentence-literal{color:#7a684599;margin-top:4px;font-size:11px;font-style:italic}.sentence-english{color:#7a6845;margin-top:4px;font-family:Playfair Display,serif;font-size:13px;font-style:italic}.lantern-row{justify-content:center;align-items:center;gap:16px;margin-bottom:16px;display:flex}.hint-btn,.replay-btn{color:#7a6845;cursor:pointer;background:0 0;border:1.5px solid #e8dcc4;border-radius:20px;padding:7px 18px;font-family:Noto Sans KR,sans-serif;font-size:12px;transition:all .2s}.hint-btn:hover,.replay-btn:hover{color:#e8863a;border-color:#e8863a}.replay-btn{opacity:.35;pointer-events:none}.replay-btn.active{opacity:1;pointer-events:auto}.card-meta-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.pattern-en{color:var(--text-primary);letter-spacing:-.02em;margin-top:10px;font-size:20px;font-weight:600;display:block}.pattern-usage-note{color:var(--text-muted);margin-top:8px;font-size:12px;font-style:italic}.card-source-label{color:#7a68458c;text-align:center;margin-top:-10px;margin-bottom:14px;font-size:11px}.card-progress{color:var(--text-muted);align-items:center;gap:8px;font-size:12px;font-weight:500;display:flex}.card-progress-label{color:#f5edd866;white-space:nowrap;font-size:11px}.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{text-align:center;background:#fffdfa;border:3px solid #f3a15f;border-radius:20px;margin-bottom:28px;padding:28px 34px 34px;position:relative;overflow:hidden;box-shadow:0 12px 28px #00000047}.drill-display:before{content:"";pointer-events:none;background:0 0;border:1px dashed #f3a15fa6;border-radius:14px;position:absolute;inset:8px}.card-stage .drill-display.noun-card:before,.card-stage .drill-display.verb-card:before,.card-stage .drill-display.adjective-card:before{background:0 0}.filled-slot.adjective{color:var(--accent-adjective);background:var(--accent-adjective-glow)}.drill-sentence{letter-spacing:-.01em;z-index:1;color:#111827;font-family:Noto Sans KR,sans-serif;font-size:36px;font-weight:700;line-height:1.45;position:relative}.blank-slot{flex-direction:column;align-items:center;gap:4px;min-width:110px;transition:all .2s;display:inline-flex}.blank-slot.drag-over{transform:scale(1.05)}.blank-line{background:repeating-linear-gradient(90deg,#e8863a 0 6px,#0000 6px 10px);border-radius:2px;width:110px;height:3px;transition:all .2s}.blank-slot.drag-over .blank-line{background:#e8863a;height:4px}.blank-label{letter-spacing:.12em;color:#e8863a;font-family:Noto Sans KR,sans-serif;font-size:9px;font-weight:700}@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,.filled-slot.verb{color:#ea7f2d;text-shadow:none;border-color:#ea7f2d}.token{color:#111827}.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}.drill-translations{z-index:1;flex-direction:column;gap:4px;margin-top:12px;display:flex;position:relative}.drill-rom{color:#4b5563;opacity:1;font-size:16px;font-style:normal;font-weight:500}.drill-literal{color:#6b7280;opacity:1;font-size:14px;line-height:1.4}.drill-english{color:#111827;font-size:16px;font-weight:600;line-height:1.5}.drill-pattern-chip{color:#171717;z-index:1;background:#f4ce45;border-radius:10px;max-width:92%;margin:0 auto 12px;padding:4px 12px;font-size:14px;font-weight:700;line-height:1.2;display:inline-block;position:relative}.tap-pattern-hint{letter-spacing:.12em;color:#e27f31;align-items:center;gap:7px;margin-bottom:10px;font-size:10px;font-weight:700;display:inline-flex}.pulse-dot{background:#e27f31;border-radius:999px;width:7px;height:7px;animation:1.6s ease-in-out infinite pulseDot}@keyframes pulseDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.75)}}.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{color:#7a6845;text-align:left;background:#ffffff8c;border:1px solid #e8dcc4;border-radius:14px;width:100%;margin-bottom:14px;padding:16px 20px;font-size:13px;line-height:1.6}.card-note strong{color:#1a1208;font-weight:600}.examples{text-align:left;width:100%;margin:8px 0 20px}.examples-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.examples h4{text-transform:uppercase;color:#7a68458c;letter-spacing:.1em;margin:0;font-size:11px;font-weight:700}.translation-toggles{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.translation-toggle{color:#7a6845a6;background:#ffffff73;border:1px solid #e8dcc4;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .2s}.translation-toggle:hover{color:#7a6845;border-color:#e8863a}.translation-toggle.active{color:#1a1208;background:#ffffffbf;border-color:#e8863a}.example{background:#ffffff8c;border:1px solid #e8dcc4;border-radius:12px;flex-direction:column;gap:3px;margin-bottom:6px;padding:12px 16px;transition:background .2s;display:flex}.example:hover{background:#fffc}.example-kr{color:#1a1208;font-family:Noto Serif KR,serif;font-size:17px;font-weight:400}.example-en{color:#7a6845;font-family:Playfair Display,serif;font-size:13px;font-style:italic;line-height:1.45}.example-rom{color:#a89060;letter-spacing:.05em;font-size:12px;line-height:1.1}.example-literal{color:#7a684599;font-size:11px;line-height:1.45}.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:#7a6845a6;margin-bottom:10px;font-size:13px;font-weight:500}.rating-buttons{justify-content:center;gap:6px;display:flex}.rating-btn{color:#7a6845;background:#ffffff8c;border:1.5px solid #e8dcc4;border-radius:10px;flex:1;max-width:90px;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}.mode-hint{text-align:center;color:#7a6845a6;letter-spacing:.04em;margin:0 0 8px;font-size:11px;font-style:italic}.tiles-label{text-align:center;letter-spacing:.14em;color:#7a684580;margin:0 0 10px;font-size:10px;font-weight:700}.drag-hint{text-align:center;color:#7a684573;letter-spacing:.04em;margin:8px 0 0;font-size:10px;font-style:italic}.dancheong-bar{opacity:.5;background:linear-gradient(90deg,#c8403a,#c8973a,#3ac8a8,#3a7ac8,#9b7ae8,#4db87a);border-radius:2px;height:4px;margin:18px 0 0}.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}.pronunciation-feedback{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;align-items:center;gap:4px;width:min(460px,100%);padding:8px 12px;display:flex}.pronunciation-score{color:#1a1208;font-size:13px;font-weight:700}.pronunciation-message{color:#7a6845;text-align:center;font-size:12px;line-height:1.4}.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-row{align-items:center;gap:4px;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 8px;font-size:11px;font-weight:700;transition:all .2s}.speed-btn:hover{color:var(--text-secondary);border-color:var(--border-active)}.speed-btn.active{color:var(--text-primary);border-color:var(--accent-noun);background:color-mix(in srgb, var(--accent-noun) 20%, var(--btn-secondary-bg))}.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.active.adjective{color:#9b7ae8;background:#9b7ae82e}.filter-btn.active.adverb{color:#2aa7a1;background:#2aa7a133}.filter-btn.active.interjection{color:#fbbf24;background:#fbbf2426}.filter-btn.active.particle{color:#6b7280;background:#6b72802e}.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-type.adjective{color:#9b7ae8;background:#9b7ae82e}.dict-type.adverb{color:#2aa7a1;background:#2aa7a133}.dict-type.interjection{color:#fbbf24;background:#fbbf2426}.dict-type.particle{color:#6b7280;background:#6b72802e}.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);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid #ede8dc29;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-subtitle-on-dark);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-title-on-dark)}.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-title-on-dark);margin:0 0 8px;font-size:22px;font-weight:700}.import-subtitle{color:var(--text-subtitle-on-dark);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-review-queue{color:#f8d487;background:#fbbf241f;border:1px solid #fbbf2447;border-radius:10px;padding:12px 16px;font-size:13px}.import-review-queue p{color:#edd8a3;margin:6px 0 10px}.import-review-chips{flex-wrap:wrap;gap:6px;display:flex}.import-review-chip{background:#1a100559;border:1px solid #fbbf2459;border-radius:999px;padding:3px 8px;font-size:12px}.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{background:#f8f3e8;border:1px solid #e6dcc7;border-radius:22px;width:100%;max-width:1000px;margin:0 auto;padding:32px 24px;box-shadow:0 10px 30px #1c160c1f}.dictionary-full .dictionary-page{width:100%}.dict-page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dict-page-actions{align-items:center;gap:8px;display:flex}.dict-lore-form{grid-template-columns:1.1fr 1.2fr 1.2fr .8fr auto;gap:8px;margin-bottom:12px;display:grid}.dict-page-title{color:var(--text-title-on-dark);letter-spacing:-.02em;font-size:22px;font-weight:700}.dict-unlocked-counter{color:#5f4f37;white-space:nowrap;background:#fff8ea;border:1px solid #d8c9af;border-radius:999px;margin-left:auto;margin-right:10px;padding:6px 10px;font-size:12px;font-weight:700}.dict-export-btn{color:#5a4a32;background:#fffaf0;border:1px solid #d4c6ab;border-radius:8px;padding:7px 14px;font-size:12px;font-weight:600;transition:all .2s}.dict-export-btn:hover:not(:disabled){color:#2d2618;border-color:#bc9a6d}.dict-export-btn:disabled{opacity:.55;cursor:not-allowed}.dict-quiz-btn{color:#281b0c;background:#ea8a3d;border-radius:100px;padding:8px 20px;font-size:13px;font-weight:600;transition:all .2s;box-shadow:0 5px 18px #ba753459}.dict-quiz-btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px #ba753473}.dict-poster-section{background:#efd0a6;border:2px solid #28201899;border-radius:22px;margin-bottom:18px;padding:18px 16px 14px;box-shadow:0 8px 30px #0000002e}.dict-poster-board{grid-template-columns:minmax(180px,1fr) minmax(260px,360px) minmax(180px,1fr);align-items:stretch;gap:10px;display:grid}.dict-mini-column{grid-template-rows:repeat(5,minmax(72px,1fr));gap:8px;display:grid}.dict-mini-card{text-align:left;cursor:pointer;background:#fffdf8;border:2px solid #24201b;border-radius:8px;width:100%;padding:6px 7px;transition:transform .15s,box-shadow .15s;box-shadow:0 2px #0000002e}.dict-mini-card:hover{transform:translateY(-1px);box-shadow:0 5px #0003}.dict-mini-head{align-items:center;gap:5px;margin-bottom:5px;display:flex}.dict-mini-emoji{font-size:12px;line-height:1}.dict-mini-title{color:#1e1a15;letter-spacing:.01em;font-size:10px;font-weight:700}.dict-mini-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;display:grid}.dict-mini-chip{color:#3b342c;white-space:nowrap;text-overflow:ellipsis;background:#f4eee2;border-radius:4px;align-items:center;gap:3px;padding:2px 4px;font-size:9px;line-height:1.1;display:flex;overflow:hidden}.dict-cover-card{background:#f4eee3;border:8px solid #1f1d1a;border-radius:24px;flex-direction:column;justify-content:space-between;min-height:430px;padding:26px 18px 20px;display:flex;position:relative;overflow:hidden}.dict-cover-card:before{content:"";z-index:0;background-image:linear-gradient(#e0a85b80 2px,#0000 2px),linear-gradient(90deg,#e0a85b80 2px,#0000 2px);background-size:64px 64px;position:absolute;inset:0}.dict-cover-kicker,.dict-cover-title-wrap,.dict-cover-footer{z-index:1;position:relative}.dict-cover-kicker{text-transform:uppercase;letter-spacing:.09em;color:#4a4134;text-align:center;margin-bottom:18px;font-size:10px;font-weight:700}.dict-cover-title-wrap{text-align:center;background:#f2bf74;border:2px dashed #e39a3a;border-radius:34px;align-self:center;max-width:240px;padding:24px 18px 18px}.dict-cover-title{text-transform:uppercase;letter-spacing:.01em;color:#3f3a32;margin:0;font-size:34px;line-height:.98}.dict-cover-sub{color:#4a4339;letter-spacing:.03em;margin:10px 0 0;font-size:13px;font-weight:600}.dict-cover-footer{text-transform:uppercase;letter-spacing:.03em;color:#5a4f40;background:#f2bf74cc;border-radius:14px;align-self:flex-start;padding:7px 10px;font-size:12px;font-weight:700}.dict-poster-caption{text-align:center;color:#1f1a14;background:#fcf8f0;border-radius:18px;max-width:720px;margin:12px auto 0;padding:12px 20px 10px;font-size:38px;font-weight:800;line-height:1.04;box-shadow:0 2px #1e160a24}.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}@media (width<=980px){.dict-poster-board{grid-template-columns:1fr}.dict-cover-card{order:-1;min-height:360px}.dict-mini-column{grid-template-rows:none;grid-template-columns:repeat(2,minmax(0,1fr))}.dict-poster-caption{font-size:28px}}@media (width<=620px){.dict-poster-section{border-radius:16px;padding:12px 10px 10px}.dict-mini-column{grid-template-columns:1fr}.dict-cover-card{border-width:6px;border-radius:16px;min-height:320px;padding:18px 12px 14px}.dict-cover-card:before{background-size:48px 48px}.dict-cover-title{font-size:28px}.dict-cover-sub{font-size:11px}.dict-cover-footer{font-size:10px}.dict-poster-caption{border-radius:12px;padding:9px 10px 8px;font-size:21px}}.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-pill.lore-pill{color:#8f651f;background:#fff6df;border-color:#d5a84d}.category-pill.lore-pill.active{color:#2c1d03;background:#e8b455;border-color:#e8b455}.category-emoji{font-size:14px;line-height:1}.category-label{line-height:1}.dict-count-label{color:#6d5a3e;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{cursor:pointer;text-align:center;background:#fff9ec;border:1px solid #dcc8a8;border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:16px 10px 12px;transition:all .2s;display:flex;position:relative;box-shadow:0 6px 16px #2c1e0a1f}.dict-hidden-file-input{display:none}.dict-tile.unlocked{border-width:1.5px}.dict-tile:hover{background:#fffef8;border-color:#caa06a;transform:translateY(-2px);box-shadow:0 10px 20px #2c1e0a29}.dict-tile.personal{border-style:dashed;border-color:#e8863a}.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:36px}.dict-mastered-badge{color:#f9d65c;text-shadow:0 0 8px #f9d65c8c;font-size:14px;position:absolute;top:6px;left:8px}.dict-tile.mastery-burst-once .dict-mastered-badge{animation:1.2s ease-out masteredPulse}@keyframes masteredPulse{0%{text-shadow:0 0 #f9d65c33;transform:scale(.9)}35%{text-shadow:0 0 18px #f9d65cf2;transform:scale(1.24)}to{text-shadow:0 0 8px #f9d65c8c;transform:scale(1)}}.dict-proficiency-pill{text-transform:uppercase;letter-spacing:.08em;border:1px solid #0000;border-radius:999px;margin-top:2px;padding:2px 7px;font-size:9px;font-weight:700}.dict-proficiency-pill.seen{color:#cbd5e1;background:#94a3b82e;border-color:#94a3b859}.dict-proficiency-pill.learning{color:#9df3bc;background:#4ade802e;border-color:#4ade8059}.dict-proficiency-pill.familiar{color:#b9d8ff;background:#60a5fa2e;border-color:#60a5fa59}.dict-tile-image-btn,.dict-tile-image-remove{color:#6b5538;cursor:pointer;z-index:2;background:#fffaf0f2;border:1px solid #d5c3a3;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;line-height:1;display:inline-flex;position:absolute;top:6px}.dict-tile-image-btn{right:8px}.dict-tile-image-remove{color:#fca5a5;right:34px}.dict-tile-image-btn:hover:not(:disabled),.dict-tile-image-remove:hover:not(:disabled){color:#3a2b19;border-color:#caa06a}.dict-tile-image-btn:disabled,.dict-tile-image-remove:disabled{opacity:.6;cursor:default}.dict-tile-emoji{margin-bottom:2px;font-size:28px;line-height:1}.dict-tile-thumb{object-fit:cover;border:1px solid #dcc8a8;border-radius:10px;width:46px;height:46px;margin-bottom:2px}.dict-tile-thumb-sm{object-fit:cover;border:1px solid #dcc8a8;border-radius:4px;width:18px;height:18px}.dict-tile-emoji-sm{font-size:16px;line-height:1}.dict-tile-kr{color:#21180e;letter-spacing:-.01em;font-family:Noto Sans KR,sans-serif;font-size:16px;font-weight:600}.dict-tile-en{color:#4e3b24;letter-spacing:0;text-transform:none;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;font-family:Inter,Noto Sans KR,sans-serif;font-size:13px;font-weight:500;line-height:1.25;display:-webkit-box;overflow:hidden}.dict-tile-roman{color:#8b7652;opacity:.9;letter-spacing:.01em;font-family:Inter,Noto Sans KR,sans-serif;font-size:10px;font-style:italic;font-weight:500}.dict-tile-type{text-transform:uppercase;letter-spacing:.08em;border:1px solid #0000;border-radius:100px;padding:2px 7px;font-family:Inter,Noto Sans KR,sans-serif;font-size:8px;font-weight:700}.dict-tile-type.noun{color:#2a1a00;background:#ff9a45;border-color:#ffba87}.dict-tile-type.verb{color:#082911;background:#4ade80;border-color:#8cf4ad}.dict-tile-type.adjective{color:#4e2f91;background:#9b7ae83d;border-color:#9b7ae880}.dict-tile-type.adverb{color:#0f5b59;background:#2aa7a13d;border-color:#2aa7a17a}.dict-tile-type.interjection{color:#fbbf24;background:#fbbf2426}.dict-tile-type.particle{color:#4b5563;background:#6b728033;border-color:#6b728066}.dict-pos-filter{flex-wrap:wrap;gap:6px;margin:14px 0 10px;display:flex}.pos-pill{color:#7b6647;background:#fffaf0;border:1px solid #d8c8ae;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:600;transition:all .2s}.pos-pill:hover{color:#4f3f2a;border-color:#c9a97c}.pos-pill.active{color:#2d2618;background:#fff}.pos-pill.active.noun{background:var(--accent-noun-glow);color:var(--accent-noun)}.pos-pill.active.verb{background:var(--accent-verb-glow);color:var(--accent-verb)}.pos-pill.active.adjective{color:#7448cf;background:#9b7ae833}.pos-pill.active.adverb{color:#0f7c78;background:#2aa7a133}.pos-pill.active.interjection{color:#fbbf24;background:#fbbf2426}.pos-pill.active.particle{color:#4b5563;background:#6b72802e}.dict-tile-level{letter-spacing:.06em;border:1px solid #0000;border-radius:100px;padding:2px 6px;font-family:Inter,Noto Sans KR,sans-serif;font-size:9px;font-weight:700}.dict-tile-level.level-1{color:#04220d;background:#78f5a1;border-color:#a6f8bf}.dict-tile-level.level-2{color:#291500;background:#ffb06d;border-color:#ffd1a8}.dict-tile-level.level-3{color:#e8ecff;background:#334266;border-color:#4f6292}.dict-tile-source{color:#8a775a;opacity:.8;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-top:3px;font-size:10px;overflow:hidden}.dict-lore-badge{filter:drop-shadow(0 1px 2px #00000059);font-size:12px;position:absolute;top:8px;right:28px}.dict-tile.locked{opacity:.92;filter:grayscale(.2);cursor:default;background:linear-gradient(#f8717114,#0000 55%),#f9f1df;border-color:#b657576b;position:relative}.dict-tile.locked:hover{background:linear-gradient(#f8717114,#0000 55%),#f9f1df;border-color:#b657576b;transform:none;box-shadow:0 6px 16px #2c1e0a1f}.dict-tile-lock{opacity:1;filter:drop-shadow(0 0 4px #f8717180);font-size:14px;position:absolute;top:6px;right:6px}.dict-tile-locked-badge{letter-spacing:.08em;color:#fecaca;background:#f8717147;border:1px solid #f8717173;border-radius:999px;padding:1px 6px;font-size:9px;font-weight:800;position:absolute;top:6px;left:8px}.dict-tile-emoji.dimmed{filter:grayscale(.65);opacity:.78}.dict-tile-thumb.dimmed{filter:grayscale(.7);opacity:.74}.locked-text{opacity:1;font-weight:700;color:#6c665b!important}.dict-tile-tooltip{color:#ffd7b6;white-space:nowrap;z-index:10;pointer-events:none;background:#241a0df2;border:1px solid #e8863a73;border-radius:6px;padding:4px 10px;font-size:11px;animation:.15s fadeIn;position:absolute;bottom:-32px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000004d}.dict-reset-modal-overlay{z-index:200;background:#1a1a2eb8;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dict-reset-modal{background:var(--bg-card);border:1px solid #d6b789;border-radius:16px;width:min(460px,100%);padding:20px;box-shadow:0 20px 50px #0c0c1859}.dict-reset-modal h3{color:var(--text-primary);margin:0 0 8px;font-size:20px}.dict-reset-modal p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.dict-reset-error{font-weight:600;color:#b63838!important;margin-top:10px!important}.dict-reset-actions{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.dict-reset-confirm,.dict-reset-cancel{border:1px solid #0000;border-radius:10px;padding:9px 14px;font-size:13px;font-weight:700;transition:all .2s}.dict-reset-confirm{color:#fff;background:#c73535;border-color:#a62828}.dict-reset-confirm:hover:not(:disabled){background:#aa2525}.dict-reset-cancel{color:#4f3d26;background:#fff;border-color:#d4c3a8}.dict-reset-cancel:hover:not(:disabled){color:#2f2416;border-color:#c4a578}.dict-reset-confirm:disabled,.dict-reset-cancel:disabled{opacity:.6;cursor:not-allowed}.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-title-on-dark);flex:1;font-size:20px;font-weight:700}.quiz-subtitle{color:var(--text-subtitle-on-dark);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)}.quiz-round-counter{color:var(--text-muted);margin-left:auto;font-size:13px;font-weight:600}.game-mode-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.game-mode-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;box-shadow:var(--shadow-card);text-align:center;border-radius:18px;flex-direction:column;align-items:center;gap:10px;padding:28px 20px;transition:all .25s;display:flex}.game-mode-card:hover{background:var(--bg-card-hover);border-color:var(--border-active);transform:translateY(-3px);box-shadow:0 6px 24px #0000004d}.game-mode-icon{font-size:40px;line-height:1}.game-mode-name{color:var(--text-primary);font-size:16px;font-weight:700}.game-mode-desc{color:var(--text-muted);font-size:12px;line-height:1.5}.listening-timer-bar{background:var(--btn-secondary-bg);border-radius:3px;width:100%;height:6px;margin-bottom:24px;overflow:hidden}.listening-timer-fill{background:var(--accent-verb);border-radius:3px;height:100%;transition:width .1s linear}.listening-timer-bar.warning .listening-timer-fill{background:var(--accent-noun)}.listening-timer-bar.urgent .listening-timer-fill{background:var(--accent-blank);animation:.5s infinite timer-pulse}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.6}}.listening-lantern-wrap{justify-content:center;margin-bottom:32px;display:flex}.listening-options{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.listening-tile{background:var(--bg-card);border:2px solid var(--border-color);cursor:pointer;border-radius:16px;flex-direction:column;align-items:center;gap:8px;min-height:100px;padding:24px 16px;transition:all .2s;display:flex}.listening-tile:hover:not(:disabled){border-color:var(--border-active);background:var(--bg-card-hover);transform:translateY(-2px)}.listening-tile.correct{border-color:var(--accent-verb);background:var(--accent-verb-glow);animation:.4s ease-out tile-flash}.listening-tile.wrong{border-color:var(--accent-blank);background:#f8717114;animation:.4s ease-out tile-shake}@keyframes tile-flash{0%{box-shadow:0 0 0 0 var(--accent-verb)}50%{box-shadow:0 0 20px #4ade8066}to{box-shadow:none}}@keyframes tile-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.listening-tile-emoji{font-size:32px;line-height:1}.listening-tile-en{color:var(--text-secondary);font-size:14px;font-weight:500}.listening-tile-reveal{flex-direction:column;align-items:center;gap:2px;margin-top:4px;animation:.3s ease-out fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.listening-tile-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:16px;font-weight:600}.listening-tile-rom{color:var(--text-muted);font-size:11px}.memory-grid{perspective:800px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;display:grid}.memory-card{aspect-ratio:3/4;cursor:pointer;background:0 0;border:none;padding:0}.memory-card-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .4s;position:relative}.memory-card.flipped .memory-card-inner,.memory-card.matched .memory-card-inner{transform:rotateY(180deg)}.memory-card-front,.memory-card-back{backface-visibility:hidden;border:2px solid var(--border-color);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.memory-card-front{background:var(--bg-card);color:var(--text-muted);font-size:24px}.memory-card-back{background:var(--bg-card-hover);gap:6px;padding:8px;transform:rotateY(180deg)}.memory-card.matched .memory-card-front,.memory-card.matched .memory-card-back{border-color:var(--accent-verb)}.memory-card.matched .memory-card-back{background:var(--accent-verb-glow)}.memory-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:18px;font-weight:600}.memory-emoji{font-size:24px}.memory-en{color:var(--text-secondary);text-align:center;word-break:break-word;font-size:12px}.timed-stats{align-items:center;gap:12px;margin-left:auto;display:flex}.timed-score{color:var(--accent-verb);font-size:14px;font-weight:700}.timed-clock{color:var(--text-primary);text-align:center;min-width:40px;font-size:16px;font-weight:700}.timed-clock.urgent{color:var(--accent-blank);animation:.5s infinite timer-pulse}.timed-prompt{flex-direction:column;align-items:center;gap:12px;margin-bottom:24px;padding:32px;display:flex}.timed-prompt-emoji{font-size:56px;line-height:1}.timed-prompt-en{color:var(--text-secondary);font-size:18px;font-weight:600}.timed-options{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.timed-option{background:var(--bg-card);border:2px solid var(--border-color);color:var(--text-primary);cursor:pointer;text-align:center;border-radius:14px;padding:16px;font-family:Noto Sans KR,sans-serif;font-size:20px;font-weight:600;transition:all .15s}.timed-option:hover:not(:disabled){border-color:var(--border-active);background:var(--bg-card-hover)}.timed-option.correct{border-color:var(--accent-verb);background:var(--accent-verb-glow);animation:.3s ease-out tile-flash}.timed-option.dimmed{opacity:.4}.spelling-prompt{flex-direction:column;align-items:center;gap:10px;margin-bottom:16px;padding:24px;display:flex}.spelling-emoji{font-size:56px;line-height:1}.spelling-en{color:var(--text-secondary);font-size:18px;font-weight:600}.spelling-hint-da{color:var(--text-muted);font-size:12px;font-style:italic}.spelling-display{background:var(--bg-card);border:2px solid var(--border-color);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:80px;margin-bottom:16px;padding:20px;transition:all .3s;display:flex}.spelling-display.correct{border-color:var(--accent-verb);background:var(--accent-verb-glow)}.spelling-display.wrong{border-color:var(--accent-blank);background:#f8717114;animation:.4s ease-out tile-shake}.spelling-assembled{color:var(--text-primary);letter-spacing:2px;min-height:40px;font-family:Noto Sans KR,sans-serif;font-size:32px;font-weight:700}.spelling-correct-answer{color:var(--accent-verb);font-family:Noto Sans KR,sans-serif;font-size:16px;font-weight:500}.content-view{flex-direction:column;gap:16px;display:flex}.content-view-header{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.content-view-title{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.content-view-source{color:var(--text-muted);background:var(--btn-secondary-bg);border-radius:100px;padding:3px 10px;font-size:12px}.content-view-toggle{color:var(--text-muted);cursor:pointer;align-items:center;gap:6px;margin-left:auto;font-size:12px;display:flex}.content-view-toggle input{accent-color:var(--accent-verb)}.content-view-quiz-toggle{border:1px solid var(--border-color);background:var(--btn-secondary-bg);color:var(--text-muted);border-radius:8px;padding:5px 10px;font-size:12px;font-weight:600;transition:all .2s}.content-view-quiz-toggle.active{color:var(--text-primary);border-color:var(--accent-verb)}.content-quiz-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;gap:8px;padding:10px 12px;display:flex}.content-quiz-bank{flex-wrap:wrap;gap:6px;display:flex}.content-quiz-chip{border:1px solid var(--border-color);background:var(--btn-secondary-bg);color:var(--text-secondary);border-radius:999px;padding:6px 10px;font-family:Noto Sans KR,sans-serif;font-size:13px}.content-quiz-status{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:12px;display:flex}.content-quiz-reset{border:1px solid var(--border-color);color:var(--text-muted);background:0 0;border-radius:8px;padding:4px 8px;font-size:11px}.content-view-body{flex-direction:column;gap:4px;display:flex}.content-line{border-radius:8px;align-items:flex-start;gap:8px;padding:6px 12px;transition:background .15s;display:flex}.content-line:hover{background:var(--btn-secondary-bg)}.content-line-text{color:var(--text-primary);flex-wrap:wrap;flex:1;align-items:baseline;gap:2px;font-family:Noto Sans KR,sans-serif;font-size:16px;line-height:2;display:flex}.content-line-audio{transform-origin:100% 0;flex-shrink:0;transform:scale(.5)}.content-token-plain{color:var(--text-muted)}.content-word{cursor:pointer;border-radius:3px;flex-direction:column;align-items:center;padding:0 2px;transition:all .15s;display:inline-flex;position:relative}.content-word:hover{background:#ffffff0f}.content-word-noun{color:var(--accent-noun)}.content-word-verb{color:var(--accent-verb)}.content-word-adjective{color:var(--accent-adjective)}.content-word-adverb{color:#2aa7a1}.content-word-default{color:var(--text-primary)}.content-quiz-blank{border:1px dashed var(--border-color);color:var(--text-primary);background:0 0;border-radius:6px;padding:0 6px;font-family:Noto Sans KR,sans-serif;font-size:15px}.content-quiz-blank.active{border-color:var(--accent-verb);background:var(--accent-verb-glow)}.content-quiz-blank.correct{border-color:var(--accent-verb)}.content-quiz-blank.wrong{border-color:var(--accent-blank);color:var(--accent-blank)}.content-word-rom{color:var(--text-muted);margin-top:-4px;font-family:sans-serif;font-size:9px;line-height:1;display:block}.content-line-rom{color:var(--text-muted);margin-left:2px;font-size:11px;font-style:italic}.content-line-carry{color:var(--accent-noun);margin-left:2px;font-size:11px}.content-word-popup{z-index:100;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.content-word-popup-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;flex-direction:column;align-items:center;gap:12px;min-width:260px;max-width:360px;padding:28px;display:flex;position:relative;box-shadow:0 8px 32px #00000080}.content-word-popup-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:18px;position:absolute;top:12px;right:16px}.content-word-popup-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:28px;font-weight:700}.content-word-popup-base{color:var(--accent-verb);font-size:13px;font-weight:500}.content-word-popup-type{text-transform:uppercase;letter-spacing:.08em;background:var(--btn-secondary-bg);color:var(--text-muted);border-radius:100px;padding:3px 12px;font-size:11px;font-weight:700}.content-word-popup-type.noun{color:var(--accent-noun);background:var(--accent-noun-glow)}.content-word-popup-type.verb{color:var(--accent-verb);background:var(--accent-verb-glow)}.content-word-popup-type.adjective{color:var(--accent-adjective);background:var(--accent-adjective-glow)}.content-word-popup-type.adverb{color:#2aa7a1;background:#2aa7a12e}.content-word-popup-type.particle{color:#6b7280;background:#6b72802e}.content-word-popup-rom{color:var(--text-muted);font-size:13px}.content-word-popup-actions{align-items:center;gap:16px;margin-top:8px;display:flex}.content-word-add-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:8px 20px;font-size:13px;font-weight:600;transition:all .2s}.content-word-add-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.import-tabs{background:var(--btn-secondary-bg);border:1px solid var(--border-color);border-radius:10px;gap:2px;padding:3px;display:flex}.import-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.import-tab:hover{color:var(--text-secondary)}.import-tab.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);font-weight:600;box-shadow:0 1px 4px #0000004d}.import-tab-count{background:#ffffff26;border-radius:100px;padding:1px 6px;font-size:11px;font-weight:700}.card-preview-list{flex-direction:column;gap:12px;display:flex}.card-preview-count{color:var(--text-muted);background:var(--btn-secondary-bg);border-radius:100px;padding:2px 8px;font-size:11px}.card-preview-examples{flex-direction:column;gap:4px;margin-bottom:8px;display:flex}.card-preview-source{color:var(--text-muted);margin-top:4px;font-size:11px;font-style:italic}.card-preview-actions{border-top:1px solid var(--border-color);gap:8px;margin-top:10px;padding-top:10px;display:flex}.card-preview-confirm{background:var(--accent-verb-glow);color:var(--accent-verb);border:1px solid var(--accent-verb-dim);cursor:pointer;border-radius:8px;flex:1;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s}.card-preview-confirm:hover:not(:disabled){background:#4ade8033}.card-preview-confirm:disabled{opacity:.4;cursor:default}.card-preview-dismiss{color:var(--text-muted);border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s}.card-preview-dismiss:hover{color:var(--accent-blank);border-color:var(--accent-blank)}.learn-section{width:100%;max-width:720px;margin:0 auto;padding:32px 24px 48px}.learn-header{margin-bottom:32px}.learn-title{color:var(--text-title-on-dark);margin-bottom:8px;font-size:24px;font-weight:700}.learn-subtitle{color:var(--text-subtitle-on-dark);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-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:28px}.drill-display{border-radius:16px;padding:24px 24px 28px}.drill-pattern-chip{border-radius:8px;margin-bottom:10px;padding:3px 10px;font-size:12px}.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:24px}.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}.lessons-page{width:100%;max-width:720px;position:relative}.lessons-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.lessons-title{color:var(--text-title-on-dark);font-size:22px;font-weight:700}.lessons-import-btn{background:var(--btn-primary-bg);width:36px;height:36px;color:var(--btn-primary-text);cursor:pointer;box-shadow:var(--btn-primary-shadow);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:22px;font-weight:600;transition:all .2s;display:flex}.lessons-import-btn:hover{box-shadow:var(--btn-hover-lift);transform:translateY(-1px)}.lessons-import-hint{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;margin-bottom:16px;padding:12px 16px;font-size:13px;line-height:1.5}.lessons-loading,.lessons-empty{text-align:center;color:var(--text-muted);padding:48px 0}.lessons-empty-sub{color:var(--text-muted);margin-top:8px;font-size:14px}.lesson-unlock-toast{z-index:20;background:radial-gradient(circle at 92% 20%, #4ade8038, transparent 32%), linear-gradient(180deg, #4ade8024, #4ade800f), var(--bg-card);color:#d7ffe4;border:1px solid #4ade806b;border-radius:12px;margin-bottom:14px;padding:11px 14px;font-size:13px;font-weight:600;animation:.32s lessonUnlockPop;position:sticky;top:8px;box-shadow:0 8px 22px #00000042}.lesson-unlock-title{color:#92f3b2;margin-bottom:4px;display:block}.lesson-unlock-names{color:var(--text-secondary);font-weight:500}@keyframes lessonUnlockPop{0%{opacity:0;transform:translateY(-6px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}.lessons-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.lesson-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;box-shadow:var(--shadow-card);border-radius:14px;align-items:center;gap:16px;padding:20px;transition:all .2s;display:flex;position:relative}.lesson-card:hover{background:var(--bg-card-hover);border-color:var(--border-active);box-shadow:var(--btn-hover-lift);transform:translateY(-2px)}.lesson-card.locked{opacity:.68;filter:grayscale(.35);cursor:default}.lesson-card.locked:hover{background:var(--bg-card);border-color:var(--border-color);box-shadow:var(--shadow-card);transform:none}.lesson-lock-overlay{font-size:14px;position:absolute;top:8px;left:8px}.lesson-delete-btn{border:1px solid var(--border-color);background:var(--bg-secondary);width:22px;height:22px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:14px;line-height:1;display:inline-flex;position:absolute;top:8px;right:8px}.lesson-delete-btn:hover:not(:disabled){border-color:var(--accent-blank);color:var(--accent-blank)}.lesson-progress-ring{flex-shrink:0;width:52px;height:52px;position:relative}.lesson-ring-svg{width:52px;height:52px;transform:rotate(-90deg)}.lesson-ring-bg{fill:none;stroke:var(--border-color);stroke-width:2.5px}.lesson-ring-fill{fill:none;stroke:var(--accent-verb);stroke-width:2.5px;stroke-linecap:round;transition:stroke-dasharray .4s}.lesson-ring-text{color:var(--text-secondary);justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex;position:absolute;inset:0}.lesson-card-info{flex-direction:column;gap:4px;min-width:0;display:flex}.lesson-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.lesson-card-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:4px;align-self:flex-start;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.lesson-card-stats{color:var(--text-muted);gap:12px;font-size:12px;display:flex}.lesson-card-date{color:var(--text-muted);opacity:.7;font-size:11px}.lesson-flow{width:100%;max-width:640px}.lesson-flow-loading{text-align:center;color:var(--text-muted);padding:48px 0}.lesson-flow-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;display:flex}.lesson-back-btn{background:var(--btn-secondary-bg);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;padding:6px 14px;font-size:13px;transition:all .2s}.lesson-back-btn:hover{color:var(--text-primary);border-color:var(--border-active)}.lesson-flow-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:18px;font-weight:600;overflow:hidden}.lesson-flow-title-wrap{flex-direction:column;flex:1;min-width:0;display:flex}.lesson-flow-subtitle{color:var(--text-muted);margin-top:2px;font-size:12px}.lesson-parts-indicator{gap:6px;display:flex}.lesson-source-selector{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.lesson-source-pill{border:1px solid var(--border-color);background:var(--btn-secondary-bg);color:var(--text-secondary);cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:6px 10px;font-size:12px;transition:all .2s;display:inline-flex}.lesson-source-pill:hover:not(:disabled){border-color:var(--border-active);color:var(--text-primary)}.lesson-source-pill.active{color:#f3c090;background:#f3a15f1f;border-color:#f3a15f99}.lesson-source-pill.complete{border-color:#4ade8073}.lesson-source-pill.locked{opacity:.55;cursor:not-allowed}.lesson-source-pill-label{text-overflow:ellipsis;white-space:nowrap;max-width:240px;overflow:hidden}.lesson-source-pill-state{font-weight:700}.lesson-part-dot{background:var(--btn-secondary-bg);color:var(--text-muted);border:1px solid var(--border-color);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .2s}.lesson-part-dot.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:#0000}.lesson-part-dot.done{background:var(--accent-verb-glow);color:var(--accent-verb);border-color:#4ade8033}.lesson-section-title{color:var(--text-primary);margin-bottom:6px;font-size:18px;font-weight:600}.lesson-section-desc{color:var(--text-muted);margin-bottom:20px;font-size:13px}.lesson-empty-msg{text-align:center;color:var(--text-muted);padding:24px 0}.lesson-word-tiles{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px;display:grid}.lesson-word-tile{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;transition:all .2s;display:flex}.lesson-word-tile:hover{background:var(--bg-card-hover);border-color:var(--border-active)}.lesson-word-tile.tapped{border-color:var(--accent-verb);background:var(--accent-verb-glow)}.lesson-word-emoji{font-size:28px}.lesson-word-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:18px;font-weight:600}.lesson-word-en{color:var(--text-secondary);font-size:12px}.lesson-word-tts{margin-top:4px}.lesson-advance-btn{background:var(--btn-primary-bg);color:var(--btn-primary-text);cursor:pointer;box-shadow:var(--btn-primary-shadow);border:none;border-radius:10px;margin:0 auto;padding:12px 32px;font-size:14px;font-weight:600;transition:all .2s;display:block}.lesson-advance-btn:hover:not(:disabled){box-shadow:var(--btn-hover-lift);transform:translateY(-1px)}.lesson-advance-btn:disabled{opacity:.4;cursor:not-allowed}.lesson-recall-question{flex-direction:column;align-items:center;gap:16px;display:flex}.lesson-recall-prompt{color:var(--text-secondary);font-size:15px}.lesson-recall-player{justify-content:center;display:flex}.lesson-recall-options{grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:400px;display:grid}.lesson-recall-opt{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;border-radius:10px;padding:14px;font-size:14px;font-weight:500;transition:all .2s}.lesson-recall-opt:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-active)}.lesson-recall-opt.correct{border-color:var(--accent-verb);background:var(--accent-verb-glow);color:var(--accent-verb)}.lesson-recall-opt.wrong{border-color:var(--accent-blank);background:var(--accent-blank-glow);color:var(--accent-blank)}.lesson-recall-feedback{flex-direction:column;align-items:center;gap:12px;display:flex}.recall-correct{color:var(--accent-verb);font-weight:600}.recall-wrong{color:var(--accent-blank);font-weight:500}.lesson-recall-done{text-align:center;color:var(--text-primary);padding:24px 0}.lesson-skip-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:13px;text-decoration:underline;transition:color .2s}.lesson-skip-btn:hover{color:var(--text-secondary)}.lesson-recall-counter{color:var(--text-muted);font-size:12px}.word-suggestions{scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;-webkit-overflow-scrolling:touch;gap:8px;padding:8px 0;display:flex;overflow-x:auto}.word-suggestion-chip{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;white-space:nowrap;border-radius:20px;flex-shrink:0;padding:6px 14px;font-family:Noto Sans KR,sans-serif;font-size:14px;transition:background .15s,border-color .15s,transform .1s}.word-suggestion-chip:hover{transform:translateY(-1px)}.word-suggestion-chip.noun{border-color:var(--accent-noun);color:var(--accent-noun)}.word-suggestion-chip.noun:hover{background:var(--accent-noun);color:var(--bg-primary)}.word-suggestion-chip.verb{border-color:var(--accent-verb);color:var(--accent-verb)}.word-suggestion-chip.verb:hover{background:var(--accent-verb);color:var(--bg-primary)}.word-bank{grid-template-columns:repeat(2,1fr);gap:10px;padding:8px 0;display:grid}.word-bank-tile{cursor:grab;-webkit-user-select:none;user-select:none;background:#1a2333;border:1.5px solid #ffffff12;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:108px;padding:16px 12px 14px;transition:border-color .15s,transform .15s,opacity .2s,box-shadow .15s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 14px #0000003d}.word-bank-tile:before{content:"";opacity:.8;background:#e27f31;height:3px;position:absolute;top:0;left:0;right:0}.word-bank-tile:hover:not(:disabled){border-color:#e27f31;transform:translateY(-2px);box-shadow:0 12px 22px #e27f3140}.word-bank-tile.noun{border-color:#f3a15f}.word-bank-tile.noun:hover:not(:disabled){border-color:#e27f31;box-shadow:0 12px 22px #00000047}.word-bank-tile.verb{border-color:#f3a15f}.word-bank-tile.verb:hover:not(:disabled){border-color:#e27f31;box-shadow:0 12px 22px #00000047}.word-bank-tile.adjective{border-color:#f3a15f}.word-bank-tile.adjective:hover:not(:disabled){border-color:#e27f31;box-shadow:0 12px 22px #00000047}.word-bank-tile.eliminated{opacity:.25;pointer-events:none;filter:grayscale(.6);transform:scale(.95)}.word-bank-tile.wrong-shake{border-color:var(--accent-blank);animation:.4s wordBankShake}@keyframes wordBankShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.word-bank-tile-emoji{font-size:34px;line-height:1}.word-bank-tile-kr{color:#f5edd8;font-family:Noto Serif KR,serif;font-size:20px;font-weight:700;line-height:1.2}.word-bank-tile-level{letter-spacing:.03em;color:#fff;background:#f5a836eb;border-radius:999px;align-self:flex-start;padding:2px 7px;font-size:10px;font-weight:700}.word-bank-tile-rom{color:#f5edd866;letter-spacing:.06em;font-size:11px;line-height:1.1}.word-bank-tile-en{color:#e8863a;font-size:11px;font-weight:700;line-height:1.1}.word-bank.quiz-mode-bank .word-bank-tile.quiz-only{gap:0;min-height:92px}.word-bank.quiz-mode-bank .word-bank-tile.quiz-only .word-bank-tile-kr{font-size:26px}.word-bank.quiz-mode-bank .word-bank-tile.quiz-only .word-bank-tile-emoji,.word-bank.quiz-mode-bank .word-bank-tile.quiz-only .word-bank-tile-rom,.word-bank.quiz-mode-bank .word-bank-tile.quiz-only .word-bank-tile-en{display:none}.quiz-feedback-message{text-align:center;color:#fca5a5;margin-top:10px;font-size:13px;font-weight:600}.mastery-burst{z-index:60;color:#fbbf24;letter-spacing:.01em;background:#171717eb;border:1px solid #f59e0b73;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:700;animation:.18s ease-out masteryToastIn;display:inline-flex;position:fixed;bottom:94px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #00000059}.mastery-burst-star{font-size:15px}@keyframes masteryToastIn{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.practice-mode-toggle{background:#ffffff0f;border-radius:20px;flex-shrink:0;gap:4px;padding:3px;display:flex}.card-difficulty-toggle{letter-spacing:.08em;color:#f5edd873;cursor:pointer;background:0 0;border:none;border-radius:16px;padding:5px 14px;font-family:Noto Sans KR,sans-serif;font-size:12px;font-weight:700;transition:all .2s}.card-difficulty-toggle:hover{color:#f5edd8bf}.card-difficulty-toggle.advanced,.card-difficulty-toggle.beginner{color:#0d1117;background:#c8973a}@media (width<=480px){.word-bank{gap:8px}.word-bank-tile{border-radius:12px;min-height:98px;padding:10px 8px}.word-bank-tile-kr{font-size:18px}.word-bank-tile-rom,.word-bank-tile-en{font-size:11px}.word-bank-tile-emoji{font-size:28px}}.dict-particles-btn{color:#5a4a32;cursor:pointer;background:#fffaf0;border:1px solid #d4c6ab;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:600;transition:background .2s,color .2s}.dict-particles-btn:hover{color:#2d2618;background:#f5e8d1}.particle-guide{max-width:700px;margin:0 auto;padding:16px}.particle-guide-header{margin-bottom:24px}.particle-back-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-bottom:12px;padding:0;font-size:13px;text-decoration:underline}.particle-back-btn:hover{color:var(--text-secondary)}.particle-guide-title{color:var(--text-primary);margin:0 0 8px;font-size:22px;font-weight:700}.particle-guide-subtitle{color:var(--text-muted);margin:0;font-size:14px;line-height:1.5}.particle-list{flex-direction:column;gap:8px;display:flex}.particle-item{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:10px;transition:border-color .2s;overflow:hidden}.particle-item.expanded{border-color:var(--accent-noun)}.particle-item-header{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:14px 16px;display:flex}.particle-hangul{color:var(--accent-noun);min-width:70px;font-family:Noto Sans KR,sans-serif;font-size:20px;font-weight:700}.particle-meta{flex-direction:column;flex:1;gap:2px;display:flex}.particle-name{color:var(--text-primary);font-size:14px;font-weight:600}.particle-function{color:var(--text-muted);font-size:12px}.particle-chevron{color:var(--text-muted);font-size:12px;transition:transform .2s}.particle-detail{padding:0 16px 16px}.particle-description{color:var(--text-secondary);margin:0 0 14px;font-size:14px;line-height:1.5}.particle-rule{background:var(--bg-primary);color:var(--text-secondary);border-radius:8px;margin-bottom:14px;padding:12px;font-size:13px;line-height:1.5}.particle-rule strong{color:var(--accent-noun)}.particle-rule-examples{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.particle-rule-ex{color:var(--text-muted);background:var(--bg-secondary);border-radius:4px;padding:2px 8px;font-family:Noto Sans KR,sans-serif;font-size:13px}.particle-examples{margin-bottom:14px}.particle-examples h4{color:var(--text-primary);margin:0 0 8px;font-size:13px;font-weight:600}.particle-example{border-bottom:1px solid var(--border-color);flex-direction:column;gap:2px;padding:8px 0;display:flex}.particle-example:last-child{border-bottom:none}.particle-ex-kr{color:var(--text-primary);font-family:Noto Sans KR,sans-serif;font-size:15px;font-weight:500}.particle-ex-en{color:var(--text-secondary);font-size:13px}.particle-ex-literal{color:var(--text-muted);font-size:12px;font-style:italic}.particle-quiz{background:var(--bg-primary);border-radius:8px;padding:14px}.particle-quiz h4{color:var(--text-primary);margin:0 0 8px;font-size:13px;font-weight:600}.particle-quiz-prompt{color:var(--text-secondary);margin:0 0 10px;font-size:14px}.particle-quiz-prompt strong{color:var(--text-primary);font-family:Noto Sans KR,sans-serif}.particle-quiz-options{flex-wrap:wrap;gap:8px;display:flex}.particle-quiz-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:8px;padding:8px 18px;font-family:Noto Sans KR,sans-serif;font-size:15px;transition:background .15s,border-color .15s}.particle-quiz-btn:hover:not(:disabled){border-color:var(--accent-noun)}.particle-quiz-btn.correct{background:var(--accent-verb);border-color:var(--accent-verb);color:#000}.particle-quiz-btn.incorrect{background:var(--accent-blank);border-color:var(--accent-blank);color:#fff}.particle-quiz-btn:disabled{cursor:default;opacity:.7}.particle-quiz-result{margin:10px 0 0;font-size:13px;line-height:1.4}.particle-quiz-result.correct{color:var(--accent-verb)}.particle-quiz-result.incorrect{color:var(--accent-blank)}.settings-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#1a1a2eb8;justify-content:flex-end;align-items:flex-start;display:flex;position:fixed;inset:0}.settings-panel{background:var(--bg-card);border-left:1px solid var(--border-color);flex-direction:column;gap:28px;width:320px;max-width:92vw;height:100vh;padding:24px 20px 40px;display:flex;overflow-y:auto;box-shadow:-4px 0 24px #0006}.settings-panel-header{justify-content:space-between;align-items:center;display:flex}.settings-panel-title{color:var(--text-primary);margin:0;font-size:18px;font-weight:700}.settings-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:22px;line-height:1;transition:color .15s}.settings-close-btn:hover{color:var(--text-primary)}.settings-section{flex-direction:column;gap:12px;display:flex}.settings-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0;font-size:11px;font-weight:700}.settings-section-hint{color:var(--text-muted);margin:0;font-size:12px}.settings-toggles{flex-direction:column;gap:8px;display:flex}.settings-toggle-row{border-bottom:1px solid var(--border-color);cursor:default;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.settings-toggle-row:last-child{border-bottom:none}.settings-toggle-label{color:var(--text-primary);flex-direction:column;gap:2px;font-size:14px;display:flex}.settings-toggle-hint{color:var(--text-muted);font-size:11px}.settings-toggle-btn{cursor:pointer;border:none;border-radius:14px;flex-shrink:0;padding:4px 14px;font-size:12px;font-weight:600;transition:background .15s,color .15s}.settings-toggle-btn.on{background:var(--accent-verb);color:#fff}.settings-toggle-btn.off{background:var(--meta-pill-bg);color:var(--meta-pill-text);border:1px solid var(--border-color)}.settings-voices-loading,.settings-voices-unavailable{color:var(--text-muted);font-size:13px}.settings-voices{flex-direction:column;gap:8px;display:flex}.settings-voice-btn{border:1px solid var(--border-color);background:var(--meta-pill-bg);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 14px;transition:border-color .15s,background .15s;display:flex}.settings-voice-btn.unlocked{cursor:pointer}.settings-voice-btn.locked{opacity:.5;cursor:not-allowed}.settings-voice-btn.selected{border-color:var(--accent-verb);background:color-mix(in srgb, var(--accent-verb) 12%, var(--bg-card))}.settings-voice-btn:hover:not(.locked):not(.selected){border-color:var(--text-muted)}.voice-btn-name{color:var(--text-primary);font-size:14px;font-weight:600}.voice-btn-active{color:var(--accent-verb);font-size:12px;font-weight:600}.voice-btn-locked{color:var(--text-muted);font-size:11px}.settings-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;padding:5px 10px;font-size:13px;transition:border-color .15s,color .15s}.settings-btn:hover{border-color:var(--accent-verb);color:var(--text-primary)}.card-stage{max-width:640px}.practice-topbar{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.practice-logo{flex-direction:column;line-height:1;display:flex}.practice-logo-main{color:#e8b84b;font-family:Playfair Display,serif;font-size:22px;font-weight:700}.practice-logo-sub{letter-spacing:.14em;color:#f5edd88c;text-transform:lowercase;margin-top:2px;font-size:10px}.card-meta-row{gap:10px;margin-bottom:12px}.card-progress{flex:1;grid-template-columns:auto 1fr auto auto;align-items:center;gap:8px;display:grid}.card-progress-left,.card-progress-right{color:#f5edd873;white-space:nowrap;font-size:11px}.card-progress-track{background:#090c12e6;border-radius:999px;height:4px;overflow:hidden}.card-progress-fill{background:#c8973a;height:100%;transition:width .18s;display:block}.pass-indicator{color:#f5edd8b3;background:#141b26b3;border:1px solid #f5edd829;padding:5px 10px;font-size:11px}.sentence-area{cursor:pointer}.tap-hint{transition:opacity .2s}.audio-state-line{color:#c8973a;opacity:0;min-height:14px;margin-top:2px;font-size:10px;font-style:italic;transition:opacity .2s}.audio-state-line.active{opacity:.86}.audio-state-line.playing{color:#e8b84b}.lantern-btn{color:#1a1208;cursor:pointer;background:radial-gradient(circle at 30% 25%,#e8b84b 0%,#c8973a 48%,#8e6a24 100%);border:1.5px solid #c8973a;border-radius:999px;width:44px;height:44px;font-size:20px;line-height:1;transition:transform .15s,box-shadow .2s,filter .2s;box-shadow:0 0 #e8b84b66}.lantern-btn:hover{filter:brightness(1.06);transform:translateY(-1px)}.lantern-btn.playing{animation:1s ease-in-out infinite lanternPulse}@keyframes lanternPulse{0%,to{filter:brightness();box-shadow:0 0 #e8b84b40}50%{filter:brightness(1.18);box-shadow:0 0 18px #e8b84ba6}}.result-area{opacity:0;background:#141b26;border:1.5px solid #c8973a40;border-radius:14px;margin:12px 0 14px;padding:14px 16px;display:none;transform:translateY(6px)}.result-area.visible{animation:.22s ease-out forwards resultFadeIn;display:block}@keyframes resultFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.result-korean{color:#f5edd8;font-family:Noto Serif KR,serif;font-size:26px;line-height:1.2}.result-english{color:#e8b84b;margin-top:6px;font-family:Playfair Display,serif;font-size:16px;font-style:italic}.result-literal{color:#f5edd899;margin-top:4px;font-size:12px}.word-bank-tile{cursor:grab}.word-bank-tile:active{cursor:grabbing}.word-bank-tile.eliminated{opacity:.35;pointer-events:none;border-color:#f8717173}.word-bank.quiz-mode-bank .word-bank-tile.quiz-only{min-height:96px}.word-bank.quiz-mode-bank .word-bank-tile.quiz-only .word-bank-tile-kr{font-size:26px;line-height:1.1}.story-mode{flex-direction:column;gap:12px;width:100%;max-width:980px;margin:0 auto;padding:12px;display:flex}.story-controls,.story-scene{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:14px}.story-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.difficulty-row .difficulty-btn{font-size:12px}.story-feedback{color:var(--accent-verb)}.story-audio-status{color:var(--text-secondary);font-size:12px}.story-line{border-bottom:1px solid var(--border);margin-bottom:12px;padding-bottom:10px}.story-kr{font-size:24px;font-weight:700}.story-literal{color:var(--text-secondary);margin-top:4px;font-style:italic}.story-en{color:var(--text-primary);margin-top:2px}.blank-panel{border:1px solid var(--accent-noun-dim);border-radius:14px;margin-top:8px;padding:12px}.blank-panel.wrong{border-color:var(--accent-blank);animation:.35s tileShake}.story-options{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;display:grid}.story-option-card{border:1px solid var(--border);background:color-mix(in srgb, var(--bg-card) 88%, var(--accent-noun-glow));text-align:left;cursor:pointer;border-radius:12px;padding:8px}.story-option-card:hover{border-color:var(--accent-noun)}.story-option-emoji{font-size:20px}.story-option-rom{color:var(--text-secondary);font-style:italic}.story-option-en{color:var(--accent-noun);font-weight:600}.story-audio-btn{margin-top:6px}.syllable-build{margin:8px 0;font-size:28px;font-weight:700}.story-type-mode input{background:var(--bg-input);border:1px solid var(--border);min-width:220px;color:var(--text-primary);border-radius:10px;padding:8px 10px}.story-complete{border:1px solid var(--accent-verb-dim);border-radius:12px;margin-top:10px;padding:10px}.story-scenario-meta{color:var(--text-secondary);flex-wrap:wrap;gap:12px;font-size:12px;display:flex}.story-asterisk-list{color:var(--text-secondary);flex-wrap:wrap;gap:10px;margin-top:10px;font-size:12px;display:flex}.dict-favorite-badge,.dict-flag-badge{border:1px solid var(--border);background:color-mix(in srgb, var(--bg-card) 80%, #000);border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;display:inline-flex;position:absolute;top:8px;right:8px}.dict-favorite-badge{color:#f59e0b;border-color:#f59e0b66;right:34px}.dict-flag-badge{color:#f87171;border-color:#f8717166;right:60px}.dict-action-overlay{z-index:90;position:fixed;inset:0}.dict-action-menu{z-index:100;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:6px;min-width:170px;padding:6px;display:flex;position:fixed;box-shadow:0 10px 30px #00000059}.dict-action-menu button{border:1px solid var(--border);background:var(--btn-secondary-bg);color:var(--text-primary);text-align:left;border-radius:8px;padding:8px 10px}.dict-action-menu button:hover{border-color:var(--accent-verb)}.dict-action-label{color:var(--text-secondary);padding:2px 6px 0;font-size:.75rem}.dict-action-select{border:1px solid var(--border);background:var(--bg-panel);color:var(--text-primary);border-radius:8px;padding:7px 10px}.dict-action-select:disabled{opacity:.65}.practice-source-scroll{gap:8px;padding:8px 2px 14px;display:flex;overflow-x:auto}.decode-overlay{z-index:1200;background:#080e2099;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.decode-modal{background:var(--panel-bg,#0f2138);border:1px solid #ffffff2e;border-radius:18px;width:min(860px,100%);max-height:80vh;padding:16px;overflow:auto}.decode-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.decode-close{color:inherit;cursor:pointer;background:0 0;border:none;font-size:24px}.decode-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;margin-top:12px;display:grid}.decode-tile{background:#ffffff0f;border:1px solid #ffffff24;border-radius:12px;flex-direction:column;gap:4px;padding:10px;display:flex}.decode-kr{font-weight:700}.decode-rom{opacity:.8;font-size:.86rem}.decode-en{opacity:.9;font-size:.9rem}.dict-floating-practice-btn{z-index:160;position:fixed;bottom:84px;right:18px}.dict-practice-menu-overlay{z-index:300;background:#080e2080;justify-content:center;align-items:flex-end;padding:12px;display:flex;position:fixed;inset:0}.dict-practice-menu{background:var(--panel-bg,#102742);border:1px solid #ffffff26;border-radius:14px;width:min(920px,100%);max-height:70vh;padding:14px;overflow:auto}.dict-practice-menu-head{justify-content:space-between;align-items:center;display:flex}.dict-practice-section{margin-top:10px}.dict-practice-list{grid-template-columns:1fr;gap:6px;display:grid}.dict-practice-item{text-align:left;justify-content:space-between;gap:10px;display:flex}.dict-floating-card-wrap{z-index:280;pointer-events:none;justify-content:center;display:flex;position:fixed;top:80px;left:0;right:0}.dict-floating-card{pointer-events:auto;background:#0d1e31f5;border:1px solid #ffffff2e;border-radius:14px;width:min(760px,100% - 24px);padding:14px}.dict-floating-card-head{justify-content:space-between;align-items:center;display:flex}.dict-floating-dropzone{border:2px dashed #f5a836b3;border-radius:12px;justify-content:center;align-items:center;min-height:56px;margin-top:10px;padding:8px;display:flex}.dict-floating-feedback.wrong{color:#ffae8d;margin-top:8px}.dict-floating-feedback.correct{color:#a9f5ca;margin-top:8px}.dict-floating-actions{gap:8px;margin-top:10px;display:flex}.dict-tile.practice-draggable{cursor:grab}.import-anki-panel{background:#ffffff08;border:1px solid #ffffff24;border-radius:14px;margin-bottom:18px;padding:14px}.import-anki-manual-label{letter-spacing:.02em;color:#ffffffbf;text-transform:uppercase;margin-top:10px;margin-bottom:6px;font-size:.86rem}.import-anki-zones{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px;margin-top:8px;display:grid}.import-anki-zones.manual{margin-top:0}.import-anki-zone{border:1px dashed #f5a8368c;border-radius:12px;flex-direction:column;gap:8px;padding:12px;transition:border-color .16s,background .16s,transform .16s;display:flex}.import-anki-zone.bulk{background:linear-gradient(120deg,#f5a83633,#f5a8360f);border-width:2px;border-color:#f5a836e6;box-shadow:0 10px 24px #00000038}.import-anki-zone.loading{opacity:.65}.import-anki-zone.drag-over{background:#f5a83624;border-color:#f5a836;transform:translateY(-1px)}.import-anki-summary{gap:4px;display:grid}.import-anki-breakdown{gap:6px;margin-top:8px;display:grid}.import-anki-breakdown-item{background:#00000029;border:1px solid #ffffff1f;border-radius:10px;grid-template-columns:1.4fr repeat(5,minmax(88px,1fr));align-items:center;gap:8px;padding:8px 10px;font-size:.86rem;display:grid}@media (width<=880px){.import-anki-breakdown-item{grid-template-columns:1fr;gap:2px}}.import-review-list{flex-direction:column;gap:10px;margin-top:8px;display:flex}.import-review-item{background:#0000002e;border:1px solid #ffffff21;border-radius:10px;padding:10px}.import-review-meta{opacity:.9;flex-wrap:wrap;gap:8px;font-size:.85rem;display:flex}.import-review-json{background:#00000038;border-radius:8px;max-height:180px;margin-top:8px;padding:8px;font-size:.78rem;overflow:auto}
