:root{--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-body: "Inter", system-ui, sans-serif;--font-display: "Scheherazade New", serif;--font-serif: "Source Serif 4", Georgia, serif;--font-mono: "SF Mono", "Fira Code", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-lg: 17px;--text-xl: 20px;--text-2xl: 24px;--text-xs-fluid: clamp(11px, .3vw + 10px, 12px);--text-sm-fluid: clamp(13px, .4vw + 11px, 14px);--text-base-fluid: clamp(15px, .5vw + 13px, 18px);--text-lg-fluid: clamp(18px, .6vw + 15px, 22px);--text-xl-fluid: clamp(22px, .8vw + 18px, 28px);--text-2xl-fluid: clamp(28px, 1vw + 22px, 36px);--reading-line-height: 1.6;--reading-max-width: 65ch;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 999px;--transition-fast: .1s ease;--transition-base: .15s ease;--transition-slow: .3s ease;--container-sm: 480px;--container-md: 640px;--container-lg: 960px;--container-xl: 1200px}[data-theme=light]{--bg: #f7f6f3;--surface: #ffffff;--panel: #efede8;--text-primary: #1c1b1f;--text-secondary: #4a4750;--text-muted: #6a6670;--accent: #6d4cff;--accent-strong: #5a3df0;--border: #e3dde9;--shadow: rgba(20, 16, 30, .08);--nav-bg: rgba(247, 246, 243, .9);--nav-border: rgba(28, 27, 31, .08);--nav-dropdown-bg: #ffffff;--nav-dropdown-border: #e3dde9;--nav-dropdown-hover: #efede8;--primary-color: #6d4cff;--primary-gradient: linear-gradient(45deg, #6d4cff, #8f7bff);--bg-primary: var(--bg);--bg-secondary: var(--surface);--bg-tertiary: var(--panel);--accent-hover: var(--accent-strong);--danger: #dc2626;--danger-rgb: 220, 38, 38;--success: #16a34a;--success-rgb: 22, 163, 74;--warning: #d97706;--warning-rgb: 217, 119, 6}[data-theme=dark]{--bg: #0f1014;--surface: #171a24;--panel: #1e2230;--text-primary: #f3f1ff;--text-secondary: #c6c0d6;--text-muted: #9b96b0;--accent: #9b7bff;--accent-strong: #b39bff;--border: #2b2f43;--shadow: rgba(0, 0, 0, .4);--nav-bg: rgba(15, 16, 20, .88);--nav-border: rgba(255, 255, 255, .08);--nav-dropdown-bg: #171a24;--nav-dropdown-border: #2b2f43;--nav-dropdown-hover: #1e2230;--primary-color: #9b7bff;--primary-gradient: linear-gradient(45deg, #9b7bff, #c2b1ff);--bg-primary: var(--bg);--bg-secondary: var(--surface);--bg-tertiary: var(--panel);--accent-hover: var(--accent-strong);--danger: #ef4444;--danger-rgb: 239, 68, 68;--success: #22c55e;--success-rgb: 34, 197, 94;--warning: #fbbf24;--warning-rgb: 251, 191, 36}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms;animation-iteration-count:1;transition-duration:.01ms;scroll-behavior:auto}}.state-loading{opacity:.6;pointer-events:none;position:relative}.state-loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:state-spin .6s linear infinite}@keyframes state-spin{to{transform:rotate(360deg)}}.state-error{border-color:var(--danger);background-color:rgba(var(--danger-rgb),.05)}.state-success{border-color:var(--success);background-color:rgba(var(--success-rgb),.05)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;min-height:100vh;overflow-x:hidden;transition:background .2s ease,color .2s ease;background:var(--bg);color:var(--text-primary)}a{color:inherit;text-decoration:none}.has-navbar{padding-top:52px}.page{max-width:1200px;margin:0 auto;padding:48px 24px 96px;display:grid;grid-template-columns:260px minmax(0,1fr);gap:32px}.library-rail{position:sticky;top:72px;align-self:start;display:flex;flex-direction:column;gap:24px}.rail-card{padding:0 0 16px;border-bottom:1px solid var(--border)}.rail-title{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--text-muted);margin-bottom:8px;-webkit-user-select:none;user-select:none}.rail-title--spaced{margin-top:16px}.rail-search,.rail-select{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--panel);color:var(--text-primary)}.rail-hint{font-size:12px;color:var(--text-muted);margin-top:8px}.rail-list{display:flex;flex-direction:column;gap:8px}.rail-item{display:flex;justify-content:space-between;color:var(--text-secondary);font-size:14px;-webkit-user-select:none;user-select:none;cursor:pointer;padding:6px 8px;border-radius:6px;transition:background .2s ease,color .2s ease}.rail-item:hover{background:var(--panel);color:var(--text-primary)}.rail-item.active{color:var(--text-primary);font-weight:600}.year-list,.year-group{display:flex;flex-direction:column;gap:8px}.year-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;border:none;background:none;padding:6px 0;font-size:14px;color:var(--text-secondary);cursor:pointer;transition:color .2s ease}.year-toggle:hover{color:var(--text-primary)}.year-group.is-open .year-toggle{color:var(--text-primary);font-weight:600}.year-items{display:none;flex-direction:column;gap:8px;border-left:1px solid var(--border);padding-left:12px;margin-left:4px}.year-group.is-open .year-items{display:flex}.year-item{border:none;background:none;text-align:left;font-size:14px;color:var(--text-muted);cursor:pointer;padding:4px 0;transition:color .2s ease}.year-item:hover,.year-item.active{color:var(--text-primary)}.year-empty{font-size:12px;color:var(--text-muted);padding:2px 0}.library-main{display:flex;flex-direction:column;gap:32px}.library-default.is-hidden{display:none}.library-detail{display:none;flex-direction:column;gap:16px;padding:0 0 16px;border-bottom:1px solid var(--border)}.library-detail.is-active{display:flex;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.detail-back{border:none;background:none;color:var(--accent);font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none;min-height:44px;display:flex;align-items:center;transition:color .2s ease}.detail-back:hover{color:var(--accent-strong)}.detail-title{font-family:Scheherazade New,serif;font-size:clamp(28px,4vw,38px);font-weight:700;line-height:1.2}.detail-summary{font-size:16px;color:var(--text-secondary);line-height:1.6}.detail-meta{font-size:12px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.detail-content{display:flex;flex-direction:column;gap:16px;color:var(--text-secondary);line-height:1.7;font-size:16px}.detail-content p{margin:0}.library-hero{padding:0 0 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:16px}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.24em;color:var(--text-muted);-webkit-user-select:none;user-select:none}.hero-title{font-family:Scheherazade New,serif;font-size:clamp(30px,4vw,40px);font-weight:700;line-height:1.1;-webkit-user-select:none;user-select:none}.hero-summary{font-size:16px;color:var(--text-secondary);line-height:1.6}.library-hero--signin{text-align:center;padding:60px 20px}.hero-title--signin{margin-bottom:16px}.hero-summary--signin{margin-bottom:24px}.pnav-login-btn--hero{font-size:16px;padding:12px 24px}.hero-meta{font-size:12px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.hero-link{color:var(--accent);font-weight:600;font-size:14px;-webkit-user-select:none;user-select:none}.shelf{display:flex;flex-direction:column;gap:12px}.shelf-header{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}.shelf-title{font-size:24px;font-family:Scheherazade New,serif;-webkit-user-select:none;user-select:none}.shelf-subtitle{color:var(--text-secondary);font-size:14px}.shelf-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}.shelf-item{padding:16px 12px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px;cursor:pointer;border-radius:8px;transition:background .2s ease}.shelf-item:hover{background:var(--panel)}.shelf-item:active{transform:scale(.995)}.shelf-item-title{font-weight:600;font-size:16px}.shelf-item-summary{font-size:14px;color:var(--text-secondary);line-height:1.6}.shelf-item-meta{font-size:12px;color:var(--text-muted);-webkit-user-select:none;user-select:none}.library-empty{display:none;padding:16px 0;color:var(--text-muted);font-size:14px}.mobile-filter-btn{display:none;position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--primary-color, #f093fb);border:none;color:#fff;cursor:pointer;z-index:999;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000004d;transition:transform .15s ease,box-shadow .15s ease}.mobile-filter-btn:hover{transform:scale(1.05);box-shadow:0 6px 20px #0006}.mobile-filter-btn:active{transform:scale(.98)}.mobile-filter-btn svg{width:20px;height:20px}.mobile-filter-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:997}.mobile-filter-overlay.is-open{display:block}@media(max-width:768px){.page{grid-template-columns:1fr}.library-rail{position:fixed;top:70px;left:0;bottom:0;width:280px;background:var(--bg, #1a1a2e);z-index:998;padding:20px 16px;overflow-y:auto;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);border-right:1px solid var(--border, rgba(255, 255, 255, .08))}.library-rail.is-open{transform:translate(0)}.mobile-filter-btn{display:flex}}.coming-soon-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg)}.coming-soon-content{text-align:center;max-width:480px;padding:48px 24px}.coming-soon-content h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:16px}.coming-soon-content p{font-size:1.1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.coming-soon-content .coming-soon-back{display:inline-block;padding:10px 24px;background:var(--accent);color:#fff;border-radius:8px;text-decoration:none;font-weight:600;transition:opacity .2s}.coming-soon-content .coming-soon-back:hover{opacity:.85}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
