:root{--bg:#0f172a;--bg-card:#1e293b;--bg-input:#1e293b;--bg-nav:#1e293b;--border:#334155;--text:#e2e8f0;--text-muted:#94a3b8;--text-dim:#64748b;--accent:#3b82f6;--green:#16a34a;--red:#dc2626;--orange:#ea580c}[data-theme=light]{--bg:#f8fafc;--bg-card:#fff;--bg-input:#fff;--bg-nav:#fff;--border:#e2e8f0;--text:#0f172a;--text-muted:#475569;--text-dim:#94a3b8;--accent:#2563eb;--green:#16a34a;--red:#dc2626;--orange:#ea580c}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{max-width:480px;margin:0 auto;padding:16px}.nav{background:var(--bg-nav);border-radius:12px;gap:8px;margin-bottom:20px;padding:4px;display:flex}.nav a,.nav button{text-align:center;color:var(--text-muted);cursor:pointer;font-weight:600;font-size:inherit;background:0 0;border:none;border-radius:8px;flex:1;padding:10px 6px;text-decoration:none;transition:all .2s}.nav a.active{background:var(--accent);color:#fff}.nav .theme-toggle{color:var(--text-muted);flex:0;padding:8px;font-size:1.2rem}.nav .theme-toggle:hover{background:var(--border)}.login{flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:80dvh;display:flex}.login h1{font-size:1.5rem}.login form{flex-direction:column;gap:12px;width:100%;max-width:320px;display:flex}.login input,input,select,textarea{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:8px;padding:12px;font-family:inherit;font-size:1rem}.login button,button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s}.login button:active,button:active{transform:scale(.97)}button:disabled{opacity:.5;cursor:not-allowed}.deck-grid{flex-direction:column;gap:8px;margin-top:12px;display:flex}.deck-card{background:var(--bg-card);color:var(--text);text-align:left;border:none;border-radius:12px;justify-content:space-between;align-items:center;width:100%;padding:16px;display:flex}.deck-card span{color:var(--accent);font-weight:600}.review{flex-direction:column;align-items:center;gap:16px;display:flex}.progress{color:var(--text-muted);align-self:flex-start;font-size:.9rem}.flashcard{background:var(--bg-card);cursor:pointer;-webkit-user-select:none;user-select:none;border:2px solid var(--border);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:220px;padding:32px 20px;transition:transform .15s,border-color .15s,opacity .2s;display:flex}.flashcard.revealed{border-color:var(--accent)}.flashcard:active{transform:scale(.98)}.flashcard-leaving{opacity:0;transform:scale(.95)translateY(-10px)}.card-text{text-align:center;word-break:break-word;font-size:2.2rem;font-weight:700}.back{border-top:1px solid var(--border);width:100%;margin-top:16px;padding-top:16px}.tags{color:var(--text-dim);margin-top:12px;font-size:.8rem}.hint{color:var(--text-dim);margin-top:16px;font-size:.8rem}.furigana-ruby{flex-direction:column;align-items:center;line-height:1.2;display:inline-flex}.furigana-reading{color:var(--text-muted);font-size:.65em}.grade-buttons{grid-template-columns:1fr 1fr;gap:8px;width:100%;display:grid}.grade{cursor:pointer;border:none;border-radius:12px;padding:18px 8px;font-size:1rem;font-weight:700;transition:opacity .15s,transform .15s}.grade:active{transform:scale(.95)}.grade.again{background:var(--red)}.grade.hard{background:var(--orange)}.grade.good{background:var(--green)}.grade.easy{background:var(--accent)}.grade-feedback{font-size:1.2rem;font-weight:700;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.page-enter{animation:.25s slideIn}.dashboard{flex-direction:column;gap:20px;display:flex}.streak-card{text-align:center;background:linear-gradient(135deg,#ea580c,#f97316);border-radius:16px;padding:24px}.flame{font-size:3rem}.streak-number{font-size:3rem;font-weight:800}.streak-label{color:#fffc;font-size:.9rem}.daily-counters{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.counter-box{background:var(--bg-card);text-align:center;border:2px solid #0000;border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;transition:border-color .2s;display:flex}.counter-icon{font-size:1.5rem}.counter-value{font-size:2rem;font-weight:800}.counter-label{color:var(--text-muted);font-size:.8rem}.counter-sub{color:var(--text-muted);margin-top:-2px;font-size:.7rem}.counter-new{border-color:#6c5ce7}.counter-due{border-color:#e17055}.counter-started{border-color:#00b894}.counter-total{border-color:#636e72}.deck-filter{background:var(--bg-card);border-radius:12px;align-items:center;padding:12px 16px;display:flex}.deck-filter label{color:var(--text-muted);align-items:center;gap:10px;font-size:.9rem;display:flex}.deck-filter select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 12px;font-size:.9rem}.stats-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.stat-box{background:var(--bg-card);text-align:center;border-radius:12px;flex-direction:column;gap:4px;padding:16px;display:flex}.stat-value{color:var(--accent);font-size:1.6rem;font-weight:700}.stat-label{color:var(--text-muted);font-size:.75rem}.per-deck,.activity{background:var(--bg-card);border-radius:12px;padding:16px}.per-deck h3,.activity h3{color:var(--text-muted);margin-bottom:12px;font-size:.9rem}.deck-stat-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:8px 0;display:flex}.activity-bars{align-items:flex-end;gap:6px;height:120px;display:flex}.bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.bar{background:var(--accent);border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:height .5s}.bar-label{color:var(--text);margin-top:4px;font-size:.7rem}.bar-date{color:var(--text-dim);font-size:.6rem}.error{color:var(--red);font-size:.9rem}h2{font-size:1.3rem}.import-page form{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.file-label{background:var(--bg-card);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:12px;display:flex}.file-label input[type=file]{display:none}.file-label span{color:var(--text-muted)}.checkbox-label{color:var(--text-muted);align-items:center;gap:8px;font-size:.9rem;display:flex}.import-result{background:var(--bg-card);border-left:4px solid var(--green);border-radius:12px;margin-bottom:20px;padding:16px}.import-result .tag{background:var(--primary);color:#fff;border-radius:4px;margin-left:8px;padding:2px 8px;font-size:.8rem;display:inline-block}.import-result .warning{color:var(--orange,#e6a817);font-size:.85rem}.progress-bar-container{background:var(--bg-card);border-radius:8px;margin:12px 0;padding:12px}.progress-bar{background:var(--bg,#1a1a2e);border-radius:6px;height:12px;overflow:hidden}.progress-fill{background:var(--primary,#6c5ce7);border-radius:6px;height:100%;transition:width .3s}.progress-text{text-align:center;color:var(--text-muted);margin-top:6px;font-size:.85rem}.deck-list{background:var(--bg-card);border-radius:12px;padding:16px}.deck-list h3{color:var(--text-muted);margin-bottom:8px}.deck-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:8px 0;display:flex}.note{color:var(--text-dim);font-size:.8rem}.page{padding:20px 0}.empty-state{text-align:center;color:var(--text-dim);padding:60px 20px}.empty-state .empty-icon{opacity:.5;margin-bottom:16px;font-size:3rem}.empty-state h3{color:var(--text-muted);margin-bottom:8px;font-size:1.1rem}.empty-state p{margin-bottom:16px;line-height:1.5}.empty-state .cta-button{background:var(--accent);color:#fff;border-radius:8px;padding:10px 20px;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-block}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--border) 50%, var(--bg-card) 75%);background-size:200% 100%;border-radius:8px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.tab-bar{background:var(--bg-nav);border-radius:10px;gap:4px;margin-bottom:16px;padding:4px;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:10px;font-weight:600;transition:all .2s}.tab-btn.active{background:var(--accent);color:#fff}.import-page label{color:var(--text-muted);flex-direction:column;gap:6px;font-size:.9rem;display:flex}.proposals{margin-top:16px}.proposals-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.proposals-header h4{color:var(--text);font-size:1rem}.btn-accept-all{background:var(--green);padding:8px 16px;font-size:.9rem}.proposal-card{background:var(--bg-card);border-radius:10px;align-items:flex-end;gap:8px;margin-bottom:8px;padding:12px;display:flex}.proposal-fields{flex:1;gap:8px;display:flex}.proposal-fields label{flex:1}.proposal-fields input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:6px;margin-top:4px;padding:8px;font-size:.9rem}.proposal-actions{gap:4px;display:flex}.btn-accept-one{background:var(--green);padding:8px 12px;font-size:.9rem}.btn-reject{background:var(--red);padding:8px 12px;font-size:.9rem}.admin-section{background:var(--bg-card);border-radius:12px;margin-bottom:16px;padding:16px}.admin-section h3{color:var(--text);margin-bottom:12px;font-size:.95rem}.usage-stats{grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.stat-card{text-align:center;background:var(--bg);border-radius:8px;padding:12px 4px}.stat-card .stat-value{font-size:1.4rem}.refresh-btn{background:var(--border);padding:8px 16px;font-size:.85rem}.admin-section code{background:var(--bg);color:var(--accent);border-radius:4px;padding:2px 6px;font-size:.85rem}@media (width<=375px){.app{padding:12px}.flashcard{min-height:180px;padding:24px 16px}.card-text{font-size:1.8rem}.grade{padding:16px 6px;font-size:.9rem}.nav a,.nav button{padding:8px 4px;font-size:.75rem}.stats-grid{grid-template-columns:1fr}.daily-counters{grid-template-columns:repeat(2,1fr)}.usage-stats{grid-template-columns:1fr}}@media (width>=768px){.app{max-width:600px}.flashcard{min-height:280px}.card-text{font-size:2.8rem}}.fade-enter{animation:.25s fadeIn}.slide-enter{animation:.25s slideIn}.browser{gap:16px;max-width:100%;min-height:80vh;display:flex}.browser-sidebar{background:var(--bg-card);border-radius:8px;flex-shrink:0;width:200px;min-width:160px;max-height:80vh;padding:12px;font-size:.85rem;overflow-y:auto}.browser-sidebar h3{text-transform:uppercase;opacity:.7;margin:8px 0 4px;font-size:.8rem}.browser-sidebar ul{margin:0;padding:0;list-style:none}.browser-sidebar li{cursor:pointer;border-radius:4px;padding:3px 6px}.browser-sidebar li:hover{background:var(--bg-input)}.browser-sidebar li.active{background:var(--accent);color:#fff}.browser-main{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.browser-toolbar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.browser-toolbar .search-bar{flex:1;min-width:200px}.browser-actions{flex-wrap:wrap;gap:4px;display:flex}.browser-actions button{padding:2px 8px;font-size:.75rem}.browser-actions select{background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:2px 4px;font-size:.75rem}.card-table-wrapper{flex:1;overflow-x:auto}.card-table{border-collapse:collapse;width:100%;font-size:.82rem}.card-table th{background:var(--bg-card);text-align:left;white-space:nowrap;border-bottom:2px solid var(--border);padding:6px 8px;position:sticky;top:0}.card-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.card-table th.sortable:hover{color:var(--accent)}.card-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:4px 8px}.card-table tr:hover{background:#ffffff08}.card-table tr.selected{background:#6366f126}.card-table td input[type=text]{width:100%;padding:2px 4px;font-size:.8rem}.state-badge{border-radius:10px;padding:1px 6px;font-size:.7rem;font-weight:600}.state-badge.state-new{color:#22c55e;background:#22c55e33}.state-badge.state-learning{color:#eab308;background:#eab30833}.state-badge.state-review{color:#3b82f6;background:#3b82f633}.pagination{justify-content:space-between;align-items:center;padding:8px 0;font-size:.8rem;display:flex}.pagination button{padding:2px 10px;font-size:.75rem}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:12px;flex-direction:column;gap:8px;width:90%;max-width:500px;max-height:70vh;padding:20px;display:flex;overflow-y:auto}.modal h3{margin:0 0 8px}.dup-group{background:var(--bg-input);border-radius:6px;padding:8px}.dup-group ul{margin:4px 0 0 16px;font-size:.8rem}@media (width<=768px){.browser{flex-direction:column}.browser-sidebar{width:100%;max-height:200px}}.presets-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.presets-header h2{margin:0}.presets-list{flex-direction:column;gap:12px;display:flex}.preset-card{background:var(--bg-card);border:1px solid var(--border,#334155);border-radius:10px;padding:16px}.preset-card.default{border-color:var(--primary,#3b82f6)}.preset-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.preset-card-header h3{margin:0;font-size:1rem}.preset-card-stats{color:var(--text-muted,#94a3b8);flex-wrap:wrap;gap:12px;font-size:.8rem;display:flex}.preset-card-actions{gap:6px;display:flex}.badge-default{background:var(--primary,#3b82f6);color:#fff;border-radius:4px;margin-left:8px;padding:2px 6px;font-size:.7rem}.modal form{flex-direction:column;gap:12px;display:flex}.modal fieldset{border:1px solid var(--border,#334155);border-radius:8px;padding:12px}.modal legend{padding:0 6px;font-weight:600}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.form-group.checkbox label{cursor:pointer;align-items:center;gap:6px;display:flex}.form-group.checkbox input[type=checkbox]{width:auto}.form-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.error-banner{color:#fca5a5;cursor:pointer;background:#7f1d1d;border-radius:6px;margin-bottom:12px;padding:8px 12px}.review-top-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.timer-display{font-variant-numeric:tabular-nums;color:var(--text-muted,#94a3b8);text-align:center;min-width:70px;font-size:1.2rem}.auto-advance-toggle{align-items:center;gap:6px;font-size:.8rem;display:flex}.auto-advance-toggle label{cursor:pointer;align-items:center;gap:4px;display:flex}.advance-delay{background:var(--bg-input,#1e293b);color:var(--text,#e2e8f0);border:1px solid var(--border,#334155);border-radius:4px;padding:2px 6px;font-size:.75rem}.deck-list{flex-direction:column;gap:12px;display:flex}.deck-card-full{background:var(--bg-card);border:1px solid var(--border,#334155);border-radius:10px;padding:16px}.deck-card-full.no-preset{border-color:#f59e0b}.deck-card-main{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.deck-card-info h3{margin:0 0 6px;font-size:1.05rem}.deck-card-meta{color:var(--text-muted,#94a3b8);flex-wrap:wrap;gap:10px;font-size:.8rem;display:flex}.badge-preset{background:var(--primary,#3b82f6);color:#fff;border-radius:4px;padding:1px 6px;font-size:.7rem}.badge-none{color:#fbbf24;background:#78350f;border-radius:4px;padding:1px 6px;font-size:.7rem}.deck-preset-editor{border-top:1px solid var(--border,#334155);align-items:center;gap:8px;margin-top:10px;padding-top:10px;display:flex}.preset-select{background:var(--bg-input,#1e293b);color:var(--text,#e2e8f0);border:1px solid var(--border,#334155);border-radius:6px;flex:1;max-width:250px;padding:6px 10px;font-size:.85rem}
