/* ============================================================
   DIENST-CALCULATOR.CSS — prijscalculator op dienstpagina's
   Bouwt voort op calculators.css (calc-card, calc-result,
   calc-choice, calc-range, calc-toggle ...). Voeg beide bestanden
   samen toe op de dienstpagina's.
   ============================================================ */

.svc-calc-section {
  padding: clamp(48px, 7vw, 84px) 0;
  background: linear-gradient(180deg, #ffffff 0%, var(--color-light-bg) 100%);
}
.svc-calc-section .section-header { margin-bottom: clamp(28px, 4vw, 44px); }

/* ── Twee-koloms layout ─────────────────────────────────── */
.dcalc {
  display: grid;
  grid-template-columns: 1.3fr 0.9fr;
  gap: 28px;
  align-items: stretch;
  max-width: 1040px;
  margin: 0 auto;
}
/* Linkervak: velden verdelen over de volledige hoogte zodat er
   geen witte ruimte onderaan ontstaat als het rechter paneel hoger is. */
.dcalc__config {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 20px;
}

/* Beide kolommen even hoog: resultaatpaneel vult de rijhoogte */
.dcalc__result {
  display: flex;
  flex-direction: column;
  align-self: stretch;
}
/* Trust-footer onderaan uitlijnen zodat de hoogte mooi gevuld is */
.dcalc__result .dcalc-trust { margin-top: auto; }

/* Marges weg: de flex-gap + space-between regelt nu de verticale ruimte */
.dcalc .calc-field { margin-bottom: 0; }

/* ── Extra-toggles met prijs rechts ─────────────────────── */
.dcalc .calc-toggle { gap: 8px; }
.calc-toggle__txt { flex: 1; line-height: 1.3; }
.calc-toggle__price {
  font-size: 12.5px; font-weight: 700; white-space: nowrap;
  color: var(--color-primary-dark); font-variant-numeric: tabular-nums;
}

/* ── Resultaatpaneel ────────────────────────────────────── */
.dcalc__result { padding: 28px; }
.dcalc__result .calc-result__big { margin-top: 4px; }

/* Samenvatting / checklist van keuzes */
.dcalc-summary {
  list-style: none; margin: 20px 0 4px; padding: 18px 0 4px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex; flex-direction: column; gap: 11px;
}
.dcalc-summary li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13.5px; color: rgba(255, 255, 255, 0.92); line-height: 1.4;
}
.dcalc-summary__ic {
  flex: none; display: inline-flex; margin-top: 1px;
  color: var(--color-primary);
}
.dcalc-summary strong { color: #fff; font-weight: 600; }

/* CTA */
.dcalc-cta { width: 100%; margin-top: 18px; }

/* ── Trust-footer (review + stappen) ────────────────────── */
.dcalc-trust { margin-top: 22px; padding-top: 20px; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.dcalc-review { text-align: center; margin-bottom: 18px; }
.dcalc-stars { color: #ffc83d; letter-spacing: 2px; font-size: 15px; }
.dcalc-review p {
  color: rgba(255, 255, 255, 0.88); font-size: 13.5px; font-style: italic;
  margin: 8px 0 6px; line-height: 1.5;
}
.dcalc-review__who { font-size: 12.5px; color: rgba(255, 255, 255, 0.6); }
.dcalc-review__who strong { color: var(--color-primary); }

.dcalc-steps { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.dcalc-steps li {
  display: flex; align-items: center; gap: 11px;
  font-size: 13px; color: rgba(255, 255, 255, 0.8);
}
.dcalc-steps li span {
  flex: none; width: 22px; height: 22px; border-radius: 50%;
  background: rgba(var(--color-primary-rgb), 0.18); color: var(--color-primary);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}

/* ── Uitgebreide content op dienstpagina's ──────────────── */
.svc-price-info { padding: clamp(44px, 6vw, 72px) 0; }
.svc-price-info .svc-price-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
  margin-top: 26px;
}
.svc-price-card {
  background: #fff; border: 1px solid var(--color-border);
  border-radius: 16px; padding: 24px; box-shadow: var(--shadow-md);
}
.svc-price-card h3 { font-size: 17px; margin-bottom: 8px; color: var(--color-dark); }
.svc-price-card p { color: var(--color-text-gray); font-size: 14.5px; line-height: 1.6; }

/* FAQ */
.svc-faq { padding: clamp(44px, 6vw, 76px) 0; background: var(--color-light-bg); }
.svc-faq__list { max-width: 800px; margin: 26px auto 0; display: flex; flex-direction: column; gap: 12px; }
.svc-faq .faq-item {
  background: #fff; border: 1px solid var(--color-border); border-radius: 14px;
  overflow: hidden; box-shadow: var(--shadow-md);
}
.svc-faq details summary {
  cursor: pointer; list-style: none; padding: 18px 22px;
  font-weight: 600; font-size: 15.5px; color: var(--color-dark);
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.svc-faq details summary::-webkit-details-marker { display: none; }
.svc-faq details summary::after {
  content: '+'; font-size: 22px; font-weight: 400; color: var(--color-primary-dark);
  transition: transform 0.25s ease; line-height: 1;
}
.svc-faq details[open] summary::after { transform: rotate(45deg); }
.svc-faq details .faq-answer { padding: 0 22px 20px; color: var(--color-text-gray); font-size: 14.5px; line-height: 1.65; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 920px) {
  .dcalc { grid-template-columns: 1fr; }
  .dcalc__result { position: static; }
  .svc-price-info .svc-price-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .dcalc .calc-toggles { grid-template-columns: 1fr; }
}
