/* ══════════════════════════════════════════════════════
   SIGNA v3 — CSS (merged from Claude Design)
══════════════════════════════════════════════════════ */

/* ── Variables (from design) ── */
:root {
  /* Design tokens */
  --navy:        #0d1b2a;
  --navy-2:      #122538;
  --navy-3:      #1a2f47;
  --green:       #1a7a3a;
  --green-2:     #0f5c28;
  --green-3:     #22c55e;
  --bg:          #f1f5f9;
  --card:        #ffffff;
  --text:        #0d1b2a;
  --text-2:      #475569;
  --muted:       #94a3b8;
  --border:      #e2e8f0;
  --border-2:    #cbd5e1;
  --amber:       #f59e0b;
  --red:         #dc2626;
  --teal:        #0891b2;
  --violet:      #8b5cf6;
  --cyan:        #06b6d4;
  --gold:        #d97706;
  --shadow-card: 0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.03);
  --shadow-pop:  0 4px 12px rgba(15,23,42,.08), 0 2px 4px rgba(15,23,42,.04);
  --shadow-lg:   0 8px 32px rgba(15,23,42,.12);
  --r-card:      10px;
  --r-input:     7px;
  --t:           160ms cubic-bezier(.4,0,.2,1);
  --sb-w:        256px;
  --sb-mini:      64px;
  --topbar-h:     60px;
  --sb-border:   rgba(255,255,255,.05);

  /* Aliases for page compatibility */
  --bg-card:     #ffffff;
  --text-1:      #0d1b2a;
  --text-3:      #94a3b8;
  --danger:      #dc2626;
  --warning:     #f59e0b;
  --r:           10px;
  --r-sm:         7px;
  --sh-sm:       0 1px 2px rgba(15,23,42,.04);
  --sh:          0 4px 12px rgba(15,23,42,.08);
  --sh-lg:       0 8px 32px rgba(15,23,42,.12);
  --radius:       10px;
  --radius-sm:    7px;
  --teal-500:    #0891b2;
  --success:     #059669;
  --info:        #0891b2;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px}
body{
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--text);
  font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;font-feature-settings:"tnum" 1,"ss01" 1}

/* ══════════════════════════════════════════════════════
   APP LAYOUT
══════════════════════════════════════════════════════ */
.app-layout{min-height:100vh;display:flex;width:100%}

/* ── SIDEBAR ── */
.sidebar{
  position:sticky;top:0;
  width:var(--sb-w);min-width:var(--sb-w);
  flex-shrink:0;
  background:var(--navy);
  color:#cbd5e1;
  display:flex;flex-direction:column;
  height:100vh;
  z-index:30;
  transition:width var(--t),min-width var(--t);
  border-right:1px solid var(--sb-border);
  overflow:hidden;
}
.sidebar:hover{overflow-y:auto;overflow-x:hidden}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:#1a2f47;border-radius:3px}

/* Brand — clickable, collapses sidebar */
.sidebar-brand{
  display:flex;align-items:center;gap:10px;
  height:64px;padding:0 16px;
  border-bottom:1px solid var(--sb-border);
  width:100%;text-align:left;
  background:rgba(0,0,0,.1);
  cursor:pointer;
  transition:background var(--t);
  white-space:nowrap;overflow:hidden;flex-shrink:0;
}
.sidebar-brand:hover{background:rgba(255,255,255,.04)}
.brand-icon{
  flex-shrink:0;
  width:34px;height:34px;
  border-radius:9px;
  background:linear-gradient(135deg,var(--green),var(--green-2));
  display:grid;place-items:center;
  font-size:15px;color:#fff;
  box-shadow:0 2px 8px rgba(26,122,58,.4);
}
.brand-text{flex:1;min-width:0;overflow:hidden}
.brand-name{font-size:14px;font-weight:800;color:#fff;white-space:nowrap;letter-spacing:.01em}
.brand-sub{font-size:11px;color:#64748b;font-weight:500;white-space:nowrap}
.brand-chevron{
  flex-shrink:0;width:22px;height:22px;
  display:grid;place-items:center;
  color:#64748b;font-size:10px;
  border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  transition:all var(--t);
}
.sidebar-brand:hover .brand-chevron{color:#cbd5e1;background:rgba(255,255,255,.12)}

/* Nav */
.sidebar-nav{flex:1;padding:12px 8px;overflow:visible}
.nav-section{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:#64748b;padding:16px 12px 8px;
  white-space:nowrap;overflow:hidden;
}
.nav-item{
  width:100%;display:flex;align-items:center;gap:12px;
  padding:9px 12px;border-radius:7px;
  color:#cbd5e1;font-size:13.5px;font-weight:500;
  text-align:left;position:relative;
  transition:background var(--t),color var(--t);
  margin-bottom:1px;white-space:nowrap;overflow:hidden;
}
.nav-item:hover{background:rgba(255,255,255,.04);color:#fff}
.nav-item.active{background:rgba(26,122,58,.18);color:#fff}
.nav-item.active::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;
  width:3px;background:var(--green-3);border-radius:0 3px 3px 0;
}
.nav-icon{flex-shrink:0;display:grid;place-items:center;width:18px;font-size:14px}
.nav-item.active .nav-icon{color:var(--green-3)}
.nav-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}
.nav-badge{
  flex-shrink:0;font-size:10.5px;font-weight:700;
  padding:2px 7px;border-radius:999px;
  min-width:20px;text-align:center;
  font-family:"JetBrains Mono",monospace;
}
.nav-badge-red  {background:rgba(220,38,38,.18);color:#fca5a5}
.nav-badge-amber{background:rgba(245,158,11,.18);color:#fcd34d}
.nav-badge{background:rgba(220,38,38,.18);color:#fca5a5}

/* Sidebar footer */
.sidebar-footer{
  padding:12px 16px;
  border-top:1px solid var(--sb-border);
  background:rgba(0,0,0,.15);
  flex-shrink:0;
}
.sidebar-user{display:flex;align-items:center;gap:10px}
.user-avatar{
  width:34px;height:34px;flex-shrink:0;
  border-radius:8px;
  background:linear-gradient(135deg,var(--green),var(--green-2));
  color:#fff;font-weight:700;font-size:12px;
  display:grid;place-items:center;
  letter-spacing:.02em;
}
.user-details{flex:1;min-width:0;overflow:hidden}
.user-name{color:#fff;font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{color:#64748b;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btn-logout{
  width:30px;height:30px;flex-shrink:0;
  border-radius:7px;display:grid;place-items:center;
  color:#94a3b8;font-size:13px;
  transition:background var(--t),color var(--t);
}
.btn-logout:hover{background:rgba(220,38,38,.18);color:#fca5a5}

/* ── MINI SIDEBAR ── */
body.sidebar-mini .sidebar{width:var(--sb-mini);min-width:var(--sb-mini);overflow:visible}
body.sidebar-mini .sidebar:hover{overflow:visible}
body.sidebar-mini .brand-text,
body.sidebar-mini .nav-label,
body.sidebar-mini .nav-section,
body.sidebar-mini .nav-badge,
body.sidebar-mini .user-details,
body.sidebar-mini .brand-chevron{display:none!important}
body.sidebar-mini .sidebar-brand{justify-content:center;padding:0;gap:0;height:64px}
body.sidebar-mini .nav-item{justify-content:center;padding:9px 0;gap:0}
body.sidebar-mini .sidebar-nav{padding:12px 8px}
body.sidebar-mini .sidebar-footer{padding:12px 0;display:flex;justify-content:center}
body.sidebar-mini .sidebar-user{justify-content:center}
body.sidebar-mini .user-avatar{margin:0}
body.sidebar-mini .btn-logout{margin:0}
/* Tooltips in mini mode */
body.sidebar-mini .nav-item[title]:hover::after{
  content:attr(title);
  position:absolute;left:calc(100% + 12px);top:50%;
  transform:translateY(-50%);
  background:var(--navy);color:#fff;
  padding:6px 10px;border-radius:6px;
  font-size:12px;font-weight:600;white-space:nowrap;
  box-shadow:var(--shadow-pop);
  border:1px solid rgba(255,255,255,.06);
  z-index:50;pointer-events:none;
}

/* ── MAIN AREA ── */
.main-area{
  flex:1;min-width:0;
  display:flex;flex-direction:column;
  min-height:100vh;
  background:var(--bg);
}

/* ── TOPBAR ── */
.topbar{
  position:sticky;top:0;z-index:20;
  height:var(--topbar-h);
  background:#fff;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;gap:16px;
}
.topbar-burger{
  display:none;
  width:38px;height:38px;
  align-items:center;justify-content:center;
  border-radius:var(--r-input);
  color:var(--text-2);font-size:16px;
  transition:background var(--t);
}
.topbar-burger:hover{background:var(--bg)}
.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}
.topbar-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.1}
.topbar-actions{display:flex;align-items:center;gap:10px}
.topbar-notif{
  width:38px;height:38px;
  display:grid;place-items:center;
  color:var(--text-2);border-radius:var(--r-input);
  position:relative;
  transition:background var(--t),color var(--t);
}
.topbar-notif:hover{background:var(--bg)}
.notif-dot{
  position:absolute;top:8px;right:8px;
  width:7px;height:7px;border-radius:999px;
  border:2px solid #fff;
}
.notif-dot-red{background:var(--red)}
.notif-dot-amber{background:var(--amber)}
.topbar-clock{
  display:flex;align-items:center;gap:9px;
  padding:6px 12px;
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-input);color:var(--text-2);
}
.clock-text{line-height:1.15}
.clock-time{font-weight:600;font-size:13px;color:var(--text);font-family:"JetBrains Mono",monospace}
.clock-date{font-size:11px;color:var(--text-2)}

/* ── PAGE CONTENT ── */
.page-content{
  padding:28px;flex:1;
  animation:fadeUp .18s ease;
}
@keyframes fadeUp{from{opacity:.7;transform:translateY(4px)}to{opacity:1;transform:none}}

/* Mobile overlay */
.sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(13,27,42,.5);backdrop-filter:blur(2px);
  z-index:25;
}

/* ══════════════════════════════════════════════════════
   PAGE HEADER
══════════════════════════════════════════════════════ */
.page-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;margin-bottom:24px;flex-wrap:wrap;
}
.page-header-left{flex:1;min-width:0}
.page-header-left h1{
  font-size:26px;font-weight:800;color:var(--text);
  letter-spacing:-.015em;margin-bottom:4px;
  display:flex;align-items:center;gap:10px;
}
.page-header-left p{font-size:13.5px;color:var(--text-2);max-width:560px;margin-left:44px}
.page-header-actions{display:flex;gap:8px;flex-wrap:wrap}
.ph-icon{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;
  display:grid;place-items:center;font-size:14px;color:#fff;
}

/* Section label (design style) */
.section-label{
  display:flex;align-items:baseline;justify-content:space-between;
  margin:8px 2px 12px;font-size:12px;font-weight:700;color:var(--text);
  letter-spacing:.01em;
}
.section-label span:first-child::before{
  content:"";display:inline-block;width:3px;height:12px;
  background:var(--green);border-radius:2px;
  margin-right:8px;vertical-align:-1px;
}
.section-meta{font-size:10.5px;font-weight:600;color:var(--muted);letter-spacing:.06em}

/* ══════════════════════════════════════════════════════
   STAT CARDS
══════════════════════════════════════════════════════ */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;margin-bottom:24px;
}
.stat-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r-card);
  padding:18px;
  box-shadow:var(--shadow-card);
  position:relative;overflow:hidden;
  transition:box-shadow var(--t),transform var(--t);
  cursor:default;
}
.stat-card::before{
  content:"";position:absolute;top:0;left:0;right:0;
  height:3px;background:var(--tone,var(--green));
}
.stat-card:hover{box-shadow:var(--shadow-pop);transform:translateY(-1px)}
.stat-top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;
}
.stat-icon{
  width:38px;height:38px;border-radius:9px;
  display:grid;place-items:center;
}
.stat-value{
  font-size:32px;font-weight:800;color:var(--text);
  letter-spacing:-.025em;line-height:1.05;margin-bottom:2px;
}
.stat-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px}
.stat-foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:8px;padding-top:10px;border-top:1px dashed var(--border);
}
.stat-sub{font-size:11.5px;color:var(--muted)}

/* Color variants (design style with --tone) */
.c-green {--tone:var(--green)}     .c-green  .stat-icon{background:rgba(26,122,58,.1);color:var(--green)}
.c-teal  {--tone:var(--teal)}      .c-teal   .stat-icon{background:rgba(8,145,178,.1);color:var(--teal)}
.c-amber {--tone:var(--amber)}     .c-amber  .stat-icon{background:rgba(245,158,11,.1);color:var(--amber)}
.c-red   {--tone:var(--red)}       .c-red    .stat-icon{background:rgba(220,38,38,.08);color:var(--red)}
.c-violet{--tone:var(--violet)}    .c-violet .stat-icon{background:rgba(139,92,246,.1);color:var(--violet)}
.c-cyan  {--tone:var(--cyan)}      .c-cyan   .stat-icon{background:rgba(6,182,212,.1);color:var(--cyan)}
.c-gold  {--tone:var(--gold)}      .c-gold   .stat-icon{background:rgba(217,119,6,.1);color:var(--gold)}

/* ══════════════════════════════════════════════════════
   PANELS
══════════════════════════════════════════════════════ */
.panel{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r-card);
  box-shadow:var(--shadow-card);
  margin-bottom:16px;overflow:hidden;
}
.panel-header,.panel-head{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:12px;padding:18px 20px 14px;
  border-bottom:1px solid var(--border);
}
.panel-title{
  font-size:15px;font-weight:800;color:var(--text);
  letter-spacing:-.01em;
  display:flex;align-items:center;gap:9px;
}
.panel-sub{font-size:12px;color:var(--text-2);margin-top:2px}
.pt-icon{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-size:11px;color:#fff;flex-shrink:0}
.panel-body{padding:20px}

/* ══════════════════════════════════════════════════════
   TABLES
══════════════════════════════════════════════════════ */
.table-wrap,.t-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table,.t{width:100%;border-collapse:collapse;font-size:13px}
thead th,.t th{
  padding:12px 20px;text-align:left;
  font-weight:600;font-size:10.5px;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);background:#fafbfc;
  border-bottom:1px solid var(--border);white-space:nowrap;
}
tbody td,.t td{
  padding:14px 20px;
  border-bottom:1px solid var(--border);
  vertical-align:middle;
}
tbody tr:last-child td,.t tbody tr:last-child td{border-bottom:0}
tbody tr,.t tbody tr{transition:background var(--t)}
tbody tr:hover td,.t tbody tr:hover td{background:rgba(26,122,58,.04)}

/* User cell */
.user-cell{display:flex;align-items:center;gap:12px}
.td-avatar,.avatar{
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  color:#fff;font-weight:700;font-size:12px;
  flex-shrink:0;letter-spacing:.02em;
}
.user-name{font-weight:700;color:var(--text);font-size:12.5px;letter-spacing:.04em;text-transform:uppercase}
.user-nip,.td-mono{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted);margin-top:2px}
.opd-badge,.badge-tag{
  display:inline-block;padding:3px 9px;
  background:#f1f5f9;border:1px solid var(--border);
  border-radius:6px;font-size:11.5px;font-weight:600;color:var(--text-2);
}
.queue-num{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:36px;height:26px;padding:0 8px;
  background:rgba(26,122,58,.1);color:var(--green-2);
  border-radius:6px;font-weight:700;font-size:12px;
}

/* ══════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:var(--r-input);
  font-size:13px;font-weight:600;font-family:inherit;
  border:none;cursor:pointer;
  transition:background var(--t),border-color var(--t),color var(--t),box-shadow var(--t),transform var(--t);
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(180deg,var(--green) 0%,var(--green-2) 100%);
  color:#fff;
  box-shadow:0 1px 2px rgba(15,92,40,.25),inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary:hover{box-shadow:0 2px 8px rgba(15,92,40,.3),inset 0 1px 0 rgba(255,255,255,.15);transform:translateY(-.5px)}
.btn-outline{
  background:#fff;border:1px solid var(--border-2);color:var(--text);
}
.btn-outline:hover{border-color:var(--green);color:var(--green)}
.btn-warning{background:var(--amber);color:#fff;border:none}
.btn-warning:hover{filter:brightness(1.05)}
.btn-danger{background:var(--red);color:#fff;border:none}
.btn-success{background:linear-gradient(135deg,#059669,#047857);color:#fff}
.btn-ghost{color:var(--text-2);font-size:12.5px;padding:6px 10px;font-weight:600}
.btn-ghost:hover{color:var(--green)}
.btn-tte{
  background:rgba(26,122,58,.08);color:var(--green-2);
  padding:5px 11px;font-size:11.5px;font-weight:700;
  letter-spacing:.04em;border-radius:var(--r-input);
  text-transform:uppercase;
}
.btn-tte:hover{background:linear-gradient(180deg,var(--green),var(--green-2));color:#fff}
.btn-sm{padding:6px 12px;font-size:12.5px}
.btn-xs{padding:4px 9px;font-size:12px}
.btn-icon{padding:6px;min-width:30px;justify-content:center;width:30px;height:30px}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;filter:none!important}

/* ══════════════════════════════════════════════════════
   BADGES / PILLS
══════════════════════════════════════════════════════ */
.pill,.badge{
  display:inline-flex;align-items:center;
  padding:3px 10px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.01em;white-space:nowrap;
}
.badge-aktif        {background:rgba(26,122,58,.1);color:#15803d}
.badge-periksa      {background:rgba(245,158,11,.1);color:#b45309}
.badge-aktifasi     {background:rgba(139,92,246,.1);color:#6d28d9}
.badge-ditangguhkan {background:rgba(220,38,38,.08);color:#b91c1c}
.badge-default      {background:var(--bg);color:var(--muted);border:1px solid var(--border)}

/* ══════════════════════════════════════════════════════
   FORMS
══════════════════════════════════════════════════════ */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:5px}
.form-label .req{color:var(--red);margin-left:2px}
.form-hint{font-size:11.5px;color:var(--muted);margin-top:4px}
.form-control{
  width:100%;padding:9px 12px;
  border:1.5px solid var(--border);border-radius:var(--r-input);
  background:#fff;color:var(--text);
  font-size:13.5px;font-family:inherit;outline:none;
  transition:border-color var(--t),box-shadow var(--t);
}
.form-control:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(26,122,58,.1);
}
.form-control::placeholder{color:var(--muted)}
select.form-control{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;background-size:14px;
  padding-right:34px;
}
textarea.form-control{resize:vertical;min-height:80px}
.form-grid  {display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.form-full{grid-column:1/-1}
.form-section{margin-bottom:20px}
.form-section-title{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;color:var(--muted);
  padding-bottom:8px;border-bottom:1px solid var(--border);
  margin-bottom:14px;display:flex;align-items:center;gap:7px;
}
.input-wrap{position:relative;display:flex;align-items:center}
.input-wrap .form-control{padding-left:36px}
.input-icon{position:absolute;left:11px;font-size:14px;color:var(--muted);pointer-events:none;z-index:1}
.input-action{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--muted);font-size:13px;padding:4px}
.input-action:hover{color:var(--text)}
.input-nip,.input-nik,.input-wa{font-family:"JetBrains Mono",monospace}

/* Filter bar */
.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.filter-sep{width:1px;height:20px;background:var(--border);flex-shrink:0}
.filter-count{margin-left:auto;font-size:12px;color:var(--muted);font-weight:500}

/* Search in topbar style */
.search-wrap{
  display:flex;align-items:center;gap:8px;
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r-input);padding:6px 10px;
  transition:border-color var(--t),box-shadow var(--t);
}
.search-wrap:focus-within{border-color:var(--green);box-shadow:0 0 0 3px rgba(26,122,58,.1)}
.search-wrap input{flex:1;border:0;background:transparent;outline:none;font-size:13px;color:var(--text);min-width:0}
.search-wrap input::placeholder{color:var(--muted)}

/* ══════════════════════════════════════════════════════
   ALERTS
══════════════════════════════════════════════════════ */
.alert{
  padding:12px 16px;border-radius:var(--r-input);
  font-size:13.5px;font-weight:500;
  display:flex;align-items:center;gap:9px;margin-bottom:16px;
}
.alert-success{background:rgba(26,122,58,.08);border:1px solid rgba(26,122,58,.2);color:#15803d}
.alert-error  {background:rgba(220,38,38,.07);border:1px solid rgba(220,38,38,.2);color:#b91c1c}
.alert-warning{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);color:#b45309}
.alert-info   {background:rgba(8,145,178,.07);border:1px solid rgba(8,145,178,.2);color:#0369a1}

/* ══════════════════════════════════════════════════════
   MODALS
══════════════════════════════════════════════════════ */
.modal-overlay,.confirm-overlay{
  position:fixed;inset:0;
  background:rgba(13,27,42,.5);
  display:none;
  align-items:center;justify-content:center;
  z-index:600;padding:16px;
  backdrop-filter:blur(2px);
  opacity:0;
  transition:opacity .18s;
}
.modal-overlay.open,.confirm-overlay.open{display:flex}
.modal-overlay.visible,.confirm-overlay.visible{opacity:1}
.modal{
  background:#fff;border-radius:14px;
  box-shadow:var(--shadow-lg);
  width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;
  transform:translateY(14px);transition:transform .2s;
}
.modal-overlay.visible .modal,.confirm-overlay.visible .modal{transform:translateY(0)}
.modal-sm{max-width:420px}
.modal-lg{max-width:720px}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border);
  position:sticky;top:0;background:#fff;z-index:1;
}
.modal-title{display:flex;align-items:center;gap:10px;font-size:14.5px;font-weight:700}
.modal-title-icon{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;font-size:12px;color:#fff;flex-shrink:0}
.modal-close{
  width:28px;height:28px;border-radius:7px;
  display:grid;place-items:center;
  background:var(--bg);font-size:16px;color:var(--text-2);
  transition:all var(--t);
}
.modal-close:hover{background:#fee2e2;color:var(--red)}
.modal-body{padding:20px}
.modal-footer{
  padding:13px 20px;border-top:1px solid var(--border);
  display:flex;justify-content:flex-end;gap:8px;background:#fafbfc;
}

/* ══════════════════════════════════════════════════════
   EMPTY STATE
══════════════════════════════════════════════════════ */
.empty-state{text-align:center;padding:48px 20px}
.empty-icon{width:64px;height:64px;border-radius:16px;background:var(--bg);display:grid;place-items:center;font-size:26px;margin:0 auto 16px;color:var(--muted)}
.empty-state h3{font-size:15.5px;font-weight:700;color:var(--text);margin-bottom:6px}
.empty-state p{font-size:13.5px;color:var(--muted)}

/* ══════════════════════════════════════════════════════
   MISC COMPONENTS
══════════════════════════════════════════════════════ */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.two-col{display:grid;grid-template-columns:1.15fr 1fr;gap:16px;margin-top:8px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.detail-item{background:var(--bg);border-radius:8px;padding:11px 14px}
.detail-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:4px}
.detail-value{font-size:13.5px;color:var(--text)}
.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border);flex-wrap:wrap;gap:8px}
.pagination-info{font-size:12.5px;color:var(--muted)}
.pagination-btns{display:flex;gap:4px}
.confirm-box{background:#fff;border-radius:14px;padding:30px;width:100%;max-width:380px;box-shadow:var(--shadow-lg);text-align:center}
.confirm-icon{width:54px;height:54px;border-radius:50%;background:rgba(220,38,38,.08);display:grid;place-items:center;font-size:22px;color:var(--red);margin:0 auto 14px}
.confirm-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:6px}
.confirm-msg{font-size:13.5px;color:var(--text-2);margin-bottom:22px}
.confirm-btns{display:flex;gap:8px;justify-content:center}
.approval-check{width:16px;height:16px;cursor:pointer;accent-color:var(--green)}
.footnote{margin-top:28px;padding:16px 4px 8px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:11.5px;color:var(--muted);border-top:1px solid var(--border)}

/* Step wizard */
.step-wizard{display:flex;align-items:center;background:var(--card);border-radius:var(--r-card);border:1px solid var(--border);box-shadow:var(--shadow-card);padding:16px 20px;margin-bottom:16px;gap:0;overflow-x:auto}
.step-item{display:flex;align-items:center;gap:10px;flex-shrink:0;opacity:.45;transition:opacity var(--t)}
.step-item.active{opacity:1}
.step-item.done{opacity:.7}
.step-circle{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-size:13px;font-weight:700;background:var(--bg);border:2px solid var(--border);color:var(--muted);transition:all var(--t)}
.step-item.active .step-circle{background:var(--green);border-color:var(--green);color:#fff}
.step-item.done .step-circle{background:#dcfce7;border-color:var(--green);color:var(--green)}
.step-num{font-size:10.5px;color:var(--muted);font-weight:600}
.step-label{font-size:12.5px;font-weight:600;color:var(--text)}
.step-connector{flex:1;min-width:20px;height:2px;background:var(--border);margin:0 8px;transition:background var(--t)}
.step-connector.done{background:var(--green)}
.email-mode-group{display:flex;gap:8px}
.email-mode-btn{flex:1;padding:9px 12px;border-radius:var(--r-input);border:1.5px solid var(--border);background:var(--bg);font-size:12.5px;font-weight:500;color:var(--text-2);cursor:pointer;transition:all var(--t);text-align:center}
.email-mode-btn.active{border-color:var(--green);background:rgba(26,122,58,.06);color:var(--green);font-weight:700}

/* LOGIN */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#060e1f 0%,#0a1e10 60%,#0a1628 100%);padding:20px}
.login-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(20px);border-radius:18px;padding:38px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */
@media(max-width:1180px){
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .two-col{grid-template-columns:1fr}
  .charts-grid{grid-template-columns:1fr}
}
@media(max-width:1024px){
  .sidebar{
    position:fixed;top:0;left:0;height:100vh;
    transform:translateX(-100%);
    width:var(--sb-w)!important;min-width:var(--sb-w)!important;
    z-index:400;
  }
  .sidebar.mobile-open{transform:translateX(0);box-shadow:var(--shadow-lg)}
  .sidebar-overlay.show{display:block}
  .main-area{margin-left:0!important}
  .topbar-burger{display:flex}
  .topbar{padding:0 16px}
  /* Reset mini state on mobile */
  body.sidebar-mini .brand-text,
  body.sidebar-mini .nav-label,
  body.sidebar-mini .nav-section,
  body.sidebar-mini .nav-badge,
  body.sidebar-mini .user-details,
  body.sidebar-mini .brand-chevron{display:block!important}
  body.sidebar-mini .sidebar-brand{justify-content:flex-start;padding:0 16px;gap:10px;height:64px}
  body.sidebar-mini .nav-item{justify-content:flex-start;padding:9px 12px;gap:12px}
  body.sidebar-mini .sidebar-footer{padding:12px 16px;justify-content:flex-start;display:block}
  body.sidebar-mini .sidebar-user{justify-content:flex-start}
  .form-grid,.form-grid-3{grid-template-columns:1fr 1fr}
  .page-content{padding:16px}
  .search-wrap{display:none}
  .clock-date{display:none}
}
@media(max-width:640px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .form-grid,.form-grid-3{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}
  .filter-bar{flex-direction:column;align-items:stretch}
  .filter-count{margin-left:0}
  .page-header{flex-direction:column}
  .page-header-actions{width:100%;justify-content:flex-start}
  .page-header-left h1{font-size:20px}
  .topbar-clock{display:none}
  .stat-value{font-size:26px}
}
@media(min-width:1440px){
  .stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .page-content{padding:32px 36px}
}
@media(min-width:1920px){
  .page-content{padding:36px 44px}
  .stat-card{padding:22px}
}

/* Master data 3 col responsive */
.master-3col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;align-items:start}
@media(max-width:1100px){.master-3col{grid-template-columns:1fr 1fr!important}}
@media(max-width:700px) {.master-3col{grid-template-columns:1fr!important}}

/* ══════════════════════════════════════════════════════
   SVG NAV ICONS (Lucide style - matches design)
══════════════════════════════════════════════════════ */
.nav-icon-svg {
  flex-shrink: 0;
  display: block;
  opacity: .75;
  transition: opacity var(--t);
}
.nav-item:hover .nav-icon-svg { opacity: 1; }
.nav-item.active .nav-icon-svg { opacity: 1; color: var(--green-3); }

/* Topbar breadcrumb (design style) */
.topbar-eyebrow {
  font-size: 10px; font-weight: 700;
  color: var(--muted); letter-spacing: .08em;
  text-transform: uppercase; line-height: 1; margin-bottom: 3px;
}
.topbar-h {
  font-size: 15px; font-weight: 700;
  color: var(--text); line-height: 1.1;
}

/* Page title (design style) */
.page-title {
  font-size: 26px; font-weight: 800;
  color: var(--text); letter-spacing: -.015em;
  margin: 0 0 4px;
}
.page-sub {
  font-size: 13.5px; color: var(--text-2);
  margin: 0; max-width: 560px;
}
.crumbs {
  font-size: 11.5px; color: var(--muted);
  margin-bottom: 6px; letter-spacing: .01em;
}
.crumbs span { color: var(--text-2); font-weight: 600; }

/* Stat card sparkline area */
.stat-spark {
  opacity: .6;
  pointer-events: none;
}

/* Icon button (topbar) */
.icon-btn {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  color: var(--text-2); border-radius: var(--r-input);
  position: relative;
  transition: background var(--t), color var(--t);
}
.icon-btn:hover { background: var(--bg); color: var(--text); }
.icon-btn .dot {
  position: absolute; top: 8px; right: 9px;
  width: 7px; height: 7px; border-radius: 999px;
  border: 2px solid #fff;
}
.icon-btn .dot.red   { background: var(--red); }
.icon-btn .dot.amber { background: var(--amber); }

/* Avatar gradient variants (design pattern) */
.av-green  { background: linear-gradient(135deg, #34d399 0%, #15803d 100%); }
.av-blue   { background: linear-gradient(135deg, #38bdf8 0%, #0891b2 100%); }
.av-violet { background: linear-gradient(135deg, #a78bfa 0%, #7c3aed 100%); }
.av-amber  { background: linear-gradient(135deg, #fcd34d 0%, #d97706 100%); }

/* Stat delta badge */
.stat-delta {
  font-size: 11px; font-weight: 600;
  display: inline-flex; align-items: center; gap: 3px;
  white-space: nowrap;
}
.stat-delta.up   { color: #15803d; }
.stat-delta.down { color: #b45309; }
.stat-delta.neu  { color: var(--muted); }

/* Panel head actions */
.page-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.page-head {
  display: flex; align-items: flex-end;
  justify-content: space-between;
  gap: 24px; margin-bottom: 24px; flex-wrap: wrap;
}

/* TTE button (design specific) */
.btn-tte-sm {
  background: rgba(26,122,58,.08); color: var(--green-2);
  padding: 5px 11px; font-size: 11.5px; font-weight: 700;
  letter-spacing: .04em; border-radius: var(--r-input);
  text-transform: uppercase; display: inline-flex; align-items: center; gap: 5px;
  transition: all var(--t); cursor: pointer; border: none;
}
.btn-tte-sm:hover {
  background: linear-gradient(180deg, var(--green), var(--green-2));
  color: #fff;
}

/* Panel navigation footer (step wizard) */
.panel-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 20px; border-top: 1px solid var(--border);
  background: #fafbfc; gap: 8px;
}


/* ════════════════════════════════════════════════════
   DARK MODE
   ════════════════════════════════════════════════════ */
[data-theme="dark"] {
  --bg:       #0f172a;
  --card:     #1e293b;
  --text:     #f1f5f9;
  --text-2:   #94a3b8;
  --muted:    #64748b;
  --border:   #334155;
  --border-2: #475569;
  --bg-card:  #1e293b;
  --text-1:   #f1f5f9;
  --text-3:   #64748b;
}
[data-theme="dark"] body          { background: #0f172a; color: #f1f5f9; }
[data-theme="dark"] .topbar       { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .panel        { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .panel-header { background: #16213a; border-color: #334155; }
[data-theme="dark"] .stat-card    { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .modal        { background: #1e293b; }
[data-theme="dark"] .modal-header { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .modal-footer,.panel-nav { background: #16213a; border-color: #334155; }
[data-theme="dark"] .form-control { background: #0f172a; border-color: #334155; color: #f1f5f9; }
[data-theme="dark"] .form-control:focus { border-color: var(--green); }
[data-theme="dark"] .btn-outline  { background: #1e293b; border-color: #475569; color: #cbd5e1; }
[data-theme="dark"] .btn-outline:hover { border-color: var(--green); color: var(--green-3); }
[data-theme="dark"] thead th      { background: #16213a; color: #64748b; }
[data-theme="dark"] tbody td      { border-color: #334155; }
[data-theme="dark"] tbody tr:hover td { background: rgba(26,122,58,.08); }
[data-theme="dark"] .badge-default { background: #334155; color: #94a3b8; border-color: #475569; }
[data-theme="dark"] .detail-item  { background: #0f172a; }
[data-theme="dark"] .empty-icon   { background: #0f172a; }
[data-theme="dark"] .topbar-clock { background: #0f172a; border-color: #334155; }
[data-theme="dark"] .filter-bar .form-control { background: #0f172a; }
[data-theme="dark"] .step-wizard  { background: #1e293b; border-color: #334155; }
[data-theme="dark"] .step-circle  { background: #0f172a; border-color: #475569; }
[data-theme="dark"] .confirm-box  { background: #1e293b; }
[data-theme="dark"] .search-wrap  { background: #0f172a; border-color: #334155; }
[data-theme="dark"] .search-wrap input { color: #f1f5f9; }

/* Smooth theme transition */
body, .topbar, .panel, .stat-card, .modal, .form-control, .sidebar,
.btn, thead th, tbody td, .badge-default, .topbar-clock, .step-wizard {
  transition: background var(--t), border-color var(--t), color var(--t);
}

/* Dark mode toggle button */
.theme-toggle {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: var(--r-input);
  background: none; border: none; cursor: pointer;
  color: var(--text-2); font-size: 16px;
  transition: background var(--t), color var(--t);
}
.theme-toggle:hover { background: var(--bg); color: var(--text); }

/* ════════════════════════════════════════════════════
   CHART CONTAINERS
   ════════════════════════════════════════════════════ */
.chart-wrap {
  position: relative;
  padding: 16px;
}
.chart-wrap canvas {
  max-height: 220px;
}
.chart-legend {
  display: flex; flex-wrap: wrap; gap: 8px 16px;
  padding: 10px 16px; border-top: 1px solid var(--border);
}
.chart-legend-item {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500; color: var(--text-2);
}
.chart-legend-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.charts-2col {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 14px; margin-bottom: 14px;
}
@media (max-width: 1024px) { .charts-2col { grid-template-columns: 1fr; } }

/* ════════════════════════════════════════════════════
   ENHANCED ANIMATIONS
   ════════════════════════════════════════════════════ */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: none; }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes countUp {
  from { opacity: 0; transform: scale(.85); }
  to   { opacity: 1; transform: scale(1); }
}
.stat-card     { animation: slideUp .3s ease both; }
.stat-card:nth-child(1) { animation-delay: .05s; }
.stat-card:nth-child(2) { animation-delay: .10s; }
.stat-card:nth-child(3) { animation-delay: .15s; }
.stat-card:nth-child(4) { animation-delay: .20s; }
.stat-value    { animation: countUp .4s ease both; animation-delay: .25s; }
.panel         { animation: slideUp .3s ease both; animation-delay: .1s; }

/* ════════════════════════════════════════════════════
   MOBILE IMPROVEMENTS
   ════════════════════════════════════════════════════ */
@media (max-width: 640px) {
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .stat-card  { padding: 14px; }
  .stat-value { font-size: 24px; }
  .stat-icon-wrap { width: 32px; height: 32px; font-size: 14px; }
  .page-content { padding: 14px 12px; }
  .panel-header { padding: 12px 14px; }
  .panel-body   { padding: 12px; }
  thead th, tbody td { padding: 10px 12px; }
  .charts-2col { grid-template-columns: 1fr; }
  .page-header  { gap: 12px; }
  .page-header-left h1 { font-size: 20px; }
  .topbar { padding: 0 14px; gap: 8px; }
  .search-wrap { display: none; }
  .topbar-clock { display: none; }
}
@media (max-width: 380px) {
  .stats-grid { grid-template-columns: 1fr; }
}
