/* ===================================================================
   AscentAIO — OWNER analytics (admin.ascentaio.com)
   Separate surface. Fleet-wide rollups from GET /api/admin/metrics.
   Electric-red neon on near-black (brand-consistent, functional).
   =================================================================== */
:root{
  --accent-rgb:255,45,70; --accent:rgb(var(--accent-rgb)); --accent-2:#FF99A6;
  --accent-h:#FF5566; --neon:#FF1744;
  --bg:#050406; --bg-2:#0A0810; --panel:#0E0C12; --panel-2:#15121B;
  --card:rgba(14,12,18,.6); --line:rgba(255,255,255,.07); --line-2:rgba(255,255,255,.12);
  --text:#F4E9EB; --muted:#9298A6; --faint:#56535e;
  --ok:#FF5566; --warn:#FFB020; --bad:#FF4533;
  --glow:drop-shadow(0 0 1.5px #FF99A6) drop-shadow(0 0 5px #FF2247) drop-shadow(0 0 14px #FF1744);
  --ease:cubic-bezier(.2,.7,.2,1); --radius:13px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(60% 40% at 15% -5%, rgba(var(--accent-rgb),.07), transparent 55%),
    radial-gradient(45% 40% at 95% 0%, rgba(var(--accent-rgb),.05), transparent 55%),
    var(--bg);
  color:var(--text);font-family:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased;min-height:100vh;
}
h1,h2,h3,h4{font-family:"Space Grotesk","Inter",sans-serif;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)} .faint{color:var(--faint)}
.mono{font-family:"JetBrains Mono",Consolas,monospace}
::selection{background:rgba(var(--accent-rgb),.3);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#1c1820;border:3px solid transparent;background-clip:content-box;border-radius:6px}

/* brand */
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:24px;height:24px;flex-shrink:0;filter:var(--glow)}
.brand-name{font-family:"Space Grotesk";font-weight:700;font-size:18px;letter-spacing:.2px}
.brand-accent{color:var(--accent);text-shadow:0 0 6px rgba(var(--accent-rgb),.4)}
.tag{font-family:"JetBrains Mono",monospace;font-size:10px;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--accent);border:1px solid rgba(var(--accent-rgb),.35);border-radius:999px;padding:3px 9px;background:rgba(var(--accent-rgb),.08)}

/* buttons + fields */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:none;
  font-family:"Space Grotesk";font-weight:600;font-size:13.5px;padding:10px 16px;border-radius:10px;
  color:#fff;background:var(--accent);transition:transform .15s var(--ease),box-shadow .2s,background .2s;
  box-shadow:0 0 16px rgba(var(--accent-rgb),.5)}
.btn:hover{transform:translateY(-1px);background:var(--accent-h);box-shadow:0 0 24px rgba(var(--accent-rgb),.8)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn.ghost{background:rgba(255,255,255,.05);color:var(--text);border:1px solid var(--line-2);box-shadow:none}
.btn.ghost:hover{background:rgba(255,255,255,.09)}
.btn.sm{padding:8px 12px;font-size:12.5px}
.input{width:100%;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;color:var(--text);
  font-size:14px;padding:9px 11px;outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.16)}
.input.mono{font-family:"JetBrains Mono",monospace;letter-spacing:.06em}
.label{display:block;font-size:11px;letter-spacing:.06em;color:var(--muted);margin-bottom:6px;text-transform:uppercase;font-family:"JetBrains Mono",monospace}

/* ── login ── */
.auth{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--line);border-radius:18px;
  padding:36px 32px;backdrop-filter:blur(10px);box-shadow:0 40px 90px -40px rgba(0,0,0,.85)}
.auth-card .brand{justify-content:center;margin-bottom:14px}
.auth-card h1{font-size:21px;text-align:center;margin-bottom:6px}
.auth-card .sub{color:var(--muted);text-align:center;font-size:13px;margin-bottom:22px}
.auth-card .label{margin-top:4px}
.auth-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin:12px 0 18px;cursor:pointer}
.auth-msg{min-height:18px;font-size:13px;margin-top:12px;text-align:center}
.auth-msg.err{color:#ff8478}.auth-msg.ok{color:var(--ok)}
.auth-note{font-size:11.5px;color:var(--faint);text-align:center;margin-top:18px;line-height:1.5}

/* ── shell ── */
.top{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;padding:14px clamp(16px,4vw,34px);
  background:rgba(8,6,10,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.top .right{margin-left:auto;display:flex;align-items:center;gap:12px}
.top .who{font-size:12.5px;color:var(--muted)}
.wrap{max-width:1240px;margin:0 auto;padding:24px clamp(16px,4vw,34px) 60px}
.section-h{display:flex;align-items:baseline;gap:10px;margin:30px 2px 14px}
.section-h h2{font-size:17px}
.section-h .hint{font-size:11.5px;color:var(--faint);font-family:"JetBrains Mono",monospace}

/* status banner */
.status{margin:14px 0;padding:12px 16px;border-radius:11px;border:1px solid var(--line);background:var(--card);font-size:13.5px;color:var(--muted)}
.status.err{border-color:rgba(255,69,51,.4);color:#ff8478}
.status.hide{display:none}

/* filters */
.filters{display:grid;grid-template-columns:repeat(6,1fr) auto auto;gap:10px;align-items:end;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;backdrop-filter:blur(8px)}
.filters .f{min-width:0}
.filters .acts{display:flex;gap:8px}
@media(max-width:900px){.filters{grid-template-columns:repeat(2,1fr)}.filters .acts{grid-column:1/-1}}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:16px}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;backdrop-filter:blur(8px);position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.7}
.kpi .v{font-family:"Space Grotesk";font-weight:700;font-size:26px;line-height:1.1}
.kpi .l{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);font-family:"JetBrains Mono",monospace;margin-top:4px}
.kpi.good .v{color:var(--ok)} .kpi.bad .v{color:var(--bad)} .kpi.warn .v{color:var(--warn)}

/* cards + tables */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:6px 4px;backdrop-filter:blur(8px);overflow-x:auto}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:900px){.grid2{grid-template-columns:1fr}}
table.t{width:100%;border-collapse:collapse;font-size:13px}
table.t th{text-align:left;font-family:"JetBrains Mono",monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;
  color:var(--muted);font-weight:600;padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
table.t td{padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.04);white-space:nowrap}
table.t tr:last-child td{border-bottom:none}
table.t tr:hover td{background:rgba(255,255,255,.02)}
table.t td.num,table.t th.num{text-align:right;font-family:"JetBrains Mono",monospace}
.name{font-weight:600}
.pill{display:inline-block;font-size:10.5px;font-family:"JetBrains Mono",monospace;padding:2px 8px;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);color:#c4c7d2}
.bar{height:6px;border-radius:3px;background:rgba(255,255,255,.07);overflow:hidden;min-width:60px}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));box-shadow:0 0 8px rgba(var(--accent-rgb),.5)}
.chip{display:inline-block;font-size:11px;font-family:"JetBrains Mono",monospace;padding:3px 9px;border-radius:999px;margin:2px;
  background:rgba(255,69,51,.12);border:1px solid rgba(255,69,51,.28);color:#ff9a8f}
.fhrow{display:flex;gap:12px;align-items:baseline;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04)}
.fhrow:last-child{border-bottom:none}
.fhrow .site{min-width:120px;font-weight:600}

/* chart */
.chartwrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;backdrop-filter:blur(8px)}
.spark{width:100%;height:auto;display:block}
.spark .bar-r{fill:rgba(var(--accent-rgb),.22)}
.spark .line{stroke:var(--accent);stroke-width:2;filter:drop-shadow(0 0 4px rgba(var(--accent-rgb),.6))}
.spark .dot{fill:var(--accent)}
.spark .ax{stroke:rgba(255,255,255,.08);stroke-width:1}
.spark .lbl{fill:var(--faint);font-size:9px;font-family:"JetBrains Mono",monospace}
.legend{display:flex;gap:18px;margin-top:10px;font-size:11.5px;color:var(--muted);font-family:"JetBrains Mono",monospace}
.legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:6px;vertical-align:middle}
.legend .l-bar{background:rgba(var(--accent-rgb),.5)} .legend .l-line{background:var(--accent)}
.empty{padding:26px;text-align:center;color:var(--faint);font-size:13px}
