:root{--bg: #0f0f10;--bg-elev: #1a1a1c;--bg-elev-2: #232326;--border: #2c2c30;--text: #f1f1f1;--text-dim: #a8a8ad;--accent: #ff0033;--accent-hover: #ff2a52;--header-h: 64px;--queue-w: 340px;--radius: 10px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;background:var(--bg);color:var(--text)}button{font-family:inherit}a{color:inherit}.app{display:flex;flex-direction:column;height:100vh;width:100%;overflow:hidden}.app-header{height:var(--header-h);display:flex;align-items:center;gap:16px;padding:0 20px;background:var(--bg-elev);border-bottom:1px solid var(--border);z-index:60;flex-shrink:0}.logo-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center}.logo{height:40px;width:auto;display:block}.search-wrap{flex:1;display:flex;justify-content:center}.search-group{display:flex;gap:8px;width:100%;max-width:720px;align-items:center}.search-input{flex:1;min-width:0;height:40px;padding:0 16px;border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:20px;font-size:15px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ff00332e}.btn-yt-search{flex-shrink:0;height:40px;padding:0 16px;border:1px solid var(--border);background:var(--bg-elev-2);color:var(--text);border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .15s ease,border-color .15s ease,color .15s ease}.btn-yt-search:hover:not(:disabled),.btn-yt-search:focus-visible{background:var(--accent);border-color:var(--accent);color:#fff;outline:none}.btn-yt-search:disabled{opacity:.45;cursor:not-allowed}.header-actions{display:flex;gap:8px;align-items:center}.btn-icon{background:var(--bg-elev-2);border:none;cursor:pointer;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;transition:background-color .15s ease,transform .4s ease}.btn-icon:hover{background:#303034}.btn-icon:active .btn-icon-img{transform:rotate(-180deg)}.btn-icon-img{width:18px;height:18px;display:block;transition:transform .4s ease;filter:invert(1)}.btn-icon-svg{width:18px;height:18px;display:block;color:var(--text)}.btn-tv-toggle.is-active{background:var(--accent)}.btn-tv-toggle.is-active:hover{background:var(--accent-hover)}.btn-tv-toggle.is-active .btn-icon-svg{color:#fff}.btn-primary,.btn-secondary,.btn-link{border:none;cursor:pointer;font-size:14px;font-weight:500;padding:8px 14px;border-radius:8px;transition:background-color .15s ease,transform .05s ease}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-elev-2);color:var(--text)}.btn-secondary:hover{background:#303034}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-link{background:none;color:var(--text-dim);padding:4px 8px;font-size:13px}.btn-link:hover{color:var(--text)}.btn-sm{font-size:13px;padding:6px 10px}.app-main{flex:1;overflow:hidden;position:relative}.app-main.with-mini{padding-bottom:0}.view{height:100%;overflow:auto}.view[hidden]{display:none!important}.browse{padding:24px 28px 120px;max-width:1500px;margin:0 auto}.browse-header{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.browse-header-main{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.browse-header h2{margin:0;font-size:22px;font-weight:600}.browse-header .count{color:var(--text-dim);font-size:14px}.services-row{display:flex;flex-wrap:wrap;gap:8px}.service-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-elev-2);border-radius:999px;font-size:12px;color:var(--text-dim);border:1px solid var(--border)}.service-pill.is-up{color:var(--text)}.service-dot{width:8px;height:8px;border-radius:50%;background:#6b7280;flex-shrink:0}.service-pill.is-up .service-dot{background:#4ade80;box-shadow:0 0 6px #4ade8099}.service-pill.is-down .service-dot{background:#ff4d4f}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}.status-msg{padding:60px 24px;text-align:center;color:var(--text-dim)}.status-msg.error{color:#ff7373}.video-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s ease,border-color .15s ease}.video-card:hover{transform:translateY(-2px);border-color:#3a3a3f}.video-card.is-current{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.thumb{position:relative;background:linear-gradient(135deg,#2a2a2e,#1a1a1c);border:none;cursor:pointer;padding:0 0 56.25%;width:100%;height:0}@supports (aspect-ratio: 16 / 9){.thumb{aspect-ratio:16 / 9;height:auto;padding-bottom:0;display:flex;align-items:center;justify-content:center}}.thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.thumb-inner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;border-radius:50%;background:#ff0033d9;display:flex;align-items:center;justify-content:center;transition:background .15s ease,transform .15s ease,opacity .15s ease}.thumb:hover .thumb-inner{transform:translate(-50%,-50%) scale(1.06);background:var(--accent)}.thumb.has-thumb .thumb-inner{opacity:0}.thumb.has-thumb:hover .thumb-inner{opacity:1}.play-icon{color:#fff;font-size:22px;margin-left:4px}.thumb-ext{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.thumb-res{position:absolute;bottom:8px;right:8px;background:#000000d9;color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;font-weight:600;letter-spacing:.3px}.card-body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:8px}.card-title{margin:0;font-size:15px;font-weight:500;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.card-meta{display:flex;gap:10px;font-size:12px;color:var(--text-dim);flex-wrap:wrap}.card-meta .folder{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}.card-actions{display:flex;gap:8px;margin-top:4px}.btn-secondary.is-queued,.btn-secondary.is-queued:disabled{background:#2ea0432e;color:#4ade80;opacity:1;cursor:default}.player-view{height:100%;display:grid;grid-template-columns:1fr var(--queue-w);gap:20px;padding:20px;overflow:hidden}.player-main{display:flex;flex-direction:column;gap:16px;min-width:0;overflow:auto}.player-stage{width:100%;background:#000;border-radius:12px;flex-shrink:0;position:relative;height:0;padding-bottom:56.25%}@supports (aspect-ratio: 16 / 9){.player-stage{height:auto;padding-bottom:0;aspect-ratio:16 / 9}}.player-info{display:flex;flex-direction:column;gap:10px}.player-title{margin:0;font-size:22px;font-weight:600;word-break:break-word}.player-meta{display:flex;gap:12px;color:var(--text-dim);font-size:14px}.player-actions{display:flex;gap:10px;margin-top:6px}.player-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--text-dim)}.queue-panel{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden}.queue-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.queue-header h3{margin:0;font-size:15px;font-weight:600}.queue-empty{padding:24px 16px;color:var(--text-dim);font-size:13px;line-height:1.5}.queue-list{list-style:none;margin:0;padding:6px 0;overflow-y:auto}.queue-divider{display:flex;align-items:center;gap:8px;padding:8px 14px}.queue-divider-line{flex:1;height:1px;background:var(--border)}.queue-divider-text{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);white-space:nowrap}.queue-divider-row{display:block;padding:0}.queue-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;margin:2px 6px}.queue-item:hover{background:var(--bg-elev-2)}.queue-thumb{position:relative;flex:0 0 auto;width:72px;height:41px;padding:0;border:none;border-radius:6px;overflow:hidden;cursor:pointer;background:#000}.queue-thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.queue-thumb-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:26px;height:26px;border-radius:50%;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;opacity:0;transition:opacity .15s ease,background-color .15s ease}.queue-thumb:not(.has-thumb) .queue-thumb-play{opacity:1;background:var(--bg-elev-2)}.queue-thumb:hover .queue-thumb-play{opacity:1;background:var(--accent)}.queue-info{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:none;border:none;color:var(--text);text-align:left;padding:0;cursor:pointer}.queue-info-title{font-size:13px;font-weight:500;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;width:100%;word-break:break-word}.queue-info-artist{font-size:11px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.queue-jump,.queue-remove{background:none;border:none;color:var(--text-dim);cursor:pointer;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.queue-jump{font-size:16px}.queue-remove{font-size:18px}.queue-jump:hover,.queue-remove:hover{color:var(--text);background:var(--bg-elev-2)}.queue-jump:hover{color:var(--accent)}.queue-next{display:grid;grid-template-columns:1fr auto;grid-template-areas:"label remove" "thumb thumb" "body  body";gap:8px;padding:12px 12px 14px;border-bottom:1px solid var(--border);background:var(--bg-elev-2)}.queue-next-label{grid-area:label;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);align-self:center}.queue-next .queue-remove{grid-area:remove;align-self:center}.queue-next-thumb{grid-area:thumb;position:relative;width:100%;padding:0 0 56.25%;border:none;border-radius:8px;overflow:hidden;cursor:pointer;background:#000}@supports (aspect-ratio: 16 / 9){.queue-next-thumb{aspect-ratio:16 / 9;padding-bottom:0}}.queue-next-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.queue-next-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background-color .15s ease}.queue-next-thumb:hover .queue-next-play{background:var(--accent)}.queue-next-res{position:absolute;bottom:6px;right:6px;background:#000000b3;color:#fff;font-size:11px;padding:2px 6px;border-radius:4px}.queue-next-body{grid-area:body;display:flex;flex-direction:column;gap:2px;min-width:0}.queue-next-title{margin:0;font-size:14px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.queue-next-meta{font-size:12px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-surface{position:fixed;z-index:80;background:#000;overflow:hidden;box-shadow:0 12px 32px #00000080;transition:top .28s ease,left .28s ease,bottom .28s ease,right .28s ease,width .28s ease,height .28s ease,border-radius .28s ease}.video-surface video{width:100%;height:100%;display:block;background:#000;object-fit:contain}.video-surface.mode-browse{cursor:pointer;border:1px solid var(--border)}.video-surface.mode-browse video{pointer-events:none}.mini-label{position:absolute;bottom:0;left:0;right:0;padding:6px 10px;background:linear-gradient(to top,#000c,#0000);color:#fff;font-size:12px;display:flex;justify-content:space-between;gap:8px;pointer-events:none}.mini-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.mini-hint{opacity:.8;font-size:11px;flex-shrink:0}@media (max-width: 960px){.player-view{grid-template-columns:1fr;grid-template-rows:auto 1fr}.queue-panel{max-height:280px}}@media (max-width: 600px){.app-header{padding:0 12px;gap:8px}.logo{height:32px}.header-actions .btn-secondary{padding:6px 10px;font-size:12px}.btn-yt-search{padding:0 10px;font-size:12px}.header-actions .btn-icon{width:32px;height:32px}.header-actions .btn-icon-img{width:16px;height:16px}.browse{padding:16px 12px 120px}}.yt-results{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px 16px;margin-bottom:18px}.yt-results-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}.yt-results-header h3{margin:0;font-size:14px;font-weight:600;letter-spacing:.02em;color:var(--text)}.yt-results-hint{font-size:11px;color:var(--text-dim)}.yt-results-empty{margin:0;font-size:13px;color:var(--text-dim)}.yt-results-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.yt-card{display:flex;flex-direction:column;gap:6px;padding:6px;border-radius:8px;text-decoration:none;color:inherit;background:transparent;transition:background-color .15s ease,box-shadow .15s ease;text-align:left;font:inherit;border:1px solid transparent;cursor:pointer}button.yt-card{width:100%}.yt-card:hover,.yt-card:focus-visible{background:var(--bg-elev-2);outline:none}.yt-card-local{border-color:#f036}.yt-card-local:hover,.yt-card-local:focus-visible{border-color:var(--accent);background:var(--bg-elev-2)}.yt-local-badge{position:absolute;top:6px;left:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:3px 7px;border-radius:4px;line-height:1.2;box-shadow:0 1px 4px #00000073}.yt-card-download:disabled{cursor:default}.yt-card-download.is-requested{opacity:.75}.yt-card-download.is-error{border-color:#ff5a5a80}.yt-download-badge{position:absolute;top:6px;left:6px;color:#fff;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:3px 7px;border-radius:4px;line-height:1.2;box-shadow:0 1px 4px #00000073}.yt-download-badge.is-requesting{background:#b58200}.yt-download-badge.is-requested{background:#1f8a3f}.yt-download-badge.is-error{background:#c0392b}.yt-thumb{position:relative;width:100%;border-radius:6px;overflow:hidden;background:#000;padding-bottom:56.25%}@supports (aspect-ratio: 16 / 9){.yt-thumb{aspect-ratio:16 / 9;padding-bottom:0}}.yt-thumb img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.yt-duration{position:absolute;bottom:4px;right:4px;background:#000000c7;color:#fff;font-size:11px;padding:1px 5px;border-radius:3px;line-height:1.4}.yt-card-body{display:flex;flex-direction:column;gap:2px;padding:0 2px;min-width:0}.yt-card-title{font-size:13px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.yt-card-channel{font-size:12px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}html.tv-mode{--header-h: 96px;--queue-w: 480px;--radius: 14px}html.tv-mode .app-header{gap:24px;padding:0 32px}html.tv-mode .logo{height:56px}html.tv-mode .search-group{gap:14px;max-width:1100px}html.tv-mode .search-input{height:60px;padding:0 24px;border-radius:30px;font-size:22px}html.tv-mode .btn-yt-search{height:60px;padding:0 24px;border-radius:30px;font-size:18px}html.tv-mode .header-actions{gap:14px}html.tv-mode .btn-icon{width:60px;height:60px}html.tv-mode .btn-icon-img,html.tv-mode .btn-icon-svg{width:28px;height:28px}html.tv-mode .btn-primary,html.tv-mode .btn-secondary{font-size:18px;padding:12px 22px;border-radius:12px}html.tv-mode .btn-link{font-size:16px;padding:8px 12px}html.tv-mode .btn-sm{font-size:16px;padding:10px 16px}html.tv-mode .browse{padding:36px 40px 200px;max-width:2400px}html.tv-mode .browse-header{gap:14px;margin-bottom:28px}html.tv-mode .browse-header h2{font-size:32px}html.tv-mode .browse-header .count{font-size:18px}html.tv-mode .service-pill{font-size:16px;padding:6px 14px}html.tv-mode .service-dot{width:10px;height:10px}html.tv-mode .grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:28px}html.tv-mode .card-body{padding:16px 18px 18px;gap:10px}html.tv-mode .card-title{font-size:20px;line-height:1.35}html.tv-mode .card-meta{font-size:16px;gap:14px}html.tv-mode .thumb-ext,html.tv-mode .thumb-res{font-size:14px;padding:4px 10px;border-radius:6px}html.tv-mode .thumb-inner{width:84px;height:84px}html.tv-mode .play-icon{font-size:30px}html.tv-mode .player-view{gap:28px;padding:28px}html.tv-mode .player-info{gap:14px}html.tv-mode .player-title{font-size:32px}html.tv-mode .player-meta{font-size:20px;gap:18px}html.tv-mode .player-actions{gap:14px;margin-top:10px}html.tv-mode .queue-header{padding:18px 20px}html.tv-mode .queue-header h3{font-size:20px}html.tv-mode .queue-empty{padding:32px 20px;font-size:16px;line-height:1.5}html.tv-mode .queue-list{padding:10px 0}html.tv-mode .queue-item{gap:14px;padding:10px 14px;margin:4px 8px;border-radius:12px}html.tv-mode .queue-thumb{width:128px;height:72px;border-radius:8px}html.tv-mode .queue-thumb-play{width:40px;height:40px;font-size:18px}html.tv-mode .queue-info-title{font-size:17px;line-height:1.35}html.tv-mode .queue-info-artist{font-size:14px}html.tv-mode .queue-jump,html.tv-mode .queue-remove{width:44px;height:44px}html.tv-mode .queue-jump{font-size:22px}html.tv-mode .queue-remove{font-size:26px}html.tv-mode .queue-divider{padding:12px 18px}html.tv-mode .queue-divider-text{font-size:13px}html.tv-mode .queue-next{padding:18px 18px 22px;gap:12px}html.tv-mode .queue-next-label{font-size:14px}html.tv-mode .queue-next-title{font-size:18px}html.tv-mode .queue-next-meta{font-size:15px}html.tv-mode .queue-next-play{width:64px;height:64px;font-size:26px}html.tv-mode .queue-next-res{font-size:14px;padding:4px 10px}html.tv-mode .yt-results{padding:20px 24px 24px;margin-bottom:28px}html.tv-mode .yt-results-header h3{font-size:20px}html.tv-mode .yt-results-hint,html.tv-mode .yt-results-empty{font-size:16px}html.tv-mode .yt-results-row{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}html.tv-mode .yt-card{padding:10px;gap:10px;border-radius:12px}html.tv-mode .yt-card-title{font-size:17px}html.tv-mode .yt-card-channel{font-size:15px}html.tv-mode .yt-duration{font-size:14px;padding:2px 8px}html.tv-mode .yt-local-badge,html.tv-mode .yt-download-badge{font-size:13px;padding:5px 10px}html.tv-mode .mini-label{font-size:16px;padding:10px 14px}html.tv-mode .mini-hint{font-size:14px}html.tv-mode .status-msg{font-size:18px;padding:80px 24px}html.tv-mode :focus-visible{outline:3px solid var(--accent);outline-offset:3px}html.tv-mode .video-card:hover,html.tv-mode .video-card:focus-within{transform:translateY(-3px);border-color:var(--accent)}
