:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#fafaf7;--bg-2:#f4f3ee;--surface:#fff;--surface-2:#faf9f6;--surface-sunk:#f1f1ec;--ink:#0e1116;--ink-2:#1f2937;--muted:#6b7280;--muted-2:#9ca3af;--muted-3:#c0c2bd;--line:#e8e7e0;--line-strong:#d6d4cb;--line-soft:#f0efe9;--accent:#1b4d44;--accent-hover:#143b34;--accent-soft:#1b4d4414;--accent-ring:#1b4d442e;--accent-ink:#fff;--rose:#b42318;--rose-soft:#fef0ef;--gold:#a86614;--gold-soft:#fdf3dc;--blue:#1e4fcf;--blue-soft:#eaf0ff;--green:#15663d;--green-soft:#e9f5ee;--amber:#92400e;--amber-soft:#fef3c7;--s-wishlist:#b45309;--s-queued:#6b7280;--s-reading:#1b4d44;--s-paused:#a16207;--s-finished:#166534;--s-abandoned:#b42318;--font-sans:"Inter var", "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif:"Source Serif 4", "Iowan Old Style", "Charter", "Georgia", serif;--font-mono:ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, monospace;--r-xs:4px;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-pill:999px;--shadow-1:0 1px 1px #0f11150a, 0 0 0 1px #0f11150a;--shadow-2:0 1px 2px #0f11150d, 0 4px 12px #0f11150d;--shadow-cover:0 1px 1px #0f11150f, 0 8px 18px #0f111514, 0 22px 44px #0f11150d;--shadow-panel:0 24px 80px #0f11152e, 0 0 0 1px #0f11150a;--ease:cubic-bezier(.16, 1, .3, 1);--ease-out:cubic-bezier(.2, .8, .2, 1);--ease-spring:cubic-bezier(.34, 1.36, .64, 1);--d-fast:.12s;--d-base:.18s;--d-slow:.28s}@supports (font-variation-settings:normal){:root{--font-sans:"Inter var", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}}*{box-sizing:border-box}html,body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-feature-settings:"ss01", "cv11", "cv02", "cv03";font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;line-height:1.5}body{background:radial-gradient(1200px 600px at 80% -200px, #1b4d440a, transparent 60%), radial-gradient(900px 600px at -10% 0%, #a866140a, transparent 60%), var(--bg);min-height:100vh}::selection{background:var(--accent-soft);color:var(--accent)}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:0;padding:0}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--accent-ring);outline-offset:2px;border-radius:var(--r-sm)}h1,h2,h3,h4,h5,p{margin:0}.app{grid-template-rows:auto 1fr;min-height:100vh;display:grid}.app-header{z-index:30;-webkit-backdrop-filter:saturate(140%)blur(14px);border-bottom:1px solid var(--line-soft);background:#fafaf7c7;position:sticky;top:0}.app-header-inner{justify-content:space-between;align-items:center;gap:18px;max-width:1440px;margin:0 auto;padding:14px 28px;display:flex}.brand{align-items:center;gap:10px;display:inline-flex}.brand-mark{background:var(--ink);color:#fafaf7;border-radius:7px;place-items:center;width:26px;height:26px;display:inline-grid}.brand-name{color:var(--ink);letter-spacing:-.011em;font-size:14px;font-weight:600}.brand-divider{background:var(--line-strong);width:1px;height:14px}.brand-tag{color:var(--muted);font-size:13px;font-weight:450}.header-meta{align-items:center;gap:4px;display:inline-flex}.header-stat{border-radius:var(--r-pill);color:var(--ink-2);font-variant-numeric:tabular-nums;letter-spacing:-.005em;align-items:center;gap:6px;padding:6px 10px;font-size:12.5px;font-weight:550;display:inline-flex}.header-stat svg{color:var(--muted-2)}.header-stat em{color:var(--muted);font-style:normal;font-weight:450}.header-link{border-radius:var(--r-pill);color:var(--ink-2);transition:background var(--d-base) var(--ease), color var(--d-base) var(--ease);background:0 0;align-items:center;gap:4px;margin-left:6px;padding:6px 10px;font-size:12.5px;font-weight:550;display:inline-flex}.header-link:hover{background:var(--surface);box-shadow:var(--shadow-1);color:var(--ink)}.workspace{grid-template-columns:minmax(0,1fr) 380px;align-items:start;gap:56px;width:100%;max-width:1440px;margin:0 auto;padding:36px 28px 80px;display:grid}.discover{gap:48px;min-width:0;display:grid}.shelf{align-self:start;min-width:0;position:sticky;top:76px}.hero{gap:28px;display:grid}.hero-copy{gap:10px;max-width:560px;display:grid}.hero-title{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--ink);font-size:clamp(28px,1.4rem + 1.2vw,38px);font-weight:500;line-height:1.12}.hero-title em{color:var(--accent);font-style:italic;font-weight:500}.hero-sub{color:var(--muted);max-width:52ch;font-size:14.5px;line-height:1.55}.hero-search{gap:0;display:grid}.search-bar{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);height:52px;box-shadow:var(--shadow-1);transition:border-color var(--d-base) var(--ease), box-shadow var(--d-base) var(--ease);align-items:stretch;gap:0;padding:0 6px 0 16px;display:flex;position:relative}.search-bar:focus-within{border-color:var(--accent-ring);box-shadow:0 0 0 4px var(--accent-soft), var(--shadow-1)}.search-bar>svg{color:var(--muted);flex:none;align-self:center;margin-right:12px}.search-bar input{min-width:0;height:100%;color:var(--ink);letter-spacing:-.005em;background:0 0;border:0;outline:0;flex:1;align-self:center;padding:0;font-size:15px;font-weight:450}.search-bar input::placeholder{color:var(--muted-2);font-weight:400}.search-count{border-radius:var(--r-pill);background:var(--surface-sunk);height:22px;color:var(--muted);font-variant-numeric:tabular-nums;align-self:center;align-items:center;margin-right:8px;padding:0 8px;font-size:11.5px;font-weight:550;display:inline-flex}.search-loading{align-self:center;align-items:center;gap:3px;margin-right:8px;display:inline-flex}.search-loading span{background:var(--accent);opacity:.4;border-radius:999px;width:4px;height:4px;animation:1.1s ease-in-out infinite searchPulse}.search-loading span:nth-child(2){animation-delay:.15s}.search-loading span:nth-child(3){animation-delay:.3s}@keyframes searchPulse{0%,to{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}.search-kbd{border:1px solid var(--line);background:var(--surface-2);min-width:22px;height:22px;color:var(--muted);font-family:var(--font-mono);border-bottom-width:2px;border-radius:5px;place-items:center;padding:0 6px;font-size:11px;display:inline-grid}.search-divider{background:var(--line);flex:none;align-self:center;width:1px;height:22px;margin:0 6px 0 4px}.search-controls{flex:none;align-items:stretch;gap:2px;display:inline-flex}.select-field{align-self:center;align-items:center;display:inline-flex;position:relative}.select-trigger{height:30px;color:var(--ink-2);letter-spacing:-.005em;transition:background var(--d-fast) var(--ease), color var(--d-fast) var(--ease);background:0 0;border-radius:6px;align-items:center;gap:6px;padding:0 8px 0 10px;font-size:12.5px;font-weight:500;display:inline-flex}.select-field:hover .select-trigger{background:var(--surface-sunk)}.select-field:focus-within .select-trigger{background:var(--surface-sunk);box-shadow:0 0 0 2px var(--accent-soft)}.select-label{color:var(--muted);font-weight:450}.select-value{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;max-width:14ch;font-weight:550;overflow:hidden}.select-trigger svg{color:var(--muted-2);transition:transform var(--d-fast) var(--ease);margin-left:0}.select-field:hover .select-trigger svg{color:var(--muted)}.select-field select{opacity:0;cursor:pointer;appearance:none;width:100%;height:100%;font:inherit;border:0;padding:4px;position:absolute;inset:0}.results{gap:18px;display:grid}.results-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:end;gap:16px;padding-bottom:14px;display:flex}.results-title h2{font-family:var(--font-serif);letter-spacing:-.015em;color:var(--ink);font-size:22px;font-weight:500;line-height:1.2}.results-title p{color:var(--muted);max-width:60ch;margin-top:4px;font-size:13px}.result-pill{border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent);align-items:center;gap:6px;padding:5px 10px;font-size:11.5px;font-weight:550;display:inline-flex}.result-pill .dot{background:var(--accent);border-radius:999px;width:6px;height:6px;animation:1.4s ease-in-out infinite resultPulse}@keyframes resultPulse{0%,to{opacity:.4}50%{opacity:1}}.book-grid{grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:28px 22px;display:grid}.book-card{text-align:left;background:0 0;border:0;grid-template-rows:auto auto;gap:14px;display:grid}.book-cover-button{aspect-ratio:2/3;border-radius:var(--r-md);background:var(--surface-sunk);width:100%;box-shadow:var(--shadow-cover);transition:transform var(--d-slow) var(--ease), box-shadow var(--d-slow) var(--ease);display:block;position:relative;overflow:hidden}.book-card:hover .book-cover-button{transform:translateY(-2px);box-shadow:0 1px 1px #0f11150f,0 12px 22px #0f11151f,0 28px 56px #0f111514}.book-cover{object-fit:cover;width:100%;height:100%;transition:transform var(--d-slow) var(--ease);display:block}.book-card:hover .book-cover{transform:scale(1.03)}.cover-fallback{color:#fafaf7;width:100%;height:100%;font-family:var(--font-serif);text-align:center;background:linear-gradient(#ffffff0a,#0000000f),linear-gradient(160deg,#1e2a32 0%,#0e1116 100%);place-content:center;gap:8px;padding:16px;display:grid}.fallback-mark{letter-spacing:-.02em;font-size:38px;font-style:italic;font-weight:500;line-height:1}.fallback-label{font-family:var(--font-sans);color:#fafaf7a6;letter-spacing:.02em;text-transform:uppercase;font-size:11.5px;font-weight:500;display:block}.book-cover.compact,.cover-fallback.compact{border-radius:var(--r-sm);aspect-ratio:auto;width:44px;height:64px;box-shadow:var(--shadow-1);padding:6px}.cover-fallback.compact .fallback-mark{font-size:20px}.cover-fallback.compact .fallback-label{display:none}.saved-badge{z-index:2;border-radius:var(--r-pill);-webkit-backdrop-filter:blur(8px);color:#fafaf7;letter-spacing:-.005em;background:#0f1115c7;align-items:center;gap:4px;padding:4px 8px 4px 6px;font-size:11px;font-weight:550;display:inline-flex;position:absolute;top:10px;left:10px}.book-overlay{opacity:0;transition:opacity var(--d-base) var(--ease);pointer-events:none;background:linear-gradient(#0000 55%,#0f11158c 100%);position:absolute;inset:0}.book-card:hover .book-overlay{opacity:1}.book-quick-actions{opacity:0;transition:opacity var(--d-base) var(--ease), transform var(--d-base) var(--ease);justify-content:flex-end;align-items:center;gap:6px;display:flex;position:absolute;bottom:10px;left:10px;right:10px;transform:translateY(4px)}.book-card:hover .book-quick-actions,.book-card:focus-within .book-quick-actions{opacity:1;pointer-events:auto;transform:translateY(0)}.q-btn{-webkit-backdrop-filter:blur(6px);width:28px;height:28px;color:var(--ink);transition:transform var(--d-fast) var(--ease), background var(--d-fast) var(--ease);cursor:pointer;background:#fafaf7eb;border-radius:7px;place-items:center;display:inline-grid;box-shadow:0 1px 2px #0f11152e}.q-btn:hover{background:#fff;transform:translateY(-1px)}.q-btn.is-active{background:var(--ink);color:#fafaf7}.q-btn.is-active.heart{background:var(--rose);color:#fff}.book-body{gap:6px;padding:0 2px;display:grid}.book-title{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--ink);-webkit-line-clamp:2;line-clamp:2;overflow-wrap:anywhere;-webkit-box-orient:vertical;font-size:15px;font-weight:500;line-height:1.25;display:-webkit-box;overflow:hidden}.book-author{color:var(--muted);-webkit-line-clamp:1;line-clamp:1;letter-spacing:-.005em;-webkit-box-orient:vertical;font-size:12.5px;font-weight:450;display:-webkit-box;overflow:hidden}.book-meta-row{flex-wrap:wrap;align-items:center;gap:6px;min-height:18px;margin-top:2px;display:flex}.meta-chip{background:var(--surface-sunk);height:18px;color:var(--muted);font-variant-numeric:tabular-nums;border-radius:4px;align-items:center;padding:0 6px;font-size:11px;font-weight:500;display:inline-flex}.meta-chip.subtle{color:var(--muted-2);background:0 0;padding-left:0}.library-board{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);grid-template-rows:auto auto 1fr;gap:16px;max-height:calc(100vh - 100px);padding:20px;display:grid;overflow:hidden}.library-header{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:start;gap:12px;padding-bottom:14px;display:flex}.library-header h2{font-family:var(--font-serif);letter-spacing:-.012em;color:var(--ink);margin-top:2px;font-size:18px;font-weight:500;line-height:1.15}.eyebrow{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:600}.library-snap{border-radius:var(--r-md);background:var(--surface-2);align-items:center;gap:4px;padding:6px 4px;display:inline-flex}.library-snap span{border-right:1px solid var(--line-soft);text-align:center;gap:1px;min-width:38px;padding:0 8px;display:grid}.library-snap span:last-child{border-right:0}.library-snap strong{color:var(--ink);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600;line-height:1}.library-snap em{color:var(--muted-2);letter-spacing:.04em;text-transform:uppercase;font-size:9.5px;font-style:normal;font-weight:500;line-height:1}.shelf-tabs{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--line-soft);flex-wrap:wrap;gap:4px;padding:4px;display:flex}.shelf-tab{min-width:max-content;height:28px;color:var(--muted);letter-spacing:-.005em;transition:background var(--d-fast) var(--ease), color var(--d-fast) var(--ease);background:0 0;border-radius:5px;flex:auto;justify-content:center;align-items:center;gap:6px;padding:0 10px;font-size:12px;font-weight:500;display:inline-flex}.shelf-tab:hover{color:var(--ink-2);background:#0f11150a}.shelf-tab.is-active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-1)}.tab-count{border-radius:var(--r-pill);background:var(--surface-sunk);min-width:18px;height:16px;color:var(--muted);font-variant-numeric:tabular-nums;place-items:center;padding:0 5px;font-size:10.5px;font-weight:600;display:inline-grid}.shelf-tab.is-active .tab-count{background:var(--accent-soft);color:var(--accent)}.shelf-list{scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent;flex-direction:column;gap:2px;margin:0;padding:0 0 4px;list-style:none;display:flex;overflow:auto}.shelf-list::-webkit-scrollbar{width:8px}.shelf-list::-webkit-scrollbar-thumb{background:var(--line);background-clip:padding-box;border:2px solid #0000;border-radius:999px}.shelf-list::-webkit-scrollbar-thumb:hover{background:var(--line-strong);background-clip:padding-box;border:2px solid #0000}.shelf-item{border-radius:var(--r-md);transition:background var(--d-fast) var(--ease);grid-template-columns:44px minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px 8px;display:grid}.shelf-item:hover{background:var(--surface-2)}.shelf-cover-button{display:block}.shelf-text{gap:4px;min-width:0;display:grid}.shelf-title{font-family:var(--font-serif);letter-spacing:-.005em;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;line-height:1.2;overflow:hidden}.shelf-author{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.shelf-meta{color:var(--muted-2);font-variant-numeric:tabular-nums;align-items:center;gap:6px;margin-top:2px;font-size:11px;font-weight:500;display:inline-flex}.shelf-meta>span{color:var(--muted)}.shelf-rating{color:var(--gold);align-items:center;gap:2px;display:inline-flex}.shelf-badge{border-radius:999px;place-items:center;width:14px;height:14px;display:inline-grid}.shelf-badge.heart{color:var(--rose)}.shelf-actions{opacity:0;transition:opacity var(--d-base) var(--ease), transform var(--d-base) var(--ease);gap:2px;display:inline-flex;transform:translate(4px)}.shelf-item:hover .shelf-actions,.shelf-item:focus-within .shelf-actions{opacity:1;transform:translate(0)}.status-dot{background:var(--muted);border-radius:999px;flex:none;width:7px;height:7px}.dot-wishlist{background:var(--s-wishlist)}.dot-queued{background:var(--s-queued)}.dot-reading{background:var(--s-reading);box-shadow:0 0 0 2px #1b4d442e}.dot-paused{background:var(--s-paused)}.dot-finished{background:var(--s-finished)}.dot-abandoned{background:var(--s-abandoned)}.empty-shelf{border:1px dashed var(--line-strong);border-radius:var(--r-lg);background:var(--surface-2);text-align:center;align-content:center;place-items:center;gap:8px;margin-top:4px;padding:28px 18px;display:grid}.empty-icon{background:var(--surface);width:32px;height:32px;color:var(--accent);border:1px solid var(--line);border-radius:9px;place-items:center;margin-bottom:4px;display:inline-grid}.empty-shelf h3{font-family:var(--font-serif);color:var(--ink);letter-spacing:-.005em;font-size:14.5px;font-weight:500}.empty-shelf p{color:var(--muted);max-width:28ch;font-size:12.5px;line-height:1.5}.btn{background:var(--surface);border:1px solid var(--line);height:36px;color:var(--ink);letter-spacing:-.005em;box-shadow:var(--shadow-1);transition:transform var(--d-fast) var(--ease), background var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease);border-radius:7px;justify-content:center;align-items:center;gap:6px;padding:0 14px;font-size:13px;font-weight:550;display:inline-flex}.btn:hover{background:var(--surface-2);border-color:var(--line-strong)}.btn:active{transform:translateY(1px)}.btn.primary{background:var(--ink);color:#fafaf7;border-color:var(--ink)}.btn.primary:hover{background:#1a1f27;border-color:#1a1f27}.btn.ghost{box-shadow:none;background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--surface);border-color:var(--line)}.btn.danger{color:var(--rose)}.btn.danger:hover{background:var(--rose-soft);border-color:#b423182e}.ghost-btn{width:28px;height:28px;color:var(--muted);transition:background var(--d-fast) var(--ease), color var(--d-fast) var(--ease);background:0 0;border-radius:6px;place-items:center;display:inline-grid}.ghost-btn:hover{background:var(--surface-sunk);color:var(--ink)}.ghost-btn.danger:hover{background:var(--rose-soft);color:var(--rose)}.detail-scrim{z-index:50;-webkit-backdrop-filter:blur(2px);animation:scrimIn .24s var(--ease);background:#0f111552;position:fixed;inset:0}@keyframes scrimIn{0%{opacity:0}to{opacity:1}}.detail{z-index:60;background:var(--surface);border-left:1px solid var(--line);width:min(440px,100vw);box-shadow:var(--shadow-panel);animation:detailIn .28s var(--ease);grid-template-rows:auto 1fr;display:grid;position:fixed;top:0;bottom:0;right:0}@keyframes detailIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.detail-toolbar{border-bottom:1px solid var(--line-soft);-webkit-backdrop-filter:saturate(140%)blur(8px);backdrop-filter:saturate(140%)blur(8px);background:#ffffffdb;justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.detail-eyebrow{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:550}.detail-toolbar-actions{gap:4px;display:inline-flex}.detail-scroll{scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent;gap:24px;padding:24px 24px 32px;display:grid;overflow:auto}.detail-hero{grid-template-columns:92px minmax(0,1fr);align-items:start;gap:18px;display:grid}.detail-cover{aspect-ratio:2/3;border-radius:var(--r-md);width:92px;box-shadow:var(--shadow-cover);overflow:hidden}.detail-cover .book-cover,.detail-cover .cover-fallback{width:100%;height:100%}.detail-headline{gap:6px;min-width:0;display:grid}.detail-title{font-family:var(--font-serif);letter-spacing:-.018em;color:var(--ink);overflow-wrap:anywhere;font-size:22px;font-weight:500;line-height:1.18}.detail-author{color:var(--muted);letter-spacing:-.005em;font-size:13px}.detail-facts{flex-wrap:wrap;align-items:center;gap:6px;margin-top:2px;display:flex}.detail-facts span{border-radius:var(--r-pill);background:var(--surface-sunk);height:20px;color:var(--muted);font-variant-numeric:tabular-nums;align-items:center;padding:0 7px;font-size:11px;font-weight:500;display:inline-flex}.detail-link{color:var(--accent);align-items:center;gap:4px;margin-top:4px;font-size:12.5px;font-weight:550;display:inline-flex}.detail-link:hover{text-underline-offset:3px;text-decoration:underline}.detail-actions{flex-wrap:wrap;gap:8px;display:flex}.detail-section{border-top:1px solid var(--line-soft);gap:12px;padding-top:20px;display:grid}.detail-section-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.detail-section-head h3{font-family:var(--font-sans);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:600}.muted-tag{color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px;font-weight:500}.status-tag{border-radius:var(--r-pill);background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line);align-items:center;gap:6px;padding:4px 9px 4px 7px;font-size:11.5px;font-weight:550;display:inline-flex}.status-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.status-option{background:var(--surface-2);height:32px;color:var(--muted);transition:background var(--d-fast) var(--ease), color var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease);border:1px solid #0000;border-radius:7px;align-items:center;gap:7px;padding:0 10px;font-size:12px;font-weight:500;display:inline-flex}.status-option:hover{background:var(--surface);color:var(--ink);border-color:var(--line)}.status-option.is-active{background:var(--surface);color:var(--ink);border-color:var(--ink);box-shadow:0 0 0 3px #0f11150f}.rating-row{align-items:center;gap:4px;display:inline-flex}.star-btn{width:32px;height:32px;color:var(--muted-3);transition:color var(--d-fast) var(--ease), transform var(--d-fast) var(--ease-spring);background:0 0;border-radius:6px;place-items:center;display:inline-grid}.star-btn:hover{color:var(--gold);transform:scale(1.06)}.star-btn.is-active{color:var(--gold)}.signal-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.signal-btn{background:var(--surface-2);height:36px;color:var(--muted);transition:background var(--d-fast) var(--ease), color var(--d-fast) var(--ease), border-color var(--d-fast) var(--ease);border:1px solid #0000;border-radius:7px;justify-content:center;align-items:center;gap:7px;padding:0 10px;font-size:12.5px;font-weight:500;display:inline-flex}.signal-btn:hover{background:var(--surface);color:var(--ink-2);border-color:var(--line)}.signal-btn.is-active{border-color:#0000}.signal-btn.is-active.like{background:var(--green-soft);color:var(--green)}.signal-btn.is-active.dislike,.signal-btn.is-active.heart{background:var(--rose-soft);color:var(--rose)}.signal-btn.is-active.owned{background:var(--blue-soft);color:var(--blue)}.progress-inputs{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.number-field,.notes-field{gap:5px;display:grid}.number-field span{color:var(--muted);letter-spacing:.02em;text-transform:uppercase;font-size:11px;font-weight:550}.number-field input,.notes-field{border:1px solid var(--line);background:var(--surface);width:100%;height:34px;color:var(--ink);transition:border-color var(--d-fast) var(--ease), box-shadow var(--d-fast) var(--ease);font-variant-numeric:tabular-nums;border-radius:6px;padding:0 10px;font-size:13px;font-weight:500}.notes-field{resize:vertical;height:auto;min-height:96px;font-family:var(--font-sans);color:var(--ink);padding:10px 12px;font-size:13px;font-weight:450;line-height:1.55}.notes-field::placeholder{color:var(--muted-2)}.number-field input:focus,.notes-field:focus{border-color:var(--accent-ring);box-shadow:0 0 0 3px var(--accent-soft);outline:0}.progress-bar{background:var(--surface-sunk);border-radius:999px;width:100%;height:4px;position:relative;overflow:hidden}.progress-bar span{background:var(--accent);border-radius:inherit;height:100%;transition:width var(--d-slow) var(--ease);display:block}.tag-editor{gap:8px;margin-top:4px;display:grid}.tag-input{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px;display:grid}.tag-input input{border:1px solid var(--line);background:var(--surface);border-radius:6px;height:32px;padding:0 10px;font-size:12.5px}.tag-input input:focus{border-color:var(--accent-ring);box-shadow:0 0 0 3px var(--accent-soft);outline:0}.tag-row{flex-wrap:wrap;gap:4px;display:flex}.tag-chip{border-radius:var(--r-pill);background:var(--surface-sunk);height:22px;color:var(--ink-2);transition:background var(--d-fast) var(--ease);align-items:center;gap:4px;padding:0 4px 0 8px;font-size:11.5px;font-weight:500;display:inline-flex}.tag-chip:hover{background:var(--rose-soft);color:var(--rose)}.tag-chip svg{opacity:.5}.tag-chip:hover svg{opacity:1}.detail-foot{border-top:1px solid var(--line-soft);padding-top:16px}.state-panel{border:1px dashed var(--line-strong);border-radius:var(--r-lg);background:var(--surface-2);text-align:center;align-content:center;place-items:center;gap:10px;min-height:280px;padding:36px;display:grid}.state-icon{background:var(--surface);width:36px;height:36px;color:var(--accent);border:1px solid var(--line);box-shadow:var(--shadow-1);border-radius:10px;place-items:center;display:inline-grid}.state-panel h3{font-family:var(--font-serif);letter-spacing:-.012em;color:var(--ink);font-size:18px;font-weight:500}.state-panel p{color:var(--muted);max-width:42ch;font-size:13.5px;line-height:1.55}.state-panel.danger .state-icon{color:var(--rose);background:var(--rose-soft);border-color:#b423182e}.state-panel em{font-family:var(--font-serif);color:var(--ink-2);font-style:italic;font-weight:500}.skeleton-card{pointer-events:none}.skeleton{background:var(--surface-sunk);border-radius:4px;display:block;position:relative;overflow:hidden}.skeleton:after{content:"";animation:shimmer 1.4s var(--ease) infinite;background:linear-gradient(90deg,#0000,#ffffffb3,#0000);position:absolute;inset:0;transform:translate(-100%)}.skeleton-cover{border-radius:var(--r-md);width:100%;height:100%}.skeleton-line{width:70%;height:10px}.skeleton-line.wide{width:92%}.skeleton-line.short{width:44%}@keyframes shimmer{to{transform:translate(100%)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (width<=1180px){.workspace{grid-template-columns:1fr;gap:40px}.shelf{position:static}.library-board{max-height:none}}@media (width<=880px){.app-header-inner{padding:12px 18px}.header-meta{gap:0}.header-stat em{display:none}.workspace{padding:24px 18px 60px}.hero-title{font-size:26px}.search-bar{height:48px}.book-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:22px 16px}}@media (width<=560px){.app-header-inner{padding:12px 14px}.brand-divider,.brand-tag,.header-link{display:none}.workspace{gap:32px;padding:20px 14px 56px}.search-controls{flex-wrap:wrap}.status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.signal-row{grid-template-columns:1fr}.detail{width:100vw}.results-header{flex-direction:column;align-items:start;gap:8px}}
