:root{--bg:#f3f6fa;--surface:#fff;--ink:#12263a;--ink-soft:#4a5a6e;--subtle:#8a97a6;--line:#dde4eb;--primary:#0f6fb8;--primary-dark:#0a558f;--accent:#e66d3c;--danger:#c0392b;--ok:#2b8a5a;--warn:#c08a0e;--shadow:0 1px 2px #0c263a0f, 0 4px 16px #0c263a0f;color:var(--ink);background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif}*{box-sizing:border-box}body,html,#root{min-height:100%;margin:0;padding:0}.subtle{color:var(--subtle);font-size:.9rem}.login-root{background:linear-gradient(#e8eff7 0%,#d7e3ef 100%);place-items:center;min-height:100vh;display:grid}.login-card{background:var(--surface);box-shadow:var(--shadow);border-radius:14px;gap:.9rem;width:100%;min-width:320px;max-width:380px;padding:2rem 2.25rem;display:grid}.login-card h1{margin:0;font-size:1.5rem}.login-card label{color:var(--ink-soft);gap:.3rem;font-size:.85rem;display:grid}.login-card input{border:1px solid var(--line);background:#fbfcfe;border-radius:8px;padding:.55rem .75rem;font-size:1rem}.login-card input:focus{outline:2px solid var(--primary);outline-offset:1px;border-color:var(--primary)}.login-card button{background:var(--primary);color:#fff;cursor:pointer;border:0;border-radius:8px;margin-top:.5rem;padding:.65rem 1rem;font-weight:600}.login-card button:hover:not(:disabled){background:var(--primary-dark)}.login-card button:disabled{opacity:.6;cursor:progress}.login-error{color:var(--danger);background:#fbe7e3;border-radius:8px;padding:.5rem .75rem;font-size:.85rem}.page{max-width:1200px;min-height:100vh;margin:0 auto;padding:1.5rem 1.5rem 4rem}.topbar{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.topbar h1{margin:0;font-size:1.4rem}.topbar-right{align-items:center;gap:.75rem;display:flex}.button-ghost{border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;background:0 0;border-radius:6px;padding:.35rem .75rem;font-size:.85rem}.button-ghost:hover{background:var(--line);color:var(--ink)}.error-banner{color:var(--danger);background:#fbe7e3;border-radius:8px;margin-bottom:1rem;padding:.6rem .85rem;font-size:.9rem}.filters{grid-template-columns:minmax(200px,1fr) auto auto auto;align-items:center;gap:.6rem;margin-bottom:1.25rem;display:grid}.filters input,.filters select{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:.5rem .7rem;font-size:.9rem}.filters .count{color:var(--subtle);white-space:nowrap;font-size:.85rem}.grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.card{background:var(--surface);box-shadow:var(--shadow);border-radius:10px;flex-direction:column;transition:transform .12s,box-shadow .12s;display:flex;overflow:hidden}.card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0c263a1a,0 8px 24px #0c263a14}.poster-wrap{aspect-ratio:2/3;background:linear-gradient(135deg,#cdd9e3,#eaf1f7);position:relative}.poster-wrap img{object-fit:cover;width:100%;height:100%;display:block}.poster-placeholder{width:100%;height:100%;color:var(--subtle);place-items:center;font-size:3rem;font-weight:600;display:grid}.badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--ink-soft);text-transform:capitalize;background:#fffc;border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:600;position:absolute;top:8px;left:8px}.badge-watched{color:var(--ok);background:#dcf5e8e6}.badge-in_progress{color:var(--warn);background:#fdf4dbe6}.badge-dropped{color:var(--danger);background:#fde4dfe6}.card-body{gap:.35rem;padding:.6rem .75rem .85rem;display:grid}.card-body h3{margin:0;font-size:.95rem;line-height:1.2}.meta{color:var(--subtle);flex-wrap:wrap;align-items:center;gap:.35rem;font-size:.75rem;display:flex}.type-pill{background:var(--line);color:var(--ink-soft);text-transform:capitalize;border-radius:4px;padding:1px 6px;font-weight:600}.moods{color:var(--ink-soft);font-size:.75rem}.empty{text-align:center;color:var(--subtle);grid-column:1/-1;padding:3rem 1rem}.shell{flex-direction:column;min-height:100vh;display:flex}.shell .topbar{background:var(--surface);border-bottom:1px solid var(--line);z-index:5;padding:.75rem 1.25rem;position:sticky;top:0}.shell .topbar h1{font-size:1.15rem}.shell .content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:1.25rem 1.5rem 3rem}.tabs{flex-wrap:wrap;flex:1;justify-content:center;gap:.25rem;display:flex}.tab{color:var(--ink-soft);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:.4rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none}.tab:hover{background:var(--line);color:var(--ink)}.tab.active{background:var(--primary);color:#fff}.page-section{max-width:100%}.section-head{justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1rem;display:flex}.section-head h2{margin:0 0 .2rem;font-size:1.2rem}.section-head p{margin:0}.button-primary{background:var(--primary);color:#fff;cursor:pointer;border:0;border-radius:6px;padding:.55rem 1rem;font-weight:600}.button-primary:hover:not(:disabled){background:var(--primary-dark)}.button-primary:disabled{opacity:.6;cursor:progress}.banner-ok{color:var(--ok);background:#dcf5e8;border-radius:8px;padding:.5rem .75rem;font-size:.85rem}.library-root{grid-template-columns:260px 1fr;gap:1.25rem;display:grid}@media (width<=900px){.library-root{grid-template-columns:1fr}}.filters-rail{background:var(--surface);box-shadow:var(--shadow);border-radius:10px;flex-direction:column;align-self:start;gap:.6rem;max-height:calc(100vh - 120px);padding:1rem;display:flex;position:sticky;top:80px;overflow-y:auto}.filters-rail .rail-head{justify-content:space-between;align-items:center;display:flex}.filters-rail h2{margin:0;font-size:1rem}.filters-rail label{color:var(--ink-soft);gap:.25rem;font-size:.8rem;display:grid}.filters-rail input,.filters-rail select{border:1px solid var(--line);background:#fbfcfe;border-radius:6px;padding:.4rem .6rem;font-size:.85rem}.filters-rail .two-up{grid-template-columns:1fr 1fr;gap:.4rem;display:grid}.filters-rail .count{color:var(--subtle);margin-top:.5rem;font-size:.8rem}.library-main{min-width:0}.card{cursor:pointer}.card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.card-compact{flex:0 0 140px;min-width:140px}.card-compact .meta,.card-compact .moods{display:none}.badge-custom{background:var(--primary);color:#fff}.modal-backdrop{z-index:50;background:#0c263a8c;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border-radius:14px;width:100%;max-width:720px;max-height:90vh;padding:1.5rem;position:relative;overflow-y:auto;box-shadow:0 20px 40px #0c263a33}.modal-close{cursor:pointer;color:var(--subtle);background:0 0;border:0;font-size:1.8rem;position:absolute;top:8px;right:12px}.modal-close:hover{color:var(--ink)}.modal-header{gap:1rem;margin-bottom:1rem;display:flex}.modal-poster{border-radius:6px;flex:0 0 150px;width:150px}.modal-section{margin-top:1.25rem}.modal-section h3{margin:0 0 .4rem;font-size:1rem}.tags-row{flex-wrap:wrap;gap:.3rem;margin-top:.4rem;display:flex}.tag{background:var(--line);color:var(--ink-soft);border-radius:999px;padding:2px 7px;font-size:.75rem}.tag-genre{color:var(--primary-dark);background:#d7e4f2}.tag-mood{color:#b2501f;background:#fde3d6}.row-feedback{border-bottom:1px dashed var(--line);grid-template-columns:minmax(110px,auto) 1fr;align-items:center;gap:.5rem .75rem;padding:.55rem 0;display:grid}.row-feedback:last-of-type{border-bottom:0}.row-feedback-name{font-weight:500}.row-feedback-controls{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.row-feedback-notes{grid-column:1/-1;gap:.4rem;display:flex}.row-feedback-notes input{border:1px solid var(--line);border-radius:6px;flex:1;padding:.35rem .55rem}.chip-check{color:var(--ink-soft);background:var(--line);border-radius:999px;align-items:center;gap:.25rem;padding:3px 8px;font-size:.8rem;display:inline-flex}.rating-chip{border:1px solid var(--line);background:var(--surface);cursor:pointer;color:var(--ink-soft);border-radius:999px;padding:3px 9px;font-size:.75rem}.rating-chip:hover{border-color:var(--primary);color:var(--primary)}.rating-chip.selected.rating-love{color:#b2502c;background:#fde3e0;border-color:#f0b0a0}.rating-chip.selected.rating-like{color:#1e6a3f;background:#dff3e6;border-color:#a9dbbd}.rating-chip.selected.rating-down{color:#8a3424;background:#fdebe8;border-color:#e9bab0}.rating-chip.small{padding:2px 7px;font-size:.7rem}.row-progress{grid-template-columns:minmax(110px,auto) 50px 50px 1fr auto;align-items:center;gap:.5rem;padding:.4rem 0;display:grid}.row-progress input{border:1px solid var(--line);border-radius:6px;width:100%;padding:.3rem .4rem;font-size:.85rem}.row-progress label{color:var(--subtle);align-items:center;gap:.2rem;font-size:.75rem;display:flex}.picks-stack{flex-direction:column;gap:1rem;display:flex}.pick-row{background:var(--surface);box-shadow:var(--shadow);cursor:pointer;border-radius:10px;grid-template-columns:180px 1fr;gap:1rem;padding:1rem;transition:transform .12s;display:grid}.pick-row:hover{transform:translateY(-2px)}.pick-card-wrap{pointer-events:none}.pick-rationale h3{margin:0 0 .3rem}.pick-rationale p{color:var(--ink-soft);margin:0;line-height:1.5}.lanes{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;display:grid}.lane-card{background:var(--surface);box-shadow:var(--shadow);border-radius:10px;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.lane-card header h3{margin:0 0 .2rem;font-size:1rem}.lane-card header p{margin:0}.lane-result{background:var(--bg);cursor:pointer;border-radius:8px;margin-top:.5rem;padding:.75rem}.lane-result-title{margin-bottom:.3rem;font-weight:600}.lane-result-rationale{color:var(--ink-soft);margin:0;font-size:.85rem;line-height:1.4}.vibe-stack{flex-direction:column;gap:1.25rem;display:flex}.vibe-row-head{justify-content:space-between;align-items:baseline;margin-bottom:.4rem;display:flex}.vibe-row-head h3{text-transform:capitalize;margin:0;font-size:.95rem}.vibe-row-scroll{scroll-snap-type:x mandatory;gap:.75rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.vibe-row-scroll>.card{scroll-snap-align:start}.fav-section{margin-bottom:1.5rem}.fav-head h3{margin:0;font-size:1rem}.fav-head p{margin:0 0 .5rem}.history-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;display:grid}.history-row{background:var(--surface);box-shadow:var(--shadow);cursor:pointer;border-radius:10px;grid-template-columns:120px 1fr;gap:.75rem;padding:.75rem;transition:transform .12s;display:grid}.history-row:hover{transform:translateY(-2px)}.history-poster{pointer-events:none}.history-reactions{flex-direction:column;gap:.4rem;font-size:.85rem;display:flex}.history-reaction-row{grid-template-columns:60px 1fr;align-items:center;gap:.5rem;display:grid}.settings-root{max-width:720px}.settings-card{background:var(--surface);box-shadow:var(--shadow);border-radius:10px;margin-bottom:1rem;padding:1.25rem}.settings-card h3{margin:0 0 .5rem}.form-stack{gap:.6rem;max-width:360px;display:grid}.form-stack input{border:1px solid var(--line);border-radius:6px;padding:.5rem .7rem;font-size:.9rem}.kv-grid{grid-template-columns:120px 1fr;gap:.4rem 1rem;margin-bottom:.75rem;display:grid}.viewer-row{border-bottom:1px dashed var(--line);padding:.4rem 0}.viewer-row:last-child{border-bottom:0}.profile-card{background:var(--bg);border-radius:8px;margin-top:.75rem;padding:.85rem 1rem}.profile-card header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.profile-card h4{margin:0;font-size:.95rem}.profile-card p{margin:.4rem 0;line-height:1.5}.small{font-size:.75rem}.vector-grid{grid-template-columns:140px 1fr;gap:.2rem .8rem;margin:.4rem 0 0;padding:0;font-size:.8rem;display:grid}.vector-row{display:contents}.vector-grid dt{color:var(--ink-soft);font-weight:500}.vector-grid dd{color:var(--ink);margin:0}
