*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #16161f;--bg-card-hover: #1c1c28;--bg-surface: #1e1e2a;--bg-input: #1a1a26;--border: #2a2a3a;--border-light: #333346;--text-primary: #f0f0f5;--text-secondary: #a0a0b8;--text-muted: #6a6a82;--accent: #6366f1;--accent-hover: #818cf8;--accent-dim: rgba(99, 102, 241, .15);--green: #22c55e;--green-dim: rgba(34, 197, 94, .15);--red: #ef4444;--orange: #f59e0b;--orange-dim: rgba(245, 158, 11, .15);--radius: 10px;--radius-sm: 6px;--shadow: 0 4px 24px rgba(0, 0, 0, .3);--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}html,body{height:100%;font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow:hidden}#app{display:flex;flex-direction:column;height:100vh}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border);position:relative;z-index:100;flex-shrink:0}.header-inner{display:flex;align-items:center;gap:16px;padding:0 20px;height:56px;max-width:100%}.logo{display:flex;align-items:center;gap:8px;flex-shrink:0}.logo-icon{width:22px;height:22px;color:var(--accent)}.logo-text{font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--accent),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;white-space:nowrap}.header-center{flex:1;display:flex;align-items:center;gap:12px;justify-content:center}.nav-tabs{display:flex;gap:2px;background:var(--bg-primary);border-radius:8px;padding:3px}.nav-tab{padding:6px 14px;border:none;background:none;color:var(--text-secondary);font-size:.85rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;font-family:var(--font);white-space:nowrap}.nav-tab:hover{color:var(--text-primary);background:var(--bg-surface)}.nav-tab.active{background:var(--accent);color:#fff}.live-dot-small{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.search-box{position:relative;max-width:240px;flex-shrink:0}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:7px 12px 7px 32px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.85rem;font-family:var(--font);outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.refresh-btn{width:36px;height:36px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.refresh-btn svg{width:16px;height:16px}.refresh-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.refresh-btn.spinning svg{animation:spin .6s ease-in-out}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.layout{display:flex;flex:1;overflow:hidden}.sidebar{width:220px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.sidebar-header{display:flex;align-items:center;gap:8px;padding:16px 16px 12px;border-bottom:1px solid var(--border)}.sidebar-icon{width:18px;height:18px;color:var(--accent)}.sidebar-header h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.sports-list{list-style:none;padding:8px;overflow-y:auto;flex:1}.sport-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .15s;margin-bottom:2px;position:relative}.sport-item:hover{background:var(--bg-surface)}.sport-item.active{background:var(--accent-dim)}.sport-item.active .sport-name{color:var(--accent);font-weight:600}.sport-indicator{width:3px;height:18px;border-radius:2px;background:var(--border);flex-shrink:0}.sport-item.active .sport-indicator{background:var(--accent)}.sport-indicator.live-bar{background:var(--green);animation:pulse-bar 2s infinite}.sport-icon{width:18px;height:18px;flex-shrink:0;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.sport-icon svg{width:100%;height:100%}.sport-item.active .sport-icon{color:var(--accent)}.sport-icon-live{color:var(--red)}@keyframes pulse-bar{0%,to{opacity:1}50%{opacity:.5}}.sport-name{font-size:.88rem;color:var(--text-secondary);flex:1}.sport-item.active .sport-name{color:var(--text-primary)}.sport-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-primary);padding:2px 7px;border-radius:10px;font-weight:500}.sport-divider{height:1px;background:var(--border);margin:6px 0}.main-content{flex:1;overflow-y:auto;padding:20px}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.content-header-left{display:flex;align-items:baseline;gap:12px}.content-header h2{font-size:1.3rem;font-weight:700}.match-count{font-size:.85rem;color:var(--text-muted)}.sidebar-toggle{display:none;width:36px;height:36px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);border-radius:8px;cursor:pointer;align-items:center;justify-content:center}.sidebar-toggle svg{width:18px;height:18px}.matches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.match-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .2s ease;animation:fadeInUp .3s ease both;position:relative}.match-card:hover{border-color:var(--card-accent, var(--border-light));background:var(--bg-card-hover);transform:translateY(-2px);box-shadow:var(--shadow)}.match-card:has(.has-poster) .card-poster{transition:filter .2s}.match-card:hover .card-poster{filter:brightness(1.1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-poster{width:100%;height:160px;object-fit:cover;display:block}.card-body{padding:14px}.match-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.match-badges{display:flex;gap:6px;flex-wrap:wrap}.badge{font-size:.7rem;font-weight:600;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.badge-live{background:var(--green-dim);color:var(--green);display:flex;align-items:center;gap:4px}.badge-dot{width:5px;height:5px;border-radius:50%;background:var(--green);animation:pulse-dot 1.5s infinite}.badge-upcoming{background:var(--orange-dim);color:var(--orange)}.badge-sport{background:var(--accent-dim);color:var(--accent)}.badge-tag{background:#a855f726;color:#a855f7}.match-header-right{display:flex;align-items:center;gap:8px}.viewers-badge{font-size:.72rem;color:var(--green);font-weight:500;display:flex;align-items:center;gap:4px}.viewers-badge:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--green)}.match-time{font-size:.78rem;color:var(--text-muted);font-weight:500}.event-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:10px;line-height:1.3}.match-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--border)}.match-date{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--text-muted)}.watch-btn{padding:5px 14px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font)}.watch-btn:hover{background:var(--accent-hover);transform:scale(1.05)}.footer-right{display:flex;align-items:center;gap:8px}.sources-count{font-size:.72rem;color:var(--text-muted);background:var(--bg-primary);padding:3px 8px;border-radius:4px}.source-tabs{display:flex;gap:8px;flex-wrap:wrap;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.source-tabs:empty{display:none;border-top:none;padding:0}.source-tab{padding:6px 14px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);font-size:.82rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .15s;font-family:var(--font);min-height:34px}.source-tab:hover{background:var(--bg-card-hover);color:var(--text-primary)}.source-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;grid-column:1 / -1}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}.loading-state p,.error-state p,.empty-state p{color:var(--text-muted);font-size:.9rem}.error-state svg,.empty-state svg{width:40px;height:40px;color:var(--text-muted);margin-bottom:12px}.error-state h3,.empty-state h3{font-size:1rem;margin-bottom:6px}.error-state button{margin-top:12px;padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;font-family:var(--font)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .2s}.modal-overlay.open{opacity:1;pointer-events:auto}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:90vw;max-width:900px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 40px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header-info{display:flex;align-items:center;gap:12px;min-width:0}.modal-header h3{font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-category{font-size:.78rem;color:var(--accent);background:var(--accent-dim);padding:3px 10px;border-radius:4px;font-weight:500;white-space:nowrap}.modal-close{width:32px;height:32px;border:none;background:var(--bg-surface);color:var(--text-secondary);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.modal-close svg{width:18px;height:18px}.modal-close:hover{background:var(--red);color:#fff}.modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.stream-container{flex:1;background:#000;min-height:400px;position:relative}.stream-container iframe{width:100%;height:100%;min-height:400px;border:none}.stream-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;color:var(--text-muted)}.placeholder-icon{width:48px;height:48px;margin-bottom:12px;opacity:.5}.toast-container{position:fixed;bottom:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{padding:10px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;font-size:.85rem;color:var(--text-primary);box-shadow:var(--shadow);animation:toastIn .3s ease}.toast.error{border-color:var(--red);background:#ef44441a;color:var(--red)}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.sidebar{position:fixed;left:0;top:56px;bottom:0;z-index:90;transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.sidebar-toggle{display:flex}.header-center{justify-content:flex-start}}@media(max-width:640px){.matches-grid{grid-template-columns:1fr}.search-box{max-width:160px}.nav-tabs{display:none}.modal-overlay{align-items:center}.modal-content{width:95vw;max-width:95vw;max-height:85vh;border-radius:12px}.modal-body{overflow-y:auto}.stream-container,.stream-container iframe{min-height:250px}.source-tabs{gap:6px;padding:12px 16px}.source-tab{padding:8px 16px;font-size:.82rem;min-height:36px}}
