/* ==========================================================
   HIJAMA-V3 · COMPONENTS  —  Layer 4 of 5
   Page-level primitives used across all templates.
   Depends on: tokens.css + base.css + shell.css
   ========================================================== */

/* ═══════════════════════════════════════════════════════════
   BADGE
   ═══════════════════════════════════════════════════════════ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-3);
  background: var(--brand-weak);
  color: var(--brand);
  border-radius: var(--r-pill);
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  line-height: 1;
  white-space: nowrap;
}
.badge          { color: var(--brand-on-weak); }
.badge--gold    { background: var(--accent-weak);  color: var(--accent-on-weak); }
.badge--success { background: var(--success-weak); color: var(--success-on-weak); }
.badge--danger  { background: var(--danger-weak);  color: var(--danger-on-weak); }
.badge--neutral { background: var(--bg-soft);      color: var(--text-on-soft); }

/* ═══════════════════════════════════════════════════════════
   CARD
   ═══════════════════════════════════════════════════════════ */

.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  min-width: 0;
  overflow-wrap: anywhere;
  transition:
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out);
}
.card--hover:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--border-strong);
}
.card--flat { box-shadow: none; }
.card--elev { box-shadow: var(--shadow-sm); }
.card--featured {
  border-color: var(--brand);
  box-shadow: var(--shadow-glow);
}

/* ═══════════════════════════════════════════════════════════
   SECTION
   ═══════════════════════════════════════════════════════════ */

.section {
  padding-block: clamp(var(--sp-16), 10vw, var(--sp-24));
}
.section--tight { padding-block: var(--sp-12); }
.section--hero  { padding-block: clamp(var(--sp-16), 12vw, var(--sp-32)); }
.section--surface {
  background: var(--bg-soft);
  border-block: 1px solid var(--border);
}
.section--muted {
  background: var(--bg-muted);
  border-block: 1px solid var(--border);
}
.section--dark {
  background: linear-gradient(135deg, var(--c-blue-900) 0%, var(--c-blue-800) 100%);
  color: var(--brand-on);
}
.section--dark h1,
.section--dark h2,
.section--dark h3 { color: var(--brand-on); }
.section--dark .section-head__eyebrow { color: var(--accent); }

.section-head {
  max-inline-size: 62ch;
  margin-inline: auto;
  text-align: center;
  margin-block-end: var(--sp-10);
}
.section-head--start {
  margin-inline: 0;
  text-align: start;
}
.section-head__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--brand);
  margin-block-end: var(--sp-3);
}
.section-head__title {
  font-size: var(--text-3xl);
  font-family: var(--font-display);
  letter-spacing: var(--tracking-tight);
}
.section-head__lead {
  font-size: var(--text-md);
  color: var(--text-soft);
  line-height: var(--leading-body);
  margin-block-start: var(--sp-4);
  margin-inline: auto;
  max-inline-size: 58ch;
}
.section-head--start .section-head__lead { margin-inline: 0; }

/* ═══════════════════════════════════════════════════════════
   PAGE HERO
   ═══════════════════════════════════════════════════════════ */

.page-hero {
  padding-block: clamp(var(--sp-12), 8vw, var(--sp-20)) var(--sp-12);
  /* Gebruikt alleen CSS-variabelen — dark mode cascade blijft intact. */
  background: linear-gradient(180deg, var(--bg-muted) 0%, var(--bg-soft) 60%, var(--bg) 100%);
  border-block-end: 1px solid var(--border);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 900px 500px at 12% 8%,  rgba(30, 64, 175, 0.20), transparent 60%),
    radial-gradient(ellipse 700px 400px at 88% 25%, rgba(59, 130, 246, 0.14), transparent 60%),
    radial-gradient(ellipse 500px 300px at 50% 100%, rgba(200, 161, 90, 0.06), transparent 70%);
  z-index: -1;
}
[data-theme='dark'] .page-hero::before {
  /* Origineel dark-pattern — unchanged. */
  background:
    radial-gradient(ellipse 800px 400px at 15% 10%, rgba(96, 165, 250, 0.12), transparent 60%),
    radial-gradient(ellipse 600px 300px at 85% 30%, rgba(59, 130, 246, 0.08), transparent 60%);
}
.page-hero__inner { max-inline-size: 780px; }
.page-hero h1 {
  font-size: var(--text-4xl);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin-block-start: var(--sp-4);
}
.page-hero h1 em {
  font-style: italic;
  color: var(--brand);
}
.page-hero__lead {
  font-size: var(--text-md);
  color: var(--text-soft);
  line-height: var(--leading-body);
  margin-block-start: var(--sp-5);
  max-inline-size: 62ch;
}
.page-hero__ctas {
  display: flex;
  gap: var(--sp-3);
  margin-block-start: var(--sp-8);
  flex-wrap: wrap;
}

/* Dual hero — voor homepage: praktijk-kaart + driver-kaart naast elkaar */
.hero-dual {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-block-start: var(--sp-8);
}
@media (min-width: 768px) {
  .hero-dual { grid-template-columns: 1fr 1fr; }
}
.hero-dual__card {
  padding: var(--sp-6);
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  transition:
    border-color var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
  text-decoration: none;
  color: var(--text);
}
.hero-dual__card:hover {
  border-color: var(--brand);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.hero-dual__icon {
  inline-size: 48px; block-size: 48px;
  display: grid; place-items: center;
  background: var(--brand-weak);
  color: var(--brand);
  border-radius: var(--r-md);
}
.hero-dual__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--text);
}
.hero-dual__sub {
  font-size: var(--text-sm);
  color: var(--text-soft);
  line-height: var(--leading-body);
}
.hero-dual__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-block-start: var(--sp-2);
  padding-block-start: var(--sp-3);
  border-block-start: 1px solid var(--border);
  font-size: var(--text-xs);
  color: var(--text-dim);
}
.hero-dual__arrow {
  inline-size: 18px; block-size: 18px;
  color: var(--brand);
  transition: transform var(--dur-fast) var(--ease-out);
}
.hero-dual__card:hover .hero-dual__arrow { transform: translateX(4px); }

/* ═══════════════════════════════════════════════════════════
   BREADCRUMB
   ═══════════════════════════════════════════════════════════ */

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
  font-size: var(--text-sm);
  color: var(--text-dim);
  padding: 0;
}
.breadcrumb li { display: inline-flex; align-items: center; }
.breadcrumb a {
  color: var(--text-soft);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.breadcrumb a:hover { color: var(--brand); }
.breadcrumb li + li::before {
  content: '›';
  margin-inline-end: var(--sp-2);
  color: var(--border-strong);
}
.breadcrumb [aria-current='page'] {
  color: var(--text);
  font-weight: var(--fw-medium);
}

/* ═══════════════════════════════════════════════════════════
   PROSE — long-read typography
   ═══════════════════════════════════════════════════════════ */

.prose {
  max-inline-size: 68ch;
  color: var(--text-soft);
  font-size: var(--text-md);
  line-height: var(--leading-body);
}
.prose > * + * { margin-block-start: var(--sp-5); }
.prose h2 {
  font-size: var(--text-2xl);
  color: var(--text);
  margin-block-start: var(--sp-10);
}
.prose h3 {
  font-size: var(--text-xl);
  color: var(--text);
  margin-block-start: var(--sp-8);
}
.prose p { max-inline-size: none; }
.prose ul, .prose ol {
  padding-inline-start: 1.5rem;
  list-style: disc;
}
.prose ol { list-style: decimal; }
.prose li + li { margin-block-start: var(--sp-2); }
.prose strong { color: var(--text); font-weight: var(--fw-semi); }
.prose a:not(.btn) {
  color: var(--brand);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.prose a:not(.btn):hover {
  color: var(--brand-hover);
  text-decoration-thickness: 2px;
}
/* Buttons in .prose behouden hun eigen kleur (niet overschrijven) */
.prose a.btn { text-decoration: none; }
.prose blockquote {
  padding: var(--sp-5) var(--sp-6);
  background: var(--bg-muted);
  border-inline-start: 3px solid var(--brand);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--text);
  line-height: var(--leading-snug);
}
.prose hr {
  border: 0;
  border-block-start: 1px solid var(--border);
  margin-block: var(--sp-10);
}

/* ═══════════════════════════════════════════════════════════
   SPLIT layout — content + sticky aside
   ═══════════════════════════════════════════════════════════ */

.split {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
  align-items: start;
}
@media (min-width: 960px) {
  .split {
    grid-template-columns: 1fr 320px;
    gap: var(--sp-12);
  }
}
.split__aside {
  padding: var(--sp-6);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}
@media (min-width: 960px) {
  .split__aside {
    position: sticky;
    inset-block-start: calc(var(--header-h) + var(--sp-5));
  }
}
.split__aside h3 {
  font-family: var(--font-body);
  font-size: var(--text-md);
  font-weight: var(--fw-semi);
}

/* ═══════════════════════════════════════════════════════════
   TREATMENT CARD
   ═══════════════════════════════════════════════════════════ */

.treatment-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-8) var(--sp-6) var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  min-width: 0;                       /* kritiek: laat card krimpen binnen grid-track */
  overflow-wrap: anywhere;            /* lange woorden als "Spanningsverlichting" breken */
  word-break: normal;
  transition:
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    border-color var(--dur-base);
}
.treatment-card h3,
.treatment-card__sub { overflow-wrap: anywhere; hyphens: auto; }
@media (max-width: 560px) {
  .treatment-card { padding: var(--sp-6) var(--sp-4) var(--sp-4); }
  .treatment-card h3 { font-size: var(--text-lg); }
  .treatment-card__price { font-size: var(--text-2xl); }
}
.treatment-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--brand);
}
.treatment-card--featured {
  border-color: var(--brand);
  box-shadow: 0 0 0 4px var(--brand-weak);
}
.treatment-card__badge {
  position: absolute;
  inset-block-start: calc(var(--sp-3) * -1);
  inset-inline-start: 50%;
  transform: translateX(-50%);
}
html[dir='rtl'] .treatment-card__badge { transform: translateX(50%); }
.treatment-card__sub {
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-dim);
}
.treatment-card h3 {
  font-size: var(--text-xl);
  font-family: var(--font-display);
}
.treatment-card__meta {
  display: flex;
  gap: var(--sp-3);
  align-items: baseline;
  margin-block-start: var(--sp-2);
}
.treatment-card__price {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  color: var(--brand);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
}
.treatment-card__duration {
  font-size: var(--text-sm);
  color: var(--text-dim);
}
.treatment-card__for {
  margin-block-start: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg-soft);
  border-radius: var(--r-md);
  font-size: var(--text-sm);
  color: var(--text-soft);
}
.treatment-card__list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-block: var(--sp-5) var(--sp-4);
  font-size: var(--text-sm);
  color: var(--text-soft);
  list-style: none;
}
.treatment-card__list li {
  position: relative;
  padding-inline-start: var(--sp-6);
}
.treatment-card__list li::before {
  content: '';
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 0.3em;
  inline-size: 14px; block-size: 14px;
  background: var(--brand);
  mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='black' d='M6 11.4L2.4 7.8l1.4-1.4L6 8.6l6.2-6.2 1.4 1.4z'/></svg>");
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='black' d='M6 11.4L2.4 7.8l1.4-1.4L6 8.6l6.2-6.2 1.4 1.4z'/></svg>");
  mask-size: contain; -webkit-mask-size: contain;
}
.treatment-card .btn { margin-block-start: auto; }

/* ═══════════════════════════════════════════════════════════
   CITY TILE
   ═══════════════════════════════════════════════════════════ */

.city-tile {
  position: relative;
  padding: var(--sp-6);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  text-decoration: none;
  color: var(--text);
  transition:
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out);
  overflow: hidden;
  isolation: isolate;
}
.city-tile::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--brand-weak) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
  z-index: -1;
}
.city-tile:hover {
  transform: translateY(-3px);
  border-color: var(--brand);
  box-shadow: var(--shadow-md);
  color: var(--text);
}
.city-tile:hover::before { opacity: 1; }
.city-tile__region {
  font-size: var(--text-xs);
  color: var(--text-dim);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  font-weight: var(--fw-medium);
}
.city-tile__name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--fw-semi);
  color: var(--text);
}
.city-tile__meta {
  font-size: var(--text-sm);
  color: var(--text-soft);
  margin-block-start: var(--sp-1);
}
.city-tile__arrow {
  position: absolute;
  inset-block-end: var(--sp-5);
  inset-inline-end: var(--sp-5);
  inline-size: 28px; block-size: 28px;
  display: grid; place-items: center;
  color: var(--brand);
  opacity: 0;
  transform: translateX(-6px);
  transition:
    opacity var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out);
}
html[dir='rtl'] .city-tile__arrow { transform: translateX(6px); }
.city-tile:hover .city-tile__arrow { opacity: 1; transform: translateX(0); }

/* ═══════════════════════════════════════════════════════════
   STAT
   ═══════════════════════════════════════════════════════════ */

.stat { text-align: center; }
.stat__num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--fw-bold);
  color: var(--brand);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  display: block;
}
.stat__label {
  display: block;
  margin-block-start: var(--sp-2);
  font-size: var(--text-xs);
  color: var(--text-on-soft);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  font-weight: var(--fw-semi);
}
.stat__sub {
  display: block;
  margin-block-start: var(--sp-1);
  font-size: var(--text-xs);
  color: var(--text-faint);
}

.stat-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-6);
  padding: var(--sp-8) var(--sp-4);
  background: var(--bg-muted);
  border-radius: var(--r-lg);
}
@media (min-width: 768px) {
  .stat-strip { grid-template-columns: repeat(4, 1fr); }
}

/* ═══════════════════════════════════════════════════════════
   PROCESS STEPS
   ═══════════════════════════════════════════════════════════ */

.process-steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  counter-reset: step;
}
@media (min-width: 640px) { .process-steps { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .process-steps { grid-template-columns: repeat(4, 1fr); } }

.process-step {
  position: relative;
  padding: var(--sp-8) var(--sp-6) var(--sp-6);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  counter-increment: step;
}
.process-step::before {
  content: counter(step, decimal-leading-zero);
  position: absolute;
  inset-block-start: var(--sp-4);
  inset-inline-end: var(--sp-4);
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: var(--fw-bold);
  color: var(--brand);
  opacity: 0.18;
  line-height: 1;
}
.process-step__icon {
  inline-size: 44px; block-size: 44px;
  display: grid; place-items: center;
  background: var(--brand-weak);
  color: var(--brand);
  border-radius: var(--r-md);
  margin-block-end: var(--sp-4);
}
.process-step h3 {
  font-size: var(--text-lg);
  font-family: var(--font-display);
  margin-block-end: var(--sp-2);
}
.process-step p {
  font-size: var(--text-sm);
  color: var(--text-soft);
  line-height: var(--leading-body);
}

/* ═══════════════════════════════════════════════════════════
   ACCORDION (native details)
   ═══════════════════════════════════════════════════════════ */

.accordion details {
  border-block-end: 1px solid var(--border);
  padding-block: var(--sp-4);
}
.accordion details:last-child { border-block-end: 0; }
.accordion summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-4);
  font-family: var(--font-body);
  font-weight: var(--fw-semi);
  font-size: var(--text-md);
  color: var(--text);
  transition: color var(--dur-fast);
}
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary:hover { color: var(--brand); }
.accordion summary::after {
  content: '+';
  font-size: 1.5rem;
  color: var(--brand);
  font-weight: var(--fw-regular);
  transition: transform var(--dur-base) var(--ease-out);
  flex-shrink: 0;
  line-height: 1;
}
.accordion details[open] summary::after {
  content: '−';
}
.accordion details > *:not(summary) {
  margin-block-start: var(--sp-3);
  color: var(--text-soft);
  line-height: var(--leading-body);
  font-size: var(--text-base);
}

/* ═══════════════════════════════════════════════════════════
   FORM primitives
   ═══════════════════════════════════════════════════════════ */

.form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.form__row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-4);
}
.form__hint {
  display: block;
  margin-block-start: var(--sp-1);
  font-size: var(--text-xs);
  color: var(--text-dim);
}
.form__error {
  display: block;
  margin-block-start: var(--sp-2);
  font-size: var(--text-sm);
  color: var(--danger);
}
.form__success {
  padding: var(--sp-4) var(--sp-5);
  background: var(--success-weak);
  border: 1px solid var(--success);
  border-radius: var(--r-md);
  color: var(--success);
  font-weight: var(--fw-medium);
}

.label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--text-soft);
  margin-block-end: var(--sp-2);
}

.input, .textarea, .select {
  display: block;
  inline-size: 100%;
  padding: var(--sp-3) var(--sp-4);
  min-block-size: 48px;
  font-family: var(--font-body);
  font-size: 16px;       /* iOS no-zoom */
  color: var(--text);
  background: var(--surface);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-md);
  transition:
    border-color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
}
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 4px var(--brand-weak);
}
.input::placeholder, .textarea::placeholder {
  color: var(--text-faint);
}
.textarea {
  min-block-size: 120px;
  resize: vertical;
  line-height: var(--leading-body);
}
.select {
  padding-inline-end: var(--sp-10);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2364748b'><path d='M4 6l4 4 4-4z'/></svg>");
  background-repeat: no-repeat;
  background-position: right var(--sp-3) center;
  background-size: 16px;
}
html[dir='rtl'] .select { background-position: left var(--sp-3) center; }

/* Checkbox-card (check) */
.check {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-4);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
  background: var(--surface);
}
.check:hover {
  border-color: var(--brand);
  background: var(--brand-weak);
}
.check input {
  margin-block-start: 3px;
  inline-size: 18px; block-size: 18px;
  accent-color: var(--brand);
  flex-shrink: 0;
}
.check__title {
  display: block;
  font-weight: var(--fw-semi);
  color: var(--text);
}
.check__desc {
  display: block;
  font-size: var(--text-sm);
  color: var(--text-soft);
  margin-block-start: 2px;
}
.check:has(input:checked) {
  border-color: var(--brand);
  background: var(--brand-weak);
}

/* Radio-card (pkg-option) for booking */
.pkg-select {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sp-3);
}
.pkg-option {
  position: relative;
  padding: var(--sp-5);
  background: var(--surface);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-lg);
  cursor: pointer;
  transition:
    transform var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out),
    background var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
}
.pkg-option:hover {
  border-color: var(--brand);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.pkg-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.pkg-option:has(input:checked) {
  border-color: var(--brand);
  background: var(--brand-weak);
  box-shadow: 0 0 0 4px var(--brand-weak);
}
.pkg-option__title {
  display: block;
  font-weight: var(--fw-semi);
  font-size: var(--text-md);
  color: var(--text);
}
.pkg-option__meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-block-start: var(--sp-3);
}
.pkg-option__price {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  color: var(--brand);
  line-height: 1;
}
.pkg-option__time {
  font-size: var(--text-sm);
  color: var(--text-dim);
}

/* ═══════════════════════════════════════════════════════════
   REVIEW CARD
   ═══════════════════════════════════════════════════════════ */

.review-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  box-shadow: var(--shadow-xs);
  transition:
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
}
.review-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
.review-card__stars {
  display: inline-flex;
  gap: 2px;
  color: var(--accent);
}
.review-card__stars svg { inline-size: 16px; block-size: 16px; }
.review-card__text {
  font-size: var(--text-base);
  color: var(--text-soft);
  line-height: var(--leading-body);
  flex: 1;
}
.review-card__meta {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding-block-start: var(--sp-4);
  border-block-start: 1px solid var(--border);
}
.review-card__avatar {
  inline-size: 40px; block-size: 40px;
  border-radius: 50%;
  background: var(--brand-weak);
  color: var(--brand);
  display: grid; place-items: center;
  font-weight: var(--fw-semi);
  font-size: var(--text-sm);
}
.review-card__name {
  font-weight: var(--fw-semi);
  font-size: var(--text-sm);
  color: var(--text);
}
.review-card__city {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-dim);
}

/* ═══════════════════════════════════════════════════════════
   CTA BAND
   ═══════════════════════════════════════════════════════════ */

.cta-band {
  padding-block: var(--sp-16);
  background: linear-gradient(135deg, var(--bg-muted) 0%, var(--surface) 100%);
  border-block-start: 1px solid var(--border);
  text-align: center;
}
.cta-band h2 {
  font-size: var(--text-3xl);
  font-family: var(--font-display);
}
.cta-band p {
  color: var(--text-soft);
  max-inline-size: 52ch;
  margin-inline: auto;
  margin-block-start: var(--sp-3);
}
.cta-band__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: center;
  margin-block-start: var(--sp-8);
}

/* ═══════════════════════════════════════════════════════════
   TIMELINE
   ═══════════════════════════════════════════════════════════ */

.timeline {
  position: relative;
  list-style: none;
  padding: 0;
}
.timeline::before {
  content: '';
  position: absolute;
  inset-inline-start: 13px;
  inset-block: 8px;
  inline-size: 2px;
  background: var(--border);
}
.timeline li {
  position: relative;
  padding-inline-start: var(--sp-10);
  padding-block-end: var(--sp-6);
}
.timeline li::before {
  content: '';
  position: absolute;
  inset-inline-start: 6px;
  inset-block-start: 8px;
  inline-size: 16px; block-size: 16px;
  border-radius: 50%;
  background: var(--brand);
  box-shadow: 0 0 0 4px var(--bg);
}
.timeline h3 {
  font-size: var(--text-md);
  font-family: var(--font-body);
  font-weight: var(--fw-semi);
  margin-block-end: var(--sp-1);
}
.timeline p {
  font-size: var(--text-sm);
  color: var(--text-soft);
  line-height: var(--leading-body);
}

/* ═══════════════════════════════════════════════════════════
   GRID utility classes
   ═══════════════════════════════════════════════════════════ */

.grid            { display: grid; gap: var(--sp-5); }
.grid > *        { min-width: 0; }  /* overflow-safety: grid children moeten kunnen krimpen */
.grid-2          { grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr)); }
.grid-3          { grid-template-columns: repeat(auto-fit, minmax(min(260px, 100%), 1fr)); }
.grid-4          { grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr)); }
.grid-fixed-2    { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-fixed-3    { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* ═══════════════════════════════════════════════════════════
   DATE STRIP — 14-day chip picker voor booking
   ═══════════════════════════════════════════════════════════ */
.date-strip {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(108px, 1fr));
  gap: var(--sp-2);
  padding: var(--sp-3);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  margin-block-start: var(--sp-2);
  /* Reserve vertical space so the 14-chip JS fill doesn't trigger CLS. */
  min-block-size: 192px;
}
.date-chip {
  appearance: none;
  -webkit-appearance: none;
  position: relative;
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--sp-2) var(--sp-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  cursor: pointer;
  text-align: center;
  line-height: 1.25;
  transition:
    background var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out),
    color var(--dur-fast) var(--ease-out),
    transform var(--dur-fast) var(--ease-out);
}
.date-chip:hover { border-color: var(--brand); color: var(--brand); transform: translateY(-1px); }
.date-chip:focus-visible { outline: 2px solid var(--border-focus); outline-offset: 2px; }
.date-chip.is-active {
  background: var(--brand);
  color: var(--brand-on);
  border-color: var(--brand);
  box-shadow: 0 6px 16px rgba(30,64,175,0.3);
}
.date-chip--sunnah { border-color: var(--accent); border-width: 1.5px; }
.date-chip--sunnah.is-active { box-shadow: 0 6px 16px rgba(245,158,11,0.35); }
.date-chip__day { display: block; white-space: nowrap; }
.date-chip__badge {
  position: absolute;
  top: -6px; right: -6px;
  width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent);
  color: var(--c-ink-900);
  border-radius: 50%;
  font-size: 10px;
  font-weight: var(--fw-bold);
  box-shadow: 0 2px 4px rgba(0,0,0,0.15);
}
.form__hint__action {
  appearance: none;
  background: none;
  border: 0;
  color: var(--brand);
  font: inherit;
  font-weight: var(--fw-semi);
  cursor: pointer;
  padding: 0;
  margin-left: var(--sp-2);
  text-decoration: underline;
}
@media (max-width: 480px) {
  .date-strip { grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); }
}

/* ═══════════════════════════════════════════════════════════
   SLOT GRID — time-slot chips for booking (LEGACY — time is now a <select>)
   ═══════════════════════════════════════════════════════════ */
.slot-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
  gap: var(--sp-2);
  padding: var(--sp-3);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  min-height: 64px;
  align-content: start;
}
.slot-grid__hint {
  grid-column: 1 / -1;
  margin: 0;
  padding: var(--sp-3);
  text-align: center;
  color: var(--text-on-soft);
  font-size: var(--text-sm);
}
.slot-chip {
  appearance: none;
  -webkit-appearance: none;
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--sp-2) var(--sp-1);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  font-variant-numeric: tabular-nums;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.slot-chip:hover  { border-color: var(--brand); color: var(--brand); transform: translateY(-1px); }
.slot-chip:focus-visible { outline: 2px solid var(--border-focus); outline-offset: 2px; }
.slot-chip.is-active {
  background: var(--brand);
  color: var(--brand-on);
  border-color: var(--brand);
  box-shadow: 0 4px 12px rgba(30,64,175,0.25);
}
@media (max-width: 480px) {
  .slot-grid { grid-template-columns: repeat(auto-fill, minmax(64px, 1fr)); gap: var(--sp-1); padding: var(--sp-2); }
}

/* ═══════════════════════════════════════════════════════════
   INFO BOX — for tips, warnings, callouts
   ═══════════════════════════════════════════════════════════ */

.info-box {
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-md);
  border: 1px solid;
  font-size: var(--text-sm);
  line-height: var(--leading-body);
}
.info-box--info    { background: var(--brand-weak);  border-color: var(--border-brand); color: var(--brand-on-weak); }
.info-box--sunnah  { background: var(--accent-weak); border-color: var(--c-gold-300);   color: var(--accent-on-weak); }
.info-box--warn    { background: var(--warn-weak);   border-color: var(--c-gold-300);   color: var(--warn-on-weak); }
.info-box--success { background: var(--success-weak);border-color: var(--success);      color: var(--success-on-weak); }
.info-box--muted   { background: var(--bg-soft);     border-color: var(--border);       color: var(--text-on-soft); }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE UTILITIES
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 639px) {
  .page-hero { padding-block: var(--sp-12) var(--sp-10); }
  .page-hero h1 { font-size: var(--text-3xl); }
  .section { padding-block: var(--sp-12); }
}

/* ═══════════════════════════════════════════════════════════
   ADMIN & CLIENT PORTAL — WIDGETS, GAUGES, CHECKLISTS
   ═══════════════════════════════════════════════════════════ */

.admin-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--sp-4);
}
@media (max-width: 1024px) {
  .admin-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
  .admin-grid { grid-template-columns: 1fr; }
}

.admin-widget {
  background: var(--surface);
  border: 1px solid var(--border-brand);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.03), 0 6px 20px rgba(15, 23, 42, 0.04);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.admin-widget:hover {
  box-shadow: 0 2px 6px rgba(30, 64, 175, 0.08), 0 14px 40px rgba(30, 64, 175, 0.08);
  transform: translateY(-1px);
}
.admin-widget--wide  { grid-column: span 2; }
.admin-widget--accent {
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-strong) 100%);
  color: #fff;
  border-color: transparent;
}
.admin-widget--accent .admin-widget__eyebrow { color: rgba(255,255,255,0.75); }
.admin-widget--accent .admin-widget__title   { color: #fff; }
.admin-widget--accent .admin-stat__label     { color: rgba(255,255,255,0.82); }
.admin-widget--accent .admin-stat__num       { color: #fff; }
.admin-widget--accent .admin-widget__more    { color: var(--c-gold-300); }
@media (max-width: 1024px) {
  .admin-widget--wide { grid-column: span 2; }
}
@media (max-width: 600px) {
  .admin-widget--wide { grid-column: 1 / -1; }
}

.admin-widget__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp-3);
  margin-block-end: var(--sp-1);
}
.admin-widget__eyebrow {
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--text-dim);
  font-weight: var(--fw-semi);
  display: block;
  margin-block-end: 2px;
}
.admin-widget__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin: 0;
}
.admin-widget__more {
  font-size: var(--text-xs);
  color: var(--brand);
  text-decoration: none;
  white-space: nowrap;
}
.admin-widget__more:hover { text-decoration: underline; }

.admin-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-block: var(--sp-2);
}
.admin-stat__num {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
  color: var(--text);
  line-height: 1;
}
.admin-stat__label {
  font-size: var(--text-xs);
  color: var(--text-soft);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
}
.admin-stat--warn .admin-stat__num { color: var(--warn); }

/* Finance grid — 4 mini-cells inside accent widget */
.finance-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--sp-4);
  padding-block: var(--sp-2);
}
.finance-grid > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
@media (max-width: 600px) {
  .finance-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Container gauge (RIVM naaldcontainer) */
.container-gauge__label {
  font-size: var(--text-xs);
  color: var(--text-soft);
  margin-block-end: var(--sp-2);
}
.container-gauge__bar {
  position: relative;
  block-size: 24px;
  background: var(--bg-sunken);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.container-gauge__fill {
  block-size: 100%;
  background: linear-gradient(90deg, var(--success) 0%, var(--warn) 70%, var(--danger) 95%);
  transition: inline-size var(--dur-slow) var(--ease-out-expo);
}
.container-gauge__pct {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--text);
  mix-blend-mode: difference;
  filter: invert(1);
}
.container-gauge__note {
  font-size: var(--text-xs);
  color: var(--text-dim);
  margin-block-start: var(--sp-2);
  line-height: var(--leading-snug);
}

/* Appointment list rows */
.appt-list { display: flex; flex-direction: column; gap: var(--sp-2); list-style: none; padding: 0; margin: 0; }
.appt-row {
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg-soft);
  border-radius: var(--r-md);
  font-size: var(--text-sm);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-3);
}
.appt-row--empty {
  justify-content: center;
  color: var(--text-dim);
  font-style: italic;
  padding-block: var(--sp-5);
}

/* Incident status card */
.incident-status {
  display: flex;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-3);
  border-radius: var(--r-md);
}
.incident-status--clean {
  background: var(--success-weak);
  color: var(--success);
}
.incident-status strong { display: block; font-family: var(--font-display); font-size: var(--text-md); }
.incident-status p      { font-size: var(--text-xs); color: var(--text-soft); margin: 0; }

/* Compliance checklist */
.checklist { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--sp-2); }
.checklist__item {
  display: flex;
  gap: var(--sp-2);
  align-items: center;
  font-size: var(--text-sm);
  color: var(--text-soft);
}
.checklist__dot {
  inline-size: 8px; block-size: 8px;
  border-radius: 50%;
  background: var(--text-dim);
  flex-shrink: 0;
}
.checklist__item--ok   .checklist__dot { background: var(--success); }
.checklist__item--warn .checklist__dot { background: var(--warn); }
.checklist__item--ok   { color: var(--text); }

/* Admin mini stats grid */
.admin-mini-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-3);
}
.admin-mini-stats > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: var(--sp-3);
  background: var(--bg-soft);
  border-radius: var(--r-sm);
}
.admin-mini-stats strong {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--text);
}
.admin-mini-stats span {
  font-size: var(--text-xs);
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
}

/* Elevated nav-card (for admin module grid) */
.nav-card--elev {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border-brand);
  border-radius: var(--r-lg);
  text-decoration: none;
  color: var(--text);
  transition: all var(--dur-base) var(--ease-out);
}
.nav-card--elev:hover {
  border-color: var(--brand);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(30, 64, 175, 0.10);
}
.nav-card--elev .nav-card__icon {
  font-size: 24px;
  margin-block-end: var(--sp-1);
}
.nav-card--elev .nav-card__label {
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: var(--fw-semi);
}
.nav-card--elev .nav-card__lead {
  font-size: var(--text-xs);
  color: var(--text-soft);
  line-height: var(--leading-snug);
}

/* Tier progression bar (stempelkaart) */
.tier-bar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  padding-block: var(--sp-2);
}
.tier-bar__track {
  position: relative;
  block-size: 10px;
  background: var(--bg-sunken);
  border-radius: var(--r-pill);
  overflow: hidden;
}
.tier-bar__fill {
  block-size: 100%;
  background: linear-gradient(90deg, #cd7f32 0%, #c0c0c0 50%, var(--c-gold-500) 100%);
  border-radius: var(--r-pill);
  transition: inline-size var(--dur-slow) var(--ease-out-expo);
}
.tier-bar__labels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
}
.tier-bar__tier {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  text-align: center;
  font-size: var(--text-2xs);
  color: var(--text-dim);
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--r-sm);
  transition: all var(--dur-base) var(--ease-out);
}
.tier-bar__tier strong {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--text-soft);
}
.tier-bar__tier small { font-size: var(--text-2xs); color: var(--text-dim); }
.tier-bar__tier--current {
  background: var(--brand-weak);
}
.tier-bar__tier--current strong { color: var(--brand); }

/* ═══════════════════════════════════════════════════════════
   ACCOUNT NUDGE (non-intrusive floating invite)
   ═══════════════════════════════════════════════════════════ */
.account-nudge {
  position: fixed;
  inset-inline: var(--sp-3);
  inset-block-end: var(--sp-4);
  z-index: 900;
  max-inline-size: 520px;
  margin-inline: auto;
  background: var(--surface);
  border: 1px solid var(--border-brand);
  border-radius: var(--r-xl);
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.18);
  transform: translateY(120%);
  transition: transform 380ms var(--ease-out-expo), opacity var(--dur-base) var(--ease-out);
  opacity: 0;
}
.account-nudge.is-visible {
  transform: translateY(0);
  opacity: 1;
}
.account-nudge__body {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-3) var(--sp-4);
}
.account-nudge__icon {
  inline-size: 36px; block-size: 36px;
  background: var(--brand-weak);
  color: var(--brand);
  border-radius: 50%;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.account-nudge__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-inline-size: 0;
}
.account-nudge__text strong {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--text);
}
.account-nudge__text span {
  font-size: var(--text-xs);
  color: var(--text-soft);
  line-height: var(--leading-snug);
}
.account-nudge__cta {
  padding: var(--sp-2) var(--sp-4);
  background: var(--brand);
  color: var(--brand-on);
  text-decoration: none;
  border-radius: var(--r-pill);
  font-size: var(--text-sm);
  font-weight: var(--fw-semi);
  white-space: nowrap;
  transition: background var(--dur-fast);
}
.account-nudge__cta:hover { background: var(--brand-hover); }
.account-nudge__close {
  inline-size: 28px; block-size: 28px;
  background: transparent;
  border: 0;
  color: var(--text-dim);
  border-radius: 50%;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.account-nudge__close:hover { background: var(--bg-soft); color: var(--text); }

@media (max-width: 600px) {
  .account-nudge__body { grid-template-columns: auto 1fr auto; gap: var(--sp-2); }
  .account-nudge__close { grid-column: 3; grid-row: 1; justify-self: end; }
  .account-nudge__text   { grid-column: 1 / 3; grid-row: 2; }
  .account-nudge__cta    { grid-column: 1 / 4; grid-row: 3; text-align: center; padding-block: var(--sp-3); }
}
@media (prefers-reduced-motion: reduce) {
  .account-nudge { transition: opacity var(--dur-base); transform: none; }
}

/* ═══════════════════════════════════════════════════════════
   PORTAAL SUB-PAGES (klant-gezicht)
   ═══════════════════════════════════════════════════════════ */
.portal-sub-shell {
  max-inline-size: 880px;
  margin-inline: auto;
}
.portal-sub-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
  margin-block-end: var(--sp-5);
}
.portal-sub-actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }

/* ── Voortgang components ───────────────────────────── */
.voortgang-today {
  background: var(--surface);
  border: 1px solid var(--border-brand);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  box-shadow: 0 8px 32px rgba(15, 23, 42, 0.04);
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  margin-block-end: var(--sp-5);
}
.voortgang-today__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.voortgang-saved {
  padding: 4px var(--sp-2);
  background: var(--success-weak);
  color: var(--success);
  border-radius: var(--r-pill);
  font-size: var(--text-xs);
  font-weight: var(--fw-semi);
}
.voortgang-slider__label {
  display: block;
  font-weight: var(--fw-semi);
  font-size: var(--text-md);
  margin-block-end: var(--sp-2);
  color: var(--text);
}

/* Per-slider gradient override via CSS var */
.voortgang-slider .intake-slider__range[style*="--slider-gradient"]::-webkit-slider-runnable-track {
  background: var(--slider-gradient);
}
.voortgang-slider .intake-slider__range[style*="--slider-gradient"]::-moz-range-track {
  background: var(--slider-gradient);
}

.voortgang-chart, .voortgang-list, .voortgang-insights {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  margin-block-end: var(--sp-4);
}
.voortgang-chart svg {
  inline-size: 100%;
  block-size: auto;
  margin-block-start: var(--sp-3);
  background: var(--bg-soft);
  border-radius: var(--r-md);
}
.voortgang-chart--empty {
  text-align: center;
  padding-block: var(--sp-8);
}
.voortgang-legend {
  display: flex;
  justify-content: center;
  gap: var(--sp-4);
  font-size: var(--text-xs);
  color: var(--text-soft);
  margin-block-start: var(--sp-2);
}
.voortgang-legend__dot {
  display: inline-block;
  inline-size: 10px; block-size: 10px;
  border-radius: 50%;
  margin-inline-end: 4px;
  vertical-align: middle;
}

.voortgang-list ul { list-style: none; padding: 0; margin-block-start: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-2); }
.voortgang-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-3);
  background: var(--bg-soft);
  border-radius: var(--r-sm);
}
.voortgang-list__date strong { font-family: var(--font-display); }
.voortgang-list__date { font-size: var(--text-sm); color: var(--text-soft); }
.voortgang-list__scores { display: flex; gap: var(--sp-3); font-size: var(--text-sm); font-variant-numeric: tabular-nums; }
.voortgang-list__scores em { font-style: normal; }

.voortgang-insights__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
  margin-block-start: var(--sp-3);
}
@media (max-width: 600px) { .voortgang-insights__grid { grid-template-columns: 1fr; } }
.voortgang-insights__stat {
  padding: var(--sp-4);
  background: var(--bg-soft);
  border-radius: var(--r-md);
  border-left: 3px solid var(--text-dim);
}
.voortgang-insights__stat.is-ok { border-left-color: var(--success); background: var(--success-weak); }
.voortgang-insights__stat strong {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  display: block;
  margin-block: 4px;
  color: var(--text);
}
.voortgang-insights__label {
  font-size: var(--text-xs);
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
}
.voortgang-insights__hint {
  font-size: var(--text-xs);
  color: var(--text-soft);
}

/* ── Toast (simple confirmation) ─────────────────────── */
.toast {
  position: fixed;
  inset-block-end: var(--sp-6);
  inset-inline-end: var(--sp-6);
  z-index: 1000;
  padding: var(--sp-3) var(--sp-5);
  background: var(--success);
  color: #fff;
  border-radius: var(--r-pill);
  font-weight: var(--fw-semi);
  box-shadow: 0 8px 24px rgba(15, 118, 61, 0.35);
  transform: translateY(20px);
  opacity: 0;
  transition: all 300ms var(--ease-out-expo);
  pointer-events: none;
}
.toast.is-visible { transform: translateY(0); opacity: 1; }

/* ═══════════════════════════════════════════════════════════
   ADMIN · KLANT-PROFIEL + BEHANDELING-REGISTRATIE
   ═══════════════════════════════════════════════════════════ */

/* Klant-header (profile page) */
.klant-header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--sp-4);
  align-items: center;
  padding: var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border-brand);
  border-radius: var(--r-lg);
  margin-block-end: var(--sp-4);
}
.klant-header__avatar {
  inline-size: 64px; block-size: 64px;
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-strong) 100%);
  color: #fff;
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-bold);
}
.klant-header__info h1 { font-size: var(--text-xl); margin: 0; font-family: var(--font-display); }
.klant-header__info p {
  color: var(--text-soft);
  font-size: var(--text-sm);
  margin-block-start: 2px;
}
.klant-header__actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
@media (max-width: 640px) {
  .klant-header { grid-template-columns: auto 1fr; }
  .klant-header__actions { grid-column: 1 / -1; justify-content: flex-end; }
}

.klant-stats { margin-block-end: var(--sp-5); }

/* 2-column klant page */
.klant-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--sp-4);
}
@media (max-width: 900px) {
  .klant-grid { grid-template-columns: 1fr; }
}

/* Timeline */
.klant-timeline {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
}
.klant-timeline__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-block-end: var(--sp-4);
}
.klant-timeline__filters {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.klant-timeline__filters button {
  padding: 4px var(--sp-3);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  color: var(--text-soft);
  border-radius: var(--r-pill);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all var(--dur-fast);
}
.klant-timeline__filters button:hover { border-color: var(--brand); }
.klant-timeline__filters button.is-active {
  background: var(--brand);
  color: var(--brand-on);
  border-color: var(--brand);
}

.timeline {
  list-style: none;
  padding: 0;
  margin: 0;
  position: relative;
}
.timeline::before {
  content: '';
  position: absolute;
  inset-inline-start: 12px;
  inset-block: 8px;
  inline-size: 2px;
  background: var(--border);
}
.timeline__item {
  position: relative;
  padding-block: var(--sp-3);
  padding-inline-start: var(--sp-8);
}
.timeline__dot {
  position: absolute;
  inset-inline-start: 6px;
  inset-block-start: var(--sp-4);
  inline-size: 14px; block-size: 14px;
  border-radius: 50%;
  border: 3px solid var(--surface);
  box-shadow: 0 0 0 2px var(--border);
  z-index: 1;
}
.timeline__content {
  background: var(--bg-soft);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
}
.timeline__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  margin-block-end: 4px;
}
.timeline__head strong {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--text);
}
.timeline__head time {
  font-size: var(--text-xs);
  color: var(--text-dim);
  white-space: nowrap;
}
.timeline__content p {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-soft);
}
.timeline__note {
  margin: var(--sp-2) 0 0;
  padding: var(--sp-2) var(--sp-3);
  background: var(--surface);
  border-left: 3px solid var(--brand);
  border-radius: var(--r-sm);
  font-size: var(--text-sm);
  color: var(--text);
  font-style: italic;
}

.klant-sidebar { display: flex; flex-direction: column; gap: var(--sp-4); }
.klant-intake-summary {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-2) var(--sp-3);
  margin-block-start: var(--sp-3);
  font-size: var(--text-sm);
}
.klant-intake-summary dt { color: var(--text-dim); font-size: var(--text-xs); }
.klant-intake-summary dd { margin: 0; color: var(--text); }
.klant-intake-summary code {
  font-size: var(--text-xs);
  padding: 2px 6px;
  background: var(--bg-soft);
  border-radius: var(--r-xs);
}

/* ── Behandeling-registratie tool ─────────────────────── */
.behandeling-grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--sp-5);
  align-items: start;
}
@media (max-width: 900px) {
  .behandeling-grid { grid-template-columns: 1fr; }
}
.behandeling-sticky {
  position: sticky;
  inset-block-start: 90px;
  display: flex;
  flex-direction: column;
}

.cost-calc {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-2) var(--sp-4);
  margin-block-start: var(--sp-3);
  font-size: var(--text-sm);
}
.cost-calc dt { color: rgba(255,255,255,0.75); }
.cost-calc dd { margin: 0; text-align: end; color: #fff; font-variant-numeric: tabular-nums; }
.cost-calc__total { padding-block-start: var(--sp-2); border-block-start: 1px solid rgba(255,255,255,0.2); font-weight: var(--fw-bold); font-size: var(--text-md); }
.cost-calc__total strong { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--c-gold-300); }
.cost-calc__total small { color: rgba(255,255,255,0.7); margin-inline-start: var(--sp-1); }
.cost-calc__breakdown {
  margin-block-start: var(--sp-4);
  padding-block-start: var(--sp-3);
  border-block-start: 1px solid rgba(255,255,255,0.2);
  font-size: var(--text-xs);
}
.cost-calc__breakdown summary { cursor: pointer; color: rgba(255,255,255,0.85); font-size: var(--text-xs); }
.cost-calc__breakdown ul { list-style: none; padding: 0; margin-block-start: var(--sp-2); display: flex; flex-direction: column; gap: 4px; }
.cost-calc__breakdown li {
  display: flex;
  justify-content: space-between;
  color: rgba(255,255,255,0.75);
}

/* Materialen grid */
.materials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-2);
  max-block-size: 520px;
  overflow-y: auto;
  padding-inline-end: var(--sp-2);
}
.material-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-soft);
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  transition: all var(--dur-fast);
}
.material-row.is-active {
  background: var(--brand-weak);
  border-color: var(--brand);
}
.material-row__info { min-inline-size: 0; }
.material-row__info strong {
  display: block;
  font-size: var(--text-sm);
  color: var(--text);
}
.material-row__info small {
  font-size: var(--text-xs);
  color: var(--text-dim);
}
.material-row__qty {
  inline-size: 64px;
  padding: 4px var(--sp-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-semi);
  background: var(--surface);
}

/* ═══════════════════════════════════════════════════════════
   ADMIN · VOORRAAD / FINANCIEEL / COMPLIANCE
   ═══════════════════════════════════════════════════════════ */

/* Voorraad-tabel */
.voorraad-table { display: grid; gap: 2px; }
.voorraad-table__head {
  display: grid;
  grid-template-columns: 2.4fr 0.8fr 0.5fr 0.7fr 1fr 1.2fr 0.7fr 0.5fr;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-sunken);
  border-radius: var(--r-sm);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--text-dim);
  font-weight: var(--fw-semi);
}
.voorraad-row {
  display: grid;
  grid-template-columns: 2.4fr 0.8fr 0.5fr 0.7fr 1fr 1.2fr 0.7fr 0.5fr;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-soft);
  border-radius: var(--r-sm);
  font-size: var(--text-sm);
  align-items: center;
}
.voorraad-row--low      { background: #fef3c7; }
.voorraad-row--expiring { background: #fef3c7; }
.voorraad-row--expired  { background: #fee2e2; }
.voorraad-row--empty    { background: #fee2e2; }
.voorraad-row input[type=number] {
  inline-size: 100%;
  padding: 4px 6px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  text-align: center;
  font-variant-numeric: tabular-nums;
  background: var(--surface);
}
.voorraad-row__name strong { display: block; font-size: var(--text-sm); }
.voorraad-row__name small  { display: block; color: var(--text-dim); font-size: var(--text-2xs); }
.voorraad-badge {
  padding: 2px var(--sp-2);
  border-radius: var(--r-pill);
  font-size: var(--text-2xs);
  font-weight: var(--fw-semi);
  text-align: center;
}
@media (max-width: 900px) {
  .voorraad-table__head,
  .voorraad-row { grid-template-columns: 1fr; gap: 4px; padding-block: var(--sp-3); }
  .voorraad-table__head span:not(:first-child) { display: none; }
  .voorraad-row span::before {
    content: attr(data-label) ' ';
    color: var(--text-dim);
    font-size: var(--text-xs);
  }
}

/* Voorraad orderlist */
.voorraad-orderlist { display: flex; flex-direction: column; gap: var(--sp-1); margin-block-top: var(--sp-3); }
.voorraad-orderlist__row {
  display: grid;
  grid-template-columns: 2fr auto auto;
  gap: var(--sp-4);
  align-items: center;
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-soft);
  border-radius: var(--r-sm);
  font-size: var(--text-sm);
}
.voorraad-orderlist__row small { display: block; color: var(--text-dim); font-size: var(--text-xs); }
.voorraad-orderlist__qty { text-align: center; }
.voorraad-orderlist__qty strong { font-family: var(--font-display); font-size: var(--text-md); }
.voorraad-orderlist__cost { font-family: var(--font-display); font-weight: var(--fw-bold); color: var(--brand); min-inline-size: 80px; text-align: end; }

/* Fin chart + bars */
.fin-chart { inline-size: 100%; block-size: auto; background: var(--bg-soft); border-radius: var(--r-md); margin-block-top: var(--sp-3); }
.fin-bars  { display: flex; flex-direction: column; gap: var(--sp-3); margin-block-top: var(--sp-3); }
.fin-bar__label {
  display: flex;
  justify-content: space-between;
  font-size: var(--text-sm);
  margin-block-end: 4px;
}
.fin-bar__label strong { font-family: var(--font-display); }
.fin-bar__label span   { color: var(--text-soft); font-size: var(--text-xs); }
.fin-bar__track { block-size: 10px; background: var(--bg-sunken); border-radius: var(--r-pill); overflow: hidden; }
.fin-bar__fill  { block-size: 100%; background: linear-gradient(90deg, var(--brand), var(--c-gold-500)); border-radius: var(--r-pill); transition: inline-size var(--dur-slow) var(--ease-out-expo); }

/* Compliance progress bar (in accent widget) */
.compliance-progress {
  position: relative;
  block-size: 14px;
  background: rgba(255,255,255,0.15);
  border-radius: var(--r-pill);
  overflow: hidden;
  margin-block-top: var(--sp-2);
}
.compliance-progress__fill {
  block-size: 100%;
  background: linear-gradient(90deg, var(--c-gold-500), var(--c-gold-300));
  border-radius: var(--r-pill);
  transition: inline-size var(--dur-slow) var(--ease-out-expo);
}
.compliance-progress__pct {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--ink-900);
  mix-blend-mode: difference;
}

/* Compliance checklist */
.compliance-checklist { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); margin-block-top: var(--sp-3); }
@media (max-width: 760px) { .compliance-checklist { grid-template-columns: 1fr; } }
.compliance-check {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-start;
  padding: var(--sp-3);
  background: var(--bg-soft);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: all var(--dur-fast);
}
.compliance-check:hover { border-color: var(--brand); }
.compliance-check.is-done {
  background: var(--success-weak);
  border-color: var(--success);
}
.compliance-check input { margin-block-start: 3px; flex-shrink: 0; }
.compliance-check__body strong { display: block; font-size: var(--text-sm); color: var(--text); }
.compliance-check__body small  { display: block; color: var(--text-dim); font-size: var(--text-xs); margin-block-top: 2px; }
.compliance-check__body em     { display: block; color: var(--success); font-size: var(--text-xs); margin-block-top: 4px; font-style: normal; }

/* Email template grid (berichten) */
.template-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-3);
  margin-block-top: var(--sp-3);
}
.template-card {
  padding: var(--sp-3);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.template-card strong { font-family: var(--font-display); font-size: var(--text-sm); }
.template-card small  { color: var(--text-dim); font-size: var(--text-xs); }
.template-card__actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2);
  margin-block-top: var(--sp-1);
}
.template-card__actions code { font-size: var(--text-2xs); color: var(--text-dim); }

/* ═══════════════════════════════════════════════════════════
   AGENDA (week view) + klanten-filters + instellingen-grid
   ═══════════════════════════════════════════════════════════ */

.agenda-grid {
  display: grid;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  font-size: var(--text-xs);
}
.agenda-time {
  padding: 4px var(--sp-2);
  background: var(--bg-sunken);
  color: var(--text-dim);
  font-variant-numeric: tabular-nums;
  text-align: end;
  font-size: var(--text-2xs);
}
.agenda-day-head {
  padding: var(--sp-2);
  background: var(--surface);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.agenda-day-head strong { font-family: var(--font-display); font-size: var(--text-sm); }
.agenda-day-head span { font-size: var(--text-2xs); color: var(--text-soft); }
.agenda-day-head em { font-size: var(--text-2xs); color: var(--c-gold-600); font-style: normal; }
.agenda-day-head.is-sunnah {
  background: linear-gradient(135deg, #fffbeb 0%, var(--surface) 100%);
}
.agenda-day-head.is-today {
  background: var(--brand);
  color: var(--brand-on);
}
.agenda-day-head.is-today strong,
.agenda-day-head.is-today span { color: var(--brand-on); }

.agenda-cell {
  background: var(--surface);
  min-block-size: 28px;
  position: relative;
  cursor: pointer;
  transition: background var(--dur-fast);
}
.agenda-cell:hover { background: var(--bg-soft); }
.agenda-cell.is-sunnah {
  background: linear-gradient(135deg, rgba(254, 243, 199, 0.4), transparent 80%);
}
.agenda-cell.is-blocked {
  background: var(--bg-sunken);
  cursor: not-allowed;
  opacity: 0.6;
}

.agenda-prayer {
  display: block;
  padding: 2px var(--sp-1);
  font-size: var(--text-2xs);
  color: var(--text-dim);
  text-align: center;
}

.agenda-booking {
  position: absolute;
  inset: 2px;
  padding: 4px 6px;
  border-radius: var(--r-xs);
  font-size: var(--text-2xs);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}
.agenda-booking strong { display: block; font-weight: var(--fw-semi); }
.agenda-booking small { color: var(--text-dim); font-size: 9px; }
.agenda-booking--dry     { background: #dbeafe; }
.agenda-booking--wet     { background: #fecaca; }
.agenda-booking--sport   { background: #d1fae5; }
.agenda-booking--premium { background: #fef3c7; }

.agenda-legend {
  display: inline-block;
  inline-size: 16px; block-size: 10px;
  border-radius: 2px;
  margin-inline-end: 4px;
  vertical-align: middle;
}

/* Klanten filters */
.klant-filters {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-block: var(--sp-3) var(--sp-2);
}
.klant-filters button {
  padding: 6px var(--sp-3);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  color: var(--text-soft);
  border-radius: var(--r-pill);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all var(--dur-fast);
}
.klant-filters button:hover { border-color: var(--brand); }
.klant-filters button.is-active {
  background: var(--brand);
  color: var(--brand-on);
  border-color: var(--brand);
}
.klant-row:hover { background: var(--brand-weak) !important; }
.klant-row__name strong { display: block; font-size: var(--text-sm); }
.klant-row__name small  { display: block; color: var(--text-dim); font-size: var(--text-2xs); }

/* Instellingen */
.settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sp-3);
}
.settings-input {
  inline-size: 80px;
  padding: 4px var(--sp-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface);
  font-variant-numeric: tabular-nums;
}
