/* Clinic Silo — Teal theme override */
/* Overrides the master brand teal (#2596BE) with Clinic Teal (#0E7490) */
:root {
  --primary-500:  #0E7490;
  --primary-600:  #0C6280;
  --primary-700:  #0A5270;
  --primary-400:  #22AECF;
  --primary-300:  #67CEDF;
  --primary-200:  #A5E4EE;
  --primary-100:  #CFFAFE;
  --primary-50:   #ECFEFF;
  --primary-950:  #082F3E;
  --accent:       var(--primary-500);
  --accent-hover: var(--primary-600);
  --accent-press: var(--primary-700);
  --accent-soft:  var(--primary-50);
  --sp-color-primary:       var(--primary-500);
  --sp-color-primary-hover: var(--primary-600);
  --sp-color-primary-dark:  var(--primary-700);

  /* Orange semantic (used for allergies, No Show status) */
  --orange-500: #EA580C;
  --orange-50:  #FFF7ED;
  --orange-100: #FFEDD5;

  /* Named semantic colours used in badge helpers */
  --fg-success: var(--success-600);
  --fg-warning: var(--warning-600);
  --fg-danger:  var(--danger-600);
  --fg-info:    var(--info-600);
  --fg-orange:  var(--orange-500);
}

/* ── Extra badge variants ───────────────────────────────────────── */
.badge-teal {
  background: var(--primary-50);
  color: var(--primary-700);
}
.badge-teal .dot { background: var(--primary-500); }

.badge-info {
  background: var(--info-50);
  color: var(--info-700);
}
.badge-info .dot { background: var(--info-500); }

.badge-orange {
  background: var(--orange-100);
  color: var(--orange-500);
}
.badge-orange .dot { background: var(--orange-500); }

/* ── Stat chip (small icon+label card used on Comms/Dashboard) ── */
.stat-chip {
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.stat-chip__icon {
  width: 36px; height: 36px;
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.stat-chip__label {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--fg-3);
}
.stat-chip__value { font-size: 22px; font-weight: 700; color: var(--fg-1); }

/* ── KPI card ───────────────────────────────────────────────────── */
.kpi-card {
  background: #fff;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex; flex-direction: column; gap: 10px;
}
.kpi-card__label {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--fg-3);
}
.kpi-card__value { font-size: 28px; font-weight: 700; color: var(--fg-1); letter-spacing: -.02em; }
.kpi-card__sub   { font-size: 12px; color: var(--fg-3); }
.kpi-card__trend {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 12px; font-weight: 600;
}
.kpi-card__trend--up   { color: var(--fg-success); }
.kpi-card__trend--down { color: var(--fg-danger);  }

/* ── Step stepper ───────────────────────────────────────────────── */
.sp-stepper {
  display: flex; align-items: center;
  background: #fff; border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: 16px 20px;
}
.sp-stepper__step {
  display: flex; align-items: center; gap: 10px;
}
.sp-stepper__circle {
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
  font-size: 12px; font-weight: 700;
  flex-shrink: 0;
  border: 2px solid var(--border-subtle);
  background: #fff; color: var(--fg-4);
}
.sp-stepper__circle--done    { background: var(--primary-500); border-color: var(--primary-500); color: #fff; }
.sp-stepper__circle--active  { border-color: var(--primary-500); color: var(--primary-600); background: #fff; }
.sp-stepper__label { font-size: 13px; font-weight: 500; color: var(--fg-4); white-space: nowrap; }
.sp-stepper__label--active { color: var(--fg-1); font-weight: 600; }
.sp-stepper__label--done   { color: var(--fg-2); }
.sp-stepper__line { flex: 1; height: 2px; background: var(--border-subtle); margin: 0 12px; }
.sp-stepper__line--done { background: var(--primary-500); }

/* ── Week calendar ──────────────────────────────────────────────── */
.sp-week-cal { display: flex; flex-direction: column; overflow: hidden; }
.sp-week-cal__head {
  display: grid;
  grid-template-columns: 60px repeat(7, 1fr);
  border-bottom: 1px solid var(--border-subtle);
  background: var(--neutral-25, #fafbfc);
}
.sp-week-cal__day-hd {
  padding: 10px 8px; text-align: center;
  border-left: 1px solid var(--border-subtle);
}
.sp-week-cal__day-hd--today { background: var(--primary-50); }
.sp-week-cal__dow {
  font-size: 10px; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--fg-3);
}
.sp-week-cal__day-hd--today .sp-week-cal__dow { color: var(--primary-600); }
.sp-week-cal__date { font-size: 18px; font-weight: 700; color: var(--fg-1); margin-top: 2px; }
.sp-week-cal__day-hd--today .sp-week-cal__date { color: var(--primary-600); }

.sp-week-cal__body { flex: 1; overflow-y: auto; }
.sp-week-cal__grid {
  display: grid;
  grid-template-columns: 60px repeat(7, 1fr);
  position: relative;
}
.sp-week-cal__hour-lbl {
  padding: 4px 8px;
  font-size: 10.5px; font-weight: 600; color: var(--fg-4);
  text-align: right; line-height: 1;
}
.sp-week-cal__day-col {
  position: relative;
  border-left: 1px solid var(--border-subtle);
}
.sp-week-cal__day-col--today { background: rgba(14,116,144,.02); }
.sp-week-cal__hour-cell { border-bottom: 1px solid var(--neutral-100, #eceff3); }
.sp-week-cal__event {
  position: absolute; left: 3px; right: 3px;
  border-radius: 4px; padding: 4px 7px;
  overflow: hidden; cursor: pointer;
  font-size: 11.5px; border-left-width: 3px; border-left-style: solid;
  box-sizing: border-box;
}
.sp-week-cal__event:hover { filter: brightness(.97); }
.sp-week-cal__now-line {
  position: absolute; left: 0; right: 0;
  height: 2px; background: var(--primary-500); z-index: 2;
}
.sp-week-cal__now-dot {
  position: absolute; left: -5px; top: -4px;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--primary-500);
}

/* appointment event colour variants */
.sp-cal-ev--scheduled { background: rgba(37,99,235,.07); border-color: #2563EB; }
.sp-cal-ev--confirmed { background: rgba(14,116,144,.08); border-color: var(--primary-500); }
.sp-cal-ev--inprogress{ background: rgba(217,119,6,.10);  border-color: #D97706; }
.sp-cal-ev--completed { background: rgba(5,150,105,.07);  border-color: #059669; }
.sp-cal-ev--cancelled { background: rgba(107,114,128,.09);border-color: #6B7280; }
.sp-cal-ev--noshow    { background: rgba(234,88,12,.08);  border-color: #EA580C; }

/* ── Outstanding balance gradient card ─────────────────────────── */
.balance-card {
  background: linear-gradient(160deg, var(--primary-500), var(--primary-700));
  border-radius: var(--radius-lg);
  padding: 20px;
  color: #fff;
}
.balance-card__label { font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; opacity: .85; }
.balance-card__amount { font-size: 32px; font-weight: 700; letter-spacing: -.02em; margin-top: 4px; font-variant-numeric: tabular-nums; }
.balance-card__divider { border-top: 1px solid rgba(255,255,255,.2); margin-top: 14px; padding-top: 14px; display: flex; justify-content: space-between; }
.balance-card__stat-lbl { font-size: 11px; opacity: .85; }
.balance-card__stat-val { font-size: 14px; font-weight: 600; margin-top: 2px; }
.balance-card__bar-track {
  margin-top: 12px; height: 6px; border-radius: 4px;
  background: rgba(255,255,255,.25); overflow: hidden;
}
.balance-card__bar-fill { height: 100%; background: #fff; border-radius: 4px; }
.balance-card__pct { margin-top: 6px; font-size: 11px; opacity: .85; text-align: right; }

/* ── Payment method tiles ───────────────────────────────────────── */
.pay-method-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.pay-method-tile {
  padding: 10px 4px; border: 1.5px solid var(--border-subtle);
  border-radius: var(--radius-md); background: #fff; cursor: pointer;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  font-size: 11.5px; font-weight: 600; color: var(--fg-3);
  transition: border-color var(--dur-fast), background var(--dur-fast), color var(--dur-fast);
}
.pay-method-tile:hover { border-color: var(--border-default); color: var(--fg-1); }
.pay-method-tile--active {
  border-color: var(--primary-500); background: var(--primary-50);
  color: var(--primary-700);
}
