:root {
  /* Elsődleges paletta — a megadott Clinical Teal alapból levezetve */
  --cv-primary-50:  #f0fafc;
  --cv-primary-100: #d9f1f7;
  --cv-primary-200: #a8dce8;
  --cv-primary-300: #75c8da;
  --cv-primary-400: #5fbad4;   /* Arculati horgony */
  --cv-primary-500: #3aa5c2;
  --cv-primary-600: #2887a0;
  --cv-primary-700: #1c6880;

  --cv-color-primary:       var(--cv-primary-400);
  --cv-color-primary-hover: var(--cv-primary-500);

  /* Neutrális színek */
  --cv-neutral-50:  #f7f9fa;
  --cv-neutral-100: #edf1f4;
  --cv-neutral-200: #d8e1e8;
  --cv-neutral-300: #b8c9d4;
  --cv-neutral-400: #7f9aaa;
  --cv-neutral-600: #354f5c;
  --cv-neutral-700: #23373f;
  --cv-neutral-800: #161f24;

  /* Visszajelzési státuszok */
  --cv-success-bg:  #e9f7ef;
  --cv-success:     #28a665;
  --cv-warning:     #e8a83c;

  /* Tipográfia */
  --cv-font-display: 'Sora', sans-serif;
  --cv-font-body:    'DM Sans', sans-serif;

  --cv-radius-md:  12px;
  --cv-shadow-xs:   0 1px 3px rgba(13,21,24,.06);
  --cv-shadow-primary: 0 4px 16px rgba(95,186,212,.35);
  --cv-transition: 150ms ease;
}

body {
  font-family: var(--cv-font-body);
  background-color: var(--cv-neutral-50);
  color: var(--cv-neutral-700);
}

h1, h2, h3, h4 {
  font-family: var(--cv-font-display);
  font-weight: 700;
  color: var(--cv-neutral-800);
}

/* Navigációs sáv */
.cv-navbar {
  background: #fff;
  border-bottom: 1px solid var(--cv-neutral-200);
  height: 65px;
}

.cv-navbar-brand {
  font-family: var(--cv-font-display);
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--cv-primary-700);
  text-decoration: none;
}
.cv-navbar-brand span { color: var(--cv-primary-400); }

/* =════════════════════════════════════════════════════
   OLDALSÁV (SIDEBAR) STÍLUSOK - JAVÍTVA ÉS KIEGÉSZÍTVE
   ═════════════════════════════════════════════════════ */
.cv-sidebar {
  background: #fff;
  border-right: 1px solid var(--cv-neutral-200);
  min-height: calc(100vh - 65px);
  padding: 1.5rem 1rem;
}

/* Szekció feliratok (pl: Klinikai modulok) */
.cv-sidebar-section {
  font-family: var(--cv-font-display);
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--cv-neutral-400);
  padding: 1.25rem 0.75rem 0.5rem;
}
.cv-sidebar-section:first-child {
  padding-top: 0;
}

/* A konkrét linkek formázása */
.cv-sidebar-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;              /* Távolság az ikon és a szöveg között */
  padding: 0.75rem 1rem;
  border-radius: var(--cv-radius-md);
  font-family: var(--cv-font-body);
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--cv-neutral-600);
  text-decoration: none;     /* Aláhúzás eltávolítása */
  transition: all var(--cv-transition);
}

/* Ikonok külön kiemelése a linkeken belül */
.cv-sidebar-link i {
  font-size: 1.1rem;
  color: var(--cv-neutral-400);
  transition: color var(--cv-transition);
}

/* Hover / Egér ráhúzás állapot */
.cv-sidebar-link:hover {
  background-color: var(--cv-neutral-50);
  color: var(--cv-neutral-800);
}
.cv-sidebar-link:hover i {
  color: var(--cv-neutral-700);
}

/* Aktív menüpont állapot (Amikor a pageId egyezik) */
.cv-sidebar-link.active {
  background-color: var(--cv-primary-50); /* Halvány klinikai teal háttér */
  color: var(--cv-primary-700);            /* Sötét teal szöveg */
  font-weight: 600;
}
.cv-sidebar-link.active i {
  color: var(--cv-primary-400);            /* Élénk teal ikon */
}

/* =════════════════════════════════════════════════════
   EGYÉB KOMPONENSEK
   ═════════════════════════════════════════════════════ */
.cv-stat-card {
  background: #fff;
  border: 1px solid var(--cv-neutral-200);
  border-radius: var(--cv-radius-md);
  box-shadow: var(--cv-shadow-xs);
  padding: 1.25rem 1.5rem;
  position: relative;
  overflow: hidden;
}
.cv-stat-card::after {
  content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%; background: var(--cv-color-primary);
}
.cv-stat-card.success::after { background: var(--cv-success); }
.cv-stat-card.warning::after { background: var(--cv-warning); }

.cv-stat-value {
  font-family: var(--cv-font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--cv-neutral-800);
}
.cv-stat-label {
  font-size: .8125rem; font-weight: 500; color: var(--cv-neutral-400); text-transform: uppercase; letter-spacing: .05em;
}

.cv-table-wrapper {
  background: #fff; border: 1px solid var(--cv-neutral-200); border-radius: var(--cv-radius-md); overflow: hidden;
}

.cv-status {
  display: inline-flex; align-items: center; gap: 6px; font-weight: 500; font-size: 0.85rem;
}
.cv-status::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.cv-status-active { color: var(--cv-success); }
.cv-status-pending { color: var(--cv-warning); }

.btn-primary {
  background: var(--cv-color-primary); border-color: var(--cv-color-primary); box-shadow: var(--cv-shadow-primary);
}
.btn-primary:hover {
  background: var(--cv-color-primary-hover); border-color: var(--cv-color-primary-hover);
}

/* Weekly schedule styles */
.cv-weekly-schedule { background: #fff; border: 1px solid var(--cv-neutral-200); border-radius: var(--cv-radius-md); padding: 1rem; }
.cv-weekly-grid { display: grid; grid-template-columns: 70px repeat(7, minmax(180px, 1fr)); gap: 1px; min-width: 1040px; background: var(--cv-neutral-200); }
.cv-weekly-time-column { border-right: 2px solid var(--cv-neutral-200); overflow: hidden; box-sizing: border-box; padding-top: 46px; }
.cv-time-slot { font-size: 0.75rem; text-align: center; color: var(--cv-neutral-500); padding: 2px 4px; height: 45px; border-bottom: 1px solid var(--cv-neutral-100); line-height: 1.2; }
.cv-day-header { font-weight: 700; text-align: center; padding: 10px 6px; background: var(--cv-primary-50); color: var(--cv-primary-700); font-size: 0.94rem; border-bottom: 1px solid var(--cv-neutral-200); }
.cv-slots { display: flex; flex-direction: column; gap: 0; min-height: 1170px; background: #fff; }
.cv-time-slot-cell { min-height: 45px; border-bottom: 1px solid var(--cv-neutral-100); background: #fff; position: relative; padding: 4px 6px; }
.cv-appointment-block { cursor: pointer; background: var(--cv-primary-500); color: #fff; padding: 6px 8px; border-radius: 6px; font-size: 0.8rem; line-height: 1.15; box-shadow: 0 2px 6px rgba(0,0,0,0.12); transition: transform 0.15s ease, box-shadow 0.15s ease; }
.cv-appointment-block:hover { transform: translateY(-1px); box-shadow: 0 4px 10px rgba(0,0,0,0.18); }
.cv-appointment-title { font-weight: 700; margin-top: 2px; }
.cv-appointment-meta { font-size: 0.75rem; opacity: 0.9; }
.cv-appointment-details { border: 1px solid var(--cv-neutral-200); border-radius: var(--cv-radius-md); background: var(--cv-neutral-50); padding: 1rem; }
.cv-appointment-details.d-none { display: none; }
.cv-appointment-details-header { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; border-bottom: 1px solid var(--cv-neutral-200); padding-bottom: 0.75rem; margin-bottom: 0.75rem; }
.cv-appointment-details-body p { margin-bottom: 0.45rem; }
.cv-appointment-details-actions .btn { white-space: nowrap; }
