/* ===================================================================
   AscentAIO — member area (login + dashboard)
   self-contained · Abyss storm theme · functional, brand-consistent
   =================================================================== */
:root{
  --accent-rgb:255,45,70; --accent:rgb(var(--accent-rgb)); --accent-2:#FF99A6;
  --accent-ink:#fff; --accent-h:#FF5566; --accent-deep:#C20E2A;
  --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;
  --go:#FF2D46; --amber:#9298A6; --red:#FF2D46; --neon:#FF1744;
  --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% 50% at 18% 0%, rgba(var(--accent-rgb),.08), transparent 55%),
    radial-gradient(50% 45% at 92% 12%, rgba(var(--accent-rgb),.06), transparent 55%),
    var(--bg);
  color:var(--text);font-family:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:15px;line-height:1.6;-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)}
::selection{background:rgba(var(--accent-rgb),.3);color:#fff}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-thumb{background:#1c242e;border:3px solid transparent;background-clip:content-box;border-radius:6px}

/* brand mark */
.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)}

/* 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:14px;padding:12px 18px;border-radius:11px;
  color:#fff;background:var(--accent);transition:transform .18s var(--ease),box-shadow .25s,background .2s;
  box-shadow:0 0 18px rgba(var(--accent-rgb),.55),0 4px 16px -6px rgba(var(--accent-rgb),.5)}
.btn:hover{transform:translateY(-1px);background:var(--accent-h);box-shadow:0 0 28px rgba(var(--accent-rgb),.85),0 8px 24px -6px rgba(var(--accent-rgb),.7)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn.full{width:100%}
.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);border-color:rgba(255,255,255,.22)}
.btn.sm{padding:8px 13px;font-size:12.5px;border-radius:9px}
.btn.danger{background:rgba(255,69,51,.14);color:#ff8478;border:1px solid rgba(255,69,51,.3);box-shadow:none}
.btn.danger:hover{background:rgba(255,69,51,.2)}
.input{width:100%;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;color:var(--text);
  font-size:15px;padding:13px 14px;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),.18)}
.input.mono{font-family:"JetBrains Mono",Consolas,monospace;letter-spacing:.12em}
.label{display:block;font-size:12px;letter-spacing:.04em;color:var(--muted);margin-bottom:8px;text-transform:uppercase}

/* ───────── 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:38px 34px;backdrop-filter:blur(10px);box-shadow:0 40px 90px -40px rgba(0,0,0,.8)}
.auth-card .brand{justify-content:center;margin-bottom:6px}
.auth-card .brand-mark{width:30px;height:30px}
.auth-card .brand-name{font-size:20px}
.auth-eyebrow{text-align:center;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--accent);margin:18px 0 6px}
.auth-card h1{text-align:center;font-size:24px;margin-bottom:6px}
.auth-card .sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:26px}
.auth-field{margin-bottom:14px}
.auth-remember{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);margin:0 2px 14px;cursor:pointer;user-select:none}
.auth-remember input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.auth-msg{min-height:20px;font-size:13px;margin:4px 2px 12px;text-align:center}
.auth-msg.err{color:#ff8478}.auth-msg.ok{color:#FF5566}
.auth-foot{text-align:center;margin-top:20px;font-size:13px;color:var(--muted)}
.auth-foot a{color:var(--accent)}
.auth-back{position:fixed;top:20px;left:22px;font-size:13px;color:var(--muted)}
.auth-back:hover{color:var(--accent)}

/* ───────── DASHBOARD ───────── */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:24px 18px;
  border-right:1px solid var(--line);background:linear-gradient(180deg,rgba(10,15,22,.6),rgba(4,7,12,.35));backdrop-filter:blur(10px)}
.side .brand{padding:4px 8px 26px}
.side-nav{display:flex;flex-direction:column;gap:3px;flex:1}
.side-nav button{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:transparent;border:none;cursor:pointer;
  color:var(--muted);font-family:"Inter";font-size:14px;font-weight:500;padding:11px 13px;border-radius:10px;transition:.18s}
.side-nav button .ic{width:16px;text-align:center;opacity:.8}
.side-nav button:hover{background:rgba(255,255,255,.04);color:var(--text)}
.side-nav button.active{color:#fff;background:linear-gradient(90deg,rgba(var(--accent-rgb),.16),transparent)}
.side-nav button.active .ic{color:var(--accent);opacity:1}
.side-foot{border-top:1px solid var(--line);padding-top:16px;display:flex;flex-direction:column;gap:10px}
.side-user{display:flex;align-items:center;gap:10px;font-size:13px}
.avatar{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#0a6b58);
  display:grid;place-items:center;color:var(--accent-ink);font-weight:700;font-family:"Space Grotesk";font-size:13px}

.main{padding:30px clamp(20px,4vw,44px);min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.topbar h1{font-size:24px}
.topbar .hello{color:var(--muted);font-size:13px;margin-top:2px}
.badge{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;
  background:rgba(var(--accent-rgb),.14);color:var(--accent-2);border:1px solid rgba(var(--accent-rgb),.3)}
.badge.ok{background:rgba(255,45,70,.14);color:#FF5566;border-color:rgba(255,45,70,.3)}
.badge.warn{background:rgba(255,174,66,.15);color:var(--amber);border-color:rgba(255,174,66,.3)}

.panel{display:none;animation:fade .3s var(--ease)}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.grid{display:grid;gap:16px}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;backdrop-filter:blur(8px)}
.card h3{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:14px;font-family:"Inter";font-weight:600}
.card.span2{grid-column:span 2}
.kv{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--muted);font-size:13.5px}
.kv .v{font-weight:600;font-size:14px}
.kv .v.mono{font-family:"JetBrains Mono",monospace;letter-spacing:.06em;color:var(--accent-2)}
.stat-big{font-family:"Space Grotesk";font-weight:700;font-size:40px;line-height:1;
  background:linear-gradient(180deg,#fff,var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat-lbl{color:var(--muted);font-size:12.5px;text-transform:uppercase;letter-spacing:.5px;margin-top:8px}
.dl{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ver{font-family:"JetBrains Mono",monospace;color:var(--accent-2);font-size:14px}
.notes{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:12px}
.notes li{font-size:13.5px;color:#c2c5cf;display:flex;gap:10px}
.notes li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);margin-top:8px;flex-shrink:0}
.rows{display:flex;flex-direction:column}
.rows .r{display:grid;grid-template-columns:90px 1fr auto;gap:12px;align-items:center;padding:11px 4px;border-bottom:1px solid var(--line);font-size:13.5px}
.rows .r:last-child{border-bottom:none}
.rows .r .store{color:var(--muted);font-family:"JetBrains Mono",monospace;font-size:12px}
.rows .r .ts{color:var(--faint);font-size:12px;font-family:"JetBrains Mono",monospace}
.field-row{margin-bottom:18px}
.connect{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border:1px solid var(--line);border-radius:11px;background:var(--panel-2)}
.keybox{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:var(--panel-2);border:1px solid var(--line-2);border-radius:12px;padding:16px 18px}
.keybox code{font-family:"JetBrains Mono",Consolas,monospace;font-size:clamp(16px,2.4vw,22px);letter-spacing:.14em;
  color:var(--accent-2);text-shadow:0 0 10px rgba(var(--accent-rgb),.3);word-break:break-all}
.key-actions{display:flex;gap:8px;flex-shrink:0}
.toast{position:fixed;right:18px;bottom:18px;z-index:50;background:var(--panel-2);border:1px solid var(--line-2);
  border-left:3px solid var(--accent);border-radius:10px;padding:13px 16px;font-size:13.5px;box-shadow:0 12px 30px rgba(0,0,0,.5);
  opacity:0;transform:translateY(8px);transition:.25s}
.toast.show{opacity:1;transform:none}

/* responsive */
@media (max-width:760px){
  .app{grid-template-columns:1fr}
  .side{position:static;height:auto;flex-direction:row;align-items:center;gap:10px;padding:12px 16px;border-right:0;border-bottom:1px solid var(--line);overflow-x:auto}
  .side .brand{padding:0 8px 0 0}
  .side-nav{flex-direction:row;flex:1}
  .side-nav button{padding:8px 11px;white-space:nowrap}
  .side-nav button .ic{display:none}
  .side-foot{border-top:0;padding-top:0;flex-direction:row}
  .side-user .who{display:none}
  .grid.c2,.grid.c3{grid-template-columns:1fr}
  .card.span2{grid-column:span 1}
}
