﻿/* ═══════════════════════════════════════════
   LIGHT MODE — DEFAULT (putih bersih)
   Toggle class: body.dark = DARK MODE
   ═══════════════════════════════════════════ */
:root{
  /* === BASE COLORS — selaras landing.html === */
  --bg:#F8F8F6;--surface:#FFFFFF;--bg-surface:#FFFFFF;
  --bg-card:#FFFFFF;--bg-elevated:#F2F2F0;--bg-hover:#EBEBEA;
  --border:#EAEAE6;--border2:#D5D5CF;--border3:#C0C0BA;
  --text:#141412;--text2:#5C5C57;--text3:#98988F;

  /* === ACCENT — Blue (selaras landing) === */
  --accent:#2563EB;--accent-lt:#EFF6FF;--accent-dk:#1D4ED8;
  --accent-mid:rgba(37,99,235,0.18);--accent-hover:#2563EB;
  --accent-glow:0 0 20px rgba(37,99,235,0.20);

  /* === SEMANTIC COLORS === */
  --blue:#2563EB;--blue-lt:#EFF6FF;--blue-glow:0 0 20px rgba(37,99,235,0.20);
  --green:#16A34A;--green-lt:#F0FDF4;--green-dk:#15803D;
  --red:#DC2626;--red-lt:#FEF2F2;
  --orange:#D97706;--orange-lt:#FFFBEB;
  --purple:#7C3AED;--purple-lt:#F5F3FF;
  --teal:#0D9488;--teal-lt:#F0FDFA;

  /* === STAT TILE COLORS === */
  --tile-blue:#2563EB;--tile-green:#16A34A;--tile-orange:#D97706;
  --tile-red:#DC2626;--tile-purple:#7C3AED;

  /* === SIDEBAR === */
  --sb-bg:#1E293B;--sb-text:#CBD5E1;--sb-text-hover:#FFFFFF;
  --sb-label:#94A3B8;--sb-border:rgba(255,255,255,0.06);
  --sb-hover:#0F172A;--sb-active-bg:#2563EB;--sb-active-color:#FFFFFF;
  --sidebar-w:230px;

  /* === HEADER === */
  --header-bg:#FFFFFF;--header-border:#EAEAE6;
  --glass-bg:rgba(255,255,255,0.97);--glass-border:#EAEAE6;--glass-blur:blur(12px);

  /* === RADIUS — selaras landing === */
  --radius:8px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;

  /* === SHADOW === */
  --shadow:0 1px 3px rgba(0,0,0,0.06);
  --shadow-sm:0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 4px 16px rgba(0,0,0,0.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.10);
  --shadow-xl:0 20px 48px rgba(0,0,0,0.14),0 6px 16px rgba(0,0,0,0.08);

  /* === FONT — selaras landing === */
  --font-display:'Plus Jakarta Sans','Helvetica Neue',sans-serif;
  --font-body:'DM Sans',-apple-system,sans-serif;
  --font-mono:'DM Mono','Courier New',monospace;

  /* === LAYOUT === */
  --topbar-h:57px;--transition:.2s ease;--transition-md:.25s ease;
}

/* ═══════════════════════════════════════════
   DARK MODE — body.dark class (toggle)
   Dark AI Infrastructure aesthetic
   ═══════════════════════════════════════════ */
body.dark,[data-theme="dark"],body.dark-mode{
  --bg:#090909;--surface:#0e0e0e;--bg-surface:#0e0e0e;
  --bg-card:#111111;--bg-elevated:#161616;--bg-hover:#1a1a1a;
  --border:#272727;--border2:#333333;--border3:#444444;
  --text:#ffffff;--text2:#B8B8B8;--text3:#555555;
  --accent:#60A5FA;--accent-lt:rgba(96,165,250,0.10);--accent-dk:#3B82F6;
  --accent-mid:rgba(96,165,250,0.18);--accent-hover:#60A5FA;
  --accent-glow:0 0 20px rgba(96,165,250,0.25);
  --blue:#60A5FA;--blue-lt:rgba(96,165,250,0.10);--blue-glow:0 0 20px rgba(96,165,250,0.25);
  --green:#34D399;--green-lt:rgba(52,211,153,0.12);--green-dk:#10B981;
  --red:#F87171;--red-lt:rgba(248,113,113,0.12);
  --orange:#FBBF24;--orange-lt:rgba(251,191,36,0.12);
  --purple:#A78BFA;--purple-lt:rgba(167,139,250,0.12);
  --teal:#2DD4BF;--teal-lt:rgba(45,212,191,0.12);
  --sb-bg:#0e0e0e;--sb-text:#B8B8B8;--sb-text-hover:#FFFFFF;
  --sb-label:#555555;--sb-border:rgba(255,255,255,0.06);
  --sb-hover:#161616;--sb-active-bg:#3B82F6;--sb-active-color:#FFFFFF;
  --header-bg:#0e0e0e;--header-border:#272727;
  --glass-bg:#111111;--glass-border:#272727;--glass-blur:blur(12px);
  --shadow:0 1px 3px rgba(0,0,0,0.60);
  --shadow-sm:0 1px 2px rgba(0,0,0,0.50);
  --shadow-md:0 4px 16px rgba(0,0,0,0.70);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.80);
  --shadow-xl:0 20px 48px rgba(0,0,0,0.90),0 6px 16px rgba(0,0,0,0.60);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .2s,color .2s}
.hidden{display:none!important}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.15);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,0.28)}
::-webkit-scrollbar-track{background:transparent}
body.dark ::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12)}
body.dark ::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.20)}

/* ── AUTH — SPLIT LAYOUT ── */
#auth-page{min-height:100vh;display:flex;background:#090909}
.auth-split{display:flex;width:100%;min-height:100vh}

/* ── FORM SIDE (LEFT) ── */
.auth-left{
  flex:1;min-width:0;background:#090909;
  position:relative;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:80px 48px 60px;overflow-y:auto
}
.auth-logo{position:absolute;top:28px;left:40px;display:flex;align-items:center;gap:10px}
.auth-logo-icon{
  width:38px;height:38px;
  background:linear-gradient(135deg,#2563EB,#1D4ED8);
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 0 20px rgba(37,99,235,.25)
}
.auth-logo-icon svg{width:18px;height:18px;stroke:#fff;stroke-width:2.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.auth-logo-name{font-family:var(--font-display);font-size:18px;font-weight:800;color:#fff;letter-spacing:-.04em}
.auth-left-inner{width:100%;max-width:384px}

/* ── VISUAL SIDE (RIGHT) ── */
.auth-right{
  display:none;
  flex:0 0 46%;background:#090909;
  position:relative;overflow:hidden;
  align-items:center;justify-content:center
}
.auth-right::before{
  content:'';position:absolute;
  width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.10) 0%,transparent 65%);
  top:-120px;right:-100px;pointer-events:none
}
.auth-right::after{
  content:'';position:absolute;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.07) 0%,transparent 65%);
  bottom:-80px;left:-60px;pointer-events:none
}
.auth-right-bg{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,0.04) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none
}
.auth-right-inner{position:relative;z-index:1;display:flex;align-items:center;gap:20px}
.auth-right .auth-logo-icon{
  width:44px;height:44px;border-radius:12px;
  margin:0;flex-shrink:0;
  box-shadow:0 0 28px rgba(37,99,235,.40),0 4px 16px rgba(0,0,0,.5)
}
.auth-right .auth-logo-icon svg{width:20px;height:20px}
.auth-right-brand{font-family:var(--font-display);font-size:22px;font-weight:700;color:#fff;letter-spacing:-.04em;white-space:nowrap}
.auth-right-vline{width:1px;height:32px;background:rgba(255,255,255,0.5);flex-shrink:0}
.auth-right-moto{font-size:22px;font-weight:400;color:rgba(255,255,255,0.7);white-space:nowrap;font-family:var(--font-display)}

/* ── AUTH FORM CARD ── */
.auth-card{background:transparent;border:none;padding:0;box-shadow:none;animation:authFadeUp .35s ease both}
.auth-card::before{display:none}
body.dark .auth-card{background:transparent;border-color:transparent}
.auth-title{font-family:var(--font-display);font-size:23px;font-weight:500;color:#fff;margin-bottom:6px;letter-spacing:-.03em;line-height:1.3}
.auth-subtitle{font-size:13px;color:#B8B8B8;margin-bottom:24px;line-height:1.6}
.auth-card .field{margin-bottom:16px}
.auth-card .field label{display:block;font-size:14px;font-weight:400;color:#B8B8B8;margin-bottom:8px;letter-spacing:0}
.auth-card .field input{
  width:100%;padding:10px 16px;
  background:#0e0e0e;border:none;outline:1px solid #272727;
  border-radius:12px;font-size:14px;font-family:inherit;color:#fff;
  transition:outline-color .15s;box-sizing:border-box
}
.auth-card .field input::placeholder{color:#555}
.auth-card .field input:focus{outline:2px solid #353535;outline-offset:0}
.auth-pw-wrap{position:relative}
.auth-pw-wrap input{padding-right:44px}
.auth-pw-toggle{
  position:absolute;right:13px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;color:#B8B8B8;
  display:flex;align-items:center;padding:0;transition:color .15s
}
.auth-pw-toggle:hover{color:#fff}
.auth-pw-toggle svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.auth-btn{
  width:100%;padding:12px;
  background:#2563EB;border:none;outline:1px solid #1D4ED8;border-radius:8px;
  color:#fff;font-size:14.5px;font-weight:500;font-family:inherit;cursor:pointer;
  box-shadow:inset 0 3px 4px rgba(255,255,255,.10),inset 0 -3px 4px rgba(0,0,0,.20),0 0 16px rgba(37,99,235,.25);
  transition:opacity .15s;text-shadow:0 1px 2px rgba(0,0,0,.15)
}
.auth-btn:hover{opacity:.9}
.auth-btn:disabled{cursor:not-allowed;opacity:.55}
.auth-switch{text-align:center;margin-top:20px;font-size:13.5px;color:#B8B8B8}
.auth-switch a{color:#2563EB;cursor:pointer;font-weight:400}
.auth-switch a:hover{opacity:.8}
.auth-form-logo{display:none}
.auth-google-btn{
  width:100%;padding:11px 16px;
  background:#0e0e0e;border:none;outline:1px solid #272727;border-radius:12px;
  color:#fff;font-size:14px;font-family:inherit;
  display:flex;align-items:center;justify-content:center;gap:10px;
  cursor:pointer;transition:background .15s;margin-bottom:16px
}
.auth-google-btn:hover{background:#181818}
.auth-google-btn:disabled{opacity:.5;cursor:not-allowed}
.auth-divider{display:flex;align-items:center;margin:0 0 16px}
.auth-divider-line{flex:1;height:1px;background:#272727}
.auth-divider-text{margin:0 10px;font-size:12px;color:#555;white-space:nowrap}
.auth-footer{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:20px;font-size:11.5px;color:#555}
.auth-footer a{color:#555;text-decoration:none;transition:color .15s}
.auth-footer a:hover{color:#B8B8B8}
.auth-footer span{color:#444}

@keyframes authFadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

@media(min-width:768px){.auth-right{display:flex}}
@media(max-width:767px){.auth-left{padding:80px 28px 50px}.auth-logo{left:24px}}
@media(max-width:400px){.auth-left{padding:72px 20px 40px}.auth-logo{left:20px}}

/* ── FIELDS ── */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:5px;letter-spacing:0;font-family:var(--font-body)}
.field input,.field select,.field textarea{
  width:100%;padding:8px 12px;
  background:var(--bg-card);border:1px solid var(--border2);
  border-radius:var(--radius);font-size:13.5px;font-family:var(--font-body);
  color:var(--text);outline:none;
  transition:border-color var(--transition),box-shadow var(--transition)
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(37,99,235,.15)
}
.field input::placeholder{color:var(--text3)}
.field select option{background:var(--bg-card);color:var(--text)}
body.dark .field input,body.dark .field select,body.dark .field textarea{background:var(--bg-elevated);border-color:var(--border2)}
body.dark .field select option{background:var(--bg-elevated)}
.field-hint{font-size:11px;color:var(--text3);margin-top:4px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:1px solid transparent;transition:all var(--transition);white-space:nowrap;letter-spacing:.01em}
.btn-full{width:100%}

/* Primary — teal */
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent-dk);box-shadow:none}
.btn-primary:hover{background:var(--accent-dk);border-color:var(--accent-dk);box-shadow:0 2px 5px rgba(37,99,235,.35);transform:none}
.btn-primary:active{opacity:.9}.btn-primary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}

/* Success — ghost teal */
.btn-success{background:var(--green-lt);color:var(--green);border-color:rgba(22,163,74,.30)}
.btn-success:hover{background:rgba(22,163,74,.15);border-color:rgba(22,163,74,.40)}

/* Danger — solid red */
.btn-danger{background:var(--red-lt);color:var(--red);border-color:rgba(231,76,60,0.30)}
.btn-danger:hover{background:rgba(231,76,60,0.18);border-color:rgba(231,76,60,0.50)}

/* Warn — solid orange */
.btn-warn{background:var(--orange-lt);color:var(--orange);border-color:rgba(243,156,18,0.30)}
.btn-warn:hover{background:rgba(243,156,18,0.18);border-color:rgba(243,156,18,0.50)}

/* Ghost — outline */
.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border2)}
.btn-ghost:hover{background:var(--bg-elevated);color:var(--text);border-color:var(--border2)}

.btn-sm{padding:6px 13px;font-size:12px}
.btn-xs{padding:4px 9px;font-size:11px;border-radius:var(--radius)}.btn-xs:active{opacity:.8}
/* ── MESSAGES ── */
.msg{font-size:12px;padding:10px 13px;border-radius:var(--radius-md);margin:10px 0;display:flex;align-items:flex-start;gap:9px;line-height:1.5;border:1px solid transparent;border-left-width:2px;border-left-style:solid;font-family:var(--font-mono)}
.msg svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:2px}
.msg-error{background:var(--red-lt);color:var(--red);border-color:rgba(248,81,73,0.18);border-left-color:var(--red)}
.msg-success{background:var(--green-lt);color:var(--green);border-color:rgba(22,163,74,.25);border-left-color:var(--green)}
.msg-info{background:var(--blue-lt);color:var(--blue);border-color:rgba(56,139,253,0.18);border-left-color:var(--blue)}
.msg-warn{background:var(--orange-lt);color:var(--orange);border-color:rgba(210,153,34,0.18);border-left-color:var(--orange)}

/* ── APP LAYOUT ── */
#app{display:flex;min-height:100vh}

/* ── SIDEBAR — Gentelella dark navy ── */
.sidebar{width:var(--sidebar-w);background:var(--sb-bg);border-right:none;box-shadow:2px 0 5px rgba(0,0,0,0.2);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;overflow:hidden;transition:transform var(--transition-md);z-index:200}
.sidebar-header{padding:18px 16px;border-bottom:1px solid var(--sb-border);flex-shrink:0;background:var(--sb-hover)}
.sidebar-brand{font-family:var(--font-display);font-size:16px;font-weight:700;display:flex;align-items:center;gap:10px;letter-spacing:.02em;color:#FFFFFF;margin-bottom:0}
.sidebar-brand-icon{width:32px;height:32px;background:var(--accent);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-brand-icon svg{width:16px;height:16px;stroke:#fff;stroke-width:2.5;fill:none;stroke-linecap:round}
/* AI status badge */
.sb-ai-status{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:rgba(37,99,235,.15);border:1px solid rgba(37,99,235,.30);border-radius:3px;font-size:11px;font-weight:600;color:var(--accent);font-family:var(--font-body);width:fit-content;margin:10px 16px 0}
.sb-ai-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0;animation:aiPulse 2s ease infinite}
@keyframes aiPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0}
.sb-section{padding:2px 0}.sidebar-section{padding:2px 0}
.sidebar-section-label{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--sb-label);padding:16px 16px 6px;opacity:.7;white-space:nowrap}
.sb-admin-lbl{color:var(--sb-label)}
.sb-admin-divider{display:flex;align-items:center;gap:7px;margin:4px 0 2px;padding:10px 16px 4px;font-size:11px;font-weight:700;color:var(--sb-label);letter-spacing:.08em;border-top:1px solid var(--sb-border);opacity:.7}
.sidebar-sep{display:none}
.menu-item{display:flex;align-items:center;gap:10px;padding:11px 16px;margin:0;border-radius:0;border-left:3px solid transparent;cursor:pointer;color:var(--sb-text);font-size:13px;font-weight:400;transition:all var(--transition);user-select:none;position:relative}
.menu-item:hover{background:var(--sb-hover);color:#FFFFFF;border-left-color:var(--accent)}
.menu-item.active{background:var(--sb-active-bg);color:#FFFFFF;font-weight:600;border-left-color:transparent;box-shadow:none;border-top:none;border-right:none;border-bottom:none}
.menu-item .icon{width:17px;height:17px;flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .15s}
.menu-item.active .icon,.menu-item:hover .icon{opacity:1}
.menu-item .icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.menu-item.logout{color:rgba(231,76,60,0.80)}.menu-item.logout:hover{background:rgba(231,76,60,0.10);color:#E74C3C;border-left-color:#E74C3C}
.menu-item.soon{opacity:.35;cursor:default}
.soon-tag{margin-left:auto;font-size:9px;font-weight:600;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.35);padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;font-family:var(--font-mono)}
.menu-badge{background:var(--red);color:#fff;font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;margin-left:auto;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--font-mono);animation:badgePop .3s cubic-bezier(.34,1.56,.64,1)}
.menu-badge.hidden{display:none!important}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}
@keyframes badgePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.menu-sub{padding:8px 10px 8px 44px;font-size:12px;color:var(--sb-text);border-left:3px solid transparent}
.menu-sub:hover{background:var(--sb-hover);color:#FFFFFF;border-left-color:var(--accent)}
.menu-sub.active-sub{color:#FFFFFF;background:rgba(37,99,235,.12);border-left-color:var(--accent)}

/* ── SIDEBAR BOTTOM ── */
.sidebar-bottom{flex-shrink:0;border-top:1px solid var(--sb-border);padding:10px 0 12px;background:var(--sb-hover)}
.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 16px;border-radius:0;cursor:pointer;transition:background .15s;margin-bottom:2px;border-left:3px solid transparent}
.sidebar-user:hover{background:rgba(255,255,255,0.05);border-left-color:var(--accent)}
.sidebar-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#FFFFFF}
.sidebar-user-role{font-size:10.5px;color:var(--sb-text);margin-top:1px;font-family:var(--font-mono)}

/* ── THEME TOGGLE ── */
.theme-toggle{display:flex;align-items:center;gap:9px;padding:8px 16px;margin:0;border-radius:0;border-left:3px solid transparent;cursor:pointer;color:var(--sb-text);font-size:12px;font-weight:400;transition:all .15s;user-select:none}
.theme-toggle:hover{background:rgba(255,255,255,0.05);color:#FFFFFF;border-left-color:var(--accent)}
.ti-wrap{width:17px;height:17px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.ti-wrap svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ti-moon{display:block}.ti-sun{display:none}
body.dark .ti-moon{display:none}
body.dark .ti-sun{display:block}
.theme-toggle-lbl{flex:1;font-size:12px}
.theme-pill{width:30px;height:17px;border-radius:9px;background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.20);position:relative;flex-shrink:0;transition:background .2s,border-color .2s}
.theme-pill::after{content:'';position:absolute;top:2px;left:2px;width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,0.60);transition:transform .2s,background .2s}
body.dark .theme-pill{background:rgba(96,165,250,0.30);border-color:rgba(96,165,250,0.55)}
body.dark .theme-pill::after{transform:translateX(13px);background:#fff}
/* ── HAMBURGER ── */
.hamburger{display:none;position:fixed;top:14px;left:14px;z-index:300;width:38px;height:38px;border-radius:8px;background:var(--surface);border:1px solid var(--border);cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--shadow-md);flex-direction:column;gap:5px;padding:10px}
.hamburger span{display:block;width:18px;height:2px;background:var(--text2);border-radius:2px;transition:all var(--transition)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150}

/* ── MAIN ── */
.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh;transition:margin var(--transition);display:flex;flex-direction:column}

/* ── TOPBAR — Gentelella white clean ── */
.topbar{height:var(--topbar-h);position:sticky;top:0;z-index:101;background:var(--header-bg);border-bottom:1px solid var(--header-border);box-shadow:0 1px 3px rgba(0,0,0,0.06);display:flex;align-items:center;justify-content:space-between;padding:0 20px 0 16px;flex-shrink:0;transition:background var(--transition),border-color var(--transition)}
body.dark .topbar{background:var(--header-bg);border-bottom-color:var(--header-border)}
.tb-ham{width:34px;height:34px;border-radius:var(--radius);background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:all var(--transition)}
.tb-ham:hover{background:var(--bg-hover);color:var(--text)}
.tb-ham svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tb-right{display:flex;align-items:center;gap:4px}
.tb-icon-btn{width:35px;height:35px;border-radius:var(--radius);background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:all var(--transition);position:relative}
.tb-icon-btn:hover{background:var(--bg-hover);color:var(--text)}
#notif-bell-btn.has-unread{color:var(--accent)}
#notif-bell-btn.has-unread svg{stroke:var(--accent)}
.tb-sep{width:1px;height:20px;background:var(--border);margin:0 6px}
.tb-user{display:flex;align-items:center;gap:9px;padding:5px 10px 5px 6px;border-radius:var(--radius);cursor:pointer;transition:all var(--transition);border:1px solid transparent;margin-left:4px}
.tb-user:hover{background:var(--bg-hover);border-color:var(--border)}
.tb-user.open{background:var(--bg-hover);border-color:var(--border2)}
.tb-avatar{width:35px;height:35px;border-radius:50%;background:var(--accent);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid var(--border)}
body.dark .tb-avatar{border-color:var(--border2)}
.tb-user-info{line-height:1.3}
.tb-username{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap}
.tb-role{font-size:10px;color:var(--text2);white-space:nowrap;font-family:var(--font-mono)}
.tb-user-wrap{position:relative}
.tb-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:192px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:500;padding:4px;animation:ddFadeIn .15s ease}
@keyframes ddFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.tb-dd-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:400;color:var(--text2);transition:all var(--transition)}
.tb-dd-item:hover{background:var(--bg-hover);color:var(--text)}
.tb-dd-item svg{width:14px;height:14px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tb-dd-divider{height:1px;background:var(--border);margin:4px 0}
.tb-dd-danger{color:var(--red)}
.tb-dd-danger:hover{background:var(--red-lt);color:var(--red)}
body.dark .tb-dropdown{background:var(--bg-card);border-color:var(--border)}
/* ── PAGE HEADER — Gentelella clean ── */
.page-header{padding:14px 25px;border-bottom:1px solid var(--border);background:var(--header-bg);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;position:sticky;top:var(--topbar-h);z-index:100;box-shadow:0 1px 2px rgba(0,0,0,0.04)}
body.dark .page-header{background:var(--header-bg);border-bottom-color:var(--border)}
.page-title{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:0;color:var(--text)}
.page-subtitle{font-size:13px;color:var(--text2);margin-top:2px;font-family:var(--font-body);letter-spacing:0}
.page-content{padding:20px 25px}
.page-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text3);margin-bottom:4px}
.breadcrumb span{color:var(--text3)}
.breadcrumb a{color:var(--text2);cursor:pointer}.breadcrumb a:hover{color:var(--accent)}
/* -- TABS -- */
.tabs{display:flex;gap:0;background:transparent;border:none;border-bottom:1px solid var(--border);border-radius:0;padding:0;margin-bottom:18px}
.tab{flex:none;text-align:center;padding:10px 16px;border-radius:0;font-size:13px;font-weight:400;cursor:pointer;color:var(--text2);transition:all var(--transition);border-bottom:2px solid transparent;margin-bottom:-1px}
.tab:hover{color:var(--text);background:var(--bg-hover)}
.tab.active{background:transparent;color:var(--accent);font-weight:600;border:none;border-bottom:2px solid var(--accent);box-shadow:none}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:14px;margin-bottom:20px}

/* Base tile */
.stat-card{
  border-radius:var(--radius-md);padding:18px 20px;position:relative;overflow:hidden;
  border:none;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease;
  cursor:default;color:#fff;background:var(--tile-blue);
}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat-card::before{display:none}
.stat-card::after{display:none}

/* Solid color per position */
.stat-card:nth-child(1){background:var(--tile-blue)}
.stat-card:nth-child(2){background:var(--tile-green)}
.stat-card:nth-child(3){background:var(--tile-orange)}
.stat-card:nth-child(4){background:var(--tile-red)}
.stat-card:nth-child(5){background:var(--tile-purple)}

/* Override for semantic states */
.stat-card.bot-active{background:var(--tile-green);color:#fff;border:none;box-shadow:var(--shadow)}
.stat-card.bot-active:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat-card.bot-secondary{background:var(--tile-blue);color:#fff;border:none;box-shadow:var(--shadow)}
.stat-card.bot-alert{background:var(--tile-red);color:#fff;border:none;box-shadow:var(--shadow)}

/* Icon — small on top */
.stat-icon{
  width:34px;height:34px;border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;margin-bottom:12px;
  background:rgba(255,255,255,0.20);border:none;flex-shrink:0;
}
.stat-card.bot-active .stat-icon,
.stat-card.bot-secondary .stat-icon,
.stat-card.bot-alert .stat-icon{background:rgba(255,255,255,0.20);border:none}

/* Label */
.stat-label{
  font-size:12px;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:rgba(255,255,255,0.85);
  margin-bottom:6px;font-family:var(--font-body);
}
.stat-card.bot-active .stat-label{color:rgba(255,255,255,0.85)}

/* Value */
.stat-value{
  font-size:38px;font-weight:700;color:#fff;
  font-family:var(--font-display);letter-spacing:-.02em;
  line-height:1;display:block;
}
.stat-card.bot-active .stat-value{color:#fff}

/* Sub */
.stat-sub{font-size:12px;color:rgba(255,255,255,0.70);margin-top:6px;font-family:var(--font-body)}
.stat-trend{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:3px;margin-top:8px;letter-spacing:.01em;background:rgba(255,255,255,0.20);color:#fff;border:none}
.stat-trend.up{background:rgba(255,255,255,0.20);color:#fff;border:none}
.stat-trend.down{background:rgba(0,0,0,0.15);color:#fff;border:none}
/* -- CARD -- */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow);transition:box-shadow var(--transition)}
.card:hover{border-color:var(--border2);box-shadow:var(--shadow-md)}
body.dark .card:hover{border-color:var(--border2);box-shadow:var(--shadow-md)}
.card-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:14px 18px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:8px}
.card-title{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:0;color:var(--text)}
.card-subtitle{font-size:12px;color:var(--text2);margin-top:2px;font-weight:400;font-family:var(--font-body)}
.card-body{padding:18px}
.table-wrap{overflow-x:auto}
#trx-table{table-layout:fixed;width:100%}
#trx-table td,#trx-table th{overflow:hidden;text-overflow:ellipsis}
table{width:100%;border-collapse:collapse;font-family:var(--font-body)}
th{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text2);padding:10px 14px;border-bottom:2px solid var(--border);background:var(--bg-elevated);text-align:left;white-space:nowrap}
td{padding:12px 14px;font-size:13.5px;color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle;transition:background var(--transition)}
tr:last-child td{border-bottom:none}
tbody tr{transition:background var(--transition)}
tbody tr:hover td{background:var(--bg-elevated)!important}
tbody tr:nth-child(even) td{background:rgba(0,0,0,0.015)}
tbody tr:nth-child(even):hover td{background:var(--bg-elevated)!important}
body.dark tbody tr:nth-child(even) td{background:rgba(255,255,255,0.02)}
body.dark tbody tr:hover td{background:var(--bg-hover)!important}
body.dark tbody tr:nth-child(even):hover td{background:var(--bg-hover)!important}
.td-mono{font-family:var(--font-mono);font-size:11.5px;color:var(--text2)}

.empty-state{text-align:center;padding:48px 24px;color:var(--text3);font-size:13px}
td.empty-state{padding:40px 24px;color:var(--text3);font-size:13px;text-align:center;font-style:normal}
.empty-state-icon{display:flex;align-items:center;justify-content:center;margin-bottom:14px;opacity:.35}
.empty-state-icon svg{width:40px;height:40px;stroke:var(--text3);fill:none;stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round}
.empty-state-title{font-size:14px;font-weight:600;color:var(--text2);margin-bottom:6px}
.empty-state-desc{font-size:12.5px;color:var(--text3);max-width:280px;margin:0 auto;line-height:1.6}

/* ── SKELETON ── */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.8s infinite;border-radius:4px;display:inline-block}
.skeleton-line{height:11px;border-radius:6px;margin-bottom:8px}
.skeleton-text{width:60%}.skeleton-title{width:40%;height:15px}.skeleton-full{width:100%}
.skeleton-row{display:flex;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);align-items:center}

/* ── PAGINATION ── */
.pagination{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-top:1px solid var(--border);background:var(--bg-elevated)}
.pagination-info{font-size:11px;color:var(--text3);font-family:var(--font-mono)}
.pagination-btns{display:flex;gap:3px}
.page-btn{padding:4px 10px;border-radius:4px;border:1px solid var(--border);background:transparent;font-size:11px;cursor:pointer;color:var(--text3);font-family:var(--font-body);transition:all var(--transition);font-weight:500}
.page-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text2);border-color:var(--border2)}
.page-btn.active{background:rgba(37,99,235,.10);color:var(--accent);border-color:rgba(37,99,235,.28);font-weight:600}
.page-btn:disabled{opacity:.3;cursor:not-allowed}
#article-pagination:not(:empty){position:sticky;bottom:0;background:var(--bg-elevated);border-top:1px solid var(--border);z-index:20;box-shadow:0 -2px 16px rgba(0,0,0,.3);margin:0 -28px;padding:0 28px}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:3px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-family:var(--font-body);border:1px solid transparent}
.badge::before{content:'';width:4px;height:4px;border-radius:50%;flex-shrink:0}

.badge-active,.badge-verified,.badge-healthy,.badge-confirmed,.badge-published{background:var(--green-lt);color:var(--green);border-color:rgba(22,163,74,.30)}
.badge-active::before,.badge-verified::before,.badge-healthy::before,.badge-confirmed::before,.badge-published::before{background:var(--green)}

.badge-pending,.badge-propagating{background:var(--orange-lt);color:var(--orange);border-color:rgba(243,156,18,0.30)}
.badge-pending::before,.badge-propagating::before{background:var(--orange)}

.badge-running{background:var(--accent-lt);color:var(--accent);border-color:rgba(37,99,235,.25)}
.badge-running::before{background:var(--accent)}

.badge-down,.badge-failed,.badge-rejected,.badge-suspended{background:var(--red-lt);color:var(--red);border-color:rgba(231,76,60,0.30)}
.badge-down::before,.badge-failed::before,.badge-rejected::before,.badge-suspended::before{background:var(--red)}

.badge-idle,.badge-paused,.badge-stopped,.badge-inactive,.badge-draft,.badge-cancelled{background:var(--bg-elevated);color:var(--text3);border-color:var(--border)}
.badge-idle::before,.badge-paused::before,.badge-stopped::before,.badge-inactive::before,.badge-draft::before,.badge-cancelled::before{background:var(--text3)}

.badge-info,.badge-blue{background:var(--blue-lt);color:var(--blue);border-color:rgba(52,152,219,0.30)}
.badge-info::before,.badge-blue::before{background:var(--blue)}
/* ── MODAL ── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .18s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;max-width:520px;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 5px 20px rgba(0,0,0,.15);animation:slideUp .22s ease}
@keyframes slideUp{from{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-sm{max-width:400px}.modal-lg{max-width:680px}
.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-elevated);border-radius:var(--radius-md) var(--radius-md) 0 0}
.modal-title{font-size:16px;font-weight:600;color:var(--text);font-family:var(--font-display);letter-spacing:0}
.modal-close{width:28px;height:28px;border-radius:4px;border:none;background:transparent;cursor:pointer;color:var(--text3);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.modal-close:hover{background:var(--red-lt);color:var(--red)}
.modal-body{padding:18px 20px;overflow-y:auto;flex:1}
.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--bg-elevated)}
body.dark .overlay{background:rgba(0,0,0,.72)}
body.dark .modal{background:var(--surface);border-color:var(--border)}

/* ── FORM HELPERS ── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-section{margin-bottom:18px}
.form-section-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.10em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border);font-family:var(--font-mono)}
.tag-wrap{display:flex;flex-wrap:wrap;gap:5px;padding:7px 8px;border:1px solid var(--border);border-radius:var(--radius-md);min-height:40px;cursor:text;transition:all var(--transition);background:var(--bg-elevated)}
.tag-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px rgba(37,99,235,.15)}
.tag{background:var(--accent-lt);color:var(--accent);padding:2px 8px;border-radius:3px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:4px;border:1px solid rgba(37,99,235,.22);font-family:var(--font-body)}
.tag button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:0;line-height:1}
.tag-wrap input{border:none;outline:none;font-size:13px;font-family:inherit;flex:1;min-width:80px;padding:2px 4px;background:transparent;color:var(--text)}

/* ── NS BOX ── */
.ns-box{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;margin:10px 0}
.ns-item{font-family:var(--font-mono);font-size:12px;color:var(--text);background:var(--bg);border:1px solid var(--border);padding:8px 12px;border-radius:6px;margin:5px 0;display:flex;align-items:center;justify-content:space-between}
.ns-copy{font-size:10.5px;color:var(--accent);cursor:pointer;font-family:var(--font-mono);font-weight:600}
.ns-copy:hover{color:var(--accent-dk)}

/* ── STEPS ── */
.steps{display:flex;align-items:center;margin-bottom:20px}
.step{display:flex;align-items:center;flex:1}
.step-dot{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text3);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition);font-family:var(--font-body)}
.step.active .step-dot{border-color:var(--accent);background:rgba(37,99,235,.10);color:var(--accent);box-shadow:0 0 0 3px var(--accent-lt)}
.step.done .step-dot{border-color:var(--green);background:var(--green);color:#000}
.step-label{font-size:11px;color:var(--text3);margin-left:7px;font-weight:500;white-space:nowrap;font-family:var(--font-mono)}
.step.active .step-label{color:var(--accent);font-weight:600}
.step.done .step-label{color:var(--green)}
.step-line{flex:1;height:1px;background:var(--border);margin:0 8px;border-radius:1px;overflow:hidden}
.step-line-fill{height:100%;width:0%;background:var(--green);border-radius:1px;transition:width .4s ease}

/* ── PROFILE HERO ── */
.profile-hero{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px 28px;display:flex;align-items:center;gap:22px;margin-bottom:20px;flex-wrap:wrap}
.profile-hero-avatar{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,#2563EB,#1D4ED8);color:#fff;font-size:26px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 20px rgba(37,99,235,.30);letter-spacing:-.02em}
body.dark .profile-hero-avatar{color:#fff;box-shadow:0 0 20px rgba(96,165,250,.25)}
.profile-hero-info{flex:1;min-width:180px}
.profile-hero-name{font-family:var(--font-display);font-size:19px;font-weight:800;color:var(--text);letter-spacing:-.03em}
.profile-hero-email{font-size:12px;color:var(--text3);margin-top:3px;font-family:var(--font-body)}
.profile-hero-badges{display:flex;gap:7px;margin-top:10px;flex-wrap:wrap}
.profile-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:3px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-family:var(--font-body);border:1px solid transparent}
.profile-badge-role{background:var(--accent-lt);color:var(--accent);border-color:rgba(37,99,235,.22)}
.profile-badge-status{background:var(--green-lt);color:var(--green);border-color:rgba(22,163,74,.25)}
.profile-hero-stats{display:flex;gap:24px;flex-shrink:0}
.profile-hero-stat{text-align:center;padding:0 4px}
.profile-hero-stat-val{font-size:15px;font-weight:800;color:var(--text);font-family:var(--font-display);letter-spacing:-.03em}
.profile-hero-stat-lbl{font-size:10px;color:var(--text3);margin-top:3px;font-weight:500;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}
/* keep old id reference working */
.profile-avatar-lg{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--blue));color:#000;font-size:26px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ── SETTINGS ── */
.settings-group{margin-bottom:24px}
.settings-group-title{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.12em;margin-bottom:9px;padding:0 2px;font-family:var(--font-mono)}
.settings-row{display:flex;align-items:center;gap:14px;padding:13px 18px}
.settings-row+.settings-row{border-top:1px solid var(--border)}
.settings-row-clickable{cursor:pointer;transition:background var(--transition)}
.settings-row-clickable:hover{background:var(--bg-hover)}
.settings-row-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--border)}
.settings-row-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.settings-icon-purple{background:var(--purple-lt);color:var(--purple);border-color:rgba(188,140,255,0.20)}
.settings-icon-green{background:var(--green-lt);color:var(--green);border-color:rgba(22,163,74,.25)}
.settings-icon-blue{background:var(--blue-lt);color:var(--blue);border-color:rgba(56,139,253,0.20)}
.settings-icon-orange{background:var(--orange-lt);color:var(--orange);border-color:rgba(210,153,34,0.20)}
.settings-icon-red{background:var(--red-lt);color:var(--red);border-color:rgba(248,81,73,0.20)}
.settings-row-body{flex:1;min-width:0}
.settings-row-title{font-size:13px;font-weight:600;color:var(--text)}
.settings-row-sub{font-size:11.5px;color:var(--text3);margin-top:2px;line-height:1.4}
.settings-toggle{width:42px;height:24px;border-radius:12px;background:var(--bg-elevated);border:1px solid var(--border2);position:relative;transition:background .2s,border-color .2s;flex-shrink:0}
.settings-toggle.on{background:var(--accent);border-color:var(--accent)}
.settings-toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.35)}
.settings-toggle.on .settings-toggle-knob{transform:translateX(18px)}
body.dark .settings-toggle.on{background:var(--accent);border-color:var(--accent)}

/* ── INFO GRID ── */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}
.info-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;transition:all var(--transition);box-shadow:var(--shadow)}
.info-box:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.info-box-icon{font-size:22px;margin-bottom:10px}
.info-box-title{font-size:13px;font-weight:700;margin-bottom:4px;color:var(--text)}
.info-box-desc{font-size:12px;color:var(--text2);line-height:1.6}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}
.pricing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:22px;position:relative;transition:all var(--transition);box-shadow:var(--shadow-sm)}
.pricing-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.09)}
.pricing-card.popular{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-lt),0 1px 4px rgba(0,0,0,.06)}
.pricing-popular-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:3px 12px;border-radius:3px;white-space:nowrap;letter-spacing:.04em}
.pricing-name{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-family:var(--font-body)}
.pricing-price{font-size:26px;font-weight:800;font-family:var(--font-display);letter-spacing:-.02em;color:var(--text)}
.pricing-price span{font-size:12px;font-weight:400;color:var(--text3)}
.pricing-features{margin-top:14px;list-style:none}
.pricing-features li{font-size:12px;color:var(--text2);padding:5px 0;display:flex;align-items:center;gap:7px;border-bottom:1px solid var(--border)}
.pricing-features li:last-child{border-bottom:none}
.pricing-features li::before{content:'\2713';color:var(--green);font-weight:700;font-size:11px;flex-shrink:0;background:var(--green-lt);width:16px;height:16px;border-radius:3px;display:flex;align-items:center;justify-content:center}

/* ── ALERTS ── */
.alert{padding:11px 13px;border-radius:var(--radius-md);font-size:12px;margin-bottom:12px;display:flex;gap:9px;line-height:1.5;border:1px solid transparent;font-family:var(--font-body)}
.alert-info{background:var(--blue-lt);color:var(--blue);border-color:rgba(56,139,253,0.20)}
.alert-success{background:var(--green-lt);color:var(--green);border-color:rgba(22,163,74,.25)}
.alert-warn{background:var(--orange-lt);color:var(--orange);border-color:rgba(210,153,34,0.20)}
.alert-error{background:var(--red-lt);color:var(--red);border-color:rgba(248,81,73,0.20)}

/* ── DOMAIN STATUS BAR ── */
.domain-status-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:12px;display:flex;align-items:center;gap:12px}
.domain-status-bar.pending{border-color:rgba(210,153,34,0.28);background:var(--orange-lt)}
.domain-status-bar.verified{border-color:rgba(22,163,74,.22);background:rgba(22,163,74,.05)}
.domain-status-bar.failed{border-color:rgba(248,81,73,0.22);background:var(--red-lt)}
.domain-status-icon{font-size:18px;flex-shrink:0}
.domain-status-text{flex:1}
.domain-status-title{font-size:13px;font-weight:600;color:var(--text)}
.domain-status-sub{font-size:11.5px;color:var(--text2);margin-top:2px;font-family:var(--font-mono)}

/* ── TOAST ── */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:340px}
.toast{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-lg);pointer-events:auto;overflow:hidden;animation:toastIn .28s cubic-bezier(.34,1.4,.64,1) forwards;border-left:4px solid transparent;font-family:var(--font-body)}
.toast.success{border-left-color:var(--green)}
.toast.error{border-left-color:var(--red)}
.toast.warn{border-left-color:var(--orange)}
.toast.info{border-left-color:var(--blue)}
.toast-bar{display:none}
.toast-inner{display:flex;align-items:flex-start;gap:10px;padding:12px 12px 10px}
.toast-icon{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.toast-icon svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.toast.success .toast-icon{background:var(--green-lt);color:var(--green)}
.toast.error .toast-icon{background:var(--red-lt);color:var(--red)}
.toast.warn .toast-icon{background:var(--orange-lt);color:var(--orange)}
.toast.info .toast-icon{background:var(--blue-lt);color:var(--blue)}
.toast-body{flex:1;min-width:0;padding-top:1px}
.toast-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;font-family:var(--font-display)}
.toast-msg{font-size:12px;color:var(--text2);margin-top:3px;line-height:1.5;font-family:var(--font-body)}
.toast-close{background:none;border:none;color:var(--text3);cursor:pointer;flex-shrink:0;padding:2px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:.15s;margin-top:-1px}
.toast-close:hover{background:var(--red-lt);color:var(--red)}
.toast-close svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.toast-timer{height:3px;background:var(--border);overflow:hidden}
.toast-timer-bar{height:100%;width:100%;transition:width linear}
.toast.success .toast-timer-bar{background:var(--green)}.toast.warn .toast-timer-bar{background:var(--orange)}.toast.info .toast-timer-bar{background:var(--blue)}.toast.error .toast-timer-bar{background:var(--red)}
@keyframes toastIn{from{transform:translateX(16px);opacity:0}to{transform:translateX(0);opacity:1}}
body.dark .toast{background:var(--surface);border-color:var(--border);box-shadow:0 4px 16px rgba(0,0,0,.40)}
@keyframes toastOut{from{opacity:1;transform:translateX(0) scale(1)}to{opacity:0;transform:translateX(28px) scale(.96)}}

/* ── MISC ── */
.spinner{width:14px;height:14px;border:2px solid var(--border2);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.quick-amt{padding:8px 14px;border:1px solid var(--border);border-radius:4px;background:var(--bg-elevated);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-body);color:var(--text2);transition:all var(--transition)}
.quick-amt:hover{background:var(--bg-hover);border-color:var(--border2);color:var(--text)}
.quick-amt.selected{background:rgba(37,99,235,.10);border-color:rgba(37,99,235,.28);color:var(--accent)}

/* ── FILTER BAR ── */
.filter-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px 14px}
.filter-bar input,.filter-bar select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-family:var(--font-mono);outline:none;background:var(--bg);color:var(--text);transition:border-color var(--transition)}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(37,99,235,.15)}
.filter-bar input{min-width:190px}
.filter-bar select option{background:var(--bg-elevated);color:var(--text)}
/* inline filter controls inside cards */
.flt-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.flt-ctrl{padding:7px 11px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:12.5px;font-family:inherit;outline:none;background:var(--surface);color:var(--text);transition:border-color var(--transition);min-width:0}
.flt-ctrl:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(37,99,235,.15)}
.flt-ctrl-sm{padding:6px 10px;font-size:12px}
.flt-ctrl option{background:var(--bg-elevated);color:var(--text)}

/* ── PAGE ANIMATION ── */
[id^="page-"]{animation:pageIn .2s ease}
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ── INVOICE (print) ── */
@media print{body > *:not(#invoice-print-frame){display:none!important}#invoice-print-frame{display:block!important;position:fixed;inset:0;z-index:99999}@page{size:A4;margin:0}}
#invoice-print-frame{display:none;position:fixed;inset:0;background:#fff;z-index:99999;overflow:auto;padding:0}
.inv-page{width:210mm;min-height:297mm;margin:0 auto;padding:16mm 16mm 12mm;background:#fff;font-family:'DM Sans',Arial,sans-serif;font-size:10pt;color:#1A1A18;box-sizing:border-box;position:relative}
.inv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6mm}
.inv-brand-name{font-size:22pt;font-weight:800;color:#2563EB;letter-spacing:-.03em;margin-bottom:1mm}
.inv-brand-sub{font-size:8.5pt;color:#9B9B94}
.inv-label{text-align:right}.inv-label-text{font-size:28pt;font-weight:900;color:#2563EB;letter-spacing:-.04em}
.inv-label-no{font-size:10pt;color:#6B6B65;margin-top:1mm}
.inv-divider{border:none;border-top:3px solid #2563EB;margin:0 0 6mm}
.inv-meta{display:grid;grid-template-columns:1fr 1fr;gap:5mm;margin-bottom:6mm}
.inv-meta-box{background:#F8F8F6;padding:4mm 5mm;border-radius:3mm}
.inv-meta-label{font-size:7.5pt;font-weight:700;color:#9B9B94;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2mm}
.inv-meta-row{display:flex;justify-content:space-between;margin-bottom:1mm}
.inv-meta-key{color:#6B6B65;font-size:9.5pt}.inv-meta-val{font-weight:600;font-size:9.5pt}
.inv-status-lunas{color:#16A34A}.inv-status-pending{color:#D97706}
.inv-table{width:100%;border-collapse:collapse;margin-bottom:4mm}
.inv-table th{background:#2563EB;color:#fff;padding:2.5mm 3.5mm;font-size:8.5pt;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.inv-table th:last-child,.inv-table td:last-child{text-align:right}
.inv-table td{padding:3mm 3.5mm;border-bottom:1px solid #EAEAE6;font-size:9.5pt;vertical-align:top}
.inv-table tr:last-child td{border-bottom:none}
.inv-table-desc{font-weight:600;margin-bottom:.5mm}.inv-table-sub{font-size:8.5pt;color:#6B6B65}
.inv-total-row td{background:#EFF6FF;font-weight:700;color:#2563EB;font-size:11pt;border-top:2px solid #2563EB}
.inv-bottom{display:grid;grid-template-columns:1fr 1fr;gap:5mm;margin-top:5mm}
.inv-bank-box{border-left:4px solid #2563EB;background:#EFF6FF;padding:4mm 5mm;border-radius:0 3mm 3mm 0}
.inv-bank-label{font-size:7.5pt;font-weight:700;color:#9B9B94;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2mm}
.inv-bank-row{display:flex;justify-content:space-between;margin-bottom:1.5mm;font-size:9.5pt}
.inv-bank-key{color:#6B6B65}.inv-bank-val{font-weight:600}
.inv-bank-val.highlight{color:#2563EB;font-size:11pt}
.inv-note-box{padding:4mm 5mm}
.inv-note-label{font-size:7.5pt;font-weight:700;color:#9B9B94;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2mm}
.inv-note-text{font-size:9pt;color:#6B6B65;line-height:1.6}
.inv-footer{position:absolute;bottom:12mm;left:16mm;right:16mm;text-align:center;font-size:8pt;color:#9B9B94;border-top:1px solid #EAEAE6;padding-top:3mm}
.inv-close-btn{position:fixed;top:16px;right:16px;z-index:100000;background:var(--bg-elevated);color:var(--text);border:1px solid var(--border2);border-radius:8px;padding:8px 16px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
.inv-print-btn{position:fixed;top:16px;right:130px;z-index:100000;background:var(--accent);color:#000;border:none;border-radius:8px;padding:8px 16px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
body.dark .inv-print-btn{color:#fff}
@media print{.inv-close-btn,.inv-print-btn{display:none!important}}
#hist-trx-table{table-layout:auto}#hist-trx-table th,#hist-trx-table td{white-space:nowrap}
.inv-btn{font-size:11px!important;padding:3px 8px!important}

/* ── APP FOOTER ── */
.app-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:14px 28px;border-top:1px solid var(--border);background:var(--surface);margin-top:auto}
.app-footer-left,.app-footer-right{display:flex;align-items:center;gap:10px}
.app-footer-brand{display:flex;align-items:center;gap:7px;font-family:var(--font-display);font-size:12.5px;font-weight:700;color:var(--text2)}
.app-footer-icon{width:20px;height:20px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.app-footer-icon svg{width:11px;height:11px;stroke:#fff;stroke-width:2.5;fill:none;stroke-linecap:round}
.app-footer-sep{width:1px;height:14px;background:var(--border)}
.app-footer-copy{font-size:11.5px;color:var(--text3)}
.app-footer-status{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--green)}
.app-footer-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
.app-footer-ver{font-size:11px;color:var(--text3);font-family:var(--font-mono)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .hide-mobile{display:none!important}
  table th:nth-child(n+4):not(:last-child),table td:nth-child(n+4):not(:last-child){display:none}
  table.show-all th,table.show-all td{display:table-cell!important}
  .hamburger{display:none}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}
  .sidebar-overlay.show{display:block}
  .main{margin-left:0}
  .page-header{padding:14px 16px}
  .tb-user-info{display:none}
  .tb-sep{display:none}
  .page-content{padding:14px 16px}
  .stats-row{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  table{font-size:12px}
  th,td{padding:9px 10px}
  .modal{margin:10px}
  .toast-wrap{left:14px;right:14px;width:auto;bottom:16px}
}

/* ── NOTIFICATION BELL & PANEL ── */
.notif-bell{position:fixed;top:16px;right:20px;z-index:150;width:38px;height:38px;border-radius:50%;background:var(--surface);border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.notif-bell:hover{background:var(--accent-lt);border-color:var(--accent)}
.notif-bell svg{width:17px;height:17px;stroke:var(--text2);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke var(--transition)}
.notif-bell:hover svg,.notif-bell.has-unread svg{stroke:var(--accent)}
.notif-count{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;border-radius:9px;background:var(--red);color:#fff;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--surface);box-shadow:0 2px 6px rgba(220,38,38,0.3);animation:badgePop .3s cubic-bezier(.34,1.56,.64,1)}
.notif-count.hidden{display:none!important}
.notif-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:190;display:none}
.notif-overlay.show{display:block}
.notif-panel{position:fixed;top:0;right:-400px;width:380px;height:100vh;background:var(--bg-card);border-left:1px solid var(--border);box-shadow:var(--shadow-xl);z-index:200;display:flex;flex-direction:column;transition:right .3s cubic-bezier(.4,0,.2,1)}
.notif-panel.open{right:0}
.notif-panel-head{padding:14px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:transparent}
.notif-panel-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.02em}
.notif-panel-actions{display:flex;align-items:center;gap:8px}
.notif-mark-all{font-size:11px;color:var(--accent);cursor:pointer;font-weight:600;padding:4px 8px;border-radius:6px;transition:background var(--transition);font-family:var(--font-mono)}
.notif-mark-all:hover{background:var(--accent-lt)}
.notif-close-btn{width:28px;height:28px;border-radius:7px;border:none;background:transparent;cursor:pointer;color:var(--text3);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.notif-close-btn:hover{background:var(--red-lt);color:var(--red)}
.notif-list{flex:1;overflow-y:auto;padding:4px 0}
.notif-empty{padding:48px 24px;text-align:center;color:var(--text3);font-size:13px}
.notif-item{display:flex;align-items:flex-start;gap:10px;padding:11px 16px;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border);position:relative}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:var(--bg-hover)}
.notif-item.unread{background:rgba(37,99,235,.04)}
.notif-item.unread:hover{background:rgba(37,99,235,.08)}
.notif-item-icon{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.notif-item-icon svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.notif-icon-success{background:var(--green-lt);color:var(--green)}.notif-icon-warn{background:var(--orange-lt);color:var(--orange);border-color:rgba(210,153,34,0.20)}.notif-icon-error{background:var(--red-lt);color:var(--red);border-color:rgba(248,81,73,0.20)}.notif-icon-info{background:var(--blue-lt);color:var(--blue);border-color:rgba(56,139,253,0.20)}
.notif-item-body{flex:1;min-width:0}
.notif-item-title{font-size:12.5px;font-weight:600;color:var(--text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-item-msg{font-size:11.5px;color:var(--text2);margin-top:2px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.notif-item-time{font-size:11px;color:var(--text3);margin-top:4px;font-family:var(--font-body)}
.notif-unread-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px;box-shadow:0 0 5px var(--accent)}
.notif-filter-bar{display:flex;gap:4px;padding:7px 10px;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0;overflow-x:auto;scrollbar-width:none}
.notif-filter-bar::-webkit-scrollbar{display:none}
.notif-filter-tab{padding:4px 11px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;color:var(--text3);transition:all var(--transition);display:flex;align-items:center;gap:5px;border:1px solid transparent;font-family:var(--font-body)}
.notif-filter-tab:hover{background:var(--bg-hover);color:var(--text2)}
.notif-filter-tab.active{background:var(--accent-lt);color:var(--accent);border-color:rgba(37,99,235,.25)}
.notif-filter-badge{min-width:16px;height:16px;border-radius:8px;background:rgba(37,99,235,.15);color:var(--accent);font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0 4px}
.notif-filter-tab.active .notif-filter-badge{background:var(--accent);color:#000}
body.dark .notif-filter-tab.active .notif-filter-badge{color:#fff}
.notif-cat{font-size:10px;font-weight:600;padding:1px 7px;border-radius:20px;margin-top:4px;display:inline-block;letter-spacing:.03em;font-family:var(--font-mono)}
.notif-cat-topup{background:var(--green-lt);color:var(--green)}
.notif-cat-artikel{background:var(--blue-lt);color:var(--blue)}
.notif-cat-domain{background:var(--orange-lt);color:var(--orange)}
.notif-cat-sistem{background:var(--bg-elevated);color:var(--text3);border:1px solid var(--border)}
.notif-item-chevron{flex-shrink:0;color:var(--text3);margin-top:3px;opacity:0;transition:opacity var(--transition)}
.notif-item:hover .notif-item-chevron{opacity:1}
body.dark .notif-panel{background:var(--surface)}

/* ── ADMIN KPI — Gentelella solid tiles ── */
.adm-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.adm-kpi-card{
  border-radius:var(--radius-md);padding:18px 20px;cursor:pointer;
  position:relative;overflow:hidden;border:none;
  transition:transform .2s ease,box-shadow .2s ease;
  display:flex;flex-direction:column;color:#fff;
  box-shadow:var(--shadow);background:var(--tile-blue);
}
.adm-kpi-card::before{display:none}
.adm-kpi-card::after{display:none}
.adm-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
body.dark .adm-kpi-card:hover{box-shadow:var(--shadow-lg)}
.adm-kpi-card:hover::after{display:none}

/* Icon — decorative large bottom-right */
.adm-kpi-icon{
  position:absolute;right:14px;bottom:10px;
  width:52px;height:52px;border-radius:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0.15;background:transparent;flex-shrink:0;
}
.adm-kpi-icon svg{width:48px;height:48px;stroke:#fff;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* Text */
.adm-kpi-label{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,0.85);margin-bottom:6px;font-family:var(--font-body);line-height:1.3}
.adm-kpi-val{font-size:38px;font-weight:700;font-family:var(--font-display);letter-spacing:-.02em;line-height:1;margin-bottom:4px;color:#fff}
.adm-kpi-sub{font-size:12px;color:rgba(255,255,255,0.70);line-height:1.4;font-family:var(--font-body)}
.adm-kpi-arr{display:none}

/* Color variants — solid backgrounds */
.kpi-orange{background:var(--tile-orange)}.kpi-orange .adm-kpi-icon{background:transparent;color:#fff;opacity:.15}
.kpi-red{background:var(--tile-red)}.kpi-red .adm-kpi-icon{background:transparent;color:#fff;opacity:.15}
.kpi-blue{background:var(--tile-blue)}.kpi-blue .adm-kpi-icon{background:transparent;color:#fff;opacity:.15}
.kpi-green{background:var(--tile-green)}.kpi-green .adm-kpi-icon{background:transparent;color:#fff;opacity:.15}
.kpi-purple{background:var(--tile-purple)}.kpi-purple .adm-kpi-icon{background:transparent;color:#fff;opacity:.15}
.kpi-accent{background:var(--accent)}.kpi-accent .adm-kpi-icon{background:transparent;color:#fff;opacity:.15}
.kpi-teal{background:var(--teal)}.kpi-teal .adm-kpi-icon{background:transparent;color:#fff;opacity:.15}

/* All kpi val/label/sub → white */
.kpi-orange .adm-kpi-val,.kpi-red .adm-kpi-val,.kpi-blue .adm-kpi-val,
.kpi-green .adm-kpi-val,.kpi-purple .adm-kpi-val,.kpi-accent .adm-kpi-val,.kpi-teal .adm-kpi-val{color:#fff}

@media(max-width:1100px){.adm-kpi-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.adm-kpi-row{grid-template-columns:repeat(2,1fr)}.notif-panel{width:100%;right:-100%}.notif-bell{top:14px;right:60px}}
/* ── DOMAIN USER-GROUP CARDS (admin) ── */
.dom-ucard{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;margin-bottom:10px;overflow:hidden;transition:border-color var(--transition-md)}
.dom-ucard:hover{border-color:var(--border2)}
.dom-ucard-hdr{padding:14px 20px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background var(--transition);flex-wrap:wrap}
.dom-ucard-hdr:hover{background:var(--bg-hover)}
.dom-ucard-avatar{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;flex-shrink:0;font-family:var(--font-display)}
.dom-ucard-stats{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-left:auto}
.dom-ustat{text-align:center;min-width:44px}
.dom-ustat-lbl{font-size:9px;color:var(--text3);font-weight:600;font-family:var(--font-mono);letter-spacing:.07em;text-transform:uppercase;margin-bottom:1px}
.dom-ustat-val{font-size:19px;font-weight:800;font-family:var(--font-display);letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums}
.dom-ustat-sub{font-size:9px;color:var(--text3);font-family:var(--font-mono)}
.dom-ucard-chevron{width:16px;height:16px;stroke:var(--text3);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;transition:transform .25s ease;margin-left:2px}
.dom-ucard-chevron.expanded{transform:rotate(180deg)}
.dom-ucard-body{border-top:1px solid var(--border)}
/* new grid row */
.dom-ucard-row{display:grid;grid-template-columns:1fr 150px 190px auto;align-items:center;gap:14px;padding:11px 20px;border-bottom:1px solid var(--border);transition:background var(--transition)}
.dom-ucard-row:last-child{border-bottom:none}
.dom-ucard-row:hover{background:var(--bg-hover)}
.dom-urow-name{min-width:0}
.dom-urow-status{display:flex;flex-direction:column;gap:4px}
.dom-urow-jadwal{min-width:0}
.dom-urow-aksi{display:flex;gap:3px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.dom-art-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin:4px 0}
.dom-art-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}
@media(max-width:960px){.dom-ucard-stats{gap:12px;margin-left:0}.dom-ustat-val{font-size:17px}.dom-ucard-row{grid-template-columns:1fr 130px 1fr}}
@media(max-width:640px){.dom-ucard-row{grid-template-columns:1fr;gap:8px}.dom-urow-aksi{justify-content:flex-start}.dom-summary-strip{gap:6px}}

/* ── DOMAIN CARDS (user view) ── */
#dom-user-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.domcard{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color var(--transition-md),box-shadow var(--transition-md);display:flex;flex-direction:column}
.domcard:hover{border-color:var(--border2);box-shadow:var(--shadow-md)}
.domcard-hdr{padding:14px 18px 12px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border);position:relative}
.domcard-hdr::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:0}
.domcard-running .domcard-hdr::before{background:var(--blue)}
.domcard-paused .domcard-hdr::before{background:var(--orange)}
.domcard-stopped .domcard-hdr::before{background:var(--text3)}
.domcard-name strong{font-size:13.5px;font-weight:700;font-family:var(--font-mono);color:var(--text);display:block;line-height:1.3}
.domcard-brand{font-size:11px;color:var(--text3);margin-top:3px}
.domcard-badges{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.domcard-badge{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;font-family:var(--font-mono)}
.domcard-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.domcard-stats{display:flex;flex:1}
.domstat{flex:1;padding:11px 10px;text-align:center;border-right:1px solid var(--border)}
.domstat:last-child{border-right:none}
.domstat-lbl{font-size:9px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono);margin-bottom:4px}
.domstat-val{font-size:19px;font-weight:800;font-family:var(--font-display);letter-spacing:-.04em;line-height:1;margin-bottom:2px;font-variant-numeric:tabular-nums}
.domstat-sub{font-size:9.5px;color:var(--text3);font-family:var(--font-mono);line-height:1.3}
.domcard-prog{height:3px;background:var(--border)}
.domcard-prog-fill{height:100%;background:var(--accent);transition:width .6s ease}
.domcard-footer{padding:10px 14px;display:flex;align-items:center;gap:5px;flex-wrap:wrap;background:var(--bg-elevated);border-top:1px solid var(--border)}
.domcard-footer-sep{width:1px;height:14px;background:var(--border);margin:0 2px;flex-shrink:0}
@media(max-width:900px){#dom-user-cards{grid-template-columns:1fr}}

/* ── DATA ANALYTIC CARDS ── */
.da-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.da-grid-4{grid-template-columns:repeat(4,1fr)}
.da-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 16px 14px;text-align:center;position:relative;cursor:default;transition:border-color var(--transition-md)}
.da-card:hover{border-color:var(--border2)}
.da-red{border-color:var(--border)}.da-green{border-color:var(--border)}.da-blue{border-color:var(--border)}.da-purple{border-color:var(--border)}
.da-inner{display:flex;flex-direction:column;align-items:center;width:100%}
.da-ico{width:42px;height:42px;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;flex-shrink:0}
.da-ico svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.da-ico-red{background:var(--red-lt);color:var(--red)}
.da-ico-green{background:var(--green-lt);color:var(--green)}
.da-ico-blue{background:var(--blue-lt);color:var(--blue)}
.da-ico-purple{background:var(--purple-lt);color:var(--purple)}
.da-num{font-size:28px;font-weight:800;font-family:var(--font-display);letter-spacing:-.05em;line-height:1;margin-bottom:5px;font-variant-numeric:tabular-nums}
.da-red .da-num{color:var(--red)}.da-green .da-num{color:var(--green)}.da-blue .da-num{color:var(--blue)}.da-purple .da-num{color:var(--purple)}
.da-label{font-size:11px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;line-height:1.4;margin-bottom:10px;font-family:var(--font-body)}
.da-bar-wrap{width:100%}
.da-bar{height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden}
.da-bar-fill{height:100%;border-radius:2px;width:0%;transition:width .7s cubic-bezier(.4,0,.2,1)}
.da-bar-red{background:var(--red)}.da-bar-green{background:var(--green)}.da-bar-blue{background:var(--blue)}.da-bar-purple{background:var(--purple)}
.da-sublabel{font-size:10px;color:var(--text3);margin-top:5px;text-align:right;font-family:var(--font-body)}
.da-card[data-tooltip]::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);font-size:11px;padding:5px 10px;border-radius:var(--radius-md);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:200;font-weight:400;font-family:var(--font-body)}
.da-card[data-tooltip]:hover::after{opacity:1}
@media(max-width:768px){.da-grid,.da-grid-4{grid-template-columns:1fr 1fr}}

/* ── COMPACT DASHBOARD STATS BAR ── */
.dash-kpi-bar{display:flex;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:0;overflow:hidden;position:relative}
.dkpi{flex:1;padding:16px 20px;border-right:1px solid var(--border);position:relative;min-width:0}
.dkpi:last-child{border-right:none}
.dkpi::before{display:none}
.dkpi-v{font-size:22px;font-weight:800;color:var(--text);font-family:var(--font-display);letter-spacing:-.03em;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dkpi-blue .dkpi-v{color:var(--blue)}.dkpi-green .dkpi-v{color:var(--green)}
.dkpi-l{font-size:11px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-top:4px;white-space:nowrap;font-family:var(--font-body)}
.dkpi-sub{font-size:10px;color:var(--text3);margin-top:2px;font-family:var(--font-body)}
@media(max-width:768px){.dash-kpi-bar{flex-wrap:wrap}.dkpi{min-width:50%;border-bottom:1px solid var(--border)}.dkpi:nth-child(even){border-right:none}.dkpi:nth-last-child(-n+2){border-bottom:none}}

/* ── ICON STAT CARDS ── */
.sk-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.sk-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px 22px;position:relative;overflow:hidden;transition:border-color var(--transition-md),box-shadow var(--transition-md),transform var(--transition-md)}
.sk-card:hover{border-color:var(--border2)}
body.dark .sk-card:hover{border-color:var(--border2);box-shadow:var(--shadow-md)}
.sk-card-clickable:hover{border-color:var(--accent)!important;box-shadow:0 0 0 3px rgba(37,99,235,.08)!important}
.sk-card-clickable:active{transform:scale(.98)}
.sk-inner{display:flex;align-items:flex-start;gap:16px}
.sk-icon{width:42px;height:42px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.sk-icon svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.sk-icon-blue{background:var(--blue-lt);color:var(--blue)}
.sk-icon-green{background:var(--green-lt);color:var(--green)}
.sk-icon-orange{background:var(--orange-lt);color:var(--orange)}
.sk-icon-purple{background:var(--purple-lt);color:var(--purple)}
.sk-label{font-size:11px;font-weight:500;color:var(--text3);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-body)}
.sk-val{font-size:28px;font-weight:800;font-family:var(--font-display);color:var(--text);line-height:1;letter-spacing:-.05em;font-variant-numeric:tabular-nums}
.sk-sub{font-size:11px;color:var(--text3);margin-top:5px;line-height:1.4;font-family:var(--font-body)}
@media(max-width:768px){.sk-row{grid-template-columns:1fr 1fr}}

/* ── PERIOD BUTTONS & AREA CHART ── */
.cpbtn-group{display:flex;border:1px solid var(--border);border-radius:4px;overflow:hidden;background:var(--bg-elevated);gap:0}
.cpbtn{border:none;background:transparent;padding:5px 12px;font-size:12px;font-weight:500;color:var(--text3);cursor:pointer;transition:background var(--transition),color var(--transition);line-height:1;font-family:var(--font-body)}
.cpbtn:hover:not(.active){background:var(--bg-hover);color:var(--text2)}
.cpbtn.active{background:rgba(37,99,235,.10);color:var(--accent)}
.area-chart-wrap{width:100%;position:relative}
.area-chart-wrap svg{display:block;overflow:visible}
.chart-tooltip{position:absolute;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;font-size:12px;pointer-events:none;box-shadow:var(--shadow-md);white-space:nowrap;z-index:10;display:none;font-family:var(--font-body)}
.chart-tooltip-date{font-weight:600;color:var(--text);margin-bottom:3px}
.chart-tooltip-val{color:var(--accent)}

/* ── ACTIVITY FEED ── */
.activity-feed{display:flex;flex-direction:column;max-height:300px;overflow-y:auto}
.activity-feed::-webkit-scrollbar{width:4px}.activity-feed::-webkit-scrollbar-track{background:transparent}.activity-feed::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}.activity-feed::-webkit-scrollbar-thumb:hover{background:var(--text3)}
.activity-item{display:flex;align-items:flex-start;gap:11px;padding:10px 16px;border-bottom:1px solid var(--border)}
.activity-item:last-child{border-bottom:none}
.activity-item-link:hover{background:var(--bg-hover)}
.activity-icon{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.activity-icon svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.act-blue{background:var(--blue-lt);color:var(--blue)}
.act-green{background:var(--green-lt);color:var(--green)}
.act-orange{background:var(--orange-lt);color:var(--orange)}
.act-red{background:var(--red-lt);color:var(--red)}
.act-title{font-size:12px;font-weight:500;color:var(--text);margin-bottom:2px}
.act-time{font-size:11px;color:var(--text3);font-family:var(--font-body)}

/* ── LIVE INDICATORS ── */
.live-indicator{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;font-family:var(--font-body);color:var(--green)}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;box-shadow:0 0 6px var(--green);animation:livePulse 2s ease infinite}
.live-dot.dot-blue{background:var(--blue);box-shadow:0 0 6px var(--blue)}
.live-dot.dot-red{background:var(--red);box-shadow:0 0 5px var(--red);animation:none}
.live-dot.dot-orange{background:var(--orange);box-shadow:0 0 5px var(--orange)}
.live-dot.dot-gray{background:var(--text3);box-shadow:none;animation:none}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.75)}}
.terminal-text{font-family:var(--font-mono);font-size:11.5px;color:var(--text2);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;line-height:1.7;overflow-x:auto;white-space:pre-wrap}
.terminal-text .t-green{color:var(--green)}.terminal-text .t-blue{color:var(--blue)}.terminal-text .t-red{color:var(--red)}.terminal-text .t-dim{color:var(--text3)}
.processing-bar{width:100%;height:2px;background:var(--border);border-radius:1px;overflow:hidden}
.processing-bar-fill{height:100%;background:linear-gradient(90deg,transparent,var(--accent),transparent);background-size:200% 100%;animation:processingSlide 1.4s linear infinite;border-radius:1px}
@keyframes processingSlide{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── SETTINGS TABS + STATUS (gabung) ── */
.cfg-tabs-sticky{position:sticky;top:56px;z-index:50;background:var(--bg);padding:10px 0 0;margin-bottom:16px;border-bottom:1px solid var(--border)}
.cfg-status-strip{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:10px}
.cfg-status-strip-lbl{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);margin-right:2px;flex-shrink:0;font-family:var(--font-body)}
.cfg-status-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px 3px 7px;border-radius:20px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text2);cursor:default;transition:all var(--transition);font-family:var(--font-body)}
.cfg-status-chip.ok{border-color:rgba(22,163,74,.25);color:var(--green);background:var(--green-lt)}
.cfg-status-chip.warn{border-color:rgba(210,153,34,0.25);color:var(--orange);background:var(--orange-lt)}
.cfg-status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}
.cfg-status-dot.ok{background:var(--green);box-shadow:0 0 5px var(--green);animation:livePulse 2s ease infinite}
.cfg-status-dot.warn{background:var(--orange)}
.cfg-tab-row{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;padding-bottom:10px}
.cfg-tab-row::-webkit-scrollbar{display:none}
.cfg-tab-btn{border-radius:4px;font-size:12px;font-weight:500;padding:6px 16px;transition:all var(--transition);white-space:nowrap;border:1px solid var(--border);background:transparent;color:var(--text3);cursor:pointer;font-family:var(--font-body)}
.cfg-tab-btn:hover:not(.active){background:var(--bg-hover);color:var(--text2);border-color:var(--border2)}
.cfg-tab-btn.active{background:rgba(37,99,235,.10);color:var(--accent);border-color:rgba(37,99,235,.25);font-weight:600}

/* ── BRAND LOGO DINAMIS ── */
.brand-logo-img{width:28px;height:28px;object-fit:contain;border-radius:6px}

/* ── MAINTENANCE BANNER (admin reminder) ── */
#maintenance-banner{display:flex;align-items:center;gap:6px;font-size:10.5px;color:#f97316;font-weight:600;padding:4px 9px;background:rgba(249,115,22,.1);border-radius:20px;width:fit-content;border:1px solid rgba(249,115,22,.22);letter-spacing:.01em;margin-top:6px}
#maintenance-banner.hidden{display:none}
.mnt-banner-dot{width:6px;height:6px;background:#f97316;border-radius:50%;flex-shrink:0;animation:aiPulse 2.5s ease infinite}
#maintenance-banner button{background:transparent;border:none;color:#f97316;font-size:10px;font-weight:700;padding:0 0 0 4px;cursor:pointer;font-family:inherit;opacity:.8;transition:opacity .15s;text-decoration:underline}
#maintenance-banner button:hover{opacity:1}

/* ── MAINTENANCE SCREEN ── */
#maintenance-screen{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:150px 20px;background:var(--bg);font-family:var(--font-mono);font-size:14px;color:var(--text);text-align:center}
#maintenance-screen.hidden{display:none}
.mnt-article{display:block;text-align:left;width:650px;max-width:100%;margin:0 auto}
.mnt-article h1{font-size:48px;margin:0 0 24px;font-family:var(--font-display);letter-spacing:-.04em;color:var(--accent)}
.mnt-article p{margin:0 0 16px;line-height:1.7;color:var(--text2)}
.mnt-brand{display:flex;align-items:center;gap:10px;margin-bottom:32px;font-size:15px;font-weight:700;color:var(--text)}
.mnt-brand-icon{width:30px;height:30px;border-radius:4px;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 12px rgba(37,99,235,.25)}
.mnt-brand-icon svg{width:14px;height:14px;stroke:#000;fill:none;stroke-width:2.5;stroke-linecap:round}

/* ── PLATFORM TAB: grid + hint + preview ── */
.cfg-platform-grid{display:grid;grid-template-columns:1fr 260px;gap:24px;align-items:start}
@media(max-width:780px){.cfg-platform-grid{grid-template-columns:1fr}}
.cfg-label{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:4px}
.cfg-hint{font-size:11px;color:var(--text3);margin-top:4px;line-height:1.5}
.cfg-preview-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:10px}
.cfg-preview-box{border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;background:var(--surface)}
.cfg-preview-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:8px}

/* ── PACKAGE EDIT CARDS (admin settings) ── */
.pkg-edit-card{border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:10px;background:var(--bg-card)}
.pkg-edit-name{font-size:12.5px;font-weight:700;color:var(--text);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border);font-family:var(--font-mono)}
.pkg-edit-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:680px){.pkg-edit-row{grid-template-columns:1fr 1fr}}

/* ── TOP LOADING BAR ── */
.nbar{position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;pointer-events:none;opacity:0;transition:opacity .15s}
.nbar.loading{opacity:1}
.nbar::after{content:'';display:block;height:100%;width:0%;background:var(--accent);border-radius:0 2px 2px 0;animation:nbarGrow 1.8s ease-in-out forwards}
.nbar.done::after{width:100%!important;background:var(--green);transition:width .2s ease;animation:none}
@keyframes nbarGrow{0%{width:0%}40%{width:65%}70%{width:82%}100%{width:92%}}
@keyframes nbarShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── GLOBAL INPUT FOCUS ── */
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)!important;box-shadow:0 0 0 2px rgba(37,99,235,.18)!important}

/* ── PAGE LOADING SPINNER ── */
.page-loading{min-height:200px;display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:13px;flex-direction:column;gap:12px}
.page-loading::before{content:'';width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}

/* ── ITEM A: EXTRACTED INLINE STYLES ──────────────────── */

/* Utility */
.mt-s{margin-top:6px}
.fw-600{font-weight:600}

/* Micro label (uppercase tiny header above values) */
.lbl-xs{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.09em;margin-bottom:3px;font-family:var(--font-mono)}

/* Progress bar */
.prog-wrap{width:100%;height:5px;background:var(--bg-elevated);border-radius:99px;overflow:hidden;margin-top:7px}
.prog-bar{height:100%;border-radius:99px;transition:width .6s cubic-bezier(.4,0,.2,1);background:var(--accent)}
body.dark .prog-bar{background:var(--accent)}
.prog-sub-row{display:flex;justify-content:space-between;align-items:center;margin-top:5px}
.prog-sub-text{font-size:10px;color:var(--text3);font-weight:500;font-family:var(--font-body)}

/* Sub subscription stat inline */
.sub-stat-wrap{text-align:right;min-width:120px}
.sub-prog-lbl{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-family:var(--font-body)}
.sub-stat-big{font-size:26px;font-weight:800;color:var(--accent);font-family:var(--font-display);letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums}
.sub-stat-sep{font-size:14px;color:var(--border);margin:0 1px}
.sub-stat-total{font-size:15px;font-weight:700;color:var(--text3);font-family:var(--font-display);letter-spacing:-.02em;font-variant-numeric:tabular-nums}

/* Sub detail grid */
.sub-detail-grid{padding:14px 18px;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border);display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-top:16px}
.sub-dl{font-size:10px;color:var(--text3);font-weight:600;letter-spacing:.06em;margin-bottom:4px;text-transform:uppercase;font-family:var(--font-body)}
.sub-dv{font-size:13px;font-weight:700;color:var(--text)}
.sub-dv-accent{color:var(--accent)}
.sub-dv-green{color:var(--green)}

/* Bank hero card */
.bank-hero{background:linear-gradient(135deg,#0D1625 0%,#0D1117 60%,#101820 100%);border:1px solid rgba(26,187,156,.25);border-radius:var(--radius-md);padding:24px 26px;margin-bottom:16px;color:#E6EDF3;position:relative;overflow:hidden;box-shadow:0 0 24px rgba(26,187,156,.08)}
.bank-hero::before{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(26,187,156,.04);top:-60px;right:-40px;pointer-events:none}
.bank-hero::after{content:'';position:absolute;width:120px;height:120px;border-radius:50%;background:rgba(26,187,156,.03);bottom:-30px;right:80px;pointer-events:none}
.bank-hero-lbl{font-size:10px;font-weight:600;color:rgba(255,255,255,0.40);text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;font-family:var(--font-body)}
.bank-hero-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;position:relative}
.bank-hero-info{display:flex;align-items:center;gap:16px}
.bank-hero-icon{width:48px;height:48px;background:rgba(26,187,156,.15);border:1px solid rgba(26,187,156,.30);border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;flex-shrink:0;color:var(--accent);font-family:var(--font-display)}
.bank-hero-name-sub{font-size:11px;color:rgba(255,255,255,0.40);margin-bottom:4px;font-family:var(--font-body)}
.bank-hero-number{font-size:22px;font-weight:700;font-family:var(--font-mono);letter-spacing:.08em;line-height:1;color:#E6EDF3}
.bank-hero-an{font-size:11px;color:rgba(255,255,255,0.40);margin-top:4px;font-family:var(--font-body)}
.bank-copy-btn{padding:8px 18px;background:rgba(26,187,156,.12);border:1px solid rgba(26,187,156,.30);border-radius:4px;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-body);white-space:nowrap;transition:all var(--transition)}
.bank-copy-btn:hover{background:rgba(26,187,156,.22);border-color:rgba(26,187,156,.50)}
body.dark .bank-hero{background:linear-gradient(135deg,#0D1625 0%,#0D1117 60%,#101820 100%);border-color:rgba(26,187,156,.28);box-shadow:0 0 24px rgba(26,187,156,.10)}

/* Topup steps */
.topup-steps{display:flex;align-items:flex-start;margin-bottom:20px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 20px}
.topup-step{flex:1;text-align:center}
.topup-step-num{width:32px;height:32px;border-radius:50%;background:var(--bg);border:1px solid var(--border);color:var(--text3);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-family:var(--font-body)}
.topup-step-num.is-active{background:rgba(37,99,235,.10);border-color:rgba(37,99,235,.30);color:var(--accent)}
.topup-step-ttl{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:3px;font-family:var(--font-body)}
.topup-step-ttl.is-active{color:var(--accent)}
.topup-step-desc{font-size:11px;color:var(--text3);line-height:1.5;font-family:var(--font-body)}
.topup-step-sep{width:20px;height:1px;background:var(--border);margin-top:16px;flex-shrink:0}

/* Admin article tabs */
.adm-tab-nav{display:flex;gap:2px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;padding:3px;margin-bottom:16px;width:fit-content}
.adm-tab-item{padding:6px 16px;border-radius:3px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;color:var(--text3);font-family:var(--font-body)}
.adm-tab-item:hover{color:var(--text2);background:var(--bg-hover)}
.adm-tab-item.active{background:rgba(37,99,235,.10);color:var(--accent)}

/* Filter column group (label + input stacked) */
.filter-col{display:flex;flex-direction:column;gap:4px}
.filter-col-lbl{font-size:11px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}

/* Article preview modal (uses CSS vars instead of hardcoded) */
.art-prev-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:var(--bg-elevated)}
.art-prev-foot{padding:10px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-elevated)}
.art-prev-kw-badge{font-size:10px;background:var(--accent-lt);color:var(--accent);padding:2px 8px;border-radius:3px;font-weight:600;letter-spacing:.04em;border:1px solid rgba(37,99,235,.22);font-family:var(--font-body)}
.art-prev-slug{font-size:11px;color:var(--text3);font-family:var(--font-body)}
.art-prev-api-btn{font-size:12px;padding:5px 13px;border-radius:4px;border:1px solid rgba(37,99,235,.25);background:rgba(37,99,235,.08);color:var(--accent);cursor:pointer;font-family:var(--font-body);transition:all var(--transition)}
.art-prev-api-btn:hover{background:rgba(37,99,235,.15);border-color:rgba(37,99,235,.40)}

/* ── ITEM B: HARDCODED COLORS → CSS VARS ── */

/* Bot log modal */
/* ── USER DASHBOARD SPECIFIC ── */
#sub-status-card{
  border-color:var(--accent);
  background:var(--bg-card);
  border-top:3px solid var(--accent);
  position:relative;
  overflow:hidden;
}
#sub-status-card::before{display:none}

#sub-status-card:hover{border-color:var(--accent)}
#sub-status-card .card-body{position:relative}
body.dark #sub-status-card{border-color:var(--accent)}

#no-sub-card{border-color:var(--border);transition:border-color var(--transition-md)}
#no-sub-card:hover{border-color:var(--border2)}

/* ── BOT LOG MODAL ── */
.bot-log-shell{background:var(--bg-card);border-radius:var(--radius-md);width:100%;max-width:620px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 5px 20px rgba(0,0,0,.15);overflow:hidden;border:1px solid var(--border)}
.bot-log-head{padding:16px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.bot-log-head-title{font-size:16px;font-weight:600;color:var(--text);letter-spacing:0;font-family:var(--font-display)}
.bot-log-head-sub{font-size:12px;color:var(--text3);margin-top:2px;font-family:var(--font-body)}
.bot-log-status-bar{padding:8px 20px;border-bottom:1px solid var(--border);background:var(--bg-elevated);display:flex;align-items:center;gap:10px;flex-shrink:0}
.bot-log-indicator{width:6px;height:6px;border-radius:50%;background:var(--text3);flex-shrink:0}
.bot-log-status-text{font-size:12px;font-weight:500;color:var(--text2);font-family:var(--font-body)}
.bot-log-count{margin-left:auto;font-size:11px;color:var(--text3);font-family:var(--font-body)}
.bot-log-timeline{overflow-y:auto;flex:1;padding:14px 20px}
.bot-log-empty{text-align:center;padding:30px;color:var(--text3);font-size:13px}
.bot-log-foot{padding:11px 20px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--bg-elevated)}
body.dark .bot-log-shell{background:var(--surface)}

/* Dialog modals (logout, confirm) */
.dlg-shell{background:var(--bg-card);border-radius:var(--radius-md);width:340px;box-shadow:0 5px 20px rgba(0,0,0,.15);overflow:hidden;animation:slideUp .22s ease;border:1px solid var(--border)}
.dlg-body{padding:20px 20px 0}
.dlg-icon-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.dlg-icon{width:36px;height:36px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.dlg-icon-danger{background:var(--red-lt);border-color:rgba(248,81,73,0.22)}
.dlg-title{font-size:16px;font-weight:600;color:var(--text);letter-spacing:0;font-family:var(--font-display)}
.dlg-sub{font-size:12px;color:var(--text3);margin-top:2px;line-height:1.5}
.dlg-note{font-size:12px;color:var(--text3);padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:16px;font-family:var(--font-body)}
.dlg-foot{padding:0 20px 18px;display:flex;gap:8px;justify-content:flex-end}
body.dark .dlg-shell{background:var(--surface)}

/* Schedule preview */
.schedule-preview-box{background:rgba(26,187,156,.07);border:1px solid rgba(26,187,156,.20);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:14px;font-size:12px;font-family:var(--font-body)}
.schedule-preview-ttl{font-weight:600;color:var(--green);margin-bottom:8px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-body)}
.schedule-preview-list{color:var(--text2);line-height:1.9}

/* Package topup banner */
.pkg-topup-banner{background:rgba(26,187,156,.08);border:1px solid rgba(26,187,156,.20);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px}
.pkg-topup-icon{width:34px;height:34px;background:rgba(26,187,156,.15);border:1px solid rgba(26,187,156,.25);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pkg-topup-lbl{font-size:10px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;font-family:var(--font-body)}
.pkg-topup-name{font-size:13px;font-weight:700;color:var(--text)}

/* Orange warning box */
.warn-box{display:flex;align-items:flex-start;gap:8px;padding:10px 13px;background:var(--orange-lt);border:1px solid rgba(210,153,34,0.28);border-radius:var(--radius-md);font-size:12px;color:var(--orange);font-family:var(--font-body)}

/* Email verification success overlay animations */
@keyframes vsoCardIn{from{transform:translateY(28px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
@keyframes vsoPop{from{transform:scale(0);opacity:0}65%{transform:scale(1.18)}to{transform:scale(1);opacity:1}}
@keyframes vsoRingOut{0%{transform:scale(.85);opacity:.7}100%{transform:scale(1.5);opacity:0}}
@keyframes vsoCheckDraw{to{stroke-dashoffset:0}}
@keyframes vsoFadeUp{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Theme card picker */
.theme-card:hover{border-color:var(--accent)!important;box-shadow:0 0 0 3px rgba(37,99,235,.10)}
.theme-card.selected{border-color:var(--accent)!important;box-shadow:0 0 0 4px rgba(37,99,235,.15)}
@media(max-width:560px){#theme-cards-grid{grid-template-columns:1fr!important}}
