:root {
  --navy:       #111111;
  --text:       #111111;
  --text-mid:   #555555;
  --text-light: #999999;
  --bg:         #f4f4f5;
  --bg-alt:     #e9e9eb;
  --white:      #ffffff;
  --border:     #e0e0e0;
  --green:      #22c55e;
  --green-bg:   #f0fdf4;
  --green-text: #166534;
  --green-bdr:  #bbf7d0;
  --red:        #ef4444;
  --red-bg:     #fef2f2;
  --red-text:   #991b1b;
  --amber:      #f59e0b;
  --radius:     10px;
  --radius-lg:  14px;
  --shadow-sm:  0 1px 3px rgba(0,0,0,.07);
  --shadow:     0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:  0 8px 40px rgba(0,0,0,.15);
  --font:       'Inter', system-ui, sans-serif;
  --sidebar-w: 220px;
  --header-h:  58px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;}

/* ══ AUTH ══════════════════════════════════════════════ */
#auth-screen {
  height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--bg);
}
.auth-card {
  background:var(--white);border:1px solid var(--border);border-radius:20px;
  padding:48px 44px 40px;width:100%;max-width:400px;text-align:center;
  box-shadow:var(--shadow);
}
.auth-logo { width:60px;height:60px;border-radius:50%;margin-bottom:20px;border:2px solid var(--border); }
.auth-card h1 { font-size:1.5rem;font-weight:800;letter-spacing:-.03em;margin-bottom:6px; }
.auth-card p  { color:var(--text-mid);font-size:.88rem;margin-bottom:28px;line-height:1.6; }
.btn-ms {
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  width:100%;padding:12px 20px;background:var(--navy);color:#fff;
  border:none;border-radius:var(--radius);font-family:var(--font);
  font-size:.92rem;font-weight:600;cursor:pointer;transition:background .18s;
}
.btn-ms:hover{background:#333;}
#auth-err {
  background:#fef2f2;border:1px solid #fecaca;border-radius:8px;
  padding:10px 14px;font-size:.74rem;color:#991b1b;margin-bottom:14px;display:none;text-align:left;
  white-space:pre-wrap;font-family:monospace;max-height:300px;overflow-y:auto;
}

/* ══ SHELL ═════════════════════════════════════════════ */
#shell { display:none;height:100vh;flex-direction:column; }

/* ── Header ── */
.shell-header {
  height:var(--header-h);background:var(--white);border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 20px;gap:14px;flex-shrink:0;
  box-shadow:var(--shadow-sm);z-index:50;position:relative;
}
.shell-brand { display:flex;align-items:center;gap:9px;text-decoration:none;flex-shrink:0; }
.shell-logo  { width:30px;height:30px;border-radius:50%;object-fit:cover; }
.shell-brand-name { font-size:.84rem;font-weight:700;color:var(--text);letter-spacing:-.01em; }
.shell-brand-sub  { font-size:.66rem;color:var(--text-light); }
.header-search {
  flex:1;max-width:340px;margin-left:auto;position:relative;
}
.header-search input {
  width:100%;border:1.5px solid var(--border);border-radius:var(--radius);
  background:var(--bg);color:var(--text);font-family:var(--font);font-size:.83rem;
  padding:7px 12px 7px 34px;outline:none;transition:border-color .18s;
}
.header-search input:focus{border-color:var(--navy);background:var(--white);}
.header-search input::placeholder{color:var(--text-light);}
.header-search svg {
  position:absolute;left:10px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;color:var(--text-light);pointer-events:none;
}
.header-actions { display:flex;align-items:center;gap:10px;margin-left:auto; }
.user-chip {
  display:flex;align-items:center;gap:7px;background:var(--bg);
  border:1px solid var(--border);border-radius:20px;padding:4px 11px 4px 7px;
  font-size:.76rem;color:var(--text-mid);
}
.user-av {
  width:22px;height:22px;background:var(--navy);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.58rem;font-weight:700;flex-shrink:0;
}
.signout-link { font-size:.72rem;color:var(--text-light);cursor:pointer;margin-left:2px; }
.signout-link:hover{color:var(--red);}

/* ── Layout ── */
.shell-body { display:flex;flex:1;overflow:hidden; }

/* ── Sidebar ── */
.sidebar {
  width:var(--sidebar-w);background:var(--white);border-right:1px solid var(--border);
  flex-shrink:0;display:flex;flex-direction:column;padding:16px 12px;gap:2px;
  overflow-y:auto;transition:width .2s,padding .2s,opacity .15s;
}
/* Collapsed sidebar — slides to zero width */
#shell.sidebar-collapsed .sidebar {
  width:0;padding:0;opacity:0;overflow:hidden;pointer-events:none;
}
/* Sidebar toggle button in header */
#sidebar-toggle {
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:7px;border:1px solid var(--border);
  background:var(--white);cursor:pointer;flex-shrink:0;color:var(--text-mid);
  transition:background .15s;margin-right:4px;
}
#sidebar-toggle:hover{background:var(--bg);}

.nav-label {
  font-size:.64rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-light);padding:10px 10px 6px;margin-top:6px;
}
.nav-section-header {
  display:flex;align-items:center;justify-content:space-between;
  font-size:.64rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-light);padding:10px 10px 6px;margin-top:6px;
  cursor:pointer;user-select:none;border-radius:6px;transition:all .15s;
}
.nav-section-header:hover{background:var(--bg);color:var(--text-mid);}
.nav-section-chevron{width:10px;height:10px;flex-shrink:0;opacity:.5;transition:transform .2s;}
.nav-item {
  display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;
  font-size:.83rem;font-weight:500;color:var(--text-mid);cursor:pointer;
  transition:all .15s;user-select:none;
}
.nav-item:hover{background:var(--bg);color:var(--text);}
.nav-item.active{background:var(--navy);color:#fff;}
.nav-item svg{width:15px;height:15px;flex-shrink:0;opacity:.7;}
.nav-item.active svg{opacity:1;}
.nav-notif-badge {
  margin-left:auto;min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  background:var(--red);color:#fff;font-size:.7rem;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
}
.sidebar-footer { margin-top:auto;padding-top:16px;border-top:1px solid var(--border); }

/* ── Nav group (collapsible Books of Accounts) ── */
.nav-group-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 10px;border-radius:8px;font-size:.83rem;font-weight:500;
  color:var(--text-mid);cursor:pointer;transition:all .15s;user-select:none;gap:6px;
}
.nav-group-header:hover{background:var(--bg);color:var(--text);}
.nav-group-header svg.nav-group-icon{width:15px;height:15px;flex-shrink:0;opacity:.7;}
.nav-group-header .nav-group-chevron{width:12px;height:12px;flex-shrink:0;opacity:.5;transition:transform .2s;margin-left:auto;}
.nav-sub-item {
  padding-left:30px;font-size:.8rem;
}
.nav-sub-item.active{background:var(--navy);color:#fff;}

/* ── Main ── */
.main-content { flex:1;overflow-y:auto;padding:28px 28px; }
.page { display:none; }
.page.active { display:block; }

/* ── Page header ── */
.page-header {
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:24px;gap:16px;flex-wrap:wrap;
}
.page-title { font-size:1.3rem;font-weight:800;letter-spacing:-.03em; }
.page-sub   { font-size:.82rem;color:var(--text-mid);margin-top:2px; }

/* ══ BUTTONS ═══════════════════════════════════════════ */
.btn {
  display:inline-flex;align-items:center;gap:7px;padding:8px 16px;
  border-radius:var(--radius);font-family:var(--font);font-size:.82rem;
  font-weight:600;cursor:pointer;border:none;transition:all .18s;
  text-decoration:none;white-space:nowrap;letter-spacing:-.01em;
}
.btn-primary { background:var(--navy);color:#fff;border:1.5px solid var(--navy); }
.btn-primary:hover{background:#333;border-color:#333;}
.btn-danger  { background:var(--red-bg);color:var(--red-text);border:1.5px solid #fecaca; }
.btn-danger:hover{background:#fee2e2;}
.btn-outline { background:transparent;color:var(--text);border:1.5px solid var(--border); }
.btn-outline:hover{border-color:#999;background:var(--bg);}
.btn-ghost   { background:transparent;color:var(--text-mid);border:none;padding:6px 10px; }
.btn-ghost:hover{background:var(--bg);color:var(--text);}
.btn-sm { padding:6px 12px;font-size:.76rem; }
.btn-icon { padding:7px;border-radius:8px; }

/* ── INLINE TABLE SPINNER ───────────────────────────── */
.tbl-spinner { display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 0;gap:14px; }
.tbl-spin-ring { width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:tbl-spin .7s linear infinite; }
.tbl-spin-label { font-size:.82rem;color:var(--text-light);font-weight:500; }
@keyframes tbl-spin { to { transform:rotate(360deg); } }

/* ── PAGINATION ─────────────────────────────────────── */
.pg-btn { min-width:34px;height:34px;padding:0 8px;border:1.5px solid var(--border);background:var(--white);color:var(--text);border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s; }
.pg-btn:hover:not(:disabled){ border-color:var(--navy);color:var(--navy);background:var(--bg); }
.pg-btn.pg-active { background:var(--navy);color:#fff;border-color:var(--navy); }
.pg-btn.pg-disabled,.pg-btn:disabled { opacity:.35;cursor:default; }
.pg-ellipsis { font-size:.82rem;color:var(--text-light);padding:0 4px;line-height:34px; }

/* ══ DASHBOARD ═════════════════════════════════════════ */
.stat-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px; }
.stat-card {
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:20px 22px;
}
.stat-label { font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-light);margin-bottom:6px; }
.stat-value { font-size:2rem;font-weight:800;letter-spacing:-.04em;line-height:1; }
.stat-sub   { font-size:.74rem;color:var(--text-mid);margin-top:4px; }
.stat-card.accent { background:var(--navy);color:#fff; }
.stat-card.accent .stat-label { color:rgba(255,255,255,.5); }
.stat-card.accent .stat-sub   { color:rgba(255,255,255,.55); }

.chart-row { display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px; }
@media(max-width:720px){.chart-row{grid-template-columns:1fr;}}
.chart-card {
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;
}
.chart-title { font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-light);margin-bottom:16px; }
.bar-row { display:flex;align-items:center;gap:10px;margin-bottom:10px; }
.bar-label { font-size:.78rem;color:var(--text-mid);width:110px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.bar-track { flex:1;height:8px;background:var(--bg-alt);border-radius:4px;overflow:hidden; }
.bar-fill  { height:100%;background:var(--navy);border-radius:4px;transition:width .5s ease; }
.bar-count { font-size:.74rem;font-weight:600;color:var(--text);width:36px;text-align:right;flex-shrink:0; }

.donut-wrap { display:flex;align-items:center;gap:20px; }
.donut-legend { flex:1; }
.legend-row { display:flex;align-items:center;gap:8px;margin-bottom:8px; }
.legend-dot { width:9px;height:9px;border-radius:50%;flex-shrink:0; }
.legend-label { font-size:.78rem;color:var(--text-mid);flex:1; }
.legend-val   { font-size:.78rem;font-weight:700;color:var(--text); }

.recent-table { width:100%;border-collapse:collapse; }
.recent-table th {
  font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--text-light);padding:0 0 10px;border-bottom:1px solid var(--border);text-align:left;
}
.recent-table td { padding:10px 0;border-bottom:1px solid var(--border);font-size:.82rem;color:var(--text-mid); }
.recent-table tr:last-child td { border-bottom:none; }
.recent-table td:first-child { color:var(--text);font-weight:600; }

/* ══ CUSTOMERS LIST ════════════════════════════════════ */
.toolbar {
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:12px 16px;margin-bottom:16px;
}
.search-wrap { position:relative;flex:1;min-width:180px;max-width:300px; }
.search-wrap input {
  width:100%;border:1.5px solid var(--border);border-radius:var(--radius);
  background:var(--bg);color:var(--text);font-family:var(--font);
  font-size:.82rem;padding:7px 12px 7px 32px;outline:none;transition:border-color .18s;
}
.search-wrap input:focus{border-color:var(--navy);background:var(--white);}
.search-wrap input::placeholder{color:var(--text-light);}
.search-wrap svg{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:var(--text-light);pointer-events:none;}
.filter-sel {
  border:1.5px solid var(--border);border-radius:var(--radius);
  background:var(--bg);color:var(--text);font-family:var(--font);
  font-size:.8rem;padding:7px 9px;outline:none;cursor:pointer;
}
.filter-sel:focus{border-color:var(--navy);}
.count-pill {
  font-size:.76rem;color:var(--text-mid);background:var(--bg);
  border:1px solid var(--border);border-radius:20px;padding:4px 11px;
  white-space:nowrap;margin-left:auto;
}
.count-pill b{color:var(--text);}

.customers-table-wrap {
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
}
table.ctable { width:100%;border-collapse:collapse; }
table.ctable thead th {
  background:var(--bg);border-bottom:1.5px solid var(--border);
  color:var(--text-light);font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;padding:9px 14px;white-space:nowrap;
  position:sticky;top:0;z-index:4;cursor:pointer;user-select:none;text-align:left;
  transition:color .15s;
}
table.ctable thead th:hover{color:var(--text);}
table.ctable thead th.sort-asc::after{content:' ↑';color:var(--navy);}
table.ctable thead th.sort-desc::after{content:' ↓';color:var(--navy);}
table.ctable thead th.th-actions {
  position:sticky;top:0;right:0;z-index:6;
  background:var(--bg);
  box-shadow:-2px 0 6px rgba(0,0,0,.06);
}
table.ctable tbody tr { border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s; }
table.ctable tbody tr:hover{background:var(--bg);}
table.ctable tbody tr:last-child{border-bottom:none;}
table.ctable tbody td { padding:10px 14px;font-size:.82rem;color:var(--text-mid);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
td.td-name{color:var(--text);font-weight:600;font-size:.84rem;}
.td-actions{
  width:70px;text-align:right;
  position:sticky;right:0;
  background:var(--white);
  box-shadow:-2px 0 6px rgba(0,0,0,.06);
  z-index:2;
}
table.ctable tbody tr:hover .td-actions { background:var(--bg); }

.tag {
  display:inline-block;font-size:.66rem;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;padding:2px 8px;border-radius:20px;border:1px solid;
}
.tag-nc   {background:var(--green-bg);color:var(--green-text);border-color:var(--green-bdr);}
.tag-trad {background:#f5f3ff;color:#5b21b6;border-color:#ddd6fe;}
.tag-pers {background:#fff7ed;color:#9a3412;border-color:#fed7aa;}
.tag-uid  {background:var(--bg);color:var(--text-light);border-color:var(--border);}

.empty-state {
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:64px 24px;gap:10px;color:var(--text-light);font-size:.86rem;
}
.empty-state svg{opacity:.25;margin-bottom:4px;}

/* ══ MODAL ══════════════════════════════════════════════ */
.modal-overlay {
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;
  display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;
}
.modal-overlay.open{display:flex;}
.modal {
  background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:620px;
  box-shadow:var(--shadow-lg);position:relative;margin:auto;
}
.modal-header {
  padding:20px 24px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.modal-title { font-size:1rem;font-weight:800;letter-spacing:-.02em; }
.modal-close {
  width:28px;height:28px;border-radius:8px;background:var(--bg);border:1px solid var(--border);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:.9rem;color:var(--text-mid);transition:all .15s;
}
.modal-close:hover{background:var(--bg-alt);color:var(--text);}
.modal-body { padding:20px 24px; }
.modal-footer {
  padding:14px 24px;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:flex-end;gap:10px;
}

/* ── Form ── */
.form-grid { display:grid;grid-template-columns:1fr 1fr;gap:14px 16px; }
.form-grid .span2 { grid-column:1/-1; }
.field { display:flex;flex-direction:column;gap:5px; }
.field label { font-size:.76rem;font-weight:600;color:var(--text-mid);letter-spacing:.01em; }
.field input,.field select,.field textarea {
  border:1.5px solid var(--border);border-radius:var(--radius);
  background:var(--white);color:var(--text);font-family:var(--font);
  font-size:.84rem;padding:8px 11px;outline:none;transition:border-color .18s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy);}
.field textarea{resize:vertical;min-height:72px;}
.form-section-title {
  grid-column:1/-1;font-size:.68rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--text-light);padding-top:6px;
  border-top:1px solid var(--border);margin-top:4px;
}
.form-section-title:first-child{border-top:none;margin-top:0;padding-top:0;}

/* ── Toast ── */
#toast {
  position:fixed;bottom:24px;right:24px;z-index:500;
  background:var(--navy);color:#fff;border-radius:10px;
  padding:12px 18px;font-size:.82rem;font-weight:500;
  box-shadow:var(--shadow-lg);display:none;align-items:center;gap:9px;
  max-width:320px;
}
#toast.show{display:flex;}
#toast.success{background:#15803d;}
#toast.error  {background:var(--red);}

/* ── Confirm dialog ── */
#confirm-overlay {
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:400;
  display:none;align-items:center;justify-content:center;
}
#confirm-overlay.open{display:flex;}
.confirm-box {
  background:var(--white);border-radius:var(--radius-lg);padding:28px 28px 22px;
  max-width:360px;width:90%;box-shadow:var(--shadow-lg);text-align:center;
}
.confirm-box h3{font-size:.98rem;font-weight:700;margin-bottom:8px;}
.confirm-box p{font-size:.84rem;color:var(--text-mid);margin-bottom:20px;line-height:1.5;}
.confirm-actions{display:flex;gap:10px;justify-content:center;}

/* ── Loading ── */
#loading-overlay {
  position:fixed;bottom:24px;right:24px;
  background:var(--white);border:1px solid var(--border);border-radius:12px;
  box-shadow:0 4px 20px rgba(0,0,0,.12);z-index:600;
  display:none;flex-direction:row;align-items:center;gap:10px;padding:10px 16px;
}
#loading-overlay.show{display:flex;}
.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;}
@keyframes spin{to{transform:rotate(360deg);}}
.loading-msg{font-size:.82rem;color:var(--text-mid);font-weight:500;white-space:nowrap;}

/* ── Version badge ── */
.version-badge {
  font-size:.7rem;font-weight:600;color:var(--text-light);
  background:var(--bg);border:1px solid var(--border);border-radius:20px;
  padding:3px 10px;letter-spacing:.02em;white-space:nowrap;flex-shrink:0;
}
.version-date { color:var(--text-light);font-weight:400; }

/* ── Settings dropdown ── */
.settings-wrap { position:relative;flex-shrink:0; }
.settings-dropdown {
  position:absolute;top:calc(100% + 8px);right:0;
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);min-width:200px;z-index:200;
  display:none;flex-direction:column;overflow:hidden;
}
.settings-dropdown.open { display:flex; }
.settings-item {
  display:flex;align-items:center;gap:9px;padding:10px 14px;
  font-size:.82rem;color:var(--text-mid);cursor:pointer;transition:background .12s;
}
.settings-item:hover:not(.no-hover) { background:var(--bg);color:var(--text); }
.settings-item.no-hover { color:var(--text-light);cursor:default;font-size:.78rem; }
.settings-divider { height:1px;background:var(--border);margin:4px 0; }
.settings-label {
  font-size:.64rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-light);padding:8px 14px 2px;
}

.si-tab {
  padding:6px 14px;border-radius:6px;font-size:.8rem;font-weight:600;
  cursor:pointer;color:var(--text-mid);transition:all .15s;
}
.si-tab:hover{color:var(--text);background:var(--white);}
.si-tab.active{background:var(--white);color:var(--text);box-shadow:var(--shadow-sm);}

/* ── Success dialog ── */
#success-overlay {
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:400;
  display:none;align-items:center;justify-content:center;
}
#success-overlay.open{display:flex;}
.success-box {
  background:var(--white);border-radius:var(--radius-lg);padding:32px 32px 24px;
  max-width:380px;width:90%;box-shadow:var(--shadow-lg);text-align:center;
}
.success-icon {
  width:52px;height:52px;background:var(--green-bg);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
}
.success-box h3{font-size:1.05rem;font-weight:800;margin-bottom:6px;color:var(--text);}
.success-box p{font-size:.84rem;color:var(--text-mid);margin-bottom:22px;line-height:1.5;}
.success-actions{display:flex;gap:10px;justify-content:center;}

/* scrollbar */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:#bbb;}



/* ── Quotation CRM cards ── */
.quot-card {
  background:var(--white);border-radius:var(--radius);padding:16px 18px;
  cursor:pointer;transition:box-shadow .15s,transform .1s;
  border:1.5px solid var(--border);
}
.quot-card:hover{box-shadow:var(--shadow);transform:translateY(-1px);}
.quot-card-value{font-size:2rem;font-weight:800;line-height:1;margin-bottom:4px;}
.quot-card-label{font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-mid);}
.quot-card-blue  .quot-card-value{color:#2563eb;}
.quot-card-red   .quot-card-value{color:#dc2626;}
.quot-card-yellow .quot-card-value{color:#d97706;}
.quot-card-green .quot-card-value{color:#16a34a;}
.quot-card-purple .quot-card-value{color:#7c3aed;}
.quot-card-orange .quot-card-value{color:#ea580c;}
.quot-card-navy  .quot-card-value{color:#0f172a;}
.quot-card-pulse{animation:quot-pulse 2s infinite;}
@keyframes quot-pulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.3);}50%{box-shadow:0 0 0 6px rgba(220,38,38,0);}}

/* ── Quotation badges ── */
.quot-badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:.72rem;font-weight:600;}
.quot-badge-pending {background:#fef9c3;color:#854d0e;}
.quot-badge-won     {background:#dcfce7;color:#166534;}
.quot-badge-overdue {background:#fee2e2;color:#991b1b;}

/* ── Quotation Request badges ── */
.qr-badge{display:inline-block;padding:2px 9px;border-radius:99px;font-size:.72rem;font-weight:600;}
.qr-badge-gray  {background:#f3f4f6;color:#374151;}
.qr-badge-yellow{background:#fef9c3;color:#854d0e;}
.qr-badge-blue  {background:#dbeafe;color:#1e40af;}
.qr-badge-green {background:#dcfce7;color:#166534;}
.qr-badge-red   {background:#fee2e2;color:#991b1b;}
.qr-badge-orange{background:#ffedd5;color:#9a3412;}
.qr-badge-teal  {background:#ccfbf1;color:#0f766e;}

/* ── QR Tabs ── */
.qr-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:14px;}
.qr-tab{background:none;border:none;cursor:pointer;padding:8px 18px;font-size:.85rem;font-weight:600;color:var(--text-mid);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:7px;}
.qr-tab:hover{color:var(--text);}
.qr-tab-active{color:var(--primary);border-bottom-color:var(--primary);}
.qr-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 6px;border-radius:99px;background:#ef4444;color:#fff;font-size:.68rem;font-weight:700;line-height:1;}

/* ── Age pill ── */
.quot-age{display:inline-block;padding:1px 7px;border-radius:99px;font-size:.72rem;font-weight:700;}
.quot-age-ok    {background:#f0f9ff;color:#0369a1;}
.quot-age-yellow{background:#fef9c3;color:#854d0e;}
.quot-age-red   {background:#fee2e2;color:#991b1b;}


/* ── Books of Accounts ── */
.books-tab {
  padding:7px 14px;border:none;border-bottom:2px solid transparent;background:none;
  font-size:.8rem;font-weight:500;color:var(--text-mid);cursor:pointer;
  transition:all .15s;white-space:nowrap;border-radius:0;
}
.books-tab:hover{color:var(--text);}
.books-tab-active{color:var(--navy);border-bottom-color:var(--navy);font-weight:600;}
.books-table {
  border-collapse:collapse;width:max-content;min-width:100%;font-size:.8rem;
}
.books-table th {
  padding:7px 10px;text-align:center;border-bottom:2px solid var(--border);
  font-size:.72rem;font-weight:600;color:var(--text-light);white-space:nowrap;
  background:var(--bg);position:sticky;top:0;
}
.books-table th:first-child { text-align:left; }
.books-table td {
  padding:5px 10px;border-bottom:1px solid var(--border);color:var(--text);
  white-space:nowrap;
}
/* Title/colspan rows must never be clipped */
.books-table td[colspan] { white-space:nowrap; overflow:visible; text-overflow:clip; max-width:none; }
/* Give the date column a right gap so it doesn't bleed into the name */
.books-table th:first-child,
.books-table td:first-child {
  padding-right:10px;
}
.books-table tbody tr:hover{background:var(--bg);}
#books-table-wrapper { overflow-x:auto; overflow-y:visible; display:block; }

/* ── Tasks Module ── */
.tasks-tab {
  background:transparent;border:none;border-bottom:2px solid transparent;
  padding:.45rem .9rem;font-size:.85rem;font-weight:500;cursor:pointer;
  color:var(--text-light);margin-bottom:-2px;transition:color .15s;
}
.tasks-tab.active { color:var(--navy);border-bottom-color:var(--navy); }
.tasks-tab:hover:not(.active) { color:var(--text); }

.form-select-sm {
  padding:5px 10px;font-size:.82rem;border:1.5px solid var(--border);
  border-radius:7px;background:var(--white);color:var(--text);cursor:pointer;
  height:32px;
}
.form-select-sm:focus { outline:none;border-color:var(--navy); }

.badge { display:inline-block;padding:2px 8px;border-radius:99px;font-size:.74rem;font-weight:600; }
.badge-outline { background:transparent;border:1px solid var(--border);color:var(--text); }

/* ── Trello-style Task Cards ── */
.trello-card {
  background:var(--white);
  border-radius:10px;
  box-shadow:0 1px 3px rgba(9,30,66,.12), 0 0 0 1px rgba(9,30,66,.06);
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:transform .15s ease, box-shadow .15s ease;
  cursor:default;
}
.trello-card:hover {
  transform:translateY(-3px);
  box-shadow:0 6px 18px rgba(9,30,66,.18), 0 0 0 1px rgba(9,30,66,.06);
}
.trello-card--pending { opacity:.78; }
.trello-card--completed { opacity:.7; }

.trello-card__label {
  height:5px;
  flex-shrink:0;
}
.trello-card__label--high     { background:#ef4444; }
.trello-card__label--overdue  { background:#dc2626; }

.trello-card__label--normal   { background:#64748b; }
.trello-card__label--low      { background:#94a3b8; }
.trello-card__label--completed { background:#16a34a; }

.trello-card__body {
  padding:12px 14px;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:5px;
}
.trello-card__badges {
  display:flex;flex-wrap:wrap;gap:4px;
}
.trello-card__title {
  font-size:.87rem;font-weight:600;color:var(--text);line-height:1.35;
  margin-top:2px;
}
.trello-card__title--done {
  text-decoration:line-through;color:var(--text-light);
}
.trello-card__desc {
  font-size:.77rem;color:var(--text-light);line-height:1.4;
}
.trello-card__notes {
  font-size:.77rem;color:var(--text-mid);font-style:italic;
  background:var(--bg);border-radius:5px;padding:4px 7px;
}
.trello-card__footer {
  margin-top:auto;padding-top:8px;
  display:flex;align-items:center;justify-content:space-between;gap:6px;
  border-top:1px solid var(--border);
}
.trello-card__meta {
  display:flex;flex-wrap:wrap;gap:4px;
}
.trello-card__action { flex-shrink:0; }
.trello-chip {
  display:inline-flex;align-items:center;gap:3px;
  font-size:.72rem;color:var(--text-light);background:var(--bg);
  border-radius:5px;padding:2px 6px;
}
.trello-chip--red   { color:#dc2626;background:#fef2f2; }
.trello-chip--green { color:#16a34a;background:#f0fdf4; }
.trello-card__awaiting {
  font-size:.74rem;color:#d97706;font-style:italic;
}

/* ── Kanban Board ── */
.kanban-board {
  display:grid;
  gap:14px;
  align-items:start;
}
.kanban-board--2col { grid-template-columns:1fr 1fr; }
.kanban-board--3col { grid-template-columns:1fr 1fr 1fr; }

.kanban-col {
  background:var(--bg);
  border-radius:10px;
  border:1px solid var(--border);
  min-height:160px;
  display:flex;
  flex-direction:column;
}
.kanban-col__header {
  padding:9px 13px 7px;
  display:flex;align-items:center;gap:7px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.kanban-col__title {
  font-size:.78rem;font-weight:700;color:var(--text);flex:1;
  text-transform:uppercase;letter-spacing:.05em;
}
.kanban-col__count {
  background:var(--navy);color:#fff;
  border-radius:99px;font-size:.68rem;font-weight:700;
  padding:1px 7px;
}
.kanban-col__count--orange { background:#f97316; }
.kanban-col__count--green  { background:#16a34a; }
.kanban-col__body {
  padding:8px;
  display:flex;flex-direction:column;gap:7px;
  flex:1;
}
.kanban-col__empty {
  text-align:center;padding:24px 14px;
  color:var(--text-light);font-size:.8rem;
}

@media (max-width:900px) {
  .kanban-board--3col { grid-template-columns:1fr; }
  .kanban-board--2col { grid-template-columns:1fr; }
}
@media (min-width:901px) and (max-width:1200px) {
  .kanban-board--3col { grid-template-columns:1fr 1fr; }
}

