@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;600;700;800&display=swap');

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

:root {
  --primary: #d61e30; 
  --primary-light: #ffebed;
  --bg: #f8f9fa;
  --card: #ffffff;
  --border: #e9ecef;
  --text: #1a1a2e;
  --muted: #6c757d;
  --success: #10b981;
  --danger: #ef4444;
  --radius: 24px;
  --shadow: 0 10px 30px -5px rgba(0,0,0,0.05);
  --transition-smooth: all 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}

html[data-theme="dark"],
body[data-theme="dark"],
[data-theme="dark"] {
  --bg: #0f1115;
  --card: #1a1d23;
  --border: #2d3139;
  --text: #ffffff;
  --muted: #c4c9d0;
  --primary-light: rgba(214, 30, 48, 0.15);
}

body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  padding: 20px;
  transition: background 0.5s ease, color 0.3s ease;
  -webkit-font-smoothing: antialiased;
  overscroll-behavior-y: contain;
}

.container { max-width: 500px; margin: 0 auto; padding-bottom: 40px; }

/* ── VIEW TRANSITIONS ── */
.view-container { display: none; }
.view-active { 
  display: block;
  animation: viewEnter 0.38s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes viewEnter {
  from { opacity: 0; transform: translateY(24px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── STAGGERED CARD ENTRANCE ── */
@keyframes cardEnter {
  from { opacity: 0; transform: translateY(20px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-16px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes popIn {
  0%   { opacity: 0; transform: scale(0.85); }
  70%  { transform: scale(1.04); }
  100% { opacity: 1; transform: scale(1); }
}

.menu-grid .menu-card {
  animation: cardEnter 0.4s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.menu-grid .menu-card:nth-child(1) { animation-delay: 0.04s; }
.menu-grid .menu-card:nth-child(2) { animation-delay: 0.08s; }
.menu-grid .menu-card:nth-child(3) { animation-delay: 0.12s; }
.menu-grid .menu-card:nth-child(4) { animation-delay: 0.16s; }
.menu-grid .menu-card:nth-child(5) { animation-delay: 0.20s; }
.menu-grid .menu-card:nth-child(6) { animation-delay: 0.24s; }
.menu-grid .menu-card:nth-child(7) { animation-delay: 0.28s; }
.menu-grid .menu-card:nth-child(8) { animation-delay: 0.32s; }

.section-group {
  animation: cardEnter 0.38s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.section-group:nth-child(1) { animation-delay: 0.06s; }
.section-group:nth-child(2) { animation-delay: 0.12s; }
.section-group:nth-child(3) { animation-delay: 0.18s; }
.section-group:nth-child(4) { animation-delay: 0.24s; }

.chart-box {
  animation: cardEnter 0.42s cubic-bezier(0.16, 1, 0.3, 1) 0.22s both;
}

.badge {
  animation: popIn 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) 0.1s both;
}
header h1 {
  animation: cardEnter 0.45s cubic-bezier(0.16, 1, 0.3, 1) 0.16s both;
}

/* Fade for overlays/modals */
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── INPUT FOCUS SPRING ── */
input.nav-input { 
  border: 1px solid transparent; background: var(--bg); padding: 8px 12px; 
  border-radius: 12px; font-family: inherit; font-weight: 800; font-size: 15px; 
  color: var(--text); width: 110px; text-align: right; outline: none; 
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}
input.nav-input:focus { 
  background: var(--card); border-color: var(--primary); 
  box-shadow: 0 0 0 3px var(--primary-light);
  transform: scale(1.02);
}

header.main-header { margin-bottom: 30px; position: relative; padding-top: 50px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.dashboard-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.dashboard-title { font-size: 14px; font-weight: 800; text-transform: uppercase; color: var(--text); transition: color 0.3s ease; }
.dashboard-title span { color: var(--primary); }

.badge { display: inline-block; font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--primary); background: var(--primary-light); padding: 8px 16px; border-radius: 100px; margin-bottom: 16px; border: 1px solid rgba(214, 30, 48, 0.1); }
h1 { font-size: 26px; font-weight: 800; line-height: 1.2; letter-spacing: -0.5px; text-align: center; }
h1 span { color: var(--primary); }

/* FIX: Theme Toggle Styling and Consistency */
.theme-toggle { background: var(--card); border: 1px solid var(--border); width: 44px; height: 44px; border-radius: 14px; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow); transition: var(--transition-smooth); position: relative; overflow: hidden; }
.theme-toggle svg { width: 20px; height: 20px; fill: none; stroke: var(--text); stroke-width: 2; position: absolute; transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.35s ease; }
.sun { opacity: 1; transform: translateY(0) rotate(0deg); }
.moon { opacity: 0; transform: translateY(20px) rotate(45deg); }
[data-theme="dark"] .sun { opacity: 0; transform: translateY(-20px) rotate(-45deg); }
[data-theme="dark"] .moon { opacity: 1; transform: translateY(0) rotate(0deg); }
.theme-toggle:hover { transform: rotate(15deg) scale(1.08); }
.theme-toggle:active { transform: scale(0.92); }

/* Reset style bawaan browser untuk button yang dipakai sebagai menu card / select trigger */
button.menu-card, button.select-trigger {
  font-family: 'Plus Jakarta Sans', sans-serif;
  text-align: left;
  background: none;
  border: none;
  width: 100%;
  color: var(--text);
}
button.menu-card {
  background: var(--card);
  border: 1px solid var(--border);
}

.menu-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 10px; }
.menu-card { 
  background: var(--card); border: 1px solid var(--border); 
  padding: 22px 18px 20px;
  border-radius: var(--radius); cursor: pointer; 
  color: var(--text);
  display: flex; flex-direction: column; align-items: flex-start; gap: 14px; 
  transition: transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.2s ease, border-color 0.15s ease, background 0.3s ease, color 0.3s ease; 
  box-shadow: var(--shadow);
}
.menu-card h3 { font-size: 14px; font-weight: 800; margin: 0; }
.menu-card .menu-sub { font-size: 10.5px; color: var(--muted); font-weight: 500; margin-top: 1px; line-height: 1.4; }
.menu-info { display: flex; flex-direction: column; }
.menu-card:hover { transform: translateY(-6px) scale(1.01); border-color: var(--primary); box-shadow: 0 20px 44px -8px rgba(214,30,48,0.18); }
.menu-card:active { transform: translateY(-2px) scale(0.985); transition-duration: 0.1s; }
.menu-card:hover .menu-icon { transform: scale(1.12) rotate(-4deg); }

/* COMING SOON - dark/disabled look */
.menu-card.locked { 
  cursor: not-allowed; 
  background: color-mix(in srgb, var(--bg) 60%, var(--border) 40%);
  border-color: transparent;
  opacity: 0.5;
  filter: grayscale(1) brightness(0.85);
}
.menu-card.locked:hover { transform: none; box-shadow: var(--shadow); }
.menu-card.locked:hover .menu-icon { transform: none; }

.menu-icon { 
  background: var(--primary-light); color: var(--primary); width: 54px; height: 54px; 
  border-radius: 18px; display: flex; align-items: center; justify-content: center; 
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  flex-shrink: 0;
}
.menu-icon svg { width: 26px; height: 26px; stroke: currentColor; fill: none; stroke-width: 2; }
.menu-card h3 { font-size: 17px; font-weight: 700; }

.back-btn { 
  background: var(--card); border: 1px solid var(--border); padding: 12px 22px; 
  border-radius: 100px; font-weight: 700; font-size: 12px; cursor: pointer; 
  color: var(--muted); margin-bottom: 20px; display: inline-flex; align-items: center; gap: 6px;
  transition: all 0.2s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.3s ease, color 0.3s ease; min-height: 44px;
}
.back-btn:hover { color: var(--primary); border-color: var(--primary); background: var(--primary-light); transform: translateX(-3px); }
.back-btn:active { transform: translateX(-1px) scale(0.97); }

.hero-revenue { 
  background: var(--primary); color: white; border-radius: var(--radius); 
  padding: 35px 20px; text-align: center; margin-bottom: 20px; 
  box-shadow: 0 20px 40px rgba(214, 30, 48, 0.2);
  animation: cardEnter 0.4s cubic-bezier(0.16, 1, 0.3, 1) 0.05s both;
}
.revenue-value { font-size: 38px; font-weight: 800; margin-top: 8px; transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }
.hero-revenue:hover .revenue-value { transform: scale(1.04); }

.date-selector { display: flex; gap: 8px; margin-bottom: 20px; justify-content: center; align-items: flex-start; }
.custom-select-container { position: relative; width: 140px; }
.select-trigger { 
  background: var(--card); border: 1px solid var(--border); color: var(--text); 
  padding: 10px 16px; border-radius: 14px; font-weight: 700; font-size: 13px; cursor: pointer; 
  display: flex; justify-content: space-between; align-items: center; 
  transition: all 0.18s ease;
}
.select-trigger:hover { border-color: var(--primary); }
.select-trigger::after { content: ''; width: 8px; height: 8px; border-right: 2.5px solid var(--primary); border-bottom: 2.5px solid var(--primary); transform: rotate(45deg); transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1); margin-bottom: 4px; }
.active .select-trigger::after { transform: rotate(-135deg); margin-bottom: -4px; }
.select-options { 
  position: absolute; top: calc(100% + 8px); left: 0; width: 100%; 
  background: var(--card); border: 1px solid var(--border); border-radius: 16px; 
  box-shadow: 0 10px 30px rgba(0,0,0,0.1); z-index: 100; 
  max-height: 0; overflow: hidden; 
  transition: max-height 0.28s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.2s ease, transform 0.28s cubic-bezier(0.16, 1, 0.3, 1); 
  opacity: 0; transform: translateY(-6px) scale(0.98);
}
.active .select-options { max-height: 220px; opacity: 1; overflow-y: auto; padding: 8px; transform: translateY(0) scale(1); }
.option-item { padding: 10px 12px; border-radius: 10px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.15s ease; color: var(--text); }
.option-item:hover { background: var(--primary-light); color: var(--primary); transform: translateX(3px); }
.option-item:active { transform: translateX(1px) scale(0.98); }

.section-group { 
  background: var(--card); border-radius: var(--radius); padding: 24px; margin-bottom: 16px; 
  border: 1px solid var(--border); box-shadow: var(--shadow); position: relative;
  color: var(--text);
  transition: box-shadow 0.2s ease, border-color 0.2s ease, background 0.3s ease, color 0.3s ease;
}
.section-group:hover { box-shadow: 0 14px 36px -6px rgba(0,0,0,0.08); }
.section-label { font-size: 11px; font-weight: 800; text-transform: uppercase; color: var(--muted); margin-bottom: 18px; display: block; border-left: 3px solid var(--primary); padding-left: 10px; }
.deck-item { display: flex; justify-content: space-between; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--border); transition: padding-left 0.2s ease; }
.deck-item:last-child { border-bottom: none; }
.deck-item:hover { padding-left: 4px; }
.deck-title { font-size: 14px; font-weight: 700; }
.input-wrapper { display: flex; align-items: center; gap: 6px; }

.auto-val { font-weight: 800; font-size: 16px; color: var(--primary); transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }
.unit { font-size: 12px; font-weight: 700; color: var(--muted); }

.btn-group { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.export-btn { width: 100%; background: var(--text); color: var(--card); border: none; padding: 20px; border-radius: 20px; font-weight: 800; cursor: pointer; transition: opacity 0.15s, transform 0.12s; font-size: 14px; text-transform: uppercase; }
.export-btn:hover { opacity: 0.88; }
.export-btn:active { transform: scale(0.98); }
.import-btn { width: 100%; background: var(--card); color: var(--text); border: 2px solid var(--border); padding: 20px; border-radius: 20px; font-weight: 800; cursor: pointer; transition: border-color 0.15s, transform 0.12s; font-size: 14px; text-transform: uppercase; }
.import-btn:hover { border-color: var(--primary); color: var(--primary); }
.import-btn:active { transform: scale(0.98); }
.reset-btn { width: 100%; background: transparent; color: var(--muted); border: 2px dashed var(--border); padding: 14px; border-radius: 20px; font-weight: 700; font-size: 11px; cursor: pointer; margin-bottom: 16px; display: block; width: 100%; transition: border-color 0.15s, color 0.15s, transform 0.12s; }
.reset-btn:hover { border-color: var(--danger); color: var(--danger); }
.reset-btn:active { transform: scale(0.98); }

.insight-panel { background: var(--primary-light); border: 1px solid var(--primary); border-radius: 18px; padding: 16px; margin-bottom: 20px; font-size: 12px; color: var(--text); line-height: 1.5; display: none; }
.insight-panel b { color: var(--primary); display: block; margin-bottom: 4px; font-size: 13px; text-transform: uppercase; }

.slider-container { margin-top: 15px; }
input[type="range"] { width: 100%; height: 6px; background: var(--border); border-radius: 5px; outline: none; -webkit-appearance: none; cursor: pointer; }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; width: 20px; height: 20px; background: var(--primary); border-radius: 50%; }

.chart-box { background: var(--card); border-radius: var(--radius); padding: 24px; margin-top: 24px; border: 1px solid var(--border); box-shadow: var(--shadow); position: relative; color: var(--text); transition: background 0.3s ease, color 0.3s ease; }
.chart-title { font-size: 12px; font-weight: 800; text-align: center; margin-bottom: 20px; text-transform: uppercase; color: var(--muted); }
.chart-container { height: 260px; position: relative; }

.leads-results-container { background: #1a1a2e; color: white; border-radius: var(--radius); padding: 24px; margin-top: 20px; box-shadow: 0 15px 35px rgba(0,0,0,0.2); }
.funnel-item { border-bottom: 1px solid rgba(255,255,255,0.1); padding: 15px 0; display: flex; justify-content: space-between; align-items: center; }
.funnel-item:last-child { border-bottom: none; }
.funnel-item span { font-size: 13px; font-weight: 600; color: white; }
.result-val { font-size: 16px; font-weight: 800; color: var(--primary); }
.overall-row { text-align: center; padding-top: 20px; border-top: 2px dashed rgba(255,255,255,0.1); margin-top: 10px; }
[data-theme="dark"] .leads-results-container { background: #0d0f14; }

/* ── GLOBAL STICKY THEME TOGGLE ── */
.global-theme-toggle {
  position: fixed; top: 16px; right: 16px; z-index: 9000;
  background: var(--card); border: 1px solid var(--border);
  width: 44px; height: 44px; border-radius: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,0.10);
  transition: var(--transition-smooth);
  overflow: hidden;
}
.global-theme-toggle svg { width: 20px; height: 20px; fill: none; stroke: var(--text); stroke-width: 2; position: absolute; transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.4s ease; }
.global-theme-toggle .sun { opacity: 1; transform: translateY(0) rotate(0deg); }
.global-theme-toggle .moon { opacity: 0; transform: translateY(20px) rotate(45deg); }
[data-theme="dark"] .global-theme-toggle .sun { opacity: 0; transform: translateY(-20px) rotate(-45deg); }
[data-theme="dark"] .global-theme-toggle .moon { opacity: 1; transform: translateY(0) rotate(0deg); }
/* Hide per-view toggles since we have global one now */
.view-theme-toggle { display: none !important; }
/* Sobun nav toggle: keep hidden too, global handles it */
.sobun-view-theme-toggle { display: none !important; }

/* ══════════════════════════════════════════
   PERIOD LABEL BADGE
══════════════════════════════════════════ */
.period-label-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--primary-light); border: 1px solid rgba(214,30,48,0.15);
  color: var(--primary); border-radius: 100px;
  padding: 5px 14px; font-size: 11px; font-weight: 800;
  letter-spacing: 0.3px; margin-bottom: 16px;
  animation: popIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.period-label-badge svg { width: 13px; height: 13px; stroke: currentColor; fill: none; stroke-width: 2; }

/* ══════════════════════════════════════════
   ALERT BANNER (home dashboard)
══════════════════════════════════════════ */
.alert-banner-wrap { margin: 0 0 16px; display: flex; flex-direction: column; gap: 8px; }
.alert-banner {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 16px; border-radius: 16px;
  font-size: 12px; font-weight: 600; line-height: 1.45;
  animation: slideInLeft 0.3s cubic-bezier(0.16, 1, 0.3, 1) both;
  border: 1px solid;
}
.alert-banner.alert-danger  { background: rgba(239,68,68,.09); border-color: rgba(239,68,68,.2); color: #ef4444; }
.alert-banner.alert-warning { background: rgba(245,158,11,.09); border-color: rgba(245,158,11,.2); color: #f59e0b; }
.alert-banner.alert-success { background: rgba(16,185,129,.09); border-color: rgba(16,185,129,.2); color: #10b981; }
.alert-banner-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.alert-banner-body b { display: block; font-size: 12.5px; font-weight: 800; margin-bottom: 1px; }

/* ══════════════════════════════════════════
   TARGET VS AKTUAL (branch view)
══════════════════════════════════════════ */
.target-section {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-bottom: 16px;
  box-shadow: var(--shadow);
}
.target-section-title {
  font-size: 11px; font-weight: 800; text-transform: uppercase;
  color: var(--muted); margin-bottom: 16px; display: block;
  border-left: 3px solid var(--primary); padding-left: 10px;
}
.target-branch-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.target-branch-item { display: flex; flex-direction: column; gap: 5px; }
.target-branch-label {
  font-size: 10px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--muted); margin-bottom: 2px;
}
.target-branch-input {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 10px; padding: 8px 10px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12px; font-weight: 700; color: var(--text);
  width: 100%; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.target-branch-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-light); }
.target-progress-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-top: 16px; }
.target-progress-card {
  background: var(--bg); border-radius: 14px; padding: 14px 12px;
  border: 1px solid var(--border); text-align: center;
  transition: transform 0.2s cubic-bezier(0.34,1.56,0.64,1);
}
.target-progress-card:hover { transform: translateY(-3px); }
.tpc-branch { font-size: 10px; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 0.4px; margin-bottom: 6px; }
.tpc-pct { font-size: 22px; font-weight: 800; letter-spacing: -1px; line-height: 1; margin-bottom: 6px; }
.tpc-label { font-size: 10px; color: var(--muted); font-weight: 600; }
.tpc-bar-wrap { height: 5px; background: var(--border); border-radius: 5px; overflow: hidden; margin: 8px 0 4px; }
.tpc-bar { height: 100%; border-radius: 5px; transition: width 0.6s cubic-bezier(0.16,1,0.3,1); }
.tpc-status { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.4px; }

/* ══════════════════════════════════════════
   HISTORICAL TREND (branch view)
══════════════════════════════════════════ */
.history-section {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px; margin-top: 16px;
  box-shadow: var(--shadow);
}
.history-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.history-title { font-size: 11px; font-weight: 800; text-transform: uppercase; color: var(--muted); border-left: 3px solid var(--primary); padding-left: 10px; }
.history-save-btn {
  background: var(--primary); color: white; border: none;
  padding: 8px 16px; border-radius: 100px; font-weight: 800;
  font-size: 11px; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif;
  transition: opacity 0.15s, transform 0.12s; text-transform: uppercase; letter-spacing: 0.3px;
}
.history-save-btn:hover { opacity: 0.88; }
.history-save-btn:active { transform: scale(0.97); }
.history-chart-wrap { height: 240px; position: relative; margin-bottom: 16px; }
.history-metric-tabs { display: flex; gap: 6px; margin-bottom: 16px; flex-wrap: wrap; }
.history-tab {
  padding: 5px 12px; border-radius: 100px; font-size: 11px; font-weight: 700;
  cursor: pointer; border: 1px solid var(--border); background: var(--bg);
  color: var(--muted); font-family: 'Plus Jakarta Sans', sans-serif;
  transition: all 0.15s; white-space: nowrap;
}
.history-tab.active { border-color: var(--primary); color: var(--primary); background: var(--primary-light); }
.history-empty { text-align: center; padding: 30px; color: var(--muted); font-size: 12px; }
.history-empty-ico { font-size: 24px; margin-bottom: 6px; opacity: 0.4; }
.history-list { display: flex; flex-direction: column; gap: 6px; max-height: 200px; overflow-y: auto; }
.history-entry {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 12px; border-radius: 12px; background: var(--bg);
  border: 1px solid var(--border); font-size: 12px;
  transition: border-color 0.15s;
}
.history-entry:hover { border-color: var(--primary); }
.history-entry-period { font-weight: 800; color: var(--text); }
.history-entry-vals { display: flex; gap: 10px; align-items: center; }
.history-entry-rev { font-weight: 800; font-size: 12px; color: var(--primary); }
.history-entry-del { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 13px; padding: 2px 5px; opacity: 0.5; transition: opacity 0.15s; }
.history-entry-del:hover { opacity: 1; color: #ef4444; }

/* ══════════════════════════════════════════
   ONBOARDING EMPTY STATE (home view)
══════════════════════════════════════════ */
.onboarding-banner {
  background: var(--card); border: 1.5px dashed var(--border);
  border-radius: var(--radius); padding: 24px 20px; margin-top: 16px;
  text-align: center; display: none;
  animation: cardEnter 0.4s cubic-bezier(0.16, 1, 0.3, 1) 0.4s both;
}
.onboarding-banner.visible { display: block; }
.onboarding-ico { font-size: 30px; margin-bottom: 10px; opacity: 0.6; }
.onboarding-title { font-size: 14px; font-weight: 800; margin-bottom: 4px; }
.onboarding-sub { font-size: 12px; color: var(--muted); line-height: 1.5; margin-bottom: 14px; }
.onboarding-cta {
  background: var(--primary); color: white; border: none;
  padding: 12px 22px; border-radius: 100px; font-weight: 800;
  font-size: 12px; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif;
  transition: opacity 0.15s, transform 0.12s; text-transform: uppercase; letter-spacing: 0.5px;
  box-shadow: 0 4px 14px rgba(214,30,48,0.25);
}
.onboarding-cta:hover { opacity: 0.88; }
.onboarding-cta:active { transform: scale(0.97); }

/* ══════════════════════════════════════════
   RICH TOAST
══════════════════════════════════════════ */
.rich-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(80px);
  background: var(--text); color: var(--card);
  border-radius: 100px; padding: 12px 22px;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 700;
  box-shadow: 0 8px 30px rgba(0,0,0,0.2);
  z-index: 99999; pointer-events: none;
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease;
  opacity: 0; white-space: nowrap; max-width: 90vw;
  text-overflow: ellipsis; overflow: hidden;
}
.rich-toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }

/* ══════════════════════════════════════════
   EXPORT PDF BUTTON
══════════════════════════════════════════ */
.pdf-export-btn {
  width: 100%; background: var(--card); color: #6366f1;
  border: 2px solid rgba(99,102,241,0.3); padding: 14px; border-radius: 20px;
  font-weight: 800; cursor: pointer; transition: background 0.15s, color 0.15s, transform 0.12s;
  font-size: 12px; text-transform: uppercase; font-family: 'Plus Jakarta Sans', sans-serif;
  margin-top: 10px;
}
.pdf-export-btn:hover { background: #6366f1; color: white; border-color: #6366f1; }
.pdf-export-btn:active { transform: scale(0.98); }

/* ── JSON BACKUP BUTTON ── */
.backup-btn-group { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 10px; }
.json-export-btn { width: 100%; background: var(--card); color: var(--success); border: 2px solid var(--success); padding: 14px; border-radius: 20px; font-weight: 800; cursor: pointer; transition: background 0.15s, color 0.15s, transform 0.12s; font-size: 12px; text-transform: uppercase; opacity: 0.85; }
.json-export-btn:hover { background: var(--success); color: white; opacity: 1; }
.json-export-btn:active { transform: scale(0.98); }
.json-import-btn { width: 100%; background: var(--card); color: var(--muted); border: 2px dashed var(--border); padding: 14px; border-radius: 20px; font-weight: 800; cursor: pointer; transition: border-color 0.15s, color 0.15s, transform 0.12s; font-size: 12px; text-transform: uppercase; }
.json-import-btn:hover { border-color: var(--primary); color: var(--primary); }
.json-import-btn:active { transform: scale(0.98); }

/* .back-btn sudah didefinisikan di atas — tidak perlu duplikat */

/* ── UTILITY CLASSES (replacing scattered inline styles) ── */
.color-primary { color: var(--primary); }
.color-muted { color: var(--muted); }
.fw-800 { font-weight: 800; }
.fs-14 { font-size: 14px; }
.mr-8 { margin-right: 8px; }
.deck-title-sub { color: var(--muted); font-size: 12px; font-weight: 700; }
.section-gradient { background: linear-gradient(145deg, var(--card), var(--bg)); border-top: 3px solid var(--primary); }
.auto-val-lg { font-size: 22px; }

/* ── BRANCH COMPARISON ── */
.branch-cols { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.dot-perdos { background: #10b981; }
.branch-col.perdos  { border-top: 4px solid #10b981; }
.perdos .branch-field input:focus  { border-color: #10b981; box-shadow: 0 0 0 3px rgba(16,185,129,.12); }
.bc-val-perdos { font-weight: 800; color: #10b981; text-align: right; }
.winner-perdos { background: rgba(16,185,129,.12); color: #10b981; }
.branch-col { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; box-shadow: var(--shadow); }
.branch-col.raya  { border-top: 4px solid #6366f1; }
.branch-col.kemboja { border-top: 4px solid #f59e0b; }
.branch-col-title { font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.branch-col-title .dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.dot-raya    { background: #6366f1; }
.dot-kemboja { background: #f59e0b; }
.branch-input-row { display: flex; flex-direction: column; gap: 10px; }
.branch-field { display: flex; flex-direction: column; gap: 4px; }
.branch-field label { font-size: 10.5px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .4px; }
.branch-field input {
  border: 1px solid var(--border); background: var(--bg);
  border-radius: 12px; padding: 9px 12px;
  font-family: 'Plus Jakarta Sans', sans-serif; font-size: 14px; font-weight: 800;
  color: var(--text); outline: none; width: 100%; text-align: right;
  transition: border-color .2s, box-shadow .2s;
}
.branch-field input:focus { border-color: #6366f1; box-shadow: 0 0 0 3px rgba(99,102,241,.12); }
.kemboja .branch-field input:focus { border-color: #f59e0b; box-shadow: 0 0 0 3px rgba(245,158,11,.12); }
.branch-result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 16px; }
.branch-stat-card { background: var(--card); border: 1px solid var(--border); border-radius: 18px; padding: 16px; box-shadow: var(--shadow); text-align: center; }
.branch-stat-card .bsc-label { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; color: var(--muted); margin-bottom: 8px; }
.branch-stat-card .bsc-val { font-size: 20px; font-weight: 800; letter-spacing: -.5px; }
.branch-stat-card .bsc-sub { font-size: 11px; color: var(--muted); margin-top: 4px; }
.branch-winner { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; font-weight: 800; padding: 2px 8px; border-radius: 20px; margin-top: 6px; }
.winner-raya    { background: rgba(99,102,241,.12); color: #6366f1; }
.winner-kemboja { background: rgba(245,158,11,.12); color: #f59e0b; }
.winner-tie     { background: rgba(16,185,129,.1);  color: #10b981; }
.bc-compare-table { background: var(--card); border-radius: var(--radius); border: 1px solid var(--border); box-shadow: var(--shadow); overflow: hidden; margin-bottom: 16px; }
.bc-compare-table table { width: 100%; border-collapse: collapse; font-size: 13px; }
.bc-compare-table thead { background: var(--bg); }
.bc-compare-table th { padding: 12px 16px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .7px; color: var(--muted); text-align: left; }
.bc-compare-table td { padding: 13px 16px; border-top: 1px solid var(--border); vertical-align: middle; }
.bc-compare-table tr:hover td { background: rgba(99,102,241,.03); }
.bc-metric-name { font-weight: 700; font-size: 13px; }
.bc-val-raya    { font-weight: 800; color: #6366f1; text-align: right; }
.bc-val-kemboja { font-weight: 800; color: #f59e0b; text-align: right; }
.bc-val-delta   { font-size: 11px; font-weight: 700; text-align: right; }
.delta-pos { color: var(--success); }
.delta-neg { color: var(--danger); }
.delta-neu { color: var(--muted); }
.bc-chart-wrap { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; box-shadow: var(--shadow); margin-bottom: 16px; }
.bc-chart-title { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; color: var(--muted); margin-bottom: 16px; text-align: center; }
.bc-chart-container { height: 220px; position: relative; }
.bc-reset-btn { width: 100%; background: transparent; color: var(--muted); border: 2px dashed var(--border); padding: 14px; border-radius: 20px; font-weight: 700; font-size: 11px; cursor: pointer; transition: border-color 0.15s, color 0.15s, transform 0.12s; }
.bc-reset-btn:hover { border-color: var(--danger); color: var(--danger); }
.bc-reset-btn:active { transform: scale(0.98); }
@media(max-width: 700px) { .branch-cols { grid-template-columns: 1fr; } .branch-result-grid { grid-template-columns: 1fr; } }

/* ── CHART DARK MODE POLISH ── */
[data-theme="dark"] .chart-box { border-color: var(--border); }

/* ── CUSTOM CONFIRM MODAL ── */
.confirm-overlay {
  display: none; position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,0.6);
  align-items: center; justify-content: center; padding: 20px;
  isolation: isolate;
}
.confirm-overlay.open { display: flex; animation: fadeIn .18s ease; }
.confirm-modal {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 24px; padding: 32px 28px; width: 100%; max-width: 360px;
  box-shadow: 0 24px 48px -8px rgba(0,0,0,0.18);
  animation: slideUp .28s cubic-bezier(0.34,1.56,0.64,1);
  text-align: center;
}
.confirm-icon { font-size: 36px; margin-bottom: 14px; line-height: 1; }
.confirm-title { font-size: 17px; font-weight: 800; margin-bottom: 8px; letter-spacing: -.4px; }
.confirm-msg { font-size: 13px; color: var(--muted); line-height: 1.6; margin-bottom: 24px; }
.confirm-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.confirm-cancel {
  padding: 13px; border-radius: 14px; border: 1.5px solid var(--border);
  background: var(--bg); color: var(--text); font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 800; cursor: pointer; transition: .2s;
}
.confirm-cancel:hover { border-color: var(--muted); }
.confirm-ok {
  padding: 13px; border-radius: 14px; border: none;
  background: var(--danger); color: white; font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 13px; font-weight: 800; cursor: pointer; transition: .2s;
  box-shadow: 0 4px 14px rgba(239,68,68,.3);
}
.confirm-ok:hover { opacity: .88; }

/* ── INPUT VALIDATION ── */
input.nav-input.input-error {
  border-color: var(--danger) !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.15) !important;
  background: rgba(239,68,68,.05) !important;
}
.sobun-wrapper .ci.input-error {
  border-color: var(--danger) !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.15) !important;
}
.field-error-msg {
  font-size: 10px; font-weight: 700; color: var(--danger);
  display: none; white-space: nowrap;
}
.field-error-msg.show { display: inline-block; }

/* ── IMPORT LOADING OVERLAY ── */
.import-loading {
  display: none; position: fixed; inset: 0; z-index: 18000;
  background: rgba(0,0,0,0.45); backdrop-filter: blur(4px);
  align-items: center; justify-content: center; flex-direction: column; gap: 16px;
}
.import-loading.show { display: flex; }
.import-spinner {
  width: 48px; height: 48px; border: 4px solid rgba(255,255,255,.2);
  border-top-color: var(--primary); border-radius: 50%;
  animation: spin .8s linear infinite;
}
.import-loading-txt { color: white; font-size: 14px; font-weight: 700; letter-spacing: -.2px; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── PROMO EMPTY STATE (no products loaded) ── */
.promo-no-products {
  background: var(--primary-light); border: 1px dashed var(--primary);
  border-radius: 14px; padding: 20px; text-align: center;
  font-size: 12.5px; color: var(--primary); font-weight: 700;
  margin-bottom: 14px; display: none;
}
.promo-no-products.show { display: block; }

.sobun-wrapper {
  max-width: 1280px;
  margin: 0 auto;
}
.sobun-wrapper .nav {
  position: sticky; top: 0; z-index: 200;
  background: rgba(15,17,21,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
  padding: 0 12px; height: 52px;
  transition: background 0.5s ease, color 0.3s ease;
  gap: 4px;
  overflow: hidden;
}
[data-theme="light"] .sobun-wrapper .nav { background: rgba(248,249,250,0.92); }

/* Back to Suite button inside nav */
.sobun-back-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 0 12px; height: 32px;
  border-radius: 10px;
  border: 1.5px solid var(--border);
  background: var(--card);
  color: var(--muted);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 11px; font-weight: 800;
  cursor: pointer; white-space: nowrap;
  flex-shrink: 0; margin-right: 4px;
  transition: all 0.2s;
  letter-spacing: -0.1px;
  min-width: 44px; min-height: 32px;
}
.sobun-back-btn:hover { color: var(--primary); border-color: var(--primary); background: var(--primary-light); }
.sobun-back-btn svg { flex-shrink: 0; }
.sobun-wrapper .nav-brand {
  font-size: 12px; font-weight: 800;
  color: var(--primary); margin-right: 8px;
  white-space: nowrap; flex-shrink: 0;
  letter-spacing: -0.3px; display: flex; align-items: center; gap: 6px;
}
.sobun-wrapper .nav-brand span { color: var(--muted); font-weight: 500; }
.sobun-wrapper .nav-tabs { 
  display: flex; overflow-x: auto; flex: 1; 
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
}
.sobun-wrapper .nav-tabs::-webkit-scrollbar { height: 0; }
.sobun-wrapper .nav-tab {
  padding: 0 12px; height: 52px; line-height: 52px;
  font-size: 12px; font-weight: 700;
  color: var(--muted); cursor: pointer;
  border: none; background: none;
  border-bottom: 2.5px solid transparent;
  white-space: nowrap;
  transition: color .18s ease, border-color .18s ease, opacity .15s ease;
  font-family: 'Plus Jakarta Sans', sans-serif;
  letter-spacing: -0.1px;
  position: relative;
  scroll-snap-align: start;
  min-width: 44px;
  flex-shrink: 0;
}
.sobun-wrapper .nav-tab:hover { color: var(--text); }
.sobun-wrapper .nav-tab:active { opacity: 0.7; }
.sobun-wrapper .nav-tab.active { color: var(--primary); border-bottom-color: var(--primary); }

/* Mobile: hide brand name to save space, show only icon */
@media (max-width: 600px) {
  .sobun-wrapper .nav-brand { display: none; }
  .sobun-wrapper .nav { padding: 0 8px; gap: 2px; }
  .sobun-back-btn { padding: 0 8px; font-size: 10px; }
  .sobun-wrapper .nav-tab { padding: 0 10px; font-size: 11px; }
  .btn-import-label { display: none; }
  .sobun-wrapper .btn-import { padding: 0 10px; min-width: 36px; gap: 0; }
  .sobun-wrapper .theme-toggle { width: 32px; height: 32px; margin-left: 4px; }
}
.sobun-wrapper .theme-toggle {
  background: var(--bg);
  border: 1px solid var(--border);
  width: 38px; height: 38px;
  border-radius: 12px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow); transition: var(--transition-smooth);
  position: relative; overflow: hidden;
  margin-left: 12px; flex-shrink: 0;
}
.sobun-wrapper .theme-toggle svg {
  width: 17px; height: 17px; fill: none; stroke: var(--text);
  stroke-width: 2; position: absolute;
  transition: transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.4s ease;
}
.sobun-wrapper .page { display: none; padding: 24px 0 60px; }
.sobun-wrapper .page.active {
  display: block;
  animation: viewEnter 0.35s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.sobun-wrapper .ph { margin-bottom: 22px; animation: slideInLeft 0.3s cubic-bezier(0.16, 1, 0.3, 1) 0.05s both; }
.sobun-wrapper .ph-title { font-size: 19px; font-weight: 800; letter-spacing: -0.5px; }
.sobun-wrapper .ph-sub { font-size: 12px; color: var(--muted); margin-top: 3px; }
.sobun-wrapper .card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 20px; padding: 18px;
  box-shadow: 0 10px 30px -5px rgba(0,0,0,0.05);
  transition: box-shadow 0.22s ease, border-color 0.18s ease, transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.sobun-wrapper .card:hover {
  box-shadow: 0 16px 38px -6px rgba(0,0,0,0.1);
  transform: translateY(-2px);
}
.sobun-wrapper .card-title {
  font-size: 10.5px; font-weight: 800; letter-spacing: .9px;
  text-transform: uppercase; color: var(--muted); margin-bottom: 16px;
  border-left: 3px solid var(--primary); padding-left: 9px;
}
.sobun-wrapper .g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.sobun-wrapper .g3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.sobun-wrapper .g4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.sobun-wrapper .fx { display: flex; gap: 14px; align-items: flex-start; flex-wrap: wrap; }
.sobun-wrapper .fx1 { flex: 1; min-width: 260px; }
.sobun-wrapper .mb8 { margin-bottom: 8px; }
.sobun-wrapper .mb14 { margin-bottom: 14px; }
.sobun-wrapper .mb20 { margin-bottom: 20px; }
.sobun-wrapper .sep { border: none; border-top: 1px solid var(--border); margin: 14px 0; }
.sobun-wrapper .stat { text-align: center; padding: 18px 10px; }
.sobun-wrapper .stat-v { font-size: 26px; font-weight: 800; letter-spacing: -1px; line-height: 1; transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }
.sobun-wrapper .stat:hover .stat-v { transform: scale(1.12); }
.sobun-wrapper .stat-l { font-size: 11px; color: var(--muted); margin-top: 6px; font-weight: 600; }
.sobun-wrapper .hero-banner {
  background: var(--primary); border-radius: 20px;
  padding: 28px 24px; margin-bottom: 20px;
  box-shadow: 0 20px 40px rgba(214, 30, 48, 0.25);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 16px;
  animation: cardEnter 0.4s cubic-bezier(0.16, 1, 0.3, 1) 0.08s both;
  transition: box-shadow 0.25s ease, transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.sobun-wrapper .hero-banner:hover {
  box-shadow: 0 28px 52px rgba(214, 30, 48, 0.32);
  transform: translateY(-3px);
}
.sobun-wrapper .hero-banner-title { font-size: 13px; font-weight: 700; color: rgba(255,255,255,0.7); text-transform: uppercase; letter-spacing: 1px; }
.sobun-wrapper .hero-banner-val { font-size: 36px; font-weight: 800; color: white; letter-spacing: -1.5px; margin-top: 4px; }
.sobun-wrapper .hero-banner-badge { background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.2); border-radius: 100px; padding: 6px 14px; font-size: 12px; font-weight: 700; color: white; }
/* Tier Cards */
.sobun-wrapper .tc { border-radius: 10px; padding: 18px; border: 1px solid; transition: transform 0.28s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.22s ease; }
.sobun-wrapper .tc:hover { transform: translateY(-6px) scale(1.02); box-shadow: 0 16px 36px -6px rgba(0,0,0,0.12); }
.sobun-wrapper .tc:hover { transform: translateY(-4px); }
.sobun-wrapper .tc-br { background: rgba(201,125,46,0.1); border-color: rgba(201,125,46,.22); }
.sobun-wrapper .tc-si { background: rgba(138,150,163,0.09); border-color: rgba(138,150,163,.2); }
.sobun-wrapper .tc-go { background: rgba(230,168,23,0.1); border-color: rgba(230,168,23,.22); }
.sobun-wrapper .tc-pl { background: rgba(96,165,250,0.09); border-color: rgba(96,165,250,.2); }
.sobun-wrapper .tc-ico { font-size: 20px; margin-bottom: 6px; line-height: 1; }
.sobun-wrapper .tc-name { font-size: 14px; font-weight: 800; margin-bottom: 1px; }
.sobun-wrapper .tc-sub { font-size: 10px; color: var(--muted); margin-bottom: 11px; }
.sobun-wrapper .tc-mult { font-size: 28px; font-weight: 500; line-height: 1; }
.sobun-wrapper .tc-ml { font-size: 10px; color: var(--muted); margin-bottom: 11px; margin-top: 1px; }
.sobun-wrapper .tc-rows { display: flex; flex-direction: column; gap: 5px; }
.sobun-wrapper .tc-row { display: flex; justify-content: space-between; font-size: 11px; }
.sobun-wrapper .tc-row span:first-child { color: var(--muted); }
.sobun-wrapper .tc-row span:last-child { font-weight: 700; font-size: 10.5px; }
/* Badges */
.sobun-wrapper .tbadge { display: inline-flex; align-items: center; gap: 5px; padding: 3px 9px; border-radius: 20px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.sobun-wrapper .tb-br { background: rgba(201,125,46,0.1); color: #c97d2e; border: 1px solid rgba(201,125,46,.25); }
.sobun-wrapper .tb-si { background: rgba(138,150,163,0.09); color: #8a96a3; border: 1px solid rgba(138,150,163,.2); }
.sobun-wrapper .tb-go { background: rgba(230,168,23,0.1); color: #e6a817; border: 1px solid rgba(230,168,23,.25); }
.sobun-wrapper .tb-pl { background: rgba(96,165,250,0.09); color: #60a5fa; border: 1px solid rgba(96,165,250,.2); }
/* Tables */
.sobun-wrapper .tw { overflow-x: auto; border-radius: 10px; border: 1px solid var(--border); }
.sobun-wrapper .tw-nb { overflow-x: auto; }
.sobun-wrapper table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.sobun-wrapper thead { background: var(--bg); }
.sobun-wrapper th { padding: 10px 12px; text-align: left; font-size: 10px; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: .7px; white-space: nowrap; }
.sobun-wrapper td { padding: 10px 12px; border-top: 1px solid var(--border); vertical-align: middle; }
.sobun-wrapper tbody tr:hover td { background: rgba(214,30,48,.03); }
.sobun-wrapper .tr { text-align: right; }
.sobun-wrapper .tc2 { text-align: center; }
.sobun-wrapper .mono { font-size: 12px; }
/* Forms */
.sobun-wrapper .fg { display: flex; flex-direction: column; gap: 5px; margin-bottom: 11px; }
.sobun-wrapper .fg:last-child { margin-bottom: 0; }
.sobun-wrapper label { font-size: 11px; font-weight: 700; color: var(--muted); letter-spacing: 0.3px; }
.sobun-wrapper input:not(.nav-input), .sobun-wrapper select {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 10px; padding: 9px 12px;
  color: var(--text); font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12.5px; outline: none;
  transition: border-color .2s, box-shadow .2s; width: 100%;
}
.sobun-wrapper input:not(.nav-input):focus, .sobun-wrapper select:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}
.sobun-wrapper input[readonly] { opacity: .4; cursor: not-allowed; }
/* Field yang dikunci karena data dari Excel */
.sobun-wrapper input.xl-locked {
  opacity: 1 !important; cursor: not-allowed !important;
  background: color-mix(in srgb, var(--bg) 80%, rgba(214,30,48,0.08) 20%) !important;
  border-color: rgba(214,30,48,0.25) !important;
  color: var(--primary) !important;
  font-weight: 800 !important;
}
.sobun-wrapper input.xl-locked:focus {
  box-shadow: 0 0 0 3px rgba(214,30,48,0.10) !important;
  border-color: rgba(214,30,48,0.35) !important;
}
.sobun-wrapper select {
  cursor: pointer; -webkit-appearance: none; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; padding-right: 30px;
}
input[type="number"] { -moz-appearance: textfield; }
/* Combobox */
.sobun-wrapper .cw { position: relative; }
.sobun-wrapper .ci {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 10px; padding: 9px 30px 9px 12px;
  color: var(--text); font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12.5px; outline: none;
  transition: border-color .2s, box-shadow .2s; width: 100%; cursor: text;
}
.sobun-wrapper .ci:focus { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-light); }
.sobun-wrapper .ca { position: absolute; right: 11px; top: 50%; transform: translateY(-50%); color: var(--muted); pointer-events: none; font-size: 10px; }
.sobun-wrapper .cd {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  z-index: 999; background: var(--card);
  border: 1px solid var(--border); border-radius: 14px;
  max-height: 220px; overflow-y: auto; display: none;
  box-shadow: 0 20px 40px -8px rgba(0,0,0,0.1);
}
.sobun-wrapper .cd.open { display: block; }
.sobun-wrapper .co { padding: 9px 12px; font-size: 12.5px; cursor: pointer; border-bottom: 1px solid var(--border); color: var(--text); transition: background .1s; }
.sobun-wrapper .co:last-child { border-bottom: none; }
.sobun-wrapper .co:hover, .sobun-wrapper .co.foc { background: var(--primary-light); color: var(--primary); }
.sobun-wrapper .co-sub { font-size: 10px; color: var(--muted); margin-top: 2px; }
.sobun-wrapper .co-empty { padding: 12px; font-size: 12px; color: var(--muted); text-align: center; }
/* Status pills */
.sobun-wrapper .sp { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 20px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.sobun-wrapper .sp-am { background: rgba(16,185,129,.12); color: #10b981; }
.sobun-wrapper .sp-ti { background: rgba(245,158,11,.12); color: #f59e0b; }
.sobun-wrapper .sp-bo { background: rgba(239,68,68,.12); color: #ef4444; }
/* Filter pills */
.sobun-wrapper .fpr { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 16px; }
.sobun-wrapper .fp {
  padding: 6px 14px; border-radius: 100px;
  font-size: 11.5px; font-weight: 700; cursor: pointer;
  border: 1px solid var(--border); background: var(--card); color: var(--muted);
  transition: var(--transition-smooth); font-family: 'Plus Jakarta Sans', sans-serif;
}
.sobun-wrapper .fp:hover { color: var(--text); border-color: var(--border); }
.sobun-wrapper .fp.active { border-color: var(--primary); color: var(--primary); background: var(--primary-light); }
/* Search */
.sobun-wrapper .sw { position: relative; margin-bottom: 14px; }
.sobun-wrapper .sw input { padding-left: 36px; }
.sobun-wrapper .si { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: 13px; pointer-events: none; }
/* Buttons */
.sobun-wrapper .btn {
  display: flex; align-items: center; justify-content: center;
  gap: 6px; padding: 10px 18px; border-radius: 10px;
  border: none; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 12.5px; font-weight: 800; transition: opacity .15s, transform .1s;
  width: 100%; margin-top: 8px; text-transform: uppercase; letter-spacing: 0.3px;
}
.sobun-wrapper .btn:active { transform: scale(.98); }
.sobun-wrapper .btn-p { background: var(--primary); color: white; box-shadow: 0 4px 14px rgba(214,30,48,.3); }
.sobun-wrapper .btn-p:hover { opacity: .88; }
.sobun-wrapper .btn-del { background: none; border: none; color: #ef4444; cursor: pointer; font-size: 14px; opacity: .5; padding: 2px 6px; transition: opacity .15s; }
.sobun-wrapper .btn-del:hover { opacity: 1; }
/* Calc Result */
.sobun-wrapper .cr { background: var(--bg); border-radius: 10px; padding: 14px; border: 1px solid var(--border); }
.sobun-wrapper .cr-row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; font-size: 12.5px; border-bottom: 1px solid var(--border); }
.sobun-wrapper .cr-row:last-child { border: none; font-weight: 700; font-size: 13px; padding-top: 8px; }
/* Tag */
.sobun-wrapper .tag { display: inline-block; padding: 2px 8px; border-radius: 5px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .4px; }
.sobun-wrapper .tag-a { background: rgba(16,185,129,.12); color: #10b981; }
.sobun-wrapper .tag-b { background: rgba(214,30,48,.1); color: var(--primary); }
.sobun-wrapper .tag-np { background: rgba(0,0,0,.05); color: var(--muted); }
[data-theme="dark"] .sobun-wrapper .tag-np { background: rgba(255,255,255,.05); }
/* Flow */
.sobun-wrapper .flow { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 2px 0; }
.sobun-wrapper .fn { padding: 10px 14px; border-radius: 10px; font-size: 11.5px; font-weight: 700; border: 1px solid; text-align: center; min-width: 96px; }
.sobun-wrapper .fa { color: var(--muted); font-size: 13px; display: flex; flex-direction: column; align-items: center; gap: 1px; line-height: 1.4; }
.sobun-wrapper .fa-u { font-size: 10px; color: #10b981; }
.sobun-wrapper .fa-d { font-size: 10px; color: #ef4444; }
/* Empty */
.sobun-wrapper .empty { text-align: center; padding: 40px 20px; color: var(--muted); }
.sobun-wrapper .empty-ico { font-size: 30px; margin-bottom: 8px; opacity: .35; }
/* Promo panel */
.sobun-wrapper .promo-panel { min-width: 290px; max-width: 310px; flex-shrink: 0; }
/* Save dot */
.save-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); display: inline-block; margin-left: 8px; opacity: 0; transition: opacity 0.3s; }
.save-dot.visible { opacity: 1; animation: pulse-dot 1.5s ease-in-out; }
@keyframes pulse-dot { 0%,100%{opacity:0} 30%,70%{opacity:1} }
@keyframes valuePop {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.08); }
  100% { transform: scale(1); }
}
.value-pop { animation: valuePop 0.35s cubic-bezier(0.34, 1.56, 0.64, 1); }
/* Import button */
.sobun-wrapper .btn-import {
  display: flex; align-items: center; justify-content: center;
  gap: 7px; padding: 0 14px; height: 34px; border-radius: 10px;
  border: 1.5px solid rgba(214,30,48,0.22); background: var(--primary-light);
  color: var(--primary); cursor: pointer;
  font-family: 'Plus Jakarta Sans', sans-serif; font-size: 12px; font-weight: 800;
  white-space: nowrap; flex-shrink: 0; margin-left: 8px; transition: var(--transition-smooth);
}
.sobun-wrapper .btn-import:hover { background: var(--primary); color: white; }
.sobun-wrapper .btn-import svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
/* Modal */
.xl-overlay { display: none; position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,0.6); backdrop-filter: blur(6px); align-items: center; justify-content: center; padding: 20px; }
.xl-overlay.open { display: flex; animation: fadeIn .2s ease; }
.xl-modal { background: var(--card); border: 1px solid var(--border); border-radius: 24px; padding: 28px; width: 100%; max-width: 480px; box-shadow: 0 20px 40px -8px rgba(0,0,0,0.1); animation: slideUp .3s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes slideUp { from{transform:translateY(20px) scale(.98);opacity:0} to{transform:none;opacity:1} }
.xl-title { font-size: 16px; font-weight: 800; margin-bottom: 4px; letter-spacing: -.4px; }
.xl-sub { font-size: 12px; color: var(--muted); margin-bottom: 20px; line-height: 1.5; }
.xl-drop { border: 2px dashed var(--border); border-radius: 14px; padding: 32px 20px; text-align: center; cursor: pointer; transition: border-color .2s, background .2s; margin-bottom: 16px; position: relative; }
.xl-drop:hover, .xl-drop.drag { border-color: var(--primary); background: var(--primary-light); }
.xl-drop input[type="file"] { position: absolute; inset:0; opacity:0; cursor:pointer; }
.xl-drop-ico { font-size: 28px; margin-bottom: 8px; }
.xl-drop-txt { font-size: 13px; font-weight: 700; color: var(--text); }
.xl-drop-sub { font-size: 11px; color: var(--muted); margin-top: 3px; }
.xl-progress { display: none; margin-bottom: 14px; }
.xl-progress.show { display: block; }
.xl-prog-bar { height: 4px; background: var(--border); border-radius: 4px; overflow: hidden; margin-bottom: 6px; }
.xl-prog-fill { height: 100%; background: var(--primary); border-radius: 4px; transition: width .3s; }
.xl-prog-txt { font-size: 11px; color: var(--muted); }
.xl-preview { background: var(--bg); border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; font-size: 11.5px; margin-bottom: 16px; display: none; max-height: 180px; overflow-y: auto; }
.xl-preview.show { display: block; }
.xl-prow { display: flex; justify-content: space-between; padding: 4px 0; border-bottom: 1px solid var(--border); font-size: 12px; }
.xl-prow:last-child { border: none; }
.xl-prow span:first-child { color: var(--muted); }
.xl-prow span:last-child { font-weight: 700; font-size: 11px; color: var(--primary); }
.xl-prow-section { margin-top: 8px; padding-top: 8px; border-top: 1.5px solid var(--border); }
.xl-prow-section span:first-child { color: var(--text); font-weight: 800; font-size: 12px; }
.xl-prow-warn span:last-child { color: var(--danger) !important; }
.xl-err { background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.2); color: #ef4444; border-radius: 10px; padding: 10px 13px; font-size: 12px; margin-bottom: 14px; display: none; }
.xl-err.show { display: block; }
.xl-actions { display: flex; gap: 10px; }
.xl-btn { flex: 1; padding: 11px; border-radius: 10px; border: none; cursor: pointer; font-family: 'Plus Jakarta Sans', sans-serif; font-size: 12.5px; font-weight: 800; transition: opacity .15s, transform .1s; text-transform: uppercase; letter-spacing: .3px; }
.xl-btn:active { transform: scale(.98); }
.xl-btn-cancel { background: var(--bg); color: var(--text); border: 1px solid var(--border); }
.xl-btn-apply { background: var(--primary); color: white; box-shadow: 0 4px 14px rgba(214,30,48,.3); }
.xl-btn-apply:disabled { opacity: .4; cursor: not-allowed; }
.xl-btn-apply:not(:disabled):hover { opacity: .88; }
.xl-toast { position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--card); border: 1px solid var(--border); border-radius: 100px; padding: 10px 20px; font-size: 12.5px; font-weight: 700; box-shadow: 0 20px 40px -8px rgba(0,0,0,0.1); z-index: 10000; opacity: 0; transition: opacity .3s, transform .3s; white-space: nowrap; display: flex; align-items: center; gap: 8px; }
.xl-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
@media(max-width:900px){ .sobun-wrapper .g4{grid-template-columns:1fr 1fr} .sobun-wrapper .g3{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .sobun-wrapper .g2,.sobun-wrapper .g3,.sobun-wrapper .g4{grid-template-columns:1fr} .sobun-wrapper .promo-panel{max-width:100%} .sobun-wrapper .hero-banner{flex-direction:column;gap:10px} }

/* ── PASSWORD GATE MODAL ── */
.pw-overlay {
  display:none; position:fixed; inset:0; z-index:99998;
  background:rgba(0,0,0,0.78); backdrop-filter:blur(10px);
  align-items:center; justify-content:center; padding:20px;
}
.pw-overlay.open { display:flex; animation:fadeIn .2s ease; }
@keyframes pwSlideUp { from{transform:translateY(24px) scale(.97);opacity:0} to{transform:none;opacity:1} }
.pw-modal {
  background:var(--card); border:1px solid var(--border);
  border-radius:28px; padding:36px 32px 28px; width:100%; max-width:360px;
  box-shadow:0 32px 64px -12px rgba(0,0,0,0.3);
  animation:pwSlideUp .35s cubic-bezier(0.34,1.56,0.64,1);
  text-align:center;
}
.pw-logo { font-size:44px; line-height:1; margin-bottom:8px; }
.pw-title { font-size:19px; font-weight:800; margin-bottom:6px; letter-spacing:-.5px; }
.pw-sub { font-size:12.5px; color:var(--muted); margin-bottom:24px; line-height:1.6; }
.pw-input-wrap { position:relative; margin-bottom:10px; }
.pw-input {
  width:100%; padding:14px 50px 14px 20px;
  background:var(--bg); border:2px solid var(--border);
  border-radius:14px; font-family:'Plus Jakarta Sans',sans-serif;
  font-size:16px; font-weight:800; color:var(--text); outline:none;
  text-align:center; letter-spacing:4px;
  transition:border-color .2s, box-shadow .2s;
}
.pw-input:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-light); }
.pw-input.pw-error {
  border-color:var(--danger)!important;
  box-shadow:0 0 0 3px rgba(239,68,68,.15)!important;
  animation:pwShake .35s ease;
}
@keyframes pwShake {
  0%,100%{transform:translateX(0)} 20%{transform:translateX(-8px)}
  40%{transform:translateX(8px)} 60%{transform:translateX(-5px)} 80%{transform:translateX(5px)}
}
.pw-toggle-btn {
  position:absolute; right:14px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; color:var(--muted);
  font-size:18px; padding:4px; line-height:1; transition:color .15s;
}
.pw-toggle-btn:hover { color:var(--text); }
.pw-err-msg { font-size:11.5px; color:var(--danger); font-weight:700; min-height:18px; margin-bottom:12px; }
.pw-btn {
  width:100%; padding:14px; background:var(--primary); color:white;
  border:none; border-radius:14px; font-family:'Plus Jakarta Sans',sans-serif;
  font-size:14px; font-weight:800; cursor:pointer; text-transform:uppercase;
  letter-spacing:.6px; transition:opacity .15s, transform .1s;
  box-shadow:0 6px 18px rgba(214,30,48,.3); margin-bottom:12px;
}
.pw-btn:hover { opacity:.9; }
.pw-btn:active { transform:scale(.98); }
.pw-hint { font-size:11px; color:var(--muted); }
/* badge on import button when locked */
.btn-import-locked { background:var(--bg)!important; color:var(--muted)!important; border-color:var(--border)!important; }


/* ══════════════════════════════════════════
   DARK MODE — EXPLICIT TEXT COLOR OVERRIDES
   Fixes browser button/input default color 
   not inheriting from body in dark mode
══════════════════════════════════════════ */
[data-theme="dark"] .menu-card,
[data-theme="dark"] .menu-card h3,
[data-theme="dark"] .menu-card .menu-sub,
[data-theme="dark"] .section-group,
[data-theme="dark"] .deck-title,
[data-theme="dark"] .dashboard-title,
[data-theme="dark"] .chart-box,
[data-theme="dark"] .chart-title,
[data-theme="dark"] .back-btn,
[data-theme="dark"] .select-trigger,
[data-theme="dark"] .option-item,
[data-theme="dark"] .history-entry-period,
[data-theme="dark"] .target-branch-label,
[data-theme="dark"] .tpc-branch,
[data-theme="dark"] .section-label,
[data-theme="dark"] .history-title,
[data-theme="dark"] .period-label-badge,
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] p,
[data-theme="dark"] span:not([class*="primary"]):not([class*="muted"]):not([class*="danger"]):not([class*="success"]) {
  color: var(--text);
}

[data-theme="dark"] .menu-card .menu-sub,
[data-theme="dark"] .muted,
[data-theme="dark"] .chart-title,
[data-theme="dark"] .section-label,
[data-theme="dark"] .history-title,
[data-theme="dark"] .target-branch-label,
[data-theme="dark"] .tpc-branch,
[data-theme="dark"] .tpc-label,
[data-theme="dark"] .unit,
[data-theme="dark"] .back-btn {
  color: var(--muted);
}

/* All buttons in dark mode inherit text color properly */
[data-theme="dark"] button {
  color: inherit;
}
