/* ============================================================
   Vega ERP — self-contained modern theme + layout.
   Sits on top of Bootstrap 4 (grid/components) + icon fonts.
   Defines the full app shell (topbar, sidebar, content) so it
   does NOT depend on the legacy Hyper app.min.css layout.
   ============================================================ */
:root {
  --vega-primary: #4f46e5;
  --vega-primary-2: #6d28d9;
  --vega-primary-soft: #eef2ff;
  --vega-ink: #1f2937;
  --vega-muted: #6b7280;
  --vega-bg: #f4f5fb;
  --vega-border: #e8eaf2;
  --vega-radius: 12px;
  --vega-sidebar-w: 252px;
  --vega-topbar-h: 64px;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--vega-bg);
  color: var(--vega-ink);
  font-family: 'Segoe UI', system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
  font-size: 14px;
}
a { color: var(--vega-primary); }

/* ── Topbar ──────────────────────────────────────────────── */
.navbar-custom {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--vega-topbar-h);
  display: flex;
  align-items: center;
  background: linear-gradient(90deg, var(--vega-primary) 0%, var(--vega-primary-2) 100%);
  box-shadow: 0 2px 14px rgba(79, 70, 229, 0.28);
  z-index: 1001;
}
.navbar-custom .logo-box {
  width: var(--vega-sidebar-w);
  min-width: var(--vega-sidebar-w);
  height: var(--vega-topbar-h);
  display: flex;
  align-items: center;
  padding-left: 24px;
}
.navbar-custom .logo { display: inline-flex; align-items: center; text-decoration: none; }
.logo-lg-text-light { color: #fff; font-weight: 700; letter-spacing: .5px; font-size: 20px; }
.navbar-custom .topnav-menu-left { flex: 1; list-style: none; margin: 0; padding: 0 16px; display: flex; align-items: center; }
.navbar-custom .topnav-menu-left h4 { color: rgba(255,255,255,.92); margin: 0; font-size: 15px; font-weight: 600; }
.navbar-custom .topnav-menu { list-style: none; margin: 0; padding: 0 16px 0 0; display: flex; align-items: center; }
.navbar-custom .nav-user { display: flex; align-items: center; gap: 8px; color: #fff; cursor: pointer; padding: 6px 10px; border-radius: 10px; }
.navbar-custom .nav-user:hover { background: rgba(255,255,255,.12); }
.navbar-custom .pro-user-name { color: #fff; font-weight: 600; }
.navbar-custom .nav-user img { border: 2px solid rgba(255,255,255,.5); }

/* ── Sidebar ─────────────────────────────────────────────── */
.left-side-menu {
  position: fixed;
  top: var(--vega-topbar-h);
  left: 0;
  bottom: 0;
  width: var(--vega-sidebar-w);
  height: calc(100vh - var(--vega-topbar-h));
  overflow-y: auto;
  overflow-x: hidden;
  background: #fff;
  border-right: 1px solid var(--vega-border);
  box-shadow: 0 0 24px rgba(31, 41, 55, 0.05);
  z-index: 1000;
  padding: 8px 0 24px;
}
.left-side-menu .h-100 { height: auto !important; }
#sidebar-menu ul { list-style: none; margin: 0; padding: 0; }
#sidebar-menu .menu-title {
  color: var(--vega-muted);
  font-size: 11px;
  letter-spacing: .8px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 14px 22px 6px;
}
#sidebar-menu > ul > li > a {
  display: flex;
  align-items: center;
  color: #44495b;
  font-weight: 500;
  font-size: 14px;
  padding: 11px 22px;
  border-radius: 0 24px 24px 0;
  margin-right: 12px;
  text-decoration: none;
  cursor: pointer;
  transition: all .15s ease;
}
#sidebar-menu > ul > li > a:hover { background: var(--vega-primary-soft); color: var(--vega-primary); }
#sidebar-menu > ul > li.mm-active > a { background: var(--vega-primary-soft); color: var(--vega-primary); }
#sidebar-menu i { font-size: 17px; margin-right: 12px; display: inline-flex; min-width: 20px; }
#sidebar-menu .menu-arrow { margin-left: auto; transition: transform .2s; font-size: 13px; opacity: .6; }
#sidebar-menu > ul > li.mm-active > a .menu-arrow { transform: rotate(90deg); }

/* nested group (e.g. "User Management", "Location Info") */
#sidebar-menu .nav-second-level { padding: 2px 0 6px; }
#sidebar-menu .menu-group { padding: 0; }
#sidebar-menu .menu-subtitle {
  display: block;
  color: #9aa1b3;
  font-size: 10.5px;
  letter-spacing: .7px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 12px 20px 6px 28px;
}
/* leaf items with a guide rail + dot */
#sidebar-menu .nav-third-level {
  position: relative;
  margin-left: 30px;
  padding-left: 0;
  border-left: 1.5px solid #edeef5;
}
#sidebar-menu .leaf-link {
  display: flex;
  align-items: center;
  color: #5b6172;
  padding: 8px 16px 8px 16px;
  font-size: 13px;
  border-radius: 8px;
  margin: 1px 12px 1px 0;
  text-decoration: none;
  transition: all .12s ease;
}
#sidebar-menu .leaf-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #c7cbdb;
  margin-right: 12px; margin-left: -3.5px;
  flex: 0 0 auto;
  transition: all .12s ease;
}
#sidebar-menu .leaf-text { flex: 1 1 auto; }
#sidebar-menu .leaf-link:hover { color: var(--vega-primary); background: var(--vega-primary-soft); }
#sidebar-menu .leaf-link:hover .leaf-dot { background: var(--vega-primary); }
#sidebar-menu li.mm-active > .leaf-link {
  color: var(--vega-primary);
  font-weight: 600;
  background: var(--vega-primary-soft);
}
#sidebar-menu li.mm-active > .leaf-link .leaf-dot {
  background: var(--vega-primary);
  box-shadow: 0 0 0 3px rgba(79,70,229,.18);
}
/* "coming soon" items: muted but clean, with a small badge */
#sidebar-menu .leaf-link.is-soon { color: #aab0c0; cursor: default; }
#sidebar-menu .leaf-link.is-soon:hover { background: transparent; color: #aab0c0; }
#sidebar-menu .leaf-link.is-soon .leaf-dot { background: #dfe2ec; }
#sidebar-menu .soon-badge {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: #9aa1b3;
  background: #f0f1f7;
  border-radius: 6px;
  padding: 2px 6px;
  margin-left: 6px;
}

.left-side-menu::-webkit-scrollbar { width: 6px; }
.left-side-menu::-webkit-scrollbar-thumb { background: #d7dae6; border-radius: 6px; }
.left-side-menu { scrollbar-width: thin; scrollbar-color: #d7dae6 transparent; }

/* ── Content ─────────────────────────────────────────────── */
.content-page {
  margin-left: var(--vega-sidebar-w);
  padding-top: var(--vega-topbar-h);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.content-page > .content { flex: 1 1 auto; padding: 18px 22px 8px; }
.container-fluid { width: 100%; padding: 0; }

.page-title-box { padding: 0 0 16px; }
.page-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--vega-ink);
  margin: 0;
  padding-left: 12px;
  position: relative;
  line-height: 1.2;
}
.page-title::before {
  content: '';
  position: absolute;
  left: 0; top: 2px; bottom: 2px;
  width: 4px; border-radius: 4px;
  background: linear-gradient(var(--vega-primary), var(--vega-primary-2));
}

/* ── Cards ───────────────────────────────────────────────── */
.card {
  background: #fff;
  border: 1px solid var(--vega-border);
  border-radius: var(--vega-radius);
  box-shadow: 0 4px 18px rgba(31, 41, 55, 0.05);
  margin-bottom: 20px;
}
.card-body { padding: 20px 22px; }
.card-title {
  font-weight: 700;
  color: var(--vega-ink);
  font-size: 15px;
  margin: 0 0 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--vega-border);
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn { border-radius: 9px; font-weight: 600; padding: .45rem 1rem; }
.btn-primary { background: var(--vega-primary); border-color: var(--vega-primary); }
.btn-primary:hover, .btn-primary:focus {
  background: var(--vega-primary-2); border-color: var(--vega-primary-2);
  box-shadow: 0 4px 14px rgba(79, 70, 229, .35);
}
.btn-success { background: #10b981; border-color: #10b981; }
.btn-light { background: #eef0f6; border-color: #eef0f6; color: #4b5163; }
.btn-light:hover { background: #e2e5ef; }
.btn-outline-primary { color: var(--vega-primary); border-color: var(--vega-primary); background: #fff; }
.btn-outline-primary:hover { background: var(--vega-primary); border-color: var(--vega-primary); color: #fff; }
.btn-outline-danger { color: #ef4444; border-color: #ef4444; background: #fff; }
.btn-outline-danger:hover { background: #ef4444; border-color: #ef4444; color: #fff; }
.btn-outline-secondary { color: #5b6172; border-color: #d2d6e2; background: #fff; }
.btn-outline-secondary:hover { background: #5b6172; border-color: #5b6172; color: #fff; }
.btn-outline-info { color: #0ea5b7; border-color: #0ea5b7; background: #fff; }
.btn-outline-info:hover { background: #0ea5b7; border-color: #0ea5b7; color: #fff; }
.btn-outline-success { color: #16a34a; border-color: #16a34a; background: #fff; }
.btn-outline-success:hover { background: #16a34a; border-color: #16a34a; color: #fff; }
.btn-sm { padding: .28rem .6rem; font-size: 12.5px; }
/* compact, single-row action buttons for list/grid rows */
.row-actions { display: inline-flex; gap: 6px; flex-wrap: nowrap; align-items: center; justify-content: flex-end; }
.row-actions .btn { white-space: nowrap; display: inline-flex; align-items: center; gap: 4px; line-height: 1; }
.btn-action { padding: .25rem .5rem; font-size: 12px; font-weight: 600; border-radius: 7px; }
.btn-block { display: block; width: 100%; }

/* ── Forms ───────────────────────────────────────────────── */
.form-group { margin-bottom: 16px; }
label { font-weight: 600; font-size: 13px; color: #404657; margin-bottom: 6px; display: inline-block; }
.form-control {
  display: block; width: 100%;
  border-radius: 9px;
  border: 1px solid var(--vega-border);
  padding: .5rem .75rem;
  font-size: 14px;
  color: var(--vega-ink);
  background: #fff;
  transition: border-color .12s, box-shadow .12s;
}
.form-control:focus {
  outline: none;
  border-color: var(--vega-primary);
  box-shadow: 0 0 0 3px rgba(79, 70, 229, .12);
}
.form-control-sm { padding: .3rem .55rem; font-size: 13px; border-radius: 7px; }
select.form-control { cursor: pointer; }

/* ── Tables ──────────────────────────────────────────────── */
.table { width: 100%; margin: 0; border-collapse: collapse; }
.table thead th {
  background: #f7f8fc;
  color: #6b7280;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--vega-border);
}
.table td { padding: 11px 14px; font-size: 13.5px; color: #374151; border-top: 1px solid var(--vega-border); vertical-align: middle; }
.table-sm td, .table-sm th { padding: 8px 12px; }
.table-hover tbody tr { transition: background .12s ease; }
.table-hover tbody tr:hover { background: var(--vega-primary-soft); }
.table-bordered { border: 1px solid var(--vega-border); border-radius: 10px; overflow: hidden; }
.table-primary, .table-primary > td { background: var(--vega-primary-soft); }
.table-secondary, .table-secondary > td { background: #f4f5fb; }
.thead-light th { background: #f7f8fc; }
.table-responsive { overflow-x: auto; }

/* Fixed-layout list table — keeps columns aligned and clips long values to a
   single line (full text in title) so the grid stays tidy with many rows. */
.ls-table { table-layout: fixed; width: 100%; }
.ls-table td, .ls-table th { overflow: hidden; }
.ls-table td { vertical-align: middle; }
.ls-table td.clip { white-space: nowrap; text-overflow: ellipsis; }
.ls-table td.nowrap { white-space: nowrap; }
.ls-table tbody tr:nth-child(even) { background: #fcfcfe; }
.ls-actions { gap: 4px; justify-content: center; }
.btn-icon {
  width: 30px; height: 30px; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; line-height: 1; border-radius: 7px;
}

/* ── List-first view (reusable ListView component) ───────────── */
.lv-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.lv-new { font-weight: 600; white-space: nowrap; }
.lv-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.lv-search { position: relative; flex: 1 1 260px; max-width: 420px; min-width: 200px; }
.lv-search .form-control { padding-left: 34px; padding-right: 30px; }
.lv-search-ic { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); font-size: 13px; opacity: .6; pointer-events: none; }
.lv-search-clear { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); border: 0; background: transparent; font-size: 18px; line-height: 1; color: #9ca3af; cursor: pointer; }
.lv-exports { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.lv-table { table-layout: fixed; width: 100%; }
.lv-table td, .lv-table th { overflow: hidden; }
.lv-table td { vertical-align: middle; }
.lv-table td.clip { white-space: nowrap; text-overflow: ellipsis; }
.lv-table tbody tr:nth-child(even) { background: #fcfcfe; }

/* details modal: clean label/value rows */
.lv-details { display: grid; grid-template-columns: 1fr 1fr; gap: 0 26px; }
.lv-detail-row { padding: 9px 0; border-bottom: 1px solid #f1f2f4; }
.lv-detail-k { font-size: 10px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase; color: #6b7280; margin-bottom: 3px; }
.lv-detail-v { font-size: 13.5px; color: #1a1a1a; word-break: break-word; }

/* back bar for the full-page form view */
.lv-backbar { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.lv-back { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; color: var(--vega-primary); background: var(--vega-primary-soft); border: 1px solid transparent; border-radius: 8px; padding: .4rem .8rem; cursor: pointer; }
.lv-back:hover { border-color: var(--vega-primary); }

/* ── Report shell (date filter + summary tiles) ─────────────── */
.rf-row { display: flex; align-items: flex-end; gap: 12px; flex-wrap: wrap; }
.rf-row .form-group { min-width: 150px; }
.report-tiles { margin-top: 14px; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); }
.report-tiles .count-tile { padding: 12px 10px; border-radius: 11px; }
.report-tiles .ct-val { font-size: 22px; font-weight: 800; line-height: 1; color: #1a1a1a; }
.report-tiles .ct-lbl { font-size: 10.5px; color: #6b7280; margin-top: 5px; font-weight: 600; text-transform: uppercase; letter-spacing: .4px; }
.count-tile.tone-primary { border-color: #c7d2fe; background: #eef2ff; } .count-tile.tone-primary .ct-val { color: #3730a3; }
.count-tile.tone-success { border-color: #bbf7d0; background: #f0fdf4; } .count-tile.tone-success .ct-val { color: #15803d; }
.count-tile.tone-danger  { border-color: #fecdd3; background: #fff1f2; } .count-tile.tone-danger  .ct-val { color: #be123c; }
.count-tile.tone-warning { border-color: #fde68a; background: #fffbeb; } .count-tile.tone-warning .ct-val { color: #b45309; }
.count-tile.tone-info    { border-color: #bae6fd; background: #f0f9ff; } .count-tile.tone-info    .ct-val { color: #0369a1; }
.count-tile.tone-muted   { border-color: var(--vega-border); background: #f8fafc; } .count-tile.tone-muted .ct-val { color: #64748b; }
@media (max-width: 820px) { .rf-row { flex-direction: column; align-items: stretch; } .rf-row .form-group { min-width: 0; } }

/* report quick-links grid (dashboard) */
.report-links { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.report-links a {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 14px; border: 1px solid var(--vega-border); border-radius: 10px;
  background: #fff; color: var(--vega-ink); font-weight: 600; font-size: 13.5px;
  transition: border-color .12s, box-shadow .12s, transform .08s;
}
.report-links a:hover { border-color: var(--vega-primary); box-shadow: 0 2px 10px rgba(79,70,229,.1); transform: translateY(-1px); text-decoration: none; }

/* mobile: turn list rows into stacked cards */
@media (max-width: 820px) {
  .lv-table colgroup, .lv-table thead { display: none; }
  .lv-table, .lv-table tbody, .lv-table tr, .lv-table td { display: block; width: 100%; }
  .lv-table tr { border: 1px solid var(--vega-border); border-radius: 10px; margin-bottom: 10px; padding: 4px 12px; background: #fff; }
  .lv-table tbody tr:nth-child(even) { background: #fff; }
  .lv-table td { border: none !important; padding: 7px 0; display: flex; justify-content: space-between; align-items: center; gap: 14px; text-align: right; white-space: normal; overflow: visible; }
  .lv-table td.clip { white-space: normal; text-overflow: clip; }
  .lv-table td::before { content: attr(data-label); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: .3px; color: #6b7280; text-align: left; flex: 0 0 auto; }
  .lv-table td.lv-hide-m { display: none; }
  .lv-table td.lv-actions { justify-content: flex-end; }
  .lv-table td.lv-actions::before { display: none; }
  .lv-table .empty-row td { justify-content: center; }
  .lv-table .empty-row td::before { display: none; }
  .lv-details { grid-template-columns: 1fr; }
  .lv-toolbar, .lv-head { flex-direction: column; align-items: stretch; }
  .lv-search { max-width: none; }
}

.table .btn-link {
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 8px; color: var(--vega-primary);
  text-decoration: none; font-size: 14px; border: 0; background: transparent;
  cursor: pointer; transition: background .12s;
}
.table .btn-link:hover { background: var(--vega-primary-soft); }
.table .btn-link.text-danger { color: #ef4444; }
.table .btn-link.text-danger:hover { background: #fdeaea; }

/* ── Alerts ──────────────────────────────────────────────── */
.alert { border: 0; border-radius: 10px; font-size: 14px; padding: 12px 16px; margin-bottom: 16px; position: relative; }
.alert-success { background: #e7f8f1; color: #0f7a55; }
.alert-warning { background: #fff6e6; color: #9a6a00; }
.alert-danger { background: #fdeaea; color: #b42318; }
.alert-info { background: var(--vega-primary-soft); color: var(--vega-primary); }
.alert .close { position: absolute; right: 12px; top: 10px; background: transparent; border: 0; font-size: 18px; opacity: .5; cursor: pointer; }

/* ── Footer ──────────────────────────────────────────────── */
.footer { padding: 14px 22px; color: var(--vega-muted); border-top: 1px solid var(--vega-border); font-size: 13px; }

/* ── Profile dropdown ────────────────────────────────────── */
.profile-dropdown { background: #fff; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,.14); border: 1px solid var(--vega-border); min-width: 220px; padding: 6px 0; margin-top: 8px; }
.profile-dropdown .dropdown-header { padding: 10px 16px; }
.profile-dropdown .dropdown-item { display: block; padding: 9px 16px; color: #44495b; text-decoration: none; cursor: pointer; }
.profile-dropdown .dropdown-item:hover { background: var(--vega-primary-soft); color: var(--vega-primary); }
.profile-dropdown .dropdown-divider { border-top: 1px solid var(--vega-border); margin: 4px 0; }

/* ── Login ───────────────────────────────────────────────── */
.vega-login-bg {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--vega-primary) 0%, var(--vega-primary-2) 100%);
}
.vega-login-bg .card { box-shadow: 0 18px 50px rgba(20, 20, 60, .35); border: 0; }
.vega-captcha-img svg { width: 100%; height: 46px; }

/* ── Modal picker (Form Path chooser) ────────────────────── */
.vega-modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(17, 24, 39, .5);
  z-index: 2000;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.vega-modal {
  background: #fff;
  width: 640px; max-width: 100%;
  max-height: 84vh;
  border-radius: 14px;
  box-shadow: 0 24px 70px rgba(0,0,0,.35);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.vega-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--vega-border);
}
.vega-modal-head h5 { margin: 0; font-weight: 700; font-size: 16px; }
.vega-modal-close { background: transparent; border: 0; font-size: 24px; line-height: 1; color: var(--vega-muted); cursor: pointer; }
.vega-modal-search { padding: 14px 20px 8px; }
.vega-modal-body { overflow-y: auto; padding: 6px 12px 16px; }
.vega-pick-group { margin-top: 10px; }
.vega-pick-group-title {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
  color: var(--vega-primary); padding: 6px 8px;
}
.vega-pick-item {
  display: flex; flex-direction: column; align-items: flex-start;
  width: 100%; text-align: left;
  background: transparent; border: 1px solid transparent;
  border-radius: 9px; padding: 9px 12px; cursor: pointer;
  transition: all .12s ease;
}
.vega-pick-item:hover { background: var(--vega-primary-soft); border-color: #dfe2f5; }
.vega-pick-row { display: flex; align-items: center; justify-content: space-between; width: 100%; }
.vega-pick-name { font-weight: 600; color: var(--vega-ink); font-size: 14px; }
.vega-pick-path { font-size: 12px; color: var(--vega-muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.vega-pick-badge { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; border-radius: 6px; padding: 2px 7px; }
.vega-pick-badge.is-live { background: #e7f8f1; color: #0f7a55; }
.vega-pick-badge.is-soon { background: #f0f1f7; color: #9aa1b3; }

/* ── Checkbox mapping grid (RBAC mapping screens) ────────── */
.check-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
}
.check-item {
  display: flex; align-items: flex-start; gap: 10px;
  border: 1px solid var(--vega-border);
  border-radius: 10px;
  padding: 10px 12px;
  margin: 0; cursor: pointer;
  transition: all .12s ease;
  background: #fff;
}
.check-item:hover { border-color: #cfd3e6; background: #fafbff; }
.check-item.is-checked { border-color: var(--vega-primary); background: var(--vega-primary-soft); }
.check-item.is-disabled { opacity: .6; cursor: not-allowed; background: #f7f8fc; }
.check-item input { margin-top: 3px; width: 16px; height: 16px; accent-color: var(--vega-primary); }
.check-body { display: flex; flex-direction: column; min-width: 0; }
.check-label { font-weight: 600; font-size: 13.5px; color: var(--vega-ink); }
.check-sub { font-size: 11px; color: var(--vega-muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; word-break: break-all; }
.check-note { font-size: 10px; color: #c2410c; margin-top: 2px; font-weight: 600; }

/* utilities used by components */
.cursor-pointer { cursor: pointer; }
.text-danger { color: #ef4444; }
.text-muted { color: var(--vega-muted) !important; }
.thead-light { }

/* ── Form sections (grouped controls in a subtle panel) ───── */
.form-section {
  border: 1px solid var(--vega-border);
  border-radius: 12px;
  background: #fcfdff;
  padding: 16px 18px 4px;
  margin-bottom: 16px;
}
.form-section + .form-section { margin-top: 16px; }
/* compact inline checkbox group */
.check-row { display: flex; flex-wrap: wrap; gap: 10px 22px; margin-bottom: 12px; }
.check-row label { display: inline-flex; align-items: center; gap: 8px; font-weight: 500; margin: 0; cursor: pointer; }
.check-row input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--vega-primary); }
.form-section-title {
  display: flex; align-items: center; gap: 9px;
  font-size: 11.5px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
  color: var(--vega-primary); margin: 0 0 14px;
}
.form-section-title .step {
  width: 22px; height: 22px; flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--vega-primary); color: #fff; border-radius: 50%;
  font-size: 11px; font-weight: 700;
}
.form-section-title .grow { flex: 1; height: 1px; background: var(--vega-border); }
.req { color: #ef4444; margin-left: 2px; font-weight: 700; }

/* Auto-aligning field grid — equal, responsive columns that always line up.
   Use instead of hand-picked col-md-* so controls stay tidy at any width. */
.field-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 0 18px;
  align-items: start;
}
.field-grid > .form-group { margin-bottom: 16px; min-width: 0; }
.field-grid .col-span-2 { grid-column: span 2; }
.field-grid .col-span-full { grid-column: 1 / -1; }

/* "Status & Document" rows — a compact control on the left + the document/upload
   control taking the rest, all on one line (stacks on small screens). */
.status-doc-grid { display: grid; grid-template-columns: minmax(190px, 240px) 1fr; gap: 0 22px; align-items: start; }
.status-doc-grid-3 { display: grid; grid-template-columns: minmax(160px, 200px) 1.2fr minmax(240px, 320px); gap: 0 22px; align-items: start; }
.status-doc-grid > .form-group, .status-doc-grid-3 > .form-group { min-width: 0; margin-bottom: 0; }
.status-doc-grid .form-control, .status-doc-grid-3 .form-control { height: 40px; }
@media (max-width: 820px) {
  .status-doc-grid, .status-doc-grid-3 { grid-template-columns: 1fr; gap: 0; }
  .status-doc-grid > .form-group, .status-doc-grid-3 > .form-group { margin-bottom: 16px; }
}
/* equal control heights so a row of selects/inputs aligns on the same baseline */
.field-grid .form-control { height: 40px; }
.field-grid textarea.form-control { height: auto; }

/* Inline line-item entry row — flexible fields + a trailing Add button,
   all bottom-aligned and wrapping cleanly. */
.line-row { display: flex; flex-wrap: wrap; gap: 0 14px; align-items: flex-end; }
.line-row > .form-group { flex: 1 1 170px; margin-bottom: 10px; min-width: 0; }
.line-row > .line-add { flex: 0 0 auto; margin-bottom: 10px; }
.line-row .form-control { height: 40px; }
.line-row .line-add .btn { height: 40px; display: inline-flex; align-items: center; }

/* card section heading inside a form (lighter than card-title) */
.card-subhead { font-weight: 700; color: var(--vega-ink); font-size: 13.5px; margin: 2px 0 14px; }

/* ── Action footer (form buttons) ────────────────────────── */
.form-actions {
  display: flex; align-items: center; gap: 10px;
  padding-top: 18px; margin-top: 18px; border-top: 1px solid var(--vega-border);
}
.form-actions .spacer { flex: 1 1 auto; }

/* ── Inline line-item entry bar ──────────────────────────── */
.line-entry {
  background: linear-gradient(180deg, #f7f8ff 0%, #f3f4fd 100%);
  border: 1px solid #e3e6f8;
  border-radius: 12px;
  padding: 16px 16px 4px;
  margin-bottom: 16px;
}
.line-entry .form-group { margin-bottom: 12px; }
.line-entry label { font-size: 12px; color: #555c70; }

/* compact info chip (e.g. quotation no) */
.info-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--vega-primary-soft); color: var(--vega-primary);
  border-radius: 8px; padding: 6px 12px; font-weight: 600; font-size: 13px;
}
.info-chip .lbl { color: var(--vega-muted); font-weight: 600; }

/* ── Badges / status pills ───────────────────────────────── */
.badge { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .3px; padding: 4px 10px; border-radius: 20px; }
.badge-success { background: #e7f8f1; color: #0f7a55; }
.badge-danger  { background: #fdeaea; color: #b42318; }
.badge-warning { background: #fff6e6; color: #9a6a00; }
.badge-info    { background: var(--vega-primary-soft); color: var(--vega-primary); }
.badge-purple  { background: #efe9fe; color: #6d28d9; }
.badge-muted   { background: #f0f1f7; color: #8b91a3; }

/* ── Empty state row ─────────────────────────────────────── */
.empty-row td { text-align: center; color: var(--vega-muted); padding: 30px 14px !important; font-size: 13px; }
.empty-row .icon { display:block; font-size: 22px; opacity: .4; margin-bottom: 4px; }

/* table count chip next to titles */
.count-chip { font-size: 12px; font-weight: 700; color: var(--vega-primary); background: var(--vega-primary-soft); border-radius: 20px; padding: 2px 10px; margin-left: 8px; }

/* search box in card headers */
.card-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.search-input { max-width: 260px; }

/* table footer (grand total) */
.table tfoot th { background: #f7f8fc; padding: 11px 14px; font-size: 13px; color: var(--vega-ink); border-top: 2px solid var(--vega-border); }

/* ── Shared modal (Modal component) ──────────────────────── */
.vega-overlay {
  position: fixed; inset: 0; background: rgba(17,24,39,.55);
  z-index: 2000; display: flex; align-items: flex-start; justify-content: center;
  padding: 6vh 16px; overflow-y: auto;
}
.vega-dialog {
  background: #fff; border-radius: 16px; width: 100%;
  box-shadow: 0 26px 80px rgba(0,0,0,.35);
  display: flex; flex-direction: column; max-height: 88vh;
  animation: vega-pop .14s ease;
}
@keyframes vega-pop { from { opacity:0; transform: translateY(8px) scale(.98); } to { opacity:1; transform:none; } }
.vega-dialog.sm { max-width: 460px; }
.vega-dialog.md { max-width: 680px; }
.vega-dialog.lg { max-width: 880px; }
.vega-dialog.xl { max-width: 1120px; }
.vega-dialog-head { display: flex; align-items: center; justify-content: space-between; padding: 16px 22px; border-bottom: 1px solid var(--vega-border); }
.vega-dialog-head h5 { margin: 0; font-weight: 700; font-size: 16px; color: var(--vega-ink); }
.vega-dialog-body { padding: 18px 22px; overflow-y: auto; }
.vega-dialog-foot { display: flex; justify-content: flex-end; gap: 10px; padding: 14px 22px; border-top: 1px solid var(--vega-border); }

/* ── Upload controls ─────────────────────────────────────── */
/* read-only / auto-filled field — visually distinct from editable inputs */
.form-control.is-readonly, .form-control[readonly] { background: #f6f7fb; color: #5b6172; cursor: default; }
.form-control.is-readonly:focus, .form-control[readonly]:focus { box-shadow: none; border-color: var(--vega-border); }

.upload-control { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.upload-control input[type=file] { font-size: 13px; }
.upload-control input[type=file]::file-selector-button {
  border: 1px solid var(--vega-border); background: #fff; color: var(--vega-ink);
  border-radius: 8px; padding: 7px 14px; margin-right: 10px; cursor: pointer;
  font-weight: 600; font-size: 12.5px; transition: all .12s ease;
}
.upload-control input[type=file]::file-selector-button:hover { background: var(--vega-primary-soft); color: var(--vega-primary); border-color: #dfe2f5; }
.upload-control .btn { padding: .25rem .7rem; font-size: 12.5px; }
.avatar-preview { width: 84px; height: 84px; object-fit: cover; border-radius: 14px; border: 2px solid var(--vega-border); background: #f7f8fc; }
.avatar-sm { width: 32px; height: 32px; object-fit: cover; border-radius: 50%; border: 1px solid var(--vega-border); }

/* ── Hamburger toggle + mobile drawer backdrop ───────────── */
.sidebar-toggle {
  display: none;
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 20px;
  line-height: 1;
  margin-right: 12px;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 8px;
}
.sidebar-toggle:hover { background: rgba(255,255,255,.15); }
.sidebar-toggle i { display: none; }
.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: var(--vega-topbar-h) 0 0 0;
  background: rgba(17, 24, 39, .45);
  z-index: 999;
}

/* ── Responsive: tablet / mobile ─────────────────────────── */
@media (max-width: 991.98px) {
  .navbar-custom .logo-box {
    width: auto;
    min-width: auto;
    padding-left: 14px;
  }
  .sidebar-toggle { display: inline-flex; align-items: center; }

  .left-side-menu {
    transform: translateX(-100%);
    transition: transform .25s ease;
    box-shadow: 0 0 40px rgba(0,0,0,.2);
    z-index: 1002;
  }
  #wrapper.sidebar-open .left-side-menu { transform: translateX(0); }
  #wrapper.sidebar-open .sidebar-backdrop { display: block; }

  .content-page { margin-left: 0; }
  .content-page > .content { padding: 16px 14px 8px; }
  .navbar-custom .topnav-menu-left { padding-left: 8px; }
}

@media (max-width: 575.98px) {
  .logo-lg-text-light { font-size: 17px; }
  .card-body { padding: 16px; }
  .content-page > .content { padding: 14px 10px 8px; }
}

/* ── Dashboard ─────────────────────────────────────────────── */
.dash-hero {
  background: linear-gradient(100deg, var(--vega-primary) 0%, var(--vega-primary-2) 100%);
  color: #fff; border-radius: var(--vega-radius); padding: 20px 24px;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 14px;
  margin-bottom: 18px;
  box-shadow: 0 6px 20px rgba(79, 70, 229, .18);
}
.dash-hero .hero-id { display: flex; align-items: center; gap: 15px; min-width: 0; }
.dash-hero .hero-avatar {
  width: 54px; height: 54px; border-radius: 50%; flex: 0 0 auto;
  background: rgba(255, 255, 255, .16); border: 2px solid rgba(255, 255, 255, .4);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 800; color: #fff; letter-spacing: .5px;
}
.dash-hero h3 { margin: 0; font-size: 21px; font-weight: 700; color: #fff !important; letter-spacing: .2px; line-height: 1.2; }
.dash-hero p { margin: 5px 0 0; color: rgba(255, 255, 255, .92); font-size: 13px; }
.dash-hero p strong { color: #fff; font-weight: 700; }
.dash-hero .hero-meta { text-align: right; font-size: 14px; font-weight: 600; color: #fff; }
.dash-hero .hero-meta-label { display: block; font-size: 10.5px; font-weight: 600; letter-spacing: .8px; text-transform: uppercase; color: rgba(255, 255, 255, .7); margin-bottom: 2px; }

/* dim + lock the dashboard body while a new period is loading */
.dash-content { transition: opacity .15s ease; }
.dash-content.is-loading { opacity: .55; pointer-events: none; }

.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; margin-bottom: 18px; }
.stat-card {
  display: flex; align-items: center; gap: 14px; background: #fff;
  border: 1px solid var(--vega-border); border-radius: var(--vega-radius);
  padding: 16px 18px; text-decoration: none; color: var(--vega-ink);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(79,70,229,.12); border-color: #c7c9f5; color: var(--vega-ink); }
.stat-card .stat-icon { width: 46px; height: 46px; flex: 0 0 46px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 22px; background: var(--vega-primary-soft); }
.stat-card .stat-body { min-width: 0; }
.stat-card .stat-num { font-size: 24px; font-weight: 800; line-height: 1.1; }
.stat-card .stat-label { font-size: 12px; color: var(--vega-muted); margin-top: 2px; }
.stat-card .stat-sub { font-size: 11px; color: var(--vega-muted); margin-top: 1px; }
.stat-card.accent-amber .stat-icon { background: #fef3c7; }
.stat-card.accent-green .stat-icon { background: #dcfce7; }
.stat-card.accent-blue .stat-icon { background: #dbeafe; }
.stat-card.accent-rose .stat-icon { background: #ffe4e6; }
.stat-card.accent-violet .stat-icon { background: #ede9fe; }

.dash-bar-row { display: flex; align-items: center; gap: 10px; margin-bottom: 9px; font-size: 13px; }
.dash-bar-row .bar-label { width: 130px; flex: 0 0 130px; color: var(--vega-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-bar-row .bar-track { flex: 1; height: 16px; background: #f0f1f7; border-radius: 8px; overflow: hidden; }
.dash-bar-row .bar-fill { height: 100%; border-radius: 8px; background: linear-gradient(90deg, var(--vega-primary), var(--vega-primary-2)); }
.dash-bar-row .bar-fill.green { background: #16a34a; }
.dash-bar-row .bar-fill.amber { background: #d97706; }
.dash-bar-row .bar-fill.rose { background: #e11d48; }
.dash-bar-row .bar-fill.blue { background: #2563eb; }
.dash-bar-row .bar-fill.violet { background: #7c3aed; }
.dash-bar-row .bar-val { width: 56px; flex: 0 0 56px; text-align: right; font-weight: 700; }

/* dashboard sections */
.dash-section { margin-bottom: 22px; }
.dash-section-head { display: flex; align-items: baseline; gap: 10px; margin: 0 2px 10px; padding-bottom: 6px; border-bottom: 2px solid var(--vega-border); }
.dash-section-head h4 { margin: 0; font-size: 15px; font-weight: 700; color: var(--vega-ink); letter-spacing: .2px; }
.dash-section-note { font-size: 11px; color: var(--vega-muted, #6b7280); font-style: italic; }

/* dashboard period selector */
.period-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; }
.period-bar .period-label { font-weight: 600; font-size: 13px; color: var(--vega-ink); }
.period-seg { display: inline-flex; background: #f0f1f7; border-radius: 9px; padding: 3px; gap: 2px; }
.period-seg button { border: 0; background: transparent; padding: 6px 12px; border-radius: 7px; font-size: 12.5px; font-weight: 600; color: var(--vega-muted, #555); cursor: pointer; transition: all .12s ease; }
.period-seg button:hover { color: var(--vega-ink); }
.period-seg button.active { background: #fff; color: var(--vega-primary); box-shadow: 0 1px 3px rgba(0,0,0,.12); }
.period-custom { display: inline-flex; align-items: center; gap: 6px; }
.period-custom input { width: 150px; }
.period-resolved { margin-left: auto; font-size: 12.5px; font-weight: 700; color: var(--vega-primary); }

/* status count tiles (clearer than near-empty bars) */
.count-tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.count-tiles.six { grid-template-columns: repeat(3, 1fr); }
.count-tile { border: 1px solid var(--vega-border); border-radius: 9px; padding: 9px 8px; text-align: center; background: #fbfbfe; }
.count-tile .ct-num { font-size: 22px; font-weight: 800; line-height: 1; color: #9aa0ad; }
.count-tile .ct-label { font-size: 11px; color: var(--vega-muted, #6b7280); margin-top: 4px; font-weight: 600; }
.count-tile.has { background: #fff; }
.count-tile.has.green  { border-color: #b6e6c5; } .count-tile.has.green  .ct-num { color: #16a34a; }
.count-tile.has.amber  { border-color: #f3dca6; } .count-tile.has.amber  .ct-num { color: #d97706; }
.count-tile.has.rose   { border-color: #f5c2cd; } .count-tile.has.rose   .ct-num { color: #e11d48; }
.count-tile.has.blue   { border-color: #b9cdf7; } .count-tile.has.blue   .ct-num { color: #2563eb; }
.count-tile.has.violet { border-color: #cdbef5; } .count-tile.has.violet .ct-num { color: #7c3aed; }

/* stock-by-warehouse item breakdown */
.wh-block { margin-bottom: 14px; }
.wh-block:last-child { margin-bottom: 0; }
.wh-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 6px; padding-bottom: 3px; border-bottom: 1px dashed var(--vega-border); }
.wh-head .wh-name { font-weight: 700; font-size: 13px; color: var(--vega-ink); }
.wh-head .wh-total { font-size: 11.5px; color: var(--vega-muted, #6b7280); font-weight: 600; }

/* repairing money monitoring strip */
.rep-money { display: flex; gap: 10px; margin-top: 12px; border-top: 1px solid var(--vega-border); padding-top: 12px; }
.rep-money-box { flex: 1; text-align: center; background: #f7f8fc; border: 1px solid var(--vega-border); border-radius: 9px; padding: 8px 6px; }
.rep-money-box span { display: block; font-size: 11px; color: var(--vega-muted, #6b7280); margin-bottom: 3px; }
.rep-money-box strong { font-size: 16px; }

.quick-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.quick-actions a { display: inline-flex; align-items: center; gap: 7px; padding: 9px 14px; border-radius: 9px; border: 1px solid var(--vega-border); background: #fff; color: var(--vega-ink); text-decoration: none; font-size: 13px; font-weight: 600; transition: all .12s ease; }
.quick-actions a:hover { background: var(--vega-primary-soft); border-color: #c7c9f5; color: var(--vega-primary); }
