/*
  MandalaMine ERP UI/UX V2 — Native Responsive Plug & Play Pack
  File: mandalamine-uiux-v2.css
  Scope: activated only when JS adds body.mmd-v2.
  Goal: desktop/tablet/mobile polish without backend rewrite.
*/

:root {
  --mmd2-bg: #06111e;
  --mmd2-bg-2: #0a1828;
  --mmd2-bg-3: #10243a;
  --mmd2-ink: #f8fafc;
  --mmd2-muted: #cbd5e1;
  --mmd2-soft: #93a4b8;
  --mmd2-faint: #64748b;
  --mmd2-gold: #C99A2E;
  --mmd2-gold-2: #E2BE69;
  --mmd2-red: #f87171;
  --mmd2-orange: #fb923c;
  --mmd2-green: #34d399;
  --mmd2-card: rgba(255,255,255,.075);
  --mmd2-card-2: rgba(255,255,255,.105);
  --mmd2-card-3: rgba(255,255,255,.145);
  --mmd2-border: rgba(255,255,255,.14);
  --mmd2-border-2: rgba(255,255,255,.22);
  --mmd2-shadow: 0 22px 70px rgba(0,0,0,.34);
  --mmd2-shadow-soft: 0 14px 38px rgba(0,0,0,.24);
  --mmd2-ring: 0 0 0 4px rgba(201,154,46,.26);
  --mmd2-r-xs: 10px;
  --mmd2-r-sm: 14px;
  --mmd2-r-md: 18px;
  --mmd2-r-lg: 24px;
  --mmd2-r-xl: 32px;
  --mmd2-topbar-h: 48px;
  --mmd2-content-max: 1540px;
  --mmd2-sidebar-w: 286px;
  --mmd2-mobile-dock-h: 72px;
  --mmd2-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html.mmd-v2-lock-scroll { overflow: hidden; }
body.mmd-v2 {
  min-height: 100vh;
  color: var(--mmd2-ink);
  font-family: var(--mmd2-font);
  letter-spacing: -.012em;
  background:
    radial-gradient(circle at 9% -8%, rgba(201,154,46,.22), transparent 32rem),
    radial-gradient(circle at 100% 14%, rgba(31,95,153,.12), transparent 34rem),
    linear-gradient(140deg, #050b14 0%, var(--mmd2-bg) 44%, #071523 100%);
  overflow-x: hidden;
}
body.mmd-v2 * { box-sizing: border-box; }
body.mmd-v2 a { color: #f5d58d; }
body.mmd-v2 a:hover { color: #ffe4a3; }
body.mmd-v2 :focus-visible { outline: none; box-shadow: var(--mmd2-ring); }
body.mmd-v2 img, body.mmd-v2 svg, body.mmd-v2 canvas { max-width: 100%; }
body.mmd-v2 button, body.mmd-v2 input, body.mmd-v2 select, body.mmd-v2 textarea { font: inherit; }
body.mmd-v2.mmd-density-compact {
  --mmd2-r-sm: 11px;
  --mmd2-r-md: 14px;
  --mmd2-r-lg: 18px;
  --mmd2-topbar-h: 44px;
}

/* App surface normalization */
body.mmd-v2 #root,
body.mmd-v2 #app,
body.mmd-v2 main,
body.mmd-v2 [class*="App"],
body.mmd-v2 [class*="page"],
body.mmd-v2 [class*="dashboard"] {
  min-width: 0;
}
body.mmd-v2 main,
body.mmd-v2 .main,
body.mmd-v2 [role="main"] {
  width: min(var(--mmd2-content-max), 100%);
  margin-left: auto;
  margin-right: auto;
}

/* Premium topbar */
.mmd-topbar {
  position: sticky;
  top: 0;
  z-index: 9998;
  min-height: var(--mmd2-topbar-h);
  display: grid;
  grid-template-columns: minmax(210px, 300px) minmax(120px, 1fr) auto;
  gap: 8px 12px;
  align-items: center;
  align-content: center;
  padding: 6px clamp(14px, 2vw, 26px);
  border-bottom: 1px solid var(--mmd2-border);
  background: rgba(6,17,30,.88);
  backdrop-filter: blur(24px) saturate(130%);
  box-shadow: 0 6px 24px rgba(0,0,0,.22);
}
.mmd-brand {
  min-width: 0;
  display: flex;
  gap: 10px;
  align-items: center;
}
/* Header lama ERP disembunyikan: kontrolnya sudah dipindah ke topbar V2 ini (anti header dobel) */
body.mmd-v2.mmd-merged-header .tb { display: none !important; }
/* Grup kanan: role select, density, tower, + kontrol asli (Sites/bell/user/tema/Logout) */
.mmd-topbar-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 0 0 auto;
  justify-self: end;
  justify-content: flex-end;
  flex-wrap: nowrap;   /* desktop: SATU baris, tidak pernah pecah ke baris kedua */
}
/* Desktop: sembunyikan kontrol V2 yang redundan biar header benar2 satu baris rapi.
   Ganti mode kerja tetap tersedia lewat role-strip di Control Tower (chip Owner/Site/QAQC/...). */
.mmd-topbar .mmd-select[data-mmd-role-select] { display: none; }
.mmd-topbar .mmd-icon-btn[data-mmd-action="density"] { display: none; }
/* Deretan kontrol asli (Sites/notif/riwayat/user/EN/Bantuan/tema/Logout) tetap satu
   blok utuh — wrap sebagai satu kesatuan ke baris kedua, bukan pecah berantakan. */
.mmd-topbar-actions .mmd-native-ua {
  display: flex !important;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  margin: 0 !important;
}
.mmd-topbar-actions .mmd-native-ua > * { flex: 0 0 auto; }
/* User pill boleh menyusut + ellipsis kalau layar sempit, biar Logout tidak terdorong keluar */
.mmd-topbar-actions .mmd-native-ua #ua-user {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 168px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mmd-search-slot { min-width: 0; }
.mmd-topbar .gsrch.mmd-search-slot { flex: 1 1 auto; max-width: none; margin: 0; }
/* Desktop: rampingkan kontrol di topbar biar header benar2 slim (mobile tetap 44px touch-target) */
@media (min-width: 861px) {
  .mmd-topbar .mmd-command-open { height: 32px; border-radius: 9px; }
  .mmd-topbar .mmd-icon-btn { min-height: 32px; width: 32px; border-radius: 9px; }
  .mmd-topbar .mmd-select { min-height: 32px; border-radius: 9px; }
  .mmd-topbar .mmd-search-slot,
  .mmd-topbar .gsrch.mmd-search-slot input,
  .mmd-topbar-actions .mmd-native-ua :is(button, a, input, select) { min-height: 32px !important; height: 32px; }
  /* Tombol teks (EN / Bantuan / Logout / Sites / user) lebih ringkas & profesional */
  .mmd-topbar-actions .mmd-native-ua :is(button, a, input, select) {
    padding-top: 0; padding-bottom: 0;
    font-size: 12.5px; font-weight: 600; border-radius: 9px;
  }
  .mmd-topbar-actions .mmd-native-ua #ua-user { font-size: 12px; font-weight: 600; }
}
.mmd-brand-mark {
  flex: 0 0 auto;
  width: 31px;
  height: 31px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: transparent;
  font-weight: 950;
  letter-spacing: -.08em;
  background: #fff;
  background-image: url('../mandalamine_erp_mark.svg');
  background-size: 24px 24px;
  background-repeat: no-repeat;
  background-position: center;
  border: 1px solid rgba(8,33,63,.10);
  box-shadow: 0 4px 14px rgba(8,33,63,.12), inset 0 1px rgba(255,255,255,.55);
}
.mmd-brand-title { min-width: 0; line-height: 1.05; }
.mmd-brand-title strong { display: flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 900; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mmd-brand-title span { display: block; margin-top: 2px; color: var(--mmd2-soft); font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .035em; white-space: nowrap; overflow: visible; }
/* BETA badge di samping logo — dipindah dari header lama ERP, gaya emas konsisten brand */
.mmd-beta-badge {
  flex: 0 0 auto;
  display: inline-block;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .5px;
  color: #1a1205;
  background: linear-gradient(135deg, #d9b765, #C49A48);
  padding: 1px 6px;
  border-radius: 5px;
  line-height: 1.4;
}
.mmd-command-open {
  height: 44px;
  border: 1px solid var(--mmd2-border);
  border-radius: 15px;
  color: var(--mmd2-muted);
  background: rgba(255,255,255,.07);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 13px;
  cursor: pointer;
  min-width: 0;
  text-align: left;
}
.mmd-command-open:hover { background: rgba(255,255,255,.11); }
.mmd-command-open span:first-child { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mmd-kbd {
  margin-left: auto;
  flex: 0 0 auto;
  color: var(--mmd2-soft);
  border: 1px solid var(--mmd2-border);
  background: rgba(0,0,0,.14);
  border-radius: 9px;
  padding: 4px 7px;
  font-size: 11px;
}
.mmd-select,
.mmd-icon-btn,
.mmd-primary-btn,
.mmd-secondary-btn,
.mmd-chip-btn {
  border: 1px solid var(--mmd2-border);
  background: rgba(255,255,255,.075);
  color: var(--mmd2-ink);
  border-radius: 15px;
  min-height: 44px;
}
.mmd-select { padding: 0 30px 0 11px; cursor: pointer; max-width: 150px; }
.mmd-icon-btn {
  width: 44px;
  display: grid;
  place-items: center;
  cursor: pointer;
  font-weight: 850;
}
.mmd-icon-btn:hover, .mmd-select:hover { background: rgba(255,255,255,.11); }
.mmd-icon-btn.is-active { background: rgba(201,154,46,.16); border-color: rgba(201,154,46,.48); color: #ffe3a0; }
.mmd-primary-btn,
.mmd-secondary-btn,
.mmd-chip-btn { cursor: pointer; padding: 0 14px; font-weight: 800; }
.mmd-primary-btn { background: linear-gradient(135deg, var(--mmd2-gold-2), var(--mmd2-gold)); color: #08101b; border-color: rgba(255,226,155,.65); }
.mmd-secondary-btn:hover, .mmd-chip-btn:hover { background: rgba(255,255,255,.12); }

/* Control tower */
.mmd-control-tower {
  width: min(var(--mmd2-content-max), 100%);
  margin: 12px auto 12px;
  padding: 0 clamp(14px, 2vw, 28px);
  display: block;
}
body.mmd-hide-tower .mmd-control-tower { display: none; }
.mmd-hero-grid {
  display: grid;
  /* minmax(0,...) bukan px tetap -> track selalu bisa menyusut, tidak pernah
     memaksa lebar > viewport (anti "kolom keluar dari batas" + body overflow-x
     hidden yang meng-clip kartu kanan). Proporsi visual tetap via fr. */
  grid-template-columns: minmax(0, 1.5fr) repeat(3, minmax(0, .72fr));
  gap: 12px;
  align-items: stretch;
  max-width: 100%;
}
.mmd-hero-main,
.mmd-kpi-card,
.mmd-panel,
.mmd-workflow-card {
  border: 1px solid var(--mmd2-border);
  background: linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.065));
  border-radius: var(--mmd2-r-lg);
  box-shadow: var(--mmd2-shadow-soft);
  backdrop-filter: blur(18px);
}
.mmd-hero-main {
  padding: clamp(14px, 1.8vw, 20px);
  min-height: 140px;
  min-width: 0;
  position: relative;
  overflow: hidden;
}
.mmd-hero-main::after {
  content: "";
  position: absolute;
  right: -90px;
  top: -90px;
  width: 230px;
  height: 230px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(201,154,46,.24), transparent 64%);
  pointer-events: none;
}
.mmd-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border: 1px solid rgba(201,154,46,.28);
  border-radius: 999px;
  background: rgba(201,154,46,.11);
  color: #ffe1a0;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .03em;
  text-transform: uppercase;
}
.mmd-hero-main h1 {
  margin: 9px 0 7px;
  font-size: clamp(21px, 2.2vw, 32px);
  line-height: 1.04;
  letter-spacing: -.045em;
}
.mmd-hero-main p {
  margin: 0;
  max-width: 870px;
  color: var(--mmd2-muted);
  line-height: 1.45;
  font-size: 12.5px;
}
.mmd-hero-actions {
  margin-top: 12px;
  display: flex;
  gap: 9px;
  flex-wrap: wrap;
}
.mmd-kpi-card {
  padding: 13px;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 9px;
}
.mmd-card-label { color: var(--mmd2-soft); font-size: 12px; font-weight: 850; text-transform: uppercase; letter-spacing: .07em; }
.mmd-card-value { margin-top: 5px; font-size: clamp(20px, 1.9vw, 28px); font-weight: 950; letter-spacing: -.06em; }
.mmd-status {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 850;
  border: 1px solid transparent;
}
.mmd-status.ok { color: #a7f3d0; border-color: rgba(52,211,153,.28); background: rgba(52,211,153,.12); }
.mmd-status.review { color: #fed7aa; border-color: rgba(251,146,60,.28); background: rgba(251,146,60,.12); }
.mmd-status.hold { color: #fecaca; border-color: rgba(248,113,113,.28); background: rgba(248,113,113,.12); }
.mmd-role-strip {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  /* Samakan gutter kolom dgn baris lain (hero/panels/Command Center) -> 12px,
     biar jarak antar kolom konsisten dari atas ke bawah halaman. */
  gap: 12px;
}
.mmd-role-chip {
  min-width: 0;
  border: 1px solid var(--mmd2-border);
  border-radius: var(--mmd2-r-md);
  padding: 9px 11px;
  background: rgba(255,255,255,.065);
  color: var(--mmd2-ink);
  text-align: left;
  cursor: pointer;
}
.mmd-role-chip b { display: block; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mmd-role-chip span { display: block; margin-top: 3px; color: var(--mmd2-soft); font-size: 11px; line-height: 1.3; }
.mmd-role-chip.is-active { background: rgba(201,154,46,.15); border-color: rgba(201,154,46,.48); box-shadow: inset 0 1px rgba(255,255,255,.16); }
.mmd-panels-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, .76fr);
  gap: 12px;
  max-width: 100%;
}
.mmd-panel { padding: 13px; min-width: 0; }
.mmd-panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 9px; }
.mmd-panel-head h2 { margin: 0; font-size: 16px; letter-spacing: -.025em; }
.mmd-panel-head span { color: var(--mmd2-soft); font-size: 12px; font-weight: 750; }
/* Exception Center: tampilkan ~2 item, sisanya scroll di dalam kotaknya.
   max-height dihitung dari 2 item (tinggi seragam) + gap + sedikit "peek"
   item ke-3 sebagai sinyal masih ada lanjutannya. Berlaku di semua ukuran
   (mobile & desktop), bukan cuma laptop. */
.mmd-exception-list {
  display: grid;
  gap: 8px;
  max-height: 156px;
  overflow-y: auto;
  padding-right: 4px;
  scrollbar-width: thin;
}
.mmd-exception-list::-webkit-scrollbar { width: 6px; }
.mmd-exception-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.16); border-radius: 999px; }
.mmd-exception-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 11px;
  border: 1px solid var(--mmd2-border);
  border-radius: var(--mmd2-r-md);
  background: rgba(0,0,0,.12);
}
.mmd-exception-item b { display: block; font-size: 13px; }
.mmd-exception-item small { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-top: 4px; color: var(--mmd2-soft); line-height: 1.35; }
.mmd-badge {
  flex: 0 0 auto;
  display: inline-flex;
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  border: 1px solid var(--mmd2-border);
}
.mmd-badge.ok { color: #a7f3d0; border-color: rgba(52,211,153,.3); background: rgba(52,211,153,.1); }
.mmd-badge.review { color: #fed7aa; border-color: rgba(251,146,60,.3); background: rgba(251,146,60,.1); }
.mmd-badge.hold { color: #fecaca; border-color: rgba(248,113,113,.3); background: rgba(248,113,113,.1); }
.mmd-flow {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}
.mmd-flow-step {
  border: 1px solid var(--mmd2-border);
  border-radius: 14px;
  padding: 8px;
  min-height: 44px;
  background: rgba(255,255,255,.055);
}
.mmd-flow-step strong { display: block; font-size: 12px; }
.mmd-flow-step small { display: block; margin-top: 4px; color: var(--mmd2-soft); line-height: 1.25; font-size: 10.5px; }

/* Role workflow cards */
.mmd-workflows {
  width: min(var(--mmd2-content-max), 100%);
  /* Beri jarak ke baris Exception/Audit di atasnya supaya judul kartu Command
     Center tak nempel/tabrakan dgn header panel di atasnya. */
  margin: 16px auto 14px;
  padding: 0 clamp(14px, 2vw, 28px);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  /* Gutter kolom konsisten 12px (sama dgn hero/role/panels di atasnya). */
  gap: 12px;
}
.mmd-workflow-card {
  padding: 10px 11px;
  min-width: 0;
  border-radius: var(--mmd2-r-md, 14px);
  box-shadow: none;
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
}
.mmd-workflow-card strong { display: block; font-size: 12px; letter-spacing: .2px; }
.mmd-workflow-card p { margin: 3px 0 8px; color: var(--mmd2-soft); font-size: 10.8px; line-height: 1.32; }
.mmd-workflow-card button { width: 100%; }
/* Tombol Command Center: slim, bukan 44px penuh -> baris jadi tipis & seamless */
.mmd-workflow-card .mmd-secondary-btn {
  min-height: 30px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}

/* Universal across ALL laptop sizes (anti-kepotong selamanya).
   PELAJARAN: mengunci Control Tower ke tinggi viewport (100vh - topbar - 170px)
   itu rapuh -> 100vh beda-beda tiap browser (tinggi toolbar/URL bar beda), dan
   "170px" cuma tebakan. Tidak ada satu angka yang benar untuk semua ukuran,
   makanya selalu ada yang kepotong di salah satu laptop.

   Pendekatan universal: JANGAN paksa muat 1 layar. Biarkan konten mengalir &
   halaman scroll natural -> di layar berapapun, sebesar/sependek apapun, tidak
   pernah ada yang terpotong. Sizing tetap kompak & responsif (clamp) sehingga di
   laptop normal tetap pas ~1 layar, tapi kalau layar pendek dia scroll mulus,
   bukan kepotong. Additive & reversible. */
@media (min-width: 1025px) {
  .mmd-control-tower {
    display: block;
    margin: 12px auto;
  }
  .mmd-hero-main p {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  /* Exception list dibatasi oleh JUMLAH ISI (content-based), bukan viewport.
     Ini robust di semua ukuran: daftar panjang scroll di dalam kotaknya sendiri,
     daftar pendek tampil apa adanya. Tidak bergantung 100vh sama sekali. */
  .mmd-exception-list { max-height: 156px; }
  /* Audit Trail Flow (5 langkah Pit->Finance) dikasih ruang cukup supaya tak
     pernah bocor/kepotong; kalau sempit, langkah wrap rapi ke bawah. */
  .mmd-panels-grid { min-height: 118px; }
}

/* Layar pendek (laptop ~720-860px): rampingkan hero & role strip biar lebih
   ringkas -> di banyak laptop tetap muat ~1 layar tanpa scroll. Tapi ini cuma
   optimasi tampilan; kalau toh tak muat, halaman scroll natural (tak kepotong). */
@media (min-width: 1025px) and (max-height: 820px) {
  .mmd-control-tower { margin: 10px auto; }
  .mmd-hero-main { padding: 13px 16px; }
  .mmd-hero-main h1 { font-size: clamp(18px, 1.6vw, 24px); margin: 7px 0 6px; line-height: 1.06; }
  .mmd-hero-main p { -webkit-line-clamp: 2; font-size: 12px; line-height: 1.4; }
  .mmd-hero-actions { margin-top: 10px; }
  .mmd-kpi-card { padding: 12px; gap: 7px; }
  .mmd-card-value { font-size: clamp(18px, 1.7vw, 24px); margin-top: 4px; }
  .mmd-role-chip { padding: 8px 10px; }
}

/* Existing app refinements */
body.mmd-v2 :is(.card, .panel, .box, .widget, .summary-card, .stat-card, section, article):not(.mmd-ignore):not(.mmd-hero-main):not(.mmd-kpi-card):not(.mmd-panel):not(.mmd-workflow-card) {
  border-color: var(--mmd2-border);
}
body.mmd-v2 :is(button, .btn, [role="button"]):not(.mmd-ignore):not(.mmd-command-open):not(.mmd-icon-btn):not(.mmd-role-chip):not(.mmd-primary-btn):not(.mmd-secondary-btn):not(.mmd-chip-btn) {
  min-height: 40px;
  border-radius: 12px;
}
body.mmd-v2 :is(input, select, textarea):not(.mmd-ignore):not(.mmd-select) {
  min-height: 42px;
  border-radius: 12px;
  border: 1px solid rgba(148,163,184,.32);
}
body.mmd-v2 :is(input, select, textarea):focus {
  outline: none;
  border-color: rgba(201,154,46,.62);
  box-shadow: var(--mmd2-ring);
}
body.mmd-v2 label { color: var(--mmd2-muted); font-weight: 700; }
body.mmd-v2 :is(h1,h2,h3) { letter-spacing: -.035em; }
body.mmd-v2 :is(table) {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}
body.mmd-v2 thead th {
  position: sticky;
  top: var(--mmd2-topbar-h);
  z-index: 4;
  background: rgba(10,24,40,.94);
  color: #dce6f2;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .055em;
  border-bottom: 1px solid var(--mmd2-border);
  white-space: nowrap;
}
body.mmd-v2 th, body.mmd-v2 td { padding: 11px 12px; border-bottom: 1px solid rgba(255,255,255,.08); }
body.mmd-v2 tbody tr:hover { background: rgba(255,255,255,.055); }
.mmd-table-scroll {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--mmd2-border);
  border-radius: var(--mmd2-r-md);
  background: rgba(0,0,0,.12);
}
.mmd-table-scroll > table { min-width: 760px; }
.mmd-table-scroll::after {
  content: "Geser tabel ke samping →";
  display: none;
  padding: 9px 12px;
  color: var(--mmd2-soft);
  font-size: 12px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.mmd-empty-state {
  border: 1px dashed rgba(148,163,184,.36) !important;
  border-radius: var(--mmd2-r-md) !important;
  background: rgba(15,23,42,.42) !important;
  color: var(--mmd2-soft) !important;
  padding: 18px !important;
}
.mmd-empty-state::before { content: "ⓘ "; color: var(--mmd2-gold-2); font-weight: 900; }
.mmd-sticky-context {
  position: sticky !important;
  top: calc(var(--mmd2-topbar-h) + 8px) !important;
  z-index: 20 !important;
  border-radius: var(--mmd2-r-md) !important;
  backdrop-filter: blur(18px);
  background: rgba(8,18,30,.82) !important;
  border: 1px solid var(--mmd2-border) !important;
}

/* Command palette */
.mmd-command-layer {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  padding: min(9vh, 78px) 16px 16px;
  background: rgba(2,6,12,.68);
  backdrop-filter: blur(12px);
}
.mmd-command-layer.is-open { display: block; }
.mmd-command-modal {
  width: min(760px, 100%);
  margin: 0 auto;
  border: 1px solid var(--mmd2-border-2);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(15,32,52,.98), rgba(6,17,30,.98));
  box-shadow: var(--mmd2-shadow);
  overflow: hidden;
}
.mmd-command-input-wrap { padding: 14px; border-bottom: 1px solid var(--mmd2-border); }
.mmd-command-input {
  width: 100%;
  height: 52px;
  border-radius: 16px;
  border: 1px solid var(--mmd2-border);
  background: rgba(255,255,255,.075);
  color: var(--mmd2-ink);
  padding: 0 16px;
  font-size: 16px;
}
.mmd-command-list { max-height: min(58vh, 520px); overflow: auto; padding: 8px; }
.mmd-command-item {
  width: 100%;
  border: 0;
  border-radius: 15px;
  background: transparent;
  color: var(--mmd2-ink);
  text-align: left;
  padding: 12px;
  display: grid;
  grid-template-columns: 32px minmax(0,1fr) auto;
  gap: 10px;
  align-items: center;
  cursor: pointer;
}
.mmd-command-item:hover, .mmd-command-item.is-active { background: rgba(255,255,255,.1); }
.mmd-command-item b { display: block; font-size: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mmd-command-item span { display: block; margin-top: 3px; color: var(--mmd2-soft); font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mmd-command-tag { color: #ffe0a0 !important; border: 1px solid rgba(201,154,46,.28); background: rgba(201,154,46,.1); padding: 4px 7px; border-radius: 999px; margin-top: 0 !important; }

/* Toast */
.mmd-toast-host {
  position: fixed;
  z-index: 10002;
  right: 16px;
  bottom: 16px;
  display: grid;
  gap: 10px;
  width: min(380px, calc(100vw - 32px));
}
.mmd-toast {
  border: 1px solid var(--mmd2-border);
  border-radius: var(--mmd2-r-md);
  padding: 13px 14px;
  background: rgba(11,24,40,.94);
  color: var(--mmd2-muted);
  box-shadow: var(--mmd2-shadow-soft);
  backdrop-filter: blur(18px);
}
.mmd-toast b { display: block; color: var(--mmd2-ink); margin-bottom: 4px; }

/* Mobile dock */
.mmd-mobile-dock {
  position: fixed;
  z-index: 9997;
  left: 10px;
  right: 10px;
  bottom: 10px;
  min-height: 62px;
  display: none;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
  padding: 7px;
  border: 1px solid var(--mmd2-border);
  border-radius: 22px;
  background: rgba(6,17,30,.9);
  backdrop-filter: blur(22px);
  box-shadow: 0 18px 60px rgba(0,0,0,.4);
}
.mmd-dock-btn {
  border: 0;
  border-radius: 16px;
  background: transparent;
  color: var(--mmd2-muted);
  display: grid;
  gap: 3px;
  place-items: center;
  font-size: 10px;
  font-weight: 750;
  cursor: pointer;
  min-width: 0;
}
.mmd-dock-btn strong { font-size: 18px; line-height: 1; }
.mmd-dock-btn.is-primary { background: linear-gradient(135deg, var(--mmd2-gold-2), var(--mmd2-gold)); color: #08101b; }

/* Role highlighting, no security hiding */
body.mmd-v2 [data-mmd-role-match="dim"] { opacity: .62; }
body.mmd-v2 [data-mmd-role-match="match"] { outline: 1px solid rgba(201,154,46,.28); outline-offset: 2px; }

/* Print and screenshot */
@media print {
  .mmd-topbar, .mmd-mobile-dock, .mmd-command-layer, .mmd-toast-host { display: none !important; }
  body.mmd-v2 { background: #fff !important; color: #111 !important; }
  .mmd-control-tower, .mmd-workflows { display: none !important; }
}

/* Tablet */
@media (max-width: 1180px) {
  .mmd-topbar { grid-template-columns: minmax(200px,280px) minmax(110px,1fr) auto; }
  .mmd-topbar .mmd-icon-btn[data-mmd-action="density"] { display: none; }
  .mmd-hero-grid { grid-template-columns: minmax(0, 1fr) minmax(0,.42fr); }
  .mmd-hero-main { grid-column: 1 / -1; }
  .mmd-role-strip { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .mmd-workflows { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .mmd-flow { grid-template-columns: repeat(3, minmax(0,1fr)); }
}

@media (max-width: 860px) {
  :root { --mmd2-topbar-h: auto; }
  body.mmd-v2 { padding-bottom: calc(var(--mmd2-mobile-dock-h) + env(safe-area-inset-bottom, 0px)); }
  .mmd-topbar {
    position: sticky;
    grid-template-columns: 1fr auto;
    height: auto;
    min-height: 64px;
    gap: 9px;
    padding: 9px 12px;
  }
  .mmd-topbar .mmd-search-slot { order: 4; grid-column: 1 / -1; }
  .mmd-topbar-actions { flex-wrap: wrap; gap: 8px; justify-content: flex-start; }
  /* Di HP deretan tombol asli boleh wrap lagi biar nama user panjang tak terpotong */
  .mmd-topbar-actions .mmd-native-ua { flex-wrap: wrap; }
  .mmd-brand { min-width: 0; }
  .mmd-brand-mark { width: 40px; height: 40px; border-radius: 14px; }
  .mmd-brand-title strong { font-size: 14px; }
  .mmd-brand-title span { font-size: 10px; }
  .mmd-command-open {
    order: 4;
    grid-column: 1 / -1;
    height: 42px;
  }
  .mmd-select { display: none; }
  .mmd-icon-btn[data-mmd-action="tower"] { display: grid; }
  .mmd-control-tower { margin-top: 12px; padding-inline: 12px; }
  .mmd-hero-grid { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
  .mmd-hero-main { padding: 17px; min-height: unset; }
  .mmd-hero-main h1 { font-size: 27px; }
  .mmd-hero-main p { font-size: 13px; line-height: 1.55; }
  .mmd-kpi-card { padding: 14px; border-radius: 18px; }
  .mmd-card-value { font-size: 24px; }
  .mmd-role-strip { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 8px; }
  .mmd-role-chip { padding: 11px; border-radius: 16px; }
  .mmd-panels-grid { grid-template-columns: 1fr; }
  .mmd-workflows { grid-template-columns: 1fr; padding-inline: 12px; gap: 9px; }
  .mmd-flow { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .mmd-mobile-dock { display: grid; }
  .mmd-toast-host { bottom: 86px; }
  .mmd-table-scroll::after { display: block; }
  body.mmd-v2 thead th { top: 0; }
  body.mmd-v2 :is(input, select, textarea, button, .btn, [role="button"]) { min-height: 44px; }
}

/* Mobile */
@media (max-width: 560px) {
  .mmd-topbar { grid-template-columns: 1fr auto; }
  .mmd-topbar .mmd-icon-btn[data-mmd-action="density"] { display: none; }
  .mmd-topbar .mmd-icon-btn[data-mmd-action="tower"] { display: none; }
  .mmd-command-open { grid-column: 1 / -1; }
  .mmd-kbd { display: none; }
  .mmd-hero-grid { grid-template-columns: 1fr; }
  .mmd-hero-actions { display: grid; grid-template-columns: 1fr 1fr; }
  .mmd-hero-actions button { width: 100%; padding-inline: 8px; }
  .mmd-role-strip { grid-template-columns: 1fr 1fr; }
  .mmd-role-chip span { display: none; }
  .mmd-flow { grid-template-columns: 1fr; }
  .mmd-panel, .mmd-workflow-card { border-radius: 18px; }
  .mmd-exception-item { align-items: flex-start; }
  .mmd-command-layer { padding-top: 8px; }
  .mmd-command-modal { border-radius: 22px; }
  .mmd-command-list { max-height: 68vh; }
  .mmd-command-item { grid-template-columns: 28px minmax(0,1fr); }
  .mmd-command-tag { display: none !important; }
  body.mmd-v2 .mmd-card-table table,
  body.mmd-v2 .mmd-card-table thead,
  body.mmd-v2 .mmd-card-table tbody,
  body.mmd-v2 .mmd-card-table th,
  body.mmd-v2 .mmd-card-table td,
  body.mmd-v2 .mmd-card-table tr { display: block; }
  body.mmd-v2 .mmd-card-table table { min-width: 0; }
  body.mmd-v2 .mmd-card-table thead { display: none; }
  body.mmd-v2 .mmd-card-table tr {
    margin: 10px;
    border: 1px solid var(--mmd2-border);
    border-radius: 16px;
    background: rgba(255,255,255,.055);
    overflow: hidden;
  }
  body.mmd-v2 .mmd-card-table td {
    display: grid;
    grid-template-columns: 42% 1fr;
    gap: 10px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    min-height: 42px;
    align-items: center;
    word-break: break-word;
  }
  body.mmd-v2 .mmd-card-table td::before {
    content: attr(data-mmd-label);
    color: var(--mmd2-soft);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .05em;
  }
  .mmd-mobile-dock { left: 8px; right: 8px; bottom: max(8px, env(safe-area-inset-bottom)); border-radius: 20px; }
}

@media (max-width: 400px) {
  .mmd-brand-title span { display: none; }
  .mmd-hero-main h1 { font-size: 24px; }
  .mmd-hero-actions { grid-template-columns: 1fr; }
  .mmd-role-strip { grid-template-columns: 1fr; }
  .mmd-dock-btn { font-size: 9px; }
  .mmd-dock-btn strong { font-size: 17px; }
}

/* === Fix: jangan ketiban Pro-sidebar lama (069/070_prosidebar) ===
   Sidebar lama itu position:fixed; left:0; width:236px di desktop >=1080px
   (body.mm-side), dan menggeser #app via padding-left:236px. Tapi elemen V2
   (control-tower & workflows) di-prepend/append ke <body> langsung, di LUAR
   #app, jadi tidak ikut tergeser -> ketiban sidebar (hero "Tower" kepotong).
   Geser manual selebar sidebar. Topbar sengaja dibiarkan full-width: brand
   shield-nya jadi "logo well" di kiri-atas, di atas kolom sidebar (layout
   admin standar). Hanya aktif saat sidebar aktif -> nol efek di mobile/mode
   tanpa sidebar. Additive & reversible. */
@media (min-width: 1080px) {
  body.mmd-v2.mm-side .mmd-control-tower,
  body.mmd-v2.mm-side .mmd-workflows {
    margin-left: 236px;
    /* keduanya default width:min(content-max,100%)=100% -> harus dikurangi
       lebar sidebar biar tidak overflow ke kanan (scrollbar horizontal). */
    width: min(var(--mmd2-content-max), calc(100% - 236px));
  }
  /* Fix: item pertama sidebar ("Dashboard") ketiban topbar full-width.
     Sidebar lama mulai dari top:0, padahal topbar V2 menutup 54px teratas.
     Turunkan awal sidebar tepat di bawah topbar -> seluruh nav (Dashboard
     ke bawah) kelihatan utuh, tidak terpotong. Additive & reversible. */
  body.mmd-v2.mm-side #mm-sidebar {
    top: var(--mmd2-topbar-h) !important;
  }
}

/* === Phase 2 — Dashboard 1 lapis (buang KPI dobel) ===================
   Control Tower V2 di atas sudah jadi "glance" tunggal: keputusan
   TAHAN/TINJAU, rantai bukti, exception live, dan flow ore→…→payment.
   Maka di panel "Ringkasan Eksekutif" (lapisan detail di bawahnya) kita
   sembunyikan elemen yang persis mengulang itu (ditandai .mmd-dup-hide
   oleh dedupeExecPanel di JS): flag keputusan + kartu Ore YTD / Total
   Pengapalan / Tagihan QAQC. !important supaya menang atas inline style
   display:block yang di-set ulang loadExec tiap muat. Sisa panel (OB/SR,
   Karyawan, Payroll, Kas, tabel per-owner, grafik, detail dokumen/
   reklamasi) tetap tampil — itu drill-down yang tidak ada di Control
   Tower. Additive & reversible: lepas V2 = semua kembali utuh. */
.mmd-v2 .mmd-dup-hide { display: none !important; }
/* Panel detail di bawah glance: rapatkan jarak atas judulnya sedikit
   supaya transisi Control Tower -> Ringkasan terasa satu aliran, bukan
   dua ringkasan terpisah. */
.mmd-v2 #exec-panel.mmd-exec-deduped { margin-top: 4px; }
