*,:before,:after{box-sizing:border-box}html{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;line-height:1.5}#root{min-height:100dvh}.page-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.stat-row{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px;display:grid}.search-row{background:var(--surface,#fff);border:1px solid var(--border,#303f9f1a);box-shadow:none;border-radius:10px;align-items:center;margin-bottom:16px;padding:0 12px;display:flex}.search-icon{color:var(--ink-faint,#94a3b8);flex-shrink:0;display:flex}.search-input{background:0 0;border:none;outline:none;flex:1;padding:12px 8px;font-size:1rem}.search-clear{cursor:pointer;color:#636366;background:0 0;border:none;font-size:1.25rem}.filter-section{margin-bottom:16px}.filter-label{color:#636366;margin:0 0 8px;font-size:.85rem}.chip-scroll{flex-wrap:wrap;gap:8px;display:flex}.filter-chip{border:1px solid var(--border-strong,#303f9f24);background:var(--surface,#fff);cursor:pointer;color:var(--ink-muted,#707b7c);border-radius:8px;padding:7px 12px;font-size:.8125rem;font-weight:500}.filter-chip.active{border-color:var(--primary,#303f9f);background:var(--primary,#303f9f);color:#fff}.book-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.book-row{text-align:left;cursor:pointer;background:#fff;border:none;border-radius:12px;align-items:center;gap:12px;width:100%;padding:12px;display:flex;box-shadow:0 1px 3px #00000014}.book-thumb{background:var(--surface-2,#f5f6f8);border:1px solid var(--border,#303f9f14);border-radius:8px;flex-shrink:0;place-items:center;width:48px;height:64px;display:grid;overflow:hidden}.book-thumb img{object-fit:cover;width:100%;height:100%}.book-thumb.tiny{width:40px;height:52px}.book-row-title{font-size:1rem;font-weight:600}.book-row-author,.muted{color:#636366;font-size:.9rem}.book-row-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;font-size:.8rem;display:flex}.book-row-cat-pill{text-transform:uppercase;letter-spacing:.05em;background:var(--surface-2,#f5f6f8);color:var(--ink-muted,#707b7c);border:1px solid var(--border,#303f9f1a);border-radius:6px;padding:3px 8px;font-size:.6875rem;font-weight:600}.book-row-cat-pill--compact{padding:2px 6px;font-size:.625rem}.book-row-cats--text{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.lent-badge{background:var(--surface-2,#f5f6f8);color:var(--ink-muted,#707b7c);text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border,#303f9f1a);border-radius:6px;padding:3px 8px;font-size:.6875rem;font-weight:600}.chev{color:#c7c7cc;font-size:1.25rem}.empty{text-align:center;padding:48px 16px}.empty-title{font-size:1.25rem;font-weight:600}.btn-primary{color:#fff;cursor:pointer;background:#007aff;border:none;border-radius:12px;padding:12px 20px;font-weight:600}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary.full{width:100%;margin-top:8px}.btn-google{color:#3c4043;cursor:pointer;background:#fff;border:1px solid #dadce0;border-radius:12px;padding:12px 20px;font-size:.95rem;font-weight:600;transition:box-shadow .15s}.btn-google:hover:not(:disabled){box-shadow:0 1px 3px #3c404340}.btn-google:disabled{opacity:.65;cursor:not-allowed}.btn-google.full{width:100%;margin-top:4px}.btn-secondary{color:#007aff;cursor:pointer;background:#007aff18;border:1px solid #007aff;border-radius:12px;padding:10px 16px}.btn-secondary.full{width:100%}.btn-secondary.small{padding:6px 12px;font-size:.85rem}.btn-success{color:#fff;cursor:pointer;background:#34c759;border:none;border-radius:12px;padding:12px 16px;font-weight:600}.btn-success.full{width:100%}.btn-success.small{padding:8px;font-size:.85rem}.btn-danger{color:#fff;cursor:pointer;background:#ff3b30;border:none;border-radius:12px;padding:10px 16px}.btn-ghost{color:#007aff;cursor:pointer;background:0 0;border:none;font-size:1rem}.modal-backdrop{z-index:100;background:#00000073;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal-backdrop.sub{z-index:200}.modal{background:#fff;border-radius:16px;width:100%;max-width:420px;max-height:90vh;padding:20px}.modal.sheet{border-radius:16px 16px 0 0;flex-direction:column;align-self:end;max-width:520px;max-height:92vh;display:flex;overflow:hidden}@media (width>=640px){.modal.sheet{border-radius:16px;align-self:center;max-height:90vh}}.modal.scroll{overflow-y:auto}.modal.tiny{max-width:320px}.modal-tiny-wide{max-width:min(400px,92vw)}.modal-alert-msg{text-align:left;white-space:pre-line;color:var(--ink,#1a1f2e);margin:0 0 12px;font-size:.875rem;line-height:1.5}.modal-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.modal-head h2{margin:0;font-size:1.15rem}.head-actions{align-items:center;gap:8px;display:flex}.form-block{margin-bottom:16px}.label{margin-bottom:6px;font-size:.95rem;font-weight:600;display:block}.input{background:#e5e5ea;border:none;border-radius:12px;width:100%;padding:12px;font-size:1rem}.input.area{resize:vertical;min-height:80px}.row{display:flex}.row.gap{align-items:center;gap:8px}.row .input{flex:1}.mt{margin-top:8px}.file-btn{color:#007aff;cursor:pointer;background:#007aff18;border-radius:12px;padding:12px 16px;font-weight:600;display:inline-block}.file-btn.full{box-sizing:border-box;text-align:center;width:100%;display:block}.file-btn.is-busy{opacity:.65;pointer-events:none}.hidden-input{display:none}.cover-preview{border-radius:12px;max-height:200px;margin-bottom:8px;display:block}.cover-preview.small{max-height:120px}.cover-preview-wrap{margin-bottom:8px}.category-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.cat-pill{border:1px solid var(--border-strong,#303f9f24);cursor:pointer;background:var(--surface,#fff);color:var(--ink-muted,#707b7c);border-radius:8px;padding:8px 12px;font-size:.8125rem;font-weight:500;transition:background .15s,border-color .15s,color .15s}.cat-pill.on{background:var(--primary,#303f9f);border-color:var(--primary,#303f9f);color:#fff}.success-banner{color:#1a7f37;background:#34c75922;border-radius:8px;padding:10px}.small{font-size:.85rem}.detail-cover{text-align:center;margin-bottom:16px}.detail-cover-img{border-radius:12px;max-height:280px;box-shadow:0 4px 16px #0000001f}.detail-cover-placeholder{background:var(--surface-2,#f5f6f8);border:1px solid var(--border,#303f9f1a);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:10px;height:180px;display:flex}.detail-cover-ph-label{color:var(--ink-muted,#707b7c);font-size:.8125rem;font-weight:600}.detail-title{text-align:center;margin:0 0 4px;font-size:1.35rem}.detail-author{text-align:center;color:#636366;margin:0 0 16px}.detail-cats{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:16px;display:flex}.chip{border-radius:8px;padding:6px 12px;font-size:.8125rem}.chip.chip--neutral{background:var(--surface-2,#f5f6f8);color:var(--ink,#1a1f2e);border:1px solid var(--border,#303f9f1a);font-weight:500}.detail-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;display:grid}.detail-cell{text-align:center;background:#e5e5ea;border-radius:12px;padding:12px}.detail-cell-label{color:#636366;margin-bottom:4px;font-size:.75rem;display:block}.lend-panel{background:var(--surface-2,#f5f6f8);border:1px solid var(--border,#303f9f1a);border-radius:10px;margin-bottom:16px;padding:16px}.lend-panel h3{color:var(--text-title,#303f9f);margin:0 0 8px;font-size:1rem}.detail-actions{margin-top:8px}.scanner-region{background:#000;border-radius:12px;min-height:260px;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;min-height:260px;display:block}.scanner-file-target{pointer-events:none;opacity:0;width:320px;height:240px;position:fixed;top:0;left:-9999px;overflow:hidden}.error-text{color:#ff3b30}.segment{background:#e5e5ea;border-radius:10px;margin-bottom:16px;padding:4px;display:flex}.segment button{cursor:pointer;color:#636366;background:0 0;border:none;border-radius:8px;flex:1;padding:10px;font-weight:600}.segment button.on{color:#007aff;background:#fff;box-shadow:0 1px 2px #00000014}.lent-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.lent-extra{border-top:1px solid #f2f2f7;padding:0 12px 12px}.lent-extra p{margin:6px 0}.overdue{color:#ff3b30;font-weight:600}.status-pill{border-radius:8px;margin-top:6px;padding:2px 10px;font-size:.75rem;display:inline-block}.status-pill.out{color:#ff9500;background:#ff950022}.status-pill.in{color:#248a3d;background:#34c75922}.stats-page .section-title{margin:24px 0 12px;font-size:1.15rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.stat-card{text-align:center;background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 3px #0000000f}.stat-card-val{color:#007aff;font-size:1.5rem;font-weight:700;display:block}.stat-card-title{color:#636366;font-size:.8rem}.stat-list{flex-direction:column;gap:10px;display:flex}.stat-row-bar{background:#fff;border-radius:12px;grid-template-columns:120px 1fr 40px;align-items:center;gap:8px;padding:10px 12px;font-size:.9rem;display:grid}.bar-track{background:#e5e5ea;border-radius:4px;height:8px;overflow:hidden}.bar-fill{border-radius:4px;height:100%}.stat-row-pct{text-align:right;color:#636366;font-size:.85rem}.recent-list{margin:0;padding:0;list-style:none}.recent-row{border-bottom:1px solid #e5e5ea;align-items:center;gap:12px;padding:10px 0;display:flex}.settings-hero{text-align:center;padding:24px 0}.settings-logo-wrap{max-width:min(260px,100%);margin:0 auto 12px}.settings-brand-logo{width:100%;height:auto;display:block}.settings-icon{background:var(--surface-2,#f5f6f8);width:64px;height:64px;color:var(--primary,#303f9f);border:1px solid var(--border,#303f9f1a);border-radius:14px;justify-content:center;align-items:center;margin:0 auto 12px;display:flex}.settings-block{background:#fff;border-radius:12px;margin-bottom:12px;padding:16px;box-shadow:0 1px 3px #0000000f}.settings-block h3{margin:0 0 12px;font-size:1.05rem}.settings-block.danger-zone{border:1px solid #ff3b3044}.settings-stats{margin:0 0 12px;padding-left:20px}.wish-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.wish-card{background:#fff;border-radius:12px;align-items:flex-start;gap:12px;padding:12px;display:flex;box-shadow:0 1px 3px #00000014}.wish-thumb{background:#e5e5ea;border-radius:8px;flex-shrink:0;place-items:center;width:64px;height:96px;display:grid;overflow:hidden}.wish-thumb img{object-fit:cover;width:100%;height:100%}.wish-body{flex:1;min-width:0}.wish-notes{color:#636366;margin:6px 0 0;font-size:.85rem}.wish-menu{position:relative}.wish-menu summary{cursor:pointer;color:#636366;padding:4px 8px;font-weight:700;list-style:none}.wish-menu-pop{z-index:20;background:#fff;border-radius:12px;flex-direction:column;min-width:160px;padding:8px;display:flex;position:absolute;top:100%;right:0;box-shadow:0 4px 24px #00000026}.wish-menu-pop button{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:10px 12px;font-size:.95rem}.wish-menu-pop button.danger{color:#ff3b30}.toast{color:#fff;z-index:300;background:#1c1c1e;border-radius:12px;align-items:center;gap:12px;padding:12px 20px;font-size:.95rem;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast-x{color:#fff;cursor:pointer;background:0 0;border:none;font-size:1.25rem}:root{--font-ui:"Inter", system-ui, -apple-system, sans-serif;--font-script:"Noto Sans Devanagari", "Kohinoor Devanagari", var(--font-ui);--bg-page:#f0f2f5;--ink:#1a1f2e;--text-title:#303f9f;--text-label:#707b7c;--ink-muted:#707b7c;--ink-faint:#94a3b8;--surface:#fff;--surface-2:#f5f6f8;--border:#303f9f1a;--border-strong:#303f9f24;--primary:#303f9f;--primary-dark:#283593;--primary-soft:#e8eaf6;--accent-warm:#c2410c;--accent-soft:#fff7ed;--gradient-accent:linear-gradient(90deg, #2563eb 0%, #9333ea 48%, #ea580c 100%);--success:#059669;--danger:#dc2626;--warn:#d97706;--shadow-card:0 4px 12px #00000014;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 6px 20px #00000012;--shadow-lg:0 12px 32px #0000001a;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}body{min-height:100dvh;font-family:var(--font-ui);color:var(--ink);background:var(--bg-page);margin:0}.theme-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);position:relative;overflow:hidden}.theme-card:before{content:"";background:var(--gradient-accent);border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:4px;position:absolute;top:0;left:0;right:0}.dev-auth-banner{color:#78350f;border-radius:var(--radius-sm);background:#fef3c7;border:1px solid #fcd34d;margin:0 -12px 10px;padding:8px 12px;font-size:.75rem;line-height:1.45}.dev-auth-banner code{background:#ffffffb3;border-radius:3px;padding:0 .2em;font-size:.7rem}.app{flex-direction:column;max-width:720px;min-height:100dvh;margin:0 auto;padding:0 12px 24px;display:flex}@media (width>=900px){.app{max-width:880px}}.app-brand{text-align:center;margin-bottom:14px;padding:28px 22px 24px}.app-brand-bar{background:var(--surface);border-bottom:1px solid var(--border-strong);box-shadow:none;border-radius:0;margin-bottom:0;padding:6px 10px 8px}.app-brand-heading{justify-content:center;align-items:center;margin:0;display:flex}.app-brand-logo{width:100%;max-width:min(300px,96vw);height:auto;display:block}.app-brand-eyebrow{letter-spacing:.2em;text-transform:uppercase;color:var(--text-label);margin:0 0 14px;font-size:.72rem;font-weight:600}.app-brand-title{font-family:var(--font-script), var(--font-ui);color:var(--text-title);letter-spacing:.01em;margin:0;font-size:clamp(1.45rem,4.8vw,2rem);font-weight:700;line-height:1.28}.app-nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;z-index:50;background:var(--surface);border:none;border-bottom:1px solid var(--border-strong);box-shadow:none;border-radius:0;flex-wrap:nowrap;gap:0;margin-top:0;padding:0 4px;display:flex;position:sticky;top:0;overflow-x:auto}.app-nav .nav-tab{z-index:1;position:relative}.app-nav::-webkit-scrollbar{display:none}.nav-tab{min-width:0;color:var(--ink-muted);cursor:pointer;background:0 0;border:none;border-radius:0;flex-direction:column;flex:1 0 auto;align-items:center;gap:6px;padding:12px 8px 14px;font-size:.75rem;font-weight:600;transition:color .15s;display:flex}.nav-tab:hover{color:var(--primary)}.nav-tab.active{color:var(--primary);box-shadow:none;background:0 0}.nav-tab.active:after{content:"";background:var(--primary);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:0;left:10px;right:10px}.nav-tab .nav-svg{opacity:.55;flex-shrink:0;width:20px;height:20px}.nav-tab:hover .nav-svg,.nav-tab.active .nav-svg{opacity:1}.nav-tab .nav-lbl{white-space:nowrap;letter-spacing:.01em}@media (width>=480px){.nav-tab{flex-direction:row;gap:8px;padding:14px 12px 16px;font-size:.8125rem}.nav-tab.active:after{left:14px;right:14px}}.app-main{flex:1;padding-top:16px;padding-bottom:32px}.app-footer-note{border-top:1px solid var(--border-strong);text-align:center;color:var(--ink-muted);margin-top:auto;padding:12px 8px 2px;font-size:.82rem}.app-footer-note a{color:var(--primary);font-weight:600;text-decoration:none}.app-footer-note a:hover{text-decoration:underline}.app-loading{min-height:100dvh;color:var(--ink-muted);flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:24px;font-weight:500;display:flex}.loading-spinner{border:3px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;width:44px;height:44px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.landing{box-sizing:border-box;min-height:100dvh;padding:32px 18px 48px;position:relative}.landing-bg{z-index:0;pointer-events:none;background:radial-gradient(ellipse 130% 90% at 8% -10%, #2563eb11, transparent 55%), radial-gradient(ellipse 100% 80% at 100% 20%, #9333ea0d, transparent 50%), radial-gradient(ellipse 90% 50% at 45% 105%, #ea580c0b, transparent 52%), linear-gradient(180deg, #eef0f4 0%, var(--bg-page) 38%, var(--bg-page) 100%);position:fixed;inset:0}.landing-inner{z-index:1;align-items:start;gap:36px;max-width:1080px;margin:0 auto;display:grid;position:relative}@media (width>=900px){.landing-inner{grid-template-columns:minmax(0,1.08fr) minmax(320px,400px);align-items:center;gap:52px;padding-top:12px}}.landing-hero{position:relative}.landing-hero-accent{display:none}@media (width>=640px){.landing-hero{padding-left:22px}.landing-hero-accent{background:var(--gradient-accent);opacity:.92;border-radius:4px;width:4px;height:calc(100% - 48px);max-height:220px;display:block;position:absolute;top:4px;left:0}}.landing-logo{width:100%;max-width:min(280px,100%);height:auto;margin:0 0 10px;display:block}.landing-title{font-family:var(--font-script), var(--font-ui);color:var(--text-title);letter-spacing:.01em;margin:0 0 20px;font-size:clamp(1.95rem,4.8vw,2.5rem);font-weight:700;line-height:1.18}.landing-tagline{color:var(--ink);max-width:34em;margin:0 0 16px;font-size:clamp(1.05rem,2.2vw,1.2rem);font-weight:500;line-height:1.58}.landing-sub{color:var(--ink-muted);max-width:36em;margin:0;font-size:.9375rem;line-height:1.68}.landing-sub-strong{color:var(--primary);font-weight:600}.landing-section-head{border-bottom:1px solid var(--border-strong);margin-top:36px;margin-bottom:16px;padding-bottom:12px}.landing-section-label{font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase;color:var(--text-title);margin:0 0 4px;font-size:.8125rem;font-weight:700}.landing-section-desc{color:var(--ink-muted);margin:0;font-size:.875rem}.landing-features{grid-template-columns:1fr;gap:12px;margin:0;padding:0;list-style:none;display:grid}@media (width>=640px){.landing-features{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}}.landing-feature{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;gap:14px;padding:20px 20px 22px;transition:box-shadow .22s,border-color .22s,transform .22s;display:flex;box-shadow:0 2px 8px #0000000a}.landing-feature:hover{border-color:#303f9f24;transform:translateY(-2px);box-shadow:0 8px 24px #303f9f14}.landing-feature-icon-wrap{background:linear-gradient(145deg, var(--primary-soft) 0%, #e8eaf6 100%);width:48px;height:48px;color:var(--primary);border:1px solid #303f9f14;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.landing-svg-ico{width:22px;height:22px}.landing-feature-body{min-width:0}.landing-feature-title{font-family:var(--font-ui);color:var(--text-title);letter-spacing:-.01em;margin:0 0 8px;font-size:.9375rem;font-weight:600}.landing-feature-text{color:var(--ink-muted);margin:0;font-size:.875rem;line-height:1.55}.landing-aside{flex-direction:column;gap:16px;display:flex}.landing-cta{text-align:left;border:1px solid var(--border-strong);padding:28px 24px 22px}.landing-cta-logo{width:100%;max-width:200px;height:auto;margin:0 0 14px;display:block}.landing-cta-badge{letter-spacing:.16em;text-transform:uppercase;color:var(--primary);background:var(--primary-soft);border:1px solid #303f9f1a;border-radius:999px;margin-bottom:16px;padding:7px 12px;font-size:.625rem;font-weight:700;display:inline-block}.landing-cta-title{font-family:var(--font-ui);color:var(--text-title);letter-spacing:-.02em;margin:0 0 12px;font-size:1.375rem;font-weight:700;line-height:1.25}.landing-cta-lead{color:var(--ink-muted);margin:0 0 20px;font-size:.90625rem;line-height:1.6}.landing-cta-actions{background:var(--surface-2);border-radius:var(--radius-md);border:1px solid var(--border);padding:18px 16px 16px}.landing-btn-google{color:#3c4043;cursor:pointer;background:#fff;border:1px solid #dadce0;border-radius:8px;justify-content:center;align-items:center;gap:12px;width:100%;padding:13px 20px;font-family:inherit;font-size:.9375rem;font-weight:600;transition:box-shadow .2s,border-color .2s,background .2s;display:flex}.landing-btn-google:hover:not(:disabled){background:#fafafa;border-color:#c6c9ce;box-shadow:0 1px 2px #3c40431f,0 2px 10px #3c404314}.landing-btn-google:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.landing-btn-google:disabled{opacity:.65;cursor:not-allowed}.landing-google-g{flex-shrink:0;width:20px;height:20px}.landing-cta-error{color:var(--danger);margin:14px 0 0;font-size:.875rem;line-height:1.45}.landing-cta-foot{color:var(--ink-faint);text-align:center;margin:16px 0 0;font-size:.75rem;line-height:1.45}@media (prefers-reduced-motion:reduce){.landing-feature{transition:none}.landing-feature:hover{transform:none}.landing-btn-google{transition:none}}.setup-screen{place-items:center;min-height:100dvh;padding:24px 16px;display:grid}.setup-card{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-card);text-align:left;border:none;padding:28px 26px 26px;position:relative;overflow:hidden}.setup-card-head{margin-bottom:4px}.setup-card:before{content:"";background:var(--gradient-accent);border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:4px;position:absolute;top:0;left:0;right:0}.setup-brand-latin{letter-spacing:.2em;color:var(--text-label);margin:0 0 10px;font-size:.72rem;font-weight:600}.setup-brand-logo{width:100%;max-width:220px;height:auto;margin:0 0 12px;display:block}.setup-card-title--after-logo{margin-top:0}.setup-card-title{font-family:var(--font-script), var(--font-ui);color:var(--text-title);margin:0 0 14px;font-size:clamp(1.4rem,4.2vw,1.75rem);font-weight:700;line-height:1.3}.setup-lead{color:var(--ink-muted);margin:0 0 16px;font-size:.95rem;line-height:1.55}.setup-lead code{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:2px 6px;font-size:.85em}.setup-pre{background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border);padding:14px;font-size:.78rem;line-height:1.5;overflow:auto}.setup-hint{color:var(--ink-muted);margin-top:14px;font-size:.88rem;line-height:1.55}.setup-hint p{margin:0 0 10px}.setup-hint p:last-child{margin-bottom:0}.setup-hint code{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:2px 6px;font-size:.82em}.sign-in-error{color:var(--danger);margin-top:14px;font-size:.88rem;line-height:1.45}.bootstrap-error-pre{white-space:pre-wrap;word-break:break-word}.tab-page{padding:4px 0 16px}.page-header{margin-bottom:20px}.page-header h1,.page-heading{color:var(--text-title);letter-spacing:-.02em;margin:0;font-size:1.5rem;font-weight:700}.app-title{font-family:var(--font-script);color:var(--text-title);font-size:clamp(1.2rem,4.2vw,1.55rem);font-weight:700;line-height:1.35}.icon-btn{background:linear-gradient(160deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;cursor:pointer;width:44px;height:44px;box-shadow:var(--shadow-md);border:none;border-radius:50%;font-size:1.35rem;line-height:1;transition:transform .15s}.icon-btn--fab{background:var(--primary);width:42px;height:42px;box-shadow:var(--shadow-sm);font-size:unset;border-radius:10px;justify-content:center;align-items:center;display:flex}.icon-btn--fab:hover{background:var(--primary-dark);transform:none}.icon-btn--fab:active{transform:scale(.98)}.icon-btn--fab-text{width:auto;min-width:unset;height:auto;min-height:42px;font-family:var(--font-ui);letter-spacing:.02em;white-space:nowrap;gap:8px;padding:9px 14px 9px 12px;font-size:.8125rem;font-weight:600}.icon-btn--fab-text svg{flex-shrink:0}.icon-btn:hover:not(.icon-btn--fab){transform:scale(1.05)}.icon-btn:active:not(.icon-btn--fab){transform:scale(.97)}.stat-mini{background:var(--surface);text-align:center;border:1px solid var(--border);box-shadow:none;border-left:3px solid var(--primary);border-radius:10px;padding:14px 10px 12px}.stat-mini-ico{color:var(--ink-faint);justify-content:center;align-items:center;margin-bottom:8px;display:flex}.stat-mini--primary{border-left-color:var(--primary)}.stat-mini--primary .stat-mini-ico,.stat-mini--primary .stat-mini-val{color:var(--primary)}.stat-mini--success{border-left-color:#047857}.stat-mini--success .stat-mini-ico,.stat-mini--success .stat-mini-val{color:#0f766e}.stat-mini--warn{border-left-color:#b45309}.stat-mini--warn .stat-mini-ico,.stat-mini--warn .stat-mini-val{color:#c2410c}.stat-mini .stat-mini-val{letter-spacing:-.02em;font-size:1.35rem;font-weight:700;display:block}.stat-mini .stat-mini-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-label);margin-top:4px;font-size:.6875rem;font-weight:600}.stat-row{gap:10px}.search-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.filter-label{color:var(--text-label);font-size:.82rem;font-weight:600}.search-input{color:var(--ink)}.filter-chip{border:1px solid var(--border-strong);background:var(--surface);transition:background .15s,border-color .15s}.filter-chip:hover{color:var(--ink);border-color:#303f9f59}.filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff!important}.book-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);transition:box-shadow .2s,transform .15s}.book-row:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.muted{color:var(--ink-muted)}.btn-primary{background:linear-gradient(160deg, var(--primary) 0%, var(--primary-dark) 100%);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.btn-primary.pink{background:linear-gradient(145deg,#db2777 0%,#be185d 100%)}.btn-secondary{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);border-radius:var(--radius-md)}.btn-ghost{color:var(--primary);font-weight:600}.btn-success{background:linear-gradient(145deg, var(--success) 0%, #047857 100%);border-radius:var(--radius-md)}.btn-danger{background:linear-gradient(145deg, var(--danger) 0%, #b91c1c 100%);border-radius:var(--radius-md)}.btn-danger.plain{color:var(--danger);background:0 0}.input{background:var(--surface-2);border:1px solid var(--border);color:var(--ink);border-radius:var(--radius-md)}.file-btn{background:var(--primary-soft);color:var(--primary);border-radius:var(--radius-md)}.modal{border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:var(--radius-lg)}.modal.sheet{background:var(--surface)}.detail-cell{background:var(--surface-2);border:1px solid var(--border)}.settings-block{background:var(--surface);box-shadow:var(--shadow-card);border-radius:var(--radius-lg);border:none}.settings-page h2,.stats-page .section-title,.stats-page .page-header h1,.settings-page .page-header h1{color:var(--text-title)}.wish-card,.lent-card{border:1px solid var(--border)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nav-tab:focus-visible,.btn-primary:focus-visible,.icon-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.stat-card{border:1px solid var(--border);box-shadow:none;background:var(--surface);text-align:center;border-radius:10px;padding:16px 12px}.stat-card-ico{color:var(--ink-faint);justify-content:center;margin-bottom:8px;display:flex}.stat-card-ico svg{display:block}.stat-card-val{letter-spacing:-.03em;color:var(--primary);font-size:1.45rem;font-weight:700;display:block}.stat-card-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-label);margin-top:4px;font-size:.6875rem;font-weight:600}.stat-card--tone-primary .stat-card-val,.stat-card--tone-primary .stat-card-ico{color:var(--primary)}.stat-card--tone-success .stat-card-val,.stat-card--tone-success .stat-card-ico{color:#0f766e}.stat-card--tone-warn .stat-card-val,.stat-card--tone-warn .stat-card-ico{color:#c2410c}.stat-card--tone-neutral .stat-card-val,.stat-card--tone-neutral .stat-card-ico{color:var(--ink-muted)}.segment{background:var(--surface-2);border:1px solid var(--border)}.segment button.on{color:var(--primary);background:var(--surface)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.library-page-head{align-items:center}.category-filter{width:100%;position:relative}.category-filter__measure{pointer-events:none;visibility:hidden;white-space:nowrap;flex-wrap:nowrap;align-items:center;gap:10px;display:flex;position:absolute;top:0;left:-9999px}.category-filter__line{flex-wrap:nowrap;align-items:center;gap:10px;width:100%;display:flex}.category-filter__line .filter-chip{flex-shrink:0}.category-filter__line .filter-chip--more{margin-left:auto}.filter-chip--more{color:var(--primary);background:var(--surface-2);border-style:dashed}.filter-chip--more:hover{color:var(--primary-dark);border-color:#303f9f73}.category-filter__expanded{border-top:1px solid var(--border);flex-wrap:wrap;gap:10px;margin-top:12px;padding-top:12px;display:flex}.category-filter__expanded[hidden]{display:none!important}.chip-scroll--h{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:10px;padding-bottom:6px;overflow-x:auto}.filter-chip-glyph{margin-right:4px}.stat-mini-ico{opacity:.85;margin-bottom:4px;font-size:1.1rem;display:block}.book-thumb--lg{border-radius:10px;width:60px;height:80px}.book-row-cats{align-items:center;gap:4px;display:inline-flex}.book-row-pages{flex-basis:100%;width:100%;margin-top:2px}.book-thumb-fallback-inner{width:100%;height:100%;color:var(--ink-faint);background:var(--surface-2);justify-content:center;align-items:center;display:flex}.add-book-head{justify-content:flex-end}.add-book-hero{text-align:center;padding:8px 0 20px}.add-book-hero-icon{color:var(--primary);justify-content:center;margin-bottom:12px;display:flex}.add-book-hero-title{color:var(--ink);margin:0 0 6px;font-size:1.35rem;font-weight:700}.add-book-hero-sub{margin:0;font-size:.95rem}.cover-actions{flex-direction:column;gap:10px;display:flex}@media (width>=480px){.cover-actions{flex-flow:wrap}}.file-btn--primary{background:linear-gradient(160deg, var(--primary) 0%, var(--primary-dark) 100%);text-align:center;justify-content:center;color:#fff!important}.detail-cell{flex-direction:column;align-items:center;gap:4px;padding:14px 10px;display:flex}.detail-cell-ico{color:var(--ink-muted);justify-content:center;align-items:center;margin-bottom:2px;display:flex}.detail-cell-ico svg{display:block}.detail-cell span:not(.detail-cell-label):not(.detail-cell-ico){font-size:.95rem;font-weight:600}.detail-cell-mono{word-break:break-all;font-family:ui-monospace,monospace;font-size:.85rem}.detail-cover-ph-ico{margin-bottom:8px;font-size:3rem;display:block}.lend-panel-heading{color:var(--text-title);align-items:center;gap:10px;font-size:1rem;font-weight:600;display:flex}.lend-panel-ico{color:var(--primary);display:flex}.lend-borrower{margin:0 0 8px;font-size:1.15rem;font-weight:600}.lend-notes{margin-top:8px}.stats-grid--4{grid-template-columns:repeat(2,minmax(0,1fr))}@media (width>=640px){.stats-grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}}.stat-row-bar{grid-template-columns:minmax(100px,140px) 1fr 44px;align-items:center}.stat-row-mid{flex-direction:column;gap:6px;min-width:0;display:flex}.stat-row-count{font-size:.8rem}.bar-fill--primary{background:var(--primary)}.settings-rows{flex-direction:column;gap:14px;display:flex}.settings-row{align-items:flex-start;gap:12px;display:flex}.settings-row-ico{background:var(--surface-2);width:36px;height:36px;color:var(--ink-muted);border:1px solid var(--border);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-row-ico svg{display:block}.settings-row-label{color:var(--ink-muted);margin-bottom:2px;font-size:.8rem}.settings-row--link{color:inherit;border-radius:var(--radius-sm);margin:-4px;padding:4px;text-decoration:none}.settings-row--link:hover{background:var(--surface-2)}.link-accent{color:var(--primary);font-weight:600}.settings-clear-final ul{color:var(--ink-muted);margin:8px 0 12px;padding-left:20px;font-size:.9rem}
