: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}.announcement-banner{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;margin-bottom:1rem;background:#3498db14;border:1px solid var(--info);border-left:4px solid var(--info);border-radius:var(--radius)}.announcement-banner.type-maintenance{background:#3498db14;border-color:var(--info);border-left-color:var(--info)}.announcement-banner.type-other{background:#f39c1214;border-color:var(--warning);border-left-color:var(--warning)}.announcement-banner-icon{flex-shrink:0;font-size:1.4rem;line-height:1.2}.announcement-banner-body{flex:1;font-size:.9rem;line-height:1.6}.announcement-banner-title{font-weight:600;margin-bottom:.3rem;color:var(--text-primary);letter-spacing:.3px}.announcement-banner.type-maintenance .announcement-banner-title{color:var(--info)}.announcement-banner.type-other .announcement-banner-title{color:var(--warning)}.announcement-banner-message p{margin:0 0 .4rem}.announcement-banner-message p:last-child{margin-bottom:0}.announcement-banner-link{display:inline-block;margin-top:.4rem;font-size:.85rem}.announcement-banner-meta{margin-top:.4rem;font-size:.75rem;color:var(--text-muted)}.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)}.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}.admin-table-header.watchlist-header,.admin-table-row.watchlist-row{grid-template-columns:80px 130px 1fr 1.5fr 2fr 70px 120px 240px}.admin-table-row.watchlist-row{font-size:.85rem}.admin-table-header.be-alert-header,.admin-table-row.be-alert-row{grid-template-columns:160px 80px 1.3fr 1.3fr 100px 200px}.admin-table-header.be-ignore-header,.admin-table-row.be-ignore-row{grid-template-columns:180px 180px 1.5fr 160px 160px 110px}.admin-table-row.be-alert-row,.admin-table-row.be-ignore-row{font-size:.85rem}.severity-badge{display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-sm);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.severity-badge.info{background:#3498db2e;color:var(--info)}.severity-badge.caution{background:#ffaa002e;color:var(--warning)}.severity-badge.urgent{background:#e74c3c38;color:var(--danger)}.category-badge{display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-sm);font-size:.72rem;font-weight:600;background:#00d4ff1f;color:var(--accent)}.category-badge.under_investigation{background:#ffaa0026;color:var(--warning)}.category-badge.ban_alt_watch{background:#e74c3c2e;color:var(--danger)}.category-badge.suspected_exploiter{background:#e74c3c26;color:var(--danger)}.category-badge.vip{background:#00e67626;color:var(--success)}.category-badge.other{background:#ffffff14;color:var(--text-muted)}.online-now-pill{display:inline-block;margin-left:.4rem;color:var(--success);font-size:.8rem;animation:online-pulse 2s ease-in-out infinite}@keyframes online-pulse{0%,to{opacity:1}50%{opacity:.5}}.about-page{max-width:960px;line-height:1.55}.about-page h2{font-size:1.3rem;margin-bottom:.5rem}.about-page code{background:var(--bg-secondary);padding:.05rem .35rem;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.85em;color:var(--accent)}.about-quick-facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin:1.2rem 0 1.8rem}.about-fact{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:.7rem .9rem}.about-fact-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:.25rem}.about-fact-value{font-size:.95rem;color:var(--text-primary);font-weight:600}.about-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem;margin-bottom:2rem}.about-tab-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.2rem;transition:border-color .15s ease}.about-tab-card:hover{border-color:var(--accent-dim)}.about-tab-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.3rem}.about-tab-header h3{font-size:1.05rem;color:var(--accent);margin:0}.about-admin-pill{font-size:.7rem;padding:.1rem .5rem;border-radius:12px;background:#ffaa002e;color:var(--warning);text-transform:uppercase;letter-spacing:.4px;font-weight:600}.about-tab-tagline{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem;font-style:italic}.about-tab-card ul{margin:0;padding-left:1.1rem;font-size:.87rem}.about-tab-card li{margin-bottom:.3rem;color:var(--text-secondary)}.about-tab-card li strong{color:var(--text-primary)}.about-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.2rem;margin-bottom:1rem}.about-section h3{font-size:1rem;color:var(--accent);margin-bottom:.5rem}.about-section ul,.about-section ol{margin:0;padding-left:1.3rem;font-size:.9rem}.about-section li{margin-bottom:.35rem;color:var(--text-secondary)}.about-section li strong{color:var(--text-primary)}.about-footnote{background:none;text-align:center;color:var(--text-muted);font-size:.85rem;border-style:dashed}.about-footnote p{margin:0}.freshness-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.75rem}.freshness-card{background:var(--bg-primary);border:1px solid var(--border);border-left:3px solid var(--accent-dim);border-radius:var(--radius);padding:.7rem .9rem}.freshness-card h4{font-size:.85rem;margin:0;color:var(--text-primary);display:inline-flex;align-items:center;gap:.4rem;font-weight:600}.freshness-sub{font-size:.72rem;color:var(--text-muted);font-weight:400}.freshness-header{display:flex;align-items:center;gap:.45rem;margin-bottom:.45rem}.freshness-dot{width:.55rem;height:.55rem;border-radius:50%;background:var(--accent);box-shadow:0 0 6px currentColor;flex-shrink:0}.freshness-card ul{margin:0;padding-left:1.1rem;font-size:.82rem;line-height:1.4}.freshness-card li{margin-bottom:.2rem;color:var(--text-secondary)}.freshness-last-sync{font-size:.78rem;color:var(--text-secondary);background:#ff77e114;border:1px solid rgba(255,119,225,.25);padding:.3rem .5rem;border-radius:4px;margin-bottom:.45rem}.freshness-last-sync strong{color:var(--text-primary)}.freshness-sync-label,.freshness-next{color:var(--text-muted)}.players-header-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.qbox-sync-pill{font-size:.75rem;color:var(--text-secondary);background:#ff77e11a;border:1px solid rgba(255,119,225,.3);padding:.25rem .55rem;border-radius:999px;white-space:nowrap;cursor:help}.freshness-live{border-left-color:#0fa}.freshness-live .freshness-dot{background:#0fa;color:#0fa;animation:freshness-pulse 1.6s infinite}.freshness-5min{border-left-color:#00e5ff}.freshness-5min .freshness-dot{background:#00e5ff;color:#00e5ff}.freshness-15min{border-left-color:#7cd3ff}.freshness-15min .freshness-dot{background:#7cd3ff;color:#7cd3ff}.freshness-3hr{border-left-color:#ff77e1}.freshness-3hr .freshness-dot{background:#ff77e1;color:#ff77e1}.freshness-daily{border-left-color:#b48cff}.freshness-daily .freshness-dot{background:#b48cff;color:#b48cff}@keyframes freshness-pulse{0%,to{box-shadow:0 0 4px currentColor}50%{box-shadow:0 0 10px currentColor,0 0 16px currentColor}}.watchlist-help{margin:0 0 1.5rem;padding:.6rem .9rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius)}.watchlist-help>summary{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.9rem;font-weight:600;color:var(--accent);list-style:none;outline:none}.watchlist-help>summary::marker{content:""}.watchlist-help>summary:before{content:"▸ ";display:inline-block;transition:transform .15s ease;color:var(--accent)}.watchlist-help[open]>summary:before{transform:rotate(90deg)}.watchlist-help-body{margin-top:.8rem;font-size:.85rem;color:var(--text-secondary);line-height:1.55}.watchlist-help-body h4{color:var(--text-primary);font-size:.9rem;margin:.8rem 0 .3rem}.watchlist-help-body h4:first-of-type{margin-top:0}.watchlist-help-body ul{margin:0 0 .6rem;padding-left:1.2rem}.watchlist-help-body li{margin-bottom:.25rem}.watchlist-help-body strong{color:var(--text-primary)}.watchlist-help-body code,.watchlist-help-body .severity-badge{vertical-align:baseline}.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)}.players-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.server-switcher{display:flex;align-items:center;gap:.4rem;color:var(--text-muted);font-size:.9rem}.server-switcher select{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.3rem .6rem}.players-table,.sessions-table{width:100%;border-collapse:collapse;margin-top:.5rem}.players-table th,.players-table td,.sessions-table th,.sessions-table td{padding:.5rem .7rem;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}.players-table th,.sessions-table th{color:var(--text-muted);text-transform:uppercase;font-size:.7rem;letter-spacing:.5px;font-weight:600}.players-table .num,.sessions-table .num{text-align:right;font-variant-numeric:tabular-nums}.players-table .small,.sessions-table .small{font-size:.78rem;color:var(--text-secondary)}.players-table .mono,.sessions-table .mono{font-family:var(--font-mono)}.player-row{cursor:pointer;transition:background .1s}.player-row:hover{background:var(--bg-card-hover)}.flag{font-size:1.1rem;margin-right:.2rem}.muted{color:var(--text-muted);font-style:italic}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem;color:var(--text-muted);font-size:.85rem}.pagination button{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.3rem .8rem;cursor:pointer}.pagination button:disabled{opacity:.4;cursor:not-allowed}.drawer-backdrop{position:fixed;inset:0;background:#000000bf;display:flex;justify-content:flex-end;z-index:100;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.drawer{width:min(720px,100%);height:100%;background:var(--bg-primary);overflow-y:auto;padding:1.5rem;border-left:1px solid var(--border);box-shadow:-8px 0 32px #0009}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.drawer-close{background:transparent;color:var(--text-muted);border:none;font-size:1.6rem;cursor:pointer;padding:0 .4rem;line-height:1}.drawer-close:hover{color:var(--text-primary)}.drawer-section{margin-top:1.5rem}.kv-grid{display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1rem;font-size:.85rem;align-items:baseline}.kv-grid>span:nth-child(odd){color:var(--text-muted);text-transform:uppercase;font-size:.7rem;letter-spacing:.5px}.charts-controls{display:flex;gap:1.5rem;align-items:center}.chart-section{margin-bottom:2.5rem}.chart-section>h3{margin-bottom:.8rem;color:var(--text-primary)}.chart-section>h4{color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem}.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.chart-half{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}@media(max-width:900px){.chart-row{grid-template-columns:1fr}}.badge{display:inline-block;padding:0 .25rem;border-radius:var(--radius-sm);font-size:.7rem}.badge.danger{color:var(--danger)}.badge.muted{color:var(--text-muted)}
