:root{--bg: #051424;--bg-rgb: 5, 20, 36;--sidebar-bg: rgba(5,20,36,.97);--bg-elev: #122031;--primary: #cabeff;--primary-rgb: 202, 190, 255;--primary-hover: #d8ceff;--primary-glow: rgba(202,190,255,.25);--primary-10: rgba(202,190,255,.1);--primary-12: rgba(202,190,255,.12);--primary-18: rgba(202,190,255,.18);--primary-35: rgba(202,190,255,.35);--text-primary: #e8e4f5;--text-secondary: #c9c3dd;--text-muted: rgba(232,228,245,.55);--text-faint: rgba(232,228,245,.3);--border-glass: rgba(202,190,255,.12);--border-soft: rgba(202,190,255,.18);--border-strong: rgba(202,190,255,.36);--surface-container: #122031;--surface-container-high: #1d2b3c;--card-bg: #122031;--card-glass: rgba(18,32,49,.72);--tooltip-bg: #0b1422;--tooltip-text: #e8e4f5;--tooltip-border: rgba(202,190,255,.34);--chart-line: #cabeff;--chart-fill-start: rgba(202,190,255,.4);--chart-fill-end: rgba(202,190,255,.03);--heat-0: #1a2437;--heat-1: #2a3650;--heat-2: #3e4f73;--heat-3: #596f9f;--heat-4: #8fa8df;--focus-ring: rgba(202,190,255,.52);--success: #6ee7b7;--info: #60a5fa;--warning: #fbbf24;--error: #ffb4ab;--danger: #ffb4ab;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 20px;--space-5: 32px;--space-6: 48px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-glass: 0 8px 32px rgba(0,0,0,.3);--shadow-card: 0 4px 16px rgba(0,0,0,.2);--sidebar-width: 240px;--right-panel-width: 260px}[data-theme=canopy]{--bg: #040f08;--bg-rgb: 4,15,8;--sidebar-bg: rgba(4,15,8,.97);--bg-elev: #122018;--primary: #6ee7b7;--primary-rgb: 110,231,183;--primary-hover: #93f0cc;--primary-glow: rgba(110,231,183,.25);--primary-10: rgba(110,231,183,.1);--primary-12: rgba(110,231,183,.12);--primary-18: rgba(110,231,183,.18);--primary-35: rgba(110,231,183,.35);--border-glass: rgba(110,231,183,.12);--border-soft: rgba(110,231,183,.2);--border-strong: rgba(110,231,183,.38);--text-primary: #e2f0eb;--text-secondary: #b8d6cb;--text-muted: rgba(226,240,235,.55);--text-faint: rgba(226,240,235,.3);--surface-container: #122018;--surface-container-high: #1a2f24;--card-bg: #122018;--card-glass: rgba(18,32,24,.72)}[data-theme=ember]{--bg: #0f0a04;--bg-rgb: 15,10,4;--sidebar-bg: rgba(15,10,4,.97);--bg-elev: #22180e;--primary: #fbbf24;--primary-rgb: 251,191,36;--primary-hover: #fcd05c;--primary-glow: rgba(251,191,36,.25);--primary-10: rgba(251,191,36,.1);--primary-12: rgba(251,191,36,.12);--primary-18: rgba(251,191,36,.18);--primary-35: rgba(251,191,36,.35);--border-glass: rgba(251,191,36,.12);--border-soft: rgba(251,191,36,.2);--border-strong: rgba(251,191,36,.38);--text-primary: #f5f0e8;--text-secondary: #dfd0b8;--text-muted: rgba(245,240,232,.55);--text-faint: rgba(245,240,232,.3);--surface-container: #22180e;--surface-container-high: #2f2418;--card-bg: #22180e;--card-glass: rgba(34,24,14,.72)}[data-theme=abyss]{--bg: #020d0f;--bg-rgb: 2,13,15;--sidebar-bg: rgba(2,13,15,.97);--bg-elev: #0f1d21;--primary: #22d3ee;--primary-rgb: 34,211,238;--primary-hover: #67e8f9;--primary-glow: rgba(34,211,238,.25);--primary-10: rgba(34,211,238,.1);--primary-12: rgba(34,211,238,.12);--primary-18: rgba(34,211,238,.18);--primary-35: rgba(34,211,238,.35);--border-glass: rgba(34,211,238,.12);--border-soft: rgba(34,211,238,.2);--border-strong: rgba(34,211,238,.38);--text-primary: #e0f4f7;--text-secondary: #b7dce2;--text-muted: rgba(224,244,247,.55);--text-faint: rgba(224,244,247,.3);--surface-container: #0f1d21;--surface-container-high: #173039;--card-bg: #0f1d21;--card-glass: rgba(15,29,33,.72)}[data-theme=velvet]{--bg: #0d0509;--bg-rgb: 13,5,9;--sidebar-bg: rgba(13,5,9,.97);--bg-elev: #22121a;--primary: #fb7185;--primary-rgb: 251,113,133;--primary-hover: #fda4b0;--primary-glow: rgba(251,113,133,.25);--primary-10: rgba(251,113,133,.1);--primary-12: rgba(251,113,133,.12);--primary-18: rgba(251,113,133,.18);--primary-35: rgba(251,113,133,.35);--border-glass: rgba(251,113,133,.12);--border-soft: rgba(251,113,133,.2);--border-strong: rgba(251,113,133,.38);--text-primary: #f5e8ee;--text-secondary: #ddc2cd;--text-muted: rgba(245,232,238,.55);--text-faint: rgba(245,232,238,.3);--surface-container: #22121a;--surface-container-high: #341a28;--card-bg: #22121a;--card-glass: rgba(34,18,26,.72)}[data-theme=abyss_graphite]{--bg: #070B12;--bg-rgb: 7,11,18;--sidebar-bg: rgba(10,17,29,.97);--bg-elev: #0D1522;--primary: #7E8CFF;--primary-rgb: 126,140,255;--primary-hover: #98A4FF;--primary-glow: rgba(126,140,255,.32);--primary-10: rgba(126,140,255,.1);--primary-12: rgba(126,140,255,.12);--primary-18: rgba(126,140,255,.18);--primary-35: rgba(126,140,255,.35);--border-glass: rgba(154,174,208,.18);--border-soft: rgba(154,174,208,.18);--border-strong: rgba(154,174,208,.36);--text-primary: #EAF1FF;--text-secondary: #A8B6CF;--text-muted: rgba(168,182,207,.7);--text-faint: rgba(168,182,207,.4);--surface-container: #0D1626;--surface-container-high: #162236;--card-bg: #0D1626;--card-glass: rgba(15,25,40,.72);--success: #34D399;--warning: #FBBF24;--error: #FB7185;--danger: #FB7185}[data-theme=neon_mint_ledger]{--bg: #06110F;--bg-rgb: 6,17,15;--sidebar-bg: rgba(9,24,21,.97);--bg-elev: #0C1D19;--primary: #35D6C0;--primary-rgb: 53,214,192;--primary-hover: #53E6D1;--primary-glow: rgba(53,214,192,.34);--primary-10: rgba(53,214,192,.1);--primary-12: rgba(53,214,192,.12);--primary-18: rgba(53,214,192,.18);--primary-35: rgba(53,214,192,.35);--border-glass: rgba(124,190,174,.2);--border-soft: rgba(124,190,174,.2);--border-strong: rgba(124,190,174,.38);--text-primary: #E9FFF8;--text-secondary: #9FD1C3;--text-muted: rgba(159,209,195,.72);--text-faint: rgba(159,209,195,.4);--surface-container: #0D241F;--surface-container-high: #133229;--card-bg: #0D241F;--card-glass: rgba(13,36,31,.7);--success: #22C55E;--warning: #F59E0B;--error: #F87171;--danger: #F87171}[data-theme=ember_night]{--bg: #120B0A;--bg-rgb: 18,11,10;--sidebar-bg: rgba(23,15,13,.97);--bg-elev: #1D1311;--primary: #FF8A5B;--primary-rgb: 255,138,91;--primary-hover: #FFA37E;--primary-glow: rgba(255,138,91,.34);--primary-10: rgba(255,138,91,.1);--primary-12: rgba(255,138,91,.12);--primary-18: rgba(255,138,91,.18);--primary-35: rgba(255,138,91,.35);--border-glass: rgba(208,157,139,.22);--border-soft: rgba(208,157,139,.22);--border-strong: rgba(208,157,139,.4);--text-primary: #FFF3EE;--text-secondary: #D6BBB0;--text-muted: rgba(214,187,176,.72);--text-faint: rgba(214,187,176,.42);--surface-container: #241714;--surface-container-high: #321f1b;--card-bg: #241714;--card-glass: rgba(36,23,20,.7);--success: #4ADE80;--warning: #FBBF24;--error: #FB7185;--danger: #FB7185}[data-theme=mist_paper]{--bg: #131b2a;--bg-rgb: 19,27,42;--sidebar-bg: rgba(19,27,42,.97);--bg-elev: #1b2740;--primary: #7f93ff;--primary-rgb: 127,147,255;--primary-hover: #9baafe;--primary-glow: rgba(127,147,255,.26);--primary-10: rgba(91,108,250,.1);--primary-12: rgba(91,108,250,.12);--primary-18: rgba(91,108,250,.18);--primary-35: rgba(91,108,250,.35);--border-glass: rgba(130,150,210,.18);--border-soft: rgba(130,150,210,.2);--border-strong: rgba(130,150,210,.36);--text-primary: #e8eefc;--text-secondary: #b8c6e7;--text-muted: rgba(184,198,231,.7);--text-faint: rgba(184,198,231,.42);--surface-container: #1b2740;--surface-container-high: #253454;--card-bg: #1b2740;--card-glass: rgba(27,39,64,.76);--success: #16A34A;--warning: #D97706;--error: #DC2626;--danger: #DC2626}[data-theme=sage_linen]{--bg: #101b17;--bg-rgb: 16,27,23;--sidebar-bg: rgba(16,27,23,.97);--bg-elev: #16251f;--primary: #45b896;--primary-rgb: 69,184,150;--primary-hover: #65c8aa;--primary-glow: rgba(69,184,150,.26);--primary-10: rgba(47,143,115,.1);--primary-12: rgba(47,143,115,.12);--primary-18: rgba(47,143,115,.18);--primary-35: rgba(47,143,115,.35);--border-glass: rgba(91,146,129,.18);--border-soft: rgba(91,146,129,.2);--border-strong: rgba(91,146,129,.36);--text-primary: #e7f5f0;--text-secondary: #b8d9ce;--text-muted: rgba(184,217,206,.7);--text-faint: rgba(184,217,206,.42);--surface-container: #16251f;--surface-container-high: #20342c;--card-bg: #16251f;--card-glass: rgba(22,37,31,.76);--success: #15803D;--warning: #B7791F;--error: #C53030;--danger: #C53030}[data-theme=royal_plum]{--bg: #0B0A14;--bg-rgb: 11,10,20;--sidebar-bg: rgba(16,15,32,.97);--bg-elev: #141226;--primary: #9B7BFF;--primary-rgb: 155,123,255;--primary-hover: #AF95FF;--primary-glow: rgba(155,123,255,.35);--primary-10: rgba(155,123,255,.1);--primary-12: rgba(155,123,255,.12);--primary-18: rgba(155,123,255,.18);--primary-35: rgba(155,123,255,.35);--border-glass: rgba(166,150,222,.2);--border-soft: rgba(166,150,222,.2);--border-strong: rgba(166,150,222,.38);--text-primary: #F0EEFF;--text-secondary: #B7AFD8;--text-muted: rgba(183,175,216,.72);--text-faint: rgba(183,175,216,.42);--surface-container: #191731;--surface-container-high: #221f3d;--card-bg: #191731;--card-glass: rgba(25,23,49,.72);--success: #34D399;--warning: #F59E0B;--error: #FB7185;--danger: #FB7185}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;background-color:var(--bg);background-image:radial-gradient(ellipse 800px 600px at 60% -10%,rgba(var(--primary-rgb),.1) 0%,transparent 70%),radial-gradient(ellipse 600px 500px at -10% 100%,rgba(96,165,250,.07) 0%,transparent 70%);color:#d5e4fa;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}html.session-mobile-scroll-lock,body.session-mobile-scroll-lock{overflow:hidden!important;overscroll-behavior:none}html.session-mobile-scroll-lock #main-content,html.session-mobile-scroll-lock #page-content,body.session-mobile-scroll-lock #main-content,body.session-mobile-scroll-lock #page-content{overflow:hidden!important}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;-webkit-user-select:none;user-select:none}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(var(--primary-rgb),.15);border-radius:10px}#sidebar{position:fixed;left:0;top:0;height:100vh;width:240px;background:var(--sidebar-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-right:1px solid rgba(var(--primary-rgb),.12);display:flex;flex-direction:column;z-index:100;transition:width .25s cubic-bezier(.4,0,.2,1);overflow:hidden}#sidebar.collapsed{width:64px}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:0 16px;height:72px;border-bottom:1px solid rgba(var(--primary-rgb),.1);flex-shrink:0}.sidebar-logo-icon{width:38px;height:38px;background:rgba(var(--primary-rgb),.15);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary)}.sidebar-logo-text{overflow:hidden;white-space:nowrap}.sidebar-logo-text h1{font-size:18px;font-weight:700;color:var(--primary);letter-spacing:-.01em}.sidebar-logo-text p{font-size:10px;font-weight:600;color:#e8e4f559;text-transform:uppercase;letter-spacing:.1em;margin-top:1px}#sidebar.collapsed .sidebar-logo-text{display:none}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto;overflow-x:hidden}.nav-item{display:flex;align-items:center;gap:12px;height:44px;padding:0 12px;margin:2px 8px;border-radius:8px;cursor:pointer;color:#e8e4f58c;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s ease,color .15s ease;white-space:nowrap;position:relative}.nav-item:hover{background:#ffffff0d;color:#e8e4f5}.nav-item.active{background:rgba(var(--primary-rgb),.1);color:var(--primary);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--primary);border-radius:0 3px 3px 0}.nav-item.dimmed{opacity:.35;pointer-events:none}.nav-label{overflow:hidden;white-space:nowrap}#sidebar.collapsed .nav-label{display:none}#sidebar.collapsed .nav-item{justify-content:center;margin:2px 6px}#sidebar.collapsed .nav-item.active:before{left:-6px}.nav-divider{height:1px;background:rgba(var(--primary-rgb),.08);margin:8px 16px}.soon-chip{font-size:9px;font-weight:700;letter-spacing:.08em;background:rgba(var(--primary-rgb),.12);color:rgba(var(--primary-rgb),.5);padding:2px 6px;border-radius:99px;text-transform:uppercase;margin-left:auto}#sidebar.collapsed .soon-chip{display:none}.sidebar-user{border-top:1px solid rgba(var(--primary-rgb),.1);height:72px;display:flex;align-items:center;gap:10px;padding:0 14px;flex-shrink:0}.user-avatar{width:34px;height:34px;background:rgba(var(--primary-rgb),.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--primary);flex-shrink:0}.user-name{font-size:14px;font-weight:500;color:#e8e4f5;overflow:hidden;white-space:nowrap;flex:1}.user-settings{color:#e8e4f573;cursor:pointer;transition:color .15s}.user-settings:hover{color:#e8e4f5}#sidebar.collapsed .user-name,#sidebar.collapsed .user-settings{display:none}#sidebar.collapsed .sidebar-user{justify-content:center}#sidebar-toggle{position:fixed;left:228px;top:50%;transform:translateY(-50%);z-index:101;width:22px;height:22px;background:rgba(var(--primary-rgb),.15);border:1px solid rgba(var(--primary-rgb),.2);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:left .25s cubic-bezier(.4,0,.2,1),background .15s;color:var(--primary)}#sidebar-toggle:hover{background:rgba(var(--primary-rgb),.25)}#sidebar-toggle.collapsed{left:52px}#sidebar-toggle .material-symbols-outlined{font-size:14px}#main-content{margin-left:240px;min-height:100vh;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}#main-content.sidebar-collapsed{margin-left:64px}#top-bar{position:sticky;top:0;height:56px;background:rgba(var(--bg-rgb),.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(var(--primary-rgb),.12);display:flex;align-items:center;padding:0 32px;gap:16px;z-index:90}.topbar-title{font-size:17px;font-weight:600;color:#e8e4f5;white-space:nowrap;min-width:120px}.topbar-search{flex:1;max-width:480px;margin:0 auto;position:relative}.topbar-search input{width:100%;background:#00000038;border:1px solid rgba(var(--primary-rgb),.13);border-radius:9999px;padding:7px 18px 7px 42px;font-size:14px;color:#e8e4f5;font-family:Inter,sans-serif;outline:none;transition:border-color .15s,box-shadow .15s}.topbar-search input::placeholder{color:#e8e4f54d}.topbar-search input:focus{border-color:rgba(var(--primary-rgb),.4);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.topbar-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#e8e4f559;font-size:18px;pointer-events:none}.topbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}.streak-chip{display:flex;align-items:center;gap:5px;background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.15);border-radius:9999px;padding:5px 12px;font-size:13px;font-weight:600;color:#fbbf24;white-space:nowrap}.topbar-avatar{width:32px;height:32px;background:#8b5cf640;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#a78bfa;border:1.5px solid rgba(var(--primary-rgb),.25);cursor:pointer}#page-content{padding:32px;max-width:1280px}.screen{display:none}.screen.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.screen.active{animation:fadeIn .2s ease both}.glass-card{background:#ffffff0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(var(--primary-rgb),.12);border-radius:16px}.glass-card--interactive{cursor:pointer;transition:background .15s,border-color .15s}.glass-card--interactive:hover{background:#fff1;border-color:rgba(var(--primary-rgb),.22)}.prog-track{width:100%;height:8px;background:rgba(var(--primary-rgb),.13);border-radius:9999px;overflow:hidden}.prog-fill{height:100%;background:linear-gradient(90deg,var(--primary) 0%,#60a5fa 100%);border-radius:9999px;transition:width 1s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.prog-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.22) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2.4s ease infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.stat-card{padding:20px 22px;display:flex;flex-direction:column;justify-content:space-between}.stat-val{font-size:28px;font-weight:700;color:#e8e4f5;line-height:1;font-variant-numeric:tabular-nums}.stat-label{font-size:11px;font-weight:600;color:#e8e4f580;text-transform:uppercase;letter-spacing:.1em}.stat-delta-up{font-size:11px;font-weight:600;color:#6ee7b7;background:#6ee7b71f;padding:2px 7px;border-radius:99px}.stat-delta-down{font-size:11px;font-weight:600;color:#ffb4ab;background:#ffb4ab1f;padding:2px 7px;border-radius:99px}.stat-delta-date{font-size:11px;font-weight:600;color:#e8e4f580;background:rgba(var(--primary-rgb),.08);padding:2px 7px;border-radius:99px}.book-card{border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;background:#ffffff0a;border:1px solid rgba(var(--primary-rgb),.12)}.book-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0009,0 0 20px rgba(var(--primary-rgb),.12)}.book-cover{aspect-ratio:2/3;width:100%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.book-cover-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px;position:relative}.book-card-info{padding:10px 12px 12px}.book-card-title{font-size:13px;font-weight:600;color:#e8e4f5;line-height:1.3;margin-bottom:2px}.book-card-author{font-size:11px;color:#e8e4f58c;margin-bottom:8px}.genre-chip{display:inline-flex;align-items:center;padding:3px 9px;background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.2);border-radius:9999px;font-size:10px;font-weight:600;color:var(--primary);text-transform:none;letter-spacing:.06em;white-space:nowrap;transition:background .15s,border-color .15s}.genre-chip[style*=cursor]{-webkit-user-select:none;user-select:none}.genre-chip[style*=cursor]:hover{background:rgba(var(--primary-rgb),.2);border-color:rgba(var(--primary-rgb),.4)}.genre-chip.active{background:var(--primary);color:var(--bg);border-color:var(--primary)}.stars{color:#fbbf24;letter-spacing:1px;font-size:13px}.stars.dim{color:#e8e4f533}.filter-chip{padding:6px 16px;border-radius:9999px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid rgba(var(--primary-rgb),.18);color:#e8e4f58c;background:transparent;transition:all .15s;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}.filter-chip:hover{color:#e8e4f5;border-color:rgba(var(--primary-rgb),.35)}.filter-chip:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.filter-chip.active{background:var(--primary);color:var(--bg);border-color:var(--primary)}.timer-ring-wrap{position:relative;width:260px;height:260px;display:flex;align-items:center;justify-content:center}.timer-ring-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.timer-glow{filter:drop-shadow(0 0 8px rgba(var(--primary-rgb),.5))}.timer-digits{font-size:52px;font-weight:800;color:#e8e4f5;font-variant-numeric:tabular-nums;letter-spacing:-.03em;text-shadow:0 0 30px rgba(var(--primary-rgb),.45);line-height:1;text-align:center}@keyframes pulse-ring{0%{transform:scale(.97);opacity:.4}50%{transform:scale(1);opacity:.15}to{transform:scale(.97);opacity:.4}}.ring-pulse{animation:pulse-ring 3s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.chart-bar-wrap{height:220px;display:flex;align-items:flex-end;gap:8px;padding-bottom:24px;position:relative}.chart-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:0;height:100%;justify-content:flex-end;position:relative;overflow:visible}.chart-bar{width:100%;background:rgba(var(--primary-rgb),.35);border-radius:4px 4px 0 0;transition:background .2s,height .5s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;min-height:3px}.chart-bar:hover{background:rgba(var(--primary-rgb),.65)}.chart-bar.today{background:linear-gradient(180deg,var(--primary) 0%,rgba(var(--primary-rgb),.65) 100%);box-shadow:0 0 14px rgba(var(--primary-rgb),.4)}.chart-bar-label{font-size:10px;font-weight:600;color:#e8e4f566;text-transform:uppercase;letter-spacing:.06em;position:absolute;bottom:-18px;left:50%;transform:translate(-50%);white-space:nowrap}.heatmap-wrap{display:flex;flex-direction:column;gap:4px;overflow-x:auto}.heatmap-months{display:flex;align-items:flex-end;padding-left:28px}.heatmap-month-label{font-size:10px;font-weight:600;font-family:Inter,sans-serif;color:#e8e4f561;white-space:nowrap;overflow:hidden;flex-shrink:0}.heatmap-body{display:flex;gap:4px;align-items:flex-start}.heatmap-days{display:flex;flex-direction:column;gap:2px;flex-shrink:0;width:24px}.heatmap-day-label{font-size:9px;font-weight:500;font-family:Inter,sans-serif;color:#e8e4f552;height:12px;line-height:12px;text-align:right;white-space:nowrap}.heatmap-grid{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,12px);gap:2px}.heatmap-cell{width:12px;height:12px;border-radius:2px;cursor:pointer;transition:box-shadow .1s}.heatmap-cell:hover{box-shadow:0 0 0 1px rgba(var(--primary-rgb),.6)}.hm-0{background:rgba(var(--primary-rgb),.05)}.hm-1{background:rgba(var(--primary-rgb),.18)}.hm-2{background:rgba(var(--primary-rgb),.38)}.hm-3{background:rgba(var(--primary-rgb),.6)}.hm-4{background:var(--primary)}.genre-bar-row{display:flex;align-items:center;gap:12px;padding:4px 0}.genre-bar-label{font-size:12px;font-weight:500;color:#e8e4f5a6;width:100px;flex-shrink:0}.genre-bar-track{flex:1;height:10px;background:rgba(var(--primary-rgb),.1);border-radius:9999px;overflow:hidden}.genre-bar-fill{height:100%;border-radius:9999px;transition:width .6s cubic-bezier(.4,0,.2,1)}.genre-bar-pct{font-size:12px;font-weight:600;color:#e8e4f580;width:36px;text-align:right;flex-shrink:0}.period-tabs{display:inline-flex;background:#00000040;border:1px solid rgba(var(--primary-rgb),.12);border-radius:9999px;padding:3px;gap:2px;position:relative}.period-tab{padding:8px 20px;border-radius:9999px;font-size:13px;font-weight:500;color:#e8e4f58c;cursor:pointer;border:none;background:transparent;font-family:Inter,sans-serif;transition:color .2s;position:relative;z-index:1;white-space:nowrap}.period-tab:hover:not(.active){color:#e8e4f5}.period-tab.active{color:var(--bg)}.period-pill{position:absolute;top:3px;bottom:3px;background:var(--primary);border-radius:9999px;box-shadow:0 2px 12px rgba(var(--primary-rgb),.35);transition:left .25s cubic-bezier(.34,1.56,.64,1),width .25s cubic-bezier(.34,1.56,.64,1);z-index:0}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--primary);color:var(--bg);border:none;border-radius:9999px;padding:12px 28px;font-size:14px;font-weight:700;font-family:Inter,sans-serif;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 20px rgba(var(--primary-rgb),.45)}.btn-primary:active{transform:scale(.97)}.btn-primary:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:rgba(var(--primary-rgb),.08);color:#dfe8f8;border:1px solid rgba(var(--primary-rgb),.28);border-radius:9999px;padding:10px 18px;font-size:13px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .1s}.btn-secondary:hover{background:rgba(var(--primary-rgb),.16);border-color:rgba(var(--primary-rgb),.42);color:#e8e4f5}.btn-secondary:active{transform:scale(.98)}.btn-secondary:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:rgba(var(--primary-rgb),.06);color:var(--primary);border:1px solid rgba(var(--primary-rgb),.35);border-radius:9999px;padding:11px 24px;font-size:14px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:background .15s,border-color .15s}.btn-ghost:hover{background:rgba(var(--primary-rgb),.14);border-color:rgba(var(--primary-rgb),.55)}.btn-ghost:active{transform:scale(.97)}.btn-ghost:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.currently-reading-card{display:flex;gap:24px;padding:24px;align-items:flex-start}.cr-cover{border-radius:8px;flex-shrink:0;box-shadow:0 8px 32px #00000080;display:flex;align-items:center;justify-content:center;font-size:28px;position:relative;overflow:hidden}.cr-info{flex:1;min-width:0}.activity-row{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid rgba(var(--primary-rgb),.07);transition:background .15s,transform .15s}.activity-row:hover{background:#ffffff06;border-radius:8px;transform:translate(4px)}.activity-row:last-child{border-bottom:none}.session-layout-v5{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;padding:0 0 40px}.session-left-col{display:flex;flex-direction:column;align-items:center;gap:0}.session-topbar-mini{width:100%;display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.session-x-btn{width:36px;height:36px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(var(--primary-rgb),.14);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#e8e4f580;transition:background .15s,color .15s}.session-x-btn:hover{background:#ffb4ab1f;color:#ffb4ab;border-color:#ffb4ab40}.session-x-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.session-rec-pill{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:#6ee7b7;text-transform:uppercase;letter-spacing:.1em;background:#6ee7b714;border:1px solid rgba(110,231,183,.18);border-radius:9999px;padding:5px 14px}.session-rec-pill.paused{color:#fbbf24;background:#fbbf2414;border-color:#fbbf242e}.session-rec-dot{width:7px;height:7px;background:#6ee7b7;border-radius:50%;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 6px #6ee7b7;flex-shrink:0}.session-rec-pill.paused .session-rec-dot{background:#fbbf24;box-shadow:0 0 6px #fbbf24;animation:none}.session-finish-btn{background:var(--primary);color:var(--bg);border:none;border-radius:9999px;padding:8px 24px;font-size:14px;font-weight:700;font-family:Inter,sans-serif;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s}.session-finish-btn:hover{background:var(--primary-hover);box-shadow:0 4px 20px rgba(var(--primary-rgb),.45)}.session-finish-btn:active{transform:scale(.96)}.session-finish-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.session-book-hero{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;margin-bottom:4px}.session-cover-box{position:relative;width:148px;height:auto;aspect-ratio:2 / 3;border-radius:12px;overflow:visible;flex-shrink:0;margin-bottom:18px;box-shadow:0 16px 56px #000000a6,0 0 0 1px rgba(var(--primary-rgb),.1)}.session-cover-box img{width:100%;height:100%;object-fit:cover;border-radius:12px;display:block}.session-from-badge{position:absolute;bottom:-13px;right:-12px;background:rgba(var(--bg-rgb),.9);border:1px solid rgba(var(--primary-rgb),.28);border-radius:9999px;padding:5px 14px;font-size:12px;font-weight:700;color:var(--primary);white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 16px rgba(var(--primary-rgb),.2)}.session-book-title-text{font-size:19px;font-weight:700;color:#e8e4f5;line-height:1.25;letter-spacing:-.01em;margin-bottom:3px}.session-book-author-text{font-size:13px;color:#e8e4f580;margin-bottom:12px}.session-book-progress-row{width:100%;max-width:280px}.session-book-pct-lbl{font-size:11px;font-weight:600;color:var(--primary);display:block;margin-bottom:4px}.session-goal-row{display:flex;align-items:center;gap:6px;margin:20px 0 0;font-size:14px;font-weight:500;color:#e8e4f573}.session-actions-bar{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:24px;width:100%}.session-action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;background:#ffffff0d;border:1px solid rgba(var(--primary-rgb),.12);border-radius:18px;width:82px;height:82px;justify-content:center;cursor:pointer;color:#e8e4f580;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;font-family:Inter,sans-serif;transition:all .15s;-webkit-user-select:none;user-select:none}.session-action-btn .material-symbols-outlined{font-size:22px}.session-action-btn:hover:not(:disabled){background:rgba(var(--primary-rgb),.08);color:#e8e4f5;border-color:rgba(var(--primary-rgb),.28);transform:translateY(-1px)}.session-action-btn:disabled{opacity:.28;cursor:not-allowed}.session-action-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.session-action-btn--soon{opacity:.45}.session-action-soon-chip{margin-top:2px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(var(--primary-rgb),.7);background:rgba(var(--primary-rgb),.12);border:1px solid rgba(var(--primary-rgb),.24);border-radius:999px;padding:2px 6px;line-height:1}.session-pause-main{width:92px;height:92px;border-radius:50%;background:rgba(var(--primary-rgb),.09);border:1.5px solid rgba(var(--primary-rgb),.22);color:var(--primary);font-size:11px}.session-pause-main .material-symbols-outlined{font-size:30px}.session-pause-main:hover{background:rgba(var(--primary-rgb),.16);border-color:rgba(var(--primary-rgb),.45);transform:translateY(-1px);box-shadow:0 4px 20px rgba(var(--primary-rgb),.25)}.session-right-col{display:flex;flex-direction:column;gap:20px;padding-top:4px}.session-mobile-note-btn{display:none}.session-bottom-actions{display:flex;justify-content:center;gap:10px;margin-top:12px}.session-cancel-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid rgba(255,180,171,.28);background:#ffb4ab12;color:#ffb4ab;border-radius:9999px;padding:10px 18px;font-family:Inter,sans-serif;font-size:13px;font-weight:700;cursor:pointer}.session-cancel-btn .material-symbols-outlined{font-size:16px}.session-cancel-btn:hover{background:#ffb4ab1f;border-color:#ffb4ab6b}@keyframes overlay-fade{0%{opacity:0}to{opacity:1}}@keyframes picker-enter{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.finish-session-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(var(--bg-rgb),.82);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:overlay-fade .22s ease both}.finish-session-modal{width:100%;max-width:420px;max-height:calc(100dvh - 40px);overflow-y:auto;overscroll-behavior:contain;background:rgba(var(--bg-rgb),.96);border:1px solid rgba(var(--primary-rgb),.18);border-radius:24px;box-shadow:0 28px 80px #000000f2,0 0 0 1px rgba(var(--primary-rgb),.06) inset;display:flex;flex-direction:column;animation:picker-enter .28s cubic-bezier(.34,1.56,.64,1) both;scrollbar-width:thin;scrollbar-color:rgba(var(--primary-rgb),.2) transparent;position:relative}.finish-session-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(var(--primary-rgb),.35) 40%,rgba(var(--primary-rgb),.35) 60%,transparent);border-radius:24px 24px 0 0;pointer-events:none}.finish-session-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid rgba(var(--primary-rgb),.08);flex-shrink:0}.finish-session-header h2{font-size:17px;font-weight:700;color:#e8e4f5;letter-spacing:-.01em}.finish-back-btn{width:34px;height:34px;border-radius:8px;background:#ffffff0a;border:1px solid rgba(var(--primary-rgb),.1);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#e8e4f580;transition:all .15s}.finish-back-btn:hover{background:#ffffff14;color:#e8e4f5}.finish-back-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.finish-discard-btn{background:#ffb4ab14;border:1px solid rgba(255,180,171,.2);color:#ffb4ab;border-radius:9999px;padding:6px 18px;font-size:13px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all .15s}.finish-discard-btn:hover{background:#ffb4ab26;border-color:#ffb4ab59}.finish-book-row{display:flex;align-items:center;gap:14px;padding:16px 24px;border-bottom:1px solid rgba(var(--primary-rgb),.06)}.finish-book-cover{width:44px;height:62px;border-radius:6px;overflow:hidden;flex-shrink:0;background:rgba(var(--primary-rgb),.08);box-shadow:0 4px 16px #0006}.finish-book-cover img{width:100%;height:100%;object-fit:cover;display:block}.finish-book-title{font-size:14px;font-weight:700;color:#e8e4f5;line-height:1.3}.finish-book-author{font-size:12px;color:#e8e4f573;margin-top:2px}.finish-ring-wrap{position:relative;display:flex;align-items:center;justify-content:center;padding:20px 24px 8px}.finish-ring-svg{width:260px;height:260px;cursor:pointer;touch-action:none;flex-shrink:0}.finish-ring-center{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.finish-pct-val{font-size:58px;font-weight:800;color:#e8e4f5;line-height:1;letter-spacing:-.04em;font-variant-numeric:tabular-nums;text-shadow:0 0 40px rgba(var(--primary-rgb),.3)}.finish-pct-label{font-size:13px;font-weight:500;color:#e8e4f566;margin-top:4px}.finish-pct-delta{font-size:11px;font-weight:600;margin-top:6px;letter-spacing:.01em}.finish-info-section{padding:4px 24px 8px}.finish-info-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid rgba(var(--primary-rgb),.07);font-size:14px}.finish-info-row:last-child{border-bottom:none}.finish-info-row>span:first-child{color:#e8e4f566;font-weight:400}.finish-info-row .finish-val{color:#e8e4f5;font-weight:600}.finish-date-chip{background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.15);border-radius:9999px;padding:4px 13px;font-size:12px;font-weight:600;color:var(--primary)}.finish-comment-wrap{padding:0 24px 12px}.finish-comment{width:100%;min-height:90px;resize:none;background:#00000040;border:1px solid rgba(var(--primary-rgb),.12);border-radius:12px;padding:14px 16px;color:#e8e4f5;font-size:14px;font-family:Inter,sans-serif;line-height:1.6;outline:none;transition:border-color .15s,box-shadow .15s}.finish-comment:focus{border-color:rgba(var(--primary-rgb),.4);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.12)}.finish-comment::placeholder{color:#e8e4f540}.finish-save-btn{display:block;width:calc(100% - 48px);margin:0 24px 24px;background:var(--primary);color:var(--bg);border:none;border-radius:9999px;padding:16px;font-size:16px;font-weight:700;font-family:Inter,sans-serif;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s}.finish-save-btn:hover{background:var(--primary-hover);box-shadow:0 6px 24px rgba(var(--primary-rgb),.45)}.finish-save-btn:active{transform:scale(.98)}.finish-save-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.progress-mode-toggle{display:inline-flex;background:#00000038;border:1px solid rgba(var(--primary-rgb),.14);border-radius:9999px;padding:2px;gap:2px;flex-shrink:0}.progress-mode-btn{padding:4px 13px;border-radius:9999px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#e8e4f573;cursor:pointer;border:none;background:transparent;font-family:Inter,sans-serif;transition:background .15s,color .15s,box-shadow .15s;line-height:1.8;white-space:nowrap;-webkit-user-select:none;user-select:none}.progress-mode-btn.active{background:var(--primary);color:var(--bg);box-shadow:0 1px 8px rgba(var(--primary-rgb),.35)}.progress-mode-btn:hover:not(.active){color:#e8e4f5}.progress-mode-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}input[type=number].page-num-input{width:80px;background:#0003!important;border:1px solid rgba(var(--primary-rgb),.2)!important;border-radius:8px;padding:8px 12px;font-size:16px;font-weight:600;color:#e8e4f5!important;text-align:center;font-family:Inter,sans-serif;outline:none;transition:border-color .15s,box-shadow .15s;-moz-appearance:textfield}input[type=number].page-num-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.18)}input[type=number].page-num-input::-webkit-inner-spin-button,input[type=number].page-num-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pct-input-wrap{position:relative;display:inline-flex;align-items:center}input[type=number].pct-input{width:80px;background:#0003!important;border:1px solid rgba(var(--primary-rgb),.2)!important;border-radius:8px;padding:8px 28px 8px 12px;font-size:16px;font-weight:600;color:#e8e4f5!important;text-align:center;font-family:Inter,sans-serif;outline:none;transition:border-color .15s,box-shadow .15s;-moz-appearance:textfield}input[type=number].pct-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.18)}input[type=number].pct-input::-webkit-inner-spin-button,input[type=number].pct-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pct-suffix{position:absolute;right:10px;font-size:13px;font-weight:700;color:var(--primary);pointer-events:none;-webkit-user-select:none;user-select:none}.pct-calc-hint{font-size:12px;color:#e8e4f566;min-height:16px;transition:opacity .2s;line-height:1.4}input[type=text].lib-search-input{background:#0003!important;border:1px solid rgba(var(--primary-rgb),.13)!important;border-radius:9999px;padding:8px 16px 8px 36px;font-size:13px;color:#e8e4f5!important;font-family:Inter,sans-serif;outline:none;width:220px;transition:border-color .15s,box-shadow .15s;box-shadow:none}input[type=text].lib-search-input::placeholder{color:#e8e4f54d}input[type=text].lib-search-input:focus{border-color:rgba(var(--primary-rgb),.4)!important;box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}textarea.session-notes{width:100%;min-height:160px;background:#0003;border:1px solid rgba(var(--primary-rgb),.12);border-radius:12px;padding:14px 16px;color:#e8e4f5;font-size:15px;font-family:Inter,sans-serif;line-height:1.6;resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s}textarea.session-notes:focus{border-color:rgba(var(--primary-rgb),.45);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.12)}textarea.session-notes::placeholder{color:#e8e4f540}#finish-reading-time-input::-webkit-inner-spin-button,#finish-reading-time-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.finish-reading-time-input{width:52px;background:#0003;border:1px solid rgba(var(--primary-rgb),.2);border-radius:6px;padding:3px 8px;font-size:14px;font-weight:600;color:#e8e4f5;text-align:center;font-family:Inter,sans-serif;outline:none}.finish-reading-time-input:focus{border-color:rgba(var(--primary-rgb),.45);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.14)}.line-chart-dot{fill:var(--primary);stroke:var(--bg);stroke-width:2;cursor:pointer}.line-chart-dot.today{fill:var(--bg);stroke:var(--primary);stroke-width:2.5}.line-chart-x-label{font-family:Inter,sans-serif;font-size:10px;font-weight:600;fill:#e8e4f566;text-anchor:middle}#chart-y-axis span{font-size:10px;color:#e8e4f54d;font-family:Inter,sans-serif;font-weight:500;text-align:right;display:block}.settings-nav-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;text-align:left;font-family:Inter,sans-serif}.settings-nav-btn:hover{background:#ffffff0d;color:var(--text-primary)}.settings-nav-btn.active{background:var(--primary-10);color:var(--primary)}.settings-nav-btn .material-symbols-outlined{font-size:18px;flex-shrink:0}.theme-card{border-radius:10px;border:2px solid rgba(var(--primary-rgb),.1);overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s;position:relative}.theme-card:hover{border-color:rgba(var(--primary-rgb),.35);transform:translateY(-2px)}.theme-card--active{border-color:var(--primary)!important}.theme-card-preview{overflow:hidden}.theme-card-info{padding:8px 10px 6px;background:#ffffff08}.theme-card-name{font-size:12px;font-weight:700;color:var(--text-primary)}.theme-card-label{font-size:10px;color:var(--text-muted);margin-top:1px}.theme-card-check{position:absolute;top:6px;right:6px;color:var(--primary);opacity:0;transition:opacity .15s}.theme-card--active .theme-card-check{opacity:1}@keyframes card-stagger-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes option-select-pulse{0%{box-shadow:0 0 rgba(var(--primary-rgb),0),0 4px 16px #0000004d}35%{box-shadow:0 0 0 6px rgba(var(--primary-rgb),.3),0 8px 32px #0006}to{box-shadow:0 0 rgba(var(--primary-rgb),0),0 4px 16px #0000004d}}.book-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:20px;background-color:rgba(var(--bg-rgb),.72);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:overlay-fade .22s ease both}.book-picker-modal{width:100%;max-width:780px;min-height:520px;max-height:calc(100dvh - 40px);overflow-y:auto;overscroll-behavior:contain;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(var(--primary-rgb),.18);border-radius:20px;box-shadow:0 24px 64px #051424cc,0 0 0 1px rgba(var(--primary-rgb),.06) inset;display:flex;flex-direction:column;position:relative;animation:picker-enter .28s cubic-bezier(.34,1.56,.64,1) both;scrollbar-width:thin;scrollbar-color:rgba(var(--primary-rgb),.25) transparent}.book-picker-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(var(--primary-rgb),.35) 40%,rgba(var(--primary-rgb),.35) 60%,transparent 100%);border-radius:20px 20px 0 0;pointer-events:none}.book-picker-header{display:flex;align-items:center;justify-content:center;padding:24px 24px 20px;flex-shrink:0;border-bottom:1px solid rgba(var(--primary-rgb),.08);position:relative}.book-picker-header h2{font-family:Inter,sans-serif;font-size:24px;font-weight:600;line-height:1.25;letter-spacing:-.01em;color:var(--text-primary);margin:0}.picker-subtitle{font-size:14px;color:var(--text-muted);padding:12px 24px 0;margin:0;flex-shrink:0;text-align:center}.picker-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;color:#e8e4f58c;border-radius:8px;background:#ffffff0a;border:1px solid rgba(var(--primary-rgb),.1);font-size:18px;line-height:1;font-family:Inter,sans-serif;transition:color .15s ease,background .15s ease,border-color .15s ease;position:absolute;right:24px;top:50%;transform:translateY(-50%)}.picker-close:hover{color:var(--text-primary);background:#ffffff14;border-color:rgba(var(--primary-rgb),.22)}.book-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:16px 24px 8px;flex:1}.book-option{position:relative;display:flex;flex-direction:column;gap:10px;padding:14px;background:#ffffff0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(var(--primary-rgb),.12);border-radius:16px;box-shadow:0 4px 16px #0000004d;cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease;animation:card-stagger-in .3s ease both}.book-option:nth-child(1){animation-delay:80ms}.book-option:nth-child(2){animation-delay:.13s}.book-option:nth-child(3){animation-delay:.18s}.book-option:hover{background:#ffffff12;border-color:rgba(var(--primary-rgb),.4);box-shadow:0 8px 32px #0006,0 0 20px rgba(var(--primary-rgb),.12);transform:translateY(-2px)}.book-option.selected{background:rgba(var(--primary-rgb),.08);border:2px solid var(--primary);box-shadow:0 8px 32px #0006,0 0 24px rgba(var(--primary-rgb),.2);transform:translateY(-2px);animation:option-select-pulse .45s ease both}.book-option-badge{position:absolute;top:10px;left:10px;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;flex-shrink:0;background:#051424b3;border:1px solid rgba(var(--primary-rgb),.3);border-radius:6px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:Inter,sans-serif;font-size:11px;font-weight:600;color:rgba(var(--primary-rgb),.75)}.book-option-check{position:absolute;top:10px;right:10px;z-index:2;display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;background:var(--primary);border-radius:50%;opacity:0;transform:scale(.5);transition:opacity .2s ease,transform .2s cubic-bezier(.34,1.56,.64,1)}.book-option.selected .book-option-check{opacity:1;transform:scale(1);top:9px;right:9px}.book-option-cover{width:100%;aspect-ratio:2/3;border-radius:8px;overflow:hidden;background:var(--bg-03);flex-shrink:0;position:relative}.book-option-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.book-option:hover .book-option-cover img{transform:scale(1.04)}.book-option-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.book-option-title{font-family:Inter,sans-serif;font-size:14px;font-weight:600;line-height:1.3;color:var(--text-primary);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-option-author{font-family:Inter,sans-serif;font-size:12px;font-weight:400;color:var(--text-muted);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-option-progress-wrap{width:100%;height:4px;background:rgba(var(--primary-rgb),.15);border-radius:9999px;overflow:hidden;margin-top:4px}.book-option-progress-bar{height:4px;background:linear-gradient(90deg,var(--primary) 0%,#60a5fa 100%);border-radius:9999px;min-width:0;position:relative;overflow:hidden}.book-option-percent{font-family:Inter,sans-serif;font-size:11px;font-weight:500;color:var(--text-muted);margin:0;line-height:1.3}.book-option-meta{font-family:Inter,sans-serif;font-size:11px;font-weight:400;color:var(--text-faint);line-height:1.3;margin:0}.book-picker-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 24px;flex-shrink:0;border-top:1px solid rgba(var(--primary-rgb),.08);background:rgba(var(--bg-rgb),.3);border-radius:0 0 20px 20px}.book-picker-footer .btn-primary:disabled{opacity:.4;cursor:not-allowed;pointer-events:none;box-shadow:none;transform:none}.btn-add-manually{-webkit-appearance:none;-moz-appearance:none;appearance:none;font-family:Inter,sans-serif;cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:8px 16px;min-height:36px;color:#e8e4f58c;border:1px solid rgba(var(--primary-rgb),.18);border-radius:9999px;background:#ffffff08;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);font-size:13px;font-weight:500;line-height:1;white-space:nowrap;-webkit-user-select:none;user-select:none;transition:color .15s ease,background .15s ease,border-color .15s ease,transform .15s ease,box-shadow .15s ease;margin-top:16px}.btn-add-manually:hover{color:var(--primary);background:rgba(var(--primary-rgb),.06);border-color:rgba(var(--primary-rgb),.32);transform:translateY(-1px);box-shadow:0 2px 12px rgba(var(--primary-rgb),.12)}.btn-add-manually:focus-visible{outline:2px solid var(--primary);outline-offset:3px}@keyframes quick-btn-in{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes details-expand{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.manual-log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;background-color:rgba(var(--bg-rgb),.75);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:overlay-fade .22s ease both}.manual-log-modal{width:100%;max-width:480px;max-height:calc(100dvh - 40px);overflow-y:auto;overscroll-behavior:contain;background:#ffffff0d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(var(--primary-rgb),.18);border-radius:20px;box-shadow:0 24px 64px rgba(var(--bg-rgb),.8),0 0 0 1px rgba(var(--primary-rgb),.06) inset;display:flex;flex-direction:column;position:relative;animation:picker-enter .28s cubic-bezier(.34,1.56,.64,1) both;scrollbar-width:thin;scrollbar-color:rgba(var(--primary-rgb),.25) transparent}.manual-log-modal::-webkit-scrollbar{width:4px}.manual-log-modal::-webkit-scrollbar-track{background:transparent}.manual-log-modal::-webkit-scrollbar-thumb{background:rgba(var(--primary-rgb),.25);border-radius:9999px}.manual-log-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(var(--primary-rgb),.35) 35%,rgba(var(--primary-rgb),.35) 65%,transparent 100%);border-radius:20px 20px 0 0;pointer-events:none;z-index:1}.manual-log-header{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 24px 20px;flex-shrink:0;border-bottom:1px solid rgba(var(--primary-rgb),.08)}.manual-log-header__title-group{display:flex;align-items:center;gap:8px;min-width:0}.manual-log-header__icon{font-size:22px;color:var(--primary);opacity:.8;flex-shrink:0;line-height:1}.manual-log-title{font-family:Inter,sans-serif;font-size:20px;font-weight:600;line-height:1.25;letter-spacing:-.01em;color:#e8e4f5;margin:0;white-space:nowrap}.manual-log-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(var(--primary-rgb),.1);background:#ffffff0a;cursor:pointer;padding:0;margin:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;color:#e8e4f58c;border-radius:8px;transition:color .15s,background .15s,border-color .15s}.manual-log-close:hover{color:#e8e4f5;background:#ffffff14;border-color:rgba(var(--primary-rgb),.22)}.manual-log-body{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:24px;display:flex;flex-direction:column;gap:24px}.book-profile-modal-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:0 24px 20px}.signout-modal-actions{justify-content:center;margin-top:-6px}.manual-log-section{display:flex;flex-direction:column;gap:12px}.manual-log-section__label{font-family:Inter,sans-serif;font-size:11px;font-weight:600;color:#e8e4f573;line-height:1;text-transform:uppercase;letter-spacing:.1em;margin:0}.manual-log-section:first-child .manual-log-section__label{text-align:center}.time-quick-pick{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.time-quick-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(var(--primary-rgb),.14);font-family:Inter,sans-serif;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:64px;padding:8px;background:#ffffff0a;border-radius:9999px;-webkit-user-select:none;user-select:none;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s,color .15s;animation:quick-btn-in .28s ease both}.time-quick-btn:nth-child(1){animation-delay:.1s}.time-quick-btn:nth-child(2){animation-delay:.14s}.time-quick-btn:nth-child(3){animation-delay:.18s}.time-quick-btn:nth-child(4){animation-delay:.22s}.time-quick-btn__number{font-size:22px;font-weight:700;line-height:1;color:#e8e4f5;font-variant-numeric:tabular-nums;transition:color .15s}.time-quick-btn__unit{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#e8e4f54d;transition:color .15s}.time-quick-btn:hover:not(.active){background:rgba(var(--primary-rgb),.07);border-color:rgba(var(--primary-rgb),.3);transform:translateY(-1px)}.time-quick-btn:hover:not(.active) .time-quick-btn__number{color:var(--primary)}.time-quick-btn.active{background:var(--primary);border-color:var(--primary);box-shadow:0 4px 20px rgba(var(--primary-rgb),.4);transform:translateY(-1px)}.time-quick-btn.active .time-quick-btn__number{color:var(--bg)}.time-quick-btn.active .time-quick-btn__unit{color:rgba(var(--bg-rgb),.65)}.manual-duration-custom{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:4px}.manual-duration-custom__divider{display:flex;align-items:center;gap:10px;width:100%}.manual-duration-custom__divider-line{flex:1;height:1px;background:rgba(var(--primary-rgb),.1)}.manual-duration-custom__label{font-family:Inter,sans-serif;font-size:10px;font-weight:600;color:#e8e4f547;letter-spacing:.09em;text-transform:uppercase;white-space:nowrap;line-height:1;-webkit-user-select:none;user-select:none}.manual-duration-custom__pill{display:inline-flex;align-items:center;gap:0;background:rgba(var(--primary-rgb),.06);border:1px solid rgba(var(--primary-rgb),.14);border-radius:12px;padding:14px 20px 12px;cursor:text;transition:background .15s,border-color .15s,box-shadow .15s}.manual-duration-custom__pill:focus-within{background:rgba(var(--primary-rgb),.1);border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.14)}input[type=number].manual-duration-custom__input{width:3ch;background:transparent!important;border:none!important;box-shadow:none!important;padding:0;font-family:Inter,sans-serif;font-size:22px;font-weight:800;color:#e8e4f5!important;outline:none;line-height:1;font-variant-numeric:tabular-nums;text-align:center;-moz-appearance:textfield}input[type=number].manual-duration-custom__input::-webkit-inner-spin-button,input[type=number].manual-duration-custom__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.manual-duration-custom__input::placeholder{color:#e8e4f52e}.manual-duration-custom__suffix{font-family:Inter,sans-serif;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#e8e4f559;padding-left:6px;align-self:flex-end;padding-bottom:2px;pointer-events:none;-webkit-user-select:none;user-select:none;line-height:1}.manual-duration-display{font-family:Inter,sans-serif;font-size:13px;font-weight:500;color:var(--primary);line-height:1;min-height:16px}.manual-book-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ffffff0a;border:1px solid rgba(var(--primary-rgb),.12);border-radius:10px;position:relative;min-height:56px}.manual-book-cover{width:32px;height:48px;border-radius:4px;overflow:hidden;flex-shrink:0;background:#2c3a4c;position:relative}.manual-book-cover__img{width:100%;height:100%;object-fit:cover;display:block}.manual-book-cover__placeholder{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,rgba(var(--primary-rgb),.15),#60a5fa1a)}.manual-book-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.manual-book-info__title{font-family:Inter,sans-serif;font-size:14px;font-weight:600;color:#e8e4f5;line-height:1.2;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.manual-book-info__author{font-family:Inter,sans-serif;font-size:12px;font-weight:400;color:#e8e4f58c;line-height:1;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.manual-book-change{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:none;font-family:Inter,sans-serif;font-size:12px;font-weight:500;color:var(--primary);cursor:pointer;padding:4px 0;flex-shrink:0;opacity:.75;transition:opacity .15s;text-decoration:underline;text-underline-offset:2px}.manual-book-change:hover{opacity:1}.manual-when-group{display:inline-flex;background:#00000040;border:1px solid rgba(var(--primary-rgb),.12);border-radius:9999px;padding:3px;gap:2px;flex-wrap:wrap}.manual-when-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;font-family:Inter,sans-serif;cursor:pointer;padding:7px 14px;border-radius:9999px;font-size:13px;font-weight:500;color:#e8e4f58c;background:transparent;transition:color .15s,background .15s,box-shadow .15s;white-space:nowrap}.manual-when-btn:hover:not(.active){color:#e8e4f5}.manual-when-btn.active{color:var(--bg);background:var(--primary);font-weight:600;box-shadow:0 2px 12px rgba(var(--primary-rgb),.35)}.manual-details-wrap{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(var(--primary-rgb),.08);padding-top:16px}.manual-details-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:none;font-family:Inter,sans-serif;cursor:pointer;padding:0;display:inline-flex;align-items:center;gap:6px;min-height:32px;font-size:13px;font-weight:500;color:var(--primary);opacity:.75;transition:opacity .15s}.manual-details-toggle:hover{opacity:1}.manual-details-toggle__icon{font-size:16px;font-weight:600;color:inherit;line-height:1;width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s}.manual-details-toggle[aria-expanded=true] .manual-details-toggle__icon{transform:rotate(45deg)}.manual-details-body{display:flex;flex-direction:column;gap:18px;padding-top:18px;animation:details-expand .22s ease both}.manual-form-label{font-family:Inter,sans-serif;font-size:12px;font-weight:500;color:#e8e4f58c;line-height:1;display:block;margin-bottom:6px}.manual-form-label .optional{color:#e8e4f54d;font-weight:400}.manual-pages-input-wrap{position:relative;display:inline-flex;align-items:center}input[type=number].manual-pages-input{width:140px;padding:10px 52px 10px 14px;text-align:right;font-variant-numeric:tabular-nums;background:#00000038!important;border:1px solid rgba(var(--primary-rgb),.14)!important;border-radius:8px;font-family:Inter,sans-serif;font-size:15px;font-weight:700;color:#e8e4f5;outline:none;transition:border-color .15s,box-shadow .15s;-moz-appearance:textfield}input[type=number].manual-pages-input::-webkit-inner-spin-button,input[type=number].manual-pages-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number].manual-pages-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.18)}.manual-pages-suffix{position:absolute;right:12px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;color:#e8e4f559;pointer-events:none;-webkit-user-select:none;user-select:none;line-height:1}.pct-progress-row{display:flex;align-items:center;gap:10px;padding:2px 0}.pct-progress-row__label{font-size:12px;font-weight:500;color:#e8e4f566;width:48px;flex-shrink:0;letter-spacing:.01em}.pct-was-badge{display:inline-flex;align-items:center;justify-content:center;width:80px;font-size:15px;font-weight:700;color:#e8e4f573;background:rgba(var(--primary-rgb),.06);border:1px solid rgba(var(--primary-rgb),.12);border-radius:8px;padding:8px 0;font-family:Inter,sans-serif;font-variant-numeric:tabular-nums;flex-shrink:0;letter-spacing:-.01em}.pct-was-page-hint{font-size:11px;color:#e8e4f540;white-space:nowrap;flex-shrink:0}.pct-delta-hint{font-size:13px;font-weight:600;color:#6ee7b7;min-height:20px;transition:opacity .2s;line-height:1.4;padding:8px 12px;background:#6ee7b712;border-radius:8px;border:1px solid rgba(110,231,183,.15)}.pct-delta-hint.negative{color:#ffb4ab;background:#ffb4ab12;border-color:#ffb4ab26}.pct-delta-hint.neutral{color:#e8e4f566;background:rgba(var(--primary-rgb),.04);border-color:rgba(var(--primary-rgb),.1)}textarea.manual-note-textarea,input.manual-note-textarea{width:100%;background:#0003;border:1px solid rgba(var(--primary-rgb),.12);border-radius:10px;padding:12px 14px;color:#e8e4f5;font-size:14px;font-family:Inter,sans-serif;line-height:1.5;outline:none;transition:border-color .15s,box-shadow .15s}textarea.manual-note-textarea{resize:vertical}textarea.manual-note-textarea:focus,input.manual-note-textarea:focus{border-color:rgba(var(--primary-rgb),.45);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.12)}.manual-note-char-count{font-family:Inter,sans-serif;font-size:11px;color:#e8e4f54d;text-align:right;margin-top:4px}.manual-log-footer{padding:16px 24px;flex-shrink:0;border-top:1px solid rgba(var(--primary-rgb),.08)}.manual-log-save{width:100%;padding:14px;border-radius:12px;border:none;font-family:Inter,sans-serif;font-size:15px;font-weight:700;letter-spacing:-.01em;cursor:pointer;background:var(--primary);color:var(--bg);transition:opacity .15s,transform .15s,box-shadow .15s}.manual-log-save:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(var(--primary-rgb),.4)}.manual-log-save:disabled{opacity:.35;cursor:not-allowed}.manual-log-save__label{line-height:1}#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;width:320px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:13px 16px;background:#2c3a4c;border-radius:12px;border:1px solid rgba(202,190,255,.12);font-family:Inter,sans-serif;font-size:14px;color:#e8e4f5;box-shadow:0 4px 24px #0006;animation:toastIn .2s ease-out both;position:relative;overflow:hidden;pointer-events:all}@keyframes toastIn{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.toast-progress{position:absolute;bottom:0;left:0;height:3px;background:#6ee7b780;animation:toastProgress 3s linear forwards}@keyframes toastProgress{0%{width:100%}to{width:0%}}.day-tooltip{position:fixed;z-index:200;display:none;align-items:center;gap:6px;padding:8px 14px;background:rgba(var(--bg-rgb),.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(var(--primary-rgb),.24);border-radius:10px;box-shadow:0 8px 32px #00000073;pointer-events:none;white-space:nowrap;font-family:Inter,sans-serif}.day-tooltip-date{font-size:12px;font-weight:600;color:var(--text-muted)}.day-tooltip-sep{font-size:11px;color:var(--text-faint)}.day-tooltip-value{font-size:13px;font-weight:700;color:var(--primary)}.book-profile-table-action-btn{display:inline-flex;align-items:center;justify-content:center;min-width:30px;min-height:24px;padding:3px 10px;border-radius:9999px;border:1px solid rgba(var(--primary-rgb),.25);background:rgba(var(--primary-rgb),.08);color:#dfe8f8;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.book-profile-table-action-btn:hover{background:rgba(var(--primary-rgb),.16);border-color:rgba(var(--primary-rgb),.42)}.book-profile-table-action-btn .material-symbols-outlined{font-size:14px}.book-profile-table-action-btn--danger:hover{color:#ffb4ab;border-color:#ffb4ab66;background:#ffb4ab14}.book-profile-line-chart-wrap{width:100%;padding:8px 0 2px}.book-profile-line-chart-hint{margin-top:8px;font-size:12px;color:#e8e4f58c}.book-profile-rating-wrap{display:flex;align-items:stretch;gap:10px;height:100%}.book-profile-edit-trigger-col{display:flex;flex-direction:column;gap:8px;padding-top:4px;width:fit-content;min-width:fit-content;margin-right:5px}.book-profile-edit-trigger-mobile{display:none}.book-profile-rating-card.book-profile-rating-shell{flex:1;min-height:100%;width:330px;display:flex;flex-direction:column;justify-content:space-between;align-items:center;text-align:center;margin:0 auto}.book-profile-rating-head-wrap{display:flex;justify-content:center;margin-bottom:10px;width:100%}.book-profile-rating-head-inner{width:100%;min-height:180px;text-align:center;padding:10px 14px 20px;border-radius:14px;display:flex;flex-direction:column;justify-content:center;align-items:center}.book-profile-rating-pill{min-width:158px;height:42px;border-radius:9999px;border:1px solid rgba(232,228,245,.38);background:#0f1c3238;display:flex;align-items:center;justify-content:center;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:#e8e4f5c7;margin-bottom:16px;font-weight:700;padding:0 18px}.book-profile-score-ring{width:156px;height:156px;border-radius:50%;display:flex;align-items:center;justify-content:center}.book-profile-score-value{font-size:78px;font-weight:900;line-height:1}.book-profile-rating-stars-row{justify-content:center;margin-top:2px}.book-profile-rating-star-icon-lg{font-size:34px}@media (max-width: 1279px){#sidebar{width:64px}#sidebar .nav-label,#sidebar .sidebar-logo-text,#sidebar .user-name,#sidebar .user-settings,#sidebar .soon-chip{display:none}#sidebar .nav-item,#sidebar .sidebar-user{justify-content:center}#sidebar-toggle{display:none}#main-content,#main-content.sidebar-collapsed{margin-left:64px}}@media (max-width: 1279px){#sidebar,#sidebar-toggle,#top-bar{display:none}#main-content,#main-content.sidebar-collapsed{margin-left:0;padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}#mobile-nav{display:flex!important}.home-hero{padding-right:52px}.home-hero-title{line-height:1.15;overflow-wrap:anywhere;word-break:break-word}.book-profile-edit-trigger-col{display:none}.book-profile-edit-trigger-mobile{display:block;width:100%;margin-bottom:8px}.book-profile-rating-wrap{flex-direction:column;align-items:stretch;gap:8px}.book-profile-rating-card.book-profile-rating-shell{width:100%}.book-profile-edit-trigger-mobile .btn-secondary{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px}}#mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom,0px));background:rgba(var(--bg-rgb),.92);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(var(--primary-rgb),.12);align-items:center;justify-content:space-between;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;color:#e8e4f566;cursor:pointer;flex:1 1 0;min-width:0;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;transition:color .15s}.mobile-nav-item.active{color:var(--primary)}.mobile-nav-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:#e8e4f5;cursor:pointer;flex:1 1 0;min-width:0;margin-top:-22px;height:70px;border-radius:18px;background:linear-gradient(180deg,rgba(var(--primary-rgb),.28),rgba(var(--primary-rgb),.14));border:1px solid rgba(var(--primary-rgb),.38);box-shadow:0 10px 22px #00000052;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.mobile-nav-center:hover{transform:translateY(-1px);box-shadow:0 12px 26px #00000059}.mobile-nav-center.active{border-color:rgba(var(--primary-rgb),.62)}.mobile-nav-center.has-session{box-shadow:0 0 0 2px #fbbf2447,0 12px 26px #00000059}.mobile-nav-center .material-symbols-outlined{font-size:28px}.mobile-profile-corner-btn{display:none}@media (max-width: 1279px){.mobile-profile-corner-btn{position:absolute!important;top:calc(env(safe-area-inset-top,0px) + 10px)!important;right:calc(env(safe-area-inset-right,0px) + 12px)!important;bottom:auto!important;left:auto!important;z-index:10000;width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;padding:0;background:#8b5cf64d;color:#d9ccff;border:1px solid rgba(202,190,255,.24);box-shadow:0 10px 24px #0000003d;font-size:10px;font-weight:800;line-height:1;cursor:pointer;transform:translateZ(0)}}.profile-hero-head{margin-bottom:18px}.profile-hero-title{font-size:28px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:4px}.profile-hero-subtitle{font-size:14px;color:var(--text-muted)}.profile-grid-two{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.profile-card-pad-lg{padding:22px}.profile-card-pad-md{padding:20px}.profile-section-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.profile-metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.profile-metric-card{border:1px solid var(--metric-border, rgba(202,190,255,.22));background:var(--metric-bg, rgba(202,190,255,.08));border-radius:12px;padding:12px}.profile-metric-head{display:flex;align-items:center;gap:6px;margin-bottom:6px}.profile-metric-icon{font-size:16px;color:var(--metric-color, #cabeff)}.profile-metric-label{font-size:11px;font-weight:700;color:var(--metric-color, #cabeff);text-transform:uppercase;letter-spacing:.06em}.profile-metric-value{font-size:24px;font-weight:800;color:var(--metric-color, #cabeff);line-height:1}.profile-metric-hint{font-size:11px;color:#e8e4f5a6;margin-top:4px}.profile-progress-layout{display:grid;grid-template-columns:1fr 320px;gap:16px;margin-bottom:20px}.profile-tracks-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.profile-track-card{border:1px solid rgba(202,190,255,.12);border-radius:12px;padding:12px;background:#ffffff05}.profile-track-head{display:flex;justify-content:space-between;margin-bottom:10px;align-items:center}.profile-track-label{font-size:13px;font-weight:700;color:#e8e4f5;display:inline-flex;align-items:center;gap:10px}.profile-track-icon{font-size:28px;color:#cabeff;background:#cabeff1f;border:1px solid rgba(202,190,255,.25);border-radius:10px;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.profile-track-ratio{font-size:12px;color:#e8e4f5a6}.profile-track-bar{height:8px;border-radius:999px;background:#cabeff29;overflow:hidden}.profile-track-fill{height:100%;background:linear-gradient(90deg,#cabeff,#60a5fa)}.profile-track-foot{margin-top:8px;font-size:11px;color:#e8e4f594}.profile-honor-card{padding:16px}.profile-honor-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}.profile-honor-icon{color:#fbbf24;font-variation-settings:"FILL" 1}.profile-honor-title{font-size:14px;font-weight:800;color:#e8e4f5}.profile-honor-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:356px;overflow-y:auto;padding-right:2px}.profile-honor-empty{grid-column:1 / -1;font-size:12px;color:#e8e4f57a;padding:8px 0}.profile-honor-item{border-radius:10px;padding:8px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px}.profile-honor-item-title{font-size:10px;font-weight:700;color:#e8e4f5;line-height:1.2}.profile-honor-item-tier{font-size:9px;font-weight:700;color:var(--profile-tier-color, #cabeff)}.profile-ach-grid{display:grid;grid-template-columns:repeat(10,minmax(0,1fr));gap:10px;align-items:center}.profile-ach-btn{height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:default;position:relative;overflow:hidden}.profile-ach-fill{position:absolute;left:0;right:0;bottom:0;pointer-events:none}.profile-ach-icon{position:relative;z-index:1;font-size:24px}.profile-tooltip{display:flex;transform:none;z-index:9999;max-width:min(280px,calc(100vw - 16px));white-space:normal}.profile-streak-icon{font-size:16px;font-variation-settings:"FILL" 1}.profile-identity-row{display:flex;align-items:center;gap:16px}@media (min-width: 1280px){.profile-identity-panel{background:transparent;border:none;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}}.profile-avatar-lg{width:72px;height:72px;border-radius:50%;background:#8b5cf640;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#a78bfa;flex-shrink:0}.profile-identity-name-row{display:flex;align-items:center;gap:8px;min-height:30px}.profile-identity-name{font-size:21px;font-weight:800;color:var(--text-primary)}.profile-identity-sub{font-size:12px;color:var(--text-muted);margin-top:3px}.profile-name-edit-btn{min-height:26px;padding:3px 9px;font-size:11px}.profile-name-edit-btn .material-symbols-outlined{font-size:14px}.profile-name-edit-wrap{display:grid;gap:8px;width:min(360px,100%)}.profile-name-edit-input{min-height:34px;padding:6px 10px;border-radius:8px;border:1px solid rgba(var(--primary-rgb),.2);background:#ffffff0d;color:var(--text-primary);font-size:14px}.profile-name-edit-input:focus{outline:none;border-color:rgba(var(--primary-rgb),.45);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.12)}.profile-name-edit-actions{display:flex;align-items:center;gap:8px}.profile-name-save-btn{min-height:28px;padding:4px 10px;font-size:11px}.profile-name-edit-error{font-size:12px;color:#ffb4ab;margin-top:-2px}.profile-title-pill{font-size:10px;font-weight:700;padding:2px 10px;border-radius:99px;display:inline-block;margin-top:8px;letter-spacing:.04em}.profile-identity-actions{margin-top:14px}.profile-title-btn{padding:7px 12px;font-size:12px}.profile-title-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.profile-title-choice-btn{padding:6px 10px;font-size:11px}.profile-metric-card--green{--metric-color: #6ee7b7;--metric-border: rgba(110,231,183,.22);--metric-bg: rgba(110,231,183,.08)}.profile-metric-card--violet{--metric-color: #cabeff;--metric-border: rgba(202,190,255,.22);--metric-bg: rgba(202,190,255,.08)}.profile-metric-card--gold{--metric-color: #fbbf24;--metric-border: rgba(251,191,36,.22);--metric-bg: rgba(251,191,36,.08)}.profile-snapshot-title{margin-bottom:10px}.profile-metric-grid--compact .profile-metric-card{min-height:0;padding:10px 10px 8px}.profile-metric-grid--compact .profile-metric-head{margin-bottom:6px}.profile-metric-grid--compact .profile-metric-label{font-size:10px;letter-spacing:.04em}.profile-metric-grid--compact .profile-metric-value{font-size:22px;line-height:1.05}.profile-metric-grid--compact .profile-metric-hint{display:none}.profile-section-title--spacious{margin-bottom:14px}.profile-section-title--center{text-align:center}.profile-honor-item-icon{color:var(--profile-icon-color, #cabeff);font-size:22px}.profile-modal-open{display:flex}.profile-title-modal{max-width:760px;width:100%}.profile-title-modal-body{max-height:65vh;overflow-y:auto}.profile-title-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.profile-title-card{border:1px solid var(--profile-title-border, rgba(202,190,255,.16));background:#ffffff05;border-radius:10px;padding:10px}.profile-title-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.profile-title-card-name{font-size:13px;font-weight:800;color:var(--profile-title-color, #cabeff)}.profile-title-card-state{font-size:10px;font-weight:700;color:var(--profile-title-state-color, rgba(232,228,245,.55))}.profile-title-card-reqs{font-size:11px;color:#e8e4f5b3}.add-book-overlay-open{display:flex}.add-book-modal-shell{max-width:680px;width:100%;max-height:85vh;display:flex;flex-direction:column}.add-book-title-group-centered{width:100%;justify-content:center}.add-book-mode-tabs{padding:12px 24px 0;display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.add-book-tab-btn{padding:8px 14px;font-size:12px}.add-book-status-wrap{padding:12px 24px}.add-book-status-label{font-size:14px;font-weight:700;color:#e8e4f5cc;margin-bottom:10px;text-align:center}.add-book-status-row{display:flex;gap:8px}.add-book-status-btn{flex:1;padding:8px;font-size:12px}.add-book-status-btn-missing{border-color:#ffb4ab8c}.add-book-body{flex:1;overflow-y:auto;padding:0 24px 24px}.add-book-search-row{display:flex;gap:8px;margin-top:10px;margin-bottom:10px}.add-book-search-input{flex:1;min-height:44px;resize:none}.add-book-search-action-sticky{display:flex;justify-content:flex-end;margin-bottom:10px}.add-book-search-action-btn[disabled]{opacity:.5;cursor:not-allowed}.add-book-result-item{padding:10px;border-radius:10px;margin-bottom:6px;cursor:pointer;border:1px solid rgba(202,190,255,.08);background:#ffffff08}.add-book-result-item.selected{border-color:#cabeff59;background:#cabeff1f}.add-book-result-title{font-size:13px;color:#e8e4f5}.add-book-result-sub{font-size:12px;color:#e8e4f58c}.add-book-pages-input{width:100%;padding:10px;border-radius:8px;border:1px solid rgba(202,190,255,.18);background:#ffffff0f;color:#e8e4f5;margin-bottom:10px}.add-book-csv-wrap{min-height:var(--add-book-csv-min-height, 0);display:flex;flex-direction:column;justify-content:space-between}.add-book-csv-ready{margin-top:10px;margin-bottom:8px;font-size:12px}.add-book-csv-list{max-height:220px;overflow-y:auto;border:1px solid rgba(202,190,255,.14);border-radius:10px;padding:8px}.add-book-csv-row{font-size:12px;padding:6px 4px;border-bottom:1px solid rgba(202,190,255,.08)}.add-book-csv-import-btn{margin-top:10px}.add-book-csv-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:14px}.add-book-csv-file-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.add-book-file-hidden{display:none}.add-book-file-btn{padding:8px 12px;font-size:12px}.add-book-file-name{font-size:12px;color:#e8e4f599}.add-book-csv-help{text-align:right;font-size:12px;color:#e8e4f58c}.add-book-csv-help-link{color:#cabeff}.add-book-manual-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.add-book-span-full{grid-column:1 / -1}.add-book-input-compact{min-height:44px;resize:none}.add-book-cover-row{grid-column:1 / -1;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.home-streak-icon{font-size:16px;font-variation-settings:"FILL" 1}.home-hero{margin-bottom:24px}.home-hero-title{font-size:28px;font-weight:800;color:#e8e4f5;letter-spacing:-.02em;margin-bottom:4px}.home-hero-subtitle{font-size:14px;color:#e8e4f580}.home-main-grid{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}.home-main-col{display:flex;flex-direction:column;gap:20px}.home-side-col{display:flex;flex-direction:column;gap:16px}.home-card-pad-2024{padding:20px 24px}.home-card-pad-2224{padding:22px 24px}.home-card-pad-22{padding:22px}.home-kicker{font-size:10px;font-weight:700;color:#e8e4f566;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}.home-empty{text-align:center;padding:24px 0;color:#e8e4f566;font-size:14px}.home-cr-cover{background:linear-gradient(135deg,#1d2b3c,#283647);width:72px;height:108px;border-radius:7px;flex-shrink:0;overflow:hidden}.home-cover-img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.home-cr-title{font-size:15px;font-weight:700;color:#e8e4f5;margin-bottom:2px;line-height:1.25}.home-cr-author{font-size:12px;color:#e8e4f573;margin-bottom:10px}.home-cr-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.home-cr-pages{font-size:11px;color:#e8e4f573}.home-cr-pct{font-size:11px;font-weight:700;color:#cabeff}.home-cr-side{display:none}.home-prog-5{height:5px}.home-center-row{margin-top:16px;display:flex;justify-content:center}.home-current-list{display:flex;flex-direction:column}.home-start-btn{padding:10px 24px;font-size:13px}.home-start-icon{font-size:18px;font-variation-settings:"FILL" 1}.home-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.home-stat-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.home-stat-val-sm{font-size:20px}.home-icon-18{font-size:18px}.home-icon-blue{color:#60a5fa}.home-icon-violet{color:#cabeff}.home-icon-purple{color:#a78bfa}.home-icon-green{color:#6ee7b7}.home-recent-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.home-recent-title{font-size:15px;font-weight:700;color:#e8e4f5;letter-spacing:-.01em}.home-more-btn{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;color:#e8e4f58c;cursor:pointer;font-size:12px;font-weight:600}.home-icon-16{font-size:16px}.home-empty-tight{text-align:center;padding:16px 0;color:#e8e4f566;font-size:14px}.home-session-cover{width:40px;height:56px;border-radius:6px;flex-shrink:0;overflow:hidden;background:linear-gradient(135deg,#1d2b3c,#283647)}.home-session-info{flex:1;min-width:0}.home-session-title{font-size:13px;font-weight:600;color:#e8e4f5}.home-session-sub{font-size:11px;color:#e8e4f573;margin-top:2px}.home-session-pages{font-size:12px;font-weight:600;color:#cabeff}.home-side-card-center{text-align:center}.home-goal-kicker{margin-bottom:14px}.home-goal-ring-wrap{position:relative;width:120px;height:120px;margin:0 auto 14px}.home-goal-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.home-goal-ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.home-goal-value{font-size:22px;font-weight:800}.home-goal-target{font-size:10px;color:#e8e4f566;text-transform:uppercase;letter-spacing:.06em}.home-goal-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:99px;margin-bottom:6px}.home-goal-icon{font-size:14px;font-variation-settings:"FILL" 1}.home-goal-badge-text{font-size:12px;font-weight:700}.home-achievements-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px}.home-streak-main-row{display:block}.home-streak-main-copy{min-width:0}.home-streak-goal-mobile{display:none}.library-streak-icon{font-size:16px;font-variation-settings:"FILL" 1}.library-toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:22px}.library-filter-row{display:flex;gap:8px;flex-wrap:wrap}.library-active-genre-chip{display:flex;align-items:center;gap:6px}.library-chip-close{font-size:14px;line-height:1}.library-search-wrap{position:relative;margin-left:auto}.library-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:16px;color:#e8e4f559;pointer-events:none}.library-add-btn{padding:9px 20px;font-size:13px}.library-add-icon{font-size:18px}.library-loading{text-align:center;padding:48px 0;color:#e8e4f566;font-size:14px}.library-state{min-height:260px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;color:#e8e4f59e}.library-state-icon{font-size:34px;color:#ffb4ab}.library-state-title{font-size:16px;font-weight:800;color:#e8e4f5}.library-state-copy{max-width:420px;font-size:13px;line-height:1.5}.library-retry-btn{margin-top:4px;padding:9px 16px;font-size:12px}.library-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}.library-book-cover{background:#8b5cf626}.library-book-img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.library-book-info{display:flex;flex-direction:column;min-height:188px;padding-bottom:8px}.library-book-footer{margin-top:auto}.library-genre-row{display:flex;align-items:center;gap:6px;margin-bottom:7px;flex-wrap:wrap}.library-genre-chip{font-size:9px;height:24px;padding:0 8px;cursor:pointer}.library-prog-track{height:4px;margin-bottom:4px}.library-meta-row{display:flex;justify-content:space-between;align-items:center}.library-stars{display:inline-flex;gap:1px}.library-star{font-size:14px}.library-pct-label{font-size:11px;font-weight:700}.library-status-wrap{margin-top:7px}.library-status-pill{font-size:10px;font-weight:600;padding:2px 7px;border-radius:99px;cursor:pointer}.stats-tooltip{display:flex;transform:none;max-width:calc(100vw - 16px)}.stats-streak-icon{font-size:16px;font-variation-settings:"FILL" 1}#screen-stats{display:flex;flex-direction:column}.stats-head-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:28px}.stats-title{font-size:28px;font-weight:800;color:#e8e4f5;letter-spacing:-.02em}.stats-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stats-cards-grid-primary{order:1}.stats-chart-card{order:2}.stats-insights-grid{order:3}.stats-cards-grid-secondary{order:4;margin-bottom:24px;grid-template-columns:repeat(3,minmax(0,1fr))}.stats-card-minh{min-height:110px}.stats-card-head{display:flex;justify-content:space-between;align-items:start;margin-bottom:10px}.stats-card-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;min-height:20px}.stats-card-title-row--spacious{margin-bottom:12px}.stats-card-title-left{display:inline-flex;align-items:center;gap:8px;min-width:0}.stats-card-title-text{font-size:11px;font-weight:700;color:#e8e4f57a;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-icon-fill{font-variation-settings:"FILL" 1}.stats-icon-20{font-size:20px}.stats-icon-violet{color:#cabeff}.stats-icon-blue{color:#60a5fa}.stats-icon-gold{color:#fbbf24}.stats-icon-green{color:#6ee7b7}.stats-label-top{margin-top:4px}.stats-chart-card{padding:24px 28px;margin-bottom:24px}.stats-streak-feature-card{padding:20px 22px;margin-bottom:14px}.stats-streak-feature-val{color:#fbbf24}.stats-streak-feature-mobile{display:none}.stats-cards-grid>.glass-card,.stats-streak-feature-card{backdrop-filter:none;-webkit-backdrop-filter:none;background:#ffffff0d;isolation:isolate;overflow:hidden}.stats-chart-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.stats-chart-title{font-size:17px;font-weight:700;color:#e8e4f5}.stats-chart-controls{display:flex;align-items:center;gap:12px}.stats-chart-label{font-size:11px;color:#e8e4f559;font-weight:500}.genre-bars-list{display:flex;flex-direction:column;gap:14px}.stats-genre-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.stats-insights-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.stats-insight-card{padding:24px}.stats-insight-title{font-size:16px;font-weight:700;color:#e8e4f5;margin-bottom:16px}.stats-insight-subtitle{font-size:10px;color:#e8e4f54d;margin-bottom:6px;letter-spacing:.04em}.stats-genre-title{margin-bottom:20px}.stats-genre-head .stats-genre-title{margin-bottom:0}.genre-diagram-wrap{display:grid;grid-template-columns:132px minmax(0,1fr);gap:14px;align-items:center}.genre-donut{width:132px;height:132px;border-radius:50%;display:grid;place-items:center;position:relative}.genre-donut:after{content:"";width:76px;height:76px;border-radius:50%;background:rgba(var(--bg-rgb),.9);border:1px solid rgba(var(--primary-rgb),.16)}.genre-donut-center{position:absolute;z-index:1;font-size:12px;font-weight:700;color:#e8e4f5}.genre-diagram-legend{display:flex;flex-direction:column;gap:8px}.genre-diagram-row{display:grid;grid-template-columns:10px minmax(0,1fr) auto auto;gap:8px;align-items:center}.genre-diagram-dot{width:10px;height:10px;border-radius:50%}.genre-diagram-name{min-width:0;font-size:12px;color:#e8e4f5b3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.genre-diagram-minutes,.genre-diagram-pct{font-size:11px;color:#e8e4f58c;white-space:nowrap}.heatmap-legend{display:flex;align-items:center;gap:6px;margin-top:12px}.heatmap-legend span{font-size:10px;color:#e8e4f559}.heatmap-legend-cell{width:12px;height:12px;border-radius:2px}@media (max-width: 767px){html,body,#root{width:100%;max-width:100%;overflow-x:hidden}body{min-width:0}input,textarea,select{font-size:16px!important}#top-bar{display:none}.topbar-title{min-width:0}.streak-chip{padding:5px 9px;font-size:12px}#main-content,#main-content.sidebar-collapsed{width:100%;max-width:100%;min-width:0;margin-left:0;padding-bottom:86px}#page-content{width:100%;max-width:none;min-width:0;padding:12px 16px 96px}#screen-settings{padding-top:0}.settings-title-block{display:none}.settings-layout{display:flex!important;flex-direction:column!important;gap:14px!important;align-items:stretch!important}.settings-tabs-card{position:sticky;top:0;z-index:60;display:flex!important;flex-direction:row!important;gap:6px;width:100%;margin:0;padding:8px 12px!important;overflow-x:auto;border-radius:12px;border:1px solid rgba(var(--primary-rgb),.12);background:rgba(var(--bg-rgb),.94);box-shadow:0 10px 24px #0000002e;scrollbar-width:none}.settings-tabs-card::-webkit-scrollbar{display:none}.settings-tabs-card>div[style*="flex: 1"]{display:none!important}.settings-tabs-card .settings-nav-btn{width:auto;min-width:0;height:38px;flex:0 0 auto;justify-content:center;gap:6px;padding:0 11px;border-radius:999px;font-size:12px;line-height:1;white-space:nowrap}.settings-tabs-card .settings-nav-btn.active{background:var(--primary);color:var(--bg)}.settings-tabs-card .settings-nav-btn .material-symbols-outlined{font-size:16px!important}.settings-signout-wrap{margin-top:0!important;padding-top:0!important;border-top:0!important}.settings-content-panel{min-width:0}.settings-section>.glass-card{padding:18px!important;border-radius:12px}.settings-content-panel .theme-card{min-width:0}.settings-content-panel [style*="repeat(5,1fr)"]{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}.settings-content-panel [style*="justify-content: space-between"]{gap:12px}.settings-content-panel .btn-ghost,.settings-content-panel .btn-primary{min-height:40px}.screen.active{width:100%;min-width:0}#mobile-nav{display:flex!important;align-items:center;justify-content:stretch;height:calc(72px + env(safe-area-inset-bottom,0px));padding:0 8px env(safe-area-inset-bottom,0px);overflow:hidden}.mobile-nav-item,.mobile-nav-center{width:100%;min-width:0;text-decoration:none}.mobile-nav-item{justify-content:center;font-size:9px;letter-spacing:0;line-height:1.1}.mobile-nav-item .material-symbols-outlined{font-size:23px}.mobile-nav-item span:last-child,.mobile-nav-center span:last-child{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav-center{height:58px;margin-top:-10px;border-radius:16px;font-size:9px;letter-spacing:0;line-height:1.1}.mobile-nav-center .material-symbols-outlined{font-size:26px}.home-hero-title,.stats-title,.profile-hero-title{font-size:24px}.home-main-grid,.profile-grid-two,.profile-progress-layout{grid-template-columns:1fr}.home-main-col,.home-side-col{display:contents}.home-current-card{order:-2}.home-recent-card{order:2}.home-goal-card{display:none}.home-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;order:-1}.home-streak-card{order:1}.home-achievements-card{order:3}.home-stat-grid .stat-card{min-height:72px;padding:10px 8px;justify-content:center}.home-stat-head{gap:3px;margin-bottom:5px;justify-content:center}.home-stat-head .material-symbols-outlined{display:inline-flex;font-size:14px;line-height:1}.home-stat-val-sm{font-size:15px;text-align:center;white-space:nowrap}.home-stat-grid .stat-label{font-size:8px;letter-spacing:0;text-align:center;line-height:1.15;white-space:nowrap}.stats-cards-grid,.profile-metric-grid,.profile-tracks-grid,.profile-title-modal-grid{grid-template-columns:1fr}.profile-metric-grid--compact{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.profile-metric-grid--compact .profile-metric-card{padding:8px 8px 7px}.profile-metric-grid--compact .profile-metric-label{font-size:9px;letter-spacing:0}.profile-metric-grid--compact .profile-metric-icon{font-size:14px}.profile-metric-grid--compact .profile-metric-value{font-size:20px}.currently-reading-card{gap:14px;position:relative;align-items:flex-start}.home-cr-cover{width:58px;height:86px}.currently-reading-card .cr-info{min-height:86px;padding-right:0}.home-cr-meta{align-items:flex-start}.home-cr-side{position:absolute;top:0;right:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:0;flex-shrink:0;width:86px;height:86px}.home-cr-goal-mini{display:inline-grid;place-items:center;position:relative;width:86px;height:86px}.home-cr-goal-mini-ring{position:absolute;top:0;right:0;bottom:0;left:0;width:86px;height:86px;transform:rotate(-90deg)}.home-cr-goal-mini-text{position:relative;z-index:1;max-width:48px;font-size:10px;font-weight:800;color:#e8e4f5;line-height:1.05;text-align:center}.home-cr-pct{font-size:12px;font-weight:700;color:#cabeff;margin-left:auto}.home-start-btn{width:100%;padding-inline:14px}.activity-row{gap:10px}.home-session-pages{display:none}.home-streak-goal-mobile{display:flex;justify-content:flex-end;margin:0;flex-shrink:0}.home-streak-main-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px;width:246px;max-width:100%}.home-streak-main-copy p{margin-bottom:0!important}.home-streak-goal-mobile-ring{position:relative;width:96px;height:96px}.home-streak-goal-mobile-ring svg{width:96px;height:96px;transform:rotate(-90deg);filter:drop-shadow(0 0 6px rgba(var(--primary-rgb),.4))}.home-streak-goal-mobile-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;line-height:1.05}.home-streak-goal-mobile-value{font-size:14px;font-weight:800;color:#e8e4f5}.home-streak-goal-mobile-target{margin-top:2px;font-size:9px;color:#e8e4f57a;white-space:nowrap}.home-streak-goal-mobile-ring:before{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(var(--primary-rgb),.18),rgba(var(--bg-rgb),.92) 72%);border:1px solid rgba(var(--primary-rgb),.14);pointer-events:none}.home-streak-week-row{width:246px;max-width:100%}.library-toolbar{align-items:stretch}.library-search-wrap,.library-add-btn{width:100%;margin-left:0}.library-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.library-book-info{min-height:164px}.stats-head-row,.stats-chart-head{align-items:stretch;flex-direction:column}.stats-chart-controls{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:10px;width:100%}.stats-chart-label{min-width:0}.progress-mode-toggle{margin-left:auto;width:auto;max-width:max-content;align-self:flex-end;flex:0 0 auto}.period-tabs{width:100%}.period-tab{flex:1;padding:8px;font-size:12px}.stats-chart-card{padding:18px 16px}.stats-cards-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px}.stats-cards-grid-primary{order:3}.stats-chart-card{order:1}.stats-insights-grid{order:5}.stats-cards-grid-secondary{order:4;margin-bottom:14px}.stats-card-minh{min-height:82px;padding:12px}.stats-card-minh .stats-card-head,.stats-card-title-row{margin-bottom:6px}.stats-card-title-text{font-size:10px}.stats-card-minh .stat-val{font-size:18px;line-height:1.05}.stats-card-minh .stat-label{font-size:10px;line-height:1.15}.stats-card-minh .stats-icon-20{font-size:17px}.stats-card-minh .stat-delta-date{font-size:9px}.stats-streak-feature-card{padding:14px 12px;margin-bottom:10px}.stats-streak-feature-mobile{display:block}.stats-streak-feature-card .stats-streak-feature-val{font-size:24px}.stats-card-minh-compact .stat-val{font-size:20px}.stats-card-current-streak-desktop{display:none}.stats-insights-grid{grid-template-columns:1fr;gap:12px;margin-bottom:16px}.stats-insight-card{padding:14px 12px;min-width:0;overflow:hidden}.stats-insight-title{font-size:14px;margin-bottom:8px}.stats-insight-subtitle{margin-bottom:4px}#screen-stats>div[style*=grid]{grid-template-columns:1fr!important;gap:16px!important}.heatmap-wrap{overflow-x:hidden;padding-bottom:2px}.heatmap-months{padding-left:22px}.heatmap-body{gap:3px}.heatmap-days{width:19px;gap:1px}.heatmap-day-label{height:7px;line-height:7px;font-size:7px}.heatmap-grid{grid-template-rows:repeat(7,7px);gap:1px}.heatmap-cell{width:5px;height:7px;border-radius:1.5px}.heatmap-month-label{font-size:7px}.heatmap-legend{gap:4px;margin-top:8px}.heatmap-legend span{font-size:9px}.heatmap-legend-cell{width:9px;height:9px}.genre-bars-list{gap:8px}.stats-genre-head{gap:8px;margin-bottom:8px}.stats-genre-head .progress-mode-toggle{margin-left:0}.genre-diagram-wrap{grid-template-columns:1fr;justify-items:center;gap:10px}.genre-donut{width:112px;height:112px}.genre-donut:after{width:64px;height:64px}.genre-diagram-legend{width:100%}.genre-bar-row{min-width:0;gap:8px;padding:2px 0}.genre-bar-label{width:82px;min-width:0;flex:0 1 82px;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.genre-bar-track{height:8px}.genre-bar-pct{width:30px;font-size:11px}.profile-identity-row{align-items:flex-start}.profile-identity-name-row{flex-wrap:wrap}.profile-name-edit-wrap{width:100%}.profile-avatar-lg{width:58px;height:58px}.profile-title-list{flex-direction:column}.profile-ach-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.profile-ach-btn{height:36px}.profile-ach-icon{font-size:22px}.profile-honor-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-height:344px;overflow-y:auto}#screen-session{min-height:calc(100dvh - 86px)}#session-idle-overlay{position:fixed!important;top:12px!important;right:16px!important;bottom:86px!important;left:16px!important;min-height:0}.session-layout-v5{width:100%;max-width:none;grid-template-columns:1fr;gap:18px}.session-left-col,.session-right-col{min-width:0}.session-left-col{align-items:stretch}.session-topbar-mini{display:none}.session-book-hero{display:grid;grid-template-columns:56px minmax(0,1fr) auto;column-gap:12px;row-gap:5px;align-items:center;width:100%;margin-top:0;text-align:left}.session-cover-box{grid-row:1 / 4;width:56px;height:84px;aspect-ratio:2 / 3;margin-bottom:0;border-radius:9px}.session-from-badge{display:none}.session-cover-box+div{display:none}.session-rec-pill{display:none}.session-book-title-text{align-self:end;grid-column:2;max-width:100%;font-size:16px;line-height:1.2;text-align:left}.session-book-author-text{grid-column:2;max-width:100%;font-size:12px;text-align:left}.session-book-progress-row{align-self:start;grid-column:2 / 4;max-width:100%}.session-book-pct-lbl{text-align:left}.session-mobile-note-btn{grid-column:3;grid-row:1 / 3;align-self:center;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;width:66px;height:52px;border-radius:14px;border:1px solid rgba(var(--primary-rgb),.18);background:rgba(var(--primary-rgb),.07);color:#e8e4f5b8;font-family:Inter,sans-serif;font-size:9px;font-weight:800;text-transform:uppercase;line-height:1}.session-mobile-note-btn .material-symbols-outlined{font-size:20px}.session-goal-row{justify-content:center;width:100%}#screen-session .ring-pulse{width:198px!important;height:198px!important}#screen-session .ring-pulse+.ring-pulse{width:228px!important;height:228px!important}.timer-ring-wrap{width:176px;height:176px}.timer-digits{font-size:32px;letter-spacing:0}.session-actions-bar{display:flex;width:100%;justify-content:center;gap:8px;margin-top:14px}.session-action-btn--soon{display:none}.session-actions-bar .session-action-btn:not(.session-pause-main){display:none}.session-action-btn{min-width:0;height:58px;padding:6px;font-size:10px;line-height:1.1;text-align:center}.session-action-btn .material-symbols-outlined{font-size:20px}.session-pause-main{width:152px;height:58px;border-radius:14px}.session-pause-main .material-symbols-outlined{font-size:28px}.session-action-soon-chip{top:-7px;right:4px;font-size:8px;padding:1px 5px}.btn-add-manually{width:100%;justify-content:center}textarea.session-notes{min-height:108px}.session-right-col>:nth-child(1){order:3}.session-right-col>:nth-child(2){order:2}.session-right-col>:nth-child(3){order:1}.session-right-col>:nth-child(4){order:0;margin-top:0!important}.session-right-col>:nth-child(5){order:4}#screen-session .session-right-col .glass-card{padding:16px!important}.session-bottom-actions{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:10px;width:100%}.session-bottom-actions .session-finish-btn,.session-cancel-btn{width:100%;min-height:44px;padding:10px 12px!important}#screen-session .session-right-col .glass-card div[style*="gridTemplateColumns: 'repeat(3,1fr)'"],#screen-session .session-right-col .glass-card div[style*="grid-template-columns: repeat(3,1fr)"]{grid-template-columns:repeat(3,minmax(0,1fr))!important}#session-pages-mode>div,#session-pct-mode>div{flex-wrap:wrap;gap:8px!important}input[type=number].page-num-input,input[type=number].pct-input{width:88px;min-height:40px}.pct-input-wrap{flex-shrink:0}#screen-session .session-right-col .glass-card div[style*="gridTemplateColumns: '1fr 72px 96px'"],#screen-session .session-right-col .glass-card div[style*="grid-template-columns: 1fr 72px 96px"]{grid-template-columns:minmax(0,1fr) 58px 72px!important;gap:8px!important}.finish-session-overlay,.manual-log-overlay{padding:12px;align-items:flex-end}.book-picker-overlay{padding:12px;align-items:flex-end;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 22dvh)}.manual-log-overlay.signout-overlay{align-items:flex-end;padding-bottom:calc(env(safe-area-inset-bottom,0px) + 22dvh)}.finish-session-modal,.book-picker-modal,.manual-log-modal{width:100%;max-width:none;max-height:calc(100dvh - 24px);border-radius:16px}.book-picker-modal{min-height:0}.book-picker-header{padding:18px 18px 8px}.book-picker-grid{flex-direction:column;gap:10px!important}.book-option{flex:0 0 auto!important;display:grid;grid-template-columns:58px minmax(0,1fr);gap:10px;padding:10px}.book-option-cover{grid-row:span 2}.book-option-info{justify-content:center}.book-option-title{-webkit-line-clamp:2}.manual-log-body{padding:18px}.manual-log-title{white-space:normal}.manual-log-overlay.add-book-overlay-open{align-items:flex-start;padding-top:calc(env(safe-area-inset-top,0px) + 52px)}.manual-log-modal.add-book-modal-shell{margin-top:0;max-height:calc(100dvh - env(safe-area-inset-top,0px) - 16px);min-height:0}.add-book-body{max-height:calc(100dvh - 220px);overflow-y:auto;-webkit-overflow-scrolling:touch}.add-book-search-action-sticky{position:sticky;top:0;z-index:2;display:flex;justify-content:center;padding:8px 0 10px;margin-bottom:8px;background:linear-gradient(to bottom,rgba(var(--bg-rgb),.94),rgba(var(--bg-rgb),.88));backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.add-book-search-action-btn{width:100%}.home-current-card--scroll .home-current-list{max-height:360px;overflow-y:auto;padding-right:2px;-webkit-overflow-scrolling:touch}}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.sidebar__logo{padding:var(--space-4);border-bottom:1px solid var(--sidebar-border);display:flex;align-items:center;gap:var(--space-2)}.sidebar__logo-text{font-size:18px;font-weight:800;color:var(--primary);letter-spacing:-.5px}.sidebar__nav{flex:1;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;gap:var(--space-1);overflow-y:auto}.sidebar__nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-muted);font-size:14px;font-weight:500;transition:background .15s,color .15s;text-decoration:none}.sidebar__nav-item:hover{background:var(--bg-02);color:var(--text-primary)}.sidebar__nav-item.active{background:rgba(var(--primary-rgb),.12);color:var(--primary)}.sidebar__nav-item.active .material-symbols-outlined{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}.sidebar__footer{padding:var(--space-3) var(--space-2);border-top:1px solid var(--sidebar-border)}.main-content{margin-left:var(--sidebar-width);margin-right:var(--right-panel-width);flex:1;padding:var(--space-5);min-height:100vh}.right-panel{width:var(--right-panel-width);background:var(--sidebar-bg);border-left:1px solid var(--sidebar-border);position:fixed;top:0;right:0;height:100vh;z-index:100;display:flex;flex-direction:column;padding:var(--space-4);gap:var(--space-4);overflow-y:auto;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.right-panel__section{display:flex;flex-direction:column;gap:var(--space-2)}.right-panel__title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint)}.page-header{margin-bottom:var(--space-5)}.page-header h1{font-size:28px;font-weight:800}.page-header p{margin-top:var(--space-1);font-size:14px}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-layout--rich{background:radial-gradient(700px 420px at 10% 10%,rgba(var(--primary-rgb),.12),transparent 70%),radial-gradient(620px 380px at 90% 90%,rgba(96,165,250,.12),transparent 70%),var(--bg);padding:24px}.auth-card{width:100%;max-width:400px;background:var(--surface-container);border:1px solid var(--border-glass);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-5);box-shadow:var(--shadow-glass)}.auth-card--rich{max-width:720px;width:min(100%,720px);padding:28px;border-radius:20px}.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:20px}.auth-brand__logo{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(var(--primary-rgb),.14);color:var(--primary)}.auth-brand__logo .material-symbols-outlined{font-size:24px}.auth-brand h1{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.auth-brand p{margin-top:2px;font-size:13px;color:var(--text-muted)}.auth-card__logo{text-align:center;margin-bottom:var(--space-5)}.auth-card__logo h1{font-size:32px;font-weight:800;color:var(--primary)}.auth-card__logo p{font-size:14px;margin-top:var(--space-1)}.auth-card__form{display:flex;flex-direction:column;gap:var(--space-3)}.auth-card__form--rich{gap:14px}.auth-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.auth-submit{width:100%;margin-top:4px}.auth-card__footer{margin-top:var(--space-4);text-align:center;font-size:14px;color:var(--text-muted)}@media (max-width: 760px){.auth-card--rich{padding:20px}.auth-grid-2{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:14px;font-weight:600;border:none;transition:background .15s,opacity .15s,transform .1s;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:active{transform:scale(.97)}.btn--primary{background:var(--primary);color:var(--bg)}.btn--primary:hover:not(:disabled){background:var(--primary-hover)}.btn--ghost{background:var(--bg-02);color:var(--text-primary);border:1px solid var(--border-glass)}.btn--ghost:hover:not(:disabled){background:var(--bg-03)}.btn--danger{background:#ffb4ab1a;color:var(--error);border:1px solid rgba(255,180,171,.2)}.btn--danger:hover:not(:disabled){background:#ffb4ab26}.btn--sm{padding:var(--space-1) var(--space-3);font-size:12px}.btn--lg{padding:var(--space-3) var(--space-5);font-size:16px;width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--loading{opacity:.7;cursor:wait}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-label{font-size:13px;font-weight:500;color:var(--text-muted)}.form-input{background:var(--bg-02);border:1px solid var(--border-glass);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.form-input::placeholder{color:var(--text-faint)}.form-input:focus{border-color:rgba(var(--primary-rgb),.4);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.form-input--error{border-color:#ffb4ab66}.form-error{font-size:12px;color:var(--error);margin-top:2px}.card{background:var(--surface-container);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-card)}.card--hover:hover{border-color:rgba(var(--primary-rgb),.2);box-shadow:0 0 0 1px rgba(var(--primary-rgb),.1),var(--shadow-card)}.progress-bar{height:6px;background:var(--bg-03);border-radius:var(--radius-full);overflow:hidden}.progress-bar__fill{height:100%;background:var(--primary);border-radius:var(--radius-full);transition:width .3s ease}.star-rating{display:flex;gap:2px}.star-rating__star{font-size:18px;cursor:pointer;transition:color .1s,transform .1s;-webkit-user-select:none;user-select:none}.star-rating__star--filled{color:var(--warning)}.star-rating__star--empty{color:var(--text-faint)}.star-rating__star:hover{transform:scale(1.2)}.badge{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.03em}.badge--reading{background:rgba(var(--primary-rgb),.12);color:var(--primary)}.badge--read{background:#6ee7b71f;color:var(--success)}.badge--want{background:#60a5fa1f;color:var(--info)}@keyframes skeleton-pulse{0%,to{opacity:.6}50%{opacity:.3}}.skeleton{background:var(--bg-03);border-radius:var(--radius-md);animation:skeleton-pulse 1.5s ease-in-out infinite}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:14px}.alert--error{background:#ffb4ab1a;color:var(--error);border:1px solid rgba(255,180,171,.2)}.alert--success{background:#6ee7b71a;color:var(--success);border:1px solid rgba(110,231,183,.2)}.book-profile-loading,.book-profile-empty{padding:24px;color:var(--text-muted)}.book-profile-page{display:grid;gap:14px}.book-profile-back-wrap{margin-bottom:4px}.book-profile-back-btn{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-size:12px;font-weight:600;color:var(--text-primary);background:#ffffff0a;border:1px solid var(--border-glass);border-radius:999px;padding:6px 12px 6px 8px;transition:background .15s,border-color .15s,transform .12s}.book-profile-back-btn:hover{background:rgba(var(--primary-rgb),.12);border-color:rgba(var(--primary-rgb),.32)}.book-profile-back-btn:active{transform:translateY(1px)}.book-profile-back-btn__icon{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:16px;color:var(--primary);background:rgba(var(--primary-rgb),.16);border:1px solid rgba(var(--primary-rgb),.24)}.book-profile-layout{display:grid;gap:14px}.book-profile-hero{--book-cover-w: 220px;--book-cover-h: 330px;display:grid;grid-template-columns:var(--book-cover-w) minmax(0,1fr) auto;grid-template-areas:"cover main rating" "meta progress progress";gap:20px;align-items:stretch}.hero-cover-col,.hero-main-col,.hero-rating-col{min-width:0}.hero-cover-col{grid-area:cover}.hero-main-col{grid-area:main;display:flex;min-height:var(--book-cover-h);height:var(--book-cover-h);max-height:var(--book-cover-h)}.hero-rating-col{grid-area:rating}.hero-meta-col{grid-area:meta}.book-profile-cover{width:var(--book-cover-w);max-width:100%;aspect-ratio:2 / 3;border-radius:8px;overflow:hidden;background:#111;border:1px solid var(--border-glass)}.book-profile-cover-img{width:100%;height:100%;object-fit:contain}.book-meta-panel{margin-top:6px;border:1px solid var(--border-glass);border-radius:8px;background:var(--bg-02);padding:10px 12px;display:grid;gap:8px}.meta-row{display:flex;justify-content:space-between;gap:10px}.meta-label{font-size:12px;line-height:16px;color:var(--text-muted)}.meta-value{font-size:13px;line-height:18px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:11px;line-height:14px;font-weight:700;text-transform:capitalize}.status-read{background:#6ee7b729;color:#6ee7b7}.status-reading{background:rgba(var(--primary-rgb),.16);color:var(--primary)}.status-want{background:#fbbf2429;color:#fbbf24}.book-profile-main{display:grid;gap:14px}.book-profile-head-main{min-width:0;height:100%;display:flex;flex-direction:column;overflow:visible}.book-profile-edit-mode-col{width:100%;height:100%;min-width:0;display:flex;flex-direction:column;gap:12px}.book-profile-edit-actions{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.book-profile-edit-actions .btn-secondary,.book-profile-edit-actions .btn-primary{min-height:36px;padding:8px 14px;font-size:12px;line-height:1}.book-profile-danger-btn{color:#ffb4ab;background:#ffb4ab14;border-color:#ffb4ab47}.book-profile-danger-btn:hover:not(:disabled){color:#ffd6d1;background:#ffb4ab24;border-color:#ffb4ab6b}.book-profile-danger-btn--solid{background:#ffb4ab29;border-color:#ffb4ab73}.book-profile-edit-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.book-profile-input-compact{min-height:42px}.book-profile-edit-description-wrap{flex:1;min-height:120px}.book-profile-edit-description-input{min-height:100%;resize:none}.book-profile-title{font-size:clamp(22px,2.2vw,30px);line-height:1.2;font-weight:700;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.book-profile-author{margin-top:8px;font-size:15px;line-height:22px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.genres-row{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.genre-chip{max-width:220px;height:28px;padding:0 10px;border-radius:999px;border:1px solid var(--border-glass);background:#ffffff0a;font-size:12px;line-height:16px;display:inline-flex;align-items:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-profile-hero-description{margin-top:10px;border:1px solid var(--border-glass);border-radius:8px;padding:8px 10px;background:var(--bg-02);flex:1;display:flex;flex-direction:column;justify-content:flex-start;min-height:120px;overflow:hidden}.book-profile-hero-description-label{display:block;font-size:11px;line-height:14px;color:var(--text-faint);margin-bottom:4px}.book-profile-hero-description p{margin:0;font-size:12px;line-height:17px;color:var(--text-secondary);white-space:pre-wrap;overflow:auto}.book-profile-hero-description-mobile{display:none}.book-profile-progress-wrap{margin-top:0}.book-profile-progress-track{height:6px}.book-profile-progress-label{margin-top:6px;font-size:12px;color:var(--text-secondary)}.book-profile-kpi-strip{margin-top:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.book-profile-hero-progress{grid-area:progress;margin-top:4px}.book-profile-rating-card{border:1px solid var(--border-glass);border-radius:8px;background:var(--bg-02);padding:8px 10px;display:grid;gap:6px;width:330px;max-width:100%;flex-shrink:0}.book-profile-rating-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.book-profile-rating-title{margin:0;font-size:14px;line-height:18px;font-weight:700}.book-profile-rating-stars{display:inline-flex;gap:2px}.book-profile-rating-star-btn{width:30px;height:30px;border:0;background:transparent;cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center}.book-profile-rating-star-btn:focus-visible{outline:2px solid rgba(var(--primary-rgb),.65);outline-offset:2px;border-radius:3px}.book-profile-rating-star-icon{font-size:28px;color:var(--warning);line-height:1}.book-profile-rating-star-icon.is-filled{font-variation-settings:"FILL" 1,"wght" 500,"GRAD" 0,"opsz" 24}.book-profile-rating-star-icon.is-empty{color:rgba(var(--primary-rgb),.38);font-variation-settings:"FILL" 0,"wght" 500,"GRAD" 0,"opsz" 24}.book-profile-rating-half.active+.book-profile-rating-half.right,.book-profile-rating-half.active.left{box-shadow:none}.book-profile-rating-value{font-size:13px;line-height:18px;font-weight:600;color:var(--text-primary)}.book-profile-rating-help{margin:0;font-size:11px;line-height:12px;color:var(--text-muted);min-height:12px}.book-profile-rating-card[data-disabled=true]{opacity:.7}.book-profile-rating-card[data-disabled=true] .book-profile-rating-star-btn{cursor:not-allowed}.book-profile-kpi-cell{border:1px solid var(--border-glass);border-radius:8px;padding:8px 10px;background:var(--bg-02);display:grid;gap:3px}.book-profile-kpi-cell span{font-size:11px;color:var(--text-faint)}.book-profile-kpi-label{display:inline-flex;align-items:center;gap:6px}.book-profile-kpi-icon{font-size:14px;color:rgba(var(--primary-rgb),.9)}.book-profile-kpi-cell strong{font-size:13px;color:var(--text-primary)}.book-profile-tabs{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}.book-profile-tabs::-webkit-scrollbar{display:none;width:0;height:0}.book-profile-tab{white-space:nowrap;text-transform:none!important;letter-spacing:0!important}.book-profile-tab-label-mobile{display:none}.book-profile-tab.active{opacity:1}.book-profile-panel{display:grid;gap:10px}.book-profile-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.book-profile-panel-title{font-size:14px;font-weight:700}.book-profile-table-wrap{overflow-x:auto}.book-profile-table{width:100%;border-collapse:collapse;font-size:13px}.book-profile-table th,.book-profile-table td{padding:8px 6px;border-bottom:1px solid var(--border-glass)}.book-profile-table th{text-align:left;color:var(--text-faint);font-size:12px;font-weight:600}.book-profile-table .num{text-align:right}.book-profile-notes{width:100%;min-height:160px;resize:vertical;border-radius:8px;border:1px solid var(--border-glass);background:var(--bg-02);color:var(--text-primary);padding:10px;box-sizing:border-box;font:inherit}.book-profile-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.book-profile-meta-grid div{border:1px solid var(--border-glass);border-radius:8px;padding:8px 10px;background:var(--bg-02);display:grid;gap:3px}.book-profile-meta-grid span{font-size:11px;color:var(--text-faint)}.book-profile-meta-grid strong{font-size:13px;color:var(--text-primary);font-weight:600}.book-profile-links{display:flex;gap:12px}.book-profile-links a{color:rgba(var(--primary-rgb),.95);text-decoration:none;font-size:13px}.book-profile-description summary{cursor:pointer;font-size:13px;color:var(--text-secondary)}.book-profile-description p{margin:8px 0 0;color:var(--text-secondary);line-height:1.5;font-size:13px}@media (max-width: 980px){.book-profile-hero{--book-cover-w: 170px;--book-cover-h: 255px;grid-template-columns:var(--book-cover-w) minmax(0,1fr);grid-template-areas:"cover main" "meta progress" "rating rating"}.book-profile-kpi-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.book-profile-meta-grid{grid-template-columns:1fr}.book-profile-cover{width:100%;max-width:none}}@media (max-width: 640px){.book-profile-hero{--book-cover-h: 198px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-areas:"cover rating" "main meta" "desc desc" "progress progress";justify-content:stretch;align-items:start;gap:8px 10px}.book-profile-cover{width:100%;max-width:none}.hero-rating-col{width:100%!important;max-width:none!important;min-width:0!important;min-height:var(--book-cover-h)}.book-profile-rating-wrap{width:100%!important;max-width:none!important;height:var(--book-cover-h)!important;max-height:var(--book-cover-h)!important;align-items:flex-start}.book-profile-edit-trigger-col{display:none}.book-profile-rating-card.book-profile-rating-shell{width:100%!important;max-width:none!important;min-width:0!important;min-height:0!important;height:var(--book-cover-h)!important;max-height:var(--book-cover-h)!important;padding:8px;align-content:center;justify-content:space-around;gap:6px;box-sizing:border-box;overflow:hidden}.book-profile-rating-head-wrap{margin-bottom:2px}.book-profile-rating-head-inner{min-height:0;padding:0}.book-profile-rating-pill{min-width:0;height:28px;padding:0 8px;margin-bottom:8px;font-size:10px;letter-spacing:.06em}.book-profile-score-ring{width:86px;height:86px}.book-profile-score-value{font-size:44px}.book-profile-rating-stars-row{gap:1px;margin-top:0}.book-profile-rating-star-btn{width:20px;height:26px}.book-profile-rating-star-icon-lg{font-size:20px}.book-profile-rating-help{min-height:0}.hero-main-col{height:auto;min-height:0;max-height:none;margin-top:-2px}.book-profile-head-main{height:auto}.book-profile-title{font-size:21px}.book-profile-author{margin-top:5px}.genres-row{margin-top:7px}.book-profile-hero-description{margin-top:8px}.book-profile-head-main .book-profile-hero-description-desktop{display:none}.book-profile-hero-description-mobile{display:flex;grid-area:desc;margin-top:0;min-height:110px}.hero-meta-col.book-meta-panel{margin-top:0;padding:8px 9px;gap:6px;align-self:start}.hero-meta-col .meta-row{gap:6px}.hero-meta-col .meta-label{font-size:11px;line-height:14px}.hero-meta-col .meta-value{font-size:12px;line-height:16px}}@media (min-width: 641px) and (max-width: 767px){.book-profile-hero{--book-cover-h: 222px;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;grid-template-areas:"cover rating" "main meta" "desc desc" "progress progress"!important;justify-content:stretch;align-items:start;gap:10px 12px}.book-profile-cover{width:100%;max-width:none}.hero-rating-col{width:100%!important;max-width:none!important;min-width:0!important;min-height:var(--book-cover-h)}.book-profile-rating-wrap{width:100%!important;max-width:none!important;height:var(--book-cover-h)!important;max-height:var(--book-cover-h)!important;align-items:flex-start}.book-profile-edit-trigger-col{display:none}.book-profile-rating-card.book-profile-rating-shell{width:100%!important;max-width:none!important;min-width:0!important;min-height:0!important;height:var(--book-cover-h)!important;max-height:var(--book-cover-h)!important;padding:9px;justify-content:space-around;gap:7px;box-sizing:border-box;overflow:hidden}.book-profile-rating-head-wrap{margin-bottom:2px}.book-profile-rating-head-inner{min-height:0;padding:0}.book-profile-rating-pill{min-width:0;height:30px;padding:0 9px;margin-bottom:8px;font-size:10px;letter-spacing:.06em}.book-profile-score-ring{width:96px;height:96px}.book-profile-score-value{font-size:48px}.book-profile-rating-stars-row{gap:1px;margin-top:0}.book-profile-rating-star-btn{width:22px;height:28px}.book-profile-rating-star-icon-lg{font-size:21px}.book-profile-rating-help{min-height:0}.hero-main-col{height:auto;min-height:0;max-height:none;margin-top:-2px}.book-profile-head-main{height:auto}.book-profile-title{font-size:22px}.book-profile-author{margin-top:5px}.genres-row{margin-top:7px}.book-profile-hero-description{margin-top:8px}.book-profile-head-main .book-profile-hero-description-desktop{display:none}.book-profile-hero-description-mobile{display:flex;grid-area:desc;margin-top:0;min-height:120px}.hero-meta-col.book-meta-panel{margin-top:0;padding:9px 10px;gap:7px;align-self:start}.hero-meta-col .meta-row{gap:7px}}@media (max-width: 767px){.book-profile-rating-card.book-profile-rating-shell{border:none}.hero-rating-col{min-height:0!important}.book-profile-rating-wrap{height:auto!important;max-height:none!important;gap:6px!important}.book-profile-rating-card.book-profile-rating-shell{height:auto!important;max-height:none!important;overflow:visible!important}.book-profile-edit-trigger-mobile{margin-bottom:4px!important}.book-profile-edit-trigger-mobile .btn-secondary{min-height:30px;padding:5px 10px;font-size:12px;gap:4px;border-radius:10px}.book-profile-edit-trigger-mobile .btn-secondary .material-symbols-outlined{font-size:16px}.book-profile-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;overflow-x:visible;padding-bottom:0}.book-profile-tab{min-width:0;width:100%;height:34px;padding:0 6px!important;border-radius:999px;font-size:11px!important;line-height:1.1;font-weight:600;text-align:center;white-space:normal;letter-spacing:0!important}.book-profile-tab-label-full{display:none}.book-profile-tab-label-mobile{display:inline}.book-profile-edit-actions{justify-content:stretch}.book-profile-edit-actions .btn-secondary,.book-profile-edit-actions .btn-primary{flex:1 1 0;min-width:0}.book-profile-edit-grid{grid-template-columns:1fr}}
