@font-face{font-family:Space Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/4ba802ed8e67eac5-s.e45fea2b.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/d7a0600e467cf0bd-s.20ecb425.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/dc0d9adbac686440-s.p.3b382e45.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/b8f2b92a9960dd69-s.12167c5a.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/28e60ca39c9ae554-s.7a4e9fcc.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../media/8d05cfa5faa8406c-s.p.4adea45d.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Mono Fallback;src:local(Arial);ascent-override:81.58%;descent-override:26.3%;line-gap-override:0.0%;size-adjust:137.28%}.space_mono_bed26322-module__qDd7Qq__className{font-family:Space Mono,Space Mono Fallback;font-style:normal}.space_mono_bed26322-module__qDd7Qq__variable{--font-mono:"Space Mono","Space Mono Fallback"}
:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--ink:#0f0f0f;--paper:#f6f0e8;--accent:#d4551f;--accent-dark:#b8441a;--accent-text:#fff;--emerald:#0f6b63;--violet:#53f;--muted:#5b564d;--card:#fff8ee;--card-bg:#fff8ee;--border:#0f0f0f1f;--shadow:0 18px 45px #0d0b061f;--radius:22px;--success:#0f6b63;--error:#b8441a;--error-text:#fff}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--ink:#f0f0f0;--paper:#121212;--card:#1e1e1e;--card-bg:#1e1e1e;--border:#ffffff1f;--shadow:0 18px 45px #0006;--muted:#a0a0a0;--accent:#e05a20;--accent-dark:#c44a18;--accent-text:#fff;--success:#2dd4bf;--error:#dc2626;--error-text:#fff}}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--ink:#f0f0f0;--paper:#121212;--card:#1e1e1e;--card-bg:#1e1e1e;--border:#ffffff1f;--shadow:0 18px 45px #0006;--muted:#a0a0a0;--accent:#e05a20;--accent-dark:#c44a18;--accent-text:#fff;--success:#2dd4bf;--error:#dc2626;--error-text:#fff}*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100vw;min-height:100vh;overflow-x:hidden}body{color:var(--ink);background:var(--paper);font-family:var(--font-body),"Hiragino Kaku Gothic ProN",sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}:root:not([data-theme=dark]) body{background:radial-gradient(circle at 15% 15%,#ff6b2c2e,#0000 45%),radial-gradient(circle at 80% 20%,#0f6b632e,#0000 46%),radial-gradient(circle at 25% 70%,#5533ff24,#0000 40%),linear-gradient(#fbf6ef 0%,#f3e8d8 100%)}:root[data-theme=dark] body{background:radial-gradient(circle at 15% 15%,#ff6b2c1f,#0000 45%),radial-gradient(circle at 80% 20%,#0f6b631f,#0000 46%),radial-gradient(circle at 25% 70%,#5533ff1a,#0000 40%),linear-gradient(#121212 0%,#1a1a1a 100%)}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) body{background:radial-gradient(circle at 15% 15%,#ff6b2c1f,#0000 45%),radial-gradient(circle at 80% 20%,#0f6b631f,#0000 46%),radial-gradient(circle at 25% 70%,#5533ff1a,#0000 40%),linear-gradient(#121212 0%,#1a1a1a 100%)}}a{color:inherit;text-decoration:none}.page{flex-direction:column;gap:64px;padding:48px 6vw 80px;display:flex}.nav{justify-content:space-between;align-items:center;gap:16px;display:flex}.logo{font-family:var(--font-display),serif;letter-spacing:.5px;align-items:center;gap:12px;font-weight:700;display:flex}.badge{border:1px solid var(--border);text-transform:uppercase;letter-spacing:1.2px;border-radius:999px;padding:4px 12px;font-size:12px}.hero{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:center;gap:32px;display:grid}.hero h1{font-family:var(--font-display),serif;font-size:clamp(2.8rem,4vw,4.2rem);line-height:1.05}.hero p{color:var(--muted);max-width:560px;font-size:1.1rem}.hero-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:28px}.cta-row{flex-wrap:wrap;gap:12px;margin-top:24px;display:flex}.btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:12px 22px;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .15s;box-shadow:0 12px 24px #ff6b2c40}.btn:hover{transform:translateY(-2px)}.btn:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.btn.secondary:focus-visible{outline-color:var(--ink)}.btn.secondary{color:var(--ink);border:1px solid var(--border);box-shadow:none;background:0 0}.grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px;padding:20px}.card h3{font-family:var(--font-display),serif;margin-bottom:8px}.mono{font-family:var(--font-mono),monospace}.trainer-shell{gap:32px;max-width:1200px;margin:0 auto;display:grid}.trainer-two{grid-template-columns:minmax(0,1.25fr) minmax(0,.9fr);align-items:start}.trainer-two .question-card{grid-area:1/1}.trainer-two .detail-card{grid-area:1/2}.trainer-center{grid-template-columns:minmax(0,1fr);justify-items:center}.trainer-center .question-card{width:100%;max-width:640px}.question-card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:28px;padding:40px}.card-enter{animation:.35s ease-out card-fade-in}.summary-emoji{animation:.4s ease-out summary-pop}.summary-stat{animation:.3s ease-out both card-fade-in}@keyframes card-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes summary-pop{0%{transform:scale(0)}70%{transform:scale(1.1)}to{transform:scale(1)}}.choices{gap:14px;margin-top:22px;display:grid}.choice{cursor:pointer;background:#0f6b6314;border:1px solid #0f6b6333;border-radius:16px;padding:16px 18px;font-size:1.05rem;line-height:1.4;transition:transform .15s,background .15s}.choice:hover{background:#0f6b631f;transform:translateY(-1px)}.choice:focus-visible{outline:3px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){.btn,.choice,.clickable-word{transition:none}.btn:hover,.choice:hover{transform:none}.card-enter,.summary-emoji,.summary-stat{animation:none}}.question-card h2,.question-prompt{word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;font-size:clamp(1.6rem,2.4vw,2.2rem);line-height:1.25}.rating-buttons{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.rating-buttons .btn-animated{flex:auto;min-width:70px;max-width:120px}.detail-card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:24px;flex-direction:column;gap:16px;padding:32px;display:flex}.detail-head{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.detail-head h2{font-family:var(--font-display),serif;font-size:clamp(1.8rem,2.6vw,2.6rem)}.detail-block{word-wrap:break-word;overflow-wrap:break-word;background:#0f6b6314;border:1px solid #0f6b6326;border-radius:16px;padding:16px;line-height:1.55}.detail-source{color:var(--muted);margin-top:8px;font-size:.85rem}@media (max-width:900px){.trainer-two{grid-template-columns:1fr}.trainer-two .question-card,.trainer-two .detail-card{grid-area:auto/1}}.stat-row{flex-wrap:wrap;gap:12px;display:flex}.stat{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:12px 16px}.footer-note{color:var(--muted);font-size:.9rem}@media (max-width:720px){.page{padding:32px 6vw 64px}.hero h1{font-size:clamp(2.2rem,6vw,3rem)}.question-card{padding:24px}.detail-card{padding:20px}}@media (max-width:480px){.rating-buttons{gap:6px}.rating-buttons .btn-animated{min-width:60px;padding:10px 12px;font-size:.85rem}.question-card{padding:20px}.settings-row{gap:4px}.theme-toggle .theme-label,.sound-toggle .sound-label,.logo>span:not(.badge){display:none}.settings-row .btn.secondary{padding:8px 12px;font-size:.8rem}.daily-goal{padding:12px}}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.theme-toggle,.sound-toggle{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;color:var(--ink);border-radius:999px;align-items:center;gap:6px;padding:8px 12px;font-size:.875rem;transition:background .15s;display:flex}.theme-toggle:hover,.sound-toggle:hover{background:var(--border)}.theme-icon,.sound-icon{font-size:1rem}.theme-label{text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.streak-counter{color:#fff;background:linear-gradient(135deg,#ff6b2c 0%,#ff8f5a 100%);border-radius:999px;align-items:center;gap:4px;padding:6px 12px;font-weight:600;display:inline-flex;box-shadow:0 4px 12px #ff6b2c4d}.streak-fire{font-size:1rem}.streak-count{font-size:1rem;font-weight:700}.streak-label{opacity:.9;margin-left:2px;font-size:.75rem}.daily-goal{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:16px}.daily-goal-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.daily-goal-title{color:var(--muted);font-size:.875rem}.daily-goal-count{font-size:.875rem;font-weight:600}.daily-goal-track{background:var(--border);border-radius:4px;height:8px;overflow:hidden}.daily-goal-fill{background:linear-gradient(90deg,var(--emerald),var(--success));border-radius:4px;height:100%}.daily-goal-complete{text-align:center;color:var(--success);margin-top:10px;font-size:.875rem;font-weight:600}.settings-row{align-items:center;gap:8px;display:flex}.choice-animated{cursor:pointer;text-align:left;width:100%;color:var(--ink);word-wrap:break-word;overflow-wrap:break-word;background:#0f6b6314;border:1px solid #0f6b6333;border-radius:16px;padding:16px 18px;font-size:1.05rem;line-height:1.4}.choice-animated:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.choice-animated:disabled{cursor:default}.choice-correct{background:var(--success);border-color:var(--success);color:#fff}.choice-incorrect{background:var(--error);border-color:var(--error);color:#fff}.choice-reveal-correct{background:var(--success);border-color:var(--success);color:#fff}.btn-animated{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:12px 22px;font-size:.95rem;font-weight:600;box-shadow:0 12px 24px #ff6b2c40}.btn-animated:focus-visible{outline:3px solid var(--accent);outline-offset:2px}.btn-animated.secondary{color:var(--ink);border:1px solid var(--border);box-shadow:none;background:0 0}.btn-animated.secondary:focus-visible{outline-color:var(--ink)}.kanken-gauge{padding:20px}.kanken-gauge-header{justify-content:space-between;align-items:baseline;margin-bottom:16px;display:flex}.kanken-gauge-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.kanken-gauge-level{color:var(--accent);font-size:1.5rem;font-weight:700}.kanken-gauge-track{background:var(--border);border-radius:6px;height:12px;margin-bottom:8px;position:relative}.kanken-gauge-confidence{background:#0f6b6340;border-radius:6px;height:100%;position:absolute;top:0}.kanken-gauge-marker{background:var(--accent);border:3px solid var(--card-bg);border-radius:50%;width:20px;height:20px;position:absolute;top:-4px;transform:translate(-50%);box-shadow:0 2px 8px #ff6b2c66}.kanken-gauge-tick{background:var(--card-bg);width:2px;height:100%;position:absolute;top:0;transform:translate(-50%)}.kanken-gauge-labels{height:20px;margin-top:4px;position:relative}.kanken-gauge-label{color:var(--muted);font-size:.7rem;position:absolute;transform:translate(-50%)}.kanken-gauge-confidence-text{color:var(--muted);text-align:center;margin-top:12px;font-size:.8rem}.rank-badge{text-align:center;padding:20px}.rank-badge-header{margin-bottom:8px}.rank-badge-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.rank-badge-title-container{margin-bottom:12px}.rank-badge-title{color:var(--accent);font-size:2rem;font-weight:700;line-height:1.2;display:block}.rank-badge-reading{color:var(--muted);font-size:.875rem;display:block}.rank-badge-count{margin-bottom:16px}.rank-badge-number{color:var(--ink);font-size:1.5rem;font-weight:600}.rank-badge-suffix{color:var(--muted);font-size:.8rem;display:block}.rank-badge-progress{background:#0f6b6314;border-radius:12px;padding:12px}.rank-badge-progress-header{color:var(--muted);justify-content:space-between;margin-bottom:8px;font-size:.8rem;display:flex}.rank-badge-progress-track{background:var(--border);border-radius:4px;height:8px;overflow:hidden}.rank-badge-progress-fill{background:linear-gradient(90deg,var(--emerald),var(--success));border-radius:4px;height:100%;transition:width .3s}.rank-badge-max{color:var(--success);font-weight:600}.learning-frontier{padding:20px}.learning-frontier-header{margin-bottom:16px}.learning-frontier-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.learning-frontier-zone{background:#0f6b6314;border-radius:16px;margin-bottom:16px;padding:20px}.learning-frontier-range{justify-content:center;align-items:center;gap:12px;margin-bottom:8px;font-size:1.25rem;display:flex}.learning-frontier-current{color:var(--accent);font-size:1.75rem;font-weight:700}.learning-frontier-low,.learning-frontier-high{color:var(--muted)}.learning-frontier-arrow{color:var(--border)}.learning-frontier-description{color:var(--muted);text-align:center;font-size:.8rem}.learning-frontier-milestone{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:12px}.learning-frontier-milestone-header{color:var(--muted);justify-content:space-between;margin-bottom:8px;font-size:.8rem;display:flex}.learning-frontier-milestone-track{background:var(--border);border-radius:4px;height:8px;overflow:hidden}.learning-frontier-milestone-fill{background:linear-gradient(90deg,var(--accent),var(--accent-dark));border-radius:4px;height:100%;transition:width .3s}.learning-frontier-max{text-align:center;color:var(--success);font-weight:600}.grade-comparison{text-align:center;padding:20px}.grade-comparison-main{margin-bottom:16px}.grade-comparison-prefix{color:var(--muted);margin-bottom:4px;font-size:.875rem;display:block}.grade-comparison-grade{color:var(--emerald);font-size:1.75rem;font-weight:700;display:block}.grade-comparison-details{justify-content:center;gap:24px;display:flex}.grade-comparison-item{text-align:center}.grade-comparison-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:.75rem;display:block}.grade-comparison-value{font-size:1rem;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.stats-card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:20px;overflow:hidden}.stats-card-header{border-bottom:1px solid var(--border);padding:16px 20px}.stats-card-title{color:var(--ink);font-size:.875rem;font-weight:600}.activity-heatmap{padding:20px}.activity-heatmap-header{justify-content:space-between;align-items:baseline;margin-bottom:16px;display:flex}.activity-heatmap-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.activity-heatmap-stats{color:var(--muted);font-size:.8rem}.activity-heatmap-container{gap:6px;display:flex}.activity-heatmap-day-labels{flex-direction:column;flex-shrink:0;gap:2px;display:flex}.activity-heatmap-day-label{color:var(--muted);height:12px;font-size:.65rem;line-height:12px}.activity-heatmap-grid{gap:2px;display:flex;overflow-x:auto}.activity-heatmap-week{flex-direction:column;flex-shrink:0;gap:2px;display:flex}.activity-heatmap-month-label{color:var(--muted);white-space:nowrap;width:0;height:12px;font-size:.65rem;line-height:12px;overflow:visible}.activity-heatmap-cell{background:var(--border);border-radius:2px;width:12px;height:12px}.activity-heatmap-cell.intensity-0{background:var(--border)}.activity-heatmap-cell.intensity-1{background:#0f6b634d}.activity-heatmap-cell.intensity-2{background:#0f6b6380}.activity-heatmap-cell.intensity-3{background:#0f6b63b3}.activity-heatmap-cell.intensity-4{background:var(--success)}.activity-heatmap-legend{color:var(--muted);justify-content:flex-end;align-items:center;gap:4px;margin-top:12px;font-size:.7rem;display:flex}.activity-heatmap-legend .activity-heatmap-cell{flex-shrink:0;width:10px;height:10px}.trouble-words{padding:20px}.trouble-words-header{justify-content:space-between;align-items:baseline;margin-bottom:16px;display:flex}.trouble-words-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.trouble-words-count{color:var(--error);font-size:.8rem;font-weight:600}.trouble-words-empty{text-align:center;color:var(--success);background:#0f6b6314;border-radius:12px;padding:20px}.trouble-words-list{flex-direction:column;gap:8px;display:flex}.trouble-word-item{background:color-mix(in srgb,var(--ink)3%,transparent);border:1px solid var(--border);border-radius:12px;align-items:center;gap:12px;padding:12px;display:flex}.trouble-word-item.urgency-critical{background:#d4551f14;border-color:#d4551f33}.trouble-word-item.urgency-warning{background:#ffc10714;border-color:#ffc10733}.trouble-word-urgency{font-size:1rem}.trouble-word-info{flex:1;min-width:0}.trouble-word-lemma{font-size:1rem;font-weight:600}.trouble-word-reading{color:var(--muted);margin-left:4px;font-size:.8rem}.trouble-word-status{text-align:right}.trouble-word-due{font-size:.8rem;font-weight:600;display:block}.trouble-word-item.urgency-critical .trouble-word-due{color:var(--error)}.trouble-word-item.urgency-warning .trouble-word-due{color:#d4a00a}.trouble-word-retrievability{color:var(--muted);font-size:.7rem;display:block}.skill-radar{padding:20px}.skill-radar-header{justify-content:space-between;align-items:baseline;margin-bottom:16px;display:flex}.skill-radar-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.skill-radar-overall{color:var(--accent);font-size:1rem;font-weight:600}.skill-radar-empty{text-align:center;color:var(--muted);padding:20px}.skill-radar-list{flex-direction:column;gap:16px;display:flex}.skill-radar-item{flex-direction:column;gap:6px;display:flex}.skill-radar-item-header{justify-content:space-between;align-items:baseline;display:flex}.skill-radar-item-label{font-size:.9rem;font-weight:500}.skill-radar-item-accuracy{color:var(--accent);font-size:.9rem;font-weight:600}.skill-radar-item-bar-container{position:relative}.skill-radar-item-bar{background:var(--border);border-radius:4px;height:8px;overflow:hidden}.skill-radar-item-bar-fill{background:linear-gradient(90deg,var(--accent),var(--accent-dark));border-radius:4px;height:100%;transition:width .3s}.skill-radar-item-footer{justify-content:space-between;align-items:center;display:flex}.skill-radar-item-attempts{color:var(--muted);font-size:.7rem}.skill-radar-item-volume{background:var(--border);border-radius:2px;width:60px;height:4px;overflow:hidden}.skill-radar-item-volume-fill{background:var(--muted);border-radius:2px;height:100%}.skill-radar-legend{border-top:1px solid var(--border);justify-content:center;gap:16px;margin-top:16px;padding-top:12px;display:flex}.skill-radar-legend-item{color:var(--muted);align-items:center;gap:6px;font-size:.7rem;display:flex}.skill-radar-legend-bar{border-radius:3px;width:20px;height:6px}.skill-radar-legend-bar.accuracy{background:linear-gradient(90deg,var(--accent),var(--accent-dark))}.skill-radar-legend-bar.volume{background:var(--muted)}.kanji-grid{padding:20px}.kanji-grid-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.kanji-grid-title{font-family:var(--font-display),serif;font-size:1.1rem;font-weight:600}.kanji-grid-stats{color:var(--muted);font-size:.875rem}.kanji-grid-empty{text-align:center;color:var(--muted);padding:32px}.kanji-grid-progress{margin-bottom:16px}.kanji-grid-progress-bar{background:var(--border);border-radius:4px;height:8px;display:flex;overflow:hidden}.kanji-grid-progress-fill{height:100%;transition:width .3s}.kanji-grid-progress-fill.mastery-4{background:var(--success)}.kanji-grid-progress-fill.mastery-2{background:var(--accent)}.kanji-grid-progress-labels{justify-content:space-between;margin-top:6px;font-size:.7rem;display:flex}.mastery-label-4{color:var(--success)}.mastery-label-2{color:var(--accent)}.mastery-label-0{color:var(--muted)}.kanji-grid-filter{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.kanji-grid-filter-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:12px;padding:4px 10px;font-size:.75rem;transition:all .15s}.kanji-grid-filter-btn:hover{border-color:var(--accent);color:var(--accent)}.kanji-grid-filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.kanji-grid-grades{flex-direction:column;gap:20px;max-height:400px;display:flex;overflow-y:auto}.kanji-grid-grade-section{border:1px solid var(--border);border-radius:8px;padding:12px}.kanji-grid-grade-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.kanji-grid-grade-label{font-size:.9rem;font-weight:600}.kanji-grid-grade-count{color:var(--muted);font-size:.75rem}.kanji-grid-cells{flex-wrap:wrap;gap:4px;display:flex}.kanji-cell{cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.9rem;transition:all .15s;display:flex}.kanji-cell:hover{z-index:10;transform:scale(1.2)}.kanji-cell.mastery-0{background:var(--border);color:var(--muted)}.kanji-cell.mastery-1{color:var(--ink);background:#ef44444d}.kanji-cell.mastery-2{color:var(--ink);background:#fbbf2466}.kanji-cell.mastery-3{color:var(--ink);background:#3b82f666}.kanji-cell.mastery-4{color:var(--ink);background:#22c55e80}.kanji-detail-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.kanji-detail-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;min-width:280px;max-width:90vw;padding:24px;position:relative}.kanji-detail-close{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:1.5rem;line-height:1;position:absolute;top:12px;right:12px}.kanji-detail-close:hover{color:var(--ink)}.kanji-detail-char{text-align:center;font-size:4rem;font-family:var(--font-display),serif;margin-bottom:16px}.kanji-detail-info{flex-direction:column;gap:12px;display:flex}.kanji-detail-row{justify-content:space-between;align-items:center;display:flex}.kanji-detail-label{color:var(--muted);font-size:.875rem}.kanji-detail-value{font-size:.875rem;font-weight:500}.kanji-detail-value.mastery-0{color:var(--muted)}.kanji-detail-value.mastery-1{color:#ef4444}.kanji-detail-value.mastery-2{color:#fbbf24}.kanji-detail-value.mastery-3{color:#3b82f6}.kanji-detail-value.mastery-4{color:var(--success)}.kanji-grid-legend{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;margin-top:16px;padding-top:12px;display:flex}.kanji-grid-legend-label{color:var(--muted);font-size:.75rem}.kanji-grid-legend-item{color:var(--muted);align-items:center;gap:4px;font-size:.7rem;display:flex}.kanji-grid-legend-cell{border-radius:3px;width:16px;height:16px}.kanji-grid-legend-cell.mastery-0{background:var(--border)}.kanji-grid-legend-cell.mastery-1{background:#ef44444d}.kanji-grid-legend-cell.mastery-2{background:#fbbf2466}.kanji-grid-legend-cell.mastery-3{background:#3b82f666}.kanji-grid-legend-cell.mastery-4{background:#22c55e80}.clickable-word{cursor:pointer;border-bottom:1px dotted #0f6b6366;border-radius:2px;transition:background .15s}.clickable-word:hover{background:#0f6b631a}.word-drawer-backdrop{z-index:200;background:#0006;position:fixed;inset:0}.word-drawer{background:var(--card-bg);max-height:60vh;padding:16px 24px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));z-index:201;border-radius:24px 24px 0 0;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -8px 32px #00000026}.word-drawer-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.word-drawer-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.5rem;line-height:1;position:absolute;top:16px;right:20px}.word-drawer-close:hover{color:var(--ink)}.word-drawer-header{margin-bottom:16px}.word-drawer-word{font-size:1.5rem;font-weight:700}.word-drawer-status{justify-content:center;padding:24px;display:flex}.word-drawer-not-found{text-align:center;color:var(--muted);padding:24px;font-size:.95rem}.word-drawer-entries{flex-direction:column;gap:16px;display:flex}.word-drawer-entry{background:#0f6b630f;border:1px solid #0f6b631f;border-radius:16px;padding:16px}.word-drawer-entry-head{flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:8px;display:flex}.word-drawer-lemma{font-size:1.2rem;font-weight:600}.word-drawer-reading{color:var(--muted);font-size:.95rem}.word-drawer-pos{background:var(--border);color:var(--muted);border-radius:4px;padding:2px 8px;font-size:.75rem}.word-drawer-definition{margin-bottom:4px;line-height:1.5}.word-drawer-gloss{color:var(--muted);margin-bottom:8px;font-size:.9rem}.word-drawer-add-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:opacity .15s}.word-drawer-add-btn:hover:not(:disabled){opacity:.9}.word-drawer-add-btn:disabled{background:var(--border);color:var(--muted);cursor:default}.freq-spectrum{padding:20px}.freq-spectrum-header{margin-bottom:12px}.freq-spectrum-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.freq-spectrum-subtitle{color:var(--ink);margin-top:2px;font-size:.85rem}.freq-spectrum-svg{width:100%;height:auto;display:block}.freq-spectrum-legend{color:var(--muted);justify-content:flex-end;align-items:center;gap:16px;margin-top:8px;font-size:.7rem;display:flex}.freq-spectrum-legend-item{align-items:center;gap:4px;display:flex}.freq-spectrum-legend-swatch{border-radius:2px;width:12px;height:8px;display:inline-block}
/*# sourceMappingURL=30e6c82aae0481d3.css.map*/