@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap');

/* ════════════════════════════════════════════════════════
   DESIGN TOKENS
════════════════════════════════════════════════════════ */
:root {
  --bg:       #060608;
  --card:     #0f0f14;
  --surface:  #17171f;
  --surface2: #1e1e28;
  --input:    #0c0c11;

  --border:   rgba(255,255,255,.08);
  --border2:  rgba(255,255,255,.14);
  --border-r: rgba(192,57,43,.28);
  --border-r2:rgba(192,57,43,.5);

  --r1: #8b0000;
  --r2: #c0392b;
  --r3: #e74c3c;
  --r4: #ff6b6b;
  --r-bg:  rgba(192,57,43,.1);
  --r-bg2: rgba(192,57,43,.06);

  --green:        #22c55e;
  --green-bg:     rgba(34,197,94,.1);
  --green-border: rgba(34,197,94,.25);
  --yellow:       #eab308;
  --yellow-bg:    rgba(234,179,8,.1);
  --blue:         #3b82f6;
  --blue-bg:      rgba(59,130,246,.1);
  --purple:       #a855f7;
  --purple-bg:    rgba(168,85,247,.1);
  --orange:       #f97316;
  --orange-bg:    rgba(249,115,22,.1);

  --tx:  #f1f1f5;
  --tx2: #8a8a9e;
  --tx3: #52526a;

  --radius:    18px;
  --radius-sm: 10px;
  --radius-xs: 6px;

  --sw:      224px;
  --sw-icon:  64px;

  --shadow:    0 0 0 1px var(--border), 0 8px 32px rgba(0,0,0,.35);
  --shadow-lg: 0 0 0 1px var(--border), 0 20px 60px rgba(0,0,0,.5);
  --shadow-r:  0 4px 20px rgba(192,57,43,.22);
  --shadow-r2: 0 8px 40px rgba(192,57,43,.38);

  --transition: .2s cubic-bezier(.22,.68,0,1.2);
  --transition-slow: .35s cubic-bezier(.22,.68,0,1.2);
}

/* ── RESET ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: 'Geist', 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 13px; line-height: 1.6;
  color: var(--tx); background: var(--bg);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(192,57,43,.4); border-radius: 2px; }

/* ── KEYFRAMES ───────────────────────────────────────── */
@keyframes fade-up {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fade-in {
  from { opacity:0; }
  to   { opacity:1; }
}
@keyframes slide-in-left {
  from { opacity:0; transform:translateX(-14px); }
  to   { opacity:1; transform:translateX(0); }
}
@keyframes shimmer {
  0%   { background-position:-200% center; }
  100% { background-position: 200% center; }
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50%     { opacity:.4; transform:scale(.75); }
}
@keyframes pulse-ring {
  0%   { box-shadow:0 0 0 0 rgba(192,57,43,.5); }
  70%  { box-shadow:0 0 0 8px rgba(192,57,43,0); }
  100% { box-shadow:0 0 0 0 rgba(192,57,43,0); }
}
@keyframes toast-in {
  from { opacity:0; transform:translateX(24px) scale(.96); }
  to   { opacity:1; transform:translateX(0)    scale(1); }
}
@keyframes toast-out {
  to { opacity:0; transform:translateX(24px) scale(.96); }
}
@keyframes spin {
  to { transform:rotate(360deg); }
}

/* ════════════════════════════════════════════════════════
   LAYOUT
════════════════════════════════════════════════════════ */
.main-wrap {
  margin-left: var(--sw);
  min-height: 100vh;
  padding: 28px 32px 56px;
  transition: margin-left var(--transition-slow);
}
.main-wrap.sb-collapsed { margin-left: var(--sw-icon); }

.auth-wrap {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
}

/* ── Page enter animation ────────────────────────────── */
.page { animation: fade-up .42s cubic-bezier(.22,.68,0,1.2) backwards; }

/* ════════════════════════════════════════════════════════
   SIDEBAR
════════════════════════════════════════════════════════ */
.sidebar {
  position: fixed; top:0; left:0;
  width: var(--sw); height: 100vh;
  background: var(--card);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  z-index: 300; overflow: hidden;
  box-shadow: 4px 0 40px rgba(0,0,0,.4);
  transition: width var(--transition-slow);
  will-change: width;
}
.sidebar::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, transparent, var(--r2), transparent);
  background-size: 200% auto;
  animation: shimmer 4s linear infinite;
  box-shadow: 0 0 16px rgba(192,57,43,.5);
  pointer-events:none;
}
.sidebar.collapsed { width: var(--sw-icon); }

/* ── Sidebar logo ────────────────────────────────────── */
.sidebar-logo {
  padding: 16px 14px 14px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.sidebar-logo-row { display:flex; align-items:center; gap:10px; overflow:hidden; }
.sidebar-logo-texts { min-width:0; overflow:hidden; white-space:nowrap; transition:opacity var(--transition); }
.sidebar.collapsed .sidebar-logo-texts { opacity:0; pointer-events:none; width:0; }
.logo-text { font-size:13px; font-weight:700; color:var(--tx); letter-spacing:-.2px; }
.logo-sub  { font-size:10px; color:var(--tx3); margin-top:1px; }

/* ── Shield icon ─────────────────────────────────────── */
.security-logo {
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0; color:var(--r3);
  background: linear-gradient(135deg,rgba(192,57,43,.2),rgba(139,0,0,.08));
  border:1px solid var(--border-r);
  border-radius:var(--radius-sm);
  box-shadow: 0 0 16px rgba(192,57,43,.28), inset 0 1px 0 rgba(255,255,255,.08);
  position:relative; overflow:hidden;
  transition: box-shadow var(--transition), transform var(--transition);
}
.security-logo::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at 50% 0%, rgba(192,57,43,.28), transparent 65%);
  pointer-events:none;
}
.security-logo svg { display:block; position:relative; z-index:1; filter:drop-shadow(0 0 4px rgba(231,76,60,.7)); }
.security-logo:hover { box-shadow:0 0 24px rgba(192,57,43,.5), inset 0 1px 0 rgba(255,255,255,.1); transform:scale(1.04); }
.security-logo--lg { width:38px; height:38px; border-radius:10px; }
.security-logo--lg svg { width:20px; height:20px; }
.security-logo--sm { width:32px; height:32px; border-radius:9px; }
.security-logo--sm svg { width:17px; height:17px; }
.security-logo--xs { width:18px; height:18px; border-radius:5px; }
.security-logo--xs svg { width:10px; height:10px; }

/* ── Sidebar nav ─────────────────────────────────────── */
.sidebar-nav {
  flex:1; padding:8px 8px; display:flex; flex-direction:column; gap:1px;
  overflow-y:auto; overflow-x:hidden;
}
.nav-section {
  font-size:9px; font-weight:700; color:var(--tx3);
  text-transform:uppercase; letter-spacing:1.5px;
  padding: 14px 10px 5px;
  white-space:nowrap; overflow:hidden;
  transition: opacity var(--transition);
}
.sidebar.collapsed .nav-section { opacity:0; height:0; padding:0; }
.nav-item {
  display:flex; align-items:center; gap:9px;
  padding:7px 10px; border-radius:var(--radius-sm);
  color:var(--tx2); text-decoration:none;
  font-size:13px; font-weight:400;
  transition: all var(--transition);
  border:1px solid transparent;
  position:relative; overflow:hidden;
  white-space:nowrap;
}
.nav-item::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--r2); border-radius:0 1px 1px 0;
  transform:scaleY(0); transform-origin:center;
  transition:transform var(--transition);
  box-shadow:0 0 6px var(--r2);
}
.nav-item:hover { background:rgba(255,255,255,.04); color:var(--tx); border-color:var(--border); }
.nav-item:hover::before { transform:scaleY(1); }
.nav-item.active {
  background: rgba(192,57,43,.1);
  color:var(--tx); border-color:var(--border-r); font-weight:500;
}
.nav-item.active::before { transform:scaleY(1); }
.nav-item.active .nav-icon { color:var(--r3); }
.nav-icon { font-size:14px; width:18px; text-align:center; color:var(--tx3); flex-shrink:0; transition:color var(--transition); }
.nav-icon--logo { width:auto; display:inline-flex; align-items:center; }
.nav-label { transition:opacity var(--transition); white-space:nowrap; overflow:hidden; }
.sidebar.collapsed .nav-label { opacity:0; width:0; }
.sidebar.collapsed .nav-item { justify-content:center; padding:9px 0; }
.nav-dot {
  margin-left:auto; min-width:18px; height:18px; border-radius:9px;
  font-size:10px; font-weight:600; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; padding:0 5px;
  background:var(--yellow-bg); color:var(--yellow);
}
.nav-dot.green { background:var(--green-bg); color:var(--green); }
.nav-dot.red   { background:var(--r-bg); color:var(--r4); }
.sidebar.collapsed .nav-dot { display:none; }

/* ── Sidebar status block ────────────────────────────── */
.sidebar-status-block {
  padding:8px 12px 6px; border-top:1px solid var(--border);
  display:flex; flex-direction:column; gap:5px;
  flex-shrink:0;
  transition:opacity var(--transition);
}
.sidebar.collapsed .sidebar-status-block { opacity:0; height:0; padding:0; overflow:hidden; }
.sidebar-status-row { display:flex; align-items:center; justify-content:space-between; font-size:11px; color:var(--tx3); }
.status-badge { font-size:10px; font-weight:600; padding:1px 8px; border-radius:20px; }
.status-badge.on  { background:var(--green-bg); color:var(--green); border:1px solid var(--green-border); }
.status-badge.off { background:rgba(255,255,255,.05); color:var(--tx3); border:1px solid var(--border); }

/* ── Sidebar footer ──────────────────────────────────── */
.sidebar-footer {
  padding:10px 10px; border-top:1px solid var(--border);
  display:flex; flex-direction:column; gap:7px; flex-shrink:0;
}
.user-chip {
  display:flex; align-items:center; gap:9px;
  padding:9px 10px;
  background:rgba(192,57,43,.07);
  border:1px solid var(--border-r);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-r);
  transition: box-shadow var(--transition);
  overflow:hidden;
}
.user-chip:hover { box-shadow:var(--shadow-r2); }
.user-avatar {
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--r1),var(--r2));
  box-shadow:0 0 10px rgba(192,57,43,.4);
  animation:pulse-ring 3.5s ease-in-out infinite;
}
.user-info { display:flex; flex-direction:column; min-width:0; flex:1; overflow:hidden; transition:opacity var(--transition); }
.sidebar.collapsed .user-info { opacity:0; width:0; }
.user-name { font-size:12px; font-weight:600; color:var(--tx); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.user-role { font-size:10px; color:var(--r4); font-weight:500; }
.logout-btn {
  color:var(--tx3); font-size:13px; text-decoration:none;
  padding:3px 5px; border-radius:4px; transition:all var(--transition);
  border:none; background:none; cursor:pointer; flex-shrink:0;
}
.logout-btn:hover { color:var(--r4); }
.sg71-brand { text-align:center; font-size:9px; color:var(--tx3); letter-spacing:.4px; transition:opacity var(--transition); }
.sg71-brand span { background:linear-gradient(90deg,var(--r3),var(--r4)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; font-weight:700; }
.sidebar.collapsed .sg71-brand { opacity:0; height:0; overflow:hidden; }

/* ── Sidebar collapse toggle ─────────────────────────── */
.sidebar-toggle-btn {
  display:flex; align-items:center; justify-content:center;
  width:24px; height:24px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:50%; cursor:pointer;
  position:absolute; top:50%; right:-12px;
  transform:translateY(-50%);
  box-shadow:var(--shadow); z-index:10;
  transition:all var(--transition);
  color:var(--tx3); font-size:10px;
}
.sidebar-toggle-btn:hover { background:var(--surface2); color:var(--tx); border-color:var(--border2); }
.sidebar.collapsed .sidebar-toggle-btn { transform:translateY(-50%) rotate(180deg); }
.sidebar-toggle-wrap { position:relative; height:0; flex-shrink:0; }

/* ════════════════════════════════════════════════════════
   TOPBAR (mobile / tablet)
════════════════════════════════════════════════════════ */
.topbar {
  display:none;
  position:fixed; top:0; left:0; right:0; height:54px; z-index:250;
  background:var(--card);
  border-bottom:1px solid var(--border);
  align-items:center; gap:12px;
  padding:0 16px;
  box-shadow:0 2px 20px rgba(0,0,0,.3);
}
.topbar-menu {
  width:36px; height:36px; background:none; border:1px solid var(--border);
  border-radius:var(--radius-xs); color:var(--tx2); font-size:16px; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:all var(--transition);
  flex-shrink:0;
}
.topbar-menu:hover { background:var(--surface); color:var(--tx); }
.topbar-title { font-size:14px; font-weight:600; color:var(--tx); flex:1; }
.topbar-user {
  width:30px; height:30px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--r1),var(--r2));
  flex-shrink:0;
}

/* ── Mobile drawer ───────────────────────────────────── */
.mob-overlay {
  display:none; position:fixed; inset:0; z-index:290;
  background:rgba(0,0,0,.7); backdrop-filter:blur(4px);
}
.mob-overlay.open { display:block; animation:fade-in .2s; }

/* ════════════════════════════════════════════════════════
   PAGE HEADER
════════════════════════════════════════════════════════ */
.page-top {
  display:flex; align-items:flex-start; justify-content:space-between;
  margin-bottom:24px; flex-wrap:wrap; gap:12px;
}
.page-top--center { align-items:center; }
.page-title {
  font-size:21px; font-weight:700; letter-spacing:-.5px; color:var(--tx);
  position:relative; padding-bottom:10px;
}
.page-title::after {
  content:''; position:absolute; left:0; bottom:0;
  width:28px; height:2px; border-radius:1px;
  background:linear-gradient(90deg,var(--r2),var(--r4));
  box-shadow:0 0 8px rgba(192,57,43,.5);
}
.page-title--solo { padding-bottom:7px; }
.page-sub { font-size:12px; color:var(--tx3); margin-top:5px; max-width:54ch; }
.page-actions { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

.admin-users-brand { display:flex; align-items:center; gap:12px; }
.admin-users-brand .security-logo--lg { flex-shrink:0; }

/* ── Stat pills ──────────────────────────────────────── */
.stat-pill {
  display:inline-flex; align-items:center; gap:5px;
  background:var(--r-bg); border:1px solid var(--border-r);
  color:var(--r4); padding:4px 12px; border-radius:20px;
  font-size:11px; font-weight:500;
}
.stat-pill::before { content:'●'; font-size:6px; }
.stat-pill--neutral { background:rgba(255,255,255,.04); border-color:var(--border); color:var(--tx2); }
.stat-pill--neutral::before { color:var(--tx3); }

/* ════════════════════════════════════════════════════════
   STAT CARDS
════════════════════════════════════════════════════════ */
.stats-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:14px; margin-bottom:24px;
}
.stat-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px 20px;
  box-shadow:var(--shadow);
  position:relative; overflow:hidden;
  transition:box-shadow var(--transition), border-color var(--transition);
  animation:fade-up .45s cubic-bezier(.22,.68,0,1.2) calc(var(--i,0)*55ms) backwards;
}
.stat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
}
.stat-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--r2),transparent);
  opacity:0; transition:opacity var(--transition);
}
.stat-card:hover { border-color:var(--border2); box-shadow:var(--shadow-lg); }
.stat-card:hover::after { opacity:1; }
.stat-card-label {
  font-size:10px; font-weight:600; color:var(--tx3);
  text-transform:uppercase; letter-spacing:1px;
  display:flex; align-items:center; gap:5px; margin-bottom:10px;
}
.stat-card-label::before { content:'◈'; font-size:8px; color:var(--tx3); }
.stat-card-label.green::before  { color:var(--green); }
.stat-card-label.yellow::before { color:var(--yellow); }
.stat-card-label.red::before    { color:var(--r3); }
.stat-card-label.blue::before   { color:var(--blue); }
.stat-card-value { font-size:34px; font-weight:700; color:#fff; letter-spacing:-1.5px; line-height:1; }
.stat-card-sub   { font-size:11px; color:var(--tx3); margin-top:5px; }

/* ════════════════════════════════════════════════════════
   CARD
════════════════════════════════════════════════════════ */
.card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px 24px;
  margin-bottom:16px;
  box-shadow:var(--shadow);
  position:relative; overflow:hidden;
  transition:box-shadow var(--transition), border-color var(--transition);
}
.card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
  pointer-events:none;
}
.card:hover { box-shadow:var(--shadow-lg); }
.card--nm { margin-bottom:0; }
.card--settings { padding:24px 26px; }
.card-head { display:flex; align-items:center; gap:10px; margin-bottom:14px; flex-wrap:wrap; }
.card-title { font-size:14px; font-weight:600; color:var(--tx); }
.card-desc  { font-size:12px; color:var(--tx3); margin-bottom:16px; line-height:1.6; }

/* ════════════════════════════════════════════════════════
   AUTH PAGES — contained card layout
════════════════════════════════════════════════════════ */
.auth-wrap {
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  background:
    radial-gradient(ellipse 70% 50% at 20% 60%, rgba(139,0,0,.12), transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 20%, rgba(80,0,0,.08), transparent 55%),
    var(--bg);
}
.auth-split {
  width:100%; max-width:920px;
  display:flex;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow: 0 0 0 1px rgba(192,57,43,.22), 0 40px 80px rgba(0,0,0,.7), 0 8px 24px rgba(0,0,0,.5);
  animation:fade-up .5s cubic-bezier(.22,.68,0,1.2);
}
.auth-split__left {
  width:42%; min-height:500px;
  background:linear-gradient(155deg,#0a0006 0%,#1c0000 35%,#2e0c08 70%,#1a0606 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:52px 36px;
  position:relative; overflow:hidden;
  flex-shrink:0;
}
.auth-split__left::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 90% 70% at 50% 25%, rgba(192,57,43,.28), transparent 60%),
    radial-gradient(ellipse 60% 90% at 15% 85%, rgba(139,0,0,.2), transparent 55%),
    radial-gradient(ellipse 40% 40% at 85% 10%, rgba(231,76,60,.08), transparent 50%);
  pointer-events:none;
}
.auth-split__left::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(192,57,43,.4),transparent);
  display:none;
}
.auth-split__left-inner { position:relative; z-index:1; text-align:center; max-width:280px; }
.auth-split__right {
  flex:1;
  display:flex; align-items:center; justify-content:center;
  padding:48px 40px;
  background:var(--card);
  border-left:1px solid rgba(255,255,255,.06);
  position:relative;
}
.auth-split__right::before {
  content:''; position:absolute; top:0; right:0; width:60%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
}
.auth-brand-logo {
  width:72px; height:72px; border-radius:20px;
  background:linear-gradient(145deg,rgba(192,57,43,.3),rgba(139,0,0,.15));
  border:1px solid rgba(192,57,43,.55);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 40px rgba(192,57,43,.5), 0 0 80px rgba(192,57,43,.15), inset 0 1px 0 rgba(255,255,255,.12);
  position:relative; overflow:hidden; margin:0 auto 28px;
  transition:box-shadow .3s;
}
.auth-brand-logo::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(231,76,60,.35),transparent 65%);
}
.auth-brand-logo svg { position:relative; z-index:1; filter:drop-shadow(0 0 10px rgba(231,76,60,.9)); }
.auth-brand-name {
  font-size:20px; font-weight:800; letter-spacing:3px;
  text-transform:uppercase; color:#f5f5ff;
  text-shadow:0 1px 0 #c0392b,0 2px 0 #922b21,0 4px 16px rgba(192,57,43,.55);
  line-height:1.25; margin-bottom:14px;
}
.auth-brand-tagline { font-size:12px; color:rgba(241,241,245,.45); line-height:1.7; }
.auth-brand-dots { display:flex; justify-content:center; gap:6px; margin-top:32px; }
.auth-brand-dot { width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.12); }
.auth-brand-dot:nth-child(2) { background:rgba(192,57,43,.65); width:22px; border-radius:4px; }
.auth-brand-dot:nth-child(3) { background:rgba(255,255,255,.07); }

/* ── Auth form container ─────────────────────────────── */
.auth-card {
  width:100%; max-width:340px;
}
.auth-card--standalone {
  background:var(--surface);
  border:1px solid var(--border-r);
  border-radius:var(--radius);
  padding:36px 32px;
  box-shadow:var(--shadow-lg), var(--shadow-r);
  position:relative; overflow:hidden;
}
.auth-card--standalone::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--r1),var(--r3),var(--r1));
  animation:shimmer 3.5s linear infinite; background-size:200% auto;
  box-shadow:0 0 18px rgba(192,57,43,.45);
}
.auth-title { font-size:22px; font-weight:700; color:var(--tx); margin-bottom:3px; letter-spacing:-.3px; }
.auth-sub   { font-size:12px; color:var(--tx3); margin-bottom:24px; }
.auth-form  { display:flex; flex-direction:column; gap:16px; }

/* ── Forgot password panel ───────────────────────────── */
.forgot-panel { overflow:hidden; max-height:0; transition:max-height .38s cubic-bezier(.22,.68,0,1.2), opacity .3s; opacity:0; }
.forgot-panel.open { max-height:240px; opacity:1; }
.forgot-panel-inner { border-top:1px solid var(--border); padding:16px 0 4px; display:flex; flex-direction:column; gap:10px; }
.forgot-link { background:none; border:none; color:var(--tx3); font-size:11px; cursor:pointer; font-family:inherit; padding:0; transition:color var(--transition); text-align:center; display:block; width:100%; }
.forgot-link:hover { color:var(--r4); }
.auth-footer-link { text-align:center; margin-top:18px; padding-top:14px; border-top:1px solid var(--border); font-size:11px; color:var(--tx3); }

/* ════════════════════════════════════════════════════════
   FIELDS / INPUTS
════════════════════════════════════════════════════════ */
.field { display:flex; flex-direction:column; gap:6px; }
.field label, .form-label {
  font-size:11px; font-weight:600; color:var(--tx3);
  text-transform:uppercase; letter-spacing:.8px;
}
.field input[type=text],
.field input[type=password],
.field input[type=number],
.field input[type=email],
input.flex-input,
.form-input {
  padding:10px 13px;
  background:var(--input);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--tx); font-size:13px; font-family:inherit;
  transition:border-color var(--transition), box-shadow var(--transition);
  outline:none;
  width:100%;
}
.field input:focus, input.flex-input:focus, .form-input:focus {
  border-color:var(--border-r2);
  box-shadow:0 0 0 3px rgba(192,57,43,.13);
}
.field input::placeholder { color:var(--tx3); }
.field-hint { font-size:11px; color:var(--tx3); }
.add-form { display:flex; gap:10px; flex-wrap:wrap; align-items:flex-end; }
.add-form .field { flex:1; min-width:120px; }
.inline-form { display:flex; gap:9px; flex-wrap:wrap; align-items:center; }
.inline-form .flex-input { flex:1; min-width:180px; }

/* ── Toggle ──────────────────────────────────────────── */
.toggle-label {
  display:flex; align-items:center; gap:9px; cursor:pointer;
  font-size:13px; color:var(--tx2); user-select:none;
}
.toggle-label input[type=checkbox] { display:none; }
.toggle-track {
  width:36px; height:20px; border-radius:10px;
  background:var(--surface); border:1px solid var(--border);
  position:relative; transition:all .25s; flex-shrink:0;
}
.toggle-thumb {
  position:absolute; top:3px; left:3px; width:12px; height:12px;
  border-radius:50%; background:var(--tx3); transition:all .25s;
}
.toggle-label input:checked ~ .toggle-track { background:var(--green); border-color:var(--green); box-shadow:0 0 8px rgba(34,197,94,.35); }
.toggle-label input:checked ~ .toggle-track .toggle-thumb { left:19px; background:#fff; }
.bs-check { display:flex; align-items:center; gap:8px; cursor:pointer; font-size:13px; color:var(--tx2); }
.bs-check input[type=checkbox] { accent-color:var(--green); }

/* ── Settings form ───────────────────────────────────── */
.settings-form { display:flex; flex-direction:column; gap:14px; }
.settings-form--narrow { max-width:480px; }
.settings-form--bot { display:grid; grid-template-columns:1fr 1fr; gap:14px 20px; }
.settings-form--bot > .field--span-full,
.settings-form--bot > .btn-primary { grid-column:1/-1; }
@media (max-width:680px) { .settings-form--bot { grid-template-columns:1fr; } }
.settings-page { width:100%; max-width:1100px; }

/* ════════════════════════════════════════════════════════
   BUTTONS
════════════════════════════════════════════════════════ */
.btn-primary {
  padding:10px 22px;
  background:linear-gradient(135deg,var(--r2),var(--r1));
  color:#fff; border:none; border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; font-family:inherit;
  cursor:pointer; white-space:nowrap;
  box-shadow:var(--shadow-r), inset 0 1px 0 rgba(255,255,255,.12);
  transition:all var(--transition);
  position:relative; overflow:hidden;
}
.btn-primary:hover {
  background:linear-gradient(135deg,var(--r3),var(--r2));
  box-shadow:var(--shadow-r2), inset 0 1px 0 rgba(255,255,255,.18);
  transform:translateY(-1px) scale(1.01);
}
.btn-primary:active { transform:translateY(0) scale(.99); }
.btn-primary--full { width:100%; padding:11px; text-align:center; display:block; text-decoration:none; }

.btn-full {
  width:100%; padding:11px;
  background:linear-gradient(135deg,var(--r2),var(--r1));
  color:#fff; border:none; border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; font-family:inherit;
  cursor:pointer; text-decoration:none; display:block; text-align:center;
  box-shadow:var(--shadow-r), inset 0 1px 0 rgba(255,255,255,.12);
  transition:all var(--transition);
}
.btn-full:hover {
  background:linear-gradient(135deg,var(--r3),var(--r2));
  box-shadow:var(--shadow-r2), inset 0 1px 0 rgba(255,255,255,.18);
  transform:translateY(-1px);
}
.btn-full:active { transform:translateY(0); }

.btn-ghost {
  padding:8px 14px;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  color:var(--tx2); border-radius:var(--radius-sm);
  font-size:12px; font-family:inherit; cursor:pointer;
  text-decoration:none; display:inline-block;
  transition:all var(--transition);
}
.btn-ghost:hover {
  border-color:var(--border2); color:var(--tx);
  background:rgba(255,255,255,.07); transform:translateY(-1px);
}
.btn-ghost.btn-danger-ghost:hover { border-color:var(--border-r2); color:var(--r4); background:var(--r-bg); }

.btn-danger {
  padding:8px 16px;
  background:var(--r-bg); color:var(--r4);
  border:1px solid var(--border-r); border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; font-family:inherit; cursor:pointer;
  text-decoration:none; display:inline-block; transition:all var(--transition);
}
.btn-danger:hover { background:rgba(192,57,43,.18); transform:translateY(-1px); }

.btn-sm  { padding:6px 12px !important; font-size:12px !important; }
.btn-xs  { padding:3px 9px  !important; font-size:11px !important; }
.btn-icon-danger {
  width:28px; height:28px; background:transparent;
  border:1px solid transparent; color:var(--tx3);
  border-radius:var(--radius-xs); cursor:pointer; font-size:12px;
  display:inline-flex; align-items:center; justify-content:center;
  transition:all var(--transition);
}
.btn-icon-danger:hover { background:var(--r-bg); border-color:var(--border-r); color:var(--r4); transform:scale(1.1); }
.btn-copy {
  flex-shrink:0; padding:4px 10px; font-size:11px; font-weight:600;
  background:rgba(255,255,255,.06); border:1px solid var(--border);
  border-radius:var(--radius-xs); color:var(--tx2); cursor:pointer;
  transition:all var(--transition); font-family:inherit;
}
.btn-copy:hover { border-color:var(--border2); color:var(--tx); }

/* ════════════════════════════════════════════════════════
   TABLE
════════════════════════════════════════════════════════ */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:13px; }
thead tr { border-bottom:1px solid var(--border2); }
th { text-align:left; padding:10px 14px; color:var(--tx3); font-weight:600; font-size:10px; text-transform:uppercase; letter-spacing:.9px; white-space:nowrap; }
td { padding:11px 14px; border-bottom:1px solid var(--border); vertical-align:middle; transition:background .15s; }
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover td { background:rgba(255,255,255,.02); }
code { background:rgba(255,255,255,.06); border:1px solid var(--border); padding:2px 6px; border-radius:var(--radius-xs); font-size:12px; font-family:'Geist Mono','Consolas',monospace; color:#c8c8e0; }
.muted   { color:var(--tx3) !important; }
.mono-sm { font-family:'Geist Mono','Consolas',monospace; font-size:12px; }

/* ════════════════════════════════════════════════════════
   TAGS / BADGES
════════════════════════════════════════════════════════ */
.badge { background:rgba(255,255,255,.06); border:1px solid var(--border); color:var(--tx2); padding:2px 9px; border-radius:20px; font-size:11px; font-weight:500; }
.badge-blue { background:var(--blue-bg); border-color:rgba(59,130,246,.25); color:#60a5fa; }
.badge-red  { background:var(--r-bg); border-color:var(--border-r); color:var(--r4); }

.tag { padding:2px 9px; border-radius:20px; font-size:11px; font-weight:500; display:inline-flex; align-items:center; gap:4px; }
.tag-green  { background:var(--green-bg);  color:var(--green);  border:1px solid var(--green-border); }
.tag-gray   { background:rgba(255,255,255,.05); color:var(--tx3); border:1px solid var(--border); }
.tag-purple { background:var(--purple-bg); color:#c084fc;       border:1px solid rgba(168,85,247,.25); }
.tag-warn   { background:var(--orange-bg); color:var(--orange);  border:1px solid rgba(249,115,22,.25); }
.tag-red    { background:var(--r-bg);      color:var(--r4);      border:1px solid var(--border-r); }
.tag-blue-soft { background:var(--blue-bg); color:#60a5fa; border:1px solid rgba(59,130,246,.25); }
.expiry-tag { font-size:12px; color:var(--tx3); font-family:'Geist Mono',monospace; }
.stat-chip { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:600; }
.stat-chip .a { color:var(--green); }
.stat-chip .e { color:var(--r4); }
.stat-chip .sep { color:var(--tx3); }

/* ════════════════════════════════════════════════════════
   ALERTS / TOAST
════════════════════════════════════════════════════════ */
.alert { padding:12px 15px; border-radius:var(--radius-sm); margin-bottom:16px; font-size:13px; }
.alert-ok    { background:var(--green-bg); border:1px solid var(--green-border); color:var(--green); }
.alert-error { background:var(--r-bg); border:1px solid var(--border-r); color:var(--r4); }

/* Toast */
.toast-root {
  position:fixed; top:16px; right:16px; z-index:9999;
  display:flex; flex-direction:column; gap:8px;
  pointer-events:none;
}
.toast {
  min-width:280px; max-width:380px;
  padding:12px 16px; border-radius:var(--radius-sm);
  background:var(--surface2); border:1px solid var(--border2);
  box-shadow:var(--shadow-lg);
  color:var(--tx); font-size:13px;
  display:flex; align-items:center; gap:10px;
  pointer-events:all;
  animation:toast-in .3s cubic-bezier(.22,.68,0,1.2);
}
.toast.toast-ok  { border-left:3px solid var(--green); }
.toast.toast-err { border-left:3px solid var(--r3); }
.toast.toast-out { animation:toast-out .25s ease forwards; }
.toast-icon { font-size:15px; flex-shrink:0; }

/* ════════════════════════════════════════════════════════
   PILL TABS
════════════════════════════════════════════════════════ */
.pill-tabs { display:flex; gap:6px; margin-bottom:16px; flex-wrap:wrap; }
.pill-tab {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 15px; border-radius:20px; font-size:12px; font-weight:500;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  color:var(--tx2); cursor:pointer; text-decoration:none;
  transition:all var(--transition);
}
.pill-tab:hover { background:rgba(255,255,255,.07); border-color:var(--border2); color:var(--tx); transform:translateY(-1px); }
.pill-tab.active {
  background:var(--r-bg); border-color:var(--border-r2);
  color:var(--tx); font-weight:600;
  box-shadow:var(--shadow-r);
}
.pill-tab-dot { width:7px; height:7px; border-radius:50%; background:var(--r2); flex-shrink:0; box-shadow:0 0 5px var(--r2); }
.pill-tab-dot.green { background:var(--green); box-shadow:0 0 5px var(--green); }
.pill-tab-emoji { font-size:13px; }

/* ── Admin tabs ──────────────────────────────────────── */
.admin-tabs { display:flex; gap:6px; margin-bottom:18px; flex-wrap:wrap; }
.admin-tab {
  display:inline-flex; align-items:center; gap:7px;
  padding:6px 15px; border-radius:20px; font-size:12px; font-weight:500;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  color:var(--tx2); text-decoration:none; transition:all var(--transition);
}
.admin-tab:hover { border-color:var(--border2); color:var(--tx); background:rgba(255,255,255,.07); transform:translateY(-1px); }
.admin-tab.active { background:var(--r-bg); border-color:var(--border-r2); color:var(--tx); font-weight:600; box-shadow:var(--shadow-r); }
.admin-tab__logo { display:inline-flex; flex-shrink:0; }

/* ════════════════════════════════════════════════════════
   SEARCH
════════════════════════════════════════════════════════ */
.search-wrap { position:relative; margin-bottom:14px; }
.search-wrap input {
  width:100%; padding:9px 12px 9px 36px;
  background:var(--input); border:1px solid var(--border);
  border-radius:var(--radius-sm); color:var(--tx);
  font-size:13px; font-family:inherit; outline:none;
  transition:border-color var(--transition), box-shadow var(--transition);
}
.search-wrap input:focus { border-color:var(--border-r); box-shadow:0 0 0 3px rgba(192,57,43,.1); }
.search-wrap input::placeholder { color:var(--tx3); }
.search-icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--tx3); font-size:13px; pointer-events:none; }

/* ════════════════════════════════════════════════════════
   UID LIST / USER LIST
════════════════════════════════════════════════════════ */
.user-list { display:flex; flex-direction:column; }
.user-list-row {
  display:flex; align-items:center; gap:12px;
  padding:10px 14px; border-bottom:1px solid var(--border);
  transition:all var(--transition);
}
.user-list-row:last-child { border-bottom:none; }
.user-list-row:hover { background:rgba(255,255,255,.025); }
.user-list-row--expired { opacity:.65; }
.ula { width:34px; height:34px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:#fff; }
.ula--a { background:linear-gradient(135deg,#8b0000,#c0392b); }
.ula--b { background:linear-gradient(135deg,#1a5276,#2980b9); }
.ula--c { background:linear-gradient(135deg,#145a32,#27ae60); }
.ula--d { background:linear-gradient(135deg,#7d6608,#d4ac0d); }
.ula--e { background:linear-gradient(135deg,#4a235a,#8e44ad); }
.ula--f { background:linear-gradient(135deg,#641e16,#c0392b); }
.ula--g { background:linear-gradient(135deg,#0e6655,#1abc9c); }
.ula--h { background:linear-gradient(135deg,#784212,#d35400); }
.user-list-info { flex:1; min-width:0; }
.user-list-name { font-size:13px; font-weight:500; color:var(--tx); }
.user-list-sub  { font-size:11px; color:var(--tx2); margin-top:1px; }
.user-list-sub--expired { color:var(--r4) !important; }
.user-list-badge { min-width:24px; height:22px; padding:0 7px; background:rgba(255,255,255,.05); border:1px solid var(--border); border-radius:20px; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:600; color:var(--tx2); flex-shrink:0; }

/* UID status dot */
.uid-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; display:inline-block; margin-right:2px; }
.uid-dot--active  { background:var(--green); box-shadow:0 0 4px var(--green); }
.uid-dot--expired { background:var(--r3); box-shadow:0 0 4px var(--r3); }
.uid-dot--unknown { background:var(--tx3); }

/* ════════════════════════════════════════════════════════
   KEY ROW / API KEY DISPLAY
════════════════════════════════════════════════════════ */
.key-row { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.key-display {
  flex:1; min-width:180px; padding:10px 13px;
  background:var(--input); border:1px solid var(--border);
  border-radius:var(--radius-sm); word-break:break-all;
  font-size:12px; color:#c8c8e0; font-family:'Geist Mono','Consolas',monospace;
}
.key-mini { display:flex; align-items:center; gap:5px; }
.hint { font-size:12px; color:var(--tx3); margin-bottom:10px; }
.link { color:var(--r3); text-decoration:none; transition:color var(--transition); }
.link:hover { color:var(--r4); }
.inline-link { color:var(--r3); text-decoration:none; font-weight:600; }
.inline-link:hover { color:var(--r4); }
.info-row { display:flex; align-items:center; gap:9px; margin-top:10px; font-size:12px; }
.info-label { color:var(--tx2); font-weight:500; }
.inline-code { background:rgba(255,255,255,.06); border:1px solid var(--border); padding:2px 7px; border-radius:var(--radius-xs); font-family:'Geist Mono',monospace; font-size:12px; color:#c8c8e0; }

/* ════════════════════════════════════════════════════════
   MISC
════════════════════════════════════════════════════════ */
.empty-state { text-align:center; padding:40px 20px; color:var(--tx3); }
.empty-icon  { font-size:28px; display:block; margin-bottom:12px; opacity:.15; }
.error-code {
  font-size:64px; font-weight:800; letter-spacing:-3px; line-height:1; margin:20px 0;
  background:linear-gradient(135deg,var(--r2),var(--r4));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 20px rgba(192,57,43,.45));
}
.error-msg { color:var(--tx3); margin-bottom:28px; font-size:13px; }

/* ════════════════════════════════════════════════════════
   ADMIN CONTROLS GRID
════════════════════════════════════════════════════════ */
.controls-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:14px; }
.ctrl-card {
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:14px 14px 12px;
  display:flex; flex-direction:column; gap:10px;
}
.ctrl-card-head { display:flex; align-items:center; gap:9px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.ctrl-card-name { font-size:13px; font-weight:600; color:var(--tx); flex:1; }
.ctrl-label { font-size:10px; font-weight:700; color:var(--tx3); text-transform:uppercase; letter-spacing:.8px; margin-bottom:5px; display:block; }
.ctrl-input {
  width:100%; padding:7px 10px;
  background:var(--input); border:1px solid var(--border);
  border-radius:var(--radius-xs); color:var(--tx); font-size:12px; font-family:inherit;
  outline:none; transition:border-color var(--transition);
}
.ctrl-input:focus { border-color:var(--border-r2); box-shadow:0 0 0 2px rgba(192,57,43,.1); }
.ctrl-api-row { display:flex; align-items:center; justify-content:space-between; font-size:12px; color:var(--tx2); }
.ctrl-save {
  margin-top:2px; padding:7px 14px; font-size:11px; font-weight:600;
  background:var(--r-bg); border:1px solid var(--border-r); border-radius:var(--radius-xs);
  color:var(--r4); cursor:pointer; font-family:inherit; transition:all var(--transition); width:100%;
}
.ctrl-save:hover { background:rgba(192,57,43,.2); transform:translateY(-1px); }

/* ── Limit shortcut pills ────────────────────────────── */
.ctrl-shortcuts {
  display:flex; flex-wrap:wrap; gap:4px;
}
.ctrl-shortcut {
  padding:3px 8px; font-size:10px; font-weight:600; font-family:inherit;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:20px; color:var(--tx3); cursor:pointer;
  transition:all var(--transition);
}
.ctrl-shortcut:hover {
  background:rgba(234,179,8,.14); border-color:rgba(234,179,8,.4);
  color:var(--yellow); transform:translateY(-1px);
}
.ctrl-shortcut--clear { color:var(--green); border-color:rgba(34,197,94,.25); background:var(--green-bg); }
.ctrl-shortcut--clear:hover { background:rgba(34,197,94,.2); border-color:var(--green); color:var(--green); }

/* ════════════════════════════════════════════════════════
   SLIDEOVER (Add UID panel)
════════════════════════════════════════════════════════ */
.slideover {
  position:fixed; top:0; bottom:0; right:-100%;
  width:380px; max-width:100vw;
  background:var(--card);
  border-left:1px solid var(--border);
  z-index:500; padding:28px 24px;
  overflow-y:auto;
  transition:right var(--transition-slow);
  box-shadow:-8px 0 40px rgba(0,0,0,.4);
}
.slideover.open { right:0; }
.slideover-backdrop {
  display:none; position:fixed; inset:0; z-index:499;
  background:rgba(0,0,0,.6); backdrop-filter:blur(4px);
}
.slideover-backdrop.open { display:block; animation:fade-in .2s; }
.slideover-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.slideover-title { font-size:16px; font-weight:700; color:var(--tx); }
.slideover-close { width:30px; height:30px; background:none; border:1px solid var(--border); border-radius:var(--radius-xs); color:var(--tx3); cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; transition:all var(--transition); }
.slideover-close:hover { background:var(--surface); color:var(--tx); }

/* ════════════════════════════════════════════════════════
   ACTION CLUSTER
════════════════════════════════════════════════════════ */
.action-cluster { display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
.pw-wrap { display:flex; align-items:center; gap:5px; }
.pw-tiny { width:90px; padding:4px 8px; font-size:11px; background:var(--input); border:1px solid var(--border); border-radius:var(--radius-xs); color:var(--tx); font-family:inherit; outline:none; }
.pw-tiny:focus { border-color:var(--border-r); }
.api-status-badge { display:inline-flex; align-items:center; gap:6px; padding:4px 11px; border-radius:20px; font-size:11px; font-weight:600; }
.api-status-badge.enabled  { background:var(--green-bg); color:var(--green); border:1px solid var(--green-border); }
.api-status-badge.disabled { background:var(--r-bg); color:var(--r4); border:1px solid var(--border-r); }
.limit-notice { display:inline-flex; align-items:center; gap:5px; font-size:11px; color:var(--yellow); padding:3px 9px; background:var(--yellow-bg); border:1px solid rgba(234,179,8,.2); border-radius:20px; }
.reset-req-pending td { background:rgba(192,57,43,.025); }

/* ════════════════════════════════════════════════════════
   USER CARDS (admin_users)
════════════════════════════════════════════════════════ */
.admin-users-page { width:100%; }
.user-grid { display:flex; flex-direction:column; gap:14px; }
.user-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow);
  transition:box-shadow var(--transition), border-color var(--transition);
  position:relative;
  animation:fade-up .45s cubic-bezier(.22,.68,0,1.2) calc(var(--i,0)*50ms) backwards;
}
.user-card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent); pointer-events:none; }
.user-card:hover { box-shadow:var(--shadow-lg); border-color:var(--border2); }
.user-card__head {
  display:flex; flex-wrap:wrap; align-items:center; gap:12px;
  padding:16px 18px; border-bottom:1px solid var(--border);
  background:rgba(0,0,0,.2);
}
.user-card__avatar { width:44px; height:44px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:15px; font-weight:700; color:#fff; }
.user-card__identity { flex:1; min-width:130px; }
.user-card__name { font-size:15px; font-weight:700; margin:0 0 2px; color:var(--tx); letter-spacing:-.2px; }
.user-card__id   { font-size:11px; color:var(--tx3); margin:0; }
.user-card__badges { display:flex; flex-wrap:wrap; align-items:center; gap:6px; }
.user-card__live { font-size:11px; font-weight:600; color:var(--green); display:inline-flex; align-items:center; gap:5px; }
.user-card__live-dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 5px var(--green); animation:pulse-dot 2s ease-in-out infinite; }
.user-card__actions { margin-left:auto; display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.user-card__form { display:inline; margin:0; }

.user-card__stats { display:grid; grid-template-columns:repeat(6,1fr); gap:8px; padding:12px 18px; border-bottom:1px solid var(--border); }
@media (max-width:600px) { .user-card__stats { grid-template-columns:repeat(3,1fr); } }
@media (max-width:400px) { .user-card__stats { grid-template-columns:repeat(2,1fr); } }
.user-stat {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:10px 8px; text-align:center;
  transition:all var(--transition);
}
.user-stat:hover { border-color:var(--border2); transform:translateY(-2px); box-shadow:var(--shadow); }
.user-stat__val { display:block; font-size:20px; font-weight:700; color:#fff; line-height:1.1; }
.user-stat__lbl { display:block; font-size:9px; font-weight:600; color:var(--tx2); text-transform:uppercase; letter-spacing:.6px; margin-top:4px; }

.user-card__dl { margin:0; padding:4px 18px 14px; }
.user-card__row { display:grid; grid-template-columns:minmax(130px,24%) 1fr; gap:6px 14px; padding:8px 0; border-bottom:1px solid var(--border); align-items:center; }
.user-card__row:last-of-type { border-bottom:none; }
.user-card__row--full { grid-column:1/-1; }
@media (max-width:560px) { .user-card__row { grid-template-columns:1fr; gap:3px; } }
.user-card__dl dt { font-size:10px; font-weight:700; color:var(--tx2); text-transform:uppercase; letter-spacing:.8px; margin:0; }
.user-card__dl dd { margin:0; font-size:13px; color:var(--tx); word-break:break-word; }
.user-card__code { display:inline-block; max-width:100%; padding:3px 8px; border-radius:var(--radius-sm); background:rgba(255,255,255,.06); border:1px solid var(--border); font-family:'Geist Mono',monospace; font-size:12px; color:#c0c0d8; }
.user-card__keybar { display:flex; align-items:center; gap:8px; min-width:0; padding:7px 10px; border-radius:var(--radius-sm); background:var(--input); border:1px solid var(--border); transition:all var(--transition); }
.user-card__keybar:hover { border-color:var(--border2); }
.user-card__code--masked { flex:1; min-width:0; display:block; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; border:none; background:transparent; padding:0; font-family:'Geist Mono',monospace; font-size:12px; color:#c8c8e0; }
.user-card__keycell { margin:0; }
.user-card__empty { color:var(--tx3); font-size:12px; font-style:italic; }

/* ════════════════════════════════════════════════════════
   PORTAL (public free portal)
════════════════════════════════════════════════════════ */
.portal-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; background:var(--bg); }
.portal-card {
  width:100%; max-width:420px;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:40px 32px;
  box-shadow:var(--shadow-lg);
  position:relative; overflow:hidden;
  animation:fade-up .45s cubic-bezier(.22,.68,0,1.2);
}
.portal-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--r1),var(--r3),var(--r1)); animation:shimmer 4s linear infinite; background-size:200% auto; box-shadow:0 0 18px rgba(192,57,43,.4); }
.portal-title { font-size:22px; font-weight:700; text-align:center; margin-bottom:8px; }
.portal-sub { text-align:center; color:var(--tx3); font-size:13px; margin-bottom:22px; line-height:1.65; }
.portal-info { display:flex; gap:7px; justify-content:center; margin-bottom:22px; flex-wrap:wrap; }
.portal-field-lg input { font-size:15px !important; padding:12px 14px !important; }
.portal-submit-lg { margin-top:10px; padding:13px !important; font-size:14px !important; }
.success-box { background:var(--green-bg); border:1px solid var(--green-border); border-radius:var(--radius-sm); padding:22px; text-align:center; color:var(--green); }
.success-icon { font-size:32px; display:block; margin-bottom:8px; }
.success-uid { font-family:'Geist Mono',monospace; font-size:18px; font-weight:700; margin:8px 0; color:var(--tx); }
.success-msg { font-size:12px; color:var(--tx3); margin-top:6px; }
.disabled-box { background:var(--r-bg); border:1px solid var(--border-r); border-radius:var(--radius-sm); padding:26px; text-align:center; color:var(--r4); }
.disabled-box p { color:var(--tx3); font-size:13px; margin-top:10px; }

/* ════════════════════════════════════════════════════════
   API DOCS
════════════════════════════════════════════════════════ */
.endpoint-card { border-left:3px solid var(--r2); }
.endpoint-header { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:14px; }
.endpoint-path { font-size:13px; color:var(--tx); font-family:'Geist Mono',monospace; }
.endpoint-desc { font-size:12px; color:var(--tx3); margin-left:auto; }
.ep-section { margin-bottom:16px; }
.ep-section:last-child { margin-bottom:0; }
.ep-label { font-size:10px; font-weight:600; color:var(--tx2); text-transform:uppercase; letter-spacing:.7px; margin-bottom:6px; display:flex; align-items:center; gap:6px; }
.code-block { background:rgba(0,0,0,.5); border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden; }
.code-bar { display:flex; align-items:center; justify-content:space-between; padding:7px 12px; background:rgba(255,255,255,.03); border-bottom:1px solid var(--border); font-size:11px; color:var(--tx3); }
.code-bar button { background:rgba(255,255,255,.06); border:1px solid var(--border); color:var(--tx2); padding:3px 9px; border-radius:var(--radius-xs); font-size:11px; cursor:pointer; transition:all var(--transition); font-family:inherit; }
.code-bar button:hover { border-color:var(--border-r); color:var(--r3); }
pre { padding:16px; margin:0; font-family:'Geist Mono','Consolas',monospace; font-size:12.5px; line-height:1.75; color:#cdd6f4; overflow-x:auto; white-space:pre; }
.code-comment { color:var(--tx3); }
.api-docs { display:flex; flex-direction:column; gap:7px; }
.api-row { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.method { padding:2px 8px; border-radius:var(--radius-xs); font-size:11px; font-weight:700; letter-spacing:.3px; min-width:42px; text-align:center; font-family:'Geist Mono',monospace; }
.method.post { background:var(--yellow-bg); color:var(--yellow); border:1px solid rgba(234,179,8,.25); }
.method.get  { background:var(--green-bg); color:var(--green); border:1px solid var(--green-border); }
.api-desc { font-size:12px; color:var(--tx3); }
.tabs { display:flex; gap:4px; margin-bottom:6px; }
.tab { padding:4px 12px; border-radius:20px; background:rgba(255,255,255,.04); border:1px solid var(--border); color:var(--tx2); font-size:12px; cursor:pointer; transition:all var(--transition); font-family:inherit; }
.tab.active { background:var(--r-bg); border-color:var(--border-r); color:var(--r3); }
.tab-content.hidden { display:none; }
.lang-tabs { display:flex; border-bottom:1px solid var(--border); }
.lang-tab { padding:7px 14px; background:transparent; border:none; border-bottom:2px solid transparent; color:var(--tx2); font-size:12px; font-weight:500; cursor:pointer; transition:all var(--transition); margin-bottom:-1px; font-family:inherit; }
.lang-tab:hover { color:var(--tx); }
.lang-tab.active { color:var(--r3); border-bottom-color:var(--r2); }
.lang-content { margin-top:10px; }
.lang-content.hidden { display:none; }

/* ════════════════════════════════════════════════════════
   SETTINGS TABS
════════════════════════════════════════════════════════ */
.settings-tabs { display:flex; gap:4px; border-bottom:1px solid var(--border); margin-bottom:22px; flex-wrap:wrap; }
.settings-tab { padding:9px 16px; background:none; border:none; border-bottom:2px solid transparent; color:var(--tx3); font-size:13px; font-weight:500; cursor:pointer; transition:all var(--transition); font-family:inherit; margin-bottom:-1px; }
.settings-tab:hover { color:var(--tx); }
.settings-tab.active { color:var(--r3); border-bottom-color:var(--r2); font-weight:600; }
.settings-panel { display:none; }
.settings-panel.active { display:block; animation:fade-up .3s cubic-bezier(.22,.68,0,1.2); }

/* ════════════════════════════════════════════════════════
   CUSTOM CONFIRM MODAL
════════════════════════════════════════════════════════ */
.sg-modal-wrap { display:none; position:fixed; inset:0; z-index:9999; align-items:center; justify-content:center; background:rgba(0,0,0,.75); backdrop-filter:blur(6px); }
.sg-modal-box { background:var(--surface2); border:1px solid rgba(192,57,43,.4); border-radius:var(--radius); padding:30px 28px 24px; max-width:340px; width:90%; box-shadow:var(--shadow-lg), var(--shadow-r); position:relative; animation:fade-up .25s cubic-bezier(.22,.68,0,1.2); }
.sg-modal-box::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; border-radius:var(--radius) var(--radius) 0 0; background:linear-gradient(90deg,var(--r1),var(--r3),var(--r1)); }

/* ════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════ */
@media (max-width:1100px) {
  .stats-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
  :root { --sw: var(--sw-icon); }
  .main-wrap { margin-left:var(--sw-icon) !important; }
  .sidebar { width:var(--sw-icon); }
  .sidebar-logo-texts,
  .nav-label,
  .nav-section,
  .sidebar-status-block,
  .user-info,
  .sg71-brand { display:none !important; }
  .nav-item { justify-content:center !important; padding:9px 0 !important; }
  .sidebar-toggle-wrap { display:none; }
  .user-chip { justify-content:center; padding:8px; }
  .user-chip .logout-btn { display:none; }
}
@media (max-width:768px) {
  .main-wrap { padding:70px 16px 40px !important; margin-left:0 !important; }
  .sidebar { display:none; }
  .sidebar.open { display:flex; width:var(--sw) !important; animation:slide-in-left .3s cubic-bezier(.22,.68,0,1.2); }
  .sidebar.open .sidebar-logo-texts,
  .sidebar.open .nav-label,
  .sidebar.open .nav-section,
  .sidebar.open .sidebar-status-block,
  .sidebar.open .user-info,
  .sidebar.open .sg71-brand { display:block !important; }
  .sidebar.open .nav-item { justify-content:flex-start !important; padding:7px 10px !important; }
  .sidebar.open .user-chip { justify-content:flex-start; padding:9px 10px; }
  .sidebar.open .user-chip .logout-btn { display:inline-block; }
  .topbar { display:flex; }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .page-title { font-size:18px; }
  .auth-split { max-width:420px; border-radius:var(--radius); }
  .auth-split__left { display:none; }
  .auth-split__right { min-height:auto; padding:40px 28px; }
}
@media (max-width:520px) {
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
  .add-form { flex-direction:column; align-items:stretch; }
  .main-wrap { padding:65px 12px 36px !important; }
  .page-top { flex-direction:column; align-items:flex-start; }
  .slideover { width:100vw; }
}
