*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #141414;--bg-hover: #1a1a1a;--bg-active: #222;--text-primary: #f0f0f0;--text-secondary: #a0a0a0;--text-muted: #606060;--accent: #e50914;--accent-hover: #ff1a1a;--accent-dim: rgba(229, 9, 20, .15);--danger: #ef4444;--success: #22c55e;--border: #1a1a1a;--border-light: #222;--radius: 6px;--radius-lg: 10px;--shadow: 0 4px 20px rgba(0, 0, 0, .6);--navbar-height: 64px;--mini-player-height: 64px;--transition: .15s ease}body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased}#root{max-width:unset;margin:0;padding:0;text-align:unset}button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}select{font:inherit;color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px;cursor:pointer}select option{background:var(--bg-tertiary);color:var(--text-primary)}select:focus{outline:none;border-color:var(--accent)}.app-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;min-width:0;overflow-x:hidden;min-height:100vh;padding-top:var(--navbar-height)}.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height);z-index:100;background:transparent;transition:background .3s ease}.navbar-scrolled{background:#000000eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px #ffffff0a}.navbar-inner{display:flex;align-items:center;height:100%;padding:0 48px;gap:32px;max-width:1920px;margin:0 auto}.navbar-logo{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0}.navbar-eye-logo{color:var(--accent)}.navbar-brand{font-size:1.3rem;font-weight:800;color:#fff;letter-spacing:-.5px}.navbar-links{display:flex;align-items:center;gap:4px}.navbar-link{color:var(--text-secondary);text-decoration:none;font-size:.88rem;font-weight:500;padding:6px 14px;border-radius:var(--radius);transition:color .2s,background .2s;white-space:nowrap}.navbar-link:hover{color:#fff}.navbar-link.active{color:#fff;font-weight:600}.navbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.navbar-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:var(--text-secondary);transition:color .2s,background .2s}.navbar-icon-btn:hover{color:#fff;background:#ffffff14}.navbar-search.open{position:relative}.navbar-search-form{display:flex;align-items:center;gap:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:4px 12px;min-width:240px}.navbar-search-input{background:transparent;border:none;color:#fff;font-size:.88rem;outline:none;width:100%;font-family:inherit}.navbar-search-input::placeholder{color:var(--text-muted)}.navbar-search-close{color:var(--text-secondary);display:flex;padding:2px}.navbar-search-close:hover{color:#fff}.navbar-user-menu{position:relative}.navbar-user-btn{display:flex;align-items:center;gap:6px;padding:4px;border-radius:var(--radius);transition:background .2s}.navbar-user-btn:hover{background:#ffffff0f}.navbar-avatar{width:30px;height:30px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;overflow:hidden}.navbar-avatar img{width:100%;height:100%;object-fit:cover}.navbar-chevron{color:var(--text-secondary);transition:transform .2s}.navbar-chevron.rotated{transform:rotate(180deg)}.navbar-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-lg);min-width:220px;padding:8px 0;box-shadow:0 8px 32px #00000080;animation:dropdown-in .15s ease-out}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.navbar-dropdown-header{display:flex;align-items:center;gap:10px;padding:12px 16px}.navbar-dropdown-avatar{width:36px;height:36px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff;overflow:hidden;flex-shrink:0}.navbar-dropdown-avatar img{width:100%;height:100%;object-fit:cover}.navbar-dropdown-name{font-size:.88rem;font-weight:600;color:#fff}.navbar-dropdown-role{font-size:.72rem;color:var(--text-muted);text-transform:capitalize}.navbar-dropdown-divider{height:1px;background:var(--border);margin:4px 0}.navbar-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 16px;font-size:.84rem;color:var(--text-secondary);transition:background .15s,color .15s;text-align:left}.navbar-dropdown-item:hover{background:#ffffff0f;color:#fff}.navbar-dropdown-logout{color:var(--accent)}.navbar-dropdown-logout:hover{color:var(--accent-hover);background:var(--accent-dim)}.status-dot-nav{width:6px;height:6px;border-radius:50%;display:inline-block;margin-left:4px}.status-dot-nav.status-operational{background:var(--success)}.status-dot-nav.status-degraded{background:#f59e0b}.status-dot-nav.status-outage{background:var(--danger)}.navbar-hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;width:36px;height:36px;padding:0}.hamburger-line{display:block;width:18px;height:2px;background:#fff;border-radius:1px;position:relative}.hamburger-line:before,.hamburger-line:after{content:"";position:absolute;width:18px;height:2px;background:#fff;border-radius:1px;left:0;transition:transform .2s}.hamburger-line:before{top:-6px}.hamburger-line:after{top:6px}.hamburger-line.open{background:transparent}.hamburger-line.open:before{transform:rotate(45deg) translate(4px,4px)}.hamburger-line.open:after{transform:rotate(-45deg) translate(4px,-4px)}.navbar-mobile-overlay{position:fixed;inset:0;top:var(--navbar-height);background:#0009;z-index:99;animation:fadeIn .15s ease}.navbar-mobile-menu{background:var(--bg-tertiary);padding:16px;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--border)}.navbar-mobile-link{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius);color:var(--text-secondary);text-decoration:none;font-size:.92rem;font-weight:500;transition:all var(--transition)}.navbar-mobile-link:hover,.navbar-mobile-link.active{color:#fff;background:#ffffff0f}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.navbar-inner{padding:0 16px;gap:12px}.navbar-links{display:none}.navbar-hamburger{display:flex}.navbar-search.open .navbar-search-form{min-width:160px}}.search-bar{position:relative;flex:1;max-width:480px}.search-bar input{width:100%;padding:10px 12px 10px 40px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color var(--transition)}.search-bar input:focus{border-color:var(--accent)}.search-bar input::placeholder{color:var(--text-muted)}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:var(--text-muted);padding:4px;border-radius:50%;display:flex;transition:all var(--transition)}.search-clear:hover{color:var(--text-primary);background:var(--bg-hover)}.browse-page{display:flex;flex-direction:column;gap:14px;padding:24px}.browse-page .search-bar{max-width:none}.networks-header{display:flex;align-items:center;gap:12px}.networks-search-wrap{flex:1}.networks-search-input{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:14px;padding:9px 14px;outline:none;transition:border-color .15s}.networks-search-input:focus{border-color:var(--accent)}.networks-search-input::placeholder{color:var(--text-muted)}.networks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.network-tile{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;display:flex;flex-direction:column}.network-tile:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 4px 16px #6366f133}.network-tile-logos{position:relative;aspect-ratio:16/9;background:#0d0d14;overflow:hidden}.network-tile-logo-single{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:10px;opacity:0;transition:opacity .7s ease}.network-tile-logo-single.active{opacity:1}.network-tile-logo-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.network-tile-flag{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:52px;line-height:1}.network-tile-info{padding:8px 10px;display:flex;align-items:baseline;justify-content:space-between;gap:6px}.network-tile-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.network-tile-count{font-size:11px;color:var(--text-muted);white-space:nowrap}.channels-network-bar{display:flex;align-items:center;gap:12px;padding-bottom:2px}.channels-back-btn{flex-shrink:0}.channels-network-name{font-size:16px;font-weight:700;color:var(--text-primary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.browse-toolbar{display:flex;flex-direction:column;gap:8px}.browse-toolbar-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.browse-filters{display:flex;gap:8px;flex-wrap:wrap}.browse-toolbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}.browse-select{padding:7px 28px 7px 10px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.82rem;cursor:pointer;transition:all var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.browse-select:hover{border-color:var(--border-light);color:var(--text-secondary)}.browse-select:focus{border-color:var(--accent);outline:none;color:var(--text-primary)}.browse-select.active{border-color:var(--accent);color:var(--accent);background-color:var(--accent-dim);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236366f1' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.browse-sort{min-width:110px}.browse-total{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted);white-space:nowrap;padding:7px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);font-variant-numeric:tabular-nums}.browse-chips{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.browse-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 8px 4px 10px;background:var(--accent-dim);color:var(--accent);border-radius:20px;font-size:.76rem;font-weight:500}.browse-chip-label{color:var(--accent);opacity:.6;text-transform:capitalize}.browse-chip-x{display:flex;align-items:center;padding:1px;margin-left:2px;color:var(--accent);opacity:.5;border-radius:50%;transition:all var(--transition)}.browse-chip-x:hover{opacity:1;background:#6366f133}.browse-clear-all{font-size:.76rem;color:var(--text-muted);padding:4px 8px;border-radius:var(--radius);transition:color var(--transition)}.browse-clear-all:hover{color:var(--danger)}.live-countries-header{display:flex;flex-direction:column;gap:16px;margin-bottom:8px}.live-countries-title-row{display:flex;align-items:flex-end;justify-content:space-between}.live-countries-title{font-size:1.6rem;font-weight:700;color:var(--text-primary);letter-spacing:-.5px;margin:0}.live-countries-subtitle{font-size:.82rem;color:var(--text-muted);margin:4px 0 0}.live-countries-toolbar{display:flex;align-items:center;gap:10px}.live-countries-search{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:0 12px;transition:border-color .15s}.live-countries-search:focus-within{border-color:var(--accent)}.live-countries-search svg{color:var(--text-muted);flex-shrink:0}.live-countries-search input{flex:1;background:none;border:none;color:var(--text-primary);font-size:.88rem;padding:9px 0;outline:none}.live-countries-search input::placeholder{color:var(--text-muted)}.live-countries-sort-wrap{position:relative;flex-shrink:0}.live-countries-sort-wrap select{padding:9px 32px 9px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:.82rem;cursor:pointer;appearance:none;outline:none;transition:border-color .15s}.live-countries-sort-wrap select:focus{border-color:var(--accent)}.live-countries-sort-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.live-section-label{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.live-section-label svg{color:var(--accent)}.live-featured-section{margin-bottom:24px}.live-featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.live-countries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.live-country-tile{border-radius:10px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;background:linear-gradient(135deg,hsl(var(--tile-hue) 40% 12%),hsl(var(--tile-hue) 30% 8%));border:1px solid hsl(var(--tile-hue) 20% 18%);display:flex;flex-direction:column}.live-country-tile:hover{transform:translateY(-3px);box-shadow:0 8px 24px hsl(var(--tile-hue) 40% 8% / .5);border-color:hsl(var(--tile-hue) 50% 45%)}.live-country-tile.featured{background:linear-gradient(135deg,hsl(var(--tile-hue) 45% 14%),hsl(var(--tile-hue) 35% 9%));border-color:hsl(var(--tile-hue) 30% 22%)}.live-country-tile.featured:hover{border-color:hsl(var(--tile-hue) 55% 50%);box-shadow:0 8px 28px hsl(var(--tile-hue) 50% 10% / .5)}.live-country-tile-body{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:14px 14px 10px;min-height:0}.live-country-tile-code{font-size:1.5rem;font-weight:800;color:hsl(var(--tile-hue) 50% 60%);letter-spacing:2px;line-height:1;opacity:.7}.live-country-tile-name{font-size:.82rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;margin-top:4px;line-height:1.3}.live-country-tile-footer{display:flex;align-items:center;gap:5px;padding:0 14px 10px;font-size:.7rem;color:var(--text-muted)}.live-country-tile-footer svg{opacity:.5}.live-country-tile.featured .live-country-tile-code{font-size:1.8rem}.live-country-tile.featured .live-country-tile-name{font-size:.88rem}.live-country-tile.featured .live-country-tile-body{padding:16px 16px 10px}.live-channel-filters{display:flex;align-items:center;gap:10px;margin-top:4px}.live-channel-search{flex:1;max-width:360px;display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:0 12px;transition:border-color .15s}.live-channel-search:focus-within{border-color:var(--accent)}.live-channel-search svg{color:var(--text-muted);flex-shrink:0}.live-channel-search input{flex:1;background:none;border:none;color:var(--text-primary);font-size:.88rem;padding:9px 0;outline:none}.live-channel-search input::placeholder{color:var(--text-muted)}.live-filter-select-wrap{position:relative;flex-shrink:0}.live-filter-select-wrap select{padding:9px 32px 9px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:.82rem;cursor:pointer;appearance:none;outline:none;max-width:240px;transition:border-color .15s}.live-filter-select-wrap select:focus{border-color:var(--accent)}.live-filter-select-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}@media(max-width:768px){.live-featured-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.live-countries-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.live-countries-title{font-size:1.3rem}.live-channel-filters{flex-wrap:wrap}.live-channel-search{max-width:none}}@media(max-width:480px){.live-featured-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px}.live-countries-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}.live-countries-toolbar{flex-direction:column}.live-countries-sort-wrap{align-self:flex-end}.live-country-tile-name{font-size:.75rem}.live-country-tile.featured .live-country-tile-name{font-size:.8rem}}.channel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:6px}.channel-card{display:flex;align-items:center;gap:12px;padding:8px 10px;background:transparent;border:1px solid transparent;border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.channel-card:hover{background:var(--bg-secondary);border-color:var(--border)}.channel-card-logo{width:42px;height:42px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.channel-card-logo img{width:100%;height:100%;object-fit:contain}.channel-card-logo-fallback{color:var(--text-muted);opacity:.4}.channel-card-info{flex:1;min-width:0}.channel-card-name{font-size:.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.channel-card-meta{display:flex;align-items:center;gap:6px;margin-top:1px}.channel-card-country{font-size:.75rem;color:var(--text-muted)}.channel-tag{font-size:.68rem;padding:1px 6px;background:var(--bg-tertiary);color:var(--text-muted);border-radius:3px}.channel-card-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--transition);flex-shrink:0}.channel-card:hover .channel-card-actions{opacity:1}.btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;color:var(--text-secondary);transition:all var(--transition)}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-play{color:var(--accent)}.btn-play:hover{background:var(--accent-dim);color:var(--accent-hover)}.btn-favorite.active{color:var(--danger)}.btn-back{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);color:var(--text-secondary);font-size:.9rem;transition:all var(--transition)}.btn-back:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-clear{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);color:var(--text-muted);font-size:.85rem;margin-left:auto;transition:all var(--transition)}.btn-clear:hover{color:var(--danger);background:#ef44441a}.player-page{display:flex;flex-direction:column;gap:12px}.player-body{display:flex;gap:16px;align-items:flex-start}.player-top-bar{display:flex;align-items:center;gap:16px}.player-channel-info{display:flex;align-items:center;gap:12px;flex:1}.player-channel-logo{width:40px;height:40px;border-radius:var(--radius);object-fit:contain;background:var(--bg-tertiary)}.player-channel-info h2{font-size:1.1rem;font-weight:600}.player-channel-meta{font-size:.8rem;color:var(--text-secondary)}.player-video-container{flex:1;min-width:0;aspect-ratio:16 / 9;background:#000;border-radius:var(--radius-lg);overflow:hidden}.player-epg{width:320px;flex-shrink:0;display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 140px);overflow-y:auto}.epg-now-next{display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.epg-program{display:flex;flex-direction:column;gap:4px;padding:10px 14px;position:relative}.epg-program.epg-now>.epg-program-badge,.epg-program.epg-next>.epg-program-badge{flex-shrink:0}.epg-program.epg-now{border-bottom:1px solid var(--border)}.epg-program-badge{display:inline-flex;align-items:center;font-size:.65rem;font-weight:700;letter-spacing:.06em;padding:2px 8px;border-radius:4px;text-transform:uppercase}.epg-program-badge.now{background:#ef444426;color:#f87171}.epg-program-badge.next{background:#6366f126;color:var(--accent)}.epg-program-info{flex:1;min-width:0}.epg-program-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-left:8px}.epg-program.epg-now .epg-program-title{margin-left:0;margin-top:6px}.epg-program-time{font-size:.78rem;color:var(--text-muted);margin-left:8px}.epg-program.epg-now .epg-program-time{margin-left:0}.epg-program-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.4;margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.epg-progress-bar{width:100%;height:3px;background:var(--bg-tertiary);border-radius:2px;margin-top:8px;overflow:hidden}.epg-progress-fill{height:100%;background:var(--danger);border-radius:2px;transition:width 1s linear}.epg-schedule-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.epg-schedule-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;font-size:.85rem;color:var(--text-secondary);transition:all var(--transition)}.epg-schedule-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.epg-schedule-chevron{margin-left:auto;transition:transform .15s}.epg-schedule-chevron.open{transform:rotate(180deg)}.epg-schedule-list{border-top:1px solid var(--border);max-height:320px;overflow-y:auto}.epg-schedule-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:.82rem;border-bottom:1px solid var(--border);transition:background var(--transition)}.epg-schedule-item:last-child{border-bottom:none}.epg-schedule-item:hover{background:var(--bg-hover)}.epg-schedule-item.past{opacity:.45}.epg-schedule-item.now{background:var(--accent-dim)}.epg-schedule-time{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;min-width:60px}.epg-schedule-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.epg-schedule-cat{font-size:.7rem;padding:2px 6px;background:var(--bg-tertiary);color:var(--text-muted);border-radius:4px;flex-shrink:0}.epg-schedule-live{font-size:.6rem;font-weight:700;padding:1px 5px;border-radius:3px;background:var(--danger);color:#fff;flex-shrink:0}.video-player{position:relative;width:100%;height:100%;background:#000;outline:none}.video-player video{width:100%;height:100%;display:block}.video-player.compact video{object-fit:cover}.video-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#000000b3;color:var(--text-secondary);font-size:.9rem;z-index:10;pointer-events:none}.video-error{color:var(--text-secondary);pointer-events:all;background:radial-gradient(ellipse at center,#0f0f0ff2,#000000fa)}.error-signal{position:relative;display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:4px}.error-signal svg{color:#ef4444;z-index:1}.error-signal-rings{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.error-ring{position:absolute;border:1.5px solid rgba(239,68,68,.15);border-radius:50%;animation:error-ring-pulse 2.5s ease-out infinite}.error-ring:nth-child(1){width:60px;height:60px;animation-delay:0s}.error-ring:nth-child(2){width:80px;height:80px;animation-delay:.4s}@keyframes error-ring-pulse{0%{transform:scale(.8);opacity:.6}to{transform:scale(1.4);opacity:0}}.error-title{font-size:1.1rem;font-weight:600;color:#e8e8e8;margin-bottom:4px}.error-detail{font-size:.8rem;color:#666;max-width:280px;text-align:center;line-height:1.4}.error-technical{margin-top:10px;padding:8px 12px;background:#0009;border:1px solid rgba(255,80,80,.3);border-radius:6px;color:#f88;font-family:Courier New,monospace;font-size:.7rem;line-height:1.5;max-width:480px;width:90%;text-align:left;white-space:pre-wrap;word-break:break-all;overflow-y:auto;max-height:120px}.error-retry{margin-top:16px;padding:8px 20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#e8e8e8;font-size:.82rem;font-weight:500;cursor:pointer;transition:all .15s}.error-retry:hover{background:#ffffff26;border-color:#ffffff40}.cp-watermark{position:absolute;top:14px;right:16px;font-size:.8rem;font-weight:700;letter-spacing:.08em;color:#ffffff40;text-shadow:0 1px 3px rgba(0,0,0,.5);pointer-events:none;z-index:3;-webkit-user-select:none;user-select:none;transition:opacity .3s;text-align:right;animation:watermarkRainbow 120s ease-in-out infinite}@keyframes watermarkRainbow{0%,97%{color:#ffffff40;text-shadow:0 1px 3px rgba(0,0,0,.5)}97.5%{color:transparent;background:linear-gradient(90deg,#ff6b6b,#ffd93d,#6bcb77,#4d96ff,#9b59b6,#ff6b6b) 100% 0 / 200% 100%;-webkit-background-clip:text;background-clip:text;text-shadow:none}99%{color:transparent;background:linear-gradient(90deg,#ff6b6b,#ffd93d,#6bcb77,#4d96ff,#9b59b6,#ff6b6b) 0 0 / 200% 100%;-webkit-background-clip:text;background-clip:text;text-shadow:none}99.5%{color:#ffffff40;background:none;text-shadow:0 1px 3px rgba(0,0,0,.5)}to{color:#ffffff40;text-shadow:0 1px 3px rgba(0,0,0,.5)}}.cp-viewer-id{font-size:.6rem;font-weight:500;letter-spacing:.04em;color:#ffffff2e;margin-top:2px;font-family:SF Mono,Fira Code,Consolas,monospace;animation:viewerIdFade 2s ease-in-out}@keyframes viewerIdFade{0%{opacity:0}15%{opacity:1}to{opacity:1}}.cp-username-watermark{position:absolute;bottom:14px;right:16px;font-size:.7rem;font-weight:600;letter-spacing:.04em;color:#fff3;text-shadow:0 1px 3px rgba(0,0,0,.5);pointer-events:none;z-index:3;-webkit-user-select:none;user-select:none;transition:opacity .3s,bottom .3s;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.custom-player.controls-visible .cp-watermark{opacity:.4}.custom-player.controls-visible .cp-username-watermark{bottom:72px;opacity:.3}.cp-stats-overlay{position:absolute;top:12px;left:12px;z-index:20;background:#000000d1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:0;font-family:SF Mono,Fira Code,Consolas,Courier New,monospace;font-size:11px;color:#ffffffd9;min-width:300px;max-width:420px;pointer-events:auto;-webkit-user-select:text;user-select:text;line-height:1.4}.cp-stats-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08);font-weight:600;font-size:11px;letter-spacing:.03em;color:#fff9;text-transform:uppercase}.cp-stats-close{background:none;border:none;color:#fff6;cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:3px;transition:color .15s,background .15s}.cp-stats-close:hover{color:#fff;background:#ffffff1a}.cp-stats-grid{padding:6px 0}.cp-stats-row{display:flex;justify-content:space-between;gap:16px;padding:2.5px 10px}.cp-stats-row:hover{background:#ffffff0a}.cp-stats-label{color:#ffffff73;white-space:nowrap;flex-shrink:0}.cp-stats-value{color:#ffffffe6;text-align:right;word-break:break-all}.cp-center-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:#0000008c;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:8;transition:transform .15s,background .15s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cp-center-play:hover{transform:translate(-50%,-50%) scale(1.1);background:#000000b3}.next-ep-overlay{position:absolute;bottom:90px;right:20px;z-index:12;display:flex;align-items:center;gap:12px;padding:12px 20px;background:#000c;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:nextEpSlideIn .4s ease-out;transition:background .2s,transform .2s}.next-ep-overlay:hover{background:#ffffff26;transform:scale(1.03)}.next-ep-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;opacity:.7}.next-ep-title{font-size:14px;font-weight:600;max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@keyframes nextEpSlideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:640px){.next-ep-overlay{bottom:80px;right:10px;padding:10px 14px;gap:8px}.next-ep-title{font-size:12px;max-width:160px}}.cp-gradient{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(transparent,#000000d9);pointer-events:none;z-index:4;opacity:0;transition:opacity .3s}.cp-controls{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;z-index:5;opacity:0;transition:opacity .3s}.custom-player.controls-visible .cp-gradient,.custom-player.controls-visible .cp-controls{opacity:1}.cp-group{display:flex;align-items:center;gap:4px}.cp-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;color:#ffffffd9;transition:background .15s,color .15s;flex-shrink:0}.cp-btn:hover{background:#ffffff1f;color:#fff}.cp-btn.active{background:#ffffff26;color:#fff}.cp-btn.cp-btn-label{width:auto;padding:0 10px;gap:5px;font-size:.78rem}.cp-btn-text{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cp-skip-label{font-size:.6rem;font-weight:700;position:absolute;bottom:2px;pointer-events:none}.cp-btn{position:relative}.cp-chevron{transition:transform .15s}.cp-chevron.open{transform:rotate(180deg)}.cp-live-badge{display:flex;align-items:center;gap:6px;padding:3px 10px 3px 8px;border-radius:4px;background:#ef444433;color:#f87171;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-left:4px}.cp-live-dot{width:7px;height:7px;border-radius:50%;background:#ef4444;animation:live-pulse 1.5s ease-in-out infinite;flex-shrink:0}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.cp-reset-btn{display:flex;align-items:center;gap:4px;margin-left:2px;opacity:.6;transition:opacity .15s ease,color .15s ease}.cp-reset-btn:hover{opacity:1}.cp-reset-btn.catching-up{opacity:1;color:#6366f1}.cp-catchup-label{font-size:.68rem;font-weight:700;color:#6366f1;letter-spacing:.02em}.spin-reverse{animation:spin-reverse 1s linear infinite}@keyframes spin-reverse{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.cp-volume-group{display:flex;align-items:center;position:relative}.cp-volume-slider-wrap{width:0;overflow:hidden;transition:width .2s ease;display:flex;align-items:center}.cp-volume-group:hover .cp-volume-slider-wrap{width:80px}.cp-volume-slider{-webkit-appearance:none;appearance:none;width:72px;height:4px;border-radius:2px;background:#ffffff40;outline:none;cursor:pointer;margin:0 4px}.cp-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 1px 4px #0006}.cp-volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:none;cursor:pointer;box-shadow:0 1px 4px #0006}.cp-menu-wrapper{position:relative}.cp-dropdown{position:absolute;bottom:calc(100% + 8px);right:0;min-width:190px;max-height:280px;overflow-y:auto;background:#141414f2;border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 8px 24px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:30}.cp-dropdown-title{padding:8px 12px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#fff6;border-bottom:1px solid rgba(255,255,255,.08)}.cp-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 12px;font-size:.82rem;color:#ffffffb3;transition:background .1s}.cp-dropdown-item:hover{background:#ffffff14;color:#fff}.cp-dropdown-item.active{color:var(--accent);background:#6366f126}.cp-dropdown-icon{display:flex;flex-shrink:0;opacity:.6}.cp-dropdown-item.active .cp-dropdown-icon{opacity:1;color:var(--accent)}.cp-dropdown-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cp-dropdown-meta{font-size:.72rem;color:#ffffff59}.cp-check{color:var(--accent);font-weight:700;flex-shrink:0}.cp-health-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:#fff3}.cp-health-dot.ok{background:#22c55e;box-shadow:0 0 6px #22c55e66}.cp-health-dot.bad{background:#ef4444;box-shadow:0 0 6px #ef444466}.cp-health-dot.checking{background:#ffffff4d;animation:health-pulse 1s ease-in-out infinite}@keyframes health-pulse{0%,to{opacity:1}50%{opacity:.3}}@media(max-width:640px){.cp-btn-text{display:none}.cp-btn.cp-btn-label{padding:0;width:36px;justify-content:center}.cp-chevron{display:none}.cp-live-badge{padding:3px 6px;font-size:.65rem}}.pip-player{position:fixed;z-index:250;width:340px;border-radius:10px;overflow:hidden;box-shadow:0 8px 32px #0009,0 0 0 1px #ffffff14;cursor:grab;transition:box-shadow .2s;touch-action:none;-webkit-user-select:none;user-select:none}.pip-player:active{cursor:grabbing}.pip-player:hover{box-shadow:0 8px 40px #000000bf,0 0 0 1px #ffffff1f}.pip-video{position:relative;width:100%;aspect-ratio:16 / 9;background:#000;cursor:pointer}.pip-video video{width:100%;height:100%;object-fit:cover}.pip-video .player-controls,.pip-video .player-top-bar,.pip-video .viewer-id-overlay,.pip-video .player-center-play{display:none!important}.pip-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;opacity:0;transition:opacity .2s;color:#fff;pointer-events:none}.pip-video:hover .pip-overlay{opacity:1}.pip-bar{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#121212f2}.pip-live-icon{color:#e74c3c;flex-shrink:0}.pip-name{flex:1;font-size:.78rem;font-weight:500;color:#e8e8e8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pip-actions{display:flex;gap:2px}.pip-btn{background:none;border:none;color:#999;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.pip-btn:hover{color:#fff;background:#ffffff1a}@media(max-width:768px){.pip-player{width:200px}}.page-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;color:var(--text-primary)}.page-header h1{font-size:1.4rem;font-weight:700}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--text-muted);text-align:center}.empty-state h2{font-size:1.2rem;color:var(--text-secondary)}.empty-state p{font-size:.9rem;max-width:400px}.center-content{display:flex;align-items:center;justify-content:center;min-height:300px}.load-more{display:flex;justify-content:center;padding:20px}.spinner{display:flex;align-items:center;justify-content:center}.spinner-ring{width:100%;height:100%;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tv-guide{display:flex;flex-direction:column;gap:12px}.tv-guide-controls{display:flex;align-items:center;gap:8px}.btn-guide-nav{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);transition:all var(--transition)}.btn-guide-nav:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-guide-now{padding:6px 14px;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:.8rem;font-weight:600;transition:all var(--transition)}.btn-guide-now:hover{background:var(--accent-hover)}.tv-guide-date{font-size:.85rem;color:var(--text-secondary);margin-left:8px}.tv-guide-grid{position:relative;overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary)}.tv-guide-header{display:flex;position:sticky;top:0;z-index:10;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.tv-guide-channel-col{flex-shrink:0;border-right:1px solid var(--border)}.tv-guide-timeline-header{display:flex;position:relative}.tv-guide-time-marker{position:absolute;top:0;padding:8px 12px;font-size:.75rem;font-weight:600;color:var(--text-secondary);border-left:1px solid var(--border)}.tv-guide-body{max-height:calc(100vh - 220px);overflow-y:auto}.tv-guide-row{display:flex;border-bottom:1px solid var(--border)}.tv-guide-row:last-child{border-bottom:none}.tv-guide-channel-cell{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:0 10px;border-right:1px solid var(--border);background:var(--bg-secondary);cursor:pointer;transition:background var(--transition);position:sticky;left:0;z-index:5;overflow:hidden}.tv-guide-channel-cell:hover{background:var(--bg-hover)}.tv-guide-channel-logo{width:28px;height:28px;border-radius:4px;object-fit:contain;flex-shrink:0}.tv-guide-logo-fallback{color:var(--text-muted);flex-shrink:0}.tv-guide-channel-name{font-size:.78rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.tv-guide-programs{position:relative;flex-shrink:0;overflow:hidden}.tv-guide-now-line{position:absolute;top:0;bottom:0;width:2px;background:var(--danger);z-index:15;pointer-events:none}.program-slot{position:absolute;top:3px;bottom:3px;border-radius:4px;background:var(--bg-tertiary);border:1px solid var(--border);padding:0 8px;overflow:hidden;cursor:pointer;display:flex;align-items:center;gap:6px;box-sizing:border-box}.program-slot:hover{background:var(--bg-hover);z-index:4}.program-slot.live{background:var(--accent-dim);border-color:var(--accent)}.program-slot.past{opacity:.5}.program-title{font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}.program-live-badge{font-size:.55rem;font-weight:700;padding:1px 4px;border-radius:3px;background:var(--danger);color:#fff;flex-shrink:0;line-height:1}.program-tooltip{position:absolute;top:calc(100% + 4px);left:0;z-index:50;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius);padding:10px;min-width:200px;max-width:300px;box-shadow:var(--shadow);pointer-events:none}.program-tooltip strong{display:block;font-size:.85rem;margin-bottom:4px}.program-tooltip-time{font-size:.75rem;color:var(--text-secondary);margin-bottom:6px}.program-tooltip-desc{font-size:.75rem;color:var(--text-secondary);line-height:1.4;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.program-tooltip-cat{font-size:.7rem;padding:2px 6px;background:var(--accent-dim);color:var(--accent);border-radius:4px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}@media(max-width:768px){.main-content{padding:0}.player-body{flex-direction:column}.player-epg{width:100%;max-height:none}.channel-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:4px}.browse-toolbar-row{flex-direction:column;align-items:stretch}.browse-toolbar-right{margin-left:0}.networks-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.networks-header{flex-direction:column;align-items:stretch}.vod-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.vod-header{gap:10px}.vod-filters{flex-wrap:wrap}.fav-tabs{overflow-x:auto;flex-wrap:nowrap}.content-row{padding:0 20px;margin-bottom:28px}.hero-billboard-content{padding:0 28px 40px}.hero-billboard-title{font-size:2.2rem}.hero-billboard{min-height:70vh}.poster-card{flex:0 0 140px}}@media(max-width:640px){.channel-grid{grid-template-columns:1fr}.browse-filters{flex-direction:column}.networks-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}.vod-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px}.channels-network-bar{flex-wrap:wrap;gap:8px}.vod-header{gap:8px}.vod-title-row h1{font-size:1.1rem}.vod-filters{flex-direction:column;gap:8px}.vod-search,.vod-select-wrap,.vod-select-wrap select{width:100%}.page-header h1{font-size:1.1rem}.fav-tabs{overflow-x:auto;flex-wrap:nowrap;gap:4px}.fav-tab{white-space:nowrap;font-size:.75rem;padding:5px 10px}.chat-panel{width:calc(100vw - 16px);right:8px;bottom:8px;max-height:60vh}.browse-page .networks-header{gap:8px}.networks-search-input{font-size:14px}.subscription-banner{font-size:.75rem;padding:8px 12px}.content-row{padding:0 16px}.hero-billboard-content{padding:0 16px 28px}.hero-billboard-title{font-size:1.5rem}.poster-card{flex:0 0 120px}.hero-btn-primary,.hero-btn-secondary{padding:8px 20px;font-size:.85rem}}.sidebar-user{margin-top:auto;padding:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.sidebar-user-info{display:flex;align-items:center;gap:8px;padding:8px 10px;font-size:.82rem;font-weight:500;color:var(--text-secondary);overflow:hidden}.sidebar-username{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius);font-size:.82rem;color:var(--text-muted);transition:all var(--transition)}.sidebar-logout:hover{background:#ef44441a;color:var(--danger)}.sidebar-version{display:block;width:100%;text-align:center;padding:4px 0 2px;font-size:.65rem;color:#fff3;background:none;border:none;cursor:pointer;transition:color .2s}.sidebar-version:hover{color:#ffffff80}.sidebar-status-btn{display:flex;width:100%;align-items:center;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;font-size:.6rem;color:#fff3;padding:2px 0;transition:color .2s}.sidebar-status-btn:hover{color:#ffffff80}.status-dot-sm{display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-dot-sm-operational{background:#22c55e;box-shadow:0 0 4px #22c55e80}.status-dot-sm-degraded{background:#f59e0b;box-shadow:0 0 4px #f59e0b80}.status-dot-sm-outage{background:#ef4444;box-shadow:0 0 4px #ef444480}.sidebar-user-clickable{cursor:pointer;border-radius:var(--radius);transition:background .15s}.sidebar-user-clickable:hover{background:#ffffff0f}.sidebar-avatar-sm{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.sidebar-avatar-img{width:100%;height:100%;object-fit:cover}.sidebar-profile-popup{position:absolute;bottom:80px;left:12px;right:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:14px;z-index:100;box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;gap:10px}.sidebar-profile-header{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;font-weight:600;color:var(--text-primary)}.sidebar-profile-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:4px}.sidebar-profile-close:hover{color:var(--text-primary)}.sidebar-profile-preview{display:flex;align-items:center;gap:10px}.sidebar-profile-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff}.sidebar-profile-name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.sidebar-profile-form{display:flex;flex-direction:column;gap:8px}.sidebar-profile-input{background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:.82rem;color:var(--text-primary);outline:none}.sidebar-profile-input:focus{border-color:var(--accent)}.sidebar-profile-colors{display:flex;flex-wrap:wrap;gap:4px}.sidebar-profile-swatch{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .1s}.sidebar-profile-swatch:hover{transform:scale(1.15)}.sidebar-profile-swatch.active{border-color:#fff}.sidebar-profile-save{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:6px 0;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}.sidebar-profile-save:hover{background:var(--accent-hover)}.sidebar-profile-save:disabled{opacity:.6;cursor:default}.sidebar-profile-msg{font-size:.78rem;text-align:center;color:var(--accent)}.sidebar-profile-lang{display:flex;flex-direction:column;gap:4px;padding-top:8px;margin-top:4px;border-top:1px solid var(--border)}.sidebar-profile-lang-label{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-secondary);font-weight:500}.sidebar-profile-lang-select{background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:.82rem;color:var(--text-primary);cursor:pointer}.sidebar-profile-lang-select:focus{border-color:var(--accent);outline:none}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:24px}.login-card{width:100%;max-width:400px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:40px 32px;animation:fadeSlideUp .4s ease}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--accent);font-size:1.4rem;font-weight:800;margin-bottom:28px}.login-card h1{font-size:1.3rem;font-weight:700;text-align:center;margin-bottom:6px}.login-subtitle{text-align:center;font-size:.85rem;color:var(--text-secondary);margin-bottom:28px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.login-field input{width:100%;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color var(--transition)}.login-field input:focus{border-color:var(--accent)}.login-field input::placeholder{color:var(--text-muted)}.login-password-wrap{position:relative}.login-password-wrap input{padding-right:40px}.login-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);padding:4px;display:flex;transition:color var(--transition)}.login-eye:hover{color:var(--text-primary)}.login-error{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius);color:#f87171;font-size:.82rem}.login-submit{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px;background:var(--accent);color:#fff;border-radius:var(--radius);font-size:.9rem;font-weight:600;transition:background var(--transition);margin-top:4px}.login-submit:hover:not(:disabled){background:var(--accent-hover)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.login-switch{text-align:center;margin-top:20px;font-size:.82rem;color:var(--text-secondary)}.login-switch button{color:var(--accent);font-weight:600;margin-left:4px;transition:color var(--transition)}.login-switch button:hover{color:var(--accent-hover)}@keyframes blob1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(40px,-30px) scale(1.06)}66%{transform:translate(-30px,20px) scale(.94)}}@keyframes blob2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-35px,25px) scale(.97)}66%{transform:translate(25px,-20px) scale(1.04)}}@keyframes blob3{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,35px) scale(1.05)}}.home-page{min-height:100vh;background:var(--bg-primary);display:flex;flex-direction:column}.home-hero{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.home-hero:after{content:"";position:absolute;bottom:0;left:0;right:0;height:160px;background:linear-gradient(to bottom,transparent,var(--bg-primary));pointer-events:none;z-index:1}.home-hero-bg{position:absolute;inset:0;background:var(--bg-primary)}.home-hero-blob{position:absolute;border-radius:50%;filter:blur(70px);animation-iteration-count:infinite;animation-timing-function:ease-in-out;will-change:transform}.home-hero-blob.blob-1{width:560px;height:560px;top:-120px;left:-80px;background:radial-gradient(ellipse,rgba(99,102,241,.35) 0%,transparent 70%);animation-name:blob1;animation-duration:9s}.home-hero-blob.blob-2{width:420px;height:420px;bottom:-100px;right:-60px;background:radial-gradient(ellipse,rgba(139,92,246,.28) 0%,transparent 70%);animation-name:blob2;animation-duration:12s}.home-hero-blob.blob-3{width:280px;height:280px;top:35%;left:45%;background:radial-gradient(ellipse,rgba(59,130,246,.22) 0%,transparent 70%);animation-name:blob3;animation-duration:15s}.home-hero-content{position:relative;text-align:center;max-width:600px;padding:40px 24px;animation:fadeSlideUp .6s ease;z-index:2}.home-logo{display:flex;align-items:center;justify-content:center;gap:12px;color:var(--accent);font-size:1.6rem;font-weight:800;margin-bottom:24px}.home-hero-content h1{font-size:2.4rem;font-weight:800;line-height:1.15;margin-bottom:16px;background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-tagline{font-size:1.05rem;color:var(--text-secondary);line-height:1.6;margin-bottom:36px}.home-cta{display:flex;justify-content:center;gap:12px}.home-btn-primary{display:flex;align-items:center;gap:8px;padding:13px 28px;background:var(--accent);color:#fff;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 16px #6366f14d}.home-btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #6366f166}.home-features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:900px;margin:0 auto;padding:48px 24px 72px}.home-feature{text-align:center;padding:28px 20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .2s}.home-feature:hover{border-color:var(--border-light);transform:translateY(-2px)}.home-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:var(--accent-dim);color:var(--accent);margin-bottom:16px}.home-feature h3{font-size:1rem;font-weight:600;margin-bottom:8px}.home-feature p{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.home-footer{text-align:center;padding:24px;font-size:.78rem;color:var(--text-muted);border-top:1px solid var(--border)}.home-footer span{color:var(--accent);font-weight:600}@media(max-width:768px){.home-hero-content h1{font-size:1.8rem}.home-features{grid-template-columns:1fr;max-width:400px}}.admin-page{display:flex;flex-direction:column;gap:20px;padding:24px}.admin-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-color);margin-bottom:-8px}.admin-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.admin-tab:hover{color:var(--text-primary)}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-refresh{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius);color:var(--text-secondary);margin-left:auto;transition:all var(--transition)}.admin-refresh:hover{background:var(--bg-tertiary);color:var(--text-primary)}.admin-stats{display:flex;gap:16px}.admin-stat{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--accent);min-width:140px}.admin-stat div{display:flex;flex-direction:column}.admin-stat-value{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.admin-stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.admin-error{padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius);color:#f87171;font-size:.82rem}.admin-table-wrap{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;padding:10px 14px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-hover)}.admin-row-self td{background:var(--accent-dim)}.admin-cell-id{color:var(--text-muted);font-variant-numeric:tabular-nums}.admin-cell-username{font-weight:500}.admin-you-badge{display:inline-block;margin-left:6px;padding:1px 6px;font-size:.65rem;font-weight:600;background:var(--accent-dim);color:var(--accent);border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.admin-cell-viewer-id{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem;color:var(--text-secondary);letter-spacing:.06em}.admin-role-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:.72rem;font-weight:600;text-transform:capitalize}.admin-role-badge.admin{background:#eab3081f;color:#eab308}.admin-role-badge.user{background:var(--bg-tertiary);color:var(--text-secondary)}.admin-cell-date{font-size:.78rem;color:var(--text-muted)}.admin-cell-actions{display:flex;gap:4px}.admin-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;color:var(--text-muted);transition:all var(--transition)}.admin-action-btn:hover{background:var(--accent-dim);color:var(--accent)}.admin-action-btn.danger:hover{background:#ef44441f;color:var(--danger)}.playlist-page{padding:24px 32px;max-width:900px}.playlist-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem}.playlist-count{color:var(--accent);font-weight:500}.playlist-url-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:32px}.playlist-url-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.playlist-url-header h2{font-size:1.1rem;font-weight:600}.playlist-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:4px;background:#22c55e1f;color:var(--success)}.playlist-url-desc{color:var(--text-secondary);font-size:.85rem;margin-bottom:16px}.playlist-url-box{display:flex;gap:8px;margin-bottom:12px}.playlist-url-input{flex:1;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius);padding:10px 14px;color:var(--text-primary);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem;outline:none;cursor:text;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-url-input:focus{border-color:var(--accent)}.playlist-copy-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--accent);color:#fff;border-radius:var(--radius);font-weight:500;font-size:.85rem;transition:all var(--transition);white-space:nowrap}.playlist-copy-btn:hover{background:var(--accent-hover)}.playlist-url-actions{display:flex;gap:16px}.playlist-action-link{display:inline-flex;align-items:center;gap:5px;color:var(--text-secondary);font-size:.8rem;text-decoration:none;transition:color var(--transition)}.playlist-action-link:hover{color:var(--accent)}.xtream-credentials{display:flex;flex-direction:column;gap:12px}.xtream-field{display:flex;flex-direction:column;gap:4px}.xtream-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.xtream-value-row{display:flex;gap:8px;align-items:center}.xtream-value-row .playlist-url-input{flex:1;font-size:.9rem}.xtream-value-row .playlist-copy-btn{padding:10px 14px}.xtream-password-note{color:var(--text-secondary);font-size:.85rem;font-style:italic;padding:10px 0}.playlist-guides-title{font-size:1.1rem;font-weight:600;margin-bottom:16px}.playlist-guides{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}.playlist-guide-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:border-color var(--transition)}.playlist-guide-card:hover{border-color:var(--border-light)}.playlist-guide-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;color:var(--text-primary)}.playlist-guide-header h3{font-size:.95rem;font-weight:600}.playlist-guide-steps{list-style:none;counter-reset:step;padding:0}.playlist-guide-steps li{counter-increment:step;position:relative;padding-left:28px;margin-bottom:8px;color:var(--text-secondary);font-size:.82rem;line-height:1.5}.playlist-guide-steps li:before{content:counter(step);position:absolute;left:0;top:1px;width:20px;height:20px;background:var(--accent-dim);color:var(--accent);font-size:.7rem;font-weight:600;border-radius:50%;display:flex;align-items:center;justify-content:center}.playlist-notice{display:flex;gap:12px;padding:16px;background:#6366f10f;border:1px solid rgba(99,102,241,.15);border-radius:var(--radius);color:var(--text-secondary);font-size:.82rem;line-height:1.5}.playlist-notice svg{flex-shrink:0;color:var(--accent);margin-top:2px}.admin-sub-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:.72rem;font-weight:600;white-space:nowrap}.admin-sub-badge.active{background:#22c55e1f;color:var(--success)}.admin-sub-badge.unlimited{background:#6366f11f;color:var(--accent)}.admin-sub-badge.expired,.admin-sub-badge.revoked{background:#ef44441a;color:var(--danger)}.admin-sub-badge.none{background:var(--bg-tertiary);color:var(--text-muted)}.admin-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;min-width:360px;max-width:480px;display:flex;flex-direction:column;gap:16px}.admin-modal h2{font-size:1.1rem;font-weight:600}.admin-sub-current{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.admin-sub-section-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:-8px}.admin-sub-actions{display:flex;flex-wrap:wrap;gap:8px}.admin-sub-actions button{padding:8px 16px;background:var(--accent-dim);color:var(--accent);border-radius:var(--radius);font-size:.85rem;font-weight:500;transition:all var(--transition)}.admin-sub-actions button:hover{background:var(--accent);color:#fff}.admin-sub-custom{display:flex;align-items:center;gap:8px}.admin-sub-custom input[type=date]{flex:1;padding:8px 10px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.85rem}.admin-sub-custom button{padding:8px 14px;background:var(--accent);color:#fff;border-radius:var(--radius);font-size:.82rem;font-weight:500}.admin-sub-custom button:disabled{opacity:.4;cursor:not-allowed}.admin-sub-revoke{padding-top:4px;border-top:1px solid var(--border)}.admin-sub-revoke button.danger{padding:8px 16px;background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);font-size:.85rem;font-weight:500;transition:all var(--transition)}.admin-sub-revoke button.danger:hover{background:var(--danger);color:#fff}.admin-modal-close{padding:8px;color:var(--text-muted);font-size:.82rem;align-self:center;transition:color var(--transition)}.admin-modal-close:hover{color:var(--text-primary)}.admin-pw-form{display:flex;gap:8px;margin:16px 0}.admin-pw-form input{flex:1;padding:8px 12px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem}.subscription-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;margin:16px 24px 0;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);color:#f87171;font-size:.85rem}.sidebar-sub-info{font-size:.7rem;color:var(--text-muted);padding:0 10px 2px}.account-page{max-width:720px;margin:0 auto;padding:32px 24px}.account-title{font-size:1.5rem;font-weight:700;margin-bottom:20px}.account-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0;overflow-x:auto}.account-tab{display:flex;align-items:center;gap:6px;padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:.88rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s}.account-tab:hover{color:var(--text)}.account-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.account-content{min-height:300px}.account-section{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.account-section-title{font-size:1.1rem;font-weight:600;margin:24px 0 12px}.account-desc{color:var(--text-muted);font-size:.88rem;margin-bottom:12px}.account-profile-top{display:flex;align-items:center;gap:24px;margin-bottom:24px;padding:20px;background:var(--surface-2);border-radius:12px;border:1px solid var(--border)}.account-avatar-wrap{position:relative;flex-shrink:0}.account-avatar-lg{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.account-avatar-img{width:100%;height:100%;object-fit:cover}.account-avatar-overlay{position:absolute;inset:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#00000080;color:#fff;cursor:pointer;opacity:0;transition:opacity .2s}.account-avatar-wrap:hover .account-avatar-overlay{opacity:1}.account-avatar-remove{position:absolute;top:-4px;right:-4px;width:20px;height:20px;border-radius:50%;background:var(--danger, #e74c3c);color:#fff;border:2px solid var(--bg-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;opacity:0;transition:opacity .2s}.account-avatar-wrap:hover .account-avatar-remove{opacity:1}.account-user-info{display:flex;flex-direction:column;gap:6px}.account-info-row{display:flex;gap:8px;align-items:center;font-size:.88rem}.account-info-label{color:var(--text-muted);min-width:80px}.account-info-value{color:var(--text);font-weight:500}.account-form{display:flex;flex-direction:column;gap:8px;max-width:400px}.account-form-inline{flex-direction:row;max-width:100%}.account-form-inline .account-input{flex:1}.account-form-inline .account-save-btn{width:auto;margin-top:0}.account-label{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:500;color:var(--text-muted);margin-top:8px}.account-input{padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;outline:none;transition:border-color .15s}.account-input:focus{border-color:var(--accent)}.account-select{padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;outline:none;cursor:pointer}.account-colors{display:flex;flex-wrap:wrap;gap:6px}.account-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .1s,border-color .15s}.account-swatch:hover{transform:scale(1.15)}.account-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--accent)}.account-save-btn{margin-top:12px;padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:filter .15s;width:fit-content}.account-save-btn:hover:not(:disabled){filter:brightness(1.1)}.account-save-btn:disabled{opacity:.5;cursor:not-allowed}.account-msg{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:.85rem;margin-top:8px}.account-msg.success{background:#2ecc711a;color:#2ecc71;border:1px solid rgba(46,204,113,.2)}.account-msg.error{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.account-pw-wrap{position:relative}.account-pw-wrap .account-input{width:100%;padding-right:40px;box-sizing:border-box}.account-pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.account-sub-card{padding:20px;border-radius:12px;border:1px solid var(--border);background:var(--surface-2)}.account-sub-card.active{border-color:#2ecc714d}.account-sub-card.inactive{border-color:#ef44444d}.account-sub-status{display:flex;align-items:center;gap:12px;margin-bottom:8px}.account-sub-label{font-weight:600;font-size:.95rem}.account-sub-badge{padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.account-sub-badge.active{background:#2ecc7126;color:#2ecc71}.account-sub-badge.inactive{background:#ef444426;color:#ef4444}.account-sub-detail{font-size:.88rem;color:var(--text-muted)}.account-notice{display:flex;gap:12px;padding:14px 16px;border-radius:10px;font-size:.85rem;margin-bottom:16px;border:1px solid var(--border)}.account-notice.warning{border-color:#ef444440;background:#ef44440f;color:var(--danger)}.account-notice.info{border-color:#6366f140;background:#6366f10f}@media(max-width:600px){.account-page{padding:16px}.account-profile-top{flex-direction:column;text-align:center}.account-tabs{gap:0}.account-tab{padding:10px 12px;font-size:.82rem}.account-form-inline{flex-direction:column}}.redeem-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--mini-player-height) - 40px);padding:24px}.redeem-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;max-width:480px;width:100%;text-align:center}.redeem-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:var(--accent-dim);color:var(--accent);margin-bottom:20px}.redeem-card h1{font-size:1.4rem;font-weight:600;margin-bottom:8px}.redeem-desc{color:var(--text-secondary);font-size:.9rem;margin-bottom:24px}.redeem-form{display:flex;gap:8px;margin-bottom:16px}.redeem-input{flex:1;padding:12px 16px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-primary);font-family:SF Mono,Fira Code,Consolas,monospace;font-size:1rem;text-align:center;letter-spacing:.05em;outline:none}.redeem-input:focus{border-color:var(--accent)}.redeem-input::placeholder{color:var(--text-muted);letter-spacing:.02em}.redeem-btn{padding:12px 24px;background:var(--accent);color:#fff;border-radius:var(--radius);font-weight:600;font-size:.9rem;transition:all var(--transition);white-space:nowrap}.redeem-btn:hover:not(:disabled){background:var(--accent-hover)}.redeem-btn:disabled{opacity:.5;cursor:not-allowed}.redeem-success{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius);color:var(--success);font-size:.85rem;text-align:left;margin-bottom:16px}.redeem-success p{margin-top:4px;opacity:.85}.redeem-error{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);color:#f87171;font-size:.85rem;margin-bottom:16px}.redeem-info{color:var(--text-muted);font-size:.78rem;margin-top:8px}.admin-section-divider{height:1px;background:var(--border);margin:32px 0 24px}.gc-generate-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}.gc-generate-card h3{font-size:.95rem;font-weight:600;margin-bottom:14px}.gc-generate-form{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.gc-field{display:flex;flex-direction:column;gap:4px}.gc-field label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.gc-field select,.gc-field input{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:.85rem;min-width:120px}.gc-field input[type=number]{width:80px;min-width:unset}.gc-generate-btn{padding:8px 20px;background:var(--accent);color:#fff;border-radius:var(--radius);font-weight:500;font-size:.85rem;transition:all var(--transition);display:flex;align-items:center;gap:6px}.gc-generate-btn:hover:not(:disabled){background:var(--accent-hover)}.gc-generate-btn:disabled{opacity:.5}.gc-new-codes{background:#22c55e0f;border:1px solid rgba(34,197,94,.15);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:16px}.gc-new-codes-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.gc-new-codes-header h3{font-size:.9rem;font-weight:600;color:var(--success)}.gc-copy-all-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;background:#22c55e26;color:var(--success);border-radius:var(--radius);font-size:.78rem;font-weight:500;transition:all var(--transition)}.gc-copy-all-btn:hover{background:var(--success);color:#fff}.gc-code-list{display:flex;flex-direction:column;gap:6px}.gc-code-item{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:var(--bg-secondary);border-radius:var(--radius)}.gc-code-item code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.85rem;color:var(--text-primary);letter-spacing:.03em}.gc-code-copy{padding:4px 8px;color:var(--text-muted);border-radius:4px;transition:all var(--transition)}.gc-code-copy:hover{color:var(--accent);background:var(--accent-dim)}.gc-code-cell{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem;letter-spacing:.02em}.admin-activity-sync{font-size:.75rem;color:var(--text-muted);margin-bottom:12px}.admin-activity-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.admin-activity-card h3{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;margin-bottom:14px}.admin-activity-empty{color:var(--text-muted);font-size:.85rem;text-align:center;padding:24px 0}.admin-live-dot{width:8px;height:8px;border-radius:50%;background:#ef4444;display:inline-block;animation:live-pulse 1.5s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.4}}.admin-type-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.admin-type-badge.live{background:#ef444426;color:#f87171}.admin-type-badge.vod{background:#6366f126;color:#a5b4fc}.admin-type-badge.series{background:#22c55e26;color:#86efac}.admin-cell-ip{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem;color:var(--text-secondary)}.admin-suspicious-badge{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:2px 10px;border-radius:12px;font-size:.75rem;font-weight:600;background:#f59e0b26;color:#fbbf24}.admin-ip-list{display:flex;flex-direction:column;gap:6px}.admin-ip-user{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.admin-ip-user.suspicious{border-color:#f59e0b66}.admin-ip-user-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;transition:background var(--transition)}.admin-ip-user-header:hover{background:var(--bg-hover)}.admin-ip-user-info{display:flex;align-items:center;gap:8px}.admin-ip-warn{color:#fbbf24}.admin-ip-username{font-weight:600;font-size:.9rem}.admin-ip-count{font-size:.75rem;color:var(--text-muted)}.admin-ip-details{padding:0 14px 14px}.admin-table-compact{font-size:.8rem}.admin-table-compact th,.admin-table-compact td{padding:6px 10px}.admin-ip-link{color:var(--accent);text-decoration:none;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem}.admin-ip-link:hover{text-decoration:underline;color:var(--accent-hover)}.admin-ip-cell{display:flex;flex-direction:column;gap:2px}.admin-ip-geo{font-size:.75rem;color:var(--text-secondary)}.admin-ip-isp{color:var(--text-muted)}.admin-cell-geo{font-size:.8rem;color:var(--text-secondary)}.admin-text-muted{color:var(--text-muted)}.movies-page{padding:0}.vod-header{margin-bottom:24px}.vod-title-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.vod-title-row h1{font-size:1.5rem;font-weight:700}.vod-count{font-size:.85rem;color:var(--text-muted);background:var(--surface-2);padding:3px 10px;border-radius:12px}.vod-filters{display:flex;gap:10px;flex-wrap:wrap}.vod-search{display:flex;align-items:center;gap:8px;flex:1;min-width:200px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:0 12px;transition:border-color var(--transition)}.vod-search:focus-within{border-color:var(--accent)}.vod-search input{flex:1;background:none;border:none;color:var(--text);font-size:.9rem;padding:10px 0;outline:none}.vod-search svg{color:var(--text-muted);flex-shrink:0}.vod-select-wrap{position:relative}.vod-select-wrap select{appearance:none;background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-size:.85rem;padding:10px 32px 10px 12px;border-radius:8px;cursor:pointer;outline:none;transition:border-color var(--transition)}.vod-select-wrap select:focus{border-color:var(--accent)}.vod-select-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.vod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}@media(min-width:768px){.vod-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}}.vod-card{cursor:pointer;border-radius:10px;overflow:hidden;background:var(--surface-2);border:1px solid var(--border);transition:all .2s ease}.vod-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.vod-poster{position:relative;aspect-ratio:2/3;overflow:hidden;background:var(--surface)}.vod-poster img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.vod-card:hover .vod-poster img{transform:scale(1.05)}.vod-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:var(--surface)}.vod-rating{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:3px;background:#000000bf;color:#fbbf24;font-size:.72rem;font-weight:600;padding:3px 7px;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.vod-fav-btn{position:absolute;top:8px;left:8px;background:#0009;color:#fff9;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s,color .2s,background .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.vod-card:hover .vod-fav-btn{opacity:1}.vod-fav-btn.active{opacity:1;color:#ef4444;background:#000000b3}.vod-fav-btn:hover{color:#ef4444}.fav-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.fav-tab{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:20px;font-size:.82rem;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;transition:all .15s}.fav-tab:hover{border-color:var(--accent);color:var(--text-primary)}.fav-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.fav-section{margin-bottom:24px}.fav-section-title{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.vod-info{padding:10px;display:flex;flex-direction:column;gap:2px}.vod-name{font-size:.82rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.3}.vod-genre{font-size:.72rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.series-detail-page{padding:0}.series-detail-page>.btn-back{margin-bottom:16px}.series-hero{position:relative;border-radius:12px;overflow:hidden;min-height:320px;background-size:cover;background-position:center top;background-color:var(--surface-2);margin-bottom:24px}.series-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,#0a0a0af2,#0a0a0acc 40%,#0a0a0a66)}.series-hero-content{position:relative;display:flex;gap:24px;padding:28px;align-items:flex-start}.series-poster{width:180px;border-radius:8px;box-shadow:0 8px 24px #00000080;flex-shrink:0}.series-meta{flex:1;min-width:0}.series-meta h1{font-size:1.6rem;font-weight:700;margin-bottom:10px;line-height:1.2}.series-meta-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.series-badge{display:inline-flex;align-items:center;gap:4px;font-size:.78rem;padding:3px 10px;background:#ffffff1a;border-radius:4px;color:var(--text-muted)}.series-badge svg{color:#fbbf24}.series-plot{font-size:.88rem;color:var(--text-muted);line-height:1.6;margin-bottom:14px;max-width:600px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.series-credits{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.series-credit{display:flex;align-items:flex-start;gap:6px;font-size:.8rem;color:var(--text-muted);line-height:1.4}.series-credit svg{flex-shrink:0;margin-top:2px}.vod-play-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.vod-play-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.vod-play-secondary{background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.vod-play-secondary:hover{background:#ffffff2e}.episode-progress-bar{height:3px;background:#ffffff1a;border-radius:2px;margin-top:6px;overflow:hidden}.episode-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.episode-progress-label{color:var(--accent)!important;font-weight:500}.series-seasons{margin-top:0}.series-season-tabs{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px}.season-tab{padding:8px 18px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);font-size:.85rem;font-weight:500;border-radius:8px;cursor:pointer;white-space:nowrap;transition:all .15s}.season-tab:hover{border-color:var(--accent);color:var(--text)}.season-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.series-episodes{display:flex;flex-direction:column;gap:6px}.episode-card{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.episode-card:hover{border-color:var(--accent);background:#6366f10f}.episode-num{font-size:.85rem;font-weight:700;color:var(--accent);min-width:32px;text-align:center}.episode-info{flex:1;min-width:0}.episode-title{font-size:.88rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.episode-meta{display:flex;gap:12px;margin-top:3px}.episode-meta span{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.episode-play{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border:none;border-radius:50%;cursor:pointer;flex-shrink:0;transition:all .15s}.episode-play:hover{filter:brightness(1.15);transform:scale(1.05)}.watch-page{display:flex;flex-direction:column;height:calc(100vh - 48px)}.watch-top-bar{display:flex;align-items:center;gap:12px;padding:8px 0 12px}.watch-title{font-size:1rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vod-player{flex:1}.ios-fake-fullscreen{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;z-index:999999!important;background:#000!important;margin:0!important;padding:0!important;border-radius:0!important}.ios-fake-fullscreen video{width:100%!important;height:100%!important;object-fit:contain!important}.vod-controls{flex-direction:column!important;gap:4px!important}.vod-progress-wrap{display:flex;align-items:center;gap:8px;width:100%;padding:0 4px}.vod-progress-bar{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:#fff3;border-radius:2px;outline:none;cursor:pointer;transition:height .15s}.vod-progress-bar:hover{height:6px}.vod-progress-bar::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer;transition:transform .15s}.vod-progress-bar:hover::-webkit-slider-thumb{transform:scale(1.2)}.vod-progress-bar::-moz-range-thumb{width:14px;height:14px;background:var(--accent);border:none;border-radius:50%;cursor:pointer}.vod-time{font-size:.75rem;color:#ffffffb3;font-variant-numeric:tabular-nums;min-width:44px;text-align:center}.cp-controls-row{display:flex;justify-content:space-between;align-items:center;width:100%}@media(max-width:640px){.series-hero-content{flex-direction:column;align-items:center;text-align:center}.series-poster{width:140px}.series-meta-row{justify-content:center}.series-plot{text-align:left}.vod-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.vod-filters{flex-direction:column}}.detail-tagline{font-size:.9rem;color:#ffffff8c;font-style:italic;margin:0 0 10px}.detail-ext-badges{display:flex;gap:8px;margin:8px 0;flex-wrap:wrap}.ext-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:4px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-decoration:none;transition:opacity .15s}.ext-badge:hover{opacity:.8}.imdb-badge{background:#f5c518;color:#000}.tmdb-badge{background:#01b4e4;color:#000}.detail-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.trailer-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;text-decoration:none}.trailer-btn:hover{background:#ffffff38}.detail-cast-section{padding:24px 24px 8px}.detail-section-title{font-size:1rem;font-weight:600;color:#ffffffbf;margin:0 0 14px;letter-spacing:.05em;text-transform:uppercase}.cast-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:10px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.cast-scroll::-webkit-scrollbar{height:4px}.cast-scroll::-webkit-scrollbar-track{background:transparent}.cast-scroll::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.cast-card{flex:0 0 90px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.cast-photo{width:72px;height:72px;border-radius:50%;object-fit:cover;background:#ffffff14}.cast-photo-placeholder{display:flex;align-items:center;justify-content:center;color:#ffffff4d}.cast-name{font-size:.72rem;font-weight:600;color:#ffffffd9;line-height:1.2}.cast-char{font-size:.65rem;color:#ffffff73;line-height:1.2}.chat-fab{position:fixed;bottom:24px;right:24px;width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0006;z-index:1000;opacity:.35;transition:transform .15s,background .15s,opacity .25s}.chat-fab:hover,.chat-fab:has(.chat-fab-badge){opacity:1}.chat-fab:hover{transform:scale(1.08);background:var(--accent-hover, #5a5fe0)}.chat-fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;border-radius:10px;background:#e74c3c;color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px}.chat-panel{position:fixed;bottom:24px;right:24px;width:340px;height:480px;background:var(--bg-secondary, #1a1a2e);border:1px solid rgba(255,255,255,.1);border-radius:12px;display:flex;flex-direction:column;z-index:1000;box-shadow:0 8px 32px #00000080;overflow:hidden}.chat-minimized{height:auto;width:auto;min-width:140px;padding:8px 14px;flex-direction:row;align-items:center;gap:8px;cursor:pointer;font-size:.8rem;color:#fffc}.chat-minimized:hover{background:var(--bg-hover, #222244)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.chat-header-title{font-size:.82rem;font-weight:600;display:flex;align-items:center;gap:6px;color:#ffffffe6}.chat-header-actions{display:flex;gap:4px}.chat-header-actions button,.chat-close-btn{background:none;border:none;color:#ffffff80;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.chat-header-actions button:hover,.chat-close-btn:hover{color:#fff;background:#ffffff1a}.chat-messages{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:6px}.chat-empty{color:#ffffff59;font-size:.8rem;text-align:center;padding:40px 10px}.chat-msg{display:flex;gap:8px;align-items:flex-start}.chat-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.chat-avatar-img{width:100%;height:100%;object-fit:cover}.chat-msg-body{flex:1;min-width:0}.chat-msg-meta{display:flex;align-items:baseline;gap:6px;margin-bottom:1px}.chat-msg-name{font-size:.72rem;font-weight:600;display:flex;align-items:center;gap:3px}.chat-admin-crown{color:#f1c40f;flex-shrink:0}.chat-msg-time{font-size:.6rem;color:#ffffff4d}.chat-msg-text{font-size:.8rem;color:#ffffffd9;word-break:break-word;line-height:1.35}.chat-input-bar{display:flex;gap:6px;padding:10px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.chat-input{flex:1;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:8px 12px;color:#fff;font-size:.8rem;outline:none}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:#ffffff4d}.chat-send-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;padding:8px 12px;cursor:pointer;display:flex;align-items:center;transition:background .15s}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover, #5a5fe0)}.chat-send-btn:disabled{opacity:.4;cursor:default}.chat-mod-shield{color:#3498db;flex-shrink:0}.chat-mod-btn{background:none;border:none;color:#3498db;cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center}.chat-mod-btn:hover{background:#3498db26}.chat-msg{position:relative}.chat-msg-actions{position:absolute;top:2px;right:4px;display:flex;gap:2px;background:var(--bg-tertiary, #242424);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:2px;z-index:5}.chat-action-btn{background:none;border:none;color:#ffffff80;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:all .15s}.chat-action-delete:hover{color:#ef4444;background:#ef44441f}.chat-action-timeout:hover{color:#f59e0b;background:#f59e0b1f}.chat-action-ban:hover{color:#ef4444;background:#ef44441f}.chat-action-timeout-wrap{position:relative}.chat-timeout-picker{position:absolute;bottom:100%;right:0;display:flex;gap:2px;background:var(--bg-secondary, #1a1a2e);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:4px;margin-bottom:4px;z-index:10}.chat-timeout-option{background:none;border:1px solid rgba(255,255,255,.1);color:#ffffffb3;cursor:pointer;padding:3px 8px;border-radius:4px;font-size:.7rem;white-space:nowrap}.chat-timeout-option:hover{background:#f59e0b26;color:#f59e0b;border-color:#f59e0b4d}.chat-banned-bar{display:flex;align-items:center;gap:8px;padding:12px;border-top:1px solid rgba(255,255,255,.08);color:#ef4444;font-size:.78rem;flex-shrink:0}.chat-bans-overlay{position:absolute;inset:44px 0 0;background:var(--bg-secondary, #1a1a2e);z-index:10;display:flex;flex-direction:column;border-radius:0 0 12px 12px}.chat-bans-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);font-size:.85rem;font-weight:600}.chat-bans-header button{background:none;border:none;color:#ffffff80;cursor:pointer;padding:2px}.chat-bans-list{flex:1;overflow-y:auto;padding:8px}.chat-bans-empty{text-align:center;color:#ffffff4d;font-size:.8rem;padding:24px 0}.chat-ban-item{display:flex;justify-content:space-between;align-items:center;padding:8px;border-radius:6px;background:#ffffff08;margin-bottom:4px}.chat-ban-info{display:flex;flex-direction:column;gap:2px}.chat-ban-name{font-size:.8rem;font-weight:500;color:#ffffffd9}.chat-ban-type{font-size:.68rem;font-weight:600;text-transform:uppercase}.chat-ban-type.ban{color:#ef4444}.chat-ban-type.timeout{color:#f59e0b}.chat-ban-expires{font-size:.68rem;color:#fff6}.chat-unban-btn{background:#22c55e1f;border:1px solid rgba(34,197,94,.2);color:#22c55e;border-radius:6px;padding:4px 10px;font-size:.72rem;cursor:pointer;font-weight:500}.chat-unban-btn:hover{background:#22c55e33}.chat-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;overflow-x:auto}.chat-tab{flex:1;padding:7px 12px;background:none;border:none;border-bottom:2px solid transparent;color:#ffffff80;font-size:.72rem;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.chat-tab:hover{color:#fffc}.chat-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.chat-msg-action{display:flex;align-items:baseline;justify-content:space-between;gap:8px;padding:4px 8px;font-style:italic;font-size:.78rem;color:#ffffff8c;border-left:2px solid var(--accent, #6c6ff2);margin:2px 0;background:#6c6ff20d;border-radius:0 4px 4px 0}.chat-msg-action-text{flex:1;min-width:0}.chat-msg-action-name{font-weight:600;font-style:normal}.chat-watching-link{color:var(--accent, #6c6ff2);text-decoration:underline;text-underline-offset:2px;font-weight:500;cursor:pointer;transition:color .15s}.chat-watching-link:hover{color:var(--accent-hover, #5a5fe0)}.admin-role-select{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.75rem;padding:4px 6px;cursor:pointer}.admin-role-select:focus{border-color:var(--accent);outline:none}.admin-role-badge.chatmod{background:#3498db26;color:#3498db}@media(max-width:640px){.chat-panel{width:calc(100vw - 16px);right:8px;bottom:8px;height:400px}.chat-fab{bottom:16px;right:16px;width:38px;height:38px}}.profile-page{max-width:520px;margin:0 auto;padding:24px 16px}.profile-title{font-size:1.2rem;font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:20px;color:#ffffffe6}.profile-card{background:var(--bg-secondary, #1a1a2e);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:20px;margin-bottom:16px}.profile-preview{display:flex;align-items:center;gap:14px;margin-bottom:20px}.profile-avatar-lg{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;color:#fff}.profile-preview-name{font-size:1.1rem;font-weight:600;color:#fff;display:block}.profile-preview-username{font-size:.78rem;color:#fff6}.profile-form{display:flex;flex-direction:column;gap:14px}.profile-label{font-size:.78rem;font-weight:500;color:#fff9;display:flex;flex-direction:column;gap:6px}.profile-input{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 12px;color:#fff;font-size:.88rem;outline:none}.profile-input:focus{border-color:var(--accent)}.profile-colors{display:flex;flex-wrap:wrap;gap:8px}.profile-color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .15s}.profile-color-swatch:hover{transform:scale(1.15)}.profile-color-swatch.active{border-color:#fff;box-shadow:0 0 0 2px #fff3}.profile-save-btn{background:var(--accent);border:none;border-radius:8px;color:#fff;padding:10px;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s}.profile-save-btn:hover:not(:disabled){background:var(--accent-hover, #5a5fe0)}.profile-save-btn:disabled{opacity:.5}.profile-message{font-size:.8rem;color:#2ecc71;text-align:center}.profile-info-section{background:var(--bg-secondary, #1a1a2e);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:16px}.profile-info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.profile-info-row:last-child{border-bottom:none}.profile-info-label{font-size:.78rem;color:#ffffff80}.profile-info-value{font-size:.8rem;color:#ffffffd9;font-weight:500}.changelog-overlay{position:fixed;inset:0;background:#0009;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.changelog-modal{background:var(--card-bg, #1a1a2e);border:1px solid rgba(255,255,255,.1);border-radius:12px;width:90%;max-width:520px;max-height:70vh;display:flex;flex-direction:column;animation:scaleIn .2s ease-out}.changelog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.changelog-header h2{margin:0;font-size:1.1rem;font-weight:600}.changelog-close{background:none;border:none;color:#ffffff80;cursor:pointer;padding:4px;border-radius:6px;transition:color .15s,background .15s}.changelog-close:hover{color:#fff;background:#ffffff1a}.changelog-list{overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}.changelog-entry{padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.06)}.changelog-entry:last-child{border-bottom:none;padding-bottom:0}.changelog-entry-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}.changelog-version-badge{background:var(--accent, #6366f1);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:.3px}.changelog-date{font-size:.75rem;color:#ffffff59}.changelog-entry-title{margin:0 0 4px;font-size:.95rem;font-weight:600}.changelog-description{margin:0;font-size:.82rem;color:#fff9;line-height:1.5;white-space:pre-line}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.status-page{max-width:640px;margin:0 auto;padding:32px 16px}.status-header{display:flex;align-items:center;gap:10px;margin-bottom:24px}.status-header h1{margin:0;font-size:1.4rem;font-weight:700;flex:1}.status-refresh-btn{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#fff9;cursor:pointer;padding:6px;border-radius:8px;transition:background .15s,color .15s;display:flex;align-items:center}.status-refresh-btn:hover{background:#ffffff1a;color:#fff}.status-refresh-btn:disabled{opacity:.5;cursor:default}.status-refresh-btn .spin{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-overall{display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:10px;font-weight:600;font-size:1rem;margin-bottom:16px}.status-overall-operational{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.status-overall-degraded{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.status-overall-outage{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot-operational{background:#22c55e;box-shadow:0 0 6px #22c55e80}.status-dot-degraded{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.status-dot-outage{background:#ef4444;box-shadow:0 0 6px #ef444480}.status-meta{display:flex;gap:20px;margin-bottom:20px;font-size:.8rem;color:#fff6}.status-meta-item{display:flex;align-items:center;gap:6px}.status-services{display:flex;flex-direction:column;gap:8px}.status-service{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;transition:background .15s}.status-service:hover{background:#ffffff0d}.status-service-left{display:flex;align-items:center;gap:10px;color:#fffc;font-weight:500;font-size:.9rem}.status-service-right{display:flex;align-items:center;gap:10px}.status-service-detail{font-size:.75rem;color:#ffffff59}.status-service-latency{font-size:.72rem;color:#ffffff4d;font-variant-numeric:tabular-nums}.status-badge{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px}.status-badge-ok{background:#22c55e26;color:#22c55e}.status-badge-down{background:#ef444426;color:#ef4444}.status-error{text-align:center;color:#ffffff80;padding:40px 0}@media(max-width:768px){.status-page{padding:20px 12px}.status-meta{flex-direction:column;gap:8px}.status-service{flex-direction:column;align-items:flex-start;gap:8px}.status-service-right{width:100%;justify-content:flex-end}}[dir=rtl] .chat-panel,[dir=rtl] .chat-fab{right:auto;left:24px}[dir=rtl] .detail-back svg,[dir=rtl] .watch-back svg,[dir=rtl] .player-back svg{transform:scaleX(-1)}@media(max-width:640px){[dir=rtl] .chat-panel{left:8px;right:8px}}.wt-page{display:flex;flex-direction:column;height:calc(100vh - var(--navbar-height))}.wt-centered{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:#888}.wt-error{color:#e74c3c;font-size:.85rem}.wt-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#141414e6;border-bottom:1px solid var(--border);flex-shrink:0}.wt-topbar-left,.wt-topbar-right{display:flex;align-items:center;gap:10px;font-size:.85rem}.wt-live-dot{color:#e74c3c;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.wt-room-code{color:#ccc}.wt-room-code strong{color:#fff;font-family:monospace;letter-spacing:1px}.wt-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500}.wt-btn:hover{filter:brightness(1.15)}.wt-btn-sm{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#ffffff14;color:#ccc;border:none;border-radius:5px;cursor:pointer;font-size:.78rem}.wt-btn-sm:hover{background:#ffffff26;color:#fff}.wt-btn-sm.danger:hover{background:#e74c3c40;color:#e74c3c}.wt-body{display:flex;flex:1;min-height:0}.wt-video-area{flex:1;display:flex;flex-direction:column;min-width:0;background:#000}.wt-player-wrap{flex:1;position:relative}.wt-player-wrap .player-container{position:absolute;inset:0}.wt-no-channel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#666}.wt-channel-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#141414f2;font-size:.82rem;color:#aaa;flex-shrink:0}.wt-channel-bar strong{color:#fff}.wt-sidebar{width:300px;display:flex;flex-direction:column;background:#121212f2;border-left:1px solid var(--border);flex-shrink:0}.wt-section-title{display:flex;align-items:center;gap:6px;padding:10px 12px;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:#888;border-bottom:1px solid var(--border)}.wt-members{flex-shrink:0;max-height:200px;overflow-y:auto}.wt-member-list{padding:6px 0}.wt-member{display:flex;align-items:center;gap:8px;padding:4px 12px;font-size:.82rem;color:#ddd}.wt-member-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#fff;flex-shrink:0}.wt-host-icon{color:#f1c40f;flex-shrink:0}.wt-chat{flex:1;display:flex;flex-direction:column;min-height:0;border-top:1px solid var(--border)}.wt-chat-messages{flex:1;overflow-y:auto;padding:8px 12px;font-size:.82rem}.wt-chat-msg{margin-bottom:4px;line-height:1.4}.wt-chat-name{font-weight:600;margin-right:6px}.wt-chat-text{color:#ccc}.wt-chat-system{color:#666;font-size:.75rem;text-align:center;margin:6px 0;font-style:italic}.wt-chat-input{display:flex;gap:6px;padding:8px;border-top:1px solid var(--border);flex-shrink:0}.wt-chat-input input{flex:1;background:#ffffff0f;border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:#e8e8e8;font-size:.82rem}.wt-chat-input button{background:var(--accent);border:none;color:#fff;border-radius:6px;padding:6px 10px;cursor:pointer;display:flex;align-items:center}.wt-chat-input button:disabled{opacity:.4}.wt-empty{color:#555;font-size:.82rem;text-align:center;padding:24px}.wt-modal-overlay{position:fixed;inset:0;background:#000000b3;z-index:300;display:flex;align-items:center;justify-content:center}.wt-modal{background:#1a1a1a;border:1px solid #333;border-radius:12px;width:460px;max-height:70vh;display:flex;flex-direction:column}.wt-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #333}.wt-modal-header h3{margin:0;font-size:1rem;color:#e8e8e8}.wt-search-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid #222;color:#888}.wt-search-bar input{flex:1;background:none;border:none;color:#e8e8e8;font-size:.9rem;outline:none}.wt-channel-list{flex:1;overflow-y:auto;padding:4px 0}.wt-channel-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 14px;background:none;border:none;color:#ddd;cursor:pointer;font-size:.85rem;text-align:left}.wt-channel-item:hover{background:#ffffff0f}.wt-channel-logo{width:28px;height:28px;border-radius:4px;object-fit:contain;background:#222}.wt-channel-name{flex:1}.wt-channel-country{color:#666;font-size:.75rem}@media(max-width:768px){.wt-body{flex-direction:column}.wt-sidebar{width:100%;max-height:40vh;border-left:none;border-top:1px solid var(--border)}.wt-members{max-height:80px}}.dashboard-page{margin-top:calc(-1 * var(--navbar-height));padding-bottom:60px}.hero-billboard{position:relative;width:100%;min-height:85vh;background:var(--bg-secondary);background-size:cover;background-position:center top;display:flex;align-items:flex-end}.hero-billboard-empty{min-height:55vh;background:linear-gradient(135deg,#0a0a0a,#1a0505,#0a0a0a)}.hero-billboard-vignette{position:absolute;inset:0;background:linear-gradient(to top,#000,#000000e6 15%,#00000080 40%,#00000026 60%,#0000004d),linear-gradient(to right,rgba(0,0,0,.8) 0%,rgba(0,0,0,.2) 50%,transparent 70%);pointer-events:none}.hero-billboard-content{position:relative;z-index:2;padding:0 56px 64px;max-width:640px;display:flex;flex-direction:column;gap:12px}.hero-billboard-greeting{font-size:1.1rem;font-weight:500;color:#ffffffbf;letter-spacing:.5px;text-shadow:0 2px 12px rgba(0,0,0,.5);margin:0}.hero-billboard-title{font-size:3.2rem;font-weight:800;color:#fff;line-height:1.05;letter-spacing:-1.5px;text-shadow:0 4px 30px rgba(0,0,0,.7)}.hero-billboard-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.hero-billboard-badge{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:#ffffffe6;background:#ffffff1a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:4px 10px;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.hero-billboard-badge.rating-badge{color:#fbbf24;background:#fbbf241f;border-color:#fbbf2433}.hero-billboard-genres{display:flex;gap:6px;flex-wrap:wrap}.hero-billboard-genre{font-size:.75rem;font-weight:500;color:#fffc;padding:3px 10px;border-radius:20px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hero-billboard-plot{font-size:.9rem;color:#ffffffbf;line-height:1.55;max-width:520px;margin:0;text-shadow:0 1px 8px rgba(0,0,0,.5)}.hero-billboard-actions{display:flex;gap:12px;margin-top:6px}.hero-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 32px;font-size:1rem;font-weight:700;border-radius:var(--radius);cursor:pointer;transition:all .2s;font-family:inherit;background:#fff;color:#000}.hero-btn-primary:hover{background:#ffffffd9;transform:scale(1.03)}.hero-btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;font-size:1rem;font-weight:600;border-radius:var(--radius);cursor:pointer;transition:all .2s;font-family:inherit;background:#ffffff1f;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1)}.hero-btn-secondary:hover{background:#fff3;transform:scale(1.03)}.poster-card{flex:0 0 165px;cursor:pointer;border-radius:var(--radius);overflow:hidden;scroll-snap-align:start;transition:transform .25s ease,box-shadow .25s ease;position:relative}.poster-card:hover{transform:scale(1.08);z-index:3}.poster-card-image{width:100%;aspect-ratio:2/3;background:var(--bg-tertiary);background-size:cover;background-position:center;position:relative;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);overflow:hidden}.poster-card-placeholder{font-size:2rem;font-weight:800;color:var(--text-muted);text-transform:uppercase}.poster-card-hover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000073;opacity:0;transition:opacity .2s}.poster-card:hover .poster-card-hover{opacity:1}.poster-card-rating{position:absolute;top:6px;left:6px;display:inline-flex;align-items:center;gap:3px;font-size:.68rem;font-weight:700;color:#fbbf24;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:2px 7px;border-radius:4px}.poster-card-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff26}.poster-card-progress-fill{height:100%;background:var(--accent)}.poster-card-info{padding:6px 2px 4px;display:flex;flex-direction:column;gap:2px}.poster-card-title{font-size:.78rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.poster-card-sub{font-size:.68rem;color:var(--text-muted);font-weight:500}.poster-card-numbered{flex:0 0 190px;display:flex;align-items:flex-end;overflow:visible}.poster-card-numbered .poster-card-image{flex:0 0 130px;width:130px}.poster-card-numbered .poster-card-info{display:none}.poster-card-number{font-size:6rem;font-weight:900;line-height:.8;color:transparent;-webkit-text-stroke:2px var(--accent);text-stroke:2px var(--accent);margin-right:-16px;z-index:1;flex-shrink:0;font-style:italic;-webkit-user-select:none;user-select:none}.content-row{padding:0 56px;margin-bottom:40px}.content-row:first-of-type{margin-top:-20px;position:relative;z-index:3}.content-row-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.content-row-title{font-size:1.25rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px;margin:0}.content-row-title.clickable{cursor:pointer;transition:color .2s}.content-row-title.clickable:hover{color:var(--accent)}.content-row-accent{width:3px;height:1.2em;background:var(--accent);border-radius:2px;flex-shrink:0}.content-row-icon{display:flex;color:var(--accent)}.content-row-arrow{opacity:.5;transition:opacity .2s}.content-row-title.clickable:hover .content-row-arrow{opacity:1}.content-row-tabs{display:flex;gap:4px}.content-row-tab{font-size:.78rem;font-weight:500;padding:4px 12px;border-radius:4px;color:var(--text-secondary);transition:all .15s}.content-row-tab:hover{color:#fff}.content-row-tab.active{color:#fff;background:var(--accent)}.content-row-scroll-wrap{position:relative}.content-row-scroll{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x proximity;scroll-behavior:smooth;padding-bottom:4px}.content-row-scroll::-webkit-scrollbar{height:0}.content-row-nav{position:absolute;top:0;bottom:4px;width:48px;display:flex;align-items:center;justify-content:center;color:#fff;z-index:5;transition:opacity .2s;opacity:.7}.content-row-nav:hover{opacity:1}.content-row-nav-left{left:-24px;background:linear-gradient(to right,rgba(0,0,0,.9),transparent)}.content-row-nav-right{right:-24px;background:linear-gradient(to left,rgba(0,0,0,.9),transparent)}.sports-card{flex:0 0 210px;background:var(--bg-tertiary);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:8px;cursor:default;border:1px solid var(--border);transition:border-color .2s;position:relative;scroll-snap-align:start}.sports-card:hover{border-color:var(--border-light)}.sports-card.flagged{border-color:var(--accent)}.sports-flag{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .2s}.sports-flag:hover,.sports-flag.active{color:var(--accent)}.sports-card-league{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sports-card-league img{width:16px;height:16px;object-fit:contain;filter:brightness(0) invert(1)}.sports-card-teams{display:flex;flex-direction:column;gap:4px;flex:1}.sports-card-team{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sports-card-team img{width:20px;height:20px;object-fit:contain;flex-shrink:0}.sports-card-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:6px;border-top:1px solid var(--border)}.sports-card-time{font-size:.72rem;color:var(--text-secondary)}.live-badge{font-size:.65rem;font-weight:700;color:#fff;background:var(--accent);padding:2px 8px;border-radius:3px;letter-spacing:.5px;animation:livePulse 2s infinite}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.7}}.sports-card-watch{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;color:#fff;background:var(--accent);padding:3px 10px;border-radius:4px;transition:background .15s}.sports-card-watch:hover{background:var(--accent-hover)}.event-card{flex:0 0 260px;border-radius:var(--radius);overflow:hidden;background:var(--bg-tertiary);scroll-snap-align:start}.event-card-image{width:100%;aspect-ratio:16 / 9;background:var(--bg-secondary);background-size:cover;background-position:center}.event-card-info{padding:10px 12px;display:flex;flex-direction:column;gap:4px}.event-card-title{font-size:.88rem;font-weight:600;color:var(--text-primary)}.event-card-date{font-size:.75rem;color:var(--accent);display:flex;align-items:center;gap:4px;font-weight:500}.event-card-desc{font-size:.75rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.admin-event-form{display:flex;flex-direction:column;gap:12px}.admin-event-form textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;resize:vertical;font-family:inherit}@media(max-width:768px){.hero-billboard{min-height:65vh}.hero-billboard-content{padding:0 20px 32px;max-width:100%}.hero-billboard-title{font-size:1.8rem;letter-spacing:-.5px}.hero-billboard-plot{font-size:.82rem;-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.hero-btn-primary,.hero-btn-secondary{padding:10px 20px;font-size:.88rem}.content-row{padding:0 16px;margin-bottom:28px}.poster-card{flex:0 0 130px}.poster-card-numbered{flex:0 0 150px}.poster-card-numbered .poster-card-image{flex:0 0 100px;width:100px}.poster-card-number{font-size:4rem}.sports-card{flex:0 0 180px}}.dashboard-section-link{cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .2s}.dashboard-section-link:hover{color:var(--accent)}.sports-game-card{flex:0 0 200px;background:var(--bg-secondary);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px;cursor:default;border:1px solid var(--border-color);transition:border-color .2s;position:relative}.sports-game-card:hover{border-color:var(--text-muted)}.sports-game-card-league{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sports-card-league-logo{width:16px;height:16px;object-fit:contain;flex-shrink:0;filter:brightness(0) invert(1)}.sports-game-card-teams{display:flex;flex-direction:column;gap:4px;flex:1}.sports-card-team{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sports-card-team-logo{width:20px;height:20px;object-fit:contain;flex-shrink:0}.sports-card-vs{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;padding-left:26px}.sports-game-time{font-size:.75rem;color:var(--text-secondary)}.sports-live-badge{font-size:.7rem;font-weight:700;color:#fff;background:#e53935;padding:2px 8px;border-radius:4px;letter-spacing:.5px;animation:sports-pulse 1.5s ease-in-out infinite}@keyframes sports-pulse{0%,to{opacity:1}50%{opacity:.6}}.sports-page{padding:24px;max-width:1000px;margin:0 auto}.sports-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.sports-header h1{font-size:1.5rem;margin:0}.sports-back-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;padding:6px 8px;cursor:pointer;display:flex;align-items:center}.sports-back-btn:hover{background:var(--bg-tertiary)}.sports-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:20px;scrollbar-width:none}.sports-tabs::-webkit-scrollbar{display:none}.sports-tab{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);font-size:.8rem;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.sports-tab:hover{border-color:var(--text-muted)}.sports-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sports-tab-count{background:#ffffff26;padding:1px 6px;border-radius:10px;font-size:.7rem}.sports-tab.active .sports-tab-count{background:#ffffff40}.sports-empty{color:var(--text-muted);font-size:.9rem;text-align:center;padding:40px 0}.sports-league-group{margin-bottom:20px}.sports-league-header{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.sports-league-logo{width:20px;height:20px;object-fit:contain}.sports-game-list{display:flex;flex-direction:column;gap:4px}.sports-game-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border-color)}.sports-game-row.finished{opacity:.5}.sports-game-row.flagged{border-color:#f59e0b;background:#f59e0b0f}.sports-flag-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;flex-shrink:0;transition:color .15s}.sports-flag-btn:hover,.sports-flag-btn.active{color:#f59e0b}.sports-game-card .sports-flag-btn{position:absolute;top:6px;right:6px;padding:2px}.sports-game-card.flagged{border-color:#f59e0b;background:#f59e0b0f}.sports-game-teams{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.sports-team{display:flex;align-items:center;gap:6px;min-width:0}.sports-team-logo{width:22px;height:22px;object-fit:contain;flex-shrink:0}.sports-team-name{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sports-vs{color:var(--text-muted);font-size:.7rem;flex-shrink:0;padding:0 4px}.sports-game-status{flex-shrink:0;margin-left:12px}.sports-game-finished{font-size:.75rem;color:var(--text-muted)}.sports-date-group{margin-bottom:20px}.sports-date-header{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.sports-game-league-badge{flex-shrink:0;margin-right:4px}.sports-game-league-badge img{width:18px;height:18px;object-fit:contain}.sports-watch-btn{flex-shrink:0;margin-left:8px;display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:.72rem;font-weight:600;border-radius:6px;border:none;background:var(--accent);color:#fff;cursor:pointer;transition:opacity .15s}.sports-watch-btn:hover{opacity:.85}.sports-card-watch-btn{display:flex;align-items:center;gap:3px;padding:2px 8px;font-size:.65rem;font-weight:600;border-radius:4px;border:none;background:var(--accent);color:#fff;cursor:pointer;margin-left:6px}.sports-card-watch-btn:hover{opacity:.85}.sports-game-card-bottom{display:flex;align-items:center;justify-content:center;gap:6px}.admin-ml-linked{background:#3b82f60a}.admin-ml-teams{font-weight:500;font-size:.85rem;white-space:nowrap}.admin-ml-league{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.admin-ml-league-logo{width:16px;height:16px;object-fit:contain}.admin-ml-input-wrap{display:flex;flex-direction:column}.admin-ml-select{width:100%;min-width:180px;padding:4px 8px;font-size:.8rem;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.admin-ml-select:focus{border-color:var(--accent);outline:none}.admin-ml-input{width:100%;min-width:160px;padding:4px 8px;font-size:.8rem;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary)}.admin-ml-input:focus{border-color:var(--accent);outline:none}.admin-presets-toggle{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:6px 12px;font-size:.8rem;color:var(--text-muted);cursor:pointer;border-radius:6px;transition:background .15s}.admin-presets-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary)}.admin-presets-panel{margin-top:8px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.admin-preset-row{display:flex;align-items:center;gap:8px;padding:4px 0}.admin-preset-row+.admin-preset-row{border-top:1px solid var(--border-color)}.admin-preset-label{font-size:.8rem;color:var(--text-primary);font-weight:500;min-width:200px}.admin-preset-url{font-size:.75rem;color:var(--text-muted);flex:1;font-family:monospace}.admin-preset-add{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color)}@media(max-width:768px){.sports-page{padding:16px}.sports-game-card{flex:0 0 170px}.sports-team-name{font-size:.78rem}.sports-game-league-badge{display:none}}.cineby-page{padding-bottom:3rem}.cineby-header{margin-bottom:1.5rem}.cineby-title{font-size:1.8rem;font-weight:700;color:#fff}.cineby-subtitle{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.cineby-search-bar{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.75rem 1rem;margin-bottom:2rem}.cineby-search-bar svg{color:var(--text-secondary);flex-shrink:0}.cineby-search-bar input{flex:1;background:none;border:none;color:#fff;font-size:.95rem;outline:none}.cineby-row{margin-bottom:2.5rem}.cineby-row-title{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:1rem}.cineby-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.cineby-card{cursor:pointer;border-radius:10px;overflow:hidden;background:var(--surface);border:1px solid var(--border);transition:transform .2s,border-color .2s,box-shadow .2s}.cineby-card:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:0 8px 24px #0006}.cineby-card-poster{position:relative;aspect-ratio:2/3;overflow:hidden;background:#111}.cineby-card-poster img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.cineby-card:hover .cineby-card-poster img{transform:scale(1.05)}.cineby-card-no-poster{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.cineby-card-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080;opacity:0;transition:opacity .2s;color:#fff}.cineby-card:hover .cineby-card-overlay{opacity:1}.cineby-card-rating{position:absolute;top:6px;left:6px;background:#000000bf;color:#fbbf24;border-radius:4px;font-size:.7rem;padding:2px 6px;display:flex;align-items:center;gap:3px;font-weight:600}.cineby-card-type{position:absolute;top:6px;right:6px;border-radius:4px;font-size:.65rem;padding:2px 6px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.cineby-card-type.movie{background:#7c3aed;color:#fff}.cineby-card-type.tv{background:#0ea5e9;color:#fff}.cineby-card-info{padding:.6rem .75rem}.cineby-card-title{font-size:.82rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cineby-card-year{font-size:.72rem;color:var(--text-secondary)}.cineby-watch-page{padding:0!important}.cineby-hero{position:relative;min-height:450px;background-size:cover;background-position:center top;display:flex;align-items:flex-end;padding:3rem 2rem 2rem}.cineby-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg) 0%,rgba(10,10,14,.7) 50%,rgba(10,10,14,.4) 100%)}.cineby-back-btn{position:absolute;top:1rem;left:1rem;z-index:2;display:flex;align-items:center;gap:.4rem;background:#00000080;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;cursor:pointer;font-size:.85rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cineby-back-btn:hover{background:#ffffff26}.cineby-hero-content{position:relative;z-index:1;display:flex;gap:1.5rem;align-items:flex-end;max-width:900px}.cineby-hero-poster{width:180px;border-radius:10px;box-shadow:0 8px 32px #00000080;flex-shrink:0}.cineby-hero-info h1{font-size:1.8rem;font-weight:700;color:#fff;margin-bottom:.5rem}.cineby-hero-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.cineby-meta-badge{display:inline-flex;align-items:center;gap:4px;background:#ffffff1a;border-radius:6px;padding:.25rem .6rem;font-size:.78rem;color:#ccc}.cineby-hero-genres{font-size:.82rem;color:var(--text-secondary);margin-bottom:.5rem}.cineby-hero-overview{font-size:.85rem;color:#bbb;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:1rem}.cineby-play-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;padding:.7rem 1.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s}.cineby-play-btn:hover{filter:brightness(1.15)}.cineby-play-btn:disabled{opacity:.6;cursor:not-allowed}.cineby-error{display:flex;align-items:center;gap:.4rem;color:#f87171;font-size:.82rem;margin-top:.5rem}.cineby-player-section{background:#000}.cineby-player-section:fullscreen{display:flex;align-items:center;justify-content:center}.cineby-player-section:fullscreen .cineby-player-container{max-width:100%;width:100%;height:100%}.cineby-player-section:fullscreen .cineby-video{height:100%;object-fit:contain}.cineby-player-container{position:relative;max-width:1200px;margin:0 auto;aspect-ratio:16/9}.cineby-video{width:100%;height:100%;background:#000}.cineby-video::cue{background:#000000b3;color:#fff;font-size:1.1rem;line-height:1.4}.cineby-player-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:#0009;color:#fff}.cineby-player-container.cineby-idle{cursor:none}.cineby-player-controls{position:absolute;bottom:0;left:0;right:0;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(transparent,#000c);transition:opacity .3s ease,visibility .3s ease;opacity:1;visibility:visible}.cineby-idle .cineby-player-controls{opacity:0;visibility:hidden}.cineby-player-controls button{background:none;border:none;color:#fff;cursor:pointer;padding:.3rem;display:flex;align-items:center;position:relative}.cineby-player-controls button:hover,.cineby-player-controls button.active{color:var(--primary)}.cineby-player-time{font-size:.75rem;color:#ccc;white-space:nowrap}.cineby-player-seek{flex:1;height:4px;cursor:pointer;accent-color:var(--primary)}.cineby-video{cursor:pointer}.cineby-volume-wrap{display:flex;align-items:center;gap:.25rem}.cineby-volume-slider{width:60px;height:4px;cursor:pointer;accent-color:var(--primary)}.cineby-track-menu-wrap{position:relative}.cineby-track-menu{position:absolute;bottom:100%;right:0;background:#141414f2;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:.4rem 0;min-width:180px;max-height:300px;overflow-y:auto;margin-bottom:.5rem;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.cineby-track-menu-title{padding:.4rem .75rem;font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:.2rem}.cineby-track-option{display:block;width:100%;text-align:left;background:none;border:none;color:#ccc;padding:.4rem .75rem;font-size:.8rem;cursor:pointer;transition:background .15s}.cineby-track-option:hover{background:#ffffff1a;color:#fff}.cineby-track-option.selected{color:var(--primary);font-weight:600}.cineby-track-option.selected:before{content:"\\2713 "}.cineby-player-overlay{pointer-events:none}.cineby-episodes-section{padding:1.5rem 2rem}.cineby-season-selector{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.cineby-season-selector label{color:#fff;font-weight:600}.cineby-season-selector select{background:var(--surface);color:#fff;border:1px solid var(--border);border-radius:6px;padding:.4rem .75rem;font-size:.85rem}.cineby-episodes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.cineby-episode-card{display:flex;gap:.75rem;cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .2s}.cineby-episode-card:hover{border-color:var(--primary)}.cineby-episode-thumb{position:relative;width:160px;flex-shrink:0;aspect-ratio:16/9;background:#111;overflow:hidden}.cineby-episode-thumb img{width:100%;height:100%;object-fit:cover}.cineby-episode-no-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.cineby-episode-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity .2s;color:#fff}.cineby-episode-card:hover .cineby-episode-play{opacity:1}.cineby-episode-info{padding:.6rem .5rem;flex:1;min-width:0}.cineby-episode-num{font-size:.7rem;color:var(--primary);font-weight:700}.cineby-episode-info h4{font-size:.82rem;color:#fff;margin:.15rem 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cineby-episode-runtime{font-size:.72rem;color:var(--text-secondary)}.cineby-similar-section{padding:1.5rem 2rem}.cineby-similar-section h2{font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:1rem}.spin{animation:spin 1s linear infinite}@media(max-width:768px){.cineby-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.cineby-hero{min-height:350px;padding:2rem 1rem 1.5rem}.cineby-hero-poster{width:120px}.cineby-hero-info h1{font-size:1.3rem}.cineby-hero-content{align-items:flex-end}.cineby-episodes-section{padding:1rem}.cineby-episodes-grid{grid-template-columns:1fr}}
