:root{--bg:#fbfbfc;--surface:#fff;--surface-2:#f4f4f6;--border:#ebebef;--border-strong:#dcdce2;--text:#18181b;--muted:#71717a;--accent:#4f46e5;--accent-soft:#eef2ff;--accent-contrast:#fff;--danger:#dc2626;--star:#f59e0b;--green:#16a34a;--amber:#d97706;--yellow:#eab308;--shadow:0 1px 2px #18181b0f, 0 1px 3px #18181b0a;--shadow-lg:0 12px 34px #18181b24;--radius:14px;--radius-sm:10px}[data-theme=dark]{--bg:#0b0b0d;--surface:#151519;--surface-2:#1e1e24;--border:#27272e;--border-strong:#36363f;--text:#f4f4f5;--muted:#a1a1aa;--accent:#818cf8;--accent-soft:#1e1b34;--accent-contrast:#0b0b0d;--danger:#f87171;--star:#fbbf24;--green:#4ade80;--amber:#fbbf24;--yellow:#facc15;--shadow:0 1px 2px #0006;--shadow-lg:0 16px 44px #0000008c}*{box-sizing:border-box}[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app{max-width:1060px;margin:0 auto;padding:0 20px 64px}.center{text-align:center}.muted{color:var(--muted)}.error{color:var(--danger)}.topbar{background:color-mix(in srgb, var(--bg) 88%, transparent);-webkit-backdrop-filter:saturate(180%)blur(10px);backdrop-filter:saturate(180%)blur(10px);z-index:20;justify-content:space-between;align-items:center;gap:12px;padding:22px 0 18px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:10px;display:flex}.brand-mark{border-radius:7px;display:block}.topbar h1{letter-spacing:-.02em;margin:0;font-size:1.3rem;font-weight:650}.topbar-actions{align-items:center;gap:8px;display:flex}.btn{font:inherit;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);white-space:nowrap;justify-content:center;align-items:center;gap:6px;padding:8px 14px;font-weight:500;text-decoration:none;transition:border-color .15s,background .15s,opacity .15s,transform 50ms;display:inline-flex}.btn:hover{border-color:var(--accent)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent);font-weight:600}.btn.primary:hover{opacity:.92}.btn.small{padding:5px 11px;font-size:.82rem}.btn.icon{padding:7px 11px;font-size:1.1rem;line-height:1}.btn.danger{color:var(--danger)}.btn.danger:hover{border-color:var(--danger)}.btn.goodreads:hover{border-color:var(--amber);color:var(--amber)}.stats-strip{grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px;display:grid}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:2px;padding:14px 16px;display:flex}.stat-value{letter-spacing:-.02em;font-size:1.45rem;font-weight:680}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}.controls{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.search{font:inherit;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text);padding:10px 14px}.search::placeholder{color:var(--muted)}.control-group{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.segmented{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);gap:2px;padding:3px;display:inline-flex}.seg{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:6px 12px;font-size:.84rem;transition:background .15s,color .15s}.seg:hover{color:var(--text)}.seg.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow);font-weight:600}.select{font:inherit;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;padding:8px 12px;font-size:.84rem}.view-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);gap:2px;margin-left:auto;padding:3px;display:inline-flex}.vt{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:6px;transition:background .15s,color .15s;display:inline-flex}.vt svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;width:18px;height:18px}.vt.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.vt:last-child svg rect{fill:currentColor;stroke:none}.book-list.list{flex-direction:column;gap:12px;display:flex}.book-list.grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;display:grid}.book-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .18s,transform .18s,border-color .18s}.book-item:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.book-item.list{grid-template-columns:64px 1fr auto;align-items:start;gap:16px;padding:14px;display:grid}.book-item.list:hover{transform:translateY(-1px)}.book-item.grid{flex-direction:column;gap:12px;padding:14px;display:flex}.book-item.grid:hover{transform:translateY(-3px)}.book-cover{background:var(--surface-2);border-radius:9px;overflow:hidden;box-shadow:inset 0 0 0 1px #0000000a}.book-item.list .book-cover{width:64px;height:92px}.book-item.grid .book-cover{aspect-ratio:2/3;width:100%}.book-cover img{object-fit:cover;width:100%;height:100%;display:block}.gen-cover{color:#fff;text-shadow:0 1px 3px #00000059;flex-direction:column;justify-content:flex-end;gap:3px;width:100%;height:100%;padding:8px;display:flex}.gen-cover-title{-webkit-line-clamp:4;-webkit-box-orient:vertical;font-weight:650;line-height:1.15;display:-webkit-box;overflow:hidden}.gen-cover-author{opacity:.85;-webkit-line-clamp:1;-webkit-box-orient:vertical;font-size:.78em;display:-webkit-box;overflow:hidden}.book-item.list .gen-cover-title{-webkit-line-clamp:3;font-size:.62rem}.book-item.list .gen-cover-author{display:none}.book-item.grid .gen-cover-title{-webkit-line-clamp:5;font-size:1.05rem}.book-body{flex-direction:column;gap:9px;min-width:0;display:flex}.book-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.book-item.grid .book-top{flex-direction:column;gap:8px}.book-top-right{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:14px;display:flex}.book-item.grid .book-top-right{justify-content:flex-start}.book-title-block{flex-direction:column;gap:3px;min-width:0;display:flex}.title{letter-spacing:-.01em;word-break:break-word;margin:0;font-size:1rem;font-weight:600;line-height:1.25}.author{color:var(--muted);margin:0;font-size:.84rem}.status-pill{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;align-self:flex-start;width:fit-content;padding:2px 8px;font-size:.68rem;font-weight:600}.status-pill.want{background:var(--surface-2);color:var(--muted)}.status-pill.reading{background:color-mix(in srgb, var(--amber) 16%, transparent);color:var(--amber)}.status-pill.finished{background:color-mix(in srgb, var(--green) 18%, transparent);color:var(--green)}.tags{flex-wrap:wrap;gap:6px;display:flex}.tag{font:inherit;background:var(--surface-2);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:999px;padding:2px 9px;font-size:.76rem;transition:color .15s,border-color .15s,background .15s}.tag:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.book-progress{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.book-item.grid .book-progress{margin-top:auto}.progress-wrap{flex:1;align-items:center;gap:9px;min-width:150px;display:flex}.progress{background:var(--surface-2);border-radius:999px;flex:1;height:8px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1),background .3s}.progress-fill.done{background:var(--green)}.progress-fill.low{background:var(--yellow)}.progress-pct{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums;min-width:32px;font-size:.74rem;font-weight:600}.page-input{color:var(--muted);align-items:center;gap:6px;font-size:.82rem;display:flex}.page-input input{border:1px solid var(--border-strong);background:var(--surface);width:58px;color:var(--text);font:inherit;text-align:right;border-radius:8px;padding:5px 7px;font-size:.82rem}.book-dates{color:var(--muted);flex-wrap:wrap;align-items:center;gap:4px 8px;font-size:.78rem;display:flex}.date-icon{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;flex-shrink:0;width:13px;height:13px;margin-right:2px}.date-label{color:var(--text);font-weight:600}.date-sep{opacity:.5}.stars{flex-shrink:0;gap:1px;display:inline-flex}.star{cursor:pointer;color:var(--star);background:0 0;border:none;padding:1px;line-height:0}.star svg{width:100%;height:100%;fill:var(--border-strong);transition:fill .12s,transform .12s}.star.filled svg{fill:var(--star)}.star:not(:disabled):hover svg{transform:scale(1.18)}.stars.readonly .star{cursor:default}.notes-toggle{color:var(--accent);cursor:pointer;font:inherit;text-align:center;background:0 0;border:none;padding:2px 0;font-size:.8rem}.notes-toggle:hover{text-decoration:underline}.notes-expanded{color:var(--muted);white-space:pre-wrap;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:10px 12px;font-size:.86rem;line-height:1.5}.book-item.list .notes-expanded{grid-column:1/-1}.book-item.grid .book-actions{flex-wrap:wrap}.book-item.grid .notes-toggle{flex-basis:100%}.gr-toggle{width:fit-content;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;font-size:.8rem;display:inline-flex}.gr-toggle input{width:15px;height:15px;accent-color:var(--accent);cursor:pointer;margin:0}.gr-toggle input:checked+span{color:var(--text)}.book-form>label.gr-toggle{color:var(--muted);flex-direction:row;align-items:center;font-weight:500}.book-actions{flex-direction:column;align-items:stretch;gap:6px;display:flex}.book-item.grid .book-actions{border-top:1px solid var(--border);flex-direction:row;padding-top:12px}.book-item.grid .book-actions .btn{flex:1}.book-item.list .book-actions{align-self:stretch}.book-item.list .notes-toggle{margin-top:auto}.empty{text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:14px;padding:64px 20px;display:flex}.modal-backdrop{z-index:60;background:#00000080;justify-content:center;align-items:flex-start;padding:20px;animation:.15s fade;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:480px;box-shadow:var(--shadow-lg);margin:auto;animation:.18s cubic-bezier(.22,1,.36,1) pop}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px)scale(.98)}}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.modal-head h2{letter-spacing:-.01em;margin:0;font-size:1.15rem;font-weight:650}.book-form{flex-direction:column;gap:14px;padding:18px;display:flex}.book-form>label,.form-row label{color:var(--muted);flex-direction:column;gap:6px;font-size:.82rem;font-weight:600;display:flex}.book-form input[type=text],.book-form input[type=number],.book-form input[type=url],.book-form input[type=date],.book-form textarea,.taginput input{font:inherit;border:1px solid var(--border-strong);background:var(--bg);color:var(--text);border-radius:9px;padding:9px 11px;font-weight:400}.book-form textarea{resize:vertical}:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.book-form input:focus,.book-form textarea:focus,.page-input input:focus,.search:focus,.select:focus{outline:2px solid var(--accent);outline-offset:0;border-color:var(--accent)}.form-row{gap:12px;display:flex}.form-row label{flex:1}.form-cover{flex-direction:column;align-items:center;gap:8px;display:flex}.modal-cover{width:116px;height:174px}.modal-cover .gen-cover-title{font-size:.92rem}.upload-btn{cursor:pointer}.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.taginput{flex-direction:column;gap:8px;display:flex}.taginput .tag{cursor:default;align-items:center;gap:4px;display:inline-flex}.taginput .tag button{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.95rem;line-height:1}.taginput .tag button:hover{color:var(--danger)}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}@media (width<=720px){.stats-strip{grid-template-columns:repeat(3,1fr)}.stat:nth-child(4),.stat:nth-child(5){grid-column:span 1}}@media (width<=600px){.app{padding:0 14px 48px}.topbar h1{font-size:1.15rem}.stats-strip{grid-template-columns:repeat(2,1fr)}.control-group{gap:8px}.segmented{flex:1;justify-content:space-between}.view-toggle{margin-left:0}.book-item.list{grid-template-columns:56px 1fr;grid-template-areas:"cover body""actions actions"}.book-item.list .book-cover{grid-area:cover}.book-item.list .book-body{grid-area:body}.book-item.list .book-actions{border-top:1px solid var(--border);flex-direction:row;grid-area:actions;padding-top:12px}.book-item.list .book-actions .btn{flex:1}.book-item.list .notes-toggle{margin-top:0}}
