:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0b0e14;--surface-low:#151922;--surface:#1d222d;--surface-high:#2a303d;--text:#ecf1f5;--muted:#9eabb6;--outline:#3a4652;--cyan:#66d7ff;--green:#51e082;--amber:#f2c66d;--red:#ff8d86;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,sans-serif}*{box-sizing:border-box}html{scrollbar-gutter:stable}body{background:linear-gradient(135deg, #66d7ff14, transparent 38%), radial-gradient(circle at 82% 10%, #51e0820f, transparent 28%), var(--bg);min-width:320px;min-height:100vh;margin:0;overflow-y:scroll}button,input,select{font:inherit}button{cursor:pointer}.portal-shell{width:min(1440px,100%);margin:0 auto;padding:28px}.topbar,.metrics-grid,.workspace{gap:16px;display:grid}.topbar{grid-template-columns:1fr auto;align-items:center;margin-bottom:22px}.topbar-brand{min-width:0}.topbar-account{justify-content:flex-end;align-items:center;gap:18px;min-width:0;display:flex}.account-copy{text-align:right;gap:3px;display:grid}.account-copy strong{font-size:14px}.account-copy span{color:var(--muted);font-size:12px}.brand-line{letter-spacing:0;align-items:center;gap:12px;display:flex}.brand-line.large{justify-content:center;margin-bottom:16px}.brand-logo{object-fit:contain;flex:none;width:72px;height:32px}.brand-logo.large{width:96px;height:42px}.brand-sub{color:var(--text);font-size:18px;font-weight:700}.muted,.panel-heading span,.ip-row small,.rule-row small{color:var(--muted)}.topbar-actions{gap:10px;display:flex}.metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:16px}.metric,.ip-list,.rules-panel,.login-card,.rule-modal,.notice{background:#1d222dc7;border:1px solid #8094a42e;box-shadow:0 24px 80px #00000038}.metric{border-radius:8px;padding:18px}.metric span{color:var(--muted);text-transform:uppercase;letter-spacing:.14em;font-size:12px;display:block}.metric strong{margin-top:8px;font-size:28px;display:block}.metric small{color:var(--muted);margin-top:6px;font-size:12px;display:block}.metric.good strong{color:var(--green)}.metric.warn strong,.notice.warn{color:var(--amber)}.workspace{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start}.ip-list{grid-column:1}.rules-panel{grid-column:2/-1}.ip-list,.rules-panel{border-radius:8px;height:min(72vh,846px);min-height:520px;padding:18px}.rules-panel{grid-template-rows:auto minmax(0,1fr);display:grid;overflow:hidden}.ip-list{scrollbar-gutter:stable;overflow-y:auto}.activity-panel{background:#1d222dc7;border:1px solid #8094a42e;border-radius:8px;margin-top:16px;padding:18px;box-shadow:0 24px 80px #00000038}.activity-list{gap:8px;display:grid}.activity-row{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:14px;padding:13px 14px;display:grid}.activity-row strong,.activity-row small{display:block}.activity-row small{color:var(--muted);margin-top:3px}.activity-drawer-backdrop{z-index:20;background:#00000094;justify-content:flex-end;padding:18px;display:flex;position:fixed;inset:0}.activity-drawer{background:#1d222dfa;border:1px solid #8094a43d;border-radius:8px;width:min(460px,100%);max-height:100%;padding:18px;overflow-y:auto;box-shadow:0 28px 90px #0000006b}.activity-drawer .activity-panel{box-shadow:none;background:0 0;border:0;margin-top:0;padding:0}.debug-drawer{align-content:start;gap:16px;display:grid}.debug-drawer .panel-heading{margin-bottom:0}.debug-actions{grid-template-columns:minmax(118px,1fr) auto auto auto;align-items:end;gap:10px;display:grid}.debug-actions label{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;gap:7px;font-size:12px;font-weight:700;display:grid}.debug-actions select{border:1px solid var(--outline);min-height:38px;color:var(--text);background:var(--surface-low);letter-spacing:0;text-transform:none;border-radius:8px;padding:0 10px}.debug-pop-list{gap:10px;display:grid}.debug-section-heading{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;justify-content:space-between;align-items:center;gap:12px;font-size:12px;font-weight:800;display:flex}.debug-section-heading strong{color:var(--text)}.debug-event-list{gap:10px;max-height:360px;padding-right:4px;display:grid;overflow-y:auto}.debug-pop-row{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;display:grid}.debug-event-row{background:#090d1338;border:1px solid #8094a42e;border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:12px;padding:12px;display:grid}.debug-pop-row strong,.debug-pop-row small,.debug-event-row strong,.debug-event-row small{display:block}.debug-pop-row small,.debug-event-row small{color:var(--muted);margin-top:4px}.debug-json{border:1px solid var(--outline);background:#090d1352;border-radius:8px;padding:12px}.debug-json summary{cursor:pointer;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:800}.debug-json pre{max-height:320px;color:var(--text);white-space:pre-wrap;word-break:break-word;margin:12px 0 0;font-size:12px;line-height:1.55;overflow:auto}.panel-heading{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.panel-heading h2{margin:0;font-size:20px}.rule-actions{justify-content:flex-end;align-items:center;gap:10px;display:flex}.sort-control{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;grid-template-columns:auto minmax(128px,1fr);align-items:center;gap:8px;font-size:12px;font-weight:700;display:grid}.sort-control select{border:1px solid var(--outline);min-height:38px;color:var(--text);background:var(--surface-low);letter-spacing:0;text-transform:none;border-radius:8px;padding:0 10px}.ip-row{border:1px solid var(--outline);width:100%;color:var(--text);background:var(--surface-low);text-align:left;border-radius:8px;grid-template-columns:1fr auto;gap:4px 10px;margin-bottom:10px;padding:14px;display:grid}.ip-row.active{border-color:var(--cyan);background:#66d7ff14}.ip-row small{grid-column:1/2}.ip-row em{color:var(--green);grid-area:1/2/3;align-self:center;font-style:normal}.rule-table{scrollbar-gutter:stable;--rule-grid-columns:minmax(70px, .55fr) minmax(96px, .65fr) minmax(220px, 2fr) minmax(120px, .9fr) minmax(96px, auto);grid-auto-rows:max-content;align-content:start;gap:8px;height:100%;min-height:0;padding-right:4px;display:grid;overflow-y:auto}.rule-head,.rule-row{grid-template-columns:var(--rule-grid-columns);align-items:center;gap:14px;display:grid}.admin-rule-head,.admin-rule-row{grid-template-columns:var(--rule-grid-columns)}.rule-head{z-index:1;min-height:34px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;background:#1d222dfa;border-bottom:1px solid #8094a42e;padding:0 14px;font-size:12px;position:sticky;top:0}.rule-row{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;padding:14px}.rule-row strong,.rule-row small{display:block}.status{width:fit-content;color:var(--amber);background:#f2c66d1f;border-radius:999px;padding:4px 9px;font-size:12px}.status.ok{color:var(--green);background:#51e0821f}.primary-button,.ghost-button,.danger-button{min-height:42px;color:var(--text);border:1px solid #0000;border-radius:8px;padding:0 16px;font-weight:700}.primary-button{background:var(--cyan);color:#041019}.primary-button.compact{min-height:38px}.primary-button:disabled{cursor:not-allowed;opacity:.55}.ghost-button{border-color:var(--outline);background:var(--surface-low)}.danger-button{color:var(--red);background:#ff8d861a;border-color:#ff8d8659}.notice{color:var(--text);border-radius:8px;margin-bottom:16px;padding:14px}.loading-shell{min-height:100vh}.loading-panel{text-align:center;background:linear-gradient(135deg,#66d7ff14,#0000 42%),#1d222db8;border:1px solid #8094a42e;border-radius:8px;align-content:center;place-items:center;gap:24px;min-height:520px;display:grid;box-shadow:0 24px 80px #00000038}.loading-panel h1{margin:0;font-size:24px}.loading-panel p{color:var(--muted);margin:8px 0 0}.shield-loader{width:86px;height:86px;position:relative}.shield-loader:before{content:"";border:2px solid #66d7ff73;border-radius:18px 18px 26px 26px;position:absolute;inset:15px;transform:rotate(45deg);box-shadow:0 0 28px #66d7ff2e}.shield-loader span{border:1px solid #0000;border-top-color:var(--cyan);border-radius:50%;animation:1.4s linear infinite shield-spin;position:absolute;inset:0}.shield-loader span:nth-child(2){border-top-color:var(--green);animation-duration:1.9s;animation-direction:reverse;inset:10px}.shield-loader span:nth-child(3){border-top-color:var(--amber);animation-duration:2.3s;inset:22px}@keyframes shield-spin{to{transform:rotate(360deg)}}.empty-state{border:1px dashed var(--outline);min-height:220px;color:var(--muted);text-align:center;border-radius:8px;place-items:center;padding:24px;display:grid}.empty-state.compact{min-height:96px}.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.login-noise{pointer-events:none;opacity:.05;background-image:linear-gradient(#ffffff26 1px,#0000 1px),linear-gradient(90deg,#ffffff26 1px,#0000 1px);background-size:10px 10px;position:fixed;inset:0}.login-card{text-align:center;border-radius:8px;width:min(440px,100%);padding:34px;position:relative}.login-card .primary-button{width:100%;margin-top:24px}.login-card .ghost-button.full-width{width:100%;margin-top:10px}.login-card h1{margin:18px 0 8px;font-size:24px}.admin-shell .metric strong{font-size:26px}.admin-workspace .ip-list,.admin-workspace .rules-panel{min-height:620px}.admin-ip-detail{grid-template-rows:auto minmax(0,1fr);gap:18px;min-height:0;display:grid}.admin-filters{gap:10px;margin-bottom:14px;display:grid}.admin-filters input,.admin-filters select{border:1px solid var(--outline);width:100%;min-height:42px;color:var(--text);background:var(--surface-low);border-radius:8px;padding:0 12px}.system-stats-panel{background:#1d222dc7;border:1px solid #8094a42e;border-radius:8px;min-height:620px;padding:18px;box-shadow:0 24px 80px #00000038}.status-pill{width:fit-content;color:var(--amber);text-transform:uppercase;letter-spacing:.1em;background:#f2c66d1f;border-radius:999px;padding:6px 10px;font-size:12px}.status-pill.good{color:var(--green);background:#51e0821f}.stats-overview{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px;display:grid}.stats-notice{margin-bottom:16px}.stats-group-tabs{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:16px;display:grid}.stats-group-tabs button{border:1px solid var(--outline);min-height:58px;color:var(--muted);background:var(--surface-low);text-align:left;border-radius:8px;padding:10px 12px}.stats-group-tabs button.active{border-color:var(--cyan);color:var(--text);background:#66d7ff1a}.stats-group-tabs strong,.stats-group-tabs span{display:block}.stats-group-tabs strong{color:inherit;font-size:13px}.stats-group-tabs span{margin-top:3px;font-size:12px}.stats-detail{gap:16px;display:grid}.stats-card{background:#0f131b7a;border:1px solid #8094a42e;border-radius:8px;padding:16px}.panel-heading.compact{margin-bottom:12px}.panel-heading h3{margin:0;font-size:16px}.pop-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.game-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.game-stat-card{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;align-content:start;gap:12px;padding:14px;display:grid}.game-stat-card strong,.game-stat-card span{display:block}.game-stat-card span{color:var(--muted);margin-top:3px;font-size:12px}.metric-table{gap:8px;display:grid}.metric-table.compact{gap:6px}.metric-table-row{background:#090d133d;border:1px solid #8094a42e;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;min-height:38px;padding:8px 10px;display:grid}.metric-table-row span{color:var(--muted);font-size:12px}.metric-table-row strong{font-size:13px}.map-headroom-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.map-fill-row{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;gap:10px;padding:12px;display:grid}.map-fill-row div:first-child{justify-content:space-between;align-items:center;gap:12px;display:flex}.map-fill-row strong{font-size:13px}.map-fill-row span{color:var(--muted);font-size:12px}.map-fill-track{background:#8094a42e;border-radius:999px;height:8px;overflow:hidden}.map-fill-track span{border-radius:inherit;background:var(--green);height:100%;display:block}.map-fill-row.warn .map-fill-track span{background:var(--amber)}.map-fill-row.critical .map-fill-track span{background:var(--red)}.pop-stat{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;gap:12px;padding:14px;display:grid}.pop-stat>div:first-child{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.pop-stat strong,.pop-stat span{display:block}.pop-stat span{color:var(--muted);margin-top:3px;font-size:12px}.pop-stat em{color:var(--green);background:#51e0821f;border-radius:999px;justify-self:start;padding:4px 9px;font-size:12px;font-style:normal}.pop-stat.warn em{color:var(--amber);background:#f2c66d1f}.pop-stat p{color:var(--amber);margin:0;font-size:13px;line-height:1.45}.pop-stat dl{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:0;display:grid}.pending-rules-panel{align-content:start;display:grid}.pending-rule-table{scrollbar-gutter:stable;gap:8px;max-height:min(64vh,720px);padding-right:4px;display:grid;overflow-y:auto}.pending-rule-head,.pending-rule-row{grid-template-columns:minmax(132px,.8fr) minmax(150px,.9fr) minmax(220px,1.2fr) minmax(150px,.7fr);align-items:center;gap:14px;display:grid}.pending-rule-head{z-index:1;min-height:34px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;background:#1d222dfa;border-bottom:1px solid #8094a42e;padding:0 14px;font-size:12px;position:sticky;top:0}.pending-rule-row{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;padding:14px}.pending-rule-row strong,.pending-rule-row small{display:block}.pending-rule-row small{color:var(--muted);overflow-wrap:anywhere;margin-top:4px}.pop-stat dt{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:11px}.pop-stat dd{margin:4px 0 0;font-weight:800}.detail-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.detail-strip span{border:1px solid var(--outline);min-height:58px;color:var(--muted);background:var(--surface-low);text-transform:uppercase;letter-spacing:.1em;border-radius:8px;padding:10px 12px;font-size:12px}.detail-strip strong{color:var(--text);text-transform:none;letter-spacing:0;margin-top:5px;font-size:14px;display:block}.modal-backdrop{z-index:40;background:#0000009e;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.rule-modal{z-index:1;border-radius:8px;width:min(520px,100%);padding:22px;position:relative}.rule-modal label{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;gap:8px;margin-bottom:16px;font-size:12px;font-weight:700;display:grid}.rule-modal input,.rule-modal select{border:1px solid var(--outline);width:100%;min-height:44px;color:var(--text);background:var(--surface-low);border-radius:8px;padding:0 12px}.rule-modal input[aria-invalid=true]{border-color:#ff8d86a6}.field-hint{color:var(--muted);letter-spacing:0;text-transform:none;font-size:11px}.mode-tabs{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:16px;display:grid}.mode-tabs.ip-mode-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.mode-tabs button{border:1px solid var(--outline);min-height:40px;color:var(--muted);background:var(--surface-low);border-radius:8px;font-weight:700}.mode-tabs button.active{border-color:var(--cyan);color:var(--text);background:#66d7ff1a}.preset-panel{gap:10px;margin-bottom:16px;display:grid}.preset-heading,.preset-row{grid-template-columns:1fr 138px;align-items:center;gap:12px;display:grid}.preset-heading{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:12px}.preset-heading strong{color:var(--text)}.preset-heading span{justify-self:end}.preset-row{border:1px solid var(--outline);background:var(--surface-low);border-radius:8px;min-height:66px;padding:10px 12px}.preset-row strong,.preset-row small{display:block}.preset-row small{color:var(--muted);margin-top:4px}@media (width<=920px){.portal-shell{padding:16px}.topbar,.workspace{grid-template-columns:1fr}.ip-list,.rules-panel{grid-column:auto;height:fit-content;overflow:visible}.topbar-account{justify-content:space-between;align-items:flex-start}.account-copy{text-align:left}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stats-overview,.stats-group-tabs,.pop-stats-grid,.game-stats-grid,.map-headroom-grid{grid-template-columns:1fr}.rule-head,.pending-rule-head{display:none}.rule-table{height:auto;max-height:none;padding-right:0;overflow:visible}.rule-row,.admin-rule-row,.pending-rule-row,.detail-strip,.activity-row{grid-template-columns:1fr}.debug-actions{grid-template-columns:1fr 1fr;align-items:stretch}.activity-drawer-backdrop{padding:12px}.rule-actions{justify-content:space-between;width:100%}}@media (width<=560px){.metrics-grid,.stats-overview,.game-stats-grid,.map-headroom-grid{grid-template-columns:1fr}.topbar-actions{flex-wrap:wrap}.panel-heading{flex-direction:column;align-items:flex-start}.rule-actions,.sort-control{grid-template-columns:1fr;width:100%}.rule-actions{align-items:stretch}.mode-tabs,.preset-heading,.preset-row,.debug-actions{grid-template-columns:1fr}.preset-heading span{justify-self:start}}
