/* ===========================================================
   MedVitaal Nordic Serenity overrides + Bootstrap-bridge.
   Past de huisstijl-tokens toe op Bootstrap-componenten zodat de
   wizard-modal, formulieren en bestaande knoppen consistent zijn.
   =========================================================== */

/* Knoppen alignen met Bootstrap btn-classes.
   We overschrijven zowel direct background-color als de Bootstrap CSS-vars
   (--bs-btn-bg etc.) omdat Bootstrap 5 die intern gebruikt; alleen background-color
   zetten laat hover/active states soms terugvallen op het Bootstrap-blauw. */
.btn-primary,
.btn-primary:focus {
  --bs-btn-bg: var(--green-700);
  --bs-btn-border-color: var(--green-700);
  --bs-btn-color: var(--paper);
  /* Hover op green-700 i.p.v. green-600: wit op green-600 = 3.96:1 (zakt onder WCAG AA);
     wit op green-700 = 6.37:1. Hover-feedback komt van translateY + shadow, niet van een
     lichtere groen. Geldt ook voor de bespoke .btn--primary (zie nordic-serenity.css). */
  --bs-btn-hover-bg: var(--green-700);
  --bs-btn-hover-border-color: var(--green-700);
  --bs-btn-hover-color: var(--paper);
  --bs-btn-active-bg: var(--green-700);
  --bs-btn-active-border-color: var(--green-700);
  --bs-btn-active-color: var(--paper);
  --bs-btn-disabled-bg: var(--green-700);
  --bs-btn-disabled-border-color: var(--green-700);
  --bs-btn-disabled-color: var(--paper);
  background-color: var(--green-700);
  border-color: var(--green-700);
  color: var(--paper);
  border-radius: var(--radius-pill);
  font-weight: 600;
  padding: 0.7em 1.5em;
}
.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus-visible {
  background-color: var(--green-700);
  border-color: var(--green-700);
  color: var(--paper);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
.btn-outline-secondary,
.btn-outline-secondary:focus {
  color: var(--navy-900);
  border-color: var(--line);
  background: var(--paper);
  border-radius: var(--radius-pill);
  font-weight: 600;
}
.btn-outline-secondary:hover {
  background: var(--cream);
  border-color: var(--navy-900);
  color: var(--navy-900);
}
/* Brand-bridge the accent outline buttons so a stray btn-outline-primary
   (Bootstrap blue) or btn-outline-success can never render off-brand again:
   both become a green-outline button that fills with brand green on hover. */
.btn-outline-primary,
.btn-outline-primary:focus,
.btn-outline-success,
.btn-outline-success:focus {
  --bs-btn-color: var(--green-700);
  --bs-btn-border-color: var(--green-700);
  --bs-btn-hover-bg: var(--green-700);
  --bs-btn-hover-border-color: var(--green-700);
  --bs-btn-hover-color: var(--paper);
  --bs-btn-active-bg: var(--green-600);
  --bs-btn-active-border-color: var(--green-600);
  color: var(--green-700);
  border-color: var(--green-700);
  background: transparent;
  border-radius: var(--radius-pill);
  font-weight: 600;
}
.btn-outline-primary:hover,
.btn-outline-primary:active,
.btn-outline-primary:focus-visible,
.btn-outline-success:hover,
.btn-outline-success:active,
.btn-outline-success:focus-visible {
  background: var(--green-700);
  border-color: var(--green-700);
  color: var(--paper);
  box-shadow: var(--shadow-sm);
}
.btn-lg {
  padding: 1em 1.8em;
  font-size: 1.05rem;
}

/* Forms - tekstvelden en checkboxes */
.form-control,
.form-select {
  border: 2px solid var(--line);
  border-radius: var(--radius-sm);
  font-family: var(--sans);
  color: var(--navy-900);
  background: var(--cream);
  padding: 0.7em 1em;
}
.form-control:focus,
.form-select:focus {
  border-color: var(--green-700);
  background: var(--paper);
  box-shadow: 0 0 0 4px var(--green-100);
}
.form-control-lg {
  padding: 1em 1.2em;
  font-size: 1.1rem;
}
.form-label {
  font-weight: 600;
  color: var(--ink-700);
  margin-bottom: 0.4em;
}
.form-text {
  color: var(--ink-500);
}
.form-check-input {
  width: 1.2em;
  height: 1.2em;
  border-radius: 6px;
  border: 2px solid var(--line);
  cursor: pointer;
}
.form-check-input:checked {
  background-color: var(--green-700);
  border-color: var(--green-700);
}
/* Step 3 safety questions render as branded toggle switches (form-switch) */
/* Label on the left, toggle on the right (after the label text) */
.form-switch {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding-left: 0;
}
.form-switch .form-check-label {
  flex: 1 1 auto;
}
.form-switch .form-check-input {
  flex: 0 0 auto;
  width: 2.5em;
  height: 1.4em;
  margin-top: 0.15em;
  margin-left: 0;
  border-radius: 2em;
  background-color: var(--line);
  border-color: var(--line);
  /* Solid white knob, visible in both on and off states */
  --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}
.form-switch .form-check-input:not(:checked):not(:focus) {
  --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}
.form-switch .form-check-input:checked {
  background-color: var(--green-700);
  border-color: var(--green-700);
}
.form-switch .form-check-input:focus {
  border-color: var(--green-700);
  box-shadow: 0 0 0 0.2rem rgba(27, 107, 90, 0.2);
  --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}
.form-check-label {
  font-weight: 500;
  color: var(--ink-700);
  cursor: pointer;
}
.invalid-feedback {
  color: var(--danger);
  font-size: 0.88rem;
}

/* Wizard modal styling */
.mv-wizard {
  background: var(--paper);
  border-radius: var(--radius-lg);
}
.mv-wizard .wizard-step {
  display: none;
}
.mv-wizard .wizard-step.active {
  display: block;
}
#wizardStepIndicator {
  font-weight: 600;
  color: var(--ink-500);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.76rem;
}

/* Modal extras */
.modal-content {
  border: 0;
  border-radius: var(--radius-lg);
  background: var(--paper);
  box-shadow: var(--shadow-lg);
}
.modal-header .btn-close:focus {
  box-shadow: 0 0 0 4px var(--green-100);
}

/* Alerts in Nordic Serenity tones */
.alert {
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  padding: 1em 1.2em;
}
.alert-info {
  background: var(--blue-100);
  border-color: var(--blue-300);
  color: var(--navy-700);
}
.alert-success {
  background: var(--green-100);
  border-color: var(--green-300);
  color: var(--green-700);
}
.alert-warning {
  background: var(--peach-100);
  border-color: var(--peach-300);
  color: #5a4a78;
}
.alert-danger {
  background: var(--rose-100);
  border-color: var(--danger);
  color: var(--rose-700);
}

/* Utility classes voor MedVitaal */
.bg-light {
  background: var(--cream) !important;
}
.text-primary {
  color: var(--green-700) !important;
}
.text-muted {
  color: var(--ink-500) !important;
}
.rounded-3 {
  border-radius: var(--radius) !important;
}
.shadow-lg {
  box-shadow: var(--shadow-lg) !important;
}

/* Container fluid for wizard breath room */
.mv-wizard .invalid-feedback.d-block {
  display: block !important;
}

/* Legal page content styling */
.legal-content {
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 4vw, 56px);
  box-shadow: var(--shadow-sm);
}
.legal-content h2 {
  font-size: 1.6rem;
  margin: 2em 0 .6em;
  color: var(--navy-900);
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content h3 {
  font-size: 1.2rem;
  margin: 1.6em 0 .4em;
  color: var(--green-700);
}
.legal-content h4 {
  font-size: 1.02rem;
  margin: 1.2em 0 .3em;
  color: var(--navy-700);
}
.legal-content p, .legal-content li {
  color: var(--ink-700);
  font-size: 1rem;
  line-height: 1.75;
}
.legal-content ul, .legal-content ol {
  margin: 0 0 1em 1.4em;
}
.legal-content hr {
  border: 0;
  border-top: 1px solid var(--line);
  margin: 2.5em 0;
}
.legal-content a {
  color: var(--green-700);
  text-decoration: underline;
}
.legal-content .note {
  background: var(--peach-50);
  border-left: 4px solid var(--peach-300);
  padding: 1em 1.2em;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 1.5em 0;
}
.legal-content .last-updated {
  margin-top: 3em;
  color: var(--ink-500);
  font-size: .9rem;
  text-align: right;
}

/* ===========================================================
   Layout helpers - vervangen inline styles uit templates
   =========================================================== */

/* Sub-page hero (smaller padding dan home hero) */
.hero--compact {
  padding: clamp(56px, 7vw, 96px) 0;
}

/* Single-column hero (geen aside card) */
.hero__inner--single {
  grid-template-columns: 1fr;
}

.hero__copy--narrow {
  max-width: 760px;
}

.hero__copy--medium {
  max-width: 820px;
}

/* Team / usp grid in 2-koloms variant met smallere container */
.usp--narrow {
  max-width: 880px;
  margin: 0 auto;
}

/* ── Stoppen met roken pagina ── */

/* Light section variant on a white (paper) background */
.section--paper {
  padding: clamp(80px, 10vw, 130px) 0;
  background: var(--paper);
}

/* Process in three steps instead of the default four-column steps grid */
.steps--three {
  grid-template-columns: repeat(3, 1fr);
}

/* Two-column comparison (e.g. nicotine replacement vs medication) */
.compare {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 900px;
  margin: 0 auto;
}

.compare__card {
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
  box-shadow: var(--shadow-sm);
}

.compare__card h3 {
  margin: 0 0 0.6em;
}

.compare__card .price-card__list {
  margin: 0;
  padding: 16px 0 0;
  border-bottom: none;
}

/* Benefits list: centered, single column */
.voordelen__list {
  max-width: 720px;
  margin: 0 auto;
  border-top: none;
}

@media (max-width: 960px) {
  .steps--three {
    grid-template-columns: 1fr;
  }
}

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

/* Trustline-variant: verticaal gestapeld met grotere font */
.trustline--stacked {
  flex-direction: column;
  gap: 14px;
  align-items: flex-start;
}
.trustline--stacked li {
  font-weight: 700;
  font-size: 1rem;
}
.trustline--stacked a {
  color: inherit;
}

/* Breadcrumb (kleine link-trail boven page-header) */
.breadcrumb {
  list-style: none;
  padding: 0;
  margin: 0 0 0.8em;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 0.85rem;
  color: var(--ink-500);
}
.breadcrumb a {
  color: var(--green-700);
  font-weight: 600;
}
.breadcrumb [aria-current="page"] {
  color: var(--ink-700);
}

/* USP-card kleur-varianten (gebruikt op about-us team-cards) */
.usp__icon--lavender {
  background: var(--peach-100);
  color: #6A5B8E;
}
.usp__icon--green {
  background: var(--green-100);
}
.eyebrow--lavender {
  background: var(--peach-100);
  color: #6A5B8E;
}
.eyebrow--no-bottom {
  margin-bottom: 0.6em;
}

/* Gecentreerd tekstblok onder een section__head (gebruikt op about-us) */
.prose-center {
  margin: 0 auto;
  text-align: center;
}

/* Lijst zonder boven-/binnenrand wanneer hij bovenaan een price-card staat */
.price-card__list--flush {
  border-top: none;
  margin-top: 0;
  padding-top: 0;
}

/* CTA-balk binnen een section (gebruikt in our-method) */
.section__cta-center {
  text-align: center;
  margin-top: 3rem;
  position: relative;
  z-index: 1;
}
.section__cta-center .btn + .btn {
  margin-left: 12px;
}

/* Lichte tekst voor traject-sectie intro (kontrast op groen vlak) */
.section__sub--light {
  color: rgba(255, 255, 255, 0.8);
  font-size: 1.08rem;
}

/* BMI prefill summary in de wizard */
.bmi-summary {
  background: var(--green-50);
  border: 1px solid var(--green-100);
  border-radius: var(--radius);
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.bmi-summary__value {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--green-700);
}

/* Verberg lengte+gewicht inputs als BMI al bekend is via homepage */
.mv-wizard[data-prefilled-bmi="true"] .mv-bmi-extra {
  display: none;
}

/* Wizard error feedback - default hidden tot JS de tekst zet */
.mv-wizard .invalid-feedback[id$="Error"]:empty {
  display: none !important;
}

/* Wizard succes-icon (groot in done-step) */
.mv-wizard-icon {
  font-size: 4rem;
}

/* Wizard done-step alert breedte */
.mv-wizard-alert {
  max-width: 480px;
}

/* Impersonation banner (super-admin "switch user" indicator) */
.impersonation-banner {
  background: #dc3545;
  color: #ffffff;
  padding: 10px 20px;
  text-align: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  font-size: 14px;
}
.impersonation-banner a {
  color: #ffffff;
  margin-left: 20px;
  text-decoration: underline;
  font-weight: bold;
}
.impersonation-banner__spacer {
  height: 45px;
}

/* Footer logo wit-invertering (svg met currentColor wordt zo overschreven) */
.logo--light img {
  filter: brightness(0) invert(1);
}

/* Error/404 page hero actions gecentreerd */
.mv-hero__actions--center {
  justify-content: center;
}

/* Checkout-return page (na Mollie betaling) */
.mv-checkout-icon {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--green-700) 0%, var(--green-300) 100%);
  color: var(--paper);
  display: grid;
  place-items: center;
  margin: 0 auto 1.4rem;
  box-shadow: 0 12px 32px rgba(27, 107, 90, 0.25);
  font-size: 2.2rem;
}
.mv-checkout-next {
  margin: 2rem 0 1rem;
  text-align: left;
  background: var(--cream);
  border-radius: var(--radius);
  padding: 1.4rem 1.6rem;
}
.mv-checkout-next h5 {
  margin: 0 0 1rem;
  color: var(--navy-900);
  font-weight: 700;
}
.mv-checkout-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.mv-checkout-list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 0.5rem 0;
  color: var(--ink-700);
  font-size: 0.96rem;
}
.mv-checkout-list__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--green-700);
  color: var(--paper);
  display: grid;
  place-items: center;
}

/* ===========================================================
   MedVitaal modal - Nordic Serenity styling met eigen animatie.
   Vervangt de default Bootstrap modal-look met:
   - Slide-up + fade-in animatie (rust, niet "pop")
   - Decoratieve gradient bar bovenaan
   - Eyebrow-stijl step indicator
   - Grote pill-vormige close button
   - Ruime rounded corners en zachte schaduw
   =========================================================== */

.mv-modal {
  display: none;
}
.mv-modal.show {
  display: block;
}
.mv-modal .modal-backdrop {
  background: rgba(26, 37, 48, 0.55);
}

/* Backdrop overschrijven (Bootstrap injecteert .modal-backdrop in body) */
.modal-backdrop.show {
  background:
    radial-gradient(800px 600px at 100% 0%, rgba(184, 169, 209, 0.35) 0%, transparent 55%),
    radial-gradient(700px 500px at 0% 100%, rgba(123, 200, 184, 0.35) 0%, transparent 55%),
    rgba(26, 37, 48, 0.55);
  opacity: 1;
  backdrop-filter: blur(3px);
}

.mv-modal__dialog {
  max-width: 760px;
  margin: 1.5rem auto;
  pointer-events: none;
}
.mv-modal.show .mv-modal__dialog {
  pointer-events: auto;
}

/* Slide-up + fade-in animatie (eigen, geen Bootstrap fade) */
.mv-modal__content {
  position: relative;
  background: var(--paper);
  border: 0;
  border-radius: var(--radius-xl);
  box-shadow: 0 32px 80px rgba(26, 37, 48, 0.18), 0 8px 24px rgba(26, 37, 48, 0.06);
  overflow: hidden;
  opacity: 0;
  transform: translateY(40px) scale(0.98);
  transition: opacity 0.35s ease, transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}
.mv-modal.show .mv-modal__content {
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Decoratieve gradient bar bovenaan (groen → lavendel → blauw) */
.mv-modal__bar {
  height: 6px;
  background: linear-gradient(90deg, var(--green-700) 0%, var(--green-300) 30%, var(--peach-300) 65%, var(--blue-300) 100%);
}

/* Header: step indicator links, sluitknop rechts */
.mv-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 28px 0;
  position: relative;
}
.mv-modal__indicator {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  background: var(--green-100);
  color: var(--green-700);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  min-height: 28px;
}
.mv-modal__indicator:empty {
  visibility: hidden;
}
.mv-modal__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  background: var(--cream);
  color: var(--navy-900);
  border: 0;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.mv-modal__close:hover {
  background: var(--navy-900);
  color: var(--paper);
}
.mv-modal__close:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 4px var(--green-100);
}

.mv-modal__body {
  padding: 24px 28px 32px;
}

/* Wizard body styling (binnen modal) */
.mv-wizard {
  position: relative;
}
.mv-wizard__inner {
  padding: 0;
}
.mv-wizard h5 {
  font-family: var(--sans);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--navy-900);
  letter-spacing: -0.01em;
}
.mv-wizard .form-label {
  font-weight: 600;
  color: var(--navy-700);
}
.mv-wizard .form-check-label {
  color: var(--ink-700);
}

/* Geanimeerde step-transitie (kleine fade-up per stap) */
.mv-wizard .wizard-step {
  display: none;
  animation: mvStepIn 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.mv-wizard .wizard-step.active {
  display: block;
}
@keyframes mvStepIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 680px) {
  .mv-modal__dialog {
    margin: 0;
    max-width: 100%;
    min-height: 100vh;
  }
  .mv-modal__content {
    border-radius: 0;
    min-height: 100vh;
  }
  .mv-modal__body {
    padding: 20px 18px 28px;
  }
}

/* Auth-card (login / password reset) */
.mv-auth {
  min-height: calc(100vh - 200px);
  display: grid;
  place-items: center;
  padding: clamp(40px, 6vw, 80px) 0;
  background:
    radial-gradient(600px 400px at 100% 0%, var(--peach-100) 0%, transparent 60%),
    radial-gradient(500px 400px at 0% 100%, var(--green-100) 0%, transparent 60%),
    var(--cream);
}
.mv-auth__card {
  background: var(--paper);
  border-radius: var(--radius-xl);
  padding: clamp(32px, 4vw, 56px);
  box-shadow: var(--shadow-lg);
  width: 100%;
  max-width: 480px;
}
.mv-auth__card h1 {
  font-size: 1.7rem;
  margin: 0 0 .4em;
}
.mv-auth__card .lede {
  font-size: 1rem;
  margin-bottom: 1.5em;
}
.mv-auth__links {
  text-align: center;
  margin-top: 1.5em;
  font-size: .92rem;
  color: var(--ink-500);
}
.mv-auth__links a {
  color: var(--green-700);
  font-weight: 600;
}

/* Voedingswaarden — macroverhoudingsbalk op de dieetkaart (MEDVIT-18).
   Caloriebasis-aandelen worden als breedte gezet vanuit de template. */
.diet-macro-bar {
  display: flex;
  height: 6px;
  max-width: 240px;
  border-radius: 3px;
  overflow: hidden;
}
.diet-macro-bar > span {
  display: block;
  height: 100%;
}
.diet-macro-legend {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .15rem;
}
.diet-macro-dot {
  margin-right: .25rem;
  line-height: 1;
}
/* Macrokleuren uit de huisstijl: eiwit = groen, koolhydraten = mint, vet = blauw. */
.diet-macro-protein { background: var(--green-700); color: var(--green-700); }
.diet-macro-carbs   { background: var(--green-300); color: var(--green-300); }
.diet-macro-fat     { background: var(--blue-300);  color: var(--blue-300); }

/* Roterende motivatiequote (MEDVIT-22). Quotes liggen gestapeld op een vaste
   hoogte zodat de banner niet verspringt; de actieve quote fadet in. */
.quote-card {
  background: linear-gradient(135deg, var(--green-700) 0%, var(--green-600) 100%);
  color: #fff;
}
.quote-rotator {
  position: relative;
  min-height: 4.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.quote-rotator .quote-item {
  position: absolute;
  left: 0;
  right: 0;
  margin: 0;
  padding: 0 1rem;
  font-style: italic;
  font-size: 1.05rem;
  opacity: 0;
  transition: opacity .6s ease;
  pointer-events: none;
}
.quote-rotator .quote-item--active {
  opacity: 1;
  pointer-events: auto;
}
@media (prefers-reduced-motion: reduce) {
  .quote-rotator .quote-item { transition: none; }
}

/* Schema-browser — bladeren door dieet-/trainingsschema's van één doelgroep.
   Progressive enhancement: zonder JS staan alle .schema-slide onder elkaar
   (zichtbaar voor crawlers/PDF/toegankelijkheid) en blijft de navigatie verborgen.
   Na init voegt JS .schema-browser--js toe en wordt alleen het actieve schema
   getoond — een directe wissel (geen fade), anders dan de quote-rotator. */
.schema-browser--js .schema-slide { display: none; }
.schema-browser--js .schema-slide--active { display: block; }
/* Alleen in de no-JS gestapelde weergave krijgen volgende schema's ruimte ertussen;
   onder JS staat er nooit meer dan één tegelijk, dus geen marge. */
.schema-browser:not(.schema-browser--js) .schema-slide + .schema-slide { margin-top: 1.5rem; }

/* Subtiele wissel-animatie bij bladeren: het actieve schema schuift licht omhoog
   en faded in. Alleen onder JS en buiten reduced-motion. */
.schema-browser--js .schema-slide--active {
  animation: schema-slide-in .28s ease both;
}
@keyframes schema-slide-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .schema-browser--js .schema-slide--active { animation: none; }
}

/* Navigatie als één samenhangende pil i.p.v. losse knoppen + tekst. */
.schema-browser__nav {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  background: var(--green-50);
  border-radius: var(--radius-pill);
  padding: .2rem;
}
.schema-browser__btn {
  border: 0;
  background: transparent;
  color: var(--green-700);
  border-radius: 50%;
  width: 1.85rem;
  height: 1.85rem;
  line-height: 1;
  font-size: 1.2rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color .15s ease, color .15s ease, transform .15s ease;
}
.schema-browser__btn:hover {
  background: var(--green-600);
  color: var(--paper);
}
.schema-browser__btn:active { transform: scale(.92); }
/* Eigen focus-ring conform de huisstijlconventie (zie .mv-modal__close), zodat
   toetsenbordfocus zichtbaar verschilt van hover (WCAG 2.4.7). */
.schema-browser__btn:focus-visible {
  background: var(--green-600);
  color: var(--paper);
  outline: 0;
  box-shadow: 0 0 0 4px var(--green-100);
}
@media (prefers-reduced-motion: reduce) {
  .schema-browser__btn { transition: none; }
}
.schema-browser__counter {
  min-width: 2.75rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--ink-500);
  letter-spacing: .02em;
}
.schema-browser__counter .schema-browser__current { color: var(--green-700); }

.schema-slide__title {
  font-weight: 700;
  line-height: 1.2;
  color: var(--ink-700);
}

/* Maaltijdtype-chip in huisstijlgroen i.p.v. Bootstrap-grijs. */
.meal-row__type {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .03em;
  color: var(--green-700);
  background: var(--green-50);
  border: 1px solid var(--green-100);
  border-radius: var(--radius-pill);
  padding: .12rem .55rem;
}

/* Dagtotaal als rustige voettekst-paneel i.p.v. losse regel. */
.schema-totals {
  margin-top: 1rem;
  padding: .7rem .9rem;
  background: var(--green-50);
  border-radius: var(--radius-sm);
  font-size: .85rem;
  color: var(--ink-700);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .15rem .5rem;
}
.schema-totals__label {
  font-weight: 700;
  color: var(--green-700);
}
.schema-totals__kcal { font-weight: 700; }
.schema-totals__item { color: var(--ink-500); }

/* Zelf-selectie van de doelgroep. In de lege staat staat dit formulier in een
   gecentreerde kolom (mx-auto + max-width) zodat label/select/knop als één blok
   uitlijnen i.p.v. drie losse uitlijningen onder het gecentreerde icoon. */
.doelgroep-form {
  max-width: 22rem;
}

/* "Wijzig doelgroep": native <details>-disclosure waarmee de patiënt zijn dieet-
   of trainingsdoelgroep kan aanpassen zonder JS. De standaard-driehoek wordt
   verborgen; de summary leest als een rustige tekstlink in huisstijlgroen. */
.doelgroep-change {
  border-top: 1px solid var(--line);
  padding-top: .85rem;
}
.doelgroep-change > summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .85rem;
  font-weight: 600;
  color: var(--green-700);
  border-radius: var(--radius-sm);
}
.doelgroep-change > summary::-webkit-details-marker { display: none; }
.doelgroep-change > summary::before {
  content: "\f044"; /* fa-pen-to-square */
  font-family: "Font Awesome 6 Free", "Font Awesome 5 Free";
  font-weight: 900;
  font-size: .8em;
}
.doelgroep-change > summary:hover { color: var(--green-600); }
.doelgroep-change > summary:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 4px var(--green-100);
}

/* Motivatiequote als ondertitel onder de hero-begroeting (i.p.v. een losse
   kaart). Hergebruikt de quote-rotator fade, maar links uitgelijnd op één regel
   in huisstijl-groen i.p.v. de gecentreerde groene banner. */
.dashboard-quote {
  position: relative;
  min-height: 1.7rem;
  margin: -.25rem 0 1.5rem;
  justify-content: flex-start;
  color: var(--green-700);
  font-style: italic;
  font-size: 1.05rem;
}
.dashboard-quote .quote-item {
  padding: 0;
  text-align: left;
  font-size: 1.05rem;
}
.dashboard-quote__author {
  color: var(--ink-500);
  font-style: normal;
  font-size: .9rem;
}

/* Dashboard-zijbalk — 'Jouw cijfers'-lijst. De vier KPI's zijn samengevat
   tot compacte label/waarde-regels (label links, waarde rechts) i.p.v. losse
   display-cijfers, zodat ze in de smalle kolom passen. */
.stat-list .stat-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: .6rem 0;
  border-top: 1px solid var(--ink-100, rgba(0, 0, 0, .08));
}
.stat-list .stat-row:first-child {
  border-top: 0;
  padding-top: 0;
}
.stat-list .stat-label {
  color: var(--ink-500);
  font-size: .92rem;
}
.stat-list .stat-value {
  font-weight: 700;
  font-size: 1.15rem;
  text-align: right;
}
/* Voortgangsbalk-regel loopt door onder de '% naar doel'-regel: geen extra
   scheidingslijn of bovenmarge zodat balk en percentage bij elkaar horen. */
.stat-list .stat-row--bar {
  border-top: 0;
  padding-top: 0;
}

/* ===========================================================
   'Widget'-kaarten (luchtiger, iOS-achtig) — huisstijl
   Gedeelde class .app-cards op de portal-/app-pagina's (dashboard,
   instellingen, design-system) zodat de publieke site de Bootstrap-
   default kaarten houdt. Vervangt de grijze, tabel-achtige .card-
   header-balk door een transparante kop met een zacht getint icoon-
   squircle. Alle waarden uit nordic-serenity.css.
   =========================================================== */
.app-cards .card {
  border: 0;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
  background: var(--paper);
}
/* Header zonder grijze vulling: titel 'zweeft' boven de inhoud met een
   haarfijne, groen-getinte scheidingslijn i.p.v. een balk. */
.app-cards .card-header {
  background: transparent;
  border-bottom: 1px solid var(--green-50);
  padding: 1.1rem 1.25rem .75rem;
}
.app-cards .card-header h5 {
  display: flex;
  align-items: center;
  font-size: 1.05rem;
  color: var(--ink-700);
}
/* Leidend kop-icoon als zacht getint 'squircle' — geeft het iOS-widget gevoel
   binnen de huisstijl (groen-100 vlak, groen-700 glyph = AA-contrast). */
.app-cards .card-header h5 i:first-child {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.1rem;
  height: 2.1rem;
  margin-right: .65rem !important;
  border-radius: .7rem;
  background: var(--green-100);
  color: var(--green-700);
  font-size: .9rem;
}
.app-cards .card-body {
  padding: 1.25rem;
}
/* Tabel luchtiger: gedempte, kleine kolomkoppen i.p.v. zwarte vette
   tekst, en wat meer ademruimte per rij met haarfijne scheidingslijnen. */
.app-cards .table thead th {
  border-bottom: 1px solid var(--green-50);
  color: var(--ink-500);
  font-weight: 600;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.app-cards .table td {
  border-color: var(--green-50);
  padding-top: .7rem;
  padding-bottom: .7rem;
}

/* ===========================================================
   Publieke utility-classes (huisstijl)
   Eén bron voor semantische tekst-/badge-/knopklassen die in
   templates gebruikt worden maar nergens gedefinieerd waren.
   Tokens komen uit nordic-serenity.css. Contrast geverifieerd
   op WCAG AA (4.5:1) tegen --cream en --paper.
   =========================================================== */

/* Semantische tekstkleuren (stat-cijfers, gewichts-/BMI-indicatoren) */
.text-positive  { color: var(--green-700); }   /* 6.09:1 op cream */
.text-negative  { color: var(--danger); }      /* 5.23:1 op cream */
.text-attention { color: var(--amber-700); }   /* 4.82:1 op cream */

/* Merk-vulkleur (o.a. voortgangsbalk). Bootstrap .progress-bar zet
   background-color zonder !important, dus dit wint via laadvolgorde. */
.bg-brand { background-color: var(--green-700); }

/* Standaard "primary pill"-knop voor losse .btn-default-verwijzingen.
   Spiegelt de Bootstrap .btn-primary-behandeling (incl. AA-hover hierboven),
   NIET de bespoke .btn--primary, zodat er geen .btn-collision ontstaat. */
.btn-default {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5em;
  background-color: var(--green-700);
  border: 2px solid var(--green-700);
  color: var(--paper);
  border-radius: var(--radius-pill);
  font-weight: 600;
  padding: 0.7em 1.5em;
  text-decoration: none;
  cursor: pointer;
  transition: all .2s ease;
}
.btn-default:hover,
.btn-default:active,
.btn-default:focus-visible {
  background-color: var(--green-700);
  border-color: var(--green-700);
  color: var(--paper);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}

/* Publieke badges op huisstijl. Bootstrap's .bg-*-utilities dragen
   !important, dus specificiteit alleen verliest — daarom hier ook
   !important op background EN color. Spiegelt admin-custom.css:402-408. */
.badge.bg-success   { background-color: var(--green-700) !important; color: var(--paper) !important; }
.badge.bg-warning   { background-color: var(--peach-300) !important; color: var(--navy-900) !important; }
.badge.bg-danger    { background-color: var(--danger)    !important; color: var(--paper) !important; }
.badge.bg-info      { background-color: #2C5282          !important; color: var(--paper) !important; }
.badge.bg-secondary { background-color: var(--navy-700)  !important; color: var(--paper) !important; }
.badge.bg-primary   { background-color: var(--green-700) !important; color: var(--paper) !important; }
.badge.bg-dark      { background-color: var(--navy-900)  !important; color: var(--paper) !important; }
