:root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary:#fff;--bg-secondary:#f4f4f4;--bg-tertiary:#f8f9fa;--bg-card:#fff;--bg-hover:#f0f0f0;--bg-input:#fff;--bg-overlay:#00000080;--bg-overlay-heavy:#000000b3;--bg-overlay-card:#ffffffe6;--text-primary:#000;--text-secondary:#555;--text-muted:#777;--text-placeholder:#a6a0a0;--text-inverse:#fff;--border-color:#e0e0e0;--border-light:#f0f0f0;--border-medium:#ddd;--border-dark:#ccc;--link-color:#2563eb;--link-hover:#1d4ed8;--accent-primary:#007bff;--accent-primary-hover:#0056b3;--success:#10b981;--success-light:#e8f5e8;--success-dark:#2e7d32;--error:#e74c3c;--error-light:#fee2e2;--warning:#ff9100;--progress-green:#44d7b6;--progress-blue:#00aeff;--progress-red:#ff000c;--shadow-light:#0000000f;--shadow-medium:#0000001a;--shadow-heavy:#0003;--shadow-book:#00000040;--gradient-skeleton:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);--gradient-divider:linear-gradient(90deg,#0000,#ddd,#0000);--gradient-insight:linear-gradient(135deg,#667eea,#764ba2);--navbar-bg:#fff;--navbar-border:#e2e2e2;--dropdown-bg:#f3eded;--tag-bg:#f3f4f6;--stat-bg:#f8f8f8;--toggle-bg:#ccc;--toggle-active:#44d7b6;background-color:#fff;background-color:var(--bg-primary);color:#000;color:var(--text-primary);color-scheme:light dark;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-synthesis:none;font-weight:400;line-height:1.5;text-rendering:optimizeLegibility}@media (prefers-color-scheme:dark){:root{--bg-primary:#121212;--bg-secondary:#1e1e1e;--bg-tertiary:#252525;--bg-card:#1e1e1e;--bg-hover:#2d2d2d;--bg-input:#2d2d2d;--bg-overlay:#000000b3;--bg-overlay-heavy:#000000d9;--bg-overlay-card:#1e1e1ee6;--text-primary:#f0f0f0;--text-secondary:#b0b0b0;--text-muted:#888;--text-placeholder:#666;--text-inverse:#121212;--border-color:#3d3d3d;--border-light:#2d2d2d;--border-medium:#444;--border-dark:#555;--link-color:#60a5fa;--link-hover:#93c5fd;--accent-primary:#3b82f6;--accent-primary-hover:#60a5fa;--success:#34d399;--success-light:#1a3d2e;--success-dark:#6ee7b7;--error:#f87171;--error-light:#3d1a1a;--warning:#fbbf24;--progress-green:#34d399;--progress-blue:#38bdf8;--progress-red:#f87171;--shadow-light:#0003;--shadow-medium:#0000004d;--shadow-heavy:#00000080;--shadow-book:#00000080;--gradient-skeleton:linear-gradient(90deg,#2d2d2d 25%,#3d3d3d 50%,#2d2d2d 75%);--gradient-divider:linear-gradient(90deg,#0000,#3d3d3d,#0000);--gradient-insight:linear-gradient(135deg,#4c51bf,#6b21a8);--navbar-bg:#1e1e1e;--navbar-border:#3d3d3d;--dropdown-bg:#252525;--tag-bg:#2d2d2d;--stat-bg:#252525;--toggle-bg:#444;--toggle-active:#34d399;background-color:#fff;background-color:var(--bg-primary);color:#000;color:var(--text-primary)}}#root{display:flex;flex-direction:column;min-height:100%;width:100%}@media (prefers-color-scheme:dark){.book-action-icon.light,.details-icon,.filter-icon.light,.icon-invert,.nav-icon,.profile-tab-icon.light,.share-icon.light{filter:invert(1)}.book-action-icon.dark,.filter-icon.dark,.icon-no-invert,.profile-tab-icon.dark,.share-icon.dark{filter:none}.footer-logo img,.navbar-logo img{filter:invert(1)}.profile-card{border:1px solid #4a4a4a;box-shadow:0 4px 20px #ffffff1a}}.navbar{align-items:center;background-color:var(--navbar-bg);border-bottom:1px solid var(--navbar-border);box-shadow:0 4px 6px var(--shadow-medium);display:flex;justify-content:space-between;padding:12px 0;position:fixed;top:0;transition:transform .3s ease-in-out,opacity .3s ease-in-out;width:100%;z-index:1000}.navbar-visible{opacity:1;transform:translateY(0)}.navbar-hidden{opacity:0;transform:translateY(-100%)}.navbar>*{flex:1 1}.hamburger-container{align-items:center;cursor:pointer;display:flex;height:40px;justify-content:center;margin-left:32px;position:relative;width:40px}.hamburger{display:flex;flex-direction:column;gap:4px}.bar{background:var(--text-secondary);border-radius:3px;height:3px;transition:all .3s ease-in-out;width:24px}.close-icon{cursor:pointer;height:24px;position:absolute;width:24px}.navbar-logo{display:flex;flex:2 1;justify-content:left;padding-left:40px}.navbar-logo img{display:block;height:80px;width:auto}.hamburger-container,.navbar-button-container{align-items:center;display:flex;flex:1 1}.hamburger-container{justify-content:flex-start}.navbar-nav{background:var(--dropdown-bg);box-shadow:0 10px 15px var(--shadow-heavy);display:none;flex-direction:column;left:0;position:absolute;text-align:left;top:104px;width:300px}.navbar-nav.open{display:flex}.navbar-nav ul{flex-direction:column;gap:5px;list-style:none;margin:0;padding:0}.navbar-nav li{border-bottom:1px solid var(--border-medium);padding:16px 0 20px 24px}.navbar-nav li a{color:var(--text-secondary);font-size:16px;text-decoration:none}.navbar-button-container{display:flex;flex:1 1;justify-content:flex-end;margin-right:24px}.navbar-link{background-color:var(--bg-card);border-radius:4px;color:var(--text-primary);padding:10px 20px;text-decoration:none}.navbar-link:hover{color:var(--link-color)}.navbar-button{background-color:var(--bg-card);border:2px solid var(--text-primary);border-radius:8px;color:var(--text-primary);font-weight:500;margin:10px;padding:10px 20px;text-decoration:none;transition:border .2s ease}.navbar-button:hover{border:2px solid var(--link-color);color:var(--link-color)}.navbar-profile{align-items:center;cursor:pointer;display:flex}.navbar-profile img.profile-pic{background-color:var(--bg-hover);border:2px solid var(--bg-primary);border-radius:50%;height:60px;object-fit:cover;width:60px}.profile-dropdown{background:var(--dropdown-bg);box-shadow:0 10px 15px var(--shadow-heavy);display:none;flex-direction:column;position:absolute;right:0;text-align:left;top:104px;width:300px}.profile-dropdown.open{display:block}.profile-dropdown ul{flex-direction:column;gap:5px;list-style:none;margin:0;padding:0}.profile-dropdown li{border-bottom:1px solid var(--border-medium);padding:16px 0 20px 24px}.profile-dropdown li a{color:var(--text-secondary);font-size:16px;text-decoration:none}.profile-dropdown li button{background:none;border:none;cursor:pointer;font-size:16px;text-align:left;width:100%}@media (max-width:767px){.profile-dropdown{top:72px;width:180px}.profile-dropdown ul{margin-left:0}.hamburger-container{margin-left:16px}.close-icon{cursor:pointer;height:24px;left:0;position:absolute;top:20%;transform:translate(-2%);width:24px}.navbar{padding-bottom:5px}.navbar-button-container{margin-right:16px}.hide-on-mobile{display:none!important}.navbar-button{background:none;border:1.5px solid var(--text-primary);border-radius:8px;color:var(--text-primary);padding:8px 16px;text-decoration:none}.navbar-logo img{flex:2 1;height:50px}.navbar-profile img.profile-pic{height:40px;margin-top:10px;width:40px}.navbar-nav{top:72px;width:180px}}.footer{background:var(--bg-card);box-shadow:0 5px 15px var(--shadow-heavy);display:block!important;font-family:Rubik,sans-serif;margin-top:auto;padding:60px 0;position:relative;text-align:center;visibility:visible!important;width:100%;z-index:10}.footer-container{margin:0 auto;max-width:1200px;padding:0 20px}.footer-logo{margin-bottom:24px}.footer-logo img{height:50px;width:auto}.footer-nav{margin-bottom:15px}.footer-nav ul{display:flex;gap:30px;justify-content:center;list-style:none;padding:0}.footer-nav li a{color:var(--text-secondary);font-size:16px;font-weight:medium;text-decoration:none;transition:color .3s ease}.footer-nav li a:hover{color:var(--link-color)}.footer-bottom{align-items:center;border-top:1px solid var(--navbar-border);color:var(--text-muted);display:flex;font-size:14px;justify-content:space-between;margin-top:80px;padding:0 60px}.footer-copyright{flex:1 1;font-size:14px;text-align:left}.footer-links{flex:1 1;text-align:right}.footer-links a{color:var(--text-primary);font-size:14px;font-weight:400;margin-left:15px;text-decoration:none}.footer-links a:hover{color:var(--link-color)}@media (max-width:768px){.footer{padding:40px 0}.footer-nav ul{flex-direction:column;gap:24px}.footer-bottom{flex-direction:column;text-align:center}.footer-copyright{margin-bottom:10px;text-align:center}.footer-links{text-align:center}.footer-bottom{font-size:12px;margin-top:32px;padding:0 40px}}.home-container{display:flex;justify-content:space-between;margin-top:120px;width:100%}.book-feed-wrapper{margin:24px 60px;width:100%}.book-feed-container{display:flex;flex-direction:column;justify-content:flex-start;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px;width:100%}.book-feed-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}@media (max-width:1024px){.book-feed-grid{gap:20px;grid-template-columns:1fr}}.feed-empty-state{color:var(--text-muted);padding:60px 20px;text-align:center}.feed-empty-state p{font-size:16px;margin:8px 0}.book-feed-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.book-feed-heading{font-size:32px;font-weight:700;margin:0;text-align:left}.filter-icon-container{position:relative}.filter-icon{height:24px;transition:opacity .2s ease;width:24px}.filter-icon.light{opacity:.6}.filter-icon.dark{left:12px;opacity:0;position:absolute;top:12px}.filter-icon-container:hover .filter-icon.light{opacity:0}.filter-icon-container:hover .filter-icon.dark{opacity:1;transform:scale(1.02)}.filter-dropdown-content{box-shadow:0 4px 6px var(--shadow-medium)}.filter-dropdown-content select{border-radius:6px;cursor:pointer}.filter-dropdown-content select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.book-feed-card{align-items:flex-start;background-color:var(--bg-card);border-radius:24px;box-shadow:0 0 30px 0 var(--shadow-light);box-sizing:border-box;display:flex;gap:20px;padding:24px;position:relative;transition:all .3s ease-in-out;width:100%}.book-feed-card:hover{background-color:var(--bg-tertiary);box-shadow:0 8px 40px 0 var(--shadow-medium);transform:translateY(-4px)}.image-wrapper{border-radius:8px;display:inline-block;flex-shrink:0;height:auto;max-width:200px;overflow:hidden;position:relative;transition:all .2s}.image-wrapper.feed-clickable{cursor:pointer}.image-wrapper.feed-clickable:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.image-wrapper:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.book-feed-image{border-radius:8px;box-shadow:0 10px 35px 0 #00000040;display:block;height:auto;width:200px}.book-info{display:flex;flex-direction:column}.book-title-section{margin-bottom:8px}.book-title{color:#1f2937;color:var(--text-primary,#1f2937);font-size:32px;font-weight:700;line-height:1.2;margin:0;text-align:left}.book-title.feed-clickable-title{cursor:pointer}.book-info .book-author{color:#6b7280!important;color:var(--text-secondary,#6b7280)!important;font-size:1.5rem!important;font-weight:400;margin:0;text-align:left}.book-actions{display:flex;gap:12px;margin:15px 0}.feed-buy-link{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:400;gap:6px;justify-content:center;padding:6px 12px;position:relative;transition:all .2s ease}.feed-buy-link:hover{background-color:var(--bg-tertiary);border-color:var(--border-dark);color:var(--text-primary)}.add-to-stack-button{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-medium)!important;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:400;gap:6px;justify-content:center;padding:6px 12px;position:relative;transition:all .2s ease}.add-to-stack-button:hover{background-color:var(--bg-tertiary);border:1px solid var(--border-dark)!important;color:var(--text-primary)}.add-to-stack-button:focus{border:1px solid var(--border-dark)!important;outline:none}.add-to-stack-button:active{background-color:var(--bg-hover);border:1px solid var(--border-dark)!important}.add-to-stack-button:focus-visible{border:1px solid var(--border-dark)!important}.add-to-stack-button.added{cursor:not-allowed}.add-to-stack-button.added,.add-to-stack-button.added:hover{background-color:#e8f5e8;border:1px solid #4caf50;color:#2e7d32}.add-to-stack-button:disabled{cursor:not-allowed;opacity:.7}.smart-book-search{width:100%}.smart-book-search .search-input{background-color:var(--bg-input);border:1px solid var(--border-medium);border-radius:8px;color:var(--text-primary);font-size:16px;outline:none;padding:12px 16px;transition:border-color .2s ease;width:100%}.smart-book-search .search-input:focus{border-color:var(--accent-primary)}.searching-indicator{color:var(--text-muted);font-size:13px;padding:6px 0 2px}.search-results{-webkit-overflow-scrolling:touch;background:var(--bg-card);border:1px solid var(--border-medium);border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 6px var(--shadow-medium);max-height:420px;overflow-y:auto;z-index:1000}.results-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-light);padding:12px 16px}.results-header h4{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;gap:8px;margin:0}.result-count{color:var(--text-muted);font-weight:400}.book-result{align-items:center;border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;padding:12px 16px;transition:background-color .2s ease}.book-result:hover{background-color:var(--bg-tertiary)}.book-result:last-child{border-bottom:none}.book-result img{border-radius:4px;height:60px;margin-right:12px;object-fit:cover;width:40px}.book-info{flex:1 1}.book-info h3{color:var(--text-secondary);font-size:14px;font-weight:600;line-height:1.3;margin:0 0 4px}.book-info p{color:var(--text-muted);font-size:12px;margin:0 0 6px}.source-badge{border-radius:3px;display:inline-block;font-size:10px;font-weight:500;padding:2px 6px;text-transform:uppercase}.source-badge.local{background-color:#e8f5e8;color:#2e7d32}.source-badge.google{background-color:#e3f2fd;color:#1976d2}.load-more-results{background:var(--bg-tertiary);border:none;border-top:1px solid var(--border-light);color:#4a90d9;color:var(--accent-primary,#4a90d9);cursor:pointer;display:block;font-size:14px;font-weight:500;padding:12px;text-align:center;width:100%}.load-more-results:hover{background:var(--bg-secondary)}.load-more-results:disabled{cursor:default;opacity:.6}.feed-icon-container{align-items:center;display:flex;height:16px;justify-content:center;position:relative;width:16px}.feed-icon{height:16px;transition:opacity .2s ease;width:16px}.feed-icon.light{opacity:.6}.feed-icon.dark{left:0;opacity:0;position:absolute;top:0}.add-to-stack-button:hover .feed-icon.light,.feed-buy-link:hover .feed-icon.light{opacity:0}.add-to-stack-button:hover .feed-icon.dark,.feed-buy-link:hover .feed-icon.dark{opacity:1}.reader-card{align-items:flex-start;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:16px;margin-bottom:6px;margin-top:6px;padding:16px;transition:all .2s}.reader-card:hover{background:var(--bg-hover);box-shadow:0 4px 12px var(--shadow-medium);transform:translateY(-2px)}.reader-profile-pic{border-radius:50%;flex-shrink:0;height:48px;object-fit:cover;width:48px}.reader-info{display:flex;flex:1 1;flex-direction:column;gap:6px}.reader-username{color:#2563eb;font-size:.95rem;font-weight:600;text-decoration:none}.reader-username:hover{text-decoration:underline}.reader-status{color:#6b7280;font-size:.875rem;font-weight:500}.reader-timestamp{color:#9ca3af;font-size:.8rem}.book-summary-container{margin-top:8px}.book-summary,.book-summary-container{background:none!important;border:none!important;box-shadow:none!important;padding:0!important}.book-summary{color:var(--text-secondary);font-size:14px;line-height:1.5}.expand-summary{color:#3b82f6;cursor:pointer;font-weight:500;margin-left:4px}.expand-summary:hover{color:#2563eb;text-decoration:underline}.book-no-results{color:red;font-size:18px;padding:20px;text-align:center}.book-loading{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;font-size:16px;gap:12px;padding:20px;text-align:center}.book-loading-icon{align-items:center;animation:pulse 1.5s ease-in-out infinite;display:flex;height:48px;justify-content:center;width:48px}.book-loading-icon svg{height:48px;transition:opacity .3s ease-in-out;width:48px}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.book-loading p{color:var(--text-muted);font-size:16px;margin:0}.book-no-image{align-items:center;background-color:var(--bg-hover);border-radius:8px;color:var(--text-muted);display:flex;font-size:14px;height:300px;justify-content:center;width:200px}@media (max-width:768px){.book-feed-card{align-items:center;flex-direction:column;padding:24px;width:100%}.image-wrapper{display:flex;justify-content:center;width:100%}.book-feed-image{margin:0 auto;max-width:300px;width:100%}.book-title-section{margin-bottom:12px}.book-title{word-wrap:break-word;font-size:1.75rem;line-height:1.3;margin:0}.book-info .book-author{font-size:1.125rem!important;margin:0}.book-info{gap:0}.book-actions{margin:8px 0}.reader-card{gap:12px;padding:12px}.reader-profile-pic{height:40px;width:40px}.reader-info{gap:4px}.reader-username{font-size:.9rem}.reader-status{font-size:.8rem}.reader-timestamp{font-size:.75rem}}@media (max-width:480px){.book-title{font-size:1.5rem;line-height:1.4}.book-info .book-author{font-size:1rem!important}.book-summary-container{margin-top:8px}.reader-card{gap:10px;padding:10px}.reader-profile-pic{height:36px;width:36px}.reader-username{font-size:.85rem}.reader-status{font-size:.75rem}.reader-timestamp{font-size:.7rem}.book-feed-heading,.book-feed-select{margin-left:24px}.feed-note{bottom:0;left:0;padding:24px 0;transform:translateY(0);width:100%}.book-feed-wrapper{margin:0;padding:0 24px;width:100%}.filter-dropdown-content{gap:8px;left:auto;min-width:180px;padding:12px;right:0;transform:translateX(0)}.filter-icon-container{padding:14px}.filter-icon-container svg{height:26px;width:26px}.filter-icon.dark{left:14px;top:14px}.book-feed-container{padding:0}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.shimmer{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background:linear-gradient(90deg,var(--bg-tertiary,#f0f0f0) 25%,var(--bg-hover,#e0e0e0) 50%,var(--bg-tertiary,#f0f0f0) 75%);background-size:800px 100%;border-radius:8px}.skeleton-image{aspect-ratio:2/3;border-radius:8px;width:100%}.skeleton-title{height:20px;margin-bottom:8px;width:80%}.skeleton-author{height:14px;margin-bottom:16px;width:50%}.skeleton-reader{border-radius:12px;height:60px;width:100%}body,html{background-color:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;height:100%;margin:0;overflow-x:hidden;overflow-y:auto;padding:0}.nav-icon{height:24px;margin-right:8px;vertical-align:middle;width:24px}a:focus:not(:focus-visible),button:focus:not(:focus-visible){outline:none}.details-icon{height:20px;margin:0;vertical-align:middle;width:20px}.app-container{background-color:var(--bg-primary);display:flex;flex-direction:column;max-width:100%;min-height:100vh;overflow-x:hidden;overflow-x:clip}main{flex:1 1}img{height:auto;max-width:100%;width:100%}.tab-button{-webkit-tap-highlight-color:transparent}a{color:var(--text-primary);text-decoration:none}a:active,a:hover{color:var(--text-secondary)}.wrapper{margin:0 auto;max-width:100%;padding:80px 20px 40px}.heading{width:90%}h1{font-size:56px;font-weight:700;margin-bottom:20px}h1,h2{font-family:Hanken Grotesk,sans-serif}h2{font-size:28px;font-weight:600;margin-bottom:15px}h3{font-family:Hanken Grotesk,sans-serif;font-size:20px;font-weight:500;margin-bottom:10px}.separator-small{background:var(--border-dark) none repeat;height:1px;margin-bottom:50px;margin-top:50px;width:40px}p{font-family:Hanken Grotesk,sans-serif;font-size:20px;line-height:1.5}.intro,p{color:var(--text-primary);font-weight:400;margin-bottom:10px}.intro{font-size:28px}@media (max-width:1024px){h1{font-size:38px}h2{font-size:28px}h3{font-size:22px}body{font-size:16px}}.heading{width:85%}@media only screen and (max-width:1000px){main{margin:40px 0 0}.wrapper{margin:24px auto 60px;max-width:90%;padding:60px 20px 40px}h1{font-size:32px}h2{font-size:26px}h3{font-size:20px}body{font-size:12px}.heading{width:100%}.intro{color:var(--text-primary);font-size:18px;font-weight:400;margin-bottom:10px}}@media (max-width:1000px){.wrapper,main{margin:0!important}.wrapper{max-width:100%;padding:20px 10px 40px}}.app-loading{background:#fff;background:var(--bg-primary,#fff);min-height:100vh}.filter-icon-container{align-items:center;border-radius:8px;cursor:pointer;display:flex;padding:12px;transition:background-color .2s ease}.filter-icon-container:hover{background-color:var(--bg-hover)}.filter-icon-container svg{height:24px;width:24px}.share-icon-container{align-items:center;border-radius:6px;cursor:pointer;display:flex;padding:12px;transition:background-color .2s ease}.share-icon-container:hover{background-color:var(--bg-hover)}.share-icon{height:24px;transition:all .3s ease;width:24px}.filter-icon.light,.share-icon.light{opacity:.6}.filter-icon.dark,.share-icon.dark{opacity:0;position:absolute}.share-icon-container:hover .share-icon.light{opacity:0}.share-icon-container:hover .share-icon.dark{opacity:1;transform:scale(1.02)}.filter-icon-container:hover .filter-icon.dark,.filter-icon-container:hover .filter-icon.light{opacity:.6}.filter-dropdown{display:inline-block;position:relative}.filter-dropdown-content{background-color:var(--bg-card);display:flex;flex-direction:column;gap:12px;min-width:280px;padding:16px;width:320px;z-index:1000}.filter-option{border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;margin:2px 0;padding:12px 16px;transition:all .2s ease}.filter-option:hover{background-color:var(--bg-hover);color:var(--text-primary)}.filter-option.active{background-color:var(--accent-primary);color:var(--text-inverse)}.filter-option.active:hover{background-color:var(--accent-primary-hover)}.section-controls{align-items:center;display:flex;flex-shrink:0;gap:15px;margin-left:auto}.shared-dropdown{-webkit-appearance:none;appearance:none;background-color:var(--bg-input);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;background-size:16px;border:1px solid var(--border-medium);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:16px;padding:12px 40px 12px 16px;transition:border-color .2s ease;width:100%}.shared-dropdown:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}.shared-dropdown:disabled{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.custom-dropdown{position:relative;width:100%}.custom-dropdown-trigger{align-items:center;background-color:var(--bg-input);border:1px solid var(--border-medium);border-radius:8px;box-sizing:border-box;color:var(--text-primary);cursor:pointer;display:flex;font-size:16px;justify-content:space-between;min-height:48px;padding:12px 20px 12px 16px;transition:border-color .2s ease;width:100%}.custom-dropdown-trigger:hover{border-color:var(--border-dark)}.custom-dropdown-trigger:focus{outline:none}.custom-dropdown-trigger.open,.custom-dropdown-trigger:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.custom-dropdown.disabled .custom-dropdown-trigger{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.custom-dropdown-value{color:var(--text-secondary);flex:1 1;text-align:left}.custom-dropdown-value:empty:before{color:var(--text-placeholder);content:attr(placeholder)}.custom-dropdown-arrow{flex-shrink:0;position:absolute;right:4px;top:50%;transform:translateY(-50%);transition:transform .2s ease}.custom-dropdown-arrow.open{transform:translateY(-50%) rotate(180deg)}.custom-dropdown-menu{background-color:var(--bg-card);border:1px solid var(--border-medium);border-radius:0 0 8px 8px;border-top:none;box-shadow:0 4px 6px -1px var(--shadow-medium);left:0;margin-top:1px;max-height:300px;overflow-y:auto;position:absolute;right:0;scrollbar-color:var(--border-dark) var(--bg-tertiary);scrollbar-width:thin;top:100%;z-index:1000}.custom-dropdown-menu::-webkit-scrollbar{width:8px}.custom-dropdown-menu::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.custom-dropdown-menu::-webkit-scrollbar-thumb{background:var(--border-dark);border:1px solid var(--bg-tertiary);border-radius:4px}.custom-dropdown-menu::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.custom-dropdown-option{color:var(--text-secondary);cursor:pointer;font-size:16px;padding:12px 16px;transition:background-color .15s ease}.custom-dropdown-option.highlighted,.custom-dropdown-option:hover{background-color:var(--bg-hover)}.custom-dropdown-option.selected{background-color:var(--success-light);color:var(--link-color);font-weight:500}.custom-dropdown-option.selected:hover{background-color:var(--bg-tertiary)}@media (min-width:768px){.custom-dropdown-menu{max-height:400px;min-width:250px}.custom-dropdown-option{font-size:15px;padding:14px 16px}.filter-dropdown-content{gap:16px;min-width:320px;width:360px}}.custom-dropdown-option.disabled{color:var(--text-placeholder);cursor:not-allowed}.custom-dropdown-option.disabled,.custom-dropdown-option.disabled:hover{background-color:var(--bg-tertiary)}.custom-dropdown-option:last-child{border-radius:0 0 8px 8px}@media (max-width:767px){.filter-icon-container{padding:14px}.filter-icon-container svg{height:26px;width:26px}.share-icon-container{padding:14px}.share-icon{height:26px;width:26px}.filter-dropdown-content{left:50%;max-width:300px;position:fixed;top:200px;transform:translateX(-50%);width:90vw;z-index:1000}.filter-option{font-size:16px;padding:16px 20px}.shared-dropdown{font-size:16px;padding:14px 40px 14px 16px}.custom-dropdown-trigger{font-size:16px;padding:14px 20px 14px 16px}}.reading-page-container{padding:20px 0 40px 10px}.bookstack-page-container,.reading-page-container{box-sizing:border-box;max-width:100vw;overflow-x:hidden;width:100%}.bookstack-page-container{padding:20px 10px 40px}.heading{margin-bottom:10px}.page-title{margin-bottom:30px;text-align:left}.page-title h1{color:var(--text-secondary);font-size:2.5em;font-weight:600;margin:0 32px}.modal-overlay{align-items:center;background-color:var(--bg-overlay);bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:2rem 1rem;position:fixed;right:0;top:0;transition:background-color .3s ease;z-index:1000}.modal-overlay.scrollable{align-items:flex-start;padding:2rem 1rem}.modal-overlay>div:not(.modal){align-items:center;display:flex;justify-content:center;margin:0 auto;max-width:600px;min-height:100vh;padding:2rem 0;width:100%}.modal-overlay.fade-transition{background-color:#00000080!important;transition:background-color .4s ease}.modal-inner-content{min-height:400px;position:relative}.update-animation.modal-overlay{box-shadow:0 5px 15px #0003;max-height:500px}.update-animation{animation:slideIn .3s ease-out;background:var(--bg-card);border-radius:12px;box-shadow:0 5px 15px var(--shadow-heavy);margin:0 auto;max-width:400px;padding:3rem 2rem;text-align:center;width:100%}.success-icon{animation:bounceIn .6s ease-out;color:var(--success);font-size:4rem;margin-bottom:1rem}.update-animation h3{color:var(--text-primary);font-size:1.5rem;margin-bottom:.5rem}.update-animation p{color:var(--text-muted);font-size:1rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}.book-overlay{align-items:center;background-color:var(--bg-overlay-heavy);bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.book:hover .book-overlay{opacity:1}.edit-link{background-color:var(--bg-card);border:none;border-top:1px solid var(--text-primary);color:var(--link-color);cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:12px 24px;text-align:center;transition:all .2s}.edit-link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.book-actions-overlay{display:flex;flex-direction:row;margin:auto 0 0;width:100%}.buy-link{background-color:var(--bg-card);border:none;border-radius:0;border-top:1px solid var(--text-primary);color:var(--text-primary);font-size:14px;font-weight:700;padding:10px 20px;text-align:center;text-decoration:none;transition:background-color .2s;width:30%}.buy-link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.add-to-stack-link{background-color:var(--bg-card);border-bottom:none;border-left:1px solid var(--text-primary);border-radius:0;border-right:none;border-top:1px solid var(--text-primary);color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:background-color .2s;width:70%}.add-to-stack-link:hover{background-color:var(--bg-hover);color:var(--text-primary)}.empty-book-placeholder{align-items:center;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-end;margin:0 2em 4em}.book-outline{align-items:center;background-color:var(--bg-tertiary);border:3px dashed var(--border-dark);border-radius:4px;display:flex;height:264px;justify-content:center;position:relative;transition:all .2s ease-in-out;width:180px}.book-outline:hover{background-color:var(--bg-hover);border-color:var(--text-muted);box-shadow:0 25px 75px var(--shadow-medium);transform:translateY(-7px) scale(1.02)}.plus-icon{color:var(--text-muted);font-size:4rem;font-weight:300;transition:color .2s ease-in-out}.book-outline:hover .plus-icon{color:var(--text-secondary)}@media (max-width:767px){.empty-book-placeholder{margin:0 0 4em}.book-outline{height:210px;width:150px}.plus-icon{font-size:3rem}}.group{margin-bottom:60px}.group-grid{align-items:flex-end;display:flex;flex-wrap:wrap;gap:40px 0;justify-content:left}.group header{margin-bottom:3em;padding-left:40px}.group h2{font-size:4em;font-weight:400;margin:0;text-align:left}.book-container{align-items:center;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-end;margin:0 2em 4em}.book-content{margin-bottom:-10px}.book{border-radius:4px;box-shadow:0 10px 35px 0 #00000040;overflow:hidden;position:relative;transition:all .2s ease-in-out;width:180px}.book:hover{border-radius:4px 4px 0 0;box-shadow:0 15px 45px #0003;opacity:1;transform:translateY(-7px) scale(1.02)}.book.format-audio{height:200px;width:200px}.book.format-audio .progress-bar{background:#ff9100;box-shadow:0 0 20px #ff9100}.status-worn .status-layer{background:url(/static/media/worn.0b35bf8e4cb6ec30fb96.png) no-repeat 50%;background-size:cover}.status-notstarted .status-layer,.status-worn .status-layer{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.status-notstarted .status-layer{background:url(/static/media/plastic-wrap.c59fdf37ce328f7be1cb.png) no-repeat 50%;background-size:cover;opacity:.8;transition:opacity .2s ease-in-out}.status-notstarted:hover .status-layer{opacity:1}.status-notstarted:hover:before{filter:blur(2px);opacity:1;transform:translateY(-7px) scale(1.02)}.book:hover+.progress,.book:hover+.progress .progress-bar{height:16px}.progress-0 .progress-bar{width:0}.progress-10 .progress-bar{width:10%}.progress-20 .progress-bar{width:20%}.progress-30 .progress-bar{width:30%}.progress-40 .progress-bar{width:40%}.progress-50 .progress-bar{width:50%}.progress-60 .progress-bar{width:60%}.progress-70 .progress-bar{width:70%}.progress-80 .progress-bar{width:80%}.progress-90 .progress-bar{width:90%}.progress,.progress-100 .progress-bar{width:100%}.progress{background-color:var(--bg-tertiary);border-radius:20px;bottom:-20px;height:6px;overflow:hidden;position:relative;transition:height .2s ease-in-out}.progress-bar{background:#44d7b6;border-radius:20px;box-shadow:0 0 20px #00ffc8;height:100%;transition:height .2s ease-in-out,width .2s ease-in-out}.status-done .progress-bar{background:#00aeff;box-shadow:0 0 20px #00aeff}.status-worn .progress-bar{background:#ff000c;box-shadow:0 0 20px #ff000c}.inline-progress-slider{align-items:center;bottom:-20px;display:flex;flex-direction:column;padding:2px 0;position:relative;width:100%}.reads-edit-link{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:11px;margin-top:6px;opacity:.6;padding:0;transition:opacity .15s,color .15s}.reads-edit-link:hover{color:var(--text-primary);opacity:1}.inline-progress-slider input[type=range]{-webkit-appearance:none;appearance:none;border-radius:20px;cursor:pointer;height:6px;outline:none;transition:height .2s ease-in-out;width:100%}.inline-progress-slider input[type=range]:hover{height:12px}.inline-progress-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#44d7b6;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px #0003;cursor:grab;height:16px;margin-top:1.5px;width:16px}.inline-progress-slider input[type=range]::-moz-range-thumb{background:#44d7b6;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px #0003;cursor:grab;height:16px;width:16px}.inline-progress-slider input.status-done::-webkit-slider-thumb{background:#00aeff}.inline-progress-slider input.status-done::-moz-range-thumb{background:#00aeff}.inline-progress-slider input.status-worn::-webkit-slider-thumb{background:#ff000c}.inline-progress-slider input.status-worn::-moz-range-thumb{background:#ff000c}.add-to-reads-link{background:none;border:none;bottom:-20px;color:#2563eb;color:var(--link-color,#2563eb);cursor:pointer;font-size:13px;font-weight:500;padding:4px 0;position:relative;text-align:center;transition:color .2s ease;width:100%}.add-to-reads-link:hover{color:#1d4ed8;color:var(--link-hover,#1d4ed8);text-decoration:underline}.stack-action-btn{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-medium)!important;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;font-weight:400;justify-content:center;padding:6px 12px;text-decoration:none!important;transition:all .2s ease;width:100%}.stack-action-btn:hover{background-color:var(--bg-tertiary);border-color:var(--border-dark)!important;color:var(--text-primary);text-decoration:none!important}.stack-visitor-actions{bottom:-20px;display:flex;gap:6px;justify-content:center;min-height:24px;position:relative;text-align:center}.stack-edit-btn{font-size:11px!important;opacity:.7;padding:3px 8px!important}.stack-edit-btn:hover{opacity:1}.book:hover .note{opacity:1;transform:translateY(0)}.note{background:var(--bg-card);border-radius:12px 12px 0 0;bottom:0;box-shadow:0 5px 25px var(--shadow-book);color:var(--text-secondary);display:block;left:0;opacity:0;padding:0;position:absolute;right:0;text-align:left;transform:translateY(20px);transition:opacity .2s ease-in-out,transform .2s ease-in-out;width:100%;z-index:10}.note-content{display:flex;flex-direction:column;height:100%;padding:0}.note-text-content{flex:1 1;padding:15px}.hover-add-to-stack-btn{background:#ffffff26;border:1px solid #ffffff80;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:12px;font-weight:500;margin-top:8px;padding:5px 12px;transition:background .2s,border-color .2s}.hover-add-to-stack-btn:hover{background:#ffffff4d;border-color:#fff}.note-visible{opacity:1!important;transform:translateY(0)!important;transition:opacity .3s ease-in-out,transform .3s ease-in-out}.note p{font-size:14px;padding:5px 10px 0}.status-notstarted:hover .note{opacity:1;transform:translateY(0)}.filters{box-sizing:border-box;justify-content:space-between;margin-top:10px;max-width:100%;width:100%}.filters,.filters-right{align-items:center;display:flex}.filters-right{flex-shrink:0;gap:15px;margin-left:auto}.filter-dropdown-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-medium);margin-top:5px;min-width:200px;padding:15px;position:absolute;right:0;top:100%;z-index:100}.filter-dropdown-content select{background-color:var(--bg-input);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-primary);font-size:14px;margin-bottom:10px;padding:8px 12px;width:100%}.filter-dropdown-content select:last-child{margin-bottom:0}.recommend-toggle{align-items:center;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px}.switch{display:inline-block;height:20px;position:relative;width:34px}.switch input{height:0;opacity:0;width:0}.slider{background-color:var(--toggle-bg);border-radius:20px;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{background-color:var(--bg-primary);border-radius:50%;bottom:3px;content:"";height:14px;left:3px;width:14px}.switch input:checked+.slider{background-color:var(--toggle-active)}.switch input:checked+.slider:before{transform:translateX(14px)}.reading-stack{margin-top:20px}.reading-stack .book-grid{align-items:flex-end;display:flex;flex-wrap:wrap;gap:20px}.book-item{cursor:pointer;text-align:center;width:100%}.reading-stack .back-btn{background-color:var(--text-secondary);border:none;border-radius:5px;color:var(--text-inverse);cursor:pointer;font-size:16px;margin-bottom:15px;padding:10px 15px}.reading-stack .back-btn:hover{background-color:var(--text-muted)}.start-reading-btn{background-color:var(--bg-card);border:2px solid #0000;border-color:var(--text-primary);border-radius:8px;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:1em;font-weight:500;margin-top:20px;padding:.6em 1.2em;transition:border-color .25s}@media (max-width:767px){.book:hover .note{opacity:1;transform:none}.note p{font-size:11px;padding:0 10px}.group{margin-bottom:8em}.book-container{cursor:pointer;margin:0 0 4em}.group-grid{gap:10px 10px;justify-content:center}.book{width:150px}*{margin-left:0!important}.bookstack-page-container,.reading-page-container{margin:0;padding:5px 10px 30px}.filters{align-items:center;display:flex;margin-bottom:10px;margin-top:-10px;padding:0 20px;width:100%}.filters,.filters-right{gap:15px;justify-content:flex-end}.filters-right{flex-shrink:0;margin-left:0}.filter-dropdown-content{left:50%;max-width:300px;position:fixed;top:200px;transform:translateX(-50%);width:90vw;z-index:1000}.page-title h1{font-size:1.8em;margin-bottom:10px;margin-left:12px!important;text-align:left}.group-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(2,1fr);justify-content:center;margin-left:0;padding:0 10px}.book-container{margin:0 auto;max-width:150px;width:100%}.empty-book-placeholder{height:225px;margin:0 auto;width:150px}.book-outline{height:100%;width:100%}.plus-icon{font-size:2em}.modal-overlay{padding:20px 10px}.modal-overlay>div{max-width:500px;width:95vw}.group h2{font-size:36px;margin-bottom:20px;margin-left:0;text-align:left}.group{margin-bottom:40px!important}.recommend-toggle .switch{transform:scale(1.2)}}.success-modal-overlay{left:50%;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:1000}.success-modal{background:var(--bg-card);border-radius:12px;box-shadow:0 10px 25px var(--shadow-heavy);max-width:400px;min-width:300px;padding:2rem;text-align:center}.success-modal .success-icon{font-size:2rem;margin-bottom:1rem}.success-modal h3{color:var(--text-primary);font-size:1.1rem;font-weight:500;margin:0}.book-action-buttons{border-top:1px solid var(--border-color);display:flex;flex-direction:row;gap:0;margin-top:1rem}.book-action-button{align-items:center;background:#0000;border:none;border-top:1px solid var(--border-color);color:inherit;cursor:pointer;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:15px 10px;position:relative;text-decoration:none;transition:all .3s ease}.book-action-button:hover{background-color:var(--bg-tertiary)}.book-action-icon{height:24px;margin-bottom:6px;transition:all .3s ease;width:24px}.book-action-icon.light{opacity:.6}.book-action-icon.dark{background:none;border:none;left:50%;margin-bottom:0;opacity:0;outline:none;position:absolute;top:15px;transform:translateX(-50%)}.book-action-button:hover .book-action-icon.light{opacity:0}.book-action-button:hover .book-action-icon.dark{animation:bounce .6s ease-in-out;opacity:1;transform:translateX(-50%) scale(1.1)}.book-action-text{color:var(--text-muted);font-size:11px;font-weight:500;text-align:center;transition:color .3s ease}.book-action-button:hover .book-action-text{color:var(--text-secondary)}@keyframes bounce{0%,20%,50%,80%,to{transform:translateX(-50%) scale(1.1)}40%{transform:translateX(-50%) scale(1.2)}60%{transform:translateX(-50%) scale(1.15)}}.skeleton-book{pointer-events:none}.book-skeleton-cover{animation:skeletonShimmer 1.4s ease-in-out infinite;aspect-ratio:2/3;background:linear-gradient(110deg,#e5e7eb 30%,#f3f4f6 50%,#e5e7eb 70%);background:linear-gradient(110deg,var(--bg-tertiary,#e5e7eb) 30%,var(--bg-secondary,#f3f4f6) 50%,var(--bg-tertiary,#e5e7eb) 70%);background-size:200% 100%;border-radius:6px;width:100%}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
/*# sourceMappingURL=main.fdd55d7d.css.map*/