@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,300;12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=JetBrains+Mono:wght@400;500;600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

:root {
  --red:        #e8192c;
  --red-dim:    #b0101f;
  --red-glow:   rgba(232,25,44,0.18);
  --red-subtle: rgba(232,25,44,0.08);
  --bg:         #080808;
  --bg-1:       #0f0f0f;
  --bg-2:       #161616;
  --bg-3:       #1e1e1e;
  --bg-hover:   #222222;
  --border:     #1f1f1f;
  --border-2:   #2a2a2a;
  --border-3:   #363636;
  --text:       #f2f2f2;
  --text-2:     #a0a0a0;
  --text-3:     #555555;
  --green:      #16a34a;
  --green-fg:   #4ade80;
  --amber:      #d97706;
  --amber-fg:   #fbbf24;
  --blue:       #2563eb;
  --blue-fg:    #60a5fa;
  --font-display: 'Bricolage Grotesque', sans-serif;
  --font-body:    'DM Sans', sans-serif;
  --font-mono:    'JetBrains Mono', monospace;
  --radius-xs: 6px;
  --radius-sm: 10px;
  --radius:    16px;
  --radius-lg: 22px;
  --sidebar-w: 252px;
  --topbar-h:  60px;
  --shadow:     0 4px 16px rgba(0,0,0,0.6);
  --shadow-red: 0 4px 24px rgba(232,25,44,0.25);
  --ease: cubic-bezier(0.4,0,0.2,1);
  --dur: 180ms;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;font-size:15px}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.15;letter-spacing:-0.02em}
a{color:var(--red);text-decoration:none;transition:opacity var(--dur) var(--ease)}
a:hover{opacity:0.8}
img,svg{display:block;max-width:100%}
.cp-icon{flex-shrink:0}

.layout{display:flex;min-height:100vh}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:200;transition:transform var(--dur) var(--ease);overflow-y:auto;overflow-x:hidden}
.sidebar-logo{padding:20px 18px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.logo-mark{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-icon{width:34px;height:34px;background:var(--red);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-red)}
.logo-text{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-0.04em;color:var(--text)}
.logo-text em{color:var(--red);font-style:normal}
.sidebar-nav{flex:1;padding:14px 10px}
.nav-section{margin-bottom:22px}
.nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--text-3);padding:0 10px;margin-bottom:4px;font-family:var(--font-display)}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--radius-sm);color:var(--text-2);font-size:13.5px;font-weight:500;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);text-decoration:none;margin-bottom:1px;white-space:nowrap}
.nav-item:hover{background:var(--bg-hover);color:var(--text)}
.nav-item.active{background:var(--red-subtle);color:var(--red);font-weight:600}
.nav-item.active .cp-icon{color:var(--red)}
.nav-item--danger{color:var(--text-3)}
.nav-item--danger:hover{background:rgba(232,25,44,0.08);color:var(--red)}
.sidebar-footer{padding:12px 10px;border-top:1px solid var(--border);flex-shrink:0}
.user-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg-2)}
.user-avatar{width:32px;height:32px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:var(--font-display);color:#fff;flex-shrink:0}
.user-chip-info{flex:1;min-width:0}
.user-chip-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip-email{font-size:11px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* MAIN */
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0}
.topbar{height:var(--topbar-h);background:var(--bg-1);border-bottom:1px solid var(--border);padding:0 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;gap:12px}
.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}
.topbar-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.page-title{font-size:17px;font-weight:700;font-family:var(--font-display);letter-spacing:-0.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-xs);background:var(--red);border:none;cursor:pointer;color:#fff;transition:background var(--transition);flex-shrink:0}
.menu-btn:hover{background:var(--red-dark);color:#fff}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:199;backdrop-filter:blur(2px)}
.content{padding:28px;flex:1}

/* CARDS */
.card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:border-color var(--dur) var(--ease)}
.card--hover:hover{border-color:var(--border-2)}
.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.card-title{font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:-0.02em}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.stat-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;transition:border-color var(--dur)}
.stat-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease)}
.stat-card:hover{border-color:var(--border-2)}
.stat-card:hover::after{transform:scaleX(1)}
.stat-icon{width:36px;height:36px;background:var(--red-subtle);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--red);margin-bottom:14px}
.stat-value{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-0.04em;margin-bottom:3px;line-height:1}
.stat-label{font-size:12px;color:var(--text-2);font-weight:500}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;font-family:var(--font-body);border:none;cursor:pointer;transition:all var(--dur) var(--ease);text-decoration:none;white-space:nowrap;line-height:1;-webkit-tap-highlight-color:transparent}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-dim);box-shadow:var(--shadow-red);color:#fff}
.btn-secondary{background:var(--bg-2);color:var(--text);border:1px solid var(--border-2)}
.btn-secondary:hover{background:var(--bg-3);border-color:var(--border-3);color:var(--text)}
.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}
.btn-ghost:hover{color:var(--text);border-color:var(--border-2);background:var(--bg-2)}
.btn-danger{background:rgba(232,25,44,0.1);color:var(--red);border:1px solid rgba(232,25,44,0.25)}
.btn-danger:hover{background:var(--red);color:#fff;border-color:var(--red)}
.btn-success{background:rgba(22,163,74,0.1);color:var(--green-fg);border:1px solid rgba(22,163,74,0.25)}
.btn-success:hover{background:var(--green);color:#fff;border-color:var(--green)}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:var(--radius-xs);gap:5px}
.btn-lg{padding:13px 26px;font-size:15px;border-radius:var(--radius-sm)}
.btn-full{width:100%}
.btn-icon{padding:8px;aspect-ratio:1}

/* FORMS */
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-label{display:block;font-size:11.5px;font-weight:700;color:var(--text-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.7px;font-family:var(--font-display)}
.form-control{width:100%;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-size:14px;font-family:var(--font-body);transition:border-color var(--dur),box-shadow var(--dur);outline:none;-webkit-appearance:none}
.form-control:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow)}
.form-control::placeholder{color:var(--text-3)}
.form-control--mono{font-family:var(--font-mono);font-size:13px}
select.form-control{cursor:pointer}

/* TABLES */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{padding:11px 14px;text-align:left;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-3);border-bottom:1px solid var(--border);white-space:nowrap;font-family:var(--font-display)}
tbody td{padding:13px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--bg-2)}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px 3px;border-radius:999px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;font-family:var(--font-display)}
.badge-success{background:rgba(22,163,74,0.12);color:var(--green-fg)}
.badge-warning{background:rgba(217,119,6,0.12);color:var(--amber-fg)}
.badge-danger{background:rgba(232,25,44,0.12);color:var(--red)}
.badge-muted{background:var(--bg-2);color:var(--text-2);border:1px solid var(--border-2)}
.badge-blue{background:rgba(37,99,235,0.12);color:var(--blue-fg)}
.badge-admin{background:rgba(232,25,44,0.15);color:var(--red);border:1px solid rgba(232,25,44,0.3)}

/* ALERTS */
.alert{display:flex;align-items:flex-start;gap:10px;padding:13px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;margin-bottom:16px}
.alert .cp-icon{flex-shrink:0;margin-top:1px}
.alert-error{background:rgba(232,25,44,0.08);border:1px solid rgba(232,25,44,0.25);color:#f87171}
.alert-success{background:rgba(22,163,74,0.08);border:1px solid rgba(22,163,74,0.25);color:var(--green-fg)}
.alert-info{background:rgba(37,99,235,0.08);border:1px solid rgba(37,99,235,0.25);color:var(--blue-fg)}
.alert-warning{background:rgba(217,119,6,0.08);border:1px solid rgba(217,119,6,0.25);color:var(--amber-fg)}

/* BALANCE HERO */
.balance-hero{background:linear-gradient(135deg,#130407 0%,#1a0505 60%,#0f0909 100%);border:1px solid rgba(232,25,44,0.2);border-radius:var(--radius);padding:26px;position:relative;overflow:hidden}
.balance-hero::before{content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;background:radial-gradient(circle,rgba(232,25,44,0.12) 0%,transparent 70%);pointer-events:none}
.balance-hero-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-2);margin-bottom:10px;font-family:var(--font-display)}
.balance-hero-amount{font-family:var(--font-display);font-size:38px;font-weight:800;letter-spacing:-0.05em;line-height:1;margin-bottom:12px}
.balance-hero-sub{font-size:13px;color:var(--text-2);display:flex;align-items:center;gap:6px}
.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-green{background:var(--green-fg);box-shadow:0 0 5px var(--green-fg)}
.dot-red{background:var(--red);box-shadow:0 0 5px var(--red)}
.dot-amber{background:var(--amber-fg);box-shadow:0 0 5px var(--amber-fg)}
.dot-muted{background:var(--text-3)}
.balance-hero-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}

/* AUTH */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg);position:relative}
.auth-wrap::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 70% 10%,rgba(232,25,44,0.06) 0%,transparent 55%);pointer-events:none}
.auth-grid{display:grid;grid-template-columns:1fr 420px;gap:0;max-width:900px;width:100%;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);position:relative}
.auth-panel{padding:48px 40px}
.auth-branding{background:linear-gradient(160deg,#130407 0%,#0a0101 100%);padding:48px 40px;display:flex;flex-direction:column;justify-content:space-between;border-right:1px solid var(--border)}
.auth-branding h2{font-size:28px;font-weight:800;margin-bottom:14px;letter-spacing:-0.04em}
.auth-branding p{font-size:14px;color:var(--text-2);line-height:1.7}
.auth-features{margin-top:40px;display:flex;flex-direction:column;gap:14px}
.auth-feature{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-2)}
.auth-feature-dot{width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0}
.auth-panel h1{font-size:26px;font-weight:800;letter-spacing:-0.04em;margin-bottom:6px}
.auth-panel-sub{font-size:14px;color:var(--text-2);margin-bottom:30px}
.auth-footer{margin-top:22px;text-align:center;font-size:13px;color:var(--text-2)}

/* PERMS */
.perm-list{display:flex;flex-direction:column;gap:8px}
.perm-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;background:var(--bg-2);border-radius:var(--radius-sm);font-size:13px}
.perm-label{color:var(--text-2);display:flex;align-items:center;gap:8px}

/* TABS */
.tabs{display:flex;gap:2px;background:var(--bg-2);padding:3px;border-radius:var(--radius-sm);margin-bottom:22px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{flex-shrink:0;padding:7px 18px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-2);transition:all var(--dur) var(--ease);text-decoration:none;white-space:nowrap;font-family:var(--font-display);display:flex;align-items:center;gap:6px}
.tab:hover{color:var(--text)}
.tab.active{background:var(--bg-1);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,0.4)}

/* EMPTY */
.empty-state{text-align:center;padding:48px 24px;color:var(--text-2)}
.empty-icon{width:48px;height:48px;background:var(--bg-2);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--text-3)}
.empty-state h3{font-size:15px;margin-bottom:6px;color:var(--text)}
.empty-state p{font-size:13px;color:var(--text-2)}

/* CODE */
.mono{font-family:var(--font-mono);font-size:12.5px}
code{font-family:var(--font-mono);font-size:12.5px;background:var(--bg-3);padding:2px 6px;border-radius:4px;color:var(--red)}
.code-block{background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:16px;font-family:var(--font-mono);font-size:12.5px;line-height:1.7;overflow-x:auto;color:var(--text);-webkit-overflow-scrolling:touch;position:relative}
.code-block .kw{color:#ff79c6}
.code-block .str{color:#f1fa8c}
.code-block .key{color:var(--blue-fg)}
.code-block .val{color:#50fa7b}
.code-block .num{color:#bd93f9}
.code-block .cmt{color:var(--text-3);font-style:italic}

/* COPY FIELD */
.copy-field{display:flex;gap:8px;align-items:stretch}
.copy-input{flex:1;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius-xs);padding:10px 14px;color:var(--text-2);font-size:12.5px;font-family:var(--font-mono);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;outline:none;min-width:0}

/* API DOCS */
.doc-layout{display:grid;grid-template-columns:220px 1fr;gap:28px;align-items:start}
.doc-nav{position:sticky;top:calc(var(--topbar-h) + 20px);background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.doc-nav-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-3);margin-bottom:10px;font-family:var(--font-display)}
.doc-nav-item{display:block;padding:7px 10px;border-radius:var(--radius-xs);font-size:13px;color:var(--text-2);text-decoration:none;transition:all var(--dur);font-weight:500}
.doc-nav-item:hover{color:var(--text);background:var(--bg-2)}
.doc-nav-item.active{color:var(--red);background:var(--red-subtle);font-weight:600}
.doc-section{margin-bottom:36px}
.doc-section-title{font-size:20px;font-weight:800;letter-spacing:-0.03em;margin-bottom:10px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.doc-section-sub{font-size:14px;color:var(--text-2);margin-bottom:20px;line-height:1.7}
.endpoint-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:16px;overflow:hidden}
.endpoint-header{padding:14px 18px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);background:var(--bg-2);flex-wrap:wrap}
.method-badge{font-family:var(--font-mono);font-size:11px;font-weight:600;padding:3px 9px;border-radius:5px;flex-shrink:0}
.method-get{background:rgba(22,163,74,0.15);color:var(--green-fg)}
.method-post{background:rgba(37,99,235,0.15);color:var(--blue-fg)}
.endpoint-path{font-family:var(--font-mono);font-size:13px;color:var(--text);flex:1;word-break:break-all}
.endpoint-desc{font-size:13px;color:var(--text-2)}
.endpoint-body{padding:18px}
.param-table{width:100%;border-collapse:collapse;font-size:12.5px}
.param-table th,.param-table td{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border)}
.param-table th{color:var(--text-3);font-size:10.5px;text-transform:uppercase;letter-spacing:1px}
.param-table td:first-child{font-family:var(--font-mono);color:var(--red)}
.param-table td:last-child{color:var(--text-2)}

/* LAYOUT HELPERS */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.flex{display:flex}
.flex-center{display:flex;align-items:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-wrap{flex-wrap:wrap}
.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}
.text-sm{font-size:12.5px}.text-xs{font-size:11px}
.text-muted{color:var(--text-2)}.text-dim{color:var(--text-3)}
.text-red{color:var(--red)}.text-green{color:var(--green-fg)}.text-amber{color:var(--amber-fg)}
.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono)}.font-bold{font-weight:700}
.w-full{width:100%}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--border-3)}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes spin{to{transform:rotate(360deg)}}
.fade-up{animation:fadeUp .25s var(--ease) both}
.loading{animation:pulse 1.4s ease infinite}
.spinning{animation:spin .8s linear infinite}

/* ── MOBILE ── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);box-shadow:none}
  .sidebar.open{transform:translateX(0);box-shadow:4px 0 40px rgba(0,0,0,.8)}
  .sidebar-overlay.open{display:block}
  .main{margin-left:0}
  .topbar{padding:0 16px}
  .menu-btn{display:flex}
  .content{padding:16px}
  .auth-grid{grid-template-columns:1fr;max-width:440px}
  .auth-branding{display:none}
  .auth-panel{padding:32px 24px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .balance-hero-amount{font-size:28px}
  .doc-layout{grid-template-columns:1fr}
  .doc-nav{position:static}
  .form-row{grid-template-columns:1fr}
  .balance-hero-actions{gap:6px}
  .balance-hero-actions .btn{flex:1}
  .page-title{font-size:15px}
  .topbar{height:56px}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .tabs{gap:1px}
  .tab{padding:6px 12px;font-size:12px}
  .balance-hero-amount{font-size:24px}
}

/* ── Missing class aliases & additions ─────────────────── */

/* Auth aliases (map to .auth-outer / .auth-box pattern) */
.auth-outer { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px 16px; background:var(--bg); position:relative; }
.auth-outer::before { content:''; position:fixed; top:0;left:0;right:0;bottom:0; background:radial-gradient(ellipse at 65% 15%, rgba(232,25,44,0.06) 0%, transparent 55%); pointer-events:none; }
.auth-box { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:32px 28px; width:100%; max-width:390px; position:relative; }
.auth-brand { display:flex; flex-direction:column; align-items:center; margin-bottom:26px; text-align:center; }
.auth-glyph { width:48px; height:48px; background:var(--red); border-radius:13px; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-red); margin-bottom:11px; }
.auth-glyph svg { stroke:#fff; fill:none; width:24px; height:24px; }
.auth-heading { font-size:22px; font-weight:800; letter-spacing:-0.5px; }
.auth-sub { font-size:12.5px; color:var(--text-muted); margin-top:3px; }
.auth-footer { text-align:center; margin-top:20px; font-size:12.5px; color:var(--text-muted); }

/* Badge dot (inline status indicator inside badges) */
.badge-dot { width:5px; height:5px; border-radius:50%; flex-shrink:0; display:inline-block; }

/* Balance card classes */
.balance-label { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-bottom:8px; }
.balance-amount { font-size:42px; font-weight:800; letter-spacing:-2px; line-height:1; margin-bottom:18px; }

/* Empty state */
.empty { text-align:center; padding:40px 20px; }
.empty-icon { width:48px; height:48px; background:var(--bg-card2); border:1px solid var(--border); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; margin:0 auto 12px; }
.empty-icon svg { stroke:var(--text-dim); fill:none; width:20px; height:20px; }
.empty-title { font-size:13.5px; font-weight:600; color:var(--text); margin-bottom:3px; }
.empty-sub { font-size:12px; color:var(--text-muted); }

/* Form hint */
.form-hint { font-size:11.5px; color:var(--text-muted); margin-top:4px; }

/* Font weight utility */
.fw-700 { font-weight:700; }

/* Logo glyph & wordmark */
.logo-glyph { width:34px; height:34px; background:var(--red); border-radius:9px; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-red); flex-shrink:0; }
.logo-glyph svg { stroke:#fff; fill:none; width:18px; height:18px; }
.logo-wordmark { font-size:18px; font-weight:800; letter-spacing:-0.5px; color:var(--text); }
.logo-wordmark em { color:var(--red); font-style:normal; }

/* Nav danger variant */
.nav-danger { color:var(--red) !important; }
.nav-danger:hover { background:var(--red-subtle) !important; }

/* Stat card text */
.stat-val { font-size:22px; font-weight:800; letter-spacing:-0.5px; line-height:1; margin-bottom:3px; }
.stat-lbl { font-size:11.5px; color:var(--text-muted); font-weight:500; }

/* Topbar title */
.topbar-title { font-size:15px; font-weight:700; letter-spacing:-0.2px; white-space:nowrap; }

/* Admin tag */
.admin-tag { display:inline-flex; align-items:center; gap:4px; background:rgba(232,25,44,0.12); border:1px solid rgba(232,25,44,0.22); color:var(--red); padding:2px 8px; border-radius:4px; font-size:9.5px; font-weight:700; text-transform:uppercase; letter-spacing:1px; }
