@import"https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500;700&family=Space+Grotesk:wght@400;500;600&display=swap";:root{--bg: #080b12;--surface: rgba(7, 11, 17, .88);--surface-strong: rgba(12, 18, 28, .94);--text: #f5f5f1;--muted: rgba(245, 245, 241, .6);--accent: #6ed3ff;--accent-strong: #34b8ff;--glow: #94f1ff;--cyber-grid: radial-gradient(circle at 80% 10%, rgba(110, 211, 255, .12), transparent 55%);--bg-2: #11162a;--bg-3: #05060a;--on-accent: #05060a;--border-soft: color-mix(in srgb, var(--text) 12%, transparent);--border: color-mix(in srgb, var(--text) 9%, transparent);--border-strong: color-mix(in srgb, var(--text) 18%, transparent);--border-subtle: color-mix(in srgb, var(--text) 6%, transparent);--fill-soft: color-mix(in srgb, var(--text) 8%, transparent);--fill-softer: color-mix(in srgb, var(--text) 3%, transparent);--hover-fill: color-mix(in srgb, var(--text) 10%, transparent);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .45);--shadow-xl: 0 30px 70px rgba(5, 6, 10, .48);--shadow-modal: 0 40px 80px rgba(0, 0, 0, .55);--shadow-toast: 0 8px 24px rgba(0, 0, 0, .4);--shadow-card: 0 10px 30px rgba(0, 0, 0, .25);--overlay-aurora: linear-gradient( 120deg, rgba(255, 138, 176, .05), rgba(0, 240, 255, .04) );--overlay-backdrop: color-mix(in srgb, var(--bg) 75%, transparent);--overlay-scrim: rgba(0, 0, 0, .3);--fade-from: rgba(15, 16, 24, 0);--fade-to: rgba(15, 16, 24, .85);--fade-to-strong: rgba(15, 16, 24, .9);--danger: #ff4f82;--toast-error-border: rgba(255, 82, 82, .5);--toast-error-bg: rgba(255, 82, 82, .1);--toast-warning-border: rgba(255, 193, 7, .5);--toast-warning-bg: rgba(255, 193, 7, .1);--toast-info-border: rgba(33, 150, 243, .5);--toast-info-bg: rgba(33, 150, 243, .1);--toast-success-border: rgba(76, 175, 80, .5);--toast-success-bg: rgba(76, 175, 80, .1);--tier-s-bg: linear-gradient(120deg, #ff9edb, #ffdd55);--tier-s-text: #160b1a;--tier-s-shadow: 0 0 18px rgba(255, 158, 219, .4);--tier-a-bg: linear-gradient(120deg, #7cf3ff, #82ffb0);--tier-a-text: #042018;--tier-a-shadow: 0 0 16px rgba(124, 243, 255, .35);--tier-b-bg: linear-gradient(120deg, #9fa8ff, #cfd5ff);--tier-b-text: #0c1030;--tier-b-shadow: 0 0 14px rgba(159, 168, 255, .3);--tier-c-bg: linear-gradient(120deg, #ffd3a0, #ffe9c7);--tier-c-text: #2a1607;--tier-c-shadow: 0 0 12px rgba(255, 211, 160, .25);--spinner-border: color-mix(in srgb, var(--text) 10%, transparent);--confetti-bg: radial-gradient(circle at 20% 30%, rgba(255, 158, 219, .35), transparent 35%), radial-gradient(circle at 80% 20%, rgba(0, 240, 255, .25), transparent 30%), radial-gradient(circle at 60% 70%, rgba(255, 221, 85, .3), transparent 32%);font-size:16px}*{box-sizing:border-box}.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:var(--bg);padding:.75rem 1.5rem;text-decoration:none;border-radius:0 0 .5rem;z-index:10001;font-weight:600;transition:top .2s}.skip-link:focus{top:0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:.25rem}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}body{margin:0;min-height:100vh;font-family:Zen Kaku Gothic New,Hiragino Sans,Source Han Sans,sans-serif;background:linear-gradient(135deg,var(--bg) 0%,var(--bg-2) 65%,var(--bg-3) 100%);color:var(--text);padding:clamp(1.25rem,2.5vw,3rem) clamp(.75rem,2.5vw,3rem);position:relative;font-feature-settings:"palt" 1}body:before{content:"";position:fixed;inset:0;background:var(--cyber-grid);opacity:.3;pointer-events:none}body:after{content:"";position:fixed;inset:0;background:var(--overlay-aurora);pointer-events:none}#root{position:relative;isolation:isolate}.site-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2.5rem;padding:1rem 0;border-bottom:1px solid var(--border-subtle)}.brand-block{display:flex;gap:0;align-items:center;flex-shrink:0}.kanji-badge{width:2.25rem;height:2.25rem;border-radius:.5rem;background:var(--text);color:var(--bg);display:grid;place-items:center;font-size:1.25rem;font-family:Space Grotesk,sans-serif;font-weight:600;box-shadow:0 1px 3px #0000001a}.header-nav{display:flex;gap:1.75rem;align-items:center;flex:1;justify-content:center}.nav-link{background:none;border:none;color:var(--text);font-size:.875rem;font-weight:500;cursor:pointer;padding:.5rem 0;transition:color .2s ease;font-family:Space Grotesk,sans-serif;position:relative;white-space:nowrap}.nav-link:hover{color:var(--accent)}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);transition:width .2s ease}.nav-link:hover:after{width:100%}.header-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.header-dropdowns{display:flex;gap:.5rem;align-items:center}.header-select{padding:.4375rem .625rem;border:1px solid var(--border);border-radius:.5rem;background:var(--surface-strong);color:var(--text);font-size:.8125rem;cursor:pointer;transition:border-color .2s ease,background .2s ease;font-family:Space Grotesk,sans-serif;height:2rem;min-width:auto;line-height:1.2}.header-select:hover{border-color:var(--border-strong);background:var(--surface)}.header-select:focus{outline:none;border-color:var(--accent)}@media(max-width:900px){.site-header{flex-wrap:wrap;gap:1rem}.header-nav{order:3;width:100%;justify-content:flex-start;gap:1.5rem}.header-actions{order:2}}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.68rem;margin:0 0 .25rem;color:var(--muted)}h1,h2,h3,h4{margin:0;font-family:Space Grotesk,sans-serif}button,select,input,textarea{font:inherit;color:inherit}button,select{border-radius:.5rem;border:1px solid var(--border-soft);background:var(--surface);padding:.4375rem 1rem;font-size:.8125rem;transition:border .2s ease,transform .15s ease}.header-actions button{height:2rem;line-height:1.2}button:hover,select:hover{border-color:var(--accent);transform:translateY(-1px)}button:focus-visible,select:focus-visible,textarea:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.ghost-btn{background:transparent}.pill-btn{background:var(--accent);border-color:var(--accent);color:var(--on-accent);font-weight:600;font-size:.8125rem;padding:.4375rem 1rem;height:2rem;line-height:1.2}.layout-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(320px,50vw,560px),1fr));gap:clamp(1rem,2vw,2rem);width:100%}#main-content{width:100%;max-width:min(1180px,98vw);margin:0 auto;padding-inline:clamp(.5rem,2vw,1.5rem)}.panel{background:var(--surface);border-radius:clamp(1rem,1.6vw,1.6rem);padding:clamp(1.2rem,2vw,2rem);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--border);box-shadow:var(--shadow-xl);width:100%}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:clamp(.75rem,1vw,1.25rem);margin-bottom:clamp(1rem,1.5vw,1.5rem)}.metrics-inline{display:flex;flex-wrap:wrap;gap:clamp(.35rem,.8vw,.75rem)}.chip{padding:clamp(.2rem,.6vw,.35rem) clamp(.65rem,1vw,.9rem);border-radius:999px;background:var(--surface-strong);color:var(--muted);font-size:clamp(.75rem,.9vw,.85rem)}.chip.muted{opacity:.7}.reading-stack{border-radius:1.25rem;padding:1.5rem;border:1px solid var(--border);background:linear-gradient(145deg,var(--fill-soft),transparent);min-height:220px;margin-bottom:1.4rem}.reading-content{line-height:1.8;font-size:clamp(1.08rem,1.42vw,1.35rem);word-break:keep-all;overflow-wrap:break-word;position:relative;overflow-y:auto}.reading-content-inner{line-height:inherit;font-size:inherit}.reading-content.is-collapsed{max-height:9rem;padding-right:.5rem}.reading-content.is-collapsed:after{content:"";position:absolute;inset:auto 0 0;height:3rem;background:linear-gradient(180deg,var(--fade-from),var(--fade-to));pointer-events:none}.collapse-bar{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.6rem}.collapse-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--muted)}.collapse-toggle input{accent-color:var(--accent)}.reading ruby{ruby-position:over;ruby-align:center;font-size:1.25rem;line-height:1.8;margin:0 .06em}.reading rt{text-align:center;font-size:clamp(.66rem,1vw,.82rem);letter-spacing:.05em;color:var(--accent);opacity:.9;line-height:1.1;font-weight:600;transform:translateY(-.02em)}.reading rb{line-height:1.8}.tracking{margin-top:1rem;min-height:1.5rem;letter-spacing:.08em;font-size:1rem;color:var(--text);transition:max-height .25s ease,opacity .2s ease}.tracking.is-collapsed{max-height:4.8rem;opacity:.95;overflow:hidden;position:relative;white-space:normal}.tracking.is-collapsed:after{content:"";position:absolute;inset:auto 0 0;height:1.2rem;background:linear-gradient(180deg,var(--fade-from),var(--fade-to-strong));pointer-events:none}.tracking.is-collapsed .glyph{display:inline-block;flex-direction:row;align-items:center;gap:.1rem;padding:.1rem .15rem;min-width:auto}.glyph{position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:.15rem;padding:.2rem .15rem;min-width:.85rem;line-height:1}.reading-line .glyph:before{content:attr(data-reading);font-size:.6rem;color:var(--accent);letter-spacing:.08em;line-height:1}.reading-line .glyph[data-reading=""]:before{content:""}.tracking .glyph:before{content:""}.reading-line{margin:0 0 clamp(.5rem,1vw,.85rem);display:flex;flex-wrap:wrap;gap:.05rem}.reading-line:last-child{margin-bottom:0}.reading-glyph{font-size:1.25rem;color:var(--text)}.tracking .done{color:var(--accent-strong)}.tracking .error{color:var(--danger);text-decoration:underline wavy currentColor}.tracking .cursor{border-bottom:2px solid var(--accent);color:var(--accent);animation:caret 1s steps(2) infinite}.tracking .pending{color:var(--muted)}@keyframes caret{0%{opacity:1}50%{opacity:.35}to{opacity:1}}.typing-suite{display:flex;flex-direction:column;gap:1rem}.progress-shell{width:100%;height:.45rem;border-radius:999px;background:color-mix(in srgb,var(--text) 14%,transparent);overflow:hidden}.progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent) 0%,var(--glow) 90%);transition:width .2s ease}textarea{width:100%;min-height:clamp(110px,18vw,140px);border-radius:1rem;border:1px solid var(--border-strong);padding:1rem 1.25rem;background:var(--surface-strong);resize:vertical}.hint-row{margin:-.25rem 0 .25rem;color:var(--muted);display:flex;gap:.4rem;align-items:baseline;font-size:.95rem}.hint-char{color:var(--text);font-size:1.05rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:clamp(.75rem,1vw,1rem)}.stat-grid strong{font-size:1.4rem;font-family:Space Grotesk,sans-serif}.search-row{display:flex;gap:.75rem;margin-bottom:1rem}.search-row input{flex:1;border-radius:999px;border:1px solid var(--border-strong);padding:.55rem 1rem;background:var(--surface-strong)}.vocab-list{display:grid;gap:.75rem;max-height:360px;overflow-y:auto;padding-right:.5rem}.pagination-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.75rem}.pagination-row .muted{text-align:center;flex:1}.vocab-card{border-radius:1rem;border:1px solid var(--border);padding:1rem;background:var(--surface-strong);display:flex;justify-content:space-between;gap:.75rem;align-items:center;transition:background .2s ease,border-color .2s ease,transform .2s ease}.vocab-card:hover{background:var(--surface);border-color:var(--border-strong);transform:translateY(-1px)}.vocab-card main{flex:1}.vocab-card h4{margin:0 0 .15rem;font-size:1.1rem}.vocab-card p{margin:0;color:var(--muted);font-size:.85rem}.card-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem}.favorite-list{display:grid;gap:.5rem;max-height:240px;overflow-y:auto}.favorite-chip{padding:.45rem .75rem;border-radius:.9rem;background:var(--fill-soft);border:1px solid var(--border-soft);display:flex;justify-content:space-between;gap:.5rem;font-size:.9rem}.favorite-chip button{border-radius:.5rem;padding:.15rem .5rem}.favorites-block{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.filter-group{display:flex;gap:.5rem;align-items:center}.muted{color:var(--muted)}.modal-backdrop{position:fixed;inset:0;background:var(--overlay-backdrop);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:10}.modal-card{width:min(520px,calc(100% - 2rem));border-radius:1.1rem;background:var(--surface);border:1px solid var(--border);padding:1.5rem;box-shadow:var(--shadow-modal)}.modal-card header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.custom-theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin:1rem 0}.custom-theme-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.2rem}.vocab-detail{display:flex;flex-direction:column;gap:1.5rem}.vocab-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.vocab-detail-title h2{margin:0;font-size:2rem;color:var(--text);line-height:1.2}.vocab-detail-kana{margin:.5rem 0 0;font-size:1.2rem;color:var(--muted)}.vocab-detail-section{display:flex;flex-direction:column;gap:.5rem}.vocab-detail-section h3{margin:0;font-size:.9rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.vocab-detail-translation{margin:0;font-size:1.1rem;color:var(--text);line-height:1.6}.vocab-detail-pos{margin:0;font-size:1rem;color:var(--muted);font-family:monospace}.vocab-detail-forms{display:flex;flex-direction:column;gap:.5rem}.vocab-detail-forms>div{display:flex;gap:.75rem;align-items:baseline}.vocab-detail-form-label{font-size:.9rem;color:var(--muted);min-width:80px}.vocab-detail-form-value{font-size:1rem;color:var(--text);font-family:monospace}.vocab-detail-example{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--fill-soft);border-radius:.5rem;border:1px solid var(--border-subtle)}.vocab-detail-example-ja{margin:0;font-size:1.1rem;color:var(--text);line-height:1.6}.vocab-detail-example-translation{margin:0;font-size:.95rem;color:var(--muted);line-height:1.5}.vocab-detail-frequency{margin:0;font-size:1rem;color:var(--muted);font-family:monospace}.vocab-reading-modal{display:flex;flex-direction:column;gap:1.5rem}.vocab-reading-section{display:flex;flex-direction:column;gap:.75rem}.vocab-reading-section h3{margin:0;font-size:.9rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.level-checkboxes{display:flex;flex-wrap:wrap;gap:.75rem}.level-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem .75rem;border:1px solid var(--border);border-radius:.5rem;background:var(--surface-strong);transition:background .2s ease,border-color .2s ease}.level-checkbox:hover{background:var(--surface);border-color:var(--border-strong)}.level-checkbox input[type=checkbox]{margin:0;cursor:pointer;accent-color:var(--accent)}.level-checkbox input[type=checkbox]:checked+span{color:var(--accent);font-weight:600}.level-checkbox span{font-size:.95rem;color:var(--text);-webkit-user-select:none;user-select:none}.vocab-reading-section input[type=number]{padding:.75rem;border:1px solid var(--border);border-radius:.5rem;background:var(--surface-strong);color:var(--text);font-size:1rem;width:100%;transition:border-color .2s ease}.vocab-reading-section input[type=number]:focus{outline:none;border-color:var(--accent)}.vocab-reading-hint{margin:0;font-size:.85rem;color:var(--muted)}.file-drop{margin-top:1rem;border:1px dashed color-mix(in srgb,var(--text) 30%,transparent);border-radius:.8rem;padding:.75rem;text-align:center;cursor:pointer}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:2rem}.error-boundary-content{background:var(--surface);border-radius:1rem;padding:2.5rem;max-width:600px;text-align:center;box-shadow:var(--shadow-lg)}.error-boundary-content h2{color:var(--accent);margin-bottom:1rem}.error-boundary-content p{color:var(--muted);margin-bottom:1.5rem}.error-details{margin:1.5rem 0;text-align:left;background:var(--overlay-scrim);border-radius:.5rem;padding:1rem}.error-details summary{cursor:pointer;color:var(--accent);margin-bottom:.5rem}.error-details pre{margin:.5rem 0;font-size:.85rem;color:var(--muted);overflow-x:auto}.error-stack{font-size:.75rem;opacity:.7}.error-toast-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.75rem;max-width:400px;width:calc(100% - 2rem)}.error-toast{background:var(--surface-strong);border:1px solid;border-radius:.75rem;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;box-shadow:var(--shadow-toast);animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-error{border-color:var(--toast-error-border);background:var(--toast-error-bg)}.toast-warning{border-color:var(--toast-warning-border);background:var(--toast-warning-bg)}.toast-info{border-color:var(--toast-info-border);background:var(--toast-info-bg)}.toast-success{border-color:var(--toast-success-border);background:var(--toast-success-bg)}.toast-content{display:flex;align-items:center;gap:.75rem;flex:1}.toast-icon{font-size:1.25rem;flex-shrink:0}.toast-message{color:var(--text);font-size:.9rem;line-height:1.5}.toast-close{background:transparent;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer;padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .2s;flex-shrink:0}.toast-close:hover{background:var(--hover-fill);color:var(--text)}.result-hero{position:relative;padding:1rem 1rem 1.5rem;text-align:center}.badge-tier{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:999px;font-weight:700;font-size:.9rem}.badge-s{background:var(--tier-s-bg);color:var(--tier-s-text);box-shadow:var(--tier-s-shadow)}.badge-a{background:var(--tier-a-bg);color:var(--tier-a-text);box-shadow:var(--tier-a-shadow)}.badge-b{background:var(--tier-b-bg);color:var(--tier-b-text);box-shadow:var(--tier-b-shadow)}.badge-c{background:var(--tier-c-bg);color:var(--tier-c-text);box-shadow:var(--tier-c-shadow)}.result-hero h3{margin:.75rem 0 .25rem}.result-hero .muted{margin:0}.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-top:.5rem}.result-card{padding:.75rem .85rem;border-radius:.9rem;background:var(--fill-softer);border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.result-card strong{font-size:1.35rem}.result-actions{display:flex;justify-content:flex-end;gap:.6rem}.result-confetti{position:absolute;inset:0;pointer-events:none;background:var(--confetti-bg);animation:floatConfetti 8s ease-in-out infinite;filter:blur(8px);z-index:-1}@keyframes floatConfetti{0%{transform:translateY(0);opacity:.9}50%{transform:translateY(-12px);opacity:.7}to{transform:translateY(0);opacity:.9}}@media(max-width:640px){.error-toast-container{right:.5rem;top:.5rem;width:calc(100% - 1rem);max-width:none}.error-boundary{min-height:50vh;padding:1rem}.error-boundary-content{padding:1.5rem}}.loading-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:2rem;gap:1rem}.loading-spinner{width:3rem;height:3rem;border:3px solid var(--spinner-border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--muted);font-size:.9rem;margin:0}
