*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0d0f12;--bg2: #13161b;--bg3: #1a1e25;--bg4: #222730;--gold: #c9a84c;--gold2: #e8c66a;--gold-dim: #7a6230;--gold-bg: rgba(201,168,76,.08);--text: #e8e2d6;--text2: #9a9488;--text3: #5a5650;--border: #2a2e38;--border2: #3a3e4a;--green: #3dba7e;--red: #e05555;--radius: 10px;--radius-sm: 6px}html,body,#root{height:100%}body{font-family:Lato,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app{display:grid;grid-template-columns:320px 1fr;height:100vh}.app-menu-toggle,.app-nav-backdrop,.sidebar-drawer-close{display:none}.breadcrumb-start{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.breadcrumb-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace;letter-spacing:1px}.reader-top-empty-start{display:flex;flex-wrap:wrap;align-items:center;gap:10px;flex:1;min-width:0}.reader-top-empty-row .user-badge-top{margin-left:auto;flex-shrink:0}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(300px,88vw);max-width:320px;z-index:2000;transform:translate3d(-100%,0,0);transition:transform .25s ease;will-change:transform}.sidebar.sidebar--drawer-open{transform:translateZ(0)}.reader{min-width:0;width:100%}.app-nav-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:1990;margin:0;padding:0;border:none;background:#050608b8;cursor:pointer;-webkit-tap-highlight-color:transparent}.sidebar-header{position:relative;padding-right:48px}.sidebar-drawer-close{display:inline-flex;align-items:center;justify-content:center;position:absolute;top:10px;right:10px;width:40px;height:40px;border:none;border-radius:var(--radius-sm);background:var(--bg3);color:var(--text2);font-size:24px;line-height:1;cursor:pointer;z-index:2}.sidebar-drawer-close:hover{color:var(--text);background:var(--bg4)}.app-menu-toggle{display:inline-flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:42px;height:42px;flex-shrink:0;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg3);color:var(--gold);cursor:pointer;-webkit-tap-highlight-color:transparent}.app-menu-toggle:hover{border-color:var(--gold-dim);background:var(--bg4)}.app-menu-toggle-bar{display:block;width:18px;height:2px;border-radius:1px;background:currentColor}.breadcrumb{flex-wrap:wrap;row-gap:8px}.reader-top,.reader-top-empty,.player-bar{padding-left:14px;padding-right:14px}.content-area:not(.content-area--book-reader){padding-left:16px;padding-right:16px}}@media (min-width: 901px){.app-nav-backdrop,.app-menu-toggle{display:none!important}}.sidebar{background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:22px 18px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.logo{display:flex;align-items:center;gap:10px;margin-bottom:12px}.logo-icon{width:34px;height:34px;background:var(--gold);border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--bg);flex-shrink:0}.logo-text{font-family:Playfair Display,serif;font-size:18px;color:var(--gold)}.logo-sub{font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace;letter-spacing:1px;text-transform:uppercase}.stats-pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.stat-pill{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:3px 10px;font-size:11px;font-family:JetBrains Mono,monospace;color:var(--text2)}.stat-pill.gold{border-color:var(--gold-dim);color:var(--gold)}.stat-pill.streaming{border-color:var(--gold-dim);color:var(--gold);animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.search-box{position:relative}.search-box input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px 8px 32px;color:var(--text);font-size:13px;font-family:Lato,sans-serif;outline:none;transition:border-color .15s}.search-box input:focus{border-color:var(--gold-dim)}.search-box input::placeholder{color:var(--text3)}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:15px;pointer-events:none}.chapters-label{padding:14px 18px 6px;font-size:10px;letter-spacing:2px;color:var(--text3);font-family:JetBrains Mono,monospace;text-transform:uppercase;flex-shrink:0}.chapters-list{flex:1;overflow-y:auto;padding:0 8px 8px;min-height:0}.chapters-list::-webkit-scrollbar{width:3px}.chapters-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.sidebar-footer{flex-shrink:0;padding:12px 14px 16px;border-top:1px solid var(--border);background:var(--bg2)}.sidebar-logout-btn{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--bg3);color:var(--text2);font-size:12px;font-family:Lato,sans-serif;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.sidebar-logout-btn:hover{color:var(--red);border-color:#e0555573;background:#e055550f}.chapter-item{padding:10px;border-radius:8px;cursor:pointer;margin-bottom:1px;transition:background .12s;display:flex;align-items:flex-start;gap:10px;position:relative}.chapter-item:hover{background:var(--bg3)}.chapter-item.active{background:var(--bg4);border-left:2px solid var(--gold);padding-left:8px}.chapter-item.active .chapter-title{color:var(--gold)}.chapter-num{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text3);min-width:20px;padding-top:2px}.chapter-info{flex:1;min-width:0}.chapter-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:2px;line-height:1.3}.chapter-tag{font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace}.chapter-status{display:flex;align-items:center;gap:5px;margin-top:4px}.status-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.status-text{font-size:10px;color:var(--text3)}.progress-mini{position:absolute;bottom:4px;left:38px;right:10px;height:2px;background:var(--border);border-radius:2px;overflow:hidden}.progress-mini div{height:100%;background:var(--gold);border-radius:2px}.reader{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.reader-top{padding:18px 28px 0;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.reader-top-empty{padding:14px 28px;border-bottom:1px solid var(--border);flex-shrink:0}.reader-top-empty-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;width:100%}.admin-library-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-tool-btn{font-size:12px;padding:7px 12px}.admin-tool-hint{font-size:11px;color:var(--text3);font-family:JetBrains Mono,monospace}.breadcrumb{font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace;letter-spacing:1px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.user-badge,.user-badge-top{font-size:11px;color:var(--text3);cursor:pointer;padding:3px 8px;border:1px solid var(--border);border-radius:20px;transition:all .15s;font-family:JetBrains Mono,monospace}.user-badge:hover,.user-badge-top:hover{color:var(--red);border-color:#e0555566}.chapter-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-bottom:18px}.chapter-meta{flex:1}.ch-num{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}.ch-title{font-family:Playfair Display,serif;font-size:24px;font-weight:700;color:var(--text);line-height:1.2;margin-bottom:6px}.ch-desc{font-size:13px;color:var(--text2);line-height:1.6;max-width:520px}.chapter-actions{display:flex;flex-direction:column;align-items:flex-end;gap:6px;padding-top:4px;flex-shrink:0}.btn{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--bg3);color:var(--text2);font-size:12px;font-family:Lato,sans-serif;cursor:pointer;transition:all .15s;white-space:nowrap}.btn:hover:not(:disabled){border-color:var(--gold-dim);color:var(--gold)}.btn.primary{background:var(--gold);border-color:var(--gold);color:var(--bg);font-weight:700}.btn.primary:hover:not(:disabled){background:var(--gold2)}.btn:disabled{opacity:.45;cursor:not-allowed}.inline-error{font-size:11px;color:var(--red);max-width:180px;text-align:right}.admin-only-hint{font-size:11px;color:var(--text3);max-width:220px;text-align:right;line-height:1.45}.player-bar{padding:10px 28px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;flex-shrink:0}.play-btn{width:36px;height:36px;border-radius:50%;background:var(--gold);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;flex-shrink:0;color:var(--bg)}.play-btn:hover:not(:disabled){background:var(--gold2);transform:scale(1.06)}.play-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.stop-btn{width:30px;height:30px;border-radius:50%;background:transparent;border:1px solid var(--border2);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:all .12s;flex-shrink:0}.stop-btn:hover{border-color:var(--red);color:var(--red)}.progress-section{flex:1}.progress-bar{height:3px;background:var(--border2);border-radius:3px;overflow:hidden;margin-bottom:5px}.progress-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .4s linear}.progress-info{display:flex;justify-content:space-between}.progress-text{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text3)}.speed-btn{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text2);border:1px solid var(--border2);background:var(--bg3);padding:4px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .12s;flex-shrink:0}.speed-btn:hover:not(:disabled){color:var(--gold);border-color:var(--gold-dim)}.speed-btn:disabled{opacity:.4;cursor:not-allowed}.content-area{flex:1;overflow-y:auto;padding:28px 32px;min-height:0}.content-area::-webkit-scrollbar{width:3px}.content-area::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.content-area--book-reader{padding:0;overflow:hidden;display:flex;flex-direction:column}.welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px}.welcome-icon{width:60px;height:60px;background:var(--gold-bg);border:1px solid var(--gold-dim);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--gold)}.welcome-title{font-family:Playfair Display,serif;font-size:22px;color:var(--text);margin-bottom:10px}.welcome-sub{font-size:14px;color:var(--text2);line-height:1.7;max-width:380px}.empty-chapter{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 40px}.empty-icon{font-size:36px;margin-bottom:16px}.empty-chapter h3{font-family:Playfair Display,serif;font-size:20px;color:var(--text);margin-bottom:10px}.empty-chapter p{font-size:13px;color:var(--text2);max-width:380px;line-height:1.6;margin-bottom:8px}.empty-hint{font-size:12px;color:var(--text3)!important;font-family:JetBrains Mono,monospace}.book-content{max-width:700px;margin:0 auto}.stats-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}.book-text{font-size:15px;line-height:1.9;color:var(--text2)}.book-text p{margin-bottom:16px}.book-text h2{font-family:Playfair Display,serif;font-size:20px;color:var(--text);font-weight:500;margin:28px 0 12px;border-left:3px solid var(--gold);padding-left:12px}.book-text h3{font-size:11px;font-weight:400;color:var(--gold);margin:20px 0 8px;font-family:JetBrains Mono,monospace;letter-spacing:2px;text-transform:uppercase}.book-text strong{color:var(--text);font-weight:700}.book-text .highlight{background:var(--gold-bg);border-left:3px solid var(--gold);padding:12px 16px;border-radius:0 8px 8px 0;margin:20px 0;font-style:italic;color:var(--text);font-size:14px}.book-text .rule-box{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:14px 18px;margin:20px 0}.book-text .rule-title{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}.book-text .rule-body{font-size:13px;color:var(--text2);line-height:1.6}.cursor-blink{display:inline-block;width:2px;height:15px;background:var(--gold);animation:blink .8s infinite;vertical-align:middle;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(ellipse at 20% 50%,rgba(201,168,76,.04) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(201,168,76,.03) 0%,transparent 50%)}.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:36px 40px;width:100%;max-width:400px}.login-card-wide{max-width:420px}.login-tabs{display:flex;gap:0;margin-bottom:22px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border2)}.login-tab{flex:1;padding:10px 12px;background:var(--bg3);border:none;color:var(--text3);font-size:12px;font-family:JetBrains Mono,monospace;cursor:pointer;transition:background .15s,color .15s}.login-tab:hover{color:var(--text2);background:var(--bg4)}.login-tab.active{background:var(--gold-bg);color:var(--gold);font-weight:700}.login-divider{display:flex;align-items:center;gap:12px;margin:22px 0 18px;color:var(--text3);font-size:11px;font-family:JetBrains Mono,monospace}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border2)}.google-wrap{display:flex;justify-content:center;margin-bottom:8px}.google-wrap>div{width:100%!important;max-width:320px}.google-wrap iframe{width:100%!important}.btn-google{display:inline-flex;align-items:center;justify-content:center;width:100%;max-width:320px;min-height:44px;padding:0 16px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text2);font-size:14px;font-weight:700;font-family:Lato,sans-serif;text-decoration:none;transition:border-color .15s,color .15s}.btn-google:hover{border-color:var(--gold-dim);color:var(--gold)}.login-hint{font-size:11px;color:var(--text3);line-height:1.5;margin-top:16px;text-align:center}.login-code{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--gold);background:var(--bg3);padding:2px 6px;border-radius:4px}.sidebar-nav{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.sidebar-nav-btn{flex:1 1 calc(33.33% - 4px);min-width:72px;padding:8px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--bg3);color:var(--text3);font-size:11px;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.sidebar-nav-btn:hover{color:var(--text2);border-color:var(--border)}.sidebar-nav-btn.active{background:var(--gold-bg);border-color:var(--gold-dim);color:var(--gold);font-weight:700}.btn-add-chapter{width:100%;margin-top:10px;padding:8px 12px;border-radius:var(--radius-sm);border:1px dashed var(--gold-dim);background:var(--gold-bg);color:var(--gold);font-size:11px;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:border-color .15s,background .15s}.btn-add-chapter:hover{border-color:var(--gold);background:#c9a84c1f}.btn-generate-batch{width:100%;margin-top:8px;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--bg3);color:var(--text2);font-size:11px;font-family:JetBrains Mono,monospace;letter-spacing:.3px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.btn-generate-batch:hover:not(:disabled){border-color:var(--gold-dim);color:var(--gold);background:var(--bg4)}.btn-generate-batch:disabled{opacity:.45;cursor:not-allowed}.sidebar.sidebar--batch-lock .chapters-list{pointer-events:none;opacity:.55}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#050608bf;display:flex;align-items:center;justify-content:center;padding:24px}.modal-panel{width:100%;max-width:440px;max-height:90vh;overflow-y:auto;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:0 24px 48px #00000073}.modal-panel--simple{max-width:480px}.modal-panel--wide{max-width:560px}.modal-panel--user-edit{max-width:640px}.edit-user-social-legend{margin:16px 0 0;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-family:JetBrains Mono,monospace;color:var(--gold)}.edit-user-social-grid{margin-bottom:4px}.modal-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 520px){.modal-form-grid{grid-template-columns:1fr}}.form-row--checkbox label{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text2);line-height:1.45;text-transform:none;letter-spacing:0;font-family:Lato,sans-serif}.form-row--checkbox input{width:auto;margin-top:3px}.admin-chapters-page{max-width:900px;margin:0 auto;padding-bottom:48px}.admin-chapters-hero{margin-bottom:20px}.admin-chapters-title{font-family:Playfair Display,serif;font-size:22px;color:var(--gold);margin-bottom:8px}.admin-chapters-lead{font-size:13px;color:var(--text2);line-height:1.55;margin-bottom:12px;max-width:640px}.admin-chapters-refresh{font-size:12px;padding:6px 12px}.admin-chapters-err{margin-bottom:14px;text-align:left}.admin-chapters-table-wrap{overflow-x:auto;border:1px solid var(--border2);border-radius:var(--radius);background:var(--bg3)}.admin-chapters-table{width:100%;border-collapse:collapse;font-size:12px}.admin-chapters-table th{text-align:left;padding:10px 12px;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border2);background:var(--bg2)}.admin-chapters-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle}.admin-chapters-table tr:last-child td{border-bottom:none}.admin-chapters-table .td-num{font-family:JetBrains Mono,monospace;color:var(--text3);white-space:nowrap}.admin-chapters-table .td-title{color:var(--text);font-weight:600;max-width:220px}.admin-chapters-table .td-tag{font-size:11px;color:var(--text3)}.admin-chapters-table .td-order{font-family:JetBrains Mono,monospace;font-size:11px}.admin-chapters-table .td-state{white-space:nowrap}.admin-chapters-table .td-actions{text-align:right;white-space:nowrap}.admin-chapters-table .td-actions .btn{margin-left:6px}.badge-ok{font-size:10px;color:var(--green);font-family:JetBrains Mono,monospace}.badge-warn{font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace}.badge-unpub{font-size:10px;color:var(--gold);font-family:JetBrains Mono,monospace}.btn-sm{padding:5px 10px;font-size:11px}.btn-danger-outline{border-color:#e0555573;color:var(--red)}.btn-danger-outline:hover:not(:disabled){border-color:var(--red);background:#e0555514}.admin-chapters-empty{padding:20px;text-align:center}.modal-lead{margin:0;padding:12px 20px 14px;font-size:13px;color:var(--text2);line-height:1.55;border-bottom:1px solid var(--border)}.modal-auto-hint{margin:12px 20px 0;padding:10px 12px;font-size:12px;color:var(--gold);line-height:1.45;background:var(--gold-bg);border:1px solid var(--gold-dim);border-radius:var(--radius-sm)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px;border-bottom:1px solid var(--border)}.modal-head h2{font-family:Playfair Display,serif;font-size:20px;color:var(--gold);font-weight:600}.modal-close{width:32px;height:32px;border:none;background:transparent;color:var(--text3);font-size:22px;line-height:1;cursor:pointer;border-radius:var(--radius-sm)}.modal-close:hover{color:var(--text);background:var(--bg3)}.modal-form{padding:16px 20px 22px;display:flex;flex-direction:column;gap:12px}.modal-form .form-row{display:flex;flex-direction:column;gap:5px}.modal-form .form-row label{font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace;letter-spacing:.5px;text-transform:uppercase}.modal-form .form-row input,.modal-form .form-row textarea{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:9px 12px;color:var(--text);font-size:13px;font-family:Lato,sans-serif;outline:none}.modal-form .form-row textarea{resize:vertical;min-height:88px;line-height:1.5}.modal-form .form-row input:focus,.modal-form .form-row textarea:focus{border-color:var(--gold-dim)}.modal-form .form-row select{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:9px 12px;color:var(--text);font-size:13px;font-family:Lato,sans-serif;outline:none;cursor:pointer}.modal-form .form-row select:focus{border-color:var(--gold-dim)}.modal-form .form-row-checkbox label{flex-direction:row;align-items:center;gap:10px;cursor:pointer;font-size:13px;color:var(--text2)}.modal-form .form-row-checkbox input{width:auto;accent-color:var(--gold)}.modal-err{margin-top:4px}.modal-err{text-align:left}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px;padding-top:4px}.modal-btn-cancel{background:var(--bg3)}.modal-btn-ok{min-width:120px}.sidebar-indicators-hint{padding:12px 18px 18px;flex:1;overflow-y:auto}.sidebar-indicators-hint-title{font-size:10px;letter-spacing:2px;color:var(--gold);font-family:JetBrains Mono,monospace;text-transform:uppercase;margin-bottom:8px}.sidebar-indicators-hint-text{font-size:12px;color:var(--text3);line-height:1.55}.inline-code{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--gold);background:var(--bg3);padding:1px 5px;border-radius:3px}.indicators-page{max-width:640px;margin:0 auto;padding-bottom:40px}.indicators-page--wide{max-width:1120px}.indicators-page--wide .indicators-hero,.indicators-page--wide .indicators-form{max-width:640px}.books-section-wrap{max-width:1100px}.indicators-hero{margin-bottom:28px}.indicators-title{font-family:Playfair Display,serif;font-size:22px;color:var(--gold);margin-bottom:12px}.indicators-lead{font-size:14px;color:var(--text2);line-height:1.65}.indicators-lead a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}.indicators-lead a:hover{color:var(--gold2)}.indicators-form{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}.indicators-form .form-group label{font-size:11px;color:var(--text3);font-family:JetBrains Mono,monospace;letter-spacing:1px;text-transform:uppercase}.indicators-form .form-group input{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:13px;font-family:JetBrains Mono,monospace;outline:none}.indicators-form .form-group input:not([type=checkbox]):not([type=radio]){width:100%}.indicators-form .form-group input:focus{border-color:var(--gold-dim)}.indicators-preview{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:14px 16px}.preview-title{font-size:10px;letter-spacing:2px;color:var(--gold);font-family:JetBrains Mono,monospace;text-transform:uppercase;margin-bottom:10px}.preview-list{list-style:none;font-size:12px;color:var(--text2);line-height:1.7}.preview-list li{margin-bottom:4px}.preview-list .k{color:var(--text3);font-family:JetBrains Mono,monospace;font-size:10px;margin-right:8px}.preview-list code{font-size:11px;color:var(--text);background:var(--bg);padding:2px 6px;border-radius:4px}.preview-list a{color:var(--gold);word-break:break-all}.indicators-preview-err{margin-top:0}.form-success{font-size:12px;color:var(--green);text-align:center;padding:8px;background:#3dba7e14;border-radius:var(--radius-sm);border:1px solid rgba(61,186,126,.25)}.profile-page .profile-form{max-width:560px}.profile-password-form{margin-top:4px}.profile-oauth-only-hint{margin-top:4px;margin-bottom:0}.profile-fieldset{margin:0;padding:16px 18px 18px;border:1px solid var(--border2);border-radius:var(--radius);background:var(--bg3)}.profile-fieldset+.profile-fieldset{margin-top:6px}.profile-legend{padding:0 8px;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-family:JetBrains Mono,monospace;color:var(--gold)}.profile-readonly-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 14px;padding:10px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm)}.profile-readonly-label{font-size:10px;letter-spacing:1px;text-transform:uppercase;font-family:JetBrains Mono,monospace;color:var(--text3);min-width:72px}.profile-readonly-value{font-size:13px;color:var(--text);font-family:JetBrains Mono,monospace;word-break:break-all}.profile-social-hint{font-size:12px;color:var(--text3);line-height:1.5;margin:-4px 0 10px}.profile-social-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}@media (max-width: 600px){.profile-social-grid{grid-template-columns:1fr}}.indicators-form.profile-form .form-group select{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:13px;font-family:JetBrains Mono,monospace;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.indicators-form.profile-form .form-group select:focus{border-color:var(--gold-dim)}.indicators-list-wrap{border-top:1px solid var(--border);padding-top:24px}.indicators-list-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px}.indicators-list-title{font-size:11px;letter-spacing:2px;color:var(--text3);font-family:JetBrains Mono,monospace;text-transform:uppercase;margin-bottom:0}.indicators-list-header--books{align-items:center}.books-list-header-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.books-btn-add{flex-shrink:0}.books-scope-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.books-scope-tab{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--bg3);color:var(--text2);cursor:pointer;transition:border-color .12s,color .12s,background .12s}.books-scope-tab:hover{border-color:var(--gold-dim);color:var(--text)}.books-scope-tab--active{border-color:var(--gold-dim);background:var(--gold-bg);color:var(--gold)}.books-private-badge{display:inline-block;font-size:9px;letter-spacing:1px;text-transform:uppercase;font-family:JetBrains Mono,monospace;padding:2px 6px;border-radius:4px;border:1px solid var(--gold-dim);color:var(--gold2);background:var(--gold-bg);flex-shrink:0;vertical-align:middle}.books-private-badge--inline{margin-left:6px;font-size:9px}.books-private-option-wrap{margin-bottom:0}.books-private-option-legend{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);font-family:JetBrains Mono,monospace;margin:0 0 8px}.books-private-option{border:1px solid var(--border2);border-radius:var(--radius);background:var(--bg3);box-shadow:inset 0 1px #ffffff0a;width:100%;max-width:100%;box-sizing:border-box}.books-private-option-label{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;margin:0;cursor:pointer;border-radius:var(--radius);transition:background .12s ease;width:100%;max-width:100%;box-sizing:border-box;font-size:inherit;font-family:inherit;letter-spacing:normal;text-transform:none;color:inherit}.books-private-option-label:hover{background:var(--bg4)}.books-private-option:focus-within{border-color:var(--gold-dim);box-shadow:0 0 0 1px var(--gold-dim)}.books-private-checkbox{width:22px!important;height:22px;min-width:22px;max-width:22px;margin:2px 0 0;flex:0 0 22px;flex-shrink:0;cursor:pointer;accent-color:var(--gold);padding:0;box-sizing:border-box}.books-private-option-body{display:flex;flex-direction:column;gap:8px;flex:1 1 auto;min-width:0;max-width:100%}.books-private-option-title{font-family:Playfair Display,Georgia,serif;font-size:17px;font-weight:700;color:var(--gold);line-height:1.25}.books-private-option-desc{font-size:14px;line-height:1.55;color:var(--text);margin:0}.books-grid-card--private{border-color:#7a623073}.books-add-form-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}.books-add-form-title{font-size:15px;font-family:Playfair Display,serif;color:var(--gold);margin:0}.books-add-form-close{font-size:12px}.books-inline-msg{margin:0 0 18px}.books-filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:16px 24px;margin-bottom:16px}.books-filter-search{flex:1;min-width:200px;margin-bottom:0}.books-search-input{width:100%;box-sizing:border-box;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:13px;font-family:Lato,sans-serif;outline:none}.books-search-input:focus{border-color:var(--gold-dim)}.books-filter-sort{margin-bottom:0;min-width:200px}.books-filter-sort label{display:block;font-size:11px;letter-spacing:1px;color:var(--text3);font-family:JetBrains Mono,monospace;text-transform:uppercase;margin-bottom:6px}.books-sort-select{width:100%;max-width:280px;box-sizing:border-box;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:13px;font-family:Lato,sans-serif;outline:none;cursor:pointer}.books-sort-select:focus{border-color:var(--gold-dim)}.list-header-tools--below{margin-bottom:14px}.indicators-list-wrap>.muted,.indicators-list-wrap>.form-error{margin-bottom:0}.view-mode-toggle{display:inline-flex;border:1px solid var(--border2);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg3)}.view-mode-btn{padding:8px 16px;font-size:12px;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.5px;border:none;background:transparent;color:var(--text3);cursor:pointer;transition:background .12s,color .12s}.view-mode-btn:hover{color:var(--text);background:var(--bg4)}.view-mode-btn.active{background:var(--gold-bg);color:var(--gold);font-weight:700}.view-mode-btn+.view-mode-btn{border-left:1px solid var(--border2)}.list-header-tools{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.grid-cols-control{display:flex;align-items:center;gap:8px}.grid-cols-label{font-size:11px;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);white-space:nowrap}.grid-cols-select{min-width:52px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-family:JetBrains Mono,monospace;padding:7px 10px;cursor:pointer;outline:none}.grid-cols-select:hover:not(:disabled){border-color:var(--gold-dim)}.grid-cols-select:focus{border-color:var(--gold)}.grid-cols-select:disabled{opacity:.45;cursor:not-allowed}.data-table-scroll{overflow-x:auto;border:1px solid var(--border2);border-radius:var(--radius);background:var(--bg3)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-th{text-align:left;padding:10px 12px;font-size:10px;letter-spacing:1px;text-transform:uppercase;font-family:JetBrains Mono,monospace;color:var(--text3);background:var(--bg2);border-bottom:1px solid var(--border2);white-space:nowrap}.data-th-thumb{width:72px}.data-th-wide{min-width:200px}.data-th-actions{width:1%}.data-tr{border-bottom:1px solid var(--border)}.data-tr:last-child{border-bottom:none}.data-tr:hover{background:#c9a84c0a}.data-td{padding:10px 12px;color:var(--text2);vertical-align:middle}.data-td-mono{font-family:JetBrains Mono,monospace;font-size:12px}.data-td-thumb{width:72px;padding:8px}.data-table-thumb{width:56px;height:32px;object-fit:cover;border-radius:4px;display:block;border:1px solid var(--border)}.data-table-thumb-ph{color:var(--text3);font-size:12px}.data-table-code{font-size:11px;color:var(--gold);background:var(--bg);padding:2px 6px;border-radius:4px}.data-td-clamp{max-width:320px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.data-td-actions{white-space:nowrap}.data-table-link{color:var(--gold);font-weight:600;text-decoration:none;margin-right:10px}.data-table-link:hover{text-decoration:underline}.data-table-del{background:transparent;border:1px solid var(--border2);color:var(--text3);font-size:11px;font-family:JetBrains Mono,monospace;padding:4px 10px;border-radius:4px;cursor:pointer}.data-table-del:hover{color:var(--red);border-color:#e0555559}.pill-own,.pill-cat{font-size:10px;font-family:JetBrains Mono,monospace;text-transform:uppercase;padding:3px 8px;border-radius:20px;display:inline-block}.pill-own{background:#3dba7e1f;color:var(--green);border:1px solid rgba(61,186,126,.3)}.pill-cat{background:var(--bg2);color:var(--text3);border:1px solid var(--border2)}.indicators-grid{list-style:none;display:grid;gap:20px;align-items:stretch;grid-template-columns:repeat(3,minmax(0,1fr))}.indicators-grid[data-cols="1"]{grid-template-columns:repeat(1,minmax(0,1fr))}.indicators-grid[data-cols="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}.indicators-grid[data-cols="3"]{grid-template-columns:repeat(3,minmax(0,1fr))}.indicators-grid[data-cols="4"]{grid-template-columns:repeat(4,minmax(0,1fr))}.indicators-grid[data-cols="5"]{grid-template-columns:repeat(5,minmax(0,1fr))}.indicators-grid[data-cols="6"]{grid-template-columns:repeat(6,minmax(0,1fr))}@media (max-width: 640px){.indicators-grid[data-cols]{grid-template-columns:1fr}}.indicators-grid-card{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;min-width:0;transition:border-color .15s}.indicators-grid-card:hover{border-color:var(--gold-dim)}.indicators-grid-thumb-wrap{position:relative;aspect-ratio:16 / 9;background:var(--bg2);border-bottom:1px solid var(--border2)}.indicators-grid-thumb-overlay{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:32px 12px 12px;background:linear-gradient(to top,rgba(13,15,18,.92) 0%,rgba(13,15,18,.5) 55%,transparent 100%);pointer-events:none}.indicators-grid-overlay-title{margin:0;font-size:14px;font-weight:700;line-height:1.3;color:var(--text);font-family:Lato,sans-serif;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 3px rgba(0,0,0,.85)}.indicators-grid-thumb{width:100%;height:100%;object-fit:cover;display:block}.indicators-grid-thumb-placeholder{display:none;position:absolute;top:0;right:0;bottom:0;left:0;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--bg2),var(--bg4));color:var(--text3);font-family:JetBrains Mono,monospace;font-size:13px;letter-spacing:3px}.indicators-grid-thumb-placeholder.is-visible{display:flex}.indicators-grid-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px;flex:1;min-width:0}.indicators-grid-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.indicators-grid-badge{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.indicators-grid-card-title{margin:0;font-size:15px;font-weight:700;line-height:1.35;color:var(--text);font-family:Lato,sans-serif;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.indicators-grid-desc{font-size:12px;color:var(--text2);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;flex:1}.indicators-grid-link{font-size:13px;font-weight:700;color:var(--gold);text-decoration:none;margin-top:auto}.indicators-grid-link:hover{color:var(--gold2);text-decoration:underline;text-underline-offset:3px}.indicators-grid-meta{font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace;word-break:break-all}.muted{color:var(--text3);font-size:13px}.indicators-list{list-style:none;display:flex;flex-direction:column;gap:12px}.indicators-card{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:0;overflow:hidden}.indicators-thumb-wrap{width:100%;aspect-ratio:16 / 9;background:var(--bg2);border-bottom:1px solid var(--border2)}.indicators-thumb{width:100%;height:100%;object-fit:cover;display:block}.indicators-card .indicators-card-head,.indicators-card .indicators-card-title,.indicators-card .indicators-link,.indicators-card .indicators-meta{padding-left:16px;padding-right:16px}.indicators-card .indicators-card-head{padding-top:14px}.indicators-card .indicators-meta{padding-bottom:16px}.indicators-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.script-badge{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--gold);background:var(--gold-bg);padding:4px 10px;border-radius:20px;border:1px solid var(--gold-dim)}.indicators-catalog-badge{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--text3);background:var(--bg2);padding:4px 10px;border-radius:20px;border:1px solid var(--border2);flex-shrink:0}.btn-icon-del{width:28px;height:28px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--text3);font-size:18px;line-height:1;cursor:pointer;transition:color .15s,border-color .15s}.btn-icon-del:hover{color:var(--red);border-color:#e0555566}.indicators-card-title{font-size:14px;color:var(--text);margin-bottom:8px;font-weight:700;padding-top:4px}.indicators-desc{font-size:12px;color:var(--text2);line-height:1.55;margin-bottom:10px;padding-left:16px;padding-right:16px;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.indicators-link{font-size:13px;color:var(--gold);display:inline-block;margin-bottom:8px;padding-top:2px}.indicators-link:hover{text-decoration:underline}.indicators-meta{font-size:11px;color:var(--text3);font-family:JetBrains Mono,monospace}.indicators-form .form-group .books-textarea{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:13px;font-family:Lato,sans-serif;line-height:1.5;outline:none;resize:vertical;min-height:100px}.indicators-form .form-group .books-textarea:focus{border-color:var(--gold-dim)}.books-file-input{width:100%;font-size:12px;color:var(--text2);font-family:Lato,sans-serif}.books-file-input::file-selector-button{margin-right:12px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--gold-dim);background:var(--gold-bg);color:var(--gold);font-family:JetBrains Mono,monospace;font-size:11px;cursor:pointer}.books-file-input::file-selector-button:hover{background:#c9a84c26}.books-file-hint{margin:6px 0 0;font-size:12px;color:var(--text3);line-height:1.45}.books-card-head{padding-top:14px;padding-left:16px;padding-right:16px}.books-file-badge{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.books-desc{-webkit-line-clamp:8}.books-load-err{margin-bottom:14px;text-align:left}.books-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px 20px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.books-page-spacer{width:100px;flex-shrink:0;visibility:hidden;pointer-events:none}.books-page-btn{min-width:100px;flex-shrink:0}.books-page-btn:disabled{opacity:.4;cursor:not-allowed}.books-page-info{font-size:12px;color:var(--text3);font-family:JetBrains Mono,monospace;text-align:center;flex:1 1 220px;max-width:360px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.books-grid{display:grid;gap:22px;align-items:stretch;grid-template-columns:repeat(3,minmax(0,1fr))}.books-grid[data-cols="1"]{grid-template-columns:repeat(1,minmax(0,1fr))}.books-grid[data-cols="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}.books-grid[data-cols="3"]{grid-template-columns:repeat(3,minmax(0,1fr))}.books-grid[data-cols="4"]{grid-template-columns:repeat(4,minmax(0,1fr))}.books-grid[data-cols="5"]{grid-template-columns:repeat(5,minmax(0,1fr))}.books-grid[data-cols="6"]{grid-template-columns:repeat(6,minmax(0,1fr))}@media (max-width: 640px){.books-grid[data-cols]{grid-template-columns:1fr}}.books-grid-card{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:12px;min-width:0;transition:border-color .15s}.books-grid-card:hover{border-color:var(--gold-dim)}.books-grid-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.books-grid-card-tools{display:flex;align-items:flex-start;gap:4px;flex-shrink:0}.books-fav-btn{width:36px;height:36px;padding:0;border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text3);font-size:18px;line-height:1;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.books-fav-btn:hover{border-color:var(--gold-dim);color:var(--gold2)}.books-fav-btn--on{color:var(--gold);border-color:var(--gold-dim);background:var(--gold-bg)}.books-fav-btn--table{width:34px;height:34px;font-size:16px}.data-th-narrow,.data-td-narrow{width:48px;text-align:center;vertical-align:middle}.books-grid-title{font-family:Playfair Display,serif;font-size:17px;font-weight:700;color:var(--gold);line-height:1.3;margin:0;flex:1;min-width:0;max-width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px}.books-grid-title-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 60%}.books-grid-del{flex-shrink:0}.books-grid-cover-wrap{border-radius:var(--radius-sm);overflow:hidden;background:var(--bg2);border:1px solid var(--border);aspect-ratio:3 / 4;display:flex;align-items:center;justify-content:center}.books-grid-cover-img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}.books-grid-cover--placeholder{aspect-ratio:3 / 4;border-radius:var(--radius-sm);border:1px dashed var(--border2);background:linear-gradient(160deg,var(--bg2) 0%,var(--bg4) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text3)}.books-grid-cover-icon{font-size:36px;opacity:.5}.books-grid-cover-hint{font-size:11px;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:1px}.books-grid-desc{font-size:13px;color:var(--text2);line-height:1.55;margin:0;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden;flex:1}.books-grid-author{margin:0;display:flex;flex-direction:column;gap:2px;font-size:12px}.books-grid-author-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);font-family:JetBrains Mono,monospace}.books-grid-author-name{color:var(--text);font-weight:600}.books-grid-download{font-size:13px;font-weight:700;color:var(--gold);text-decoration:none;margin-top:auto}.books-grid-download:hover{color:var(--gold2);text-decoration:underline;text-underline-offset:3px}.books-grid-actions{display:flex;flex-direction:column;gap:6px;margin-top:auto;padding-top:8px}.books-grid-read{font-size:13px;font-weight:700;font-family:Lato,sans-serif;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--gold-dim);background:var(--gold-bg);color:var(--gold);cursor:pointer;transition:border-color .15s,background .15s}.books-grid-read:hover{border-color:var(--gold);background:#c9a84c1f}.books-table-read{display:inline-block;margin-right:8px;margin-bottom:4px;padding:0;border:none;background:none;cursor:pointer;font-size:inherit;font-family:inherit;color:var(--gold);text-decoration:underline;text-underline-offset:2px}.books-table-read:hover{color:var(--gold2)}.book-reader-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#050608d1;display:flex;align-items:center;justify-content:center;padding:16px}.book-reader-view{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--bg)}.book-reader-view__top{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg2)}.book-reader-back-lib{font-size:13px;padding:8px 12px}.book-reader-view__top-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.book-reader-fs-btn{font-size:12px;padding:8px 12px}.book-reader-fs-exit{flex-shrink:0;font-size:12px;padding:8px 12px}.book-reader-view__panel{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.book-reader-panel--page{max-width:none;max-height:none;width:100%;flex:1;min-height:0;border-radius:0;box-shadow:none;border:none}.book-reader-panel--page .book-reader-body{max-height:none;flex:1;min-height:0}.book-reader-panel--page.book-reader-panel--stub{flex:0 1 auto;max-width:520px;width:calc(100% - 32px);margin:20px auto 28px;border:1px solid var(--border2);border-radius:var(--radius);box-shadow:0 16px 48px #0006}.book-reader-panel--page:fullscreen,.book-reader-panel--page:-webkit-full-screen{width:100%;height:100%;max-height:none;background:#090a0c;border-radius:0}.book-reader-panel--fs-active .book-reader-canvas-wrap{background:#0f1116}.book-reader-panel{width:100%;max-width:1200px;max-height:92vh;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:0 24px 64px #00000080;display:flex;flex-direction:column;overflow:hidden}.book-reader-panel--stub{max-width:480px;padding:0 0 20px}.book-reader-stub-text{padding:0 22px;font-size:14px;color:var(--text2);line-height:1.6;margin:0 0 16px}.book-reader-stub-actions{display:flex;flex-wrap:wrap;gap:10px;padding:0 22px}.book-reader-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.book-reader-head-text{min-width:0}.book-reader-title{font-family:Playfair Display,serif;font-size:18px;color:var(--gold);margin:0 0 6px;line-height:1.25}.book-reader-meta{margin:0;font-size:12px;color:var(--text3);font-family:JetBrains Mono,monospace;display:flex;flex-wrap:nowrap;align-items:center;gap:6px;min-width:0}.book-reader-meta-page{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.book-reader-meta-sep{flex-shrink:0;opacity:.75}.book-reader-read-stat{flex-shrink:0;color:var(--text2)}.book-reader-close{flex-shrink:0;width:36px;height:36px;border:none;border-radius:var(--radius-sm);background:var(--bg3);color:var(--text2);font-size:22px;line-height:1;cursor:pointer}.book-reader-close:hover{color:var(--text);background:var(--bg4)}.book-reader-load-panel{margin:20px 22px 24px;padding:20px 22px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);max-width:520px}.book-reader-load-title{margin:0 0 8px;font-size:15px;font-weight:700;color:var(--text)}.book-reader-load-sub{margin:0 0 14px;font-size:13px}.book-reader-load-bytes{margin:0 0 12px;font-size:12px;font-family:JetBrains Mono,monospace}.book-reader-load-panel .book-reader-progress{height:10px;border-radius:6px;background:var(--bg);border:1px solid var(--border2);overflow:hidden}.book-reader-load-panel .book-reader-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold));border-radius:5px;transition:width .2s ease-out}.book-reader-load-panel .book-reader-progress--indeterminate{position:relative;overflow:hidden}.book-reader-load-panel .book-reader-progress-indeterminate-fill{position:absolute;left:-40%;top:0;width:40%;height:100%;background:linear-gradient(90deg,transparent,var(--gold),transparent);animation:book-reader-progress-scan 1.2s ease-in-out infinite}@keyframes book-reader-progress-scan{0%{transform:translate(0)}to{transform:translate(350%)}}.book-reader-loading,.book-reader-err{margin:16px 18px}.book-reader-body{display:flex;min-height:0;flex:1;max-height:calc(92vh - 120px)}.book-reader-sidebar{width:112px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0;background:var(--bg3);color-scheme:dark}.book-reader-sidebar-head{padding:10px 12px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);font-family:JetBrains Mono,monospace;border-bottom:1px solid var(--border)}.book-reader-page-list{overflow-y:auto;padding:6px;flex:1;min-height:0;color-scheme:dark;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.book-reader-page-list::-webkit-scrollbar{width:6px}.book-reader-page-list::-webkit-scrollbar-track{background:transparent}.book-reader-page-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}.book-reader-page-list::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}.book-reader-page-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;margin-bottom:2px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--text2);font-size:12px;font-family:JetBrains Mono,monospace;cursor:pointer;text-align:left}.book-reader-page-btn:hover{background:var(--bg4);color:var(--text)}.book-reader-page-btn.is-current{border-color:var(--gold-dim);background:var(--gold-bg);color:var(--gold);font-weight:700}.book-reader-page-btn.is-read:not(.is-current){color:var(--text)}.book-reader-page-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;border:1px solid var(--border2);background:var(--bg)}.book-reader-page-dot.read{background:var(--green);border-color:#3dba7e80}.book-reader-page-num{flex:1;min-width:0}.book-reader-page-note-ico{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;opacity:.85}.book-reader-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;padding:12px 14px 16px;color-scheme:dark;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.book-reader-main::-webkit-scrollbar{width:6px}.book-reader-main::-webkit-scrollbar-track{background:transparent}.book-reader-main::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}.book-reader-main::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}.book-reader-canvas-wrap{overflow:auto;text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;color-scheme:dark;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.book-reader-canvas-wrap::-webkit-scrollbar{width:6px;height:6px}.book-reader-canvas-wrap::-webkit-scrollbar-track{background:transparent}.book-reader-canvas-wrap::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}.book-reader-canvas-wrap::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}.book-reader-canvas-inner{display:inline-block;line-height:0;vertical-align:top}.book-reader-canvas{display:block;max-width:none;vertical-align:top}.book-reader-toolbar{display:flex;flex-wrap:nowrap;align-items:center;gap:8px 10px;margin-top:14px;min-width:0;overflow-x:visible;overflow-y:visible}.book-reader-toolbar--with-zoom{align-items:center}.book-reader-page-block,.book-reader-zoom-block{display:contents}.book-reader-page-block-label,.book-reader-zoom-block-label{display:none}.book-reader-zoom-block .book-reader-zoom{order:1}.book-reader-read-toggle{order:3}.book-reader-toolbar-end{order:4;margin-left:auto}.book-reader-zoom{display:flex;flex-wrap:nowrap;align-items:center;gap:6px 8px;flex:0 0 auto;min-width:0}.book-reader-zoom-fit-short{display:none}.book-reader-zoom-fit-full{display:inline}.book-reader-zoom-range{flex:0 1 120px;width:120px;min-width:56px;max-width:160px;height:6px;accent-color:var(--gold);cursor:pointer}.book-reader-zoom-value{font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text2);min-width:42px;text-align:right}.book-reader-zoom-btn{padding:6px 12px;font-size:17px;line-height:1;min-width:38px;flex-shrink:0}.book-reader-zoom-fit{font-size:12px;padding:6px 10px;white-space:nowrap;flex-shrink:0}.book-reader-toolbar>.btn{flex-shrink:0}.book-reader-page-row{order:2;display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;gap:12px;flex-shrink:0;width:auto;max-width:100%;box-sizing:border-box}.book-reader-page-fraction{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--gold);min-width:4.25em;text-align:center;flex-shrink:0;line-height:1.2}.book-reader-nav-btn{flex-shrink:0}.book-reader-nav-short{display:none}.book-reader-nav-full{display:inline}.book-reader-read-toggle{display:inline-flex;flex-wrap:nowrap;align-items:center;gap:8px;font-size:13px;color:var(--text2);cursor:pointer;white-space:nowrap;flex-shrink:0}.book-reader-read-toggle input{accent-color:var(--gold);cursor:pointer;flex-shrink:0}.book-reader-toolbar-end{display:flex;flex-wrap:nowrap;align-items:center;gap:8px 10px;flex-shrink:0}.book-reader-notes-toggle{font-size:12px;padding:6px 12px;white-space:nowrap}.book-reader-dl{font-size:12px;color:var(--text3)}.book-reader-dl:hover{color:var(--gold)}.book-reader-notes{margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}.book-reader-notes-label{display:block;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text3);font-family:JetBrains Mono,monospace;margin-bottom:8px}.book-reader-notes-textarea{width:100%;box-sizing:border-box;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:13px;font-family:Lato,sans-serif;line-height:1.5;resize:vertical;min-height:88px}.book-reader-notes-textarea:focus{outline:none;border-color:var(--gold-dim)}.book-reader-notes-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;gap:12px}@media (max-width: 768px){.book-reader-head{padding:10px 12px;gap:8px;align-items:flex-start}.book-reader-title{font-size:16px;margin:0 0 4px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-reader-head-text{flex:1;min-width:0;max-width:100%}.book-reader-meta{font-size:11px;gap:4px;max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;touch-action:pan-x;scrollbar-width:thin;padding-bottom:4px;margin-bottom:-4px}.book-reader-meta::-webkit-scrollbar{height:4px}.book-reader-meta::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.book-reader-meta-page{flex-shrink:0;overflow:visible;text-overflow:clip;white-space:nowrap}.book-reader-body{flex-direction:column;max-height:none}.book-reader-sidebar{width:100%;max-height:none;flex-shrink:0;border-right:none;border-bottom:1px solid var(--border)}.book-reader-page-list{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;align-content:stretch;gap:4px;flex:0 0 auto;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;touch-action:pan-x;scrollbar-width:thin;padding:8px 10px}.book-reader-page-list::-webkit-scrollbar{width:6px;height:5px}.book-reader-page-list::-webkit-scrollbar-track{background:transparent}.book-reader-page-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.book-reader-page-list::-webkit-scrollbar-thumb:hover{background:var(--gold-dim)}.book-reader-page-btn{width:auto;min-width:72px;flex-shrink:0;margin-bottom:0}.book-reader-toolbar{flex-direction:column;align-items:stretch;flex-wrap:nowrap;overflow-x:visible;gap:10px}.book-reader-page-block,.book-reader-zoom-block{display:flex;flex-direction:column;align-items:stretch;gap:8px;width:100%;box-sizing:border-box;padding:10px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm)}.book-reader-page-block-label,.book-reader-zoom-block-label{display:block;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text3);font-family:JetBrains Mono,monospace}.book-reader-page-row,.book-reader-zoom-block .book-reader-zoom{order:unset}.book-reader-page-row{width:100%;max-width:100%;box-sizing:border-box;justify-content:center;gap:12px;padding:0 2px 4px;margin:0 0 -4px;border:none;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;touch-action:pan-x;scrollbar-width:thin}.book-reader-page-row::-webkit-scrollbar{height:4px}.book-reader-page-row::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.book-reader-nav-full{display:none}.book-reader-nav-short{display:inline;font-size:18px;line-height:1}.book-reader-nav-btn{min-width:48px;min-height:44px;padding:8px 12px;display:inline-flex;align-items:center;justify-content:center}.book-reader-page-fraction{font-size:14px;flex:0 0 auto;min-width:0;max-width:none;white-space:nowrap}.book-reader-zoom{width:100%;max-width:none;flex:1 1 auto;flex-wrap:wrap;row-gap:8px;column-gap:6px}.book-reader-zoom-range{flex:1 1 120px;max-width:none;width:auto;min-width:80px}.book-reader-zoom-fit-short{display:inline}.book-reader-zoom-fit-full{display:none}.book-reader-read-toggle{order:unset;width:100%;max-width:100%;white-space:normal}.book-reader-toolbar-end{order:unset;margin-left:0;width:100%;justify-content:space-between}}.books-grid-file{font-size:10px;color:var(--text3);font-family:JetBrains Mono,monospace;margin:0;word-break:break-all;opacity:.85}.books-table-title{white-space:normal;word-break:break-word;overflow-wrap:anywhere;line-height:1.45;vertical-align:top;max-width:min(360px,40vw);min-width:140px}.admin-users-page .indicators-hero{max-width:720px}.admin-users-err{margin-bottom:16px;max-width:720px}.admin-users-table-wrap{margin-top:8px}.admin-users-table .admin-users-date{white-space:nowrap;font-size:11px}.admin-users-row-inactive{opacity:.55}.admin-users-edit-btn{background:none;border:none;padding:0;cursor:pointer;font:inherit}.admin-users-edit-btn:hover{text-decoration:underline}.admin-pill-admin{border-color:var(--gold-dim)!important;color:var(--gold)!important;background:var(--gold-bg)!important}.admin-pill-user{color:var(--text2)!important}.admin-user-oauth-hint{font-size:12px;color:var(--text3);margin:0 0 8px;padding:8px 10px;background:var(--bg3);border-radius:var(--radius-sm);border:1px solid var(--border2)}.admin-user-self-hint{font-size:12px;color:var(--gold);margin:0;line-height:1.45}.library-empty-banner{max-width:520px;margin:0 auto 24px;padding:16px 18px;background:#e0555514;border:1px solid rgba(224,85,85,.25);border-radius:var(--radius);font-size:13px;color:var(--text2);line-height:1.5}.library-empty-err{margin-top:10px;color:var(--red);font-size:12px}.login-logo{text-align:center;margin-bottom:28px}.logo-icon-lg{width:56px;height:56px;background:#c9a84c1a;border:1px solid var(--gold-dim);border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--gold)}.login-logo h1{font-family:Playfair Display,serif;font-size:26px;color:var(--gold);margin-bottom:4px}.login-logo p{font-size:12px;color:var(--text3);font-family:JetBrains Mono,monospace;letter-spacing:.5px}.login-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:11px;color:var(--text3);font-family:JetBrains Mono,monospace;letter-spacing:1px;text-transform:uppercase}.form-group input,.form-group select{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:9px 12px;color:var(--text);font-size:14px;font-family:Lato,sans-serif;outline:none;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--gold-dim)}.form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-group select option{background:var(--bg3)}.form-error{font-size:12px;color:var(--red);text-align:center;padding:6px;background:#e0555514;border-radius:var(--radius-sm);border:1px solid rgba(224,85,85,.2)}.btn-submit{background:var(--gold);border:none;border-radius:var(--radius-sm);padding:12px;color:var(--bg);font-size:14px;font-weight:700;font-family:Lato,sans-serif;cursor:pointer;transition:all .15s;margin-top:4px}.btn-submit:hover:not(:disabled){background:var(--gold2)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.fullpage-loader{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--bg);color:var(--text2);font-size:13px;font-family:JetBrains Mono,monospace}.loader-dots{display:flex;gap:6px}.loader-dots span{width:8px;height:8px;background:var(--gold);border-radius:50%;animation:bounce 1.2s infinite}.loader-dots span:nth-child(2){animation-delay:.2s}.loader-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}
