*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-ui: "Hanken Grotesk", sans-serif;--font-mono: "JetBrains Mono", monospace;--accent: #1c1c1c;--accent-fg: #ffffff;--accent-soft: oklch(.22 0 0 / 12%);--accent-line: oklch(.22 0 0 / 24%);--bg: oklch(.986 0 0);--bg-grad: oklch(.968 0 0);--surface: oklch(1 0 0);--surface-2: oklch(.973 0 0);--surface-3: oklch(.951 0 0);--text: oklch(.22 0 0);--muted: oklch(.505 0 0);--faint: oklch(.66 0 0);--border: oklch(.915 0 0);--border-strong: oklch(.852 0 0);--thumb-bg: oklch(.925 0 0);--scrim: rgba(24, 24, 24, .42);--shadow-sm: 0 1px 2px rgba(20,20,20,.06), 0 1px 1px rgba(20,20,20,.04);--shadow-md: 0 6px 20px -6px rgba(20,20,20,.13), 0 2px 6px -2px rgba(20,20,20,.07);--shadow-lg: 0 24px 60px -12px rgba(20,20,20,.26), 0 8px 24px -8px rgba(20,20,20,.16);--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--gap: 20px;--card-pad: 14px;--grid-min: 280px}[data-theme=dark]{--accent-soft: oklch(.22 0 0 / 22%);--accent-line: oklch(.22 0 0 / 40%);--bg: oklch(.168 .013 262);--bg-grad: oklch(.198 .016 262);--surface: oklch(.214 .015 262);--surface-2: oklch(.246 .016 262);--surface-3: oklch(.285 .017 262);--text: oklch(.962 .005 262);--muted: oklch(.7 .013 262);--faint: oklch(.56 .013 262);--border: oklch(.305 .016 262);--border-strong: oklch(.38 .018 262);--thumb-bg: oklch(.3 .015 262);--scrim: rgba(0, 0, 0, .62);--shadow-sm: 0 1px 2px rgba(0,0,0,.2), 0 1px 1px rgba(0,0,0,.15);--shadow-md: 0 6px 20px -6px rgba(0,0,0,.4), 0 2px 6px -2px rgba(0,0,0,.25);--shadow-lg: 0 24px 60px -12px rgba(0,0,0,.6), 0 8px 24px -8px rgba(0,0,0,.4)}html,body,#root{height:100%}body{font-family:var(--font-ui);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background .35s,color .35s}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 60% 40%,var(--bg-grad),var(--bg));padding:24px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:40px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:28px}.login-wordmark{display:flex;align-items:center;gap:10px}.login-mark{width:38px;height:38px;border-radius:11px;background:var(--accent);display:grid;place-items:center;flex-shrink:0}.login-mark svg{color:var(--accent-fg)}.login-brand{font-size:24px;font-weight:800;letter-spacing:-.025em;color:var(--text)}.login-heading{display:flex;flex-direction:column;gap:4px}.login-heading h1{font-size:27px;font-weight:800;letter-spacing:-.03em}.login-heading p{font-size:14.5px;color:var(--muted)}.login-form{display:flex;flex-direction:column;gap:12px}.field-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;display:block}.field-shell{height:50px;display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--r-md);transition:border-color .15s,box-shadow .15s}.field-shell:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.field-shell svg{color:var(--muted);flex-shrink:0}.field-shell input{flex:1;border:none;outline:none;background:transparent;font-family:var(--font-ui);font-size:15px;color:var(--text)}.field-shell input::placeholder{color:var(--faint)}.eye-btn{background:none;border:none;cursor:pointer;color:var(--muted);display:grid;place-items:center;padding:0}.btn-primary{height:50px;background:var(--accent);color:var(--accent-fg);border:none;border-radius:var(--r-md);font-family:var(--font-ui);font-size:15.5px;font-weight:600;cursor:pointer;width:100%;transition:opacity .15s}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.login-error{display:flex;align-items:center;gap:7px;color:#de3b3d;font-size:13.5px;font-weight:500}.login-note{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;font-size:13px;color:var(--muted);line-height:1.5}.topbar{position:sticky;top:0;z-index:40;padding:14px clamp(16px,4vw,40px);background:color-mix(in oklch,var(--bg) 78%,transparent);-webkit-backdrop-filter:blur(18px) saturate(150%);backdrop-filter:blur(18px) saturate(150%);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;transition:background .35s,border-color .35s}.topbar-wordmark{display:flex;align-items:center;gap:8px}.topbar-mark{width:32px;height:32px;border-radius:9px;background:var(--accent);display:grid;place-items:center;flex-shrink:0}.topbar-mark svg{color:var(--accent-fg)}.topbar-brand-wrap{display:flex;flex-direction:column}.topbar-brand{font-size:19px;font-weight:800;letter-spacing:-.02em;line-height:1.1}.topbar-count{font-size:12px;color:var(--faint);font-family:var(--font-mono)}.topbar-spacer{flex:1}.icon-btn{width:36px;height:36px;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:grid;place-items:center;color:var(--muted);transition:background .15s,color .15s,border-color .15s}.icon-btn:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.avatar{width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#4c7dd9,#5959a3,#58366f);display:grid;place-items:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.app-container{max-width:1200px;margin:0 auto;padding:32px clamp(16px,4vw,40px) 96px;display:flex;flex-direction:column;gap:28px}.page-header{display:flex;flex-direction:column;gap:4px}.page-header h1{font-size:clamp(26px,3.4vw,34px);font-weight:800;letter-spacing:-.03em}.page-header p{font-size:14.5px;color:var(--muted)}.add-bar{display:flex;flex-direction:column;gap:8px}.add-bar-row{display:flex;gap:10px}.add-field{flex:1;height:52px;display:flex;align-items:center;gap:10px;padding:0 16px;background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--r-lg);transition:border-color .15s,box-shadow .15s}.add-field:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.add-field svg{color:var(--muted);flex-shrink:0}.add-field input{flex:1;border:none;outline:none;background:transparent;font-family:var(--font-ui);font-size:15px;color:var(--text)}.add-field input::placeholder{color:var(--faint)}.btn-add{height:52px;padding:0 20px;background:var(--accent);color:var(--accent-fg);border:none;border-radius:var(--r-lg);font-family:var(--font-ui);font-size:14.5px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px;white-space:nowrap;transition:opacity .15s;flex-shrink:0}.btn-add:hover{opacity:.85}.btn-add:disabled{opacity:.5;cursor:not-allowed}.add-hint{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--faint);flex-wrap:wrap}.try-link{font-family:var(--font-mono);font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:3px 8px;cursor:pointer;transition:background .15s,border-color .15s}.try-link:hover{background:var(--surface-3);border-color:var(--border-strong)}.add-error{display:flex;align-items:center;gap:7px;font-size:13.5px;color:#de3b3d;font-weight:500;animation:shudder .35s ease}@keyframes shudder{0%,to{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(5px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.controls{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.filter-chips{display:flex;gap:6px;flex-wrap:wrap}.chip{height:34px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-family:var(--font-ui);font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:7px;transition:background .15s,color .15s,border-color .15s}.chip-count{min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--surface-3);font-size:11px;font-weight:700;display:grid;place-items:center;font-feature-settings:"tnum";transition:background .15s,color .15s}.chip.active .chip-count{background:var(--bg);color:var(--text)}.chip:hover{background:var(--surface-2);color:var(--text)}.chip.active{background:var(--text);color:var(--bg);border-color:var(--text)}.controls-right{display:flex;align-items:center;gap:8px}.sort-label{font-size:13px;color:var(--muted);font-weight:500}.sort-select{height:34px;padding:0 28px 0 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-family:var(--font-ui);font-size:13.5px;font-weight:600;color:var(--text);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;outline:none;transition:border-color .15s}.sort-select:focus{border-color:var(--accent)}.view-toggle{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:3px;gap:2px}.view-btn{width:28px;height:28px;border-radius:999px;border:none;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s}.view-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.video-grid{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(var(--grid-min),1fr))}.video-grid.list{grid-template-columns:1fr}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s}.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.video-grid.list .card{flex-direction:row}.thumb{position:relative;aspect-ratio:16 / 9;background:var(--thumb-bg);overflow:hidden;flex-shrink:0}.video-grid.list .thumb{width:clamp(200px,32%,300px);aspect-ratio:unset}.thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.card:hover .thumb img{transform:scale(1.035)}.thumb-placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--faint)}.badge-watched{position:absolute;top:8px;left:8px;background:#141414bf;color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;display:flex;align-items:center;gap:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.badge-watched-check{color:#5ad27e}.thumb-like{position:absolute;top:8px;right:8px;width:34px;height:34px;border-radius:999px;background:#14141480;border:none;cursor:pointer;display:grid;place-items:center;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;transform:scale(.88);transition:opacity .2s,transform .2s,background .15s}.card:hover .thumb-like,.thumb-like.liked{opacity:1;transform:scale(1)}.thumb-like.liked svg{color:#ff7c84;color:oklch(.74 .2 18);fill:#ff7c84;fill:oklch(.74 .2 18)}.duration-pill{position:absolute;bottom:8px;right:8px;background:#141414bf;color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:600;padding:3px 7px;border-radius:999px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card-progress-wrap{padding:8px 12px 0;display:flex;flex-direction:column;gap:6px;flex-shrink:0}.card-progress-track{height:4px;background:var(--border);border-radius:999px}.card-progress-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .5s linear}.card-progress-time{font-family:var(--font-mono);font-size:11px;color:var(--faint)}.play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(0,0,0,.18) 0%,transparent 70%);display:grid;place-items:center;opacity:0;transition:opacity .2s}.card:hover .play-overlay{opacity:1}.play-circle{width:56px;height:56px;border-radius:999px;background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;color:#1c1c1c;transform:scale(.88);transition:transform .2s}.card:hover .play-circle{transform:scale(1)}.card-body{padding:var(--card-pad);display:flex;flex-direction:column;gap:9px;flex:1;min-width:0}.card-title{font-size:15px;font-weight:700;letter-spacing:-.015em;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-wrap:pretty;color:var(--text)}.video-grid.list .card-title{font-size:17px}.channel-row{display:flex;align-items:center;gap:7px;min-width:0}.channel-dot{width:18px;height:18px;border-radius:999px;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.channel-name{font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--faint);flex-wrap:wrap}.meta-sep{opacity:.5}.meta-completed{display:flex;align-items:center;gap:4px;color:var(--accent);font-weight:700}.meta-time{font-family:var(--font-mono);font-size:11.5px}.card-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.card-like-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);font-family:var(--font-ui);font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.card-like-btn:hover{background:var(--surface-3)}.card-like-btn.liked{color:#ff7c84;color:oklch(.74 .2 18);border-color:#ff7c8466;border-color:oklch(.74 .2 18 / 40%)}.card-like-btn.liked svg{fill:#ff7c84;fill:oklch(.74 .2 18)}.prog-bar-wrap{height:5px;background:var(--surface-3);border-radius:999px;overflow:hidden}.prog-bar-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .3s}.inline-player{aspect-ratio:16 / 9;background:#000;position:relative}.inline-player iframe{width:100%;height:100%;border:none;display:block}.player-bar{background:var(--surface-2);border-top:1px solid var(--border);padding:8px var(--card-pad);display:flex;justify-content:flex-end}.player-time{font-family:var(--font-mono);font-size:12px;color:var(--muted);white-space:nowrap}.player-track{flex:1;height:5px;background:var(--surface-3);border-radius:999px;overflow:hidden}.player-track-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .5s}.btn-close-player{background:none;border:none;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;padding:0;white-space:nowrap;transition:color .15s}.btn-close-player:hover{color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:var(--scrim);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{width:min(960px,100%);background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden;animation:popIn .26s cubic-bezier(.2,.8,.3,1)}@keyframes popIn{0%{transform:translateY(14px) scale(.97);opacity:0}to{transform:none;opacity:1}}.modal-player-wrap{position:relative;aspect-ratio:16 / 9;background:#000}.modal-player-wrap iframe{width:100%;height:100%;border:none;display:block}.modal-close-btn{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:999px;background:#14141499;border:none;cursor:pointer;display:grid;place-items:center;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s;z-index:1}.modal-close-btn:hover{background:#141414d9}.modal-foot{padding:18px 20px;display:flex;flex-direction:column;gap:10px}.modal-title{font-size:19px;font-weight:700;letter-spacing:-.02em;line-height:1.3}.modal-meta{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.modal-progress-row,.modal-actions{display:flex;align-items:center;gap:10px}.btn-like{height:36px;padding:0 16px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);font-family:var(--font-ui);font-size:13.5px;font-weight:600;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s,color .15s,border-color .15s}.btn-like:hover{background:var(--surface-3)}.btn-like.liked{color:#ff7c84;color:oklch(.74 .2 18);border-color:#ff7c8466;border-color:oklch(.74 .2 18 / 40%)}.btn-like.liked svg{fill:#ff7c84;fill:oklch(.74 .2 18)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:64px 0;max-width:430px;margin:0 auto}.empty-ill{width:96px;height:96px;border-radius:24px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-md);display:grid;place-items:center;color:var(--muted)}.empty-state h2{font-size:20px;font-weight:700;letter-spacing:-.02em}.empty-state p{font-size:14.5px;color:var(--muted);line-height:1.5}.btn-secondary{height:38px;padding:0 18px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-family:var(--font-ui);font-size:13.5px;font-weight:600;color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}.btn-secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}.toast-stack{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:90;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{background:var(--text);color:var(--bg);padding:10px 18px;border-radius:999px;font-size:13.5px;font-weight:600;box-shadow:var(--shadow-lg);pointer-events:auto;display:flex;align-items:center;gap:10px;animation:slideUp .25s cubic-bezier(.2,.8,.3,1);white-space:nowrap}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}.toast-undo{background:none;border:1px solid currentColor;border-radius:999px;padding:2px 10px;font-family:var(--font-ui);font-size:12px;font-weight:700;color:inherit;cursor:pointer;opacity:.75}.toast-undo:hover{opacity:1}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin .7s linear infinite;display:block}.video-page{height:100vh;background:var(--bg);display:flex;flex-direction:column;overflow:hidden}.video-page-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 16px;gap:12px;min-height:0;width:100%}.video-page-player{width:100%;max-width:1400px;aspect-ratio:16 / 9;background:#000;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.video-page-player iframe,.video-page-player>div{width:100%;height:100%}.video-page-info{width:100%;max-width:1400px;display:flex;flex-direction:column;gap:12px}.video-page-title{font-size:clamp(15px,2vw,22px);font-weight:700;letter-spacing:-.02em;line-height:1.3}.video-page-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.video-page-progress{display:flex;flex-direction:column;gap:6px}.video-page-error{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--muted)}@media (prefers-reduced-motion: no-preference){.fade-up{animation:fadeUp .42s cubic-bezier(.2,.8,.3,1) both}@keyframes fadeUp{0%{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}}
