:root {
  --bg: #f6f7fb;
  --sidebar: #1a2234;
  --sidebar-ink: #d4dbe8;
  --sidebar-ink-dim: #8894a8;
  --sidebar-accent: #3a6fd5;
  --card: #ffffff;
  --ink: #15213a;
  --ink-soft: #52607a;
  --muted: #8a94a8;
  --border: #e3e7ee;
  --border-strong: #c7cedb;
  --accent: #2a5bb8;
  --accent-ink: #ffffff;
  --accent-soft: #eaf0fb;
  --warn: #c56015;
  --warn-soft: #fdf0e2;
  --err: #b32318;
  --err-soft: #fdeceb;
  --ok: #0f7a44;
  --ok-soft: #e6f4ec;
  --focus: #ffb83d;
  --shadow-sm: 0 1px 2px rgba(18,28,50,0.06);
  --shadow: 0 1px 3px rgba(18,28,50,0.08), 0 6px 20px rgba(18,28,50,0.06);
  --radius: 8px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font: 14px/1.5 -apple-system, "Segoe UI", system-ui, Roboto, "Helvetica Neue", sans-serif;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
body.app { min-height: 100vh; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
code { font: 0.9em "SF Mono", Consolas, Menlo, monospace; background: #f0f3f8; padding: 1px 5px; border-radius: 3px; color: var(--ink-soft); }
h1 { font-size: 1.55rem; font-weight: 600; margin: 0; letter-spacing: -0.01em; }
h2 { font-size: 1.05rem; font-weight: 600; margin: 0; letter-spacing: -0.005em; }
.muted { color: var(--muted); }

/* ---- Layout shell ----------------------------------------------------- */
.shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

/* ---- Sidebar ---------------------------------------------------------- */
.sidebar {
  background: var(--sidebar);
  color: var(--sidebar-ink);
  display: flex;
  flex-direction: column;
  padding: 1.25rem 0;
}
.sidebar .brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem 1.25rem;
  margin: 0 0.75rem 0.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  text-decoration: none;
}
.sidebar .brand:hover { text-decoration: none; }
.brand-logo {
  display: block;
  width: 100%;
  max-width: 170px;
  height: auto;
  border-radius: 6px;
}

.sidebar nav { flex: 1; padding: 0.9rem 0.6rem; }
.sidebar nav ul { list-style: none; padding: 0; margin: 0; }
.sidebar nav li a {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 0.55rem 0.75rem;
  border-radius: 6px;
  color: var(--sidebar-ink);
  font-size: 0.92rem;
}
.sidebar nav li a:hover {
  background: rgba(255,255,255,0.05);
  text-decoration: none;
  color: #fff;
}
.sidebar nav li.active a {
  background: rgba(58,111,213,0.18);
  color: #fff;
  box-shadow: inset 3px 0 0 var(--sidebar-accent);
}
.sidebar .nav-icon {
  display: inline-block;
  width: 20px;
  text-align: center;
  color: var(--sidebar-ink-dim);
  font-size: 1rem;
}
.sidebar nav li.active .nav-icon { color: var(--sidebar-accent); }

.sidebar-foot {
  padding: 0.9rem 1.1rem 0.2rem;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.who-name { color: #fff; font-weight: 500; font-size: 0.9rem; }
.who-role { color: var(--sidebar-ink-dim); font-size: 0.75rem; }

/* ---- Content area ----------------------------------------------------- */
.content {
  padding: 1.75rem 2.25rem 3rem;
  max-width: 1280px;
}
.page-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.page-head .eyebrow {
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 0.15rem;
}
.range-picker { font-size: 0.85rem; }

/* ---- Buttons ---------------------------------------------------------- */
button, .btn-primary, .btn-ghost {
  font: inherit;
  cursor: pointer;
  border-radius: 6px;
  padding: 0.48rem 0.95rem;
  border: 1px solid transparent;
  transition: background 0.12s, border-color 0.12s;
}
button.btn-primary, .btn-primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: #1f4aa0;
  font-weight: 500;
}
button.btn-primary:hover, .btn-primary:hover { background: #1f4aa0; }
button.btn-ghost, .btn-ghost {
  background: #fff;
  color: var(--ink);
  border-color: var(--border-strong);
  font-weight: 500;
}
button.btn-ghost:hover, .btn-ghost:hover { background: #f4f6fa; border-color: #a9b3c4; }
.btn-sm { padding: 0.3rem 0.6rem; font-size: 0.85rem; }

input[type=text], input[type=password] {
  font: inherit;
  padding: 0.48rem 0.65rem;
  border: 1px solid var(--border-strong);
  border-radius: 5px;
  background: #fff;
  color: var(--ink);
}
input:focus, button:focus, a:focus {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
}

/* ---- Tiles ------------------------------------------------------------ */
.tiles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 1.75rem;
}
.tile {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.1rem 1.1rem 1rem;
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.tile::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--border-strong);
}
.tile-primary::before { background: var(--accent); }
.tile-accent::before  { background: #0f7a44; }
.tile-warn::before    { background: var(--warn); }
.tile-label {
  font-size: 0.78rem;
  color: var(--muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 0.35rem;
}
.tile-value {
  font-size: 1.95rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.tile-sub {
  font-size: 0.8rem;
  color: var(--ink-soft);
  margin-top: 0.45rem;
}
/* Week-over-week delta pill. Arrow + sign carry the meaning; color is
   secondary so the pill is readable for colorblind users. */
.tile-delta {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 0.08rem 0.42rem;
  border-radius: 999px;
  margin-left: 0.35rem;
  vertical-align: 0.22em;
  border: 1px solid transparent;
  white-space: nowrap;
}
.tile-delta-up    { background: #e7f4ec; color: #0f6b39; border-color: #bfe0cd; }
.tile-delta-down  { background: #fceeee; color: #9b2d2d; border-color: #f1cfcf; }
.tile-delta-flat  { background: #f0f2f6; color: var(--muted); border-color: var(--border); }
.tile-delta-new   { background: #eef1fa; color: #1f4aa0; border-color: #c9d3e9; }

/* "Last call received" heartbeat under the H1 in the dashboard header. */
.last-call {
  font-size: 0.85rem;
  margin-top: 0.25rem;
}

/* ---- Grouped bar chart (Epic API daily volume) ---------------------- */
/* Two bars per day column (GetPrescriptionInfo + RequestFills). The
   bars still carry their count label so colorblind users aren't reliant
   on the swatch color alone. */
.card .chart-grouped .chart-col-grouped {
  min-width: 56px;
}
.card .chart-grouped .chart-pair {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 3px;
  height: 100%;
}
.card .chart-grouped .chart-pair .chart-bar {
  width: 18px;
  min-width: 18px;
  position: relative;
}
/* Higher specificity to beat `.card .chart .chart-bar { background: ... }`.
   Colorblind-safe: the Fill bar also gets diagonal white stripes, so the
   two bars are distinguishable from shape alone without relying on hue. */
.card .chart-grouped .chart-bar-get  { background: var(--accent); }
.card .chart-grouped .chart-bar-fill {
  background-color: #0f7a44;
  background-image: repeating-linear-gradient(
    45deg,
    rgba(255,255,255,0.35) 0 4px,
    transparent 4px 8px
  );
}

/* Inline legend swatches in the card-head muted span */
.epic-legend-swatch {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  vertical-align: middle;
  margin-right: 0.1rem;
  margin-left: 0.25rem;
  border: 1px solid rgba(0,0,0,0.1);
}
.epic-legend-get  { background: var(--accent); }
.epic-legend-fill {
  background-color: #0f7a44;
  background-image: repeating-linear-gradient(
    45deg,
    rgba(255,255,255,0.45) 0 2px,
    transparent 2px 4px
  );
}

/* ---- Cards ------------------------------------------------------------ */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  margin-bottom: 1.5rem;
}
.card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}
.card > :not(.card-head) { padding: 0 1.25rem 1.25rem; }

/* ---- Chart ------------------------------------------------------------ */
/* Higher specificity (.card .chart) is required to win over
   `.card > :not(.card-head) { padding: 0 1.25rem 1.25rem }` which would
   otherwise clamp the chart's top padding to 0 and cause the absolute-
   positioned count labels to spill above the card's top edge. */
.card .chart {
  display: flex;
  align-items: stretch;
  gap: 0.75rem;
  height: 240px;
  padding-top: 2.25rem;
  padding-bottom: 0.5rem;
}
.chart-col {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}
/* Wrapper gives us a definite-resolved parent height so the bar's height:X%
   computes correctly. Without this, height:X% against an auto-sized parent
   resolves to 0 and bars stay invisible. */
.chart-bar-wrap {
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.chart-bar {
  width: 100%;
  max-width: 48px;
  background: linear-gradient(180deg, var(--accent) 0%, #4a7fd0 100%);
  border-radius: 4px 4px 0 0;
  position: relative;
  min-height: 3px;
}
.chart-count {
  position: absolute;
  top: -1.5em;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.78rem;
  color: var(--ink-soft);
  white-space: nowrap;
}
.chart-x {
  flex-shrink: 0;
  font-size: 0.78rem;
  color: var(--muted);
  white-space: nowrap;
}

/* ---- Data table ------------------------------------------------------- */
table.data {
  width: 100%;
  border-collapse: collapse;
}
table.data th, table.data td {
  padding: 0.7rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
table.data thead th {
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  background: #f9fafc;
  border-bottom: 1px solid var(--border-strong);
}
table.data tbody tr:last-child td { border-bottom: none; }
table.data .num { text-align: right; font-variant-numeric: tabular-nums; }
.row-actions a { font-size: 0.85rem; }
.pct-bar {
  display: inline-block;
  width: 80px;
  height: 8px;
  background: var(--border);
  border-radius: 4px;
  vertical-align: middle;
  margin-right: 0.5rem;
  overflow: hidden;
}
.pct-fill {
  display: block;
  height: 100%;
  background: var(--accent);
  border-radius: 4px;
}
.pct-val { font-variant-numeric: tabular-nums; }

/* ---- Badges + day chips ---------------------------------------------- */
.badge {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  letter-spacing: 0.02em;
  border: 1px solid transparent;
  white-space: nowrap;
}
.badge-open   { background: var(--ok-soft);   color: var(--ok);   border-color: #b4dac4; }
.badge-lunch  { background: var(--warn-soft); color: var(--warn); border-color: #f2cc9d; }
.badge-closed { background: #f0f2f6;          color: var(--ink-soft); border-color: var(--border-strong); }
.badge-err    { background: var(--err-soft);  color: var(--err);  border-color: #f2b4b0; }

.ncpdp, .local-now, .reason { font-size: 0.78rem; margin-top: 2px; }

.week-head { width: 14ch; }
.week-glance { display: flex; gap: 3px; }
.day {
  display: inline-grid;
  place-items: center;
  width: 22px; height: 22px;
  border-radius: 4px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0;
  cursor: help;
  border: 1px solid transparent;
}
.day.d-open   { background: var(--ok-soft);   color: var(--ok);    border-color: #b4dac4; }
.day.d-closed { background: #f0f2f6;          color: var(--muted); border-color: var(--border); }

/* ---- Hours table specifics ------------------------------------------- */
table.hours input {
  width: 4.5em;
  padding: 0.4rem 0.35rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
table.hours td.has-error input { border-color: var(--err); background: var(--err-soft); }
.err-msg { display: block; color: var(--err); font-size: 0.78rem; margin-top: 2px; }

.quick-actions {
  padding: 0.85rem 1.25rem;
  background: #f9fafc;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}
.quick-actions .qa-label {
  font-size: 0.85rem;
  color: var(--ink-soft);
  margin-right: 0.5rem;
}
.quick-actions .btn-ghost { font-size: 0.85rem; padding: 0.35rem 0.7rem; }

.copy-from {
  padding: 0.85rem 1.25rem;
  background: #eef5ff;
  border-bottom: 1px solid #c7d8ee;
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}
.copy-from label { font-size: 0.9rem; color: var(--ink); margin: 0; }
.copy-from select {
  font: inherit;
  padding: 0.4rem 0.55rem;
  border: 1px solid var(--border-strong);
  border-radius: 5px;
  background: #fff;
  color: var(--ink);
  min-width: 240px;
}
.copy-from .qa-note { font-size: 0.8rem; margin-left: 0.25rem; }

.form-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--border);
  background: #f9fafc;
}

/* ---- Alerts ----------------------------------------------------------- */
.alert {
  padding: 0.7rem 1rem;
  border-radius: 6px;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  font-size: 0.92rem;
}
.alert-error { background: var(--err-soft); color: var(--err); border-color: #f2b4b0; }
.alert-ok    { background: var(--ok-soft);  color: var(--ok);  border-color: #b4dac4; }

/* ---- Holiday form (compact, 2-column) ------------------------------ */
.holiday-form-compact { padding: 1rem 1.25rem 0; }
.holiday-form-compact .row-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  margin-bottom: 0.9rem;
}
@media (max-width: 700px) { .holiday-form-compact .row-2col { grid-template-columns: 1fr; } }
.holiday-form-compact .field { display: flex; flex-direction: column; gap: 0.3rem; }
.holiday-form-compact .field > label {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--ink-soft);
}
.holiday-form-compact input[type="text"],
.holiday-form-compact input[type="email"],
.holiday-form-compact input[type="password"],
.holiday-form-compact input[type="date"],
.holiday-form-compact select {
  font: inherit;
  padding: 0.45rem 0.65rem;
  border: 1px solid var(--border-strong);
  border-radius: 5px;
  background: #fff;
  color: var(--ink);
}
.holiday-form-compact .time-pair {
  display: flex;
  gap: 0.6rem;
  align-items: center;
}
.holiday-form-compact .time-pair input {
  width: 5em;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.holiday-form-compact .inline-check {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.92rem;
  color: var(--ink);
  padding-top: 1.4rem;
}
.holiday-form-compact .has-error input { border-color: var(--err); background: var(--err-soft); }
.holiday-form-compact .input-with-action {
  display: flex;
  gap: 0.6rem;
  align-items: stretch;
}
.holiday-form-compact .input-with-action input { flex: 1; min-width: 0; }
.holiday-form-compact .input-with-action button { white-space: nowrap; }

/* Password rules box (used on change-password and new-account forms) */
.password-rules {
  background: #f6f8fc;
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: 5px;
  padding: 0.6rem 0.85rem;
  font-size: 0.82rem;
  color: var(--ink-soft);
  margin-top: 0.2rem;
}
.password-rules .rules-heading {
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 0.25rem;
}
.password-rules ul {
  margin: 0;
  padding-left: 1.1rem;
  line-height: 1.5;
}

/* Wider login-card variant for change-password forced mode */
.login-card-wide { width: 480px; max-width: calc(100vw - 2rem); }
.forced-banner {
  background: var(--warn-soft);
  color: var(--warn);
  border: 1px solid #f2cc9d;
  border-radius: 5px;
  padding: 0.7rem 0.9rem;
  font-size: 0.9rem;
  margin-bottom: 1rem;
  font-weight: 500;
}
.change-password-form .form-actions { margin-top: 0.5rem; }
.holiday-form-compact .muted { font-size: 0.75rem; }
.holiday-form-compact .form-actions { padding: 0.4rem 0 1rem; border: none; background: transparent; }

.form-actions-split { justify-content: space-between; }

.empty-state-inline {
  padding: 1.5rem 1.25rem;
  color: var(--muted);
  text-align: center;
  font-style: italic;
}

.danger-zone { border-color: #f2cc9d; }
.danger-zone .card-head { background: #fdf7e4; border-bottom-color: #ead9a1; }
.danger-body {
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.btn-danger {
  font: inherit;
  cursor: pointer;
  background: #fff;
  color: var(--err);
  border: 1px solid var(--err);
  padding: 0.45rem 0.9rem;
  border-radius: 5px;
  font-weight: 500;
}
.btn-danger:hover { background: var(--err); color: #fff; }

.page-head { align-items: center; }
.page-head .btn-primary { margin-left: auto; white-space: nowrap; }

/* Row tinting for holiday list */
.row-today td { background: #fdf7e4; }
.row-past td { color: var(--muted); }
.pill {
  display: inline-block;
  font-size: 0.72rem;
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
  margin-left: 0.4rem;
  font-weight: 600;
  vertical-align: middle;
}
.pill-today { background: var(--warn-soft); color: var(--warn); border: 1px solid #f2cc9d; }
.pill-past  { background: #f0f2f6; color: var(--muted); border: 1px solid var(--border); font-weight: 500; }

.inline-form { display: inline; margin: 0; padding: 0; }
.link-button {
  background: none;
  border: none;
  color: var(--accent);
  padding: 0;
  cursor: pointer;
  font: inherit;
  text-decoration: none;
}
.link-button:hover { text-decoration: underline; }
.link-danger { color: var(--err); }

.alert {
  padding: 0.7rem 1rem;
  border-radius: 6px;
  margin: 0 0 1rem;
  border: 1px solid transparent;
  font-size: 0.92rem;
}
.alert-error { background: var(--err-soft);  color: var(--err);  border-color: #f2b4b0; }
.alert-ok    { background: var(--ok-soft);   color: var(--ok);   border-color: #b4dac4; }
.alert-warn  { background: var(--warn-soft); color: var(--warn); border-color: #f2cc9d; }

/* ---- Reports filter bar --------------------------------------------- */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  padding: 1rem 1.25rem;
  align-items: flex-end;
}
.filter-field {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.filter-field label {
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
}
.filter-field input[type="date"],
.filter-field select {
  font: inherit;
  padding: 0.42rem 0.65rem;
  border: 1px solid var(--border-strong);
  border-radius: 5px;
  background: #fff;
  color: var(--ink);
}
.filter-field select { min-width: 220px; }
.filter-actions {
  flex-direction: row;
  gap: 0.5rem;
  align-self: flex-end;
  margin-left: auto;
}
.filter-actions .btn-primary,
.filter-actions .btn-ghost { white-space: nowrap; }
.chart-scrollable { overflow-x: auto; }

.report-tabs {
  display: flex;
  gap: 0.3rem;
  margin: -0.5rem 0 1rem;
  border-bottom: 1px solid var(--border);
  padding: 0 0.25rem;
}
.report-tab {
  padding: 0.55rem 1rem;
  border-radius: 6px 6px 0 0;
  color: var(--ink-soft);
  font-size: 0.9rem;
  font-weight: 500;
  border: 1px solid transparent;
  border-bottom: none;
  margin-bottom: -1px;
}
.report-tab:hover { background: #f4f6fa; color: var(--ink); text-decoration: none; }
.report-tab-active {
  background: var(--card);
  color: var(--ink);
  border-color: var(--border);
  font-weight: 600;
}

/* ---- Audit log viewer ------------------------------------------------ */
.audit-log .nowrap { white-space: nowrap; }
.audit-log .log-note { font-size: 0.85rem; color: var(--ink-soft); max-width: 340px; }
.audit-log .reason { font-size: 0.72rem; }
.audit-log .row-actions { white-space: nowrap; }

.diff-row { display: none; }
.diff-row.open { display: table-row; }
.diff-row td {
  background: #f8fafd;
  padding: 0.8rem 1.25rem;
  border-top: 1px dashed var(--border);
}
.diff-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.diff-heading {
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 0.3rem;
}
.diff-json {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 0.6rem 0.8rem;
  font-family: SFMono-Regular, Consolas, Menlo, monospace;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--ink);
  overflow-x: auto;
  margin: 0;
  max-height: 300px;
  overflow-y: auto;
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 0.9rem 1.25rem;
  border-top: 1px solid var(--border);
}

/* ---- Messages grid ---------------------------------------------------- */
.messages-grid .msg-col { text-align: center; width: 10ch; }
.messages-grid .msg-cell { text-align: center; }
.messages-grid .ncpdp { font-size: 0.78rem; margin-top: 2px; }

.toggle-box {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  padding: 0.3rem;
  border-radius: 4px;
}
.toggle-box:hover { background: var(--accent-soft); }
.toggle-box input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
}
.toggle-indicator {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--border-strong);
  border-radius: 4px;
  background: #fff;
  position: relative;
  transition: background 0.12s, border-color 0.12s;
}
.toggle-box input:checked + .toggle-indicator {
  background: var(--accent);
  border-color: var(--accent);
}
.toggle-box input:checked + .toggle-indicator::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 0px;
  width: 6px;
  height: 12px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.toggle-box input:focus + .toggle-indicator {
  outline: 3px solid var(--focus);
  outline-offset: 1px;
}
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

/* ---- Global message toggle (iOS-style switch) ----------------------- */
.global-message-card .global-message-body {
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.toggle-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  user-select: none;
}
.toggle-switch input[type="checkbox"] {
  position: absolute; opacity: 0; width: 1px; height: 1px;
}
.toggle-switch-track {
  display: inline-block;
  width: 44px; height: 24px;
  background: var(--border-strong);
  border-radius: 999px;
  position: relative;
  transition: background 0.15s;
}
.toggle-switch-thumb {
  position: absolute;
  top: 2px; left: 2px;
  width: 20px; height: 20px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: left 0.15s;
}
.toggle-switch input:checked + .toggle-switch-track { background: var(--accent); }
.toggle-switch input:checked + .toggle-switch-track .toggle-switch-thumb { left: 22px; }
.toggle-switch input:focus + .toggle-switch-track {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
}
.toggle-switch-label {
  font-size: 0.95rem;
  color: var(--ink);
  font-weight: 500;
}

.inline-alert { margin: 0; font-size: 0.88rem; }

/* ---- Known limitation notice ---------------------------------------- */
.known-limitation {
  margin-top: 1rem;
  padding: 0.85rem 1.1rem;
  background: #fdfbf0;
  border: 1px solid #ead9a1;
  border-left: 3px solid #c89a28;
  border-radius: 6px;
  font-size: 0.85rem;
  color: var(--ink-soft);
  line-height: 1.5;
}
.known-limitation strong { color: var(--ink); }

/* ---- Empty / placeholder -------------------------------------------- */
.empty-state {
  background: var(--card);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius);
  padding: 2.5rem 2rem;
  text-align: center;
  color: var(--ink-soft);
}

/* ---- Login page ------------------------------------------------------- */
body.login-page {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background: linear-gradient(135deg, #1a2234 0%, #283455 100%);
}
.login-card {
  width: 380px;
  background: var(--card);
  border-radius: 10px;
  padding: 2.25rem 2rem;
  box-shadow: 0 10px 40px rgba(10, 18, 40, 0.35);
}
.login-logo {
  display: block;
  width: 80%;
  max-width: 220px;
  margin: 0 auto 1.5rem;
  height: auto;
}
.login-card form label {
  display: block;
  margin-bottom: 0.9rem;
  font-size: 0.82rem;
  color: var(--ink-soft);
  font-weight: 500;
}
.login-card form label input {
  display: block;
  width: 100%;
  margin-top: 0.3rem;
  font-size: 0.95rem;
  padding: 0.55rem 0.7rem;
}
.login-card form button { width: 100%; padding: 0.65rem; margin-top: 0.3rem; }
.login-card .error {
  background: var(--err-soft);
  color: var(--err);
  padding: 0.6rem 0.8rem;
  border-radius: 5px;
  font-size: 0.85rem;
  margin-bottom: 1rem;
}

/* ---- Responsive tuning ----------------------------------------------- */
@media (max-width: 760px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { flex-direction: row; padding: 0.5rem 0.75rem; flex-wrap: wrap; }
  .sidebar .brand { padding: 0.4rem 0.6rem; border: none; }
  .sidebar nav { padding: 0; }
  .sidebar nav ul { display: flex; gap: 0.25rem; flex-wrap: wrap; }
  .sidebar-foot { border: none; margin-left: auto; padding: 0 0.5rem; }
  .content { padding: 1.25rem 1rem 2rem; }
  .tile-value { font-size: 1.6rem; }
}

/* ---- Sidebar foot: identity on top, unified actions row below ------- */
.sidebar .sidebar-foot {
  flex-direction: column;
  align-items: stretch;
  gap: 0.45rem;
}
.sidebar-foot-actions {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8rem;
}
.sidebar-foot-actions .inline-form { display: inline; margin: 0; padding: 0; }
.sidebar-foot-link {
  display: inline;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--sidebar-ink-dim);
  text-decoration: none;
  cursor: pointer;
}
.sidebar-foot-link:hover {
  color: #fff;
  text-decoration: underline;
}
.sidebar-foot-link:focus {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}
.sidebar-foot-sep { color: rgba(255,255,255,0.22); user-select: none; }

/* ---- Outbound reports (iteration 3) ---------------------------------- */
/* Colorblind-friendly: each call-result chip pairs a hue with a shape or
   intensity cue. Never rely on color alone. The label text is always
   present and visible. */
.report-tab-outbound { border-left: 2px solid var(--accent-soft); }
.call-result {
  display: inline-block;
  padding: 0.1rem 0.55rem;
  border-radius: 12px;
  font-size: 0.82rem;
  font-weight: 500;
  border: 1px solid transparent;
  white-space: nowrap;
}
.call-result-person-answered { background: var(--ok-soft);   color: var(--ok);   border-color: #b8e0c7; }
.call-result-answering-machine { background: #eef2fb;        color: #3f4d6e;     border-color: #d3dbf0; }
.call-result-no-answer        { background: #f3f4f7;        color: #52607a;     border-color: #dde0e8; }
.call-result-busy             { background: var(--warn-soft); color: var(--warn); border-color: #f4d3a9; }
.call-result-error            { background: var(--err-soft); color: var(--err);  border-color: #f3bfbc; }
.call-result-texted           { background: var(--accent-soft); color: var(--accent); border-color: #c7d6ee; }
.call-result-picked-up        { background: #eef7ea;        color: #3b6b2a;     border-color: #c5e0b5; }
.call-result-unknown          { background: #f0f0f3;        color: #888;        border-color: #dcdce0; font-style: italic; }

table.outbound-records td code {
  background: transparent;
  padding: 0;
  color: var(--ink);
  font-size: 0.88rem;
}

/* Pagination controls for the records table. */
.pager {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  justify-content: center;
  padding: 1rem 0 0.25rem;
}
.pager-link {
  padding: 0.35rem 0.8rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: #fff;
  color: var(--accent);
  text-decoration: none;
  font-size: 0.88rem;
}
.pager-link:hover { background: var(--accent-soft); text-decoration: none; }
.pager-link-disabled {
  color: var(--muted);
  pointer-events: none;
  background: #fafbfd;
  border-color: var(--border);
}
.pager-state {
  color: var(--ink-soft);
  font-size: 0.85rem;
}

/* ---- Idle-timeout warning modal -------------------------------------- */
/* Not dismissible by backdrop click or ESC — user must explicitly choose
   "Stay signed in" or "Log out" (see session-idle.js). If they do
   nothing, JS redirects to /login?reason=idle when countdown hits 0. */
.idle-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.idle-modal[hidden] { display: none; }
.idle-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 25, 40, 0.55);
}
.idle-modal-card {
  position: relative;
  width: 400px;
  max-width: calc(100vw - 2rem);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.5rem 1.5rem 1.25rem;
}
.idle-modal-card:focus { outline: none; }
.idle-modal-title {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 0.5rem;
  letter-spacing: -0.005em;
}
.idle-modal-desc {
  margin: 0 0 1.25rem;
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.5;
}
.idle-modal-countdown {
  display: inline-block;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--warn);
  font-variant-numeric: tabular-nums;
  min-width: 2ch;
  text-align: center;
  padding: 0 0.15rem;
}
.idle-modal-actions {
  display: flex;
  gap: 0.6rem;
  align-items: center;
  justify-content: flex-end;
}
.idle-modal-actions .inline-form { display: inline; margin: 0; padding: 0; }
