/* =====================================================
 * style.css — single consolidated stylesheet
 * Replaces books.css + schedules.css + components.css.
 * Page-specific overrides scoped via body.page-* classes.
 * ===================================================== */

/* ── books.css ───────────────────────────────────────── */
/* ============================================================
 * books_invoices.css — Pending Receivables Dashboard
 * ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg:        #f5f3ef;
  --surface:   #ffffff;
  --surface2:  #f9f8f6;
  --border:    #e2ddd6;
  --border2:   #ccc7be;
  --accent:    #c47f17;
  --accent2:   #b94520;
  --text:      #1a1814;
  --muted:     #8a8070;
  --green:     #1a7a52;
  --green-bg:  #eaf5ef;
  --blue:      #1e5fa3;
  --blue-bg:   #eaf1fb;
  --red:       #b83030;
  --red-bg:    #fbecec;
  --amber:     #c47f17;
  --amber-bg:  #fdf3e0;
  --orange:    #c45c17;
  --orange-bg: #fdeee0;
  --radius:    10px;
  --font-head: 'Syne', sans-serif;
  --font-mono: 'DM Mono', monospace;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow:    0 4px 12px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.05);
}
html { font-size: 15px; }
body { background: var(--bg); color: var(--text); font-family: var(--font-mono); min-height: 100vh; }

/* ── Header ── */
.header {
  background: var(--surface); border-bottom: 1px solid var(--border);
  padding: 16px 32px; display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 100; box-shadow: var(--shadow-sm);
}
.header-left { display: flex; align-items: center; gap: 14px; }
.logo-badge {
  width: 40px; height: 40px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head); font-weight: 800; font-size: 16px; color: #fff;
  letter-spacing: -1px; box-shadow: 0 2px 8px rgba(196,127,23,0.35);
}
.header-title { font-family: var(--font-head); font-size: 1.1rem; font-weight: 700; }
.header-sub   { font-size: 0.72rem; color: var(--muted); margin-top: 1px; }
.header-right { display: flex; align-items: center; gap: 10px; }
.sync-info {
  font-size: 0.7rem; color: var(--muted);
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 20px; padding: 5px 12px;
}
.sync-info span { color: var(--text); font-weight: 500; }
.live-badge {
  display: flex; align-items: center; gap: 6px;
  background: var(--green-bg); border: 1px solid rgba(26,122,82,0.2);
  border-radius: 20px; padding: 5px 12px;
  font-size: 0.72rem; color: var(--green); letter-spacing: 0.05em;
}
.live-dot { width: 6px; height: 6px; background: var(--green); border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:.35} }

/* ── Main ── */
.main { padding: 24px 32px; max-width: 1280px; margin: 0 auto; }

/* ── KPI cards ── */
.kpi-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 14px; margin-bottom: 22px;
}
.kpi-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 20px;
  box-shadow: var(--shadow-sm); position: relative; overflow: hidden;
}
.kpi-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; }
.kpi-card.kpi-total::before   { background: var(--blue); }
.kpi-card.kpi-amount::before  { background: var(--green); }
.kpi-card.kpi-pending::before { background: var(--amber); }
.kpi-card.kpi-overdue::before { background: var(--red); }
.kpi-label { font-size:.65rem; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; margin-bottom:8px; }
.kpi-value {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  line-height: 1;
  font-feature-settings: "tnum" 1;
  font-variant-numeric: tabular-nums;
}
.kpi-value.blue  { color: var(--blue); }
.kpi-value.green { color: var(--green); }
.kpi-value.amber { color: var(--amber); }
.kpi-value.red   { color: var(--red); }
.kpi-sub { font-size:.68rem; color:var(--muted); margin-top:5px; }

/* ── Filter Panel ── */
.filter-panel {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 22px; margin-bottom: 20px;
  display: flex; flex-wrap: wrap; gap: 14px; align-items: flex-end;
  box-shadow: var(--shadow-sm);
}
.filter-group { display:flex; flex-direction:column; gap:5px; }
.filter-label { font-size:.65rem; color:var(--muted); letter-spacing:.1em; text-transform:uppercase; font-weight:500; }
.filter-select, .filter-input {
  background: var(--surface2); border: 1px solid var(--border); border-radius: 6px;
  color: var(--text); font-family: var(--font-mono); font-size: .84rem;
  padding: 8px 11px; outline: none; transition: border-color .2s, box-shadow .2s;
}
.filter-select { cursor:pointer; min-width:170px; }
.filter-input  { min-width:210px; }
.filter-select:focus, .filter-input:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px rgba(196,127,23,.12);
}
/* Sort pair — two selects side by side */
.sort-pair { display:flex; gap:6px; }
.sort-pair .filter-select.col { min-width:160px; }
.sort-pair .filter-select.dir { min-width:110px; }

/* Checkbox */
.filter-check-group { display:flex; align-items:center; gap:7px; padding-bottom:2px; }
.filter-check-group input[type=checkbox] { accent-color:var(--red); width:15px; height:15px; cursor:pointer; }
.filter-check-group label { font-size:.8rem; color:var(--muted); cursor:pointer; }

/* Buttons */
.btn-group { display:flex; gap:9px; align-items:center; flex-wrap:wrap; margin-left:auto; }
.btn-filter {
  background: linear-gradient(135deg,var(--accent),var(--accent2));
  border:none; border-radius:6px; color:#fff; cursor:pointer;
  font-family:var(--font-head); font-size:.84rem; font-weight:700;
  letter-spacing:.04em; padding:8px 22px;
  box-shadow:0 2px 8px rgba(196,127,23,.28);
  transition:opacity .2s, transform .1s;
}
.btn-filter:hover  { opacity:.9; }
.btn-filter:active { transform:scale(.97); }
.btn-filter:disabled { opacity:.45; cursor:not-allowed; }

.btn-reset {
  background:transparent; border:1px solid var(--border2); border-radius:6px;
  color:var(--muted); cursor:pointer; font-family:var(--font-mono); font-size:.8rem;
  padding:8px 14px; transition:border-color .2s,color .2s,background .2s;
}
.btn-reset:hover { border-color:var(--muted); color:var(--text); background:var(--surface2); }

.btn-download {
  background:var(--surface); border:1px solid var(--green); border-radius:6px;
  color:var(--green); cursor:pointer; font-family:var(--font-head); font-size:.84rem;
  font-weight:700; padding:8px 18px; transition:background .2s, box-shadow .2s;
  display:flex; align-items:center; gap:6px;
}
.btn-download:hover { background:var(--green-bg); box-shadow:0 2px 8px rgba(26,122,82,.15); }
.btn-download:disabled { opacity:.45; cursor:not-allowed; }

/* ── Table wrap ── */
.table-wrap {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  position:relative;
}
.table-header {
  padding:14px 20px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px;
}
.table-title { font-family:var(--font-head); font-size:.95rem; font-weight:700; }
.table-meta  { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.badge {
  font-size:.7rem; padding:3px 10px; border-radius:20px;
  border:1px solid; font-family:var(--font-mono); white-space:nowrap;
}
.badge-neutral { color:var(--muted);  background:var(--surface2); border-color:var(--border); }
.badge-overdue { color:var(--red);    background:var(--red-bg);   border-color:rgba(184,48,48,.2); }
.badge-total   { color:var(--green);  background:var(--green-bg); border-color:rgba(26,122,82,.2); }

/* ── Row colour legend ── */
.legend {
  display:flex; align-items:center; gap:18px;
  padding:9px 20px; border-bottom:1px solid var(--border);
  background:var(--surface2); font-size:.7rem; color:var(--muted);
  flex-wrap:wrap;
}
.legend strong { color:var(--text); font-weight:600; margin-right:4px; }
.legend-item { display:flex; align-items:center; gap:6px; }
.legend-swatch {
  width:28px; height:12px; border-radius:3px; flex-shrink:0;
}
.legend-swatch.green  { background:rgba(26,122,82,.15);  border:1px solid rgba(26,122,82,.35); }
.legend-swatch.orange { background:rgba(196,92,23,.15);  border:1px solid rgba(196,92,23,.35); }
.legend-swatch.red    { background:rgba(184,48,48,.15);  border:1px solid rgba(184,48,48,.35); }
.legend-swatch.none   { background:var(--surface); border:1px solid var(--border); }

/* ── Table ── */
.table-scroll { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:.81rem; }
thead th {
  background:var(--surface2); color:var(--muted);
  font-size:.63rem; letter-spacing:.1em; text-transform:uppercase;
  padding:10px 14px; text-align:left; white-space:nowrap;
  border-bottom:1px solid var(--border); font-weight:500;
}
thead th.right { text-align:right; }

/* ── Row colour coding ── */
tbody tr { border-bottom:1px solid var(--border); transition:filter .1s; }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { filter:brightness(.96); }

tbody tr.row-green  { background:rgba(26,122,82,.2); }
tbody tr.row-orange { background:rgba(196,92,23,.2); }
tbody tr.row-red    { background:rgba(184,48,48,.2); }

tbody td { padding:11px 14px; vertical-align:middle; color:var(--text); }

.td-date     { white-space:nowrap; font-size:.78rem; }
.td-sub      { font-size:.68rem; color:var(--muted); margin-top:2px; }
.td-customer { font-family:var(--font-head); font-weight:700; font-size:.87rem; }
.td-invno    { font-size:.78rem; white-space:nowrap; }
.td-branch   { font-size:.82rem; }
.brand-pill {
  display:inline-block; font-size:.68rem; padding:2px 8px; border-radius:4px;
  background:rgba(30,95,163,.09); color:var(--blue);
  border:1px solid rgba(30,95,163,.15); white-space:nowrap;
}
.td-amount  { text-align:right; white-space:nowrap; font-weight:600; }
.td-pending { text-align:right; white-space:nowrap; font-weight:700; }
.td-days    { text-align:right; white-space:nowrap; font-weight:600; }

/* ── Totals footer ── */
tfoot td {
  padding:11px 14px; font-weight:700; font-size:.82rem;
  border-top:2px solid var(--border); background:var(--surface2); white-space:nowrap;
}
tfoot .tfoot-label   { font-family:var(--font-head); font-size:.78rem; color:var(--muted); }
tfoot .tfoot-amount  { text-align:right; }
tfoot .tfoot-pending { text-align:right; }

/* ── Pagination ── */
.pagination {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 20px 4px; flex-wrap:wrap; gap:10px;
}
.pagination-info { font-size:.75rem; color:var(--muted); }
.pagination-controls { display:flex; align-items:center; gap:6px; }
.btn-page {
  background:var(--surface); border:1px solid var(--border2); border-radius:6px;
  color:var(--text); cursor:pointer; font-family:var(--font-head); font-weight:700;
  font-size:.8rem; padding:7px 16px;
  transition:background .15s, border-color .15s, box-shadow .15s;
  white-space:nowrap;
}
.btn-page:hover:not(:disabled) { background:var(--amber-bg); border-color:var(--accent); box-shadow:0 2px 8px rgba(196,127,23,.15); }
.btn-page:disabled { opacity:.32; cursor:not-allowed; }
.btn-page.active { background:var(--accent); border-color:var(--accent); color:#fff; box-shadow:0 2px 8px rgba(196,127,23,.28); }
.page-info { font-size:.78rem; color:var(--muted); padding:0 6px; }

/* ── Loading ── */
.loading-overlay {
  display:none; position:absolute; inset:0;
  background:rgba(245,243,239,.82); border-radius:var(--radius);
  z-index:10; align-items:center; justify-content:center;
  flex-direction:column; gap:12px; backdrop-filter:blur(2px);
}
.loading-overlay.active { display:flex; }
.spinner {
  width:28px; height:28px; border:2.5px solid var(--border2);
  border-top-color:var(--accent); border-radius:50%;
  animation:spin .65s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }
.loading-text { font-size:.72rem; color:var(--muted); }

/* ── Empty / Error ── */
.empty-state { padding:56px 20px; text-align:center; color:var(--muted); }
.empty-icon  { font-size:2.2rem; margin-bottom:10px; }
.empty-text  { font-family:var(--font-head); font-size:1rem; font-weight:700; margin-bottom:5px; color:var(--text); }
.empty-sub   { font-size:.76rem; }
.error-bar {
  background:var(--red-bg); border:1px solid rgba(184,48,48,.25);
  border-radius:6px; color:var(--red); font-size:.8rem;
  padding:10px 14px; margin-bottom:16px; display:none;
}
.error-bar.visible { display:block; }

@media (max-width:900px) { .kpi-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px) {
  .main{padding:14px;} .header{padding:12px 14px;}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:10px;}
  .filter-panel{padding:14px;} .kpi-value{font-size:1.2rem;}
}
/* ── schedules.css ───────────────────────────────────── */
/* ============================================================
 * schedules.css — Email Schedules Manager
 * Extends books.css — import books.css FIRST
 * ============================================================ */

/* ── Tab bar ─────────────────────────────────────────────────── */
.tab-bar {
  display: flex;
  gap: 0;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 0 32px;
  position: sticky;
  top: 73px;           /* sits below the sticky header */
  z-index: 90;
  box-shadow: 0 1px 0 var(--border);
}

.tab-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 12px 20px;
  font-family: var(--font-head);
  font-size: .82rem;
  font-weight: 600;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color .2s, border-color .2s;
  white-space: nowrap;
}
.tab-item:hover    { color: var(--text); }
.tab-item.active   { color: var(--accent); border-bottom-color: var(--accent); }
.tab-item svg      { flex-shrink: 0; }

/* ── Page heading ────────────────────────────────────────────── */
.sched-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 22px;
  flex-wrap: wrap;
  gap: 12px;
}
.sched-title {
  font-family: var(--font-head);
  font-size: 1.3rem;
  font-weight: 800;
  margin-bottom: 3px;
}
.sched-desc { font-size: .78rem; color: var(--muted); }

/* ── Schedules table overrides ───────────────────────────────── */
.td-num    { color: var(--muted); font-size: .75rem; width: 36px; }
.td-email  { font-weight: 600; font-size: .86rem; }
.td-date   { font-size: .75rem; color: var(--muted); white-space: nowrap; }
.td-actions { white-space: nowrap; text-align: right; }
.th-actions { text-align: right !important; }

tbody tr.row-inactive { opacity: .52; }

/* ── Action buttons ──────────────────────────────────────────── */
.action-btn {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 5px;
  cursor: pointer;
  font-size: .78rem;
  padding: 4px 8px;
  margin-left: 4px;
  transition: background .15s, border-color .15s;
  line-height: 1;
}
.action-btn:hover      { background: var(--surface2); }
.btn-edit:hover        { border-color: var(--blue);   color: var(--blue); }
.btn-del:hover         { border-color: var(--red);    color: var(--red);  }
.btn-toggle:hover      { border-color: var(--amber);  color: var(--amber);}
.btn-test:hover        { border-color: var(--blue);   color: var(--blue); background: var(--blue-bg); }

/* ── Test-send button (inside confirm modal) ─────────────────── */
.btn-test-send {
  background: linear-gradient(135deg, var(--blue), #1a4e8a);
  border: none; border-radius: 6px; color: #fff; cursor: pointer;
  font-family: var(--font-head); font-size: .84rem; font-weight: 700;
  padding: 8px 20px; transition: opacity .2s, transform .1s;
  box-shadow: 0 2px 8px rgba(30,95,163,.28);
  display: flex; align-items: center; gap: 6px;
}
.btn-test-send:hover    { opacity: .9; }
.btn-test-send:active   { transform: scale(.97); }
.btn-test-send:disabled { opacity: .45; cursor: not-allowed; }

/* ── Period pills ────────────────────────────────────────────── */
.period-pill {
  display: inline-block;
  font-size: .68rem;
  padding: 2px 9px;
  border-radius: 4px;
  white-space: nowrap;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.period-daily   { background: var(--blue-bg);   color: var(--blue);   border: 1px solid rgba(30,95,163,.18);  }
.period-weekly  { background: var(--amber-bg);  color: var(--amber);  border: 1px solid rgba(196,127,23,.22); }
.period-monthly { background: var(--green-bg);  color: var(--green);  border: 1px solid rgba(26,122,82,.2);  }

/* ── Status pills ────────────────────────────────────────────── */
.status-pill {
  display: inline-block;
  font-size: .68rem;
  padding: 2px 9px;
  border-radius: 20px;
  font-weight: 600;
  white-space: nowrap;
}
.status-on  { background: var(--green-bg); color: var(--green); border: 1px solid rgba(26,122,82,.2); }
.status-off { background: var(--surface2); color: var(--muted); border: 1px solid var(--border); }

/* ── Danger button ───────────────────────────────────────────── */
.btn-danger {
  background: var(--red-bg);
  border: 1px solid rgba(184,48,48,.25);
  border-radius: 6px;
  color: var(--red);
  cursor: pointer;
  font-family: var(--font-head);
  font-size: .84rem;
  font-weight: 700;
  padding: 8px 20px;
  transition: background .2s, box-shadow .2s;
}
.btn-danger:hover { background: #f8d7d7; box-shadow: 0 2px 8px rgba(184,48,48,.15); }
.btn-danger:disabled { opacity: .45; cursor: not-allowed; }

/* ── Modal ───────────────────────────────────────────────────── */
.modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(26,24,20,.45);
  backdrop-filter: blur(3px);
  z-index: 200;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.modal-backdrop.open { display: flex; }

.modal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.18), 0 4px 12px rgba(0,0,0,.08);
  width: 100%;
  max-width: 540px;
  animation: modalIn .2s ease;
}
.modal-sm { max-width: 380px; }

@keyframes modalIn {
  from { opacity:0; transform: translateY(12px) scale(.98); }
  to   { opacity:1; transform: translateY(0)    scale(1);   }
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px 14px;
  border-bottom: 1px solid var(--border);
}
.modal-title {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 700;
}
.modal-close {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.3rem;
  color: var(--muted);
  line-height: 1;
  padding: 0 4px;
  transition: color .15s;
}
.modal-close:hover { color: var(--text); }

.modal-body   { padding: 20px 22px; display: flex; flex-direction: column; gap: 16px; }
.modal-footer { padding: 14px 22px 18px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 10px; }

/* ── Form fields ─────────────────────────────────────────────── */
.field-row   { display: flex; gap: 14px; flex-wrap: wrap; }
.field-group { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 160px; }
.field-group.full { flex-basis: 100%; }
.field-label { font-size: .65rem; color: var(--muted); text-transform: uppercase; letter-spacing: .1em; font-weight: 500; }
.field-label .req { color: var(--red); margin-left: 1px; }

.field-input, .field-select {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: .84rem;
  padding: 8px 11px;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
  width: 100%;
}
.field-input:focus, .field-select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(196,127,23,.12);
}

/* ── Period toggle inside modal ──────────────────────────────── */
.period-toggle {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 7px;
  overflow: hidden;
  background: var(--surface2);
}
.period-btn {
  flex: 1;
  background: transparent;
  border: none;
  border-right: 1px solid var(--border);
  cursor: pointer;
  font-family: var(--font-head);
  font-size: .8rem;
  font-weight: 600;
  padding: 8px 0;
  color: var(--muted);
  transition: background .15s, color .15s;
}
.period-btn:last-child { border-right: none; }
.period-btn.active { background: var(--accent); color: #fff; }
.period-btn:hover:not(.active) { background: var(--amber-bg); color: var(--accent); }

/* ── Modal error ─────────────────────────────────────────────── */
.modal-error {
  color: var(--red);
  font-size: .78rem;
  min-height: 1em;
}

/* ── Delete confirm message ──────────────────────────────────── */
.delete-msg {
  font-size: .86rem;
  line-height: 1.65;
  color: var(--text);
}

/* ── Toast notification ──────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--text);
  color: #fff;
  font-family: var(--font-head);
  font-size: .82rem;
  font-weight: 600;
  padding: 10px 22px;
  border-radius: 40px;
  box-shadow: 0 6px 24px rgba(0,0,0,.2);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s, transform .25s;
  white-space: nowrap;
  z-index: 999;
}
.toast.show           { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.toast-success  { background: var(--green); }
.toast.toast-error    { background: var(--red); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 700px) {
  .tab-bar  { padding: 0 12px; top: 64px; }
  .tab-item { padding: 10px 12px; font-size: .76rem; }
  .modal    { border-radius: 10px; }
  .field-row { flex-direction: column; }
}
/* ── components.css ──────────────────────────────────── */
/* ============================================================
 * components.css — Shared UI primitives
 * ============================================================
 * Loaded via partials/header.php on every page. Holds anything
 * that was previously duplicated as inline <style> blocks across
 * pages: action buttons, modal dialogs, spinners, sync badge,
 * sortable table headers.
 *
 * Genuinely page-specific layout (e.g. inventory_ageing's bucket
 * grid) stays inline on that page.
 *
 * Depends on the design tokens in books.css (--accent, --border,
 * --muted, --font-head, --font-mono, --shadow-sm, etc.). Load
 * order: books.css → schedules.css → components.css.
 * ========================================================= */

/* ── Action buttons (Excel / Email / Purge / Sync) ───────── */
.btn-excel,
.btn-email-open,
.btn-purge,
.btn-sync {
  background: var(--surface);
  border-radius: 6px;
  cursor: pointer;
  font-family: var(--font-head);
  font-size: .85rem;
  font-weight: 700;
  padding: 9px 18px;
  transition: background .2s, box-shadow .2s;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}
.btn-excel:disabled,
.btn-email-open:disabled,
.btn-purge:disabled,
.btn-sync:disabled { opacity: .5; cursor: not-allowed; }

.btn-excel        { border: 1px solid #16a34a; color: #16a34a; }
.btn-excel:hover  { background: #f0fdf4; box-shadow: 0 2px 8px rgba(22,163,74,.15); }

.btn-email-open       { border: 1px solid var(--blue); color: var(--blue); }
.btn-email-open:hover { background: var(--blue-bg); box-shadow: 0 2px 8px rgba(30,95,163,.15); }

.btn-purge        { border: 1px solid var(--red); color: var(--red); }
.btn-purge:hover  { background: var(--red-bg); box-shadow: 0 2px 8px rgba(184,48,48,.15); }

.btn-sync         { border: 1px solid var(--accent); color: var(--accent); }
.btn-sync:hover   { background: var(--amber-bg); box-shadow: 0 2px 8px rgba(196,127,23,.15); }
.btn-sync.spinning svg { animation: spin .8s linear infinite; }

/* ── Modal: gradient-header variant (.modal-box, .active) ── */
/* This is the newer modal pattern used by stock_summary, book_sales,
 * inventory_ageing, contacts, cron, notifications, templates, etc.
 * The schedules.css legacy `.modal` (with .open) is unrelated and
 * still defined there — both can coexist on the same page. */

.modal-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(26,24,20,.5);
  z-index: 200;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
  padding: 20px;
}
.modal-backdrop.active { display: flex; }
.modal-backdrop.open   { display: flex; }   /* schedules.css legacy */

.modal-box {
  background: var(--surface);
  border-radius: 14px;
  box-shadow: 0 24px 64px rgba(0,0,0,.2), 0 4px 16px rgba(0,0,0,.1);
  width: 100%;
  max-width: 440px;
  overflow: hidden;
  animation: modalIn .2s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modalIn {
  from { transform: translateY(16px) scale(.97); opacity: 0; }
  to   { transform: none; opacity: 1; }
}

.modal-head {
  background: linear-gradient(135deg, var(--blue), #1a4e8a);
  padding: 22px 28px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.modal-icon {
  width: 38px; height: 38px;
  background: rgba(255,255,255,.15);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
}
.modal-title {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
}
.modal-sub {
  font-size: .72rem;
  color: rgba(255,255,255,.68);
  margin-top: 2px;
}

.modal-body { padding: 24px 28px; }

.modal-context {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .78rem;
  color: var(--muted);
  margin-bottom: 20px;
  line-height: 1.6;
}
.modal-context strong { color: var(--text); }

.modal-label {
  font-size: .68rem;
  color: var(--muted);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 6px;
  display: block;
  font-weight: 500;
}

.modal-input {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: .88rem;
  padding: 10px 12px;
  outline: none;
  margin-bottom: 20px;
  transition: border-color .2s, box-shadow .2s;
}
.modal-input:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(30,95,163,.1);
}

.modal-actions { display: flex; gap: 10px; justify-content: flex-end; }

.modal-cancel {
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 6px;
  color: var(--muted);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: .82rem;
  padding: 9px 18px;
  transition: background .2s, color .2s;
}
.modal-cancel:hover { background: var(--surface2); color: var(--text); }

.modal-send {
  background: linear-gradient(135deg, var(--blue), #1a4e8a);
  border: none;
  border-radius: 6px;
  color: #fff;
  cursor: pointer;
  font-family: var(--font-head);
  font-size: .85rem;
  font-weight: 700;
  padding: 9px 22px;
  transition: opacity .2s;
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.modal-send:hover    { opacity: .9; }
.modal-send:disabled { opacity: .45; cursor: not-allowed; }

.modal-status {
  font-size: .8rem;
  margin-top: 14px;
  padding: 9px 13px;
  border-radius: 6px;
  display: none;
  border: 1px solid;
}
.modal-status.ok  { background: var(--green-bg); color: var(--green); border-color: rgba(26,122,82,.2); display: block; }
.modal-status.err { background: var(--red-bg);   color: var(--red);   border-color: rgba(184,48,48,.2); display: block; }

/* ── Spinner ──────────────────────────────────────────────── */
.spinner-ring {
  width: 32px; height: 32px;
  border: 3px solid var(--border);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  flex-shrink: 0;
}
.spinner-ring.sm { width: 14px; height: 14px; border-width: 2px; }

@keyframes spin { to { transform: rotate(360deg); } }

.table-spinner-wrap {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 60px 0;
  color: var(--muted);
  font-size: .9rem;
}
.table-spinner-wrap.visible { display: flex; }

.fetch-badge {
  font-size: .72rem;
  color: var(--muted);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 3px 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ── Sortable table headers ───────────────────────────────── */
th.sortable       { cursor: pointer; user-select: none; white-space: nowrap; }
th.sortable:hover { background: var(--surface2); }
th.sort-asc  .sort-icon::after { content: ' ↑'; }
th.sort-desc .sort-icon::after { content: ' ↓'; }
.sort-icon        { color: var(--muted); font-size: .72rem; }

/* ── Sync status pill (inventory_ageing + future use) ─────── */
.sync-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .72rem;
  padding: 5px 11px;
  border-radius: 99px;
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--muted);
}
.sync-badge.running { background: var(--amber-bg); border-color: rgba(196,127,23,.3); color: var(--amber); }
.sync-badge.failed  { background: var(--red-bg);   border-color: rgba(184,48,48,.3);  color: var(--red);   }
.sync-badge.ok      { background: var(--green-bg); border-color: rgba(26,122,82,.3);  color: var(--green); }
.sync-badge .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.sync-badge.running .dot { animation: pulse 1.4s ease-in-out infinite; }

/* ── Date-pair (two date inputs side-by-side) ─────────────── */
.date-pair        { display: flex; gap: 6px; align-items: center; }
.date-pair span   { color: var(--muted); font-size: .8rem; }

/* ── Negative-quantity table cell ─────────────────────────── */
.qty-negative { color: var(--red); font-weight: 600; }

/* ── Sub-tab strip (notifications / contacts / templates) ── */
.nm-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin: 0 0 18px;
}
.nm-tabs a {
  padding: 10px 16px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
}
.nm-tabs a.active { color: var(--accent); border-color: var(--accent); }
.nm-tabs a:hover  { color: var(--text); }

/* ── Form shims for legacy modal bodies ──────────────────── */
/* Used by contacts.php, cron.php, notifications.php, templates.php
 * — those modals don't use the .modal-input pattern; instead they
 * style raw <input>/<textarea>/<select> inside .modal-body. */
.modal-body label {
  font-size: .65rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .1em;
  font-weight: 500;
  display: block;
  margin-bottom: 4px;
}
.modal-body input[type=text],
.modal-body input[type=email],
.modal-body input[type=number],
.modal-body textarea,
.modal-body select {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
  font-family: inherit;
  font-size: .85rem;
  box-sizing: border-box;
  transition: border-color .15s ease;
}
.modal-body input:focus,
.modal-body textarea:focus,
.modal-body select:focus { outline: none; border-color: var(--accent); }

/* ── Generic primary/secondary/danger/icon buttons ───────── */
.btn-primary,
.btn-secondary {
  padding: 8px 16px;
  border-radius: 6px;
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--border);
  transition: all .15s ease;
}
.btn-primary       { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-primary:hover { filter: brightness(.95); }
.btn-secondary     { background: var(--surface); color: var(--text); }
.btn-secondary:hover { background: var(--surface2); }

.btn-danger {
  background: var(--red);
  color: #fff;
  border: 1px solid var(--red);
  padding: 8px 16px;
  border-radius: 6px;
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
}

.btn-icon {
  background: none;
  border: none;
  padding: 4px 6px;
  cursor: pointer;
  font-size: 1rem;
  color: var(--muted);
  border-radius: 4px;
}
.btn-icon:hover { background: var(--surface2); color: var(--text); }
.btn-icon.btn-danger        { background: none; color: var(--red); border: none; }
.btn-icon.btn-danger:hover  { background: var(--red-bg); }

.td-actions { display: flex; gap: 2px; }

/* ============================================================
 * Brand-summary table — shared by book_sales_no_cache.php and
 * invoices.php. Both pages use bare <table>/<thead>/<tbody>
 * markup (no .invoice-table wrapper) plus the same column-class
 * set, chips, total-row and narrower main column.
 * ============================================================ */

.page-book-sales .table-relative,
.page-invoices   .table-relative { position: relative; }

.page-book-sales .badge-cn,
.page-invoices   .badge-cn       { color: var(--red);  background: var(--red-bg);  border-color: rgba(184,48,48,.2); }
.page-book-sales .badge-books,
.page-invoices   .badge-books    { color: var(--blue); background: var(--blue-bg); border-color: rgba(30,95,163,.2); }

.page-book-sales .btn-email,
.page-invoices   .btn-email {
  background: var(--surface); border: 1px solid var(--blue);
  border-radius: 6px; color: var(--blue);
  cursor: pointer; font-family: var(--font-head); font-size: .85rem; font-weight: 700;
  padding: 9px 20px; transition: background .2s, color .2s, box-shadow .2s;
  white-space: nowrap; display: flex; align-items: center; gap: 7px; letter-spacing: .03em;
}
.page-book-sales .btn-email:hover,
.page-invoices   .btn-email:hover    { background: var(--blue-bg); box-shadow: 0 2px 8px rgba(30,95,163,.15); }
.page-book-sales .btn-email:active,
.page-invoices   .btn-email:active   { transform: scale(.97); }
.page-book-sales .btn-email:disabled,
.page-invoices   .btn-email:disabled { opacity: .45; cursor: not-allowed; }

.page-book-sales table,
.page-invoices   table       { width: 100%; border-collapse: collapse; font-size: .82rem; }
.page-book-sales thead th,
.page-invoices   thead th    {
  background: var(--surface2); color: var(--muted);
  font-size: .65rem; letter-spacing: .1em; text-transform: uppercase;
  padding: 11px 16px; text-align: left; white-space: nowrap;
  border-bottom: 1px solid var(--border); font-weight: 500;
}
.page-book-sales thead th.right,
.page-invoices   thead th.right      { text-align: right; }
.page-book-sales tbody tr,
.page-invoices   tbody tr            { border-bottom: 1px solid var(--border); transition: background .12s; }
.page-book-sales tbody tr:last-child,
.page-invoices   tbody tr:last-child { border-bottom: none; }
.page-book-sales tbody tr:hover,
.page-invoices   tbody tr:hover      { background: #faf9f7; }
.page-book-sales tbody td,
.page-invoices   tbody td            { padding: 13px 16px; vertical-align: middle; }

.page-book-sales .td-rank,
.page-invoices   .td-rank    { color: var(--muted); font-size: .75rem; width: 36px; }
.page-book-sales .td-brand,
.page-invoices   .td-brand   { font-family: var(--font-head); font-size: .9rem; font-weight: 700; color: var(--text); }
.page-book-sales .td-sales,
.page-invoices   .td-sales   { text-align: right; font-weight: 600; color: var(--green); }
.page-book-sales .td-cn,
.page-invoices   .td-cn      { text-align: right; color: var(--red); font-size: .82rem; }
.page-book-sales .td-net,
.page-invoices   .td-net     { text-align: right; font-weight: 700; color: var(--amber); font-size: .9rem; }

.page-book-sales .chip-sales,
.page-invoices   .chip-sales { display: inline-block; background: var(--green-bg); border-radius: 4px; padding: 2px 6px; }
.page-book-sales .chip-net,
.page-invoices   .chip-net   { display: inline-block; background: var(--amber-bg); border-radius: 4px; padding: 2px 6px; }
.page-book-sales .chip-cn,
.page-invoices   .chip-cn    { display: inline-block; background: var(--red-bg);   border-radius: 4px; padding: 2px 6px; }
.page-book-sales .td-mtd,
.page-invoices   .td-mtd     { text-align: right; font-weight: 600; color: var(--blue); font-size: .9rem; }
.page-book-sales .chip-mtd,
.page-invoices   .chip-mtd   { display: inline-block; background: var(--blue-bg);  border-radius: 4px; padding: 2px 6px; color: var(--blue); font-weight: 600; }

.page-book-sales .total-row td,
.page-invoices   .total-row td {
  background: #fdf8f2 !important; border-top: 2px solid var(--border2) !important;
  font-weight: 700; font-family: var(--font-head);
}
.page-book-sales .total-row .td-brand,
.page-invoices   .total-row .td-brand { font-size: .8rem; letter-spacing: .08em; color: var(--muted); }
.page-book-sales .total-row .td-net,
.page-invoices   .total-row .td-net   { color: var(--amber); font-size: 1rem; }
.page-book-sales .total-row .td-sales,
.page-invoices   .total-row .td-sales { color: var(--green); }
.page-book-sales .total-row .td-cn,
.page-invoices   .total-row .td-cn    { color: var(--red); }

@media (max-width: 768px) {
  .page-book-sales .main,
  .page-invoices   .main         { padding: 16px; }
  .page-book-sales .filter-panel,
  .page-invoices   .filter-panel { padding: 16px; }
  .page-book-sales .btn-group,
  .page-invoices   .btn-group    { width: 100%; }
}

/* ============================================================
 * .page-stock-summary — audit-status pills + phys-count cell
 * ============================================================ */
.page-stock-summary .status-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 99px;
  font-size: .72rem; font-weight: 700; letter-spacing: .03em;
  white-space: nowrap;
}
.page-stock-summary .status-accounted     { background:#dcfce7; color:#15803d; border:1px solid #bbf7d0; }
.page-stock-summary .status-less          { background:#fef3c7; color:#92400e; border:1px solid #fde68a; }
.page-stock-summary .status-more          { background:#ede9fe; color:#5b21b6; border:1px solid #ddd6fe; }
.page-stock-summary .status-not-audited   { background:#fee2e2; color:#991b1b; border:1px solid #fecaca; }
.page-stock-summary .status-not-scheduled { background:var(--surface); color:var(--muted); border:1px solid var(--border); }

.page-stock-summary .phys-count-cell      { font-family:'DM Mono',monospace; font-size:.85rem; font-weight:500; color:var(--muted); text-align:right; }
.page-stock-summary .phys-count-cell.has-value { color:var(--text); }

/* ============================================================
 * .page-audit — audit.php (count-entry + closed read-only view)
 * Everything scoped so .kpi-card / .toast / etc. do not collide
 * with the shared style.css definitions of the same names.
 * ============================================================ */
.page-audit .brand-section { margin-bottom: 28px; }
.page-audit .brand-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-bottom: 10px; flex-wrap: wrap;
}
.page-audit .brand-header-left { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.page-audit .brand-pill-lg {
  display: inline-flex; align-items: center; gap: 7px;
  background: #f0eef8; color: #3c2b8a; border: 1px solid #c5bdf0;
  border-radius: 99px; padding: 5px 16px;
  font-family: 'Syne', sans-serif; font-size: .875rem; font-weight: 700;
}
.page-audit .brand-progress { display: flex; align-items: center; gap: 8px; font-size: .78rem; color: var(--muted); }
.page-audit .progress-bar-wrap { width: 100px; height: 6px; background: var(--border); border-radius: 99px; overflow: hidden; }
.page-audit .progress-bar-fill { height: 100%; background: #16a34a; border-radius: 99px; transition: width .3s; }

.page-audit .btn-save-all {
  padding: 7px 16px; background: #16a34a; color: #fff; border: none;
  border-radius: 8px; font-family: 'Syne', sans-serif; font-size: .8rem;
  font-weight: 700; cursor: pointer; transition: opacity .15s;
  display: flex; align-items: center; gap: 6px; white-space: nowrap;
}
.page-audit .btn-save-all:hover    { opacity: .88; }
.page-audit .btn-save-all:disabled { opacity: .5; cursor: not-allowed; }

.page-audit .btn-complete {
  padding: 7px 16px; background: #1a1814; color: #fff; border: none;
  border-radius: 8px; font-family: 'Syne', sans-serif; font-size: .8rem;
  font-weight: 700; cursor: pointer; transition: opacity .15s;
  display: flex; align-items: center; gap: 6px; white-space: nowrap;
}
.page-audit .btn-complete:hover    { opacity: .88; }
.page-audit .btn-complete:disabled { opacity: .5; cursor: not-allowed; }

/* Complete-audit confirmation modal */
.page-audit .cm-backdrop {
  position: fixed; inset: 0;
  background: rgba(20,16,10,.55);
  display: none; align-items: center; justify-content: center;
  z-index: 1000;
}
.page-audit .cm-backdrop.active { display: flex; }
.page-audit .cm-box {
  background: var(--surface); border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.28);
  max-width: 460px; width: calc(100% - 32px); padding: 24px 26px;
}
.page-audit .cm-title {
  font-family: 'Syne', sans-serif; font-size: 1.05rem; font-weight: 800;
  color: var(--text); margin: 0 0 6px 0;
  display: flex; align-items: center; gap: 8px;
}
.page-audit .cm-sub { color: var(--muted); font-size: .85rem; margin-bottom: 14px; line-height: 1.45; }
.page-audit .cm-input {
  width: 100%; padding: 10px 14px;
  border: 1px solid var(--border); border-radius: 8px;
  background: var(--surface); color: var(--text);
  font-family: inherit; font-size: .9rem; outline: none;
  transition: border-color .15s;
}
.page-audit .cm-input:focus { border-color: var(--accent, #3b82f6); box-shadow: 0 0 0 3px rgba(59,130,246,.12); }
.page-audit .cm-warn {
  margin: 12px 0 4px; padding: 10px 12px;
  background: #fff7ed; border: 1px solid #fed7aa; border-radius: 8px;
  color: #9a3412; font-size: .8rem; line-height: 1.4;
}
.page-audit .cm-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 16px; }
.page-audit .cm-cancel, .page-audit .cm-confirm {
  padding: 8px 18px; border-radius: 8px;
  font-family: 'Syne', sans-serif; font-size: .82rem; font-weight: 700;
  cursor: pointer; border: none;
}
.page-audit .cm-cancel  { background: var(--surface); color: var(--text); border: 1px solid var(--border); }
.page-audit .cm-confirm { background: #16a34a; color: #fff; }
.page-audit .cm-confirm:disabled { opacity: .5; cursor: not-allowed; }
.page-audit .cm-status { margin-top: 10px; font-size: .8rem; color: #b83030; }

/* Audit items table */
.page-audit .audit-table { width: 100%; border-collapse: collapse; }
.page-audit .audit-table thead tr { border-bottom: 1px solid var(--border); }
.page-audit .audit-table th {
  padding: 9px 14px; font-size: .7rem; font-weight: 700;
  letter-spacing: .07em; text-transform: uppercase;
  color: var(--muted); text-align: left; white-space: nowrap;
}
.page-audit .audit-table th.right { text-align: right; }
.page-audit .audit-table td {
  padding: 10px 14px; font-size: .85rem; color: var(--text);
  border-bottom: 1px solid var(--border); vertical-align: middle;
}
.page-audit .audit-table tr:last-child td { border-bottom: none; }
.page-audit .audit-table tr:hover td      { background: var(--surface); }

/* Count input */
.page-audit .count-input {
  width: 100px; padding: 6px 10px;
  border: 1px solid var(--border); border-radius: 7px;
  background: var(--surface); color: var(--text);
  font-family: 'DM Mono', monospace; font-size: .85rem;
  text-align: right; outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.page-audit .count-input:focus   { border-color: var(--accent, #3b82f6); box-shadow: 0 0 0 3px rgba(59,130,246,.12); }
.page-audit .count-input.saved   { border-color: #16a34a; background: #f0fdf4; color: #15803d; }
.page-audit .count-input.changed { border-color: #f59e0b; background: #fffbeb; }

.page-audit .saved-tick {
  color: #16a34a; font-size: .85rem;
  display: inline-block; width: 18px; text-align: center;
}

/* Search + filter toggle above the items table */
.page-audit .table-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }

/* ── Mobile: keep the Physical Count input fully visible ───────
   The previous layout put a 100px right-aligned input inside a
   table that could overflow the viewport — the last column ended
   up clipped behind the right edge. On <=720px we drop the SKU
   column, shrink padding, and let item names wrap so the count
   input + saved-tick spacer always fit on-screen. */
@media (max-width: 720px) {
  .page-audit .main          { padding: 12px; }
  .page-audit .audit-table th, .page-audit .audit-table td {
    padding: 9px 8px;
    white-space: normal;
    word-break: break-word;
  }
  .page-audit .audit-table th:nth-child(2),
  .page-audit .audit-table td:nth-child(2) { display: none; }   /* hide SKU */
  .page-audit .count-input { width: 86px; padding: 6px 8px; }
  .page-audit .table-scroll { -webkit-overflow-scrolling: touch; }
  .page-audit .brand-header { padding: 12px; gap: 8px; }
  .page-audit .btn-complete, .page-audit .btn-save-all { padding: 8px 12px; font-size: .8rem; }
}

/* Past-audits table on audit_schedule.php has 9 columns — far too
   many for a phone. Allow horizontal scroll but make sure the
   Actions column doesn't get hidden behind the viewport edge. */
@media (max-width: 720px) {
  .page-audit-schedule .table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .page-audit-schedule #pastAuditTable th,
  .page-audit-schedule #pastAuditTable td { padding: 8px 10px; white-space: nowrap; }
  .page-audit-schedule #pastAuditTable td .row-actions a,
  .page-audit-schedule #pastAuditTable td .row-actions button { padding: 4px 8px; font-size: .7rem; }
}
.page-audit .search-input {
  flex: 1; min-width: 200px; padding: 8px 12px;
  border: 1px solid var(--border); border-radius: 8px;
  background: var(--surface); color: var(--text);
  font-family: inherit; font-size: .85rem; outline: none;
  transition: border-color .15s;
}
.page-audit .search-input:focus { border-color: var(--accent, #3b82f6); box-shadow: 0 0 0 3px rgba(59,130,246,.12); }

.page-audit .filter-toggle {
  display: flex; gap: 4px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; padding: 3px;
}
.page-audit .filter-toggle button {
  padding: 5px 12px; border: none; border-radius: 6px;
  background: none; color: var(--muted);
  font-size: .75rem; font-weight: 600; cursor: pointer;
  transition: all .15s; font-family: inherit;
}
.page-audit .filter-toggle button.active {
  background: var(--surface); color: var(--text);
  box-shadow: 0 1px 3px rgba(0,0,0,.1);
}

/* Loading + small spinner */
.page-audit .load-overlay { display: none; text-align: center; padding: 72px 0; color: var(--muted); }
.page-audit .load-overlay.visible { display: block; }
.page-audit .spinner-lg {
  width: 36px; height: 36px;
  border: 3px solid var(--border); border-top-color: var(--accent, #3b82f6);
  border-radius: 50%; animation: spin .7s linear infinite;
  margin: 0 auto 14px;
}
.page-audit .spin-sm {
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,.3); border-top-color: #fff;
  border-radius: 50%; animation: spin .7s linear infinite;
  display: inline-block; vertical-align: middle;
}

/* Bottom-right toast (overrides the centered shared .toast) */
.page-audit .toast {
  position: fixed; bottom: 28px; right: 28px;
  background: var(--text); color: var(--surface);
  padding: 12px 20px; border-radius: 10px;
  font-size: .85rem; font-weight: 600;
  box-shadow: 0 4px 20px rgba(0,0,0,.18);
  z-index: 999; opacity: 0;
  transform: translateY(10px);
  transition: opacity .2s, transform .2s;
  pointer-events: none;
  left: auto; /* unset shared rule */
}
.page-audit .toast.show  { opacity: 1; transform: translateY(0); }
.page-audit .toast.error { background: #b83030; color: #fff; }

/* "Audit not found" block */
.page-audit .empty-block { text-align: center; padding: 64px 0; color: var(--muted); }
.page-audit .empty-block .e-icon { margin-bottom: 12px; }
.page-audit .empty-block .e-text { font-weight: 600; font-size: .95rem; color: var(--text); }
.page-audit .empty-block .e-sub  { font-size: .82rem; margin-top: 5px; }

/* Closed-audit (read-only) result view */
.page-audit .closed-banner {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  background: var(--surface); border: 1px solid var(--border);
  border-left: 3px solid #b83030;
  border-radius: 10px; margin-bottom: 18px;
}
.page-audit .closed-banner .lock { font-size: 1.5rem; }
.page-audit .closed-banner .label-strong { font-weight: 700; color: var(--text); }
.page-audit .closed-banner .label-sub    { font-size: .82rem; color: var(--muted); margin-top: 2px; }

.page-audit .kpi-row,
.page-expiry-tracker .kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px; margin-bottom: 20px;
}
.page-audit .kpi-card,
.page-expiry-tracker .kpi-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 12px 14px;
}
.page-audit .kpi-card::before,
.page-expiry-tracker .kpi-card::before { content: none; } /* unset the shared 3px top stripe */
.page-audit .kpi-card .kpi-label,
.page-expiry-tracker .kpi-card .kpi-label {
  font-size: .68rem; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; color: var(--muted);
}
.page-audit .kpi-card .kpi-value,
.page-expiry-tracker .kpi-card .kpi-value { margin-top: 4px; }
.page-audit .kpi-card.failed .kpi-value,
.page-expiry-tracker .kpi-card.failed .kpi-value { color: #b83030; }
.page-audit .kpi-card.clean  .kpi-value,
.page-expiry-tracker .kpi-card.clean  .kpi-value { color: #15803d; }

.page-audit .variance-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 99px;
  font-size: .7rem; font-weight: 700; letter-spacing: .04em;
  white-space: nowrap;
}
.page-audit .var-matched     { background:#dcfce7; color:#15803d; border:1px solid #bbf7d0; }
.page-audit .var-over        { background:#ede9fe; color:#5b21b6; border:1px solid #ddd6fe; }
.page-audit .var-short       { background:#fef3c7; color:#92400e; border:1px solid #fde68a; }
.page-audit .var-not-audited { background:#fee2e2; color:#991b1b; border:1px solid #fecaca; }

.page-audit .delta-cell {
  font-family: 'DM Mono', monospace; font-size: .85rem;
  font-weight: 700; white-space: nowrap;
}
.page-audit .delta-pos  { color: #15803d; }
.page-audit .delta-neg  { color: #b83030; }
.page-audit .delta-zero { color: var(--muted); font-weight: 500; }

/* ============================================================
 * .page-audit-schedule — audit_schedule.php
 * Scoped to avoid collisions with shared .toast / .spinner-ring /
 * .empty-icon variants in the rest of style.css.
 * ============================================================ */
.page-audit-schedule .audit-form-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; padding: 24px 28px; margin-bottom: 28px;
}
.page-audit-schedule .audit-form-card h2 {
  font-family: 'Syne', sans-serif; font-size: 1rem; font-weight: 700;
  color: var(--text); margin: 0 0 20px 0;
  display: flex; align-items: center; gap: 8px;
}
.page-audit-schedule .audit-form-card h2 .form-icon {
  width: 28px; height: 28px; background: var(--accent, #3b82f6);
  border-radius: 7px; display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: .85rem; flex-shrink: 0;
}

.page-audit-schedule .form-row { display: flex; gap: 14px; align-items: flex-end; flex-wrap: wrap; }
.page-audit-schedule .form-field { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 160px; }
.page-audit-schedule .form-field label {
  font-size: .72rem; font-weight: 600; letter-spacing: .05em;
  text-transform: uppercase; color: var(--muted);
}
.page-audit-schedule .form-field input,
.page-audit-schedule .form-field select,
.page-audit-schedule .form-field textarea {
  padding: 8px 12px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--surface); color: var(--text);
  font-family: inherit; font-size: .875rem; outline: none;
  transition: border-color .15s;
}
.page-audit-schedule .form-field input:focus,
.page-audit-schedule .form-field select:focus,
.page-audit-schedule .form-field textarea:focus {
  border-color: var(--accent, #3b82f6);
  box-shadow: 0 0 0 3px rgba(59,130,246,.12);
}
.page-audit-schedule .form-field textarea { resize: vertical; min-height: 64px; }

.page-audit-schedule .brand-multi-wrap { display: flex; flex-direction: column; gap: 8px; }
.page-audit-schedule .brand-tags { display: flex; flex-wrap: wrap; gap: 6px; min-height: 32px; }
.page-audit-schedule .brand-tag {
  display: inline-flex; align-items: center; gap: 5px;
  background: #eef2ff; color: #3730a3; border: 1px solid #c7d2fe;
  border-radius: 99px; padding: 3px 10px 3px 12px;
  font-size: .78rem; font-weight: 600;
}
.page-audit-schedule .brand-tag button {
  background: none; border: none; cursor: pointer;
  color: #6366f1; font-size: .9rem; line-height: 1;
  padding: 0; display: flex; align-items: center;
}
.page-audit-schedule .brand-tag button:hover { color: #b83030; }

.page-audit-schedule .btn-add-brand {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; background: var(--surface);
  border: 1px dashed var(--border); border-radius: 8px;
  color: var(--muted); font-size: .8rem; font-weight: 600;
  cursor: pointer; transition: all .15s; font-family: inherit;
}
.page-audit-schedule .btn-add-brand:hover {
  border-color: var(--accent, #3b82f6); color: var(--accent, #3b82f6);
  background: rgba(59,130,246,.05);
}

.page-audit-schedule .btn-submit {
  padding: 9px 22px; background: var(--accent, #3b82f6); color: #fff;
  border: none; border-radius: 8px;
  font-family: 'Syne', sans-serif; font-size: .875rem; font-weight: 700;
  cursor: pointer; transition: opacity .15s, transform .1s;
  white-space: nowrap; flex-shrink: 0;
}
.page-audit-schedule .btn-submit:hover    { opacity: .9; }
.page-audit-schedule .btn-submit:active   { transform: scale(.97); }
.page-audit-schedule .btn-submit:disabled { opacity: .5; cursor: not-allowed; }

/* Audit table — date group header, completion, time-remaining cells */
.page-audit-schedule .date-group-header td {
  background: var(--surface2, #f9f8f6);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--accent, #c47f17);
  padding: 10px 16px;
}
.page-audit-schedule .date-group-header.today td {
  background: rgba(26,122,82,.08); color: var(--green, #1a7a52);
  border-color: rgba(26,122,82,.2);
}
.page-audit-schedule .today-badge {
  display: inline-block; background: var(--accent, #3b82f6); color: #fff;
  font-size: .6rem; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; padding: 2px 7px; border-radius: 99px;
  margin-left: 6px; vertical-align: middle;
}

.page-audit-schedule .btn-delete-audit {
  background: none; border: none; cursor: pointer;
  color: var(--muted); padding: 4px 8px; border-radius: 6px;
  transition: color .15s, background .15s; font-size: .85rem;
}
.page-audit-schedule .btn-delete-audit:hover { color: #b83030; background: #fdf0f0; }

.page-audit-schedule .audit-notes {
  font-size: .78rem; color: var(--muted); margin-top: 2px; font-style: italic;
}

.page-audit-schedule .audit-date-link {
  display: inline-flex; align-items: center;
  color: var(--accent, #3b82f6); text-decoration: none;
  font-weight: 600; cursor: pointer;
  transition: color .15s, transform .1s;
}
.page-audit-schedule .audit-date-link:hover  { text-decoration: underline; }
.page-audit-schedule .audit-date-link:active { transform: scale(.98); }

.page-audit-schedule .audit-date-expired {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--muted); font-weight: 600;
}
.page-audit-schedule .expired-badge {
  display: inline-block; background: #fbecec; color: #b83030;
  font-size: .6rem; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; padding: 2px 7px; border-radius: 99px;
}
.page-audit-schedule .audit-row-expired td { opacity: .55; }
.page-audit-schedule .audit-row-expired .brand-pill { filter: grayscale(.5); }

.page-audit-schedule .completion-cell { display: flex; align-items: center; gap: 10px; }
.page-audit-schedule .completion-bar  {
  width: 90px; height: 6px; background: var(--border);
  border-radius: 99px; overflow: hidden; flex-shrink: 0;
}
.page-audit-schedule .completion-fill { height: 100%; background: var(--green, #1a7a52); border-radius: 99px; transition: width .3s; }
.page-audit-schedule .completion-text {
  font-family: 'DM Mono', monospace; font-size: .78rem;
  color: var(--muted); white-space: nowrap;
}

.page-audit-schedule .td-time-remaining {
  font-family: 'DM Mono', monospace; font-size: .82rem;
  color: var(--text); font-weight: 500; white-space: nowrap;
}
.page-audit-schedule .td-time-remaining.urgent  { color: #b94520; font-weight: 700; }
.page-audit-schedule .td-time-remaining.expired { color: var(--muted); font-style: italic; }

/* Bottom-right toast (overrides centered shared .toast) */
.page-audit-schedule .toast {
  position: fixed; bottom: 28px; right: 28px;
  background: var(--text); color: var(--surface);
  padding: 12px 20px; border-radius: 10px;
  font-size: .85rem; font-weight: 600;
  box-shadow: 0 4px 20px rgba(0,0,0,.18);
  z-index: 999; opacity: 0;
  transform: translateY(10px);
  transition: opacity .2s, transform .2s;
  pointer-events: none;
  left: auto;
}
.page-audit-schedule .toast.show  { opacity: 1; transform: translateY(0); }
.page-audit-schedule .toast.error { background: #b83030; color: #fff; }

/* Empty-state used inside the upcoming-audits table */
.page-audit-schedule .empty-upcoming {
  text-align: center; padding: 48px 0; color: var(--muted);
}
.page-audit-schedule .empty-upcoming .empty-icon { font-size: 2.2rem; margin-bottom: 10px; }
.page-audit-schedule .empty-upcoming .empty-text { font-weight: 600; font-size: .95rem; color: var(--text); }
.page-audit-schedule .empty-upcoming .empty-sub  { font-size: .82rem; margin-top: 4px; }

/* Small spinner (overrides shared .spinner-ring sizing for the form button) */
.page-audit-schedule .spinner-ring {
  width: 18px; height: 18px;
  border: 2px solid rgba(255,255,255,.3); border-top-color: #fff;
  border-radius: 50%; animation: spin .7s linear infinite;
  display: inline-block; vertical-align: middle; margin-right: 6px;
}

/* Past audits */
.page-audit-schedule .section-gap   { margin-top: 32px; }
.page-audit-schedule .variance-cell {
  font-family: 'DM Mono', monospace; font-size: .85rem;
  font-weight: 700; white-space: nowrap;
}
.page-audit-schedule .variance-cell.pos  { color: #15803d; }
.page-audit-schedule .variance-cell.neg  { color: #b83030; }
.page-audit-schedule .variance-cell.zero { color: var(--muted); font-weight: 500; }

.page-audit-schedule .result-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 99px;
  font-size: .7rem; font-weight: 700; letter-spacing: .04em;
  white-space: nowrap;
}
.page-audit-schedule .result-clean      { background:#dcfce7; color:#15803d; border:1px solid #bbf7d0; }
.page-audit-schedule .result-variance   { background:#fef3c7; color:#92400e; border:1px solid #fde68a; }
.page-audit-schedule .result-incomplete { background:#fee2e2; color:#991b1b; border:1px solid #fecaca; }
.page-audit-schedule .result-empty      { background:var(--surface); color:var(--muted); border:1px solid var(--border); }

/* Recurrence form chips + pills */
.page-audit-schedule .dow-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.page-audit-schedule .dow-chip {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--surface); color: var(--muted);
  font-family: 'Syne', sans-serif; font-size: .82rem; font-weight: 700;
  cursor: pointer; transition: all .12s;
}
.page-audit-schedule .dow-chip:hover { border-color: var(--accent, #3b82f6); color: var(--accent, #3b82f6); }
.page-audit-schedule .dow-chip.active {
  background: var(--accent, #3b82f6); color: #fff; border-color: var(--accent, #3b82f6);
}

.page-audit-schedule .recur-pill {
  display: inline-flex; align-items: center; gap: 3px;
  background: #fff7ed; color: #9a3412; border: 1px solid #fed7aa;
  border-radius: 99px; padding: 2px 7px;
  font-size: .65rem; font-weight: 700; letter-spacing: .03em;
  margin-left: 6px; vertical-align: middle;
}

.page-audit-schedule .recur-row-meta {
  font-size: .78rem; color: var(--muted);
  font-family: 'DM Mono', monospace;
}
.page-audit-schedule .recur-row-meta b { color: var(--text); font-family: inherit; }

/* ============================================================
 * .page-books — invoice dashboard status pills + paid-row mute
 * ============================================================ */
.page-books .status-pill   { display:inline-block; padding:2px 8px; border-radius:99px; font-size:.72rem; font-weight:600; letter-spacing:.03em; }
.page-books .status-paid   { background:#e8f5ee; color:#1a7a52; }
.page-books .status-sent   { background:#e6f1fb; color:#185fa5; }
.page-books .status-overdue{ background:#fdf0f0; color:#b83030; }
.page-books .status-draft  { background:#f1efe8; color:#5f5e5a; }
.page-books .status-void   { background:#f1efe8; color:#888780; }
.page-books .status-partial{ background:#faeeda; color:#854f0b; }
.page-books .row-paid td   { opacity:.55; }

/* ============================================================
 * .page-contacts — address-book group pills + checkbox list
 * ============================================================ */
.page-contacts .group-pill {
  display:inline-block; padding:2px 8px;
  background:var(--surface2); border:1px solid var(--border);
  border-radius:10px; font-size:.7rem; margin:2px 3px 2px 0;
}
.page-contacts .chk-list {
  display:flex; flex-wrap:wrap; gap:6px 12px;
  max-height:160px; overflow:auto; padding:8px;
  border:1px solid var(--border); border-radius:6px;
  background:var(--surface2);
}
.page-contacts .chk-list label {
  display:flex; align-items:center; gap:6px;
  font-size:.78rem; cursor:pointer;
}

/* ============================================================
 * .page-cron — heartbeat banner, status pills, runs panel
 * ============================================================ */
.page-cron .heartbeat { padding:10px 14px; border-radius:8px; font-size:.78rem; margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.page-cron .hb-ok     { background:#e6f7ec; border:1px solid #b7e2c4; color:#1a7f3a; }
.page-cron .hb-stale  { background:#fff3e0; border:1px solid #f5c98c; color:#a85100; }
.page-cron .hb-down   { background:#fde8e8; border:1px solid #f3b6b6; color:#a8131c; }
.page-cron .hb-dot    { width:8px; height:8px; border-radius:50%; background:currentColor; box-shadow: 0 0 0 4px currentColor; opacity:.4; }

.page-cron .pill       { display:inline-block; padding:2px 9px; border-radius:10px; font-size:.7rem; font-weight:600; letter-spacing:.02em; }
.page-cron .pill-ok    { background:#e6f7ec; color:#1a7f3a; }
.page-cron .pill-fail  { background:#fde8e8; color:#a8131c; }
.page-cron .pill-run   { background:#e7f3ff; color:#0a4f8a; }
.page-cron .pill-never { background:var(--surface2); color:var(--muted); border:1px solid var(--border); }
.page-cron .pill-time  { background:#fff3e0; color:#a85100; }

.page-cron .sched-cell  { font-family: var(--font-mono); font-size:.75rem; }
.page-cron .sched-human { display:block; font-family: inherit; font-size:.7rem; color:var(--muted); margin-top:2px; }

.page-cron .runs-pane         { display:none; background:var(--surface2); border:1px solid var(--border); padding:12px; border-radius:8px; margin-top:8px; }
.page-cron .runs-pane.open    { display:block; }
.page-cron .runs-pane pre     { font-family:var(--font-mono); font-size:.72rem; background:var(--surface); border:1px solid var(--border); border-radius:6px; padding:8px; overflow:auto; max-height:240px; margin:6px 0 0; white-space:pre-wrap; }
.page-cron .run-row           { padding:8px 0; border-bottom:1px solid var(--border); }
.page-cron .run-row:last-child{ border-bottom:none; }
.page-cron .modal-body label  { margin: 8px 0 4px; }

/* ============================================================
 * .page-email-schedules — recipient + report-type pills
 * ============================================================ */
.page-email-schedules .rcpt-pill {
  display:inline-block; font-size:.62rem; font-weight:700;
  padding:2px 7px; border-radius:4px; margin-right:6px;
  text-transform:uppercase; letter-spacing:.06em; vertical-align:2px;
}
.page-email-schedules .rcpt-email   { background:#eef2ff; color:#3730a3; border:1px solid #c7d2fe; }
.page-email-schedules .rcpt-contact { background:#eaf5ef; color:#1a7a52; border:1px solid rgba(26,122,82,.25); }
.page-email-schedules .rcpt-group   { background:#fdf3e0; color:#854f0b; border:1px solid rgba(196,127,23,.3); }
.page-email-schedules .report-pill {
  display:inline-block;
  background:#f3f0fb; color:#4f3c9a; border:1px solid #d8d0f0;
  padding:2px 9px; border-radius:4px;
  font-size:.72rem; font-weight:600;
}

/* ============================================================
 * .page-index — landing-page hero + card grid
 * ============================================================ */
.page-index .home-hero { max-width: 1280px; margin: 0 auto; padding: 32px 32px 8px; }
.page-index .home-hero h1 {
  font-family: var(--font-head); font-size: 1.6rem; font-weight: 800;
  letter-spacing: -.01em; margin-bottom: 4px;
}
.page-index .home-hero p { color: var(--muted); font-size: .82rem; }

.page-index .home-grid {
  max-width: 1280px; margin: 0 auto; padding: 16px 32px 40px;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}

.page-index .home-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 22px 22px 20px;
  box-shadow: var(--shadow-sm); text-decoration: none; color: var(--text);
  display: flex; flex-direction: column; gap: 10px;
  position: relative; overflow: hidden;
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.page-index .home-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background: var(--accent);
}
.page-index .home-card.c-blue::before   { background: var(--blue); }
.page-index .home-card.c-green::before  { background: var(--green); }
.page-index .home-card.c-amber::before  { background: var(--amber); }
.page-index .home-card.c-orange::before { background: var(--orange); }
.page-index .home-card.c-red::before    { background: var(--red); }
.page-index .home-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: var(--border2);
}
.page-index .home-card .icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--surface2); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
}
.page-index .home-card.c-blue   .icon { color: var(--blue); }
.page-index .home-card.c-green  .icon { color: var(--green); }
.page-index .home-card.c-amber  .icon { color: var(--amber); }
.page-index .home-card.c-orange .icon { color: var(--orange); }
.page-index .home-card.c-red    .icon { color: var(--red); }
.page-index .home-card .title {
  font-family: var(--font-head); font-size: 1rem; font-weight: 700;
  letter-spacing: -.005em;
}
.page-index .home-card .desc { font-size: .76rem; color: var(--muted); line-height: 1.5; }
.page-index .home-card .arrow {
  margin-top: auto; align-self: flex-end;
  font-size: .72rem; color: var(--muted); letter-spacing: .08em;
  text-transform: uppercase; font-weight: 600;
  display: flex; align-items: center; gap: 4px;
}
.page-index .home-card:hover .arrow { color: var(--accent); }
@media (max-width: 720px) {
  .page-index .home-hero { padding: 20px 16px 4px; }
  .page-index .home-grid { padding: 12px 16px 32px; gap: 12px; }
}

/* ============================================================
 * .page-inventory-ageing — bucket cards above the table
 * ============================================================ */
.page-inventory-ageing .age-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin-bottom:20px; }
.page-inventory-ageing .age-card {
  background: var(--surface); border:1px solid var(--border);
  border-radius: 8px; padding: 12px 14px;
  box-shadow: var(--shadow-sm);
  cursor: pointer; transition: transform .12s, box-shadow .12s;
  position: relative; overflow: hidden;
}
.page-inventory-ageing .age-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--ac, #ccc); }
.page-inventory-ageing .age-card:hover  { transform: translateY(-1px); box-shadow: var(--shadow); }
.page-inventory-ageing .age-card.active { border-color: var(--ac); box-shadow: 0 0 0 2px color-mix(in srgb, var(--ac) 25%, transparent); }
.page-inventory-ageing .age-card .age-label { font-size:.68rem; color:var(--muted); letter-spacing:.06em; text-transform:uppercase; font-weight:600; }
.page-inventory-ageing .age-card .age-count {
  font-family: var(--font-mono); font-size: 18px; font-weight: 800; line-height: 1;
  color: var(--ac); margin-top: 6px;
  font-feature-settings: "tnum" 1; font-variant-numeric: tabular-nums;
}
.page-inventory-ageing .age-card .age-sub { font-size:.7rem; color:var(--muted); margin-top:2px; }

.page-inventory-ageing .age-c0 { --ac: #1a7a52; }
.page-inventory-ageing .age-c1 { --ac: #5a7a1a; }
.page-inventory-ageing .age-c2 { --ac: #c47f17; }
.page-inventory-ageing .age-c3 { --ac: #b9651e; }
.page-inventory-ageing .age-c4 { --ac: #b83030; }

.page-inventory-ageing .bucket-pill {
  display: inline-block; font-size:.68rem; font-weight:700;
  padding: 3px 9px; border-radius: 4px; letter-spacing:.04em;
  white-space: nowrap;
}
.page-inventory-ageing .bp-0-30  { background:#dcfce7; color:#15803d; border:1px solid #bbf7d0; }
.page-inventory-ageing .bp-31-60 { background:#ecfccb; color:#365314; border:1px solid #d9f99d; }
.page-inventory-ageing .bp-61-90 { background:#fef3c7; color:#92400e; border:1px solid #fde68a; }
.page-inventory-ageing .bp-91-180{ background:#fed7aa; color:#9a3412; border:1px solid #fdba74; }
.page-inventory-ageing .bp-181-  { background:#fecaca; color:#991b1b; border:1px solid #fca5a5; }
.page-inventory-ageing .bp-empty { background:var(--surface2); color:var(--muted); border:1px solid var(--border); }

.page-inventory-ageing .mono { font-family: var(--font-mono); }

/* ============================================================
 * .page-notification-log — notifications/log nav tabs + pills
 * ============================================================ */
.page-notification-log .nm-tabs          { display:flex; gap:4px; border-bottom:1px solid var(--border); margin: 0 0 18px; }
.page-notification-log .nm-tabs a        { padding:10px 16px; font-size:.82rem; font-weight:600; color:var(--muted); text-decoration:none; border-bottom:2px solid transparent; }
.page-notification-log .nm-tabs a.active { color:var(--accent); border-color:var(--accent); }
.page-notification-log .ok-pill          { background:#e6f7ec; color:#1a7f3a; }
.page-notification-log .fail-pill        { background:#fde8e8; color:#a8131c; }
.page-notification-log .pill             { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.7rem; font-weight:600; }
.page-notification-log .err-cell         { color:#a8131c; font-size:.72rem; max-width:280px; overflow:hidden; text-overflow:ellipsis; }

/* ============================================================
 * .page-notifications — trigger-type pills + modal tweak
 * ============================================================ */
.page-notifications .trig-pill   { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.7rem; font-weight:600; }
.page-notifications .trig-manual { background:var(--surface2); color:var(--muted); border:1px solid var(--border); }
.page-notifications .trig-event  { background:#e7f3ff; color:#0a4f8a; }
.page-notifications .trig-cron   { background:#fff3e0; color:#a85100; }
.page-notifications .modal-body label { margin-top: 8px; }

/* ============================================================
 * .page-templates — template editor grid + variable tags
 * ============================================================ */
.page-templates .tpl-grid             { display:grid; grid-template-columns: 1fr 1fr; gap:16px; align-items:start; }
.page-templates .tpl-edit textarea    { font-family: var(--font-mono); font-size:.78rem; min-height: 280px; }
.page-templates .tpl-preview          { border:1px solid var(--border); border-radius:8px; background:var(--surface); padding:14px; min-height: 280px; }
.page-templates .tpl-preview .pv-subject { font-weight:700; padding-bottom:10px; border-bottom:1px solid var(--border); margin-bottom:12px; font-size:.9rem; }
.page-templates .var-tag              { display:inline-block; padding:2px 8px; background:var(--surface2); border:1px solid var(--border); border-radius:4px; font-family:var(--font-mono); font-size:.72rem; margin:2px 3px 2px 0; cursor:pointer; }
.page-templates .var-tag:hover        { border-color: var(--accent); color: var(--accent); }
.page-templates .modal-body label     { margin-top: 8px; }
@media (max-width: 900px) {
  .page-templates .tpl-grid { grid-template-columns: 1fr; }
}

/* ============================================================
 * .page-auth — login / forgot / reset standalone pages
 * ============================================================ */
.page-auth { min-height: 100vh; display:flex; align-items:center; justify-content:center; background: var(--bg); }
.auth-wrap { width:100%; padding: 32px 16px; }
.auth-card {
  max-width: 380px; margin: 0 auto; background: var(--surface);
  border: 1px solid var(--border); border-radius: 12px;
  padding: 28px 28px 22px; box-shadow: var(--shadow);
}
.auth-brand { display:flex; align-items:center; gap:14px; margin-bottom: 22px; }
.auth-title { font-family: var(--font-head); font-weight: 800; font-size: 1.1rem; letter-spacing:-0.01em; }
.auth-sub   { font-size: 0.72rem; color: var(--muted); margin-top: 2px; }
.auth-label { display:block; font-family: var(--font-head); font-size: 0.72rem; font-weight: 600;
              color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em;
              margin: 14px 0 6px; }
.auth-input {
  width:100%; padding: 10px 12px; border: 1px solid var(--border);
  border-radius: 8px; background: var(--surface2); color: var(--text);
  font-family: var(--font-mono); font-size: 0.88rem; outline: none;
  transition: border-color .15s, background .15s;
}
.auth-input:focus { border-color: var(--accent); background: var(--surface); }
.auth-submit {
  width: 100%; margin-top: 18px; padding: 11px 14px;
  background: var(--accent); color: #fff; border: none; border-radius: 8px;
  font-family: var(--font-head); font-weight: 700; font-size: 0.85rem;
  letter-spacing: 0.04em; cursor: pointer;
  transition: background .15s, transform .05s;
}
.auth-submit:hover { background: #a96a10; }
.auth-submit:active { transform: scale(.99); }
.auth-foot { margin-top: 16px; text-align: center; font-size: 0.78rem; }
.auth-foot a { color: var(--accent); text-decoration: none; }
.auth-foot a:hover { text-decoration: underline; }
.auth-error {
  background: var(--red-bg); border: 1px solid rgba(184,48,48,0.25);
  color: var(--red); padding: 10px 12px; border-radius: 8px;
  font-size: 0.8rem; margin-bottom: 6px;
}
.auth-ok {
  background: var(--green-bg); border: 1px solid rgba(26,122,82,0.25);
  color: var(--green); padding: 10px 12px; border-radius: 8px;
  font-size: 0.8rem; margin-bottom: 6px;
}

/* ============================================================
 * .page-users — admin user manager
 * ============================================================ */
.page-users .users-table { width:100%; border-collapse: collapse; background: var(--surface); border-radius: 8px; overflow: hidden; }
.page-users .users-table th, .page-users .users-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); font-size: 0.82rem; text-align: left; }
.page-users .users-table th { background: var(--surface2); font-family: var(--font-head); font-weight: 700; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); }
.page-users .users-table tr:last-child td { border-bottom: none; }
.page-users .role-pill { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.7rem; font-weight:600; }
.page-users .role-admin   { background:#fff3e0; color:#a85100; border:1px solid rgba(196,127,23,.25); }
.page-users .role-auditor { background:var(--blue-bg); color:var(--blue); border:1px solid rgba(30,95,163,.25); }
.page-users .status-off   { background:var(--surface2); color:var(--muted); border:1px solid var(--border); padding:2px 8px; border-radius:10px; font-size:.7rem; }
.page-users .row-actions  { display:flex; gap:6px; flex-wrap: wrap; }
.page-users .row-actions form { margin: 0; }
.page-users .row-actions .action-btn { margin-left: 0; }
.page-users td form .action-btn { margin-left: 0; }

/* User menu in header (top-right) */
.user-menu { position: relative; }
.user-menu-trigger {
  display: flex; align-items: center; gap: 8px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 20px; padding: 5px 12px 5px 6px;
  font-size: 0.72rem; cursor: pointer; color: var(--text);
}
.user-menu-trigger:hover { border-color: var(--border2); }
.user-menu-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff; font-family: var(--font-head); font-weight: 700;
  font-size: 0.7rem; display:flex; align-items:center; justify-content:center;
}
.user-menu-dropdown {
  display: none; position: absolute; top: calc(100% + 6px); right: 0;
  min-width: 180px; background: var(--surface);
  border: 1px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.10); z-index: 95; padding: 6px 0;
}
.user-menu.open .user-menu-dropdown { display: block; }
.user-menu-dropdown a {
  display: block; padding: 9px 14px;
  font-size: 0.78rem; color: var(--text);
  text-decoration: none;
}
.user-menu-dropdown a:hover { background: var(--surface2); color: var(--accent); }
.user-menu-dropdown .um-sep { border-top: 1px solid var(--border); margin: 4px 0; }
.user-menu-dropdown .um-who { padding: 8px 14px; font-size: 0.72rem; color: var(--muted); }
.user-menu-dropdown .um-who b { color: var(--text); font-family: var(--font-head); }

/* ── Expiry Tracker ───────────────────────────────────────────
   Sparkline in the snapshot table + red delta column for the
   rising-SKUs table. Everything else reuses .report-table,
   .kpi-card etc. from the shared report shell.
*/
.expiry-sparkline {
  display: inline-block;
  vertical-align: middle;
  shape-rendering: geometricPrecision;
}
.delta-positive { color: #b83030; }

/* Row dismissal — shown only when "Show cleared" is on. */
.page-expiry-tracker .row-cleared > td {
  color: var(--muted);
  background: var(--surface2);
  text-decoration: line-through;
  text-decoration-color: rgba(0,0,0,.25);
}
.page-expiry-tracker .row-cleared .btn-row-act { text-decoration: none; }

.page-expiry-tracker .btn-row-act {
  font: 600 .72rem/1 var(--font-head, system-ui);
  padding: 5px 10px; border-radius: 6px;
  border: 1px solid var(--border); background: var(--surface);
  color: var(--text); cursor: pointer; white-space: nowrap;
}
.page-expiry-tracker .btn-row-act:hover { background: var(--surface2); }
.page-expiry-tracker .btn-row-act.danger { color: #b83030; border-color: #f2c4c4; }
.page-expiry-tracker .btn-row-act.danger:hover { background: #fdf0f0; }
.page-expiry-tracker .btn-row-act:disabled { opacity: .55; cursor: wait; }
