:root{--red:#b71c1c;--red-dark:#7f0000;--bg:#faf7f2;--card:#fff;--border:#ede3d8;--text:#1a1a1a;--ink:#1a1a1a;--sub:#555;--muted:#999;--n5:#00695c;--n5-bg:#e0f2f1;--n4:#1b5e20;--n4-bg:#e8f5e9;--n3:#0d47a1;--n3-bg:#e3f2fd;--n2:#4a148c;--n2-bg:#f3e5f5;--n1:#b71c1c;--n1-bg:#fce4e4;--skel:#e8e0d5}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Noto Sans JP,Hiragino Kaku Gothic ProN,Yu Gothic,sans-serif}header{background:linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%);color:#fff;z-index:10;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:16px 32px;display:grid;position:sticky;top:0;box-shadow:0 2px 20px #00000059}.h-left{text-align:left}.h-center{text-align:center}.h-right{justify-content:flex-end;align-items:center;gap:10px;display:flex}.h-title{letter-spacing:3px;font-family:Noto Sans JP,Yu Gothic,sans-serif;font-size:26px;font-weight:900}.h-sub{opacity:.55;letter-spacing:1px;margin-top:3px;font-size:12px}.h-date{opacity:.75;font-size:13px}.h-greet{opacity:.45;margin-top:3px;font-size:12px}.h-settings-btn{color:#fffc;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:#0000;z-index:5;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;flex-shrink:0;padding:6px 10px;font-size:15px;line-height:1;transition:background .15s;position:relative}.h-settings-btn:hover{background:#fff3}.h-hamburger-wrap{display:none}#settingsPage{z-index:1000;background:#fff;flex-direction:column;width:360px;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;overflow:hidden;transform:translate(100%);box-shadow:-4px 0 30px #0000002e}#settingsPage.open{transform:translate(0)}.settings-page-header{background:var(--red);color:#fff;flex-shrink:0;align-items:center;gap:14px;padding:16px 20px;display:flex}.settings-back-btn{color:#fff;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:#0000;background:#ffffff26;border:none;border-radius:8px;flex-shrink:0;padding:8px 14px;font-size:15px}.settings-page-title{font-size:17px;font-weight:700}.settings-page-body{flex:1;padding:20px 24px 28px;overflow-y:auto}.settings-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:14px;font-size:12px;font-weight:700}.settings-row{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.settings-label{color:var(--sub);font-size:14px;font-weight:500}.settings-toggle{cursor:pointer;width:40px;height:22px;accent-color:var(--red)}.settings-save-row{border-top:1px solid var(--border);align-items:center;gap:14px;margin-top:22px;padding-top:18px;display:flex}.settings-save-msg{color:#388e3c;font-size:13px;font-weight:600}@media (width<=640px){#settingsPage{width:100%}}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;max-width:1120px;margin:22px auto 0;padding:0 24px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;padding:9px 20px;font-size:13px;font-weight:700;transition:background .18s,transform .12s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--red);color:#fff}.btn-primary:hover{background:#c62828}.btn-ghost{color:var(--sub);border:1.5px solid var(--border);background:#fff}.btn-ghost:hover{background:#f5f0ea}.toolbar-info{color:var(--muted);margin-left:4px;font-size:13px}.toolbar-info strong{color:var(--sub)}#statusMsg{border-radius:20px;margin-left:auto;padding:3px 10px;font-size:12px}.status-loading{color:#f57f17;background:#fff8e1}.status-ok{color:#2e7d32;background:#e8f5e9}.status-error{color:#b71c1c;background:#fce4e4}.legend{flex-wrap:wrap;align-items:center;gap:10px;max-width:1120px;margin:14px auto 0;padding:0 24px;display:flex}.legend-item{color:var(--sub);align-items:center;gap:6px;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.grid{grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px;max-width:1120px;margin:20px auto 48px;padding:0 24px;display:grid}.card{background:var(--card);border:1px solid var(--border);opacity:0;border-radius:12px;flex-direction:column;padding:26px 24px 22px;transition:transform .18s,box-shadow .18s;animation:.38s forwards rise;display:flex;position:relative;box-shadow:0 2px 14px #0000000d}.card-body{flex-direction:column;flex:1;display:flex}.card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0000001a}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.skeleton{opacity:0;align-items:flex-start;gap:16px;animation:.38s forwards rise;display:flex}.skel-big{background:var(--skel);border-radius:10px;flex-shrink:0;width:82px;height:82px;animation:1.4s ease-in-out infinite pulse}.skel-line{background:var(--skel);border-radius:6px;height:14px;margin-bottom:8px;animation:1.4s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.card-top{align-items:flex-start;gap:16px;margin-bottom:18px;display:flex;overflow:hidden}.kanji-char{color:#111;text-align:center;-webkit-user-select:none;user-select:none;flex-shrink:0;width:82px;min-width:82px;font-size:72px;font-weight:900;line-height:1}.card-info{flex-direction:column;flex:1;min-width:0;padding-top:4px;display:flex;overflow:hidden}.card-info .badge{order:1;align-self:flex-start;margin-top:8px;margin-bottom:0}.badge{letter-spacing:1px;border-radius:20px;margin-bottom:8px;padding:2px 10px;font-size:11px;font-weight:800;display:inline-block}.badge-N5{background:var(--n5-bg);color:var(--n5)}.badge-N4{background:var(--n4-bg);color:var(--n4)}.badge-N3{background:var(--n3-bg);color:var(--n3)}.badge-N2{background:var(--n2-bg);color:var(--n2)}.badge-N1{background:var(--n1-bg);color:var(--n1)}.card-meaning{color:#1a1a1a;word-break:break-word;overflow-wrap:break-word;font-size:16px;font-weight:700;line-height:1.4}.readings{border-top:1px solid var(--border);flex-wrap:wrap;gap:16px;margin-bottom:16px;padding-top:14px;display:flex}.reading-label{text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:4px;font-size:10px;font-weight:800;display:block}.reading-kana{color:#6d4c41;letter-spacing:1px;word-break:break-all;font-size:14px;font-weight:700}.examples-label{text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:8px;font-size:10px;font-weight:800}.example{background:var(--bg);border-left:3px solid var(--border);border-radius:8px;flex-direction:column;gap:3px;margin-bottom:6px;padding:8px 10px;display:flex;overflow:hidden}.example:last-child{margin-bottom:0}.ex-top{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.ex-word{color:#111;font-size:15px;font-weight:800}.ex-reading{color:var(--muted);font-size:11px}.ex-meaning{color:var(--sub);word-break:break-word;overflow-wrap:break-word;font-size:12px}.btn-quiz{color:#e65100;background:#fff3e0;border:1.5px solid #ffcc80}.btn-quiz:hover{background:#ffe0b2}.btn-quiz.active{color:#fff;background:#e65100;border-color:#e65100}.btn-save{color:#2e7d32;background:#e8f5e9;border:1.5px solid #a5d6a7}.btn-save:hover{background:#c8e6c9}.btn-save.saved{color:#fff;cursor:default;background:#2e7d32;border-color:#2e7d32}.level-filter{flex-wrap:wrap;align-items:center;gap:6px;max-width:1120px;margin:12px auto 0;padding:0 24px 10px;display:flex}.level-filter-label{color:var(--muted);margin-right:2px;font-size:12px;font-weight:600}.pill{border:1.5px solid var(--border);color:var(--sub);cursor:pointer;background:#fff;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;transition:all .15s}.pill:hover{background:#f5f0ea}.pill.active{color:#fff;border-color:#0000}.pill[data-level=all].active{background:#666}.pill[data-level="5"].active{background:var(--n5)}.pill[data-level="4"].active{background:var(--n4)}.pill[data-level="3"].active{background:var(--n3)}.pill[data-level="2"].active{background:var(--n2)}.pill[data-level="1"].active{background:var(--n1)}.quiz-screen{flex-direction:column;grid-column:1/-1;align-items:center;width:100%;max-width:640px;margin:0 auto;padding:8px 16px 48px;display:flex}.quiz-progress-wrap{background:var(--border);border-radius:4px;width:100%;height:7px;margin-bottom:12px;overflow:hidden}.quiz-progress-bar{background:var(--red);border-radius:4px;height:100%;transition:width .45s}.quiz-meta{color:var(--muted);letter-spacing:1px;margin-bottom:18px;font-size:13px}.quiz-question-card{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:12px;width:100%;margin-bottom:18px;padding:30px 28px 22px;box-shadow:0 2px 14px #0000000f}.quiz-direction-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:16px;font-size:11px;font-weight:800}.quiz-prompt-word{color:#111;margin-bottom:8px;font-size:72px;font-weight:900;line-height:1}.quiz-prompt-meaning{color:#1a1a1a;margin-bottom:8px;font-size:20px;font-weight:700;line-height:1.4}.quiz-prompt-reading{color:var(--red);margin-bottom:8px;font-size:14px;font-weight:700}.quiz-options{grid-template-columns:1fr 1fr;gap:12px;width:100%;display:grid}.quiz-option{border:2px solid var(--border);cursor:pointer;text-align:center;color:var(--text);background:#fff;border-radius:12px;padding:16px 12px;font-family:inherit;font-size:14px;font-weight:600;line-height:1.4;transition:background .14s,border-color .14s,transform .1s}.quiz-option:hover:not(:disabled){background:var(--bg);border-color:var(--red);transform:translateY(-2px)}.quiz-option.correct{color:#1b5e20;background:#e8f5e9;border-color:#2e7d32}.quiz-option.wrong{color:#b71c1c;background:#fce4e4;border-color:#b71c1c}.quiz-option:disabled{cursor:default;transform:none}.quiz-results{text-align:center;padding-top:40px}.quiz-result-emoji{margin-bottom:12px;font-size:56px}.quiz-result-score{color:var(--red);font-size:52px;font-weight:900;line-height:1}.quiz-result-pct{color:var(--muted);margin:4px 0 10px;font-size:20px}.quiz-result-msg{color:var(--sub);font-size:18px;font-weight:700}.quiz-result-time{color:var(--muted);margin-top:6px;font-size:13px}.quiz-elapsed-wrap{opacity:.35;font-size:12px}.quiz-elapsed{font-variant-numeric:tabular-nums}.quiz-tomorrow{text-align:center;background:#fff8f2;border:1.5px solid #f5d9c4;border-radius:14px;max-width:380px;margin:32px auto 0;padding:20px 24px}.quiz-tomorrow-icon{margin-bottom:6px;font-size:32px}.quiz-tomorrow-title{color:var(--red);margin-bottom:6px;font-size:17px;font-weight:800}.quiz-tomorrow-body{color:var(--sub);font-size:14px;line-height:1.6}.btn-notif-opt{border:1.5px solid var(--red);color:var(--red);cursor:pointer;background:0 0;border-radius:20px;margin-top:16px;padding:9px 18px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s,color .15s}.btn-notif-opt:hover:not(:disabled){background:var(--red);color:#fff}.btn-notif-opt.notif-opted,.btn-notif-opt:disabled{opacity:.65;cursor:default}.notif-time-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin-top:16px;display:flex}.notif-time-input{border:1.5px solid var(--border);color:var(--sub);cursor:pointer;background:#fff;border-radius:8px;padding:7px 10px;font-family:inherit;font-size:14px}.notif-time-input:disabled{opacity:.65;cursor:default}.mylist-full-empty{text-align:center;padding:72px 24px 48px}.mylist-full-empty-icon{margin-bottom:16px;font-size:56px}.mylist-full-empty-title{color:var(--sub);margin-bottom:10px;font-size:22px;font-weight:800}.mylist-full-empty-body{color:var(--muted);margin-bottom:28px;font-size:15px;line-height:1.6}.mylist-full-empty-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.tabbar{z-index:9;background:var(--bg);gap:6px;max-width:1120px;margin:0 auto;padding:10px 24px 0;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000000f}.tab{cursor:pointer;color:var(--sub);letter-spacing:0;text-align:center;background:#ede3d8;border:none;border-radius:8px 8px 0 0;padding:7px 16px;font-family:Noto Sans JP,Yu Gothic,sans-serif;font-size:18px;font-weight:900;line-height:1.3;transition:background .18s,color .18s}.tab:hover{background:#e0d5c8}.tab.active{background:var(--red);color:#fff}.vocab-header{margin-bottom:10px}.vocab-word{color:#111;-webkit-user-select:none;user-select:none;word-break:break-word;font-size:48px;font-weight:900;line-height:1.15}.vocab-reading{color:#6d4c41;letter-spacing:1px;margin-top:3px;font-size:14px;font-weight:700}.vocab-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.vocab-meta .badge{margin-bottom:0}.source-kanji-tag{color:var(--red);background:var(--n3-bg);letter-spacing:0;border-radius:7px;padding:0 7px;font-size:18px;font-weight:900;line-height:1.6}.vocab-pos{color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700;display:inline-block}.kanji-save-btn{z-index:3;cursor:pointer;color:var(--muted);background:0 0;border:none;padding:4px;font-size:20px;line-height:1;transition:color .15s,transform .1s;position:absolute;top:12px;right:14px}.kanji-save-btn:hover{color:var(--red);transform:scale(1.2)}.kanji-save-btn.saved{color:var(--red)}footer{text-align:center;color:var(--muted);padding:32px 20px;font-size:13px}.stats-section{max-width:1120px;margin:20px auto 48px;padding:0 24px}.stats-container{flex-direction:column;gap:24px;display:flex}.kpi-grid{grid-template-rows:auto auto;grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.kpi-wotd{flex-direction:column;grid-area:1/3/span 2;justify-content:center;display:flex}.kpi-card{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:24px 20px 18px;display:flex;box-shadow:0 2px 10px #0000000d}.kpi-jlpt{justify-content:flex-start!important}.kpi-num{color:var(--red);margin-bottom:8px;font-size:48px;font-weight:900;line-height:1}.kpi-lbl{color:var(--sub);letter-spacing:.3px;font-size:13px;font-weight:700}.chart-block{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px 20px 14px;box-shadow:0 2px 10px #0000000d}.chart-title{color:var(--sub);letter-spacing:.3px;margin-bottom:14px;font-size:14px;font-weight:800}.chart-canvas{display:block}.qh-list{flex-direction:column;display:flex}.qh-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:9px 0;display:flex}.qh-row:last-child{border-bottom:none}.qh-date{color:var(--muted);min-width:84px;font-size:12px;font-weight:600}.qh-bar-wrap{background:var(--bg);border-radius:5px;flex:1;height:10px;overflow:hidden}.qh-bar{background:var(--red);border-radius:5px;height:100%}.qh-score{color:var(--sub);text-align:right;min-width:90px;font-size:13px;font-weight:700}.qh-pct{color:var(--muted);font-weight:400}.qh-type{border-radius:10px;margin-left:4px;padding:2px 7px;font-size:10px;font-weight:800}.qh-type-daily{color:#0d47a1;background:#e3f2fd}.qh-type-biweekly{color:#b71c1c;background:#fce4e4}.qh-type-srs{color:#4a148c;background:#f3e5f5}.qh-type-exam{color:#fff;background:#1a237e}.exam-countdown{color:var(--text);font-variant-numeric:tabular-nums;font-size:15px;font-weight:700}.exam-countdown.warning{color:#e65100}.exam-countdown.urgent{color:var(--red);animation:.8s infinite pulse}.exam-result-banner{letter-spacing:2px;text-align:center;border-radius:12px;margin:12px 0;padding:14px 24px;font-size:20px;font-weight:900}.exam-pass{color:#1b5e20;background:#e8f5e9}.exam-fail{color:#b71c1c;background:#ffebee}.btn-exam{color:#fff!important;background:#1a237e!important;border:none!important}.btn-exam:hover{background:#283593!important}.btn-locked{color:#bbb!important;cursor:not-allowed!important;background:#f0f0f0!important;border:1.5px solid #ddd!important}.btn-locked:hover{opacity:1;transform:none!important}.stat-notif{background:#fff3e0;border:1.5px solid #ffcc80;border-radius:12px;align-items:flex-start;gap:14px;padding:18px 20px;display:flex}.stat-notif-icon{flex-shrink:0;font-size:28px;line-height:1}.stat-notif-body{flex:1}.stat-notif-title{color:#e65100;margin-bottom:6px;font-size:15px;font-weight:800}.stat-notif-sub{color:#bf360c;margin-bottom:12px;font-size:13px;line-height:1.5}.home-section{flex-direction:column;gap:24px;max-width:900px;margin:24px auto 48px;padding:0 24px;display:flex}.home-greeting{color:var(--ink);font-size:22px;font-weight:700}.home-greeting span{color:var(--red)}.home-sub{color:var(--muted);margin-top:2px;font-size:14px}.home-actions{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;display:grid}.home-action-card{background:var(--card);border:1px solid var(--border);cursor:pointer;text-align:center;border-radius:12px;padding:20px 16px;transition:box-shadow .15s,transform .15s}.home-action-card:hover{transform:translateY(-2px);box-shadow:0 4px 18px #0000001a}.home-action-icon{margin-bottom:8px;font-size:32px}.home-action-title{color:var(--ink);font-size:15px;font-weight:700}.home-action-sub{color:var(--muted);margin-top:3px;font-size:12px}.home-action-card.disabled{opacity:.45;cursor:default;pointer-events:none}.home-today{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px 20px}.home-today-title{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;font-size:13px;font-weight:700}.kpi-jlpt{cursor:pointer;-webkit-user-select:none;user-select:none}.kpi-jlpt:hover{border-color:var(--red)}.kpi-jlpt-level{line-height:1;color:var(--red)!important}.kpi-jlpt-pct{color:var(--sub);margin-bottom:4px;font-size:13px;font-weight:700}.kpi-jlpt-hint{color:var(--muted);letter-spacing:.3px;margin-top:6px;font-size:11px}.kpi-jlpt-sub{color:var(--muted);margin-top:4px;font-size:10px;line-height:1.5}.kpi-jlpt .kpi-jlpt-pct{font-size:12px}.kpi-streak-nudge{color:var(--sub);margin-top:6px;font-size:11px;line-height:1.4}.kpi-streak-nudge span{cursor:pointer;text-decoration:underline}.kpi-grid-2col{grid-template-columns:1fr 1fr!important}.kpi-grid-2col .kpi-jlpt{grid-column:unset}.kpi-wotd{overflow:hidden;flex-direction:column!important;justify-content:flex-start!important;align-items:stretch!important;padding:0!important;display:flex!important}.kpi-wotd-banner{background:linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%);color:#fff;text-align:center;border-radius:12px 12px 0 0;padding:20px 14px 18px}.kpi-wotd-banner-emoji{margin-bottom:4px;font-size:22px}.kpi-wotd-banner-title{letter-spacing:2px;text-transform:uppercase;opacity:.95;font-size:15px;font-weight:900}.kpi-wotd-body{flex-direction:column;flex:1;justify-content:center;align-items:center;padding:20px 14px;display:flex}.kpi-wotd-kanji{color:var(--red);word-break:break-word;text-align:center;margin-bottom:8px;font-size:clamp(1.6rem,4.5vw,3.2rem);font-weight:900;line-height:1.1}.kpi-wotd-reading{color:var(--sub);margin-bottom:5px;font-size:14px;font-weight:700}.kpi-wotd-meaning{color:var(--muted);font-size:12px;font-style:italic}.kpi-wotd-save-btn{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:20px;margin-top:12px;padding:6px 18px;font-size:12px;font-weight:700;transition:opacity .15s}.kpi-wotd-save-btn:hover{opacity:.85}.kpi-wotd-saved{color:var(--red);margin-top:12px;font-size:12px;font-weight:700}.home-today-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:6px 0;font-size:14px;display:flex}.home-today-row:last-child{border-bottom:none}.home-today-val{color:var(--red);font-weight:700}.home-today-val.good{color:#2e7d32}.mylist-section{max-width:1120px;margin:20px auto 48px;padding:0 24px}.mylist-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;display:flex}.mylist-search{border:1.5px solid var(--border);min-width:180px;max-width:320px;color:var(--text);background:#fff;border-radius:8px;flex:1;padding:8px 14px;font-family:inherit;font-size:13px}.mylist-search:focus{border-color:var(--red);outline:none}.mylist-count{color:var(--muted);margin-left:auto;font-size:13px}.mylist-table{border-collapse:collapse;background:var(--card);border-radius:12px;width:100%;overflow:hidden;box-shadow:0 2px 14px #0000000d}.mylist-table th{text-align:left;text-transform:uppercase;letter-spacing:1px;color:var(--muted);background:var(--bg);border-bottom:1px solid var(--border);padding:12px 16px;font-size:11px;font-weight:800}.mylist-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:11px 16px;font-size:14px}.mylist-table tr:last-child td{border-bottom:none}.mylist-table tr:hover td{background:#faf5ef}.mylist-word{font-size:20px;font-weight:900}.mylist-kana{color:var(--red);font-size:12px;font-weight:700;display:block}.mylist-date{color:var(--muted);white-space:nowrap;font-size:11px}.ml-col-word{width:160px;min-width:100px}.ml-col-meaning{text-overflow:ellipsis;white-space:nowrap;max-width:0;color:var(--sub);font-size:13px;overflow:hidden}.mylist-empty{text-align:center;color:var(--muted);padding:64px 20px;font-size:15px}.mylist-empty-icon{margin-bottom:12px;font-size:48px}.btn-danger{color:#b71c1c;background:#fce4e4;border:1.5px solid #ef9a9a}.btn-danger:hover{background:#ffcdd2}.mylist-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:2px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;font-size:13px;font-weight:800;display:flex}.mylist-section-count{color:var(--sub);background:var(--bg);border:1px solid var(--border);text-transform:none;border-radius:10px;padding:2px 9px;font-size:12px;font-weight:700}.mylist-empty-small{color:var(--muted);background:var(--bg);border-radius:12px;margin-bottom:8px;padding:18px 16px;font-size:14px}.kanji-saved-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:8px;display:grid}.kanji-saved-chip{background:var(--card);border:1px solid var(--border);text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:14px 12px 12px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.kanji-saved-chip:hover{border-color:var(--red)}.kanji-saved-chip.selected{border-color:var(--red);background:#fff5f5;box-shadow:0 0 0 2px #dc354540}.kanji-chip-check{border:1.5px solid var(--border);color:#0000;cursor:pointer;z-index:2;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:4px;font-size:11px;transition:background .15s,border-color .15s,color .15s;display:flex;position:absolute;top:7px;right:9px}.kanji-saved-chip:hover .kanji-chip-check{border-color:var(--red)}.kanji-saved-chip.selected .kanji-chip-check{background:var(--red);border-color:var(--red);color:#fff}.mylist-section.select-mode .kanji-chip-check,.mylist-section.select-mode .ml-check-icon{border-color:var(--red);color:#dc354540;cursor:grab}.kanji-saved-char{color:#111;font-size:52px;font-weight:900;line-height:1}.kanji-saved-meaning{color:var(--sub);font-size:11px;line-height:1.4}.kanji-saved-remove{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:2px;font-size:12px;line-height:1;position:absolute;top:6px;right:8px}.kanji-saved-remove:hover{color:var(--red)}#mylistBody tr{cursor:pointer;transition:background .12s}#mylistBody tr:hover{background:var(--bg)}#mylistBody tr.selected td,#mylistBody tr.selected:hover td{background:#dc354514!important}#mylistBody tr.selected td:first-child{border-left:3px solid var(--red)}.ml-check-icon{border:1.5px solid var(--border);color:#0000;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;transition:background .15s,border-color .15s,color .15s;display:inline-flex}#mylistBody tr:hover .ml-check-icon{border-color:var(--red)}#mylistBody tr.selected .ml-check-icon{background:var(--red);border-color:var(--red);color:#fff}.ml-select-toolbar{align-items:center;gap:8px;margin-bottom:16px;display:flex}.ml-longpress-hint{color:var(--muted);margin-left:4px;font-size:11px;font-weight:500;display:none}@media (pointer:coarse){.ml-longpress-hint{display:inline}}.paywall-hint{color:#5d4037;background:#fff8e1;border:1.5px solid #ffe082;border-radius:12px;flex-direction:column;align-items:flex-start;margin-bottom:18px;padding:14px 18px;font-size:14px;line-height:1.5;display:flex}.paywall-hint--full{color:#b71c1c;background:#fce4e4;border-color:#ef9a9a}@media (prefers-color-scheme:dark){.paywall-hint{color:#ffd54f;background:#2a220a;border-color:#7a6020}.paywall-hint--full{color:#ff8a80;background:#2a0808;border-color:#7a1c1c}}.ml-delete-bar{border:1.5px solid var(--red);opacity:0;pointer-events:none;background:#fff;border-radius:12px;align-items:center;gap:12px;margin-top:24px;padding:10px 18px;transition:opacity .2s,transform .2s;display:flex;position:sticky;bottom:16px;transform:translateY(8px);box-shadow:0 4px 20px #00000026}.ml-delete-bar.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.ml-delete-bar span{color:var(--text);flex:1;font-size:14px;font-weight:600}@media (pointer:coarse){.kanji-saved-chip:after{content:"hold";color:var(--muted);opacity:0;pointer-events:none;font-size:9px;transition:opacity .2s;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.mylist-section:not(:has(.kanji-saved-chip.selected,#mylistBody tr.selected)) .kanji-saved-chip:hover:after{opacity:1}}.srs-rating-wrap{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:14px;display:flex}.srs-btn{cursor:pointer;border:none;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:700;transition:transform .1s,opacity .15s;display:flex}.srs-btn:active{transform:scale(.96)}.srs-btn-again{color:#b71c1c;background:#fce4e4}.srs-btn-hard{color:#e65100;background:#fff3e0}.srs-btn-good{color:#2e7d32;background:#e8f5e9}.srs-btn-easy{color:#0d47a1;background:#e3f2fd}.srs-interval{opacity:.75;font-size:10px;font-weight:400}.btn-review{color:#4a148c;background:#f3e5f5;border:1.5px solid #ce93d8}.btn-review:hover{background:#e1bee7}.btn-review .review-count{color:#fff;vertical-align:middle;background:#4a148c;border-radius:10px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:800;display:inline-block}.auth-wrap{align-items:center;display:flex}.auth-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:12px;font-weight:700;transition:background .18s}.auth-btn-in{color:#fff;background:#ffffff2e}.auth-btn-in:hover{background:#ffffff4d}.auth-btn-out{color:#ffffffb3;background:#ffffff1a;padding:4px 10px;font-size:11px}.auth-btn-out:hover{background:#fff3}.auth-user{align-items:center;gap:8px;display:flex}.auth-avatar{object-fit:cover;border:2px solid #ffffff80;border-radius:50%;flex-shrink:0;width:28px;height:28px}.auth-avatar-fallback{color:#fff;background:#ffffff40;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:inline-flex}.auth-name{color:#ffffffe6;font-size:13px;font-weight:700}.auth-syncing{color:#fff9;margin-left:4px;font-size:11px}@media (width<=640px){header{grid-template-columns:1fr auto 1fr;gap:8px;padding:12px 14px}#settingsBtn{display:none}.h-hamburger-wrap{display:block;position:relative}.mobile-menu{color:#333;border:1px solid var(--border);z-index:600;background:#fff;border-radius:10px;min-width:160px;padding:6px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 4px 20px #0000002e}.mobile-menu-item{text-align:left;cursor:pointer;color:#333;touch-action:manipulation;-webkit-tap-highlight-color:#0000;background:0 0;border:none;border-radius:7px;width:100%;padding:13px 16px;font-size:15px;display:block}.mobile-menu-item:active{background:var(--bg)}.h-title{letter-spacing:2px;font-size:17px}.h-sub,.h-greet{display:none}.h-date{font-size:10px}.auth-name{display:none}.auth-btn-in{padding:6px 12px;font-size:11px}.auth-wrap{margin-left:0}.tabbar{bottom:0;left:0;right:0;top:unset;padding:0;padding-bottom:env(safe-area-inset-bottom);border-top:1px solid var(--border);z-index:200;background:#fff;grid-template-columns:repeat(5,1fr);gap:0;margin:0;display:grid;position:fixed;box-shadow:0 -2px 12px #0000001a}.tab{letter-spacing:0;border-radius:0;padding:10px 2px 8px;font-size:20px;line-height:1.3}.tab.active{border-top:3px solid var(--red);color:var(--red);background:#fff}.grid,.stats-section,.mylist-section,.home-section{margin-bottom:calc(72px + env(safe-area-inset-bottom))}#crisp-chatbox{bottom:72px!important}.home-actions{grid-template-columns:1fr 1fr}.home-action-card{padding:16px 10px}footer{padding-bottom:calc(80px + env(safe-area-inset-bottom) + 16px)}.toolbar{gap:8px;margin-top:12px;padding:0 12px}.btn{min-height:44px;padding:11px 14px;font-size:12px}#statusMsg{text-align:center;width:100%;margin-left:0}.level-filter{gap:6px;padding:4px 12px 8px}.toolbar-info{display:none}.legend{gap:8px;padding:0 12px}.grid{grid-template-columns:1fr;gap:12px;margin-top:12px;padding:0 12px}.card{border-radius:12px;padding:16px 14px 14px}.vocab-word{font-size:38px}.card-meaning{font-size:15px}.kanji-char{width:66px;min-width:66px;font-size:58px}.quiz-options{grid-template-columns:1fr;gap:10px}.quiz-option{min-height:52px;padding:16px 14px;font-size:14px}.quiz-prompt-word{font-size:54px}.quiz-question-card{border-radius:12px;padding:20px 14px 16px}.quiz-screen{padding:6px 0 48px}.mylist-section{padding:0 12px}.mylist-toolbar{z-index:8;background:var(--bg);border-bottom:1px solid var(--border);margin-bottom:8px;padding:8px 0 10px;position:sticky;top:52px}.mylist-table{font-size:13px}.mylist-table th,.mylist-table td{padding:9px 10px}.mylist-word{font-size:17px}.mylist-kana{font-size:11px}.btn-danger{padding:5px 8px!important;font-size:10px!important}.mylist-search{flex:1;min-width:0;max-width:100%}.kanji-chip-check{border-radius:0 12px;width:36px;height:36px;padding:10px;font-size:13px;top:0;right:0}.ml-delete-bar{bottom:calc(72px + env(safe-area-inset-bottom))}.stats-section{padding:0 12px}.kpi-grid{grid-template-columns:1fr 1fr 1fr;gap:10px}.kpi-wotd{grid-area:1/3/span 2}.kpi-num{font-size:38px}.kpi-card{border-radius:12px;padding:16px 10px 12px}.kpi-lbl{font-size:12px}.chart-block{padding:14px 12px 10px}.qh-date{min-width:70px;font-size:11px}.qh-score{min-width:70px;font-size:12px}.home-hero{padding:24px 18px 20px}.home-hero-kana{font-size:38px}.home-hero-title{font-size:20px}.home-hero-actions{flex-direction:column}.home-hero-actions .btn{text-align:center;width:100%}}.home-hero{background:linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%);color:#fff;border-radius:16px;padding:32px 28px 28px;position:relative;overflow:hidden}.home-hero:before{content:"漢字";opacity:.07;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:120px;font-weight:900;line-height:1;position:absolute;top:-14px;right:-10px}.home-hero-kana{letter-spacing:3px;margin-bottom:8px;font-size:48px;font-weight:900;line-height:1}.home-hero-title{margin-bottom:6px;font-size:22px;font-weight:700;line-height:1.3}.home-hero-sub{opacity:.75;max-width:440px;margin-bottom:20px;font-size:13px;line-height:1.6}.home-hero-actions{flex-wrap:wrap;gap:10px;display:flex}.home-hero-actions .btn-white{color:var(--red);cursor:pointer;background:#fff;border:none;border-radius:8px;padding:10px 22px;font-family:inherit;font-size:14px;font-weight:800;transition:opacity .15s,transform .12s}.home-hero-actions .btn-white:hover{opacity:.9;transform:translateY(-1px)}.home-hero-actions .btn-outline{color:#fff;cursor:pointer;background:#ffffff26;border:1.5px solid #fff6;border-radius:8px;padding:10px 22px;font-family:inherit;font-size:14px;font-weight:700;transition:background .15s}.home-hero-actions .btn-outline:hover{background:#ffffff40}.tutorial-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.tutorial-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:440px;padding:36px 32px 28px;animation:.3s rise;position:relative;box-shadow:0 16px 60px #0000004d}.tutorial-close{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:4px 6px;font-size:18px;line-height:1;transition:color .15s;position:absolute;top:14px;right:16px}.tutorial-close:hover{color:var(--text)}.tutorial-icon{margin-bottom:14px;font-size:52px;line-height:1}.tutorial-title{color:var(--text);margin-bottom:12px;font-size:22px;font-weight:900;line-height:1.3}.tutorial-body{color:var(--sub);margin-bottom:24px;font-size:14px;line-height:1.7}.tutorial-dots{justify-content:center;gap:7px;margin-bottom:20px;display:flex}.tutorial-dot{background:var(--border);border-radius:50%;width:8px;height:8px;transition:background .2s,transform .2s}.tutorial-dot.active{background:var(--red);transform:scale(1.25)}.tutorial-nav{justify-content:center;gap:10px;display:flex}.tutorial-nav .btn{min-width:110px}.kanji-detail-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:800;background:#0000008c;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.kanji-detail-modal{background:var(--card);border-radius:16px;width:100%;max-width:480px;max-height:85vh;padding:28px 26px 22px;animation:.25s rise;position:relative;overflow-y:auto;box-shadow:0 16px 60px #00000059}.kanji-detail-close{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:4px 6px;font-size:20px;transition:color .15s;position:absolute;top:12px;right:14px}.kanji-detail-close:hover{color:var(--text)}.kanji-detail-loading{text-align:center;color:var(--muted);padding:40px 20px;font-size:14px}@media (width<=640px){.tutorial-card{padding:28px 20px 22px}.tutorial-icon{font-size:42px}.tutorial-title{font-size:19px}.kanji-detail-modal{max-height:90vh;padding:22px 16px 18px}}.upgrade-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;background:#0000008c;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.upgrade-modal{background:var(--card);border-radius:20px;width:100%;max-width:400px;padding:32px 28px 28px;animation:.25s rise;position:relative;box-shadow:0 16px 60px #00000059}.upgrade-modal-context{border-left:3px solid var(--red);background:#dc354514;border-radius:0 8px 8px 0;margin-bottom:18px;padding:10px 14px;font-size:14px}.upgrade-modal-title{color:var(--text);margin-bottom:16px;font-size:22px;font-weight:900}.upgrade-modal-features{flex-direction:column;gap:8px;margin:0 0 18px;padding:0;list-style:none;display:flex}.upgrade-modal-features li{color:var(--sub);font-size:15px}.upgrade-modal-price{color:var(--red);margin-bottom:20px;font-size:28px;font-weight:900}.upgrade-modal-price span{color:var(--muted);font-size:13px;font-weight:400}.upgrade-modal-cta{text-align:center;border-radius:12px;padding:14px 24px;font-size:16px;font-weight:700;text-decoration:none;display:block}.upgrade-modal-note{color:var(--muted);text-align:center;margin-top:10px;font-size:11px}.upgrade-modal-signin{color:var(--sub);text-align:center;font-size:14px}.upgrade-card{background:linear-gradient(135deg,#fff5f5,#fff);border:1.5px solid #dc354540;border-radius:16px;align-items:center;gap:16px;margin-top:28px;padding:20px 22px;display:flex}.upgrade-card-left{flex:1}.upgrade-card-title{margin-bottom:4px;font-size:16px;font-weight:800}.upgrade-card-desc{color:var(--sub);margin-bottom:6px;font-size:13px}.upgrade-card-price{color:var(--red);font-size:18px;font-weight:900}.upgrade-card-price span{color:var(--muted);font-size:12px;font-weight:400}.upgrade-card-btn{background:var(--red);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:12px;padding:10px 18px;font-size:14px;font-weight:700;transition:opacity .15s}.upgrade-card-btn:hover{opacity:.85}@media (prefers-color-scheme:dark){.upgrade-card{background:linear-gradient(135deg,#1a0808,#1a1a1a)}}@media (width<=640px){.upgrade-card{flex-direction:column;align-items:flex-start}.upgrade-modal{padding:24px 18px 22px}}
