:root{--bg-primary: #0a0a1a;--bg-secondary: #12122a;--bg-card: #1a1a2e;--bg-card-hover: #222244;--border: #2a2a4a;--text-primary: #e0e0e0;--text-secondary: #999;--text-muted: #666;--accent: #00d4ff;--accent-dim: rgba(0, 212, 255, .15);--success: #2ecc71;--danger: #e74c3c;--warning: #f39c12;--info: #3498db;--font-sans: "Inter", -apple-system, sans-serif;--font-mono: "JetBrains Mono", monospace;--radius: 8px;--radius-sm: 4px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:inherit}input{font-family:inherit;font-size:inherit}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-loading{display:flex;justify-content:center;padding:3rem}.page-error{padding:2rem;text-align:center;color:var(--danger)}.no-data{padding:2rem;text-align:center;color:var(--text-muted)}.login-page{display:flex;align-items:center;justify-content:center;height:100vh}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:3rem;text-align:center;max-width:400px}.login-card h1{font-size:1.8rem;margin-bottom:.5rem;color:var(--accent)}.login-card p{color:var(--text-secondary);margin-bottom:1.5rem}.login-error{background:#ff44441a;border:1px solid var(--danger);border-radius:var(--radius-sm);padding:.75rem;margin-bottom:1rem;color:var(--danger);font-size:.9rem}.discord-btn{background:#5865f2;color:#fff;border:none;border-radius:var(--radius);padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:background .2s}.discord-btn:hover{background:#4752c4}.discord-btn:disabled{opacity:.6;cursor:not-allowed}.app-layout{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.header-left{display:flex;align-items:center;gap:1.5rem}.app-title{font-size:1.1rem;font-weight:700;color:var(--accent)}.tab-nav{display:flex;gap:.25rem}.tab-btn{background:none;border:none;color:var(--text-secondary);padding:.5rem .75rem;border-radius:var(--radius-sm);font-weight:500;transition:all .15s}.tab-btn:hover{background:var(--bg-card);color:var(--text-primary)}.tab-btn.active{background:var(--accent-dim);color:var(--accent)}.header-right{display:flex;align-items:center}.user-info{display:flex;align-items:center;gap:.5rem}.user-avatar{width:28px;height:28px;border-radius:50%}.user-name{color:var(--text-secondary);font-size:.9rem}.logout-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;margin-left:.5rem}.logout-btn:hover{border-color:var(--danger);color:var(--danger)}.app-main{flex:1;overflow-y:auto;padding:1.5rem}.dashboard-section{margin-bottom:2rem}.dashboard-section h2{font-size:1.1rem;margin-bottom:1rem;color:var(--text-secondary)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;font-family:var(--font-mono)}.stat-sub{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.stat-bar{height:4px;background:var(--border);border-radius:2px;margin-top:.5rem;overflow:hidden}.stat-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:.5rem}.status-dot.online{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.offline{background:var(--danger);box-shadow:0 0 6px var(--danger)}.status-indicator{display:inline-block;width:12px;height:12px;margin-right:.5rem;flex-shrink:0;vertical-align:middle}.status-indicator.ok{background:var(--success);border-radius:50%;box-shadow:0 0 6px var(--success)}.status-indicator.alert{background:var(--danger);border-radius:2px;box-shadow:0 0 8px var(--danger);animation:pulse-alert 1.5s ease-in-out infinite}.status-indicator.unknown{background:var(--text-muted);border-radius:50%;opacity:.5}@keyframes pulse-alert{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.alert-banner{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;margin-bottom:1.5rem;background:#e74c3c1f;border:2px solid var(--danger);border-radius:var(--radius);animation:banner-flash 3s ease-in-out infinite}@keyframes banner-flash{0%,to{border-color:var(--danger)}50%{border-color:#e74c3c66}}.alert-banner-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--danger);color:#fff;border-radius:4px;font-weight:900;font-size:1.1rem;flex-shrink:0}.alert-banner-text{font-size:.9rem;line-height:1.6}.alert-banner-text strong{color:var(--danger);letter-spacing:.5px}.account-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.account-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.account-card.status-alert{border-color:var(--danger)}.account-label{font-weight:600}.account-username{color:var(--text-muted);font-family:var(--font-mono);font-size:.85rem}.account-status{margin-top:.5rem}.account-reason{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.service-overall{margin-bottom:1rem;font-weight:500;display:flex;align-items:center}.service-overall.has-outage{color:var(--danger);font-weight:700;font-size:1rem}.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.5rem}.service-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-card);border:1px solid transparent;border-radius:var(--radius-sm);font-size:.9rem}.service-item.outage{background:#e74c3c14;border-color:var(--danger);font-weight:600}.charts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.charts-header h2{font-size:1.1rem}.range-selector{display:flex;gap:.25rem}.range-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);padding:.4rem 1rem;border-radius:var(--radius-sm);font-weight:500}.range-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.chart-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.incidents-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.incidents-header h2{font-size:1.1rem}.filter-tabs{display:flex;gap:.25rem}.filter-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:.85rem}.filter-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.incident-list{display:flex;flex-direction:column;gap:.5rem}.incident-card{display:flex;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.incident-card.compact{padding:.5rem 1rem;gap:.75rem}.incident-icon{font-size:1.2rem}.incident-body{flex:1}.incident-type{font-weight:600;text-transform:capitalize;font-size:.9rem}.incident-details{color:var(--text-secondary);font-size:.85rem}.incident-time{color:var(--text-muted);font-size:.8rem;font-family:var(--font-mono)}.incident-source{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.pagination button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);padding:.4rem 1rem;border-radius:var(--radius-sm)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.recap-header{margin-bottom:1rem}.recap-header h2{font-size:1.1rem;margin-bottom:.5rem}.date-nav{display:flex;align-items:center;gap:1rem}.date-nav button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:1rem}.date-display{font-weight:600}.recap-window{color:var(--text-muted);font-size:.85rem;margin-top:.25rem}.recap-incidents{margin-top:1.5rem}.recap-incidents h3{font-size:1rem;margin-bottom:.75rem;color:var(--text-secondary)}.preferences-page{max-width:600px}.preferences-page h2{font-size:1.1rem;margin-bottom:.5rem}.prefs-description{color:var(--text-secondary);margin-bottom:1.5rem}.prefs-email{margin-bottom:1.5rem}.prefs-email label{display:block;font-weight:500;margin-bottom:.5rem}.prefs-email input{width:100%;padding:.6rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary)}.prefs-email input:focus{outline:none;border-color:var(--accent)}.prefs-grid{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.prefs-header-row,.prefs-row{display:grid;grid-template-columns:1fr 80px 80px;gap:1rem;padding:.75rem 1rem;align-items:center}.prefs-header-row{background:var(--bg-secondary);font-weight:600;font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.prefs-row{border-top:1px solid var(--border)}.prefs-row:hover{background:var(--bg-card-hover)}.prefs-toggle{text-align:center}.toggle-btn{padding:.25rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:.8rem;font-weight:600;min-width:50px}.toggle-btn.on{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.toggle-btn.off{background:none;color:var(--text-muted)}.prefs-actions{margin-top:1.5rem;display:flex;align-items:center;gap:1rem}.save-btn{background:var(--accent);color:var(--bg-primary);border:none;padding:.6rem 1.5rem;border-radius:var(--radius);font-weight:600}.save-btn:hover{filter:brightness(1.1)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.save-success{color:var(--success);font-weight:500}.admin-page{max-width:900px}.admin-section{margin-bottom:2rem}.admin-section h2{font-size:1.1rem;margin-bottom:.5rem}.admin-description{color:var(--text-secondary);margin-bottom:1.5rem}.admin-add-form{margin-bottom:1.5rem}.admin-form-row{display:flex;gap:.5rem;flex-wrap:wrap}.admin-form-row select,.admin-form-row input{padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary)}.admin-form-row select{min-width:100px}.admin-form-row input{flex:1;min-width:140px}.admin-form-row select:focus,.admin-form-row input:focus{outline:none;border-color:var(--accent)}.admin-add-btn{background:var(--accent);color:var(--bg-primary);border:none;padding:.5rem 1.25rem;border-radius:var(--radius-sm);font-weight:600;white-space:nowrap}.admin-add-btn:hover{filter:brightness(1.1)}.admin-add-btn:disabled{opacity:.6;cursor:not-allowed}.admin-form-error{margin-top:.5rem;color:var(--danger);font-size:.85rem}.admin-rules-table{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.admin-table-header,.admin-table-row{display:grid;grid-template-columns:70px 1fr 1fr 80px 100px 80px;gap:.75rem;padding:.75rem 1rem;align-items:center}.admin-table-header{background:var(--bg-secondary);font-weight:600;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.admin-table-row{border-top:1px solid var(--border);font-size:.9rem}.admin-table-row:hover{background:var(--bg-card-hover)}.admin-table-row code{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.rule-type-badge{display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.rule-type-badge.role{background:#3498db26;color:var(--info)}.rule-type-badge.user{background:#00d4ff26;color:var(--accent)}.role-badge{display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.role-badge.admin{background:#ffaa0026;color:var(--warning)}.role-badge.viewer{background:#00e67626;color:var(--success)}.delete-rule-btn{background:none;border:1px solid var(--border);color:var(--text-muted);padding:.2rem .6rem;border-radius:var(--radius-sm);font-size:.8rem}.delete-rule-btn:hover{border-color:var(--danger);color:var(--danger)}.delete-rule-btn.confirm{background:var(--danger);border-color:var(--danger);color:#fff}.delete-rule-btn:disabled{opacity:.5;cursor:not-allowed}.admin-empty{padding:2rem;text-align:center;color:var(--text-muted)}.admin-table-header.cfx-header,.admin-table-row.cfx-row{grid-template-columns:1fr 1fr 100px 180px 80px}.cfx-col-username code{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.cfx-col-status{display:flex;align-items:center;gap:.25rem;text-transform:capitalize}.cfx-col-checked{color:var(--text-muted);font-size:.8rem}.backups-page h2{font-size:1.1rem;margin-bottom:.5rem}.backups-description{color:var(--text-secondary);margin-bottom:1.5rem}.backups-description code{font-family:var(--font-mono);font-size:.85rem;color:var(--accent)}.backups-scan-time{color:var(--text-muted);font-size:.85rem}.backup-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.backup-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.backup-card.healthy{border-left:3px solid var(--success)}.backup-card.warning{border-left:3px solid var(--warning)}.backup-card.critical{border-left:3px solid var(--danger)}.backup-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.backup-card-header h3{font-size:1rem}.backup-status-dot{display:inline-block;width:10px;height:10px;border-radius:50%}.backup-status-dot.healthy{background:var(--success);border-radius:50%;box-shadow:0 0 6px var(--success)}.backup-status-dot.warning{background:var(--warning);border-radius:3px;box-shadow:0 0 6px var(--warning)}.backup-status-dot.critical{background:var(--danger);border-radius:2px;box-shadow:0 0 6px var(--danger);animation:pulse-alert 1.5s ease-in-out infinite}.backup-stats{display:flex;gap:1.5rem;margin-bottom:1rem}.backup-stat-label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.backup-stat-value{font-size:1.25rem;font-weight:700;font-family:var(--font-mono)}.backup-detail{padding:.5rem 0;border-top:1px solid var(--border)}.backup-detail-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.backup-detail-value{display:block;font-weight:500;font-size:.9rem}.backup-detail-filename{display:block;font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);word-break:break-all}.backup-latest-download{display:inline-block;margin-top:.4rem;font-size:.8rem;color:var(--accent);text-decoration:none;border:1px solid var(--border);padding:.2rem .6rem;border-radius:var(--radius-sm)}.backup-latest-download:hover{border-color:var(--accent);text-decoration:none}.backup-missed{margin-top:.75rem;padding:.75rem;background:#ff444414;border:1px solid rgba(255,68,68,.2);border-radius:var(--radius-sm)}.missed-count{display:block;font-weight:600;color:var(--danger);font-size:.9rem;margin-bottom:.5rem}.missed-slot{font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary);padding:.1rem 0}.backup-download-section{margin-top:1rem}.backup-files-btn{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:.85rem;width:100%}.backup-files-btn:hover{border-color:var(--accent);color:var(--accent)}.backup-file-list{margin-top:.75rem;border:1px solid var(--border);border-radius:var(--radius-sm);max-height:200px;overflow-y:auto}.backup-file-row{display:flex;align-items:center;gap:.75rem;padding:.4rem .75rem;border-top:1px solid var(--border);font-size:.8rem}.backup-file-row:first-child{border-top:none}.backup-file-row:hover{background:var(--bg-card-hover)}.backup-file-name{flex:1;font-family:var(--font-mono);font-size:.75rem;color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.backup-file-size{color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap}.backup-file-date{color:var(--text-muted);white-space:nowrap}.backup-files-loading{padding:1rem;text-align:center}.backup-files-error{padding:.75rem;color:var(--danger);font-size:.85rem}.backup-files-empty{padding:.75rem;color:var(--text-muted);font-size:.85rem;text-align:center}.logs-page h2{font-size:1.1rem;margin-bottom:.75rem}.logs-sub-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;flex-wrap:wrap}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.log-overview{margin-bottom:1.5rem}.log-error-table{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.log-error-header,.log-error-row{display:grid;grid-template-columns:140px 1fr 70px 160px;gap:.75rem;padding:.75rem 1rem;align-items:center}.log-error-header{background:var(--bg-secondary);font-weight:600;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.log-error-row{border-top:1px solid var(--border);cursor:pointer;font-size:.85rem}.log-error-row:hover{background:var(--bg-card-hover)}.log-error-row.expanded{background:var(--bg-card)}.log-error-row code{font-family:var(--font-mono);font-size:.8rem;color:var(--accent)}.err-col-message{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.err-col-count{text-align:center;font-family:var(--font-mono)}.err-col-last{color:var(--text-muted);font-size:.8rem}.log-error-stack{padding:.75rem 1rem;background:var(--bg-primary);border-top:1px solid var(--border)}.log-error-sig{color:var(--accent);font-family:var(--font-mono);font-size:.8rem;margin-bottom:.5rem}.log-error-stack pre{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;margin:0}.log-players .charts-header{margin-top:0}.disconnect-reasons{margin-top:1.5rem}.disconnect-reasons h3{font-size:1rem;margin-bottom:.75rem;color:var(--text-secondary)}.reason-list{display:flex;flex-direction:column;gap:.25rem}.reason-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem .75rem;background:var(--bg-card);border-radius:var(--radius-sm)}.reason-badge{font-size:.8rem;font-weight:600;padding:.15rem .5rem;border-radius:var(--radius-sm);text-transform:capitalize}.reason-badge.clean{background:#00e67626;color:var(--success)}.reason-badge.timeout{background:#ffaa0026;color:var(--warning)}.reason-badge.crash{background:#ff444426;color:var(--danger)}.reason-badge.multichar{background:#00d4ff26;color:var(--accent)}.reason-badge.other{background:#66666626;color:var(--text-muted)}.reason-count{font-family:var(--font-mono);font-weight:600}.event-detail-text{color:var(--text-muted);font-size:.85rem}.log-filters{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.log-filters select,.log-filters input{padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem}.log-filters select{min-width:120px}.log-filters input[type=text]{flex:1;min-width:140px}.log-filters input[type=date]{min-width:130px}.log-filters select:focus,.log-filters input:focus{outline:none;border-color:var(--accent)}.log-event-table{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.log-event-header,.log-event-row{display:grid;grid-template-columns:160px 80px 100px 120px 1fr;gap:.75rem;padding:.6rem 1rem;align-items:center;font-size:.85rem}.log-event-header{background:var(--bg-secondary);font-weight:600;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.log-event-row{border-top:1px solid var(--border)}.log-event-row:hover{background:var(--bg-card-hover)}.evt-col-time{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.evt-col-details{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.source-badge{display:inline-block;padding:.1rem .4rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase}.source-badge.admin{background:#ffaa0026;color:var(--warning)}.source-badge.server{background:#00e67626;color:var(--success)}.source-badge.fxserver{background:#3498db26;color:var(--info)}
