*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1f2937;background:#f0f2f5;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif}#root{min-height:100vh}.login-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:12px;width:400px;padding:48px 40px;box-shadow:0 20px 60px #00000026}.login-card h1{text-align:center;color:#667eea;margin-bottom:8px;font-size:28px}.subtitle{text-align:center;color:#9ca3af;margin-bottom:32px;font-size:14px}.form-group{margin-bottom:16px}.form-group label{color:#4b5563;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.btn-primary{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;width:100%;padding:12px;font-size:16px;font-weight:600;transition:background .2s}.btn-primary:hover{background:#5a6fd6}.btn-success{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s}.btn-success:hover{background:#059669}.btn-danger{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s}.btn-danger:hover{background:#dc2626}.btn-sm{color:#374151;cursor:pointer;background:#e5e7eb;border:none;border-radius:6px;padding:6px 14px;font-size:13px;transition:background .2s}.btn-sm:hover{background:#d1d5db}.btn-danger-text{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:6px;padding:4px 10px;font-size:13px}.btn-danger-text:hover{background:#fef2f2}.alert-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:10px 12px;font-size:13px}.alert-success{color:#059669;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:8px;margin-bottom:16px;padding:10px 12px;font-size:13px}.alert-toast{z-index:999;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;position:fixed;top:72px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0000001a}.topbar{z-index:100;background:#fff;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #00000014}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-left h1{color:#667eea;font-size:18px}.topbar-right{align-items:center;gap:12px;display:flex}.user-info{color:#6b7280;font-size:14px}.today-total{color:#10b981;background:#ecfdf5;border-radius:12px;padding:4px 10px;font-size:13px;font-weight:600}.btn-available-on{font-weight:600;color:#fff!important;background:#10b981!important}.btn-available-off{font-weight:600;color:#fff!important;background:#f59e0b!important}.backend-unavailable{color:#f59e0b;font-size:12px;font-weight:600}.stream-start-time{color:#6b7280;margin-bottom:4px;font-size:13px}.badge{border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600}.badge-frontend{color:#2563eb;background:#dbeafe}.badge-backend{color:#059669;background:#d1fae5}.badge-admin{color:#d97706;background:#fef3c7}.badge-success{color:#059669;background:#d1fae5}.badge-warning{color:#d97706;background:#fef3c7}.tab-bar{background:#fff;border-bottom:1px solid #e5e7eb;gap:0;padding:0 24px;display:flex}.tab-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 24px;font-size:14px;font-weight:600;transition:all .2s}.tab-btn:hover{color:#374151}.tab-btn.active{color:#667eea;border-bottom-color:#667eea}.dashboard-body{grid-template-columns:1fr 360px;gap:24px;max-width:1400px;margin:0 auto;padding:24px;display:grid}.dashboard-body.admin-body{grid-template-columns:1fr;max-width:1200px}@media (width<=1024px){.dashboard-body{grid-template-columns:1fr}}.panel{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f}.panel h2{color:#1f2937;margin-bottom:16px;font-size:16px;font-weight:600}.panel-large{grid-column:1}.panel-right{grid-column:2}@media (width<=1024px){.panel-right{grid-column:1}}.section{margin-bottom:20px}hr{border:none;border-top:1px solid #e5e7eb;margin:20px 0}.chart-wrap{margin-bottom:16px;padding:8px 0}.backend-list{flex-wrap:wrap;gap:10px;display:flex}.backend-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:8px;padding:8px 14px;font-size:14px;display:flex}.backend-item.online{background:#f0fdf4;border-color:#a7f3d0}.backend-item.offline{background:#fef2f2;border-color:#fecaca}.backend-name{font-weight:600}.backend-count{color:#667eea;font-weight:700}.status-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px;display:inline-block}.dot-online{background:#10b981;box-shadow:0 0 6px #10b98166}.dot-offline{background:#ef4444;box-shadow:0 0 6px #ef44444d}.stream-live{text-align:center}.stream-number-display{justify-content:center;align-items:center;gap:8px;margin-bottom:8px;font-size:18px;font-weight:700;display:flex}.live-dot{background:#ef4444;border-radius:50%;width:12px;height:12px;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.timer{font-variant-numeric:tabular-nums;color:#1f2937;margin:12px 0;font-size:36px;font-weight:700}.stream-offline{gap:10px;display:flex}.stream-offline input{border:1px solid #d1d5db;border-radius:8px;outline:none;flex:1;padding:10px 12px;font-size:14px}.stream-offline input:focus{border-color:#667eea}.frontend-stream-list{flex-direction:column;gap:10px;display:flex}.stream-card{border:1px solid #e5e7eb;border-radius:10px;padding:14px}.stream-card.live{background:#fef3c7;border-color:#fcd34d}.stream-card.offline{background:#f9fafb}.stream-card-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.stream-frontend-name{font-size:15px;font-weight:600}.stream-card-body{color:#6b7280;align-items:center;gap:12px;font-size:13px;display:flex}.live-tag{color:#fff;background:#ef4444;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:600}.offline-tag{color:#9ca3af}.pending-list{flex-direction:column;gap:10px;display:flex}.pending-card{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;justify-content:space-between;align-items:center;padding:12px;display:flex}.pending-info{flex-direction:column;gap:2px;display:flex}.pending-from{color:#6b7280;font-size:13px}.pending-count{color:#d97706;font-size:20px;font-weight:700}.pending-time{color:#9ca3af;font-size:12px}.empty-tip{text-align:center;color:#9ca3af;padding:32px 0;font-size:14px}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;color:#6b7280;text-transform:uppercase;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid #f3f4f6;padding:10px 12px}.data-table tr:hover td{background:#f9fafb}.stats-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.stats-grid .panel:first-child{grid-column:1/-1}@media (width<=768px){.stats-grid{grid-template-columns:1fr}.stats-grid .panel:first-child{grid-column:1}}.stat-cards{gap:16px;display:flex}.stat-card{text-align:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;flex:1;padding:16px}.stat-value{color:#667eea;font-size:32px;font-weight:700}.stat-label{color:#6b7280;margin-top:4px;font-size:13px}.pagination{color:#6b7280;justify-content:center;align-items:center;gap:12px;margin-top:16px;font-size:13px;display:flex}.pagination .btn-sm:disabled{opacity:.4;cursor:not-allowed}.stream-card.scheduled{background:#eff6ff;border-color:#93c5fd}.scheduled-tag{color:#fff;background:#3b82f6;border-radius:4px;padding:2px 8px;font-size:12px;font-weight:600}.scheduled-dot{background:#3b82f6;border-radius:50%;width:12px;height:12px;animation:2s infinite pulse}.dot-scheduled{background:#3b82f6;box-shadow:0 0 6px #3b82f666}.stream-countdown{color:#3b82f6;font-size:12px;font-weight:600}.stream-duration{color:#6b7280;font-size:12px}.stream-form .form-group{margin-bottom:12px}.stream-form .btn-success{width:100%;margin-top:4px}.stream-detail-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (width<=768px){.stream-detail-grid{grid-template-columns:1fr}}.stream-detail-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:14px;padding:14px}.stream-detail-header{color:#6b7280;flex-wrap:wrap;align-items:center;gap:12px;font-size:13px;display:flex}.stream-detail-header strong{color:#1f2937;font-size:15px}.stream-detail-total{color:#667eea;margin-left:auto;font-weight:700}
