*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#070b14;--surface:#0c1524;--surface2:#111e32;--surface3:#172440;--border:#192842;--border2:#243654;--text:#dde4f0;--text-muted:#5a6e90;--text-dim:#8a9bbf;--gold:#c9a227;--gold-hi:#e8c040;--gold-dim:rgba(201,162,39,.12);--gold-border:rgba(201,162,39,.25);--blue:#6ec6f5;--blue-dim:rgba(110,198,245,.1);--blue-border:rgba(110,198,245,.22);--green:#4caf7d;--red:#e05c5c;--amber:#f0a030;--purple:#9b7fe8;--sidebar-w:240px;--mobile-bottom-nav-h: calc(56px + env(safe-area-inset-bottom,0px)) }html,body{height:100%;background:var(--bg);color:var(--text);font-family:Barlow,sans-serif;font-size:14px;overflow:hidden}#root{height:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.starfield{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.star{position:absolute;border-radius:50%;background:#fff;animation:twinkle var(--d,3s) ease-in-out infinite var(--delay,0s)}@keyframes twinkle{0%,to{opacity:var(--min,.1)}50%{opacity:var(--max,.6)}}.app{display:flex;height:100vh;position:relative;z-index:1}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;z-index:20;transition:transform .25s cubic-bezier(.4,0,.2,1)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:linear-gradient(to bottom,#080e1c 0%,var(--bg) 60%)}.content{flex:1;overflow-y:auto;padding:20px 24px}.sb-logo{padding:22px 20px 18px;border-bottom:1px solid var(--border)}.sb-logo h1{font-family:Bebas Neue,sans-serif;font-size:20px;letter-spacing:4px;color:var(--gold);line-height:1}.sb-logo p{font-size:9px;letter-spacing:2.5px;color:var(--text-muted);text-transform:uppercase;margin-top:4px}.sb-nav{padding:14px 0;flex:1}.nav-section-label{padding:5px 18px;font-size:9px;letter-spacing:2px;color:var(--text-muted);text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 18px;cursor:pointer;color:var(--text-dim);font-size:13px;font-weight:500;border-left:2px solid transparent;transition:all .15s;-webkit-user-select:none;user-select:none;white-space:nowrap}button.nav-item{width:100%;background:transparent;border-top:0;border-right:0;border-bottom:0;font-family:inherit;text-align:left}.nav-item .ni-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{color:var(--gold);border-left-color:var(--gold);background:var(--gold-dim)}.nav-item .ni-icon{opacity:.6;flex-shrink:0}.nav-item.active .ni-icon{opacity:1}.nav-badge{margin-left:auto;background:var(--surface3);border:1px solid var(--border2);border-radius:10px;font-size:10px;padding:1px 7px;color:var(--text-muted);font-family:Barlow Condensed,sans-serif}.nav-item.active .nav-badge{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.sb-stats{padding:14px 18px;border-top:1px solid var(--border)}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.stat-label{font-size:11px;color:var(--text-muted)}.stat-val{font-size:13px;font-weight:600;color:var(--text);font-family:Barlow Condensed,sans-serif}.stat-val.gold{color:var(--gold)}.topbar{padding:18px 24px 0;background:linear-gradient(to bottom,#0a1020,transparent)}.topbar-row1{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.page-title{font-family:Bebas Neue,sans-serif;font-size:30px;letter-spacing:4px;color:var(--text);line-height:1;white-space:nowrap;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;min-width:0;margin:0}.hamburger{display:none;background:none;border:none;color:var(--text);cursor:pointer;padding:4px;flex-shrink:0}.search-wrap{position:relative;flex:1 1 200px;max-width:440px;min-width:0}.search-input{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;padding:9px 36px 9px 38px;color:var(--text);font-family:Barlow,sans-serif;font-size:13px;outline:none;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--gold-border);box-shadow:0 0 0 3px #c9a22714}.search-input::placeholder{color:var(--text-muted)}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:15px;line-height:1;padding:2px 4px;opacity:.7}.search-clear:hover{opacity:1;color:var(--text)}.custom-select{position:relative;width:100%}.sort-sel-wrap,.agent-provider-wrap{width:auto}.custom-select-btn{display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left}.custom-select-btn:disabled{cursor:not-allowed}.custom-select-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-arrow{width:8px;height:8px;flex:0 0 auto;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:translateY(-2px) rotate(45deg);opacity:.8}.custom-select-menu{z-index:420;overflow:auto;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;box-shadow:0 12px 36px #000000a6;padding:4px}.custom-select-option{display:block;width:100%;border:0;border-radius:5px;background:transparent;color:var(--text-dim);font-family:Barlow,sans-serif;font-size:13px;text-align:left;padding:8px 10px;cursor:pointer}.custom-select-option:hover,.custom-select-option:focus{background:var(--surface3);color:var(--text);outline:none}.custom-select-option.selected{background:var(--gold-dim);color:var(--gold)}.view-toggle{display:flex;border:1px solid var(--border2);border-radius:6px;overflow:hidden;flex-shrink:0}.view-btn{padding:7px 10px;background:var(--surface);border:none;color:var(--text-muted);cursor:pointer;transition:all .15s}.view-btn:hover{background:var(--surface2);color:var(--text)}.view-btn.active{background:var(--gold-dim);color:var(--gold)}.filter-bar{display:flex;align-items:center;gap:7px;padding:0 24px 14px;flex-wrap:wrap;border-bottom:1px solid var(--border)}.fchip{display:flex;align-items:center;gap:4px;padding:5px 12px;border-radius:20px;border:1px solid var(--border2);background:transparent;font-size:11px;cursor:pointer;color:var(--text-dim);transition:all .15s;white-space:nowrap;font-family:Barlow,sans-serif}.fchip:hover{border-color:var(--border2);color:var(--text);background:var(--surface2)}.fchip.on{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.fchip.on-blue{background:var(--blue-dim);border-color:var(--blue-border);color:var(--blue)}.canon-toggle{display:flex;border:1px solid var(--border2);border-radius:20px;overflow:hidden;flex:0 0 auto}.ct-btn{padding:5px 12px;font-size:11px;cursor:pointer;border:none;background:transparent;color:var(--text-muted);font-family:Barlow,sans-serif;transition:all .15s}.ct-btn:hover{background:var(--surface2);color:var(--text)}.ct-btn.active{background:var(--gold-dim);color:var(--gold)}.ct-btn.active-leg{background:var(--blue-dim);color:var(--blue)}.ct-btn:disabled{cursor:not-allowed;opacity:.45;background:transparent;color:var(--text-muted)}.fdivider{width:1px;height:18px;background:var(--border);flex-shrink:0}.sort-sel{background-color:var(--surface);border:1px solid var(--border2);color:var(--text-dim);font-family:Barlow,sans-serif;font-size:11px;padding:5px 10px;border-radius:20px;outline:none;cursor:pointer;min-width:104px}.sort-sel:focus{border-color:var(--gold-border)}.filter-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.result-count{margin-left:auto;font-size:11px;color:var(--text-muted);white-space:nowrap}.cover{flex-shrink:0;border-radius:3px;display:flex;align-items:center;justify-content:center;font-family:Bebas Neue,sans-serif;letter-spacing:1px;color:#ffffffa6;text-align:center;line-height:1.3;position:relative;overflow:hidden}.cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 55%)}.cover-sm{width:34px;height:48px;font-size:9px}.cover-md{width:50px;height:70px;font-size:11px}.cover-lg{width:100%;aspect-ratio:.65}.badge{font-size:10px;font-weight:600;letter-spacing:.5px;padding:2px 7px;border-radius:10px;white-space:nowrap;font-family:Barlow Condensed,sans-serif;text-transform:uppercase}.b-novel{background:#6ec6f51f;color:var(--blue);border:1px solid var(--blue-border)}.b-comic{background:#f0a03024;color:var(--amber);border:1px solid rgba(240,160,48,.25)}.b-tpb{background:#4caf7d24;color:var(--green);border:1px solid rgba(76,175,125,.25)}.b-ebook{background:#9b7fe824;color:var(--purple);border:1px solid rgba(155,127,232,.25)}.b-canon{background:var(--gold-dim);color:var(--gold);border:1px solid var(--gold-border)}.b-legends{background:var(--blue-dim);color:#7ab8e0;border:1px solid rgba(110,198,245,.18)}.b-both{background:#9b7fe824;color:#b7a5ff;border:1px solid rgba(155,127,232,.28)}.b-anthology{background:#8a9bbf1a;color:var(--text-dim);border:1px solid var(--border2)}.status-dots{display:flex;gap:4px;align-items:center;flex-shrink:0;width:118px;justify-content:flex-end}.status-dots-compact{width:auto}.sbadge{display:flex;align-items:center;gap:4px;padding:2px 7px;border-radius:10px;cursor:pointer;font-size:10px;font-family:Barlow Condensed,sans-serif;font-weight:600;letter-spacing:.5px;text-transform:uppercase;border:1px solid transparent;transition:all .15s;-webkit-user-select:none;user-select:none;white-space:nowrap;line-height:1.2}button.sbadge{font-family:Barlow Condensed,sans-serif}.sbadge:disabled,.btn:disabled,.daction:disabled,.wishlist-btn:disabled{cursor:not-allowed;opacity:.55;transform:none}.sbadge:hover{filter:brightness(1.2);transform:translateY(-1px)}.sbadge svg{flex-shrink:0;width:10px;height:10px}.status-dots-compact .sbadge svg{width:10px;height:10px}.sbadge-owned-y{background:#4caf7d2e;border-color:#4caf7d59;color:var(--green)}.sbadge-owned-n{background:transparent;border-color:var(--border2);color:var(--text-muted)}.sbadge-owned-n:hover{border-color:#4caf7d66;color:var(--green)}.sbadge-read-y{background:#c9a22729;border-color:#c9a22759;color:var(--gold)}.sbadge-read-n{background:transparent;border-color:var(--border2);color:var(--text-muted)}.sbadge-read-n:hover{border-color:#c9a22759;color:var(--gold)}.book-list{display:flex;flex-direction:column;gap:1px}.book-row{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:6px;cursor:pointer;transition:background .1s;border:1px solid transparent}.book-row:hover{background:var(--surface2);border-color:var(--border)}.book-row.compact{padding:6px 10px}.binfo{flex:1;min-width:0}.btitle{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.bmeta{display:flex;align-items:center;gap:6px;margin-top:3px;flex-wrap:wrap}.bseries{font-size:10px;color:var(--text-muted)}.bauthor{font-size:12px;color:var(--text-dim);width:150px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.byear{font-size:12px;color:var(--text-muted);width:42px;text-align:right;font-family:Barlow Condensed,sans-serif;flex-shrink:0}.bera{font-size:10px;color:var(--text-muted);max-width:210px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0}.book-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.book-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s}.book-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 10px 36px #00000080}.card-cover-wrap{position:relative;overflow:hidden}.card-cover-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 55%,rgba(0,0,0,.6) 100%);z-index:1}.card-body{padding:10px 11px 12px}.card-title{font-size:11px;font-weight:600;line-height:1.35;margin-bottom:3px;color:var(--text)}.card-author{font-size:10px;color:var(--text-muted);margin-bottom:8px}.card-era{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:8px}.card-footer{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap}.upcoming-list{display:flex;flex-direction:column;gap:10px}.upcoming-card{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;transition:border-color .15s}.upcoming-card:hover{border-color:var(--border2)}.uc-info{flex:1;min-width:0}.uc-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px;overflow-wrap:anywhere}.uc-meta{font-size:12px;color:var(--text-muted);margin-bottom:8px}.uc-year{font-family:Bebas Neue,sans-serif;font-size:38px;color:var(--gold);opacity:.25;letter-spacing:2px;align-self:center;flex-shrink:0}.wishlist-btn{padding:5px 14px;border-radius:20px;border:1px solid var(--border2);background:transparent;color:var(--text-dim);font-size:11px;cursor:pointer;transition:all .15s;font-family:Barlow,sans-serif;white-space:nowrap}.wishlist-btn:hover{border-color:var(--gold-border);color:var(--gold)}.wishlist-btn.on{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.series-groups{display:flex;flex-direction:column;gap:24px}.sg-header{display:flex;align-items:center;gap:14px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border);flex-wrap:wrap}.sg-name{font-family:Bebas Neue,sans-serif;font-size:19px;letter-spacing:2.5px;color:var(--text)}.sg-count{font-size:11px;color:var(--text-muted)}.progress-wrap{flex:1;max-width:160px}.progress-bar{height:3px;background:var(--surface3);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .5s}.section-hdr{display:flex;align-items:baseline;gap:12px;margin:0 0 16px}.section-hdr h2{font-family:Bebas Neue,sans-serif;font-size:22px;letter-spacing:3px;color:var(--text)}.section-sub{font-size:11px;color:var(--text-muted);letter-spacing:.5px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state p{font-size:14px;margin-top:12px}.error-banner{margin:0 0 14px;padding:10px 12px;border:1px solid rgba(224,92,92,.35);border-radius:10px;background:#e05c5c1f;color:var(--red);font-size:13px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:90;pointer-events:none;transition:background .25s}.drawer-overlay.open{background:#00000073;pointer-events:all}.drawer{position:fixed;top:0;right:0;height:100vh;width:340px;max-width:100vw;background:var(--surface);border-left:1px solid var(--border2);z-index:91;display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);overflow:hidden}.drawer.open{transform:translate(0)}.drawer-cover{width:100%;aspect-ratio:1.6;display:flex;align-items:center;justify-content:center;font-family:Bebas Neue,sans-serif;font-size:32px;letter-spacing:3px;color:#fff9;text-align:center;padding:20px;line-height:1.3;position:relative;flex-shrink:0}.drawer-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 40%,var(--surface) 100%)}.drawer-close{position:absolute;top:14px;right:14px;background:#0006;border:1px solid var(--border2);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);z-index:2;transition:all .15s}.drawer-close:hover{background:var(--surface2);color:var(--text)}.drawer-body{flex:1;overflow-y:auto;padding:0 22px 28px}.drawer-title{font-family:Bebas Neue,sans-serif;font-size:26px;letter-spacing:2.5px;color:var(--text);line-height:1.15;margin-bottom:6px}.drawer-author{font-size:13px;color:var(--text-dim);margin-bottom:14px}.drawer-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}.drawer-divider{height:1px;background:var(--border);margin:16px 0}.drawer-field{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0}.drawer-field-label{font-size:11px;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase}.drawer-field-val{font-size:13px;color:var(--text);font-weight:500;text-align:right;max-width:60%}.drawer-actions{display:flex;gap:8px;margin-top:20px}.daction{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:10px 0;border-radius:8px;border:1px solid var(--border2);background:transparent;color:var(--text-dim);font-family:Barlow,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s}.daction:hover{background:var(--surface2);color:var(--text)}.daction.on-green{background:#4caf7d26;border-color:#4caf7d66;color:var(--green)}.daction.on-gold{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.drawer-series-pos{font-size:11px;color:var(--text-muted);margin-top:2px}.drawer-edit-row{display:flex;gap:8px;margin-top:16px}.confirm-del{background:#e05c5c1a;border:1px solid rgba(224,92,92,.25);border-radius:8px;padding:12px 14px;margin-top:12px;font-size:12px;color:var(--text-dim)}.confirm-del p{margin-bottom:10px}.confirm-del-btns{display:flex;gap:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:110;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadein .18s ease}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:12px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px #000000b3}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--border)}.modal-title{font-family:Bebas Neue,sans-serif;font-size:22px;letter-spacing:3px;color:var(--text)}.modal-body{flex:1;overflow-y:auto;padding:20px 22px}.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.form-error{margin-right:auto;color:var(--red);font-size:12px;align-self:center}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}.form-grid .span2{grid-column:1/-1}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted)}.form-input,.form-select{background-color:var(--surface2);border:1px solid var(--border2);border-radius:6px;padding:8px 11px;color:var(--text);font-family:Barlow,sans-serif;font-size:13px;outline:none;transition:border-color .15s;width:100%;color-scheme:dark}.form-input:focus,.form-select:focus{border-color:var(--gold-border);box-shadow:0 0 0 2px #c9a22714}.form-input::placeholder{color:var(--text-muted)}.form-toggle{display:flex;border:1px solid var(--border2);border-radius:6px;overflow:hidden}.form-toggle-btn{flex:1;padding:8px;background:transparent;border:none;color:var(--text-muted);font-family:Barlow,sans-serif;font-size:12px;cursor:pointer;transition:all .15s}.form-toggle-btn.active{background:var(--gold-dim);color:var(--gold)}.form-toggle-btn.active-leg{background:var(--blue-dim);color:var(--blue)}.form-toggle-btn.active-both{background:#9b7fe824;color:#b7a5ff}.btn{padding:8px 18px;border-radius:7px;font-family:Barlow,sans-serif;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s}.btn-ghost{background:transparent;border-color:var(--border2);color:var(--text-dim)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-primary{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.btn-primary:hover{background:#c9a22738}.btn-danger{background:#e05c5c1f;border-color:#e05c5c4d;color:var(--red)}.btn-danger:hover{background:#e05c5c38}@media (max-width:520px){.form-grid{grid-template-columns:1fr}.form-grid .span2{grid-column:1}}.timeline-controls{display:flex;align-items:center;gap:8px;margin-bottom:22px;flex-wrap:wrap}.tl-toggle{display:flex;border:1px solid var(--border2);border-radius:20px;overflow:hidden}.tl-btn{padding:5px 14px;font-size:11px;cursor:pointer;border:none;background:transparent;color:var(--text-muted);font-family:Barlow,sans-serif;transition:all .15s;letter-spacing:.3px;white-space:nowrap}.tl-btn:hover{background:var(--surface2);color:var(--text)}.tl-btn.active{background:var(--gold-dim);color:var(--gold)}.tl-label{font-size:11px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;white-space:nowrap}.timeline-wrap{position:relative;padding-left:56px}.tl-spine{position:absolute;left:22px;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,var(--border2) 40px,var(--border2) calc(100% - 40px),transparent)}.tl-year-block{position:relative;margin-bottom:32px}.tl-year-anchor{position:absolute;left:-56px;top:2px;width:44px;display:flex;flex-direction:column;align-items:center;gap:0}.tl-year-num{font-family:Bebas Neue,sans-serif;font-size:15px;letter-spacing:1px;color:var(--gold);line-height:1;white-space:nowrap}.tl-year-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);margin-top:4px;flex-shrink:0;box-shadow:0 0 8px #c9a22780}.tl-year-dot.dim{background:var(--border2);box-shadow:none}.tl-connector{position:absolute;left:-28px;top:7px;height:1px;width:20px;background:var(--border2)}.tl-era-label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;padding-left:1px}.tl-books{display:flex;flex-direction:column;gap:2px}.tl-book{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:all .15s;position:relative}.tl-book:hover{background:var(--surface2);border-color:var(--border)}.tl-book-info{flex:1;min-width:0}.tl-book-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-book-sub{font-size:11px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-book-badges{display:flex;align-items:center;gap:5px;margin-top:5px;flex-wrap:wrap}.tl-status{display:flex;align-items:center;gap:5px;flex-shrink:0}.tl-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tl-dot.owned{background:var(--green)}.tl-dot.unowned{background:var(--border2)}.tl-dot.read{background:var(--gold)}.lego-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:18px}.lego-stat{border:1px solid var(--border);background:linear-gradient(145deg,var(--surface),rgba(17,30,50,.78));border-radius:8px;padding:12px 14px;min-width:0}.lego-stat-val{display:block;font-family:Bebas Neue,sans-serif;font-size:27px;letter-spacing:2px;color:var(--gold);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lego-stat-label{display:block;margin-top:5px;font-size:10px;letter-spacing:1.3px;text-transform:uppercase;color:var(--text-muted)}.lego-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}button.lego-card,button.lego-row{font-family:inherit;text-align:left}.lego-card{display:flex;flex-direction:column;width:100%;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:inherit;cursor:pointer;overflow:hidden;transition:border-color .15s,transform .15s,box-shadow .15s}.lego-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 10px 36px #00000073}.lego-card-body{padding:11px 12px 13px}.lego-card-badges{display:flex;align-items:center;gap:7px;margin-top:9px;flex-wrap:wrap}.lego-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;min-height:34px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lego-thumb{display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0;background:radial-gradient(circle at 32% 24%,rgba(255,255,255,.2),transparent 28%),linear-gradient(145deg,#171a20,#3d2f12 48%,#151923);border:1px solid rgba(201,162,39,.18);color:#ffffffad;font-family:Bebas Neue,sans-serif;letter-spacing:2px}.lego-thumb:before,.lego-thumb:after{content:"";position:absolute;top:10%;width:18%;height:12%;border-radius:5px;background:#ffffff24;box-shadow:0 2px #00000040}.lego-thumb:before{left:30%}.lego-thumb:after{right:30%}.lego-thumb.has-image:before,.lego-thumb.has-image:after{display:none}.lego-thumb img{width:100%;height:100%;object-fit:cover;display:block}.lego-thumb span{position:relative;z-index:1;text-shadow:0 2px 8px rgba(0,0,0,.55)}.lego-thumb-sm{width:54px;height:42px;border-radius:6px;font-size:13px}.lego-thumb-lg{width:100%;aspect-ratio:1.55;border-width:0 0 1px;border-radius:0;font-size:26px}.drawer .lego-thumb-lg{border-width:0;aspect-ratio:1.8;font-size:34px}.lego-image-preview{width:54px;height:42px;border:1px solid var(--border);border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--surface2)}.lego-image-preview img{width:100%;height:100%;object-fit:cover;display:block}.lego-badge{display:inline-flex;align-items:center;border:1px solid;border-radius:12px;padding:3px 8px;font-size:10px;font-weight:700;font-family:Barlow Condensed,sans-serif;letter-spacing:.6px;text-transform:uppercase;line-height:1;white-space:nowrap}.lego-piece-count{display:inline-flex;align-items:baseline;gap:4px;border:1px solid var(--border2);border-radius:12px;padding:3px 8px;color:var(--text-dim);font-family:Barlow Condensed,sans-serif;font-weight:700;letter-spacing:.6px;line-height:1;white-space:nowrap}.lego-piece-count span{font-size:9px;color:var(--text-muted);letter-spacing:1px}.lego-piece-count.big{font-size:14px;color:var(--text)}.lego-list{display:flex;flex-direction:column;gap:6px}.lego-row{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:8px;border:1px solid transparent;background:transparent;color:inherit;cursor:pointer;transition:background .12s,border-color .12s}.lego-row:hover:not(:disabled){background:var(--surface2);border-color:var(--border)}.lego-row:disabled{cursor:not-allowed;opacity:.58}.lego-row-main{flex:1;min-width:0}.lego-row-top{display:flex;align-items:baseline;gap:8px;min-width:0}.lego-num{font-family:Barlow Condensed,sans-serif;font-size:12px;color:var(--gold);letter-spacing:.7px;flex-shrink:0}.lego-row-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.lego-row-meta,.lego-row-prices{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:5px}.lrm,.lrp{font-size:11px;color:var(--text-muted);line-height:1.2}.lrp{display:flex;gap:4px;align-items:baseline}.lrp-l{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}.lego-gain{color:var(--green)}.lego-loss{color:var(--red)}.lego-row-right{display:flex;align-items:center;justify-content:flex-end;min-width:126px;flex-shrink:0}.lego-drawer-kicker{margin:2px 0 6px;font-size:11px;color:var(--gold);font-family:Barlow Condensed,sans-serif;letter-spacing:1.5px;text-transform:uppercase}.lego-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.lego-status-choice{border:1px solid var(--border2);background:transparent;color:var(--text-dim);border-radius:8px;padding:8px 10px;font-family:Barlow,sans-serif;font-size:12px;cursor:pointer;transition:all .15s}.lego-status-choice:hover:not(:disabled){background:var(--surface2);color:var(--text)}.lego-status-choice:disabled{cursor:not-allowed;opacity:.55}.danger-action{border-color:#e05c5c47;color:var(--red)}.danger-action:hover{background:#e05c5c1a;color:var(--red)}.modal-close-btn{position:static;transform:none;font-size:20px;line-height:1;padding:2px 6px}.agent-wrap{display:flex;flex-direction:column;height:100%;min-height:0;max-width:760px;margin:0 auto}.topbar-row1-agent{margin-bottom:14px}.topbar-row1-agent .agent-provider-wrap{flex:1;min-width:0;max-width:320px;margin-left:auto}.agent-provider{width:100%;background-color:var(--surface2);border:1px solid var(--border2);border-radius:7px;color:var(--text);font-family:Barlow,sans-serif;font-size:12px;padding:7px 31px 7px 10px;outline:none}.agent-provider:focus{border-color:var(--gold-border);box-shadow:0 0 0 2px #c9a22712}.agent-provider:disabled{opacity:.55}.agent-clear{font-size:11px;padding:6px 10px;flex-shrink:0}.agent-provider-error{border:1px solid rgba(224,92,92,.32);background:#e05c5c1a;color:var(--red);border-radius:8px;padding:10px 12px;font-size:12px;margin:0 24px 12px;flex-shrink:0}.agent-empty{flex-shrink:0;margin-bottom:16px}.agent-suggest-label{font-size:12px;color:var(--text-muted);margin-bottom:10px;letter-spacing:.3px}.agent-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.agent-chip{padding:5px 11px;border-radius:16px;border:1px solid var(--border2);background:transparent;font-size:11px;color:var(--text-dim);cursor:pointer;font-family:Barlow,sans-serif;transition:all .15s;white-space:nowrap}.agent-chip:hover:not(:disabled){border-color:var(--gold-border);color:var(--gold);background:var(--gold-dim)}.agent-chip:disabled{opacity:.5;cursor:not-allowed}.agent-messages{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:14px;padding-bottom:20px}.agent-msg{display:flex;gap:10px;align-items:flex-start;animation:fadein .2s ease}.agent-msg.user{flex-direction:row-reverse}.agent-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;letter-spacing:1px;border:1px solid var(--border2)}.agent-avatar.assistant{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.agent-avatar.user{background:var(--surface3);border-color:var(--border2);color:var(--text-dim)}.agent-msg-body{display:flex;flex-direction:column;gap:8px;max-width:82%;min-width:0}.agent-bubble{max-width:100%;padding:11px 14px;border-radius:10px;font-size:13px;line-height:1.6;color:var(--text);overflow-wrap:anywhere}.agent-msg.assistant .agent-bubble{background:var(--surface);border:1px solid var(--border);border-top-left-radius:3px}.agent-msg.user .agent-bubble{background:var(--surface2);border:1px solid var(--border2);border-top-right-radius:3px}.agent-bubble p{margin-bottom:8px}.agent-bubble p:last-child{margin-bottom:0}.agent-bubble strong{color:var(--gold);font-weight:600}.agent-bubble code{background:var(--surface3);border:1px solid var(--border2);padding:1px 5px;border-radius:3px;font-size:11px;font-family:monospace}.agent-bubble ul{padding-left:16px;margin:4px 0}.agent-bubble li{margin-bottom:3px}.agent-diagnostic-warning{align-self:flex-start;border:1px solid rgba(240,160,48,.3);background:#f0a03014;color:var(--amber);border-radius:7px;padding:6px 9px;font-size:11px;line-height:1.4}.agent-actions-group{margin-top:10px;display:flex;flex-direction:column;gap:8px}.agent-action-card{background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:12px 14px;transition:border-color .15s}.agent-action-card:hover{border-color:var(--gold-border)}.aac-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.aac-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted)}.aac-warn{font-size:10px;color:var(--amber);border:1px solid rgba(240,160,48,.3);border-radius:10px;padding:1px 7px}.aac-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3}.aac-meta{font-size:11px;color:var(--text-muted);margin-top:2px;line-height:1.4}.aac-badges{margin-top:6px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}.aac-date{font-size:10px;color:var(--text-muted)}.aac-btns{display:flex;gap:7px;margin-top:10px}.aac-btn{padding:5px 14px;border-radius:6px;font-size:11px;font-family:Barlow,sans-serif;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:transparent;color:var(--text-dim);transition:all .15s}.aac-btn:hover:not(:disabled){background:var(--surface3);color:var(--text)}.aac-btn:disabled{opacity:.55;cursor:not-allowed}.aac-btn.primary{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.aac-btn.primary:hover:not(:disabled){background:#c9a22738}.aac-btn.applied{background:#4caf7d1f;border-color:#4caf7d4d;color:var(--green);cursor:default}.agent-action-error{margin-top:8px;color:var(--red);font-size:11px;line-height:1.4}.agent-input-area{border-top:1px solid var(--border);padding-top:14px;margin-top:4px;flex-shrink:0}.agent-input-row{display:flex;gap:8px;align-items:flex-end}.agent-textarea{flex:1;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;padding:10px 13px;color:var(--text);font-family:Barlow,sans-serif;font-size:13px;outline:none;resize:none;min-height:42px;max-height:140px;line-height:1.5;transition:border-color .2s}.agent-textarea:focus{border-color:var(--gold-border);box-shadow:0 0 0 2px #c9a22712}.agent-textarea::placeholder{color:var(--text-muted)}.agent-textarea:disabled{opacity:.65;cursor:not-allowed}.agent-send{width:38px;height:38px;border-radius:8px;border:1px solid var(--gold-border);background:var(--gold-dim);color:var(--gold);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.agent-send:hover:not(:disabled){background:#c9a22738}.agent-send:disabled{opacity:.4;cursor:default}.agent-thinking{display:flex;align-items:center;gap:7px;color:var(--text-muted);font-size:12px}.thinking-dots span{animation:fadein .8s ease infinite alternate}.thinking-dots span:nth-child(2){animation-delay:.16s}.thinking-dots span:nth-child(3){animation-delay:.32s}.agent-url-hint{font-size:11px;color:var(--text-muted);margin-top:7px;line-height:1.5}.sb-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:15}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--surface);border-top:1px solid var(--border);padding:0 4px env(safe-area-inset-bottom,0)}.bn-items{display:flex;justify-content:space-around;padding:4px 0}.bn-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 16px;border:none;background:none;color:var(--text-muted);font-family:Barlow,sans-serif;font-size:9px;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;border-radius:8px;transition:color .15s;flex:1;min-width:0}.bn-item svg{flex-shrink:0;opacity:.6;transition:opacity .15s}.bn-item.active{color:var(--gold)}.bn-item.active svg{opacity:1}@keyframes fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-page{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:20px}.login-logo{font-family:Bebas Neue,sans-serif;font-size:36px;letter-spacing:6px;color:var(--gold);text-align:center}.login-logo p{font-size:10px;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;margin-top:6px;font-family:Barlow,sans-serif;font-weight:400}.login-form{width:min(100%,320px);display:flex;flex-direction:column;gap:14px}.login-field{display:flex;flex-direction:column;gap:6px;color:var(--text-muted);font-size:11px;letter-spacing:1.4px;text-transform:uppercase}.login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:4px;padding:12px 28px;border-radius:8px;border:1px solid var(--gold-border);background:var(--gold-dim);color:var(--gold);font-family:Barlow,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .18s}.login-btn:hover{background:#c9a22738;transform:translateY(-1px);box-shadow:0 8px 24px #0006}.login-btn:disabled{opacity:.5;cursor:default;transform:none}.login-error{min-height:16px;margin:0;color:var(--red);font-size:12px;text-align:center}@media (max-width:768px){html,body{overflow:hidden}.app{height:calc(100vh - var(--mobile-bottom-nav-h))}@supports (height:100dvh){.app{height:calc(100dvh - var(--mobile-bottom-nav-h))}}.sidebar,.sb-overlay{display:none!important}.main{width:100%;min-height:0}.hamburger{display:none!important}.bauthor,.byear{display:none}.status-dots{width:auto;gap:4px}.sbadge{padding:2px 4px;font-size:0;gap:0}.sbadge svg{width:11px;height:11px}.status-dots-compact .sbadge-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.book-cards{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.content{min-height:0;padding:12px 14px;scroll-padding-bottom:12px}.filter-bar{padding:0 14px 10px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-bar .canon-toggle,.filter-bar .fchip,.filter-bar .fdivider,.filter-bar .sort-sel-wrap,.filter-bar .view-toggle,.filter-actions{flex:0 0 auto}.filter-actions{margin-left:0}.filter-bar::-webkit-scrollbar{display:none}.result-count{display:none}.topbar{padding:12px 14px 0}.topbar-row1{gap:8px;flex-wrap:wrap}.page-title{font-size:22px;flex:1}.search-wrap{order:3;flex:0 0 100%;max-width:100%}.view-toggle,.topbar-row1 .btn{order:2}.bottom-nav{display:block}.bn-item{padding:7px 6px;font-size:8px}.topbar-row1-agent{margin-bottom:10px;flex-wrap:nowrap;gap:8px}.topbar-row1-agent .agent-provider-wrap{flex:1;min-width:0;max-width:none;margin-left:0}.topbar-row1-agent .agent-provider{min-width:0;max-width:none}.topbar-row1-agent .page-title{flex:0 0 auto}.agent-provider-error{margin:0 14px 10px}.agent-msg-body{max-width:84%}.agent-wrap{height:100%;min-height:0}.agent-messages{min-height:0}.timeline-wrap{padding-left:44px}.tl-spine{left:16px}.tl-year-anchor{left:-44px;width:36px}.tl-year-num{font-size:12px}.tl-connector{left:-22px;width:14px}.uc-year{font-size:24px!important}.lego-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}.lego-stat{padding:10px 11px}.lego-stat-val{font-size:22px}.lego-cards{grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:10px}.lego-name{font-size:12px;min-height:32px}.lego-row{gap:9px;padding:9px 8px}.lego-thumb-sm{width:46px;height:38px;font-size:11px}.lego-row-right{min-width:auto;align-self:flex-start;padding-top:1px}.lego-row-prices{display:none}.lego-row-meta{gap:5px}.lrm{font-size:10px}.drawer{width:100vw;height:calc(100vh - var(--mobile-bottom-nav-h))}.modal-overlay{align-items:center;overflow-y:auto;padding:12px 14px calc(var(--mobile-bottom-nav-h) + 12px)}.modal{max-height:calc(100vh - var(--mobile-bottom-nav-h) - 24px);margin:auto 0}@supports (height:100dvh){.drawer{height:calc(100dvh - var(--mobile-bottom-nav-h))}.modal{max-height:calc(100dvh - var(--mobile-bottom-nav-h) - 24px)}}}@media (min-width:769px){.sb-overlay,.bottom-nav{display:none!important}}
