.viewer-header{background:var(--gb-surface);border-bottom:1px solid var(--gb-border-subtle);color:var(--gb-text-primary)}.viewer-header-container{max-width:1400px;padding:0 var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);height:56px;margin:0 auto;display:flex}.viewer-logo{align-items:center;gap:var(--space-2);color:var(--gb-text-primary);text-decoration:none;display:flex}.viewer-logo h1{font-family:var(--gb-font-display);letter-spacing:.04em;color:var(--gb-text-primary);margin:0;font-size:1.125rem;font-weight:700}.viewer-logo-icon{display:none}.viewer-logo img{width:auto;height:32px}.viewer-actions{gap:var(--space-3);align-items:center;display:flex}.login-button{font-family:var(--gb-font-display);letter-spacing:.04em;background:var(--gb-red);color:oklch(98% .005 265);border-radius:var(--gb-radius-sm);cursor:pointer;border:none;padding:7px 18px;font-size:.8125rem;font-weight:700;transition:background .15s}.login-button:hover{background:var(--gb-red-hover)}.viewer-username{font-family:var(--gb-font-body);color:var(--gb-text-secondary);font-size:.8125rem;font-weight:500}.logout-button{font-family:var(--gb-font-body);color:var(--gb-text-muted);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius-sm);cursor:pointer;background:0 0;padding:6px 14px;font-size:.8125rem;font-weight:500;transition:color .15s,border-color .15s}.logout-button:hover{color:var(--gb-text-secondary);border-color:var(--gb-border)}.user-avatar{background:var(--gb-surface-raised);border:1px solid var(--gb-border);width:32px;height:32px;font-family:var(--gb-font-display);color:var(--gb-text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}@media (width<=768px){.viewer-header-container{padding:0 var(--space-4);height:50px}.viewer-logo h1{font-size:1rem}.viewer-actions{gap:var(--space-2)}.viewer-username{display:none}}.ad-slot{background:#f5f5f5;border:1px solid #e0e0e0;justify-content:center;align-items:center;display:flex}.ad-slot a{width:100%;height:100%;display:block}.ad-slot img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;display:block}.ad-slot-top-banner{z-index:100;width:100%;height:90px;position:fixed;top:0;left:0;right:0}.ad-slot-bottom-banner{z-index:100;width:100%;height:90px;position:fixed;bottom:0;left:0;right:0}.ad-slot-sidebar-right{z-index:50;width:300px;height:250px;position:fixed;top:120px;right:20px}.ad-slot-below-player{z-index:10;width:100%;max-width:300px;height:250px;margin:20px auto;position:relative}.ad-carousel{width:100%;height:100%;position:relative}.ad-carousel-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;display:block}.ad-carousel-button{color:#fff;cursor:pointer;z-index:10;background:#00000080;border:none;padding:10px 12px;font-size:24px;font-weight:300;line-height:1;transition:background .2s;position:absolute;top:50%;transform:translateY(-50%)}.ad-carousel-button:hover:not(:disabled){background:#000c}.ad-carousel-button:disabled{opacity:.3;cursor:not-allowed}.ad-carousel-button.prev{left:5px}.ad-carousel-button.next{right:5px}.ad-carousel-indicator{color:#fff;z-index:10;background:#000000b3;border-radius:3px;padding:5px 10px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.viewer-page-with-fixed-banners{padding-top:90px;padding-bottom:90px}@media (width<=768px){.ad-slot-sidebar-right{aspect-ratio:300/250;width:100%;height:auto;margin:20px 0;position:static}.ad-carousel-button{padding:8px 10px;font-size:20px}.ad-carousel-indicator{padding:4px 8px;font-size:11px}}.home-page{background-color:var(--gb-bg);min-height:100vh;font-family:var(--gb-font-body)}.home-container{max-width:1400px;padding:var(--space-8) var(--space-6);margin:0 auto}.home-header{margin-bottom:var(--space-6)}.home-header h1{font-family:var(--gb-font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--gb-text-muted);margin:0;font-size:1.125rem;font-weight:700}.ad-banner{background-color:var(--gb-surface);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius);width:100%;height:80px;margin-bottom:var(--space-6);color:var(--gb-text-muted);font-size:.75rem;font-family:var(--gb-font-body);letter-spacing:.04em;justify-content:center;align-items:center;display:flex}.matches-grid{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));display:grid}@media (width<=640px){.matches-grid{gap:var(--space-3);grid-template-columns:1fr}}.match-card{background:var(--gb-surface);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius);cursor:pointer;transition:border-color .18s,transform .18s;overflow:hidden}.match-card:hover{border-color:var(--gb-border);transform:translateY(-1px)}.match-header{padding:var(--space-5) var(--space-6) var(--space-4);gap:var(--space-1);flex-direction:column;display:flex}.match-league{font-family:var(--gb-font-body);letter-spacing:.1em;text-transform:uppercase;color:var(--gb-text-muted);order:-1;margin:0;font-size:.6875rem;font-weight:600}.match-title{font-family:var(--gb-font-display);color:var(--gb-text-primary);margin:0;font-size:1.125rem;font-weight:700;line-height:1.25}.match-time{font-family:var(--gb-font-body);color:var(--gb-text-secondary);margin:0;font-size:.8125rem}.match-body{padding:var(--space-3) var(--space-6) var(--space-5);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.match-status{font-family:var(--gb-font-display);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--gb-radius-sm);white-space:nowrap;align-items:center;gap:5px;padding:4px 10px;font-size:.6875rem;font-weight:700;display:inline-flex}.status-live{background:var(--gb-red-wash);color:var(--gb-red-text)}.status-live:before{content:"";background:var(--gb-red-text);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:1.4s ease-in-out infinite pulse-dot;display:inline-block}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.status-playing{color:oklch(78% .14 75);background:oklch(55% .18 75/.12)}.status-scheduled,.status-upcoming{color:oklch(72% .12 220);background:oklch(55% .15 220/.12)}.status-finished{color:var(--gb-text-muted);background:oklch(35% .01 265/.5)}.match-button{font-family:var(--gb-font-display);letter-spacing:.05em;background:var(--gb-red);color:oklch(98% .005 265);border-radius:var(--gb-radius-sm);cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;padding:8px 20px;font-size:.8125rem;font-weight:700;transition:background .15s}.match-button:hover{background:var(--gb-red-hover)}.bottom-banner{background-color:var(--gb-surface);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius);width:100%;height:80px;color:var(--gb-text-muted);font-size:.75rem;font-family:var(--gb-font-body);letter-spacing:.04em;justify-content:center;align-items:center;display:flex}.empty-state{text-align:center;padding:var(--space-16) var(--space-6);color:var(--gb-text-muted)}.empty-state p{font-family:var(--gb-font-body);margin:0;font-size:.9375rem}@media (width<=768px){.home-container{padding:var(--space-5) var(--space-4)}.match-header{padding:var(--space-4) var(--space-5) var(--space-3)}.match-body{padding:var(--space-3) var(--space-5) var(--space-4)}.match-title{font-size:1rem}}.player-page{background-color:var(--gb-bg);min-height:100vh;font-family:var(--gb-font-body)}.player-container{width:100%;max-width:1400px;padding:var(--space-6) var(--space-6) var(--space-8);margin:0 auto}.back-button{font-family:var(--gb-font-body);color:var(--gb-text-secondary);cursor:pointer;margin-bottom:var(--space-5);background:0 0;border:none;padding:6px 0;font-size:.8125rem;font-weight:500;transition:color .15s;display:inline-block}.back-button:hover{color:var(--gb-text-primary)}.player-ad-banner{background-color:var(--gb-surface);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius);width:100%;height:80px;margin-bottom:var(--space-5);color:var(--gb-text-muted);letter-spacing:.04em;justify-content:center;align-items:center;font-size:.75rem;display:flex}.player-layout{gap:var(--space-4);margin-bottom:var(--space-5);grid-template-columns:280px 1fr;align-items:start;display:grid}@media (width<=1024px){.player-layout{grid-template-columns:1fr}.match-sidebar{order:2;max-height:280px}.player-area{order:1}}.match-sidebar{background:var(--gb-surface);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius);scrollbar-width:thin;scrollbar-color:var(--gb-border) transparent;height:fit-content;max-height:560px;overflow:hidden auto}.match-sidebar::-webkit-scrollbar{width:4px}.match-sidebar::-webkit-scrollbar-thumb{background:var(--gb-border);border-radius:2px}.sidebar-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--gb-border-subtle);background:var(--gb-surface);z-index:1;position:sticky;top:0}.sidebar-header h3{font-family:var(--gb-font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--gb-text-muted);margin:0;font-size:.6875rem;font-weight:700}.match-list{margin:0;padding:0;list-style:none}.match-item{border-bottom:1px solid var(--gb-border-subtle);cursor:pointer;transition:background .14s}.match-item:last-child{border-bottom:none}.match-item:hover{background:var(--gb-surface-raised)}.match-item.active{background:var(--gb-red-wash);outline-offset:-1px;outline:1px solid oklch(52% .22 25/.35)}.match-item-content{padding:var(--space-4) var(--space-5)}.match-item-title{font-family:var(--gb-font-display);color:var(--gb-text-primary);margin:0 0 var(--space-2) 0;font-size:.8125rem;font-weight:600;line-height:1.3}.match-item.active .match-item-title{color:var(--gb-text-primary)}.match-item-status{font-family:var(--gb-font-display);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--gb-radius-sm);align-items:center;gap:5px;margin:0;padding:3px 8px;font-size:.625rem;font-weight:700;display:inline-flex}.status-live,.match-item-status.status-live{background:var(--gb-red-wash);color:var(--gb-red-text)}.status-live:before,.match-item-status.status-live:before{content:"";background:var(--gb-red-text);border-radius:50%;flex-shrink:0;width:5px;height:5px;animation:1.4s ease-in-out infinite pulse-dot;display:inline-block}.status-playing,.match-item-status.status-playing{color:oklch(78% .14 75);background:oklch(55% .18 75/.12)}.status-scheduled,.match-item-status.status-scheduled,.status-upcoming,.match-item-status.status-upcoming{color:oklch(72% .12 220);background:oklch(55% .15 220/.12)}.status-finished,.match-item-status.status-finished{color:var(--gb-text-muted);background:oklch(35% .01 265/.5)}.player-area{background:var(--gb-surface);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius);overflow:hidden}.player-video{aspect-ratio:16/9;width:100%;color:var(--gb-text-secondary);background-color:oklch(8% .01 265);justify-content:center;align-items:center;font-size:1rem;display:flex;position:relative;overflow:hidden}.player-video>*{width:100%;height:100%;position:absolute;inset:0}.player-video iframe{border:none;width:100%;height:100%}.player-info{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--gb-border-subtle);align-items:baseline;gap:var(--space-4);flex-wrap:wrap;display:flex}.player-title{font-family:var(--gb-font-display);color:var(--gb-text-primary);flex:1;min-width:0;margin:0;font-size:1.25rem;font-weight:700}.player-league{font-family:var(--gb-font-body);letter-spacing:.08em;text-transform:uppercase;color:var(--gb-text-muted);margin:0;font-size:.75rem;font-weight:600}.player-status{font-family:var(--gb-font-display);letter-spacing:.08em;text-transform:uppercase;border-radius:var(--gb-radius-sm);flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.6875rem;font-weight:700;display:inline-flex}.player-metadata{padding:var(--space-4) var(--space-6);background:oklch(17% .023 265)}.metadata-grid{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.metadata-item{text-align:center}.metadata-label{font-family:var(--gb-font-body);color:var(--gb-text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.6875rem;font-weight:600}.metadata-value{font-family:var(--gb-font-display);color:var(--gb-text-primary);margin:4px 0 0;font-size:1.5rem;font-weight:700;line-height:1}.player-bottom-banner{background-color:var(--gb-surface);border:1px solid var(--gb-border-subtle);border-radius:var(--gb-radius);height:160px;color:var(--gb-text-muted);letter-spacing:.04em;justify-content:center;align-items:center;font-size:.75rem;display:flex}@media (width<=768px){.player-container{padding:var(--space-4) var(--space-4) var(--space-6)}.player-layout{gap:var(--space-3)}.player-ad-banner{height:70px;margin-bottom:var(--space-4)}.player-title{font-size:1.0625rem}.metadata-grid{gap:var(--space-3);grid-template-columns:1fr}.metadata-value{font-size:1.25rem}.player-bottom-banner{height:100px}.player-info{gap:var(--space-2);flex-direction:column}}.admin-header{background:linear-gradient(135deg, var(--color-dark-700) 0%, var(--color-dark-800) 100%);color:var(--color-neutral-0);box-shadow:var(--shadow-md);padding:var(--spacing-4) var(--spacing-6)}.admin-header-container{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;display:flex}.admin-logo{align-items:center;gap:var(--spacing-2);color:var(--color-neutral-0);font-size:var(--text-xl);font-weight:var(--font-weight-700);text-decoration:none;display:flex}.admin-logo-icon{font-size:1.5rem}.admin-nav{gap:var(--spacing-6);align-items:center;display:flex}.admin-nav-link{color:var(--color-neutral-0);font-weight:var(--font-weight-500);font-size:var(--text-sm);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-sm);transition:background-color var(--transition-base);text-decoration:none}.admin-nav-link:hover,.admin-nav-link.active{background-color:#ffffff1a}.admin-user-menu{align-items:center;gap:var(--spacing-3);display:flex;position:relative}.admin-user-button{align-items:center;gap:var(--spacing-2);color:var(--color-neutral-0);font-weight:var(--font-weight-500);font-size:var(--text-sm);cursor:pointer;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-sm);transition:background-color var(--transition-base);background:0 0;border:none;display:flex}.admin-user-button:hover{background-color:#ffffff1a}.admin-avatar{border-radius:var(--radius-full);background-color:var(--color-secondary-500);width:32px;height:32px;font-weight:var(--font-weight-700);font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}.admin-dropdown{background:var(--color-neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;min-width:200px;position:absolute;top:50px;right:0}.admin-dropdown-item{width:100%;padding:var(--spacing-3) var(--spacing-4);text-align:left;color:var(--color-neutral-900);cursor:pointer;font-size:var(--text-sm);transition:background-color var(--transition-base);background:0 0;border:none;text-decoration:none;display:block}.admin-dropdown-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.admin-dropdown-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg)}.admin-dropdown-item:hover{background-color:var(--color-neutral-100)}.admin-dropdown-item.logout{color:var(--color-error-600);border-bottom:1px solid var(--color-neutral-200)}.admin-dropdown-item.logout:hover{background-color:var(--color-error-50)}@media (width<=768px){.admin-header{padding:var(--spacing-3) var(--spacing-4)}.admin-header-container{gap:var(--spacing-3)}.admin-logo{font-size:var(--text-lg)}.admin-logo-sub{font-size:var(--text-xs)}.admin-nav{gap:var(--spacing-3);flex-wrap:wrap}.admin-nav-link{padding:var(--spacing-2) var(--spacing-2);font-size:var(--text-xs)}.admin-user-button{padding:var(--spacing-2);font-size:var(--text-xs);gap:var(--spacing-1)}.admin-avatar{width:28px;height:28px;font-size:var(--text-xs)}.admin-dropdown{min-width:180px}}.ads-page{background-color:var(--color-neutral-100);min-height:100vh}.ads-container{max-width:1400px;padding:var(--spacing-8) var(--spacing-6);margin:0 auto}.ads-header{margin-bottom:var(--spacing-8)}.ads-header h1{font-size:var(--text-3xl);font-weight:var(--font-weight-700);color:var(--color-neutral-900);margin:0 0 var(--spacing-2) 0}.ads-header p{font-size:var(--text-base);color:var(--color-neutral-500);margin:0}.ads-upload-section{background:var(--color-neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-8);padding:var(--spacing-8)}.ads-upload-section h2{font-size:var(--text-xl);font-weight:var(--font-weight-600);color:var(--color-neutral-900);margin:0 0 var(--spacing-6) 0}.ad-upload-form{display:block}.form-message{padding:var(--spacing-4);border-radius:var(--radius-sm);margin-bottom:var(--spacing-6);font-weight:var(--font-weight-500);border:1px solid}.form-message-success{background-color:var(--color-success-50);color:var(--color-success-800);border-color:var(--color-success-100)}.form-message-error{background-color:var(--color-error-50);color:var(--color-error-800);border-color:var(--color-error-100)}.form-fields{display:block}.form-group-row{gap:var(--spacing-4);margin-bottom:var(--spacing-6);grid-template-columns:1fr 1fr;display:grid}.form-group-row>div{display:block}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--color-neutral-300);border-radius:var(--radius-sm);font-size:var(--text-sm);box-sizing:border-box;transition:border-color var(--transition-base), box-shadow var(--transition-base)}.form-hint{font-size:var(--text-xs);color:var(--color-neutral-500);margin-top:var(--spacing-1);margin-bottom:0}.label-hint{font-weight:var(--font-weight-400);color:var(--color-neutral-500)}.label-optional{font-weight:var(--font-weight-400);color:var(--color-neutral-400);font-style:italic}.form-error{font-size:var(--text-xs);color:var(--color-error-600);margin-top:var(--spacing-1);margin-bottom:0}.submit-button{background-color:var(--color-primary-500);width:100%;color:var(--color-neutral-0);padding:var(--spacing-3) var(--spacing-6);border-radius:var(--radius-sm);font-weight:var(--font-weight-600);cursor:pointer;transition:background-color var(--transition-base);font-size:var(--text-sm);border:none}.submit-button:hover:not(:disabled){background-color:var(--color-primary-600)}.submit-button:disabled{background-color:var(--color-neutral-300);cursor:not-allowed;opacity:.6}.ads-list-section{background:var(--color-neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.ads-list-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-neutral-200)}.ads-list-header h2{font-size:var(--text-xl);font-weight:var(--font-weight-600);color:var(--color-neutral-900);margin:0}.ads-table{border-collapse:collapse;width:100%}.ads-table th{background-color:var(--color-neutral-50);padding:var(--spacing-4);text-align:left;font-weight:var(--font-weight-600);color:var(--color-neutral-900);border-bottom:1px solid var(--color-neutral-200);font-size:var(--text-sm)}.ads-table td{padding:var(--spacing-4);border-bottom:1px solid var(--color-neutral-200);font-size:var(--text-sm);color:var(--color-neutral-700)}.placement-badge{padding:var(--spacing-1) var(--spacing-3);background-color:var(--color-primary-100);color:var(--color-primary-700);border-radius:var(--radius-xs);font-size:var(--text-xs);font-weight:var(--font-weight-600);display:inline-block}.url-cell{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.url-cell a{color:var(--color-primary-500);text-decoration:none}.url-cell a:hover{text-decoration:underline}.deactivate-button{padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-success-600);color:var(--color-neutral-0);border-radius:var(--radius-sm);cursor:pointer;font-weight:var(--font-weight-500);transition:background-color var(--transition-base);font-size:var(--text-sm);border:none}.deactivate-button:hover:not(:disabled){background-color:var(--color-success-700)}.deactivate-button:disabled{background-color:var(--color-success-100);cursor:not-allowed}.reactivate-button{padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-warning-600);color:var(--color-neutral-0);border-radius:var(--radius-sm);cursor:pointer;font-weight:var(--font-weight-500);transition:background-color var(--transition-base);font-size:var(--text-sm);border:none}.reactivate-button:hover:not(:disabled){background-color:var(--color-warning-700)}.reactivate-button:disabled{background-color:var(--color-warning-100);cursor:not-allowed}.delete-button{padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-error-600);color:var(--color-neutral-0);border-radius:var(--radius-sm);cursor:pointer;font-weight:var(--font-weight-500);transition:background-color var(--transition-base);font-size:var(--text-sm);border:none}.delete-button:hover:not(:disabled){background-color:var(--color-error-700)}.delete-button:disabled{background-color:var(--color-error-100);cursor:not-allowed}.ads-table-inactive{opacity:.7}.ads-table-inactive tbody tr{background-color:var(--color-neutral-50)}.ads-table-inactive tbody tr:hover{background-color:var(--color-neutral-100)}.ads-loading{padding:var(--spacing-12) var(--spacing-6);text-align:center}.spinner-small{border:4px solid var(--color-neutral-200);border-top-color:var(--color-primary-500);border-radius:var(--radius-full);width:40px;height:40px;margin:0 auto var(--spacing-4);animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.ads-loading p{color:var(--color-neutral-500);margin:0}.ads-empty{padding:var(--spacing-12) var(--spacing-6);text-align:center;color:var(--color-neutral-500)}.ads-empty p{margin:0}.ads-error{padding:var(--spacing-6);background-color:var(--color-error-50);border:1px solid var(--color-error-100);border-radius:var(--radius-sm);margin-bottom:var(--spacing-6)}.ads-error p{color:var(--color-error-700);margin:0 0 var(--spacing-4) 0}.ads-error button{padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-error-600);color:var(--color-neutral-0);border-radius:var(--radius-sm);cursor:pointer;font-weight:var(--font-weight-500);font-size:var(--text-sm);border:none}.ads-error button:hover{background-color:var(--color-error-700)}@media (width<=768px){.ads-container{padding:var(--spacing-4) var(--spacing-4)}.ads-header h1{font-size:var(--text-2xl)}.ads-upload-section,.ads-list-section{padding:var(--spacing-4)}.form-group-row{gap:var(--spacing-3);grid-template-columns:1fr}.ads-table{font-size:var(--text-xs)}.ads-table th,.ads-table td{padding:var(--spacing-3)}.url-cell{max-width:100px}}.date-range-picker{margin-bottom:2rem}.date-range-inputs{flex-wrap:wrap;gap:1rem;display:flex}.date-input-group{flex-direction:column;gap:.5rem;display:flex}.date-input-group label{color:#333;font-size:.875rem;font-weight:600}.date-input-group input{box-sizing:border-box;border:1px solid #ccc;border-radius:4px;width:200px;padding:.5rem .75rem;font-size:.875rem}.date-input-group input:focus{border-color:#4f46e5;outline:none;box-shadow:0 0 0 3px #4f46e51a}.apply-button{color:#fff;cursor:pointer;white-space:nowrap;background-color:#4f46e5;border:none;border-radius:4px;padding:.5rem 1.5rem;font-weight:600;transition:background-color .2s}.apply-button:hover{background-color:#4338ca}.apply-button:active{transform:scale(.98)}.date-error{color:#dc2626;margin-top:.5rem;font-size:.875rem}@media (width<=768px){.date-range-picker{margin-bottom:1.5rem}.date-range-inputs{flex-direction:column;gap:.75rem}.date-input-group input{width:100%;font-size:16px}.apply-button{width:100%;font-size:.875rem}}@media (width<=640px){.date-range-picker{margin-bottom:1rem}.date-input-group label{font-size:.75rem}.date-input-group input{padding:.5rem;font-size:14px}.apply-button{padding:.5rem 1rem;font-size:.75rem}}.metrics-cards-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem;display:grid}.metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;transition:box-shadow .2s,transform .2s;box-shadow:0 1px 3px #0000001a}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.metric-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.875rem;font-weight:600}.metric-value{color:#1f2937;margin-bottom:.5rem;font-size:2.25rem;font-weight:700}.metric-subtext{color:#9ca3af;font-size:.75rem}.metric-card.loading{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.skeleton-title{background-color:#e5e7eb;border-radius:4px;width:60%;height:12px;margin-bottom:12px}.skeleton-value{background-color:#e5e7eb;border-radius:4px;width:80%;height:36px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (width<=1200px){.metrics-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.metrics-cards-grid{grid-template-columns:1fr;gap:1rem}.metric-value{font-size:1.875rem}}.streams-table-container{margin-bottom:2rem}.streams-table-container h2{color:#1f2937;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.streams-table{border-collapse:collapse;width:100%;font-size:.875rem}.streams-table thead{background-color:#f3f4f6;border-bottom:2px solid #e5e7eb}.streams-table th{text-align:left;color:#374151;white-space:nowrap;padding:1rem;font-weight:600}.streams-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.streams-table th.sortable:hover{background-color:#e5e7eb}.streams-table th.sorted{color:#4f46e5;background-color:#eef2ff}.streams-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.streams-table tbody tr:hover{background-color:#f9fafb}.streams-table td{color:#1f2937;padding:1rem}.streams-table td.stream-id{color:#4f46e5;font-family:Courier New,monospace;font-weight:500}@media (width<=768px){.streams-table th,.streams-table td{padding:.75rem .5rem;font-size:.75rem}.table-wrapper{overflow-x:auto}}.ads-table-container{margin-bottom:2rem}.ads-table-container h2{color:#1f2937;margin-bottom:1rem;font-size:1.5rem;font-weight:700}.table-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow-x:auto;box-shadow:0 1px 3px #0000001a}.ads-table{border-collapse:collapse;width:100%;font-size:.875rem}.ads-table thead{background-color:#f3f4f6;border-bottom:2px solid #e5e7eb}.ads-table th{text-align:left;color:#374151;white-space:nowrap;padding:1rem;font-weight:600}.ads-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.ads-table th.sortable:hover{background-color:#e5e7eb}.ads-table th.sorted{color:#f59e0b;background-color:#fef3c7}.ads-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.ads-table tbody tr:hover{background-color:#f9fafb}.ads-table td{color:#1f2937;padding:1rem}.ads-table td.ad-id{color:#4f46e5;font-weight:600}.ads-table td.ad-title{text-overflow:ellipsis;white-space:nowrap;max-width:300px;overflow:hidden}.ads-table td.ctr-value{color:#10b981;font-weight:600}.loading-table thead{opacity:.6}.loading-row{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.skeleton-cell{background-color:#e5e7eb;border-radius:4px;width:70%;height:16px}.empty-state{text-align:center;color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:2rem;font-size:.875rem}@media (width<=768px){.ads-table th,.ads-table td{padding:.75rem .5rem;font-size:.75rem}.ads-table td.ad-title{max-width:150px}.table-wrapper{overflow-x:auto}}.analytics-dashboard{max-width:1400px;margin:0 auto;padding:2rem}.dashboard-header{margin-bottom:2rem}.dashboard-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.export-button{color:#fff;cursor:pointer;white-space:nowrap;background-color:#16a34a;border:none;border-radius:.375rem;align-self:center;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:background-color .15s}.export-button:hover:not(:disabled){background-color:#15803d}.export-button:disabled{cursor:not-allowed;background-color:#86efac}.dashboard-header h1{color:#1f2937;margin-bottom:.5rem;font-size:2.25rem;font-weight:700}.dashboard-subtitle{color:#6b7280;margin:0;font-size:1rem}.loading-spinner{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.loading-spinner p{color:#6b7280;margin:0;font-size:.875rem}.error-state{text-align:center;background-color:#fee2e2;border:1px solid #fecaca;border-radius:8px;margin-bottom:2rem;padding:1.5rem}.error-state p{color:#dc2626;margin:0 0 1rem;font-size:.875rem}.error-actions{justify-content:center;gap:1rem;display:flex}.retry-button{color:#fff;cursor:pointer;background-color:#dc2626;border:none;border-radius:4px;padding:.5rem 1.5rem;font-weight:600;transition:background-color .2s}.retry-button:hover{background-color:#b91c1c}.auto-refresh-info{text-align:center;color:#9ca3af;border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:2rem}.auto-refresh-info small{font-size:.75rem}@media (width<=768px){.analytics-dashboard{padding:1rem}.dashboard-header h1{font-size:1.875rem}.dashboard-header{margin-bottom:1.5rem}.loading-spinner{padding:2rem 1rem}.error-state{padding:1rem}}@media (width<=640px){.analytics-dashboard{padding:.5rem}.dashboard-header h1{font-size:1.5rem}.dashboard-subtitle{font-size:.875rem}}.admin-login-page{background:linear-gradient(135deg, var(--color-primary-50) 0%, var(--color-primary-100) 100%);min-height:100vh;padding:var(--spacing-4);justify-content:center;align-items:center;display:flex}.admin-login-card{background:var(--color-neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--spacing-8);width:100%;max-width:448px}.admin-login-header{text-align:center;margin-bottom:var(--spacing-8)}.admin-login-header h1{font-size:var(--text-4xl);font-weight:var(--font-weight-700);color:var(--color-primary-600);margin-bottom:var(--spacing-2)}.admin-login-header p{color:var(--color-neutral-500);font-size:var(--text-base);margin:0}.admin-login-error{margin-bottom:var(--spacing-6);padding:var(--spacing-4);background-color:var(--color-error-50);border:1px solid var(--color-error-100);border-radius:var(--radius-sm);color:var(--color-error-700);font-size:var(--text-sm)}.admin-login-form{gap:var(--spacing-4);flex-direction:column;display:flex}.admin-form-group{flex-direction:column;display:flex}.admin-form-group label{font-size:var(--text-sm);font-weight:var(--font-weight-500);color:var(--color-neutral-700);margin-bottom:var(--spacing-2);display:block}.admin-form-group input{width:100%;padding:var(--spacing-2) var(--spacing-4);border:1px solid var(--color-neutral-300);border-radius:var(--radius-sm);font-size:var(--text-sm);transition:border-color var(--transition-base), box-shadow var(--transition-base)}.admin-form-group input:focus{border-color:var(--color-primary-500);outline:none;box-shadow:0 0 0 3px #3b82f61a}.admin-form-group input::placeholder{color:var(--color-neutral-400)}.admin-login-button{width:100%;padding:var(--spacing-3) var(--spacing-4);background-color:var(--color-primary-600);color:var(--color-neutral-0);border-radius:var(--radius-sm);font-weight:var(--font-weight-600);font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-base);border:none}.admin-login-button:hover:not(:disabled){background-color:var(--color-primary-700)}.admin-login-button:disabled{background-color:var(--color-neutral-300);cursor:not-allowed;opacity:.6}@media (width<=768px){.admin-login-page{padding:var(--spacing-4)}.admin-login-card{padding:var(--spacing-6)}.admin-login-header h1{font-size:var(--text-3xl)}.admin-login-header{margin-bottom:var(--spacing-6)}}@media (width<=480px){.admin-login-card{padding:var(--spacing-4)}.admin-login-header h1{font-size:var(--text-2xl)}.admin-login-header{margin-bottom:var(--spacing-4)}}.admin-settings-page{background-color:var(--color-neutral-50);min-height:100vh}.admin-settings-container{max-width:1200px;padding:var(--spacing-8);margin:0 auto}.admin-settings-header{margin-bottom:var(--spacing-8)}.admin-settings-header h1{font-size:var(--text-3xl);font-weight:var(--font-weight-700);color:var(--color-neutral-900);margin:0 0 var(--spacing-2) 0}.admin-settings-header p{font-size:var(--text-base);color:var(--color-neutral-600);margin:0}.admin-settings-content{gap:var(--spacing-8);grid-template-columns:1fr 1fr;display:grid}.settings-form{grid-column:1}.settings-section{background:var(--color-neutral-0);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-6);margin-bottom:var(--spacing-6)}.settings-section-header{margin-bottom:var(--spacing-6)}.settings-section-header h2{font-size:var(--text-xl);font-weight:var(--font-weight-600);color:var(--color-neutral-900);margin:0 0 var(--spacing-2) 0}.settings-section-header p{font-size:var(--text-sm);color:var(--color-neutral-600);margin:0}.form-group:last-of-type{margin-bottom:0}.form-group label{font-size:var(--text-sm);font-weight:var(--font-weight-600);color:var(--color-neutral-700);margin-bottom:var(--spacing-2);display:block}.form-group input,.form-group select{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--color-neutral-300);border-radius:var(--radius-sm);font-size:var(--text-sm);transition:border-color var(--transition-base), box-shadow var(--transition-base);box-sizing:border-box}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary-500);outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-help{font-size:var(--text-xs);color:var(--color-neutral-600);margin-top:var(--spacing-2);margin-bottom:0}.form-error{background-color:var(--color-error-50);border:1px solid var(--color-error-200);border-radius:var(--radius-sm);padding:var(--spacing-4);color:var(--color-error-700);font-size:var(--text-sm);margin-bottom:var(--spacing-6)}.form-success{background-color:var(--color-success-50);border:1px solid var(--color-success-200);border-radius:var(--radius-sm);padding:var(--spacing-4);color:var(--color-success-700);font-size:var(--text-sm);margin-bottom:var(--spacing-6)}.form-actions{gap:var(--spacing-3);margin-top:var(--spacing-8);display:flex}.settings-button{padding:var(--spacing-3) var(--spacing-6);border-radius:var(--radius-sm);font-weight:var(--font-weight-600);font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-base);border:none}.settings-button.primary{background-color:var(--color-primary-600);color:var(--color-neutral-0)}.settings-button.primary:hover:not(:disabled){background-color:var(--color-primary-700)}.settings-button.secondary{background-color:var(--color-neutral-200);color:var(--color-neutral-900)}.settings-button.secondary:hover:not(:disabled){background-color:var(--color-neutral-300)}.settings-button:disabled{opacity:.6;cursor:not-allowed}.settings-documentation{background:var(--color-neutral-0);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);padding:var(--spacing-6);grid-column:2;height:fit-content}.settings-documentation h3{font-size:var(--text-lg);font-weight:var(--font-weight-600);color:var(--color-neutral-900);margin:0 0 var(--spacing-4) 0}.doc-content{font-size:var(--text-sm);color:var(--color-neutral-600);line-height:1.6}.doc-content h4{font-size:var(--text-sm);font-weight:var(--font-weight-600);color:var(--color-neutral-900);margin:var(--spacing-4) 0 var(--spacing-2) 0}.doc-content ol,.doc-content ul{padding-left:var(--spacing-6);margin:var(--spacing-3) 0}.doc-content li{margin-bottom:var(--spacing-2)}.doc-content p{margin:var(--spacing-3) 0 0 0}@media (width<=1024px){.admin-settings-content{grid-template-columns:1fr}.settings-documentation{grid-column:1}}@media (width<=768px){.admin-settings-container{padding:var(--spacing-4)}.admin-settings-header h1{font-size:var(--text-2xl)}.settings-section{padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.form-actions{flex-direction:column}.settings-button{width:100%}}@media (width<=640px){.admin-settings-container{padding:var(--spacing-3)}.admin-settings-header{margin-bottom:var(--spacing-6)}.admin-settings-header h1{font-size:var(--text-xl)}.settings-section{padding:var(--spacing-3)}.doc-content ol{padding-left:var(--spacing-4)}}:root{--color-primary-50:#e8eaf0;--color-primary-100:#c5cad8;--color-primary-200:#9aa3bc;--color-primary-500:#1b2235;--color-primary-600:#161c2b;--color-primary-700:#111622;--color-secondary-50:#e8eaf0;--color-secondary-100:#c5cad8;--color-secondary-500:#1b2235;--color-secondary-600:#161c2b;--color-dark-700:#1b2235;--color-dark-800:#111622;--color-success-50:#dcfce7;--color-success-100:#bbf7d0;--color-success-600:#16a34a;--color-success-700:#15803d;--color-success-800:#166534;--color-error-50:#fee2e2;--color-error-100:#fecaca;--color-error-600:#dc2626;--color-error-700:#b91c1c;--color-error-800:#991b1b;--color-warning-50:#fef3c7;--color-warning-600:#f59e0b;--color-neutral-0:#fff;--color-neutral-50:#f9fafb;--color-neutral-100:#f3f4f6;--color-neutral-200:#e5e7eb;--color-neutral-300:#d1d5db;--color-neutral-400:#9ca3af;--color-neutral-500:#6b7280;--color-neutral-600:#4b5563;--color-neutral-700:#374151;--color-neutral-800:#1f2937;--color-neutral-900:#111827;--color-black:#000;--gb-bg:oklch(16% .025 265);--gb-surface:oklch(20% .025 265);--gb-surface-raised:oklch(24% .022 265);--gb-border:oklch(30% .02 265);--gb-border-subtle:oklch(23% .02 265);--gb-text-primary:oklch(95% .005 265);--gb-text-secondary:oklch(62% .012 265);--gb-text-muted:oklch(44% .012 265);--gb-red:oklch(52% .22 25);--gb-red-hover:oklch(46% .22 25);--gb-red-wash:oklch(52% .22 25/.12);--gb-red-text:oklch(72% .18 25);--gb-font-display:"Chakra Petch", sans-serif;--gb-font-body:"Albert Sans", sans-serif;--gb-radius:3px;--gb-radius-sm:2px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--font-family-base:-apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono:"Courier New", Courier, monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--font-weight-400:400;--font-weight-500:500;--font-weight-600:600;--font-weight-700:700;--spacing-0:0;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--radius-xs:.25rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--transition-fast:.15s ease-in-out;--transition-base:.2s ease-in-out;--transition-slow:.3s ease-in-out}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family-base);font-size:var(--text-base);font-weight:var(--font-weight-400);color:var(--color-neutral-900);background-color:var(--color-neutral-100);line-height:1.5}a{color:var(--color-primary-500);transition:color var(--transition-base);text-decoration:none}a:hover{color:var(--color-primary-600)}button,input,select,textarea{font-family:inherit;font-size:inherit}.container{max-width:1400px;padding:var(--spacing-6) var(--spacing-6);margin:0 auto}@media (width<=768px){.container{padding:var(--spacing-4) var(--spacing-4)}}.page{background-color:var(--color-neutral-100);min-height:100vh}.card{background:var(--color-neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-elevated{background:var(--color-neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}h1{font-size:var(--text-2xl);font-weight:var(--font-weight-700)}h2{font-size:var(--text-xl);font-weight:var(--font-weight-600)}h3{font-size:var(--text-lg);font-weight:var(--font-weight-600)}.form-group{margin-bottom:var(--spacing-6)}.form-group label{margin-bottom:var(--spacing-2);font-weight:var(--font-weight-500);color:var(--color-neutral-700);font-size:var(--text-sm);display:block}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--color-neutral-300);border-radius:var(--radius-sm);font-size:var(--text-sm);transition:border-color var(--transition-base), box-shadow var(--transition-base)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary-500);outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--color-neutral-50);color:var(--color-neutral-500);cursor:not-allowed}.form-error{font-size:var(--text-xs);color:var(--color-error-600);margin-top:var(--spacing-1)}.form-hint{font-size:var(--text-xs);color:var(--color-neutral-500);margin-top:var(--spacing-1)}.input-error{border-color:var(--color-error-600)!important}.input-error:focus{border-color:var(--color-error-600)!important;box-shadow:0 0 0 3px #ef44441a!important}.button{padding:var(--spacing-2) var(--spacing-4);background-color:var(--color-primary-500);color:var(--color-neutral-0);border-radius:var(--radius-sm);font-weight:var(--font-weight-600);font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-base);border:none}.button:hover:not(:disabled){background-color:var(--color-primary-600)}.button:disabled{background-color:var(--color-neutral-300);cursor:not-allowed;opacity:.6}.button-danger{background-color:var(--color-error-600)}.button-danger:hover:not(:disabled){background-color:var(--color-error-700)}.button-success{background-color:var(--color-success-600)}.button-success:hover:not(:disabled){background-color:var(--color-success-700)}.message{padding:var(--spacing-4);border-radius:var(--radius-sm);margin-bottom:var(--spacing-4);border:1px solid}.message-success{background-color:var(--color-success-50);color:var(--color-success-800);border-color:var(--color-success-100)}.message-error{background-color:var(--color-error-50);color:var(--color-error-800);border-color:var(--color-error-100)}.message-warning{background-color:var(--color-warning-50);color:var(--color-neutral-900);border-color:var(--color-warning-600)}.spinner{border:4px solid var(--color-neutral-200);border-top-color:var(--color-primary-500);border-radius:var(--radius-full);width:40px;height:40px;animation:.8s linear infinite spin}.badge{padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-xs);font-size:var(--text-xs);font-weight:var(--font-weight-600);display:inline-block}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-700)}.badge-success{background-color:var(--color-success-50);color:var(--color-success-700)}.badge-error{background-color:var(--color-error-50);color:var(--color-error-700)}.badge-warning{background-color:var(--color-warning-50);color:var(--color-neutral-900)}.table{border-collapse:collapse;width:100%}.table th{background-color:var(--color-neutral-50);padding:var(--spacing-4);text-align:left;font-weight:var(--font-weight-600);color:var(--color-neutral-900);border-bottom:1px solid var(--color-neutral-200);font-size:var(--text-sm)}.table td{padding:var(--spacing-4);border-bottom:1px solid var(--color-neutral-200);font-size:var(--text-sm);color:var(--color-neutral-700)}.table tbody tr:hover{background-color:var(--color-neutral-50)}.empty-state{text-align:center;padding:var(--spacing-12) var(--spacing-6);background:var(--color-neutral-0);border-radius:var(--radius-lg);color:var(--color-neutral-500)}.empty-state p{font-size:var(--text-lg);margin:0}@media (width<=768px){:root{--spacing-6:1rem}h1{font-size:var(--text-xl)}h2{font-size:var(--text-lg)}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root,.app-container{width:100%;height:100%}
