:root{--bg:#fafaf9;--fg:#1f2937;--muted:#6b7280;--border:#e5e7eb;--accent:#2563eb;--accent-fg:#ffffff;--danger:#dc2626;--success:#16a34a;--surface:#ffffff;--hover:#f3f4f6;--shadow:0 4px 12px rgba(0,0,0,0.08)}@media (prefers-color-scheme:dark){:root{--bg:#0f172a;--fg:#e5e7eb;--muted:#94a3b8;--border:#1e293b;--accent:#60a5fa;--accent-fg:#0f172a;--danger:#f87171;--success:#4ade80;--surface:#111827;--hover:#1e293b;--shadow:0 4px 12px rgba(0,0,0,0.4)}}*{box-sizing:border-box}body,html{margin:0;padding:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--fg);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer;background:none;border:none;color:inherit;padding:0}input,select,textarea{font:inherit;color:inherit;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 10px}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:transparent}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:6px;background:var(--accent);color:var(--accent-fg);font-weight:500;border:1px solid transparent;transition:opacity .15s}.btn:hover{opacity:.9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--fg);border-color:var(--border)}.btn-danger{background:var(--danger)}.btn-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px}.btn-icon:hover{background:var(--hover)}.btn-unread-sync{width:32px;height:32px;flex-shrink:0;border-radius:999px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-weight:600;padding:0;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:.82rem;line-height:1}.btn-unread-sync:disabled{opacity:.65;cursor:not-allowed}.btn-unread-sync--idle{background:color-mix(in srgb,var(--muted) 26%,var(--surface));color:color-mix(in srgb,var(--muted) 92%,var(--fg))}.btn-unread-sync--active{background:var(--accent);color:white}.btn-unread-sync:hover:not(:disabled){filter:brightness(1.06)}.icon{width:18px;height:18px;flex-shrink:0}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.auth-card{width:100%;max-width:380px;padding:32px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow)}.auth-card h1{margin:0 0 4px;font-size:1.5rem}.auth-card .subtitle{margin:0 0 24px;color:var(--muted);font-size:.9rem}.auth-card form{gap:12px}.auth-card form,.auth-card label{display:flex;flex-direction:column}.auth-card label{gap:4px;font-size:.875rem}.auth-card .auth-links{margin-top:16px;font-size:.875rem;display:flex;justify-content:space-between}.error-banner{background:color-mix(in srgb,var(--danger) 12%,transparent);color:var(--danger);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);border-radius:6px}.error-banner,.success-banner{padding:8px 12px;font-size:.875rem;margin-bottom:8px}.success-banner{background:color-mix(in srgb,var(--success) 12%,transparent);color:var(--success);border:1px solid color-mix(in srgb,var(--success) 30%,transparent);border-radius:6px}.app-root{display:flex;min-height:100vh}.sidebar{width:200px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-header{padding:12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.sidebar-header .brand{font-weight:600}.sidebar-section{padding:6px 0;border-bottom:1px solid var(--border)}.sidebar-row{display:flex;align-items:center;gap:6px;padding:8px 12px;width:100%;text-align:left;color:var(--fg);font-size:.9rem}.sidebar-row:hover{background:var(--hover);text-decoration:none}.sidebar-row.active{background:var(--hover);font-weight:500}.sidebar-row .icon-left{width:18px;display:inline-flex}.sidebar-row .label{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-row .actions{display:inline-flex;gap:2px;opacity:.6}.sidebar-row:hover .actions{opacity:1}.sidebar-sublist{display:flex;flex-direction:column;background:color-mix(in srgb,var(--surface) 70%,var(--bg))}.sidebar-sublist .sidebar-row{padding-left:28px;font-size:.85rem}.sidebar-sublist .add-row{color:var(--muted)}.sidebar-row.category-drop-target{background:color-mix(in srgb,var(--accent) 22%,var(--hover));outline:1px dashed var(--accent);outline-offset:-1px}.collapse-toggle,.open-toggle{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px}.collapse-toggle:hover,.open-toggle:hover{background:var(--hover)}.open-toggle{position:fixed;top:8px;left:8px;z-index:50;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow)}.main{flex:1 1;min-width:0;padding:24px}.main-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.main-header h1{margin:0;font-size:1.4rem}.story-list{display:flex;flex-direction:column}.story-row{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--border);border-radius:8px;margin-bottom:8px;background:var(--surface);color:var(--fg)}.story-row:hover{background:var(--hover);text-decoration:none}.story-row.story-row-draggable{cursor:-webkit-grab;cursor:grab}.story-row.story-row-draggable:active{cursor:-webkit-grabbing;cursor:grabbing}.story-text{flex:1 1;min-width:0;color:inherit}.story-text,.story-text:hover{text-decoration:none}.story-title{font-weight:500}.story-title,.story-url{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.story-url{color:var(--muted);font-size:.8rem}.story-row .delete{color:var(--danger)}.empty{padding:48px 16px;text-align:center;color:var(--muted)}.reader-wrap{max-width:760px;margin:0 auto;padding-bottom:80px}.reader-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.reader-header h2{margin:0;font-size:1.2rem}.reader-header .chapter-title{color:var(--muted);font-size:.95rem}.reader-content{font-size:1rem;line-height:1.7;-webkit-user-select:text;-moz-user-select:text;user-select:text}.reader-content *{-webkit-user-select:text!important;-moz-user-select:text!important;user-select:text!important}.reader-content p{margin:0 0 1em}.reader-content .reader-spoiler{margin:.75rem 0;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--surface) 92%,var(--fg))}.reader-content .reader-spoiler-summary{cursor:pointer;padding:8px 12px;font-size:.9rem;color:var(--muted);list-style:none;-webkit-user-select:none!important;-moz-user-select:none!important;user-select:none!important}.reader-content .reader-spoiler-summary::-webkit-details-marker{display:none}.reader-content .reader-spoiler[open]>.reader-spoiler-summary{color:var(--fg);border-bottom:1px solid var(--border)}.reader-content .reader-spoiler-body{padding:10px 12px 12px}.reader-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:8px 12px;display:flex;align-items:center;justify-content:center;gap:12px;z-index:10}.reader-nav input[type=number]{width:64px;text-align:center}.chapter-arrow{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--surface);border:1px solid var(--border)}.chapter-arrow:disabled{opacity:.3;cursor:not-allowed}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:var(--surface);border-radius:12px;padding:24px;width:100%;max-width:420px;box-shadow:var(--shadow)}.modal h2{margin:0 0 12px;font-size:1.1rem}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.modal form{gap:10px}.modal form,.modal label{display:flex;flex-direction:column}.modal label{gap:4px;font-size:.875rem}.word-popover{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;box-shadow:var(--shadow);z-index:200;font-size:.9rem;min-width:160px}.word-popover .word{font-weight:500}.word-popover .translation{color:var(--accent);margin-top:4px}.word-popover .translated-sentence{color:var(--text);margin-top:4px;font-size:.8rem}.word-popover .loading{color:var(--muted);font-style:italic}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:599px){.sidebar{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:90}.sidebar.collapsed{display:none}.main{padding:56px 16px 16px}}.settings{max-width:520px}.settings .field{margin-bottom:20px}.settings .field label{display:block;font-weight:500;margin-bottom:6px}.settings .field .hint{color:var(--muted);font-size:.85rem;margin-top:4px}.settings input[type=password],.settings select{width:100%;max-width:320px}