:root{--color-bg-primary: #1a1a2e;--color-bg-secondary: #16213e;--color-bg-surface: #1e2a4a;--color-bg-hover: #253a5e;--color-bg-page: #f0f2f5;--color-bg-card: #ffffff;--color-bg-card-hover: #f8f9fa;--color-bg-overlay: rgba(0, 0, 0, .6);--color-bg-overlay-heavy: rgba(0, 0, 0, .85);--color-text-primary: #222222;--color-text-secondary: #4b5563;--color-text-muted: #6b7280;--color-text-on-dark: #e0e0e0;--color-text-on-dark-secondary: rgba(255, 255, 255, .8);--color-text-on-dark-muted: rgba(255, 255, 255, .65);--color-text-heading: #1f2937;--color-accent: #4f46e5;--color-accent-hover: #4338ca;--color-accent-light: #a5b4fc;--color-accent-lighter: #c7d2fe;--color-accent-bg: #eef2ff;--color-accent-bg-alt: #ede9fe;--color-accent-subtle: #f0f0ff;--color-accent-purple: #c4b5fd;--color-danger: #dc2626;--color-danger-hover: #dc2626;--color-danger-bg: #fef2f2;--color-danger-light: #fca5a5;--color-success: #22c55e;--color-success-bg: #d1fae5;--color-success-dark: #065f46;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-warning-dark: #78350f;--color-today-bg: #fffbeb;--color-today-border: #fde68a;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--color-border-input: #d1d5db;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-2xs: .65rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-icon: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .08);--shadow-md: 0 2px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .16);--shadow-xl: 0 12px 40px rgba(0, 0, 0, .2);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .3);--shadow-player: 0 24px 80px rgba(0, 0, 0, .6);--tap-target-min: 44px;--header-height: 56px;--bottom-nav-height: 56px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--ease-out-smooth: cubic-bezier(.16, 1, .3, 1)}[data-theme=dark]{--color-bg-primary: #0f172a;--color-bg-secondary: #111c33;--color-bg-surface: #1b2742;--color-bg-hover: #243356;--color-bg-page: #0b1220;--color-bg-card: #162033;--color-bg-card-hover: #1d2a42;--color-bg-overlay: rgba(0, 0, 0, .75);--color-bg-overlay-heavy: rgba(0, 0, 0, .92);--color-text-primary: #e5e7eb;--color-text-secondary: #a3acbd;--color-text-muted: #9aa5b8;--color-text-on-dark: #e5e7eb;--color-text-on-dark-secondary: rgba(229, 231, 235, .82);--color-text-on-dark-muted: rgba(229, 231, 235, .62);--color-text-heading: #f3f4f6;--color-accent: #818cf8;--color-accent-hover: #a5b4fc;--color-accent-light: #c7d2fe;--color-accent-lighter: #3b3f73;--color-accent-bg: #1e2344;--color-accent-bg-alt: #241e44;--color-accent-subtle: #1a1d3a;--color-accent-purple: #a78bfa;--color-danger: #f87171;--color-danger-hover: #ef4444;--color-danger-bg: #3a1414;--color-danger-light: #fca5a5;--color-success: #34d399;--color-success-bg: #0f3a28;--color-success-dark: #6ee7b7;--color-warning: #fbbf24;--color-warning-bg: #3a2a10;--color-warning-dark: #fde68a;--color-today-bg: #2a2210;--color-today-border: #78530f;--color-border: #2a3551;--color-border-light: #1f2940;--color-border-input: #3a4866;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .35);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .45);--shadow-md: 0 2px 8px rgba(0, 0, 0, .55);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .6);--shadow-xl: 0 12px 40px rgba(0, 0, 0, .7);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .8);--shadow-player: 0 24px 80px rgba(0, 0, 0, .9)}[data-theme=dark] .home-lane--resume,[data-theme=dark] .home-lane--today{--home-lane-surface: #1d2a42;--home-lane-border: #2a3551;--home-lane-header-bg: #1f2940;--home-lane-header-border: #2a3551;--home-lane-header-hover: #243356;--home-lane-label: #e5e7eb;--home-lane-icon: #a3acbd;--home-lane-badge-bg: #e5e7eb;--home-lane-badge-fg: #162033;--home-lane-hint: #7a8598;--home-lane-rail-scrollbar: #2a3551}.home-lane--resume,.home-lane--today{--home-lane-surface: #f8f9fa;--home-lane-border: var(--color-border);--home-lane-header-bg: #eef1f5;--home-lane-header-border: var(--color-border);--home-lane-header-hover: #e5e7eb;--home-lane-label: var(--color-text-primary);--home-lane-icon: var(--color-text-secondary);--home-lane-badge-bg: var(--color-text-primary);--home-lane-badge-fg: var(--color-bg-card);--home-lane-hint: var(--color-text-muted);--home-lane-rail-scrollbar: var(--color-border)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,video{display:block;max-width:100%}button{cursor:pointer;font:inherit;border:none;background:none}input,textarea,select{font:inherit;color:var(--color-text-primary);background-color:var(--color-bg-card)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}option{color:var(--color-text-primary);background-color:var(--color-bg-card)}body{font-family:var(--font-family);background:var(--color-bg-page);color:var(--color-text-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:var(--radius-full)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.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}.header{background:var(--color-bg-primary);color:#fff;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0003}.header h1{font-size:var(--font-size-2xl);font-weight:700;letter-spacing:.5px;display:flex;align-items:center;gap:8px}.header-logo{width:32px;height:32px;border-radius:6px}.header-left{display:flex;align-items:center;gap:24px}.btn-user{background:transparent;border:1px solid rgba(255,255,255,.25);color:#ffffffd9;padding:5px 12px;border-radius:var(--radius-full);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);white-space:nowrap}.login-subtitle{font-size:var(--font-size-base);color:#888;font-weight:400;text-align:center;margin-bottom:28px}.login-error{background:#fff0f0;color:#c0392b;border:1px solid #f5c6cb;border-radius:8px;padding:10px 14px;font-size:var(--font-size-sm)}.login-toggle{margin-top:20px;text-align:center;font-size:var(--font-size-sm);color:#666}.link-btn{background:none;border:none;color:#4a90d9;cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.link-btn:hover{color:#2b6cb0}.header-search input{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-right:none;border-radius:10px 0 0 10px;color:#fff;padding:10px 18px;font-size:var(--font-size-base);outline:none;width:360px;transition:background .2s,border-color .2s}.header-search button{background:#ffffff2e;border:1px solid rgba(255,255,255,.2);border-radius:0 10px 10px 0;color:#fff;padding:10px 20px;font-size:var(--font-size-base);cursor:pointer;transition:background .2s;white-space:nowrap}.header-search button:disabled{opacity:.4;cursor:default}main{max-width:1200px;margin:0 auto;padding:24px 20px 96px}.app{min-height:100vh}.bottom-nav,.fab-wrap{display:none}.header{background:var(--color-bg-primary);color:#fff;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0003}.header h1{font-size:var(--font-size-xl);font-weight:700;letter-spacing:.5px;display:flex;align-items:center;gap:8px;white-space:nowrap}.header-logo{width:28px;height:28px;border-radius:6px}.header-left{display:flex;align-items:center;gap:22px}.header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.header-actions{display:flex;align-items:center;gap:10px}.header-dropdown-wrap{position:relative}.header-dropdown-layer{display:contents}.header-dropdown-backdrop{position:fixed;inset:0;z-index:10}.header-dropdown{position:absolute;top:calc(100% + 6px);left:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;z-index:11;padding:var(--space-1);animation:modalScaleIn .15s cubic-bezier(.34,1.56,.64,1)}.header-dropdown-right{left:auto;right:0}.header-dropdown>button{display:block;width:100%;text-align:left;padding:10px 14px;border:none;background:none;font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.header-dropdown>button:hover{background:var(--color-accent-bg);color:var(--color-accent)}.guun-mascot{flex:none;display:inline-flex;width:58px;height:46px;cursor:pointer;animation:guun-bob .9s ease-in-out infinite}.guun-svg{width:100%;height:100%;overflow:visible}.guun-fwing{transform-box:fill-box;animation:guun-flap .45s ease-in-out infinite}.guun-fwing-l{transform-origin:100% 50%}.guun-fwing-r{transform-origin:0% 50%}.guun-fwing-r{animation-name:guun-flap-r}.guun-mascot:hover{animation-duration:.5s}.guun-mascot:hover .guun-fwing{animation-duration:.25s}@keyframes guun-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes guun-flap{0%,to{transform:rotate(14deg)}50%{transform:rotate(-20deg)}}@keyframes guun-flap-r{0%,to{transform:rotate(-14deg)}50%{transform:rotate(20deg)}}@media(prefers-reduced-motion:reduce){.guun-mascot,.guun-fwing{animation:none}.guun-mascot{transform:none}}.guun-player{flex:none;display:inline-flex;width:50px;height:40px}.guun-psvg{width:100%;height:100%;overflow:visible}.guun-pfront{transform-box:fill-box;transform-origin:50% 100%;animation:guun-groove .62s ease-in-out infinite}@keyframes guun-groove{0%{transform:rotate(-5deg) translateY(0)}25%{transform:rotate(0) translateY(-2px)}50%{transform:rotate(5deg) translateY(0)}75%{transform:rotate(0) translateY(-2px)}to{transform:rotate(-5deg) translateY(0)}}.guun-note{fill:#7c6ff0;font-size:30px;font-weight:700}.guun-note1{animation:guun-note-rise 1.8s ease-in infinite}.guun-note2{animation:guun-note-rise 1.8s ease-in .9s infinite}@keyframes guun-note-rise{0%{opacity:0;transform:translateY(6px)}25%{opacity:.95}to{opacity:0;transform:translateY(-30px)}}@media(prefers-reduced-motion:reduce){.guun-pfront{animation:none}.guun-note{display:none}}.btn-compact{padding:6px 14px;font-size:var(--font-size-sm)}.btn-user{background:transparent;border:1px solid rgba(255,255,255,.25);color:#ffffffd9;min-height:var(--tap-target-min);padding:4px 10px 4px 5px;border-radius:var(--radius-full);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);white-space:nowrap;display:inline-flex;align-items:center;gap:8px}.btn-user:hover{background:#ffffff1a;border-color:#fff6}.user-info{display:flex;align-items:center;gap:8px;padding-left:12px;border-left:1px solid rgba(255,255,255,.2)}.user-name{font-size:var(--font-size-sm);color:#fffc}.btn-stream{background:#4f46e54d;border:1px solid rgba(165,180,252,.5);color:#e0e7ff;padding:5px 14px;border-radius:var(--radius-full);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);white-space:nowrap;flex-shrink:0}.btn-stream:hover{background:#4f46e566;transform:scale(1.03)}.stream-section{margin-bottom:20px}.stream-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.stream-history-list{display:flex;flex-direction:column;gap:6px}.stream-history-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--color-bg-card-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:default;transition:background var(--transition-fast)}.stream-history-item:hover{background:var(--color-accent-bg)}.stream-history-thumb{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.stream-history-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.stream-history-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stream-history-channel{font-size:var(--font-size-xs);color:var(--color-text-muted)}.stream-history-remove{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;padding:8px;border-radius:var(--radius-sm);flex-shrink:0;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.stream-history-remove:hover{color:var(--color-danger)}.btn-logout{background:transparent;border:1px solid rgba(255,255,255,.3);color:#ffffffb3;padding:4px 10px;border-radius:6px;font-size:var(--font-size-sm);cursor:pointer;transition:background .15s,color .15s}.btn-logout:hover{background:#ffffff1f;color:#fff}.btn-link-google{background:transparent;border:1px solid rgba(255,255,255,.3);color:#ffffffb3;padding:4px 10px;border-radius:6px;font-size:var(--font-size-sm);cursor:pointer;transition:background .15s,color .15s}.btn-link-google:hover{background:#ffffff1f;color:#fff}.link-msg{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:10px 20px;border-radius:8px;font-size:var(--font-size-sm);box-shadow:0 4px 12px #0000004d;cursor:pointer;z-index:9999}@keyframes toastSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#fff;box-shadow:var(--shadow-lg);cursor:pointer;pointer-events:auto;animation:toastSlideIn .3s var(--ease-out-back);max-width:360px}.toast-exit{animation:toastSlideOut .3s ease-in forwards}.toast-success{background:var(--color-success-dark)}.toast-error{background:var(--color-danger-hover)}.toast-info{background:var(--color-bg-primary)}.toast-icon{font-size:var(--font-size-base);flex-shrink:0;width:20px;text-align:center}.toast-message{flex:1;line-height:var(--line-height-tight)}.login-overlay{min-height:100vh;background:var(--color-bg-page);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:var(--color-bg-card);border-radius:16px;box-shadow:0 4px 24px #0000001a;padding:40px 36px;width:100%;max-width:380px}.login-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-heading);display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:4px}.login-logo{width:34px;height:34px;border-radius:8px}.login-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);font-weight:400;text-align:center;margin-bottom:28px}.login-form{display:flex;flex-direction:column;gap:16px}.login-error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-light);border-radius:8px;padding:10px 14px;font-size:var(--font-size-sm)}.password-input-wrap{display:flex;align-items:stretch}.password-input-wrap input{border-top-right-radius:0;border-bottom-right-radius:0}.password-toggle-btn{min-width:56px;padding:0 12px;border:1px solid var(--color-border-input);border-left:none;border-radius:0 8px 8px 0;background:var(--color-bg-card-hover);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer}.password-toggle-btn:hover:not(:disabled){color:var(--color-text-primary);background:var(--color-bg-card)}.password-toggle-btn:disabled{cursor:not-allowed;color:var(--color-text-muted)}.login-hint{margin-top:6px;color:var(--color-text-muted);font-size:var(--font-size-xs)}.login-btn{width:100%;padding:12px;font-size:var(--font-size-base);margin-top:4px}.login-toggle{margin-top:20px;text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.link-btn{background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.link-btn:hover{color:var(--color-accent)}.header-search{display:flex;align-items:center;gap:0}.header-search input{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-right:none;border-radius:10px 0 0 10px;color:#fff;padding:8px 14px;font-size:var(--font-size-sm);outline:none;width:100%;max-width:360px;transition:background .2s,border-color .2s}.header-search input::placeholder{color:#ffffff73}.header-search input:focus{background:#ffffff2e;border-color:#fff6}.header-search button{background:#ffffff2e;border:1px solid rgba(255,255,255,.2);border-radius:0 10px 10px 0;color:#fff;padding:8px 14px;font-size:var(--font-size-sm);cursor:pointer;transition:background .2s;white-space:nowrap}.header-search button:hover:not(:disabled){background:#ffffff47}.header-search button:disabled{background:#ffffff1f;color:#ffffff9e;cursor:default}.tab-nav{display:flex;gap:4px}.tab{background:transparent;color:#ffffffa6;border:none;border-radius:6px;padding:6px 16px;font-size:var(--font-size-sm);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast);position:relative}.tab:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--color-accent-light);border-radius:1px;transition:width .25s cubic-bezier(.4,0,.2,1),left .25s cubic-bezier(.4,0,.2,1)}.tab:hover{color:#fff;background:#ffffff1a}.tab.active{color:#fff;background:#ffffff26;font-weight:600}.tab.active:after{width:60%;left:20%}main{max-width:1200px;margin:0 auto;padding:24px 16px}@keyframes btnPulse{0%,to{opacity:.7}50%{opacity:1}}.btn-primary{background:var(--color-accent);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.btn-primary:hover{background:var(--color-text-primary)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{background:var(--color-bg-card-hover);color:var(--color-text-muted);cursor:not-allowed;animation:none}.btn-secondary{background:var(--color-bg-card);color:var(--color-accent);border:1px solid var(--color-accent);border-radius:8px;padding:8px 16px;font-size:var(--font-size-sm);cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--color-bg-card-hover)}.btn-secondary:active{transform:scale(.97)}.btn-secondary:disabled{background:var(--color-bg-card-hover);border-color:var(--color-border);color:var(--color-text-muted);cursor:not-allowed}.btn-danger{background:var(--color-danger);color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:var(--font-size-sm);cursor:pointer}.btn-danger:hover{background:var(--color-danger-hover)}.filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filters input,.filters select{border:1px solid var(--color-border-input);border-radius:8px;padding:8px 12px;font-size:var(--font-size-sm);background:var(--color-bg-card);color:var(--color-text-primary);outline:none}.filters input::placeholder{color:var(--color-text-muted)}.filters input:focus,.filters select:focus{border-color:var(--color-accent)}.filters input{min-width:220px}.filter-fields{display:contents}.mobile-filter-toggle{display:none}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.empty{text-align:center;color:var(--color-text-muted);padding:60px 0;font-size:var(--font-size-base)}.load-error{display:flex;align-items:center;justify-content:center;gap:var(--space-3);min-height:120px;padding:var(--space-4);color:var(--color-text-secondary);text-align:center}@media(max-width:480px){.load-error{flex-direction:column}}.video-card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s;position:relative;cursor:default}.video-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.video-card:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:3px}.video-thumbnail{position:relative;width:100%;aspect-ratio:16/9;background:#000;overflow:hidden;border-radius:12px 12px 0 0}.video-thumbnail img{width:100%;height:100%;object-fit:cover}.video-thumbnail a{display:block;width:100%;height:100%}.play-btn{position:absolute;inset:0;width:100%;height:100%;background:#0000;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-icon);color:transparent;transition:background .2s,color .2s}.video-thumbnail:hover .play-btn{background:#00000073;color:#fff}@media(hover:none){.play-btn{background:#0000002e;color:#ffffffeb}}@keyframes playerFadeIn{0%{opacity:0}to{opacity:1}}@keyframes playerSlideIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes playerLaunchArt{0%{opacity:1;transform:scale(.94)}58%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.035)}}.player-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px;animation:playerFadeIn .2s ease-out}.player-container{background:#000;border-radius:var(--radius-lg);overflow:hidden;position:relative;width:100%;max-width:1280px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;box-shadow:var(--shadow-player);animation:playerSlideIn .3s cubic-bezier(.16,1,.3,1)}.player-launch-art{position:absolute;inset:0;z-index:70;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px;pointer-events:none;background:#000000b8;color:#fff;text-align:center;animation:playerLaunchArt 1.15s cubic-bezier(.16,1,.3,1) forwards}.player-launch-avatar{width:clamp(84px,12vw,132px);aspect-ratio:1;border-radius:50%;overflow:hidden;display:grid;place-items:center;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);box-shadow:0 18px 44px #00000061;color:#fffffff0;font-size:clamp(32px,5vw,56px);font-weight:var(--font-weight-semibold)}.player-launch-avatar img{width:100%;height:100%;object-fit:cover}.player-launch-channel{max-width:min(420px,82vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.player-launch-title{max-width:min(520px,82vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#ffffffb8;font-size:var(--font-size-sm)}@media(prefers-reduced-motion:reduce){.player-launch-art{display:none}}.player-session-bar{display:flex;align-items:center;gap:12px;flex-shrink:0;padding:6px 10px 6px 14px;font-size:var(--font-size-xs);line-height:1.35}.player-session-context{display:flex;align-items:center;gap:8px;min-width:0;max-width:32%}.player-session-kind{font-weight:700;text-transform:none;letter-spacing:.02em;flex-shrink:0}.player-session-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:240px}.player-session-title{min-width:0;font-size:var(--font-size-sm);font-weight:600}.player-session-progress{margin-left:auto;flex-shrink:0;border-radius:999px;font-weight:600;font-variant-numeric:tabular-nums}.player-session-progress~.player-session-progress{margin-left:0}.player-resume-bar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--player-surface-raised);color:var(--player-text);font-size:var(--font-size-sm);border-top:1px solid var(--player-border);border-bottom:1px solid var(--player-border)}.player-resume-text{font-variant-numeric:tabular-nums;font-weight:600}.player-resume-restart{margin-left:auto;flex-shrink:0;padding:4px 12px;border-radius:999px;background:var(--player-surface);color:var(--player-text);border:1px solid var(--player-border);font-size:var(--font-size-xs);font-weight:600;cursor:pointer}.player-resume-restart:hover{background:var(--player-surface-raised);border-color:var(--player-text-secondary)}.player-resume-dismiss{flex-shrink:0;background:transparent;border:none;color:var(--player-text-secondary);font-size:14px;line-height:1;cursor:pointer;padding:2px 4px}.player-body{display:flex;flex:1;overflow:hidden;min-height:0;position:relative}.player-main{flex:1;min-width:0;display:flex;flex-direction:column}.player-sidebar{width:300px;flex-shrink:0;background:var(--color-bg-primary);border-left:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;overflow:hidden;transition:width .3s cubic-bezier(.4,0,.2,1)}.player-sidebar-ai-stack{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.player-sidebar-ai-stack[hidden]{display:none!important}.player-sidebar-layout-spacer{display:none}@media(min-width:769px){.player-sidebar-layout-spacer{display:block;flex:0 0 300px;width:300px;min-width:300px;pointer-events:none}}.player-sidebar.ai-open{width:480px}@keyframes playerAiBackdropIn{0%{opacity:0}to{opacity:1}}.player-ai-backdrop-mobile{display:none}@media(max-width:768px){.player-ai-backdrop-mobile{display:block;position:fixed;top:0;left:0;right:0;bottom:60vh;z-index:45;margin:0;padding:0;border:none;cursor:pointer;background:#0000006b;animation:playerAiBackdropIn .22s ease-out}@media(prefers-reduced-motion:reduce){.player-ai-backdrop-mobile{animation:none}}}.player-ai-backdrop-desktop{display:none}@media(min-width:769px){.player-sidebar{transition:none}.player-ai-backdrop-desktop{display:block;position:absolute;inset:0;z-index:14;margin:0;padding:0;border:none;cursor:pointer;background:#0000006b;animation:playerAiBackdropIn .25s ease-out}@media(prefers-reduced-motion:reduce){.player-ai-backdrop-desktop{animation:none}}.player-sidebar.ai-open{position:absolute;top:0;right:0;bottom:0;width:min(480px,100%)!important;flex-shrink:0;z-index:15;overflow:hidden;border-radius:12px 0 0 12px;box-shadow:-12px 0 32px #0000008c;border-left:1px solid rgba(255,255,255,.1)}.player-sidebar.ai-open:before{content:"";position:absolute;left:10px;top:50%;transform:translateY(-50%);width:4px;height:40px;border-radius:2px;background:#ffffff4d;pointer-events:none;z-index:2}.player-sidebar.ai-open .ai-panel-header{padding-left:22px}}@media(prefers-reduced-motion:reduce){.player-sidebar{transition:none}}.sidebar-tabs{display:flex;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-tab{flex:1;padding:10px 6px;background:none;border:none;border-bottom:2px solid transparent;color:#ffffff73;font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:color .2s ease,border-color .25s ease,background .2s ease;white-space:nowrap}.sidebar-tab:hover{color:#fffc;background:#ffffff0a}.sidebar-tab.active{color:#fff;border-bottom-color:var(--color-accent-light);background:#a5b4fc0f}.player-title{color:#fff;font-size:var(--font-size-base);font-weight:600;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex:1;margin:0}.player-study-btn{min-height:var(--tap-target-min);padding:0 14px;border:1px solid var(--player-border, var(--color-border-input));border-radius:var(--radius-md);background:var(--player-surface-raised, var(--color-bg-card-hover));color:var(--player-text-secondary, var(--color-text-secondary));font-size:var(--font-size-sm);font-weight:600;cursor:pointer;white-space:nowrap}.player-more-trigger{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:var(--tap-target-min);padding:0 12px;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-md);background:#ffffff1a;color:#ddd;font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.player-more-trigger:hover,.player-more-trigger[aria-expanded=true]{background:#fff3;color:#fff}.player-more-overlay{position:fixed;inset:0;z-index:1400;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.player-more-backdrop{position:absolute;inset:0;border:0;background:#0000008c}.player-more-panel{position:relative;width:min(360px,100%);max-height:min(560px,calc(100dvh - 32px));overflow:hidden;border:1px solid var(--player-border, var(--color-border));border-radius:var(--radius-lg);background:var(--player-surface, var(--color-bg-card));color:var(--player-text, var(--color-text-primary));box-shadow:var(--shadow-lg)}.player-more-panel-header{display:flex;align-items:center;justify-content:space-between;min-height:52px;padding:6px 8px 6px 16px;border-bottom:1px solid var(--player-border, var(--color-border))}.player-more-panel-header h2{margin:0;font-size:var(--font-size-base)}.player-more-panel-close{display:inline-flex;align-items:center;justify-content:center;width:var(--tap-target-min);height:var(--tap-target-min);border:0;border-radius:var(--radius-md);background:transparent;color:var(--player-text-secondary, var(--color-text-secondary));cursor:pointer}.player-more-panel-content{display:grid;gap:4px;padding:8px;overflow-y:auto}.player-more-panel-content button{display:flex;align-items:center;gap:8px;min-height:var(--tap-target-min);padding:0 12px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--player-text-secondary, var(--color-text-secondary));font:inherit;text-align:left;cursor:pointer}.player-more-panel-content button:hover,.player-more-panel-content button:focus-visible,.player-more-panel-close:hover,.player-more-panel-close:focus-visible{background:var(--player-surface-raised, var(--color-bg-card-hover));color:var(--player-text, var(--color-text-primary))}.player-more-panel-content svg{flex-shrink:0}.player-float-btn{background:#ffffff1a;border:none;color:#ccc;font-size:var(--font-size-sm);cursor:pointer;padding:4px 10px;border-radius:6px;transition:background .15s}.player-float-btn:hover{background:#fff3;color:#fff}.player-keyboard-help-btn{background:#ffffff1a;border:none;color:#ccc;font-size:var(--font-size-base);cursor:pointer;padding:4px 10px;border-radius:6px;transition:background .15s;line-height:1}.player-keyboard-help-btn:hover{background:#fff3;color:#fff}.player-sleep-btn{display:inline-flex;align-items:center;gap:6px;background:#ffffff1a;border:none;color:#ccc;font-size:var(--font-size-sm);cursor:pointer;padding:5px 10px;border-radius:6px;white-space:nowrap;transition:background .15s,color .15s;line-height:1}.player-sleep-btn svg{display:block;flex-shrink:0}.player-sleep-btn:hover{background:#fff3;color:#fff}.player-sleep-btn.active{background:var(--color-text-primary);color:var(--color-bg-card)}.player-sleep-remaining{font-variant-numeric:tabular-nums;font-weight:600;font-size:var(--font-size-xs);padding:2px 6px;border-radius:var(--radius-full);background:#00000040;color:#fff}.player-sleep-overlay{position:fixed;inset:0;z-index:1200;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px}.player-sleep-menu{width:100%;max-width:340px;background:var(--color-bg-card);border-radius:16px;padding:20px;box-shadow:var(--shadow-modal)}.player-sleep-title{display:flex;align-items:center;gap:8px;font-size:var(--font-size-lg);font-weight:700;margin-bottom:4px;color:var(--color-text-primary)}.player-sleep-title svg{color:var(--color-text-primary)}.player-sleep-label{font-size:var(--font-size-xs);font-weight:700;letter-spacing:.02em;color:var(--color-text-secondary);margin:16px 0 8px}.player-sleep-options{display:flex;flex-wrap:wrap;gap:8px}.player-sleep-opt{min-height:var(--tap-target-min);padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.player-sleep-opt.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.player-sleep-clear{min-height:var(--tap-target-min);margin-top:10px;width:100%;padding:8px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer}.player-sleep-clear:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.player-sleep-dim-btn{min-height:var(--tap-target-min);width:100%;padding:10px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:#111827;color:#f3f4f6;font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.player-sleep-note{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.5;margin-top:12px}.player-sleep-foot{display:flex;justify-content:flex-end;margin-top:14px}.player-dim{position:fixed;inset:0;z-index:1300;border:none;background:#000;color:#ffffff80;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer}.player-dim-timer{font-size:2rem;font-weight:300;color:#ffffff59;font-variant-numeric:tabular-nums}.player-dim-hint{font-size:var(--font-size-sm);color:#ffffff40}@keyframes playerKeyboardHintIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.player-keyboard-hint{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:4;pointer-events:none;padding:12px 22px;border-radius:10px;background:#000000d1;color:#fff;font-size:var(--font-size-lg);font-weight:600;letter-spacing:.02em;border:1px solid rgba(255,255,255,.12);box-shadow:0 8px 32px #00000073;animation:playerKeyboardHintIn .18s ease-out}@media(prefers-reduced-motion:reduce){.player-keyboard-hint{animation:none}}.player-list-end-backdrop{position:fixed;inset:0;z-index:225;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:20px;animation:playerFadeIn .15s ease-out}.player-list-end-panel{background:var(--color-bg-primary);border-radius:12px;max-width:400px;width:100%;padding:20px 22px 22px;box-shadow:0 16px 48px #0000008c;border:1px solid rgba(255,255,255,.1)}.player-list-end-panel h3{margin:0 0 10px;font-size:var(--font-size-base);font-weight:600;color:#fff}.player-list-end-desc{margin:0 0 18px;font-size:var(--font-size-sm);line-height:1.55;color:#ffffffb3}.player-review-actions{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:0 0 var(--space-4);padding:var(--space-3);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);background:#ffffff0d}.player-review-label{color:#ffffffb3;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);white-space:nowrap}.player-review-chip{min-height:var(--tap-target-min);padding:0 12px;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-full);background:#ffffff14;color:#ffffffe6;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer}.player-review-chip:hover,.player-review-chip:focus-visible{background:#ffffff24;border-color:#ffffff4d}.player-list-end-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.player-list-end-btn{min-height:40px}.player-keyboard-help-backdrop{position:fixed;inset:0;z-index:220;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:20px;animation:playerFadeIn .15s ease-out}.player-keyboard-help-panel{background:var(--color-bg-primary);border-radius:12px;max-width:420px;width:100%;max-height:min(85vh,520px);overflow:auto;box-shadow:0 16px 48px #0000008c;border:1px solid rgba(255,255,255,.1)}.player-keyboard-help-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid rgba(255,255,255,.08)}.player-keyboard-help-header h3{margin:0;font-size:var(--font-size-base);font-weight:600;color:#fff}.player-keyboard-help-close{min-width:var(--tap-target-min);min-height:var(--tap-target-min);background:none;border:none;color:#aaa;font-size:var(--font-size-lg);cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1}.player-keyboard-help-close:hover{color:#fff;background:#ffffff14}.player-keyboard-help-note{margin:0;padding:12px 16px;font-size:var(--font-size-xs);line-height:1.55;color:#ffffffa6;border-bottom:1px solid rgba(255,255,255,.06)}.player-keyboard-help-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.player-keyboard-help-table th{text-align:left;font-weight:600;color:var(--color-accent-light);padding:8px 10px 8px 16px;vertical-align:top;white-space:nowrap;width:1%}.player-keyboard-help-table td{padding:8px 16px 8px 8px;color:#ffffffe0;line-height:1.45}.player-keyboard-help-table tr:not(:last-child) th,.player-keyboard-help-table tr:not(:last-child) td{border-bottom:1px solid rgba(255,255,255,.06)}.player-close{background:#ffffff14;border:1px solid rgba(255,255,255,.14);color:#ffffffdb;font-size:var(--font-size-xl);cursor:pointer;min-width:var(--tap-target-min);min-height:var(--tap-target-min);padding:0;margin-left:4px;flex-shrink:0;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;line-height:1;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.player-close:hover,.player-close:focus-visible{background:#ffffff29;border-color:#ffffff4d;color:#fff}@keyframes floatingSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.floating-player{position:fixed;bottom:20px;right:20px;width:320px;background:var(--color-bg-primary);color:var(--color-text-on-dark);border-radius:12px;box-shadow:0 8px 32px #00000080;overflow:hidden;z-index:200;animation:floatingSlideIn .3s cubic-bezier(.16,1,.3,1)}.floating-player-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#ffffff14;gap:8px}.floating-player-title{color:var(--color-text-on-dark);font-size:var(--font-size-xs);font-weight:600;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex:1}.floating-player-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.floating-player-expand,.floating-player-close{background:transparent;border:1px solid transparent;color:var(--color-text-on-dark-secondary);font-size:var(--font-size-base);cursor:pointer;min-width:34px;min-height:34px;padding:0;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center}.floating-player-expand:hover,.floating-player-close:hover,.floating-player-expand:focus-visible,.floating-player-close:focus-visible{color:#fff;background:#ffffff24;border-color:#ffffff47}.floating-player-video{position:relative;width:100%;aspect-ratio:16/9}.floating-player-video>div{position:absolute;inset:0}.floating-player-video iframe{display:block;width:100%;height:100%;border:none}.player-iframe-wrap{position:relative;width:100%;aspect-ratio:16/9}.player-iframe-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}.player-below{display:flex;align-items:center;gap:var(--space-3);padding:8px 12px;border-top:1px solid var(--player-border, var(--color-border));background:var(--player-surface, var(--color-bg-card))}.player-title--below{display:none}.player-below-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);width:100%}.player-more-setting{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);min-height:var(--tap-target-min);padding:0 12px;color:var(--player-text-secondary, var(--color-text-secondary));font-size:var(--font-size-sm);font-weight:600}.player-more-setting .player-rate-select{min-width:76px}.player-more-panel-content button.active{background:var(--player-text, var(--color-text-primary));color:var(--player-bg, var(--color-bg-card))}.player-more-panel-content .player-setting-action{justify-content:space-between}.player-setting-state{flex-shrink:0;min-width:44px;padding:3px 8px;border:1px solid var(--player-border, var(--color-border));border-radius:999px;background:var(--player-surface-raised, var(--color-bg-card-hover));color:var(--player-text-muted, var(--color-text-muted));font-size:var(--font-size-xs);font-weight:600;text-align:center}.player-setting-state.active{border-color:var(--player-text, var(--color-text-primary));background:var(--player-text, var(--color-text-primary));color:var(--player-bg, var(--color-bg-card))}.btn-user-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-avatar{--user-avatar-color: #374151;--user-avatar-color-2: #4b5563;--user-avatar-color-l: #aeb6c0;--user-avatar-color-d: #232a33;--user-avatar-rgb: 55, 65, 81;display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:800;line-height:1}.user-avatar--gradient,.user-avatar--squircle{background:linear-gradient(140deg,var(--user-avatar-color-2),var(--user-avatar-color));box-shadow:0 2px 8px #0000002e,inset 0 0 0 1px #fff3}.user-avatar--squircle{border-radius:30%}.user-avatar--glossy{background:radial-gradient(circle at 33% 26%,var(--user-avatar-color-2),var(--user-avatar-color) 60%,var(--user-avatar-color-d));box-shadow:0 3px 9px #0000003d,inset 0 1px 2px #ffffff73}.user-avatar--tint{background:rgba(var(--user-avatar-rgb),.18);color:var(--user-avatar-color-d);box-shadow:inset 0 0 0 1.5px rgba(var(--user-avatar-rgb),.36);text-shadow:none}[data-theme=dark] .user-avatar--tint{background:rgba(var(--user-avatar-rgb),.3);color:var(--user-avatar-color-l);box-shadow:inset 0 0 0 1.5px rgba(var(--user-avatar-rgb),.5)}.user-avatar--mono{background:var(--color-text-primary);color:var(--color-bg-card);box-shadow:inset 0 0 0 1px #7f7f7f2e;text-shadow:none}.user-avatar--ring{background:var(--color-bg-card);color:var(--user-avatar-color);box-shadow:inset 0 0 0 2px var(--user-avatar-color);text-shadow:none}[data-theme=dark] .user-avatar--ring{color:var(--user-avatar-color-l);box-shadow:inset 0 0 0 2px var(--user-avatar-color-2)}.user-avatar--cjk{font-weight:700}.user-avatar--sm{width:32px;height:32px;font-size:var(--font-size-sm)}.user-avatar--sm.user-avatar--cjk{font-size:15px}.user-avatar--md{width:42px;height:42px;font-size:var(--font-size-base)}.user-avatar--md.user-avatar--cjk{font-size:18px}.user-avatar--lg{width:64px;height:64px;font-size:var(--font-size-xl)}.user-avatar--lg.user-avatar--cjk{font-size:26px}.header-user-summary{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:4px;border-bottom:1px solid var(--color-border-light)}.header-user-summary>div{display:grid;min-width:0}.header-user-summary strong,.header-user-summary span:not(.user-avatar){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-user-summary strong{color:var(--color-text-primary);font-size:var(--font-size-sm)}.header-user-summary span:not(.user-avatar){color:var(--color-text-muted);font-size:var(--font-size-xs)}.player-more-panel-content button:disabled{cursor:not-allowed;opacity:.58}.player-radio-caption{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:8px 12px;border-top:1px solid var(--player-border, var(--color-border));background:var(--player-surface-raised, var(--color-bg-card-hover));color:var(--player-text, var(--color-text-primary))}.player-radio-caption-copy{min-width:0;display:flex;align-items:baseline;gap:var(--space-2)}.player-radio-label{flex-shrink:0;font-size:var(--font-size-xs);font-weight:700}.player-radio-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--player-text-secondary, var(--color-text-secondary));font-size:var(--font-size-sm)}.player-radio-caption button{flex-shrink:0;min-height:var(--tap-target-min);padding:0 10px;border:1px solid var(--player-border, var(--color-border));border-radius:var(--radius-md);background:transparent;color:var(--player-text-secondary, var(--color-text-secondary));cursor:pointer}.player-below-bookmark{display:inline-flex;align-items:center;justify-content:center;gap:5px;min-height:var(--tap-target-min);padding:4px 14px;border-radius:var(--radius-md);border:1px solid var(--player-text);background:var(--player-text);color:var(--player-bg);font-size:var(--font-size-sm);font-weight:700;white-space:nowrap;cursor:pointer;transition:opacity .12s}.player-below-bookmark:hover:not(:disabled){opacity:.85}.player-below-bookmark:disabled{opacity:.6;cursor:not-allowed}.player-close--bar{display:inline-flex}.status-badge{position:absolute;top:8px;right:8px;padding:3px 8px;border-radius:12px;font-size:var(--font-size-xs);font-weight:600;border:1px solid transparent}.status-badge-clickable{cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),transform .1s}.status-badge-clickable:hover{transform:scale(1.05)}.status-unwatched{background:var(--color-bg-card-hover);color:var(--color-text-secondary);border-color:var(--color-border)}.status-watching{background:var(--color-bg-card);color:var(--color-text-primary);border-color:var(--color-text-secondary)}.status-watched{background:var(--color-text-primary);color:var(--color-bg-card);border-color:var(--color-text-primary)}.video-info{padding:12px 14px}.video-info h3{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-heading);margin-bottom:6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.channel-name-label{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:4px}.video-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}.tag{background:var(--color-border-light);color:var(--color-text-secondary);border-radius:4px;padding:2px 7px;font-size:var(--font-size-xs)}.summary-badge{background:var(--color-accent-bg);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:4px;padding:2px 7px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.category-label{background:var(--color-accent-bg-alt);color:#5b21b6;border-radius:4px;padding:2px 7px;font-size:var(--font-size-xs);font-weight:600}.video-memo{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:10px;white-space:pre-wrap;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.video-summary-preview{margin:0 0 8px;color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.45;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.btn-resume{display:inline-flex;align-items:center;gap:4px;width:100%;margin-bottom:6px;padding:5px 10px;background:linear-gradient(135deg,#1e40af,#3b82f6);color:#fff;border:none;border-radius:6px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:opacity .15s}.btn-resume:hover{opacity:.85}.video-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:var(--space-1)}.video-ai-btn{min-height:34px;padding:0 12px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card-hover);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.video-ai-btn:hover,.video-ai-btn:focus-visible{background:var(--color-bg-page);border-color:var(--color-border-input)}.video-menu-wrap{position:relative;margin-left:auto}.video-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:28px;border:none;background:transparent;color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-lg);font-weight:700;letter-spacing:2px;transition:background var(--transition-fast),color var(--transition-fast)}.video-menu-btn:hover{background:var(--color-border-light);color:var(--color-text-secondary)}.video-menu{position:absolute;bottom:calc(100% + 4px);right:0;background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;z-index:50;padding:var(--space-1);animation:modalScaleIn .15s cubic-bezier(.34,1.56,.64,1)}.video-menu button{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:9px 12px;border:none;background:none;font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.video-menu button:hover{background:var(--color-accent-bg);color:var(--color-accent)}.video-menu button:hover svg{color:var(--color-accent)}.video-menu button svg{flex-shrink:0;color:var(--color-text-muted)}.video-menu-danger{color:var(--color-danger)!important}.video-menu-danger:hover{background:var(--color-danger-bg)!important}.video-menu-danger svg{color:var(--color-danger)!important}.video-menu-back{color:var(--color-text-muted)!important;font-size:var(--font-size-xs)!important;padding:6px 12px!important;border-bottom:1px solid var(--color-border-light)!important;border-radius:0!important;margin-bottom:2px}.video-menu-msg{padding:8px 12px;font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center}.video-action-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:6px;cursor:pointer;transition:background .15s,color .15s;padding:0}.video-action-icon:hover{background:var(--color-border-light);color:var(--color-accent)}.video-action-delete:hover{background:var(--color-danger-bg);color:var(--color-danger)}.video-actions select{border:1px solid var(--color-border-input);border-radius:6px;padding:4px 8px;font-size:var(--font-size-sm);background:var(--color-bg-card);cursor:pointer;flex:1}.playlist-add-wrap{position:relative}.playlist-dropdown{position:absolute;bottom:calc(100% + 4px);right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:160px;z-index:100;overflow:hidden}.playlist-dropdown button{display:block;width:100%;text-align:left;padding:8px 14px;font-size:var(--font-size-sm);background:none;border:none;cursor:pointer;color:#222}.playlist-dropdown button:hover{background:var(--color-border-light)}.playlist-dropdown-empty,.playlist-dropdown-msg{padding:8px 14px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.playlist-view{display:flex;flex-direction:column;gap:0;background:transparent}.playlist-list-panel,.playlist-detail-panel{background:var(--color-bg-card);border-radius:12px;padding:20px;box-shadow:0 1px 4px #00000014}.playlist-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.playlist-panel-header h2{font-size:var(--font-size-base);font-weight:700}.playlist-create-form{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding:12px;background:var(--color-bg-card-hover);border-radius:8px}.playlist-create-form input{border:1px solid var(--color-border-input);border-radius:6px;padding:7px 10px;font-size:var(--font-size-sm);outline:none}.playlist-create-form input:focus{border-color:var(--color-accent)}.playlist-form-actions{display:flex;gap:8px;justify-content:flex-end}.playlist-items{list-style:none;display:flex;flex-direction:column;gap:6px}.playlist-list-item{padding:10px 12px;border-radius:8px;border:1px solid var(--color-border);cursor:pointer;transition:background .15s;display:flex;flex-direction:column;gap:4px}.playlist-list-item:hover{background:var(--color-bg-card-hover)}.playlist-list-item.active{background:var(--color-bg-card-hover);border-color:var(--color-text-secondary)}.playlist-list-item-info{display:flex;justify-content:space-between;align-items:center}.playlist-list-item-name{font-weight:600;font-size:var(--font-size-sm)}.playlist-list-item-count{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.playlist-list-item-desc{font-size:var(--font-size-xs);color:var(--color-text-muted)}.playlist-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.playlist-detail-header h2{font-size:var(--font-size-lg);font-weight:700}.playlist-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:4px}.playlist-play-controls{display:flex;align-items:center;gap:12px;flex-shrink:0}.reverse-toggle{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:var(--color-text-heading);cursor:pointer;-webkit-user-select:none;user-select:none}.reverse-toggle input{cursor:pointer}.drag-handle{cursor:grab;color:var(--color-text-muted);font-size:var(--font-size-xl);padding:4px 6px;flex-shrink:0;line-height:1;border-radius:var(--radius-sm);transition:color var(--transition-fast),transform var(--transition-fast),background var(--transition-fast)}.drag-handle:hover{color:var(--color-accent);transform:scale(1.15);background:var(--color-accent-bg)}.drag-handle:active{cursor:grabbing;color:var(--color-accent);transform:scale(1.2)}.playlist-video-list{display:flex;flex-direction:column;gap:8px}.playlist-video-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;background:var(--color-bg-card-hover)}.playlist-video-num{width:24px;text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-shrink:0}.playlist-video-item img{width:80px;aspect-ratio:16/9;object-fit:cover;border-radius:4px;flex-shrink:0}.playlist-video-info{flex:1}.playlist-video-title{font-size:var(--font-size-sm);font-weight:500}.playlist-name{font-size:var(--font-size-xs);color:var(--color-accent-light);display:block;margin-bottom:2px}.playlist-sidebar-header{padding:10px 14px;color:#ccc;font-size:var(--font-size-sm);font-weight:600;border-bottom:1px solid #333}.playlist-sidebar-list{overflow-y:auto;flex:1}.playlist-item{display:flex;gap:8px;padding:8px 10px;cursor:pointer;transition:background .15s}.playlist-item img{width:60px;aspect-ratio:16/9;object-fit:cover;border-radius:3px;flex-shrink:0}.playlist-item-info{display:flex;flex-direction:column;gap:3px}.playlist-sidebar-list .playlist-item-num{font-size:var(--font-size-xs)}.playlist-sidebar-list .playlist-item-title{font-size:var(--font-size-xs);line-height:1.3}.playlist-item-watched{align-self:center;flex-shrink:0;min-width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-success);color:#fff;font-size:var(--font-size-xs);font-weight:700}.player-container--today-queue .player-session-bar{padding:5px 12px;gap:8px;font-size:var(--font-size-2xs)}.player-container--today-queue .player-session-progress{padding:1px 8px}.player-container--today-queue .sidebar-tabs .sidebar-tab{padding:6px 4px;font-size:var(--font-size-2xs)}.player-container--today-queue .playlist-controls{padding:6px 12px;gap:10px}.player-container--today-queue .playlist-sidebar-list .playlist-item{gap:6px;padding:5px 8px}.player-container--today-queue .playlist-sidebar-list .playlist-item img{width:48px;border-radius:2px}.player-container--today-queue .playlist-sidebar-list .playlist-item-info{gap:2px}.player-container--today-queue .playlist-sidebar-list .playlist-item-num{font-size:var(--font-size-2xs)}.player-container--today-queue .playlist-sidebar-list .playlist-item-title{font-size:var(--font-size-2xs);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.player-container--today-queue .player-notes-section{padding:8px 10px 10px}.player-container--today-queue .player-notes-header{margin-bottom:6px}.player-container--today-queue .player-notes-title{font-size:var(--font-size-xs)}.player-container--today-queue .player-note-add-btn{padding:3px 8px;font-size:var(--font-size-2xs)}.playlist-controls{display:flex;align-items:center;justify-content:center;gap:20px;padding:10px 16px;background:var(--color-bg-primary)}.playlist-controls .btn-secondary{background:#ffffff1a;color:#fff;border-color:#fff3}.playlist-controls .btn-secondary:hover{background:#fff3}.playlist-controls .btn-secondary:disabled{background:#ffffff14;color:#ffffff9e;border-color:#ffffff1f;cursor:default}.playlist-progress{color:#aaa;font-size:var(--font-size-sm)}@media(min-width:769px){.playlist-controls .playlist-progress{display:none}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:900;padding:16px;animation:overlayFadeIn .2s ease-out}.modal{background:var(--color-bg-card);border-radius:16px;padding:24px;width:100%;max-width:560px;box-shadow:var(--shadow-modal);animation:modalScaleIn .25s cubic-bezier(.34,1.56,.64,1)}.confirm-dialog{max-width:360px}.confirm-dialog-message{font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1.6;word-break:break-word}.confirm-dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.confirm-dialog-danger{min-height:var(--tap-target-min);padding:0 16px;background:var(--color-danger);border:none;color:#fff;font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:background .15s}.confirm-dialog-danger:hover{background:var(--color-danger-hover)}.modal h2{font-size:var(--font-size-xl);margin-bottom:20px;color:var(--color-text-heading)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px}.modal-header h2{min-width:0;margin:0}.modal-close{flex-shrink:0;min-width:var(--tap-target-min);min-height:var(--tap-target-min);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card-hover);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-lg);line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.modal-close:hover,.modal-close:focus-visible{background:var(--color-bg-page);border-color:var(--color-border-input);color:var(--color-text-primary)}.settings-overlay{z-index:1400}.settings-modal{width:min(520px,100%);max-height:min(720px,calc(100dvh - 32px));overflow:auto;border:1px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-bg-card);box-shadow:var(--shadow-modal);animation:modalScaleIn .2s ease-out}.settings-modal-header{position:sticky;top:0;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);padding:20px 22px 16px;border-bottom:1px solid var(--color-border-light);background:var(--color-bg-card)}.settings-modal-header h2{margin:0;color:var(--color-text-heading);font-size:var(--font-size-xl)}.settings-modal-header p{margin:3px 0 0;color:var(--color-text-muted);font-size:var(--font-size-sm)}.settings-form{display:grid}.settings-section{display:grid;gap:var(--space-3);padding:20px 22px;border-bottom:1px solid var(--color-border-light)}.settings-section h3{margin:0;color:var(--color-text-heading);font-size:var(--font-size-sm)}.settings-profile-preview{display:flex;align-items:center;gap:var(--space-3)}.settings-profile-preview>div{display:grid;min-width:0;gap:3px}.settings-profile-preview strong{overflow:hidden;color:var(--color-text-primary);font-size:var(--font-size-lg);text-overflow:ellipsis;white-space:nowrap}.settings-profile-preview span:not(.user-avatar){color:var(--color-text-muted);font-size:var(--font-size-sm)}.settings-field{display:grid;gap:7px;color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600}.settings-field input,.settings-field select{width:100%;min-height:var(--tap-target-min);padding:9px 12px;border:1px solid var(--color-border-input);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text-primary);font:inherit;outline:none}.settings-field input:focus,.settings-field select:focus{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-accent-bg)}.settings-field small{color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:400}.settings-hint{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm);line-height:1.5}.settings-choice{min-width:0;margin:0;padding:0;border:0}.settings-choice legend{margin-bottom:7px;color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600}.settings-choice>div{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;border-radius:var(--radius-md);background:var(--color-bg-page)}.settings-choice button{min-height:40px;border:0;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm)}.settings-choice button.active{background:var(--color-text-primary);color:var(--color-bg-card);box-shadow:var(--shadow-xs)}.settings-avatar>.settings-avatar-styles{grid-template-columns:repeat(auto-fit,minmax(56px,1fr))}.settings-avatar .settings-avatar-style{display:flex;flex-direction:column;align-items:center;gap:6px;min-height:0;padding:8px 4px}.settings-avatar .settings-avatar-style span:not(.user-avatar){font-size:var(--font-size-xs);color:var(--color-text-secondary)}.settings-avatar .settings-avatar-style.active{background:var(--color-bg-card-hover);box-shadow:inset 0 0 0 2px var(--color-text-primary)}.settings-avatar .settings-avatar-style.active span:not(.user-avatar){color:var(--color-text-primary);font-weight:600}.settings-avatar>.settings-avatar-colors{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.settings-avatar .settings-avatar-color{width:32px;height:32px;min-height:32px;padding:0;border-radius:50%;background:var(--swatch, var(--color-bg-card));box-shadow:inset 0 0 0 1px #00000026}.settings-avatar .settings-avatar-color.active{box-shadow:0 0 0 2px var(--color-bg-card),0 0 0 4px var(--color-text-primary)}.settings-avatar .settings-avatar-color--auto{width:auto;min-width:56px;height:32px;padding:0 12px;border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--font-size-sm);box-shadow:inset 0 0 0 1px var(--color-border)}.settings-avatar .settings-avatar-color--auto.active{background:var(--color-text-primary);color:var(--color-bg-card);box-shadow:none}.settings-error{margin:16px 22px 0;padding:10px 12px;border-radius:var(--radius-md);background:var(--color-danger-bg);color:var(--color-danger);font-size:var(--font-size-sm)}.settings-actions{position:sticky;bottom:0;display:flex;justify-content:flex-end;gap:var(--space-2);padding:16px 22px;background:var(--color-bg-card)}.settings-actions button{min-height:var(--tap-target-min);padding-inline:18px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:600;margin-bottom:6px;color:var(--color-text-heading)}.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid var(--color-border-input);border-radius:8px;padding:9px 12px;font-size:var(--font-size-sm);outline:none;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-accent)}.form-group textarea{resize:vertical;min-height:80px}.url-row{display:flex;gap:8px}.url-row input{flex:1}.thumbnail-preview{margin-top:10px;border-radius:8px;overflow:hidden;aspect-ratio:16/9;background:#000}.thumbnail-preview img{width:100%;height:100%;object-fit:cover}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.error-msg{color:var(--color-danger);font-size:var(--font-size-sm);margin-top:4px}.fetching-label{color:var(--color-accent);font-size:var(--font-size-sm);font-weight:400;margin-left:6px}.play-count-badge{position:absolute;bottom:6px;left:6px;background:#000000b3;color:#fff;font-size:var(--font-size-xs);padding:2px 6px;border-radius:4px}.btn-queue-active{background:var(--color-success-bg);color:var(--color-success-dark);border:1px solid var(--color-success);border-radius:6px;padding:5px 10px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-queue-active:hover{background:#fde8e8;color:#991b1b;border-color:var(--color-danger-light)}.modal-wide{max-width:780px}.ai-study-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border-light)}.ai-study-heading{min-width:0;flex:1}.ai-study-header h2{margin:0 0 4px}.ai-study-title{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ai-study-meta{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);min-height:var(--tap-target-min);margin:var(--space-2) 0}.ai-study-usage{flex-shrink:0;padding:5px 10px;border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);background:var(--color-bg-page);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);font-variant-numeric:tabular-nums;white-space:nowrap}.ai-quality-toggle{flex-shrink:0;min-height:var(--tap-target-min);padding:5px 11px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);cursor:pointer}.ai-quality-toggle.active{border-color:var(--color-text-primary);background:var(--color-text-primary);color:var(--color-bg-card)}.ai-quality-toggle:disabled{cursor:wait;opacity:.6}.ai-study-tabs{display:flex;gap:3px;padding:3px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-page);margin-bottom:var(--space-4)}.ai-study-tab{flex:1;min-height:var(--tap-target-min);padding:7px 14px;background:transparent;border:none;border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.ai-study-tab:hover{color:var(--color-text-primary);background:var(--color-bg-card-hover)}.ai-study-tab.active{background:var(--color-text-primary);color:var(--color-bg-card);font-weight:var(--font-weight-semibold)}.ai-study-body{max-height:60vh;overflow-y:auto}.ai-panel{display:flex;flex-direction:column;gap:var(--space-3)}.ai-panel-controls{display:flex;flex-wrap:wrap;gap:8px;align-items:center;background:var(--color-bg-card);border-bottom:1px solid var(--color-border)}.ai-length-group{display:inline-flex;background:var(--color-bg-page);border-radius:var(--radius-full);padding:2px;border:1px solid var(--color-border)}.ai-length-btn{display:inline-flex;align-items:center;justify-content:center;min-height:var(--tap-target-min);padding:4px 14px;font-size:var(--font-size-xs);color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.ai-length-btn.active{background:var(--color-text-primary);color:var(--color-bg-card);font-weight:var(--font-weight-medium)}.ai-length-btn:disabled{color:var(--color-text-muted);cursor:not-allowed}.ai-inline-field{display:inline-flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.ai-inline-field select{padding:4px 8px;border:1px solid var(--color-border-input);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm)}.ai-panel-content{padding:var(--space-4);background:var(--color-bg-page);border-radius:var(--radius-md);border:1px solid var(--color-border-light);line-height:1.7;color:var(--color-text-primary)}.ai-panel-empty{padding:var(--space-6);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);background:var(--color-bg-page);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.ai-panel-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0;text-align:right}.ai-question-panel{min-height:420px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-page);overflow:hidden}.ai-question-panel .ai-chat{min-height:420px;max-height:60vh}.ai-question-panel .ai-chat-messages{padding:var(--space-4);gap:var(--space-3);background:var(--color-bg-page)}.ai-question-panel .ai-chat-context-hint,.ai-question-panel .ai-chat-daily-usage{color:var(--color-text-secondary);background:var(--color-bg-card);border-bottom-color:var(--color-border);padding-inline:var(--space-3)}.ai-question-panel .ai-chat-empty,.ai-question-panel .ai-chat-ref-time,.ai-question-panel .ai-message-meta{color:var(--color-text-secondary)}.ai-question-panel .ai-chat-empty{padding:var(--space-5) var(--space-3);gap:var(--space-2)}.ai-question-panel .ai-chat-empty-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;margin-bottom:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:0}.ai-question-panel .ai-chat-empty p{margin:0;color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.ai-question-panel .ai-chat-empty-hint{color:var(--color-text-muted)!important;font-weight:var(--font-weight-normal)!important}.ai-question-panel .ai-message-user .ai-message-bubble{background:var(--color-text-primary);border-color:var(--color-text-primary);color:var(--color-bg-card);border-radius:14px}.ai-question-panel .ai-message-assistant .ai-message-bubble{background:var(--color-bg-card);border-color:var(--color-border);color:var(--color-text-primary);border-radius:14px}.ai-question-panel .ai-message-assistant .ai-message-bubble h1,.ai-question-panel .ai-message-assistant .ai-message-bubble h2,.ai-question-panel .ai-message-assistant .ai-message-bubble h3,.ai-question-panel .ai-message-assistant .ai-message-bubble strong{color:var(--color-text-primary)}.ai-question-panel .ai-message-assistant .ai-message-bubble blockquote,.ai-question-panel .ai-stale-incomplete-hint{color:var(--color-text-secondary)}.ai-question-panel .ai-message-assistant .ai-message-bubble blockquote{border-left-color:var(--color-border)}.ai-question-panel .ai-message-assistant .ai-message-bubble th,.ai-question-panel .ai-message-assistant .ai-message-bubble td{border-color:var(--color-border)}.ai-question-panel .ai-message-assistant .ai-message-bubble th,.ai-question-panel .ai-message-assistant .ai-message-bubble pre,.ai-question-panel .ai-message-assistant .ai-message-bubble code{background:var(--color-bg-page)}.ai-question-panel .ai-md-term{text-decoration-color:var(--color-border)}.ai-question-panel .ai-md-term:hover{color:var(--color-text-primary)}.ai-question-panel .ai-bubble-icon{color:var(--color-text-muted)}.ai-question-panel .ai-bubble-icon:hover:not(:disabled){color:var(--color-text-primary);background:var(--color-bg-card-hover)}.ai-question-panel .ai-bubble-icon.saved,.ai-question-panel .ai-bubble-icon.playing,.ai-question-panel .ai-bubble-icon.loading,.ai-question-panel .ai-message-time,.ai-question-panel .ai-chat-ref-time-mark{color:var(--color-text-primary)}.ai-question-panel .ai-thinking{color:var(--color-text-secondary);font-style:normal}.ai-question-panel .ai-thinking-dots span,.ai-question-panel .ai-cursor{background:var(--color-text-primary)}.ai-question-panel .ai-message-bubble.ai-streaming{border-left-color:var(--color-text-primary);animation:none}.ai-question-panel .ai-chat-input-area{background:var(--color-bg-card);border-top-color:var(--color-border);padding:var(--space-3);gap:var(--space-2)}.ai-question-panel .ai-chat-textarea{background:var(--color-bg-page);border-color:var(--color-border-input);border-radius:var(--radius-md);color:var(--color-text-primary)}.ai-question-panel .ai-chat-textarea:focus{border-color:var(--color-text-primary)}.ai-question-panel .ai-chat-textarea::placeholder{color:var(--color-text-muted)}.ai-question-panel .ai-chat-textarea:disabled{color:var(--color-text-muted)}.ai-question-panel .ai-chat-send{background:var(--color-text-primary);color:var(--color-bg-card);border:1px solid var(--color-text-primary);border-radius:var(--radius-md);box-shadow:none;transform:none}.ai-question-panel .ai-chat-send:hover:not(:disabled){filter:none;transform:none;background:var(--color-text-primary)}.ai-question-panel .ai-chat-send:disabled{background:var(--color-bg-card-hover);border-color:var(--color-border);color:var(--color-text-muted)}.ai-question-panel .ai-chat-stop{background:var(--color-danger-bg);border-color:var(--color-danger-light);border-radius:var(--radius-md);color:var(--color-danger)}.ai-question-panel .ai-chat-stop:hover{background:var(--color-danger-bg)}.ai-question-panel .ai-chip,.ai-question-panel .ai-term-ask-btn{background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-secondary)}.ai-question-panel .ai-suggest-chips{padding-inline:var(--space-2)}.ai-question-panel .ai-chip{white-space:normal;max-width:100%;text-align:center;box-shadow:none;transform:none}.ai-question-panel .ai-chip:hover,.ai-question-panel .ai-term-ask-btn:hover{background:var(--color-bg-card-hover);border-color:var(--color-border);color:var(--color-text-primary);transform:none}.ai-question-panel .ai-save-prompt{background:var(--color-bg-card);border-color:var(--color-border);border-radius:var(--radius-md)}.ai-question-panel .ai-save-prompt-btn{background:var(--color-text-primary);border:1px solid var(--color-text-primary);border-radius:var(--radius-md);color:var(--color-bg-card)}.ai-question-panel .ai-save-prompt-btn:hover{background:var(--color-text-primary)}.ai-question-panel .ai-save-prompt-dismiss{color:var(--color-text-muted)}.ai-question-panel .ai-save-prompt-dismiss:hover{color:var(--color-text-primary)}.ai-question-panel .ai-chat-textarea:focus-visible,.ai-question-panel .ai-chat-send:focus-visible,.ai-question-panel .ai-chat-stop:focus-visible,.ai-question-panel .ai-chip:focus-visible,.ai-question-panel .ai-term-ask-btn:focus-visible,.ai-question-panel .ai-bubble-icon:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:2px}@media(max-width:640px){.modal.modal-wide{display:flex;flex-direction:column;height:calc(100dvh - 16px);max-height:calc(100dvh - 16px);overflow:hidden;padding:16px}.modal.modal-wide .ai-study-header,.modal.modal-wide .ai-study-meta,.modal.modal-wide .ai-study-tabs{flex-shrink:0}.modal.modal-wide .ai-study-body{flex:1;min-height:0;max-height:none;overflow-y:auto}.ai-study-header{gap:var(--space-2)}.ai-study-heading{min-width:0}.ai-study-meta{margin-block:var(--space-1) var(--space-2)}.ai-study-usage{margin-right:auto;padding-inline:0;border:0;background:transparent}.ai-study-tab{min-height:var(--tap-target-min);padding-inline:10px}.ai-question-panel,.ai-question-panel .ai-chat{min-height:0;height:100%}}.recommendation-chip,.header .tab,.header .btn-user,.home-lane-header-toggle,.home-lane-rail-dismiss,.status-badge-clickable,.btn-today-thumb,.player-rate-select,.player-study-btn,.player-more-trigger,.player-more-panel-content button,.player-list-end-btn{min-height:var(--tap-target-min)}.home-lane-rail-dismiss,.btn-today-thumb,.header .tab{min-width:var(--tap-target-min)}.add-video-purpose{margin:calc(var(--space-2) * -1) 0 var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5}.add-video-error{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin:var(--space-3) 0}.add-video-error .error-msg{margin:0}.ai-generation-status{margin:var(--space-3) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.ai-generation-error{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin:var(--space-3) 0}.ai-generation-error .error-msg{margin:0}.player-rate-select,.player-study-btn,.player-more-trigger{border-radius:var(--radius-md);border-color:var(--player-border, var(--color-border-input))}.today-more-menu{position:relative}.today-more-menu>summary{display:inline-flex;align-items:center;justify-content:center;min-height:var(--tap-target-min);padding:0 var(--space-3);border:1px solid var(--color-border-input);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;list-style:none}.today-more-menu>summary::-webkit-details-marker{display:none}.today-more-menu-popover{position:absolute;top:calc(100% + var(--space-2));right:0;z-index:30;display:grid;min-width:170px;padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);box-shadow:var(--shadow-lg)}.bottom-nav-add{color:var(--color-text-on-dark)}.bottom-nav-add-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--color-text-on-dark);color:var(--color-bg-primary);font-size:var(--font-size-lg);font-weight:700;line-height:1}.today-more-menu-popover button{min-height:var(--tap-target-min);padding:0 var(--space-3);border:0;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-primary);text-align:left;cursor:pointer}.today-more-menu-popover button:hover,.today-more-menu-popover button:focus-visible{background:var(--color-bg-card-hover)}@media(min-width:769px){.video-grid{grid-template-columns:repeat(auto-fit,minmax(280px,350px))!important;justify-content:center}}@media(max-width:768px){.player-close--bar,.player-resume-restart,.player-resume-dismiss,.player-rate-select,.player-below-bookmark,.player-study-btn,.player-more-trigger,.player-note-add-btn{min-height:46px!important}.player-close--bar,.player-resume-dismiss{min-width:46px!important}}@media(max-width:768px){.player-close--bar,.player-resume-restart,.player-resume-dismiss,.player-rate-select,.player-below-bookmark,.player-study-btn,.player-more-trigger,.player-note-add-btn{min-height:46px}.player-close--bar,.player-resume-dismiss{min-width:46px}}@media(max-width:768px){.add-video-item-btn,.yt-video-add-btn,.btn-stream{min-width:var(--tap-target-min);min-height:var(--tap-target-min);width:var(--tap-target-min);height:var(--tap-target-min)}}.quiz-list{display:flex;flex-direction:column;gap:var(--space-4)}.quiz-item{padding:var(--space-4);background:var(--color-bg-page);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.quiz-question{margin:0 0 var(--space-3) 0;font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1.5}.quiz-choices{display:flex;flex-direction:column;gap:6px}.quiz-choice{text-align:left;padding:10px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.quiz-choice:hover:not(:disabled){background:var(--color-accent-bg);border-color:var(--color-accent-light)}.quiz-choice.selected{background:var(--color-accent-bg);border-color:var(--color-accent)}.quiz-choice.correct{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success-dark)}.quiz-choice.wrong{background:var(--color-danger-bg);border-color:var(--color-danger)}.quiz-choice:disabled{cursor:default}.quiz-explanation{margin:var(--space-3) 0 0 0;padding:10px 14px;background:var(--color-warning-bg);border-left:3px solid var(--color-warning);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5}.quiz-submit{align-self:center;min-width:200px}.quiz-result{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-accent-bg);border-radius:var(--radius-md)}.quiz-score{margin:0;font-size:var(--font-size-lg);color:var(--color-text-primary)}.flashcard-deck{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-top:var(--space-4)}.flashcard-progress{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.flashcard{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);width:100%;min-height:180px;padding:var(--space-6) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);color:var(--color-text-primary);text-align:center;cursor:pointer;transition:background .12s,border-color .12s}.flashcard:hover{background:var(--color-bg-card-hover);border-color:var(--color-text-secondary)}.flashcard.flipped{border-color:var(--color-text-secondary)}.flashcard-side{font-size:var(--font-size-xs);font-weight:700;letter-spacing:.08em;color:var(--color-text-secondary)}.flashcard-text{font-size:var(--font-size-lg);line-height:1.6;white-space:pre-wrap}.flashcard-hint{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.flashcard-nav{display:flex;gap:var(--space-2);width:100%}.flashcard-nav .btn-secondary{flex:1}.add-video-modal{max-width:620px;height:82vh;height:82dvh;padding:var(--space-6);display:flex;flex-direction:column;overflow:hidden}.add-video-modal .search-input-row{flex-shrink:0;margin-bottom:var(--space-3)}.add-video-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 var(--space-3) 0;flex-shrink:0}.add-video-header h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0}.add-video-fetching{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-muted);flex-shrink:0}.add-video-results{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-2);min-height:0;padding:var(--space-2) 0}.add-video-item{border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast);flex-shrink:0}.add-video-item:hover{border-color:var(--color-accent-light)}.add-video-item.registered{opacity:1}.add-video-item.expanded{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.add-video-item-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);cursor:pointer;transition:background var(--transition-fast);min-height:56px}.add-video-item-row:hover{background:var(--color-bg-card-hover)}.add-video-item.registered .add-video-item-row{cursor:default}.add-video-item-thumb{width:80px;height:45px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;background:var(--color-border-light)}.add-video-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.add-video-item-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.add-video-item-channel{font-size:var(--font-size-xs);color:var(--color-text-muted)}.add-video-item-registered{font-size:var(--font-size-xs);color:var(--color-success);flex-shrink:0;padding:var(--space-1) var(--space-2)}.add-video-item-btn{width:var(--tap-target-min);height:var(--tap-target-min);border-radius:50%;border:1.5px solid var(--color-accent);background:var(--color-bg-card);color:var(--color-accent);font-size:var(--font-size-base);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.add-video-item-btn:hover{background:var(--color-accent);color:#fff}.add-video-item-btn:disabled{background:var(--color-bg-card-hover);border-color:var(--color-border);color:var(--color-text-muted);cursor:not-allowed}.add-video-expand-form{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-light);background:var(--color-accent-bg);animation:modalScaleIn .15s ease-out}.add-video-expand-form .form-group{margin-bottom:var(--space-3)}.add-video-expand-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.add-video-url-result{flex:1;overflow-y:auto;min-height:0}.add-video-url-preview{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0}.add-video-url-preview img{width:120px;height:68px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.add-video-url-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.add-video-url-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.add-video-url-channel{font-size:var(--font-size-xs);color:var(--color-text-muted)}.add-video-url-form{padding-top:var(--space-3);border-top:1px solid var(--color-border-light)}.add-video-url-form .form-group{margin-bottom:var(--space-3)}.search-modal{max-width:900px;height:90vh;height:90dvh;display:flex;flex-direction:column}.search-modal h2,.search-modal .search-input-row{flex-shrink:0}.search-modal-body{flex:1;min-height:0;display:flex;gap:16px;margin-top:4px;overflow:hidden}.search-modal-results{flex:1;min-width:0;min-height:0;overflow-y:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;align-content:start;align-items:start;padding-right:4px}.search-modal-form{width:260px;flex-shrink:0;min-height:0;overflow-y:auto;border-left:1px solid var(--color-border);padding-left:16px}.search-form-hint{height:100%;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:20px}.search-selected-preview--compact{margin-bottom:12px}.search-selected-preview--compact img{width:80px}.search-preview-wrap{margin-bottom:12px}.search-preview-thumb{position:relative;cursor:pointer;border-radius:8px;overflow:hidden;aspect-ratio:16/9;background:#000}.search-preview-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .15s}.search-preview-thumb:hover img{opacity:.7}.search-preview-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-3xl);color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.7);opacity:0;transition:opacity .15s}.search-preview-thumb:hover .search-preview-play-overlay{opacity:1}.search-selected-meta{margin-top:8px;display:flex;flex-direction:column;gap:2px}.search-selected-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-heading);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-player-wrap{margin-bottom:12px}.search-player-wrap iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:8px;display:block}.search-player-btns{display:flex;gap:6px;margin-top:6px}.search-player-btns button{flex:1}.search-register-form{border-top:1px solid var(--color-border);padding-top:12px}.modal-mode-tabs{display:flex;gap:3px;background:var(--color-border-light);border-radius:10px;padding:4px;margin-bottom:20px}.modal-mode-tab{flex:1;border:none;background:transparent;border-radius:7px;padding:8px 12px;font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text-secondary);font-weight:500;transition:all .15s}.modal-mode-tab:hover{color:var(--color-text-heading)}.modal-mode-tab.active{background:var(--color-bg-card);color:var(--color-text-heading);font-weight:700;box-shadow:0 1px 4px #0000001a}.search-section{margin-bottom:16px}.search-input-row{display:flex;gap:8px;margin-bottom:12px}.search-query-input{flex:1;border:1px solid var(--color-border-input);border-radius:8px;padding:9px 12px;font-size:var(--font-size-sm);outline:none;transition:border-color .2s}.search-query-input:focus{border-color:var(--color-accent)}.search-btn{white-space:nowrap;padding:9px 20px}.search-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;max-height:340px;overflow-y:auto;padding:2px;margin-bottom:12px}.search-result-item{cursor:pointer;border-radius:8px;overflow:hidden;border:2px solid transparent;background:var(--color-bg-card-hover);transition:border-color .15s,transform .1s,box-shadow .15s}.search-result-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--color-accent-purple)}.search-result-item.selected{border-color:var(--color-accent);background:var(--color-accent-bg)}.search-result-item img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}.search-result-info{padding:6px 8px 8px}.search-result-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:var(--font-size-xs);font-weight:500;line-height:1.35;margin-bottom:3px;color:var(--color-text-heading)}.search-result-channel{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-selected-preview{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#f0f4ff;border:1px solid var(--color-accent-lighter);border-radius:10px;margin-bottom:16px}.search-selected-preview img{width:100px;aspect-ratio:16/9;object-fit:cover;border-radius:6px;flex-shrink:0}.search-selected-info{display:flex;flex-direction:column;gap:3px;min-width:0}.search-selected-label{font-size:var(--font-size-xs);font-weight:700;color:var(--color-accent);text-transform:uppercase;letter-spacing:.5px}.search-selected-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-heading);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35}.search-selected-channel{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.channel-import-modal{max-width:860px;height:88vh;height:88dvh;display:flex;flex-direction:column;padding:0;overflow:hidden}.channel-import-header{display:flex;align-items:center;justify-content:space-between;padding:20px 28px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.channel-import-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-heading);margin:0}.channel-import-breadcrumb{display:flex;align-items:center;gap:6px;padding:10px 28px;background:var(--color-bg-card-hover);border-bottom:1px solid var(--color-border);flex-shrink:0}.crumb{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted)}.crumb.active{color:var(--color-accent);font-weight:700}.crumb.clickable{color:var(--color-accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.crumb.dim{color:var(--color-border-input)}.crumb-sep{color:var(--color-border-input);font-size:var(--font-size-sm)}.channel-import-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.channel-import-step{display:flex;flex-direction:column;gap:14px;flex:1;min-height:0;overflow-y:auto;padding:20px 28px}.channel-list{display:flex;flex-direction:column;gap:8px}.channel-card{display:flex;align-items:center;gap:14px;width:100%;padding:12px 16px;border:1.5px solid var(--color-border);border-radius:12px;cursor:pointer;background:var(--color-bg-card);color:var(--color-text-primary);font:inherit;text-align:left;transition:border-color .15s,box-shadow .15s,background .15s}.channel-card:hover{border-color:var(--color-accent-light);box-shadow:0 2px 8px #4f46e51a;background:var(--color-bg-card-hover)}.channel-card-thumb{width:52px;height:52px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--color-border)}.channel-card-thumb img{width:100%;height:100%;object-fit:cover}.channel-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-secondary);background:var(--color-border)}.channel-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.channel-card-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-heading)}.channel-card-desc{font-size:var(--font-size-xs);color:var(--color-text-muted);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.channel-card-arrow{color:var(--color-text-muted);font-size:var(--font-size-xl);flex-shrink:0}.channel-selected-bar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--color-border-light);border-radius:10px;flex-shrink:0}.channel-selected-thumb{width:28px;height:28px;border-radius:50%;object-fit:cover}.channel-selected-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-heading);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-import-loading{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:center;padding:20px}.channel-import-loading-center{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--color-text-secondary)}.playlist-list{display:flex;flex-direction:column;gap:6px}.playlist-item-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:10px;cursor:pointer;background:var(--color-bg-card);transition:border-color .15s,background .15s}.playlist-item-row:hover,.playlist-item-uploads{border-color:var(--color-text-secondary);background:var(--color-bg-card-hover)}.playlist-item-uploads:hover{border-color:var(--color-text-primary);background:var(--color-bg-card-hover)}.playlist-item-icon{font-size:var(--font-size-base);color:var(--color-text-secondary);width:20px;text-align:center;flex-shrink:0}.playlist-item-uploads .playlist-item-icon{color:#7c3aed}.playlist-item-info{flex:1;min-width:0}.playlist-item-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-heading);display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.playlist-item-count{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.playlist-item-arrow{color:var(--color-text-muted);font-size:var(--font-size-lg);flex-shrink:0}.channel-import-videos-step{gap:10px}.video-select-controls{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:var(--color-bg-card-hover);border-radius:10px;border:1px solid var(--color-border);flex-shrink:0}.video-select-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.video-select-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-left:4px}.video-select-bulk{display:flex;gap:8px}.bulk-input{flex:1;padding:6px 10px;border:1px solid var(--color-border-input);border-radius:7px;font-size:var(--font-size-sm);outline:none;background:var(--color-bg-card)}.bulk-input:focus{border-color:var(--color-accent-light)}.channel-video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.channel-video-item{cursor:pointer;border-radius:8px;overflow:hidden;border:2px solid transparent;background:var(--color-bg-card-hover);transition:border-color .12s,background .12s}.channel-video-item:hover:not(.already-registered){border-color:var(--color-accent-light)}.channel-video-item.checked{border-color:var(--color-accent);background:var(--color-accent-bg)}.channel-video-item.already-registered{background:var(--color-bg-secondary);border-color:var(--color-border);cursor:default}.channel-video-thumb{position:relative;aspect-ratio:16/9;background:#000}.channel-video-thumb img{width:100%;height:100%;object-fit:cover;display:block}.channel-video-checkbox{position:absolute;top:5px;left:5px;width:20px;height:20px;border-radius:50%;border:2px solid white;background:#00000059;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);color:#fff;font-weight:700;transition:background .12s}.channel-video-checkbox.checked{background:var(--color-accent);border-color:var(--color-accent)}.channel-video-badge{position:absolute;bottom:4px;right:4px;font-size:var(--font-size-2xs);font-weight:700;padding:2px 6px;border-radius:4px;color:#fff}.channel-video-badge.registered{background:#0009}.channel-video-info{padding:5px 7px 7px}.channel-video-title{font-size:var(--font-size-xs);color:var(--color-text-heading);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.channel-load-more{display:flex;justify-content:center;padding:8px 0}.import-result{padding:10px 14px;background:var(--color-success-bg);border:1px solid var(--color-success);border-radius:8px;color:var(--color-success-dark);font-size:var(--font-size-sm);font-weight:600;text-align:center}.playlist-tab-bar{display:flex;gap:0;background:var(--color-bg-card);border-bottom:2px solid var(--color-border);padding:0 24px;flex-shrink:0}.playlist-tab{padding:12px 20px;border:none;background:none;font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.playlist-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.playlist-tab:hover:not(.active){color:var(--color-text-heading)}.playlist-panels-row{display:grid;grid-template-columns:280px 1fr;gap:20px;margin-top:16px;align-items:start}.channel-import-playlist-step{display:flex;flex-direction:column;gap:0;min-height:0;flex:1;overflow:hidden}.channel-import-playlist-step>.channel-selected-bar{margin:12px 28px 0;flex-shrink:0}.yt-video-list-wrap{border-top:1px solid var(--color-border);padding-top:12px}.yt-video-list-loading{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;padding:12px 0}.yt-video-list{display:flex;flex-direction:column;gap:2px}.yt-video-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .1s}.yt-video-row:hover{background:var(--color-border-light)}.yt-video-row.yt-video-row-playing{background:var(--color-accent-bg-alt)}.yt-video-num{font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:20px;text-align:right;flex-shrink:0}.yt-video-thumb-wrap{position:relative;width:96px;flex-shrink:0;aspect-ratio:16/9;border-radius:5px;overflow:hidden;background:#000}.yt-video-thumb-wrap img{width:100%;height:100%;object-fit:cover;display:block}.yt-video-playing-overlay{position:absolute;inset:0;background:#4f46e58c;display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-lg)}.yt-video-title{font-size:var(--font-size-sm);color:var(--color-text-heading);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.yt-video-row-playing .yt-video-title{color:var(--color-accent);font-weight:600}.yt-video-row-registered{opacity:1}.yt-load-more{display:flex;justify-content:center;padding:12px 0 4px}.yt-video-add-btn{margin-left:auto;flex-shrink:0;min-width:var(--tap-target-min);min-height:var(--tap-target-min);width:var(--tap-target-min);height:var(--tap-target-min);border-radius:50%;border:1.5px solid var(--color-accent-light);background:var(--color-bg-card);color:var(--color-accent);font-size:var(--font-size-base);line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.yt-video-add-btn:hover{background:var(--color-text-primary);color:var(--color-bg-card);border-color:var(--color-text-primary)}.channel-filter-row{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 12px;-webkit-overflow-scrolling:touch}.channel-chip{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;max-width:160px;min-height:38px;padding:4px 12px 4px 4px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;white-space:nowrap;transition:border-color .15s,background .15s,color .15s}.channel-chip:first-child{padding-left:14px}.channel-chip:hover{border-color:var(--color-text-secondary)}.channel-chip.active{background:var(--color-text-primary);border-color:var(--color-text-primary);color:var(--color-bg-card)}.channel-chip-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-card-hover);color:var(--color-text-secondary);font-weight:700;font-size:var(--font-size-sm);object-fit:cover}.channel-chip.active .channel-chip-avatar{background:var(--color-bg-card);color:var(--color-text-primary)}.channel-chip-name{overflow:hidden;text-overflow:ellipsis}.subs-view{padding-bottom:16px}.subs-view .btn-primary{background:var(--color-text-primary);color:var(--color-bg-card);border:1px solid var(--color-text-primary);transition:opacity .15s}.subs-view .btn-primary:hover:not(:disabled){background:var(--color-text-primary);opacity:.85}.subs-view .btn-primary:disabled{background:var(--color-bg-card-hover);color:var(--color-text-muted);border-color:var(--color-border)}.subs-channel-bar{display:flex;gap:8px;overflow-x:auto;padding:4px 2px 10px;-webkit-overflow-scrolling:touch}.confirm-dialog-actions button{min-height:var(--tap-target-min)}.subs-channel-toolbar{display:flex;justify-content:flex-end;margin:4px 2px 6px}.subs-channel-chip{flex-shrink:0;display:flex;align-items:center;gap:6px;max-width:180px;padding:4px 10px 4px 4px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);cursor:pointer;transition:border-color .15s,background .15s}.subs-channel-chip.active{border-color:var(--color-text-primary);background:var(--color-text-primary)}.subs-channel-chip.active .subs-channel-name{color:var(--color-bg-card)}.subs-channel-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--color-border-light)}.subs-channel-avatar--ph{display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--color-text-secondary)}.subs-channel-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subs-add-channel-btn{flex-shrink:0;min-height:38px;padding:0 14px;border:1px dashed var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;white-space:nowrap}.subs-add-channel-btn:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.subs-search{margin-bottom:12px}.subs-uploads-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:6px 2px 10px}.subs-uploads-title{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-primary)}.subs-unsub-btn{flex-shrink:0;font-size:var(--font-size-xs);color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);padding:4px 10px;border-radius:var(--radius-md);cursor:pointer}.subs-unsub-btn:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.subs-uploads-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0 2px 10px}.subs-uploads-count{font-size:var(--font-size-xs);font-weight:700;color:var(--color-text-secondary)}.subs-toggle{display:inline-flex;align-items:center;gap:5px;font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.subs-toggle input{accent-color:var(--color-text-primary)}.subs-bulk-add-btn{margin-left:auto;flex-shrink:0;font-size:var(--font-size-xs);font-weight:600;color:var(--color-bg-card);background:var(--color-text-primary);border:1px solid var(--color-text-primary);padding:6px 12px;border-radius:var(--radius-full);cursor:pointer;transition:opacity .15s}.subs-bulk-add-btn:hover:not(:disabled){opacity:.85}.subs-bulk-add-btn:disabled{opacity:.4;cursor:default}.subs-video-row--added{background:var(--color-bg-card-hover);border-color:var(--color-border)}.subs-added-tag{margin-left:auto;flex-shrink:0;font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.subs-add-btn{margin-left:auto;flex-shrink:0;min-height:var(--tap-target-min);padding:0 16px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;cursor:pointer;transition:background .15s,border-color .15s}.subs-add-btn:hover:not(:disabled){background:var(--color-bg-card-hover);border-color:var(--color-text-secondary)}.subs-add-btn:disabled{opacity:.5;cursor:default}.yt-video-registered-text{margin-left:auto;flex-shrink:0;font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-border-light);padding:2px 7px;border-radius:5px;white-space:nowrap}.player-sidebar .yt-video-registered-text{background:#a5b4fc1f;color:#a5b4fc99;border:1px solid rgba(165,180,252,.15);font-size:var(--font-size-2xs);padding:3px 8px}.player-sidebar .yt-video-add-btn{background:transparent;border-color:#a5b4fc66;color:var(--color-accent-light)}.player-sidebar .yt-video-add-btn:hover{background:#a5b4fc33;border-color:var(--color-accent-light);color:#fff}.yt-video-registered-badge{position:absolute;bottom:3px;right:3px;font-size:var(--font-size-2xs);font-weight:700;padding:2px 5px;border-radius:4px;background:#000000a6;color:#fff}.yt-add-modal{width:480px;max-width:95vw;padding:0;display:flex;flex-direction:column}.yt-add-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px;border-bottom:1px solid var(--color-border)}.yt-add-modal-header h2{font-size:var(--font-size-base);font-weight:700;color:var(--color-text-heading);margin:0}.yt-add-preview{display:flex;align-items:center;gap:12px;padding:14px 24px;background:var(--color-bg-card-hover);border-bottom:1px solid var(--color-border)}.yt-add-preview img{width:100px;aspect-ratio:16/9;object-fit:cover;border-radius:6px;flex-shrink:0}.yt-add-preview-title{font-size:var(--font-size-sm);color:var(--color-text-heading);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.yt-add-form{padding:16px 24px 20px;display:flex;flex-direction:column;gap:12px}.yt-new-videos-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--color-success-bg);border:1px solid var(--color-success);border-radius:8px;color:var(--color-success-dark);font-size:var(--font-size-sm);font-weight:600}.btn-sm{font-size:var(--font-size-xs);padding:4px 10px}.home-lane{margin-bottom:24px;padding:0;border-radius:12px;border:1.5px solid var(--home-lane-border);background:var(--home-lane-surface);overflow:hidden}.home-lane--resume{overflow:visible}.home-lane-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--home-lane-header-bg);border-bottom:1px solid var(--home-lane-header-border);border-radius:12px 12px 0 0}.home-lane--today .home-lane-header{transition:background .12s}.home-lane--today .home-lane-header:hover{background:var(--home-lane-header-hover)}.home-lane-header-toggle{display:flex;align-items:center;gap:8px;flex:1;min-width:0;margin:0;padding:0;border:none;background:transparent;font:inherit;color:inherit;text-align:left;cursor:pointer}.home-lane-header-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.home-lane-header-extra{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}.home-lane-icon{font-size:var(--font-size-lg);color:var(--home-lane-icon);flex-shrink:0;filter:grayscale(1)}.home-lane--resume .home-lane-icon{font-size:var(--font-size-sm)}.home-lane-title{font-weight:700;font-size:var(--font-size-lg);letter-spacing:-.01em;color:var(--home-lane-label);flex:1;min-width:0}.home-lane-count{font-size:var(--font-size-sm);background:var(--home-lane-badge-bg);color:var(--home-lane-badge-fg);padding:2px 8px;border-radius:10px;font-weight:700}.home-lane-hint{font-size:var(--font-size-xs);color:var(--home-lane-hint);font-weight:500;white-space:nowrap}.home-lane-toggle{font-size:var(--font-size-xs);color:var(--home-lane-label);margin-left:4px;flex-shrink:0}.home-lane-body--rail{display:flex;gap:12px;padding:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scroll-behavior:smooth}.home-lane-body--rail::-webkit-scrollbar{height:4px}.home-lane-body--rail::-webkit-scrollbar-thumb{background:var(--home-lane-rail-scrollbar);border-radius:2px}.home-lane-rail-card{position:relative;flex:0 0 200px;width:200px;border-radius:8px;overflow:hidden;border:1px solid var(--color-border-light);background:var(--color-bg-card);box-shadow:var(--shadow-sm);scroll-snap-align:start;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.home-lane-rail-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4f46e526}.home-lane-rail-open{display:block;width:100%;padding:0;border:0;background:transparent;color:inherit;text-align:left;cursor:pointer}.home-lane-rail-open:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.home-lane-rail-thumb{display:block;position:relative;aspect-ratio:16/9;overflow:hidden}.home-lane-rail-thumb img{width:100%;height:100%;object-fit:cover}.home-lane-rail-meta{display:flex;align-items:flex-start;gap:6px;min-height:48px;padding:8px 9px 9px}.home-lane-rail-title{flex:1;min-width:0;color:var(--color-text-primary);font-size:var(--font-size-xs);font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-lane-rail-status{flex-shrink:0;padding:2px 5px;border-radius:var(--radius-full);background:var(--color-success-bg);color:var(--color-success-dark);border:1px solid var(--color-success);font-size:10px;font-weight:700;line-height:1.2}.home-lane-rail-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);color:#fff;background:#00000040;opacity:0;transition:opacity .15s;pointer-events:none}.home-lane-rail-card:hover .home-lane-rail-play{opacity:1}.home-lane-rail-time{position:absolute;bottom:4px;right:4px;z-index:2;background:#000000bf;color:#fff;font-size:var(--font-size-xs);padding:1px 5px;border-radius:3px;font-weight:600}.home-lane-rail-dismiss{position:absolute;top:4px;right:4px;z-index:3;width:28px;height:28px;border:none;border-radius:50%;background:#0009;color:#fff;font-size:var(--font-size-xs);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.home-lane-rail-card:hover .home-lane-rail-dismiss{opacity:1}@media(hover:none){.home-lane-rail-play,.home-lane-rail-dismiss{opacity:1}.home-lane-rail-dismiss{min-width:var(--tap-target-min);min-height:var(--tap-target-min);top:2px;right:2px}}.home-lane-rail-dismiss:hover{background:#dc2626cc}.home-lane-rail-dismiss:focus-visible{outline:2px solid #fff;outline-offset:2px}@media(max-width:480px){.home-lane-rail-card{flex:0 0 160px;width:160px}.home-lane-body--rail{gap:8px;padding:12px}}.home-lane-body--grid{padding:16px}.home-lane--today{margin-bottom:16px}.home-lane--today .home-lane-header{padding:8px 12px;gap:6px}.home-lane--today .home-lane-title{font-size:var(--font-size-sm)}.home-lane--today .home-lane-icon{font-size:var(--font-size-base)}.home-lane--today .home-lane-count{font-size:var(--font-size-xs);padding:1px 6px;border-radius:8px}.home-lane--today .home-lane-header-extra{gap:6px}.home-lane--today .home-lane-body--rail{padding:10px 12px}.home-lane--today .home-lane-rail-card:hover{box-shadow:0 4px 12px #f59e0b33}.home-lane--today .today-play-all-btn{padding:3px 10px;font-size:var(--font-size-xs);border-radius:10px}.home-lane--recent{margin-bottom:16px}.home-lane--recent .home-lane-header{padding:10px 14px}.today-suggestions{margin-bottom:24px;padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card)}.today-suggestions-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.today-suggestions-title{margin:0;color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.today-suggestions-desc{margin:3px 0 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.today-suggestions-add{min-height:var(--tap-target-min);padding:0 var(--space-3);border:1px solid var(--color-text-primary);border-radius:var(--radius-md);background:var(--color-text-primary);color:var(--color-bg-card);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;white-space:nowrap}.today-suggestions-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2)}.today-suggestion-item{display:flex;align-items:center;gap:var(--space-2);min-width:0;padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-page);color:var(--color-text-primary);text-align:left;cursor:pointer}.today-suggestion-item:hover,.today-suggestion-item:focus-visible{border-color:var(--color-text-primary)}.today-suggestion-item img{width:56px;height:32px;flex-shrink:0;object-fit:cover;border-radius:var(--radius-sm);background:var(--color-border-light)}.today-suggestion-info{display:flex;flex-direction:column;gap:2px;min-width:0}.today-suggestion-title{overflow:hidden;color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-overflow:ellipsis;white-space:nowrap}.today-suggestion-reason{color:var(--color-text-muted);font-size:var(--font-size-xs)}@media(max-width:768px){.today-suggestions{padding:var(--space-3);border-radius:var(--radius-md)}.today-suggestions-header{align-items:flex-start}.today-suggestions-list{grid-template-columns:1fr}.today-suggestion-item{min-height:54px}}.btn-today-thumb{position:absolute;top:8px;left:8px;width:28px;height:28px;border-radius:50%;border:none;background:#ffffffe0;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;filter:grayscale(1);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast);padding:0;z-index:2;line-height:1}.btn-today-thumb:hover{background:#fff}.btn-today-thumb.active{background:var(--color-text-primary);color:var(--color-bg-card)}.today-play-all-btn{min-height:var(--tap-target-min);padding:4px 13px;font-size:var(--font-size-sm);font-weight:700;border-radius:14px;border:1px solid var(--color-text-primary);background:var(--color-text-primary);color:var(--color-bg-card);cursor:pointer;transition:opacity .12s;white-space:nowrap;flex-shrink:0}.today-play-all-btn:hover{opacity:.85}.today-play-all-btn:disabled{cursor:not-allowed;opacity:.65}.today-audio-btn{min-height:var(--tap-target-min);padding:4px 11px;font-size:var(--font-size-xs);font-weight:700;border-radius:14px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-primary);cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap;flex-shrink:0}.today-audio-btn:hover{border-color:var(--color-text-primary);background:var(--color-bg-card-hover)}.today-audio-btn:disabled{cursor:not-allowed;opacity:.55}.today-clear-all-btn{min-height:var(--tap-target-min);min-width:var(--tap-target-min);padding:4px 10px;font-size:var(--font-size-xs);font-weight:600;border-radius:14px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .12s;white-space:nowrap;flex-shrink:0}.today-clear-all-btn:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.today-leftover-banner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-2);padding:10px 16px;margin-bottom:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card)}.today-leftover-text{font-size:var(--font-size-sm);color:var(--color-text-primary);filter:grayscale(1)}.today-leftover-actions{display:flex;align-items:center;gap:var(--space-3)}.tag-chips-area{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 16px}.tag-chip{padding:3px 10px;border-radius:12px;border:1.5px solid var(--color-border-input);background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-xs);transition:all .12s;line-height:1.3}.tag-chip:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.tag-chip.active{background:var(--color-text-primary);border-color:var(--color-text-primary);color:var(--color-bg-card);font-weight:600}.tag-chip-clear{padding:4px 10px;border-radius:14px;border:1.5px solid var(--color-danger-light);background:var(--color-danger-bg);color:var(--color-danger);cursor:pointer;font-size:var(--font-size-xs);transition:all .12s}.tag-chip-clear:hover{background:var(--color-bg-card-hover)}.tag-match-toggle{display:inline-flex;background:var(--color-bg-page);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:2px;margin-right:6px}.tag-match-btn{padding:3px 12px;font-size:var(--font-size-xs);color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.tag-match-btn.active{background:var(--color-accent);color:#fff;font-weight:var(--font-weight-medium)}.tag-chip-count{display:inline-block;background:#00000014;border-radius:8px;padding:0 5px;font-size:var(--font-size-xs);margin-left:4px;line-height:1.6;font-weight:400}.tag-chip.active .tag-chip-count{background:#ffffff40}.tag-input-wrap{position:relative}.tag-input-field{display:flex;flex-wrap:wrap;gap:5px;align-items:center;padding:6px 10px;border:1.5px solid var(--color-border-input);border-radius:8px;background:var(--color-bg-card);min-height:42px;cursor:text;transition:border-color .15s,box-shadow .15s}.tag-input-field:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.tag-input-pill{display:inline-flex;align-items:center;gap:3px;background:var(--color-accent-bg);color:var(--color-accent-hover);border-radius:12px;padding:2px 8px 2px 10px;font-size:var(--font-size-sm);font-weight:500;white-space:nowrap}.tag-input-pill-remove{background:none;border:none;cursor:pointer;color:var(--color-accent-hover);font-size:var(--font-size-base);min-width:var(--tap-target-min);min-height:var(--tap-target-min);padding:0;line-height:1}.tag-input-pill-remove:hover{color:var(--color-text-primary)}.tag-input-text{border:none;outline:none;flex:1;min-width:100px;font-size:var(--font-size-sm);background:transparent;padding:2px 0}.tag-input-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:200;max-height:200px;overflow-y:auto;list-style:none;margin:0;padding:4px 0}.tag-input-dropdown-item{padding:7px 14px;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-heading)}.tag-input-dropdown-item:hover,.tag-input-dropdown-item.active{background:var(--color-accent-bg);color:var(--color-accent)}.player-notes-section{flex:1;overflow-y:auto;background:var(--color-bg-primary);padding:12px 14px 14px}.player-notes-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.player-notes-title{font-size:var(--font-size-sm);color:#ffffffb3;font-weight:600;display:flex;align-items:center;gap:6px}.player-notes-count{background:#ffffff26;color:#fff;font-size:var(--font-size-xs);padding:1px 6px;border-radius:8px}.player-note-add-btn{font-size:var(--font-size-xs);padding:4px 10px;min-height:var(--tap-target-min);border-radius:6px;border:1px solid rgba(255,255,255,.25);background:transparent;color:#ffffffbf;cursor:pointer;transition:all .12s}.player-note-add-btn:hover{background:#ffffff1a;color:#fff}.player-note-input-wrap{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.player-note-textarea{flex:1;padding:6px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;font-size:var(--font-size-sm);resize:none;outline:none;font-family:inherit}.player-note-textarea::placeholder{color:#ffffff9e}.player-note-textarea:focus{border-color:var(--color-accent-light)}.player-note-save-btn{align-self:flex-end;padding:6px 14px;font-size:var(--font-size-sm);white-space:nowrap}.player-notes-list{list-style:none;display:flex;flex-direction:column;gap:4px}.player-note-item{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.06)}.player-note-time{flex-shrink:0;font-size:var(--font-size-xs);font-weight:700;color:var(--color-accent-light);background:#a5b4fc1f;padding:2px 8px;border-radius:5px;border:none;cursor:pointer;transition:background .12s;font-family:monospace}.player-note-time:hover{background:#a5b4fc40}.player-note-content{flex:1;font-size:var(--font-size-sm);color:var(--player-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.player-note-delete{flex-shrink:0;min-width:var(--tap-target-min);min-height:var(--tap-target-min);border-radius:50%;border:none;background:transparent;color:var(--player-text-muted);cursor:pointer;font-size:var(--font-size-xs);display:flex;align-items:center;justify-content:center;transition:all .12s}.player-note-delete:hover{background:#ef444433;color:var(--color-danger-light)}.player-notes-empty{font-size:var(--font-size-xs);color:var(--player-text-muted);text-align:center;padding:6px 0}.tqp-header-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.tqp-icon{font-size:var(--font-size-xl);flex-shrink:0;line-height:1}.tqp-header-text{min-width:0}.tqp-progress{font-size:var(--font-size-xs);color:#ffffff73;font-weight:600;letter-spacing:.3px;margin-bottom:2px}.notes-view{max-width:860px;margin:0 auto}.notes-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card)}.notes-search-input{flex:1;min-width:180px;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 14px;font-size:var(--font-size-base);outline:none;background:var(--color-bg-card);transition:border-color .2s}.notes-search-input:focus{border-color:#9ca3af}.notes-total{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;font-weight:600}.notes-download-btn{display:flex;align-items:center;gap:4px;min-height:38px;background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-secondary);padding:0 12px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s,background .15s}.notes-download-btn:hover{border-color:var(--color-accent);color:var(--color-text-primary);background:var(--color-bg-card-hover)}.notes-download-btn svg{flex-shrink:0}.notes-list{list-style:none;display:flex;flex-direction:column;gap:8px}.note-item{display:flex;align-items:center;gap:12px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:12px 14px;box-shadow:none;transition:border-color .15s,background .15s}.playlist-list-item{display:flex;align-items:center;gap:var(--space-2)}.playlist-list-select{display:block;flex:1;min-width:0;min-height:var(--tap-target-min);padding:0;border:0;background:transparent;color:inherit;text-align:left;cursor:pointer}.playlist-list-item-desc{display:block;margin:var(--space-1) 0 0}.drag-handle{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap-target-min);min-height:var(--tap-target-min);padding:0;border:0;background:transparent;color:var(--color-text-secondary);cursor:grab}.drag-handle:active{cursor:grabbing}.note-item:hover{border-color:#d1d5db;background:var(--color-bg-card-hover)}.note-open-btn{display:flex;align-items:center;gap:12px;flex:1;min-width:0;padding:0;border:0;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.note-open-btn:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:3px;border-radius:var(--radius-md)}.note-thumb{width:88px;aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0;background:#000}.note-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.ghost-card{position:relative;margin:0 0 16px;padding:12px 14px;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card)}.ghost-card-close{position:absolute;top:6px;right:8px;background:transparent;border:none;color:var(--color-text-muted);font-size:14px;cursor:pointer;padding:4px;line-height:1}.ghost-card-body{display:flex;gap:12px;align-items:flex-start}.ghost-card-thumb{width:96px;aspect-ratio:16 / 9;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0;background:#000;filter:grayscale(.5)}.ghost-card-text{flex:1;min-width:0}.ghost-card-meta{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:600}.ghost-card-mark{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-full);background:var(--color-bg-card-hover);color:var(--color-text-primary);border:1px solid var(--color-border);flex-shrink:0}.ghost-card-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);margin:2px 0 6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ghost-card-voice{margin:4px 0 0;font-style:italic;color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5}.ghost-card-summon{background:var(--color-bg-card);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:4px 12px;font-size:var(--font-size-xs);cursor:pointer}.ghost-card-summon:hover{background:var(--color-bg-card-hover);border-color:var(--color-text-secondary)}.ghost-card-actions{display:flex;gap:8px;margin-top:10px}.ghost-card-btn{flex:1;padding:7px 12px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.ghost-card-btn:hover{background:var(--color-bg-card-hover);border-color:var(--color-text-secondary)}.ghost-card-btn--rest{color:var(--color-text-secondary)}.note-video-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-content-row{display:flex;align-items:baseline;gap:8px}.note-timestamp-badge{flex-shrink:0;background:var(--color-bg-card-hover);color:var(--color-text-primary);border:1px solid var(--color-border);font-size:var(--font-size-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full);font-variant-numeric:tabular-nums}.note-type-badge{flex-shrink:0;align-self:flex-start;background:var(--color-bg-card);color:var(--color-text-secondary);border:1px solid var(--color-border);font-size:var(--font-size-xs);font-weight:700;padding:2px 8px;border-radius:var(--radius-full)}.note-content-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.4;white-space:pre-wrap;word-break:break-word}.note-delete-btn{flex-shrink:0;min-width:var(--tap-target-min);min-height:var(--tap-target-min);background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;padding:0;border-radius:var(--radius-md);transition:color .15s,background .15s;align-self:flex-start}.note-delete-btn:hover{color:var(--color-danger);border-color:var(--color-danger-light);background:var(--color-danger-bg)}.ai-chat{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.ai-chat-context-hint{flex-shrink:0;padding:8px 12px;font-size:var(--font-size-xs);color:#ffffffb8;background:#ffffff0f;border-bottom:1px solid rgba(255,255,255,.08);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-chat-daily-usage{flex-shrink:0;padding:6px 12px;font-size:var(--font-size-xs);color:#ffffffb8;border-bottom:1px solid rgba(255,255,255,.06);font-variant-numeric:tabular-nums}.ai-chat-ref-time{font-size:var(--font-size-xs);color:#ffffffb8;margin-bottom:6px;padding:0 2px}.ai-chat-ref-time-mark{color:var(--color-accent-light);font-weight:600;font-variant-numeric:tabular-nums}.ai-term-wrap{display:inline-flex;align-items:baseline;gap:3px;max-width:100%;vertical-align:baseline}.ai-md-term{cursor:help;text-decoration:underline dotted rgba(255,255,255,.35);text-underline-offset:2px}.ai-md-term:hover{color:var(--color-accent-light)}.ai-term-ask-btn{display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;flex-shrink:0;min-width:1.625rem;min-height:1.625rem;margin:0;padding:0 .2rem;border:none;border-radius:999px;font-size:.65rem;font-weight:700;line-height:1;color:var(--color-accent-light);background:#ffffff1a;cursor:pointer;vertical-align:middle;touch-action:manipulation}.ai-term-ask-btn:hover{background:#ffffff29}.ai-term-ask-btn:focus-visible{outline:2px solid var(--color-accent-light);outline-offset:2px}.ai-term-ask-btn-demo{pointer-events:none;cursor:default;vertical-align:-.15em}.ai-chat-term-hint{line-height:1.5}.ai-chat-messages{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:14px}.ai-chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px 16px;gap:8px;color:#ffffffb8}.ai-chat-empty-icon{font-size:var(--font-size-3xl);color:var(--color-accent-light);margin-bottom:4px}.ai-chat-empty p{font-size:var(--font-size-sm);line-height:1.5}.ai-chat-empty-hint{font-size:var(--font-size-xs)!important;color:#ffffffb8!important}.ai-message{display:flex;flex-direction:column;gap:4px}.ai-message-meta{font-size:var(--font-size-xs);color:#ffffffb8;padding-left:4px}.ai-message-time{font-weight:600;color:var(--color-accent-light)}.ai-message-bubble{padding:8px 11px;border-radius:10px;font-size:var(--font-size-sm);line-height:1.6;white-space:pre-wrap;word-break:break-word}.ai-message-user .ai-message-bubble{background:#6366f140;border:1px solid rgba(99,102,241,.35);color:#ffffffe6;align-self:flex-end;max-width:90%}.ai-message-assistant .ai-message-bubble{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#ffffffe0;position:relative;padding-right:52px}.ai-message-assistant .ai-message-bubble h1,.ai-message-assistant .ai-message-bubble h2,.ai-message-assistant .ai-message-bubble h3{margin:.6em 0 .3em;font-size:var(--font-size-base);font-weight:700;color:#fffffff2}.ai-message-assistant .ai-message-bubble h1{font-size:var(--font-size-lg)}.ai-message-assistant .ai-message-bubble p{margin:.4em 0;line-height:1.65}.ai-message-assistant .ai-message-bubble ul,.ai-message-assistant .ai-message-bubble ol{margin:.4em 0;padding-left:1.4em}.ai-message-assistant .ai-message-bubble li{margin:.2em 0;line-height:1.6}.ai-message-assistant .ai-message-bubble code{background:#a5b4fc1f;padding:1px 5px;border-radius:3px;font-size:var(--font-size-sm);font-family:Consolas,Monaco,monospace}.ai-message-assistant .ai-message-bubble pre{background:#00000059;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:10px 12px;overflow-x:auto;margin:.5em 0}.ai-message-assistant .ai-message-bubble pre code{background:none;padding:0;font-size:var(--font-size-sm)}.ai-message-assistant .ai-message-bubble strong{color:var(--color-accent-purple);font-weight:700}.ai-message-assistant .ai-message-bubble blockquote{border-left:3px solid rgba(165,180,252,.4);margin:.5em 0;padding:.3em .8em;color:#ffffffb8}.ai-message-assistant .ai-message-bubble table{border-collapse:collapse;width:100%;margin:.5em 0;font-size:var(--font-size-sm)}.ai-message-assistant .ai-message-bubble th,.ai-message-assistant .ai-message-bubble td{border:1px solid rgba(255,255,255,.15);padding:5px 8px;text-align:left}.ai-message-assistant .ai-message-bubble th{background:#ffffff0f;font-weight:600}.ai-bubble-icons{position:absolute;top:6px;right:6px;display:flex;gap:2px;z-index:1}.ai-bubble-icon{background:none;border:none;color:#ffffffb8;cursor:pointer;padding:4px;border-radius:5px;display:flex;align-items:center;justify-content:center;min-width:var(--tap-target-min);min-height:var(--tap-target-min);transition:color .15s,background .15s}.ai-bubble-icon:hover:not(:disabled){color:#ffffffbf;background:#ffffff14}.ai-bubble-icon:disabled{cursor:default}.ai-bubble-icon.playing{color:var(--color-accent-light)}.ai-bubble-icon.loading{color:#a5b4fc80}.ai-bubble-icon.saved{color:var(--color-accent-light)}.ai-tts-spinner{display:block;width:12px;height:12px;border:1.5px solid rgba(165,180,252,.25);border-top-color:var(--color-accent-light);border-radius:50%;animation:ai-spin .7s linear infinite}@keyframes ai-spin{to{transform:rotate(360deg)}}.inline-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-text-secondary);border-radius:50%;animation:ai-spin .7s linear infinite;vertical-align:-2px;margin-right:6px;flex-shrink:0}.ai-message-error .ai-message-bubble,.ai-message-bubble.ai-message-error{background:#ef444426;border-color:#ef444459;color:var(--color-danger-light)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.ai-cursor{display:inline-block;width:2px;height:1em;background:var(--color-accent-light);margin-left:2px;vertical-align:text-bottom;animation:blink 1s step-end infinite}.ai-thinking{display:flex;align-items:center;gap:8px;color:#a5b4fcb3;font-style:italic;font-size:var(--font-size-sm);padding:4px 0}.ai-stale-incomplete-hint{margin:0;padding:6px 0;font-size:var(--font-size-sm);line-height:1.45;color:#ffffffb8}.ai-thinking-dots{display:inline-flex;gap:4px}.ai-thinking-dots span{width:6px;height:6px;border-radius:50%;background:var(--color-accent-light);animation:ai-dot-bounce 1.4s ease-in-out infinite}.ai-thinking-dots span:nth-child(2){animation-delay:.16s}.ai-thinking-dots span:nth-child(3){animation-delay:.32s}@keyframes ai-dot-bounce{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.ai-message-bubble.ai-streaming{border-left:2px solid var(--color-accent-light);animation:ai-stream-pulse 2s ease-in-out infinite}@keyframes ai-stream-pulse{0%,to{border-left-color:#a5b4fc4d}50%{border-left-color:#a5b4fce6}}.ai-chat-input-area{flex-shrink:0;border-top:1px solid rgba(255,255,255,.1);padding:10px;display:flex;flex-direction:column;gap:6px;background:#0003}.ai-chat-textarea{width:100%;background:#ffffff12;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;font-size:var(--font-size-sm);padding:8px 10px;resize:none;line-height:1.5;font-family:inherit;outline:none;transition:border-color .15s}.ai-chat-textarea:focus{border-color:#a5b4fc80}.ai-chat-textarea::placeholder{color:#ffffff9e;font-size:var(--font-size-xs)}.ai-chat-textarea:disabled{color:#ffffffad}.ai-chat-actions{display:flex;justify-content:flex-end}.ai-chat-send{background:var(--color-text-primary);color:var(--color-bg-card);border:1px solid var(--color-text-primary);border-radius:var(--radius-md);padding:6px 18px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.ai-chat-send:hover:not(:disabled){opacity:.85;transform:translateY(-1px)}.ai-chat-send:disabled{background:var(--color-bg-card-hover);border-color:var(--color-border);color:var(--color-text-muted);cursor:not-allowed}.ai-chat-stop{background:#ef444433;color:var(--color-danger-light);border:1px solid rgba(239,68,68,.35);border-radius:7px;padding:6px 16px;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background .15s}.ai-chat-stop:hover{background:#ef44444d}.ai-suggest-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.ai-suggest-chips-initial{justify-content:center;margin-top:18px;padding:0 4px}.ai-chip{padding:5px 11px;border-radius:100px;border:1px solid rgba(255,255,255,.25);background:#ffffff0f;color:#ffffffd1;font-size:var(--font-size-xs);cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .12s;white-space:nowrap;text-align:left;line-height:1.4}.ai-chip:hover{background:#ffffff29;border-color:#ffffff80;color:#fff;transform:translateY(-1px)}.ai-chip:active{transform:translateY(0);opacity:.8}.ai-suggest-chips-initial .ai-chip{font-size:var(--font-size-xs);padding:6px 13px}.quick-ask-wrap{position:absolute;right:12px;bottom:12px;z-index:5}.quick-ask-fab{width:40px;height:40px;border-radius:50%;background:var(--color-text-primary);color:var(--color-bg-card);font-size:var(--font-size-lg);font-weight:700;border:none;cursor:pointer;box-shadow:0 2px 8px #0000004d;transition:transform .15s,background .15s}.quick-ask-fab:hover{transform:scale(1.1);background:#4f46e5}.quick-ask-popup{position:absolute;bottom:48px;right:0;background:var(--color-bg-primary);border:1px solid rgba(165,180,252,.25);border-radius:var(--radius-md);padding:6px;display:flex;flex-direction:column;gap:4px;min-width:200px;box-shadow:0 4px 16px #0006;animation:fadeIn .15s ease}.quick-ask-popup--fixed{box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.quick-ask-chip{background:#a5b4fc1a;border:1px solid rgba(165,180,252,.2);color:var(--color-accent-light);padding:10px 14px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;text-align:left;transition:background .15s;min-height:var(--tap-target-min);display:flex;align-items:center}.quick-ask-chip:hover{background:#a5b4fc33}.ai-save-prompt{display:flex;align-items:center;gap:8px;margin-top:6px;padding:6px 10px;background:#4f46e526;border:1px solid rgba(165,180,252,.3);border-radius:var(--radius-sm);animation:fadeIn .2s ease}.ai-save-prompt-btn{background:var(--color-accent);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:background .15s;min-height:36px}.ai-save-prompt-btn:hover{background:var(--color-accent-hover)}.ai-save-prompt-dismiss{background:none;border:none;color:#fff6;cursor:pointer;font-size:var(--font-size-sm);padding:0;min-width:var(--tap-target-min);min-height:var(--tap-target-min);display:inline-flex;align-items:center;justify-content:center}.ai-save-prompt-dismiss:hover{color:#ffffffb3}.btn-play-inline{padding:6px 12px;font-size:var(--font-size-sm);flex-shrink:0;min-height:36px;white-space:nowrap;width:auto}.stream-play-btn{flex-shrink:0;width:auto;min-width:36px;min-height:36px;padding:6px 12px}.ai-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(165,180,252,.15);background:#a5b4fc0d;flex-shrink:0}.ai-panel-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent-light);letter-spacing:.03em}.ai-panel-close{background:#ffffff14;border:1px solid rgba(255,255,255,.14);color:#ffffffd1;cursor:pointer;font-size:var(--font-size-base);min-width:var(--tap-target-min);min-height:var(--tap-target-min);padding:0;border-radius:var(--radius-md);line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.ai-panel-close:hover,.ai-panel-close:focus-visible{color:#fff;background:#ffffff29}.login-divider{display:flex;align-items:center;margin:18px 0;gap:12px;color:var(--color-text-muted);font-size:var(--font-size-xs)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.google-login-wrapper{display:flex;justify-content:center;margin-bottom:4px}.google-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;background:var(--color-bg-card);color:#3c4043;border:1px solid var(--color-border-input);border-radius:8px;font-size:var(--font-size-sm);font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,box-shadow .15s}.google-btn:hover:not(:disabled){background:#f8f9fa;box-shadow:0 1px 3px #00000026}.google-btn:active:not(:disabled){background:#f1f3f4}.google-btn:disabled{background:var(--color-bg-card-hover);color:var(--color-text-muted);cursor:not-allowed}@media(max-width:768px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:var(--color-bg-primary);border-top:1px solid rgba(255,255,255,.1);z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;color:#ffffff73;font-size:var(--font-size-2xs);cursor:pointer;transition:color var(--transition-fast);min-height:var(--tap-target-min);padding:4px 0}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--color-accent-light)}.bottom-nav-item.active svg{filter:drop-shadow(0 0 4px rgba(165,180,252,.4))}main{padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 8px)}.toast-container{bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 16px);right:16px;left:16px}.toast{max-width:none}.fab-wrap{display:block;position:fixed;bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 16px);right:16px;z-index:99}.fab{width:52px;height:52px;border-radius:50%;background:var(--color-text-primary);color:var(--color-bg-card);font-size:var(--font-size-2xl);border:none;cursor:pointer;box-shadow:0 4px 12px #0000004d;transition:transform var(--transition-fast),box-shadow var(--transition-fast);display:flex;align-items:center;justify-content:center}.fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #0006}.fab:active{transform:scale(.95)}.header-dropdown-wrap:has(.btn-compact){display:none}.header h1{font-size:var(--font-size-lg)}.header-logo{width:26px;height:26px}.tab-nav{gap:2px}.tab{padding:5px 10px;font-size:var(--font-size-sm)}.header-actions{width:100%;flex-wrap:wrap;gap:8px}.header-search{flex:1;min-width:0}.header-search input{width:100%;min-width:0;padding:8px 12px;font-size:var(--font-size-sm)}.header-search button{padding:8px 14px;font-size:var(--font-size-sm)}.user-info{padding-left:0;border-left:none;margin-left:auto}main{padding:16px 10px}.video-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.home-lane-body--grid{padding:10px}.home-lane--today .home-lane-body--rail{padding:8px}.filters{gap:8px}.filters input{min-width:0;flex:1}.filters select{flex:1;min-width:0}.filter-fields{display:contents}.player-overlay{padding:0;align-items:stretch}.player-container{border-radius:0;max-height:100vh;height:100vh;max-height:100dvh;height:100dvh}.player-session-bar{position:relative;z-index:46}.player-session-bar{min-height:48px;padding:4px 56px 4px 12px;gap:6px;font-size:var(--font-size-xs)}.player-close--bar{display:inline-flex}.player-session-context{flex:1;max-width:none}.player-session-title{display:none}.player-container--today-queue .player-session-bar{padding:4px 56px 4px 10px;gap:4px}.player-container--today-queue .sidebar-tabs .sidebar-tab{padding:5px 3px}.player-container--today-queue .playlist-controls{padding:5px 10px;gap:8px}.player-container--today-queue .playlist-sidebar-list .playlist-item{padding:4px 6px;gap:5px}.player-container--today-queue .playlist-sidebar-list .playlist-item img{width:40px}.player-body{flex-direction:column}.player-main{flex:none}.playlist-controls{gap:10px;padding:8px 12px;justify-content:space-between}.playlist-controls .btn-secondary{min-height:var(--tap-target-min);padding:6px 14px;font-size:var(--font-size-sm)}.playlist-progress{font-size:var(--font-size-sm);font-variant-numeric:tabular-nums}.sidebar-tab{min-height:var(--tap-target-min)}.player-sidebar{width:100%!important;flex:1;border-left:none;border-top:1px solid rgba(255,255,255,.08)}.player-sidebar.ai-open{position:fixed;bottom:0;left:0;right:0;width:100%!important;box-sizing:border-box;height:min(60dvh,calc(100dvh - var(--bottom-nav-height)));max-height:min(60dvh,calc(100dvh - var(--bottom-nav-height)));padding-bottom:env(safe-area-inset-bottom,0px);border-radius:16px 16px 0 0;z-index:50;box-shadow:0 -4px 20px #0006;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.player-sidebar.ai-open{animation:none}}.player-sidebar.ai-open .ai-panel-header:before{content:"";display:block;width:40px;height:4px;background:#ffffff4d;border-radius:2px;margin:0 auto 8px}.ai-chip{min-height:var(--tap-target-min);padding:10px 14px;font-size:var(--font-size-sm)}.ai-suggest-chips-initial{flex-direction:column}.ai-suggest-chips-initial .ai-chip{width:100%;text-align:center}.ai-chat-textarea{font-size:var(--font-size-base)}.player-close{position:absolute;top:50%;right:8px;transform:translateY(-50%)}.player-below{display:flex;flex-direction:column;gap:var(--space-2);padding:10px 12px 4px;background:var(--player-bg, #171717)}.player-title--below{font-size:var(--font-size-base);line-height:1.4;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.player-rate-controls--below{display:flex;width:100%}.player-rate-controls--below .player-rate-btn{flex:1;min-height:var(--tap-target-min);font-size:var(--font-size-sm)}.player-below-actions{display:flex;flex-wrap:nowrap;gap:var(--space-2)}.player-below-actions .player-below-bookmark,.player-below-actions .player-more-trigger{flex:1;min-width:0;padding-left:8px;padding-right:8px;font-size:var(--font-size-sm);white-space:nowrap}.floating-player{width:calc(100vw - 32px);max-width:360px;right:16px;bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 16px)}.floating-player:not(.floating-player--minimized) .floating-player-ai{display:none}.player-close,.modal-close,.player-float-btn,.player-study-btn,.floating-player-ai,.floating-player-minimize,.floating-player-expand,.floating-player-close{min-height:var(--tap-target-min);min-width:var(--tap-target-min);display:inline-flex;align-items:center;justify-content:center}.status-badge-clickable{padding:4px 10px}.status-badge-clickable:after{content:"";position:absolute;inset:-10px}.btn-today-thumb{width:28px;height:28px;position:absolute}.btn-today-thumb:after{content:"";position:absolute;inset:-8px}.video-menu-btn{min-width:var(--tap-target-min);min-height:var(--tap-target-min)}.modal-overlay{padding:8px}.modal{padding:20px 16px;max-width:100%}.login-card{padding:28px 20px}.add-video-modal{max-width:100%;height:95vh;height:95dvh;padding:var(--space-4)}.add-video-item-thumb{width:64px;height:36px}.add-video-expand-actions{flex-wrap:wrap}.add-video-url-preview img{width:80px;height:45px}.search-modal{max-width:100%;height:95vh;height:95dvh}.search-modal-body{flex-direction:column}.search-modal-results{grid-template-columns:repeat(2,1fr);flex:none;max-height:45vh;overflow-y:auto}.search-modal-form{width:100%;border-left:none;border-top:1px solid var(--color-border);padding-left:0;padding-top:12px;flex:1;min-height:auto}.channel-import-modal{max-width:100%;height:95vh;height:95dvh}.channel-import-header{padding:14px 16px 10px}.channel-import-breadcrumb{padding:8px 16px}.channel-import-step{padding:14px 16px}.channel-video-grid{grid-template-columns:repeat(2,1fr)}.playlist-panels-row{grid-template-columns:1fr;gap:12px}.playlist-tab-bar{padding:0 12px;overflow-x:auto}.playlist-tab{padding:10px 14px;font-size:var(--font-size-sm);white-space:nowrap}.note-item{gap:10px;padding:10px}.note-thumb{width:72px}.yt-add-modal{width:100%}.yt-add-modal-header{padding:14px 16px 10px}.yt-add-preview{padding:10px 16px}.yt-add-form{padding:12px 16px 16px}.home-lane--today .home-lane-header{flex-wrap:wrap}.home-lane--today .home-lane-count{display:none}.home-lane--today .home-lane-header-extra{width:100%;justify-content:flex-start}.btn-stream{min-height:36px;padding:6px 12px}.btn-play-inline{min-height:var(--tap-target-min);padding:8px 14px;font-size:var(--font-size-sm);flex-shrink:0}.quick-ask-fab{width:44px;height:44px}.quick-ask-popup{right:-4px;min-width:220px}.yt-video-add-btn{width:36px;height:36px}.ai-save-prompt-btn{min-height:36px;font-size:var(--font-size-sm)}.stream-history-item{padding:10px}}@media(max-width:768px)and (orientation:landscape){.player-body{flex-direction:row}.player-main{flex:1;max-height:none;overflow-y:auto}.player-below{padding:6px 12px 2px;gap:4px}.player-title--below{-webkit-line-clamp:1}.player-rate-controls--below .player-rate-btn{min-height:36px}.player-sidebar{width:40vw!important;max-width:320px;border-left:1px solid rgba(255,255,255,.08);border-top:none}.bottom-nav{height:44px}.bottom-nav-item{min-height:40px}.fab-wrap{bottom:56px;right:12px}.fab{width:44px;height:44px;font-size:var(--font-size-xl)}}@media(max-width:600px){.video-grid{grid-template-columns:repeat(2,1fr);gap:10px}.filters{flex-direction:column;gap:6px}.mobile-filter-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:var(--tap-target-min);width:100%}.filter-fields{display:none;width:100%;flex-direction:column;gap:6px}.filter-fields.open{display:flex}.filters input,.filters select{width:100%;min-width:0}.modal{padding:20px 16px}}@media(max-width:480px){.add-video-modal{padding:var(--space-3);height:95vh;height:95dvh}.add-video-item-thumb{width:56px;height:32px}.add-video-item-btn{width:32px;height:32px}.add-video-expand-form{padding:var(--space-2) var(--space-3)}.add-video-url-preview{flex-direction:column;align-items:flex-start}.add-video-url-preview img{width:100%;height:auto;aspect-ratio:16/9}.header{padding:8px 10px}.header h1{font-size:var(--font-size-base)}.header-logo{width:22px;height:22px}.tab-nav{gap:1px}.tab{padding:4px 8px;font-size:var(--font-size-xs)}.header-right{width:100%;flex-wrap:wrap;gap:6px;justify-content:flex-end}.header-search{flex-basis:100%}.header-search input{padding:8px 10px;font-size:var(--font-size-sm)}.header-search button{padding:8px 12px;font-size:var(--font-size-sm)}main{padding:12px 8px}.video-grid{grid-template-columns:repeat(2,1fr);gap:8px}.video-info{padding:8px 10px}.video-info h3{font-size:var(--font-size-sm)}.video-meta{gap:4px}.tag,.category-label{font-size:var(--font-size-2xs);padding:1px 5px}.video-memo{font-size:var(--font-size-xs);-webkit-line-clamp:1}.video-actions select{font-size:var(--font-size-xs);padding:3px 6px}.btn-resume{font-size:var(--font-size-xs);padding:4px 8px}.home-lane-body--grid{padding:8px}.home-lane-title{font-size:var(--font-size-sm)}.today-play-all-btn{font-size:var(--font-size-xs);padding:4px 10px}.today-clear-all-btn{padding:4px 8px}.filters{flex-direction:column;gap:6px}.filters input,.filters select{width:100%;min-width:0}.tag-chips-area{gap:6px}.tag-chip,.tag-chip-clear{min-height:var(--tap-target-min);padding:8px 14px;display:inline-flex;align-items:center}.tag-match-btn{min-height:var(--tap-target-min);padding:8px 14px}.playlist-controls,.playlist-item{gap:6px;padding:6px 8px}.playlist-item img{width:48px}.player-container--today-queue .playlist-sidebar-list .playlist-item img{width:36px}.player-container--today-queue .playlist-sidebar-list .playlist-item{padding:4px 5px;gap:4px}.yt-video-add-btn{width:32px;height:32px}.yt-video-registered-text{font-size:var(--font-size-2xs);padding:1px 5px}.player-notes-section{padding:10px}.player-note-input-wrap{flex-direction:column;gap:6px}.search-modal-results{grid-template-columns:repeat(2,1fr);gap:6px}.search-input-row{flex-direction:column;gap:6px}.search-btn{width:100%}.search-results-grid{grid-template-columns:repeat(2,1fr);gap:6px}.modal-mode-tabs{margin-bottom:12px}.modal-mode-tab{padding:6px 8px;font-size:var(--font-size-sm)}.channel-video-grid{grid-template-columns:repeat(2,1fr);gap:6px}.channel-card{padding:10px 12px;gap:10px}.channel-card-thumb{width:40px;height:40px}.channel-card-title{font-size:var(--font-size-sm)}.playlist-list-panel,.playlist-detail-panel{padding:14px}.playlist-detail-header{flex-direction:column;gap:10px}.playlist-play-controls{width:100%;justify-content:flex-start}.playlist-video-item img{width:60px}.queue-item{padding:8px 10px;gap:8px}.queue-item img{width:52px}.queue-item-title{font-size:var(--font-size-sm)}.notes-toolbar{flex-wrap:wrap;gap:8px}.notes-search-input{width:100%;flex:none;padding:8px 12px;font-size:var(--font-size-sm)}.note-item{flex-wrap:wrap;gap:8px;padding:10px}.note-thumb{width:56px}.note-video-title{font-size:var(--font-size-xs)}.note-content-text{font-size:var(--font-size-sm)}.note-content-row{gap:6px}.ai-chat-messages{padding:10px 8px}.ai-message-bubble{font-size:var(--font-size-sm);padding:7px 9px}.ai-chat-textarea{font-size:var(--font-size-base);padding:7px 9px}.ai-chip{font-size:var(--font-size-xs);padding:10px 12px;min-height:var(--tap-target-min)}.ai-term-ask-btn{min-width:2.75rem;min-height:2.75rem;padding:0 .35rem;font-size:.7rem}.ai-suggest-chips-initial .ai-chip{font-size:var(--font-size-xs);padding:5px 10px}.yt-add-preview img{width:72px}.floating-player{width:calc(100vw - 16px);max-width:280px;right:8px;bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 8px)}.login-card{padding:24px 16px;max-width:100%}.login-title{font-size:var(--font-size-lg)}.yt-video-thumb-wrap{width:72px}.btn-stream{padding:4px 10px;font-size:var(--font-size-xs);min-height:32px}.quick-ask-popup{right:-8px;left:auto;min-width:min(220px,calc(100vw - 40px))}.ai-save-prompt{flex-wrap:wrap}.stream-history-thumb{width:30px;height:30px}}.learning-cal{--cal-l0: #ebedf0;--cal-l1: #c7ccd3;--cal-l2: #949ba6;--cal-l3: #4b5563;--cal-l4: #111827;margin:0 0 var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}[data-theme=dark] .learning-cal{--cal-l0: #262b34;--cal-l1: #3b424e;--cal-l2: #586272;--cal-l3: #9aa3b2;--cal-l4: #f5f5f5}.learning-cal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-2);margin:0 0 var(--space-3)}.learning-cal-nudge{margin:2px 0 0;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.learning-cal-grid{display:grid;grid-template-rows:repeat(7,14px);grid-auto-columns:14px;grid-auto-flow:column;gap:3px;justify-content:start}.learning-cal-cell{border-radius:var(--radius-xs);background:var(--cal-l0)}.learning-cal-cell.lv1{background:var(--cal-l1)}.learning-cal-cell.lv2{background:var(--cal-l2)}.learning-cal-cell.lv3{background:var(--cal-l3)}.learning-cal-cell.lv4{background:var(--cal-l4)}.learning-cal-cell.future{background:transparent}.learning-cal-foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-1) var(--space-3);margin-top:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-muted)}.learning-cal-hint{flex:1 1 auto;min-width:0}.learning-cal-legend{display:inline-flex;flex:0 0 auto;align-items:center;gap:3px}.learning-cal-legend i{width:11px;height:11px;border-radius:var(--radius-xs)}.learning-cal-legend .lv0{background:var(--cal-l0)}.learning-cal-legend .lv1{background:var(--cal-l1)}.learning-cal-legend .lv2{background:var(--cal-l2)}.learning-cal-legend .lv3{background:var(--cal-l3)}.learning-cal-legend .lv4{background:var(--cal-l4)}.stats-widget{margin:var(--space-4) var(--space-4) var(--space-2);padding:var(--space-4);background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.stats-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:var(--space-3)}.stats-card{display:flex;flex-direction:column;gap:2px;padding:14px;background:var(--color-bg-page);border-radius:var(--radius-lg);min-width:0}.stats-card--accent,.stats-card--success,.stats-card--streak{background:var(--color-bg-card-hover)}.stats-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-heading);line-height:var(--line-height-tight)}.stats-card--accent .stats-card-value,.stats-card--success .stats-card-value,.stats-card--streak .stats-card-value{color:var(--color-text-primary)}.stats-card-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.stats-progress-row{display:flex;align-items:center;gap:10px;margin-top:10px}.stats-progress-bar-wrap{flex:1;height:8px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.stats-progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width var(--transition-normal)}.stats-progress-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0}.today-progress-bar-wrap{display:flex;align-items:center;gap:8px;margin:0 var(--space-4) var(--space-2)}.today-progress-bar-track{flex:1;height:6px;background:var(--home-lane-border);border-radius:var(--radius-full);overflow:hidden}.today-progress-bar-fill{height:100%;background:var(--color-success);border-radius:var(--radius-full);transition:width var(--transition-normal)}.today-progress-label{font-size:var(--font-size-xs);color:var(--home-lane-label);white-space:nowrap;flex-shrink:0}.home-lane-rail-card--done{border-color:var(--color-success);background:var(--color-success-bg)}.home-lane-rail-card--done .home-lane-rail-thumb img{filter:saturate(.75)}.home-lane-rail-done{position:absolute;left:8px;bottom:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-success);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);border-radius:var(--radius-full);box-shadow:0 2px 8px #0000003d}.filter-toggle-btn{padding:6px 12px;border:1px solid var(--color-border-input);background:var(--color-bg-card);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-toggle-btn:hover,.filter-toggle-btn.active{border-color:var(--color-text-primary);color:var(--color-text-primary);background:var(--color-bg-card-hover)}.category-progress-panel{margin:var(--space-2) var(--space-4) var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-card);border-radius:var(--radius-md);border:1px solid var(--color-border-light);display:flex;flex-direction:column;gap:var(--space-3)}.category-progress-row{display:grid;grid-template-columns:1fr 2fr auto;align-items:center;gap:var(--space-3)}.category-progress-label{display:flex;justify-content:space-between;gap:var(--space-2);min-width:0}.category-progress-name{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-progress-count{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.category-progress-bar{position:relative;height:8px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.category-progress-watched{position:absolute;left:0;top:0;height:100%;background:var(--color-success);transition:width var(--transition-normal)}.category-progress-watching{position:absolute;top:0;height:100%;background:var(--color-warning);transition:width var(--transition-normal),left var(--transition-normal)}.category-progress-pct{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;text-align:right;min-width:32px}@media(max-width:600px){.stats-cards{grid-template-columns:repeat(2,1fr)}.category-progress-row{grid-template-columns:1fr auto;grid-template-rows:auto auto}.category-progress-bar{grid-column:1 / -1}}.player-rate-controls{display:flex;gap:2px;background:#ffffff14;border-radius:var(--radius-md);padding:2px}.player-rate-btn{padding:4px 8px;font-size:var(--font-size-xs);border:none;background:transparent;color:#ffffffb3;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);white-space:nowrap}.player-rate-btn:hover{background:#ffffff26;color:#fff}.player-rate-btn.active{background:var(--color-accent);color:#fff;font-weight:var(--font-weight-semibold)}.player-list-end-celebrate{font-size:3rem;text-align:center;margin-bottom:var(--space-2);animation:celebratePop .5s var(--ease-out-back)}@keyframes celebratePop{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}.player-suggestions-panel{max-width:480px}.player-suggestions-list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}.player-suggestion-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-bg-page);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background var(--transition-fast);width:100%}.player-suggestion-item:hover{background:var(--color-accent-bg);border-color:var(--color-accent-lighter)}.player-suggestion-thumb{width:80px;height:45px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.player-suggestion-info{display:flex;flex-direction:column;gap:2px;min-width:0}.player-suggestion-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-suggestion-meta{font-size:var(--font-size-xs);color:var(--color-text-muted)}.floating-player-ai{background:none;border:none;color:var(--color-accent-purple);cursor:pointer;padding:2px 6px;font-size:var(--font-size-base);border-radius:var(--radius-sm);transition:color var(--transition-fast);line-height:1}.floating-player-ai:hover{color:var(--color-accent-light)}.bulk-action-bar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-accent-bg);border:1px solid var(--color-accent-lighter);border-radius:var(--radius-md);margin-bottom:var(--space-3);flex-wrap:wrap}.bulk-action-count{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-accent);margin-right:var(--space-2)}.bulk-action-input{flex:1;min-width:120px;max-width:200px;padding:var(--space-1) var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm)}.bulk-btn{padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:1px solid transparent;transition:opacity var(--transition-fast);white-space:nowrap}.bulk-btn:disabled{background:var(--color-bg-card-hover);color:var(--color-text-muted);border-color:var(--color-border);cursor:not-allowed}.bulk-btn-link{background:none;border:none;color:var(--color-accent);font-size:var(--font-size-sm);cursor:pointer;padding:var(--space-1) var(--space-2);text-decoration:underline}.bulk-btn-link:hover{color:var(--color-accent-light)}.btn-danger{background:#e53e3e;color:#fff;border-color:#c53030}.btn-danger:hover:not(:disabled){opacity:.85}.video-grid--select-mode .video-card-wrap{position:relative}.video-select-checkbox{position:absolute;top:var(--space-2);left:var(--space-2);z-index:2;width:20px;height:20px;cursor:pointer;accent-color:var(--color-accent)}.video-card-selectable{cursor:pointer;transition:outline var(--transition-fast)}.video-card-selectable.selected{outline:2px solid var(--color-accent);outline-offset:2px}.tag-manager-modal{max-width:480px;width:100%}.tag-manager-body{padding:var(--space-4);max-height:60vh;overflow-y:auto}.tag-manager-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.tag-manager-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-page);border:1px solid var(--color-border);border-radius:var(--radius-md)}.tag-manager-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.tag-manager-count{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-right:var(--space-2)}.tag-manager-actions{display:flex;gap:var(--space-1)}.tag-manager-btn-icon{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;padding:2px 6px;font-size:var(--font-size-sm);line-height:1.4;transition:background var(--transition-fast),color var(--transition-fast)}.tag-manager-btn-icon:hover:not(:disabled){background:var(--color-accent-bg);color:var(--color-accent);border-color:var(--color-accent-lighter)}.tag-manager-btn-delete:hover:not(:disabled){background:#fff5f5;color:#e53e3e;border-color:#fc8181}.tag-manager-rename-row{display:flex;align-items:center;gap:var(--space-2);flex:1}.tag-manager-rename-input{flex:1;padding:var(--space-1) var(--space-2);border:1px solid var(--color-accent-lighter);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm)}.tag-manager-btn{padding:var(--space-1) var(--space-2);font-size:var(--font-size-sm);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap}.shortcuts-modal{max-width:520px;width:100%}.shortcuts-body{padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-5);max-height:70vh;overflow-y:auto}.shortcuts-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-2)}.shortcuts-note{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-2);line-height:1.5}.shortcuts-table{width:100%;border-collapse:collapse}.shortcuts-table tr{border-bottom:1px solid var(--color-border)}.shortcuts-table tr:last-child{border-bottom:none}.shortcuts-table th,.shortcuts-table td{padding:var(--space-2) var(--space-2);text-align:left;vertical-align:middle}.shortcuts-table th{width:40%;font-weight:var(--font-weight-normal)}.shortcuts-table td{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.shortcuts-table kbd{display:inline-block;padding:2px 6px;background:var(--color-bg-page);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-family:var(--font-mono, monospace);color:var(--color-text-primary);box-shadow:0 1px 0 var(--color-border)}.floating-player-minimize{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-xs);cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1}.floating-player-minimize:hover{color:#fff;background:#ffffff1a}.floating-player--minimized{width:auto;min-width:240px;max-width:360px}@media(max-width:768px){.floating-player--minimized{left:0;right:0;bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px));width:100%;max-width:100%;border-radius:0;border-top:1px solid rgba(255,255,255,.12)}.floating-player:not(.floating-player--minimized){bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 12px);right:12px;left:auto}}@media(max-width:480px){.floating-player:not(.floating-player--minimized){width:calc(100vw - 24px);max-width:320px;right:12px;bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 12px)}}.pwa-install-banner{position:fixed;left:0;right:0;bottom:0;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-primary);border-top:1px solid rgba(255,255,255,.12);z-index:150;animation:slideUp .3s var(--ease-out-back)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pwa-install-icon{flex-shrink:0}.pwa-install-icon img{border-radius:var(--radius-md);display:block}.pwa-install-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.pwa-install-text strong{font-size:var(--font-size-sm);color:#fff;font-weight:var(--font-weight-semibold)}.pwa-install-text span{font-size:var(--font-size-xs);color:#ffffff8c}.pwa-install-btn{flex-shrink:0;white-space:nowrap}.pwa-install-dismiss{background:none;border:none;color:#fff6;cursor:pointer;padding:var(--space-2);font-size:var(--font-size-sm);line-height:1;flex-shrink:0}.pwa-install-dismiss:hover{color:#ffffffb3}@media(max-width:768px){.pwa-install-banner{bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px));border-bottom:1px solid rgba(255,255,255,.12)}}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-10) var(--space-4);gap:var(--space-3)}.empty-state-icon{font-size:3.5rem;line-height:1;filter:grayscale(1)}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-heading);margin:0}.empty-state-body{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;margin:0;max-width:320px}.empty-state-actions{margin-top:var(--space-2)}.empty-state-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}.welcome-modal{max-width:380px;width:100%;padding:var(--space-6);text-align:center}.welcome-step-indicator{display:flex;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-5)}.welcome-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:background var(--transition-fast)}.welcome-dot.active{background:var(--color-accent);width:24px;border-radius:4px}.welcome-icon{font-size:2.5rem;margin-bottom:var(--space-3);line-height:1;color:var(--color-accent)}.welcome-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-heading);margin:0 0 var(--space-3)}.welcome-body{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--space-5)}.welcome-actions{display:flex;flex-direction:column;gap:var(--space-2);align-items:center}.welcome-cta{min-width:140px;padding:var(--space-3) var(--space-5);font-size:var(--font-size-base)}.welcome-skip{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;padding:var(--space-2)}.welcome-skip:hover{color:var(--color-text-secondary)}.btn-ghost{background:none;border:1px solid var(--color-border);color:var(--color-text-secondary);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast)}.btn-ghost:hover{background:var(--color-accent-bg);border-color:var(--color-accent-lighter);color:var(--color-accent)}.stats-goal-row{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border)}.stats-goal-display{display:flex;align-items:center;gap:var(--space-3)}.stats-goal-bar-wrap{flex:1;height:6px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.stats-goal-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1)}.stats-goal-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap}.stats-goal-achieved{color:var(--color-success, #48bb78);font-weight:var(--font-weight-semibold)}.stats-goal-edit-btn{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px 4px;font-size:var(--font-size-sm)}.stats-goal-edit-btn:hover{color:var(--color-accent)}.stats-goal-set-btn{background:none;border:1px dashed var(--color-border);color:var(--color-text-muted);cursor:pointer;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-xs);width:100%;transition:border-color var(--transition-fast),color var(--transition-fast)}.stats-goal-set-btn:hover{border-color:var(--color-accent-lighter);color:var(--color-accent)}.stats-goal-edit{display:flex;align-items:center;gap:var(--space-2)}.stats-goal-edit-label{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.stats-goal-input{width:60px;padding:var(--space-1) var(--space-2);border:1px solid var(--color-accent-lighter);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-primary);font-size:var(--font-size-sm);text-align:center}.stats-goal-unit{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.stats-goal-save{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.stats-goal-cancel{padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs)}:root{--color-bg-primary: #111827;--color-bg-secondary: #f7f7f8;--color-bg-page: #f7f7f8;--color-bg-card: #ffffff;--color-bg-card-hover: #f3f4f6;--color-text-heading: #111827;--color-text-primary: #111827;--color-text-secondary: #4b5563;--color-text-muted: #5f6672;--color-accent: #111827;--color-accent-hover: #000000;--color-accent-light: #4b5563;--color-accent-lighter: #d1d5db;--color-accent-bg: #f3f4f6;--color-accent-subtle: #f9fafb;--color-border: #e5e7eb;--color-border-input: #d1d5db;--shadow-sm: none;--shadow-md: none;--shadow-lg: 0 12px 28px rgba(15, 23, 42, .1)}[data-theme=dark]{--color-bg-primary: #171717;--color-bg-secondary: #212121;--color-bg-page: #212121;--color-bg-card: #2f2f2f;--color-bg-card-hover: #3a3a3a;--color-text-heading: #f5f5f5;--color-text-primary: #f5f5f5;--color-text-secondary: #c7c7c7;--color-text-muted: #b8b8b8;--color-accent: #f5f5f5;--color-accent-hover: #ffffff;--color-accent-light: #d4d4d4;--color-accent-lighter: #a3a3a3;--color-accent-bg: #3a3a3a;--color-accent-subtle: #262626;--color-border: #424242;--color-border-input: #525252;--shadow-lg: 0 16px 36px rgba(0, 0, 0, .35)}.app{background:var(--color-bg-page);color:var(--color-text-primary)}[data-theme=dark] .header,[data-theme=dark] .tab-nav,[data-theme=dark] .tab:hover,[data-theme=dark] .tab.active,[data-theme=dark] .btn-user,[data-theme=dark] .filters,[data-theme=dark] .filters input,[data-theme=dark] .filters select,[data-theme=dark] .home-lane,[data-theme=dark] .home-lane-header,[data-theme=dark] .home-lane--today .home-lane-header,[data-theme=dark] .btn-secondary,[data-theme=dark] .btn-ghost,[data-theme=dark] .ai-panel-controls,[data-theme=dark] .bottom-nav{background:var(--color-bg-card)}[data-theme=dark] .tag,[data-theme=dark] .btn-secondary:hover,[data-theme=dark] .btn-ghost:hover,[data-theme=dark] .bottom-nav-item:hover,[data-theme=dark] .bottom-nav-item.active{background:var(--color-bg-card-hover)}.header{position:sticky;top:0;z-index:20;background:#ffffffeb;color:var(--color-text-primary);border-bottom:1px solid var(--color-border);box-shadow:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:12px 24px}.header h1{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);letter-spacing:0}.header-logo{width:24px;height:24px}.header-left{gap:20px}.header-right{gap:8px}.tab-nav{background:#f3f4f6;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:3px}.tab{color:var(--color-text-secondary);border-radius:var(--radius-sm);padding:6px 14px}.tab:after{display:none}.tab:hover{color:var(--color-text-primary);background:#fff}.tab.active{color:var(--color-text-primary);background:#fff;box-shadow:0 1px 2px #0f172a14}.btn-primary{background:#111827;color:#fff;border-radius:var(--radius-md);font-weight:var(--font-weight-medium);box-shadow:none}.btn-primary:hover{background:#000}.btn-secondary,.btn-ghost{color:var(--color-text-primary);border-color:var(--color-border);background:#fff}.btn-secondary:hover,.btn-ghost:hover{background:#f3f4f6;color:var(--color-text-primary);border-color:var(--color-border)}.btn-user{color:var(--color-text-secondary);border-color:var(--color-border);background:#fff}.btn-user:hover{color:var(--color-text-primary);background:#f3f4f6;border-color:var(--color-border)}main{max-width:1120px;padding-top:20px}.filters{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:12px;gap:8px}.filters input,.filters select{background:#fff;border-color:var(--color-border);border-radius:var(--radius-md)}.filters input:focus,.filters select:focus{border-color:#9ca3af}.quick-filter-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.quick-filter-chip{min-height:36px;padding:0 12px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.quick-filter-chip:hover{border-color:var(--color-text-secondary);color:var(--color-text-primary)}.quick-filter-chip.active{background:var(--color-text-primary);border-color:var(--color-text-primary);color:var(--color-bg-card)}.filter-secondary-row{margin-top:2px}.filter-primary-row{display:flex;align-items:stretch;gap:var(--space-2);width:100%}.filter-primary-row .filter-search{flex:1;min-width:0}.filter-toggle{min-height:var(--tap-target-min);padding:0 var(--space-4);border:1px solid var(--color-border-input);border-radius:var(--radius-md);background:var(--color-bg-card);color:var(--color-text-secondary);font-weight:600;cursor:pointer}.filter-toggle.active{border-color:var(--color-text-primary);color:var(--color-text-primary)}.filter-options{display:grid;gap:var(--space-2);width:100%;padding-top:var(--space-2)}.filter-options[hidden]{display:none}.filter-options .channel-filter-row{margin:0}.filters .filter-category-select{width:auto;min-width:0;flex:0 1 auto;max-width:60%;min-height:36px}.filter-clear-chip{color:var(--color-text-muted)}.filter-clear-chip:hover{color:var(--color-text-primary)}.home-lane{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:none}.home-lane-header,.home-lane--today .home-lane-header{background:#fff;border-bottom:1px solid var(--color-border)}.home-lane-title,.home-lane-icon,.home-lane-label{color:var(--color-text-primary)}.home-lane-count{background:var(--color-text-primary);color:var(--color-bg-card);border:1px solid var(--color-text-primary)}.home-lane-hint{color:var(--color-text-secondary)}[data-theme=light] .home-lane--resume{background:#f8fafc;border-color:#cbd5e1}[data-theme=light] .home-lane--resume .home-lane-header{background:#eef2f7;border-bottom-color:#cbd5e1}[data-theme=light] .home-lane--resume .home-lane-title,[data-theme=light] .home-lane--resume .home-lane-icon{color:#111827}[data-theme=light] .home-lane--resume .home-lane-hint{color:#475569}[data-theme=light] .home-lane--resume .home-lane-rail-card{border-color:#d1d5db;background:#fff}[data-theme=light] .home-lane--resume .home-lane-rail-title{color:#111827}.today-play-all-btn,.today-clear-all-btn{border-radius:var(--radius-md)}.video-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.library-header{margin:var(--space-6) 0 var(--space-3);padding:0;border:0;background:transparent}.library-header .home-lane-title{font-size:var(--font-size-lg)}.empty-state-steps{display:flex;justify-content:center;gap:var(--space-3);margin:var(--space-4) 0;padding:0;list-style:none;counter-reset:onboarding-step}.empty-state-steps li{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-secondary);font-size:var(--font-size-sm);counter-increment:onboarding-step}.empty-state-steps li:before{content:counter(onboarding-step);display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-primary);font-weight:700}.login-value-proposition{max-width:32ch;margin:0 auto var(--space-5);color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6;text-align:center}.notes-error-state,.subs-error-state{min-height:240px}.notes-retry-btn,.subs-retry-btn{min-height:var(--tap-target-min);margin-top:var(--space-3)}.toast-close{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap-target-min);min-height:var(--tap-target-min);margin-left:auto;padding:0;border:0;border-radius:var(--radius-sm);background:transparent;color:inherit;cursor:pointer}.toast-close:hover,.toast-close:focus-visible{background:#7f7f7f29}.subs-uploads-error{display:grid;justify-items:start;gap:var(--space-2);padding:var(--space-4)}.video-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:none;overflow:hidden}.video-card:hover{box-shadow:none;transform:none;border-color:#d1d5db}.video-thumbnail{border-radius:0}.video-info{padding:12px}.video-card-primary{display:flex;align-items:flex-start;gap:var(--space-2)}.video-card-copy{flex:1;min-width:0}.video-info h3{font-size:var(--font-size-base);line-height:1.45}.video-card-secondary{display:flex;align-items:center;gap:var(--space-2);min-height:24px;margin-top:var(--space-2)}.video-card-secondary:empty{display:none}.video-recall-label{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.video-actions{margin-top:0}.video-menu-wrap{flex-shrink:0}.video-menu-btn{min-width:var(--tap-target-min);min-height:var(--tap-target-min)}.status-badge{border-radius:var(--radius-md);box-shadow:none}.tag{background:#f3f4f6;color:var(--color-text-secondary);border:1px solid var(--color-border)}.summary-badge{background:#fff;color:var(--color-text-primary);border:1px solid var(--color-border)}.video-menu,.modal{border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.edit-video-modal{max-height:calc(100dvh - 32px);overflow-y:auto}.form-group>label{display:grid;gap:var(--space-2)}.form-label{display:block;margin-bottom:var(--space-2);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600}.ai-study-header h2{font-size:var(--font-size-lg)}.ai-panel-content{border:1px solid var(--color-border);border-radius:var(--radius-lg)}.bottom-nav{background:#fffffff0;border-top:1px solid var(--color-border);box-shadow:none}.bottom-nav-item{color:var(--color-text-secondary)}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--color-text-primary);background:#f3f4f6}@media(max-width:768px){.header{flex-wrap:wrap;padding:10px 14px;align-items:center;gap:10px}.header-left{width:auto;flex:1;min-width:0;justify-content:flex-start}.header-right{position:static;width:auto;flex-shrink:0;flex-wrap:wrap}.header-right>.btn-compact{display:none}.header-right .btn-user{display:inline-flex;max-width:120px;min-height:var(--tap-target-min);overflow:hidden;text-overflow:ellipsis}.tab-nav{display:none}main{padding:16px 12px 96px}.filter-search,.filter-category-select,.quick-filter-chip,.channel-chip{min-height:var(--tap-target-min)}.filters{align-items:stretch}.filter-fields{width:100%}.filters input,.filters select{width:100%;min-width:0}}.player-container{--player-bg: var(--color-bg-card);--player-surface: var(--color-bg-card);--player-surface-raised: var(--color-bg-card-hover);--player-border: var(--color-border);--player-text: var(--color-text-primary);--player-text-secondary: var(--color-text-secondary);--player-text-muted: var(--color-text-muted);--player-accent: var(--player-text);background:var(--player-bg);color:var(--player-text)}.player-iframe-wrap{background:#000}.player-iframe-wrap--error>:first-child{visibility:hidden}.player-session-bar,.playlist-controls,.player-sidebar{background:var(--player-bg);border-color:var(--player-border);color:var(--player-text)}.player-session-bar{min-height:52px;border-bottom:1px solid var(--player-border)}.player-session-kind,.player-session-name,.player-session-progress,.player-title,.player-video-title,.playlist-header h3{color:var(--player-text)}.player-session-meta,.player-time,.playlist-count,.player-video-meta,.player-video-description,.playlist-empty,.sidebar-tab{color:var(--player-text-muted)}.player-float-btn,.player-keyboard-help-btn,.player-rate-controls,.player-sleep-btn{background:var(--player-surface-raised);border:1px solid var(--color-border-input);color:var(--player-text-secondary);box-shadow:var(--shadow-xs)}.player-study-btn{background:var(--player-surface-raised);border:1px solid var(--color-border-input);color:var(--player-text-secondary);box-shadow:none}.player-float-btn:hover,.player-keyboard-help-btn:hover,.player-rate-btn:hover,.player-sleep-btn:hover,.player-study-btn:hover,.sidebar-tab:hover{background:var(--player-surface-raised);border-color:var(--player-accent);color:var(--player-text)}.player-rate-btn,.player-close{color:var(--player-text-secondary)}.player-more-trigger{border-color:var(--player-border);background:var(--player-surface-raised);color:var(--player-text-secondary);box-shadow:none;font-weight:600}.player-more-trigger:hover,.player-more-trigger[aria-expanded=true]{background:var(--player-surface-raised);border-color:var(--player-text-secondary);color:var(--player-text)}.player-session-kind{color:var(--player-text-secondary);font-weight:600}.player-session-name{color:var(--player-text-muted)}.player-session-progress{padding:2px 8px;border:1px solid var(--player-border);background:var(--player-surface-raised);color:var(--player-text-secondary)}:where(button,a,input,select,textarea,summary,[tabindex]):focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}@media(max-width:480px){.filter-toggle{flex:0 0 auto;padding-inline:var(--space-3)}}.player-rate-btn.active,.player-sleep-btn.active,.player-study-btn.active,.sidebar-tab.active{background:var(--player-accent);color:var(--player-bg);border-color:var(--player-accent)}.player-rate-btn:disabled{color:var(--player-text-muted);opacity:1}.playlist-sidebar-header{color:var(--player-text-secondary);border-color:var(--player-border)}.playlist-sidebar-list{background:var(--player-bg)}.playlist-item{align-items:center;background:transparent;border-left:3px solid transparent;border-bottom:1px solid var(--player-border);color:var(--player-text)}.playlist-item:hover{background:var(--player-surface-raised)}.playlist-item.active{background:var(--player-surface-raised);border-left:3px solid var(--player-accent)}.playlist-item.watched{border-left:3px solid var(--color-success)}.playlist-sidebar-list .playlist-item-num{color:var(--player-text-muted)}.playlist-sidebar-list .playlist-item-title{color:var(--player-text)}.playlist-item-watched{background:#ffffff0d;color:var(--color-success-dark);border:1px solid var(--color-success)}.player-notes-section{background:var(--player-bg);color:var(--player-text)}.player-notes-title{color:var(--player-text)}.player-notes-header{gap:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--player-border)}.player-notes-count{background:var(--player-surface-raised);color:var(--player-text-secondary);border:1px solid var(--player-border)}.player-note-add-btn{background:var(--player-surface);border-color:var(--player-border);color:var(--player-text-secondary);border-radius:var(--radius-md);font-weight:600}.player-note-add-btn:hover{background:var(--player-surface-raised);color:var(--player-text)}.player-note-textarea{background:var(--player-surface);border-color:var(--player-border);color:var(--player-text)}.player-note-textarea::placeholder{color:var(--player-text-muted)}.player-note-textarea:focus{border-color:var(--player-accent)}.player-note-item{border-bottom:1px solid var(--player-border)}.player-note-time{background:var(--player-surface-raised);color:var(--player-text);border:1px solid var(--player-border)}.player-note-time:hover{background:var(--player-surface-raised);border-color:var(--player-text-secondary)}.player-note-content{color:var(--player-text-secondary)}.player-note-delete{border-radius:var(--radius-md);color:var(--player-text-muted)}.player-note-delete:hover{background:var(--color-danger-bg);color:var(--color-danger)}.player-notes-empty{color:var(--player-text-muted)}.playlist-controls .btn-secondary{background:var(--player-surface-raised);color:var(--player-text-secondary);border-color:var(--color-border-input);box-shadow:var(--shadow-xs)}.playlist-controls .btn-secondary:hover{background:var(--player-surface-raised);color:var(--player-text)}.playlist-controls .btn-secondary:disabled{background:var(--player-surface);color:var(--player-text-muted);border-color:var(--player-border);box-shadow:none}.playlist-progress{color:var(--player-text-muted)}.player-close{background:var(--player-surface-raised);border:1px solid var(--color-border-input);color:var(--player-text-secondary);box-shadow:none}.player-close:hover,.player-close:focus-visible{background:var(--player-surface-raised);border-color:var(--player-accent);color:var(--player-text)}.sidebar-tabs{border-color:var(--player-border)}.sidebar-tab{border-bottom:none}.sidebar-tab.active{background:var(--player-surface-raised);color:var(--player-text);border-bottom:none}.player-rate-select-label{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);min-height:var(--tap-target-min);padding:0 var(--space-3);border:1px solid var(--color-border-input);border-radius:var(--radius-md);background:var(--player-surface-raised);color:var(--player-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-xs)}.player-rate-select{min-height:34px;border:none;background:transparent;color:var(--player-text);font:inherit;font-weight:var(--font-weight-semibold);outline:none}.player-list-end-panel,.player-keyboard-help-panel{background:var(--color-bg-card);color:var(--color-text-primary);border-color:var(--color-border);box-shadow:var(--shadow-modal)}.player-list-end-panel h3,.player-keyboard-help-header h3{color:var(--color-text-primary)}.player-list-end-desc,.player-keyboard-help-note{color:var(--color-text-secondary);border-color:var(--color-border)}.player-review-actions{background:var(--color-bg-page);border-color:var(--color-border)}.player-review-label{color:var(--color-text-secondary)}.player-review-chip{background:var(--color-bg-card);border-color:var(--color-border);color:var(--color-text-secondary)}.player-review-chip:hover,.player-review-chip:focus-visible{background:var(--color-bg-card-hover);border-color:var(--color-text-primary);color:var(--color-text-primary)}.sidebar-tab.active{color:var(--player-text)}.player-keyboard-help-header,.player-keyboard-help-table tr:not(:last-child) th,.player-keyboard-help-table tr:not(:last-child) td{border-color:var(--color-border)}.player-keyboard-help-close{color:var(--color-text-secondary)}.player-keyboard-help-close:hover{background:var(--color-bg-card-hover);color:var(--color-text-primary)}.player-keyboard-help-table th{color:var(--color-text-secondary)}.player-keyboard-help-table td{color:var(--color-text-primary)}.player-sidebar-ai-stack .ai-panel-header{background:var(--player-bg);border-color:var(--player-border);color:var(--player-text)}.player-sidebar-ai-stack .ai-panel-title{color:var(--player-text)}.player-sidebar-ai-stack .ai-panel-close{background:var(--player-surface-raised);border:1px solid var(--player-border);color:var(--player-text-secondary)}.player-sidebar-ai-stack .ai-panel-close:hover,.player-sidebar-ai-stack .ai-panel-close:focus-visible{background:var(--player-surface-raised);border-color:var(--player-text-secondary);color:var(--player-text)}.player-sidebar-ai-stack .ai-chat{background:var(--player-bg);color:var(--player-text)}.player-sidebar-ai-stack .ai-chat-messages{background:var(--player-bg)}.player-sidebar-ai-stack .ai-chat-context-hint,.player-sidebar-ai-stack .ai-chat-daily-usage,.player-sidebar-ai-stack .ai-chat-empty,.player-sidebar-ai-stack .ai-chat-ref-time,.player-sidebar-ai-stack .ai-message-meta{color:var(--player-text-secondary)}.player-sidebar-ai-stack .ai-message-assistant .ai-message-bubble,.player-sidebar-ai-stack .ai-chat-input-area{background:var(--player-surface);border-color:var(--player-border);color:var(--player-text)}.player-sidebar-ai-stack .ai-chat-textarea,.player-sidebar-ai-stack .ai-chip{background:var(--player-bg);border-color:var(--player-border);color:var(--player-text)}.player-sidebar-ai-stack .ai-chat-textarea::placeholder{color:var(--player-text-muted)}.player-sidebar-ai-stack .ai-chip:hover,.player-sidebar-ai-stack .ai-chip:focus-visible{background:var(--player-surface-raised);border-color:var(--player-text-secondary);color:var(--player-text)}@media(max-width:768px){.btn-user{padding-right:5px}.btn-user-name{display:none}.settings-overlay{align-items:flex-end;padding:0}.settings-modal{width:100%;max-height:calc(100dvh - 24px);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.settings-modal-header,.settings-section,.settings-actions{padding-inline:16px}.player-radio-caption{align-items:flex-start}.player-radio-caption-copy{flex-direction:column;gap:2px}.player-radio-text{white-space:normal;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.player-more-overlay{align-items:flex-end;padding:0}.player-more-panel{width:100%;max-height:min(70dvh,520px);border-width:1px 0 0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding-bottom:env(safe-area-inset-bottom,0px)}.player-more-panel-content{grid-template-columns:repeat(2,minmax(0,1fr))}.player-more-panel-content .player-more-setting{grid-column:1 / -1}.player-more-panel-content button{width:100%;min-width:0;padding-inline:10px}.player-more-panel-content .player-more-keyboard{grid-column:1 / -1}.player-container--compact-notes{height:auto;max-height:100dvh;align-self:flex-start}.player-container--compact-notes .player-body,.player-container--compact-notes .player-sidebar,.player-container--compact-notes .player-notes-section{flex:none}.player-container--compact-notes .player-notes-section{overflow:visible}.player-container--compact-notes .player-notes-empty{margin-bottom:0}.player-session-bar{min-height:52px;padding-right:60px}.player-session-name{display:none}.player-close--bar{width:44px;height:44px;right:8px;border-radius:var(--radius-md);font-size:var(--font-size-lg)}.player-below{gap:var(--space-2);padding:10px 12px 6px}.player-title--below{font-size:var(--font-size-sm);line-height:1.35}.player-below-actions .player-float-btn,.playlist-progress{display:none}.playlist-controls{gap:var(--space-2)}.playlist-controls .btn-secondary{flex:1;min-width:0}.player-sidebar.ai-open .ai-panel-header:before{background:var(--color-border)}}.ai-length-btn,.ai-panel-empty{color:var(--color-text-secondary)}[data-theme=dark] .modal-wide{background:var(--color-bg-card);color:var(--color-text-primary)}[data-theme=dark] .ai-study-title,[data-theme=dark] .ai-study-header h2,[data-theme=dark] .ai-panel-content,[data-theme=dark] .ai-panel-empty,[data-theme=dark] .ai-panel-meta,[data-theme=dark] .ai-length-btn{color:var(--color-text-primary)}[data-theme=dark] .ai-study-title,[data-theme=dark] .ai-panel-meta{color:var(--color-text-secondary)}[data-theme=dark] .ai-panel-controls,[data-theme=dark] .ai-length-group{background:var(--color-bg-secondary);border-color:var(--color-border)}[data-theme=dark] .ai-length-btn:hover{background:var(--color-bg-card-hover);color:#fff}[data-theme=dark] .ai-length-btn.active{background:var(--color-text-primary);color:var(--color-bg-card)}[data-theme=dark] .ai-panel-content,[data-theme=dark] .ai-panel-empty{background:var(--color-bg-secondary);border-color:var(--color-border-input)}[data-theme=dark] .summary-badge{background:#2d3154;color:#e0e7ff;border-color:#59608d}.add-video-modal{max-width:680px;height:auto;max-height:min(82dvh,760px)}.add-video-search-row{align-items:stretch}.recommendation-chips{display:flex;align-items:center;gap:10px;margin:-2px 0 10px;flex-shrink:0}.recommendation-chips-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap}.recommendation-chip-list{display:flex;gap:6px;flex-wrap:wrap;min-width:0}.recommendation-chip{min-height:36px;padding:0 12px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;cursor:pointer}.recommendation-chip:hover{border-color:var(--color-accent);color:var(--color-text-primary)}.recommendation-chip.active{border-color:var(--color-accent);background:var(--color-accent);color:#fff}.recommendation-chip:disabled{cursor:not-allowed}.recommendation-chip:disabled:not(.active){opacity:.65}.add-video-state{margin:2px 0 10px;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.add-video-item{background:var(--color-bg-card);box-shadow:none}.add-video-item-row{cursor:default}.add-video-thumb-wrap{position:relative;flex-shrink:0}.add-video-duration{position:absolute;right:4px;bottom:4px;padding:1px 5px;border-radius:var(--radius-sm);background:#111827db;color:#fff;font-size:11px;line-height:1.4}.add-video-item-actions{display:flex;gap:6px;flex-shrink:0}.add-video-preview-btn,.add-video-detail-btn,.add-video-add-btn{min-width:56px;min-height:var(--tap-target-min);padding:0 12px}.add-video-item-registered{color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card-hover)}.add-video-expand-form{background:var(--color-bg-page)}.add-video-url-preview{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3);background:var(--color-bg-card)}[data-theme=dark] .add-video-duration{background:#000000c7}@media(max-width:640px){.add-video-modal{height:auto;max-height:calc(100dvh - 16px);padding:16px}.add-video-modal input,.add-video-modal button{min-height:var(--tap-target-min)}.add-video-search-row{flex-direction:column}.recommendation-chips{align-items:center;flex-wrap:wrap;gap:6px 8px}.recommendation-chip-list{flex:1}.recommendation-chip{min-height:var(--tap-target-min)}.add-video-item-row{align-items:flex-start;flex-wrap:wrap}.add-video-item-thumb{width:96px;height:54px}.add-video-item-actions{width:100%;margin-top:8px}.add-video-preview-btn,.add-video-detail-btn,.add-video-add-btn{flex:1}.add-video-expand-actions,.add-video-url-form .modal-actions{flex-direction:column}.add-video-expand-actions>button,.add-video-url-form .modal-actions>button{width:100%}.empty-state-steps{align-items:flex-start;flex-direction:column;width:fit-content;margin-inline:auto}}@media(max-width:768px){.btn-primary,.btn-secondary,.btn-ghost,.ai-study-tab,.player-sleep-opt,.player-sleep-clear,.player-sleep-dim-btn,.header .header-right .btn-user,.filters .filter-search,.filters .filter-category-select,.filters .quick-filter-chip,.channel-filter-row .channel-chip{min-height:var(--tap-target-min)}.add-video-item-btn,.yt-video-add-btn,.btn-stream{min-width:var(--tap-target-min);min-height:var(--tap-target-min);width:var(--tap-target-min);height:var(--tap-target-min)}}@media(min-width:769px){.video-grid{grid-template-columns:repeat(auto-fit,minmax(280px,400px))!important;justify-content:center}.video-card-wrap,.video-card{width:100%}}.today-more-menu:not([open]) .today-more-menu-popover{display:none!important}@media(max-width:768px){.player-close--bar,.player-resume-restart,.player-resume-dismiss,.player-rate-select,.player-below-bookmark,.player-study-btn,.player-more-trigger,.player-note-add-btn{min-height:46px!important}.player-close--bar,.player-resume-dismiss{min-width:46px!important}.link-btn,.video-menu button,.player-note-time,.subs-add-channel-btn,.subs-add-btn,.notes-search-input,.header-dropdown button,.recommendation-chip,.ai-chip,.login-form input,.password-toggle-btn,.google-btn{min-height:46px!important}.link-btn,.player-note-time,.recommendation-chip,.ai-chip{min-width:46px}.player-sidebar{width:100%!important;min-width:100%;max-width:none;align-self:stretch}.bottom-nav-item{font-size:var(--font-size-xs)}.player-notes-section{flex:1;width:100%;min-height:0;border-radius:0}}.btn-primary svg,.btn-secondary svg,.subs-add-channel-btn svg,.subs-add-btn svg,.player-study-btn svg,.ai-panel-title svg,.empty-state-icon svg,.welcome-icon svg{flex-shrink:0;vertical-align:middle}.player-study-btn,.ai-panel-title,.subs-add-channel-btn,.subs-add-btn{display:inline-flex;align-items:center;gap:var(--space-2)}.player-load-error{position:absolute;inset:0;z-index:8;display:grid;place-content:center;justify-items:center;gap:var(--space-3);padding:var(--space-6);background:#000000e6;color:#fff;text-align:center}.player-load-error span{max-width:42ch;color:#ffffffd1;font-size:var(--font-size-sm)}.player-load-error .btn-primary{display:inline-flex;align-items:center;justify-content:center;min-height:var(--tap-target-min);text-decoration:none}.player-load-error-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2)}.player-load-error-actions .btn-primary,.player-load-error-actions .btn-secondary,.player-load-error-actions .btn-ghost{min-height:var(--tap-target-min)}.modal-loading-overlay{z-index:1200}.modal-loading{min-width:140px;padding:var(--space-5);border-radius:var(--radius-lg);background:var(--color-bg-card);color:var(--color-text-primary);box-shadow:var(--shadow-lg);text-align:center;font-weight:var(--font-weight-medium)}.ai-study-panel-overlay{position:absolute;inset:0;z-index:100;display:flex;align-items:stretch;justify-content:flex-end;padding:var(--space-3);background:#1118279e}.ai-study-panel{display:flex;flex-direction:column;width:min(760px,72%);min-width:0;padding:var(--space-5);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);color:var(--color-text-primary);box-shadow:var(--shadow-lg)}.ai-study-panel .ai-study-body{flex:1;min-height:0;max-height:none;overflow-y:auto}@media(max-width:768px){.ai-study-panel-overlay{padding:0}.ai-study-panel{width:100%;height:100%;padding:var(--space-4);border:0;border-radius:0}}
