/* ============================================================================
   Healthcare Dashboard — Premium Earth-Toned Design System
   Version: 1.0.0

   A clean, minimal, confident design language inspired by quiet luxury.
   Square aesthetic, generous whitespace, flat with subtle shadows.
   ============================================================================ */


/* ---------------------------------------------------------------------------
   1. DESIGN TOKENS / CSS CUSTOM PROPERTIES
   --------------------------------------------------------------------------- */

:root {
  /* Core earth-tone palette — darkest to lightest */
  --color-espresso: #2C1810;
  --color-dark-walnut: #3E2723;
  --color-coffee: #4E342E;
  --color-mocha: #5D4037;
  --color-cocoa: #6D4C41;
  --color-sienna: #795548;
  --color-clay: #8D6E63;
  --color-sandstone: #A1887F;
  --color-taupe: #BCAAA4;
  --color-latte: #D7CCC8;
  --color-cream: #EFEBE9;
  --color-ivory: #FAF7F5;
  --color-white: #FFFFFF;

  /* Accent palette */
  --color-terracotta: #C75B39;
  --color-amber: #D4A24E;
  --color-sage: #7A9B6D;
  --color-forest: #3D6B35;
  --color-slate-blue: #6B7FA3;
  --color-deep-moss: #4A6741;
  --color-rust: #A0522D;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(44, 24, 16, 0.05);
  --shadow-md: 0 2px 8px rgba(44, 24, 16, 0.08);
  --shadow-lg: 0 4px 16px rgba(44, 24, 16, 0.10);
  --shadow-card: 0 1px 3px rgba(44, 24, 16, 0.06);
  --shadow-card-hover: 0 6px 20px rgba(44, 24, 16, 0.10);

  /* Typography */
  --font-primary: 'SF Pro Display', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'SF Mono', 'Fira Code', 'Consolas', monospace;

  /* Spacing scale */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;
  --space-3xl: 64px;

  /* Border radius */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --radius-xl: 12px;

  /* Transitions */
  --transition-fast: 120ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 320ms ease;

  /* Z-index scale */
  --z-sidebar: 100;
  --z-header: 200;
  --z-dropdown: 300;
  --z-modal-backdrop: 400;
  --z-modal: 500;
  --z-toast: 600;

  /* Layout dimensions */
  --sidebar-width: 260px;
  --header-height: 64px;
}


/* ---------------------------------------------------------------------------
   2. RESET & BASE STYLES
   --------------------------------------------------------------------------- */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-primary);
  font-size: 0.9375rem; /* 15px */
  line-height: 1.6;
  color: var(--color-espresso);
  background-color: var(--color-cream);
  overflow-x: hidden;
}

h1, h2, h3, h4 {
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-espresso);
  letter-spacing: -0.01em;
}

h1 {
  font-size: 1.75rem;
  font-weight: 700;
}

h2 {
  font-size: 1.375rem;
}

h3 {
  font-size: 1.125rem;
}

h4 {
  font-size: 1rem;
}

p {
  margin-bottom: var(--space-md);
  color: var(--color-coffee);
}

small {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

a {
  color: var(--color-rust);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-terracotta);
}

img {
  max-width: 100%;
  display: block;
}

code, pre {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
}

pre {
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  overflow-x: auto;
}

code {
  background: var(--color-ivory);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  color: var(--color-mocha);
}

hr {
  border: none;
  height: 1px;
  background: var(--color-latte);
  margin: var(--space-lg) 0;
}

::selection {
  background: var(--color-taupe);
  color: var(--color-espresso);
}


/* ---------------------------------------------------------------------------
   3. APP LAYOUT — TOP NAV + MAIN CONTENT
   --------------------------------------------------------------------------- */

.app-layout {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.main-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.page-header {
  padding: var(--space-lg) var(--space-xl) 0;
}

.main-content {
  background: var(--color-cream);
  padding: var(--space-lg) var(--space-xl) var(--space-xl);
  flex: 1;
}


/* ---------------------------------------------------------------------------
   4. TOP NAVIGATION BAR
   --------------------------------------------------------------------------- */

.topbar {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-latte);
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  box-shadow: 0 1px 8px rgba(44, 24, 16, 0.04);
}

.topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height);
  padding: 0 var(--space-lg);
  width: 100%;
}

/* Brand / logo */
.topbar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
  margin-right: var(--space-xl);
}

.topbar-brand-logo {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  transition: transform var(--transition-base);
}

.topbar-brand:hover .topbar-brand-logo {
  transform: scale(1.08);
}

.topbar-brand-name {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-espresso);
  letter-spacing: -0.02em;
}

/* Left grouping: brand + nav */
.topbar-left {
  display: flex;
  align-items: center;
  gap: 0;
  flex: 1;
  min-width: 0;
}

/* Navigation links */
.topbar-nav {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-wrap: nowrap;
  padding-left: var(--space-sm);
}

/* Unified nav item style — same for links and group triggers */
.topbar-nav-link {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-cocoa);
  text-decoration: none;
  background: none;
  border: none;
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
  position: relative;
  white-space: nowrap;
  cursor: pointer;
  font-family: var(--font-primary);
  line-height: 1.4;
}

.topbar-nav-link:hover {
  color: var(--color-espresso);
  background: var(--color-cream);
}

/* Active state: subtle bottom accent bar, not a filled background */
.topbar-nav-link.active {
  color: var(--color-espresso);
  font-weight: 600;
}

.topbar-nav-link.active::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 8px;
  right: 8px;
  height: 2px;
  background: var(--color-rust);
  border-radius: 1px;
}


/* Right side */
.topbar-right {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.topbar-physician {
  display: flex;
  align-items: center;
}

.topbar-physician-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
  white-space: nowrap;
}

/* Icon buttons (bell, gear) */
.topbar-icon-group {
  position: relative;
}

.topbar-icon-btn {
  position: relative;
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  border: none;
  background: none;
  color: var(--color-cocoa);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
}

.topbar-icon-btn:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
  transform: scale(1.05);
}

.topbar-icon-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  min-width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--color-terracotta);
  color: var(--color-white);
  font-size: 0.625rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-white);
  line-height: 1;
}

.topbar-icon-badge:empty {
  display: none;
}

/* Mobile hamburger */
.topbar-hamburger {
  display: none;
  background: none;
  border: none;
  color: var(--color-espresso);
  cursor: pointer;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.topbar-hamburger:hover {
  background: var(--color-cream);
}

/* Mobile overlay */
.topbar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(44, 24, 16, 0.4);
  z-index: calc(var(--z-header) - 1);
  backdrop-filter: blur(2px);
}

/* Notification dropdown */
.notification-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: var(--space-sm);
  min-width: 340px;
  z-index: var(--z-dropdown);
}

/* ── Responsive nav: progressive compacting ────────────────── */

/* Medium screens — hide physician name, compact links */
@media (max-width: 1200px) {
  .topbar-physician { display: none; }
  .topbar-nav-link { padding: 5px 9px; font-size: 0.75rem; }
  .topbar-brand { margin-right: var(--space-md); }
}

/* Tight screens — hide brand name */
@media (max-width: 1000px) {
  .topbar-brand-name { display: none; }
  .topbar-brand { margin-right: var(--space-sm); }
}

/* Mobile — hamburger menu */
@media (max-width: 900px) {
  .topbar-nav {
    display: none;
    position: absolute;
    top: var(--header-height);
    left: 0;
    right: 0;
    background: var(--color-white);
    flex-direction: column;
    align-items: stretch;
    padding: var(--space-sm) var(--space-md);
    border-bottom: 1px solid var(--color-latte);
    box-shadow: 0 8px 24px rgba(44, 24, 16, 0.1);
    z-index: var(--z-dropdown);
    animation: slideDown 0.25s ease-out;
    overflow-x: visible;
  }

  .topbar-nav--open {
    display: flex;
  }


  .topbar-nav-link {
    padding: 12px 16px;
    font-size: 1rem;
    border-radius: var(--radius-md);
  }

  .topbar-nav-link.active::after {
    display: none;
  }

  .topbar-nav-link.active {
    background: var(--color-cream);
  }

  /* Nav group dropdowns — mobile: inline expand */
  .topbar-nav-group {
    display: block;
    width: 100%;
    position: relative;
  }

  .topbar-nav-group-trigger {
    display: flex;
    width: 100%;
    justify-content: space-between;
    padding: 12px 16px;
    font-size: 1rem;
  }

  .topbar-dropdown {
    position: static;
    transform: none;
    min-width: auto;
    border: none;
    box-shadow: none;
    border-radius: 0;
    padding: 0;
    background: var(--color-ivory);
  }

  .topbar-dropdown::before {
    display: none;
  }

  .topbar-dropdown-link {
    padding: 10px 16px 10px 32px;
    font-size: 0.9rem;
  }

  .topbar-hamburger {
    display: flex;
  }

  .topbar-overlay {
    display: block;
  }

  .topbar-physician {
    display: none;
  }

  .topbar-brand-name {
    font-size: 1rem;
  }

  .page-header {
    padding: var(--space-md) var(--space-md) 0;
  }

  .main-content {
    padding: var(--space-md);
  }
}

/* Aliases — backward compatibility with old header classes */
.header-bar { display: none; }
.header-bar-left,
.header-bar-right,
.header-left,
.header-right { display: flex; align-items: center; gap: var(--space-md); }
.header-title { font-size: 1.125rem; font-weight: 600; color: var(--color-espresso); }
.header-physician { display: flex; flex-direction: column; align-items: flex-end; line-height: 1.3; }
.header-physician-name { font-size: 0.875rem; font-weight: 600; color: var(--color-espresso); }
.header-physician-npi { font-size: 0.6875rem; color: var(--color-sandstone); font-family: var(--font-mono); }
.header-icon-btn { position: relative; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-md); border: none; background: none; color: var(--color-cocoa); cursor: pointer; transition: all var(--transition-fast); }
.header-icon-btn:hover { background: var(--color-cream); color: var(--color-espresso); }
.header-icon-badge { position: absolute; top: 4px; right: 4px; width: 16px; height: 16px; border-radius: 50%; background: var(--color-terracotta); color: var(--color-white); font-size: 0.625rem; font-weight: 700; display: flex; align-items: center; justify-content: center; border: 2px solid var(--color-white); line-height: 1; }
.header-icon-badge:empty { display: none; }

/* Sidebar aliases (for any templates that still reference them) */
.sidebar { display: none; }
.sidebar-toggle { display: none; }
.sidebar-overlay { display: none; }
.sidebar-nav-item { display: none; }
.sidebar-nav-separator { display: none; }
.sidebar-logo { display: none; }
.sidebar-logo-mark { display: none; }
.sidebar-footer { display: none; }
.sidebar-connection-status { display: none; }
.connection-dot { display: none; }


/* ---------------------------------------------------------------------------
   4b. NAV GROUP DROPDOWNS
   --------------------------------------------------------------------------- */

/* Nav group — use static positioning; dropdown anchors to topbar bottom */
.topbar-nav-group {
  position: static;
}

/* Group trigger — inherits .topbar-nav-link styles, just adds gap for chevron */
.topbar-nav-group-trigger {
  gap: 4px;
}

.topbar-nav-chevron {
  transition: transform var(--transition-fast);
  opacity: 0.5;
  flex-shrink: 0;
}

.topbar-nav-chevron--open {
  transform: rotate(180deg);
}

/* Dropdown panel — anchored to top of main content, below topbar */
.topbar-dropdown {
  position: absolute;
  top: calc(var(--header-height) - 4px);
  left: auto;
  min-width: 190px;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  box-shadow: 0 8px 24px rgba(44, 24, 16, 0.10), 0 2px 6px rgba(44, 24, 16, 0.06);
  padding: var(--space-xs) 0;
  z-index: var(--z-dropdown);
}

/* Small upward arrow on dropdown */
.topbar-dropdown::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 24px;
  width: 10px;
  height: 10px;
  background: var(--color-white);
  border-left: 1px solid var(--color-latte);
  border-top: 1px solid var(--color-latte);
  transform: rotate(45deg);
}

.topbar-dropdown-link {
  display: block;
  padding: 10px 16px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-cocoa);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.topbar-dropdown-link:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}

.topbar-dropdown-link.active {
  color: var(--color-espresso);
  font-weight: 600;
  background: var(--color-ivory);
  border-left: 3px solid var(--color-rust);
}


/* ---------------------------------------------------------------------------
   4c. COMMAND PALETTE (Cmd+K)
   --------------------------------------------------------------------------- */

[x-cloak] { display: none !important; }

.cmd-palette-overlay {
  position: fixed;
  inset: 0;
  background: rgba(44, 24, 16, 0.4);
  backdrop-filter: blur(4px);
  z-index: var(--z-modal);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 20vh;
}

.cmd-palette {
  width: 520px;
  max-width: 90vw;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-xl);
  box-shadow: 0 20px 60px rgba(44, 24, 16, 0.2);
  overflow: hidden;
  animation: scaleIn 0.15s ease-out;
}

.cmd-palette-input-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--color-latte);
  color: var(--color-sandstone);
}

.cmd-palette-input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 1rem;
  font-family: var(--font-primary);
  color: var(--color-espresso);
  background: none;
}

.cmd-palette-input::placeholder {
  color: var(--color-taupe);
}

.cmd-palette-kbd {
  font-size: 0.65rem;
  font-family: var(--font-mono);
  padding: 2px 6px;
  background: var(--color-cream);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-sm);
  color: var(--color-sandstone);
}

.cmd-palette-results {
  max-height: 320px;
  overflow-y: auto;
  padding: var(--space-xs) 0;
}

.cmd-palette-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 10px var(--space-lg);
  text-decoration: none;
  color: var(--color-espresso);
  transition: background var(--transition-fast);
}

.cmd-palette-item:hover,
.cmd-palette-item--active {
  background: var(--color-cream);
}

.cmd-palette-item-group {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
  min-width: 70px;
}

.cmd-palette-item-label {
  font-size: 0.9rem;
  font-weight: 500;
}

.cmd-palette-empty {
  padding: var(--space-lg);
  text-align: center;
  color: var(--color-sandstone);
  font-size: 0.85rem;
}

.cmd-palette-footer {
  display: flex;
  gap: var(--space-lg);
  padding: var(--space-sm) var(--space-lg);
  border-top: 1px solid var(--color-latte);
  background: var(--color-ivory);
  font-size: 0.7rem;
  color: var(--color-sandstone);
}

.cmd-palette-footer kbd {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  padding: 1px 4px;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: 3px;
  margin-right: 2px;
}

/* (Cmd+K hint replaced by search icon using .topbar-icon-btn) */


/* ---------------------------------------------------------------------------
   4d. FLOATING ACTION BUTTON (FAB)
   --------------------------------------------------------------------------- */

.fab-container {
  position: fixed;
  bottom: var(--space-xl);
  right: var(--space-xl);
  z-index: var(--z-dropdown);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-sm);
}

.fab-btn {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: none;
  background: var(--color-rust);
  color: var(--color-white);
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(160, 82, 45, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-base);
}

.fab-btn:hover {
  background: var(--color-terracotta);
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(160, 82, 45, 0.4);
}

.fab-btn--open {
  transform: rotate(45deg);
}

.fab-btn--open:hover {
  transform: rotate(45deg) scale(1.08);
}

.fab-menu {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  padding-bottom: var(--space-sm);
}

.fab-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 8px 16px;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: 24px;
  box-shadow: var(--shadow-md);
  text-decoration: none;
  color: var(--color-espresso);
  font-size: 0.8rem;
  font-weight: 500;
  font-family: inherit;
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.fab-menu-item:hover {
  background: var(--color-cream);
  box-shadow: var(--shadow-lg);
  transform: translateX(-4px);
}

.fab-menu-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--color-cocoa);
}

.fab-menu-label {
  font-size: 0.8rem;
}


/* ---------------------------------------------------------------------------
   5. ANIMATIONS
   --------------------------------------------------------------------------- */

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

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: scaleX(0);
  }
  to {
    opacity: 1;
    transform: scaleX(1);
  }
}

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

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

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

/* Reusable animation classes */
.fade-in {
  animation: fadeIn 0.4s ease-out both;
}

.fade-in-up {
  animation: fadeInUp 0.5s ease-out both;
}

.scale-in {
  animation: scaleIn 0.35s ease-out both;
}

/* Staggered children animation */
.stagger-in > * {
  animation: fadeInUp 0.4s ease-out both;
}

.stagger-in > *:nth-child(1) { animation-delay: 0.05s; }
.stagger-in > *:nth-child(2) { animation-delay: 0.1s; }
.stagger-in > *:nth-child(3) { animation-delay: 0.15s; }
.stagger-in > *:nth-child(4) { animation-delay: 0.2s; }
.stagger-in > *:nth-child(5) { animation-delay: 0.25s; }
.stagger-in > *:nth-child(6) { animation-delay: 0.3s; }
.stagger-in > *:nth-child(7) { animation-delay: 0.35s; }
.stagger-in > *:nth-child(8) { animation-delay: 0.4s; }

/* Hover lift effect */
.hover-lift {
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.hover-lift:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(44, 24, 16, 0.12);
}

/* Pulse for notification badges */
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}

@keyframes pulse-connecting {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* Smooth page transitions */
.main-content > * {
  animation: fadeInUp 0.35s ease-out both;
}

/* Card hover animations */
.card {
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

/* Header bar hidden override — we use topbar now */
.header-bar { display: none !important; }


/* ---------------------------------------------------------------------------
   6. CARD COMPONENT
   --------------------------------------------------------------------------- */

.card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.card:hover {
  box-shadow: var(--shadow-md);
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-cream);
}

.card-header h2,
.card-header h3 {
  margin: 0;
}

.card-header-subtitle {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-top: 2px;
}

.card-body {
  /* Intentionally minimal — content drives height */
}

.card-footer {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-cream);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-sm);
}

.card-clickable {
  cursor: pointer;
}

.card-clickable:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-lg);
}

/* Card with colored left border (for alerts, clinical snapshots) */
.card-accent {
  border-left: 3px solid var(--color-rust);
}

.card-accent-terracotta {
  border-left-color: var(--color-terracotta);
}

.card-accent-amber {
  border-left-color: var(--color-amber);
}

.card-accent-sage {
  border-left-color: var(--color-sage);
}

.card-accent-blue {
  border-left-color: var(--color-slate-blue);
}


/* ---------------------------------------------------------------------------
   7. STAT CARDS
   --------------------------------------------------------------------------- */

.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.stat-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--transition-base);
}

.stat-card:hover {
  box-shadow: var(--shadow-md);
}

.stat-card-label {
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
  margin-bottom: var(--space-sm);
}

.stat-card-value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.stat-card-subtext {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
}

.stat-card-trend {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 0.75rem;
  font-weight: 500;
  margin-top: var(--space-xs);
}

.stat-card-trend.up {
  color: var(--color-deep-moss);
}

.stat-card-trend.down {
  color: var(--color-terracotta);
}

.stat-card-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  margin-bottom: var(--space-sm);
}

.stat-card-icon.icon-mocha {
  background: rgba(93, 64, 55, 0.1);
  color: var(--color-mocha);
}

.stat-card-icon.icon-sage {
  background: rgba(122, 155, 109, 0.12);
  color: var(--color-sage);
}

.stat-card-icon.icon-amber {
  background: rgba(212, 162, 78, 0.12);
  color: var(--color-amber);
}

.stat-card-icon.icon-terracotta {
  background: rgba(199, 91, 57, 0.1);
  color: var(--color-terracotta);
}

.stat-card-icon.icon-blue {
  background: rgba(107, 127, 163, 0.12);
  color: var(--color-slate-blue);
}


/* ---------------------------------------------------------------------------
   8. BUTTONS
   --------------------------------------------------------------------------- */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: 10px 20px;
  font-family: var(--font-primary);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  white-space: nowrap;
  user-select: none;
}

.btn:active {
  transform: scale(0.97);
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.btn-primary {
  background: var(--color-mocha);
  color: var(--color-white);
  border-color: var(--color-mocha);
}

.btn-primary:hover:not(:disabled) {
  background: var(--color-coffee);
  border-color: var(--color-coffee);
}

.btn-secondary {
  background: transparent;
  color: var(--color-mocha);
  border-color: var(--color-taupe);
}

.btn-secondary:hover:not(:disabled) {
  background: var(--color-cream);
  border-color: var(--color-sandstone);
}

.btn-danger {
  background: var(--color-terracotta);
  color: var(--color-white);
  border-color: var(--color-terracotta);
}

.btn-danger:hover:not(:disabled) {
  background: #b5492e;
  border-color: #b5492e;
}

.btn-ghost {
  background: transparent;
  color: var(--color-cocoa);
  border-color: transparent;
}

.btn-ghost:hover:not(:disabled) {
  background: var(--color-cream);
  color: var(--color-espresso);
}

.btn-sm {
  padding: 6px 12px;
  font-size: 0.8125rem;
}

.btn-lg {
  padding: 14px 28px;
  font-size: 1rem;
  font-weight: 600;
}

.btn-block {
  display: flex;
  width: 100%;
}

.btn-icon {
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: var(--radius-md);
}

.btn-icon.btn-sm {
  width: 28px;
  height: 28px;
}


/* ---------------------------------------------------------------------------
   9. FORMS
   --------------------------------------------------------------------------- */

.form-group {
  margin-bottom: var(--space-md);
}

.form-label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-coffee);
  margin-bottom: var(--space-xs);
}

.form-label .required {
  color: var(--color-terracotta);
  margin-left: 2px;
}

.input,
.select,
.textarea {
  width: 100%;
  padding: 10px 12px;
  font-family: var(--font-primary);
  font-size: 0.875rem;
  color: var(--color-espresso);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
}

.input:focus,
.select:focus,
.textarea:focus {
  border-color: var(--color-sandstone);
  box-shadow: 0 0 0 3px rgba(141, 110, 99, 0.1);
}

.input::placeholder,
.textarea::placeholder {
  color: var(--color-taupe);
}

.input:disabled,
.select:disabled,
.textarea:disabled {
  background: var(--color-ivory);
  color: var(--color-sandstone);
  cursor: not-allowed;
}

.input.error,
.select.error,
.textarea.error {
  border-color: var(--color-terracotta);
}

.input.error:focus,
.select.error:focus,
.textarea.error:focus {
  box-shadow: 0 0 0 3px rgba(199, 91, 57, 0.1);
}

.select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A1887F' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  cursor: pointer;
}

.textarea {
  min-height: 100px;
  resize: vertical;
  line-height: 1.5;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}

.form-row:has(.form-group--third) {
  grid-template-columns: 1fr 1fr 1fr;
}

.form-hint {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
}

.form-error {
  font-size: 0.75rem;
  color: var(--color-terracotta);
  margin-top: var(--space-xs);
}

.input-group {
  display: flex;
  align-items: stretch;
}

.input-group .input {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.input-group .btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.checkbox-group,
.radio-group {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
}

.checkbox-group input,
.radio-group input {
  accent-color: var(--color-mocha);
}


/* ---------------------------------------------------------------------------
   10. TABLES
   --------------------------------------------------------------------------- */

.table-container {
  overflow-x: auto;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-latte);
  background: var(--color-white);
}

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.table thead th {
  padding: 12px var(--space-md);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-sandstone);
  background: var(--color-ivory);
  border-bottom: 1px solid var(--color-latte);
  text-align: left;
  white-space: nowrap;
  user-select: none;
}

.table thead th.sortable {
  cursor: pointer;
  transition: color var(--transition-fast);
}

.table thead th.sortable:hover {
  color: var(--color-mocha);
}

.table thead th.sorted {
  color: var(--color-mocha);
}

.table tbody tr {
  border-bottom: 1px solid var(--color-cream);
  transition: background var(--transition-fast);
}

.table tbody tr:nth-child(even) {
  background: var(--color-ivory);
}

.table tbody tr:hover {
  background: var(--color-cream);
}

.table tbody td {
  padding: 12px var(--space-md);
  color: var(--color-coffee);
  vertical-align: middle;
}

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

.table-row-clickable {
  cursor: pointer;
}

.table-cell-mono {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
}

.table-cell-actions {
  text-align: right;
  white-space: nowrap;
}

.table-cell-actions .btn + .btn {
  margin-left: var(--space-xs);
}

.table-empty {
  text-align: center;
  padding: var(--space-2xl) var(--space-md);
  color: var(--color-sandstone);
}


/* ---------------------------------------------------------------------------
   11. BADGES
   --------------------------------------------------------------------------- */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  line-height: 1.4;
}

.badge-default {
  background: var(--color-cream);
  color: var(--color-cocoa);
}

.badge-success {
  background: rgba(122, 155, 109, 0.12);
  color: var(--color-deep-moss);
}

.badge-warning {
  background: rgba(212, 162, 78, 0.14);
  color: #a07828;
}

.badge-error {
  background: rgba(199, 91, 57, 0.1);
  color: var(--color-terracotta);
}

.badge-info {
  background: rgba(107, 127, 163, 0.12);
  color: var(--color-slate-blue);
}

.badge-dark {
  background: var(--color-coffee);
  color: var(--color-white);
}

.badge-outline {
  background: transparent;
  border: 1px solid currentColor;
}

.badge-lg {
  padding: 5px 14px;
  font-size: 0.75rem;
}


/* ---------------------------------------------------------------------------
   12. STATUS DOTS
   --------------------------------------------------------------------------- */

.status-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.status-dot-sm {
  width: 6px;
  height: 6px;
}

.status-dot-lg {
  width: 10px;
  height: 10px;
}

.status-connected {
  background: var(--color-deep-moss);
}

.status-disconnected {
  background: var(--color-terracotta);
}

.status-connecting {
  background: var(--color-amber);
  animation: pulse-connecting 1.5s ease-in-out infinite;
}

.status-idle {
  background: var(--color-sandstone);
}

@keyframes pulse-connecting {
  0%, 100% {
    opacity: 1;
    box-shadow: 0 0 0 0 rgba(212, 162, 78, 0.4);
  }
  50% {
    opacity: 0.6;
    box-shadow: 0 0 0 6px rgba(212, 162, 78, 0);
  }
}


/* ---------------------------------------------------------------------------
   13. NOTIFICATION TIMELINE
   --------------------------------------------------------------------------- */

.notification-timeline {
  list-style: none;
  padding: 0;
  margin: 0;
}

.notification-item {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-md);
  border-left: 3px solid var(--color-taupe);
  margin-left: var(--space-sm);
  position: relative;
  transition: background var(--transition-fast);
}

.notification-item:hover {
  background: var(--color-ivory);
}

.notification-item + .notification-item {
  margin-top: 2px;
}

/* Priority-based left border colors */
.notification-item.priority-urgent {
  border-left-color: var(--color-terracotta);
}

.notification-item.priority-high {
  border-left-color: var(--color-amber);
}

.notification-item.priority-medium {
  border-left-color: var(--color-slate-blue);
}

.notification-item.priority-low {
  border-left-color: var(--color-taupe);
}

.notification-item-content {
  flex: 1;
  min-width: 0;
}

.notification-item-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
  margin-bottom: 2px;
}

.notification-item-body {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  line-height: 1.5;
}

.notification-item-meta {
  font-size: 0.6875rem;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.notification-item-time {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  white-space: nowrap;
  flex-shrink: 0;
}

.notification-unread {
  background: rgba(160, 82, 45, 0.03);
}

.notification-unread .notification-item-title {
  font-weight: 600;
}

.notification-unread::before {
  content: '';
  position: absolute;
  left: -7px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-rust);
}


/* ---------------------------------------------------------------------------
   14. PRIORITY MARKERS
   --------------------------------------------------------------------------- */

.priority-marker {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.priority-marker::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.priority-marker.urgent::before {
  background: var(--color-terracotta);
}

.priority-marker.urgent {
  color: var(--color-terracotta);
}

.priority-marker.high::before {
  background: var(--color-amber);
}

.priority-marker.high {
  color: #a07828;
}

.priority-marker.medium::before {
  background: var(--color-slate-blue);
}

.priority-marker.medium {
  color: var(--color-slate-blue);
}

.priority-marker.low::before {
  background: var(--color-taupe);
}

.priority-marker.low {
  color: var(--color-sandstone);
}


/* ---------------------------------------------------------------------------
   15. PATIENT ACUITY DOTS
   --------------------------------------------------------------------------- */

.acuity-dots {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.acuity-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-latte);
}

/* Level 1 — Low acuity (1 green dot) */
.acuity-level-1 .acuity-dot:nth-child(1) {
  background: var(--color-sage);
}

/* Level 2 — Moderate (2 amber dots) */
.acuity-level-2 .acuity-dot:nth-child(1),
.acuity-level-2 .acuity-dot:nth-child(2) {
  background: var(--color-amber);
}

/* Level 3 — High (3 terracotta dots) */
.acuity-level-3 .acuity-dot:nth-child(1),
.acuity-level-3 .acuity-dot:nth-child(2),
.acuity-level-3 .acuity-dot:nth-child(3) {
  background: var(--color-terracotta);
}

/* Level 4 — Critical (4 dark dots) */
.acuity-level-4 .acuity-dot:nth-child(1),
.acuity-level-4 .acuity-dot:nth-child(2),
.acuity-level-4 .acuity-dot:nth-child(3),
.acuity-level-4 .acuity-dot:nth-child(4) {
  background: var(--color-espresso);
}


/* ---------------------------------------------------------------------------
   16. HORIZONTAL BAR CHART
   --------------------------------------------------------------------------- */

.bar-chart {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.bar-chart-row {
  display: grid;
  grid-template-columns: 140px 1fr 60px;
  align-items: center;
  gap: var(--space-md);
}

.bar-chart-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-coffee);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bar-chart-track {
  height: 24px;
  background: var(--color-cream);
  border-radius: var(--radius-sm);
  overflow: hidden;
  position: relative;
}

.bar-chart-fill {
  height: 100%;
  border-radius: var(--radius-sm);
  background: var(--color-mocha);
  transition: width 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  min-width: 4px;
}

.bar-chart-fill.fill-mocha {
  background: var(--color-mocha);
}

.bar-chart-fill.fill-sage {
  background: var(--color-sage);
}

.bar-chart-fill.fill-amber {
  background: var(--color-amber);
}

.bar-chart-fill.fill-terracotta {
  background: var(--color-terracotta);
}

.bar-chart-fill.fill-blue {
  background: var(--color-slate-blue);
}

.bar-chart-fill.fill-clay {
  background: var(--color-clay);
}

.bar-chart-fill.fill-rust {
  background: var(--color-rust);
}

.bar-chart-value {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-espresso);
  text-align: right;
  font-family: var(--font-mono);
}

.bar-chart-row:hover .bar-chart-track {
  background: var(--color-latte);
}


/* ---------------------------------------------------------------------------
   17. BILLING OPPORTUNITY TABLE
   --------------------------------------------------------------------------- */

.billing-table {
  width: 100%;
}

.billing-table .opportunity-value {
  font-weight: 600;
  color: var(--color-deep-moss);
  font-family: var(--font-mono);
}

.billing-table .opportunity-code {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  background: var(--color-ivory);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
}

.billing-table .opportunity-status {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.billing-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-ivory);
  border-radius: var(--radius-md);
  margin-top: var(--space-md);
}

.billing-summary-label {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.billing-summary-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-deep-moss);
  font-family: var(--font-mono);
}


/* ---------------------------------------------------------------------------
   18. TCM TRACKING TABLE WITH COUNTDOWN BADGES
   --------------------------------------------------------------------------- */

.tcm-table {
  width: 100%;
}

.tcm-countdown {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 600;
  font-family: var(--font-mono);
}

.tcm-countdown.days-critical {
  background: rgba(199, 91, 57, 0.1);
  color: var(--color-terracotta);
}

.tcm-countdown.days-warning {
  background: rgba(212, 162, 78, 0.14);
  color: #a07828;
}

.tcm-countdown.days-ok {
  background: rgba(122, 155, 109, 0.12);
  color: var(--color-deep-moss);
}

.tcm-countdown.days-expired {
  background: rgba(199, 91, 57, 0.08);
  color: var(--color-sandstone);
  text-decoration: line-through;
}

.tcm-step-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.tcm-step {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.8125rem;
  color: var(--color-cocoa);
}

.tcm-step-check {
  width: 16px;
  height: 16px;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--color-taupe);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.625rem;
}

.tcm-step.completed .tcm-step-check {
  background: var(--color-deep-moss);
  border-color: var(--color-deep-moss);
  color: var(--color-white);
}

.tcm-step.completed {
  color: var(--color-sandstone);
}

.tcm-progress-bar {
  width: 100%;
  height: 4px;
  background: var(--color-cream);
  border-radius: 2px;
  overflow: hidden;
}

.tcm-progress-fill {
  height: 100%;
  background: var(--color-sage);
  border-radius: 2px;
  transition: width var(--transition-slow);
}


/* ---------------------------------------------------------------------------
   19. TABS
   --------------------------------------------------------------------------- */

.tab-bar {
  display: flex;
  align-items: center;
  gap: 0;
  border-bottom: 1px solid var(--color-latte);
  margin-bottom: var(--space-lg);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.tab {
  padding: var(--space-md) var(--space-lg);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sandstone);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
  font-family: var(--font-primary);
  position: relative;
  bottom: -1px;
}

.tab:hover {
  color: var(--color-mocha);
}

.tab.active {
  color: var(--color-espresso);
  border-bottom-color: var(--color-rust);
  font-weight: 600;
}

.tab-badge {
  margin-left: var(--space-xs);
  background: var(--color-cream);
  color: var(--color-cocoa);
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 10px;
}

.tab.active .tab-badge {
  background: var(--color-rust);
  color: var(--color-white);
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
  animation: fadeIn var(--transition-base);
}


/* ---------------------------------------------------------------------------
   20. MODAL
   --------------------------------------------------------------------------- */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(44, 24, 16, 0.45);
  z-index: var(--z-modal-backdrop);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}

.modal-backdrop.open {
  opacity: 1;
  visibility: visible;
}

.modal-content {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg), 0 20px 60px rgba(44, 24, 16, 0.15);
  max-width: 560px;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  transform: translateY(20px);
  transition: transform var(--transition-base);
  z-index: var(--z-modal);
}

.modal-backdrop.open .modal-content {
  transform: translateY(0);
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-lg) var(--space-md);
  border-bottom: 1px solid var(--color-cream);
}

.modal-header h2,
.modal-header h3 {
  margin: 0;
}

.modal-close {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  color: var(--color-sandstone);
  cursor: pointer;
  border-radius: var(--radius-md);
  font-size: 1.125rem;
  transition: all var(--transition-fast);
}

.modal-close:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}

.modal-body {
  padding: var(--space-lg);
}

.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg) var(--space-lg);
  border-top: 1px solid var(--color-cream);
}

.modal-lg {
  max-width: 720px;
}

.modal-sm {
  max-width: 400px;
}


/* ---------------------------------------------------------------------------
   21. TOAST NOTIFICATIONS
   --------------------------------------------------------------------------- */

.toast-container {
  position: fixed;
  top: var(--space-lg);
  right: var(--space-lg);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  pointer-events: none;
}

.toast {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-lg);
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  max-width: 380px;
  min-width: 280px;
  pointer-events: auto;
  animation: toastSlideIn var(--transition-base) ease-out;
  transition: opacity var(--transition-base), transform var(--transition-base);
}

.toast.toast-dismiss {
  opacity: 0;
  transform: translateX(100%);
}

.toast-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}

.toast-success .toast-icon {
  color: var(--color-deep-moss);
}

.toast-error .toast-icon {
  color: var(--color-terracotta);
}

.toast-warning .toast-icon {
  color: var(--color-amber);
}

.toast-info .toast-icon {
  color: var(--color-slate-blue);
}

.toast-body {
  flex: 1;
  min-width: 0;
}

.toast-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
}

.toast-message {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  margin-top: 2px;
}

.toast-close {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  color: var(--color-sandstone);
  cursor: pointer;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  flex-shrink: 0;
  transition: color var(--transition-fast);
}

.toast-close:hover {
  color: var(--color-espresso);
}

@keyframes toastSlideIn {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Toast accent left borders */
.toast-success {
  border-left: 3px solid var(--color-sage);
}

.toast-error {
  border-left: 3px solid var(--color-terracotta);
}

.toast-warning {
  border-left: 3px solid var(--color-amber);
}

.toast-info {
  border-left: 3px solid var(--color-slate-blue);
}


/* ---------------------------------------------------------------------------
   22. PAGINATION
   --------------------------------------------------------------------------- */

.pagination {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  justify-content: center;
  margin-top: var(--space-lg);
}

.pagination-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 var(--space-sm);
  font-family: var(--font-primary);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-cocoa);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.pagination-btn:hover:not(:disabled) {
  background: var(--color-cream);
  border-color: var(--color-sandstone);
}

.pagination-btn.active {
  background: var(--color-mocha);
  color: var(--color-white);
  border-color: var(--color-mocha);
}

.pagination-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.pagination-ellipsis {
  padding: 0 var(--space-xs);
  color: var(--color-sandstone);
  font-size: 0.875rem;
}

.pagination-info {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-left: var(--space-md);
}


/* ---------------------------------------------------------------------------
   23. LOADING / SKELETON
   --------------------------------------------------------------------------- */

.skeleton {
  background: linear-gradient(90deg, var(--color-cream) 25%, var(--color-latte) 50%, var(--color-cream) 75%);
  background-size: 200% 100%;
  animation: skeletonPulse 1.5s ease-in-out infinite;
  border-radius: var(--radius-md);
}

.skeleton-text {
  height: 14px;
  margin-bottom: var(--space-sm);
}

.skeleton-text:last-child {
  width: 60%;
}

.skeleton-heading {
  height: 22px;
  width: 45%;
  margin-bottom: var(--space-md);
}

.skeleton-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
}

.skeleton-card {
  height: 120px;
}

.skeleton-stat {
  height: 88px;
}

.skeleton-row {
  height: 52px;
  margin-bottom: var(--space-xs);
}

.skeleton-chart {
  height: 200px;
}

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

/* Spinner */
.spinner {
  width: 24px;
  height: 24px;
  border: 2.5px solid var(--color-latte);
  border-top-color: var(--color-mocha);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

.spinner-sm {
  width: 16px;
  height: 16px;
  border-width: 2px;
}

.spinner-lg {
  width: 36px;
  height: 36px;
  border-width: 3px;
}

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

/* Full-page loading */
.loading-overlay {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--space-md);
  padding: var(--space-3xl) 0;
  color: var(--color-sandstone);
  font-size: 0.875rem;
}


/* ---------------------------------------------------------------------------
   24. LOGIN PAGE
   --------------------------------------------------------------------------- */

.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-cream);
  padding: var(--space-lg);
}

.login-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-lg);
  max-width: 420px;
  width: 100%;
}

.login-logo {
  text-align: center;
  margin-bottom: var(--space-xl);
}

.login-logo-icon {
  width: 48px;
  height: 48px;
  background: var(--color-mocha);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-md);
  color: var(--color-white);
  font-size: 1.5rem;
  font-weight: 700;
}

.login-title {
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-xs);
}

.login-subtitle {
  font-size: 0.875rem;
  color: var(--color-sandstone);
  margin-bottom: 0;
}

.login-form .form-group {
  margin-bottom: var(--space-lg);
}

.login-form .btn-primary {
  width: 100%;
  padding: 12px;
  font-size: 0.9375rem;
  font-weight: 600;
  margin-top: var(--space-sm);
}

.login-footer {
  text-align: center;
  margin-top: var(--space-lg);
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.login-footer a {
  color: var(--color-rust);
  font-weight: 500;
}

.login-error {
  background: rgba(199, 91, 57, 0.08);
  border: 1px solid rgba(199, 91, 57, 0.2);
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-md);
  font-size: 0.8125rem;
  color: var(--color-terracotta);
}

.login-remember {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  margin-bottom: var(--space-md);
}


/* ---------------------------------------------------------------------------
   25. RESPONSIVE BREAKPOINTS
   --------------------------------------------------------------------------- */

/* Tablet: 768px – 1200px */
@media (max-width: 1200px) {
  .stat-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .bar-chart-row {
    grid-template-columns: 100px 1fr 50px;
  }

  .form-row {
    grid-template-columns: 1fr 1fr;
  }

  .main-content {
    padding: var(--space-lg);
  }
}

@media (max-width: 1024px) {
  /* Topbar responsive — handled by topbar's own @media block */
}

/* Mobile: < 768px */
@media (max-width: 768px) {
  :root {
    --header-height: 56px;
  }

  body {
    font-size: 0.875rem;
  }

  h1 {
    font-size: 1.375rem;
  }

  h2 {
    font-size: 1.125rem;
  }

  .main-content {
    padding: var(--space-md);
    padding-bottom: 80px; /* room for bottom nav */
  }

  .stat-grid {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }

  .stat-card {
    padding: var(--space-md);
  }

  .stat-card-value {
    font-size: 1.5rem;
  }

  .card {
    padding: var(--space-md);
    border-radius: var(--radius-md);
  }

  .header-bar {
    padding: 0 var(--space-md);
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .bar-chart-row {
    grid-template-columns: 80px 1fr 40px;
    gap: var(--space-sm);
  }

  .bar-chart-label {
    font-size: 0.75rem;
  }

  /* Responsive table — cards on mobile */
  .table-responsive-mobile thead {
    display: none;
  }

  .table-responsive-mobile tbody tr {
    display: flex;
    flex-direction: column;
    padding: var(--space-md);
    border-bottom: 1px solid var(--color-latte);
  }

  .table-responsive-mobile tbody td {
    padding: 4px 0;
    display: flex;
    justify-content: space-between;
  }

  .table-responsive-mobile tbody td::before {
    content: attr(data-label);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--color-sandstone);
  }

  /* Tab scrolling */
  .tab-bar {
    margin-left: calc(-1 * var(--space-md));
    margin-right: calc(-1 * var(--space-md));
    padding-left: var(--space-md);
    padding-right: var(--space-md);
  }

  .tab {
    padding: var(--space-sm) var(--space-md);
    font-size: 0.8125rem;
  }

  /* Modal full screen on mobile */
  .modal-backdrop {
    padding: 0;
    align-items: flex-end;
  }

  .modal-content {
    max-width: 100%;
    max-height: 90vh;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  }

  /* Toast full width mobile */
  .toast-container {
    top: var(--space-sm);
    right: var(--space-sm);
    left: var(--space-sm);
  }

  .toast {
    max-width: 100%;
  }
}

/* Bottom navigation for mobile */
.bottom-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 64px;
  background: var(--color-white);
  border-top: 1px solid var(--color-latte);
  z-index: var(--z-header);
  padding: 0 var(--space-sm);
}

.bottom-nav-items {
  display: flex;
  align-items: center;
  justify-content: space-around;
  height: 100%;
  list-style: none;
  margin: 0;
  padding: 0;
}

.bottom-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: 0.625rem;
  color: var(--color-sandstone);
  text-decoration: none;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  transition: color var(--transition-fast);
}

.bottom-nav-item.active {
  color: var(--color-rust);
}

.bottom-nav-item-icon {
  font-size: 1.25rem;
}

@media (max-width: 768px) {
  .bottom-nav {
    display: block;
  }
}


/* ---------------------------------------------------------------------------
   26. ANIMATIONS
   --------------------------------------------------------------------------- */

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

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

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

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(16px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.animate-fade-in {
  animation: fadeIn var(--transition-base);
}

.animate-fade-in-up {
  animation: fadeInUp var(--transition-base);
}

.animate-fade-in-down {
  animation: fadeInDown var(--transition-base);
}

.animate-slide-in-right {
  animation: slideInRight var(--transition-base);
}

/* Stagger children */
.stagger-children > * {
  animation: fadeInUp var(--transition-base) both;
}

.stagger-children > *:nth-child(1) { animation-delay: 0ms; }
.stagger-children > *:nth-child(2) { animation-delay: 40ms; }
.stagger-children > *:nth-child(3) { animation-delay: 80ms; }
.stagger-children > *:nth-child(4) { animation-delay: 120ms; }
.stagger-children > *:nth-child(5) { animation-delay: 160ms; }
.stagger-children > *:nth-child(6) { animation-delay: 200ms; }
.stagger-children > *:nth-child(7) { animation-delay: 240ms; }
.stagger-children > *:nth-child(8) { animation-delay: 280ms; }


/* ---------------------------------------------------------------------------
   27. UTILITY CLASSES
   --------------------------------------------------------------------------- */

/* Text */
.text-muted {
  color: var(--color-sandstone) !important;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.text-left {
  text-align: left;
}

.text-small {
  font-size: 0.8125rem;
}

.text-xs {
  font-size: 0.75rem;
}

.text-mono {
  font-family: var(--font-mono);
}

.text-bold {
  font-weight: 600;
}

.text-espresso {
  color: var(--color-espresso);
}

.text-mocha {
  color: var(--color-mocha);
}

.text-terracotta {
  color: var(--color-terracotta);
}

.text-sage {
  color: var(--color-deep-moss);
}

.text-amber {
  color: var(--color-amber);
}

.text-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Spacing — margins */
.mt-0 { margin-top: 0; }
.mt-xs { margin-top: var(--space-xs); }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }
.mt-2xl { margin-top: var(--space-2xl); }

.mb-0 { margin-bottom: 0; }
.mb-xs { margin-bottom: var(--space-xs); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }
.mb-2xl { margin-bottom: var(--space-2xl); }

.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }

/* Spacing — padding */
.p-0 { padding: 0; }
.p-sm { padding: var(--space-sm); }
.p-md { padding: var(--space-md); }
.p-lg { padding: var(--space-lg); }
.p-xl { padding: var(--space-xl); }

/* Flexbox */
.flex {
  display: flex;
}

.flex-col {
  display: flex;
  flex-direction: column;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-start {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.flex-end {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-1 {
  flex: 1;
}

.items-center {
  align-items: center;
}

.items-start {
  align-items: flex-start;
}

/* Gap */
.gap-xs { gap: var(--space-xs); }
.gap-sm { gap: var(--space-sm); }
.gap-md { gap: var(--space-md); }
.gap-lg { gap: var(--space-lg); }
.gap-xl { gap: var(--space-xl); }

/* Display */
.hidden {
  display: none !important;
}

.visible-mobile {
  display: none;
}

.visible-desktop {
  display: block;
}

@media (max-width: 768px) {
  .visible-mobile {
    display: block;
  }
  .visible-desktop {
    display: none;
  }
  .hidden-mobile {
    display: none !important;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .hidden-tablet {
    display: none !important;
  }
}

/* Borders */
.border-bottom {
  border-bottom: 1px solid var(--color-latte);
}

.border-top {
  border-top: 1px solid var(--color-latte);
}

/* Overflow */
.overflow-hidden {
  overflow: hidden;
}

.overflow-auto {
  overflow: auto;
}

/* Width */
.w-full {
  width: 100%;
}

.w-auto {
  width: auto;
}


/* ---------------------------------------------------------------------------
   28. PRINT STYLES
   --------------------------------------------------------------------------- */

@media print {
  *,
  *::before,
  *::after {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }

  body {
    font-size: 11pt;
    line-height: 1.4;
  }

  .topbar,
  .sidebar,
  .sidebar-overlay,
  .header-bar,
  .bottom-nav,
  .hamburger-btn,
  .toast-container,
  .modal-backdrop,
  .btn,
  .header-actions,
  .tab-bar,
  .pagination,
  .search-input-wrapper {
    display: none !important;
  }

  .app-layout {
    display: block;
  }

  .main-content {
    padding: 0;
    overflow: visible;
  }

  .card {
    border: 1px solid #ccc;
    box-shadow: none;
    page-break-inside: avoid;
    break-inside: avoid;
  }

  .stat-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .table {
    font-size: 9pt;
  }

  .table thead th {
    background: #eee !important;
    color: #333 !important;
  }

  h1, h2, h3, h4 {
    page-break-after: avoid;
    break-after: avoid;
  }

  a {
    text-decoration: underline;
  }

  a[href]::after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
    color: #666;
  }

  .notification-item,
  .table tbody tr {
    page-break-inside: avoid;
    break-inside: avoid;
  }

  .badge {
    border: 1px solid #999;
  }

  @page {
    margin: 1cm;
  }
}


/* ---------------------------------------------------------------------------
   29. PATIENT DETAIL PAGE
   --------------------------------------------------------------------------- */

.patient-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}

.patient-avatar {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  background: var(--color-mocha);
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 600;
  flex-shrink: 0;
}

.patient-info {
  flex: 1;
  min-width: 0;
}

.patient-name {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin-bottom: 2px;
}

.patient-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.patient-meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.patient-actions {
  display: flex;
  gap: var(--space-sm);
  flex-shrink: 0;
}

/* Clinical snapshot card */
.clinical-snapshot {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-md);
}

.clinical-snapshot-item {
  padding: var(--space-md);
  background: var(--color-ivory);
  border-radius: var(--radius-md);
}

.clinical-snapshot-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
  margin-bottom: var(--space-xs);
}

.clinical-snapshot-value {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-espresso);
}

/* Alert card */
.alert-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-left: 3px solid var(--color-terracotta);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-md);
}

.alert-card.alert-warning {
  border-left-color: var(--color-amber);
}

.alert-card.alert-info {
  border-left-color: var(--color-slate-blue);
}

.alert-card.alert-success {
  border-left-color: var(--color-sage);
}

.alert-card-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-xs);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.alert-card-body {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  line-height: 1.5;
}

/* Patient detail sections */
.patient-section {
  margin-bottom: var(--space-xl);
}

.patient-section-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.patient-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-md);
}

/* Medication list */
.medication-list {
  list-style: none;
  padding: 0;
}

.medication-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
}

.medication-item:last-child {
  border-bottom: none;
}

.medication-name {
  font-weight: 500;
  color: var(--color-espresso);
  font-size: 0.875rem;
}

.medication-dose {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
}


/* ---------------------------------------------------------------------------
   30. SEARCH INPUT WITH ICON
   --------------------------------------------------------------------------- */

.search-input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.search-input-wrapper .search-icon {
  position: absolute;
  left: 12px;
  color: var(--color-sandstone);
  font-size: 0.875rem;
  pointer-events: none;
  display: flex;
  align-items: center;
}

.search-input {
  width: 100%;
  padding: 9px 12px 9px 36px;
  font-family: var(--font-primary);
  font-size: 0.875rem;
  color: var(--color-espresso);
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  outline: none;
  transition: all var(--transition-fast);
}

.search-input:focus {
  background: var(--color-white);
  border-color: var(--color-sandstone);
  box-shadow: 0 0 0 3px rgba(141, 110, 99, 0.08);
}

.search-input::placeholder {
  color: var(--color-taupe);
}

.search-input-clear {
  position: absolute;
  right: 10px;
  background: none;
  border: none;
  color: var(--color-sandstone);
  cursor: pointer;
  font-size: 0.875rem;
  padding: 4px;
  border-radius: var(--radius-sm);
  display: none;
  transition: color var(--transition-fast);
}

.search-input-clear:hover {
  color: var(--color-espresso);
}

.search-input:not(:placeholder-shown) ~ .search-input-clear {
  display: flex;
}

/* Compact search for header */
.search-compact {
  max-width: 240px;
}

.search-compact .search-input {
  padding: 7px 12px 7px 32px;
  font-size: 0.8125rem;
  border-radius: var(--radius-lg);
}


/* ---------------------------------------------------------------------------
   31. TAGS / CHIPS
   --------------------------------------------------------------------------- */

.tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  font-size: 0.75rem;
  font-weight: 500;
  border-radius: var(--radius-sm);
  background: var(--color-cream);
  color: var(--color-cocoa);
  white-space: nowrap;
  transition: background var(--transition-fast);
}

.tag:hover {
  background: var(--color-latte);
}

.tag-removable {
  padding-right: 6px;
}

.tag-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border: none;
  background: none;
  color: var(--color-sandstone);
  cursor: pointer;
  border-radius: 50%;
  font-size: 0.75rem;
  transition: all var(--transition-fast);
}

.tag-remove:hover {
  background: rgba(44, 24, 16, 0.08);
  color: var(--color-espresso);
}

.tag-mocha {
  background: rgba(93, 64, 55, 0.1);
  color: var(--color-mocha);
}

.tag-sage {
  background: rgba(122, 155, 109, 0.12);
  color: var(--color-deep-moss);
}

.tag-amber {
  background: rgba(212, 162, 78, 0.14);
  color: #a07828;
}

.tag-terracotta {
  background: rgba(199, 91, 57, 0.1);
  color: var(--color-terracotta);
}

.tag-blue {
  background: rgba(107, 127, 163, 0.12);
  color: var(--color-slate-blue);
}

.tag-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
}


/* ---------------------------------------------------------------------------
   32. REPORT CARD STYLES
   --------------------------------------------------------------------------- */

.report-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-md);
}

.report-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  cursor: pointer;
  transition: all var(--transition-base);
  display: flex;
  flex-direction: column;
}

.report-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.report-card-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--color-ivory);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  color: var(--color-mocha);
  margin-bottom: var(--space-md);
}

.report-card-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-xs);
}

.report-card-description {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  line-height: 1.5;
  flex: 1;
  margin-bottom: var(--space-md);
}

.report-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--color-taupe);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-cream);
}


/* ---------------------------------------------------------------------------
   33. SETTINGS PAGE
   --------------------------------------------------------------------------- */

.settings-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-xl);
}

.settings-nav {
  list-style: none;
  padding: 0;
}

.settings-nav-item {
  padding: 10px var(--space-md);
  font-size: 0.875rem;
  color: var(--color-cocoa);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  margin-bottom: 2px;
}

.settings-nav-item:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}

.settings-nav-item.active {
  background: var(--color-cream);
  color: var(--color-espresso);
  font-weight: 600;
}

.settings-section {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  box-shadow: var(--shadow-card);
}

.settings-section-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-xs);
}

.settings-section-description {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-bottom: var(--space-lg);
}

.settings-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-cream);
}

.settings-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.settings-row:first-of-type {
  padding-top: 0;
}

.settings-row-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
  margin-bottom: 2px;
}

.settings-row-hint {
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

/* Toggle switch */
.toggle {
  position: relative;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}

.toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--color-latte);
  border-radius: 12px;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.toggle-slider::before {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background: var(--color-white);
  border-radius: 50%;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-fast);
}

.toggle input:checked + .toggle-slider {
  background: var(--color-mocha);
}

.toggle input:checked + .toggle-slider::before {
  transform: translateX(20px);
}

@media (max-width: 768px) {
  .settings-layout {
    grid-template-columns: 1fr;
  }

  .settings-nav {
    display: flex;
    overflow-x: auto;
    gap: var(--space-xs);
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-sm);
  }

  .settings-nav-item {
    white-space: nowrap;
  }
}


/* ---------------------------------------------------------------------------
   34. DROPDOWN MENU
   --------------------------------------------------------------------------- */

.dropdown {
  position: relative;
  display: inline-flex;
}

.dropdown-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: var(--space-xs);
  min-width: 180px;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-dropdown);
  padding: var(--space-xs) 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity var(--transition-fast), transform var(--transition-fast), visibility var(--transition-fast);
}

.dropdown-menu.open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dropdown-menu-left {
  left: 0;
  right: auto;
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 8px var(--space-md);
  font-size: 0.8125rem;
  color: var(--color-coffee);
  cursor: pointer;
  transition: background var(--transition-fast);
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-family: var(--font-primary);
}

.dropdown-item:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}

.dropdown-item-danger {
  color: var(--color-terracotta);
}

.dropdown-item-danger:hover {
  background: rgba(199, 91, 57, 0.06);
  color: var(--color-terracotta);
}

.dropdown-item-icon {
  width: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.7;
}

.dropdown-divider {
  height: 1px;
  background: var(--color-cream);
  margin: var(--space-xs) 0;
}

.dropdown-label {
  padding: var(--space-sm) var(--space-md) var(--space-xs);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
}


/* ---------------------------------------------------------------------------
   35. SCROLLBAR STYLES
   --------------------------------------------------------------------------- */

/* Thin scrollbar for webkit */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--color-taupe);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-sandstone);
}

/* Sidebar scrollbar — darker */
.sidebar::-webkit-scrollbar-thumb {
  background: var(--color-cocoa);
}

.sidebar::-webkit-scrollbar-thumb:hover {
  background: var(--color-clay);
}

/* Firefox scrollbar */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--color-taupe) transparent;
}

.sidebar {
  scrollbar-color: var(--color-cocoa) transparent;
}


/* ---------------------------------------------------------------------------
   36. EMPTY STATE
   --------------------------------------------------------------------------- */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-3xl) var(--space-lg);
}

.empty-state-icon {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-xl);
  background: var(--color-cream);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  color: var(--color-sandstone);
  margin-bottom: var(--space-lg);
}

.empty-state-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-sm);
}

.empty-state-description {
  font-size: 0.875rem;
  color: var(--color-sandstone);
  max-width: 340px;
  line-height: 1.6;
  margin-bottom: var(--space-lg);
}

.empty-state-compact {
  padding: var(--space-xl) var(--space-md);
}

.empty-state-compact .empty-state-icon {
  width: 48px;
  height: 48px;
  font-size: 1.25rem;
  margin-bottom: var(--space-md);
}

.empty-state-compact .empty-state-title {
  font-size: 0.9375rem;
}

.empty-state-compact .empty-state-description {
  font-size: 0.8125rem;
}


/* ---------------------------------------------------------------------------
   ADDITIONAL: PAGE-SPECIFIC HELPERS
   --------------------------------------------------------------------------- */

/* Dashboard page */
.dashboard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}

.dashboard-grid-full {
  grid-column: 1 / -1;
}

@media (max-width: 1024px) {
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
}

/* Section divider with title */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
}

.section-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-espresso);
}

.section-subtitle {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

/* Data pair — label + value side by side */
.data-pair {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
}

.data-pair:last-child {
  border-bottom: none;
}

.data-pair-label {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.data-pair-value {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
}

/* Quick actions row */
.quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

/* Content wrapper max width */
.content-narrow {
  max-width: 720px;
  margin: 0 auto;
}

.content-wide {
  max-width: 1200px;
  margin: 0 auto;
}

/* Divider */
.divider {
  height: 1px;
  background: var(--color-latte);
  margin: var(--space-lg) 0;
  border: none;
}

.divider-sm {
  margin: var(--space-md) 0;
}

/* Focus visible for accessibility */
:focus-visible {
  outline: 2px solid var(--color-slate-blue);
  outline-offset: 2px;
}

button:focus:not(:focus-visible),
a:focus:not(:focus-visible),
input:focus:not(:focus-visible),
select:focus:not(:focus-visible),
textarea:focus:not(:focus-visible) {
  outline: none;
}

/* 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;
  }
}

/* High contrast mode */
@media (prefers-contrast: high) {
  .card {
    border-width: 2px;
  }

  .badge {
    border: 1px solid currentColor;
  }

  .btn-secondary {
    border-width: 2px;
  }

  .nav-item.active,
  .sidebar-nav-item.active {
    border-left-width: 4px;
  }
}


/* ===========================================================================
   TEMPLATE COMPATIBILITY — Class aliases & missing rules
   Maps template class names to the design system
   =========================================================================== */


/* ---------------------------------------------------------------------------
   Sidebar nav aliases
   --------------------------------------------------------------------------- */

.sidebar-nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 10px var(--space-lg);
  color: var(--color-taupe);
  font-size: 0.875rem;
  font-weight: 450;
  border-left: 3px solid transparent;
  transition: all var(--transition-fast);
  cursor: pointer;
  text-decoration: none;
  position: relative;
}

.sidebar-nav-item:hover {
  color: var(--color-white);
  background: rgba(255, 255, 255, 0.04);
}

.sidebar-nav-item.active {
  color: var(--color-white);
  background: rgba(255, 255, 255, 0.06);
  border-left-color: var(--color-rust);
  font-weight: 500;
}

.sidebar-nav-icon {
  width: 20px;
  height: 20px;
  opacity: 0.7;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sidebar-nav-item.active .sidebar-nav-icon {
  opacity: 1;
}

/* Sidebar logo mark */
.sidebar-logo-mark {
  width: 32px;
  height: 32px;
  background: var(--color-rust);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  color: var(--color-white);
  font-weight: 700;
  flex-shrink: 0;
}

/* Sidebar connection status */
.sidebar-connection-status {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

.connection-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-sage);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(122, 155, 109, 0.2);
}

/* Sidebar mobile toggle */
.sidebar-toggle {
  display: none;
  position: fixed;
  top: 14px;
  left: 14px;
  z-index: calc(var(--z-header) + 1);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  color: var(--color-espresso);
  padding: 0;
}

.sidebar--open {
  transform: translateX(0) !important;
}

@media (max-width: 1024px) {
  .sidebar-toggle {
    display: flex;
  }
}


/* ---------------------------------------------------------------------------
   Header bar aliases
   --------------------------------------------------------------------------- */

.header-bar-left {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.header-bar-right {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}

.header-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-espresso);
  display: flex;
  align-items: center;
}

.header-icon-group {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.header-icon-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  min-width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--color-terracotta);
  color: var(--color-white);
  font-size: 0.625rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-white);
  line-height: 1;
}

.header-icon-badge:empty {
  display: none;
}


/* ---------------------------------------------------------------------------
   Page title row (used by all page templates)
   --------------------------------------------------------------------------- */

.page-title-row {
  display: flex;
  align-items: baseline;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.page-title-row h1 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0;
  line-height: 1.3;
}

.page-title-meta {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  font-weight: 400;
}

.page-title-back {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.page-title-back:hover {
  color: var(--color-mocha);
}

.back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  text-decoration: none;
}

.back-link:hover {
  color: var(--color-mocha);
}


/* ---------------------------------------------------------------------------
   Stat card aliases
   --------------------------------------------------------------------------- */

.stat-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.stat-number {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.stat-label {
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
}

.stat-denominator {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-sandstone);
}

@media (max-width: 1200px) {
  .stat-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .stat-cards {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }
  .stat-number {
    font-size: 1.5rem;
  }
}


/* ---------------------------------------------------------------------------
   Two-column layout
   --------------------------------------------------------------------------- */

.two-column {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-lg);
}

@media (max-width: 1024px) {
  .two-column {
    grid-template-columns: 1fr;
  }
}


/* ---------------------------------------------------------------------------
   Card full-width modifier
   --------------------------------------------------------------------------- */

.card--full-width {
  margin-bottom: var(--space-lg);
}


/* ---------------------------------------------------------------------------
   Action items (dashboard urgent items)
   --------------------------------------------------------------------------- */

.action-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.action-item {
  padding: var(--space-md);
  border-left: 3px solid var(--color-taupe);
  margin-bottom: var(--space-sm);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  background: var(--color-ivory);
  transition: background var(--transition-fast);
}

.action-item:last-child {
  margin-bottom: 0;
}

.action-item:hover {
  background: var(--color-cream);
}

.action-item--urgent {
  border-left-color: var(--color-terracotta);
  background: rgba(199, 91, 57, 0.04);
}

.action-item--urgent:hover {
  background: rgba(199, 91, 57, 0.08);
}

.action-item--warning {
  border-left-color: var(--color-amber);
  background: rgba(212, 162, 78, 0.04);
}

.action-item--warning:hover {
  background: rgba(212, 162, 78, 0.08);
}

.action-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.action-item-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
}

.action-item-count {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-espresso);
  font-family: var(--font-mono);
  background: var(--color-white);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  min-width: 28px;
  text-align: center;
}

.action-item-details {
  list-style: none;
  padding: 0;
  margin: var(--space-sm) 0 0 0;
}

.action-item-details li {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-xs) 0;
  font-size: 0.8125rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04);
}

.action-item-details li:last-child {
  border-bottom: none;
}

.detail-patient {
  font-weight: 500;
  color: var(--color-espresso);
  min-width: 120px;
}

.detail-facility {
  color: var(--color-sandstone);
  font-size: 0.75rem;
}

.detail-due {
  margin-left: auto;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-terracotta);
}


/* ---------------------------------------------------------------------------
   Bar chart aliases (dashboard facility chart)
   --------------------------------------------------------------------------- */

.bar-item {
  display: grid;
  grid-template-columns: 140px 1fr 60px auto;
  align-items: center;
  gap: var(--space-md);
}

.bar-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-coffee);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bar-track {
  height: 24px;
  background: var(--color-cream);
  border-radius: var(--radius-sm);
  overflow: hidden;
  position: relative;
}

.bar-fill {
  height: 100%;
  border-radius: var(--radius-sm);
  background: var(--color-mocha);
  transition: width 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  min-width: 4px;
}

.bar-value {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-espresso);
  text-align: right;
  font-family: var(--font-mono);
}

.bar-meta {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

@media (max-width: 768px) {
  .bar-item {
    grid-template-columns: 80px 1fr 40px;
    gap: var(--space-sm);
  }
  .bar-meta {
    display: none;
  }
  .bar-label {
    font-size: 0.75rem;
  }
}


/* ---------------------------------------------------------------------------
   Data table (simpler table used in dashboards)
   --------------------------------------------------------------------------- */

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.data-table thead th {
  padding: 10px var(--space-md);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-sandstone);
  background: var(--color-ivory);
  border-bottom: 1px solid var(--color-latte);
  text-align: left;
  white-space: nowrap;
}

.data-table tbody tr {
  border-bottom: 1px solid var(--color-cream);
  transition: background var(--transition-fast);
}

.data-table tbody tr:hover {
  background: var(--color-ivory);
}

.data-table tbody td {
  padding: 10px var(--space-md);
  color: var(--color-coffee);
  vertical-align: middle;
}

.data-table tfoot tr {
  border-top: 2px solid var(--color-latte);
}

.data-table tfoot td {
  padding: 10px var(--space-md);
  font-weight: 600;
  color: var(--color-espresso);
}

.total-row {
  background: var(--color-ivory);
}

.total-row td {
  font-weight: 600;
  color: var(--color-espresso);
}


/* ---------------------------------------------------------------------------
   Badge variants used in templates
   --------------------------------------------------------------------------- */

.badge-code {
  background: var(--color-ivory);
  color: var(--color-cocoa);
  font-family: var(--font-mono);
  font-size: 0.75rem;
}

.badge-count {
  background: var(--color-cream);
  color: var(--color-mocha);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  margin-left: var(--space-xs);
}

.badge-emr {
  background: rgba(107, 127, 163, 0.12);
  color: var(--color-slate-blue);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.badge-acuity {
  font-size: 0.6875rem;
  font-weight: 600;
}


/* ---------------------------------------------------------------------------
   Notification components (used in templates)
   --------------------------------------------------------------------------- */

.notification-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.notification-priority-indicator {
  width: 4px;
  border-radius: 2px;
  flex-shrink: 0;
  align-self: stretch;
  background: var(--color-taupe);
}

.notification-item .notification-priority-indicator {
  display: none; /* already handled by border-left on .notification-item */
}

.notification-content {
  flex: 1;
  min-width: 0;
}

.notification-meta {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.6875rem;
  color: var(--color-sandstone);
  margin-bottom: 2px;
}

.notification-time {
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

.notification-type {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--color-clay);
}

.notification-message {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  line-height: 1.5;
}

.notification-context {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-xs);
  font-size: 0.75rem;
}

.notification-patient {
  font-weight: 500;
  color: var(--color-espresso);
}

.notification-facility {
  color: var(--color-sandstone);
}

.notification-dropdown {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: var(--space-xs);
  width: 360px;
  max-height: 480px;
  overflow-y: auto;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-dropdown);
}

.notification-dropdown:empty {
  display: none;
}


/* ---------------------------------------------------------------------------
   Link action
   --------------------------------------------------------------------------- */

.link-action {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-rust);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.link-action:hover {
  color: var(--color-terracotta);
}


/* ---------------------------------------------------------------------------
   Action bar & toolbar
   --------------------------------------------------------------------------- */

.action-bar {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.no-print {
  /* handled by print styles */
}

@media print {
  .no-print {
    display: none !important;
  }
}


/* ---------------------------------------------------------------------------
   Filter bar (used by patients, facilities, reports)
   --------------------------------------------------------------------------- */

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
  padding: var(--space-md) var(--space-lg);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
}

.filter-group {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.filter-label {
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
}

.filter-select {
  padding: 6px 28px 6px 10px;
  font-family: var(--font-primary);
  font-size: 0.8125rem;
  color: var(--color-espresso);
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A1887F' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
  cursor: pointer;
  outline: none;
  transition: border-color var(--transition-fast);
}

.filter-select:focus {
  border-color: var(--color-sandstone);
}


/* ---------------------------------------------------------------------------
   Facility card styles
   --------------------------------------------------------------------------- */

.facility-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  transition: all var(--transition-base);
  text-decoration: none;
  color: inherit;
  display: block;
}

.facility-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.facility-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-md);
}


/* ---------------------------------------------------------------------------
   Patient table row styles
   --------------------------------------------------------------------------- */

.patient-row {
  cursor: pointer;
}

.patient-row:hover {
  background: var(--color-cream);
}


/* ---------------------------------------------------------------------------
   Settings page components
   --------------------------------------------------------------------------- */

.settings-field-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.settings-field {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
}

.settings-field:last-child {
  border-bottom: none;
}

.settings-field--input {
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-xs);
  padding: var(--space-md) 0;
}

.settings-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-coffee);
}

.settings-value {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
  text-align: right;
}

.settings-subsection {
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--color-cream);
}

.settings-subsection-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-md);
}

.settings-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-md) 0;
}

.settings-list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--color-cream);
  background: var(--color-ivory);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-xs);
}

.settings-list-item-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.settings-list-item-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
}

.settings-list-item-meta {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  font-family: var(--font-mono);
}

.settings-inline-form {
  margin-top: var(--space-sm);
}

.settings-inline-form-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: flex-end;
}

.settings-toggle-form {
  margin-top: var(--space-md);
}

.settings-checkbox-label {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.875rem;
  color: var(--color-cocoa);
  cursor: pointer;
}

.settings-checkbox-label input[type="checkbox"] {
  accent-color: var(--color-mocha);
}

.settings-button-group {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

.settings-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-cream);
}

.settings-input-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.settings-input-unit {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  white-space: nowrap;
}

.input-number {
  width: 100px;
  padding: 8px 12px;
  font-family: var(--font-primary);
  font-size: 0.875rem;
  color: var(--color-espresso);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  outline: none;
  text-align: center;
  transition: border-color var(--transition-fast);
}

.input-number:focus {
  border-color: var(--color-sandstone);
  box-shadow: 0 0 0 3px rgba(141, 110, 99, 0.1);
}

.inline-form {
  display: inline-block;
}

.empty-state-inline {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  font-style: italic;
  padding: var(--space-sm) 0;
}


/* ---------------------------------------------------------------------------
   Form input aliases (used by add facility and other forms)
   --------------------------------------------------------------------------- */

.form-input {
  width: 100%;
  padding: 10px 12px;
  font-family: var(--font-primary);
  font-size: 0.875rem;
  color: var(--color-espresso);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
}

.form-input:focus {
  border-color: var(--color-sandstone);
  box-shadow: 0 0 0 3px rgba(141, 110, 99, 0.1);
}

.form-input::placeholder {
  color: var(--color-taupe);
}

.form-input--disabled {
  background: var(--color-ivory);
  color: var(--color-sandstone);
  cursor: not-allowed;
}

.form-select {
  width: 100%;
  padding: 10px 36px 10px 12px;
  font-family: var(--font-primary);
  font-size: 0.875rem;
  color: var(--color-espresso);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A1887F' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  cursor: pointer;
  outline: none;
}

.form-select:focus {
  border-color: var(--color-sandstone);
  box-shadow: 0 0 0 3px rgba(141, 110, 99, 0.1);
}

.form-required {
  color: var(--color-terracotta);
  margin-left: 2px;
}

.form-optional {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  font-weight: 400;
  margin-left: var(--space-xs);
}

.form-group--inline {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.form-group--half {
  /* handled by .form-row grid */
}

.form-group--third {
  /* 3-column in a form-row */
}

.form-group--quarter {
  max-width: 50%;
}

.form-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
}

.form-checkbox input[type="checkbox"] {
  accent-color: var(--color-mocha);
  width: 16px;
  height: 16px;
}

.form-checkbox-indicator {
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--color-taupe);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.form-checkbox-label {
  font-size: 0.875rem;
  color: var(--color-coffee);
}

.form-input-group {
  display: flex;
  align-items: stretch;
}

.form-input--with-action {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.form-input-action {
  padding: 8px 12px;
  border: 1px solid var(--color-latte);
  border-left: none;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  background: var(--color-ivory);
  color: var(--color-cocoa);
  font-size: 0.8125rem;
  cursor: pointer;
  white-space: nowrap;
}

.form-actions {
  display: flex;
  gap: var(--space-sm);
  justify-content: flex-end;
  margin-top: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-cream);
}

.facility-form {
  max-width: 720px;
}


/* ---------------------------------------------------------------------------
   Action bar variants
   --------------------------------------------------------------------------- */

.action-bar-left {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex: 1;
}

.action-bar-right {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.filter-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
}

.filter-group--search {
  flex: 1;
  min-width: 200px;
  max-width: 300px;
}

.filter-input {
  width: 100%;
  padding: 8px 12px 8px 32px;
  font-family: var(--font-primary);
  font-size: 0.8125rem;
  color: var(--color-espresso);
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--transition-fast);
}

.filter-input:focus {
  border-color: var(--color-sandstone);
  background: var(--color-white);
}


/* ---------------------------------------------------------------------------
   Button variants (missing from core)
   --------------------------------------------------------------------------- */

.btn-small {
  padding: 5px 10px;
  font-size: 0.75rem;
}

.btn-warning {
  background: var(--color-amber);
  color: var(--color-white);
  border-color: var(--color-amber);
}

.btn-warning:hover:not(:disabled) {
  background: #c09340;
  border-color: #c09340;
}

.btn-text {
  background: none;
  border: none;
  color: var(--color-rust);
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.8125rem;
}

.btn-text:hover {
  color: var(--color-terracotta);
  background: var(--color-cream);
}

.btn-filter {
  padding: 6px 14px;
  font-size: 0.8125rem;
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  color: var(--color-cocoa);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.btn-filter:hover {
  background: var(--color-cream);
  border-color: var(--color-sandstone);
}

.btn-filter--active {
  background: var(--color-mocha);
  color: var(--color-white);
  border-color: var(--color-mocha);
}

.btn-filter--active:hover {
  background: var(--color-coffee);
  border-color: var(--color-coffee);
}


/* ---------------------------------------------------------------------------
   Badge variants (missing from core)
   --------------------------------------------------------------------------- */

.badge-tag {
  background: var(--color-cream);
  color: var(--color-cocoa);
  font-size: 0.6875rem;
}

.badge-type {
  background: rgba(93, 64, 55, 0.08);
  color: var(--color-mocha);
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.badge-muted {
  background: var(--color-cream);
  color: var(--color-sandstone);
}


/* ---------------------------------------------------------------------------
   Stat card variants
   --------------------------------------------------------------------------- */

.stat-card--success {
  border-left: 3px solid var(--color-sage);
}

.stat-card--warning {
  border-left: 3px solid var(--color-amber);
}

.stat-card--error {
  border-left: 3px solid var(--color-terracotta);
}


/* ---------------------------------------------------------------------------
   Facility list & detail components
   --------------------------------------------------------------------------- */

.facility-name-cell {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.facility-name {
  font-weight: 500;
  color: var(--color-espresso);
}

.facility-tags {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

.facility-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}

.facility-header-info {
  flex: 1;
}

.facility-header-name {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin-bottom: var(--space-xs);
}

.facility-header-badges {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-top: var(--space-xs);
}

.detail-list {
  display: flex;
  flex-direction: column;
}

.detail-list-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
  font-size: 0.875rem;
}

.detail-list-row:last-child {
  border-bottom: none;
}

.detail-list-row dt,
.detail-list-row .detail-label {
  color: var(--color-sandstone);
  font-weight: 400;
}

.detail-list-row dd,
.detail-list-row .detail-value {
  color: var(--color-espresso);
  font-weight: 500;
}

.detail-list-item {
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
  font-size: 0.875rem;
}

.detail-list-item:last-child {
  border-bottom: none;
}

.card-actions {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.card-header-meta {
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

.error-detail {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: rgba(199, 91, 57, 0.04);
  border-radius: var(--radius-md);
  font-size: 0.8125rem;
}

.error-detail-icon {
  color: var(--color-terracotta);
  flex-shrink: 0;
}

.error-detail-message {
  color: var(--color-cocoa);
}

.text-error {
  color: var(--color-terracotta) !important;
}


/* ---------------------------------------------------------------------------
   Data table variants
   --------------------------------------------------------------------------- */

.data-table--hover tbody tr:hover {
  background: var(--color-cream);
}

.data-table-row {
  transition: background var(--transition-fast);
}

.data-table-row--warning {
  background: rgba(212, 162, 78, 0.04);
}

.data-table-row--detail {
  background: var(--color-ivory);
}

.card-body--no-padding {
  padding: 0;
}


/* ---------------------------------------------------------------------------
   Patient detail components
   --------------------------------------------------------------------------- */

.patient-header-name {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-espresso);
}

.patient-header-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
}

.meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.meta-sep {
  color: var(--color-taupe);
}

.patient-link {
  color: var(--color-rust);
  text-decoration: none;
  font-weight: 500;
}

.patient-link:hover {
  color: var(--color-terracotta);
  text-decoration: underline;
}

.patient-sub-info {
  display: flex;
  gap: var(--space-sm);
  font-size: 0.75rem;
  color: var(--color-sandstone);
  margin-top: 2px;
}

.sub-detail {
  color: var(--color-sandstone);
}

.sub-detail-sep {
  color: var(--color-taupe);
}

.tab-item {
  padding: var(--space-md) var(--space-lg);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sandstone);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
  font-family: var(--font-primary);
  text-decoration: none;
}

.tab-item:hover {
  color: var(--color-mocha);
}

.tab-item.active {
  color: var(--color-espresso);
  border-bottom-color: var(--color-rust);
  font-weight: 600;
}

.detail-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
}

.detail-row:last-child {
  border-bottom: none;
}

.section-divider {
  height: 1px;
  background: var(--color-latte);
  margin: var(--space-lg) 0;
  border: none;
}

.card-sub-header {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-sm);
}


/* ---------------------------------------------------------------------------
   Alert components
   --------------------------------------------------------------------------- */

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
  font-size: 0.8125rem;
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
}

.alert-error,
.alert--error {
  background: rgba(199, 91, 57, 0.06);
  border-color: rgba(199, 91, 57, 0.2);
  color: var(--color-terracotta);
}

.alert--warning {
  background: rgba(212, 162, 78, 0.08);
  border-color: rgba(212, 162, 78, 0.2);
  color: #a07828;
}

.alert-icon {
  flex-shrink: 0;
  font-size: 1rem;
}

.alert-content {
  flex: 1;
  min-width: 0;
}

.alert-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.alert-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
}

.alert-item:last-child {
  border-bottom: none;
}

.alert-priority-indicator {
  width: 4px;
  border-radius: 2px;
  align-self: stretch;
  flex-shrink: 0;
}

.alert-type {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-clay);
}

.alert-message {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
}

.alert-time {
  font-size: 0.75rem;
  color: var(--color-sandstone);
}


/* ---------------------------------------------------------------------------
   Acuity indicator variants
   --------------------------------------------------------------------------- */

.acuity-indicator {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.acuity-dot--green {
  background: var(--color-sage) !important;
}

.acuity-dot--amber {
  background: var(--color-amber) !important;
}

.acuity-dot--terracotta {
  background: var(--color-terracotta) !important;
}

.acuity-dot--dark {
  background: var(--color-espresso) !important;
}


/* ---------------------------------------------------------------------------
   Billing & TCM detail components
   --------------------------------------------------------------------------- */

.billing-opp-list {
  list-style: none;
  padding: 0;
}

.billing-opp-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
}

.billing-opp-item:last-child {
  border-bottom: none;
}

.billing-opp-desc {
  font-size: 0.875rem;
  color: var(--color-coffee);
}

.billing-opp-revenue {
  font-weight: 600;
  color: var(--color-deep-moss);
  font-family: var(--font-mono);
}

.bar-label-meta {
  font-size: 0.6875rem;
  color: var(--color-sandstone);
}

.tcm-patient-name {
  font-weight: 500;
  color: var(--color-espresso);
}


/* ---------------------------------------------------------------------------
   Insurance & Diagnosis components
   --------------------------------------------------------------------------- */

.insurance-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-md);
}

.insurance-item {
  padding: var(--space-md);
  background: var(--color-ivory);
  border-radius: var(--radius-md);
}

.dx-system-group {
  margin-bottom: var(--space-md);
}

.dx-system-header {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-mocha);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  margin-bottom: var(--space-xs);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-cream);
}

.dx-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.dx-item {
  padding: 4px 0;
  font-size: 0.8125rem;
  color: var(--color-coffee);
}


/* ---------------------------------------------------------------------------
   Document tree
   --------------------------------------------------------------------------- */

.document-tree {
  padding: 0;
}

.folder {
  margin-bottom: var(--space-md);
}

.folder-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-mocha);
  margin-bottom: var(--space-xs);
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.folder-contents {
  list-style: none;
  padding: 0 0 0 var(--space-lg);
  margin: 0;
}

.document-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 4px 0;
  font-size: 0.8125rem;
}

.document-icon {
  color: var(--color-sandstone);
  flex-shrink: 0;
}

.document-link {
  color: var(--color-rust);
  text-decoration: none;
}

.document-link:hover {
  text-decoration: underline;
}


/* ---------------------------------------------------------------------------
   Report list & detail components
   --------------------------------------------------------------------------- */

.report-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.report-row {
  display: flex;
  align-items: center;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  transition: all var(--transition-base);
  text-decoration: none;
  color: inherit;
}

.report-row:hover {
  box-shadow: var(--shadow-md);
}

.report-row-main {
  flex: 1;
  min-width: 0;
}

.report-row-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-md);
  margin-bottom: 2px;
}

.report-patient-name {
  font-weight: 500;
  color: var(--color-espresso);
}

.report-facility-name {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.report-row-stats {
  display: flex;
  gap: var(--space-lg);
}

.report-stat {
  text-align: center;
}

.report-stat-value {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-espresso);
}

.report-stat-label {
  font-size: 0.6875rem;
  color: var(--color-sandstone);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.report-row-actions {
  display: flex;
  gap: var(--space-xs);
  flex-shrink: 0;
  margin-left: var(--space-md);
}


/* ---------------------------------------------------------------------------
   Progress bar (used in report detail)
   --------------------------------------------------------------------------- */

.progress-bar {
  width: 100%;
  height: 8px;
  background: var(--color-cream);
  border-radius: 4px;
  overflow: hidden;
}

.progress-bar-fill {
  height: 100%;
  border-radius: 4px;
  background: var(--color-mocha);
  transition: width var(--transition-slow);
}

.progress-bar-fill--success {
  background: var(--color-sage);
}

.progress-bar-fill--warning {
  background: var(--color-amber);
}

.progress-bar-fill--error {
  background: var(--color-terracotta);
}


/* ---------------------------------------------------------------------------
   Visit summary (report detail)
   --------------------------------------------------------------------------- */

.visit-summary-display {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--color-ivory);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-md);
}

.visit-count-large {
  display: flex;
  align-items: baseline;
  gap: 4px;
}

.visit-count-actual {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-espresso);
}

.visit-count-separator {
  font-size: 1.5rem;
  color: var(--color-taupe);
  margin: 0 2px;
}

.visit-count-expected {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-sandstone);
}

.visit-count-label {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.visit-pct-label {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
}


/* ---------------------------------------------------------------------------
   Stat number/card inline variants
   --------------------------------------------------------------------------- */

.stat-number--success {
  color: var(--color-deep-moss);
}

.stat-number--error {
  color: var(--color-terracotta);
}

.stat-inline {
  display: flex;
  align-items: baseline;
  gap: var(--space-sm);
}

.stat-cards--inline {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.stat-cards--inline .stat-card {
  flex: 1;
  min-width: 150px;
}


/* ---------------------------------------------------------------------------
   Recommendations
   --------------------------------------------------------------------------- */

.section-subheading {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-sm);
}

.recommendations-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.recommendations-list-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-cream);
  font-size: 0.8125rem;
  color: var(--color-coffee);
}

.recommendations-list-item:last-child {
  border-bottom: none;
}

.recommendations-list-item::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--color-rust);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 6px;
}

.billing-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-md);
}

.billing-summary-item {
  padding: var(--space-md);
  background: var(--color-ivory);
  border-radius: var(--radius-md);
  text-align: center;
}


/* ---------------------------------------------------------------------------
   Print styles
   --------------------------------------------------------------------------- */

.print-only {
  display: none;
}

.print-header {
  display: none;
}

@media print {
  .print-only,
  .print-header {
    display: block;
  }
}


/* ---------------------------------------------------------------------------
   Notification dropdown detail
   --------------------------------------------------------------------------- */

.notification-dropdown-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--color-cream);
}

.notification-dropdown-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
}

.notification-dropdown-list {
  max-height: 400px;
  overflow-y: auto;
}

.notification-dropdown-item {
  display: flex;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--color-cream);
  transition: background var(--transition-fast);
  cursor: pointer;
}

.notification-dropdown-item:hover {
  background: var(--color-ivory);
}

.notification-dropdown-item:last-child {
  border-bottom: none;
}

.notification-dropdown-item-body {
  flex: 1;
  min-width: 0;
}

.notification-dropdown-item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-bottom: 2px;
}

.notification-dropdown-item-message {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  line-height: 1.4;
}

.notification-dropdown-item-context {
  display: flex;
  gap: var(--space-sm);
  font-size: 0.75rem;
  color: var(--color-sandstone);
  margin-top: 2px;
}

.notification-dropout-empty {
  padding: var(--space-xl) var(--space-lg);
  text-align: center;
  color: var(--color-sandstone);
  font-size: 0.8125rem;
}

.notification-dropdown-footer {
  display: flex;
  justify-content: center;
  padding: var(--space-sm) var(--space-lg);
  border-top: 1px solid var(--color-cream);
}

.notification-count {
  min-width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--color-terracotta);
  color: var(--color-white);
  font-size: 0.625rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.notification-count:empty,
.notification-count[data-count="0"] {
  display: none;
}

.notification-list--full {
  padding: 0;
}

.notification-item--card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-sm);
}

.notification-priority-bar {
  width: 4px;
  border-radius: 2px;
  align-self: stretch;
  flex-shrink: 0;
}

.notification-body {
  flex: 1;
  min-width: 0;
}

.notification-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.notification-row--top {
  margin-bottom: 4px;
}

.notification-row--message {
  margin-bottom: 2px;
}

.notification-row--context {
  margin-top: var(--space-xs);
}


/* ---------------------------------------------------------------------------
   Search results
   --------------------------------------------------------------------------- */

.search-results-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.search-result-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--color-cream);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.search-result-item:hover {
  background: var(--color-ivory);
}

.search-result-item:last-child {
  border-bottom: none;
}

.search-result-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
}

.search-result-meta {
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

.search-result-separator {
  color: var(--color-taupe);
  margin: 0 var(--space-xs);
}

.search-results-empty {
  padding: var(--space-lg);
  text-align: center;
  color: var(--color-sandstone);
  font-size: 0.8125rem;
}


/* ---------------------------------------------------------------------------
   Icon placeholder classes (SVG icons handled inline)
   --------------------------------------------------------------------------- */

.icon-plus,
.icon-refresh,
.icon-filter,
.icon-search,
.icon-view,
.icon-facility,
.icon-warning,
.icon-connect,
.icon-trash,
.icon-arrow-left {
  display: inline-flex;
  width: 16px;
  height: 16px;
}


/* ===========================================================================
   Grandma-Friendly Dashboard Components
   Larger fonts, clearer visual hierarchy, warm colors
   =========================================================================== */

/* ── Sidebar Tweaks ──────────────────────────────────────────────────────── */

.sidebar-nav-item span {
  font-size: 1rem;
}

.sidebar-nav-separator {
  height: 1px;
  background: var(--color-stone);
  margin: var(--space-sm) var(--space-md);
  opacity: 0.4;
}

/* ── Glance Cards ────────────────────────────────────────────────────────── */

.glance-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}

.glance-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg);
  text-align: center;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-stone);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.glance-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
}

.glance-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-md);
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-linen);
}

.glance-card--patients .glance-card-icon {
  background: #e8f5e9;
  color: #2e7d32;
}

.glance-card--facilities .glance-card-icon {
  background: #e3f2fd;
  color: #1565c0;
}

.glance-card--orders .glance-card-icon {
  background: #fff3e0;
  color: #e65100;
}

.glance-card-number {
  font-size: 3rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1;
  margin-bottom: var(--space-xs);
  letter-spacing: -1px;
}

.glance-card-label {
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--color-sandstone);
}

/* ── Section Heading ─────────────────────────────────────────────────────── */

.section-heading {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin-bottom: var(--space-md);
}

/* ── Attention Cards (Needs Your Attention) ──────────────────────────────── */

.attention-section {
  margin-bottom: var(--space-xl);
}

.attention-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-md);
}

.attention-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  border-left: 5px solid var(--color-stone);
}

.attention-card--urgent {
  border-left-color: #d32f2f;
  background: #fff5f5;
}

.attention-card--warning {
  border-left-color: #f57c00;
  background: #fff8f0;
}

.attention-card--info {
  border-left-color: #1976d2;
  background: #f0f7ff;
}

.attention-card-count {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1;
  margin-bottom: var(--space-xs);
}

.attention-card--urgent .attention-card-count {
  color: #d32f2f;
}

.attention-card--warning .attention-card-count {
  color: #e65100;
}

.attention-card-label {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-xs);
}

.attention-card-desc {
  font-size: 0.95rem;
  color: var(--color-sandstone);
  line-height: 1.4;
  margin-bottom: var(--space-sm);
}

.attention-card-detail {
  font-size: 0.875rem;
  color: var(--color-walnut);
  padding: var(--space-xs) 0;
  border-top: 1px solid rgba(0,0,0,0.06);
}

.attention-card-icon {
  margin-bottom: var(--space-xs);
  color: var(--color-sandstone);
}

.attention-alert-level {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  margin-right: 4px;
  vertical-align: middle;
}
.attention-alert-level--critical { background: #c62828; color: #fff; }
.attention-alert-level--warn { background: #ef6c00; color: #fff; }

/* ── Attention Empty State ───────────────────────────────────────────────── */

.attention-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-xl) var(--space-lg);
  background: #f0faf0;
  border-radius: var(--radius-lg);
  text-align: center;
}

.attention-empty-icon {
  color: #2e7d32;
  margin-bottom: var(--space-md);
}

.attention-empty-text {
  font-size: 1.15rem;
  font-weight: 500;
  color: #2e7d32;
  max-width: 360px;
}

/* ── Update List (Recent Updates) ────────────────────────────────────────── */

.update-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.update-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-stone);
}

.update-item:last-child {
  border-bottom: none;
}

.update-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-taupe);
  flex-shrink: 0;
  margin-top: 6px;
}

.update-item.priority-urgent .update-dot {
  background: #d32f2f;
}

.update-item.priority-high .update-dot {
  background: #f57c00;
}

.update-item.priority-medium .update-dot {
  background: #1976d2;
}

.update-content {
  flex: 1;
  min-width: 0;
}

.update-message {
  font-size: 1rem;
  color: var(--color-espresso);
  line-height: 1.4;
  margin-bottom: var(--space-xs);
}

.update-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  font-size: 0.875rem;
  color: var(--color-sandstone);
}

.update-time {
  color: var(--color-taupe);
}

.update-patient {
  font-weight: 500;
  color: var(--color-walnut);
}

.update-facility {
  color: var(--color-sandstone);
}

/* ── Quick Links Grid ────────────────────────────────────────────────────── */

.quicklinks-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-xl);
}

.quicklink-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-lg) var(--space-md);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-stone);
  text-decoration: none;
  color: var(--color-espresso);
  font-size: 1rem;
  font-weight: 500;
  transition: all 0.15s ease;
  text-align: center;
}

.quicklink-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
  border-color: var(--color-taupe);
  color: var(--color-walnut);
}

.quicklink-card svg {
  color: var(--color-sandstone);
}

.quicklink-card:hover svg {
  color: var(--color-walnut);
}

/* ── Responsive: Dashboard ───────────────────────────────────────────────── */

@media (max-width: 900px) {
  .glance-cards {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }

  .quicklinks-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .glance-card-number {
    font-size: 2.2rem;
  }

  .attention-grid {
    grid-template-columns: 1fr;
  }

  .quicklinks-grid {
    grid-template-columns: 1fr;
  }

  .section-heading {
    font-size: 1.2rem;
  }
}


/* ===========================================================================
   Notes Page — Daily Patient Reports by Facility
   =========================================================================== */

/* ── Summary Bar ──────────────────────────────────────────────────────────── */

.notes-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.notes-summary-item {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-align: center;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-stone, var(--color-latte));
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.notes-summary-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
}

.notes-summary-item--attention {
  border-left: 4px solid var(--color-terracotta);
}

.notes-summary-number {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1;
  margin-bottom: var(--space-xs);
}

.notes-summary-item--attention .notes-summary-number {
  color: var(--color-terracotta);
}

.notes-summary-label {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--color-sandstone);
}

/* ── Facility Sections ────────────────────────────────────────────────────── */

.notes-facilities {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.notes-facility-section {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  border: 1px solid var(--color-latte);
  animation: fadeInUp 0.4s ease-out both;
}

.notes-facility-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  cursor: pointer;
  transition: background var(--transition-fast);
  user-select: none;
}

.notes-facility-header:hover {
  background: var(--color-ivory);
}

.notes-facility-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.notes-expand-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: var(--color-cream);
  border-radius: var(--radius-md);
  color: var(--color-cocoa);
  cursor: pointer;
  transition: transform 0.25s ease, background var(--transition-fast);
  flex-shrink: 0;
}

.notes-expand-btn.expanded {
  transform: rotate(90deg);
}

.notes-expand-btn:hover {
  background: var(--color-latte);
}

.notes-facility-name {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin: 0;
}

.notes-facility-meta {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-top: 2px;
}

.notes-facility-badges {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
  flex-shrink: 0;
}

.notes-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  font-size: 0.8125rem;
  font-weight: 500;
  border-radius: 20px;
  background: var(--color-cream);
  color: var(--color-cocoa);
}

.notes-badge--urgent {
  background: #fff0ed;
  color: var(--color-terracotta);
  font-weight: 600;
}

/* ── Patient Cards ────────────────────────────────────────────────────────── */

.notes-patient-list {
  padding: 0 var(--space-xl) var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.notes-patient-card {
  background: var(--color-ivory);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  border: 1px solid var(--color-latte);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.notes-patient-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.notes-patient-card--urgent {
  border-left: 4px solid var(--color-terracotta);
  background: #fffaf8;
}

.notes-patient-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-md);
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.notes-patient-info {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.notes-patient-name {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--color-espresso);
}

.notes-patient-room {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-cocoa);
  background: var(--color-cream);
  padding: 2px 10px;
  border-radius: 12px;
}

.notes-patient-age {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.notes-patient-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.notes-patient-dx {
  font-weight: 500;
  color: var(--color-cocoa);
}

/* ── Note Entries ─────────────────────────────────────────────────────────── */

.notes-entries {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.notes-entry {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.notes-entry:first-child {
  border-top: 1px solid var(--color-latte);
  padding-top: var(--space-md);
}

.notes-entry-icon {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-sandstone);
}

.notes-entry--unsigned_order .notes-entry-icon {
  color: var(--color-terracotta);
}

.notes-entry--wound .notes-entry-icon {
  color: #d32f2f;
}

.notes-entry--lab .notes-entry-icon {
  color: #1565c0;
}

.notes-entry--notification .notes-entry-icon {
  color: var(--color-amber);
}

.notes-entry--visit .notes-entry-icon {
  color: var(--color-sage);
}

.notes-entry--med_refill .notes-entry-icon {
  color: var(--color-slate-blue);
}

.notes-entry-content {
  flex: 1;
  min-width: 0;
}

.notes-entry-text {
  font-size: 0.9375rem;
  color: var(--color-espresso);
  line-height: 1.45;
}

.notes-entry-meta {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.notes-signed {
  color: var(--color-sage);
  font-weight: 500;
}

.notes-unsigned {
  color: var(--color-terracotta);
  font-weight: 600;
}

.notes-no-entries {
  font-size: 0.875rem;
  color: var(--color-taupe);
  font-style: italic;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-latte);
}

/* ── Empty State ──────────────────────────────────────────────────────────── */

.notes-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-3xl) var(--space-xl);
  text-align: center;
}

.notes-empty-icon {
  color: var(--color-taupe);
  margin-bottom: var(--space-lg);
}

.notes-empty-text {
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--color-sandstone);
  margin-bottom: var(--space-lg);
}

.notes-empty-action {
  display: inline-flex;
  align-items: center;
  padding: 12px 28px;
  background: var(--color-rust);
  color: var(--color-white);
  font-size: 1rem;
  font-weight: 600;
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: all var(--transition-base);
}

.notes-empty-action:hover {
  background: var(--color-terracotta);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(199, 91, 57, 0.3);
}

/* ── Notes Responsive ─────────────────────────────────────────────────────── */

@media (max-width: 900px) {
  .notes-summary {
    grid-template-columns: repeat(2, 1fr);
  }

  .notes-facility-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-sm);
  }

  .notes-facility-badges {
    margin-left: 44px;
  }

  .notes-patient-header {
    flex-direction: column;
  }
}

@media (max-width: 640px) {
  .notes-summary {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-sm);
  }

  .notes-summary-number {
    font-size: 1.8rem;
  }

  .notes-patient-list {
    padding: 0 var(--space-md) var(--space-md);
  }

  .notes-facility-header {
    padding: var(--space-md);
  }

  .notes-patient-card {
    padding: var(--space-md);
  }
}


/* ---------------------------------------------------------------------------
   14. FACILITY PAGES — Card-based, one-click connect
   --------------------------------------------------------------------------- */

/* ── Summary Cards ── */
.fac-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.fac-summary-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-md);
  text-align: center;
}

.fac-summary-number {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1;
}

.fac-summary-label {
  font-size: 0.85rem;
  color: var(--color-cocoa);
  margin-top: 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.fac-summary-card--online .fac-summary-number { color: var(--color-forest); }
.fac-summary-card--offline .fac-summary-number { color: var(--color-error); }

/* Privacy blur — reveal on hover */
.fac-summary--blur .fac-summary-number {
  filter: blur(10px);
  transition: filter 0.35s ease;
  user-select: none;
}
.fac-summary--blur:hover .fac-summary-number {
  filter: blur(0);
}

/* ── Quick Actions ── */
.fac-actions {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.fac-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: all 0.2s ease;
}

a.fac-action-btn--primary,
a.fac-action-btn--primary:visited,
a.fac-action-btn--primary:hover,
.fac-action-btn--primary {
  background: var(--color-forest, #3D6B35);
  color: #FFFFFF;
  box-shadow: 0 2px 6px rgba(61, 107, 53, 0.25);
  font-weight: 700;
  letter-spacing: 0.01em;
}
.fac-action-btn--primary:hover,
a.fac-action-btn--primary:hover {
  background: var(--color-deep-moss, #4A6741);
  color: #FFFFFF;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(61, 107, 53, 0.35);
}

.fac-action-btn--secondary {
  background: var(--color-cream);
  color: var(--color-coffee);
}
.fac-action-btn--secondary:hover {
  background: var(--color-latte);
}

.fac-action-btn--lg {
  padding: 1rem 2rem;
  font-size: 1.1rem;
}

/* ── Facility Group Sections ── */
.fac-group {
  margin-bottom: var(--space-xl);
}

.fac-group-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-latte);
}

.fac-group-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--color-cream);
  color: var(--color-coffee);
}

.fac-group-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0;
  letter-spacing: -0.01em;
}

.fac-group-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 26px;
  border-radius: 13px;
  background: var(--color-sage);
  color: var(--color-white);
  font-size: 0.8rem;
  font-weight: 700;
  padding: 0 8px;
}

.fac-group-patients {
  font-size: 0.85rem;
  color: var(--color-cocoa);
  font-weight: 500;
}

.fac-status--manual {
  color: var(--color-sage);
}

.fac-status--manual .fac-status-dot {
  background: var(--color-sage);
}

/* ── Facility Card Grid ── */
.fac-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: var(--space-lg);
}

.fac-card {
  position: relative;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: all 0.25s ease;
}

.fac-card--online {
  border-left: 4px solid var(--color-forest);
}

.fac-card--offline {
  border-left: 4px solid var(--color-error);
}

.fac-card-link {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: var(--radius-lg);
}

/* ── Card Header ── */
.fac-card-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
}

.fac-card-icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-cream);
  border-radius: var(--radius-md);
  color: var(--color-cocoa);
}

.fac-card-title h3 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0;
  line-height: 1.3;
}

.fac-card-badges {
  display: flex;
  gap: 0.35rem;
  margin-top: 0.35rem;
}

/* ── Badges ── */
.fac-badge {
  display: inline-block;
  padding: 0.15rem 0.6rem;
  border-radius: 99px;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.fac-badge--type {
  background: var(--color-cream);
  color: var(--color-coffee);
}

.fac-badge--emr {
  background: #E8F0E2;
  color: var(--color-forest);
}

.fac-badge--md {
  background: #FFF3CD;
  color: #856404;
  font-weight: 600;
  letter-spacing: 0.01em;
}

.fac-badge--tag {
  background: var(--color-ivory);
  color: var(--color-sienna);
  font-size: 0.65rem;
}

.badge-lg {
  font-size: 0.85rem;
  padding: 0.4rem 1rem;
}

/* ── Card Details ── */
.fac-card-details {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.fac-card-detail {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: var(--color-cocoa);
}

.fac-card-detail svg {
  flex-shrink: 0;
  color: var(--color-sandstone);
}

/* ── Card Footer: Status + Connect Button ── */
.fac-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-cream);
  position: relative;
  z-index: 2;
}

/* ── Status Indicator ── */
.fac-status {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  font-weight: 600;
}

.fac-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}

.fac-status--online {
  color: var(--color-forest);
}

.fac-status--online .fac-status-dot {
  background: var(--color-forest);
  box-shadow: 0 0 0 3px rgba(91, 140, 62, 0.2);
  animation: pulse 2s ease-in-out infinite;
}

.fac-status--offline {
  color: var(--color-error);
}

.fac-status--offline .fac-status-dot {
  background: var(--color-error);
}

/* ── One-Click Buttons ── */
.fac-card-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 1.1rem;
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: all 0.2s ease;
  position: relative;
  z-index: 2;
}

.fac-card-btn--connect {
  background: var(--color-forest);
  color: var(--color-white);
}

.fac-card-btn--connect:hover {
  background: var(--color-sage);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(91, 140, 62, 0.3);
}

.fac-card-btn--view {
  background: var(--color-cream);
  color: var(--color-coffee);
}

.fac-card-btn--view:hover {
  background: var(--color-latte);
}

/* ── Spinner for HTMX loading ── */
.fac-spinner {
  animation: spin 1s linear infinite;
}

.fac-spinner.htmx-indicator {
  display: none;
}

.htmx-request .fac-spinner.htmx-indicator,
.htmx-request.fac-spinner.htmx-indicator {
  display: inline-block;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Pulse once after successful connect */
@keyframes pulseOnce {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

.pulse-once {
  animation: pulseOnce 0.4s ease;
}

/* ── Empty State ── */
.fac-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-3xl) var(--space-lg);
  text-align: center;
}

.fac-empty-icon {
  color: var(--color-sandstone);
  margin-bottom: var(--space-md);
}

.fac-empty-title {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0 0 var(--space-sm);
}

.fac-empty-desc {
  font-size: 1rem;
  color: var(--color-cocoa);
  max-width: 400px;
  margin: 0 0 var(--space-lg);
}


/* ── Facility Detail: Hero Card ── */

.fac-back-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  color: var(--color-cocoa);
  transition: all 0.15s ease;
}

.fac-back-btn:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}

.fac-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  margin-bottom: var(--space-lg);
  gap: var(--space-xl);
}

.fac-hero-left {
  display: flex;
  gap: var(--space-lg);
  align-items: flex-start;
}

.fac-hero-icon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  color: var(--color-cocoa);
}

.fac-hero-info h2 {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0 0 0.35rem;
}

.fac-hero-badges {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 0.5rem;
}

.fac-hero-address,
.fac-hero-phone {
  font-size: 0.9rem;
  color: var(--color-cocoa);
  line-height: 1.5;
}

.fac-hero-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-md);
}

/* ── Connect Box (one-click) ── */
.fac-connect-box {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
}

.fac-connect-status {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.9rem;
  font-weight: 600;
}

.fac-connect-status--online { color: var(--color-forest); }
.fac-connect-status--offline { color: var(--color-error); }

.fac-connect-failures {
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--color-sandstone);
  margin-left: 0.25rem;
}

.fac-connect-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.7rem 1.5rem;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all 0.2s ease;
}

.fac-connect-btn--connect {
  background: var(--color-forest);
  color: var(--color-white);
  font-size: 1rem;
  padding: 0.8rem 1.8rem;
}

.fac-connect-btn--connect:hover {
  background: var(--color-sage);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(91, 140, 62, 0.35);
}

.fac-connect-btn--reconnect {
  background: var(--color-cream);
  color: var(--color-coffee);
}

.fac-connect-btn--reconnect:hover {
  background: var(--color-latte);
}

/* ── Delete Button ── */
.fac-delete-form {
  min-height: 32px;
}

.fac-delete-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.75rem;
  border: none;
  background: none;
  color: var(--color-sandstone);
  font-size: 0.8rem;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all 0.15s ease;
}

.fac-delete-btn:hover {
  color: var(--color-error);
  background: rgba(198, 40, 40, 0.06);
}

.fac-delete-confirm {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  color: var(--color-cocoa);
}

.fac-delete-btn--yes {
  background: var(--color-error);
  color: var(--color-white);
  padding: 0.3rem 0.8rem;
  border-radius: var(--radius-sm);
}

.fac-delete-btn--yes:hover {
  background: #b71c1c;
  color: var(--color-white);
}

.fac-delete-btn--no {
  background: var(--color-cream);
  color: var(--color-coffee);
  padding: 0.3rem 0.8rem;
}


/* ── Info Cards Row ── */
.fac-info-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-lg);
}

.fac-info-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}

.fac-info-card-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0 0 var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-cream);
}

.fac-info-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.fac-info-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
}

.fac-info-label {
  font-size: 0.85rem;
  color: var(--color-sandstone);
  font-weight: 500;
}

.fac-info-value {
  font-size: 0.9rem;
  color: var(--color-espresso);
  font-weight: 600;
  text-align: right;
}

.fac-text-error { color: var(--color-error); }


/* ── Patient List ── */
.fac-patients-section {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}

.fac-patients-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-cream);
}

.fac-patients-header h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0;
}

.fac-patients-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 28px;
  padding: 0 0.5rem;
  background: var(--color-cream);
  border-radius: 99px;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--color-coffee);
}

.fac-patients-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-sm);
}

.fac-patient-card {
  display: block;
  padding: var(--space-md);
  border: 1px solid var(--color-cream);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: all 0.2s ease;
}

.fac-patient-card:hover {
  border-color: var(--color-latte);
  background: var(--color-ivory);
}

.fac-patient-name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: 0.25rem;
}

.fac-patient-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.78rem;
  color: var(--color-sandstone);
}

.fac-patients-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xl);
  text-align: center;
  color: var(--color-sandstone);
}

.fac-patients-empty p {
  font-size: 0.9rem;
  margin: 0;
}

.fac-login-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--accent);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s;
}
.fac-login-link:hover {
  color: var(--accent-hover);
  text-decoration: underline;
}
.fac-login-link svg { flex-shrink: 0; opacity: 0.7; }


/* ── Provider Identifiers Grid ── */
.fac-info-card--wide {
  grid-column: 1 / -1;
}

.fac-ids-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.75rem;
}

.fac-id-item {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.6rem 0.85rem;
  background: var(--color-ivory);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-taupe);
}

.fac-id-label {
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--color-sandstone);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.fac-id-value {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-espresso);
  word-break: break-word;
}


/* ── Facility Responsive ── */
@media (max-width: 900px) {
  .fac-summary {
    grid-template-columns: repeat(2, 1fr);
  }

  .fac-grid {
    grid-template-columns: 1fr;
  }

  .fac-hero {
    flex-direction: column;
  }

  .fac-hero-right {
    align-items: flex-start;
    width: 100%;
  }

  .fac-connect-box {
    align-items: flex-start;
    width: 100%;
  }

  .fac-connect-btn--connect {
    width: 100%;
    justify-content: center;
  }

  .fac-info-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .fac-summary {
    grid-template-columns: 1fr 1fr;
  }

  .fac-summary-number {
    font-size: 1.8rem;
  }

  .fac-hero-left {
    flex-direction: column;
    gap: var(--space-sm);
  }

  .fac-patients-grid {
    grid-template-columns: 1fr;
  }
}


/* ============================================================================
   PROVIDER PROFILE PAGE
   ============================================================================ */

/* ── Extra Animation Keyframes ─────────────────────────────────────────────── */

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-40px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

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

@keyframes bounceIn {
  0% {
    opacity: 0;
    transform: scale(0.3);
  }
  50% {
    opacity: 1;
    transform: scale(1.06);
  }
  70% {
    transform: scale(0.95);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes popIn {
  0% {
    opacity: 0;
    transform: scale(0.6);
  }
  70% {
    transform: scale(1.04);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes pulseDot {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(122, 155, 109, 0.5);
  }
  50% {
    box-shadow: 0 0 0 6px rgba(122, 155, 109, 0);
  }
}

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

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

/* Reusable animation utility classes */
.slide-in-left {
  animation: slideInLeft 0.6s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.slide-in-up {
  animation: slideInUp 0.5s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.bounce-in {
  animation: bounceIn 0.7s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.pop-in {
  animation: popIn 0.45s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.pulse-dot {
  animation: pulseDot 2s ease-in-out infinite;
}


/* ── Hero Card ─────────────────────────────────────────────────────────────── */

.prov-hero {
  display: flex;
  gap: var(--space-xl);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-lg);
  margin-bottom: var(--space-xl);
  border: 1px solid var(--color-latte);
  position: relative;
  overflow: hidden;
}

.prov-hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-terracotta), var(--color-amber), var(--color-sage));
  background-size: 200% 100%;
  animation: shimmerGlow 3s ease-in-out infinite;
}

.prov-hero-photo {
  flex-shrink: 0;
}

.prov-avatar {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-mocha), var(--color-terracotta));
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 14px rgba(44, 24, 16, 0.18);
  animation: float 4s ease-in-out infinite;
}

.prov-avatar-initials {
  font-size: 2rem;
  font-weight: 800;
  color: var(--color-white);
  letter-spacing: 2px;
  text-transform: uppercase;
}

.prov-hero-info {
  flex: 1;
  min-width: 0;
}

.prov-hero-name {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--color-espresso);
  margin: 0 0 var(--space-xs) 0;
  line-height: 1.2;
}

.prov-hero-specialty {
  font-size: 1.05rem;
  color: var(--color-cocoa);
  font-weight: 500;
  margin: 0 0 2px 0;
}

.prov-hero-practice {
  font-size: 0.92rem;
  color: var(--color-clay);
  margin: 0 0 var(--space-md) 0;
}

.prov-hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.prov-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.3px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.prov-badge:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.prov-badge--npi {
  background: var(--color-cream);
  color: var(--color-mocha);
  border: 1px solid var(--color-latte);
}

.prov-badge--license {
  background: #EEF2FF;
  color: var(--color-slate-blue);
  border: 1px solid #C7D2FE;
}

.prov-badge--pecos {
  background: #F0FDF4;
  color: var(--color-deep-moss);
  border: 1px solid #BBF7D0;
}

.prov-badge--medicare {
  background: #FFFBEB;
  color: #92400E;
  border: 1px solid #FDE68A;
}

.prov-badge--link {
  text-decoration: none;
  cursor: pointer;
  transition: filter 0.15s ease, transform 0.15s ease;
}

.prov-badge--link:hover {
  filter: brightness(0.95);
  transform: translateY(-1px);
}

.prov-badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

.prov-badge-dot--green {
  background: var(--color-sage);
}

.prov-badge-dot--red {
  background: var(--color-terracotta);
}


/* ── Status Checks Row ─────────────────────────────────────────────────────── */

.prov-checks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.prov-check-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-latte);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.prov-check-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-card-hover);
}

.prov-check--ok .prov-check-icon {
  color: var(--color-sage);
  background: #F0FDF4;
  border: 1px solid #BBF7D0;
}

.prov-check--warn .prov-check-icon {
  color: var(--color-terracotta);
  background: #FEF2F2;
  border: 1px solid #FECACA;
}

.prov-check-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.prov-check-text {
  flex: 1;
  min-width: 0;
}

.prov-check-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-clay);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 2px;
}

.prov-check-value {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-espresso);
}

.prov-check-meta {
  font-size: 0.78rem;
  color: var(--color-sandstone);
  margin-top: 2px;
}

.prov-check-meta a {
  color: var(--color-terracotta);
  text-decoration: none;
  font-weight: 600;
}

.prov-check-meta a:hover {
  text-decoration: underline;
}


/* ── Info Cards Grid ───────────────────────────────────────────────────────── */

.prov-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}

.prov-info-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-latte);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.prov-info-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card-hover);
}

.prov-info-card-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-mocha);
  margin: 0 0 var(--space-md) 0;
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-cream);
}

.prov-info-card-title svg {
  color: var(--color-terracotta);
  flex-shrink: 0;
}

.prov-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.prov-list-item {
  padding: 8px 0;
  font-size: 0.9rem;
  color: var(--color-coffee);
  border-bottom: 1px solid var(--color-cream);
  line-height: 1.5;
  position: relative;
  padding-left: 16px;
}

.prov-list-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 14px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-terracotta);
}

.prov-list-item:last-child {
  border-bottom: none;
}


/* ── Contact & Practice Detail Grid ────────────────────────────────────────── */

.prov-detail-grid {
  display: grid;
  gap: var(--space-sm);
}

.prov-detail-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 0;
  border-bottom: 1px solid var(--color-cream);
}

.prov-detail-item:last-child {
  border-bottom: none;
}

.prov-detail-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-clay);
}

.prov-detail-value {
  font-size: 0.9rem;
  color: var(--color-espresso);
  font-weight: 500;
}

.prov-detail-value a {
  color: var(--color-terracotta);
  text-decoration: none;
  font-weight: 600;
}

.prov-detail-value a:hover {
  text-decoration: underline;
}


/* ── Section Headers ───────────────────────────────────────────────────────── */

.prov-section {
  margin-bottom: var(--space-xl);
}

.prov-section-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--color-espresso);
  margin: 0 0 var(--space-lg) 0;
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-latte);
}

.prov-section-title svg {
  color: var(--color-terracotta);
  flex-shrink: 0;
}


/* ── NP Assignment Cards ───────────────────────────────────────────────────── */

.prov-np-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-md);
}

.prov-np-card {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-latte);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  cursor: pointer;
}
.prov-np-chevron {
  margin-left: auto;
  opacity: 0.3;
  flex-shrink: 0;
  transition: opacity 0.2s;
}
.prov-np-card:hover .prov-np-chevron { opacity: 0.7; }
.prov-np-patient-count {
  font-weight: 600;
  color: var(--color-accent, #5b8c6e);
}

.prov-np-leave-banner {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
  padding: 4px 10px;
  background: #FFF3CD;
  color: #856404;
  border-radius: 6px;
  font-size: 0.76rem;
  font-weight: 600;
  border: 1px solid #FFE69C;
}

.prov-np-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-card-hover);
}

.prov-np-card--empty {
  border-style: dashed;
  border-color: var(--color-taupe);
  background: var(--color-ivory);
}

.prov-np-avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-slate-blue), var(--color-sage));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(107, 127, 163, 0.25);
}

.prov-np-avatar span {
  font-size: 1rem;
  font-weight: 800;
  color: var(--color-white);
  letter-spacing: 1px;
}

.prov-np-avatar--empty {
  background: var(--color-latte);
  box-shadow: none;
}

.prov-np-avatar--empty svg {
  color: var(--color-taupe);
}

.prov-np-info {
  flex: 1;
  min-width: 0;
}

.prov-np-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0 0 2px 0;
}

.prov-np-name--empty {
  color: var(--color-taupe);
  font-style: italic;
}

.prov-np-facility {
  font-size: 0.82rem;
  color: var(--color-clay);
  margin: 0 0 var(--space-sm) 0;
}

.prov-np-details {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs) var(--space-md);
  font-size: 0.78rem;
  color: var(--color-sandstone);
}

.prov-np-details span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}


/* ── Provider Quick Links Grid ─────────────────────────────────────────────── */
.prov-quicklinks-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-md);
}

/* ── Credentialing Checklist ── */

.cred-checklist {
  display: flex;
  flex-direction: column;
}

.cred-check-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.25rem;
  border-bottom: 1px solid var(--color-latte, #D7CCC8);
  gap: 1rem;
  transition: background 0.15s ease;
}

.cred-check-item:last-child { border-bottom: none; }

.cred-check-item:hover { background: var(--color-ivory, #FAF7F2); }

.cred-check-item--attached {
  background: #f8fdf8;
}

.cred-check-left {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex: 1;
  min-width: 0;
}

.cred-check-label {
  font-size: 0.95rem;
  color: var(--color-espresso, #3E2723);
  font-weight: 500;
}

.cred-check-right {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.cred-check-file {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.82rem;
  color: var(--color-sage, #8DAA91);
  text-decoration: none;
  padding: 0.3rem 0.6rem;
  border-radius: var(--radius-sm);
  background: #f0f7f0;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cred-check-file:hover {
  background: #e0f0e0;
  color: var(--color-deep-moss, #5B7B5E);
}

.cred-attach-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.35rem 0.7rem;
  background: var(--color-ivory, #FAF7F2);
  color: var(--color-cocoa, #5D4037);
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-sm);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s ease;
}

.cred-attach-btn:hover {
  background: var(--color-sage, #8DAA91);
  color: var(--color-white, #fff);
  border-color: var(--color-sage, #8DAA91);
}

@media (max-width: 640px) {
  .cred-check-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }
}

/* ── Compliance Card ───────────────────────────────────────────────────────── */

.prov-compliance-card {
  display: flex;
  gap: var(--space-lg);
  padding: var(--space-xl);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-latte);
  box-shadow: var(--shadow-md);
}

.prov-compliance--clean {
  background: linear-gradient(135deg, #F0FDF4, #ECFDF5);
  border-color: #BBF7D0;
}

.prov-compliance-icon {
  flex-shrink: 0;
  color: var(--color-sage);
  animation: float 3s ease-in-out infinite;
}

.prov-compliance-text {
  flex: 1;
}

.prov-compliance-text h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-deep-moss);
  margin: 0 0 var(--space-xs) 0;
}

.prov-compliance-text p {
  font-size: 0.9rem;
  color: var(--color-coffee);
  line-height: 1.6;
  margin: 0 0 var(--space-xs) 0;
}

.prov-compliance-meta {
  font-size: 0.78rem !important;
  color: var(--color-sandstone) !important;
}


/* ── Provider Profile Responsive ───────────────────────────────────────────── */

@media (max-width: 768px) {
  .prov-hero {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-lg);
  }

  .prov-hero-badges {
    justify-content: center;
  }

  .prov-checks {
    grid-template-columns: 1fr 1fr;
  }

  .prov-info-grid {
    grid-template-columns: 1fr;
  }

  .prov-np-grid {
    grid-template-columns: 1fr;
  }

  .prov-compliance-card {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}

@media (max-width: 480px) {
  .prov-checks {
    grid-template-columns: 1fr;
  }

  .prov-hero-name {
    font-size: 1.25rem;
  }

  .prov-avatar {
    width: 72px;
    height: 72px;
  }

  .prov-avatar-initials {
    font-size: 1.5rem;
  }
}


/* ============================================================================
   FACILITY COMPLIANCE & STANDING SECTION
   ============================================================================ */

.fac-compliance-section {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-latte);
  margin-bottom: var(--space-xl);
}

.fac-compliance-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0 0 var(--space-lg) 0;
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-latte);
}

.fac-compliance-title svg {
  color: var(--color-terracotta);
  flex-shrink: 0;
}

.fac-compliance-checked {
  margin-left: auto;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-sandstone);
  background: var(--color-cream);
  padding: 3px 10px;
  border-radius: 12px;
}

/* Alert Items */
.fac-compliance-alerts {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.fac-alert {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border-left: 4px solid transparent;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.fac-alert:hover {
  transform: translateX(4px);
  box-shadow: var(--shadow-sm);
}

.fac-alert--critical {
  background: #FEF2F2;
  border-left-color: #DC2626;
  color: #991B1B;
}

.fac-alert--critical .fac-alert-icon {
  color: #DC2626;
}

.fac-alert--warn {
  background: #FFFBEB;
  border-left-color: #D97706;
  color: #92400E;
}

.fac-alert--warn .fac-alert-icon {
  color: #D97706;
}

.fac-alert--ok {
  background: #F0FDF4;
  border-left-color: var(--color-sage);
  color: var(--color-deep-moss);
}

.fac-alert--ok .fac-alert-icon {
  color: var(--color-sage);
}

.fac-alert--info {
  background: #EFF6FF;
  border-left-color: var(--color-slate-blue);
  color: #1E40AF;
}

.fac-alert--info .fac-alert-icon {
  color: var(--color-slate-blue);
}

.fac-alert-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.fac-alert-text {
  font-size: 0.88rem;
  font-weight: 500;
  line-height: 1.4;
}

/* CMS Star Ratings */
.fac-ratings-card {
  background: var(--color-ivory);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  border: 1px solid var(--color-cream);
}

.fac-ratings-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-mocha);
  margin: 0 0 var(--space-md) 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.fac-ratings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-sm) var(--space-lg);
}

.fac-rating-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.fac-rating-label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-coffee);
}

.fac-rating-stars {
  display: flex;
  gap: 2px;
}

.fac-star {
  font-size: 1.1rem;
  color: var(--color-latte);
  transition: color 0.3s ease, transform 0.2s ease;
}

.fac-star--filled {
  color: var(--color-amber);
}

.fac-star--filled:hover {
  transform: scale(1.2);
}

/* Survey History Table */
.fac-survey-table {
  margin-bottom: var(--space-lg);
}

.fac-survey-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-mocha);
  margin: 0 0 var(--space-sm) 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.fac-survey {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.fac-survey thead th {
  text-align: left;
  padding: 8px 12px;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-clay);
  border-bottom: 2px solid var(--color-latte);
  background: var(--color-ivory);
}

.fac-survey tbody tr {
  transition: background 0.2s ease;
}

.fac-survey tbody tr:hover {
  background: var(--color-cream);
}

.fac-survey tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--color-cream);
  color: var(--color-coffee);
}

.fac-def-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  padding: 2px 8px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 0.82rem;
}

.fac-def-count--high {
  background: #FEE2E2;
  color: #991B1B;
}

.fac-def-count--med {
  background: #FEF3C7;
  color: #92400E;
}

.fac-def-count--low {
  background: #DCFCE7;
  color: var(--color-deep-moss);
}

/* Sources */
.fac-compliance-sources {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-xs);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-cream);
}

.fac-sources-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-clay);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.fac-source-tag {
  font-size: 0.72rem;
  padding: 2px 8px;
  border-radius: 10px;
  background: var(--color-cream);
  color: var(--color-cocoa);
  font-weight: 500;
}


/* ============================================================================
   ENHANCED CONNECTED / OFFLINE DISTINCTION
   ============================================================================ */

/* Facility list cards — stronger visual difference */
.fac-card--online {
  border-left: 4px solid var(--color-sage);
  position: relative;
}

.fac-card--online::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-sage), transparent);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  opacity: 0.6;
}

.fac-card--offline {
  border-left: 4px solid var(--color-taupe);
  opacity: 0.85;
  position: relative;
}

.fac-card--offline .fac-card-header {
  opacity: 0.7;
}

.fac-card--offline::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-taupe), transparent);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  opacity: 0.4;
}

/* Medical Director highlight */
.fac-card--med-director {
  border-left: 4px solid #D4A017 !important;
  background: linear-gradient(135deg, #FFFDF5 0%, var(--color-white) 100%);
  box-shadow: 0 2px 8px rgba(212, 160, 23, 0.12);
}

.fac-card--med-director::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, #D4A017, #F0C75E, transparent);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

/* Stronger status indicators */
.fac-status--online {
  color: var(--color-deep-moss);
  font-weight: 700;
}

.fac-status--online .fac-status-dot {
  background: var(--color-sage);
  box-shadow: 0 0 0 3px rgba(122, 155, 109, 0.2);
  animation: pulseDot 2s ease-in-out infinite;
}

.fac-status--offline {
  color: var(--color-sandstone);
  font-weight: 600;
}

.fac-status--offline .fac-status-dot {
  background: var(--color-taupe);
  box-shadow: 0 0 0 3px rgba(188, 170, 164, 0.2);
}

/* Detail page connect box enhancement */
.fac-connect-status--online {
  background: #F0FDF4;
  border: 1px solid #BBF7D0;
  padding: 8px 16px;
  border-radius: var(--radius-md);
  color: var(--color-deep-moss);
  font-weight: 700;
}

.fac-connect-status--offline {
  background: #FEF2F2;
  border: 1px solid #FECACA;
  padding: 8px 16px;
  border-radius: var(--radius-md);
  color: #991B1B;
  font-weight: 600;
}


/* ============================================================================
   CREDENTIAL WARNING & UPDATE FORM
   ============================================================================ */

/* Warning Banner */
.fac-cred-warning {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  background: linear-gradient(135deg, #FEF2F2, #FFF7ED);
  border: 1px solid #FECACA;
  border-left: 4px solid #DC2626;
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-lg);
}

.fac-cred-warning-icon {
  flex-shrink: 0;
  color: #DC2626;
  margin-top: 2px;
}

.fac-cred-warning-text {
  flex: 1;
  min-width: 0;
}

.fac-cred-warning-text strong {
  display: block;
  font-size: 0.95rem;
  color: #991B1B;
  margin-bottom: 4px;
}

.fac-cred-warning-text p {
  font-size: 0.85rem;
  color: #7F1D1D;
  line-height: 1.5;
  margin: 0;
}

.fac-cred-warning-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--color-terracotta);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
  white-space: nowrap;
}

.fac-cred-warning-btn:hover {
  background: var(--color-rust);
  transform: translateY(-1px);
}

/* Error status dot */
.fac-status--error {
  color: #DC2626;
  font-weight: 700;
}

.fac-status--error .fac-status-dot {
  background: #DC2626;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.2);
}

/* Password show/hide toggle */
.fac-info-password {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
}

.fac-pw-toggle {
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-sm);
  padding: 2px 8px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-clay);
  cursor: pointer;
  transition: all 0.2s ease;
}

.fac-pw-toggle:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}

/* Credential Edit Button */
.fac-cred-edit-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  color: var(--color-cocoa);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.fac-cred-edit-btn:hover {
  background: var(--color-cream);
  border-color: var(--color-taupe);
  color: var(--color-espresso);
}

/* Credential Update Form */
.fac-cred-form-wrapper {
  margin-bottom: var(--space-lg);
}

.fac-cred-form {
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
}

.fac-cred-form-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0 0 var(--space-md) 0;
}

.fac-cred-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}

.fac-cred-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.fac-cred-field:last-child {
  grid-column: 1 / -1;
}

.fac-cred-field label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-clay);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.fac-cred-field input {
  padding: 10px 14px;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-family: var(--font-primary);
  color: var(--color-espresso);
  background: var(--color-white);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.fac-cred-field input:focus {
  outline: none;
  border-color: var(--color-terracotta);
  box-shadow: 0 0 0 3px rgba(199, 91, 57, 0.12);
}

.fac-cred-form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.fac-cred-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  color: var(--color-cocoa);
  cursor: pointer;
}

.fac-cred-checkbox input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--color-terracotta);
}

.fac-cred-form-btns {
  display: flex;
  gap: var(--space-sm);
}

.fac-cred-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  border: none;
}

.fac-cred-btn--cancel {
  background: var(--color-white);
  color: var(--color-cocoa);
  border: 1px solid var(--color-latte);
}

.fac-cred-btn--cancel:hover {
  background: var(--color-cream);
}

.fac-cred-btn--save {
  background: var(--color-sage);
  color: white;
}

.fac-cred-btn--save:hover {
  background: var(--color-deep-moss);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(74, 103, 65, 0.25);
}

.fac-connect-failures {
  font-size: 0.78rem;
  opacity: 0.7;
  margin-left: var(--space-xs);
}

/* ── Login Administrator Card ── */
.fac-admin-card {
  border-left: 3px solid var(--color-sage);
}

.fac-admin-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs);
}

.fac-admin-header .fac-info-card-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 0;
}

.fac-admin-edit-btn {
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: 6px 14px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-cocoa);
  cursor: pointer;
  transition: all 0.2s ease;
}

.fac-admin-edit-btn:hover {
  background: var(--color-cream);
  border-color: var(--color-cocoa);
}

.fac-admin-hint {
  font-size: 0.82rem;
  color: var(--color-taupe);
  margin: 0 0 var(--space-md) 0;
  line-height: 1.4;
}

.fac-admin-contact {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md);
  background: var(--color-cream);
  border-radius: var(--radius-md);
}

.fac-admin-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-sage);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fac-admin-info {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.fac-admin-name {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-espresso);
}

.fac-admin-phone,
.fac-admin-email {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.9rem;
  color: var(--color-terracotta);
  text-decoration: none;
  transition: color 0.2s ease;
}

.fac-admin-phone:hover,
.fac-admin-email:hover {
  color: var(--color-deep-terracotta);
  text-decoration: underline;
}

.fac-admin-empty {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md);
  background: var(--color-cream);
  border-radius: var(--radius-md);
  color: var(--color-taupe);
  font-size: 0.88rem;
}

.fac-admin-empty svg {
  flex-shrink: 0;
  opacity: 0.5;
}

.fac-admin-form-wrapper {
  margin-top: var(--space-sm);
}

.fac-admin-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-md);
}

@media (max-width: 768px) {
  .fac-admin-form-grid {
    grid-template-columns: 1fr;
  }
  .fac-admin-contact {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}

/* Responsive */
@media (max-width: 640px) {
  .fac-cred-warning {
    flex-direction: column;
    gap: var(--space-sm);
  }

  .fac-cred-form-grid {
    grid-template-columns: 1fr;
  }

  .fac-cred-form-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .fac-cred-form-btns {
    justify-content: flex-end;
  }
}


/* ---------------------------------------------------------------------------
   GROUP HOMES CENSUS
   --------------------------------------------------------------------------- */

.gh-summary {
  display: flex;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}

.gh-summary-card {
  flex: 1;
  min-width: 160px;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  text-align: center;
}

.gh-summary-number {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.1;
  font-family: var(--font-mono);
}

.gh-summary-number--name {
  font-size: 1.1rem;
  font-family: var(--font-primary);
  font-weight: 600;
  color: var(--color-mocha);
}

.gh-summary-label {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Owner Group Headers */
.gh-owner-group {
  margin-bottom: var(--space-lg);
}
.gh-owner-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-xs);
  border-bottom: 2px solid var(--color-accent, #5b8c6e);
}
.gh-owner-name {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-text);
}
.gh-owner-phone {
  font-size: 0.85rem;
  color: var(--color-accent, #5b8c6e);
  text-decoration: none;
  font-weight: 500;
}
.gh-owner-phone:hover { text-decoration: underline; }
.gh-owner-count {
  margin-left: auto;
  font-size: 0.82rem;
  color: var(--color-text-muted, #8a8a8a);
  font-weight: 500;
}

/* Home Card Accordion */
.gh-homes {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.gh-home-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.gh-home-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-md) var(--space-lg);
  border: none;
  background: none;
  cursor: pointer;
  font-family: var(--font-primary);
  text-align: left;
  transition: background var(--transition-fast);
}

.gh-home-header:hover {
  background: var(--color-ivory);
}

.gh-home-header--open {
  background: var(--color-ivory);
  border-bottom: 1px solid var(--color-latte);
}

.gh-home-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.gh-chevron {
  transition: transform var(--transition-fast);
  color: var(--color-sandstone);
  flex-shrink: 0;
}

.gh-chevron--open {
  transform: rotate(90deg);
}

.gh-home-name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-espresso);
}

.gh-home-header-right {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.gh-patient-count {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-cocoa);
  background: var(--color-cream);
  padding: 3px 10px;
  border-radius: 12px;
}

.gh-home-address-chip {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Home Body (expanded) */
.gh-home-body {
  padding: 0 var(--space-lg) var(--space-lg);
}

.gh-slide-enter { transition: all 0.2s ease; }
.gh-slide-leave { transition: all 0.15s ease; }
.gh-slide-start { opacity: 0; transform: translateY(-8px); }
.gh-slide-end { opacity: 1; transform: translateY(0); }

/* Patient Table */
.gh-patient-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--space-md);
}

.gh-patient-table thead th {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-sandstone);
  font-weight: 600;
  text-align: left;
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--color-latte);
}

.gh-patient-table tbody td {
  padding: var(--space-sm) var(--space-md);
  font-size: 0.9rem;
  color: var(--color-coffee);
  border-bottom: 1px solid var(--color-cream);
}

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

.gh-patient-name-cell {
  font-weight: 500;
  color: var(--color-espresso);
}

.gh-col-action {
  width: 120px;
  text-align: right;
}

.gh-col-action:first-child {
  text-align: right;
}

/* Discharge Button */
.gh-discharge-form {
  display: inline;
}

.gh-discharge-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-sandstone);
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-primary);
  transition: all var(--transition-fast);
}

.gh-discharge-btn:hover {
  color: var(--color-terracotta);
  border-color: var(--color-terracotta);
}

.gh-confirm-row {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
}

.gh-confirm-text {
  color: var(--color-cocoa);
  font-weight: 500;
}

.gh-confirm-yes {
  padding: 3px 10px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-white);
  background: var(--color-terracotta);
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-primary);
}

.gh-confirm-no {
  padding: 3px 10px;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-sandstone);
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-primary);
}

/* Add Patient Section */
.gh-add-section {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-cream);
}

.gh-add-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-sage);
  background: none;
  border: 1px dashed var(--color-sage);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-primary);
  transition: all var(--transition-fast);
}

.gh-add-toggle:hover {
  background: rgba(122, 155, 109, 0.08);
  border-style: solid;
}

.gh-add-form {
  margin-top: var(--space-md);
}

.gh-add-fields {
  display: flex;
  gap: var(--space-sm);
  align-items: flex-end;
  flex-wrap: wrap;
}

.gh-input {
  padding: 8px 12px;
  font-size: 0.9rem;
  font-family: var(--font-primary);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  color: var(--color-espresso);
  background: var(--color-white);
  transition: border-color var(--transition-fast);
  min-width: 140px;
  flex: 1;
}

.gh-input:focus {
  outline: none;
  border-color: var(--color-sage);
}

.gh-input--date {
  max-width: 170px;
}

.gh-add-submit {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 20px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-white);
  background: var(--color-sage);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-primary);
  transition: background var(--transition-fast);
}

.gh-add-submit:hover {
  background: var(--color-deep-moss);
}

/* Home Footer */
.gh-home-footer {
  margin-top: var(--space-md);
  padding-top: var(--space-sm);
}

.gh-detail-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.8125rem;
  color: var(--color-rust);
  font-weight: 500;
}

.gh-detail-link:hover {
  color: var(--color-terracotta);
}

/* Empty States */
.gh-empty {
  padding: var(--space-lg);
  text-align: center;
  color: var(--color-sandstone);
  font-size: 0.9rem;
}

.gh-empty-state {
  text-align: center;
  padding: var(--space-3xl) var(--space-xl);
  color: var(--color-sandstone);
}

.gh-empty-state svg {
  margin: 0 auto var(--space-md);
  opacity: 0.4;
}

.gh-empty-state p {
  font-size: 1rem;
}

.gh-empty-state a {
  color: var(--color-rust);
  font-weight: 500;
}

@media (max-width: 640px) {
  .gh-summary {
    flex-direction: column;
  }

  .gh-home-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-sm);
  }

  .gh-home-header-right {
    padding-left: 26px;
  }

  .gh-add-fields {
    flex-direction: column;
  }

  .gh-input {
    min-width: 100%;
  }
}

/* ---------------------------------------------------------------------------
   PROVIDER LICENSE RENEWAL REMINDER
   --------------------------------------------------------------------------- */

.prov-check-meta--urgent {
  color: var(--color-terracotta) !important;
  font-weight: 600;
}

.prov-check-meta--ok {
  color: var(--color-sage);
}


/* ---------------------------------------------------------------------------
   CLINICAL NOTES
   --------------------------------------------------------------------------- */

.cn-summary {
  display: flex;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}

.cn-summary-card {
  flex: 1;
  min-width: 150px;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  text-align: center;
}

.cn-summary-card--warn {
  border-left: 4px solid var(--color-terracotta);
}

.cn-summary-card--revenue {
  border-left: 4px solid var(--color-sage);
}

.cn-summary-number {
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.1;
  font-family: var(--font-mono);
}

.cn-summary-label {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
  margin-top: var(--space-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Note Type Grid */
.cn-type-grid {
  display: flex;
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}

.cn-type-card {
  flex: 1;
  min-width: 140px;
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  box-shadow: var(--shadow-sm);
  text-align: center;
}

.cn-type-count {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-espresso);
  font-family: var(--font-mono);
}

.cn-type-label {
  font-size: 0.75rem;
  color: var(--color-cocoa);
  font-weight: 500;
}

.cn-type-overdue {
  font-size: 0.6875rem;
  color: var(--color-terracotta);
  font-weight: 600;
  margin-top: 2px;
}

/* Table */
.cn-table tbody td {
  vertical-align: middle;
}

.cn-row--overdue {
  background: rgba(199, 91, 57, 0.03);
}

.cn-patient-name {
  font-weight: 600;
  color: var(--color-espresso);
}

.cn-facility {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
}

.cn-never {
  color: var(--color-sandstone);
  font-style: italic;
}

.cn-days-ago {
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

.cn-col-action {
  text-align: right;
  width: 100px;
}

.cn-compose-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-white);
  background: var(--color-sage);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background var(--transition-fast);
}

.cn-compose-btn:hover {
  background: var(--color-deep-moss);
  color: var(--color-white);
}

.cn-empty {
  text-align: center;
  padding: var(--space-xl);
  color: var(--color-sage);
  font-weight: 500;
}

/* Filter */
.cn-filter {
  display: flex;
  gap: 4px;
}

.cn-filter-btn {
  padding: 4px 14px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-sandstone);
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-primary);
  transition: all var(--transition-fast);
}

.cn-filter-btn.active,
.cn-filter-btn:hover {
  color: var(--color-espresso);
  border-color: var(--color-rust);
  background: var(--color-ivory);
}

/* Reference Cards */
.cn-reference {
  margin-top: var(--space-xl);
}

.cn-reference-title {
  font-size: 1.125rem;
  color: var(--color-espresso);
  margin-bottom: var(--space-md);
}

.cn-reference-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-md);
}

.cn-ref-card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  box-shadow: var(--shadow-sm);
}

.cn-ref-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--space-xs);
}

.cn-ref-label {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-espresso);
}

.cn-ref-freq {
  font-size: 0.75rem;
  color: var(--color-sage);
  font-weight: 500;
}

.cn-ref-desc {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  margin-bottom: var(--space-sm);
}

.cn-ref-cpts {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

/* Facility Overview in Coding */
.cn-fac-group {
  border-bottom: 1px solid var(--color-latte);
}
.cn-fac-group:last-child {
  border-bottom: none;
}
.cn-fac-group-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-sm) var(--space-lg);
  background: var(--color-ivory);
}
.cn-fac-group-label {
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--color-espresso);
}
.cn-fac-group-count {
  font-size: 0.8rem;
  color: var(--color-sandstone);
}
.cn-fac-list {
  padding: 0 var(--space-lg);
}
.cn-fac-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: 8px 0;
  border-bottom: 1px solid var(--color-latte);
  font-size: 0.85rem;
}
.cn-fac-item:last-child {
  border-bottom: none;
}
.cn-fac-name {
  flex: 1;
  font-weight: 500;
  color: var(--color-espresso);
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cn-fac-emr {
  font-size: 0.75rem;
  color: var(--color-sage);
  background: var(--color-ivory);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}
.cn-fac-pts {
  font-size: 0.8rem;
  color: var(--color-cocoa);
  white-space: nowrap;
  min-width: 100px;
  text-align: right;
}
.cn-fac-empty {
  color: var(--color-rust);
  font-style: italic;
  font-size: 0.8rem;
}
.cn-fac-status {
  font-size: 0.75rem;
}
.cn-fac-status--connected {
  color: var(--color-sage);
}
.cn-fac-status--none {
  color: var(--color-latte);
}

/* Compose Form */
.cn-patient-bar {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--shadow-card);
  margin-bottom: var(--space-lg);
}

.cn-patient-bar-info {
  display: flex;
  gap: var(--space-lg);
  align-items: center;
  flex-wrap: wrap;
  font-size: 0.9rem;
  color: var(--color-cocoa);
}

.cn-patient-bar-info strong {
  color: var(--color-espresso);
  font-size: 1rem;
}

.form-textarea {
  width: 100%;
  padding: 10px 14px;
  font-size: 0.9375rem;
  font-family: var(--font-primary);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  color: var(--color-espresso);
  background: var(--color-white);
  resize: vertical;
  transition: border-color var(--transition-fast);
  line-height: 1.5;
}

.form-textarea:focus {
  outline: none;
  border-color: var(--color-sage);
  box-shadow: 0 0 0 3px rgba(122, 155, 109, 0.1);
}

/* Signature Section */
.cn-signature-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.cn-signature-pad {
  margin-top: var(--space-sm);
}

.cn-signature-actions {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-sm);
}

.cn-signature-name {
  font-weight: 600;
  color: var(--color-espresso);
  font-size: 0.9rem;
}

.cn-signature-date {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}

.btn-sm {
  padding: 4px 12px;
  font-size: 0.8125rem;
}

/* Note History */
.cn-history {
  margin-top: var(--space-xl);
}

.cn-history h3 {
  margin-bottom: var(--space-md);
}

.cn-history-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.cn-history-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.cn-history-date {
  font-weight: 600;
  font-size: 0.8125rem;
  color: var(--color-mocha);
  min-width: 90px;
}

.cn-history-summary {
  font-size: 0.875rem;
  color: var(--color-cocoa);
}

/* Voice Dictation Button */
.cn-dictate-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-cocoa);
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-primary);
  transition: all var(--transition-fast);
}

.cn-dictate-btn:hover {
  background: var(--color-cream);
  border-color: var(--color-sandstone);
}

.cn-dictate-btn--active {
  color: var(--color-terracotta);
  border-color: var(--color-terracotta);
  background: rgba(199, 91, 57, 0.05);
  animation: pulse 1.5s infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

@media (max-width: 640px) {
  .cn-summary {
    flex-direction: column;
  }
  .cn-type-grid {
    flex-direction: column;
  }
  .cn-reference-grid {
    grid-template-columns: 1fr;
  }
  .cn-patient-bar-info {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-xs);
  }
}

/* ── Notes Tab Bar & Tab Content ─────────────────────────────────── */

.tab-bar {
  display: flex;
  gap: var(--space-xs);
  border-bottom: 2px solid var(--border);
  padding-bottom: 0;
  margin-bottom: var(--space-lg);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.tab {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.7rem 1.2rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}

.tab:hover {
  color: var(--text-primary);
}

.tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  height: 1.5rem;
  padding: 0 0.45rem;
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: 999px;
  background: var(--bg-secondary);
  color: var(--text-muted);
  transition: background 0.15s, color 0.15s;
}

.tab.active .tab-badge {
  background: var(--accent);
  color: #fff;
}

.notes-tab-content {
  min-height: 200px;
}

.notes-tab-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  padding: 0.6rem 0.8rem;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
  font-size: 0.92rem;
  color: var(--text-secondary);
}

.notes-tab-stat {
  font-weight: 500;
}

.notes-tab-stat--urgent {
  color: var(--danger, #e74c3c);
  font-weight: 700;
}

@media (max-width: 640px) {
  .tab-bar {
    gap: 0;
  }
  .tab {
    padding: 0.6rem 0.8rem;
    font-size: 0.9rem;
  }
}

/* ── 2FA Note ── */
.fac-2fa-note {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--warning, #e67e22);
  font-weight: 600;
  font-size: 0.88rem;
}

.fac-2fa-note svg {
  flex-shrink: 0;
  stroke: var(--warning, #e67e22);
}

/* ── PCC Connection Dashboard ── */

.pcc-instructions {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding: 1.25rem 1.5rem;
  background: #fef9ef;
  border: 1px solid #f0ddb8;
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-lg);
  font-size: 0.95rem;
  color: var(--color-cocoa, #5D4037);
  line-height: 1.6;
}

.pcc-instructions-icon {
  flex-shrink: 0;
  color: var(--color-rust, #C97B4B);
  margin-top: 0.15rem;
}

.pcc-instructions strong {
  display: block;
  color: var(--color-espresso, #3E2723);
  margin-bottom: 0.35rem;
  font-size: 1.05rem;
}

.pcc-instructions p { margin: 0; }

.pcc-actions {
  margin-bottom: var(--space-lg);
}

.pcc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-lg);
}

.pcc-card {
  background: var(--color-white, #fff);
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.pcc-card:hover {
  box-shadow: 0 4px 16px rgba(62, 39, 35, 0.08);
  transform: translateY(-1px);
}

.pcc-card-header {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.pcc-card-icon {
  flex-shrink: 0;
  color: var(--color-sage, #8DAA91);
}

.pcc-card-info h3 {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 700;
  color: var(--color-espresso, #3E2723);
}

.pcc-card-meta {
  font-size: 0.84rem;
  color: var(--color-sandstone, #A1887F);
  font-family: var(--font-mono, monospace);
}

.pcc-card-status {
  padding: 0.85rem 1rem;
  border-radius: var(--radius-md);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.6rem;
}

.pcc-card-status--idle { background: var(--color-ivory, #FAF7F2); }
.pcc-card-status--2fa { background: #fef9ef; border: 1px solid #f0ddb8; }
.pcc-card-status--ok { background: #f0f7f0; border: 1px solid #c8e6c9; }
.pcc-card-status--error { background: #fef0f0; border: 1px solid #f5c6c6; }
.pcc-card-status--loading { background: var(--color-ivory, #FAF7F2); }

.pcc-status-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.pcc-status-dot--online { background: #66bb6a; }
.pcc-status-dot--warning { background: #ffa726; }
.pcc-status-dot--error { background: #ef5350; }

.pcc-status-text {
  flex: 1;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-espresso, #3E2723);
}

.pcc-2fa-prompt {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  margin-bottom: 0.5rem;
}

.pcc-2fa-form {
  display: flex;
  gap: 0.5rem;
  width: 100%;
}

.pcc-2fa-input {
  flex: 1;
  padding: 0.75rem 1rem;
  border: 2px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-md);
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.2em;
  background: var(--color-white, #fff);
  font-family: var(--font-mono, monospace);
  color: var(--color-espresso, #3E2723);
}

.pcc-2fa-input:focus {
  border-color: var(--color-sage, #8DAA91);
  outline: none;
  box-shadow: 0 0 0 3px rgba(141, 170, 145, 0.2);
}

.pcc-2fa-submit {
  padding: 0.75rem 1.5rem;
  background: var(--color-sage, #8DAA91);
  color: var(--color-white, #fff);
  border: none;
  border-radius: var(--radius-md);
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  transition: background 0.2s ease;
  white-space: nowrap;
}

.pcc-2fa-submit:hover { background: var(--color-deep-moss, #5B7B5E); }

.pcc-connect-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: var(--color-sage, #8DAA91);
  color: var(--color-white, #fff);
  border: none;
  border-radius: var(--radius-md);
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  width: 100%;
  justify-content: center;
  transition: background 0.2s ease;
}

.pcc-connect-btn:hover { background: var(--color-deep-moss, #5B7B5E); }

.pcc-action-btn {
  padding: 0.55rem 1.1rem;
  background: var(--color-sage, #8DAA91);
  color: var(--color-white, #fff);
  border: none;
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.2s ease;
}

.pcc-action-btn--save {
  background: #66bb6a;
}

.pcc-action-btn--save:hover {
  background: #43a047;
}

.pcc-action-btn--manual {
  background: var(--color-cocoa, #5D4037);
  text-decoration: none;
  display: inline-block;
  text-align: center;
}

.pcc-action-btn--reset {
  background: var(--color-sandstone, #A1887F);
}

.pcc-action-btn:hover { background: var(--color-deep-moss, #5B7B5E); }

.pcc-error-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.5rem;
  flex-wrap: wrap;
}

.pcc-spinner {
  animation: pcc-spin 1s linear infinite;
}

@keyframes pcc-spin {
  to { transform: rotate(360deg); }
}

@media (max-width: 640px) {
  .pcc-grid {
    grid-template-columns: 1fr;
  }
}

/* ── Notes tab empty state ── */
.notes-tab-empty {
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--color-sandstone, #A1887F);
  font-size: 1.05rem;
}

.notes-tab-empty a {
  display: inline-block;
  margin-top: 0.75rem;
  color: var(--color-sage, #8DAA91);
  font-weight: 600;
  text-decoration: none;
}

.notes-tab-empty a:hover { text-decoration: underline; }


/* ---------------------------------------------------------------------------
   SHARE CREDENTIALS MODAL
   --------------------------------------------------------------------------- */

/* Share button in hero section */
.fac-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.9rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-mocha, #5D4037);
  background: var(--color-cream, #EFEBE9);
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-sm, 6px);
  cursor: pointer;
  transition: all 0.2s ease;
}
.fac-share-btn:hover {
  background: var(--color-latte, #D7CCC8);
  border-color: var(--color-taupe, #BCAAA4);
}

/* Overlay */
.share-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* Modal card */
.share-modal {
  background: var(--color-white, #fff);
  border-radius: var(--radius-lg, 12px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
  width: 90vw;
  max-width: 480px;
  padding: 1.5rem;
  animation: share-slide-up 0.25s ease-out;
}
@keyframes share-slide-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.share-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
}
.share-modal-header h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-dark-walnut, #3E2723);
  margin: 0;
}
.share-modal-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-sandstone, #A1887F);
  padding: 0.25rem;
  border-radius: 4px;
  transition: color 0.15s;
}
.share-modal-close:hover {
  color: var(--color-dark-walnut, #3E2723);
}

/* Preview box */
.share-modal-preview {
  background: var(--color-ivory, #FAF7F5);
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-sm, 6px);
  padding: 1rem;
  margin-bottom: 1.25rem;
}
.share-preview-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-sandstone, #A1887F);
  margin-bottom: 0.5rem;
}
.share-preview-text {
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--color-dark-walnut, #3E2723);
  white-space: pre-wrap;
  word-break: break-all;
}

/* Action buttons row */
.share-modal-actions {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 1rem;
}
.share-action-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  padding: 0.9rem 0.5rem;
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-sm, 6px);
  background: var(--color-white, #fff);
  cursor: pointer;
  text-decoration: none;
  color: var(--color-mocha, #5D4037);
  font-size: 0.8rem;
  font-weight: 600;
  transition: all 0.2s ease;
}
.share-action-btn:hover {
  border-color: var(--color-taupe, #BCAAA4);
  background: var(--color-ivory, #FAF7F5);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* Email button accent */
.share-action-btn--email:hover {
  border-color: #90CAF9;
  background: #F5F9FF;
  color: #1565C0;
}
.share-action-btn--email:hover svg { stroke: #1565C0; }

/* Text/iMessage button accent */
.share-action-btn--text:hover {
  border-color: #A5D6A7;
  background: #F5FFF5;
  color: #2E7D32;
}
.share-action-btn--text:hover svg { stroke: #2E7D32; }

/* Copy button accent */
.share-action-btn--copy:hover {
  border-color: var(--color-taupe, #BCAAA4);
  background: var(--color-cream, #EFEBE9);
}

/* Warning footer */
.share-modal-warning {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  color: var(--color-sandstone, #A1887F);
  margin: 0;
  padding-top: 0.5rem;
  border-top: 1px solid var(--color-cream, #EFEBE9);
}

/* Wide variant for multi-facility share */
.share-modal--wide {
  max-width: 560px;
}
.share-modal-preview--scrollable {
  max-height: 45vh;
  overflow-y: auto;
}

/* ── Share Logins dropdown (facilities list) ── */
.share-type-wrapper {
  position: relative;
  display: inline-block;
}
.fac-action-btn--share {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.55rem 1rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-mocha, #5D4037);
  background: var(--color-cream, #EFEBE9);
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-sm, 6px);
  cursor: pointer;
  transition: all 0.2s ease;
}
.fac-action-btn--share:hover {
  background: var(--color-latte, #D7CCC8);
  border-color: var(--color-taupe, #BCAAA4);
}

.share-type-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 100;
  min-width: 200px;
  background: var(--color-white, #fff);
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: var(--radius-sm, 6px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  padding: 0.35rem 0;
}
.share-type-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.55rem 1rem;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-dark-walnut, #3E2723);
  background: none;
  border: none;
  cursor: pointer;
  transition: background 0.15s;
  text-align: left;
}
.share-type-option:hover {
  background: var(--color-ivory, #FAF7F5);
}
.share-type-option--all {
  font-weight: 700;
}
.share-type-count {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-sandstone, #A1887F);
  background: var(--color-cream, #EFEBE9);
  padding: 0.15rem 0.5rem;
  border-radius: 10px;
}
.share-type-divider {
  height: 1px;
  background: var(--color-cream, #EFEBE9);
  margin: 0.25rem 0;
}

@media (max-width: 480px) {
  .share-modal {
    width: 95vw;
    padding: 1.25rem;
  }
  .share-modal-actions {
    flex-direction: column;
    gap: 0.5rem;
  }
  .share-action-btn {
    flex-direction: row;
    justify-content: center;
  }
  .share-type-menu {
    right: 0;
    left: auto;
  }
}

/* ── Payroll ── */
.payroll-type-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.65rem;
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: var(--radius-sm, 6px);
  letter-spacing: 0.03em;
}
.payroll-type-badge--w2 {
  background: #FFF3E0;
  color: #E65100;
}
.payroll-type-badge--1099 {
  background: #E8F5E9;
  color: #2E7D32;
}
.payroll-type-badge--active {
  background: #E8F5E9;
  color: #2E7D32;
}
.payroll-type-badge--inactive {
  background: #F5F5F5;
  color: #9E9E9E;
}
.payroll-type-badge--filed {
  background: #E8F5E9;
  color: #2E7D32;
}
.payroll-type-badge--notfiled {
  background: #FFF3E0;
  color: #E65100;
}
.payroll-type-badge--requested {
  background: #E3F2FD;
  color: #1565C0;
}
.form-grid-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}
@media (max-width: 600px) {
  .form-grid-2col {
    grid-template-columns: 1fr;
  }
}


/* ── Shared Tab Bar Buttons ── */
.cap-tab-btn {
  padding: 0.75rem 1.25rem;
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  white-space: nowrap;
  border-bottom: 3px solid transparent;
  transition: all 0.2s;
  position: relative;
}
.cap-tab-btn:hover {
  opacity: 1 !important;
  color: var(--color-espresso);
  background: var(--color-cream);
}

/* ============================================================================
   GROUP HOME CENSUS MODULE — gc-* prefix
   ============================================================================ */

/* ── Sub-Navigation ───────────────────────────────────────────────────────── */

.gc-subnav {
  display: flex;
  gap: var(--space-xs);
  padding: var(--space-sm) 0;
  margin-bottom: var(--space-lg);
  border-bottom: 1px solid var(--color-latte);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.gc-subnav-link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-clay);
  text-decoration: none;
  border-radius: var(--radius-md);
  white-space: nowrap;
  transition: all var(--transition-fast);
}
.gc-subnav-link:hover {
  background: var(--color-cream);
  color: var(--color-mocha);
}
.gc-subnav-link--active {
  background: var(--color-mocha);
  color: var(--color-ivory);
}
.gc-subnav-link--active:hover {
  background: var(--color-coffee);
  color: var(--color-ivory);
}
.gc-subnav-link svg {
  flex-shrink: 0;
}

/* ── Metric Cards ─────────────────────────────────────────────────────────── */

.gc-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.gc-metric-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--transition-base);
}
.gc-metric-card:hover {
  box-shadow: var(--shadow-card-hover);
}
.gc-metric-number {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.1;
}
.gc-metric-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-clay);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-top: var(--space-xs);
}
.gc-metric-card--warning .gc-metric-number {
  color: var(--color-amber);
}

/* ── Weekly Briefing ──────────────────────────────────────────────────────── */

.gc-briefing {
  background: linear-gradient(135deg, var(--color-mocha), var(--color-coffee));
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  color: var(--color-ivory);
  margin-bottom: var(--space-xl);
  box-shadow: var(--shadow-lg);
}
.gc-briefing-title {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: var(--space-xs);
}
.gc-briefing-date {
  font-size: 0.75rem;
  opacity: 0.7;
  margin-bottom: var(--space-md);
}
.gc-briefing-stats {
  display: flex;
  gap: var(--space-xl);
  flex-wrap: wrap;
}
.gc-briefing-stat {
  text-align: center;
}
.gc-briefing-stat-num {
  font-size: 1.5rem;
  font-weight: 700;
}
.gc-briefing-stat-label {
  font-size: 0.6875rem;
  opacity: 0.8;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.gc-briefing-changes {
  margin-top: var(--space-md);
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.gc-briefing-change {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8125rem;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.15);
}
.gc-briefing-change--new { color: #b8e6b8; }
.gc-briefing-change--missing { color: #f5c2c2; }
.gc-briefing-change--transfer { color: #bdd4f0; }

/* ── Owner/Facility/Patient Accordion ─────────────────────────────────────── */

.gc-hierarchy {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.gc-owner-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.gc-owner-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  cursor: pointer;
  transition: background var(--transition-fast);
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-family: var(--font-primary);
}
.gc-owner-header:hover {
  background: var(--color-cream);
}

.gc-chevron {
  width: 16px;
  height: 16px;
  color: var(--color-clay);
  transition: transform var(--transition-base);
  flex-shrink: 0;
}
.gc-chevron--open {
  transform: rotate(90deg);
}

.gc-owner-name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-espresso);
  flex: 1;
}
.gc-owner-phone {
  font-size: 0.8125rem;
  color: var(--color-slate-blue);
  text-decoration: none;
}
.gc-owner-phone:hover {
  text-decoration: underline;
}
.gc-owner-stats {
  display: flex;
  gap: var(--space-md);
  font-size: 0.75rem;
  color: var(--color-clay);
}
.gc-owner-stat {
  white-space: nowrap;
}

.gc-owner-badge {
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.gc-owner-badge--growing { background: #e8f5e9; color: var(--color-forest); }
.gc-owner-badge--stable { background: var(--color-cream); color: var(--color-clay); }
.gc-owner-badge--shrinking { background: #fce4ec; color: #c62828; }

.gc-owner-body {
  padding: 0 var(--space-lg) var(--space-lg);
}

/* Facility rows inside owner */
.gc-facility-card {
  border: 1px solid var(--color-cream);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
  overflow: hidden;
}

.gc-facility-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  cursor: pointer;
  transition: background var(--transition-fast);
  border: none;
  background: var(--color-ivory);
  width: 100%;
  text-align: left;
  font-family: var(--font-primary);
}
.gc-facility-header:hover {
  background: var(--color-cream);
}

.gc-facility-address {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-espresso);
  flex: 1;
}
.gc-facility-count {
  font-size: 0.75rem;
  color: var(--color-clay);
  white-space: nowrap;
}
.gc-facility-count--warn {
  color: var(--color-terracotta);
  font-weight: 600;
}
.gc-facility-code {
  font-size: 0.6875rem;
  color: var(--color-sandstone);
  font-family: var(--font-mono);
}
.gc-facility-body {
  padding: var(--space-sm) var(--space-md) var(--space-md);
}

/* Patient table */
.gc-patient-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
}
.gc-patient-table th {
  text-align: left;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-clay);
  padding: var(--space-xs) var(--space-sm);
  border-bottom: 1px solid var(--color-latte);
}
.gc-patient-table td {
  padding: var(--space-xs) var(--space-sm);
  color: var(--color-espresso);
  border-bottom: 1px solid var(--color-cream);
}
.gc-patient-table tr:last-child td {
  border-bottom: none;
}

.gc-status-badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.gc-status-badge--active { background: #e8f5e9; color: var(--color-forest); }
.gc-status-badge--hospitalized { background: #fff8e1; color: #e65100; }
.gc-status-badge--discharged { background: var(--color-cream); color: var(--color-clay); }
.gc-status-badge--deceased { background: #fce4ec; color: #c62828; }
.gc-status-badge--transferred { background: #e3f2fd; color: #1565c0; }

/* ── Upload Zone ──────────────────────────────────────────────────────────── */

.gc-upload-zone {
  border: 2px dashed var(--color-taupe);
  border-radius: var(--radius-xl);
  padding: var(--space-3xl) var(--space-xl);
  text-align: center;
  cursor: pointer;
  transition: all var(--transition-base);
  background: var(--color-ivory);
  position: relative;
  margin-bottom: var(--space-xl);
}
.gc-upload-zone:hover,
.gc-upload-zone--active {
  border-color: var(--color-mocha);
  background: var(--color-cream);
}
.gc-upload-zone--active {
  border-color: var(--color-sage);
  background: #f1f8f1;
}
.gc-upload-icon {
  color: var(--color-sandstone);
  margin-bottom: var(--space-md);
}
.gc-upload-text {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-mocha);
  margin-bottom: var(--space-xs);
}
.gc-upload-hint {
  font-size: 0.8125rem;
  color: var(--color-clay);
}
.gc-upload-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

/* Upload progress */
.gc-upload-progress {
  margin: var(--space-md) 0;
  text-align: center;
}
.gc-progress-bar {
  width: 100%;
  height: 4px;
  background: var(--color-cream);
  border-radius: 2px;
  overflow: hidden;
  margin-top: var(--space-sm);
}
.gc-progress-fill {
  height: 100%;
  background: var(--color-mocha);
  border-radius: 2px;
  animation: gc-progress-pulse 1.5s ease infinite;
  width: 60%;
}
@keyframes gc-progress-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* Parsed review */
.gc-review {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.gc-review-summary {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-md);
}
.gc-review-warnings {
  background: #fff8e1;
  border: 1px solid #ffe082;
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-md);
  font-size: 0.8125rem;
  color: #e65100;
}

.gc-review-facility {
  border: 1px solid var(--color-cream);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
  overflow: hidden;
}
.gc-review-facility-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  background: var(--color-ivory);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-espresso);
}

.gc-review-actions {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

/* Upload history table */
.gc-upload-history {
  margin-top: var(--space-xl);
}
.gc-upload-history-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-md);
}

/* ── Buttons ──────────────────────────────────────────────────────────────── */

.gc-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.8125rem;
  font-weight: 600;
  font-family: var(--font-primary);
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
}
.gc-btn--primary {
  background: var(--color-mocha);
  color: var(--color-ivory);
}
.gc-btn--primary:hover {
  background: var(--color-coffee);
}
.gc-btn--secondary {
  background: var(--color-cream);
  color: var(--color-mocha);
}
.gc-btn--secondary:hover {
  background: var(--color-latte);
}
.gc-btn--danger {
  background: #fce4ec;
  color: #c62828;
}
.gc-btn--danger:hover {
  background: #f8bbd0;
}
.gc-btn--sm {
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.75rem;
}

/* ── Tables (generic) ─────────────────────────────────────────────────────── */

.gc-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.gc-table th {
  text-align: left;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-clay);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-ivory);
  border-bottom: 1px solid var(--color-latte);
}
.gc-table td {
  padding: var(--space-sm) var(--space-md);
  color: var(--color-espresso);
  border-bottom: 1px solid var(--color-cream);
}
.gc-table tr:last-child td {
  border-bottom: none;
}

/* ── Empty State ──────────────────────────────────────────────────────────── */

.gc-empty {
  text-align: center;
  padding: var(--space-3xl) var(--space-xl);
  color: var(--color-clay);
}
.gc-empty svg {
  margin-bottom: var(--space-md);
  color: var(--color-sandstone);
}
.gc-empty p {
  font-size: 0.9375rem;
  margin-bottom: var(--space-sm);
}
.gc-empty a {
  color: var(--color-mocha);
  font-weight: 600;
  text-decoration: none;
}
.gc-empty a:hover {
  text-decoration: underline;
}

/* ── Changes page ─────────────────────────────────────────────────────────── */

.gc-changes-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}
.gc-change-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  text-align: center;
}
.gc-change-card-num {
  font-size: 1.5rem;
  font-weight: 700;
}
.gc-change-card--new .gc-change-card-num { color: var(--color-forest); }
.gc-change-card--missing .gc-change-card-num { color: var(--color-terracotta); }
.gc-change-card--transfer .gc-change-card-num { color: var(--color-slate-blue); }
.gc-change-card-label {
  font-size: 0.6875rem;
  color: var(--color-clay);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-top: var(--space-xs);
}

/* ── Search ───────────────────────────────────────────────────────────────── */

.gc-search-box {
  position: relative;
  margin-bottom: var(--space-xl);
}
.gc-search-input {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  padding-left: 40px;
  font-size: 0.9375rem;
  font-family: var(--font-primary);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  background: var(--color-white);
  color: var(--color-espresso);
  transition: border-color var(--transition-fast);
}
.gc-search-input:focus {
  outline: none;
  border-color: var(--color-mocha);
}
.gc-search-icon {
  position: absolute;
  left: var(--space-md);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-sandstone);
}

/* ── Referrals ────────────────────────────────────────────────────────────── */

.gc-referral-status {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.gc-referral-status--pending { background: #fff8e1; color: #e65100; }
.gc-referral-status--accepted { background: #e8f5e9; color: var(--color-forest); }
.gc-referral-status--declined { background: #fce4ec; color: #c62828; }
.gc-referral-status--converted { background: #e3f2fd; color: #1565c0; }

/* ── Facility Detail ──────────────────────────────────────────────────────── */

.gc-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}
.gc-detail-address {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-espresso);
}
.gc-detail-meta {
  display: flex;
  gap: var(--space-lg);
  flex-wrap: wrap;
  font-size: 0.8125rem;
  color: var(--color-clay);
  margin-top: var(--space-xs);
}
.gc-detail-section {
  margin-bottom: var(--space-xl);
}
.gc-detail-section-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-mocha);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-cream);
}

/* ── Analytics Charts ─────────────────────────────────────────────────────── */

.gc-charts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.gc-chart-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
}
.gc-chart-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-md);
}

/* ── Form elements ────────────────────────────────────────────────────────── */

.gc-input {
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.8125rem;
  font-family: var(--font-primary);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  color: var(--color-espresso);
  background: var(--color-white);
}
.gc-input:focus {
  outline: none;
  border-color: var(--color-mocha);
}
.gc-select {
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.8125rem;
  font-family: var(--font-primary);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  color: var(--color-espresso);
  background: var(--color-white);
}

/* ── Responsive ───────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .gc-subnav { gap: 2px; }
  .gc-subnav-link { padding: var(--space-xs) var(--space-sm); font-size: 0.75rem; }
  .gc-subnav-link svg { display: none; }
  .gc-metrics { grid-template-columns: repeat(2, 1fr); }
  .gc-briefing-stats { gap: var(--space-md); }
  .gc-owner-header { flex-wrap: wrap; }
  .gc-charts-grid { grid-template-columns: 1fr; }
}


/* ═══════════════════════════════════════════════════════════════════════════ */
/*  NURSING HOME CENSUS MODULE  (nh-*)                                       */
/*  Parallel to gc-* classes — organized by Nurse Practitioner               */
/* ═══════════════════════════════════════════════════════════════════════════ */

/* ── NP color variables ─────────────────────────────────────── */
:root {
  --nh-np-arvin: #4a6fa5;
  --nh-np-wendell: #6b8e6b;
  --nh-np-laurence: #c4883a;
}

/* ── Sub-navigation ─────────────────────────────────────────── */

.nh-subnav {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: var(--space-sm) 0;
  margin-bottom: var(--space-lg);
  border-bottom: 1px solid var(--color-latte);
  overflow-x: auto;
}

.nh-subnav-link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-xs) var(--space-md);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-cocoa);
  text-decoration: none;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.nh-subnav-link:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}
.nh-subnav-link--active {
  background: var(--color-espresso);
  color: #fff;
}
.nh-subnav-link--active:hover {
  background: var(--color-espresso);
  color: #fff;
}
.nh-subnav-link svg {
  flex-shrink: 0;
  opacity: 0.7;
}

/* ── Metric cards ───────────────────────────────────────────── */

.nh-metrics {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.nh-metric-card {
  background: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  text-align: center;
  border: 1px solid var(--color-latte);
  box-shadow: 0 1px 3px rgba(44,24,16,0.04);
}
.nh-metric-card--sm {
  padding: var(--space-sm) var(--space-md);
}
.nh-metric-number {
  display: block;
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.2;
}
.nh-metric-card--sm .nh-metric-number {
  font-size: 1.25rem;
}
.nh-metric-label {
  display: block;
  font-size: 0.75rem;
  color: var(--color-cocoa);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.nh-metric-card--amber {
  border-left: 3px solid #f59e0b;
}
.nh-metric-card--purple {
  border-left: 3px solid #7b1fa2;
}
.nh-metric-card--blue {
  border-left: 3px solid #1565c0;
}

/* ── NP summary cards ───────────────────────────────────────── */

.nh-np-cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}

.nh-np-card {
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-latte);
  box-shadow: 0 1px 3px rgba(44,24,16,0.04);
  overflow: hidden;
}
.nh-np-card--arvin  { border-left: 4px solid var(--nh-np-arvin); }
.nh-np-card--wendell { border-left: 4px solid var(--nh-np-wendell); }
.nh-np-card--laurence { border-left: 4px solid var(--nh-np-laurence); }

.nh-np-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  cursor: pointer;
  transition: background 0.15s;
}
.nh-np-card-header:hover {
  background: var(--color-cream);
}

.nh-np-card-info {
  flex: 1;
  min-width: 0;
}
.nh-np-card-name {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin: 0;
}
.nh-np-card-meta {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
}
.nh-np-card-meta--empty {
  font-style: italic;
  color: var(--color-sandstone);
}

.nh-np-card-stats {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.nh-np-card-chevron {
  transition: transform 0.2s;
  color: var(--color-cocoa);
  flex-shrink: 0;
}
.nh-np-card-chevron--open {
  transform: rotate(180deg);
}

.nh-np-card-footer {
  padding: var(--space-sm) var(--space-lg);
  border-top: 1px solid var(--color-cream);
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

.nh-np-facilities {
  border-top: 1px solid var(--color-latte);
}

/* ── Status badges ──────────────────────────────────────────── */

.nh-status-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
}
.nh-status-badge--sm {
  padding: 1px 6px;
  font-size: 0.625rem;
}
.nh-status-badge--active {
  background: #e8f5e9;
  color: #2e7d32;
}
.nh-status-badge--hospice {
  background: #f3e5f5;
  color: #7b1fa2;
}
.nh-status-badge--hospitalized {
  background: #fff8e1;
  color: #f57f17;
}
.nh-status-badge--new {
  background: #e3f2fd;
  color: #1565c0;
}
.nh-status-badge--discharged,
.nh-status-badge--deceased {
  background: var(--color-cream);
  color: var(--color-sandstone);
}
.nh-status-badge--transferred {
  background: #e0f2f1;
  color: #00695c;
}
.nh-status-badge--pending {
  background: #fff3e0;
  color: #e65100;
}
.nh-status-badge--data_error {
  background: #fce4ec;
  color: #c62828;
}

/* ── NP color tags ──────────────────────────────────────────── */

.nh-np-tag {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 10px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #fff;
}
.nh-np-tag--arvin { background: var(--nh-np-arvin); }
.nh-np-tag--wendell { background: var(--nh-np-wendell); }
.nh-np-tag--laurence { background: var(--nh-np-laurence); }

/* ── Facility accordion rows ────────────────────────────────── */

.nh-facility-row {
  border-bottom: 1px solid var(--color-cream);
}
.nh-facility-row:last-child {
  border-bottom: none;
}

.nh-facility-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: var(--space-sm) var(--space-lg);
  cursor: pointer;
  transition: background 0.15s;
  font-size: 0.8125rem;
}
.nh-facility-header:hover {
  background: rgba(0,0,0,0.02);
}

.nh-facility-chevron {
  transition: transform 0.2s;
  color: var(--color-sandstone);
  flex-shrink: 0;
}
.nh-facility-chevron--open {
  transform: rotate(180deg);
}

.nh-facility-name {
  font-weight: 600;
  color: var(--color-espresso);
  text-decoration: none;
}
.nh-facility-name:hover {
  text-decoration: underline;
}
.nh-facility-count {
  color: var(--color-cocoa);
  font-size: 0.75rem;
}
.nh-facility-email {
  color: var(--color-sandstone);
  font-size: 0.6875rem;
  margin-left: auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 200px;
}

/* ── Tables ─────────────────────────────────────────────────── */

.nh-table-wrap {
  overflow-x: auto;
  padding: var(--space-md);
}
.nh-table-wrap h3 {
  margin: 0 0 var(--space-md);
  font-size: 0.9375rem;
  color: var(--color-espresso);
}

.nh-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
}
.nh-table th {
  text-align: left;
  padding: var(--space-xs) var(--space-sm);
  font-weight: 600;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
  border-bottom: 2px solid var(--color-latte);
}
.nh-table td {
  padding: var(--space-xs) var(--space-sm);
  border-bottom: 1px solid var(--color-cream);
  color: var(--color-espresso);
}
.nh-table tbody tr:hover {
  background: rgba(0,0,0,0.015);
}

.nh-patient-name {
  font-weight: 500;
}
.nh-td-date {
  font-size: 0.75rem;
  color: var(--color-cocoa);
  white-space: nowrap;
}
.nh-td-notes {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nh-patient-table-wrap {
  padding: 0 var(--space-lg) var(--space-md);
}

/* ── Buttons ────────────────────────────────────────────────── */

.nh-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-sm) var(--space-lg);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s;
  font-family: var(--font-primary);
}
.nh-btn--primary {
  background: var(--color-espresso);
  color: #fff;
  border-color: var(--color-espresso);
}
.nh-btn--primary:hover {
  background: var(--color-cocoa);
}
.nh-btn--secondary {
  background: #fff;
  color: var(--color-espresso);
  border-color: var(--color-latte);
}
.nh-btn--secondary:hover {
  background: var(--color-cream);
}
.nh-btn--sm {
  padding: 4px 12px;
  font-size: 0.75rem;
}
.nh-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.nh-export-btns {
  display: flex;
  gap: 8px;
  margin-left: auto;
}

/* ── Upload zone ────────────────────────────────────────────── */

.nh-upload-zone {
  border: 2px dashed var(--color-latte);
  border-radius: var(--radius-md);
  padding: var(--space-3xl) var(--space-xl);
  text-align: center;
  transition: border-color 0.2s, background 0.2s;
  cursor: pointer;
  position: relative;
  margin-bottom: var(--space-xl);
}
.nh-upload-zone:hover,
.nh-upload-zone--active {
  border-color: var(--color-sage);
  background: rgba(107,142,107,0.04);
}
.nh-upload-zone-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}
.nh-upload-icon {
  color: var(--color-sandstone);
}
.nh-upload-text {
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-espresso);
}
.nh-upload-hint {
  font-size: 0.8125rem;
  color: var(--color-sandstone);
}
.nh-upload-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

/* NP selector */
.nh-np-selector {
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.nh-np-selector-title {
  margin: 0 0 var(--space-md);
  font-size: 0.9375rem;
  color: var(--color-espresso);
}
.nh-np-selector-options {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.nh-np-radio {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--space-md) var(--space-lg);
  border: 2px solid var(--color-latte);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  min-width: 160px;
}
.nh-np-radio:hover {
  border-color: var(--color-cocoa);
}
.nh-np-radio--selected {
  border-color: var(--color-espresso);
  background: var(--color-cream);
}
.nh-np-radio-input {
  display: none;
}
.nh-np-radio-label {
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-espresso);
}
.nh-np-radio-label--arvin { color: var(--nh-np-arvin); }
.nh-np-radio-label--wendell { color: var(--nh-np-wendell); }
.nh-np-radio-label--laurence { color: var(--nh-np-laurence); }
.nh-np-radio-meta {
  font-size: 0.75rem;
  color: var(--color-sandstone);
}

/* Upload progress / error / success */
.nh-upload-progress,
.nh-upload-error,
.nh-upload-success {
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.nh-progress-content,
.nh-error-content,
.nh-success-content {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.nh-progress-title,
.nh-success-title {
  font-weight: 600;
  color: var(--color-espresso);
  margin: 0;
}
.nh-progress-hint,
.nh-success-detail {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  margin: 0;
}
.nh-upload-error {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-left: 3px solid #c62828;
}
.nh-error-content {
  color: #c62828;
}
.nh-error-dismiss {
  background: none;
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  color: var(--color-sandstone);
}
.nh-upload-success {
  border-left: 3px solid #2e7d32;
}
.nh-success-actions {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

.nh-spinner {
  animation: nh-spin 1s linear infinite;
}
@keyframes nh-spin {
  to { transform: rotate(360deg); }
}

/* ── Review section ─────────────────────────────────────────── */

.nh-review {
  margin-bottom: var(--space-xl);
}
.nh-review-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}
.nh-review-header h2 {
  margin: 0;
  font-size: 1.125rem;
}
.nh-review-summary {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
}
.nh-review-warnings {
  margin-bottom: var(--space-md);
}
.nh-review-warning {
  padding: var(--space-xs) var(--space-sm);
  background: #fff3e0;
  border-left: 3px solid #f57f17;
  border-radius: var(--radius-sm);
  font-size: 0.8125rem;
  color: #e65100;
  margin-bottom: 4px;
}
.nh-review-facility {
  margin-bottom: var(--space-md);
  padding: var(--space-md);
}
.nh-review-facility-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
  font-size: 0.875rem;
}
.nh-review-facility-count {
  color: var(--color-cocoa);
  font-size: 0.8125rem;
}
.nh-review-facility-email {
  color: var(--color-sandstone);
  font-size: 0.75rem;
  margin-left: auto;
}
.nh-review-actions {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

/* ── Upload history ─────────────────────────────────────────── */

.nh-uploads-history {
  padding: var(--space-lg);
}
.nh-uploads-history h3 {
  margin: 0 0 var(--space-md);
  font-size: 0.9375rem;
}

/* ── Changes page ───────────────────────────────────────────── */

.nh-filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}
.nh-filter-label {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  font-weight: 500;
}
.nh-filter-chip {
  padding: 4px 14px;
  border-radius: 16px;
  font-size: 0.75rem;
  font-weight: 500;
  text-decoration: none;
  border: 1px solid var(--color-latte);
  color: var(--color-cocoa);
  transition: background 0.15s, border-color 0.15s;
}
.nh-filter-chip:hover {
  background: var(--color-cream);
}
.nh-filter-chip--active {
  background: var(--color-espresso);
  color: #fff;
  border-color: var(--color-espresso);
}

.nh-change-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}
.nh-change-card {
  background: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  text-align: center;
  border: 1px solid var(--color-latte);
  box-shadow: 0 1px 3px rgba(44,24,16,0.04);
}
.nh-change-card--new { border-left: 3px solid #2e7d32; }
.nh-change-card--missing { border-left: 3px solid #c62828; }
.nh-change-card--transfer { border-left: 3px solid #1565c0; }
.nh-change-card--status { border-left: 3px solid #f57f17; }

.nh-change-card-number {
  display: block;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-espresso);
}
.nh-change-card-label {
  display: block;
  font-size: 0.75rem;
  color: var(--color-cocoa);
  margin-top: 4px;
}

.nh-change-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
}
.nh-change-badge--new { background: #e8f5e9; color: #2e7d32; }
.nh-change-badge--missing { background: #fce4ec; color: #c62828; }
.nh-change-badge--transfer { background: #e3f2fd; color: #1565c0; }
.nh-change-badge--other { background: var(--color-cream); color: var(--color-cocoa); }

.nh-classify-btns {
  display: flex;
  gap: 4px;
}

/* ── Briefing / recent changes ──────────────────────────────── */

.nh-briefing {
  padding: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.nh-briefing-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
}
.nh-briefing-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
}
.nh-briefing-change-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.nh-briefing-change {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.8125rem;
}
.nh-change-name {
  font-weight: 500;
  color: var(--color-espresso);
}
.nh-change-detail {
  color: var(--color-sandstone);
  font-size: 0.75rem;
  margin-left: auto;
}

/* ── Empty state ────────────────────────────────────────────── */

.nh-empty-state {
  padding: var(--space-xl);
  text-align: center;
  color: var(--color-sandstone);
}
.nh-empty-state p {
  margin: 0 0 var(--space-md);
}

/* ── Facility detail ────────────────────────────────────────── */

.nh-facility-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.nh-facility-detail-info h2 {
  margin: 0 0 var(--space-xs);
  font-size: 1.25rem;
}
.nh-facility-detail-email {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  margin: 4px 0;
}
.nh-facility-detail-np {
  font-size: 0.8125rem;
  color: var(--color-cocoa);
  margin: 4px 0;
}
.nh-facility-detail-stats {
  display: flex;
  gap: var(--space-sm);
}

.nh-siblings {
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.nh-siblings h3 {
  margin: 0 0 var(--space-md);
  font-size: 0.9375rem;
}
.nh-siblings-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
.nh-sibling-link {
  padding: 6px 14px;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-sm);
  font-size: 0.8125rem;
  color: var(--color-espresso);
  text-decoration: none;
  transition: background 0.15s;
}
.nh-sibling-link:hover {
  background: var(--color-cream);
}
.nh-sibling-count {
  color: var(--color-sandstone);
  font-size: 0.75rem;
}

/* ── Search ─────────────────────────────────────────────────── */

.nh-search-wrap {
  padding: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.nh-search-input-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-latte);
}
.nh-search-input-wrap svg {
  color: var(--color-sandstone);
  flex-shrink: 0;
}
.nh-search-input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 1rem;
  font-family: var(--font-primary);
  color: var(--color-espresso);
  background: transparent;
}
.nh-search-input::placeholder {
  color: var(--color-sandstone);
}
.nh-search-count {
  font-size: 0.75rem;
  color: var(--color-sandstone);
  white-space: nowrap;
}
.nh-search-empty,
.nh-search-prompt {
  text-align: center;
  padding: var(--space-xl);
  color: var(--color-sandstone);
  font-size: 0.875rem;
}

/* ── Analytics ──────────────────────────────────────────────── */

.nh-analytics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}
.nh-analytics-card {
  padding: var(--space-lg);
}
.nh-analytics-card h3 {
  margin: 0 0 var(--space-md);
  font-size: 0.9375rem;
  color: var(--color-espresso);
}
.nh-analytics-card--wide {
  grid-column: 1 / -1;
}

.nh-analytics-np-bars {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.nh-analytics-bar-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.nh-analytics-bar-label {
  width: 80px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-espresso);
}
.nh-analytics-bar-track {
  flex: 1;
  height: 24px;
  background: var(--color-cream);
  border-radius: 4px;
  overflow: hidden;
}
.nh-analytics-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.5s ease;
  min-width: 2px;
}
.nh-analytics-bar-fill--arvin { background: var(--nh-np-arvin); }
.nh-analytics-bar-fill--wendell { background: var(--nh-np-wendell); }
.nh-analytics-bar-fill--laurence { background: var(--nh-np-laurence); }

.nh-analytics-bar-value {
  width: 40px;
  text-align: right;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-espresso);
}

.nh-analytics-status-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
}
.nh-analytics-status-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-xs) 0;
}
.nh-analytics-status-count {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-espresso);
}

/* ── Responsive (NH) ────────────────────────────────────────── */

@media (max-width: 1000px) {
  .nh-metrics { grid-template-columns: repeat(3, 1fr); }
  .nh-change-cards { grid-template-columns: repeat(2, 1fr); }
  .nh-analytics-grid { grid-template-columns: 1fr 1fr; }
  .nh-facility-detail-header { flex-direction: column; }
}

@media (max-width: 768px) {
  .nh-metrics { grid-template-columns: repeat(2, 1fr); }
  .nh-change-cards { grid-template-columns: 1fr 1fr; }
  .nh-analytics-grid { grid-template-columns: 1fr; }
  .nh-np-selector-options { flex-direction: column; }
  .nh-subnav { gap: 2px; }
  .nh-subnav-link { padding: var(--space-xs) var(--space-sm); font-size: 0.75rem; }
  .nh-subnav-link svg { display: none; }
  .nh-facility-email { display: none; }
}


/* ═══════════════════════════════════════════════════════════════════════════ */
/*  CARE MANAGEMENT BILLING TRACKER  (cm-*)                                  */
/*  CCM / RPM / TCM / PCM enrollment and billing tracking                    */
/* ═══════════════════════════════════════════════════════════════════════════ */

/* ── Module Variables ── */
:root {
  --cm-ccm: #4a6fa5;
  --cm-rpm: #6b8e6b;
  --cm-tcm: #c4883a;
  --cm-pcm: #8b6ba5;
  --cm-revenue: #2e7d32;
  --cm-alert: #d32f2f;
  --cm-awv: #5a8a5a;
  --cm-dementia: #7a6a8a;
  --cm-acp: #6a7a8a;
  --cm-bhi: #8a6a6a;
  --cm-hcc: #6a8a7a;
  --cm-optimizer: #4a7a6a;
}

/* ── Sub-Navigation ── */
.cm-subnav {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-latte);
  flex-wrap: wrap;
}
.cm-subnav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-cocoa);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: background var(--transition-base), color var(--transition-base);
}
.cm-subnav-link:hover {
  background: var(--color-cream);
  color: var(--color-espresso);
}
.cm-subnav-link--active {
  background: var(--color-espresso);
  color: var(--color-white);
}
.cm-subnav-link--active:hover {
  background: var(--color-dark-walnut);
  color: var(--color-white);
}
.cm-subnav-link svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ── Metric Cards ── */
.cm-metrics {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}
.cm-metric-card {
  background: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  text-align: center;
  border: 1px solid var(--color-latte);
  box-shadow: 0 1px 3px rgba(44,24,16,0.04);
}
.cm-metric-number {
  display: block;
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.2;
}
.cm-metric-label {
  display: block;
  font-size: 0.75rem;
  color: var(--color-cocoa);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.cm-metric-card--ccm { border-left: 3px solid var(--cm-ccm); }
.cm-metric-card--rpm { border-left: 3px solid var(--cm-rpm); }
.cm-metric-card--tcm { border-left: 3px solid var(--cm-tcm); }
.cm-metric-card--pcm { border-left: 3px solid var(--cm-pcm); }
.cm-metric-card--revenue { border-left: 3px solid var(--cm-revenue); }
.cm-metric-card--alert { border-left: 3px solid var(--cm-alert); }

/* ── Program Cards ── */
.cm-program-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}
.cm-program-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  border: 1px solid var(--color-latte);
  box-shadow: var(--shadow-card);
  border-top: 3px solid var(--color-sandstone);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.cm-program-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.cm-program-card h3 {
  font-size: 0.95rem;
  margin: 0 0 var(--space-sm) 0;
  color: var(--color-espresso);
}
.cm-program-card-count {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin-bottom: var(--space-sm);
}
.cm-program-card-desc {
  font-size: 0.8rem;
  color: var(--color-cocoa);
  line-height: 1.4;
  margin-bottom: var(--space-md);
}
.cm-program-card--ccm { border-top-color: var(--cm-ccm); }
.cm-program-card--rpm { border-top-color: var(--cm-rpm); }
.cm-program-card--tcm { border-top-color: var(--cm-tcm); }
.cm-program-card--pcm { border-top-color: var(--cm-pcm); }

/* ── Dashboard Grid (2-column) ── */
.cm-dashboard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-xl);
}

/* ── Activity Feed ── */
.cm-activity-feed {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.cm-activity-item {
  display: flex;
  gap: var(--space-sm);
  align-items: flex-start;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  background: var(--color-cream);
}
.cm-activity-icon {
  flex-shrink: 0;
  width: 36px;
  height: 24px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  font-weight: 800;
  color: #fff;
  background: var(--color-sandstone);
}
.cm-activity-icon--ccm { background: var(--cm-ccm); }
.cm-activity-icon--rpm { background: var(--cm-rpm); }
.cm-activity-icon--tcm { background: var(--cm-tcm); }
.cm-activity-icon--pcm { background: var(--cm-pcm); }
.cm-activity-text {
  font-size: 0.82rem;
  color: var(--color-espresso);
  line-height: 1.4;
}
.cm-activity-meta {
  display: block;
  font-size: 0.72rem;
  color: var(--color-cocoa);
  margin-top: 2px;
}
.cm-empty-text {
  font-size: 0.85rem;
  color: var(--color-sandstone);
  text-align: center;
  padding: var(--space-lg) 0;
}

/* ── Deadline Badges ── */
.cm-deadline-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.68rem;
  font-weight: 700;
}
.cm-deadline-badge--ontrack { background: #e8f5e9; color: #2e7d32; }
.cm-deadline-badge--approaching { background: #fff8e1; color: #f57f17; }
.cm-deadline-badge--overdue { background: #ffebee; color: #c62828; }
.cm-deadline-badge--completed { background: #e8f5e9; color: #2e7d32; }

/* ── Quick Enroll Widget ── */
.cm-quick-enroll h3 { margin-top: 0; }
.cm-quick-enroll-row {
  display: flex;
  gap: var(--space-sm);
  align-items: flex-start;
}
.cm-quick-enroll-search {
  flex: 1;
  position: relative;
}
.cm-search-results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 20;
  background: #fff;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  max-height: 250px;
  overflow-y: auto;
}
.cm-search-result-item {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
  padding: var(--space-sm) var(--space-md);
  cursor: pointer;
  font-size: 0.82rem;
  border-bottom: 1px solid var(--color-cream);
}
.cm-search-result-item:hover { background: var(--color-cream); }
.cm-search-result-name { font-weight: 600; color: var(--color-espresso); }
.cm-search-result-fac { color: var(--color-cocoa); font-size: 0.75rem; }
.cm-search-result-source {
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  background: var(--color-cream);
  color: var(--color-cocoa);
}
.cm-search-result-programs {
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  background: #e3f2fd;
  color: #1565c0;
  margin-left: auto;
}
.cm-quick-enroll-selected {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-cream);
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 600;
}
.cm-quick-enroll-error {
  margin-top: var(--space-sm);
  padding: var(--space-sm);
  background: #ffebee;
  color: #c62828;
  border-radius: var(--radius-md);
  font-size: 0.82rem;
}
.cm-quick-enroll-success {
  margin-top: var(--space-sm);
  padding: var(--space-sm);
  background: #e8f5e9;
  color: #2e7d32;
  border-radius: var(--radius-md);
  font-size: 0.82rem;
}

/* ── Buttons ── */
.cm-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.82rem;
  font-weight: 600;
  font-family: inherit;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-espresso);
  cursor: pointer;
  transition: background var(--transition-base), border-color var(--transition-base);
  text-decoration: none;
}
.cm-btn:hover { background: var(--color-cream); border-color: var(--color-sandstone); }
.cm-btn--primary {
  background: var(--color-espresso);
  color: #fff;
  border-color: var(--color-espresso);
}
.cm-btn--primary:hover { background: var(--color-dark-walnut); }
.cm-btn--danger { color: var(--cm-alert); border-color: var(--cm-alert); }
.cm-btn--danger:hover { background: #ffebee; }
.cm-btn--sm { padding: 4px 10px; font-size: 0.75rem; }
.cm-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Forms ── */
.cm-form-input, .cm-form-select {
  padding: var(--space-sm) var(--space-md);
  font-size: 0.85rem;
  font-family: inherit;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-espresso);
}
.cm-form-input:focus, .cm-form-select:focus {
  outline: none;
  border-color: var(--color-sandstone);
  box-shadow: 0 0 0 2px rgba(161,136,127,0.15);
}
.cm-form-label {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-cocoa);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.cm-form-group { margin-bottom: var(--space-sm); }
.cm-form-row {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
}
.cm-form-row .cm-form-group { flex: 1; min-width: 120px; }

/* ── Tables ── */
.cm-table-wrap { overflow-x: auto; }
.cm-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.cm-table th {
  text-align: left;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-cocoa);
  border-bottom: 2px solid var(--color-latte);
}
.cm-table td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--color-cream);
  color: var(--color-espresso);
  vertical-align: middle;
}
.cm-table tbody tr:hover { background: var(--color-ivory); }
.cm-table-row--expandable { cursor: pointer; }
.cm-td-date { white-space: nowrap; font-size: 0.78rem; color: var(--color-cocoa); }
.cm-td-fac { font-size: 0.78rem; color: var(--color-cocoa); max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cm-td-actions { white-space: nowrap; }

/* ── Expand Panel ── */
.cm-expand-panel {
  background: var(--color-ivory);
  padding: var(--space-md) !important;
}
.cm-time-panel { margin-bottom: var(--space-md); }
.cm-time-summary {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-sm);
}
.cm-add-time-form {
  background: #fff;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: var(--space-md);
}
.cm-add-time-form h4 {
  margin: 0 0 var(--space-sm) 0;
  font-size: 0.82rem;
  color: var(--color-espresso);
}

/* ── Progress Bar (CCM/PCM) ── */
.cm-progress-bar {
  height: 8px;
  background: var(--color-cream);
  border-radius: 4px;
  overflow: hidden;
  min-width: 80px;
}
.cm-progress-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.3s ease;
}
.cm-progress--red { background: #ef5350; }
.cm-progress--green { background: #66bb6a; }
.cm-progress--blue { background: var(--cm-ccm); }
.cm-progress--purple { background: var(--cm-pcm); }

/* ── CPT Badges ── */
.cm-cpt-badge {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 0.68rem;
  font-weight: 700;
  background: #e3f2fd;
  color: #1565c0;
  margin-right: 3px;
}
.cm-cpt-badge--none { background: var(--color-cream); color: var(--color-sandstone); }

/* ── Count Badge ── */
.cm-count-badge {
  display: inline-block;
  padding: 1px 8px;
  border-radius: 10px;
  font-size: 0.72rem;
  font-weight: 700;
  background: var(--color-cream);
  color: var(--color-cocoa);
  margin-left: var(--space-xs);
}

/* ── Status Badges ── */
.cm-status-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.68rem;
  font-weight: 700;
}
.cm-status-badge--active { background: #e8f5e9; color: #2e7d32; }
.cm-status-badge--paused { background: #fff8e1; color: #f57f17; }
.cm-status-badge--completed { background: #e3f2fd; color: #1565c0; }
.cm-status-badge--discharged { background: var(--color-cream); color: var(--color-cocoa); }
.cm-status-badge--billed { background: #e8f5e9; color: #2e7d32; }

/* ── Program Badges ── */
.cm-program-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.68rem;
  font-weight: 800;
  color: #fff;
  background: var(--color-sandstone);
}
.cm-program-badge--ccm { background: var(--cm-ccm); }
.cm-program-badge--rpm { background: var(--cm-rpm); }
.cm-program-badge--tcm { background: var(--cm-tcm); }
.cm-program-badge--pcm { background: var(--cm-pcm); }
.cm-program-badge--bhi { background: var(--cm-bhi); }
.cm-program-badge--awv { background: var(--cm-awv); }
.cm-program-badge--dementia { background: var(--cm-dementia); }
.cm-program-badge--acp { background: var(--cm-acp); }
.cm-program-badge--hcc { background: var(--cm-hcc); }

/* ── Billing Status ── */
.cm-billing-status {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.68rem;
  font-weight: 700;
}
.cm-billing-status--pending { background: #fff8e1; color: #f57f17; }
.cm-billing-status--submitted { background: #e3f2fd; color: #1565c0; }
.cm-billing-status--paid { background: #e8f5e9; color: #2e7d32; }
.cm-billing-status--denied { background: #ffebee; color: #c62828; }

/* ── Month Navigator ── */
.cm-month-nav {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}
.cm-month-nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  background: #fff;
  border: 1px solid var(--color-latte);
  color: var(--color-espresso);
  text-decoration: none;
  font-weight: 700;
  transition: background var(--transition-base);
}
.cm-month-nav-btn:hover { background: var(--color-cream); }
.cm-month-nav-label {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-espresso);
}

/* ── TCM Timeline ── */
.cm-tcm-episodes {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.cm-tcm-card {
  background: #fff;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  border-left: 4px solid var(--color-sandstone);
}
.cm-tcm-card--ontrack { border-left-color: #66bb6a; }
.cm-tcm-card--approaching { border-left-color: #ffa726; }
.cm-tcm-card--overdue { border-left-color: #ef5350; }
.cm-tcm-card--completed { border-left-color: #66bb6a; }
.cm-tcm-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-md);
}
.cm-tcm-card-fac {
  display: block;
  font-size: 0.78rem;
  color: var(--color-cocoa);
}
.cm-tcm-complexity {
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.68rem;
  font-weight: 800;
  color: #fff;
}
.cm-tcm-complexity--moderate { background: var(--cm-tcm); }
.cm-tcm-complexity--high { background: var(--cm-alert); }

.cm-tcm-timeline {
  display: flex;
  align-items: flex-start;
  gap: 0;
  margin-bottom: var(--space-md);
  overflow-x: auto;
}
.cm-tcm-timeline-node {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 100px;
  text-align: center;
}
.cm-tcm-timeline-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid var(--color-sandstone);
  background: #fff;
  margin-bottom: 6px;
}
.cm-tcm-timeline-node--completed .cm-tcm-timeline-dot { background: #66bb6a; border-color: #66bb6a; }
.cm-tcm-timeline-node--approaching .cm-tcm-timeline-dot { background: #ffa726; border-color: #ffa726; }
.cm-tcm-timeline-node--overdue .cm-tcm-timeline-dot { background: #ef5350; border-color: #ef5350; }
.cm-tcm-timeline-node--pending .cm-tcm-timeline-dot { background: var(--color-cream); }
.cm-tcm-timeline-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-cocoa);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.cm-tcm-timeline-date { font-size: 0.75rem; color: var(--color-espresso); margin-top: 2px; }
.cm-tcm-timeline-detail { font-size: 0.68rem; color: var(--color-cocoa); margin-top: 2px; }
.cm-tcm-timeline-line {
  flex: 1;
  height: 2px;
  background: var(--color-latte);
  margin-top: 8px;
  min-width: 20px;
}
.cm-tcm-card-actions {
  display: flex;
  gap: var(--space-sm);
}
.cm-tcm-update-form {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-cream);
}

/* ── RPM Grid ── */
.cm-rpm-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-lg);
}
.cm-rpm-card { padding: var(--space-lg); }
.cm-rpm-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-md);
}
.cm-rpm-card-fac { display: block; font-size: 0.78rem; color: var(--color-cocoa); }
.cm-rpm-device-type {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 3px;
  background: var(--color-cream);
  color: var(--color-cocoa);
}

/* RPM Counter */
.cm-rpm-counter { margin-bottom: var(--space-md); }
.cm-rpm-counter-bar {
  height: 10px;
  background: var(--color-cream);
  border-radius: 5px;
  overflow: hidden;
  margin-bottom: 4px;
}
.cm-rpm-counter-fill {
  height: 100%;
  border-radius: 5px;
  transition: width 0.3s ease;
}
.cm-rpm-counter-fill--met { background: #66bb6a; }
.cm-rpm-counter-fill--approaching { background: #ffa726; }
.cm-rpm-counter-fill--low { background: #ef5350; }
.cm-rpm-counter-text { font-size: 0.78rem; color: var(--color-cocoa); }
.cm-rpm-threshold-met { color: #2e7d32; font-weight: 700; margin-left: var(--space-xs); }

/* RPM Calendar Heatmap */
.cm-rpm-calendar { margin-bottom: var(--space-md); }
.cm-rpm-calendar-header {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-cocoa);
  margin-bottom: var(--space-sm);
}
.cm-rpm-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
}
.cm-rpm-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 600;
  border-radius: 3px;
  color: var(--color-cocoa);
}
.cm-rpm-day--received { background: #c8e6c9; color: #2e7d32; }
.cm-rpm-day--empty { background: var(--color-cream); color: var(--color-sandstone); }
.cm-rpm-day--missed { background: #ffcdd2; color: #c62828; }
.cm-rpm-calendar-legend {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-sm);
  font-size: 0.68rem;
  color: var(--color-cocoa);
}
.cm-rpm-legend-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  margin-right: 4px;
  vertical-align: middle;
}
.cm-rpm-card-footer {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  align-items: center;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-cream);
}
.cm-rpm-card-meta { font-size: 0.72rem; color: var(--color-sandstone); }

/* ── Compliance / Violations ── */
.cm-violations {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.cm-violation-card {
  border-left: 4px solid var(--color-sandstone);
}
.cm-violation-card--critical { border-left-color: var(--cm-alert); }
.cm-violation-card--warning { border-left-color: var(--cm-tcm); }
.cm-violation-card--info { border-left-color: var(--cm-ccm); }
.cm-violation-header {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
  margin-bottom: var(--space-sm);
}
.cm-violation-severity {
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.65rem;
  font-weight: 800;
  color: #fff;
}
.cm-violation-severity--critical { background: var(--cm-alert); }
.cm-violation-severity--warning { background: var(--cm-tcm); }
.cm-violation-severity--info { background: var(--cm-ccm); }
.cm-violation-type { font-size: 0.82rem; font-weight: 600; color: var(--color-espresso); }
.cm-violation-patient { font-size: 0.85rem; margin-bottom: var(--space-xs); }
.cm-violation-desc { font-size: 0.82rem; color: var(--color-cocoa); line-height: 1.4; margin-bottom: var(--space-sm); }
.cm-violation-action {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-sage);
}
.cm-compliance-clean {
  text-align: center;
  padding: var(--space-xl);
}
.cm-compliance-clean h3 { margin: var(--space-md) 0 var(--space-xs) 0; }
.cm-compliance-clean p { color: var(--color-cocoa); font-size: 0.85rem; }
.cm-rules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-md);
}
.cm-rule-item {
  padding: var(--space-md);
  background: var(--color-cream);
  border-radius: var(--radius-md);
}
.cm-rule-item strong { display: block; font-size: 0.82rem; margin-bottom: 4px; color: var(--color-espresso); }
.cm-rule-item p { font-size: 0.78rem; color: var(--color-cocoa); line-height: 1.4; margin: 0; }

/* ── Alerts ── */
.cm-alert-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.cm-alert-card {
  padding: var(--space-md);
  border-radius: var(--radius-md);
  border-left: 4px solid var(--color-sandstone);
  background: #fff;
  border: 1px solid var(--color-latte);
}
.cm-alert-priority--urgent { border-left: 4px solid var(--cm-alert); }
.cm-alert-priority--high { border-left: 4px solid var(--cm-tcm); }
.cm-alert-priority--medium { border-left: 4px solid var(--cm-ccm); }
.cm-alert-priority--low { border-left: 4px solid var(--color-sage); }
.cm-alert-card-header {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs);
}
.cm-alert-priority-badge {
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.6rem;
  font-weight: 800;
  color: #fff;
}
.cm-alert-priority-badge--urgent { background: var(--cm-alert); }
.cm-alert-priority-badge--high { background: var(--cm-tcm); }
.cm-alert-priority-badge--medium { background: var(--cm-ccm); }
.cm-alert-priority-badge--low { background: var(--color-sage); }
.cm-alert-type-badge {
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.6rem;
  font-weight: 700;
  background: var(--color-cream);
  color: var(--color-cocoa);
}
.cm-alert-card-body { font-size: 0.82rem; }
.cm-alert-card-body p { margin: 4px 0 0; color: var(--color-cocoa); font-size: 0.78rem; }

/* ── Empty State ── */
.cm-empty-state { text-align: center; padding: var(--space-xl); }
.cm-empty-state p { color: var(--color-cocoa); font-size: 0.85rem; }
.cm-empty-state a { color: var(--color-espresso); font-weight: 600; }

/* ── Responsive ── */
@media (max-width: 1000px) {
  .cm-metrics { grid-template-columns: repeat(3, 1fr); }
  .cm-program-cards { grid-template-columns: repeat(2, 1fr); }
  .cm-dashboard-grid { grid-template-columns: 1fr; }
  .cm-rpm-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .cm-metrics { grid-template-columns: repeat(2, 1fr); }
  .cm-program-cards { grid-template-columns: 1fr; }
  .cm-subnav { gap: 2px; }
  .cm-subnav-link { padding: var(--space-xs) var(--space-sm); font-size: 0.75rem; }
  .cm-subnav-link svg { display: none; }
  .cm-quick-enroll-row { flex-direction: column; }
  .cm-tcm-timeline { flex-direction: column; align-items: flex-start; }
  .cm-tcm-timeline-line { width: 2px; height: 20px; margin: 0 auto; }
  .cm-tcm-timeline-node { flex-direction: row; gap: var(--space-sm); min-width: auto; text-align: left; }
  .cm-subnav-group { flex-wrap: wrap; }
  .cm-subnav-divider { display: none; }
  .cm-optimizer-facilities { grid-template-columns: 1fr; }
}


/* ═══════════════════════════════════════════════════════════════════════════ */
/*  CARE MANAGEMENT — EXTENDED MODULES (Patches 1-8)                         */
/* ═══════════════════════════════════════════════════════════════════════════ */

/* ── Extended Metric Cards ── */
.cm-metric-card--awv { border-left: 3px solid var(--cm-awv); }
.cm-metric-card--dementia { border-left: 3px solid var(--cm-dementia); }
.cm-metric-card--acp { border-left: 3px solid var(--cm-acp); }
.cm-metric-card--bhi { border-left: 3px solid var(--cm-bhi); }
.cm-metric-card--hcc { border-left: 3px solid var(--cm-hcc); }
.cm-metric-card--optimizer { border-left: 3px solid var(--cm-optimizer); }

/* ── Extended Program Cards ── */
.cm-program-card--bhi { border-top-color: var(--cm-bhi); }
.cm-program-card--awv { border-top-color: var(--cm-awv); }
.cm-program-card--dementia { border-top-color: var(--cm-dementia); }
.cm-program-card--acp { border-top-color: var(--cm-acp); }

/* ── Extended Activity Icons ── */
.cm-activity-icon--bhi { background: var(--cm-bhi); }
.cm-activity-icon--awv { background: var(--cm-awv); }
.cm-activity-icon--dementia { background: var(--cm-dementia); }
.cm-activity-icon--acp { background: var(--cm-acp); }
.cm-activity-icon--hcc { background: var(--cm-hcc); }

/* ── Sub-Nav Groups ── */
.cm-subnav-group {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  position: relative;
}
.cm-subnav-group-label {
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-cocoa);
  opacity: 0.5;
  position: absolute;
  top: -10px;
  left: var(--space-xs);
  pointer-events: none;
}
.cm-subnav-divider {
  width: 1px;
  height: 22px;
  background: var(--color-cocoa);
  opacity: 0.15;
  margin: 0 var(--space-xs);
  flex-shrink: 0;
}

/* ── RPM Two-Tier Counter (Patch 2) ── */
.cm-rpm-counter { position: relative; }
.cm-rpm-counter-tier-marker {
  position: absolute;
  top: 0;
  width: 2px;
  height: 100%;
  background: var(--color-cocoa);
  opacity: 0.2;
  pointer-events: none;
}
.cm-rpm-counter-tier-marker--primary {
  opacity: 0.4;
}
.cm-rpm-counter-fill--tier1 {
  background: var(--cm-tcm);
}
.cm-rpm-threshold-tier1 {
  color: var(--cm-tcm);
  font-size: 0.72rem;
  font-weight: 600;
  margin-left: var(--space-xs);
}
.cm-rpm-tier-labels {
  display: flex;
  justify-content: space-between;
  margin-top: 2px;
}
.cm-rpm-tier-label {
  font-size: 0.62rem;
  color: var(--color-cocoa);
  opacity: 0.6;
}

/* ── Interactive Communication Badge (Patch 1) ── */
.cm-interactive-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.62rem;
  font-weight: 700;
  background: rgba(74, 111, 165, 0.12);
  color: var(--cm-ccm);
  margin-left: var(--space-xs);
}

/* ── Consent Status ── */
.cm-consent-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.62rem;
  font-weight: 700;
}
.cm-consent-badge--yes { background: rgba(46, 125, 50, 0.12); color: var(--cm-revenue); }
.cm-consent-badge--no { background: rgba(211, 47, 47, 0.12); color: var(--cm-alert); }

/* ── AWV Components (Patch 4) ── */
.cm-awv-components {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-sm);
}
.cm-awv-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
}
.cm-awv-checklist li {
  padding: var(--space-xs) 0;
  border-bottom: 1px solid rgba(0,0,0,0.05);
  font-size: 0.82rem;
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}
.cm-awv-checklist li:last-child { border-bottom: none; }
.cm-awv-check { color: var(--cm-awv); font-weight: 700; }
.cm-awv-uncheck { color: var(--color-cocoa); opacity: 0.3; }
.cm-awv-addon-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.62rem;
  font-weight: 700;
  background: rgba(90, 138, 90, 0.12);
  color: var(--cm-awv);
  margin-left: var(--space-xs);
}

/* ── AWV Type Badge (G0438/G0439) ── */
.cm-awv-type-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.68rem;
  font-weight: 700;
}
.cm-awv-type-badge--initial { background: rgba(74, 111, 165, 0.15); color: var(--cm-ccm); }
.cm-awv-type-badge--subsequent { background: rgba(90, 138, 90, 0.15); color: var(--cm-awv); }
.cm-awv-progress {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}
.cm-awv-progress-text {
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}

/* ── Dementia Assessment (Patch 3) ── */
.cm-dementia-card {
  border-left: 3px solid var(--cm-dementia);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
}
.cm-dementia-progress {
  height: 6px;
  background: rgba(0,0,0,0.06);
  border-radius: 3px;
  overflow: hidden;
  margin: var(--space-xs) 0;
}
.cm-dementia-progress-fill {
  height: 100%;
  background: var(--cm-dementia);
  border-radius: 3px;
  transition: width 0.3s ease;
}
.cm-dementia-element {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) 0;
  font-size: 0.82rem;
  border-bottom: 1px solid rgba(0,0,0,0.04);
}
.cm-dementia-element:last-child { border-bottom: none; }
.cm-dementia-check { color: var(--cm-dementia); font-weight: 700; }
.cm-dementia-uncheck { color: var(--color-cocoa); opacity: 0.3; }

/* ── ACP Document Status (Patch 5) ── */
.cm-acp-doc-status {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.7rem;
  font-weight: 600;
}
.cm-acp-status--none { background: rgba(0,0,0,0.06); color: var(--color-cocoa); }
.cm-acp-status--discussed { background: rgba(196, 136, 58, 0.15); color: var(--cm-tcm); }
.cm-acp-status--signed { background: rgba(46, 125, 50, 0.12); color: var(--cm-revenue); }
.cm-acp-status--on_file { background: rgba(46, 125, 50, 0.2); color: var(--cm-revenue); }
.cm-acp-status--designated { background: rgba(46, 125, 50, 0.12); color: var(--cm-revenue); }
.cm-acp-record-card {
  border-left: 3px solid var(--cm-acp);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
}
.cm-acp-docs-row {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  margin-top: var(--space-sm);
}
.cm-acp-doc-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cm-acp-doc-label {
  font-size: 0.68rem;
  color: var(--color-cocoa);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ── ACP Copay Waived Badge (Fix 3) ── */
.cm-acp-copay-waived-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.62rem;
  font-weight: 700;
  background: rgba(46, 125, 50, 0.15);
  color: var(--cm-revenue);
  margin-left: var(--space-xs);
}
.cm-acp-card {
  border-left: 3px solid var(--cm-acp);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
}
.cm-acp-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}
.cm-acp-card-fac { font-size: 0.78rem; color: var(--color-cocoa); margin-left: var(--space-sm); }
.cm-acp-card-meta { display: flex; align-items: center; gap: var(--space-sm); font-size: 0.78rem; color: var(--color-cocoa); }
.cm-acp-doc-statuses { display: flex; gap: var(--space-md); flex-wrap: wrap; margin-bottom: var(--space-sm); }
.cm-acp-doc-value { font-size: 0.78rem; font-weight: 600; }
.cm-acp-card-detail { font-size: 0.82rem; color: var(--color-cocoa); }
.cm-acp-card-detail p { margin: 2px 0; }

/* ── BHI Model Badge (Patch 6) ── */
.cm-bhi-model-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cm-bhi-model-badge--general { background: rgba(138, 106, 106, 0.15); color: var(--cm-bhi); }
.cm-bhi-model-badge--cocm { background: rgba(138, 106, 106, 0.25); color: var(--cm-bhi); }

/* ── HCC Tracking (Patch 7) ── */
.cm-hcc-category {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.7rem;
  font-weight: 700;
  background: rgba(106, 138, 122, 0.15);
  color: var(--cm-hcc);
}
.cm-hcc-raf-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.72rem;
  font-weight: 700;
  background: rgba(106, 138, 122, 0.1);
  color: var(--cm-hcc);
}
.cm-hcc-gap-row {
  background: rgba(211, 47, 47, 0.03);
}
.cm-hcc-gap-intro {
  font-size: 0.82rem;
  color: var(--color-cocoa);
  margin-bottom: var(--space-md);
}
.cm-hcc-patient-group {
  margin-bottom: var(--space-lg);
}
.cm-hcc-patient-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) 0;
  border-bottom: 2px solid rgba(0,0,0,0.08);
  margin-bottom: var(--space-sm);
}
.cm-hcc-patient-meta {
  font-size: 0.78rem;
  color: var(--color-cocoa);
}
.cm-hcc-patient-raf {
  margin-left: auto;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--cm-hcc);
}

/* ── Visit Stacking Optimizer (Patch 8) ── */
.cm-optimizer-facilities {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-md);
}
.cm-optimizer-facility-card {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.cm-optimizer-facility-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.cm-optimizer-facility-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-sm);
}
.cm-optimizer-facility-count {
  font-size: 0.75rem;
  color: var(--color-cocoa);
}
.cm-optimizer-facility-revenue {
  text-align: center;
  margin: var(--space-md) 0;
}
.cm-optimizer-revenue-amount {
  display: block;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--cm-revenue);
}
.cm-optimizer-revenue-label {
  font-size: 0.72rem;
  color: var(--color-cocoa);
}
.cm-optimizer-facility-bar {
  height: 4px;
  background: rgba(0,0,0,0.06);
  border-radius: 2px;
  overflow: hidden;
}
.cm-optimizer-facility-bar-fill {
  height: 100%;
  background: var(--cm-optimizer);
  border-radius: 2px;
  transition: width 0.4s ease;
}
.cm-optimizer-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}
.cm-optimizer-header h2 { margin: 0; }
.cm-optimizer-matrix-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.cm-optimizer-matrix {
  width: 100%;
  min-width: 600px;
}
.cm-optimizer-matrix th {
  text-align: center;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cm-optimizer-matrix th:first-child {
  text-align: left;
}
.cm-optimizer-cell {
  text-align: center;
  font-size: 0.9rem;
  padding: var(--space-sm);
}
.cm-optimizer-cell--billed { color: var(--cm-revenue); }
.cm-optimizer-cell--inprogress { color: var(--cm-tcm); }
.cm-optimizer-cell--eligible { color: var(--cm-ccm); }
.cm-optimizer-cell--na { color: var(--color-cocoa); opacity: 0.3; }
.cm-optimizer-total {
  text-align: center;
  font-weight: 700;
  color: var(--cm-revenue);
}
.cm-optimizer-total-row {
  background: rgba(46, 125, 50, 0.04);
  border-top: 2px solid rgba(0,0,0,0.08);
}
.cm-optimizer-legend {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-md);
  font-size: 0.75rem;
  color: var(--color-cocoa);
}
.cm-optimizer-legend-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}
.cm-optimizer-legend-dot.cm-optimizer-cell--billed { background: var(--cm-revenue); }
.cm-optimizer-legend-dot.cm-optimizer-cell--inprogress { background: var(--cm-tcm); }
.cm-optimizer-legend-dot.cm-optimizer-cell--eligible { background: var(--cm-ccm); }
.cm-optimizer-legend-dot.cm-optimizer-cell--na { background: var(--color-cocoa); opacity: 0.3; }

/* ── Visit Optimizer CTA on Dashboard ── */
.cm-visit-optimizer-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: linear-gradient(135deg, rgba(74, 122, 106, 0.06) 0%, rgba(74, 122, 106, 0.02) 100%);
  border-left: 3px solid var(--cm-optimizer);
}
.cm-visit-cta-content h3 { margin: 0 0 var(--space-xs); }
.cm-visit-cta-content p { margin: 0; font-size: 0.82rem; color: var(--color-cocoa); }

/* ── Status Badges (general) ── */
.cm-status-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: capitalize;
}
.cm-status-badge--active { background: rgba(46, 125, 50, 0.12); color: var(--cm-revenue); }
.cm-status-badge--resolved { background: rgba(0,0,0,0.06); color: var(--color-cocoa); }
.cm-status-badge--pending_review { background: rgba(196, 136, 58, 0.15); color: var(--cm-tcm); }
.cm-status-badge--scheduled { background: rgba(74, 111, 165, 0.12); color: var(--cm-ccm); }
.cm-status-badge--completed { background: rgba(46, 125, 50, 0.12); color: var(--cm-revenue); }
.cm-status-badge--billed { background: rgba(46, 125, 50, 0.2); color: var(--cm-revenue); }
.cm-status-badge--in_progress { background: rgba(196, 136, 58, 0.15); color: var(--cm-tcm); }
.cm-status-badge--documented { background: rgba(74, 111, 165, 0.12); color: var(--cm-ccm); }

/* ── Count Badge ── */
.cm-count-badge {
  display: inline-block;
  padding: 1px 8px;
  border-radius: 10px;
  font-size: 0.68rem;
  font-weight: 700;
  background: rgba(0,0,0,0.06);
  color: var(--color-cocoa);
  margin-left: var(--space-xs);
}
.cm-count-badge--alert {
  background: rgba(211, 47, 47, 0.12);
  color: var(--cm-alert);
}

/* ── Deadline Badge ── */
.cm-deadline-badge {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.62rem;
  font-weight: 700;
  margin-left: var(--space-xs);
}
.cm-deadline-badge--ok { background: rgba(46, 125, 50, 0.1); color: var(--cm-revenue); }
.cm-deadline-badge--warning { background: rgba(196, 136, 58, 0.15); color: var(--cm-tcm); }
.cm-deadline-badge--overdue { background: rgba(211, 47, 47, 0.12); color: var(--cm-alert); }

/* ── Rules / Guide Grids ── */
.cm-rules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-md);
}
.cm-rule-item {
  padding: var(--space-md);
  background: rgba(0,0,0,0.02);
  border-radius: 6px;
  border: 1px solid rgba(0,0,0,0.04);
}
.cm-rule-item strong {
  display: block;
  margin-bottom: var(--space-xs);
  font-size: 0.82rem;
}
.cm-rule-item p {
  margin: 0;
  font-size: 0.78rem;
  color: var(--color-cocoa);
}

/* ── Date Cell ── */
.cm-td-date {
  font-size: 0.78rem;
  white-space: nowrap;
  color: var(--color-cocoa);
}
.cm-td-fac {
  font-size: 0.78rem;
  color: var(--color-cocoa);
}

/* ── Month Navigator ── */
.cm-month-nav {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}
.cm-month-nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 4px;
  background: var(--color-cream);
  color: var(--color-espresso);
  text-decoration: none;
  font-weight: 700;
  font-size: 0.85rem;
  border: 1px solid rgba(0,0,0,0.08);
}
.cm-month-nav-btn:hover { background: var(--color-espresso); color: var(--color-linen); }
.cm-month-nav-label { font-weight: 600; font-size: 0.9rem; }

/* ── Expand Panel (for BHI/CCM time entries) ── */
.cm-expand-panel {
  background: rgba(0,0,0,0.02);
  padding: var(--space-md);
}
.cm-time-panel {
  margin-bottom: var(--space-md);
}
.cm-add-time-form h4 {
  margin: 0 0 var(--space-sm);
  font-size: 0.85rem;
}
.cm-form-row {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-bottom: var(--space-sm);
}
.cm-form-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 120px;
}
.cm-form-label {
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-cocoa);
}
.cm-form-input {
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 4px;
  font-size: 0.82rem;
  background: var(--color-linen);
}
.cm-form-select {
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 4px;
  font-size: 0.82rem;
  background: var(--color-linen);
}
.cm-form-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: 0.82rem;
  cursor: pointer;
}

/* ── Empty Text ── */
.cm-empty-text {
  color: var(--color-cocoa);
  font-size: 0.82rem;
  font-style: italic;
}

/* ── Responsive additions for new modules ── */
@media (max-width: 1000px) {
  .cm-optimizer-facilities { grid-template-columns: repeat(2, 1fr); }
  .cm-rules-grid { grid-template-columns: 1fr; }
  .cm-acp-docs-row { flex-direction: column; }
}
@media (max-width: 768px) {
  .cm-optimizer-facilities { grid-template-columns: 1fr; }
  .cm-visit-optimizer-cta { flex-direction: column; text-align: center; }
}

/* ── Revenue Summary Grid (Fix 5) ── */
.cm-revenue-summary-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}
.cm-revenue-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid rgba(0,0,0,0.04);
}
.cm-revenue-summary-row:last-child { border-bottom: none; }
.cm-revenue-summary-row--total {
  border-top: 2px solid rgba(0,0,0,0.1);
  border-bottom: none;
  font-weight: 700;
  font-size: 1.05rem;
  background: rgba(46, 125, 50, 0.04);
}
.cm-revenue-summary-label { font-size: 0.85rem; }
.cm-revenue-summary-amount { font-size: 0.95rem; font-weight: 700; color: var(--cm-revenue); }
.cm-revenue-summary-row--total .cm-revenue-summary-amount { font-size: 1.1rem; }

/* ── Visit Optimizer Print/Export (Fix 4) ── */
.cm-optimizer-print-header { display: none; }
.cm-optimizer-checkbox-col { display: none; }
.cm-optimizer-print-date { color: var(--color-cocoa); font-size: 0.85rem; }
.cm-optimizer-actions {
  display: flex;
  gap: var(--space-sm);
  margin-left: auto;
}
.cm-optimizer-print-btn { white-space: nowrap; }

@media print {
  /* Hide navigation and non-essential UI */
  .topbar, .sidebar, .cm-subnav, .cm-optimizer-actions,
  .cm-optimizer-legend, .cm-btn, footer, nav,
  .cm-optimizer-header > a { display: none !important; }

  /* Show print-only elements */
  .cm-optimizer-print-header {
    display: block !important;
    text-align: center;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid #333;
  }
  .cm-optimizer-print-header h2 { margin: 0; font-size: 16px; }
  .cm-optimizer-print-header .cm-optimizer-print-date { color: #666; font-size: 12px; }
  .cm-optimizer-checkbox-col { display: table-cell !important; width: 40px; text-align: center; }

  /* Optimize the matrix for paper */
  .cm-optimizer-matrix {
    width: 100%;
    font-size: 11px;
    border-collapse: collapse;
  }
  .cm-optimizer-matrix th,
  .cm-optimizer-matrix td {
    border: 1px solid #333;
    padding: 4px 6px;
  }
  .cm-optimizer-cell--eligible {
    background: #e8f5e9 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .cm-optimizer-cell--billed {
    background: #c8e6c9 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .cm-optimizer-cell--inprogress {
    background: #fff3e0 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .cm-optimizer-total-row {
    background: #f5f5f5 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  /* Clean up layout for print */
  .card { box-shadow: none; border: 1px solid #ccc; }
  body { background: #fff; }
  .content-area { padding: 0; }
}

/* ---------------------------------------------------------------------------
   Medical Director Payments — Enhanced Components
   --------------------------------------------------------------------------- */

/* ── Secondary Metrics Row ── */
.mdp-secondary-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}
.mdp-metric-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: 0.75rem 1rem;
  text-align: center;
}
.mdp-metric-number {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-espresso);
  line-height: 1.1;
}
.mdp-metric-label {
  font-size: 0.7rem;
  color: var(--color-cocoa);
  margin-top: 0.15rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ── Aging Table ── */
.mdp-aging-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}
.mdp-aging-table th {
  padding: 0.6rem 0.75rem;
  text-align: left;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-cocoa);
  border-bottom: 2px solid var(--color-latte);
  white-space: nowrap;
}
.mdp-aging-table th:not(:first-child):not(:nth-child(2)) {
  text-align: right;
}
.mdp-aging-table td {
  padding: 0.55rem 0.75rem;
  border-bottom: 1px solid var(--color-latte);
  color: var(--color-espresso);
}
.mdp-aging-table td:not(:first-child):not(:nth-child(2)) {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.mdp-aging-cell--warn { color: #e65100; font-weight: 600; }
.mdp-aging-cell--danger { color: #c62828; font-weight: 700; }
.mdp-aging-total-row td {
  font-weight: 700;
  border-top: 2px solid var(--color-espresso);
  border-bottom: none;
  color: var(--color-espresso);
}

/* ── Bulk Setup Modal ── */
.mdp-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.mdp-modal {
  background: var(--color-white);
  border-radius: var(--radius-lg, 12px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
  max-width: 640px;
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  padding: 1.75rem;
}
.mdp-modal-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-espresso);
  margin-bottom: 1.25rem;
}
.mdp-bulk-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-latte);
}
.mdp-bulk-row:last-child { border-bottom: none; }
.mdp-bulk-name {
  flex: 1;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-espresso);
}
.mdp-bulk-type {
  font-size: 0.65rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.mdp-bulk-input {
  width: 110px;
  padding: 0.4rem 0.6rem;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-family: inherit;
  text-align: right;
}
.mdp-bulk-input:focus {
  outline: none;
  border-color: var(--color-forest);
  box-shadow: 0 0 0 2px rgba(61, 107, 53, 0.15);
}

/* ── Batch Actions Bar ── */
.mdp-batch-bar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.65rem 1.25rem;
  background: #E8F0E2;
  border: 1px solid #c5d9bc;
  border-radius: var(--radius-md);
  margin-bottom: 1rem;
}
.mdp-batch-count {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-forest);
}

/* ── Completion Dots ── */
.mdp-completion-dots {
  display: inline-flex;
  gap: 3px;
  align-items: center;
}
.mdp-completion-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-latte);
}
.mdp-completion-dot--filled {
  background: var(--color-forest);
}

/* ── Contract Row ── */
.mdp-contract-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  font-size: 0.82rem;
  color: var(--color-cocoa);
}
.mdp-contract-row label {
  font-weight: 600;
  color: var(--color-espresso);
  font-size: 0.78rem;
}
.mdp-contract-input {
  padding: 4px 8px;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  font-size: 0.82rem;
  font-family: inherit;
  width: 130px;
}
.mdp-contract-input:focus {
  outline: none;
  border-color: var(--color-forest);
}

/* ── Notes Field ── */
.mdp-notes-field {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  font-size: 0.82rem;
  font-family: inherit;
  resize: vertical;
  min-height: 2.5rem;
  color: var(--color-espresso);
}
.mdp-notes-field:focus {
  outline: none;
  border-color: var(--color-forest);
}
.mdp-notes-field::placeholder {
  color: var(--color-walnut);
  opacity: 0.5;
}

/* ── Month Cell Amount ── */
.mdp-month-amount {
  font-size: 0.68rem;
  opacity: 0.65;
  margin-top: 2px;
}

/* ── Paid YTD Line ── */
.mdp-paid-ytd {
  margin-top: 0.65rem;
  font-size: 0.78rem;
  color: var(--color-cocoa);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.mdp-paid-ytd-bar {
  flex: 1;
  max-width: 200px;
  height: 6px;
  background: var(--color-latte);
  border-radius: 3px;
  overflow: hidden;
}
.mdp-paid-ytd-fill {
  height: 100%;
  background: var(--color-forest);
  border-radius: 3px;
  transition: width 0.3s ease;
}

/* ── Reminder Log ── */
.mdp-reminder-log {
  margin-top: 0.5rem;
  font-size: 0.75rem;
  color: var(--color-cocoa);
}
.mdp-reminder-entry {
  padding: 0.25rem 0;
  border-bottom: 1px dotted var(--color-latte);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* ── Collections Badge ── */
.mdp-status--collections {
  background: #ffcdd2 !important;
  border-color: #e57373 !important;
  color: #b71c1c !important;
  font-weight: 800 !important;
}

/* ── Privacy Mode ── */
.mdp-privacy .fac-summary-number,
.mdp-privacy .mdp-metric-number,
.mdp-privacy .mdp-pv {
  filter: blur(10px);
  transition: filter 0.35s ease;
  user-select: none;
}
.mdp-privacy .fac-summary-number:hover,
.mdp-privacy .mdp-metric-number:hover,
.mdp-privacy .mdp-pv:hover {
  filter: blur(0);
}
.mdp-privacy-toggle {
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: 0.35rem 0.65rem;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-cocoa);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  transition: all 0.2s;
}
.mdp-privacy-toggle:hover { background: var(--color-cream); }
.mdp-privacy-toggle--active {
  background: var(--color-espresso);
  color: #fff;
  border-color: var(--color-espresso);
}

/* ── Undo Toast ── */
.mdp-toast {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-espresso, #2C1810);
  color: #fff;
  padding: 0.75rem 1.25rem;
  border-radius: var(--radius-lg, 12px);
  font-size: 0.88rem;
  font-weight: 500;
  box-shadow: 0 8px 30px rgba(0,0,0,0.3);
  z-index: 950;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.mdp-toast-undo {
  background: rgba(255,255,255,0.2);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  padding: 0.3rem 0.85rem;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.mdp-toast-undo:hover { background: rgba(255,255,255,0.35); }

/* ── Month Nav ── */
.mdp-month-nav {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}
.mdp-month-nav-btn {
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  padding: 0.2rem 0.55rem;
  font-size: 0.72rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  color: var(--color-cocoa);
  transition: all 0.15s;
}
.mdp-month-nav-btn:hover:not(:disabled) { background: var(--color-cream); }
.mdp-month-nav-btn:disabled { opacity: 0.3; cursor: default; }

/* ── Chart Container ── */
.mdp-chart-wrap {
  padding: 0 1.25rem 1.25rem;
  max-height: 240px;
}

/* ── Type Dropdown ── */
.mdp-type-select {
  padding: 3px 6px;
  border: 1px solid var(--color-latte);
  border-radius: var(--radius-md);
  font-size: 0.75rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  background: var(--color-cream);
  color: var(--color-cocoa);
}

/* ── New Today Badge ── */
.mdp-badge-new {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.6rem;
  font-weight: 700;
  background: #e8eaf6;
  color: #283593;
  animation: mdpPulse 2s ease-in-out infinite;
}
@keyframes mdpPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .mdp-secondary-metrics {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .mdp-batch-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 800;
    border-radius: 0;
    border: none;
    border-top: 2px solid #c5d9bc;
    flex-wrap: wrap;
    justify-content: center;
  }
  .mdp-modal {
    max-width: 100vw !important;
    max-height: 100vh !important;
    border-radius: 0 !important;
    height: 100%;
  }
  .mdp-modal-overlay {
    padding: 0;
  }
}
@media (max-width: 640px) {
  .mdp-aging-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════
   KIOSK MODE
   Employee self-service fullscreen form interface
   ═══════════════════════════════════════════════════════════════════════════ */

.kiosk-shell {
  display: flex;
  flex-direction: column;
  height: 100vh;
  width: 100vw;
  background: var(--color-cream, #EFEBE9);
  font-family: var(--font-primary, 'DM Sans', sans-serif);
}

/* ── Header ──────────────────────────────────────────────────────────────── */

.kiosk-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.65rem 1.5rem;
  background: var(--color-espresso, #2C1810);
  color: var(--color-ivory, #FAF7F5);
  flex-shrink: 0;
}

.kiosk-header-brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: -0.01em;
}

.kiosk-header-info {
  font-size: 0.88rem;
  font-weight: 500;
}

.kiosk-header-timer {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.85rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--color-taupe, #BCAAA4);
}

/* ── Progress Steps ──────────────────────────────────────────────────────── */

.kiosk-progress {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  padding: 0.75rem 1.5rem;
  background: var(--color-ivory, #FAF7F5);
  border-bottom: 1px solid var(--color-latte, #D7CCC8);
  flex-shrink: 0;
  overflow-x: auto;
}

.kiosk-step {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.6rem;
  font-size: 0.78rem;
  color: var(--color-sandstone, #A1887F);
  white-space: nowrap;
  position: relative;
}

.kiosk-step + .kiosk-step::before {
  content: '';
  position: absolute;
  left: -6px;
  width: 12px;
  height: 2px;
  background: var(--color-latte, #D7CCC8);
  top: 50%;
}

.kiosk-step-number {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 700;
  background: var(--color-latte, #D7CCC8);
  color: var(--color-sienna, #795548);
  flex-shrink: 0;
}

.kiosk-step--active .kiosk-step-number {
  background: var(--color-sage, #7A9B6D);
  color: #fff;
}

.kiosk-step--done .kiosk-step-number {
  background: var(--color-forest, #3D6B35);
  color: #fff;
}

.kiosk-step--active .kiosk-step-label {
  font-weight: 700;
  color: var(--color-espresso, #2C1810);
}

.kiosk-step--done .kiosk-step-label {
  color: var(--color-forest, #3D6B35);
}

/* ── Body ────────────────────────────────────────────────────────────────── */

.kiosk-body {
  flex: 1;
  overflow-y: auto;
  padding: 2rem 1.5rem 3rem;
  display: flex;
  justify-content: center;
}

.kiosk-form-container {
  max-width: 640px;
  width: 100%;
}

.kiosk-form-title {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--color-espresso, #2C1810);
  margin: 0 0 0.35rem;
  letter-spacing: -0.01em;
}

.kiosk-form-subtitle {
  font-size: 0.88rem;
  color: var(--color-sienna, #795548);
  margin: 0 0 1.5rem;
  line-height: 1.5;
}

/* ── Form Elements ───────────────────────────────────────────────────────── */

.kiosk-form-group {
  margin-bottom: 1rem;
}

.kiosk-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-mocha, #5D4037);
  margin-bottom: 0.3rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.kiosk-input {
  width: 100%;
  padding: 0.6rem 0.8rem;
  border: 2px solid var(--color-latte, #D7CCC8);
  border-radius: 8px;
  font-size: 0.95rem;
  font-family: inherit;
  background: #fff;
  color: var(--color-espresso, #2C1810);
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
}

.kiosk-input:focus {
  outline: none;
  border-color: var(--color-sage, #7A9B6D);
  box-shadow: 0 0 0 3px rgba(122, 155, 109, 0.15);
}

.kiosk-input::placeholder {
  color: var(--color-taupe, #BCAAA4);
}

.kiosk-input--sensitive {
  letter-spacing: 0.12em;
  font-family: 'DM Mono', monospace;
}

.kiosk-hint {
  font-size: 0.78rem;
  color: var(--color-sandstone, #A1887F);
  margin-top: 0.25rem;
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.kiosk-form-row {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.kiosk-col-6 { flex: 1 1 48%; min-width: 180px; }
.kiosk-col-3 { flex: 0 0 24%; min-width: 90px; }

/* ── Signature ───────────────────────────────────────────────────────────── */

.kiosk-signature-section {
  margin-top: 2rem;
  padding: 1.25rem;
  border: 2px solid var(--color-latte, #D7CCC8);
  border-radius: 10px;
  background: var(--color-ivory, #FAF7F5);
}

.kiosk-signature-section h3 {
  margin: 0 0 0.5rem;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-espresso, #2C1810);
}

.kiosk-sig-legal {
  font-size: 0.82rem;
  color: var(--color-sienna, #795548);
  line-height: 1.55;
  margin-bottom: 1rem;
}

.kiosk-sig-input {
  font-style: italic;
  font-size: 1.05rem !important;
}

.kiosk-sig-timestamp {
  font-size: 0.78rem;
  color: var(--color-sage, #7A9B6D);
  margin-top: 0.5rem;
  font-weight: 500;
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */

.kiosk-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 48px;
  min-width: 200px;
  padding: 0.7rem 1.75rem;
  border: none;
  border-radius: 10px;
  font-size: 0.95rem;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s ease;
}

.kiosk-btn--primary {
  background: var(--color-sage, #7A9B6D);
  color: #fff;
}

.kiosk-btn--primary:hover {
  background: var(--color-forest, #3D6B35);
}

.kiosk-btn--primary:disabled {
  background: var(--color-taupe, #BCAAA4);
  cursor: not-allowed;
}

.kiosk-form-actions {
  margin-top: 1.5rem;
  display: flex;
  justify-content: flex-end;
}

/* ── Lock / Expired Overlay ──────────────────────────────────────────────── */

.kiosk-lock-overlay {
  position: fixed;
  inset: 0;
  background: rgba(44, 24, 16, 0.92);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.kiosk-lock-content {
  text-align: center;
  color: var(--color-ivory, #FAF7F5);
  padding: 3rem;
}

.kiosk-lock-content h2 {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 1rem 0 0.5rem;
}

.kiosk-lock-content p {
  font-size: 0.95rem;
  color: var(--color-taupe, #BCAAA4);
  line-height: 1.6;
  margin: 0;
}

.kiosk-lock-icon {
  color: var(--color-amber, #D4A24E);
}

/* ── Welcome Screen ──────────────────────────────────────────────────────── */

.kiosk-welcome {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  text-align: center;
  padding: 2rem;
}

.kiosk-welcome h1 {
  font-size: 1.6rem;
  color: var(--color-espresso, #2C1810);
  margin: 0 0 0.5rem;
  font-weight: 800;
}

.kiosk-welcome-forms {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0;
  text-align: left;
}

.kiosk-welcome-forms li {
  padding: 0.5rem 0;
  font-size: 0.95rem;
  color: var(--color-mocha, #5D4037);
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

/* ── Completion Screen ───────────────────────────────────────────────────── */

.kiosk-complete {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  text-align: center;
  padding: 2rem;
}

.kiosk-complete-check {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--color-forest, #3D6B35);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
}

/* ── Kiosk Launch Button (on owner pages) ────────────────────────────────── */

.kiosk-launch-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.65rem;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  background: var(--color-sage, #7A9B6D);
  color: #fff;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s;
  white-space: nowrap;
}

.kiosk-launch-btn:hover {
  background: var(--color-forest, #3D6B35);
}

.kiosk-launch-btn svg {
  flex-shrink: 0;
}

/* ── Remote Kiosk (mobile phone) ──────────────────────────────────── */
.kiosk-remote-shell {
  min-height: 100dvh;
  max-height: none;
  overflow: visible;
}

.kiosk-remote-shell .kiosk-body {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: env(safe-area-inset-bottom, 16px);
}

.kiosk-remote-trust {
  background: rgba(122, 155, 109, 0.08);
  color: var(--color-coffee, #6D4C41);
  font-size: 0.78rem;
  text-align: center;
  padding: 0.5rem 1rem;
  border-bottom: 1px solid var(--color-latte, #D7CCC8);
  line-height: 1.5;
}

.kiosk-remote-trust strong {
  color: var(--color-espresso, #2C1810);
}

.kiosk-remote-toast {
  position: fixed;
  bottom: env(safe-area-inset-bottom, 16px);
  left: 50%;
  transform: translateX(-50%);
  background: #FFF3E0;
  color: #E65100;
  padding: 0.6rem 1.25rem;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 600;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  z-index: 1000;
  max-width: 90vw;
  text-align: center;
}

/* Remote-specific responsive tweaks */
@media (max-width: 480px) {
  .kiosk-remote-shell .kiosk-header {
    padding: 0.5rem 0.75rem;
  }

  .kiosk-remote-shell .kiosk-header-brand span {
    display: none;
  }

  .kiosk-remote-shell .kiosk-progress {
    gap: 0;
    padding: 0.5rem 0.5rem;
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
  }

  .kiosk-remote-shell .kiosk-step {
    min-width: auto;
  }

  .kiosk-remote-shell .kiosk-step-label {
    font-size: 0.6rem;
    max-width: 52px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .kiosk-remote-shell .kiosk-form-container {
    padding: 1rem;
    max-width: 100%;
  }

  .kiosk-remote-shell .kiosk-form-title {
    font-size: 1.25rem;
  }

  .kiosk-remote-shell .kiosk-form-row {
    flex-direction: column;
    gap: 0;
  }

  .kiosk-remote-shell .kiosk-col-6,
  .kiosk-remote-shell .kiosk-col-3 {
    flex: 1 1 100%;
    min-width: 0;
  }

  .kiosk-remote-shell .kiosk-input,
  .kiosk-remote-shell .kiosk-sig-input {
    font-size: 16px; /* Prevents iOS zoom on focus */
  }

  .kiosk-remote-shell .kiosk-btn {
    width: 100%;
    padding: 0.85rem 1.25rem;
    font-size: 0.95rem;
    -webkit-tap-highlight-color: transparent;
  }

  .kiosk-remote-shell .kiosk-signature-section {
    padding: 1rem;
  }
}

/* Send-to-phone panel on start page */
.kiosk-remote-panel {
  background: var(--color-ivory, #FAF7F2);
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: 12px;
  padding: 1.5rem;
  margin-top: 1rem;
}

.kiosk-remote-panel h3 {
  margin: 0 0 1rem;
  font-size: 1rem;
  color: var(--color-espresso, #2C1810);
}

.kiosk-remote-status {
  background: white;
  border: 1px solid var(--color-latte, #D7CCC8);
  border-radius: 10px;
  padding: 1rem;
  margin-top: 1rem;
}

.kiosk-remote-status-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.4rem 0;
  font-size: 0.85rem;
  color: var(--color-coffee, #6D4C41);
}

.kiosk-remote-status-row + .kiosk-remote-status-row {
  border-top: 1px solid var(--color-cream, #EFEBE9);
}


/* ===========================================================================
   PAYROLL ENTRY WORKFLOW (pew-*)
   5-stage flow: Draft → Review → Fund → Pay → Lock
   =========================================================================== */

/* ── Stage bar ───────────────────────────────────────────────────────────── */

.pew-stage-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 1rem 0 1.5rem;
}

.pew-stage-dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 700;
  border: 2px solid var(--color-latte);
  background: var(--color-white);
  color: var(--color-sandstone);
  position: relative;
  flex-shrink: 0;
  transition: all 0.2s ease;
}

.pew-stage-dot--active {
  border-color: var(--color-sage);
  background: var(--color-sage);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(122, 155, 109, 0.15);
}

.pew-stage-dot--done {
  border-color: var(--color-sage);
  background: rgba(122, 155, 109, 0.12);
  color: var(--color-sage);
}

.pew-stage-num { font-size: 0.8rem; }

.pew-stage-label {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
  margin-top: 4px;
}

.pew-stage-dot--active .pew-stage-label { color: var(--color-sage); }

.pew-stage-line {
  flex: 1;
  max-width: 80px;
  height: 2px;
  background: var(--color-latte);
  transition: background 0.2s ease;
}

.pew-stage-line--done { background: var(--color-sage); }

/* Stage header with back link */
.pew-stage-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px 0;
    margin-bottom: 4px;
}
.pew-back-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-sandstone, #a1887f);
    text-decoration: none;
    transition: color 0.15s;
}
.pew-back-link:hover { color: var(--color-espresso, #3e2723); }
.pew-stage-title {
    flex: 1;
    font-size: 14px;
    font-weight: 700;
    color: var(--color-espresso, #3e2723);
}
.pew-stage-period {
    font-size: 12px;
    color: var(--color-sandstone, #a1887f);
}

/* Clickable completed stage dots */
a.pew-stage-dot {
    text-decoration: none;
    color: inherit;
}
a.pew-stage-dot--done {
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
}
a.pew-stage-dot--done:hover {
    transform: scale(1.15);
    box-shadow: 0 0 0 3px rgba(124, 179, 66, 0.3);
}
.pew-stage-dot--done .pew-stage-label { color: var(--color-sage, #7cb342); }

/* Read-only banner for back-navigated stages */
.pew-readonly-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(122, 155, 109, 0.06);
    border: 1px solid var(--color-sage, #7cb342);
    border-radius: 10px;
    padding: 10px 16px;
    margin: 0 0 16px;
    font-size: 13px;
    color: var(--color-coffee, #6d4c41);
}
.pew-readonly-banner strong { color: var(--color-espresso, #3e2723); }
.pew-readonly-return {
    margin-left: auto;
    font-size: 12px;
    font-weight: 600;
    color: var(--color-sage, #7cb342);
    text-decoration: none;
    white-space: nowrap;
}
.pew-readonly-return:hover { text-decoration: underline; }
.pew-input--readonly {
    background: var(--color-cream, #faf8f5) !important;
    color: var(--color-sandstone, #a1887f) !important;
    cursor: not-allowed;
    border-color: transparent !important;
}

/* ── Section (entity groups in draft) ────────────────────────────────────── */

.pew-section {
  border: 1px solid var(--color-latte);
  border-radius: 10px;
  margin-bottom: 1rem;
  overflow: hidden;
}

.pew-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  background: var(--color-ivory);
  cursor: pointer;
  user-select: none;
}

.pew-section-header:hover { background: var(--color-cream); }

.pew-section-total {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-espresso);
}

.pew-section--collapsed .pew-section-body { display: none; }

.pew-chevron {
  transition: transform 0.2s ease;
  color: var(--color-sandstone);
}

.pew-section--collapsed .pew-chevron { transform: rotate(-90deg); }

/* ── Entry rows ──────────────────────────────────────────────────────────── */

.pew-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.6rem 1rem;
  border-bottom: 1px solid var(--color-cream);
  transition: background 0.15s ease;
}

.pew-row:last-child { border-bottom: none; }
.pew-row:hover { background: rgba(250, 247, 245, 0.6); }

.pew-row--header {
  background: var(--color-ivory);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-sandstone);
  padding: 0.5rem 1rem;
}

.pew-row--flagged { background: rgba(212, 162, 78, 0.06); }
.pew-row--off-cycle { background: rgba(212, 162, 78, 0.04); }
.pew-row--one-time { background: rgba(107, 127, 163, 0.04); }
.pew-row--paid { opacity: 0.65; }

.pew-row-base {
  font-size: 0.8rem;
  color: var(--color-sandstone);
}

.pew-row-name {
  font-weight: 600;
  color: var(--color-espresso);
  font-size: 0.95rem;
}

.pew-row-role {
  font-size: 0.8rem;
  color: var(--color-sandstone);
}

.pew-input {
  width: 100%;
  max-width: 140px;
  padding: 6px 10px;
  font-size: 0.9rem;
  font-family: var(--font-primary);
  color: var(--color-espresso);
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: 8px;
  outline: none;
  text-align: right;
  transition: border-color 0.15s ease;
  -moz-appearance: textfield;
}

.pew-input::-webkit-inner-spin-button,
.pew-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }

.pew-input:focus {
  border-color: var(--color-sage);
  box-shadow: 0 0 0 3px rgba(122, 155, 109, 0.1);
}

/* ── Sticky footer ───────────────────────────────────────────────────────── */

.pew-footer {
  position: sticky;
  bottom: 0;
  z-index: 20;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--color-latte);
  padding: 0.75rem 1rem;
  margin-top: 1rem;
}

.pew-footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.pew-footer-stats {
  display: flex;
  gap: 1.25rem;
  font-size: 0.85rem;
  color: var(--color-coffee);
}

.pew-footer-entity {
  font-size: 0.8rem;
  color: var(--color-sandstone);
}

.pew-footer-total {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-espresso);
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */

.pew-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.65rem 1.25rem;
  font-size: 0.9rem;
  font-weight: 600;
  font-family: var(--font-primary);
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.15s ease;
  white-space: nowrap;
}

.pew-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.pew-btn--primary {
  background: var(--color-sage);
  color: #fff;
}

.pew-btn--primary:hover:not(:disabled) {
  background: var(--color-forest);
}

.pew-btn--secondary {
  background: var(--color-ivory);
  color: var(--color-coffee);
  border: 1px solid var(--color-latte);
}

.pew-btn--secondary:hover:not(:disabled) { background: var(--color-cream); }

.pew-btn--ghost {
  background: transparent;
  color: var(--color-coffee);
  padding: 0.5rem 0.75rem;
}

.pew-btn--ghost:hover { background: var(--color-ivory); }

/* ── Progress bar ────────────────────────────────────────────────────────── */

.pew-progress {
  height: 8px;
  background: var(--color-cream);
  border-radius: 4px;
  overflow: hidden;
}

.pew-progress-fill {
  height: 100%;
  background: var(--color-sage);
  border-radius: 4px;
  transition: width 0.4s ease;
}

/* ── Pay stage: sticky progress ──────────────────────────────────────────── */

.pew-pay-progress {
  position: sticky;
  top: 0;
  z-index: 18;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--color-cream);
}

.pew-pay-progress-inner {
  max-width: 800px;
  margin: 0 auto;
}

.pew-pay-progress-stats {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  color: var(--color-sandstone);
  margin-top: 0.4rem;
}

/* ── Pay list + rows ─────────────────────────────────────────────────────── */

.pew-pay-list { padding: 0.5rem 0; }

.pew-pay-row {
  display: flex;
  align-items: center;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--color-cream);
  transition: background 0.15s ease, opacity 0.3s ease;
}

.pew-pay-row--paid {
  background: rgba(122, 155, 109, 0.04);
  padding: 0.4rem 1rem;
  min-height: 44px;
  opacity: 0.6;
}
.pew-pay-row--paid span,
.pew-pay-row--paid strong { font-size: 0.85rem; }

.pew-pay-row--flagged { background: rgba(212, 162, 78, 0.06); }

/* ── Entity divider (between groups in Pay stage) ──────────────────────── */
.pew-entity-divider {
  padding: 0.35rem 1rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-sandstone, #a1887f);
  background: var(--color-cream, #faf8f5);
  border-top: 1px solid var(--border-color, #e0e0e0);
  border-bottom: 1px solid var(--border-color, #e0e0e0);
  position: sticky;
  top: 60px;
  z-index: 10;
}

/* ── Entity header (enhanced divider with select-all + live stats) ─────── */

.pew-entity-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 1rem;
  background: var(--color-cream, #faf8f5);
  border-top: 1px solid var(--border-color, #e0e0e0);
  border-bottom: 1px solid var(--border-color, #e0e0e0);
  position: sticky;
  top: 60px;
  z-index: 10;
}
.pew-entity-select-all {
  display: flex;
  align-items: center;
  cursor: pointer;
  flex-shrink: 0;
}
.pew-entity-select-all input[type="checkbox"] {
  width: 14px;
  height: 14px;
  cursor: pointer;
  accent-color: var(--color-sage, #7cb342);
}
.pew-entity-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-sandstone, #a1887f);
}
.pew-entity-stats {
  margin-left: auto;
  display: flex;
  gap: 0.75rem;
  font-size: 0.7rem;
  white-space: nowrap;
}
.pew-entity-stat--paid {
  color: var(--color-sage, #7cb342);
  display: flex;
  align-items: center;
  gap: 0.2rem;
}
.pew-entity-stat--remaining {
  color: var(--color-sandstone, #a1887f);
}

/* ── Row checkbox ────────────────────────────────────────────────────────── */

.pew-row-checkbox {
  width: 15px;
  height: 15px;
  cursor: pointer;
  accent-color: var(--color-sage, #7cb342);
  flex-shrink: 0;
}

/* ── Row focused & selected states ───────────────────────────────────────── */

.pew-pay-row--focused {
  outline: 2px solid var(--color-sage, #7cb342);
  outline-offset: -2px;
  background: rgba(124, 179, 66, 0.04);
}
.pew-pay-row--selected {
  background: rgba(124, 179, 66, 0.06);
}
.pew-pay-row--focused.pew-pay-row--selected {
  background: rgba(124, 179, 66, 0.08);
}

/* ── Keyboard hint ───────────────────────────────────────────────────────── */

.pew-kbd-hint {
  margin-left: auto;
  font-size: 0.65rem;
  color: var(--color-sandstone, #a1887f);
  display: flex;
  align-items: center;
  gap: 0.3rem;
  white-space: nowrap;
}
.pew-kbd-hint kbd {
  display: inline-block;
  background: var(--color-cream, #faf8f5);
  border: 1px solid var(--color-latte, #e0d5c8);
  border-radius: 3px;
  padding: 0 0.3rem;
  font-size: 0.6rem;
  font-family: inherit;
  line-height: 1.5;
}
.pew-kbd-sep {
  color: var(--color-latte, #e0d5c8);
}

/* ── Bulk action bar ─────────────────────────────────────────────────────── */

.pew-bulk-bar {
  position: fixed;
  bottom: 5rem;
  left: 50%;
  transform: translateX(-50%) translateY(1rem);
  background: var(--color-white, #fff);
  border: 1px solid var(--color-sage, #7cb342);
  border-radius: 14px;
  padding: 0.6rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  box-shadow: 0 4px 24px rgba(44, 24, 16, 0.2);
  z-index: 55;
  opacity: 0;
  pointer-events: none;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.pew-bulk-bar--visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.pew-bulk-count {
  font-size: 0.8rem;
  color: var(--color-espresso, #2c1810);
}
.pew-bulk-pay-btn {
  background: var(--color-sage, #7cb342);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 0.45rem 1rem;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.pew-bulk-pay-btn:hover { background: #6d9e3a; }
.pew-bulk-pay-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.pew-bulk-clear {
  background: none;
  border: none;
  color: var(--color-sandstone, #a1887f);
  cursor: pointer;
  padding: 0.2rem;
  display: flex;
  align-items: center;
  border-radius: 4px;
  transition: color 0.15s;
}
.pew-bulk-clear:hover { color: var(--color-espresso, #2c1810); }

/* ── Type filter pills (W-2 / 1099) ──────────────────────────────────────── */
.pew-type-filter { display: flex; gap: 0.4rem; }
.pew-type-btn {
  padding: 0.3rem 0.7rem;
  border-radius: 20px;
  border: 1px solid var(--border-color, #e0e0e0);
  background: none;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-sandstone, #a1887f);
  cursor: pointer;
  transition: all 0.15s;
}
.pew-type-btn--active {
  background: var(--color-sage, #7cb342);
  border-color: var(--color-sage, #7cb342);
  color: #fff;
}

/* ── Mark-paid button (large tap target) ─────────────────────────────────── */

.pew-pay-btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid var(--color-latte, #d7ccc8);
  background: none;
  color: var(--color-sandstone, #a1887f);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: all 0.15s ease;
}

.pew-pay-btn:hover {
  border-color: var(--color-sage, #7cb342);
  color: var(--color-sage, #7cb342);
  background: rgba(122, 155, 109, 0.06);
}

@media (max-width: 600px) {
  .pew-pay-btn { width: 56px; height: 56px; }
}

/* ── Paid check icon ─────────────────────────────────────────────────────── */

.pew-paid-check {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-sage);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ── Flag button ─────────────────────────────────────────────────────────── */

.pew-flag-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: none;
  background: transparent;
  color: var(--color-taupe);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: color 0.15s ease;
}

.pew-flag-btn:hover { color: var(--color-amber); }
.pew-flag-btn--active { color: var(--color-amber); }

/* ── ACH reference input ─────────────────────────────────────────────────── */

.pew-ref-input {
  width: 90px;
  padding: 4px 8px;
  font-size: 0.75rem;
  font-family: var(--font-mono);
  color: var(--color-coffee);
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: 6px;
  outline: none;
  flex-shrink: 0;
}

.pew-ref-input:focus {
  border-color: var(--color-sage);
  background: var(--color-white);
}

/* ── Filter tabs ─────────────────────────────────────────────────────────── */

.pew-filter-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--color-cream);
  flex-wrap: wrap;
}

.pew-filter-tabs {
  display: flex;
  gap: 0.25rem;
}

.pew-filter-tab {
  padding: 0.4rem 0.75rem;
  font-size: 0.8rem;
  font-weight: 600;
  font-family: var(--font-primary);
  color: var(--color-sandstone);
  background: transparent;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.pew-filter-tab:hover { background: var(--color-ivory); color: var(--color-coffee); }

.pew-filter-tab--active {
  background: var(--color-ivory);
  color: var(--color-espresso);
}

/* ── Bottom sheet (payment confirmation) ─────────────────────────────────── */

.pew-sheet-overlay {
  position: fixed;
  inset: 0;
  background: rgba(44, 24, 16, 0.4);
  z-index: 50;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.pew-sheet {
  background: var(--color-white);
  border-radius: 16px 16px 0 0;
  padding: 1.5rem;
  width: 100%;
  max-width: 480px;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 -4px 24px rgba(44, 24, 16, 0.15);
}

.pew-sheet-enter { transition: transform 0.3s ease; }
.pew-sheet-leave { transition: transform 0.2s ease; }

/* ── Payment method selector ─────────────────────────────────────────────── */

.pew-method-option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.4rem 0.75rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-coffee);
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.pew-method-option:hover { border-color: var(--color-sandstone); }

.pew-method-option--active {
  background: var(--color-sage);
  color: #fff;
  border-color: var(--color-sage);
}

/* Inline method label (on unpaid rows) */
.pew-method-label {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 3px 8px;
    border-radius: 4px;
    border: 1px solid var(--border-color, #e0e0e0);
    background: none;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--color-sandstone, #a1887f);
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.15s;
}
.pew-method-label:hover {
    border-color: var(--color-sage, #7cb342);
    color: var(--color-sage, #7cb342);
}

/* Method picker dropdown */
.pew-method-picker {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 4px;
    background: var(--color-white, #fff);
    border: 1px solid var(--border-color, #e0e0e0);
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    z-index: 100;
    padding: 4px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 90px;
}
.pew-method-pick-btn {
    display: block;
    width: 100%;
    text-align: left;
    padding: 6px 10px;
    border: none;
    background: none;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-coffee, #6d4c41);
    cursor: pointer;
    border-radius: 4px;
    transition: background 0.1s;
}
.pew-method-pick-btn:hover { background: var(--color-cream, #faf8f5); }
.pew-method-pick-btn--active {
    background: rgba(122, 155, 109, 0.1);
    color: var(--color-sage, #7cb342);
}

/* ── Correction flow (fix paid entry amount) ────────────────────────────── */

.pew-correction-btn {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border: 1px solid var(--color-latte, #d7ccc8);
    border-radius: 4px;
    background: none;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--color-sandstone, #a1887f);
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.15s;
}
.pew-correction-btn:hover {
    border-color: var(--color-sage, #7cb342);
    color: var(--color-sage, #7cb342);
    background: rgba(122, 155, 109, 0.06);
}
.pew-correction-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.pew-correction-modal {
    background: var(--color-white, #fff);
    border-radius: 12px;
    padding: 1.5rem;
    width: 100%;
    max-width: 420px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}

/* ── Undo snackbar ───────────────────────────────────────────────────────── */

.pew-undo-snackbar {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-espresso);
  color: #fff;
  padding: 0.75rem 1.25rem;
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.9rem;
  font-weight: 500;
  box-shadow: 0 4px 20px rgba(44, 24, 16, 0.25);
  z-index: 60;
  white-space: nowrap;
}

/* ── Void Run ────────────────────────────────────────────────────────────── */

.pew-run-actions {
  display: flex;
  justify-content: flex-end;
  padding: 0 0 0.5rem;
}
.pew-void-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  color: var(--color-sandstone);
  background: none;
  border: 1px solid var(--color-latte);
  border-radius: 6px;
  padding: 0.3rem 0.75rem;
  cursor: pointer;
  opacity: 0.6;
  transition: all 0.15s;
  font-family: inherit;
}
.pew-void-btn:hover {
  color: #c0392b;
  border-color: #c0392b;
  opacity: 1;
}
.pew-void-overlay {
  position: fixed;
  inset: 0;
  background: rgba(44, 24, 16, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.pew-void-modal {
  background: var(--color-white);
  border-radius: 14px;
  padding: 1.5rem;
  width: 440px;
  max-width: 90vw;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  border: 1px solid rgba(192, 57, 43, 0.25);
  box-shadow: 0 8px 40px rgba(44, 24, 16, 0.3);
}
.pew-void-warning {
  background: rgba(192, 57, 43, 0.06);
  border: 1px solid rgba(192, 57, 43, 0.3);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 0.8rem;
  color: #c0392b;
}
.pew-void-safe {
  background: rgba(124, 179, 66, 0.08);
  border: 1px solid rgba(124, 179, 66, 0.3);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 0.8rem;
  color: var(--color-sage, #7cb342);
}
.pew-btn--danger {
  background: #c0392b;
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 0.55rem 1.25rem;
  font-weight: 600;
  font-size: 0.85rem;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.pew-btn--danger:hover { background: #a93226; }
.pew-btn--danger:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

/* ── Locked-but-editable banner ─────────────────────────────────────────── */
.pew-locked-edit-banner {
  background: #f0f4ff;
  border: 1px solid #c7d7f9;
  border-radius: 10px;
  padding: 0.65rem 1rem;
  font-size: 0.85rem;
  color: #3b5bdb;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.pew-locked-edit-banner svg { flex-shrink: 0; stroke: #3b5bdb; }
.pew-locked-edit-return {
  margin-left: auto;
  color: #3b5bdb;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  font-size: 0.8rem;
}
.pew-locked-edit-return:hover { text-decoration: underline; }

/* ── Remove entry button ────────────────────────────────────────────────── */
.pew-remove-entry-btn {
  background: none;
  border: none;
  color: var(--color-sandstone, #a1887f);
  cursor: pointer;
  padding: 0.2rem 0.35rem;
  border-radius: 6px;
  opacity: 0.4;
  transition: all 0.15s;
  display: flex;
  align-items: center;
}
.pew-remove-entry-btn:hover {
  color: #ef4444;
  opacity: 1;
  background: #fef2f2;
}

/* ── Kiosk iMessage / Send ───────────────────────────────────────────────── */
.pew-kiosk-send {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 0.5rem 0 0;
}
.pew-imessage-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: #1c8ef9;
  color: #fff;
  border-radius: 10px;
  padding: 0.7rem 1.25rem;
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.15s;
  width: fit-content;
}
.pew-imessage-btn:hover { background: #0a7ae0; }
.pew-imessage-btn svg { stroke: #fff; flex-shrink: 0; }

.pew-kiosk-link-row {
  display: flex;
  gap: 0.5rem;
}
.pew-kiosk-link-input {
  flex: 1;
  font-size: 0.75rem !important;
  color: var(--color-coffee, #795548) !important;
  background: var(--color-ivory, #faf8f5) !important;
  cursor: text;
}
.pew-copy-btn {
  background: var(--color-ivory, #faf8f5);
  border: 1px solid var(--color-latte, #e0d5c8);
  border-radius: 6px;
  padding: 0.4rem 0.75rem;
  font-size: 0.8rem;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.15s;
  font-family: inherit;
  color: var(--color-espresso, #2c1810);
}
.pew-copy-btn:hover { background: var(--color-cream, #faf8f5); }

.pew-kiosk-advanced-toggle {
  font-size: 0.8rem;
  color: var(--color-sandstone, #a1887f);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  padding: 0;
  font-family: inherit;
}
.pew-kiosk-advanced-toggle:hover { color: var(--color-walnut, #5d4037); }

/* ── Fund card ───────────────────────────────────────────────────────────── */

.pew-fund-card {
  background: var(--color-white);
  border: 1px solid var(--color-latte);
  border-radius: 14px;
  padding: 2rem;
  box-shadow: var(--shadow-md);
}

/* ── Callouts ────────────────────────────────────────────────────────────── */

.pew-callout {
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 0.85rem;
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.pew-callout--warning {
  background: rgba(212, 162, 78, 0.1);
  border: 1px solid rgba(212, 162, 78, 0.25);
  color: var(--color-coffee);
}

/* ── Badges ──────────────────────────────────────────────────────────────── */

.pew-badge {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  border-radius: 6px;
}

.pew-badge--amber {
  background: rgba(212, 162, 78, 0.15);
  color: #9A7020;
}

.pew-badge--blue {
  background: rgba(107, 127, 163, 0.15);
  color: #4A5D7A;
}
.pew-badge--sage {
  background: rgba(122, 155, 109, 0.15);
  color: var(--color-sage, #7cb342);
}

/* ── Header ──────────────────────────────────────────────────────────────── */

.pew-header {
  padding: 0 0 1rem;
  margin-bottom: 0.5rem;
}

/* ── Status dot ──────────────────────────────────────────────────────────── */

.pew-status-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}

.pew-status-dot--draft { background: var(--color-sandstone); }
.pew-status-dot--review { background: var(--color-amber); }
.pew-status-dot--fund { background: var(--color-sage); }

/* ── Save status indicator ───────────────────────────────────────────────── */

.pew-save-status {
  font-size: 0.8rem;
  color: var(--color-sage);
  transition: opacity 0.3s ease;
}

.pew-save-status--error { color: var(--color-terracotta); }

/* ── Form elements ───────────────────────────────────────────────────────── */

.pew-form-group { margin-bottom: 1rem; }

.pew-form-label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-coffee);
  margin-bottom: 0.35rem;
}

.pew-inline-error {
  font-size: 0.85rem;
  color: var(--color-terracotta);
  padding: 0.5rem 0.75rem;
  background: rgba(199, 91, 57, 0.06);
  border-radius: 8px;
}

/* ── Search results (add payee) ──────────────────────────────────────────── */

.pew-search-result {
  padding: 0.5rem 0.75rem;
  cursor: pointer;
  border-radius: 6px;
  font-size: 0.9rem;
  color: var(--color-espresso);
  transition: background 0.1s ease;
}

.pew-search-result:hover { background: var(--color-ivory); }

/* ── Off-cycle / Add-payee panel ─────────────────────────────────────────── */

.pew-panel-overlay {
  position: fixed;
  inset: 0;
  background: rgba(44, 24, 16, 0.35);
  z-index: 40;
}

.pew-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: 380px;
  max-width: 90vw;
  height: 100%;
  background: var(--color-white);
  box-shadow: -4px 0 24px rgba(44, 24, 16, 0.12);
  z-index: 41;
  overflow-y: auto;
}

.pew-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--color-latte);
}

.pew-panel-body { padding: 1.25rem; }

.pew-panel-enter { transition: transform 0.3s ease; }
.pew-panel-leave { transition: transform 0.2s ease; }

/* ── Lock summary ────────────────────────────────────────────────────────── */

.pew-lock-summary {
  background: var(--color-ivory);
  border: 1px solid var(--color-latte);
  border-radius: 12px;
  padding: 1.5rem;
}

/* ── Mobile responsive ───────────────────────────────────────────────────── */

@media (max-width: 600px) {
  .pew-stage-bar { padding: 0.75rem 0 1.25rem; }
  .pew-stage-dot { width: 28px; height: 28px; font-size: 0.7rem; }
  .pew-stage-label { font-size: 0.55rem; }
  .pew-stage-line { max-width: 40px; }

  .pew-row { flex-wrap: wrap; gap: 0.5rem; padding: 0.75rem; }
  .pew-input { max-width: 120px; font-size: 16px; /* prevent iOS zoom */ }

  .pew-footer { padding: 0.6rem 0.75rem; }
  .pew-footer-inner { flex-direction: column; gap: 0.5rem; text-align: center; }
  .pew-footer-stats { flex-wrap: wrap; justify-content: center; }

  .pew-pay-row { padding: 0.75rem; }
  .pew-pay-progress { padding: 0.6rem 0.75rem; }
  .pew-pay-progress-stats { font-size: 0.75rem; }

  .pew-filter-row { padding: 0.5rem 0.75rem; }
  .pew-filter-tab { padding: 0.35rem 0.5rem; font-size: 0.75rem; }

  .pew-sheet { padding: 1.25rem; border-radius: 14px 14px 0 0; }
  .pew-undo-snackbar { bottom: 1rem; font-size: 0.85rem; padding: 0.6rem 1rem; }

  .pew-fund-card { padding: 1.25rem; }
  .pew-panel { width: 100%; max-width: 100vw; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Directory — Status Confirmation Modal + Dirty Row + Sync Prompt
   ═══════════════════════════════════════════════════════════════════════════ */

/* Dirty row accent — unsaved changes */
.dir-row--dirty { border-left: 3px solid #f59e0b !important; }
.dir-save-dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  margin-left: 4px; vertical-align: middle;
}
.dir-save-dot--saving { background: #f59e0b; animation: dir-pulse 1s infinite; }
.dir-save-dot--saved  { background: var(--color-sage, #7cb342); }
.dir-save-dot--error  { background: #ef4444; }
@keyframes dir-pulse {
  0%, 100% { opacity: 0.4; }
  50%      { opacity: 1; }
}

/* Status confirmation modal */
.dir-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.45);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  animation: dir-fade-in 0.15s ease;
}
@keyframes dir-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.dir-modal-card {
  background: var(--card-bg, #fff);
  border-radius: 14px;
  padding: 1.5rem 1.75rem;
  max-width: 440px;
  width: 92%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.25);
  animation: dir-slide-up 0.2s ease;
}
@keyframes dir-slide-up {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dir-modal-title {
  font-size: 1.1rem; font-weight: 700;
  color: var(--color-espresso, #3e2723);
  margin: 0 0 0.75rem 0;
}
.dir-modal-body {
  color: var(--color-walnut, #795548);
  font-size: 0.9rem;
  margin-bottom: 1rem;
  line-height: 1.5;
}
.dir-modal-warning {
  background: #fef3c7;
  border: 1px solid #f59e0b;
  border-radius: 8px;
  padding: 0.75rem 1rem;
  display: flex; gap: 0.5rem; align-items: flex-start;
  margin-bottom: 1rem;
  font-size: 0.82rem;
  color: #92400e;
}
.dir-modal-warning svg { flex-shrink: 0; margin-top: 1px; }
.dir-modal-options {
  display: flex; flex-direction: column;
  gap: 0.5rem; margin-bottom: 1.25rem;
}
.dir-modal-radio {
  display: flex; gap: 0.75rem; align-items: flex-start;
  padding: 0.65rem 0.85rem;
  border: 1.5px solid var(--border-color, #e0e0e0);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.dir-modal-radio:hover { background: rgba(124,179,66,0.04); }
.dir-modal-radio:has(input:checked) {
  border-color: var(--color-sage, #7cb342);
  background: rgba(124,179,66,0.06);
}
.dir-modal-radio input[type="radio"] {
  margin-top: 3px; accent-color: var(--color-sage, #7cb342);
}
.dir-modal-radio-label {
  font-size: 0.85rem; font-weight: 600;
  color: var(--color-espresso, #3e2723);
}
.dir-modal-radio-sub {
  display: block; font-size: 0.75rem;
  color: var(--color-walnut, #795548);
  margin-top: 2px;
}
.dir-modal-actions {
  display: flex; gap: 0.5rem;
  justify-content: flex-end;
  padding-top: 0.25rem;
}
.dir-modal-btn {
  padding: 0.5rem 1.1rem;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: opacity 0.15s;
}
.dir-modal-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.dir-modal-btn--cancel {
  background: var(--border-color, #e0e0e0);
  color: var(--color-walnut, #795548);
}
.dir-modal-btn--confirm {
  background: var(--color-sage, #7cb342);
  color: #fff;
}
.dir-modal-btn--danger {
  background: #ef4444;
  color: #fff;
}

/* Sync prompt — inline banner below row */
.dir-sync-prompt {
  background: #f0fdf4;
  border: 1px solid var(--color-sage, #7cb342);
  border-radius: 8px;
  padding: 0.6rem 1rem;
  margin: 0.25rem 0 0.5rem 0;
  display: flex; align-items: center; gap: 0.75rem;
  font-size: 0.82rem;
  color: var(--color-espresso, #3e2723);
  animation: dir-slide-down 0.2s ease;
}
@keyframes dir-slide-down {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dir-sync-actions {
  display: flex; gap: 0.4rem; margin-left: auto; flex-shrink: 0;
}
.dir-btn-xs {
  padding: 0.25rem 0.6rem;
  font-size: 0.72rem;
  font-weight: 600;
  border-radius: 6px;
  cursor: pointer;
  border: none;
  transition: opacity 0.15s;
}
.dir-btn-xs--primary {
  background: var(--color-sage, #7cb342);
  color: #fff;
}
.dir-btn-xs--ghost {
  background: transparent;
  color: var(--color-walnut, #795548);
  border: 1px solid var(--border-color, #e0e0e0);
}

/* ═══════════════════════════════════════════════════════════════════════════
   Manager Portal — Session Banner + Expiry Timer
   ═══════════════════════════════════════════════════════════════════════════ */

.pew-mgr-banner {
  background: #4a3728;
  border-bottom: 2px solid #f59e0b;
  color: #fbbf24;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  padding: 0.5rem 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
  position: sticky;
  top: 0;
  z-index: 100;
  width: 100%;
  box-sizing: border-box;
}
.pew-mgr-banner .pew-sep { color: #92400e; }

.pew-session-expiry { color: #fbbf24; }
.pew-session-expiry.expiring {
  color: #f87171;
  animation: pew-pulse-expiry 1s infinite;
}
@keyframes pew-pulse-expiry {
  0%, 100% { opacity: 0.6; }
  50%      { opacity: 1; }
}

/* Disabled stage buttons with tooltip */
.pew-btn--disabled {
  opacity: 0.45;
  cursor: not-allowed;
  position: relative;
}
.pew-btn--disabled:hover::after {
  content: attr(title);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-espresso, #3e2723);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 400;
  padding: 0.35rem 0.6rem;
  border-radius: 6px;
  white-space: nowrap;
  z-index: 200;
  pointer-events: none;
}

/* ── W-2 Gross-to-Net Breakdown ────────────────────────────────────────────── */

.pew-w2-inline {
  margin-top: 6px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.pew-w2-net-line {
  font-size: 0.82rem;
  color: var(--color-sage, #7cb342);
  font-weight: 600;
}
.pew-w2-net-line strong {
  font-size: 0.95rem;
}
.pew-w2-breakdown-toggle {
  font-size: 0.7rem;
  color: var(--color-sandstone, #8d7b6a);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  padding: 0;
  line-height: 1;
}
.pew-w2-breakdown-toggle:hover {
  color: var(--color-espresso, #3e2723);
}
.pew-w2-breakdown {
  background: var(--color-ivory, #f5f0eb);
  border-radius: 8px;
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 4px;
}
.pew-deduction-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--color-sandstone, #8d7b6a);
}
.pew-deduction-row--total {
  border-top: 1px solid var(--color-latte, #d4c5b5);
  padding-top: 5px;
  font-weight: 600;
  color: #c62828;
}
.pew-deduction-row--net {
  font-weight: 700;
  font-size: 0.82rem;
  color: var(--color-sage, #7cb342);
}
.pew-deduction-note {
  font-size: 0.65rem;
  color: var(--color-sandstone, #8d7b6a);
  margin-top: 3px;
  font-style: italic;
  line-height: 1.3;
}
