/* ============================================================
   DOCTECQ PMS — Design System
   Single source of truth for all visual tokens & components.
   Applies to: Main Software, Reception, Bill Module, Patient App
   ============================================================ */

/* ── 1. GOOGLE FONTS IMPORT ───────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── 2. DESIGN TOKENS (CSS Custom Properties) ─────────────── */
:root {
  /* Brand Colors */
  --clr-primary:       #2E5077;
  --clr-primary-dark:  #1e3a5f;
  --clr-primary-light: #3d6491;
  --clr-accent:        #2E5077;
  --clr-accent-dark:   #1e3a5f;
  --clr-accent-light:  #3d6491;

  /* Specialty accent overrides — applied via body class */
  --clr-specialty:     #2E5077; /* default = dental teal */

  /* Surface & Background */
  --clr-bg:            #F2F5FA;
  --clr-surface:       #FFFFFF;
  --clr-surface-2:     #F8FAFC;
  --clr-border:        rgba(0, 0, 0, 0.07);
  --clr-border-strong: rgba(0, 0, 0, 0.12);

  /* Text */
  --clr-text:          #1A2332;
  --clr-text-muted:    #6B7A8F;
  --clr-text-light:    #9AABB8;

  /* Status Colors */
  --clr-success:       #16A34A;
  --clr-success-bg:    #F0FDF4;
  --clr-danger:        #DC2626;
  --clr-danger-bg:     #FEF2F2;
  --clr-warning:       #D97706;
  --clr-warning-bg:    #FFFBEB;
  --clr-info:          #2563EB;
  --clr-info-bg:       #EFF6FF;

  /* Spacing Scale */
  --sp-1:  4px;
  --sp-2:  8px;
  --sp-3:  12px;
  --sp-4:  16px;
  --sp-5:  20px;
  --sp-6:  24px;
  --sp-8:  32px;
  --sp-10: 40px;
  --sp-12: 48px;

  /* Border Radius */
  --r-xs:  4px;
  --r-sm:  8px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  28px;
  --r-2xl: 36px;
  --r-full: 9999px;

  /* Shadows */
  --sh-xs:  0 1px 2px rgba(0, 0, 0, 0.06);
  --sh-sm:  0 1px 4px rgba(0, 0, 0, 0.07), 0 2px 8px rgba(0, 0, 0, 0.05);
  --sh-md:  0 4px 16px rgba(0, 0, 0, 0.08), 0 1px 4px rgba(0, 0, 0, 0.04);
  --sh-lg:  0 8px 32px rgba(0, 0, 0, 0.10), 0 2px 8px rgba(0, 0, 0, 0.06);
  --sh-xl:  0 16px 48px rgba(0, 0, 0, 0.12), 0 4px 16px rgba(0, 0, 0, 0.08);

  /* Typography */
  --font-body:    'Inter', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-heading: 'Inter', system-ui, -apple-system, sans-serif;
  --font-display: 'Cormorant Garamond', 'Times New Roman', serif;
  --font-mono:    'SF Mono', 'Fira Code', 'Consolas', monospace;

  /* Font Sizes */
  --text-xs:   11px;
  --text-sm:   13px;
  --text-base: 14px;
  --text-md:   15px;
  --text-lg:   17px;
  --text-xl:   20px;
  --text-2xl:  24px;
  --text-3xl:  30px;

  /* Line Heights */
  --lh-tight:  1.25;
  --lh-snug:   1.375;
  --lh-normal: 1.5;
  --lh-relaxed:1.625;

  /* Motion */
  --dur-instant: 80ms;
  --dur-fast:    120ms;
  --dur-normal:  240ms;
  --dur-slow:    400ms;
  --dur-slower:  600ms;
  --ease:        cubic-bezier(0.4, 0, 0.2, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-out:    cubic-bezier(0, 0, 0.2, 1);
  --ease-in:     cubic-bezier(0.4, 0, 1, 1);

  /* Z-Index Scale */
  --z-below:    -1;
  --z-base:     0;
  --z-raised:   10;
  --z-dropdown: 100;
  --z-sticky:   200;
  --z-overlay:  300;
  --z-modal:    400;
  --z-toast:    500;
  --z-preloader: 12000;
  --z-top:      9999;

  /* Gradients */
  --grad-primary: linear-gradient(135deg, var(--clr-primary), var(--clr-accent));
  --grad-sidebar: linear-gradient(180deg, #1a3a52 0%, #2E5077 100%);
  --grad-surface: linear-gradient(180deg, var(--clr-surface) 0%, var(--clr-surface-2) 100%);

  /* Device safe areas (iOS notch / gesture bar) */
  --safe-top:    env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left:   env(safe-area-inset-left, 0px);
  --safe-right:  env(safe-area-inset-right, 0px);

  /* App shell metrics — single source for layout math */
  --nav-h:       60px;
  --sidebar-w:   250px;
  --bottomnav-h: 62px;

  /* Semantic aliases — used in component overrides for clarity */
  --card-bg:    var(--clr-surface);
  --text-main:  var(--clr-text);
  --text-muted: var(--clr-text-muted);
}

/* Specialty theme overrides */
body.dental  { --clr-specialty: #2E5077; }
body.opth    { --clr-specialty: #7B5EA7; }
body.homeo   { --clr-specialty: #2D9D78; }
body.general { --clr-specialty: #3A86C8; }

/* ── 3. BASE RESETS & GLOBAL STYLES ───────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--clr-text);
  line-height: var(--lh-normal);
  background-color: var(--clr-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: var(--lh-tight);
  color: var(--clr-text);
}

a {
  color: var(--clr-accent);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease);
}
a:hover { color: var(--clr-accent-dark); }

/* ── 4. DOCTECQ BRAND SYSTEM ─────────────────────────────── */

.doctecq-wordmark-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  margin: 0;
  filter: none;
  font-family: var(--font-display);
  font-size: clamp(34px, 4vw, 56px);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  white-space: nowrap;
}

.doctecq-wordmark-logo.is-light {
  color: #ffffff;
  text-shadow: 0 8px 24px rgba(0,0,0,0.18);
}

.doctecq-wordmark-logo.is-dark {
  color: #111111;
}

.doctecq-wordmark-logo.is-compact {
  font-size: clamp(22px, 2vw, 34px);
  letter-spacing: 0.18em;
}

.doctecq-wordmark-logo.is-xs {
  font-size: clamp(16px, 1.4vw, 24px);
  letter-spacing: 0.16em;
}

.doctecq-brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.doctecq-brand-lockup__mark {
  width: 44px;
  height: 44px;
  object-fit: contain;
  flex-shrink: 0;
}

/* Portfolio-style preloader */
#preloader {
  position: fixed;
  inset: 0;
  z-index: var(--z-preloader);
  background:
    radial-gradient(circle at 18% 24%, rgba(124, 63, 255, 0.09), transparent 30%),
    radial-gradient(circle at 80% 20%, rgba(0, 229, 255, 0.08), transparent 26%),
    linear-gradient(180deg, rgba(11, 12, 18, 0.98), rgba(17, 18, 28, 0.98));
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-5);
  transition: opacity 0.6s var(--ease), visibility 0.6s var(--ease);
}

#preloader.dismissing {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

#preloader.dismissed {
  display: none;
}

.preloader-logo {
  width: 88px;
  height: 70px;
}

#preloader-svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}

.draw-path {
  fill: none;
  stroke-linecap: round;
  stroke-dasharray: var(--path-length);
  stroke-dashoffset: var(--path-length);
}

.draw-path.animating {
  animation: doctecqPreloaderDraw 1s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

#arc-1 { animation-delay: 0s; }
#arc-2 { animation-delay: 0.08s; }
#arc-3 { animation-delay: 0.16s; }
#arc-4 { animation-delay: 0.24s; }
#arc-5 { animation-delay: 0.32s; }
#arc-6 { animation-delay: 0.40s; }
#stem  { animation-delay: 0s; }

.preloader-wordmark {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.96);
  opacity: 0;
  transform: translateY(8px);
}

.preloader-tagline {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.58);
  opacity: 0;
  transform: translateY(8px);
}

.preloader-progress {
  width: 128px;
  height: 1px;
  background: rgba(255,255,255,0.14);
  border-radius: var(--r-full);
  overflow: hidden;
  opacity: 0;
}

.preloader-bar {
  width: 0%;
  height: 100%;
  background: linear-gradient(90deg, #7C3FFF 0%, #00E5FF 100%);
  border-radius: var(--r-full);
  transition: width 240ms var(--ease);
}

.preloader-glow {
  position: absolute;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 229, 255, 0.16) 0%, rgba(124, 63, 255, 0.08) 35%, transparent 70%);
  filter: blur(20px);
  opacity: 0;
  transform: scale(0.88);
}

.preloader-glow.visible,
.preloader-progress.visible,
.preloader-wordmark.visible,
.preloader-tagline.visible {
  animation: doctecqPreloaderFadeIn 0.55s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

.preloader-glow.visible {
  animation: doctecqPreloaderGlow 2.2s ease-in-out infinite alternate;
}

@keyframes doctecqPreloaderDraw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes doctecqPreloaderFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes doctecqPreloaderGlow {
  0% {
    opacity: 0.45;
    transform: scale(0.9);
  }
  100% {
    opacity: 0.95;
    transform: scale(1.08);
  }
}

@media (max-width: 575px) {
  .doctecq-wordmark-logo {
    font-size: clamp(26px, 8vw, 40px);
    letter-spacing: 0.18em;
  }

  .doctecq-wordmark-logo.is-compact {
    font-size: clamp(20px, 6vw, 28px);
  }

  .preloader-logo {
    width: 76px;
    height: 60px;
  }

  .preloader-wordmark {
    font-size: 1.02rem;
    letter-spacing: 0.2em;
  }
}

/* ── 5. CARD COMPONENTS ───────────────────────────────────── */

/* Base card */
.pms-card {
  background: var(--clr-surface);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-md);
  border: 1px solid var(--clr-border);
  overflow: hidden;
  animation: pmsCardIn var(--dur-normal) var(--ease) both;
}

.pms-card:hover {
  box-shadow: var(--sh-lg);
  transition: box-shadow var(--dur-normal) var(--ease);
}

.pms-card-body {
  padding: var(--sp-4);
}

.pms-card-header {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
}

.pms-card-title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--clr-text);
  margin: 0;
}

.pms-card-subtitle {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin: 2px 0 0;
}

/* Stat card (dashboard numbers) */
.pms-stat-card {
  background: var(--clr-surface);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-md);
  border: 1px solid var(--clr-border);
  padding: var(--sp-6);
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  transition: box-shadow var(--dur-normal) var(--ease),
              transform var(--dur-normal) var(--ease);
  animation: pmsCardIn var(--dur-normal) var(--ease) both;
  cursor: default;
}
.pms-stat-card:hover {
  box-shadow: var(--sh-lg);
  transform: translateY(-2px);
}

.pms-stat-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}

.pms-stat-icon.navy    { background: rgba(46,80,119,0.10); color: var(--clr-primary); }
.pms-stat-icon.teal    { background: rgba(77,161,169,0.12); color: var(--clr-accent); }
.pms-stat-icon.green   { background: rgba(22,163,74,0.10);  color: var(--clr-success); }
.pms-stat-icon.amber   { background: rgba(217,119,6,0.10);  color: var(--clr-warning); }

.pms-stat-value {
  font-size: var(--text-3xl);
  font-weight: 800;
  color: var(--clr-text);
  line-height: 1;
  margin: 0;
}

.pms-stat-label {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin: 4px 0 0;
  font-weight: 500;
}

/* ── 5. SECTION TITLE ─────────────────────────────────────── */
.pms-section-title {
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--clr-text);
  padding-left: var(--sp-3);
  border-left: 3px solid var(--clr-accent);
  margin-bottom: var(--sp-4);
  line-height: var(--lh-tight);
}

.pms-section-label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-3);
  display: block;
}

/* ── 6. BUTTONS ───────────────────────────────────────────── */
.pms-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1;
  padding: 9px 18px;
  border-radius: var(--r-sm);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition:
    background-color var(--dur-fast) var(--ease),
    border-color     var(--dur-fast) var(--ease),
    color            var(--dur-fast) var(--ease),
    box-shadow       var(--dur-fast) var(--ease),
    transform        var(--dur-fast) var(--ease);
  white-space: nowrap;
  text-decoration: none;
  user-select: none;
  min-height: 38px;
}

.pms-btn:hover    { transform: translateY(-1px); box-shadow: var(--sh-sm); }
.pms-btn:active   { transform: translateY(0);    box-shadow: none; }
.pms-btn:disabled { opacity: 0.55; cursor: not-allowed; transform: none; box-shadow: none; }

/* Primary */
.pms-btn-primary {
  background: var(--clr-primary);
  color: #fff;
  border-color: var(--clr-primary);
}
.pms-btn-primary:hover {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: #fff;
}

/* Accent */
.pms-btn-accent {
  background: var(--clr-accent);
  color: #fff;
  border-color: var(--clr-accent);
}
.pms-btn-accent:hover {
  background: var(--clr-accent-dark);
  border-color: var(--clr-accent-dark);
  color: #fff;
}

/* Ghost */
.pms-btn-ghost {
  background: transparent;
  color: var(--clr-primary);
  border-color: var(--clr-primary);
}
.pms-btn-ghost:hover {
  background: var(--clr-primary);
  color: #fff;
}

/* Danger */
.pms-btn-danger {
  background: var(--clr-danger);
  color: #fff;
  border-color: var(--clr-danger);
}
.pms-btn-danger:hover {
  background: #b91c1c;
  border-color: #b91c1c;
  color: #fff;
}

/* Success */
.pms-btn-success {
  background: var(--clr-success);
  color: #fff;
  border-color: var(--clr-success);
}
.pms-btn-success:hover {
  background: #15803d;
  border-color: #15803d;
  color: #fff;
}

/* Loading state */
.pms-btn.is-loading {
  pointer-events: none;
  opacity: 0.75;
}
.pms-btn.is-loading::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: pmsSpin 0.6s linear infinite;
  margin-right: 6px;
  flex-shrink: 0;
}

/* Sizes */
.pms-btn-sm { padding: 6px 12px; font-size: var(--text-xs); min-height: 30px; }
.pms-btn-lg { padding: 12px 24px; font-size: var(--text-md); min-height: 46px; }

/* ── 7. BADGES / STATUS CHIPS ─────────────────────────────── */
.pms-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 3px 10px;
  border-radius: var(--r-full);
  white-space: nowrap;
  line-height: 1.4;
}

.pms-chip-new        { background: #F1F5F9; color: #475569; }
.pms-chip-checkin    { background: rgba(77,161,169,0.12); color: #287178; }
.pms-chip-checkout   { background: var(--clr-success-bg); color: var(--clr-success); }
.pms-chip-rescheduled{ background: var(--clr-warning-bg); color: var(--clr-warning); }
.pms-chip-pending    { background: var(--clr-warning-bg); color: var(--clr-warning); }
.pms-chip-paid       { background: var(--clr-success-bg); color: var(--clr-success); }
.pms-chip-partial    { background: var(--clr-info-bg);    color: var(--clr-info); }
.pms-chip-cancelled  { background: var(--clr-danger-bg);  color: var(--clr-danger); }
.pms-chip-primary    { background: rgba(46,80,119,0.10);  color: var(--clr-primary); }
.pms-chip-accent     { background: rgba(77,161,169,0.12); color: var(--clr-accent-dark); }

/* ── 8. AVATAR ────────────────────────────────────────────── */
.pms-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--clr-primary), var(--clr-accent));
  letter-spacing: 0.03em;
}
.pms-avatar-sm { width: 30px; height: 30px; font-size: var(--text-xs); }
.pms-avatar-lg { width: 48px; height: 48px; font-size: var(--text-md); }

/* ── 9. FORM INPUTS ───────────────────────────────────────── */
.pms-input,
.pms-select,
.pms-textarea {
  display: block;
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--clr-text);
  background: var(--clr-surface);
  border: 1.5px solid var(--clr-border-strong);
  border-radius: var(--r-sm);
  padding: 9px 12px;
  line-height: var(--lh-normal);
  transition:
    border-color var(--dur-fast) var(--ease),
    box-shadow   var(--dur-fast) var(--ease);
  outline: none;
  min-height: 40px;
}

.pms-input:focus,
.pms-select:focus,
.pms-textarea:focus {
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px rgba(77, 161, 169, 0.15);
}

.pms-input::placeholder,
.pms-textarea::placeholder { color: var(--clr-text-light); }

.pms-input-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--clr-text);
  margin-bottom: 6px;
}

/* ── 10. TABLE ────────────────────────────────────────────── */
.pms-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  background: var(--clr-surface);
}

.pms-table thead tr {
  border-bottom: 2px solid var(--clr-border);
}

.pms-table thead th {
  padding: 10px 14px;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  white-space: nowrap;
  background: var(--clr-surface-2);
}

.pms-table tbody td {
  padding: 11px 14px;
  color: var(--clr-text);
  border-bottom: 1px solid var(--clr-border);
  vertical-align: middle;
}

.pms-table tbody tr:last-child td { border-bottom: none; }

.pms-table tbody tr:hover td {
  background: rgba(77, 161, 169, 0.04);
  transition: background var(--dur-fast) var(--ease);
}

/* ── 11. SKELETON LOADING ─────────────────────────────────── */
.pms-skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: pmsShimmer 1.4s ease-in-out infinite;
  border-radius: var(--r-sm);
  display: block;
}

.pms-skeleton-text  { height: 14px; margin: 6px 0; }
.pms-skeleton-title { height: 20px; width: 60%; margin: 8px 0; }
.pms-skeleton-row   { height: 44px; margin: 4px 0; border-radius: var(--r-xs); }

/* ── 12. PAGE HEADER ──────────────────────────────────────── */
.pms-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
  flex-wrap: wrap;
}

.pms-page-title {
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--clr-text);
  margin: 0 0 4px;
  line-height: var(--lh-tight);
}

.pms-page-subtitle {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin: 0;
}

/* ── 13. APPOINTMENT CARD ─────────────────────────────────── */
.pms-appt-card {
  background: var(--clr-surface);
  border-radius: var(--r-md);
  border: 1px solid var(--clr-border);
  box-shadow: var(--sh-xs);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  transition:
    box-shadow var(--dur-fast) var(--ease),
    transform  var(--dur-fast) var(--ease),
    border-color var(--dur-fast) var(--ease);
  animation: pmsCardIn var(--dur-normal) var(--ease) both;
}

.pms-appt-card:hover {
  box-shadow: var(--sh-md);
  transform: translateY(-1px);
  border-color: var(--clr-accent-light);
}

.pms-appt-time {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--clr-primary);
  white-space: nowrap;
  min-width: 60px;
  text-align: center;
}

.pms-appt-info { flex: 1; min-width: 0; }
.pms-appt-name {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--clr-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0 0 2px;
}
.pms-appt-meta {
  font-size: var(--text-xs);
  color: var(--clr-text-muted);
  margin: 0;
}
.pms-appt-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
}

/* Status change animation */
.pms-appt-card.status-changed {
  animation: pmsStatusFlash 0.6s var(--ease) forwards;
}

/* ── 14. EMPTY STATE ──────────────────────────────────────── */
.pms-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-12) var(--sp-6);
  text-align: center;
  color: var(--clr-text-muted);
}

.pms-empty-state i {
  font-size: 48px;
  margin-bottom: var(--sp-4);
  opacity: 0.3;
  color: var(--clr-text-muted);
}

.pms-empty-title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--clr-text);
  margin: 0 0 var(--sp-2);
}

.pms-empty-text {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin: 0;
  max-width: 300px;
}

/* ── 15. DIVIDER ──────────────────────────────────────────── */
.pms-divider {
  border: none;
  border-top: 1px solid var(--clr-border);
  margin: var(--sp-4) 0;
}

/* ── 16. GLASS SURFACE (used by top-nav, modals) ─────────── */
.pms-glass {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255, 255, 255, 0.5);
}

/* ── 17. SWAL OVERRIDES (brand theming) ───────────────────── */
.swal2-popup {
  font-family: var(--font-body) !important;
  border-radius: var(--r-xl) !important;
}
.swal2-title {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: var(--clr-text) !important;
}
.swal2-html-container {
  font-size: var(--text-base) !important;
  color: var(--clr-text-muted) !important;
}
.swal2-confirm {
  background-color: var(--clr-primary) !important;
  border-radius: var(--r-sm) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  padding: 9px 24px !important;
  font-size: var(--text-sm) !important;
}
.swal2-cancel {
  border-radius: var(--r-sm) !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  padding: 9px 24px !important;
  font-size: var(--text-sm) !important;
}
.swal2-icon { border-color: transparent !important; }
.swal2-icon.swal2-success { color: var(--clr-success) !important; }
.swal2-icon.swal2-error   { color: var(--clr-danger)  !important; }
.swal2-icon.swal2-warning { color: var(--clr-warning) !important; }

/* Toast SweetAlert */
.swal2-toast.swal2-popup {
  border-radius: var(--r-md) !important;
  box-shadow: var(--sh-lg) !important;
  padding: 12px 16px !important;
}

/* ── 18. SCROLLBAR ────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--clr-border-strong);
  border-radius: var(--r-full);
}
::-webkit-scrollbar-thumb:hover { background: var(--clr-text-light); }

/* ── 19. UTILITY CLASSES ──────────────────────────────────── */
.pms-fw-500 { font-weight: 500; }
.pms-fw-600 { font-weight: 600; }
.pms-fw-700 { font-weight: 700; }
.pms-fw-800 { font-weight: 800; }

.pms-text-primary { color: var(--clr-primary); }
.pms-text-accent  { color: var(--clr-accent);  }
.pms-text-muted   { color: var(--clr-text-muted); }
.pms-text-danger  { color: var(--clr-danger);  }
.pms-text-success { color: var(--clr-success); }

.pms-bg-surface   { background: var(--clr-surface); }
.pms-bg-bg        { background: var(--clr-bg); }

.pms-rounded-sm  { border-radius: var(--r-sm);  }
.pms-rounded-md  { border-radius: var(--r-md);  }
.pms-rounded-lg  { border-radius: var(--r-lg);  }
.pms-rounded-xl  { border-radius: var(--r-xl);  }
.pms-rounded-full{ border-radius: var(--r-full);}

.pms-shadow-sm { box-shadow: var(--sh-sm); }
.pms-shadow-md { box-shadow: var(--sh-md); }
.pms-shadow-lg { box-shadow: var(--sh-lg); }

/* Stagger animation delays for lists */
.pms-stagger > *:nth-child(1)  { animation-delay: 0ms;   }
.pms-stagger > *:nth-child(2)  { animation-delay: 40ms;  }
.pms-stagger > *:nth-child(3)  { animation-delay: 80ms;  }
.pms-stagger > *:nth-child(4)  { animation-delay: 120ms; }
.pms-stagger > *:nth-child(5)  { animation-delay: 160ms; }
.pms-stagger > *:nth-child(6)  { animation-delay: 200ms; }
.pms-stagger > *:nth-child(7)  { animation-delay: 240ms; }
.pms-stagger > *:nth-child(8)  { animation-delay: 280ms; }
.pms-stagger > *:nth-child(n+9){ animation-delay: 320ms; }

/* ── 20. KEYFRAME ANIMATIONS ──────────────────────────────── */
@keyframes pmsCardIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0);    }
}

@keyframes pmsFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes pmsFadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0);    }
}

@keyframes pmsFadeInDown {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0);     }
}

@keyframes pmsSlideUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0);    }
}

@keyframes pmsSlideDown {
  from { transform: translateY(0);    }
  to   { transform: translateY(100%); }
}

@keyframes pmsSpin {
  to { transform: rotate(360deg); }
}

@keyframes pmsShimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

@keyframes pmsStatusFlash {
  0%   { background: rgba(22,163,74,0.12); }
  100% { background: var(--clr-surface);   }
}

@keyframes pmsPulse {
  0%, 100% { opacity: 1;   }
  50%       { opacity: 0.5; }
}

@keyframes pmsCountUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0);   }
}

/* ── 21. RESPONSIVE HELPERS ───────────────────────────────── */
@media (max-width: 768px) {
  .pms-page-title { font-size: var(--text-xl); }
  .pms-card-body  { padding: var(--sp-4); }
  .pms-stat-value { font-size: var(--text-2xl); }
}

/* ── 22. MOBILE POLISH ────────────────────────────────────── */

/* Prevent iOS from zooming into inputs on focus */
@media (max-width: 767px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="number"],
  input[type="password"],
  input[type="search"],
  input[type="date"],
  input[type="time"],
  select,
  textarea {
    font-size: max(16px, 1em);
  }
}

/* Remove tap flash on interactive elements */
.pms-btn,
.btn,
.pms-chip,
a {
  -webkit-tap-highlight-color: transparent;
}

/* Clickable elements: use manipulation so browser doesn't wait for double-tap */
button,
[type="button"],
[type="submit"],
[role="button"],
a {
  touch-action: manipulation;
}

/* Smooth momentum scrolling on iOS */
.pms-card,
.pms-table-wrap,
[class*="overflow-"] {
  -webkit-overflow-scrolling: touch;
}

/* ── 23. PRINT RESET ──────────────────────────────────────── */
@media print {
  .support-badge,
  .mobile-bottom-nav,
  .sidebar,
  .pms-btn { display: none !important; }
}

/* ── 24. DARK MODE ────────────────────────────────────────── */
[data-theme="dark"] {
  --clr-primary:       #4e7db8;
  --clr-primary-dark:  #3a6299;
  --clr-primary-light: #6494cc;
  --clr-accent:        #5bbac2;
  --clr-accent-dark:   #4aa5ad;
  --clr-accent-light:  #7dcdd3;

  --clr-bg:            #0f1219;
  --clr-surface:       #1a2030;
  --clr-surface-2:     #222a3a;
  --clr-border:        rgba(255,255,255,0.08);
  --clr-border-strong: rgba(255,255,255,0.14);

  --clr-text:          #e8edf5;
  --clr-text-muted:    #8a9ab8;
  --clr-text-light:    #5a6a82;

  --clr-success-bg:    rgba(22,163,74,0.15);
  --clr-danger-bg:     rgba(220,38,38,0.15);
  --clr-warning-bg:    rgba(217,119,6,0.15);
  --clr-info-bg:       rgba(37,99,235,0.15);

  --sh-sm:  0 1px 4px rgba(0,0,0,0.3), 0 2px 8px rgba(0,0,0,0.2);
  --sh-md:  0 4px 16px rgba(0,0,0,0.35), 0 1px 4px rgba(0,0,0,0.2);
  --sh-lg:  0 8px 32px rgba(0,0,0,0.4),  0 2px 8px rgba(0,0,0,0.25);

  /* Semantic aliases mirrored for dark mode */
  --card-bg:    var(--clr-surface);
  --text-main:  var(--clr-text);
  --text-muted: var(--clr-text-muted);
}

[data-theme="dark"] body,
[data-theme="dark"] .page-body-wrapper,
[data-theme="dark"] .content-wrapper {
  background-color: var(--clr-bg) !important;
  color: var(--clr-text) !important;
}

[data-theme="dark"] .navbar,
[data-theme="dark"] .navbar-menu-wrapper,
[data-theme="dark"] .navbar-brand-wrapper {
  background: var(--clr-surface) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .sidebar {
  background: linear-gradient(180deg, #131c2e 0%, #1a2540 100%) !important;
}

/* Sidebar always has a dark bg — keep link text white regardless of theme */
[data-theme="dark"] .sidebar .nav .nav-item .nav-link {
  color: rgba(255, 255, 255, 0.72) !important;
}

[data-theme="dark"] .sidebar .nav .nav-link i,
[data-theme="dark"] .sidebar .nav .nav-link .fa,
[data-theme="dark"] .sidebar .nav .nav-link .fas,
[data-theme="dark"] .sidebar .nav .nav-link .far,
[data-theme="dark"] .sidebar .nav .nav-link .fab,
[data-theme="dark"] .sidebar .nav .nav-link .fa-solid,
[data-theme="dark"] .sidebar .nav .nav-link .fa-regular {
  color: rgba(255, 255, 255, 0.85) !important;
  opacity: 1 !important;
}

[data-theme="dark"] .sidebar .nav .nav-item.active > .nav-link {
  color: #fff !important;
  background: rgba(77, 161, 169, 0.18) !important;
}

[data-theme="dark"] .sidebar .nav .nav-item.active > .nav-link i,
[data-theme="dark"] .sidebar .nav .nav-item.active > .nav-link .fa-solid,
[data-theme="dark"] .sidebar .nav .nav-item.active > .nav-link .fa-regular {
  color: #2E5077 !important;
  opacity: 1 !important;
}

[data-theme="dark"] .sidebar .nav .nav-item:hover > .nav-link {
  color: #fff !important;
  background: rgba(255, 255, 255, 0.07) !important;
}

/* Sidebar section separator labels */
[data-theme="dark"] .sidebar-sep span {
  color: rgba(255, 255, 255, 0.28) !important;
}

/* Sidebar brand sub-text */
[data-theme="dark"] .sidebar-brand-clinic {
  color: rgba(255, 255, 255, 0.58) !important;
}

[data-theme="dark"] .card,
[data-theme="dark"] .pms-card {
  background: var(--clr-surface) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .pms-card-header {
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .table,
[data-theme="dark"] .pms-table {
  background: var(--clr-surface) !important;
  color: var(--clr-text) !important;
}

[data-theme="dark"] .table thead th,
[data-theme="dark"] .pms-table thead th {
  background: var(--clr-surface-2) !important;
  color: var(--clr-text-muted) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .table tbody td,
[data-theme="dark"] .pms-table tbody td {
  border-color: var(--clr-border) !important;
  color: var(--clr-text) !important;
}

[data-theme="dark"] .table-striped tbody tr:nth-of-type(odd),
[data-theme="dark"] .table-hover tbody tr:hover {
  background: var(--clr-surface-2) !important;
}

/* Bootstrap .table-light uses its own CSS vars — override them explicitly */
[data-theme="dark"] .table-light,
[data-theme="dark"] .table-light > :not(caption) > * > * {
  --bs-table-bg: var(--clr-surface-2) !important;
  --bs-table-color: var(--clr-text) !important;
  --bs-table-border-color: var(--clr-border) !important;
  --bs-table-striped-bg: var(--clr-surface) !important;
  --bs-table-hover-bg: rgba(91, 186, 194, 0.07) !important;
  background-color: var(--clr-surface-2) !important;
  color: var(--clr-text) !important;
  border-color: var(--clr-border) !important;
}

/* Bootstrap table-striped: override the accent-bg CSS variable */
[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) > * {
  --bs-table-accent-bg: transparent;
  background-color: var(--clr-surface-2) !important;
  color: var(--clr-text) !important;
}

[data-theme="dark"] .form-control,
[data-theme="dark"] .pms-input,
[data-theme="dark"] .pms-select,
[data-theme="dark"] .pms-textarea,
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: var(--clr-surface-2) !important;
  color: var(--clr-text) !important;
  border-color: var(--clr-border-strong) !important;
}

[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] input::placeholder { color: var(--clr-text-light) !important; }

[data-theme="dark"] .modal-content {
  background: var(--clr-surface) !important;
  color: var(--clr-text) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer {
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .dropdown-menu {
  background: var(--clr-surface) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .dropdown-item {
  color: var(--clr-text) !important;
}

[data-theme="dark"] .dropdown-item:hover {
  background: var(--clr-surface-2) !important;
}

[data-theme="dark"] h1, [data-theme="dark"] h2, [data-theme="dark"] h3,
[data-theme="dark"] h4, [data-theme="dark"] h5, [data-theme="dark"] h6,
[data-theme="dark"] .pms-card-title, [data-theme="dark"] .pms-page-title {
  color: var(--clr-text) !important;
}

[data-theme="dark"] .pms-skeleton {
  background: linear-gradient(90deg, #1e2535 25%, #252e42 50%, #1e2535 75%);
  background-size: 200% 100%;
}

[data-theme="dark"] .swal2-popup {
  background: var(--clr-surface) !important;
  color: var(--clr-text) !important;
}

/* Time slots in dark mode */
[data-theme="dark"] .timeSelect,
[data-theme="dark"] .timeSelect.btn {
  color: var(--clr-text) !important;
  background: var(--clr-surface-2) !important;
  border-color: var(--clr-border-strong) !important;
}

[data-theme="dark"] .timeSelect:hover {
  background: var(--clr-primary) !important;
  color: #fff !important;
  border-color: var(--clr-primary) !important;
}

/* Number cards (stat cards using old w-col layout) */
[data-theme="dark"] .number-card,
[data-theme="dark"] .number-card-content1 {
  background: var(--clr-surface) !important;
  color: var(--clr-text) !important;
}

[data-theme="dark"] .number-card-number,
[data-theme="dark"] .number-card-currency {
  color: var(--clr-text) !important;
}

/* Generic Bootstrap card override */
[data-theme="dark"] .card,
[data-theme="dark"] .card-body,
[data-theme="dark"] .card-header,
[data-theme="dark"] .card-footer {
  background-color: var(--clr-surface) !important;
  color: var(--clr-text) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .card-title,
[data-theme="dark"] .card-text {
  color: var(--clr-text) !important;
}

/* Inputs, selects in dark mode (broader catch) */
[data-theme="dark"] .form-select {
  background-color: var(--clr-surface-2) !important;
  color: var(--clr-text) !important;
  border-color: var(--clr-border-strong) !important;
}

/* Dark mode toggle button */
.dark-mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: 1.5px solid var(--clr-border-strong);
  border-radius: var(--r-full);
  padding: 5px 14px;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--clr-text);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  white-space: nowrap;
}
.dark-mode-toggle:hover {
  background: var(--clr-primary);
  color: #fff;
  border-color: var(--clr-primary);
}
.dark-mode-toggle .dm-icon { font-size: 15px; }

/* ── 26. NAVBAR REDESIGN: BRAND + TOOL STRIP ─────────────── */

/* Navbar wrapper */
.navbar-menu-wrapper {
  background: var(--clr-surface, #fff) !important;
}

[data-theme="dark"] .navbar-menu-wrapper {
  background: var(--clr-surface, #1a2030) !important;
}

/* Clinic brand (left side) */
.pms-clinic-name {
  border-left: 1.5px solid var(--clr-border-strong);
  padding-left: 12px;
  line-height: 1.25;
}

.pms-clinic-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.pms-clinic-title {
  font-family: var(--font-heading);
  font-size: 13px;
  font-weight: 700;
  color: var(--clr-primary);
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0;
}

/* Uniform icon buttons (right-side tool strip) */
.pms-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(46, 80, 119, 0.07);
  color: var(--clr-primary);
  cursor: pointer;
  transition: background 0.18s var(--ease), color 0.18s var(--ease), transform 0.12s var(--ease);
  text-decoration: none;
  font-size: 15px;
  flex-shrink: 0;
  position: relative;
  line-height: 1;
}

.pms-icon-btn:hover,
.pms-icon-btn:focus-visible {
  background: var(--clr-primary);
  color: #fff !important;
  transform: scale(1.07);
  outline: none;
  text-decoration: none;
}

.pms-icon-btn:active { transform: scale(0.96); }

[data-theme="dark"] .pms-icon-btn {
  background: rgba(255, 255, 255, 0.07);
  color: var(--clr-text-muted);
}

[data-theme="dark"] .pms-icon-btn:hover,
[data-theme="dark"] .pms-icon-btn:focus-visible {
  background: var(--clr-primary);
  color: #fff !important;
}

/* Notification badge on icon buttons */
.pms-badge-dot {
  position: absolute;
  top: 1px;
  right: 1px;
  min-width: 16px;
  height: 16px;
  border-radius: 999px;
  background: var(--clr-danger, #DC2626);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0 3px;
  border: 1.5px solid var(--clr-surface, #fff);
}

[data-theme="dark"] .pms-badge-dot {
  border-color: var(--clr-surface);
}

/* Expanding search pill */
.pms-search-wrap { position: relative; }

.pms-search-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(46, 80, 119, 0.07);
  border: 1.5px solid transparent;
  border-radius: 999px;
  padding: 0;
  gap: 0;
  height: 36px;
  width: 36px;
  overflow: hidden;
  cursor: pointer;
  transition: width 0.28s cubic-bezier(0.4, 0, 0.2, 1),
              border-color 0.2s ease,
              background 0.2s ease,
              box-shadow 0.2s ease;
}

/* Match the closed search trigger's optical centering with the circular nav buttons. */
.pms-search-pill:not(.open):not(:focus-within) .pms-search-input {
  display: none;
  width: 0;
  max-width: 0;
  opacity: 0;
  pointer-events: none;
}

.pms-search-pill:not(.open):not(:focus-within) .pms-search-icon {
  width: 100%;
  min-width: 100%;
  font-size: 15px;
}

.pms-search-pill.open,
.pms-search-pill:focus-within {
  justify-content: flex-start;
  width: 230px;
  cursor: text;
  background: var(--clr-surface, #fff);
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px rgba(46, 80, 119, 0.10);
  padding: 0 10px;
  gap: 7px;
}

.pms-search-pill .pms-search-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-primary);
  font-size: 15px;
  flex-shrink: 0;
  width: 16px;
  min-width: 16px;
  line-height: 1;
  pointer-events: none;
}

.pms-search-input {
  border: none;
  background: transparent;
  outline: none;
  flex: 0 0 0;
  font-size: 13px;
  color: var(--clr-text);
  font-family: var(--font-body);
  min-width: 0;
  width: 0;
  padding: 0;
  transition: width 0.28s var(--ease);
}

.pms-search-pill.open .pms-search-input,
.pms-search-pill:focus-within .pms-search-input {
  display: block;
  flex: 1 1 auto;
  width: 170px;
  max-width: 170px;
  opacity: 1;
  pointer-events: auto;
}

.pms-search-input::placeholder { color: var(--clr-text-light); }

/* Floating search results */
.pms-search-results {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 290px;
  max-height: 340px;
  overflow-y: auto;
  background: var(--clr-surface);
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.13), 0 2px 8px rgba(0,0,0,0.07);
  border: 1px solid var(--clr-border);
  z-index: 9999;
  animation: pmsDropIn 0.18s var(--ease) both;
}

.pms-search-results.active { display: block; }

@keyframes pmsDropIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Dropdown menu refinements */
.pms-nav-dropdown {
  background: var(--clr-surface) !important;
  border: 1px solid var(--clr-border) !important;
  padding: 6px 0 !important;
}

.pms-nav-dropdown .dropdown-item {
  border-radius: 8px;
  margin: 1px 6px;
  padding: 7px 10px;
  font-size: 13px;
  transition: background 0.15s ease;
}

.pms-nav-dropdown .dropdown-item:hover {
  background: rgba(46, 80, 119, 0.08) !important;
  color: var(--clr-primary) !important;
}

[data-theme="dark"] .pms-nav-dropdown {
  background: var(--clr-surface) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .pms-nav-dropdown .dropdown-item { color: var(--clr-text) !important; }

[data-theme="dark"] .pms-nav-dropdown .dropdown-item:hover {
  background: rgba(78, 125, 184, 0.12) !important;
  color: var(--clr-accent) !important;
}

/* Dark mode: search pill */
[data-theme="dark"] .pms-search-pill {
  background: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .pms-search-pill.open,
[data-theme="dark"] .pms-search-pill:focus-within {
  background: var(--clr-surface-2);
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px rgba(78, 125, 184, 0.15);
}

[data-theme="dark"] .pms-search-results {
  background: var(--clr-surface);
  border-color: var(--clr-border);
  box-shadow: 0 8px 32px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.25);
}

/* Dark mode: appointment info bar */
[data-theme="dark"] .appointment-box {
  background: var(--clr-surface) !important;
  border-color: var(--clr-border) !important;
  color: var(--clr-text) !important;
}

[data-theme="dark"] .appointment-box .info { color: var(--clr-text) !important; }
[data-theme="dark"] .appointment-box .highlight { color: var(--clr-accent) !important; }

/* Dark mode layering: deeper bg + elevated card surfaces */
[data-theme="dark"] .container-scroller {
  background-color: var(--clr-bg) !important;
}

[data-theme="dark"] .pms-card {
  background: var(--clr-surface) !important;
  border: 1px solid var(--clr-border) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.3), 0 1px 4px rgba(0,0,0,0.18) !important;
}

[data-theme="dark"] .pms-card-body { background: transparent !important; }

[data-theme="dark"] #patient_table_container,
[data-theme="dark"] .container_patient_data_tbl,
[data-theme="dark"] .bg-light {
  background-color: var(--clr-surface-2) !important;
  color: var(--clr-text) !important;
}

[data-theme="dark"] .input-group-text {
  background: var(--clr-surface-2) !important;
  border-color: var(--clr-border-strong) !important;
  color: var(--clr-text-muted) !important;
}

[data-theme="dark"] .checkin-card,
[data-theme="dark"] .selected-doc-preview {
  background: var(--clr-surface-2) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .checkin-title,
[data-theme="dark"] .checkin-subtitle { color: var(--clr-text) !important; }

[data-theme="dark"] .form-label,
[data-theme="dark"] label { color: var(--clr-text) !important; }

[data-theme="dark"] small.text-muted { color: var(--clr-text-muted) !important; }

[data-theme="dark"] .nav-pills .nav-link { color: var(--clr-text-muted) !important; }
[data-theme="dark"] .nav-pills .nav-link.active { color: #fff !important; }

/* Stat cards elevated in dark mode */
[data-theme="dark"] .number-card {
  background: var(--clr-surface) !important;
  border: 1px solid var(--clr-border) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.28), 0 1px 4px rgba(0,0,0,0.15) !important;
}

/* Toggle card (used in patient registration form) */
.pms-toggle-card {
  background: var(--clr-surface-2, #f8fafc);
  border: 1px solid var(--clr-border-strong, #e5e7eb);
}

[data-theme="dark"] .pms-toggle-card {
  background: var(--clr-surface-2) !important;
  border-color: var(--clr-border) !important;
}

/* Dark mode: index.php hardcoded light backgrounds */
[data-theme="dark"] .checkin-card,
[data-theme="dark"] [style*="background:#f8fafc"],
[data-theme="dark"] [style*="background: #f8fafc"] {
  background: var(--clr-surface-2) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .doctor-option-box {
  background: var(--clr-surface-2) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .selected-doc-preview,
[data-theme="dark"] [style*="background:linear-gradient(135deg,#f8fbff"] {
  background: var(--clr-surface-2) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .pt_filter { background: transparent !important; }

[data-theme="dark"] .nav-pills .nav-link:not(.active) {
  background: var(--clr-surface-2) !important;
  color: var(--clr-text-muted) !important;
}

/* ── DARK MODE: APPOINTMENT TITLE BAR CONTRAST ───────────── */
/* Give "Scheduled Appointment" / "Today's Appointment Booked" headers
   a visually distinct band so they don't merge into the card body */
[data-theme="dark"] .container_patient_data_tbl h4,
[data-theme="dark"] #patient_table_container h4 {
  background: var(--clr-surface-2) !important;
  color: var(--clr-text) !important;
  border-bottom: 1px solid var(--clr-border) !important;
  margin: 0 !important;
}

/* ── DARK MODE: STAT CARD ICONS ──────────────────────────── */
/* rgba(46,80,119,0.10) on #1a2030 is near-invisible — boost opacity */
[data-theme="dark"] .number-card-icon.ic-navy  { background: rgba(78,125,184,0.22) !important;  color: var(--clr-primary) !important; }
[data-theme="dark"] .number-card-icon.ic-teal  { background: rgba(91,186,194,0.20) !important;  color: var(--clr-accent) !important;  }
[data-theme="dark"] .number-card-icon.ic-amber { background: rgba(217,119,6,0.22) !important;   color: var(--clr-warning) !important; }
[data-theme="dark"] .number-card-icon.ic-green { background: rgba(22,163,74,0.22) !important;   color: var(--clr-success) !important; }

[data-theme="dark"] .pms-stat-icon.navy  { background: rgba(78,125,184,0.22) !important;  color: var(--clr-primary) !important; }
[data-theme="dark"] .pms-stat-icon.teal  { background: rgba(91,186,194,0.20) !important;  color: var(--clr-accent) !important;  }
[data-theme="dark"] .pms-stat-icon.green { background: rgba(22,163,74,0.22) !important;   color: var(--clr-success) !important; }
[data-theme="dark"] .pms-stat-icon.amber { background: rgba(217,119,6,0.22) !important;   color: var(--clr-warning) !important; }

/* ── DARK MODE: MOBILE BOTTOM NAV ────────────────────────── */
[data-theme="dark"] .mobile-bottom-nav {
  background: rgba(19, 26, 44, 0.97) !important;
  border-color: var(--clr-border) !important;
}
[data-theme="dark"] .mobile-bottom-nav a {
  color: var(--clr-text-muted) !important;
}
[data-theme="dark"] .mobile-bottom-nav a.active,
[data-theme="dark"] .mobile-bottom-nav a.active i {
  color: var(--clr-accent) !important;
}

/* Dark mode: more-menu pop-up */
[data-theme="dark"] .more-menu {
  background: var(--clr-surface) !important;
  border-color: var(--clr-border) !important;
}
[data-theme="dark"] .more-menu a {
  color: var(--clr-text-muted) !important;
}
[data-theme="dark"] .more-menu a:hover,
[data-theme="dark"] .more-menu a.active {
  color: var(--clr-accent) !important;
}

/* Navbar responsive: hide clinic name below 480px */
@media (max-width: 479px) {
  .pms-clinic-name { display: none !important; }
  .pms-search-pill.open,
  .pms-search-pill:focus-within { width: 180px; }
  .pms-search-pill.open .pms-search-input,
  .pms-search-pill:focus-within .pms-search-input { width: 120px; }
  .pms-search-results { min-width: 240px; right: -40px; }
}

/* ── 25. MOBILE RESPONSIVE LAYOUT ────────────────────────── */

/* Mobile patient cards (shown only on small screens) */
.patient-mobile-card {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
  margin-bottom: var(--sp-3);
  box-shadow: var(--sh-xs);
}

.patient-mobile-card .pm-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.patient-mobile-card .pm-initial {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clr-primary), var(--clr-accent));
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.patient-mobile-card .pm-name {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--clr-text);
  margin: 0 0 2px;
}

.patient-mobile-card .pm-meta {
  font-size: var(--text-xs);
  color: var(--clr-text-muted);
  margin: 0;
}

.patient-mobile-card .pm-actions {
  display: flex;
  gap: var(--sp-2);
  margin-top: var(--sp-3);
  flex-wrap: wrap;
}

.patient-mobile-card .pm-actions .btn,
.patient-mobile-card .pm-actions a {
  flex: 1;
  min-width: 0;
  font-size: var(--text-xs);
  padding: 8px 6px;
  border-radius: var(--r-sm);
  text-align: center;
  touch-action: manipulation;
}

/* Time slot grid responsive */
.time-slot-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

@media (max-width: 767px) {
  .time-slot-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}

/* Appointment slot buttons responsive */
.appt-slot-btn {
  width: 100%;
  padding: 8px 4px;
  font-size: var(--text-xs);
  border-radius: var(--r-sm);
  text-align: center;
  touch-action: manipulation;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Sidebar mobile improvements */
@media (max-width: 991px) {
  .sidebar {
    z-index: 9998 !important;
  }

  .sidebar-offcanvas {
    position: fixed !important;
    left: -264px;
    top: 0;
    height: 100vh;
    z-index: 9998;
    transition: left 0.3s ease;
  }

  .sidebar-offcanvas.active {
    left: 0 !important;
  }
}

/* Sidebar slide-in on mobile via .show class (toggled by hamburger) */
@media (max-width: 991px) {
  .sidebar:not(.show) {
    transform: translateX(-100%);
    position: fixed !important;
    top: 60px;
    left: 0;
    height: calc(100vh - 60px);
    width: 250px;
    overflow-y: auto;
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 9998 !important;
    box-shadow: none;
  }

  .sidebar.show {
    transform: translateX(0) !important;
    position: fixed !important;
    top: 60px;
    left: 0;
    height: calc(100vh - 60px);
    width: 250px;
    overflow-y: auto;
    z-index: 9998 !important;
    box-shadow: var(--sh-xl) !important;
  }
}

/* Sidebar overlay */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 9997;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.sidebar-overlay.active {
  display: block;
}

/* ── §29j. DENSITY PASS — content area (Phase 1 shell revamp) ─
   Override SkyDash's content-wrapper default (38px) with plan
   tokens. The @media (max-width:767px) rule below retains the
   mobile value (16px 12px) by cascade order (later = wins). */
.content-wrapper {
  padding: var(--sp-5) !important; /* 20px desktop, down from 38px */
}

@media (max-width: 991px) {
  .content-wrapper {
    padding: var(--sp-4) !important; /* 16px tablet */
  }
}
/* Note: @media (max-width:767px) below sets 16px 12px — still applies. */

/* Touch-friendly nav items */
@media (max-width: 767px) {
  .sidebar .nav .nav-item .nav-link {
    padding: 14px 20px !important;
    font-size: 15px !important;
  }

  .navbar-toggler {
    padding: 8px !important;
    border-radius: var(--r-sm) !important;
  }

  /* Stack registration form fields on mobile */
  .pt_regist .row.g-3 > [class*="col-"] {
    width: 100% !important;
  }

  /* Stat cards: 2 per row on mobile */
  .pms-stat-card {
    padding: var(--sp-4) !important;
    gap: var(--sp-3) !important;
  }

  .pms-stat-icon {
    width: 42px !important;
    height: 42px !important;
    font-size: 18px !important;
  }

  /* Doctor list card: full width on mobile */
  .grid-margin.stretch-card {
    max-width: 100% !important;
  }

  /* Week nav buttons: larger touch targets */
  #prevWeekButton,
  #nextWeekButton {
    padding: 10px 14px !important;
    font-size: 16px !important;
  }

  /* Page body padding */
  .content-wrapper {
    padding: 16px 12px !important;
  }

  /* Section cards */
  .pms-card-body {
    padding: var(--sp-3) !important;
  }

  .pms-page-title { font-size: 18px !important; }

  /* Tables — horizontal scroll on mobile */
  .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* Bottom nav for mobile (quick-access shortcuts) */
.pms-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--clr-surface);
  border-top: 1px solid var(--clr-border);
  box-shadow: 0 -4px 16px rgba(0,0,0,0.08);
  z-index: 9997;
  padding: 8px 0 max(8px, env(safe-area-inset-bottom));
}

.pms-bottom-nav-inner {
  display: flex;
  justify-content: space-around;
  align-items: center;
}

.pms-bottom-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 4px 16px;
  color: var(--clr-text-muted);
  text-decoration: none;
  font-size: 10px;
  font-weight: 600;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.pms-bottom-nav-item i { font-size: 20px; }
.pms-bottom-nav-item.active { color: var(--clr-primary); }
.pms-bottom-nav-item:hover { color: var(--clr-primary); }

@media (max-width: 767px) {
  .pms-bottom-nav { display: block; }
  /* Pad content above bottom nav */
  .page-body-wrapper { padding-bottom: 72px !important; }
}

/* ── 27. FLUID LAYOUT — MAIN PANEL ───────────────────────── */
/*
 * sidebar is position:fixed so it doesn't participate in flex flow.
 * main-panel uses margin-left:250px (set in sidebar.inc.php) to stay
 * clear of it. Adding transition here makes the offset animate when
 * the sidebar slides in/out on mobile, and min-width:0 prevents
 * flex children from overflowing when panels or modals open.
 */
.main-panel {
  flex: 1 1 auto;
  min-width: 0;
  transition: margin-left 0.3s ease;
  will-change: margin-left;
}

.page-body-wrapper {
  display: flex;
  min-height: 100vh;
  flex-direction: row;
  flex-wrap: nowrap;
}

/* When sidebar closes on mobile, content re-centres smoothly */
@media (max-width: 991px) {
  .main-panel {
    margin-left: 0 !important;
  }
}

/* Stat cards — float layout is used; do NOT set float:none here */

/* ── 28. PAGE-SPECIFIC DARK MODE ─────────────────────────── */

/* .main-panel — youtube.php sets background-color:#ffffff inline */
[data-theme="dark"] .main-panel {
  background-color: var(--clr-bg) !important;
  background: var(--clr-bg) !important;
}

/* settings.php — uses its own --card/--text/--muted vars defined in an
 * inline <style> that is parsed AFTER design-system.css, so the vars
 * can't be overridden via [data-theme="dark"] :root. Target elements directly. */
[data-theme="dark"] .setting-card {
  background: var(--clr-surface) !important;
  background-image: none !important;
  border-color: var(--clr-border) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.28), 0 1px 4px rgba(0,0,0,0.15) !important;
}

[data-theme="dark"] .setting-card h5 {
  color: var(--clr-text) !important;
}

[data-theme="dark"] .setting-card p {
  color: var(--clr-text-muted) !important;
}

[data-theme="dark"] .setting-card .btn {
  background: var(--clr-surface-2) !important;
  color: var(--clr-primary) !important;
  border-color: var(--clr-primary) !important;
}

[data-theme="dark"] .setting-card .btn:hover,
[data-theme="dark"] .setting-card .btn:focus {
  background: var(--clr-primary) !important;
  color: #fff !important;
}

[data-theme="dark"] .setting-icon {
  color: var(--clr-accent) !important;
}

/* settings.php breadcrumb */
[data-theme="dark"] .settings-grid .breadcrumb {
  color: var(--clr-text-muted) !important;
}

/* youtube.php — hardcoded colors that bypass the generic .card override */
[data-theme="dark"] .video-card .card {
  background: var(--clr-surface) !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .video-title {
  color: var(--clr-text) !important;
}

[data-theme="dark"] .page-title-heading {
  color: var(--clr-text) !important;
}

[data-theme="dark"] #searchInput {
  background: var(--clr-surface-2) !important;
  color: var(--clr-text) !important;
  border-color: var(--clr-border-strong) !important;
}

[data-theme="dark"] #searchInput::placeholder {
  color: var(--clr-text-light) !important;
}

[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer {
  background: var(--clr-surface-2) !important;
}

/* birthdays.php — inline <style> sets body bg, .main-card, .summary-box,
 * and text colors with hardcoded values that override generic rules. */
[data-theme="dark"] .main-card {
  background: var(--clr-surface) !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.32) !important;
}

[data-theme="dark"] .page-title {
  color: var(--clr-text) !important;
}

[data-theme="dark"] .summary-box {
  background: var(--clr-surface-2) !important;
  border-left-color: var(--clr-accent) !important;
}

[data-theme="dark"] .summary-box h3,
[data-theme="dark"] .summary-box h5 {
  color: var(--clr-text) !important;
}

[data-theme="dark"] .nav-pills .nav-link {
  color: var(--clr-text-muted) !important;
}

[data-theme="dark"] .nav-pills .nav-link.active {
  background-color: var(--clr-primary) !important;
  color: #fff !important;
}

/* calender.php & birthdays modal — FullCalendar v5/v6 default bg is #fff */
[data-theme="dark"] .fc {
  background: var(--clr-surface) !important;
  color: var(--clr-text) !important;
  --fc-border-color: var(--clr-border) !important;
  --fc-page-bg-color: var(--clr-surface) !important;
  --fc-neutral-bg-color: var(--clr-surface-2) !important;
  --fc-today-bg-color: rgba(77,161,169,0.12) !important;
}

[data-theme="dark"] .fc .fc-toolbar-title {
  color: var(--clr-text) !important;
}

[data-theme="dark"] .fc .fc-daygrid-day-number,
[data-theme="dark"] .fc .fc-col-header-cell-cushion {
  color: var(--clr-text-muted) !important;
}

[data-theme="dark"] .fc .fc-daygrid-day,
[data-theme="dark"] .fc .fc-timegrid-slot,
[data-theme="dark"] .fc th,
[data-theme="dark"] .fc td {
  background: transparent !important;
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .fc .fc-scrollgrid,
[data-theme="dark"] .fc .fc-scrollgrid-section > td,
[data-theme="dark"] .fc .fc-scrollgrid-section > th {
  border-color: var(--clr-border) !important;
}

[data-theme="dark"] .fc .fc-list-day-cushion {
  background: var(--clr-surface-2) !important;
}

[data-theme="dark"] .fc .fc-list-event:hover td {
  background: var(--clr-surface-2) !important;
}

/* calender.php — .card already covered by the generic rule above;
 * only the .card-body background needs an explicit override here because
 * calender.php's inline <style> sets .fc { background-color:#fff } on the
 * FullCalendar root which sits inside .card-body. */

/* ============================================================
   29. RESPONSIVE SHELL FOUNDATION  (2026-06 shell revamp)
   Shared by: Main Software, Reception, Bill Module, Patient App
   ============================================================ */

/* Dark-mode mirror of gradient token */
[data-theme="dark"] {
  --grad-sidebar: linear-gradient(180deg, #131c2e 0%, #1a2540 100%);
}

/* ── 29a. FOCUS TREATMENT ─────────────────────────────────── */
/* Replaces the old global `:focus` glow that lived in top_nav.inc.php.
   Mouse focus stays clean; keyboard focus gets a clear brand ring;
   form fields keep a visible focus ring on any input modality. */
:focus { outline: 0; }

:focus-visible {
  outline: 2px solid var(--clr-accent);
  outline-offset: 2px;
  border-radius: 4px;
}

input:focus, select:focus, textarea:focus,
.form-control:focus, .form-select:focus {
  border-color: var(--clr-accent) !important;
  box-shadow: 0 0 0 3px rgba(77, 161, 169, 0.18) !important;
  outline: 0;
}

/* ── 29b. REDUCED MOTION ──────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ── 29c. BODY SCROLL LOCK (drawer / sheet open) ──────────── */
body.pms-lock {
  overflow: hidden;
  touch-action: none;
}

/* ── 29d. OFFCANVAS & MODAL — MOBILE SAFETY ───────────────── */
/* Offcanvas panels must never exceed the viewport on phones.
   (Width itself stays each module's choice — reception uses 560px,
   the main shell 450px — so only cap at the viewport edge here.) */
.offcanvas {
  max-width: 100vw;
}

@media (max-width: 575px) {
  /* Modals breathe on small screens; content respects safe areas */
  .modal-dialog {
    margin: var(--sp-3);
    margin-top: max(var(--sp-3), var(--safe-top));
  }
  .modal-content {
    border-radius: var(--r-lg);
    max-height: calc(100dvh - (var(--sp-3) * 2) - var(--safe-top) - var(--safe-bottom));
  }
  .modal-body {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .offcanvas-body {
    padding-bottom: calc(var(--sp-4) + var(--safe-bottom));
  }
}

/* ── 29e. SWEETALERT — RESPONSIVE PRESENTATION ────────────── */
@media (max-width: 575px) {
  .swal2-popup:not(.swal2-toast) {
    width: min(92vw, 400px) !important;
    padding: 1.1em 1em 1.4em !important;
    font-size: 14px !important;
  }
  .swal2-popup:not(.swal2-toast) .swal2-title { font-size: 17px !important; }
  .swal2-actions { flex-wrap: wrap; gap: 8px; }
  .swal2-confirm, .swal2-cancel { min-height: 42px; }

  /* Toasts dock above the bottom nav, full-width pill */
  .swal2-container.swal2-bottom,
  .swal2-container.swal2-bottom-end,
  .swal2-container.swal2-bottom-start {
    bottom: calc(var(--bottomnav-h) + var(--safe-bottom) + 8px) !important;
    padding: 0 10px !important;
  }
  .swal2-toast.swal2-popup { width: auto !important; max-width: 94vw; }
}

/* ── 29f. MOBILE BOTTOM NAV (app-style) ───────────────────── */
/* Markup lives in each shell's sidebar partial; styling is shared. */
.mobile-bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid rgba(46, 80, 119, 0.10);
  display: flex;
  justify-content: space-around;
  align-items: stretch;
  z-index: 9999;
  min-height: var(--bottomnav-h);
  padding: 6px 4px calc(6px + var(--safe-bottom));
  box-shadow: 0 -4px 20px rgba(46, 80, 119, 0.08);
}

.mobile-bottom-nav a {
  flex: 1;
  min-width: 0;
  min-height: 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  font-family: var(--font-body);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--clr-text-muted);
  text-decoration: none;
  position: relative;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: color var(--dur-fast) var(--ease);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Material-style icon pill: the active tab gets a soft capsule */
.mobile-bottom-nav i {
  display: block;
  font-size: 18px;
  line-height: 1;
  padding: 5px 16px;
  border-radius: var(--r-full);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}

.mobile-bottom-nav a.active {
  color: var(--clr-primary);
  font-weight: 700;
}

.mobile-bottom-nav a.active i {
  background: rgba(46, 80, 119, 0.10);
  color: var(--clr-primary);
}

.mobile-bottom-nav a:active i { background: rgba(46, 80, 119, 0.14); }

[data-theme="dark"] .mobile-bottom-nav a.active i {
  background: rgba(91, 186, 194, 0.16);
}

/* ── 29g. "MORE" BOTTOM SHEET ─────────────────────────────── */
.more-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 9997;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-normal) var(--ease);
}

.more-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

.more-menu {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--clr-surface);
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  box-shadow: var(--sh-xl);
  z-index: 9998;
  padding: 22px 14px calc(var(--bottomnav-h) + var(--safe-bottom) + 10px);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px 4px;
  visibility: hidden;
  transform: translateY(105%);
  transition: transform var(--dur-normal) var(--ease),
              visibility 0s linear var(--dur-normal);
}

.more-menu.show {
  visibility: visible;
  transform: translateY(0);
  transition: transform var(--dur-normal) var(--ease-out);
}

/* Grab handle */
.more-menu::before {
  content: '';
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 36px;
  height: 4px;
  border-radius: var(--r-full);
  background: var(--clr-border-strong);
}

.more-menu a {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 10px 4px;
  border-radius: var(--r-md);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  color: var(--clr-text-muted);
  text-align: center;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}

.more-menu a i {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  font-size: 18px;
  border-radius: var(--r-md);
  background: rgba(46, 80, 119, 0.07);
  color: var(--clr-primary);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}

.more-menu a:hover,
.more-menu a.active { color: var(--clr-primary); }

.more-menu a.active i,
.more-menu a:active i {
  background: var(--clr-primary);
  color: #fff;
}

/* Count badge pinned to the icon tile */
.more-menu a .badge {
  position: absolute;
  top: 4px;
  right: calc(50% - 30px);
  min-width: 17px;
  height: 17px;
  padding: 0 4px;
  border-radius: var(--r-full);
  background: var(--clr-danger);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  border: 1.5px solid var(--clr-surface);
}

[data-theme="dark"] .more-menu a i {
  background: rgba(255, 255, 255, 0.07);
  color: var(--clr-accent);
}

[data-theme="dark"] .more-menu a.active i,
[data-theme="dark"] .more-menu a:active i {
  background: var(--clr-accent);
  color: #0f1219;
}

/* ── 29h. COUNT BADGE PRIMITIVE ───────────────────────────── */
.pms-badge-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: var(--r-full);
  background: var(--clr-danger);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
}

/* ── 29i. SUPPORT BADGE — COMPACT ON PHONES ───────────────── */
@media (max-width: 767px) {
  .support-badge {
    width: 42px !important;
    padding: 8px !important;
    font-size: 14px !important;
  }
  .support-badge i { font-size: 18px !important; }
}

/* ════════════════════════════════════════════════════════════════
   §30  REDESIGN-2026  — Tokens + premium component layer
   Add-only: never edit §1–§29. This section extends the token
   system introduced in §1 with new design-system values and
   provides the reusable component classes for the ground-up
   UI/UX rebuild (Phase 2+).
   ════════════════════════════════════════════════════════════════ */

:root {
  /* ── Sidebar ─────────────────────────────────────────────── */
  --sidebar-bg-top:          #0d2035;
  --sidebar-bg-bottom:       #1c3d5e;
  --sidebar-grad:            linear-gradient(180deg, var(--sidebar-bg-top) 0%, var(--sidebar-bg-bottom) 100%);
  --sidebar-text:            rgba(255,255,255,0.72);
  --sidebar-text-active:     #ffffff;
  --sidebar-active-bg:       rgba(77,161,169,0.16);
  --sidebar-active-bar:      #2E5077;
  --sidebar-hover-bg:        rgba(255,255,255,0.07);
  --sidebar-section-label:   rgba(255,255,255,0.35);
  --sidebar-width:           260px;
  --sidebar-border:          rgba(255,255,255,0.07);

  /* ── Glass surface ───────────────────────────────────────── */
  --glass-bg:                rgba(255,255,255,0.72);
  --glass-blur:              16px;
  --glass-border-color:      rgba(255,255,255,0.52);

  /* ── Page sub-header ─────────────────────────────────────── */
  --ph-h:                    52px;
  --ph-bg:                   #ffffff;
  --ph-border:               rgba(0,0,0,0.07);

  /* ── FAB ─────────────────────────────────────────────────── */
  --fab-size:                56px;
  --fab-bg:                  linear-gradient(135deg, #2E5077, #2E5077);
  --fab-shadow:              0 4px 20px rgba(77,161,169,0.45);
  --fab-offset:              14px;

  /* ── Mobile stat strip ───────────────────────────────────── */
  --mstat-h:                 76px;
  --mstat-icon-size:         36px;
  --mstat-num-size:          20px;

  /* ── Bottom nav ──────────────────────────────────────────── */
  --bnav-h:                  62px;
  --bnav-bg:                 #ffffff;
  --bnav-border:             rgba(0,0,0,0.08);

  /* ── Gradient headline ───────────────────────────────────── */
  --grad-hero:               linear-gradient(135deg, #2E5077 0%, #2E5077 100%);
  --grad-card-navy:          linear-gradient(135deg, #2E5077, #1a3a52);
  --grad-card-teal:          linear-gradient(135deg, #2E5077, #2E5077);
}

/* ── §30a. PAGE HEADER COMPONENT ─────────────────────────── */
.pms-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: var(--ph-h);
  background: var(--ph-bg);
  border-bottom: 1px solid var(--ph-border);
  padding: 10px 20px;
  margin: -20px -20px 20px;
  position: sticky;
  top: 56px; /* below fixed navbar */
  z-index: 100;
  flex-wrap: wrap;
}
.pms-page-header-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--clr-text, #1A2332);
  margin: 0;
  line-height: 1.2;
}
.pms-page-header-sub {
  font-size: 12px;
  color: var(--clr-text-muted, #6B7A8F);
  margin-top: 2px;
}
.pms-page-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
@media (max-width: 575px) {
  .pms-page-header {
    padding: 8px 16px;
    margin: -16px -16px 16px;
    top: 98px; /* navbar + appt bar */
  }
  .pms-page-header-title { font-size: 15px; }
}

/* ── §30b. SIDEBAR AVATAR BLOCK ──────────────────────────── */
.pms-sidebar-avatar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--sidebar-border);
  margin-bottom: 4px;
}
.pms-sidebar-avatar-circle {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, #2E5077, #2E5077);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: 0.02em;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.pms-sidebar-avatar-info { min-width: 0; }
.pms-sidebar-avatar-name {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 152px;
}
.pms-sidebar-avatar-role {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10.5px;
  font-weight: 500;
  color: var(--sidebar-text);
  margin-top: 1px;
  text-transform: capitalize;
}

/* ── §30c. FAB BUTTON ────────────────────────────────────── */
.pms-fab {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--fab-size);
  height: var(--fab-size);
  border-radius: 50%;
  background: var(--fab-bg);
  box-shadow: var(--fab-shadow);
  border: none;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  position: relative;
  bottom: var(--fab-offset);
  z-index: 10;
  transition: transform 0.2s var(--ease-spring, cubic-bezier(0.34,1.56,0.64,1)),
              box-shadow 0.2s ease;
  flex-shrink: 0;
  text-decoration: none;
}
.pms-fab:hover,
.pms-fab:focus {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(77,161,169,0.55);
  color: #fff;
  text-decoration: none;
  outline: none;
}
.pms-fab:active { transform: scale(0.96); }

/* FAB pulse ring animation */
@keyframes fabPulse {
  0%   { box-shadow: var(--fab-shadow), 0 0 0 0 rgba(77,161,169,0.45); }
  70%  { box-shadow: var(--fab-shadow), 0 0 0 12px rgba(77,161,169,0); }
  100% { box-shadow: var(--fab-shadow), 0 0 0 0 rgba(77,161,169,0); }
}
.pms-fab.pms-fab-pulse { animation: fabPulse 2.8s ease-out infinite; }

/* ── §30d. MOBILE BOTTOM NAV UPGRADE ─────────────────────── */
.mobile-bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: var(--bnav-h);
  background: var(--bnav-bg);
  border-top: 1px solid var(--bnav-border);
  display: flex;
  align-items: center;
  justify-content: space-around;
  z-index: 1040;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
}
.mobile-bottom-nav a,
.mobile-bottom-nav .pms-fab-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  font-size: 10px;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  color: #9AAAB8;
  text-decoration: none;
  min-width: 44px;
  min-height: 44px;
  transition: color 0.15s ease;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  line-height: 1;
}
.mobile-bottom-nav a i,
.mobile-bottom-nav .pms-fab-wrap i {
  font-size: 19px;
}
.mobile-bottom-nav a.active,
.mobile-bottom-nav a:hover {
  color: #2E5077;
  text-decoration: none;
}
.mobile-bottom-nav a.active i {
  color: #2E5077;
}
/* FAB wrapper slot in bottom nav center */
.pms-fab-wrap {
  position: relative;
}

/* ── §30e. MOBILE STAT STRIP ─────────────────────────────── */
/*
  Single container approach: .pms-stat-container wraps the 4 stat card
  columns. On mobile (≤575px) it becomes a horizontal scroll-snap flex
  row; on desktop it collapses back to a float/grid layout. No HTML
  duplication needed.
*/

/* Mobile: transform float columns into a horizontal scroll strip */
@media (max-width: 575px) {
  .pms-stat-container {
    display: flex !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 8px;
    padding: 4px 0 8px;
    margin: 0;
  }
  .pms-stat-container::-webkit-scrollbar { display: none; }

  /* Override float columns to be flex children */
  .pms-stat-container > .basic-column,
  .pms-stat-container > .basic-column.w-col,
  .pms-stat-container > .basic-column.w-col-3 {
    flex: 0 0 calc(25vw - 10px) !important;
    min-width: 76px !important;
    max-width: 96px !important;
    float: none !important;
    padding: 0 !important;
    width: auto !important;
    min-height: 0 !important;
  }

  /* Compact card */
  .pms-stat-container .number-card {
    height: 76px !important;
    min-height: 76px !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 8px 4px !important;
    gap: 4px !important;
    border-radius: 12px !important;
    scroll-snap-align: start;
  }
  .pms-stat-container .number-card-icon {
    width: 32px !important;
    height: 32px !important;
    font-size: 13px !important;
    border-radius: 8px !important;
  }
  .pms-stat-container .number-card-body { text-align: center; }
  .pms-stat-container .number-card-number {
    font-size: 17px !important;
    line-height: 1.1;
  }
  .pms-stat-container .number-card-currency {
    font-size: 9px !important;
    margin-top: 1px !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 88px;
  }

  /* Collection card: show value, hide eye toggle */
  .pms-stat-container .collection-eye-toggle { display: none !important; }
  .pms-stat-container [id^="todayCollectionHidden_"] { display: none !important; }
  .pms-stat-container [id^="todayCollectionValue_"] {
    display: inline-block !important;
    font-size: 13px !important;
  }
}

/* ── §30f. MOBILE CARD-LIST TABLE PATTERN ────────────────── */
@media (max-width: 575px) {
  .pms-table-mobile-hidden { display: none !important; }
  .pms-mobile-card-list { display: block !important; }
}
@media (min-width: 576px) {
  .pms-mobile-card-list { display: none !important; }
}
.pms-mobile-card-list { display: none; }
.pms-mobile-row-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 12px;
  padding: 12px 16px;
  margin-bottom: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.pms-mobile-row-card dt {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6B7A8F;
  margin-bottom: 2px;
}
.pms-mobile-row-card dd {
  font-size: 13px;
  font-weight: 500;
  color: #1A2332;
  margin: 0 0 8px;
}

/* ── §30g. BOTTOM SHEET (mobile modal pattern) ───────────── */
@media (max-width: 767px) {
  .modal-bottom-sheet .modal-dialog {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    transform: translateY(100%) !important;
    transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1) !important;
  }
  .modal-bottom-sheet.show .modal-dialog {
    transform: translateY(0) !important;
  }
  .modal-bottom-sheet .modal-content {
    border-radius: 20px 20px 0 0 !important;
    border: none !important;
    max-height: 85vh;
    overflow-y: auto;
  }
  .modal-bottom-sheet .modal-header {
    border-bottom: 1px solid rgba(0,0,0,0.07);
  }
  .modal-bottom-sheet .modal-header::before {
    content: '';
    display: block;
    width: 40px;
    height: 4px;
    background: #dee2e6;
    border-radius: 2px;
    margin: 0 auto 12px;
  }
}

/* ── §30h. REVEAL ANIMATION TARGET ───────────────────────── */
.pms-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.pms-reveal.pms-revealed {
  opacity: 1;
  transform: translateY(0);
}

/* ── §30i. PREMIUM TABLE HEAD ────────────────────────────── */
.pms-table-premium thead th {
  background: linear-gradient(90deg, #2E5077, #3a6494);
  color: #fff;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 10px 14px;
  border: none;
  white-space: nowrap;
}
.pms-table-premium thead th:first-child { border-radius: 8px 0 0 0; }
.pms-table-premium thead th:last-child  { border-radius: 0 8px 0 0; }
.pms-table-premium tbody tr {
  transition: background 0.12s ease;
}
.pms-table-premium tbody tr:hover {
  background: rgba(77,161,169,0.05);
}

/* ── §30j. GLASS CARD VARIANT ────────────────────────────── */
.pms-card-glass {
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border-color);
  border-radius: var(--r-lg, 16px);
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}

/* ── §30k. GRADIENT ACCENT PILL ──────────────────────────── */
.pms-pill-gradient {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 9999px;
  background: var(--grad-hero);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* ── §30l. PREMIUM BUTTON ────────────────────────────────── */
.pms-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 10px;
  background: var(--grad-hero);
  color: #fff;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
  box-shadow: 0 2px 10px rgba(46,80,119,0.25);
  text-decoration: none;
}
.pms-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(46,80,119,0.35);
  color: #fff;
  text-decoration: none;
}
.pms-btn-primary:active { transform: translateY(0); }
.pms-btn-primary:disabled,
.pms-btn-primary.is-loading {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

/* ── §30m. MORE-MENU GRID LAYOUT ─────────────────────────── */
.more-menu {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  padding: 16px 12px 20px;
  border-radius: 20px 20px 0 0;
  background: #fff;
}
.more-menu a {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 12px 4px !important;
  border-radius: 12px;
  font-size: 10.5px !important;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  color: #4B5563 !important;
  text-decoration: none !important;
  min-height: 64px;
  text-align: center;
  transition: background 0.12s ease, color 0.12s ease;
  background: #F8FAFC;
  border: 1px solid rgba(0,0,0,0.06);
}
.more-menu a i {
  font-size: 20px !important;
  color: #2E5077;
}
.more-menu a:hover,
.more-menu a.active {
  background: rgba(77,161,169,0.10) !important;
  color: #2E5077 !important;
}
.more-menu a.active i { color: #2E5077; }
.more-menu .badge {
  position: absolute;
  top: -4px;
  right: -4px;
  font-size: 9px;
  padding: 2px 5px;
  border-radius: 9999px;
  background: #DC2626;
  color: #fff;
  line-height: 1.2;
}

/* ── §30n. NAVBAR GLASS UPGRADE ──────────────────────────── */
.navbar,
.pms-topnav {
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.pms-nav-scrolled .navbar,
.navbar.pms-nav-scrolled,
.pms-topnav.pms-nav-scrolled {
  box-shadow: 0 4px 24px rgba(0,0,0,0.10) !important;
}

/* ── §30o. APPOINTMENT BAR PILL ──────────────────────────── */
.appointment-box {
  border-left: none !important;
  border-bottom: 1px solid rgba(77,161,169,0.12) !important;
  background: rgba(255,255,255,0.96) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}
.appointment-box::before {
  content: '';
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #2E5077;
  margin-right: 10px;
  flex-shrink: 0;
  animation: apptPulse 2s ease-in-out infinite;
}
@keyframes apptPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

/* ── §30p. SIDEBAR SECTION LABEL ─────────────────────────── */
.sidebar-sep span {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sidebar-section-label, rgba(255,255,255,0.35));
}

/* ── §30q. DOCTOR AVATAR IN SIDEBAR ──────────────────────── */
.sidebar-brand-header {
  display: none !important; /* replaced by pms-sidebar-avatar */
}

/* ── §30r. PRINT MEDIA — HIDE SHELL ──────────────────────── */
@media print {
  /* Hide all navigation / chrome */
  header,
  nav.navbar,
  .sidebar,
  #sidebar,
  .mobile-bottom-nav,
  .more-menu,
  .more-overlay,
  .navbar,
  .pms-topnav,
  .pms-page-header,
  .support-badge,
  .appointment-box,
  #pms-nav-trigger,
  .breadcrumb,
  .pms-fab,
  .pms-icon-btn,
  .btn-close,
  [data-bs-dismiss],
  .offcanvas,
  .modal-backdrop,
  #right-sidebar {
    display: none !important;
  }

  /* Reset layout so content fills the page */
  body, html {
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
  }
  .page-body-wrapper {
    padding-top: 0 !important;
    min-height: unset !important;
  }
  .main-panel {
    width: 100% !important;
    margin-left: 0 !important;
    padding: 0 !important;
    min-height: unset !important;
  }
  .content-wrapper {
    padding: 8px !important;
    background: #fff !important;
  }

  /* Cards: clean borders, no shadows */
  .pms-card, .card {
    box-shadow: none !important;
    border: 1px solid #dee2e6 !important;
    break-inside: avoid;
  }

  /* Tables: full-width, no truncation */
  .table-responsive { overflow: visible !important; }
  table { width: 100% !important; }

  /* Force color printing of table headers */
  thead th {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  /* Avoid page breaks inside rows */
  tr { break-inside: avoid; }

  a[href]::after { content: none !important; }
}

/* ── §30s. CARD ENTRANCE ANIMATION ───────────────────────── */
@keyframes pmsRevealUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.pms-animate-in {
  animation: pmsRevealUp 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
}

/* ── §30t. LOADING BUTTON SPINNER ────────────────────────── */
.is-loading {
  position: relative;
  pointer-events: none;
}
.is-loading::after {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: btnSpin 0.65s linear infinite;
  margin-left: 8px;
  vertical-align: middle;
}
@keyframes btnSpin {
  to { transform: rotate(360deg); }
}

/* ═══════════════════════════════════════════════════════════════
   §31  GLOBAL BOOK APPOINTMENT MODAL  [pms-fix 2026-06-25]
   ─────────────────────────────────────────────────────────────
   Mobile: bottom sheet (slides up, 92vh max, 20px top radius)
   Desktop ≥768px: centered card (480px, border-radius 20px)
   ─────────────────────────────────────────────────────────────*/

/* ── Overlay ─────────────────────────────────────── */
.pms-book-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10500;
  align-items: flex-end;
  justify-content: center;
}
.pms-book-modal.is-open { display: flex; }
@media (min-width: 768px) {
  .pms-book-modal.is-open { align-items: center; }
}

/* ── Backdrop ────────────────────────────────────── */
.pms-book-modal-bd {
  position: absolute;
  inset: 0;
  background: rgba(15,37,64,0.52);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  cursor: pointer;
}

/* ── Sheet ───────────────────────────────────────── */
.pms-book-modal-sheet {
  position: relative;
  background: #fff;
  border-radius: 20px 20px 0 0;
  width: 100%;
  max-height: 92vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 -8px 48px rgba(15,37,64,0.2);
  z-index: 1;
}
@media (min-width: 768px) {
  .pms-book-modal-sheet {
    border-radius: 20px;
    max-width: 488px;
    max-height: 88vh;
  }
}

/* ── Drag handle ─────────────────────────────────── */
.pms-book-modal-drag {
  width: 40px; height: 4px;
  background: #dde6f0;
  border-radius: 2px;
  margin: 10px auto 0;
  flex-shrink: 0;
}
@media (min-width: 768px) { .pms-book-modal-drag { display: none; } }

/* ── Header ──────────────────────────────────────── */
.pms-book-modal-hdr {
  padding: 6px 16px 0;
  flex-shrink: 0;
  border-bottom: 1px solid #eef2f8;
}
.pms-book-modal-titlerow {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0 6px;
}
.pms-book-btn-icon {
  background: none; border: none; padding: 6px;
  font-size: 15px; cursor: pointer;
  color: #2E5077; border-radius: 8px;
  transition: background 0.15s;
  flex-shrink: 0; line-height: 1;
}
.pms-book-btn-icon:hover { background: #eef4f8; }
.pms-book-modal-title {
  font-size: 17px; font-weight: 700; color: #0f2540;
  flex: 1; line-height: 1.2; letter-spacing: -0.01em;
}
.pms-book-modal-close {
  background: #f0f4f8; border: none; border-radius: 50%;
  width: 30px; height: 30px; display: flex;
  align-items: center; justify-content: center;
  font-size: 14px; color: #4a6080; cursor: pointer;
  transition: background 0.15s, transform 0.15s;
  flex-shrink: 0;
}
.pms-book-modal-close:hover { background: #dde6f0; transform: scale(1.1); }

/* ── Step indicator ──────────────────────────────── */
.pms-book-steps-bar {
  display: flex;
  align-items: center;
  padding: 8px 0 12px;
  gap: 0;
}
.pms-step-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: #dde6f0; flex-shrink: 0;
  transition: background 0.3s, transform 0.3s;
}
.pms-step-dot.active {
  background: #2E5077;
  transform: scale(1.4);
  box-shadow: 0 0 0 3px rgba(46,80,119,0.15);
}
.pms-step-dot.done { background: #2E5077; transform: scale(1.0); }
.pms-step-line {
  flex: 1; height: 2px; background: #dde6f0;
  transition: background 0.4s;
  margin: 0 4px;
}
.pms-step-line.done { background: #2E5077; }

/* ── Body (scrollable) ───────────────────────────── */
.pms-book-modal-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0 20px 28px;
  -webkit-overflow-scrolling: touch;
  position: relative;
}
.pms-book-modal-body::-webkit-scrollbar { width: 4px; }
.pms-book-modal-body::-webkit-scrollbar-thumb { background: #d0dce8; border-radius: 2px; }

/* ── Step panels ─────────────────────────────────── */
.pms-book-step { display: none; }
.pms-book-step.active { display: block; }

.pms-bm-headline {
  font-size: 20px; font-weight: 800; color: #0f2540;
  margin: 16px 0 4px; line-height: 1.2; letter-spacing: -0.02em;
}
.pms-bm-sub {
  font-size: 13px; color: #7a8fa8; margin-bottom: 16px; line-height: 1.4;
}

/* ── Patient type toggle ─────────────────────────── */
.pms-pt-toggle {
  display: flex;
  background: #f0f4f8;
  border-radius: 10px;
  padding: 3px;
  gap: 3px;
  margin-bottom: 14px;
}
.pms-pt-toggle button {
  flex: 1; border: none; background: transparent;
  border-radius: 8px; padding: 9px 8px;
  font-size: 13px; font-weight: 600; color: #6b7fa0;
  cursor: pointer; transition: all 0.2s;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.pms-pt-toggle button.active {
  background: #fff; color: #2E5077;
  box-shadow: 0 1px 6px rgba(0,0,0,0.1);
}

/* ── Search field ────────────────────────────────── */
.pms-search-field {
  position: relative; margin-bottom: 6px;
}
.pms-search-field .pms-search-icon {
  position: absolute; left: 13px; top: 50%;
  transform: translateY(-50%);
  color: #a0b0c8; font-size: 13px; pointer-events: none;
}

/* ── Shared input ────────────────────────────────── */
.pms-bm-input {
  display: block; width: 100%;
  padding: 11px 13px 11px 38px;
  border: 1.5px solid #d8e3ef;
  border-radius: 10px;
  font-size: 14px; color: #1e3a5f;
  background: #fafcff;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
  margin-bottom: 10px;
  -webkit-appearance: none;
}
.pms-bm-input[type="date"],
.pms-bm-input[type="time"],
.pms-bm-input[type="tel"],
.pms-bm-input[type="text"] {
  padding-left: 13px;
}
.pms-search-field .pms-bm-input { padding-left: 38px; }
.pms-bm-input:focus {
  border-color: #2E5077;
  box-shadow: 0 0 0 3px rgba(77,161,169,0.14);
  background: #fff;
}
.pms-bm-input::placeholder { color: #b0bfd0; }

/* ── Search dropdown ─────────────────────────────── */
.pms-search-drop {
  border: 1.5px solid #e0eaf2;
  border-radius: 10px; overflow: hidden;
  margin-bottom: 6px; background: #fff;
  box-shadow: 0 4px 16px rgba(15,37,64,0.08);
}
.pms-search-drop:empty { display: none; }
.pms-search-drop-item {
  display: flex; align-items: center;
  padding: 10px 14px; gap: 12px;
  cursor: pointer;
  transition: background 0.12s;
  border-bottom: 1px solid #f0f5fa;
}
.pms-search-drop-item:last-child { border-bottom: none; }
.pms-search-drop-item:hover,
.pms-search-drop-item:active { background: #f0f8fa; }
.pms-pt-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg,#2E5077,#2E5077);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; color: #fff; flex-shrink: 0;
}
.pms-pt-name { font-size: 14px; font-weight: 600; color: #1e3a5f; }
.pms-pt-meta { font-size: 12px; color: #7a8fa8; }
.pms-search-empty {
  padding: 16px 14px; text-align: center;
  font-size: 13px; color: #9baec4;
}
.pms-search-loading {
  padding: 14px; text-align: center;
  color: #2E5077; font-size: 16px;
}

/* ── Selected patient card ───────────────────────── */
.pms-pat-selected-card {
  background: linear-gradient(135deg,#f0f8fb,#e8f4f8);
  border: 1.5px solid #b0d8e4;
  border-radius: 12px;
  padding: 13px 14px;
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 14px;
}
.pms-pat-selected-card .pms-pt-avatar { width: 42px; height: 42px; font-size: 14px; }
.pms-pat-sel-info { flex: 1; min-width: 0; }
.pms-pat-sel-name { font-size: 14px; font-weight: 700; color: #0f2540; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pms-pat-sel-meta { font-size: 12px; color: #4a7080; }
.pms-pat-sel-change {
  background: none; border: 1px solid #a0c8d8;
  border-radius: 8px; padding: 5px 10px;
  font-size: 12px; font-weight: 600; color: #2E5077;
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
  transition: background 0.15s;
}
.pms-pat-sel-change:hover { background: #e0f0f4; }

/* ── Field / label ───────────────────────────────── */
.pms-bm-field { margin-bottom: 13px; }
.pms-bm-label {
  display: block;
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: #6b7fa0; margin-bottom: 5px;
}
.pms-bm-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

/* ── Select ──────────────────────────────────────── */
.pms-bm-select {
  display: block; width: 100%;
  padding: 11px 36px 11px 13px;
  border: 1.5px solid #d8e3ef;
  border-radius: 10px;
  font-size: 14px; color: #1e3a5f;
  background: #fafcff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%234DA1A9' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 13px center no-repeat;
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  outline: none; cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.pms-bm-select:focus {
  border-color: #2E5077;
  box-shadow: 0 0 0 3px rgba(77,161,169,0.14);
  background-color: #fff;
}

/* ── Nav row ─────────────────────────────────────── */
.pms-bm-nav-row {
  display: flex; gap: 10px; margin-top: 18px;
  padding-top: 14px; border-top: 1px solid #eef2f8;
}
.pms-bm-btn-back {
  flex-shrink: 0;
  background: #f0f4f8; border: none; border-radius: 10px;
  padding: 11px 16px; font-size: 14px; color: #4a6080;
  cursor: pointer; transition: background 0.15s;
  display: flex; align-items: center; gap: 6px;
}
.pms-bm-btn-back:hover { background: #dde6f0; }
.pms-bm-btn-next {
  flex: 1;
  background: linear-gradient(135deg,#2E5077 0%,#2E5077 100%);
  border: none; border-radius: 10px;
  padding: 12px 20px; font-size: 14px; font-weight: 700;
  color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  transition: box-shadow 0.15s, transform 0.1s;
  box-shadow: 0 4px 16px rgba(77,161,169,0.28);
}
.pms-bm-btn-next:hover { box-shadow: 0 6px 20px rgba(77,161,169,0.38); transform: translateY(-1px); }
.pms-bm-btn-next:active { transform: none; }
.pms-bm-btn-next:disabled,
.pms-bm-btn-next.is-loading {
  opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none;
}

/* ── Submit button ───────────────────────────────── */
.pms-bm-btn-submit {
  flex: 1;
  background: linear-gradient(135deg,#2E5077 0%,#2E5077 100%);
  border: none; border-radius: 10px;
  padding: 13px 20px; font-size: 14px; font-weight: 700;
  color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  transition: box-shadow 0.15s, transform 0.1s;
  box-shadow: 0 4px 20px rgba(77,161,169,0.32);
}
.pms-bm-btn-submit:hover { box-shadow: 0 8px 24px rgba(77,161,169,0.42); transform: translateY(-1px); }
.pms-bm-btn-submit:active { transform: none; box-shadow: 0 4px 16px rgba(77,161,169,0.28); }
.pms-bm-btn-submit:disabled,
.pms-bm-btn-submit.is-loading {
  opacity: 0.6; cursor: not-allowed; transform: none;
}

/* ── Confirm card ────────────────────────────────── */
.pms-bm-confirm-card {
  background: #f8fafc; border: 1.5px solid #e0eaf2;
  border-radius: 14px; padding: 4px 16px; margin: 10px 0 4px;
}
.pms-bm-confirm-row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid #eef3f8;
}
.pms-bm-confirm-row:last-child { border-bottom: none; }
.pms-bm-confirm-ico {
  width: 32px; height: 32px; border-radius: 9px; flex-shrink: 0;
  background: linear-gradient(135deg,#2E5077,#2E5077);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 12px;
}
.pms-bm-clabel {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; color: #7a8fa8; margin-bottom: 2px;
}
.pms-bm-cvalue {
  font-size: 13px; font-weight: 600; color: #0f2540; line-height: 1.4;
}

/* ── Success panel ───────────────────────────────── */
.pms-bm-success {
  display: none; text-align: center;
  padding: 36px 20px 20px;
}
.pms-bm-success.show { display: block; }
.pms-bm-success-icon {
  width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 20px;
  background: linear-gradient(135deg,#2E5077,#2E5077);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; color: #fff;
  transform: scale(0);
}
.pms-bm-success-title {
  font-size: 22px; font-weight: 800; color: #0f2540;
  margin-bottom: 8px; letter-spacing: -0.02em;
}
.pms-bm-success-sub {
  font-size: 14px; color: #6b7fa0; margin-bottom: 24px; line-height: 1.5;
}

/* ── Dark mode ───────────────────────────────────── */
[data-theme="dark"] .pms-book-modal-sheet,
[data-theme="dark"] .pms-book-modal-hdr,
[data-theme="dark"] .pms-book-modal-body { background: #1a2a40; }
[data-theme="dark"] .pms-book-modal-title,
[data-theme="dark"] .pms-bm-headline,
[data-theme="dark"] .pms-pt-name,
[data-theme="dark"] .pms-pat-sel-name,
[data-theme="dark"] .pms-bm-cvalue { color: #e8f0f8; }
[data-theme="dark"] .pms-book-modal-hdr { border-color: #253548; }
[data-theme="dark"] .pms-bm-input,
[data-theme="dark"] .pms-bm-select { background: #162030; border-color: #2e4460; color: #d0dce8; }
[data-theme="dark"] .pms-bm-input:focus,
[data-theme="dark"] .pms-bm-select:focus { background: #1e3050; }
[data-theme="dark"] .pms-search-drop { background: #1e2e44; border-color: #2e4060; }
[data-theme="dark"] .pms-search-drop-item { border-color: #253548; }
[data-theme="dark"] .pms-search-drop-item:hover { background: #253850; }
[data-theme="dark"] .pms-pt-toggle { background: #142030; }
[data-theme="dark"] .pms-pt-toggle button.active { background: #1e3048; color: #6ecad2; }
[data-theme="dark"] .pms-bm-confirm-card { background: #142030; border-color: #253548; }
[data-theme="dark"] .pms-bm-confirm-row { border-color: #1e3048; }
[data-theme="dark"] .pms-book-modal-close { background: #253548; color: #8090a8; }
[data-theme="dark"] .pms-bm-btn-back { background: #253548; color: #8090a8; }
[data-theme="dark"] .pms-pat-selected-card { background: #142030; border-color: #2a5060; }

/* File number assignment hint (new patient location picker) */
.pms-new-file-hint {
  font-size: 12px; font-weight: 600; color: #4a7080;
  margin-top: 6px; display: flex; align-items: center; gap: 5px;
  min-height: 18px;
}
.pms-new-file-hint strong { color: #2E5077; }

/* ── §31 GLOBAL BOOTSTRAP BUTTON BRAND OVERRIDE ────────────────────────────
   Applied to every page that loads design-system.css via mainheader.inc.php.
   Uses !important to win over Bootstrap's specificity. */
.btn-primary,
a.btn-primary {
  background: linear-gradient(135deg, #2E5077, #3a6795) !important;
  border-color: #2E5077 !important;
  color: #fff !important;
}
.btn-primary:hover,
.btn-primary:focus,
a.btn-primary:hover {
  background: linear-gradient(135deg, #243f60, #2e5a80) !important;
  border-color: #243f60 !important;
  box-shadow: 0 0 0 0.2rem rgba(46,80,119,0.3) !important;
}
.btn-outline-primary {
  color: #2E5077 !important;
  border-color: #2E5077 !important;
  background: transparent !important;
}
.btn-outline-primary:hover,
.btn-outline-primary.active,
.btn-check:checked + .btn-outline-primary {
  background: #2E5077 !important;
  border-color: #2E5077 !important;
  color: #fff !important;
}

/* ============================================================
   §32 Extended Components
   ============================================================ */

/* --- 32.1 Login Layout --- */
.pms-login-layout {
  display: flex;
  min-height: 100vh;
}

/* Left brand panel */
.pms-login-brand {
  width: 40%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-10) var(--sp-8);
  background: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-accent) 100%);
  color: #fff;
  text-align: center;
}

.pms-login-brand-logo {
  margin-bottom: var(--sp-6);
  display: flex;
  align-items: center;
  justify-content: center;
}

.pms-login-brand-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: #fff;
  margin-bottom: var(--sp-3);
  line-height: var(--lh-tight);
}

.pms-login-brand-subtitle {
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.75);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-8);
}

.pms-login-brand-features {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
  width: 100%;
  max-width: 300px;
}

.pms-login-brand-features li {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.88);
  padding: var(--sp-2) 0;
}

/* Right form panel */
.pms-login-form {
  width: 60%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-8);
  background: var(--clr-surface);
}

.pms-login-form-inner {
  width: 100%;
  max-width: 420px;
  margin-left: auto;
  margin-right: auto;
}

.pms-login-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--clr-text);
  margin-bottom: var(--sp-2);
  line-height: var(--lh-tight);
}

.pms-login-subtitle {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-6);
  line-height: var(--lh-normal);
}

@media (max-width: 768px) {
  .pms-login-brand        { display: none; }
  .pms-login-form         { width: 100%; padding: var(--sp-6) var(--sp-4); }
}

/* --- 32.2 Breadcrumb --- */
.pms-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-4);
  flex-wrap: wrap;
}

.pms-breadcrumb-item {
  display: inline;
  color: var(--clr-text-muted);
}

.pms-breadcrumb-item.active {
  color: var(--clr-text);
  font-weight: 500;
}

.pms-breadcrumb-item a {
  color: var(--clr-primary);
  text-decoration: none;
}

.pms-breadcrumb-item a:hover {
  text-decoration: underline;
}

.pms-breadcrumb-sep {
  opacity: 0.4;
  margin: 0 var(--sp-1);
  user-select: none;
}

/* --- 32.3 Filter Bar --- */
.pms-filter-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
  padding: var(--sp-3) var(--sp-4);
  background: var(--clr-surface);
  border-radius: var(--r-lg);
  border: 1px solid var(--clr-border);
  margin-bottom: var(--sp-5);
  box-shadow: var(--sh-xs);
}

.pms-filter-search {
  flex: 1 1 220px;
  position: relative;
}

.pms-filter-search input {
  width: 100%;
  display: block;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--clr-text);
  background: var(--clr-surface);
  border: 1.5px solid var(--clr-border-strong);
  border-radius: var(--r-sm);
  padding: 9px 12px 9px 36px;
  line-height: var(--lh-normal);
  transition:
    border-color var(--dur-fast) var(--ease),
    box-shadow   var(--dur-fast) var(--ease);
  outline: none;
  min-height: 40px;
}

.pms-filter-search input:focus {
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px rgba(77, 161, 169, 0.15);
}

.pms-filter-search input::placeholder {
  color: var(--clr-text-light);
}

.pms-filter-search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--clr-text-muted);
  pointer-events: none;
  display: flex;
  align-items: center;
}

.pms-filter-select {
  flex: 0 0 auto;
  min-width: 150px;
  display: block;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--clr-text);
  background: var(--clr-surface);
  border: 1.5px solid var(--clr-border-strong);
  border-radius: var(--r-sm);
  padding: 9px 12px;
  line-height: var(--lh-normal);
  transition:
    border-color var(--dur-fast) var(--ease),
    box-shadow   var(--dur-fast) var(--ease);
  outline: none;
  min-height: 40px;
  cursor: pointer;
}

.pms-filter-select:focus {
  border-color: var(--clr-accent);
  box-shadow: 0 0 0 3px rgba(77, 161, 169, 0.15);
}

.pms-filter-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
}

@media (max-width: 600px) {
  .pms-filter-bar         { flex-direction: column; align-items: stretch; }
  .pms-filter-search      { flex: 1 1 100%; }
  .pms-filter-select      { min-width: unset; width: 100%; }
  .pms-filter-actions     { margin-left: 0; width: 100%; justify-content: flex-end; }
}

/* --- 32.4 Form Section --- */
.pms-form-section {
  background: var(--clr-surface);
  border-radius: var(--r-xl);
  border: 1px solid var(--clr-border);
  margin-bottom: var(--sp-5);
  overflow: hidden;
  box-shadow: var(--sh-xs);
}

.pms-form-section-header {
  padding: var(--sp-4) var(--sp-6);
  border-bottom: 1px solid var(--clr-border);
  background: var(--clr-surface-2);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.pms-form-section-icon {
  color: var(--clr-accent);
  font-size: var(--text-xl);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.pms-form-section-title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--clr-text);
  margin: 0;
}

.pms-form-section-subtitle {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin-top: var(--sp-1);
  margin-bottom: 0;
  line-height: var(--lh-normal);
}

.pms-form-section-body {
  padding: var(--sp-5) var(--sp-6);
}

.pms-form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-4);
}

@media (max-width: 600px) {
  .pms-form-section-body  { padding: var(--sp-4) var(--sp-4); }
  .pms-form-row           { grid-template-columns: 1fr; }
}

/* --- 32.5 Drawer --- */
.pms-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 360px;
  max-width: 90vw;
  background: var(--clr-surface);
  box-shadow: var(--sh-xl);
  z-index: var(--z-overlay);
  transform: translateX(100%);
  transition: transform var(--dur-normal) var(--ease);
  display: flex;
  flex-direction: column;
}

.pms-drawer.is-open {
  transform: translateX(0);
}

.pms-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: calc(var(--z-overlay) - 1);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-normal) var(--ease);
}

.pms-drawer-backdrop.is-open {
  opacity: 1;
  pointer-events: all;
}

.pms-drawer-header {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.pms-drawer-title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--clr-text);
  margin: 0;
}

.pms-drawer-close {
  background: none;
  border: none;
  padding: var(--sp-1);
  cursor: pointer;
  color: var(--clr-text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-sm);
  transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
  line-height: 1;
}

.pms-drawer-close:hover {
  color: var(--clr-text);
  background: var(--clr-surface-2);
}

.pms-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-5);
}

@media (max-width: 480px) {
  .pms-drawer { width: 100%; }
}

/* --- 32.6 Timeline --- */
.pms-timeline {
  position: relative;
  padding-left: var(--sp-6);
  list-style: none;
  margin: 0;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
}

.pms-timeline-item {
  position: relative;
  padding-bottom: var(--sp-5);
  padding-left: var(--sp-4);
}

/* Connector line between items */
.pms-timeline-item::before {
  content: '';
  position: absolute;
  left: -1px;
  top: 18px;
  bottom: 0;
  width: 2px;
  background: var(--clr-border);
}

/* Hide connector on last item */
.pms-timeline-item:last-child::before {
  display: none;
}

/* Timeline dot */
.pms-timeline-dot {
  position: absolute;
  left: calc(-1 * var(--sp-3) - 5px);
  top: 4px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--clr-accent);
  border: 2px solid var(--clr-surface);
  box-shadow: var(--sh-xs);
}

.pms-timeline-dot--success { background: var(--clr-success); }
.pms-timeline-dot--danger  { background: var(--clr-danger); }
.pms-timeline-dot--warning { background: var(--clr-warning); }

.pms-timeline-date {
  font-size: var(--text-xs);
  color: var(--clr-text-muted);
  font-weight: 500;
  margin-bottom: var(--sp-1);
}

.pms-timeline-content {
  font-size: var(--text-sm);
  color: var(--clr-text);
  line-height: var(--lh-normal);
}

.pms-timeline-label {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--r-full);
  background: rgba(46, 80, 119, 0.08);
  color: var(--clr-primary);
  margin-left: var(--sp-2);
  vertical-align: middle;
}

/* --- 32.7 Step Indicator --- */
.pms-step-indicator {
  display: flex;
  align-items: flex-start;
  margin-bottom: var(--sp-6);
}

.pms-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

.pms-step-circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--clr-text-muted);
  background: var(--clr-surface);
  transition: all var(--dur-normal) var(--ease);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.pms-step-label {
  font-size: var(--text-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-2);
  text-align: center;
  line-height: var(--lh-snug);
  transition: color var(--dur-normal) var(--ease);
}

/* Connector between steps */
.pms-step-connector {
  flex: 1;
  height: 2px;
  background: var(--clr-border);
  margin-top: 15px;
  transition: background var(--dur-normal) var(--ease);
  align-self: flex-start;
}

/* Active state */
.pms-step.is-active .pms-step-circle {
  border-color: var(--clr-primary);
  color: var(--clr-primary);
  background: rgba(46, 80, 119, 0.08);
}

.pms-step.is-active .pms-step-label {
  color: var(--clr-primary);
  font-weight: 500;
}

/* Complete state */
.pms-step.is-complete .pms-step-circle {
  background: var(--clr-primary);
  border-color: var(--clr-primary);
  color: #fff;
}

.pms-step.is-complete .pms-step-label {
  color: var(--clr-primary);
  font-weight: 500;
}

/* Completed connector */
.pms-step.is-complete + .pms-step-connector {
  background: var(--clr-primary);
}

/* --- 32.8 Empty State --- */
.pms-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-12) var(--sp-6);
  text-align: center;
  color: var(--clr-text-muted);
}

.pms-empty-icon {
  font-size: 48px;
  opacity: 0.3;
  margin-bottom: var(--sp-4);
  color: var(--clr-primary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.pms-empty-title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--clr-text);
  margin-bottom: var(--sp-2);
}

.pms-empty-subtitle {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  max-width: 320px;
  line-height: 1.5;
  margin-bottom: 0;
}

.pms-empty-action {
  margin-top: var(--sp-5);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

/* Bordered variant */
.pms-empty-state--bordered {
  border: 1px dashed var(--clr-border);
  border-radius: var(--r-xl);
  background: var(--clr-surface-2);
}

/* === PMS iOS CARD SYSTEM === */
.pms-ios-card-list { display:flex; flex-direction:column; gap:8px; padding:8px 16px 16px; }
.pms-ios-card-wrap { border-radius:12px; overflow:hidden; }
.pms-ios-card {
  display:flex; align-items:center; gap:12px; padding:12px 14px;
  background:#fff; border-left:3px solid var(--clr-accent);
  border-radius:12px; cursor:pointer;
  box-shadow:0 1px 3px rgba(0,0,0,0.06);
  transition:box-shadow .18s;
}
.pms-ios-card:hover { box-shadow:0 4px 16px rgba(46,80,119,0.12); }
.pms-ios-left  { display:flex; align-items:center; gap:10px; flex:1; min-width:0; }
.pms-ios-dot   { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.pms-ios-info  { flex:1; min-width:0; }
.pms-ios-name  {
  font-size:14px; font-weight:600; color:var(--clr-text); text-decoration:none;
  display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.pms-ios-meta { display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-top:2px; }
.pms-ios-chip { font-size:11px; color:var(--clr-text-muted); background:rgba(46,80,119,0.07); border-radius:4px; padding:1px 6px; }
.pms-ios-chip-loc { background:rgba(16,185,129,0.08); color:#059669; }
.pms-ios-phone { font-size:11px; color:var(--clr-accent); text-decoration:none; }
.pms-ios-right { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.pms-ios-date-pill { font-size:11px; font-weight:600; color:var(--clr-text-muted); }
.pms-ios-time-pill { font-size:11px; color:var(--clr-text-muted); }
.pms-ios-chevron {
  display:inline-flex; align-items:center; justify-content:center;
  width:18px; height:18px; border-radius:50%;
  background:rgba(46,80,119,0.06); border:none; padding:0;
  color:var(--clr-accent); font-size:9px; flex-shrink:0;
  transition:transform .25s, background .18s;
}
.pms-ios-chevron.open { transform:rotate(90deg); background:rgba(46,80,119,0.13); }

/* === ACTION BUTTONS === */
.pms-ios-actions { display:flex; align-items:center; gap:4px; }
.pms-ios-btn {
  display:inline-flex; align-items:center; justify-content:center;
  width:30px; height:30px; border-radius:8px; border:none;
  font-size:12px; text-decoration:none; cursor:pointer;
  transition:transform .13s, opacity .13s;
}
.pms-ios-btn:hover { transform:scale(1.08); opacity:.88; }
.pms-ios-btn-teal   { background:#2E5077; color:#fff; }
.pms-ios-btn-green  { background:#28a745; color:#fff; }
.pms-ios-btn-red    { background:#e74c3c; color:#fff; }
.pms-ios-btn-blue   { background:#3b82f6; color:#fff; }
.pms-ios-btn-orange { background:#f59e0b; color:#fff; }
.pms-ios-btn-purple { background:#8b5cf6; color:#fff; }
