:root{--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", "Courier New", Courier, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--line-height-tight: 1.2;--line-height-base: 1.5;--line-height-relaxed: 1.75;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--color-bg: #f5f5f5;--color-bg-subtle: #f9f9f9;--color-surface: #fafafa;--color-text: #1a1a1a;--color-text-muted: #4b5563;--color-text-subtle: #6b7280;--color-border: #e5e7eb;--color-border-subtle: #f3f4f6;--color-shadow: rgba(0, 0, 0, .05);--color-accent: #1a1a1a;--color-success: #059669;--color-warning: #d97706;--color-error: #dc2626;--radius-sm: 2px;--radius-md: 4px;--radius-lg: 6px;--transition-fast: .1s cubic-bezier(.4, 0, .2, 1);--transition-base: .15s cubic-bezier(.4, 0, .2, 1);--transition-slow: .2s cubic-bezier(.4, 0, .2, 1);--bg: var(--color-bg);--text: var(--color-text);--muted: var(--color-text-muted);--border: var(--color-border);--accent: var(--color-accent);--radius: var(--radius-lg)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg: #1a1a1a;--color-bg-subtle: #232323;--color-surface: #242424;--color-text: #e5e5e5;--color-text-muted: #9ca3af;--color-text-subtle: #6b7280;--color-border: #3a3a3a;--color-border-subtle: #2a2a2a;--color-shadow: rgba(0, 0, 0, .3);--color-accent: #e5e5e5;--color-success: #10b981;--color-warning: #f59e0b}}:root[data-theme=dark]{--color-bg: #1a1a1a;--color-bg-subtle: #232323;--color-surface: #242424;--color-text: #e5e5e5;--color-text-muted: #9ca3af;--color-text-subtle: #6b7280;--color-border: #3a3a3a;--color-border-subtle: #2a2a2a;--color-shadow: rgba(0, 0, 0, .3);--color-accent: #e5e5e5;--color-success: #10b981;--color-warning: #f59e0b}body{margin:0;background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}body,body *{transition:background-color var(--transition-base),color var(--transition-base),border-color var(--transition-base)}a{color:var(--color-text);text-decoration:none;border-bottom:1px solid var(--color-text-subtle);transition:border-color var(--transition-fast)}a:hover{border-bottom-color:var(--color-text)}.page{display:flex;justify-content:center;width:100%;padding:1rem;box-sizing:border-box}.layout-container{max-width:900px;width:100%;margin:0 auto;padding:var(--space-md)}@media(max-width:640px){.layout-container{padding:var(--space-sm)}}.layout-container nav{display:flex;justify-content:center;margin-bottom:var(--space-sm)}.layout-container main{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);animation:fadeIn .4s ease-out}.layout-container h1{margin:0 0 var(--space-lg) 0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);text-align:center;letter-spacing:-.02em;animation:slideDown .3s ease-out}.insights-toggle{display:flex;align-items:center;gap:var(--space-sm);margin:0 0 var(--space-md) 0;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-muted);transition:color var(--transition-fast)}.insights-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px;flex-shrink:0;accent-color:var(--color-text-muted)}.insights-toggle:hover{color:var(--color-text)}.splash-spinner{position:static!important;display:block;margin:0 auto!important;top:unset!important;right:unset!important}.library-columns{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;width:100%;margin:1rem auto 0}@media(max-width:768px){.library-columns{grid-template-columns:1fr;gap:1.5rem}}.library-column{display:flex;flex-direction:column;gap:.75rem;min-width:180px}.column-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-sm)}@media(max-width:640px){.column-title{font-size:var(--font-size-base);margin-bottom:var(--space-md)}}.column-count{font-weight:var(--font-weight-normal);font-size:var(--font-size-xs);margin-left:var(--space-xs);color:var(--color-text-muted)}.empty-column{font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic}.ascii-art{font-family:monospace;line-height:1em;white-space:pre;margin:1em 0}.search-container{position:relative;width:100%;max-width:100%;margin:0 auto 1rem;box-sizing:border-box}.search-input-wrapper{position:relative;width:100%;box-sizing:border-box}.search-input{width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-family:var(--font-mono);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);outline:none;transition:border-color var(--transition-base);box-sizing:border-box}@media(max-width:640px){.search-input{padding:var(--space-md);font-size:var(--font-size-base)}}.search-input:focus{border-color:var(--color-accent)}.search-spinner{position:absolute;top:50%;right:.75rem;width:1rem;height:1rem;margin-top:-.5rem;border:2px solid var(--color-border-subtle);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-results{position:absolute;top:100%;left:0;width:100%;box-sizing:border-box;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:.25rem;z-index:10;max-height:300px;overflow-y:auto;box-shadow:0 4px 12px var(--color-shadow);animation:slideDown .2s ease-out}.search-result-item{display:flex;align-items:center;padding:var(--space-sm);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.search-result-item:hover{background-color:var(--color-border-subtle);transform:translate(2px)}.search-result-thumb{width:40px;height:60px;object-fit:cover;margin-right:.75rem;flex-shrink:0;border-radius:.25rem}.search-result-meta{display:flex;flex-direction:column;font-size:var(--font-size-sm)}.search-result-title{font-weight:var(--font-weight-semibold);color:var(--color-text)}.search-result-subtitle{color:var(--color-text-muted)}.added-highlight{background-color:var(--color-border-subtle)}.search-results::-webkit-scrollbar{width:6px}.search-results::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}.search-feedback{position:absolute;top:100%;left:0;width:100%;margin-top:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);border-radius:var(--radius-lg);box-sizing:border-box;white-space:normal;word-wrap:break-word}.search-feedback.success{background:#05966914;color:var(--color-success);border:1px solid var(--color-success)}.search-feedback.warning{background:#d9770614;color:var(--color-warning);border:1px solid var(--color-warning)}.search-feedback.error{background:#dc262614;color:var(--color-error);border:1px solid var(--color-error)}.book-card{display:flex;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);position:relative;animation:fadeIn .3s ease-out backwards;transition:transform var(--transition-fast)}@media(max-width:640px){.book-card{padding:var(--space-md) 0;gap:var(--space-md)}}.book-card:hover{transform:translate(2px)}.book-card.menu-active{z-index:1000}.menu-backdrop{position:fixed;inset:0;background:#0000001a;z-index:999;animation:fadeIn .15s ease-out;cursor:default}.book-card:nth-child(1){animation-delay:.05s}.book-card:nth-child(2){animation-delay:.1s}.book-card:nth-child(3){animation-delay:.15s}.book-card:nth-child(4){animation-delay:.2s}.book-card:nth-child(5){animation-delay:.25s}.book-card:nth-child(n+6){animation-delay:.3s}.book-thumbnail{width:48px;height:72px;object-fit:cover;border-radius:var(--radius-sm);transition:transform var(--transition-base),box-shadow var(--transition-base)}@media(max-width:640px){.book-thumbnail{width:64px;height:96px}}.book-card:hover .book-thumbnail{transform:scale(1.05);box-shadow:0 4px 8px var(--color-shadow)}.book-main{flex:1;display:flex;flex-direction:column;gap:2px}.book-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}@media(max-width:640px){.book-title{font-size:var(--font-size-xl)}}.book-author{font-size:var(--font-size-sm);color:var(--color-text-muted)}.book-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);font-family:var(--font-mono)}.book-status{margin-top:var(--space-xs);font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:2px var(--space-xs);background:var(--color-surface)}.book-actions{position:relative}.kebab{background:none;border:none;font-size:18px;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);padding:var(--space-xs);margin:calc(-1 * var(--space-xs));min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.kebab:hover{color:var(--color-text)}.kebab-menu{position:absolute;right:0;top:24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xs);min-width:160px;z-index:1001;box-shadow:0 8px 24px #00000026,0 2px 8px #0000001a;animation:fadeInScale .15s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.menu-item{width:100%;text-align:left;padding:var(--space-xs) var(--space-sm);background:none;border:none;cursor:pointer;color:var(--color-text);transition:background var(--transition-fast);border-radius:var(--radius-sm);min-height:36px}@media(max-width:640px){.menu-item{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);min-height:44px}}.menu-item:hover{background:var(--color-border-subtle)}.menu-item.danger{color:var(--color-error)}.confirm-inline{display:flex;flex-direction:column;gap:var(--space-xs)}.confirm-text{font-size:var(--font-size-sm);color:var(--color-text-muted)}.confirm-actions{display:flex;gap:var(--space-sm)}.confirm-remove{background:var(--color-error);color:#fff;border:none;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);cursor:pointer;transition:opacity var(--transition-fast)}.confirm-remove:hover{opacity:.9}.confirm-cancel{background:none;border:1px solid var(--color-border);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text);transition:background var(--transition-fast)}.confirm-cancel:hover{background:var(--color-border-subtle)}.menu-section{display:flex;flex-direction:column}.menu-divider{height:1px;background:var(--color-border);margin:var(--space-xs) 0}.metadata-view{display:flex;flex-direction:column;gap:0;padding:var(--space-xs) 0;min-width:220px}.metadata-back{width:100%;text-align:left;padding:var(--space-xs) var(--space-sm);background:none;border:none;cursor:pointer;color:var(--color-text-muted);font-size:var(--font-size-sm);transition:color var(--transition-fast);border-radius:var(--radius-sm);margin-bottom:var(--space-xs)}.metadata-back:hover{color:var(--color-text)}.metadata-section{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md)}.metadata-section.book-section{background:#1a1a1a08}.metadata-section.author-section{background:#1a1a1a0d;margin-top:var(--space-sm)}.metadata-row{display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--font-size-sm)}.metadata-label{color:var(--color-text-muted);font-weight:var(--font-weight-medium);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.3px}.metadata-value{color:var(--color-text);font-weight:var(--font-weight-medium);word-break:break-word;padding-left:var(--space-xs);border-left:2px solid rgba(26,26,26,.1)}.insight-block{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border);width:100%;max-width:480px;animation:fadeIn .4s ease-out backwards}.insight-block:nth-child(1){animation-delay:.1s}.insight-block:nth-child(2){animation-delay:.15s}.insight-block:nth-child(3){animation-delay:.2s}.insight-block:nth-child(4){animation-delay:.25s}.insight-block:nth-child(5){animation-delay:.3s}.insight-block:nth-child(6){animation-delay:.35s}.insight-block:nth-child(7){animation-delay:.4s}.insight-block:nth-child(8){animation-delay:.45s}.insight-block:nth-child(n+9){animation-delay:.5s}.insight-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-sm)}.insight-content{display:flex;flex-direction:column;gap:var(--space-sm)}.insight-subtle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--space-sm)}.split-bar-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:var(--font-size-sm);margin-bottom:var(--space-sm)}.split-bar-label{width:100px;color:var(--color-text-muted);flex-shrink:0}.split-bar-bar{flex:1;text-align:left;margin:0 var(--space-sm)}.split-bar-value{width:32px;text-align:right;color:var(--color-text-muted);flex-shrink:0}.dot-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:var(--font-size-sm);margin-bottom:var(--space-sm)}.dot-row-label{width:100px;color:var(--color-text-muted);flex-shrink:0}.dot-row-dots{flex:1;text-align:left;margin:0 var(--space-sm);white-space:nowrap;line-height:1;font-size:var(--font-size-lg);letter-spacing:.2em}.dot{color:var(--color-border)}.dot.filled{color:var(--color-accent)}.dot-row-value{width:32px;text-align:right;color:var(--color-text-muted);flex-shrink:0}.auth-container{max-width:400px;margin:var(--space-3xl) auto;animation:fadeIn .4s ease-out}.auth-container-centered{max-width:400px;margin:var(--space-3xl) auto;text-align:center;animation:fadeIn .4s ease-out}.auth-heading{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-sm)}.auth-subtext{color:var(--color-text-muted);margin-bottom:var(--space-xl)}.auth-success-icon{font-size:var(--font-size-xl);margin-bottom:var(--space-md)}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-sm);color:var(--color-text)}.form-input{width:100%;padding:var(--space-sm) .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-mono);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-base);box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--color-accent)}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-input::placeholder{color:var(--color-text-subtle)}.form-group{margin-bottom:var(--space-lg)}.settings-section{margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-subtle)}.settings-section:last-child{border-bottom:none}.settings-section h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin-bottom:var(--space-md)}.danger-zone h2{color:var(--color-error)}.text-muted{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:var(--space-xs) 0 0 0}.text-error{font-size:var(--font-size-sm);color:var(--color-error);margin:0 0 var(--space-md) 0}.confirm-delete{max-width:400px}.confirm-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.btn{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);font-family:var(--font-mono);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast);border:none;display:inline-flex;align-items:center;justify-content:center;min-height:44px}@media(max-width:640px){.btn{padding:var(--space-md) var(--space-lg);font-size:var(--font-size-base)}}.btn:active{transform:scale(.98)}.btn-primary{background:var(--color-text);color:var(--color-bg);border:1px solid var(--color-text)}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border-subtle);border-color:var(--color-text-muted)}.btn-danger{background:transparent;color:var(--color-error);border:1px solid var(--color-error)}.btn-danger:hover{background:var(--color-error);color:#fff}.btn-compact{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.btn-compact.btn-nav{padding:4px 8px;font-size:13px;min-height:auto}@media(max-width:640px){.btn-compact:not(.btn-nav){padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base)}}.btn-link{background:transparent;color:var(--color-text-muted);border:none;text-decoration:underline;padding:0}.btn-link:hover{color:var(--color-text)}.btn-full{width:100%}:root{--danger-border-light: #d7263d;--danger-border-dark: #ff6b6b;--danger-text-light: #d7263d;--danger-text-dark: #ff6b6b}.danger-zone{background:var(--color-bg);border:2px solid var(--danger-border-light);border-radius:1rem;padding:2rem 1.5rem;margin-bottom:2.5rem;transition:border-color .2s;overflow:hidden}.danger-zone>*:last-child{margin-bottom:0!important}.settings-section.danger-zone{border-bottom:none}.danger-zone h2,.danger-zone .text-error{color:var(--danger-text-light);transition:color .2s}@media(prefers-color-scheme:dark){.danger-zone{background:var(--color-bg);border-color:#ff4d4f}.danger-zone h2,.danger-zone .text-error{color:var(--danger-text-dark)}}.dark .danger-zone{background:var(--color-bg);border-color:#ff4d4f}.dark .danger-zone h2,.dark .danger-zone .text-error{color:var(--danger-text-dark)}.nav-container{margin-bottom:var(--space-xl);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-md);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-sm);position:relative}.nav-links{display:flex;gap:var(--space-lg);flex:1;min-width:0}.nav-link{font-weight:var(--font-weight-medium);text-decoration:none;color:var(--color-text);transition:all var(--transition-fast);white-space:nowrap;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);border-bottom:2px solid transparent;margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm))}.nav-link:hover{color:var(--color-text);border-bottom-color:var(--color-text);background:var(--color-border-subtle)}.nav-link:active{background:var(--color-border);transform:scale(.98)}.nav-center{position:absolute;left:50%;transform:translate(-50%);pointer-events:none;z-index:0}.nav-center .ascii-art{font-size:.7rem;line-height:1.1;margin:0;white-space:pre;font-family:monospace;-webkit-user-select:none;user-select:none;pointer-events:auto}.nav-user-section{display:flex;align-items:center;gap:var(--space-md);flex:1;justify-content:flex-end;position:relative;z-index:1}.nav-user-name{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.nav-auth-buttons{display:flex;gap:var(--space-xs);flex-shrink:0}.settings-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);font-size:20px;width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.settings-btn:hover{background:var(--color-border-subtle);border-color:var(--color-text-muted);color:var(--color-text)}.settings-btn:active{background:var(--color-border);transform:scale(.95)}.theme-toggle{display:flex;align-items:center}.theme-toggle-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text);font-size:var(--font-size-lg);width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.theme-toggle-btn:hover{background:var(--color-border-subtle);border-color:var(--color-text-muted)}.theme-toggle-btn:active{background:var(--color-border);transform:scale(.95)}@media(prefers-color-scheme:light){.theme-toggle-btn.active{background:#00000021;color:inherit;outline:none}}.light .theme-toggle-btn.active{background:#00000021;color:inherit;outline:none}@media(prefers-color-scheme:dark){.theme-toggle-btn.active{background:#ffffff21;color:inherit;outline:none}}.dark .theme-toggle-btn.active{background:#ffffff21;color:inherit;outline:none}@media(max-width:768px){.nav-container{flex-direction:column;align-items:stretch;gap:var(--space-md)}.nav-center{position:static;transform:none;order:0;display:flex;justify-content:center;pointer-events:auto}.nav-links{justify-content:center;order:2}.nav-user-section{order:1;justify-content:center}.nav-auth-buttons{justify-content:center}.nav-user-name{max-width:none}}.message{padding:.75rem var(--space-md);border-radius:var(--radius-lg);margin-bottom:var(--space-md);font-size:var(--font-size-sm)}.message-success{background:#d1fae5;color:var(--color-success);border:1px solid #6ee7b7}.theme-toggle-btn.active{background:#00000021;color:inherit;box-shadow:none;outline:none;transition:background .15s}html[data-theme=dark] .theme-toggle-btn.active,body[data-theme=dark] .theme-toggle-btn.active{background:#ffffff21}.banner-content{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.banner-text{flex:1;color:var(--color-text)}.banner-dismiss:hover{color:var(--color-text);background:var(--color-border-subtle);border-color:var(--color-text-muted)}
