﻿:root {color-scheme: dark;--bg:#0b1016;--panel:#111827;--panel-2:#0f1520;--text:#e5e7eb;--muted:#9ca3af;--accent:#3ba5b9;--accent-2:#f2994a;--border:#1f2733;font-family:"Inter","Segoe UI",system-ui,sans-serif;background:var(--bg);color:var(--text);}
body.theme-light {color-scheme: light;--bg:#f6f7fb;--panel:#ffffff;--panel-2:#f1f5f9;--text:#0f172a;--muted:#475569;--accent:#2563eb;--accent-2:#f97316;--border:#e2e8f0;}
*{box-sizing:border-box;} body{margin:0;min-height:100vh;display:flex;justify-content:center;padding:18px;background:var(--bg);} .shell{width:min(1280px,98vw);background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 25px 90px rgba(0,0,0,0.35);overflow:hidden;} header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(90deg,rgba(59,165,185,0.12),rgba(242,153,74,0.12));}
.landing-screen{width:min(1280px,98vw);min-height:calc(100vh - 36px);display:flex;align-items:center;justify-content:center;padding:28px;border:1px solid var(--border);border-radius:18px;background:radial-gradient(circle at top left,rgba(59,165,185,0.18),transparent 32%),radial-gradient(circle at bottom right,rgba(242,153,74,0.12),transparent 28%),linear-gradient(180deg,rgba(16,24,36,0.96),rgba(9,13,19,0.98));box-shadow:0 25px 90px rgba(0,0,0,0.35);}
.landing-shell{width:min(960px,100%);display:grid;grid-template-columns:minmax(0,1.1fr) minmax(300px,0.9fr);gap:18px;align-items:stretch;}
.landing-brand{font-size:11px;text-transform:uppercase;letter-spacing:.26em;color:var(--muted);margin-bottom:10px;}
.landing-title{font-size:clamp(34px,4.8vw,60px);line-height:0.96;margin:0 0 12px;font-weight:900;letter-spacing:-.04em;}
.landing-copy{font-size:14px;line-height:1.6;color:var(--muted);max-width:58ch;margin:0 0 18px;}
.login-panel,.stats-panel{border:1px solid var(--border);border-radius:18px;background:rgba(17,24,39,0.82);backdrop-filter:blur(12px);box-shadow:0 16px 48px rgba(0,0,0,0.18);}
.login-panel{padding:22px;}
.login-form{display:grid;gap:10px;margin-top:18px;}
.login-form input,.login-form button{width:100%;}
.login-form button{padding:12px 14px;font-size:14px;min-height:44px;}
.login-status{margin-top:12px;min-height:18px;font-size:12px;color:var(--muted);}
.stats-panel{padding:18px;}
.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.login-stat{padding:14px;border-radius:14px;border:1px solid rgba(255,255,255,0.05);background:rgba(255,255,255,0.035);}
.login-stat-value{font-size:28px;line-height:1;font-weight:900;letter-spacing:-.05em;color:var(--text);}
.login-stat-label{margin-top:8px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}
.stats-note{margin-top:14px;color:var(--muted);font-size:12px;line-height:1.5;}
@media (max-width: 960px){.landing-shell{grid-template-columns:1fr;}.stats-grid{grid-template-columns:1fr;}.landing-screen{padding:16px;}}
nav{display:flex;gap:8px;flex-wrap:wrap;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--panel-2);} nav a{padding:9px 12px;border-radius:8px;border:1px solid var(--border);color:var(--text);text-decoration:none;cursor:pointer;background:var(--panel);} nav a.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0b0e14;font-weight:700;box-shadow:0 12px 30px rgba(59,165,185,0.25);} .badge-dot{display:inline-block;min-width:18px;padding:2px 6px;margin-left:6px;border-radius:999px;background:var(--accent);color:#0b0e14;font-weight:700;font-size:11px;text-align:center;}
.content{padding:14px;} .grid{display:grid;gap:12px;} .grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));} .grid.cols-3{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));} .panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:12px;} h1,h2,h3{margin:0;} h2{margin-bottom:6px;} h3{color:#d1d5db;} .muted{color:var(--muted);font-size:13px;} input,textarea,select{width:100%;border:1px solid var(--border);background:#0f1520;color:var(--text);border-radius:8px;padding:8px 10px;} button.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;color:#0b0e14;border-radius:8px;padding:8px 11px;font-weight:700;cursor:pointer;} button.secondary{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:7px 10px;cursor:pointer;} table{width:100%;border-collapse:collapse;} th,td{padding:7px 9px;border-bottom:1px solid var(--border);font-size:13px;white-space:nowrap;} tr:hover td{background:rgba(255,255,255,0.02);} .pill{background:#1c2433;color:#e5e7eb;padding:3px 8px;border-radius:999px;font-weight:700;font-size:12px;border:1px solid var(--border);} .view{display:none;} .view.active{display:block;} pre{background:#0f1117;border:1px solid var(--border);border-radius:10px;padding:12px;font-size:12px;overflow:auto;min-height:480px;white-space:pre-wrap;word-break:break-word;} .scroll-box{max-height:340px;overflow:auto;border:1px solid var(--border);border-radius:8px;padding:6px;margin-top:6px;} .uptime-bar{height:10px;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-2));} .badge{padding:2px 6px;border-radius:6px;border:1px solid var(--border);background:#0f1117;}
.linkish{color:var(--accent-2);text-decoration:underline;cursor:pointer;font-weight:700;} .tabstrip button.ptab-active, .tabstrip button.mtab-active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0b0e14;font-weight:700;}
.mod-table{width:100%;border-collapse:collapse;}
.mod-table th{padding:8px 10px;border-bottom:2px solid var(--border);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);text-align:center;white-space:nowrap;background:rgba(0,0,0,0.18);}
.mod-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.04);font-size:13px;white-space:nowrap;text-align:center;vertical-align:middle;}
.mod-table tr:last-child td{border-bottom:none;}
.mod-table tr:hover td{background:rgba(255,255,255,0.03);}
.mod-table .col-offender,.mod-table .col-actor{text-align:left;min-width:110px;padding-right:12px;}
.mod-table .col-reason{text-align:left;min-width:180px;}
.mod-table .col-type{min-width:80px;}
.mod-table .col-dur{min-width:80px;}
.mod-table .col-status{min-width:95px;}
.mod-table .col-when{min-width:100px;}
.mod-table .col-action{min-width:70px;}
/* Row state coloring */
.row-pardoned td{background:rgba(34,197,94,0.055)!important;}
.row-pardoned:hover td{background:rgba(34,197,94,0.09)!important;}
/* Status badges */
.sbadge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;}
.sbadge-active{background:rgba(239,68,68,0.14);color:#f87171;border:1px solid rgba(239,68,68,0.28);}
.sbadge-mute{background:rgba(245,158,11,0.14);color:#fbbf24;border:1px solid rgba(245,158,11,0.28);}
.sbadge-warn{background:rgba(168,85,247,0.14);color:#c084fc;border:1px solid rgba(168,85,247,0.28);}
.sbadge-pardoned{background:rgba(34,197,94,0.14);color:#4ade80;border:1px solid rgba(34,197,94,0.28);}
.sbadge-expired{background:rgba(100,116,139,0.14);color:#94a3b8;border:1px solid rgba(100,116,139,0.28);}
.sbadge-neutral{background:rgba(255,255,255,0.07);color:var(--muted);border:1px solid var(--border);}
.sev-low{background:rgba(34,197,94,0.12);color:#4ade80;border:1px solid rgba(34,197,94,0.28);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;}
.sev-medium{background:rgba(251,191,36,0.12);color:#fbbf24;border:1px solid rgba(251,191,36,0.3);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;}
.sev-high{background:rgba(239,68,68,0.14);color:#f87171;border:1px solid rgba(239,68,68,0.3);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;}
.home-hero{position:relative;overflow:hidden;padding:22px;border-radius:22px;border:1px solid color-mix(in srgb, var(--border) 75%, transparent);background:linear-gradient(135deg, rgba(14,20,32,0.92), rgba(10,15,22,0.78));box-shadow:0 22px 70px rgba(0,0,0,0.28);}
.home-hero:before,.home-hero:after{content:"";position:absolute;inset:auto;pointer-events:none;border-radius:999px;filter:blur(8px);}
.home-hero:before{width:240px;height:240px;right:-70px;top:-70px;background:radial-gradient(circle, rgba(59,165,185,0.24), transparent 70%);}
.home-hero:after{width:220px;height:220px;left:-80px;bottom:-100px;background:radial-gradient(circle, rgba(242,153,74,0.20), transparent 72%);}
.hero-layout{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,0.9fr);gap:16px;align-items:stretch;}
.eyebrow{margin:0 0 8px;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent-2);}
.hero-title{font-size:clamp(32px,4vw,56px);line-height:0.95;margin:0;color:var(--text);}
.hero-copy .muted{max-width:62ch;font-size:14px;line-height:1.55;}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.status-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,0.04);color:var(--text);font-size:12px;font-weight:700;letter-spacing:.01em;}
.status-chip .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);}
.status-chip.ok .dot{background:#22c55e;}
.status-chip.warn .dot{background:#f59e0b;}
.status-chip.bad .dot{background:#ef4444;}
.home-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.home-actions button{min-height:40px;padding:10px 14px;}
.signal-panel{position:relative;z-index:1;display:grid;gap:12px;align-content:start;padding:18px;border-radius:18px;border:1px solid var(--border);background:rgba(7,11,16,0.72);}
.signal-dial{--dial:75%;width:min(240px,100%);aspect-ratio:1;border-radius:50%;margin:auto;display:grid;place-items:center;background:conic-gradient(var(--accent) 0 var(--dial), rgba(255,255,255,0.08) 0 100%);padding:12px;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.05);}
.signal-dial-inner{width:100%;height:100%;border-radius:50%;display:grid;place-items:center;text-align:center;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.08), rgba(0,0,0,0.16) 70%);}
.signal-value{font-size:44px;line-height:1;font-weight:800;letter-spacing:-0.04em;}
.signal-stack{display:grid;gap:8px;margin-top:2px;}
.signal-row{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.05);}
.signal-row strong{font-size:14px;}
.section-title{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin:18px 0 10px;}
.section-title h2,.section-title h3{margin:0;}
.section-title .muted{max-width:60ch;}
.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;}
.home-card{position:relative;overflow:hidden;padding:16px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));}
.home-card::after{content:"";position:absolute;inset:auto -20px -25px auto;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle, rgba(255,255,255,0.12), transparent 70%);pointer-events:none;}
.home-card h3{margin-bottom:10px;font-size:16px;}
.metric-row{display:flex;justify-content:space-between;gap:12px;align-items:baseline;padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.06);}
.metric-row:last-child{border-bottom:none;}
.metric-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.12em;}
.metric-value{font-size:16px;font-weight:800;}
.bar{height:10px;border-radius:999px;background:rgba(255,255,255,0.08);overflow:hidden;margin-top:8px;}
.bar > span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-2));}
.bullet-list{display:grid;gap:8px;margin:0;padding:0;list-style:none;}
.bullet-list li{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.05);}
.bullet-list li span:last-child{font-weight:700;color:var(--text);}
.home-notes{display:grid;gap:10px;}
.note-item{padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,0.05);background:rgba(255,255,255,0.035);}
.note-item.warning{border-color:rgba(245,158,11,0.32);background:rgba(245,158,11,0.08);}
.note-item.good{border-color:rgba(34,197,94,0.28);background:rgba(34,197,94,0.08);}
.shortcut-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;}
.shortcut{padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.035);text-decoration:none;color:var(--text);display:block;}
.shortcut:hover{transform:translateY(-1px);border-color:rgba(255,255,255,0.14);}
.shortcut .mini{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.shortcut .main{display:block;font-size:15px;font-weight:800;margin-bottom:6px;}
.shortcut .sub{display:block;font-size:12px;color:var(--muted);line-height:1.45;}
@media (max-width: 960px){.hero-layout{grid-template-columns:1fr;}.signal-dial{width:min(220px,100%);}}
/* â”€â”€ Global polish â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.flex{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px;letter-spacing:.04em;}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,165,185,0.15);}
button.primary:hover{filter:brightness(1.08);}
button.secondary:hover{border-color:var(--accent);color:var(--text);}
button:active{transform:scale(0.98);}
.tabstrip button{font-size:12px;padding:7px 12px;font-weight:600;}
.tabstrip button.ptab-active,.tabstrip button.mtab-active,.tabstrip button.ptab-active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0b0e14;font-weight:700;border-color:transparent;}
/* Section headings */
.section-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px;}
.section-head h3,.section-head h2{margin:0;}
/* Better scrollable boxes */
.scroll-box::-webkit-scrollbar{width:5px;height:5px;}
.scroll-box::-webkit-scrollbar-track{background:rgba(255,255,255,0.03);}
.scroll-box::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}
/* Table improvements */
thead tr{background:rgba(0,0,0,0.2);}
th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;}
td{vertical-align:middle;}
/* Monospace in certain contexts */
code{font-family:monospace;background:rgba(255,255,255,0.08);padding:1px 5px;border-radius:4px;font-size:12px;}
pre::-webkit-scrollbar{width:5px;height:5px;}
pre::-webkit-scrollbar-track{background:rgba(255,255,255,0.03);}
pre::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;}
/* Player detail metric rows */
.metric-row{border-bottom:1px solid rgba(255,255,255,0.05);}
tr.selected-row td{background:rgba(59,165,185,0.1)!important;border-color:rgba(59,165,185,0.2)!important;}

/* ── UI Polish ─────────────────────────────────────────────────────────── */
.panel { transition: box-shadow 0.18s ease; }
.home-card { transition: box-shadow 0.18s ease, transform 0.18s ease; }
.home-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.32); transform: translateY(-1px); }
.shortcut { transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease; }
.shortcut:hover { box-shadow: 0 4px 18px rgba(0,0,0,0.22); }
button.secondary { transition: border-color 0.15s, background 0.15s, color 0.15s; }
button.secondary:hover { background: rgba(255,255,255,0.06); }
nav a { transition: background 0.15s, color 0.15s, border-color 0.15s; }
input, select, textarea { transition: border-color 0.15s, box-shadow 0.15s; }
.mod-table tr { transition: background 0.1s; }
thead tr { position: sticky; top: 0; z-index: 1; }

/* ── Customize / drag-and-drop ─────────────────────────────────────────── */
.sort-handle {
  display: none;
  position: absolute;
  top: 10px; right: 12px;
  width: 28px; height: 28px;
  border-radius: 6px;
  background: rgba(255,255,255,0.07);
  border: 1px solid var(--border);
  align-items: center;
  justify-content: center;
  cursor: grab;
  color: var(--muted);
  font-size: 14px;
  z-index: 20;
  user-select: none;
  letter-spacing: -1px;
}
.sort-handle:hover { background: rgba(59,165,185,0.18); color: var(--accent); border-color: var(--accent); }
.customize-active [data-sort-id] { position: relative; }
.customize-active [data-sort-id] .sort-handle { display: flex; }
.customize-active [data-sort-id] {
  outline: 2px dashed rgba(59,165,185,0.28);
  outline-offset: 2px;
  transition: outline-color 0.2s;
}
.customize-active [data-sort-id]:hover { outline-color: rgba(59,165,185,0.7); }
.sort-ghost { opacity: 0.25 !important; }
.sort-chosen { cursor: grabbing !important; box-shadow: 0 8px 32px rgba(0,0,0,0.4) !important; z-index: 100; }
.sort-drag { background: var(--panel) !important; border: 2px solid var(--accent) !important; }
#customizeBtn { font-size: 12px; padding: 6px 12px; }
#customizeBtn.active { background: linear-gradient(135deg,var(--accent),var(--accent-2)); color: #0b0e14; font-weight: 700; border-color: transparent; }
.customize-banner {
  display: none;
  background: linear-gradient(90deg, rgba(59,165,185,0.14), rgba(242,153,74,0.10));
  border-bottom: 1px solid rgba(59,165,185,0.28);
  padding: 8px 16px;
  font-size: 12px;
  color: var(--accent);
  align-items: center;
  gap: 12px;
}
.customize-banner.visible { display: flex; }

/* Tab-mode drag hint in customize mode */
.customize-active [data-sort-mode="tabs"] > [data-sort-id] { cursor: grab; }
.customize-active [data-sort-mode="tabs"] > [data-sort-id]:hover { outline: 2px dashed rgba(59,165,185,0.6); outline-offset: 2px; }
.customize-active [data-sort-mode="tabs"] > [data-sort-id]:active { cursor: grabbing; }
/* Nav drag hint */
.customize-active nav[data-sort-group] > [data-sort-id] { cursor: grab; outline: 1px dashed rgba(59,165,185,0.35); outline-offset: 2px; border-radius: 8px; }
.customize-active nav[data-sort-group] > [data-sort-id]:hover { outline-color: var(--accent); }
