/* ═══════════════════════════════════════════════
   NATIONAL LIMS — COMPLETE STYLESHEET v3.0
   Mobile-first, responsive, modern design
═══════════════════════════════════════════════ */

:root {
  --pri: #1a73e8; --pri-d: #0d47a1; --pri-l: #e3f2fd; --pri-xl: #f0f7ff;
  --grn: #43a047; --grn-d: #2e7d32; --grn-l: #e8f5e9;
  --org: #f57c00; --org-l: #fff3e0;
  --red: #e53935; --red-d: #b71c1c; --red-l: #ffebee;
  --yel: #f9a825; --yel-l: #fff8e1;
  --pur: #8e24aa; --pur-l: #f3e5f5;
  --tel: #00897b; --tel-l: #e0f2f1;
  --g50: #fafafa; --g100: #f5f5f5; --g200: #eeeeee; --g300: #e0e0e0;
  --g400: #bdbdbd; --g500: #9e9e9e; --g600: #757575; --g700: #616161;
  --g800: #424242; --g900: #212121;
  --dark: #1e2228; --white: #fff;
  --sw: 260px; --th: 60px;
  --sh-xs: 0 1px 3px rgba(0,0,0,.08);
  --sh-sm: 0 2px 8px rgba(0,0,0,.10);
  --sh-md: 0 4px 16px rgba(0,0,0,.12);
  --sh-lg: 0 8px 32px rgba(0,0,0,.18);
  --r4: 4px; --r6: 6px; --r10: 10px; --r14: 14px; --r20: 20px;
  --tr: .18s ease;
  --font: 'Segoe UI', 'Roboto', system-ui, sans-serif;
  --mono: 'Courier New', monospace;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 14px; -webkit-tap-highlight-color: transparent; scroll-behavior: smooth; }
body { font-family: var(--font); background: var(--g100); color: var(--g900); overflow-x: hidden; min-height: 100vh; }
a { text-decoration: none; color: inherit; }
input, select, textarea, button { font-family: inherit; font-size: inherit; }
button { cursor: pointer; }
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-thumb { background: var(--g300); border-radius: 10px; }

/* ── OVERLAY ── */
#overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 790; }
#overlay.show { display: block; }

/* ── SIDEBAR ── */
.sb {
  position: fixed; left: 0; top: 0; bottom: 0; width: var(--sw);
  background: var(--dark); z-index: 800; display: flex; flex-direction: column;
  transition: transform var(--tr);
}
.sb-brand {
  padding: 14px 16px; background: rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.07);
  display: flex; align-items: center; gap: 11px; flex-shrink: 0;
}
.sb-logo {
  width: 38px; height: 38px; background: var(--pri); border-radius: var(--r6);
  display: flex; align-items: center; justify-content: center; color: #fff; font-size: 18px; flex-shrink: 0;
}
.sb-brand h2 { font-size: 14px; font-weight: 700; color: #fff; line-height: 1.2; }
.sb-brand p { font-size: 10px; color: rgba(255,255,255,.4); margin-top: 1px; }
.sb-branch { padding: 8px 12px; border-bottom: 1px solid rgba(255,255,255,.06); flex-shrink: 0; }
.sb-branch select {
  width: 100%; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12);
  color: #fff; padding: 6px 28px 6px 9px; border-radius: var(--r4); font-size: 12px; font-weight: 600;
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='white' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 6px center; background-size: 16px;
}
.sb-branch select option { background: var(--dark); }
.sb-nav { flex: 1; overflow-y: auto; overflow-x: hidden; padding: 6px 0; }
.sb-nav::-webkit-scrollbar { width: 2px; }
.nav-sec-ttl {
  padding: 8px 12px 5px; font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1.2px; color: rgba(255,255,255,.28);
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer; user-select: none; margin-top: 4px;
}
.nav-sec-ttl:hover { color: rgba(255,255,255,.5); }
.nav-sec-ttl i.arr { font-size: 9px; transition: transform .25s; }
.nav-sec-ttl.open .arr { transform: rotate(180deg); }
.nav-sub { overflow: hidden; max-height: 0; transition: max-height .3s ease; }
.nav-sub.open { max-height: 800px; }
.ni {
  padding: 9px 12px 9px 16px; display: flex; align-items: center; gap: 9px;
  cursor: pointer; transition: all var(--tr); border-left: 3px solid transparent;
  color: rgba(255,255,255,.58); font-size: 12.5px; white-space: nowrap; position: relative;
}
.ni:hover { background: rgba(255,255,255,.06); color: rgba(255,255,255,.9); }
.ni.active { background: rgba(26,115,232,.2); border-left-color: var(--pri); color: #fff; font-weight: 600; }
.ni i { width: 15px; text-align: center; font-size: 12px; opacity: .7; flex-shrink: 0; }
.ni.active i, .ni:hover i { opacity: 1; }
.ni span.label { flex: 1; overflow: hidden; text-overflow: ellipsis; }
.nbadge {
  font-size: 10px; padding: 1px 5px; border-radius: 9px; font-weight: 700;
  background: var(--red); color: #fff; flex-shrink: 0;
}
.nbadge.g { background: var(--grn); }
.nbadge.b { background: var(--pri); }
.nbadge.o { background: var(--org); }
.sb-foot { padding: 10px 12px; border-top: 1px solid rgba(255,255,255,.06); flex-shrink: 0; }
.sb-foot p { font-size: 10px; color: rgba(255,255,255,.22); }

/* ── TOPBAR ── */
.tb {
  position: fixed; top: 0; left: var(--sw); right: 0; height: var(--th);
  background: #fff; border-bottom: 1px solid var(--g200);
  display: flex; align-items: center; gap: 10px; padding: 0 18px;
  z-index: 700; box-shadow: var(--sh-xs); transition: left var(--tr);
}
.tb-ham {
  background: none; border: none; font-size: 19px; color: var(--g700);
  padding: 6px; border-radius: var(--r6); transition: background var(--tr); display: none;
}
.tb-ham:hover { background: var(--g100); }
.tb-title { flex: 1; min-width: 0; }
.tb-title h1 {
  font-size: 16px; font-weight: 700; color: var(--g900);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: flex; align-items: center; gap: 7px;
}
.tb-title h1 i { color: var(--pri); font-size: 15px; }
.tb-title p { font-size: 11px; color: var(--g500); margin-top: 1px; }
.tb-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.search-box { position: relative; }
.search-box input {
  padding: 7px 10px 7px 32px; border: 1px solid var(--g300);
  border-radius: var(--r10); background: var(--g50); width: 200px;
  font-size: 13px; transition: all .2s; color: var(--g800);
}
.search-box input:focus {
  outline: none; border-color: var(--pri); background: #fff; width: 240px;
  box-shadow: 0 0 0 3px rgba(26,115,232,.08);
}
.search-box i {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  color: var(--g500); font-size: 13px; pointer-events: none;
}
.tb-ic {
  width: 34px; height: 34px; border-radius: var(--r6); background: var(--g50);
  border: 1px solid var(--g200); display: flex; align-items: center; justify-content: center;
  cursor: pointer; position: relative; font-size: 14px; color: var(--g600); transition: all var(--tr);
}
.tb-ic:hover { background: var(--g100); }
.tb-ic .dot {
  position: absolute; top: 6px; right: 6px; width: 7px; height: 7px;
  background: var(--red); border-radius: 50%; border: 2px solid #fff;
}
.usr-chip {
  display: flex; align-items: center; gap: 8px; padding: 5px 10px;
  background: var(--g50); border: 1px solid var(--g200); border-radius: var(--r10);
  cursor: pointer; transition: all var(--tr);
}
.usr-chip:hover { background: var(--g100); }
.usr-av {
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg, var(--pri), var(--pri-d));
  display: flex; align-items: center; justify-content: center; color: #fff; font-size: 12px; flex-shrink: 0;
}
.usr-chip h4 { font-size: 12px; font-weight: 600; color: var(--g900); }
.usr-chip p { font-size: 10px; color: var(--g500); }

/* ── MAIN ── */
.main {
  margin-left: var(--sw); margin-top: var(--th);
  min-height: calc(100vh - var(--th)); padding: 18px; transition: margin-left var(--tr);
}
.page { display: none; animation: fadeIn .2s ease; }
.page.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* ── PAGE HEADER ── */
.ph {
  background: linear-gradient(135deg, var(--pri), var(--pri-d));
  color: #fff; padding: 16px 20px; border-radius: var(--r14); margin-bottom: 16px;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px;
}
.ph h1 { font-size: 18px; font-weight: 700; display: flex; align-items: center; gap: 9px; }
.ph p { font-size: 11px; opacity: .8; margin-top: 2px; }
.ph-r { display: flex; gap: 7px; flex-wrap: wrap; align-items: center; }

/* ── STATUS PILLS ── */
.pills { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.pill {
  flex: 1; min-width: 130px; padding: 11px 14px; border-radius: var(--r10);
  display: flex; flex-direction: column; cursor: pointer;
  border: 2px solid transparent; transition: all var(--tr);
}
.pill:hover { transform: translateY(-2px); box-shadow: var(--sh-sm); }
.pill.sel { border-color: currentColor; transform: translateY(-2px); }
.pill-lbl { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; }
.pill-val { font-size: 22px; font-weight: 800; margin-top: 3px; }
.p-grn { background: var(--grn-l); color: var(--grn-d); }
.p-red { background: var(--red-l); color: var(--red-d); }
.p-org { background: var(--org-l); color: var(--org); }
.p-blu { background: var(--pri-l); color: var(--pri-d); }
.p-pur { background: var(--pur-l); color: var(--pur); }

/* ── CARDS ── */
.card { background: #fff; border-radius: var(--r14); border: 1px solid var(--g200); box-shadow: var(--sh-xs); overflow: hidden; }
.card + .card { margin-top: 14px; }
.card-hd {
  padding: 13px 16px; border-bottom: 1px solid var(--g200);
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px;
}
.card-hd h2 { font-size: 14px; font-weight: 700; display: flex; align-items: center; gap: 7px; color: var(--g900); }
.card-hd h2 i { color: var(--pri); }
.card-bd { padding: 16px; }
.card-ft { padding: 11px 16px; border-top: 1px solid var(--g200); background: var(--g50); }

/* ── STAT ROW ── */
.sr { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; margin-bottom: 16px; }
.sc {
  background: #fff; border-radius: var(--r10); padding: 14px;
  border: 1px solid var(--g200); box-shadow: var(--sh-xs);
  display: flex; align-items: center; gap: 12px; transition: all var(--tr);
}
.sc:hover { transform: translateY(-2px); box-shadow: var(--sh-sm); }
.si {
  width: 44px; height: 44px; border-radius: var(--r10);
  display: flex; align-items: center; justify-content: center; font-size: 19px; color: #fff; flex-shrink: 0;
}
.si-b { background: linear-gradient(135deg, var(--pri), var(--pri-d)); }
.si-g { background: linear-gradient(135deg, var(--grn), var(--grn-d)); }
.si-o { background: linear-gradient(135deg, #ff7043, #bf360c); }
.si-r { background: linear-gradient(135deg, var(--red), var(--red-d)); }
.si-p { background: linear-gradient(135deg, var(--pur), #6a1b9a); }
.si-t { background: linear-gradient(135deg, var(--tel), #00695c); }
.si-y { background: linear-gradient(135deg, #fdd835, #f57f17); }
.sc-val { font-size: 22px; font-weight: 800; color: var(--g900); line-height: 1; }
.sc-lbl { font-size: 11px; color: var(--g600); margin-top: 2px; }

/* ── TABLE ── */
.tw { overflow-x: auto; border-radius: var(--r10); border: 1px solid var(--g200); }
table { width: 100%; border-collapse: collapse; }
thead { background: var(--g50); }
th {
  padding: 10px 13px; text-align: left; font-size: 11px; font-weight: 700;
  color: var(--g600); text-transform: uppercase; letter-spacing: .4px;
  white-space: nowrap; border-bottom: 2px solid var(--g200);
}
td { padding: 9px 13px; border-bottom: 1px solid var(--g100); font-size: 13px; color: var(--g800); vertical-align: middle; }
tr:last-child td { border-bottom: none; }
tbody tr { transition: background var(--tr); }
tbody tr:hover { background: var(--g50); }
.pt-n { font-weight: 700; color: var(--g900); }
.pt-m { font-size: 11px; color: var(--g500); margin-top: 1px; }
.sid {
  display: inline-block; background: var(--dark); color: #fff;
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  padding: 2px 7px; border-radius: 3px; letter-spacing: .5px;
}
.due-red { color: var(--red); font-weight: 700; }
.row-u { background: #fff5f5 !important; }
.row-w { background: #fffde7 !important; }
.no-data { text-align: center; padding: 36px 20px; color: var(--g400); }
.no-data i { font-size: 36px; display: block; margin-bottom: 10px; }
.no-data p { font-size: 13px; }

/* ── BADGES ── */
.bg {
  display: inline-block; padding: 2px 8px; border-radius: 20px;
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .3px; white-space: nowrap;
}
.bg-pending, .bg-Rpt-Pending { background: #fff3e0; color: #e65100; }
.bg-completed, .bg-approved, .bg-enable, .bg-Enable { background: var(--grn-l); color: var(--grn-d); }
.bg-cancelled, .bg-inactive, .bg-rejected, .bg-disable, .bg-Disable { background: var(--red-l); color: var(--red-d); }
.bg-processing { background: var(--pur-l); color: var(--pur); }
.bg-confirmed { background: var(--grn-l); color: var(--grn-d); }
.bg-info { background: var(--pri-l); color: var(--pri-d); }
.bg-send-pending { background: var(--red-l); color: var(--red-d); }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; gap: 6px; padding: 7px 15px;
  border-radius: var(--r6); border: none; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all var(--tr); white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--sh-sm); }
.btn-p { background: var(--pri); color: #fff; } .btn-p:hover { background: var(--pri-d); }
.btn-s { background: var(--grn); color: #fff; } .btn-s:hover { background: var(--grn-d); }
.btn-d { background: var(--red); color: #fff; } .btn-d:hover { background: var(--red-d); }
.btn-w { background: var(--org); color: #fff; } .btn-w:hover { background: #e64a19; }
.btn-sec { background: #fff; color: var(--g700); border: 1px solid var(--g300); } .btn-sec:hover { background: var(--g100); }
.btn-dk { background: var(--dark); color: #fff; }
.btn-sm { padding: 5px 10px; font-size: 12px; }
.btn-lg { padding: 11px 22px; font-size: 14px; }
.ic-btn {
  width: 30px; height: 30px; padding: 0; border-radius: var(--r6);
  border: 1px solid var(--g300); background: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; color: var(--g600); cursor: pointer; transition: all var(--tr);
}
.ic-btn:hover { background: var(--g100); transform: translateY(-1px); }
.ic-btn.vi { color: var(--pri); border-color: var(--pri-l); }
.ic-btn.ed { color: var(--org); border-color: var(--org-l); }
.ic-btn.dl { color: var(--red); border-color: var(--red-l); }
.ic-btn.wa { color: #25d366; border-color: #dcf8c6; }
.ic-btn.pr { color: var(--g700); }
.ic-btn.em { color: var(--pur); border-color: var(--pur-l); }
.ic-btn.ap { color: var(--grn); border-color: var(--grn-l); }
.act-row { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.toggle-btn {
  padding: 3px 10px; border-radius: 20px; font-size: 10px; font-weight: 700;
  border: none; cursor: pointer; text-transform: uppercase;
}
.toggle-on { background: var(--grn-l); color: var(--grn-d); }
.toggle-off { background: var(--red-l); color: var(--red-d); }

/* ── FORMS ── */
.fg { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 13px; }
.fg2 { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; }
.fg3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 13px; }
.sp2 { grid-column: 1 / -1; }
.fm { display: flex; flex-direction: column; gap: 4px; }
.fm label { font-size: 11px; font-weight: 700; color: var(--g700); }
.req { color: var(--red); }
.fc {
  padding: 8px 11px; border: 1px solid var(--g300); border-radius: var(--r6);
  font-size: 13px; transition: border .2s, box-shadow .2s; background: #fff; color: var(--g900); width: 100%;
}
.fc:focus { outline: none; border-color: var(--pri); box-shadow: 0 0 0 3px rgba(26,115,232,.07); }
.fc:read-only { background: var(--g50); color: var(--g600); }
textarea.fc { min-height: 70px; resize: vertical; }
select.fc {
  appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23757575'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 9px center; background-size: 16px; padding-right: 30px;
}
.fm-hint { font-size: 11px; color: var(--g500); }
.inp-grp { display: flex; }
.inp-grp .fc { border-radius: var(--r6) 0 0 var(--r6); flex: 1; min-width: 0; }
.inp-grp .btn { border-radius: 0 var(--r6) var(--r6) 0; flex-shrink: 0; }
.inv-dropdown {
  position: absolute; z-index: 200; width: 100%; max-height: 220px; overflow-y: auto;
  background: #fff; border: 1px solid var(--g300); border-top: none;
  border-radius: 0 0 var(--r6) var(--r6); box-shadow: var(--sh-md); display: none;
}
.inv-dropdown-item { padding: 9px 12px; cursor: pointer; border-bottom: 1px solid var(--g100); font-size: 13px; }
.inv-dropdown-item:hover { background: var(--pri-xl); }
.inv-dropdown-item b { display: block; color: var(--g900); }
.inv-dropdown-item small { color: var(--g500); font-size: 11px; }
.inv-dropdown-item .price { float: right; color: var(--pri); font-weight: 700; }

/* ── FILTER BAR ── */
.fb {
  background: var(--g50); border-bottom: 1px solid var(--g200);
  padding: 12px 16px; display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-end;
}
.ff { display: flex; flex-direction: column; gap: 3px; min-width: 140px; }
.ff label { font-size: 10px; font-weight: 700; color: var(--g600); text-transform: uppercase; letter-spacing: .4px; }
.ff input, .ff select {
  padding: 7px 9px; border: 1px solid var(--g300); border-radius: var(--r6);
  font-size: 13px; background: #fff; transition: border .2s; color: var(--g900);
}
.ff input:focus, .ff select:focus { outline: none; border-color: var(--pri); }
.ff select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23757575'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 7px center; background-size: 14px; padding-right: 26px; cursor: pointer;
}
.fb-acts { display: flex; gap: 7px; align-items: flex-end; }

/* ── PAGINATION ── */
.pagi {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; background: var(--g50); border-top: 1px solid var(--g200); flex-wrap: wrap; gap: 7px;
}
.pagi-info { font-size: 12px; color: var(--g600); }
.pagi-btns { display: flex; gap: 3px; align-items: center; }
.pb {
  padding: 4px 9px; border: 1px solid var(--g300); border-radius: var(--r4);
  background: #fff; color: var(--g700); font-size: 11px; font-weight: 600; cursor: pointer; transition: all var(--tr);
}
.pb:hover:not(:disabled) { background: var(--g100); }
.pb.act { background: var(--pri); color: #fff; border-color: var(--pri); }
.pb:disabled { opacity: .4; cursor: not-allowed; }
.per-page { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--g600); }
.per-page select {
  padding: 3px 18px 3px 7px; border: 1px solid var(--g300); border-radius: 3px; font-size: 12px; background: #fff;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23757575'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 3px center; background-size: 12px;
}

/* ── MODAL ── */
.mo {
  position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 1100;
  display: none; align-items: center; justify-content: center; padding: 14px;
}
.mo.open { display: flex; }
.md {
  background: #fff; border-radius: var(--r14); width: 100%; max-width: 560px;
  max-height: 92vh; overflow-y: auto; box-shadow: var(--sh-lg); animation: mdIn .2s ease;
}
.md.lg { max-width: 860px; }
.md.xl { max-width: 1050px; }
.md.sm { max-width: 420px; }
@keyframes mdIn { from { opacity: 0; transform: translateY(-12px) scale(.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
.md-hd {
  padding: 15px 18px; border-bottom: 1px solid var(--g200);
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; background: #fff; z-index: 1;
}
.md-hd h3 { font-size: 15px; font-weight: 700; display: flex; align-items: center; gap: 8px; color: var(--g900); }
.md-hd h3 i { color: var(--pri); }
.md-cl {
  background: none; border: none; font-size: 18px; color: var(--g500);
  width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  transition: all var(--tr);
}
.md-cl:hover { background: var(--g100); color: var(--g900); }
.md-bd { padding: 18px; }
.md-ft {
  padding: 12px 18px; border-top: 1px solid var(--g200);
  display: flex; gap: 9px; justify-content: flex-end; background: var(--g50);
  position: sticky; bottom: 0;
}

/* ── TABS ── */
.tabs { display: flex; border-bottom: 2px solid var(--g200); margin-bottom: 16px; overflow-x: auto; }
.tabs::-webkit-scrollbar { height: 0; }
.tab {
  padding: 9px 16px; font-size: 13px; font-weight: 600; color: var(--g600);
  cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px;
  white-space: nowrap; transition: all var(--tr);
}
.tab:hover { color: var(--pri); }
.tab.active { color: var(--pri); border-bottom-color: var(--pri); }
.tp { display: none; }
.tp.active { display: block; }

/* ── TOAST ── */
#toast-wrap {
  position: fixed; top: 12px; right: 12px; z-index: 9999;
  display: flex; flex-direction: column; gap: 7px; pointer-events: none;
}
.toast {
  padding: 11px 16px; border-radius: var(--r10); color: #fff; font-size: 13px; font-weight: 500;
  display: flex; align-items: center; gap: 9px; box-shadow: var(--sh-md);
  min-width: 240px; max-width: 360px; pointer-events: all;
  animation: toastIn .3s ease;
}
@keyframes toastIn { from { transform: translateX(110%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.toast-cl { background: none; border: none; color: rgba(255,255,255,.7); font-size: 15px; margin-left: auto; cursor: pointer; }
.t-s { background: #2e7d32; } .t-e { background: var(--red-d); }
.t-i { background: #1565c0; } .t-w { background: #e65100; }

/* ── ALERT ── */
.al {
  padding: 11px 14px; border-radius: var(--r10); margin-bottom: 12px;
  display: flex; align-items: flex-start; gap: 9px; font-size: 13px;
}
.al i { margin-top: 1px; flex-shrink: 0; }
.al-d { background: var(--red-l); color: var(--red-d); border: 1px solid rgba(229,57,53,.2); }
.al-s { background: var(--grn-l); color: var(--grn-d); border: 1px solid rgba(67,160,71,.2); }
.al-i { background: var(--pri-l); color: var(--pri-d); border: 1px solid rgba(26,115,232,.2); }
.al-w { background: var(--yel-l); color: #e65100; border: 1px solid rgba(245,124,0,.2); }

/* ── SECTION TITLE ── */
.stl {
  font-size: 13px; font-weight: 700; color: var(--g900);
  display: flex; align-items: center; gap: 7px;
  padding-bottom: 9px; border-bottom: 2px solid var(--g200); margin-bottom: 12px;
}
.stl i { color: var(--pri); }

/* ── WIDGET GRID ── */
.wg { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 14px; margin-top: 14px; }
.wid { background: #fff; border-radius: var(--r10); border: 1px solid var(--g200); overflow: hidden; }
.wid-hd {
  padding: 11px 14px; border-bottom: 1px solid var(--g200);
  display: flex; align-items: center; justify-content: space-between;
}
.wid-hd h3 { font-size: 12px; font-weight: 700; display: flex; align-items: center; gap: 6px; color: var(--g900); }
.wr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 14px; border-bottom: 1px solid var(--g100); font-size: 13px; transition: background var(--tr);
}
.wr:hover { background: var(--g50); }
.wr:last-child { border-bottom: none; }
.wr-l { display: flex; align-items: center; gap: 7px; color: var(--g700); }
.dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.dot-b { background: var(--pri); } .dot-g { background: var(--grn); }
.dot-o { background: var(--org); } .dot-r { background: var(--red); }

/* ── FINANCIAL ── */
.fin { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; }
.fc2 { background: var(--g50); border: 1px solid var(--g200); border-radius: var(--r10); padding: 14px; }
.fc2 h4 { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; color: var(--g600); margin-bottom: 6px; }
.fv { font-size: 22px; font-weight: 800; color: var(--g900); margin-bottom: 8px; }
.fr { display: flex; justify-content: space-between; font-size: 12px; color: var(--g700); padding: 2px 0; }
.fr.ft { font-weight: 700; color: var(--g900); border-top: 1px solid var(--g300); padding-top: 6px; margin-top: 4px; }

/* ── WORK ORDER ── */
.wo-layout { display: grid; grid-template-columns: 1fr 300px; gap: 16px; margin-top: 14px; }
.wo-sum { background: var(--g50); border: 1px solid var(--g200); border-radius: var(--r10); padding: 14px; }
.wo-sum-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 9px; font-size: 13px; }
.wo-sum-row label { color: var(--g700); font-weight: 600; }
.wo-sum-row.tot { font-size: 15px; padding-top: 9px; border-top: 2px solid var(--g300); color: var(--pri); margin-bottom: 0; }
.wo-sum-row.tot span { color: var(--pri); font-weight: 800; }
.wo-num { width: 90px; padding: 5px 7px; border: 1px solid var(--g300); border-radius: var(--r4); font-size: 13px; font-weight: 700; text-align: right; }
.wo-tests th { background: var(--g50); font-size: 10px; padding: 7px 9px; border: 1px solid var(--g200); color: var(--g600); text-transform: uppercase; }
.wo-tests td { padding: 7px 9px; border: 1px solid var(--g100); font-size: 13px; }

/* ── INVOICE ── */
.inv { padding: 22px; font-size: 13px; line-height: 1.6; }
.inv-hd { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 2px solid var(--g200); }
.inv-hd h1 { font-size: 20px; font-weight: 800; color: var(--pri); }
.inv-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 18px; }
.inv-meta h3 { font-size: 10px; font-weight: 700; color: var(--g500); text-transform: uppercase; margin-bottom: 5px; }
.inv-row { display: flex; justify-content: flex-end; gap: 36px; font-size: 13px; padding: 3px 0; }
.inv-row.grand { font-size: 15px; font-weight: 800; color: var(--pri); border-top: 1px solid var(--g200); padding-top: 7px; margin-top: 3px; }
.inv-bc { font-size: 18px; font-weight: 900; letter-spacing: 3px; color: var(--dark); font-family: var(--mono); }
.inv-ft { margin-top: 20px; padding-top: 14px; border-top: 1px solid var(--g200); text-align: center; font-size: 11px; color: var(--g500); }

/* ── IMPORT ZONE ── */
.iz {
  border: 2px dashed var(--g300); border-radius: var(--r10); padding: 30px;
  text-align: center; cursor: pointer; transition: all var(--tr); background: var(--g50);
}
.iz:hover, .iz.drag { border-color: var(--pri); background: var(--pri-xl); }
.iz i { font-size: 32px; color: var(--g400); margin-bottom: 10px; display: block; }
.iz p { font-size: 13px; font-weight: 600; color: var(--g700); }
.iz small { font-size: 11px; color: var(--g500); }

/* ── AVATAR ── */
.av {
  width: 36px; height: 36px; border-radius: 50%; background: var(--g200);
  display: flex; align-items: center; justify-content: center; font-size: 13px; color: var(--g600); flex-shrink: 0;
}
.av.m { background: #e3f2fd; color: #1565c0; }
.av.f { background: #fce4ec; color: #880e4f; }

/* ── SETTINGS ── */
.set-grid { display: grid; grid-template-columns: 220px 1fr; gap: 18px; align-items: start; }
.set-nav { list-style: none; }
.set-nav li {
  padding: 9px 12px; border-radius: var(--r6); cursor: pointer; font-size: 13px;
  font-weight: 600; color: var(--g700); transition: all var(--tr);
  display: flex; align-items: center; gap: 7px; margin-bottom: 2px;
}
.set-nav li:hover { background: var(--g100); }
.set-nav li.act { background: var(--pri-l); color: var(--pri-d); }
.set-nav li i { width: 14px; text-align: center; }
.set-sec { display: none; }
.set-sec.act { display: block; }

/* ── PATIENT PORTAL ── */
#ptPortal {
  position: fixed; inset: 0; z-index: 9800; display: none; flex-direction: column;
  background: linear-gradient(135deg, #1b5e20, #388e3c 50%, var(--tel));
}
#ptPortal.show { display: flex; }
.pp-top {
  background: rgba(0,0,0,.2); padding: 12px 18px;
  display: flex; align-items: center; justify-content: space-between; color: #fff; flex-shrink: 0;
}
.pp-top h2 { font-size: 17px; font-weight: 700; display: flex; align-items: center; gap: 9px; }
.pp-body { flex: 1; overflow-y: auto; padding: 16px; max-width: 900px; margin: 0 auto; width: 100%; }
.pp-card { background: #fff; border-radius: var(--r14); padding: 18px; margin-bottom: 14px; box-shadow: var(--sh-md); }
.pp-card h3 { font-size: 14px; font-weight: 700; color: var(--g900); margin-bottom: 12px; display: flex; align-items: center; gap: 7px; }
.pp-card h3 i { color: var(--grn); }
.pp-sg { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 10px; margin-bottom: 14px; }
.pp-s { background: var(--grn-l); border-radius: var(--r10); padding: 14px; text-align: center; }
.pp-s .v { font-size: 22px; font-weight: 800; color: var(--grn-d); }
.pp-s .l { font-size: 10px; color: var(--grn); font-weight: 700; text-transform: uppercase; margin-top: 2px; }
.pp-rpt-row { padding: 12px 14px; border-bottom: 1px solid var(--g100); cursor: pointer; transition: background var(--tr); }
.pp-rpt-row:hover { background: var(--g50); }
.pp-rpt-row h4 { font-size: 13px; font-weight: 700; color: var(--g900); }
.pp-rpt-row p { font-size: 11px; color: var(--g500); margin-top: 2px; }

/* ── LOGIN ── */
#loginScreen {
  position: fixed; inset: 0; z-index: 9900; display: flex;
  background: linear-gradient(135deg, var(--pri-d) 0%, var(--pri) 55%, var(--grn) 100%);
}
#loginScreen.hidden { display: none; }
.li-left { flex: 1.2; padding: 44px; color: #fff; display: flex; flex-direction: column; justify-content: center; }
.li-logo { display: flex; align-items: center; gap: 16px; margin-bottom: 36px; }
.li-logo .icon {
  width: 56px; height: 56px; background: rgba(255,255,255,.15); border-radius: var(--r14);
  display: flex; align-items: center; justify-content: center; font-size: 26px; flex-shrink: 0;
}
.li-logo h1 { font-size: 32px; font-weight: 800; line-height: 1.1; }
.li-logo p { font-size: 13px; opacity: .8; margin-top: 2px; }
.li-feat { list-style: none; margin-top: 28px; display: flex; flex-direction: column; gap: 14px; }
.li-feat li { display: flex; align-items: center; gap: 12px; font-size: 14px; opacity: .9; }
.li-feat li .fi {
  width: 30px; height: 30px; background: rgba(255,255,255,.15); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0;
}
.li-right {
  width: 440px; background: #fff; display: flex; flex-direction: column; justify-content: center;
  padding: 44px 40px; box-shadow: -20px 0 60px rgba(0,0,0,.2); overflow-y: auto;
}
.li-right h2 { font-size: 24px; font-weight: 700; color: var(--g900); margin-bottom: 4px; }
.li-right > p { color: var(--g600); font-size: 13px; margin-bottom: 24px; }
.li-toggle { display: flex; border: 1px solid var(--g300); border-radius: var(--r6); overflow: hidden; margin-bottom: 22px; }
.li-tbtn { flex: 1; padding: 8px; background: #fff; border: none; font-size: 12px; font-weight: 700; color: var(--g600); cursor: pointer; transition: all var(--tr); }
.li-tbtn.act { background: var(--pri); color: #fff; }
.li-fw { display: none; }
.li-fw.act { display: block; }
.lif { position: relative; margin-bottom: 16px; }
.lif label { display: block; font-size: 11px; font-weight: 700; color: var(--g700); margin-bottom: 5px; }
.lif .li-lead { position: absolute; left: 12px; bottom: 10px; color: var(--g500); font-size: 15px; pointer-events: none; }
.lif input {
  width: 100%; padding: 11px 12px 11px 40px; border: 2px solid var(--g300);
  border-radius: var(--r10); font-size: 14px; transition: border .2s, box-shadow .2s; color: var(--g900);
}
.lif input:focus { outline: none; border-color: var(--pri); box-shadow: 0 0 0 4px rgba(26,115,232,.08); }
.eye-btn { position: absolute; right: 11px; bottom: 8px; background: none; border: none; color: var(--g500); cursor: pointer; font-size: 15px; padding: 4px; }
.li-btn {
  width: 100%; padding: 12px; background: linear-gradient(135deg, var(--pri), var(--pri-d));
  color: #fff; border: none; border-radius: var(--r10); font-size: 14px; font-weight: 700;
  cursor: pointer; transition: all .25s; display: flex; align-items: center; justify-content: center; gap: 9px; margin-top: 6px;
}
.li-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(26,115,232,.35); }
.li-btn.grn { background: linear-gradient(135deg, var(--grn-d), var(--grn)); }
.li-btn.grn:hover { box-shadow: 0 8px 24px rgba(67,160,71,.35); }
.li-err {
  display: none; background: var(--red-l); color: var(--red-d);
  padding: 10px 13px; border-radius: var(--r6); margin-bottom: 14px; font-size: 13px;
  align-items: center; gap: 7px;
}
.li-err.show { display: flex; }
.demo-b { background: var(--g50); border: 1px solid var(--g200); border-radius: var(--r10); padding: 12px; margin-top: 18px; }
.demo-b h4 { font-size: 11px; font-weight: 700; color: var(--g700); margin-bottom: 6px; display: flex; align-items: center; gap: 5px; }
.demo-b p { font-size: 11px; color: var(--g600); margin: 3px 0; }
.demo-b code { background: var(--g200); padding: 1px 5px; border-radius: 2px; font-family: var(--mono); }

/* ── MISC ── */
.dvd { border: none; border-top: 1px solid var(--g200); margin: 14px 0; }
.w-100 { width: 100%; }
.d-flex { display: flex; }
.gap-8 { gap: 8px; }
.gap-12 { gap: 12px; }
.align-center { align-items: center; }
.justify-between { justify-content: space-between; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mb-3 { margin-bottom: 12px; }
.text-right { text-align: right; }
.text-center { text-align: center; }
.text-red { color: var(--red); }
.text-grn { color: var(--grn); }
.text-pri { color: var(--pri); }
.fw-700 { font-weight: 700; }
.fs-11 { font-size: 11px; }
.fs-12 { font-size: 12px; }
.hidden { display: none !important; }

/* ── PRINT ── */
@media print {
  .sb, .tb, .fb, .pagi, .ph-r, #toast-wrap, .act-row, .btn, .mo { display: none !important; }
  .main { margin: 0 !important; padding: 0 !important; }
  .page { display: block !important; }
  body { background: #fff; }
  .tw { border: none; border-radius: 0; }
}

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .sb { transform: translateX(-100%); }
  .sb.open { transform: translateX(0); }
  .tb { left: 0; }
  .main { margin-left: 0; }
  .tb-ham { display: flex; }
}
@media (max-width: 860px) {
  .wo-layout { grid-template-columns: 1fr; }
  .set-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .main { padding: 10px; }
  .search-box input { width: 130px; }
  .search-box input:focus { width: 170px; }
  .usr-chip h4, .usr-chip p { display: none; }
  .li-left { display: none; }
  .li-right { width: 100%; padding: 28px 20px; }
  .sr { grid-template-columns: repeat(2, 1fr); }
  .fg { grid-template-columns: 1fr; }
  .fg2, .fg3 { grid-template-columns: 1fr; }
  .fin { grid-template-columns: 1fr 1fr; }
  .ph { flex-direction: column; align-items: flex-start; }
  .pagi { flex-direction: column; align-items: flex-start; }
  table { min-width: 560px; }
  .pills { flex-wrap: wrap; }
  .pill { min-width: calc(50% - 5px); }
  .inv-meta { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .sr { grid-template-columns: 1fr; }
  .fin { grid-template-columns: 1fr; }
  .pill { min-width: 100%; }
  .wg { grid-template-columns: 1fr; }
}
