@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_7b064e0d-module__MOT0tq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_7b064e0d-module__MOT0tq__variable{--font-inter:"Inter","Inter Fallback"}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg-primary:#fff;--color-bg-secondary:#f5f5f7;--color-bg-tertiary:#e8e8ed;--color-bg-elevated:#fff;--color-bg-glass:#ffffffb8;--color-text-primary:#1d1d1f;--color-text-secondary:#6e6e73;--color-text-tertiary:#86868b;--color-text-inverse:#fff;--color-accent:#007aff;--color-accent-hover:#0066d6;--color-accent-subtle:#007aff1a;--color-success:#30d158;--color-warning:#ff9f0a;--color-error:#ff453a;--color-border:#00000014;--color-border-strong:#00000026;--color-divider:#0000000d;--gradient-accent:linear-gradient(135deg,#007aff 0%,#5856d6 100%);--gradient-warm:linear-gradient(135deg,#ff6b6b 0%,orange 100%);--gradient-cool:linear-gradient(135deg,#667eea 0%,#764ba2 100%);--gradient-card:linear-gradient(145deg,#ffffffe6 0%,#ffffffb3 100%);--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--shadow-xl:0 16px 48px #00000029;--shadow-glow:0 0 40px #007aff26;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-serif:"Merriweather",Georgia,"Times New Roman",serif;--font-mono:"JetBrains Mono","SF Mono","Fira Code",monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--text-5xl:3rem;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--letter-spacing-tight:-.025em;--letter-spacing-normal:0;--letter-spacing-wide:.025em;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-base:.25s cubic-bezier(.4,0,.2,1);--transition-slow:.4s cubic-bezier(.4,0,.2,1);--transition-bounce:.5s cubic-bezier(.34,1.56,.64,1);--z-base:0;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-toast:400;--z-tooltip:500;--sidebar-width:260px;--sidebar-collapsed-width:72px;--header-height:60px;--content-max-width:1200px;--reader-max-width:720px}[data-theme=dark]{--color-bg-primary:#000;--color-bg-secondary:#0a0a0a;--color-bg-tertiary:#141414;--color-bg-elevated:#1c1c1e;--color-bg-glass:#1c1c1ed9;--color-text-primary:#f5f5f7;--color-text-secondary:#a1a1a6;--color-text-tertiary:#6e6e73;--color-text-inverse:#1d1d1f;--color-accent:#0a84ff;--color-accent-hover:#409cff;--color-accent-subtle:#0a84ff26;--color-border:#ffffff14;--color-border-strong:#ffffff26;--color-divider:#ffffff0d;--gradient-card:linear-gradient(145deg,#1c1c1ef2 0%,#1c1c1ecc 100%);--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 40px #0a84ff33}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh;transition:background-color var(--transition-base),color var(--transition-base)}.heading-1{font-size:var(--text-5xl);letter-spacing:var(--letter-spacing-tight);font-weight:700;line-height:var(--line-height-tight)}.heading-2{font-size:var(--text-4xl);letter-spacing:var(--letter-spacing-tight);font-weight:600;line-height:var(--line-height-tight)}.heading-3{font-size:var(--text-2xl);letter-spacing:var(--letter-spacing-tight);font-weight:600}.heading-4{font-size:var(--text-xl);font-weight:600}.body-large{font-size:var(--text-lg);line-height:var(--line-height-relaxed)}.body-small{font-size:var(--text-sm);color:var(--color-text-secondary)}.caption{font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-5);font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;font-weight:500;text-decoration:none;display:inline-flex}.btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.btn-primary{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-md),var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-border-strong)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{background:var(--color-accent-subtle);color:var(--color-accent)}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;padding:0}.btn-lg{padding:var(--space-4)var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg)}.card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.card:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-md)}.card-elevated{background:var(--color-bg-elevated);box-shadow:var(--shadow-lg);border:none}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px)}.glass{background:var(--color-bg-glass);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--color-border)}.input{width:100%;padding:var(--space-3)var(--space-4);font-size:var(--text-base);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-fast)}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle);outline:none}.input::placeholder{color:var(--color-text-tertiary)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:var(--z-sticky);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--color-divider)}.sidebar-logo{align-items:center;gap:var(--space-3);font-size:var(--text-xl);color:var(--color-text-primary);font-weight:700;text-decoration:none;display:flex}.sidebar-logo-icon{background:var(--gradient-accent);border-radius:var(--radius-md);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;font-weight:700;display:flex}.sidebar-nav{padding:var(--space-4);flex:1;overflow-y:auto}.nav-section{margin-bottom:var(--space-6)}.nav-section-title{padding:var(--space-2)var(--space-3);font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-weight:600}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3)var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:var(--space-1);font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--color-accent-subtle);color:var(--color-accent)}.nav-item.active{background:var(--color-accent-subtle);color:var(--color-accent);font-weight:600}.nav-item-icon{opacity:.8;width:20px;height:20px}a{color:inherit;text-decoration:none}.app-container{width:100%;min-height:100vh;display:flex}.main-content{background:var(--color-bg-primary);flex-direction:column;flex:1;min-height:100vh;margin-left:0;display:flex;overflow-x:hidden}.page-container{width:100%;max-width:100%;padding:var(--space-6);margin:0}.continue-card,.continue-card:hover,.continue-card:visited,.continue-card:active,.continue-card h3,.continue-card p,.filter-card,.filter-card:hover,.filter-card:visited,.filter-card:active{text-decoration:none!important}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--text-3xl);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:700}.page-subtitle{font-size:var(--text-lg);color:var(--color-text-secondary)}.book-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.book-card{aspect-ratio:2/3;border-radius:var(--radius-lg);background:var(--color-bg-tertiary);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.book-card:hover{box-shadow:var(--shadow-xl);transform:scale(1.02)translateY(-4px)}.book-card-cover{object-fit:cover;width:100%;height:100%}.book-card-overlay{opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(#0000 50%,#000c 100%);position:absolute;inset:0}.book-card:hover .book-card-overlay{opacity:1}.book-card-info{padding:var(--space-4);color:#fff;opacity:0;transition:all var(--transition-fast);position:absolute;bottom:0;left:0;right:0;transform:translateY(10px)}.book-card:hover .book-card-info{opacity:1;transform:translateY(0)}.book-card-title{font-size:var(--text-sm);margin-bottom:var(--space-1);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:600;display:-webkit-box;overflow:hidden}.book-card-author{font-size:var(--text-xs);opacity:.8}.book-card-progress{background:#fff3;height:3px;position:absolute;bottom:0;left:0;right:0}.book-card-progress-bar{background:var(--gradient-accent);height:100%;transition:width var(--transition-base)}.reader-container{background:var(--color-bg-primary);height:100vh;display:flex}.reader-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.reader-toolbar{padding:var(--space-3)var(--space-6);background:var(--color-bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.reader-content{flex:1;justify-content:center;display:flex;overflow:auto}.reader-viewport{max-width:var(--reader-max-width);width:100%;padding:var(--space-12)var(--space-8)}.reader-footer{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-secondary);border-top:1px solid var(--color-border);display:flex}.reader-sidebar{background:var(--color-bg-secondary);border-left:1px solid var(--color-border);flex-direction:column;width:320px;display:flex;overflow:hidden}.reader-sidebar-header{padding:var(--space-4);border-bottom:1px solid var(--color-border)}.reader-sidebar-tabs{gap:var(--space-1);background:var(--color-bg-tertiary);padding:var(--space-1);border-radius:var(--radius-md);display:flex}.reader-sidebar-tab{padding:var(--space-2);font-size:var(--text-sm);text-align:center;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex:1;font-weight:500}.reader-sidebar-tab.active{background:var(--color-bg-elevated);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.reader-sidebar-content{padding:var(--space-4);flex:1;overflow-y:auto}.activity-ring{width:120px;height:120px;position:relative}.activity-ring svg{transform:rotate(-90deg)}.activity-ring-bg{fill:none;stroke:var(--color-bg-tertiary);stroke-width:10px}.activity-ring-progress{fill:none;stroke-width:10px;stroke-linecap:round;transition:stroke-dashoffset var(--transition-slow)}.activity-ring-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.drop-zone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-xl);padding:var(--space-16);text-align:center;transition:all var(--transition-fast);cursor:pointer}.drop-zone:hover,.drop-zone.active{border-color:var(--color-accent);background:var(--color-accent-subtle)}.drop-zone-icon{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--color-text-tertiary)}.drop-zone-text{font-size:var(--text-lg);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.drop-zone-hint{font-size:var(--text-sm);color:var(--color-text-tertiary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-fast);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;visibility:visible}.modal{background:var(--color-bg-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:500px;max-height:90vh;transition:transform var(--transition-fast);overflow:hidden;transform:scale(.95)}.modal-overlay.open .modal{transform:scale(1)}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-xl);font-weight:600}.modal-body{padding:var(--space-6);overflow-y:auto}.modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-4)var(--space-6);border-top:1px solid var(--color-border);background:var(--color-bg-secondary);display:flex}.stat-card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.stat-value{font-size:var(--text-4xl);color:var(--color-text-primary);font-weight:700;line-height:1}.stat-label{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}.stat-trend{align-items:center;gap:var(--space-1);font-size:var(--text-sm);margin-top:var(--space-2);font-weight:500;display:inline-flex}.stat-trend.up{color:var(--color-success)}.stat-trend.down{color:var(--color-error)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-base)ease-out}.animate-slide-up{animation:slideUp var(--transition-base)ease-out}.animate-slide-in{animation:slideIn var(--transition-base)ease-out}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-spin{animation:1s linear infinite spin}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary)25%,var(--color-bg-secondary)50%,var(--color-bg-tertiary)75%);background-size:200% 100%;animation:1.5s infinite shimmer}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.flex-center{justify-content:center;align-items:center;display:flex}.stack{gap:var(--space-4);flex-direction:column;display:flex}.row{align-items:center;gap:var(--space-4);display:flex}.library-header{margin-bottom:var(--space-6)}.category-tabs{gap:var(--space-6);border-bottom:1px solid var(--color-border);margin-top:var(--space-4);display:flex}.category-tab{font-size:var(--text-sm);color:var(--color-text-secondary);padding:var(--space-3)0;cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-weight:500;position:relative}.category-tab:hover{color:var(--color-text-primary)}.category-tab.active{color:var(--color-accent);font-weight:600}.category-tab.active:after{content:"";background:var(--color-accent);border-radius:var(--radius-full);height:2px;position:absolute;bottom:-1px;left:0;right:0}.library-toolbar{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-8);flex-wrap:wrap;display:flex}.toolbar-left,.toolbar-right{align-items:center;gap:var(--space-3);display:flex}.sort-btn{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;display:flex}.sort-label{color:var(--color-accent);font-weight:500}.sort-select-hidden{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;top:0;left:0}.btn-import{border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:0;display:flex}.status-indicator{right:var(--space-2);top:var(--space-2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;background:#0009;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:absolute}.status-indicator.favorite{color:gold}
