:root{--bg: #0f1117;--bg-elev: #161a23;--card: #1b1f2a;--card-hover: #222736;--border: #2a2f3d;--border-light: #353b4d;--text: #e7e9f0;--text-dim: #9aa1b1;--text-faint: #6b7280;--accent: #ff5c9e;--accent-hover: #ff7ab8;--accent-soft: rgba(255, 92, 158, .15);--new: #ff5c7c;--new-bg: rgba(255, 92, 124, .13);--ok: #3ddc97;--radius: 12px;--radius-sm: 8px;--topbar-h: 56px;--tabbar-h: 60px;--font: -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans CJK SC", "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}input,select,button{font-size:14px}.screen-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.grow{flex:1}.spinner{width:38px;height:38px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spin{display:inline-block;animation:spin .8s linear infinite}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 18px;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.link-btn{background:none;border:none;color:var(--text-dim);padding:4px;text-decoration:none}.link-btn:hover{color:var(--accent-hover)}.icon-btn{background:var(--card);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);width:34px;height:34px;font-size:18px;display:inline-flex;align-items:center;justify-content:center}.icon-btn:hover:not(:disabled){border-color:var(--accent)}.icon-btn:disabled{opacity:.5}.state-msg{text-align:center;color:var(--text-dim);padding:48px 16px}.state-msg.error{color:var(--new)}.boot-error{text-align:center}.boot-error p{color:var(--new);margin-bottom:16px}.empty-state{text-align:center;padding:64px 16px;color:var(--text-dim)}.empty-emoji{font-size:48px;margin-bottom:12px}.empty-state p{margin:0 0 20px}.auth-bg{background:radial-gradient(circle at 30% 20%,#401728 0%,var(--bg) 55%)}.auth-card{width:100%;max-width:380px;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:32px 28px;box-shadow:0 20px 60px #00000073}.auth-brand{font-size:26px;font-weight:700;text-align:center}.auth-subtitle{text-align:center;color:var(--text-dim);margin:6px 0 24px}.auth-tabs{display:flex;background:var(--bg);border-radius:var(--radius-sm);padding:4px;margin-bottom:22px}.auth-tab{flex:1;background:none;border:none;color:var(--text-dim);padding:9px;border-radius:6px;font-weight:600}.auth-tab.active{background:var(--accent);color:#fff}.auth-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field span{font-size:13px;color:var(--text-dim)}.field input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;color:var(--text);transition:border-color .15s}.field input:focus{outline:none;border-color:var(--accent)}.auth-error{background:var(--new-bg);color:var(--new);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px}.auth-submit{margin-top:4px;padding:12px}.auth-divider{display:flex;align-items:center;gap:10px;margin:18px 0 14px;color:var(--text-faint);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.passkey-btn{width:100%;background:var(--card);border:1px solid var(--border-light);color:var(--text);border-radius:var(--radius-sm);padding:12px;font-weight:600;transition:border-color .15s,background .15s}.passkey-btn:hover:not(:disabled){border-color:var(--accent);background:var(--card-hover)}.passkey-btn:disabled{opacity:.6;cursor:not-allowed}.auth-hint{margin:10px 2px 0;font-size:12px;color:var(--text-faint);line-height:1.5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0009;display:flex;align-items:center;justify-content:center;padding:16px}.modal-card{width:100%;max-width:440px;max-height:90vh;overflow-y:auto;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080}.modal-head{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:18px 20px;background:var(--bg-elev);border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:17px}.modal-body{padding:16px 20px 22px;display:flex;flex-direction:column;gap:22px}.settings-section{display:flex;flex-direction:column;gap:12px}.settings-section-head{display:flex;align-items:center;justify-content:space-between}.settings-section-head h3{margin:0;font-size:14px;color:var(--text-dim);font-weight:600}.settings-badge{font-size:12px;color:var(--text-faint);border:1px solid var(--border);border-radius:999px;padding:2px 10px}.passkey-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.passkey-item{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}.passkey-title{font-weight:600}.passkey-meta{font-size:12px;color:var(--text-faint);margin-top:2px}.link-accent{background:none;border:none;color:var(--accent);font-weight:600;padding:4px}.link-accent:hover:not(:disabled){color:var(--accent-hover)}.link-danger{background:none;border:none;color:var(--new);padding:4px}.link-danger:disabled,.link-accent:disabled{opacity:.5;cursor:not-allowed}.ok-msg{background:#3ddc9721;color:var(--ok);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px}.warn-msg{background:var(--new-bg);color:var(--new);border-radius:var(--radius-sm);padding:9px 12px;font-size:12.5px;line-height:1.5}.layout{min-height:100vh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;height:var(--topbar-h);display:flex;align-items:center;gap:12px;padding:0 16px;background:#0f1117d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.topbar-brand{font-weight:700;font-size:17px;white-space:nowrap}.topbar-tabs{display:flex;gap:4px;margin-left:8px}.top-tab{background:none;border:none;color:var(--text-dim);padding:8px 16px;border-radius:var(--radius-sm);font-weight:600}.top-tab:hover{color:var(--text)}.top-tab.active{background:var(--accent-soft);color:var(--accent-hover)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.user-menu{display:flex;align-items:center;gap:8px}.username{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-dim);font-size:13px}.updated-hint{text-align:center;font-size:12px;color:var(--text-faint);padding:6px 16px 0}.content{flex:1;width:100%;max-width:2600px;margin:0 auto;padding:16px}.tabbar{display:none}.season-selector{display:flex;align-items:center;gap:2px}.season-arrow{background:var(--card);border:1px solid var(--border);color:var(--text);width:30px;height:34px;font-size:18px;line-height:1;border-radius:var(--radius-sm)}.season-arrow:disabled{opacity:.35;cursor:not-allowed}.season-arrow:hover:not(:disabled){border-color:var(--accent)}.season-select{background:var(--card);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:7px 8px;min-width:96px;text-align:center}.season-select:focus{outline:none;border-color:var(--accent)}.calendar{display:flex;align-items:flex-start;gap:14px;overflow-x:auto;padding-bottom:10px;scrollbar-width:thin;scrollbar-color:var(--border-light) transparent;overscroll-behavior-x:contain}.calendar::-webkit-scrollbar{height:10px}.calendar::-webkit-scrollbar-track{background:transparent}.calendar::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:999px}.calendar::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.day-col{flex:0 0 340px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.day-col--empty{flex-basis:170px}.day-head{display:flex;align-items:center;justify-content:space-between;gap:6px;margin:0 2px 12px;font-size:14.5px;font-weight:700;color:var(--text)}.day-count{background:var(--accent-soft);color:var(--accent-hover);border-radius:999px;padding:1px 8px;font-size:11px}.day-cards{display:flex;flex-direction:column;gap:8px}.day-empty{color:var(--text-faint);text-align:center;padding:18px 4px;font-size:12.5px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .15s,background .15s}.card:hover{background:var(--card-hover)}.card--new{border-color:var(--new);box-shadow:0 0 0 1px var(--new) inset}.card-main{display:flex;gap:11px;padding:10px;align-items:flex-start}.card-cover{width:58px;height:82px;object-fit:cover;border-radius:6px;flex-shrink:0;background:var(--bg)}.card-cover--empty{display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-faint)}.card-info{flex:1;min-width:0}.card-title{font-size:14px;font-weight:600;line-height:1.4;overflow-wrap:anywhere}.card-progress{margin-top:6px;font-size:12.5px;color:var(--text-dim)}.card-progress b{color:var(--text)}.card-total{color:var(--text-faint);margin-left:2px}.badge-new{display:inline-block;margin-top:6px;background:var(--new-bg);color:var(--new);font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px}.card-chevron{color:var(--text-faint);font-size:11px;margin-top:2px}.editor{border-top:1px solid var(--border);padding:10px 8px;display:flex;flex-direction:column;gap:8px}.ep-stepper{display:flex;align-items:center;gap:8px;justify-content:center}.ep-btn{width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-elev);color:var(--text);font-size:19px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.ep-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent-hover)}.ep-btn:disabled{opacity:.4;cursor:not-allowed}.ep-input{width:64px;text-align:center;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);padding:7px 4px;font-weight:600;-moz-appearance:textfield}.ep-input::-webkit-outer-spin-button,.ep-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ep-input:focus{outline:none;border-color:var(--accent)}.catchup-btn{background:none;border:1px dashed var(--border-light);color:var(--text-dim);border-radius:var(--radius-sm);padding:6px;font-size:12px}.catchup-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent-hover)}.catchup-btn:disabled{color:var(--ok);border-style:solid;border-color:transparent;cursor:default}.selection-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:12px}.search-input{flex:1;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text)}.search-input:focus{outline:none;border-color:var(--accent)}.selected-count{color:var(--text-dim);font-size:13px;white-space:nowrap}.select-row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;cursor:pointer;transition:border-color .15s,background .15s}.select-row:hover{background:var(--card-hover)}.select-row:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.select-row.selected{border-color:var(--accent)}.select-cover{width:42px;height:58px;object-fit:cover;border-radius:6px;flex-shrink:0;background:var(--bg)}.select-cover--empty{display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-faint)}.select-info{flex:1;min-width:0}.select-title{font-size:13.5px;font-weight:600;line-height:1.35;overflow-wrap:anywhere}.toggle{width:46px;height:26px;border-radius:999px;background:var(--border-light);border:none;position:relative;flex-shrink:0;transition:background .18s;padding:0}.toggle.on{background:var(--accent)}.toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .18s}.toggle.on .toggle-knob{transform:translate(20px)}@media (max-width: 767px){.topbar-tabs{display:none}.topbar-brand{font-size:16px}.username{display:none}.topbar-right{gap:8px}.content{padding:12px 12px calc(var(--tabbar-h) + 16px)}.calendar{flex-direction:column;align-items:stretch;overflow-x:visible;padding-bottom:0}.day-col{flex:0 0 auto;width:auto}.day-col--empty{display:none}.tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:30;height:var(--tabbar-h);padding-bottom:env(safe-area-inset-bottom);background:#0f1117f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border)}.tabbar-item{flex:1;background:none;border:none;color:var(--text-dim);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:11px}.tabbar-item.active{color:var(--accent-hover)}.tabbar-icon{font-size:19px}}@media (max-width: 360px){.season-select{min-width:78px}}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#0000009e;display:flex;align-items:center;justify-content:center;padding:20px;animation:detail-bg-in .22s ease}.detail-overlay.closing{animation:detail-bg-out .26s ease forwards}@keyframes detail-bg-in{0%{opacity:0}to{opacity:1}}@keyframes detail-bg-out{0%{opacity:1}to{opacity:0}}.detail-card{position:relative;width:100%;max-width:520px;max-height:88vh;overflow-y:auto;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 70px #0000008c;will-change:transform,opacity}.detail-close{position:absolute;top:10px;right:10px;z-index:2;width:32px;height:32px;border:none;border-radius:999px;background:#00000073;color:#fff;font-size:20px;line-height:1;cursor:pointer}.detail-close:hover{background:#000000b3}.detail-hero{display:flex;gap:16px;padding:20px 20px 16px;border-bottom:1px solid var(--border)}.detail-cover{width:132px;height:186px;flex-shrink:0;object-fit:cover;border-radius:var(--radius-sm);background:var(--bg)}.detail-cover--empty{display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-faint)}.detail-titles{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:8px}.detail-title-native{margin:0;font-size:19px;line-height:1.35;font-weight:700;overflow-wrap:anywhere}.detail-title-en{font-size:13px;color:var(--text-dim);line-height:1.4;overflow-wrap:anywhere}.detail-body{padding:16px 20px 22px;display:flex;flex-direction:column;gap:16px}.detail-loading{display:flex;justify-content:center;padding:24px 0}.detail-msg{color:var(--text-dim);font-size:13px}.detail-msg.error{color:var(--new)}.detail-row{display:flex;gap:10px;font-size:13.5px}.detail-label{flex-shrink:0;width:40px;color:var(--text-faint);font-size:12px;padding-top:2px}.detail-value{flex:1;overflow-wrap:anywhere}.detail-va{flex:1;margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:5px}.detail-va li{display:flex;align-items:baseline;gap:8px;overflow-wrap:anywhere}.va-cv{font-weight:600}.va-char{color:var(--text-dim);font-size:12px}.detail-summary{font-size:13.5px;line-height:1.7;color:var(--text);white-space:pre-wrap;overflow-wrap:anywhere}.detail-bgm-fix{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding-top:6px;border-top:1px dashed var(--border);font-size:12px;color:var(--text-faint)}.detail-bgm-link{color:var(--text-dim);text-decoration:none}.detail-bgm-link:hover{color:var(--accent)}.detail-bgm-edit,.detail-bgm-save,.detail-bgm-cancel{background:none;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-dim);font-size:12px;padding:3px 8px;cursor:pointer}.detail-bgm-edit:hover,.detail-bgm-save:hover,.detail-bgm-cancel:hover{color:var(--text);border-color:var(--accent)}.detail-bgm-input{width:120px;background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text);font-size:12px;padding:4px 8px}.detail-bgm-err{color:var(--new)}@media (max-width: 640px){.detail-overlay{padding:0;align-items:flex-end}.detail-card{max-width:100%;max-height:92vh;border-radius:18px 18px 0 0}.detail-cover{width:108px;height:152px}.detail-title-native{font-size:17px}}@media (prefers-reduced-motion: reduce){.detail-overlay,.detail-overlay.closing{animation:none}}
