*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{--ink:#0f0e17;--ink-soft:#6b6882;--paper:#faf8f2;--cream:#f0ede3;--white:#ffffff;--accent:#e8421a;--accent-light:#fde8e2;--indigo:#3d3bcc;--indigo-light:#ececfa;--gold:#c9921a;--gold-light:#fdf3e0;--green:#1a7a4a;--green-light:#e4f5ec;--border:rgba(15,14,23,0.1);--border-str:rgba(15,14,23,0.18);--r-sm:8px;--r-md:14px;--r-lg:20px}html{background:var(--paper)}body{min-height:100vh;background:var(--paper);font-family:'Bricolage Grotesque', sans-serif;color:var(--ink);-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}s{color:var(--accent);text-decoration:none}ul{margin-left:15px}@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes pulse{0%{opacity:1}50%{opacity:0.4}100%{opacity:1}}@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.06)}100%{transform:scale(1)}}@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}@keyframes revealUp{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes transReveal{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page{max-width:1000px;margin:0 auto;padding:0 44px 40px}.site-footer{text-align:center;margin-top:64px;padding-top:28px;border-top:1px solid var(--border);font-family:'Noto Sans JP', sans-serif;font-size:13px;font-weight:200;color:var(--ink-soft);opacity:0.5;letter-spacing:0.14em}.sec-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}.sec-label{font-family:'DM Mono', monospace;font-size:10px;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}.sec-line{flex:1;height:1px;background:var(--border)}.sec-count{font-family:'DM Mono', monospace;font-size:10px;color:var(--ink-soft);opacity:0.5;letter-spacing:0.08em}header.inner{background:var(--ink);height:130px;width:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative;margin-bottom:52px;animation:fadeUp 0.3s ease both}header.inner.no-margin{margin-bottom:0}.btn-icon{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.08);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;text-decoration:none;color:rgba(255,255,255,0.65);position:absolute;left:32px;transition:background 0.15s, color 0.15s}.btn-icon:hover{background:rgba(255,255,255,0.16);color:#fff}.btn-icon+.btn-icon{left:92px}.btn-icon.edit{left:auto;right:32px}.btn-icon svg{width:18px;height:18px}.header-wordmark{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.28em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:8px}.header-title{font-size:26px;font-weight:800;color:#fff;letter-spacing:-0.02em}.header-meta{font-family:'DM Mono', monospace;font-size:10px;color:rgba(255,255,255,0.25);letter-spacing:0.12em;margin-top:6px}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:20px;animation:fadeUp 0.35s ease both 0.05s}.search-wrap{position:relative;flex:1}.search-input{width:100%;height:40px;background:var(--white);border:1.5px solid var(--border-str);border-radius:var(--r-sm);padding:0 38px 0 14px;font-family:'Bricolage Grotesque', sans-serif;font-size:14px;color:var(--ink);outline:none;transition:border-color 0.15s}.search-input::placeholder{color:var(--ink-soft);opacity:0.5}.search-input:focus{border-color:var(--accent)}.search-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--ink-soft);opacity:0.4;pointer-events:none}.tool-btn{height:40px;padding:0 16px;border-radius:var(--r-sm);border:1.5px solid var(--border-str);background:var(--white);font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-soft);cursor:pointer;display:flex;align-items:center;gap:7px;transition:all 0.15s;white-space:nowrap;flex-shrink:0}.tool-btn:hover{border-color:var(--ink);color:var(--ink)}.tool-btn.active{background:var(--ink);border-color:var(--ink);color:var(--white)}.tool-btn .dot{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:0.5;flex-shrink:0;transition:background 0.15s, opacity 0.15s}.tool-btn.active .dot{opacity:1;background:var(--accent)}.stats-row{display:flex;align-items:center;gap:14px;margin-bottom:14px;animation:fadeUp 0.35s ease both 0.08s}.stats-label{font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}.stats-line{flex:1;height:1px;background:var(--border)}.stats-count{font-family:'DM Mono', monospace;font-size:10px;color:var(--ink-soft);opacity:0.5;letter-spacing:0.08em}.site-header{display:flex;align-items:center;justify-content:space-between;padding:36px 0 28px;border-bottom:1px solid var(--border);margin-bottom:56px;animation:fadeUp 0.35s ease both}.logotype{font-size:13px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink)}.logotype span{color:var(--accent)}.jp-sub{font-family:'Noto Sans JP', sans-serif;font-size:12px;font-weight:200;color:var(--ink-soft);letter-spacing:0.14em}.hero-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;gap:24px;animation:fadeUp 0.4s ease both 0.02s}.hero-title{font-size:clamp(52px, 7vw, 88px);font-weight:800;line-height:0.92;letter-spacing:-0.03em;color:var(--ink)}.hero-title .accent-word{color:var(--accent);font-style:italic}.hero-title .jp-word{font-family:'Noto Sans JP', sans-serif;font-weight:200;font-size:0.55em;color:var(--ink-soft);display:block;letter-spacing:0.05em;margin-top:10px}.search-col{flex-shrink:0;width:280px;padding-bottom:4px}.search-label{font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.18em;color:var(--ink-soft);text-transform:uppercase;margin-bottom:8px;display:block}.search-col .search-wrap{position:relative}.search-col .search-input{height:44px;background:var(--cream);border-color:transparent;padding:0 42px 0 16px;font-size:14px;font-weight:400}.search-col .search-input:focus{border-color:var(--accent);background:#fff}.search-col .search-icon{right:14px;width:16px;height:16px;opacity:0.5}.sec-block{margin-bottom:40px;animation:fadeUp 0.45s ease both}.sec-block:nth-child(1){animation-delay:0.05s}.sec-block:nth-child(2){animation-delay:0.12s}.sec-block:nth-child(3){animation-delay:0.19s}.sec-block:nth-child(4){animation-delay:0.26s}.games-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:12px}.tools-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:12px}.links-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:10px}.card{display:block;text-decoration:none;border-radius:var(--r-lg);position:relative;overflow:hidden;transition:transform 0.18s cubic-bezier(0.22, 0.68, 0, 1.2)}.card:hover{transform:translateY(-3px)}.card:active{transform:translateY(-1px)}.card-game{background:var(--ink);padding:26px 24px 22px;min-height:168px;display:flex;flex-direction:column;justify-content:space-between}.card-game::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg, rgba(255,255,255,0.04) 0%, transparent 60%);pointer-events:none}.game-top{display:flex;justify-content:space-between;align-items:flex-start}.game-kana{font-family:'Noto Sans JP', sans-serif;font-weight:200;font-size:28px;color:rgba(255,255,255,0.18);line-height:1}.game-tag{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.15em;text-transform:uppercase;padding:4px 8px;border-radius:4px;border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.4)}.game-name{font-size:22px;font-weight:700;color:#fff;margin-bottom:4px;line-height:1.1}.game-desc{font-size:12px;font-weight:300;color:rgba(255,255,255,0.45);line-height:1.5}.game-stripe{position:absolute;bottom:0;left:0;right:0;height:3px}.stripe-red{background:var(--accent)}.stripe-blue{background:var(--indigo)}.stripe-gold{background:var(--gold)}.card-quick{padding:20px 22px 18px;min-height:100px;display:flex;align-items:center;gap:16px}.card-quick-verbs{background:var(--indigo-light);border:1.5px solid rgba(61,59,204,0.15)}.card-quick-verbs:hover{border-color:var(--indigo)}.card-quick-kana{background:var(--accent-light);border:1.5px solid rgba(204,98,59,0.15)}.card-quick-kana:hover{border-color:var(--accent)}.card-quick-adj{background:var(--gold-light);border:1.5px solid rgba(201,146,26,0.15)}.card-quick-adj:hover{border-color:var(--gold)}.quick-kana{font-family:'Noto Sans JP', sans-serif;font-weight:200;font-size:30px;line-height:1;flex-shrink:0}.card-quick-verbs .quick-kana{color:rgba(61,59,204,0.3)}.card-quick-kana .quick-kana{color:rgba(255,98,59,0.3)}.card-quick-adj .quick-kana{color:rgba(201,146,26,0.3)}.quick-name{font-size:17px;font-weight:700;margin-bottom:3px}.card-quick-verbs .quick-name{color:var(--indigo)}.card-quick-kana .quick-name{color:var(--accent)}.card-quick-adj .quick-name{color:var(--gold)}.quick-desc{font-size:12px;font-weight:300}.card-quick-verbs .quick-desc{color:rgba(61,59,204,0.6)}.card-quick-kana .quick-desc{color:rgba(204,98,59,0.7)}.card-quick-adj .quick-desc{color:rgba(201,146,26,0.7)}.card-study{background:#fff;border:1.5px solid var(--border);padding:22px 22px 20px;min-height:90px;display:flex;align-items:flex-start;gap:14px}.card-study:hover{border-color:rgba(15,14,23,0.3)}.study-kana{font-family:'Noto Sans JP', sans-serif;font-weight:200;font-size:26px;color:rgba(15,14,23,0.12);line-height:1;flex-shrink:0;padding-top:2px}.study-name{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:2px}.study-desc{font-size:11px;font-weight:300;color:var(--ink-soft);line-height:1.5}.card-link{background:var(--cream);border:1.5px solid var(--border);border-radius:var(--r-md);padding:14px 18px;display:flex;align-items:center;gap:14px;text-decoration:none;transition:border-color 0.15s, transform 0.15s}.card-link:hover{border-color:var(--accent);transform:translateY(-1px)}.link-bullet{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;opacity:0.6}.link-body{flex:1;min-width:0}.link-name{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px}.link-host{font-family:'DM Mono', monospace;font-size:10px;font-weight:300;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-arrow{font-size:13px;color:var(--ink-soft);opacity:0.4;transition:opacity 0.15s, color 0.15s}.card-link:hover .link-arrow{opacity:1;color:var(--accent)}.no-results{display:none;text-align:center;padding:60px 20px;font-family:'DM Mono', monospace;font-size:13px;color:var(--ink-soft);opacity:0.5}.search-block{margin-bottom:40px;animation:fadeUp 0.35s ease both 0.05s}.search-block .search-input{height:48px;padding:0 48px 0 18px;font-size:15px}.search-block .search-icon{right:16px;width:17px;height:17px;opacity:0.4}.topics-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:10px;animation:fadeUp 0.4s ease both 0.12s}.topic-card{display:block;text-decoration:none;background:#fff;border:1.5px solid var(--border);border-radius:var(--r-md);padding:16px 18px 14px;transition:border-color 0.15s,transform 0.18s cubic-bezier(0.22, 0.68, 0, 1.2),box-shadow 0.18s}.topic-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,66,26,0.08)}.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}.topic-name{font-size:14px;font-weight:700;color:var(--ink);line-height:1.25;flex:1}.word-count{font-family:'DM Mono', monospace;font-size:10px;color:var(--indigo);background:var(--indigo-light);padding:3px 7px;border-radius:40px;white-space:nowrap;flex-shrink:0;letter-spacing:0.05em;transition:background 0.15s, color 0.15s}.topic-card:hover .word-count{background:var(--accent-light);color:var(--accent)}.topic-kana{font-family:'Noto Sans JP', sans-serif;font-weight:200;font-size:11px;color:var(--ink-soft);opacity:0.7;letter-spacing:0.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state{display:none;grid-column:1 / -1;text-align:center;padding:60px 20px;font-family:'DM Mono', monospace;font-size:12px;color:var(--ink-soft);opacity:0.4;letter-spacing:0.1em}.table-wrap{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;animation:fadeUp 0.4s ease both 0.12s}table{width:100%;border-collapse:collapse}thead{background:var(--cream);border-bottom:1.5px solid var(--border)}thead th{padding:11px 16px;text-align:left;font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:400}.word-row{border-bottom:1px solid var(--border);transition:background 0.12s}.word-row:last-of-type{border-bottom:none}.word-row:hover{background:var(--paper)}.word-row td{padding:12px 16px;vertical-align:middle}.td-jp{font-family:'Noto Sans JP', sans-serif;font-size:15px;line-height:1;color:var(--ink-soft);width:20%}.kana-text{display:block;font-weight:300;font-size:15px}.kanji-text{display:none;font-weight:400;font-size:15px}body.show-kanji .jp-text{display:none}body.show-kanji .kanji-text{display:block}.td-rom{font-family:'DM Mono', monospace;font-size:12px;color:var(--accent);letter-spacing:0.04em;width:20%}.td-en{font-size:14px;font-weight:500;color:var(--ink)}.td-learn{text-align:center;width:56px}.learn-tick{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%}.learn-tick.yes{background:var(--green-light);color:var(--green)}.learn-tick.yes svg{width:11px;height:11px}.learn-tick.no{visibility:hidden}.td-tip-icon{text-align:center;width:56px;position:relative}.tip-trigger{display:inline-flex;align-items:center;justify-content:center;position:relative;cursor:default}.tip-trigger svg{width:15px;height:15px}.tip-trigger.no-tip{opacity:0.15;pointer-events:none}.tip-trigger.has-tip{color:var(--gold)}.tip-overlay{display:none;position:absolute;bottom:calc(100% + 10px);right:0;width:300px;background:var(--gold-light);border:1.5px solid rgba(201,146,26,0.3);border-radius:var(--r-sm);padding:10px 14px;font-size:13px;color:var(--gold);line-height:1.55;text-align:left;z-index:20;pointer-events:none}.tip-overlay::after{content:'';position:absolute;top:100%;right:18px;border:6px solid transparent;border-top-color:rgba(201,146,26,0.3)}.tip-overlay::before{content:'';position:absolute;top:100%;right:19px;border:5px solid transparent;border-top-color:var(--gold-light);z-index:1}.tip-trigger.has-tip:hover .tip-overlay{display:block}.empty-row td{text-align:center;padding:60px 20px;font-family:'DM Mono', monospace;font-size:12px;color:var(--ink-soft);opacity:0.4;letter-spacing:0.1em}.screen{display:none}.screen.active{display:block;animation:fadeUp 0.35s ease both}.page.config-page{max-width:820px;padding-top:40px}.config-section{margin-bottom:32px}.config-label{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px;display:flex;align-items:center;gap:12px}.config-label::after{content:'';flex:1;height:1px;background:var(--border)}.topic-pills{display:flex;flex-wrap:wrap;gap:8px}.topic-pill{font-family:'DM Mono', monospace;font-size:11px;letter-spacing:0.08em;padding:7px 14px;border-radius:40px;border:1.5px solid var(--border-str);background:var(--white);color:var(--ink-soft);cursor:pointer;transition:all 0.15s;user-select:none}.topic-pill:hover{border-color:var(--ink);color:var(--ink)}.topic-pill.selected{background:var(--ink);border-color:var(--ink);color:var(--white)}.topic-pill.all-pill.selected{background:var(--indigo);border-color:var(--indigo)}.toggle-grid{display:flex;flex-wrap:wrap;gap:8px}.toggle-opt{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;padding:8px 16px;border-radius:var(--r-sm);border:1.5px solid var(--border-str);background:var(--white);color:var(--ink-soft);cursor:pointer;transition:all 0.15s;user-select:none}.toggle-opt:hover{border-color:var(--ink);color:var(--ink)}.toggle-opt.on{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.toggle-opt .tog-dot{width:8px;height:8px;border-radius:50%;background:currentColor;opacity:0.4;transition:opacity 0.15s;flex-shrink:0}.toggle-opt.on .tog-dot{opacity:1}.kana-radio-group{display:flex;gap:8px}.kana-radio{position:relative}.kana-radio input[type="radio"]{position:absolute;opacity:0;width:0;height:0}.kana-radio label{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 40px;border-radius:var(--r-md);border:1.5px solid var(--border-str);background:var(--white);cursor:pointer;transition:all 0.15s;user-select:none}.kana-radio label:hover{border-color:var(--ink)}.kana-radio input:checked+label{background:var(--accent-light);border-color:var(--accent)}.kana-radio-jp{font-family:'Noto Sans JP', sans-serif;font-size:32px;font-weight:300;line-height:1;color:var(--ink);transition:color 0.15s}.kana-radio-en{font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-soft);transition:color 0.15s}.kana-radio input:checked+label .kana-radio-jp{color:var(--accent)}.kana-radio input:checked+label .kana-radio-en{color:var(--accent)}.register-group{display:flex;gap:0}.register-group .toggle-opt{border-radius:0;border-right-width:0}.register-group .toggle-opt:first-child{border-radius:var(--r-sm) 0 0 var(--r-sm)}.register-group .toggle-opt:last-child{border-radius:0 var(--r-sm) var(--r-sm) 0;border-right-width:1.5px}.start-btn{width:100%;height:64px;background:var(--ink);color:#fff;border:none;border-radius:var(--r-md);font-family:'Bricolage Grotesque', sans-serif;font-size:18px;font-weight:800;cursor:pointer;transition:transform 0.15s, background 0.15s;margin-top:40px;letter-spacing:-0.01em}.start-btn:hover{background:#1a1928;transform:translateY(-2px)}.start-btn:active{transform:translateY(0)}.start-btn .word-count-hint{font-size:12px;font-weight:300;opacity:0.5;margin-left:10px;font-family:'DM Mono', monospace;letter-spacing:0.06em}.game-wrap{max-width:600px;margin:0 auto;padding:48px 44px 80px;display:flex;flex-direction:column;align-items:center}.game-hud{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:56px}.hud-item{display:flex;flex-direction:column;align-items:center;gap:4px}.hud-label{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft)}.hud-value{font-family:'DM Mono', monospace;font-size:22px;font-weight:400;color:var(--ink);letter-spacing:-0.01em}.hud-value.timer-running{animation:pulse 1s ease infinite}.hud-value.gold{color:var(--gold)}.hud-value.accent{color:var(--accent)}.hud-value.danger{color:var(--accent);animation:pulse 0.8s ease infinite}.hud-value.pop{animation:pop 0.2s ease both}.streak-display{display:flex;align-items:center;gap:6px;font-family:'DM Mono', monospace;font-size:22px;color:var(--ink-soft)}.streak-display.hot{color:var(--accent)}.streak-flames{font-size:18px;letter-spacing:-2px}.progress-track{width:100%;height:3px;background:var(--border);border-radius:2px;margin-bottom:56px;overflow:hidden}.progress-fill{height:100%;background:var(--ink);border-radius:2px;transition:width 0.3s ease}.time-pills{display:flex;gap:8px}.time-pill{font-family:'DM Mono', monospace;font-size:11px;letter-spacing:0.08em;padding:8px 24px;border-radius:var(--r-sm);border:1.5px solid var(--border-str);background:var(--white);color:var(--ink-soft);cursor:pointer;transition:all 0.15s;user-select:none}.time-pill:hover{border-color:var(--ink);color:var(--ink)}.time-pill.selected{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.timer-track{width:100%;height:4px;background:var(--border);border-radius:2px;margin-bottom:52px;overflow:hidden}.timer-fill{height:100%;background:var(--ink);border-radius:2px;width:100%;transition:width 1s linear, background 0.3s}.timer-fill.danger{background:var(--accent)}.word-area{text-align:center;margin-bottom:40px;width:100%;min-height:120px}.word-display{font-family:'Noto Sans JP', sans-serif;font-size:64px;font-weight:300;color:var(--ink);line-height:1.1;display:flex;align-items:center;justify-content:center}.word-display.english-word{font-family:'Bricolage Grotesque', sans-serif;font-size:42px;font-weight:700}.word-translation{font-family:'DM Mono', monospace;font-size:14px;letter-spacing:0.08em;color:var(--green);min-height:22px;opacity:0;pointer-events:none}.word-translation.visible{animation:transReveal 0.2s ease both;opacity:1}.word-hint{margin-top:20px;font-family:'DM Mono', monospace;font-size:20px;color:var(--ink);opacity:0;transition:opacity 0.3s;min-height:20px}.word-hint.visible{opacity:1}.word-correct-answer{font-family:'DM Mono',monospace;font-size:14px;letter-spacing:0.1em;color:var(--accent);min-height:22px;opacity:0;pointer-events:none}.word-correct-answer.visible{animation:revealUp 0.15s ease both;opacity:1}.verb-area{text-align:center;margin-bottom:36px;width:100%}.verb-display{font-family:'Bricolage Grotesque', sans-serif;font-size:72px;font-weight:700;color:var(--ink);line-height:1.05;margin-bottom:18px;min-height:90px;display:flex;align-items:center;justify-content:center;letter-spacing:-0.02em}.form-badge-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}.form-badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:40px;font-family:'DM Mono', monospace;font-size:12px;letter-spacing:0.08em;font-weight:400;border:1.5px solid}.badge-nai{background:#fde8e2;border-color:rgba(232,66,26,0.25);color:#c0310e}.badge-pastneg{background:#fbd5cc;border-color:rgba(192,49,14,0.3);color:#922409}.badge-te{background:#ececfa;border-color:rgba(61,59,204,0.25);color:#3d3bcc}.badge-progressive{background:#d8d7f5;border-color:rgba(45,43,180,0.3);color:#2a28a0}.badge-past{background:#e8e7f0;border-color:rgba(80,78,110,0.2);color:#504e6e}.badge-imperative{background:#d5d4e4;border-color:rgba(60,58,95,0.25);color:#3c3a5f}.badge-volitional{background:#e4f5ec;border-color:rgba(26,122,74,0.25);color:#1a7a4a}.badge-potential{background:#f0ecfa;border-color:rgba(110,70,200,0.2);color:#6e46c8}.badge-passive{background:#e2d8f5;border-color:rgba(90,50,180,0.25);color:#5232b4}.badge-causative{background:#e1f5ee;border-color:rgba(15,110,86,0.2);color:#0f6e56}.badge-conditional{background:#fef0e0;border-color:rgba(210,120,20,0.25);color:#c07010}.badge-provisional{background:#fde3c0;border-color:rgba(190,100,10,0.3);color:#a05e08}.badge-masu{background:#fdf3e0;border-color:rgba(201,146,26,0.25);color:#c9921a}.badge-register{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.18em;text-transform:uppercase;font-weight:400}.badge-register.reg-plain{color:var(--ink-soft)}.badge-register.reg-polite{color:var(--gold);font-weight:500}.verb-hint{font-family:'DM Mono', monospace;font-size:12px;color:var(--ink-soft);opacity:0;transition:opacity 0.3s;letter-spacing:0.04em;min-height:20px;margin-top:14px;text-align:center}.verb-hint.visible{opacity:0.7}.input-wrap{width:100%;position:relative;margin-bottom:20px}.answer-input{width:100%;height:60px;border:2px solid var(--border-str);border-radius:var(--r-md);background:var(--white);font-family:'Bricolage Grotesque', sans-serif;font-size:20px;font-weight:500;color:var(--ink);text-align:center;outline:none;transition:border-color 0.15s, background 0.15s}.answer-input:focus{border-color:var(--ink)}.answer-input:disabled{opacity:0.5;cursor:not-allowed}.answer-input.flash-fast{border-color:var(--green);background:var(--green-light)}.answer-input.flash-ok{border-color:var(--indigo);background:var(--indigo-light)}.answer-input.flash-slow{border-color:var(--gold);background:var(--gold-light)}.answer-input.flash-correct{border-color:var(--green);background:var(--green-light);animation:pop 0.25s ease}.answer-input.flash-wrong{border-color:var(--accent);background:var(--accent-light)}.skip-row{display:flex;align-items:center;justify-content:center;gap:10px}.skip-btn{font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-soft);background:none;border:1.5px solid var(--border-str);border-radius:40px;padding:7px 18px;cursor:pointer;transition:all 0.15s}.skip-btn:hover{border-color:var(--ink);color:var(--ink)}.skip-btn.reveal-state{border-color:var(--accent);color:var(--accent)}.kbd-hint{font-family:'DM Mono', monospace;font-size:10px;color:var(--ink-soft);opacity:0.35;letter-spacing:0.08em}.skip-btn:disabled{opacity:0.35;cursor:not-allowed}.skip-btn.next-word-state{background:var(--ink);color:#fff;border-color:var(--ink);font-size:12px;padding:9px 24px;animation:pulse 1s ease infinite}.skip-btn.next-word-state:hover{background:#1a1928;animation:none}.end-overlay{display:none;position:fixed;inset:0;background:rgba(15,14,23,0.6);z-index:100;align-items:center;justify-content:center}.end-overlay.active{display:flex;animation:fadeIn 0.25s ease both}.end-card{background:var(--paper);border-radius:var(--r-lg);padding:40px;width:min(580px, calc(100vw - 40px));max-height:85vh;overflow-y:auto;animation:fadeUp 0.3s ease both}.end-title{font-size:32px;font-weight:800;color:var(--ink);letter-spacing:-0.02em;margin-bottom:6px}.end-subtitle{font-family:'DM Mono', monospace;font-size:12px;color:var(--ink-soft);letter-spacing:0.1em;margin-bottom:32px}.best-badge{display:inline-flex;align-items:center;gap:5px;font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);background:var(--gold-light);border:1px solid var(--gold);border-radius:40px;padding:3px 10px;margin-bottom:28px}.best-badge svg{width:10px;height:10px}.end-stats{display:grid;grid-template-columns:repeat(3, 1fr);gap:10px;margin-bottom:28px}.end-stat{background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-md);padding:16px;text-align:center}.end-stat-value{font-family:'DM Mono', monospace;font-size:28px;font-weight:400;color:var(--ink);margin-bottom:4px}.end-stat-value.accent{color:var(--accent)}.end-stat-value.green{color:var(--green)}.end-stat-value.gold{color:var(--gold)}.end-stat-label{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-soft)}.end-section-label{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px;display:flex;align-items:center;gap:12px}.end-section-label::after{content:'';flex:1;height:1px;background:var(--border)}.skipped-list{margin-bottom:28px;display:flex;flex-direction:column;gap:6px}.skipped-item{display:flex;align-items:center;justify-content:space-between;background:var(--accent-light);border-radius:var(--r-sm);padding:10px 14px}.skipped-jp{font-family:'Noto Sans JP', sans-serif;font-size:18px;font-weight:300;color:var(--ink)}.skipped-en{font-size:13px;font-weight:500;color:var(--ink-soft)}.missed-list{margin-bottom:28px;display:flex;flex-direction:column;gap:6px}.missed-item{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;background:var(--accent-light);border-radius:var(--r-sm);padding:10px 14px}.missed-verb{font-family:'DM Mono', monospace;font-size:15px;font-weight:400;color:var(--ink)}.missed-form{font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.08em;color:var(--ink-soft);text-align:center;padding:4px 10px;background:rgba(15,14,23,0.06);border-radius:20px}.missed-answer{font-family:'DM Mono', monospace;font-size:13px;font-weight:400;color:var(--accent);text-align:right}.missed-romaji{font-family:'DM Mono', monospace;font-size:12px;color:var(--accent);letter-spacing:0.06em}.missed-jp{font-family:'Noto Sans JP', sans-serif;font-size:20px;font-weight:300;color:var(--ink)}.missed-en{justify-self:flex-end;padding-right:10px;font-family:"Bricolage Grotesque";font-size:14px;color:#000}.weak-section{margin-bottom:28px}.weak-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.weak-item{display:flex;align-items:center;justify-content:space-between;background:var(--accent-light);border-radius:var(--r-sm);padding:12px 16px}.weak-item-left{display:flex;align-items:center;gap:14px}.weak-jp{font-family:'Noto Sans JP',sans-serif;font-size:28px;font-weight:300;color:var(--ink);letter-spacing:-2px}.weak-romaji{font-family:'DM Mono',monospace;font-size:13px;color:var(--ink-soft);letter-spacing:0.08em}.weak-counts{display:flex;gap:10px;align-items:center}.weak-badge{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.1em;text-transform:uppercase;padding:3px 10px;border-radius:40px;border:1px solid}.weak-badge.wrong{color:var(--accent);background:rgba(232,66,26,0.08);border-color:rgba(232,66,26,0.3)}.weak-badge.skip{color:var(--gold);background:rgba(201,146,26,0.08);border-color:rgba(201,146,26,0.3)}.end-actions{display:flex;gap:10px}.end-btn{flex:1;height:52px;border-radius:var(--r-md);border:1.5px solid var(--border-str);background:var(--white);font-family:'Bricolage Grotesque', sans-serif;font-size:15px;font-weight:700;color:var(--ink);cursor:pointer;transition:all 0.15s}.end-btn:hover{border-color:var(--ink)}.end-btn.primary{background:var(--ink);color:var(--white);border-color:var(--ink)}.end-btn.primary:hover{background:#1a1928}@media (max-width: 1365px){.topics-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}}@media (max-width: 767px){.page{padding:0 20px 80px}.hero-row{flex-direction:column;align-items:flex-start;gap:32px}.search-col{width:100%}.games-grid{grid-template-columns:1fr}.tools-grid{grid-template-columns:1fr}.links-grid{grid-template-columns:1fr}.topics-grid{grid-template-columns:1fr}header.inner{height:110px}.btn-icon{width:40px;height:40px;left:20px}.btn-icon+.btn-icon{left:72px}.btn-icon.edit{left:auto;right:20px}.td-rom{display:none}.game-wrap{padding:32px 20px 60px}.word-display{font-size:48px}.verb-display{font-size:48px}.end-stats{grid-template-columns:repeat(2, 1fr)}.topic-pills{gap:6px}.missed-item{grid-template-columns:1fr 1fr}.missed-form{display:none}}.top-row{display:grid;grid-template-columns:1fr auto;gap:12px;margin-bottom:44px;animation:fadeUp 0.35s ease both 0.05s}.last-visited{display:block;text-decoration:none;background:var(--ink);border-radius:var(--r-lg);padding:20px 24px;position:relative;overflow:hidden;transition:transform 0.18s cubic-bezier(0.22, 0.68, 0, 1.2)}.last-visited:hover{transform:translateY(-2px)}.last-visited::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg, rgba(255,255,255,0.04) 0%, transparent 60%);pointer-events:none}.lv-label{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:6px}.lv-title{font-size:18px;font-weight:800;color:#fff;letter-spacing:-0.01em;margin-bottom:4px}.lv-tier{font-family:'DM Mono', monospace;font-size:10px;color:rgba(255,255,255,0.35);letter-spacing:0.08em}.lv-arrow{position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:20px;color:rgba(255,255,255,0.2);transition:color 0.15s, right 0.15s}.last-visited:hover .lv-arrow{color:rgba(255,255,255,0.6);right:18px}.lv-none{font-size:13px;font-weight:400;color:rgba(255,255,255,0.3);font-style:italic}.random-btn{background:var(--accent-light);border:1.5px solid rgba(232,66,26,0.2);border-radius:var(--r-lg);padding:20px 28px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all 0.18s cubic-bezier(0.22, 0.68, 0, 1.2);text-decoration:none;min-width:140px}.random-btn:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px)}.random-btn:hover .rb-label{color:rgba(255,255,255,0.7)}.random-btn:hover .rb-icon{color:#fff}.rb-icon{color:var(--accent);transition:color 0.15s}.rb-icon svg{width:22px;height:22px}.rb-label{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);transition:color 0.15s}.tier-block{margin-bottom:36px;animation:fadeUp 0.4s ease both}.tier-block:nth-child(2){animation-delay:0.08s}.tier-block:nth-child(3){animation-delay:0.13s}.tier-block:nth-child(4){animation-delay:0.18s}.tier-block:nth-child(5){animation-delay:0.23s}.tier-block:nth-child(6){animation-delay:0.28s}.tier-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.tier-num{font-family:'DM Mono', monospace;font-size:10px;font-weight:400;color:var(--white);background:var(--ink);padding:3px 9px;border-radius:3px;letter-spacing:0.08em;flex-shrink:0}.tier-name{font-size:13px;font-weight:700;color:var(--ink);letter-spacing:-0.01em}.tier-desc{font-size:12px;font-weight:300;color:var(--ink-soft);margin-left:4px}.tier-line{flex:1;height:1px;background:var(--border)}.cards-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:8px}.fc-card{display:block;text-decoration:none;background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-md);padding:16px 18px 14px;position:relative;transition:border-color 0.15s,transform 0.18s cubic-bezier(0.22, 0.68, 0, 1.2),box-shadow 0.18s}.fc-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px rgba(61,59,204,0.08)}.fc-card.last-open{border-color:rgba(232,66,26,0.3)}.fc-title{font-size:14px;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:6px}.fc-meta{font-family:'DM Mono', monospace;font-size:11px;color:var(--indigo);letter-spacing:0em;opacity:0.7}.fc-dot{position:absolute;top:14px;right:14px;width:6px;height:6px;border-radius:50%;background:var(--accent)}@keyframes shake{0%{transform:translateX(0)}15%{transform:translateX(-8px)}35%{transform:translateX(7px)}55%{transform:translateX(-5px)}75%{transform:translateX(4px)}90%{transform:translateX(-2px)}100%{transform:translateX(0)}}.answer-input.flash-wrong{border-color:var(--accent);background:var(--accent-light);animation:shake 0.45s ease both}.errors-list{margin-bottom:28px;display:flex;flex-direction:column;gap:6px}.error-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 14px}.error-label{font-family:'DM Mono', monospace;font-size:11px;color:var(--ink-soft);letter-spacing:0.06em}.error-label strong{color:var(--ink);font-weight:500}.error-bar-wrap{display:flex;align-items:center;gap:10px}.error-bar-track{width:80px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.error-bar-fill{height:100%;background:var(--accent);border-radius:2px}.error-count{font-family:'DM Mono', monospace;font-size:13px;font-weight:400;color:var(--accent);min-width:16px;text-align:right}@media (max-width: 767px){.top-row{grid-template-columns:1fr}.random-btn{flex-direction:row;min-width:unset;padding:16px 20px}.cards-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}}:root{--ink-faint:rgba(15,14,23,0.07)}@keyframes cardIn{from{opacity:0;transform:translateY(16px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}header.inner.sticky{position:sticky;top:0;margin-bottom:0}.progress-wrap{position:relative;z-index:99;background:var(--cream);height:3px}.progress-bar{height:100%;background:var(--accent);transition:width 0.35s cubic-bezier(0.22, 0.68, 0, 1.2)}.pill-nav-wrap{display:flex;justify-content:center;padding:24px 40px 0;overflow-x:auto;scrollbar-width:none;gap:8px}.pill-nav-wrap::-webkit-scrollbar{display:none}.pill{font-family:'DM Mono', monospace;font-size:11px;padding:6px 14px;border-radius:40px;border:1.5px solid var(--border-str);background:transparent;color:var(--ink-soft);cursor:pointer;white-space:nowrap;transition:all 0.15s;flex-shrink:0}.pill:hover{border-color:var(--ink);color:var(--ink)}.pill.active{background:var(--ink);border-color:var(--ink);color:#fff}.stage{display:flex;justify-content:center;align-items:flex-start;padding:32px 40px 20px;position:relative}.stage::before,.stage::before{height:20px;bottom:26px;transform:scaleX(0.94);opacity:0.55}.stage::after{height:20px;bottom:14px;transform:scaleX(0.97);opacity:0.3}.flashcard{width:min(680px, 100%);background:var(--white);border-radius:var(--r-lg);border:1.5px solid var(--border);overflow:hidden;position:relative;animation:cardIn 0.28s cubic-bezier(0.22, 0.68, 0, 1.2) both}.card-head{display:flex;align-items:center;padding:0 22px;height:46px;border-bottom:1.5px solid var(--ink-faint);gap:10px}.card-type{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;padding:4px 10px;border-radius:4px;font-weight:400;background:var(--accent);color:#fff}.card-counter{margin-left:auto;font-family:'DM Mono', monospace;font-size:10px;color:var(--ink-soft);opacity:0.5;letter-spacing:0.08em}.card-body{padding:28px 28px 0;text-align:center}.card-main-title{font-size:30px;font-weight:800;color:var(--ink);letter-spacing:-0.02em;line-height:1.1;margin-bottom:12px}.card-under-title{display:inline-block;font-family:'DM Mono', monospace;font-size:11px;letter-spacing:0.06em;padding:5px 14px;border-radius:40px;margin-bottom:28px}.card-description{text-align:left;padding:0 0 28px;font-size:14px;line-height:1.7;color:var(--ink)}.card-description p{margin-bottom:12px}.card-description p:last-child{margin-bottom:0}.card-description strong{font-weight:700}.card-description h2{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;margin:20px 0 10px;font-weight:400;color:var(--ink-soft)}.card-description table{width:100%;border-collapse:collapse;font-size:13px;margin:14px 0;border-radius:var(--r-sm);overflow:hidden;border:1.5px solid var(--border)}.card-description thead{background:var(--cream);border-bottom:1.5px solid var(--border)}.card-description thead th{padding:9px 12px;text-align:left;font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:400}.card-description tbody tr{border-top:1px solid var(--border)}.card-description tbody tr:first-child{border-top:none}.card-description tbody tr:hover{background:var(--paper)}.card-description td{padding:9px 12px;vertical-align:middle;line-height:1.5}.card-description td:first-child{font-weight:600;color:var(--ink)}.card-description .rom{font-family:'DM Mono', monospace;font-size:12px;color:var(--accent)}.card-description .hi{font-weight:700;color:var(--accent)}.card-tips{background:var(--gold-light);border-top:1.5px solid rgba(201,146,26,0.15);padding:16px 22px;display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.65;color:var(--ink)}.tips-icon{flex-shrink:0;width:16px;height:16px;margin-top:2px;color:var(--gold)}.card-tips p{margin-bottom:6px}.card-tips p:last-child{margin-bottom:0}.card-examples{background:var(--accent-light);border-top:1.5px solid rgba(61,59,204,0.1);padding:16px 22px;display:flex;gap:12px;align-items:flex-start;font-size:13px;line-height:1.65;color:var(--ink)}.example-icon{flex-shrink:0;width:16px;height:16px;margin-top:2px;color:var(--accent)}.card-examples p{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #e7d2cb}.card-examples p:last-child{margin-bottom:0;border-bottom:0}.card-nav{display:flex;align-items:center;justify-content:center;gap:20px;padding:28px 40px 16px}.nav-btn{width:52px;height:52px;border-radius:50%;border:1.5px solid var(--border-str);background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.15s;color:var(--ink);flex-shrink:0}.nav-btn svg{width:18px;height:18px}.nav-btn:hover:not(:disabled){border-color:var(--ink);background:var(--ink);color:#fff}.nav-btn:disabled{opacity:0.2;cursor:default}.nav-dots{display:flex;gap:6px;align-items:center}.nav-dot{width:6px;height:6px;border-radius:50%;background:var(--border-str);cursor:pointer;transition:all 0.2s;border:none;padding:0;flex-shrink:0}.nav-dot.active{background:var(--ink-soft);width:20px;border-radius:3px}.nav-dot:hover:not(.active){background:var(--ink-soft)}.kbd-hint{text-align:center;font-family:'DM Mono', monospace;font-size:10px;color:var(--ink-soft);opacity:0.4;letter-spacing:0.1em}.kbd{display:inline-block;border:1px solid var(--border-str);border-radius:4px;padding:1px 6px;font-family:'DM Mono', monospace;font-size:10px;color:var(--ink-soft);background:var(--cream)}@media (max-width: 767px){.progress-wrap{top:110px}.stage{padding:24px 20px 20px}.stage::before,.stage::after{width:calc(100% - 40px)}.pill-nav-wrap{padding:20px 20px 0;justify-content:flex-start}.card-nav{padding:20px 20px 12px}.card-main-title{font-size:24px}}.conj-backdrop{position:fixed;inset:0;background:rgba(15,14,23,0.45);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;pointer-events:none;transition:opacity 0.22s ease}.conj-backdrop.open{opacity:1;pointer-events:all}.conj-modal{background:var(--paper);width:100%;max-width:720px;max-height:82vh;border-radius:var(--r-lg);display:flex;flex-direction:column;transform:translateY(24px);transition:transform 0.28s cubic-bezier(0.22, 0.68, 0, 1.2);overflow:hidden}.conj-backdrop.open .conj-modal{transform:translateY(0)}.conj-modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 28px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.conj-verb-info{display:flex;align-items:center;gap:12px}.conj-verb-title{font-size:26px;font-weight:800;letter-spacing:-0.02em;color:var(--ink)}.conj-verb-badge{font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;padding:4px 9px;border-radius:5px;border:1.5px solid;font-weight:400}.conj-verb-exception{font-family:"DM MONO";font-size:10px;color:var(--green);background:var(--green-light);padding:4px 10px;border:1px solid var(--green);border-radius:20px}.conj-verb-badge.badge-g1{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.conj-verb-badge.badge-g2{color:var(--indigo);border-color:var(--indigo);background:var(--indigo-light)}.conj-verb-badge.badge-g3{color:var(--gold);border-color:var(--gold);background:var(--gold-light)}.conj-close-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);flex-shrink:0;transition:border-color 0.15s, color 0.15s}.conj-close-btn svg{width:14px;height:14px}.conj-close-btn:hover{border-color:var(--accent);color:var(--accent)}.conj-modal-body{overflow-y:auto;padding:0 28px 28px;flex:1}.conj-error{margin:16px 0 0;background:var(--accent-light);border:1.5px solid var(--accent);border-radius:var(--r-sm);padding:12px 16px;font-size:13px;color:var(--accent)}.conj-table{width:100%;border-collapse:collapse;font-size:14px;margin-top:6px}.conj-table th{font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft);padding:14px 12px 10px;text-align:left;font-weight:400;position:sticky;top:0;background:var(--paper)}.conj-table th:nth-child(2){text-align:center}.conj-table th:nth-child(3){text-align:center}.conj-table td{padding:10px 12px;border-top:1px solid var(--border);vertical-align:middle}.conj-table tr.sec-divider td{border-top:none;padding-top:20px;padding-bottom:4px}.conj-table tr.sec-divider span{font-family:'DM Mono', monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-soft);opacity:0.45}.conj-table td:first-child{font-family:'DM Mono', monospace;font-size:11px;letter-spacing:0.06em;color:var(--ink);width:190px}.conj-table td:not(:first-child){font-family:'DM Mono', monospace;font-size:12px;text-align:center}.conj-table.grp-1 .cell-plain{color:var(--accent)}.conj-table.grp-1 .cell-polite{color:rgba(232,66,26,0.65)}.conj-table.grp-2 .cell-plain{color:var(--indigo)}.conj-table.grp-2 .cell-polite{color:rgba(61,59,204,0.65)}.conj-table.grp-3 .cell-plain{color:var(--gold)}.conj-table.grp-3 .cell-polite{color:rgba(201,146,26,0.65)}.cell-same{color:var(--ink-soft);font-style:italic;font-size:11px}.conj-legend{display:flex;gap:20px;padding:16px 0 0;margin-top:10px;border-top:1px solid var(--border)}.conj-legend-item{display:flex;align-items:center;gap:6px;font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.1em;color:var(--ink-soft);text-transform:uppercase}.conj-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.supersearch-trigger{display:flex;align-items:center;gap:9px;height:36px;padding:0 14px 0 11px;background:var(--accent);border:1.5px solid var(--accent);border-radius:var(--r-sm);cursor:pointer;font-family:'DM Mono', monospace;color:var(--white);font-size:11px;letter-spacing:0.04em;transition:border-color 0.15s, background 0.15s;white-space:nowrap}.supersearch-trigger:hover{border-color:var(--ink);background:var(--ink)}.supersearch-trigger svg{flex-shrink:0;width:14px;height:14px;opacity:0.45}.supersearch-trigger-text{flex:1;font-size:13px}.supersearch-kbd{flex-shrink:0;font-size:10px;font-family:'DM Mono', monospace;background:var(--white);border:1px solid var(--border-str);border-radius:4px;padding:1px 6px;color:var(--ink-soft);opacity:0.6;letter-spacing:0.02em}@media (max-width: 767px){.supersearch-trigger-text{display:none}.supersearch-kbd{display:none}.supersearch-trigger{padding:0 11px;gap:0}.supersearch-trigger svg{opacity:0.6}}.ss-backdrop{position:fixed;inset:0;background:rgba(15,14,23,0.45);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:60px 16px 16px;opacity:0;pointer-events:none;transition:opacity 0.18s ease}.ss-backdrop.open{opacity:1;pointer-events:all}.ss-modal{background:var(--paper);border-radius:var(--r-lg);width:100%;max-width:660px;max-height:calc(100vh - 100px);display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(15,14,23,0.22),0 2px 8px rgba(15,14,23,0.08);transform:translateY(-12px);transition:transform 0.18s ease;overflow:hidden}.ss-backdrop.open .ss-modal{transform:translateY(0)}.ss-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.ss-input-wrap{flex:1;position:relative;display:flex;align-items:center}.ss-input-icon{position:absolute;left:11px;width:15px;height:15px;opacity:0.35;pointer-events:none;color:var(--ink-soft)}.ss-input{width:100%;padding:9px 36px 9px 36px;border:1.5px solid var(--border-str);border-radius:var(--r-sm);outline:none;background:var(--cream);font-family:'Bricolage Grotesque', sans-serif;font-size:15px;color:var(--ink);transition:border-color 0.15s, background 0.15s}.ss-input:focus{border-color:var(--accent);background:var(--white)}.ss-input::placeholder{color:var(--ink-soft);opacity:0.5}.ss-clear-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;padding:4px;color:var(--ink-soft);display:flex;align-items:center;border-radius:4px;opacity:0.5;transition:opacity 0.12s}.ss-clear-btn:hover{opacity:1}.ss-clear-btn svg{width:13px;height:13px}.ss-close-btn{background:none;border:1.5px solid var(--border-str);border-radius:var(--r-sm);cursor:pointer;padding:5px 10px;font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-soft);flex-shrink:0;transition:border-color 0.12s, color 0.12s}.ss-close-btn:hover{border-color:var(--ink);color:var(--ink)}.ss-filters{display:flex;gap:6px;padding:10px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.ss-filter{background:none;border:1.5px solid var(--border-str);border-radius:40px;padding:4px 13px;font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-soft);cursor:pointer;transition:all 0.12s}.ss-filter:hover{border-color:var(--ink);color:var(--ink)}.ss-filter.active{background:var(--ink);border-color:var(--ink);color:var(--white)}.ss-body{flex:1;overflow-y:auto;min-height:200px}.ss-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 24px;text-align:center}.ss-state-icon{font-family:'Noto Sans JP', sans-serif;font-size:2rem;font-weight:200;color:var(--ink-soft);opacity:0.15}.ss-state-text{font-family:'DM Mono', monospace;font-size:11px;letter-spacing:0.1em;color:var(--ink-soft);opacity:0.5}.ss-results{padding:6px 0}.ss-group-label{font-family:'DM Mono', monospace;font-size:9px;font-weight:400;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-soft);opacity:0.5;padding:10px 16px 4px}.ss-item{display:flex;align-items:center;gap:12px;padding:9px 16px;cursor:pointer;text-decoration:none;color:inherit;transition:background 0.1s;outline:none}.ss-item:hover,.ss-item.focused{background:var(--cream)}.ss-item-badge{flex-shrink:0;width:2px;height:28px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:'Noto Sans JP', sans-serif;font-size:0;font-weight:300}.ss-badge-vocab{background:var(--gold)}.ss-badge-flash{background:var(--indigo)}.ss-item-main{flex:1;min-width:0}.ss-item-title{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-item-title mark{background:var(--accent-light);color:var(--accent);border-radius:2px;padding:0 1px;font-style:normal}.ss-item-sub{font-family:'DM Mono', monospace;font-size:11px;letter-spacing:0.02em;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;opacity:0.7}.ss-item-sub.gold{color:var(--gold)}.ss-item-sub.indigo{color:var(--indigo)}.ss-item-sub mark{background:var(--accent-light);color:var(--accent);border-radius:2px;padding:0 1px;font-style:normal}.ss-item-arrow{font-size:12px;color:var(--ink-soft);opacity:0.2;align-self:center;flex-shrink:0;transition:opacity 0.12s}.ss-item:hover .ss-item-arrow,.ss-item.focused .ss-item-arrow{opacity:0.6}.ss-footer{display:flex;align-items:center;gap:14px;padding:9px 16px;border-top:1px solid var(--border);flex-shrink:0}.ss-hint{font-family:'DM Mono', monospace;font-size:10px;color:var(--ink-soft);opacity:0.5;display:flex;align-items:center;gap:4px}.ss-hint kbd{font-family:'DM Mono', monospace;font-size:10px;background:var(--cream);border:1px solid var(--border-str);border-radius:4px;padding:1px 5px;color:var(--ink-soft)}.ss-status{margin-left:auto;font-family:'DM Mono', monospace;font-size:10px;letter-spacing:0.08em;color:var(--ink-soft);opacity:0.4}.ss-spinner{display:flex;align-items:center;justify-content:center;padding:48px}.ss-spinner::after{content:'';width:20px;height:20px;border:2px solid var(--border-str);border-top-color:var(--accent);border-radius:50%;animation:ss-spin 0.7s linear infinite}@keyframes ss-spin{to{transform:rotate(360deg)}}@media (max-width: 600px){.ss-backdrop{padding:0;align-items:flex-end}.ss-modal{max-height:92vh;border-radius:var(--r-lg) var(--r-lg) 0 0}.ss-hint{display:none}}.config-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px;flex-wrap:wrap;gap:12px}.kana-tabs{display:flex;background:var(--white);border:1.5px solid var(--border-str);border-radius:var(--r-md);overflow:hidden;width:fit-content}.kana-tab{font-family:'Bricolage Grotesque',sans-serif;font-size:15px;font-weight:700;padding:11px 32px;border:none;background:none;cursor:pointer;color:var(--ink-soft);transition:all 0.15s;display:flex;align-items:center;gap:8px}.kana-tab .tab-jp{font-family:'Noto Sans JP',sans-serif;font-size:20px;font-weight:300}.kana-tab.active{background:var(--ink);color:#fff}.kana-tab.active .tab-jp{color:#fff}.mode-toggle{display:flex;background:var(--white);border:1.5px solid var(--border-str);border-radius:var(--r-md);overflow:hidden}.mode-btn{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;padding:10px 20px;border:none;background:none;cursor:pointer;color:var(--ink-soft);transition:all 0.15s;white-space:nowrap}.mode-btn.active{background:var(--ink);color:#fff}.row-grid{display:flex;flex-direction:column;gap:4px;margin-bottom:28px}.row-group-gap{height:8px}.config-page[data-kana="hiragana"] .kana-row.prior{border-color:var(--accent);background:var(--accent-light)}.config-page[data-kana="hiragana"] .kana-row.selected{border-color:var(--accent);background:var(--accent)}.config-page[data-kana="hiragana"] .kana-row.prior .row-label{color:rgba(232,66,26,0.7);border-color:rgba(232,66,26,0.2)}.config-page[data-kana="hiragana"] .kana-row.selected .row-label{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.config-page[data-kana="hiragana"] .kana-row.prior .row-char{color:var(--accent)}.config-page[data-kana="hiragana"] .kana-row.selected .row-char{color:#fff}.config-page[data-kana="hiragana"] .kana-row.prior .row-char-ro{color:rgba(232,66,26,0.6)}.config-page[data-kana="hiragana"] .kana-row.selected .row-char-ro{color:rgba(255,255,255,0.45)}.config-page[data-kana="hiragana"] .kana-row.prior .row-char-unit{border-color:rgba(232,66,26,0.12)}.config-page[data-kana="hiragana"] .kana-row.selected .row-char-unit{border-color:rgba(255,255,255,0.1)}.config-page[data-kana="hiragana"] .kana-row.prior .row-count-badge{color:rgba(232,66,26,0.7);border-color:rgba(232,66,26,0.2)}.config-page[data-kana="hiragana"] .kana-row.selected .row-count-badge{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.config-page[data-kana="hiragana"] .kana-row.custom-selected{border-color:var(--accent);background:var(--accent)}.config-page[data-kana="hiragana"] .kana-row.custom-selected .row-label{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.config-page[data-kana="hiragana"] .kana-row.custom-selected .row-char{color:#fff}.config-page[data-kana="hiragana"] .kana-row.custom-selected .row-char-ro{color:rgba(255,255,255,0.45)}.config-page[data-kana="hiragana"] .kana-row.custom-selected .row-char-unit{border-color:rgba(255,255,255,0.1)}.config-page[data-kana="hiragana"] .kana-row.custom-selected .row-count-badge{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.config-page[data-kana="katakana"] .kana-row.prior{border-color:var(--indigo);background:var(--indigo-light)}.config-page[data-kana="katakana"] .kana-row.selected{border-color:var(--indigo);background:var(--indigo)}.config-page[data-kana="katakana"] .kana-row.prior .row-label{color:rgba(61,59,204,0.7);border-color:rgba(61,59,204,0.2)}.config-page[data-kana="katakana"] .kana-row.selected .row-label{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.config-page[data-kana="katakana"] .kana-row.prior .row-char{color:var(--indigo)}.config-page[data-kana="katakana"] .kana-row.selected .row-char{color:#fff}.config-page[data-kana="katakana"] .kana-row.prior .row-char-ro{color:rgba(61,59,204,0.6)}.config-page[data-kana="katakana"] .kana-row.selected .row-char-ro{color:rgba(255,255,255,0.45)}.config-page[data-kana="katakana"] .kana-row.prior .row-char-unit{border-color:rgba(61,59,204,0.12)}.config-page[data-kana="katakana"] .kana-row.selected .row-char-unit{border-color:rgba(255,255,255,0.1)}.config-page[data-kana="katakana"] .kana-row.prior .row-count-badge{color:rgba(61,59,204,0.7);border-color:rgba(61,59,204,0.2)}.config-page[data-kana="katakana"] .kana-row.selected .row-count-badge{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.config-page[data-kana="katakana"] .kana-row.custom-selected{border-color:var(--indigo);background:var(--indigo)}.config-page[data-kana="katakana"] .kana-row.custom-selected .row-label{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.config-page[data-kana="katakana"] .kana-row.custom-selected .row-char{color:#fff}.config-page[data-kana="katakana"] .kana-row.custom-selected .row-char-ro{color:rgba(255,255,255,0.45)}.config-page[data-kana="katakana"] .kana-row.custom-selected .row-char-unit{border-color:rgba(255,255,255,0.1)}.config-page[data-kana="katakana"] .kana-row.custom-selected .row-count-badge{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.15)}.kana-row{display:flex;align-items:stretch;border:1.5px solid var(--border-str);border-radius:var(--r-sm);background:var(--white);overflow:hidden;cursor:pointer;transition:border-color 0.15s, background 0.15s}.kana-row:hover:not(.prior):not(.selected):not(.custom-selected){border-color:var(--ink-soft)}.kana-row.derived .row-label{font-style:italic}.row-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-soft);padding:0 12px;min-width:44px;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border);flex-shrink:0;transition:color 0.15s, border-color 0.15s}.row-chars{display:flex;align-items:center;padding:8px 14px;flex:1;transition:transform 0.15s}.kana-row.selected .row-chars,.kana-row.custom-selected .row-chars{transform:scale(1.02)}.row-char-unit{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 30px;border-right:1px solid var(--border)}.row-char-unit:last-child{border-right:none}.row-char{font-family:'Noto Sans JP',sans-serif;font-size:24px;font-weight:300;color:var(--ink);line-height:1;transition:color 0.15s}.row-char.combo{font-size:18px;letter-spacing:-1px}.row-char-ro{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.06em;color:var(--ink-soft);transition:color 0.15s}.row-count-badge{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.08em;color:var(--ink-soft);padding:0 14px;display:flex;align-items:center;white-space:nowrap;flex-shrink:0;border-left:1px solid var(--border);transition:color 0.15s, border-color 0.15s}.learn-btn-wrap{position:relative;margin-bottom:0}.learn-btn-wrap.sticky{position:sticky;bottom:0;padding:16px 0 24px;background:linear-gradient(to bottom, transparent 0%, var(--paper) 30%);z-index:10}.learn-btn{width:100%;height:72px;background:var(--ink);color:#fff;border:none;border-radius:var(--r-md);font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:800;cursor:pointer;transition:transform 0.15s, background 0.15s;letter-spacing:-0.01em;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}.learn-btn:hover:not(:disabled){background:#1a1928;transform:translateY(-2px)}.learn-btn:active{transform:translateY(0)}.learn-btn:disabled{opacity:0.45;cursor:not-allowed;transform:none}.learn-btn-label{display:flex;align-items:center;gap:8px}.learn-btn-hint{font-size:12px;font-weight:300;opacity:0.45;font-family:'DM Mono',monospace;letter-spacing:0.06em}.learn-btn-count{font-family:'DM Mono',monospace;font-size:11px;font-weight:300;opacity:0.55;letter-spacing:0.1em}.memorize-page{max-width:680px;margin:0 auto;padding:44px 44px 80px}.memorize-lede{margin-bottom:36px;text-align:center}.memorize-eyebrow{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.26em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}.memorize-title{font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-0.02em;margin-bottom:4px}.memorize-sub{font-family:'DM Mono',monospace;font-size:11px;color:var(--ink-soft);letter-spacing:0.08em}.new-row-card{background:var(--white);border:1.5px solid var(--border-str);border-radius:var(--r-lg);overflow:hidden;margin-bottom:12px;animation:revealUp 0.3s ease both;border-top-width:3px}.memorize-page[data-kana="hiragana"] .new-row-card{border-top-color:var(--accent)}.memorize-page[data-kana="katakana"] .new-row-card{border-top-color:var(--indigo)}.mem-section-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;text-align:center;padding:12px 0 0;margin-bottom:0}.memorize-page[data-kana="hiragana"] .mem-section-label{color:var(--accent)}.memorize-page[data-kana="katakana"] .mem-section-label{color:var(--indigo)}.new-row-chars{display:flex;justify-content:center;flex-wrap:wrap;padding:20px 24px 28px;gap:0}.new-row-char-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:0 24px;border-right:1px solid var(--border)}.new-row-char-card:last-child{border-right:none}.new-row-char{font-family:'Noto Sans JP',sans-serif;font-size:48px;font-weight:300;color:var(--ink);line-height:1}.new-row-char.combo{font-size:36px;letter-spacing:-2px}.new-row-romaji{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:0.14em;color:var(--ink-soft)}.prior-rows-section{margin-bottom:28px}.prior-chars-grid{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.prior-char-pill{display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 10px;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--white)}.memorize-page[data-kana="hiragana"] .prior-char-pill{background:var(--accent-light);border-color:rgba(232,66,26,0.2)}.memorize-page[data-kana="katakana"] .prior-char-pill{background:var(--indigo-light);border-color:rgba(61,59,204,0.2)}.prior-char-pill .pc-jp{font-family:'Noto Sans JP',sans-serif;font-size:18px;font-weight:300;color:var(--ink)}.memorize-page[data-kana="hiragana"] .prior-char-pill .pc-jp{color:var(--accent)}.memorize-page[data-kana="katakana"] .prior-char-pill .pc-jp{color:var(--indigo)}.prior-char-pill .pc-jp.combo{font-size:14px;letter-spacing:-1px}.prior-char-pill .pc-ro{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.1em;color:var(--ink-soft)}.start-quiz-btn{width:100%;height:64px;background:var(--ink);color:#fff;border:none;border-radius:var(--r-md);font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:800;cursor:pointer;transition:transform 0.15s, background 0.15s;letter-spacing:-0.01em}.start-quiz-btn:hover{background:#1a1928;transform:translateY(-2px)}.start-quiz-btn:active{transform:translateY(0)}.config-page{max-width:820px;margin:0 auto;padding:40px 44px 20px}@media (max-width: 768px){.row-char-unit{padding:4px 10px}.config-page{padding:40px 24px 20px}.new-row-char{font-size:36px}.new-row-chars{padding:20px 14px 28px}.new-row-char-card{padding:0 13px}.word-display.english-word{font-size:34px}}
