/* ============================================================
   TOKE EMAS — style.css v2.0
   Obsidian Gold 3D Edition — High Contrast + Shining Effects
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --gold:        #D4A843;
  --gold-light:  #FFE082;
  --gold-bright: #FFD54F;
  --gold-dim:    #9A7120;
  --gold-glow:   rgba(212,168,67,.5);
  --gold-faint:  rgba(212,168,67,.08);
  --bg-app:      #06060F;
  --bg-sidebar:  #09091A;
  --bg-card:     #0F0E22;
  --bg-card2:    #0C0B1E;
  --bg-input:    #0A0918;
  --border:      rgba(212,168,67,.25);
  --border-dim:  rgba(212,168,67,.1);
  --text-prim:   #F5F0FF;
  --text-sec:    #C8C0DC;
  --text-mute:   #7A7090;
  --danger:      #FF5252;
  --danger-bg:   rgba(255,82,82,.12);
  --success:     #69F0AE;
  --success-bg:  rgba(105,240,174,.1);
  --font:        'Segoe UI', system-ui, sans-serif;
  --mono:        'Courier New', monospace;
  --radius:      12px;
  --radius-sm:   7px;
  --radius-lg:   16px;
  --trans:       all .2s ease;
}

html, body { height:100%; font-family:var(--font); background:var(--bg-app); color:var(--text-prim); font-size:13px; line-height:1.5; overflow:hidden; }
a { color:var(--gold); text-decoration:none; }
a:hover { color:var(--gold-light); }
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(212,168,67,.3); border-radius:2px; }

/* ---- ANIMATIONS ---- */
@keyframes float-light { 0%,100%{transform:translateY(0) translateX(0);opacity:.7} 33%{transform:translateY(-14px) translateX(10px);opacity:1} 66%{transform:translateY(7px) translateX(-12px);opacity:.8} }
@keyframes shimmer { 0%{background-position:-300% center} 100%{background-position:300% center} }
@keyframes gold-shine { 0%,100%{box-shadow:0 0 10px var(--gold-glow),0 0 30px rgba(212,168,67,.15),inset 0 1px 0 rgba(255,224,130,.2)} 50%{box-shadow:0 0 22px var(--gold-glow),0 0 55px rgba(212,168,67,.25),0 0 80px rgba(212,168,67,.08),inset 0 1px 0 rgba(255,224,130,.4)} }
@keyframes text-shine { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes scanline { 0%{transform:translateY(-4px);opacity:0} 5%{opacity:1} 95%{opacity:1} 100%{transform:translateY(100vh);opacity:0} }
@keyframes ping-dot { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.8);opacity:.3} }
@keyframes fade-in { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }
@keyframes slide-left { from{opacity:0;transform:translateX(-20px)} to{opacity:1;transform:translateX(0)} }
@keyframes rotate-glow { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
@keyframes card-float { 0%,100%{transform:translateY(0) rotateX(0deg)} 50%{transform:translateY(-2px) rotateX(1deg)} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes border-glow { 0%,100%{opacity:.6} 50%{opacity:1} }

/* ---- BACKGROUND TEXTURE ---- */
body::before {
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 20% -10%, rgba(212,168,67,.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 110%, rgba(212,168,67,.08) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 50% 50%, rgba(212,168,67,.03) 0%, transparent 70%);
}

/* ---- AMBIENT ORBS ---- */
.amb-orb { position:fixed; border-radius:50%; pointer-events:none; z-index:0; }
.amb-1 { width:500px;height:500px;background:radial-gradient(circle,rgba(212,168,67,.1) 0%,transparent 65%);top:-150px;left:80px;animation:float-light 12s ease-in-out infinite; }
.amb-2 { width:300px;height:300px;background:radial-gradient(circle,rgba(212,168,67,.07) 0%,transparent 65%);top:40%;right:60px;animation:float-light 15s ease-in-out infinite reverse; }
.amb-3 { width:200px;height:200px;background:radial-gradient(circle,rgba(212,168,67,.06) 0%,transparent 65%);bottom:80px;left:260px;animation:float-light 10s ease-in-out infinite 3s; }

.scan-line { position:fixed;left:0;right:0;height:1px;z-index:999;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(212,168,67,.2) 50%,transparent 100%);animation:scanline 10s linear infinite; }

/* ---- APP LAYOUT ---- */
.app-wrapper { display:flex;height:100vh;position:relative;overflow:hidden; }

/* ---- SIDEBAR ---- */
.sidebar {
  width:205px;flex-shrink:0;
  background:linear-gradient(180deg, #0B0A1E 0%, #070616 100%);
  border-right:1px solid rgba(212,168,67,.2);
  display:flex;flex-direction:column;position:relative;z-index:10;
  overflow:hidden;animation:slide-left .4s ease;
}
.sidebar::before { content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(212,168,67,.8),transparent); }
.sidebar::after { content:'';position:absolute;top:0;right:0;bottom:0;width:1px;background:linear-gradient(180deg,rgba(212,168,67,.6),rgba(212,168,67,.05) 50%,rgba(212,168,67,.6)); }

/* Gold shining background strip on sidebar */
.sidebar-shine {
  position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;
  background:linear-gradient(135deg, rgba(212,168,67,.04) 0%, transparent 50%, rgba(212,168,67,.04) 100%);
  background-size:200% 200%;
  animation:rotate-glow 8s ease infinite;
}

.logo-area { padding:20px 16px 18px;border-bottom:1px solid rgba(212,168,67,.12);position:relative;z-index:1; }
.logo-area::after { content:'';position:absolute;bottom:-1px;left:12px;right:12px;height:1px;background:linear-gradient(90deg,transparent,rgba(212,168,67,.5),transparent); }

.logo-gem {
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg, #D4A843, #9A7120);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  margin-bottom:12px;
  animation:gold-shine 3s ease-in-out infinite;
}
.logo-name {
  font-size:14px;font-weight:800;letter-spacing:.12em;
  background:linear-gradient(90deg, #D4A843 0%, #FFE082 20%, #FFD54F 40%, #FFE082 60%, #D4A843 80%, #FFE082 100%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  animation:text-shine 2.5s linear infinite;
}
.logo-sub { font-size:10px;color:#6A6085;margin-top:3px;letter-spacing:.05em; }

.nav-area { flex:1;padding:10px 8px;overflow-y:auto;position:relative;z-index:1; }
.nav-group { font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:#4A4068;padding:12px 8px 4px;font-weight:700; }

.nav-item {
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);
  font-size:11px;color:#9A90B0;margin-bottom:2px;cursor:pointer;
  transition:var(--trans);position:relative;overflow:hidden;text-decoration:none;
}
.nav-item::before { content:'';position:absolute;inset:0;border-radius:var(--radius-sm);opacity:0;background:linear-gradient(90deg,rgba(212,168,67,.15),rgba(212,168,67,.04));transition:opacity .2s; }
.nav-item:hover::before,.nav-item.active::before { opacity:1; }
.nav-item:hover { color:#D4A843; }
.nav-item.active { color:#FFE082;font-weight:600; }
.nav-item.active::after { content:'';position:absolute;left:0;top:18%;bottom:18%;width:3px;border-radius:2px;background:linear-gradient(180deg,transparent,#D4A843,transparent);box-shadow:0 0 10px #D4A843; }
.nav-item i { font-size:16px;position:relative;z-index:1; }
.nav-item span { position:relative;z-index:1; }

.sidebar-footer { padding:14px;border-top:1px solid rgba(212,168,67,.1);position:relative;z-index:1; }
.user-chip { display:flex;align-items:center;gap:10px; }
.user-av {
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#D4A843,#9A7120);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:#1a1000;
  box-shadow:0 0 12px rgba(212,168,67,.45);
}
.user-name { font-size:12px;color:#E0D8F8;font-weight:700; }
.user-role { font-size:9px;color:#5A5075;text-transform:uppercase;letter-spacing:.06em; }
.logout-link { display:block;margin-top:8px;font-size:10px;color:#5A5075;text-align:center;padding:6px;border:1px solid rgba(212,168,67,.12);border-radius:var(--radius-sm);transition:var(--trans); }
.logout-link:hover { border-color:var(--danger);color:var(--danger);background:var(--danger-bg); }

/* ---- MAIN AREA ---- */
.main-area { flex:1;display:flex;flex-direction:column;min-width:0;position:relative;z-index:5; }

.topbar {
  height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 22px;
  background:rgba(6,6,15,.9);border-bottom:1px solid rgba(212,168,67,.12);
  position:relative;backdrop-filter:blur(10px);
}
.topbar::after { content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(212,168,67,.4),transparent); }
.page-title { font-size:15px;font-weight:700;color:#F5F0FF;display:flex;align-items:center;gap:9px; }
.page-title i { color:#D4A843;font-size:18px; }

.topbar-right { display:flex;align-items:center;gap:14px; }
.gold-ticker {
  display:flex;align-items:center;gap:7px;
  background:rgba(212,168,67,.08);border:1px solid rgba(212,168,67,.3);
  border-radius:20px;padding:5px 14px;font-size:11px;color:#FFE082;font-weight:600;
  box-shadow:0 0 10px rgba(212,168,67,.12);
}
.ticker-dot { width:7px;height:7px;border-radius:50%;background:#D4A843;box-shadow:0 0 8px #D4A843;animation:ping-dot 2s infinite; }
.topbar-date { font-size:11px;color:#7A7090; }

/* ---- PAGE CONTENT ---- */
.page-content { flex:1;overflow-y:auto;padding:20px 22px;animation:fade-in .35s ease; }

/* ---- STAT CARDS 3D ---- */
.stat-grid { display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px; }

.stat-card {
  border-radius:var(--radius);padding:16px 18px;
  background:linear-gradient(145deg, #141230, #0E0C24);
  position:relative;overflow:hidden;cursor:default;
  transition:transform .25s,box-shadow .25s;
  transform-style:preserve-3d;
  /* 3D border effect */
  box-shadow:
    0 1px 0 rgba(255,224,130,.15) inset,
    0 -1px 0 rgba(0,0,0,.5) inset,
    0 6px 20px rgba(0,0,0,.4),
    0 2px 6px rgba(0,0,0,.3);
}
.stat-card:hover {
  transform:translateY(-4px) rotateX(3deg);
  box-shadow:
    0 1px 0 rgba(255,224,130,.25) inset,
    0 -1px 0 rgba(0,0,0,.5) inset,
    0 16px 40px rgba(212,168,67,.2),
    0 8px 16px rgba(0,0,0,.4),
    0 0 20px rgba(212,168,67,.1);
}
/* Animated gold border */
.stat-card::before {
  content:'';position:absolute;inset:0;border-radius:var(--radius);padding:1px;
  background:linear-gradient(135deg, rgba(212,168,67,.7), rgba(212,168,67,.08) 40%, rgba(212,168,67,.5));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation:border-glow 3s ease-in-out infinite;
}
/* Shimmer sweep */
.stat-card::after {
  content:'';position:absolute;top:0;left:-150%;width:60%;height:100%;
  background:linear-gradient(105deg,transparent,rgba(255,224,130,.08),transparent);
  animation:shimmer 4s infinite;pointer-events:none;
}
.stat-corner-light { position:absolute;top:-25px;right:-25px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(212,168,67,.18) 0%,transparent 70%);pointer-events:none; }
.stat-val { font-size:26px;font-weight:800;color:#FFE082;font-family:var(--mono);text-shadow:0 0 18px rgba(255,224,130,.5),0 2px 4px rgba(0,0,0,.5);position:relative;z-index:1; }
.stat-val.sm { font-size:16px;line-height:1.3; }
.stat-lbl { font-size:10px;color:#9A90B0;text-transform:uppercase;letter-spacing:.1em;margin-top:5px;position:relative;z-index:1;font-weight:600; }
.stat-icon { position:absolute;bottom:12px;right:14px;font-size:28px;color:rgba(212,168,67,.09);z-index:0; }

/* ---- SECTION HEADER ---- */
.section-hdr { display:flex;align-items:center;justify-content:space-between;margin-bottom:12px; }
.section-title {
  font-size:10px;font-weight:700;color:#8A8098;text-transform:uppercase;letter-spacing:.12em;
  display:flex;align-items:center;gap:10px;
}
.section-title::before { content:'';width:18px;height:2px;background:linear-gradient(90deg,rgba(212,168,67,.9),transparent);border-radius:1px; }

/* ---- BAKI CARDS 3D ---- */
.baki-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px;margin-bottom:18px; }

.baki-card {
  border-radius:var(--radius);padding:14px;
  background:linear-gradient(145deg, #131128, #0D0B1E);
  position:relative;overflow:hidden;cursor:pointer;
  transition:all .3s ease;
  transform-style:preserve-3d;
  box-shadow:0 4px 15px rgba(0,0,0,.5),0 1px 0 rgba(255,224,130,.1) inset,0 -2px 0 rgba(0,0,0,.4) inset;
}
.baki-card:hover {
  transform:translateY(-5px) rotateX(4deg) rotateY(-1deg);
  box-shadow:0 16px 40px rgba(212,168,67,.25),0 8px 20px rgba(0,0,0,.4),0 0 20px rgba(212,168,67,.1),0 1px 0 rgba(255,224,130,.2) inset;
}
.baki-card::before {
  content:'';position:absolute;inset:0;border-radius:var(--radius);padding:1px;
  background:linear-gradient(135deg,rgba(212,168,67,.45),rgba(212,168,67,.05) 45%,rgba(212,168,67,.3));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
}
.baki-card::after { content:'';position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,224,130,.09),transparent);animation:shimmer 7s infinite;pointer-events:none; }
.baki-card.warn-low::before { background:linear-gradient(135deg,rgba(255,82,82,.5),rgba(255,82,82,.06) 45%,rgba(255,82,82,.3)); }
.baki-card.warn-low:hover { box-shadow:0 16px 40px rgba(255,82,82,.2),0 8px 20px rgba(0,0,0,.4); }

/* Baki card top light reflection */
.baki-corner { position:absolute;top:-20px;right:-20px;width:65px;height:65px;border-radius:50%;background:radial-gradient(circle,rgba(212,168,67,.15) 0%,transparent 70%);pointer-events:none; }

.bk-id { font-size:9px;font-weight:800;color:#D4A843;letter-spacing:.12em;text-shadow:0 0 10px rgba(212,168,67,.6);margin-bottom:4px; }
.bk-id.danger { color:#FF5252;text-shadow:0 0 10px rgba(255,82,82,.6); }
.bk-name { font-size:12px;font-weight:700;color:#F0ECF8;margin-bottom:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.bk-tags { display:flex;flex-wrap:wrap;gap:3px;margin-bottom:9px; }
.bk-tag { font-size:9px;padding:2px 7px;border-radius:4px;background:rgba(212,168,67,.12);color:#C09030;border:1px solid rgba(212,168,67,.25);font-weight:700; }

.bk-ratio { display:flex;align-items:baseline;gap:2px;margin-bottom:5px; }
.bk-sisa { font-size:22px;font-weight:800;color:#FFE082;font-family:var(--mono);text-shadow:0 0 12px rgba(255,224,130,.4),0 2px 4px rgba(0,0,0,.5);line-height:1; }
.bk-sisa.danger { color:#FF8080;text-shadow:0 0 12px rgba(255,128,128,.5); }
.bk-sep { font-size:13px;color:#4A4068; }
.bk-total { font-size:13px;color:#6A6085;font-family:var(--mono); }
.bk-unit { font-size:9px;color:#4A4068;margin-left:3px; }

.prog-bar { position:relative;height:4px;background:rgba(212,168,67,.08);border-radius:2px;margin:6px 0; }
.prog-fill { height:100%;border-radius:2px;background:linear-gradient(90deg,#9A7120,#D4A843,#FFE082);position:relative; }
.prog-fill::after { content:'';position:absolute;right:-2px;top:-4px;width:12px;height:12px;border-radius:50%;background:#FFE082;box-shadow:0 0 10px #D4A843,0 0 20px rgba(212,168,67,.5); }
.prog-fill.danger { background:linear-gradient(90deg,#7a1010,#CC3030,#FF6060); }
.prog-fill.danger::after { background:#FF6060;box-shadow:0 0 10px #CC3030; }
.bk-gram { font-size:10px;color:#8A8098;margin-top:3px;font-weight:500; }
.bk-kadar { display:inline-block;font-size:9px;padding:2px 7px;border-radius:4px;background:rgba(212,168,67,.08);color:#7A6030;border:1px solid rgba(212,168,67,.15);margin-top:6px;font-weight:600; }

.add-baki-btn { border-radius:var(--radius);padding:14px;border:1px dashed rgba(212,168,67,.25);background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;cursor:pointer;color:#5A5075;min-height:130px;font-size:11px;transition:var(--trans);font-weight:600; }
.add-baki-btn:hover { border-color:#D4A843;color:#D4A843;background:rgba(212,168,67,.05);box-shadow:0 0 15px rgba(212,168,67,.1); }
.add-baki-btn i { font-size:24px; }

/* ---- TRANSACTION TABLE ---- */
.tx-table-wrap { border-radius:var(--radius);overflow:hidden;border:1px solid rgba(212,168,67,.12);box-shadow:0 4px 20px rgba(0,0,0,.3); }
.tx-table { width:100%;border-collapse:collapse;font-size:11px; }
.tx-table thead tr { background:linear-gradient(90deg,rgba(212,168,67,.08),rgba(212,168,67,.04)); }
.tx-table th { padding:10px 14px;text-align:left;font-size:9px;font-weight:800;color:#9A90B0;text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid rgba(212,168,67,.12); }
.tx-table td { padding:10px 14px;border-bottom:1px solid rgba(212,168,67,.05);color:#C8C0DC;vertical-align:middle; }
.tx-table tr:last-child td { border-bottom:none; }
.tx-table tbody tr:hover { background:rgba(212,168,67,.04); }
.td-baki { font-size:10px;font-weight:800;color:#D4A843;text-shadow:0 0 8px rgba(212,168,67,.4); }
.td-date { color:#6A6085;font-size:10px; }
.td-qty-neg { color:#FF5252;font-weight:800;font-family:var(--mono); }
.td-qty-pos { color:#69F0AE;font-weight:800;font-family:var(--mono); }
.td-gram { font-family:var(--mono);font-size:11px;color:#C8C0DC; }
.td-det { color:#A8A0C0; }

.pill { display:inline-block;font-size:9px;padding:3px 8px;border-radius:4px;font-weight:800; }
.pill-jual { background:rgba(255,82,82,.15);color:#FF8080;border:1px solid rgba(255,82,82,.3); }
.pill-restok { background:rgba(105,240,174,.1);color:#69F0AE;border:1px solid rgba(105,240,174,.2); }
.pill-masuk { background:rgba(100,150,255,.1);color:#90B0FF;border:1px solid rgba(100,150,255,.2); }

/* ---- BUTTONS ---- */
.btn { display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius-sm);font-size:11px;font-weight:700;cursor:pointer;transition:var(--trans);border:none;font-family:var(--font);letter-spacing:.03em; }
.btn-gold { background:linear-gradient(135deg,#9A7120,#D4A843,#FFD54F);color:#1a1000;box-shadow:0 0 14px rgba(212,168,67,.35),0 2px 8px rgba(0,0,0,.3),0 1px 0 rgba(255,224,130,.5) inset; }
.btn-gold:hover { background:linear-gradient(135deg,#D4A843,#FFE082);box-shadow:0 0 24px rgba(212,168,67,.6),0 4px 16px rgba(0,0,0,.3);transform:translateY(-1px); }
.btn-outline { background:transparent;color:#D4A843;border:1px solid rgba(212,168,67,.35); }
.btn-outline:hover { background:rgba(212,168,67,.09);border-color:#D4A843;box-shadow:0 0 12px rgba(212,168,67,.15); }
.btn-ghost { background:rgba(255,255,255,.05);color:#C8C0DC;border:1px solid rgba(212,168,67,.1); }
.btn-ghost:hover { background:rgba(255,255,255,.09);color:#F5F0FF; }
.btn-danger { background:var(--danger-bg);color:#FF5252;border:1px solid rgba(255,82,82,.3); }
.btn-danger:hover { background:rgba(255,82,82,.22);box-shadow:0 0 14px rgba(255,82,82,.2); }
.btn-success { background:var(--success-bg);color:#69F0AE;border:1px solid rgba(105,240,174,.25); }
.btn-sm { padding:5px 11px;font-size:10px; }
.btn-lg { padding:11px 22px;font-size:13px; }

/* ---- FORMS ---- */
.form-group { margin-bottom:15px; }
.form-label { display:block;font-size:10px;font-weight:800;color:#8A8098;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px; }
.form-control {
  width:100%;padding:10px 13px;
  background:linear-gradient(145deg,#0C0A1E,#0A0818);
  color:#F5F0FF;border:1px solid rgba(212,168,67,.15);border-radius:var(--radius-sm);
  font-size:12px;font-family:var(--font);transition:var(--trans);outline:none;
  box-shadow:0 2px 8px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.03);
}
.form-control:focus { border-color:rgba(212,168,67,.55);box-shadow:0 0 0 3px rgba(212,168,67,.12),0 2px 8px rgba(0,0,0,.3); }
.form-control::placeholder { color:#4A4068; }
select.form-control option { background:#1A1630; }
.form-row { display:grid;grid-template-columns:1fr 1fr;gap:13px; }
.form-error { font-size:10px;color:#FF5252;margin-top:5px; }

/* ---- PANEL ---- */
.panel {
  background:linear-gradient(145deg,#131128,#0E0C22);
  border:1px solid rgba(212,168,67,.2);
  border-radius:var(--radius-lg);padding:18px 20px;
  position:relative;overflow:hidden;margin-bottom:15px;
  box-shadow:0 8px 30px rgba(0,0,0,.4),0 1px 0 rgba(255,224,130,.1) inset;
}
.panel::before { content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(212,168,67,.6),transparent); }
.panel-title { font-size:14px;font-weight:700;color:#F5F0FF;margin-bottom:16px;display:flex;align-items:center;gap:9px; }
.panel-title i { color:#D4A843; }

/* ---- MODAL ---- */
.modal-overlay { position:fixed;inset:0;z-index:100;background:rgba(3,2,10,.8);display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px);animation:fade-in .2s ease; }
.modal-box {
  background:linear-gradient(145deg,#141230,#0E0C24);
  border:1px solid rgba(212,168,67,.25);border-radius:var(--radius-lg);
  padding:22px 24px;width:100%;max-width:420px;position:relative;overflow:hidden;
  animation:fade-in .25s ease;
  box-shadow:0 24px 60px rgba(0,0,0,.6),0 0 40px rgba(212,168,67,.08),0 1px 0 rgba(255,224,130,.15) inset;
}
.modal-box::before { content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,#D4A843,transparent); }
.modal-title { font-size:14px;font-weight:700;color:#F5F0FF;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between; }
.modal-close { background:none;border:none;color:#5A5075;cursor:pointer;font-size:20px;padding:2px;transition:var(--trans); }
.modal-close:hover { color:#F5F0FF; }

/* ---- BADGES ---- */
.badge { display:inline-block;font-size:9px;padding:2px 8px;border-radius:4px;font-weight:800; }
.badge-gold { background:rgba(212,168,67,.15);color:#D4A843;border:1px solid rgba(212,168,67,.3); }
.badge-danger { background:var(--danger-bg);color:#FF5252;border:1px solid rgba(255,82,82,.3); }
.badge-success { background:var(--success-bg);color:#69F0AE;border:1px solid rgba(105,240,174,.25); }
.badge-mute { background:rgba(255,255,255,.06);color:#7A7090;border:1px solid rgba(255,255,255,.08); }
.badge-owner { background:rgba(212,168,67,.12);color:#D4A843;border:1px solid rgba(212,168,67,.25); }
.badge-karyawan { background:rgba(100,150,255,.1);color:#90B0FF;border:1px solid rgba(100,150,255,.2); }

/* ---- DIVIDER ---- */
.divider { height:1px;background:linear-gradient(90deg,transparent,rgba(212,168,67,.2),transparent);margin:16px 0; }

/* ---- ALERT ---- */
.alert { border-radius:var(--radius-sm);padding:11px 15px;font-size:11px;margin-bottom:14px;border-left:3px solid;font-weight:500; }
.alert-danger { background:rgba(255,82,82,.1);color:#FF9090;border-color:#FF5252; }
.alert-success { background:rgba(105,240,174,.1);color:#80F0C0;border-color:#69F0AE; }
.alert-warn { background:rgba(212,168,67,.1);color:#FFD070;border-color:#D4A843; }

/* ---- SPINNER ---- */
.spinner { width:20px;height:20px;border:2px solid rgba(212,168,67,.2);border-top-color:#D4A843;border-radius:50%;animation:spin .7s linear infinite;display:inline-block; }

/* ---- EMPTY STATE ---- */
.empty-state { text-align:center;padding:40px 20px;color:#5A5075; }
.empty-state i { font-size:40px;margin-bottom:12px;display:block;opacity:.25; }
.empty-state p { font-size:12px;color:#6A6085; }

/* ---- LOGIN PAGE ---- */
.login-page { min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-app);position:relative;overflow:hidden; }
.login-box {
  width:380px;padding:40px 34px;
  background:linear-gradient(145deg,#131128,#0D0B1E);
  border:1px solid rgba(212,168,67,.25);border-radius:var(--radius-lg);
  position:relative;overflow:hidden;animation:fade-in .4s ease;
  box-shadow:0 24px 70px rgba(0,0,0,.6),0 0 50px rgba(212,168,67,.1),0 1px 0 rgba(255,224,130,.15) inset;
}
.login-box::before { content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,#D4A843,transparent); }
.login-logo { text-align:center;margin-bottom:30px; }
.login-gem { width:56px;height:56px;border-radius:15px;background:linear-gradient(135deg,#D4A843,#9A7120);display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 15px;animation:gold-shine 3s ease-in-out infinite; }
.login-title { font-size:20px;font-weight:800;letter-spacing:.1em;background:linear-gradient(90deg,#D4A843 0%,#FFE082 40%,#D4A843 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:text-shine 2.5s linear infinite; }
.login-sub { font-size:11px;color:#5A5075;margin-top:5px;font-weight:500; }
.login-btn { width:100%;padding:12px;margin-top:8px;font-size:13px; }

/* ---- UPLOAD ZONE ---- */
.upload-zone { border:1px dashed rgba(212,168,67,.3);border-radius:var(--radius);padding:22px;text-align:center;cursor:pointer;transition:var(--trans);position:relative;overflow:hidden;background:rgba(212,168,67,.02); }
.upload-zone:hover { border-color:#D4A843;background:rgba(212,168,67,.06); }
.upload-zone.has-image { padding:6px; }
.upload-zone input[type=file] { position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%; }
.upload-zone img { width:100%;max-height:190px;object-fit:contain;border-radius:var(--radius-sm);display:block; }
.upload-icon { font-size:30px;color:#5A5075;margin-bottom:9px; }
.upload-txt { font-size:12px;color:#8A8098;font-weight:500; }
.upload-sub { font-size:10px;color:#5A5075;margin-top:4px;opacity:.7; }

/* ---- DATA TABLE ---- */
.data-table { width:100%;border-collapse:collapse; }
.data-table th { font-size:9px;font-weight:800;color:#9A90B0;text-transform:uppercase;letter-spacing:.1em;padding:9px 13px;background:rgba(212,168,67,.05);border-bottom:1px solid rgba(212,168,67,.12);text-align:left; }
.data-table td { padding:11px 13px;border-bottom:1px solid rgba(212,168,67,.05);font-size:11px;color:#C8C0DC; }
.data-table tr:hover td { background:rgba(212,168,67,.03); }
.data-table tr:last-child td { border-bottom:none; }

/* ---- STEP INDICATOR ---- */
.step-indicator { display:flex;align-items:center;margin-bottom:18px; }
.step-node { display:flex;align-items:center;gap:7px;padding:7px 16px;border:1px solid rgba(212,168,67,.1);background:rgba(212,168,67,.03);font-size:11px;color:#5A5075;font-weight:600; }
.step-node:first-child { border-radius:var(--radius-sm) 0 0 var(--radius-sm); }
.step-node:last-child { border-radius:0 var(--radius-sm) var(--radius-sm) 0; }
.step-node.active { background:rgba(212,168,67,.12);color:#FFE082;border-color:rgba(212,168,67,.4); }
.step-node.done { background:rgba(105,240,174,.08);color:#69F0AE;border-color:rgba(105,240,174,.2); }
.step-sep { width:1px;height:34px;background:rgba(212,168,67,.1);flex-shrink:0; }

/* ---- CHART WRAP ---- */
.chart-wrap { background:linear-gradient(145deg,#0E0C1E,#0A0818);border:1px solid rgba(212,168,67,.1);border-radius:var(--radius);padding:16px;margin-bottom:15px;box-shadow:0 4px 16px rgba(0,0,0,.3); }
.chart-title { font-size:10px;font-weight:800;color:#8A8098;text-transform:uppercase;letter-spacing:.1em;margin-bottom:13px; }

/* ---- UTILITIES ---- */
.flex { display:flex; }
.flex-center { display:flex;align-items:center;justify-content:center; }
.gap-8 { gap:8px; }
.gap-12 { gap:12px; }
.mb-8 { margin-bottom:8px; }
.mb-14 { margin-bottom:14px; }
.text-gold { color:#D4A843; }
.text-mute { color:#7A7090; }
.text-danger { color:#FF5252; }
.text-success { color:#69F0AE; }
.text-prim { color:#F5F0FF; }
.text-sm { font-size:11px; }
.text-xs { font-size:10px; }
.font-mono { font-family:var(--mono); }
.fw-bold { font-weight:700; }
.fw-800 { font-weight:800; }
.w-100 { width:100%; }
.d-none { display:none !important; }
.ml-auto { margin-left:auto; }