/* 2026 Brandbook DriveMe: Montserrat (headings), Open Sans (body), palette #004253 / #17182f */
.prijscalculator-wp {
  max-width: 40rem;
  margin: 1rem 0;
  font-family: 'Open Sans', sans-serif;
  font-size: 1rem;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
.prijscalculator-wp-loading {
  color: var(--pcw-secondary-text, #666);
}
.prijscalculator-wp form {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.prijscalculator-wp label {
  display: block;
  margin-bottom: 0.25rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
}
/* MAR-256: typed text stays dark in light and dark site themes (avoids inheriting light body text) */
.prijscalculator-wp input,
.prijscalculator-wp textarea,
.prijscalculator-wp select {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--pcw-input-border, #ccc);
  border-radius: 4px;
  box-sizing: border-box;
  font-family: 'Open Sans', sans-serif;
  color: var(--pcw-input-text, #17182f) !important;
  background-color: var(--pcw-input-bg, #ffffff) !important;
  color-scheme: light !important;
  caret-color: var(--pcw-input-text, #17182f) !important;
}
.prijscalculator-wp input::placeholder,
.prijscalculator-wp textarea::placeholder {
  color: var(--pcw-secondary-text, #666);
  opacity: 1;
}

/* Accordion select (custom dropdown aligned with text inputs) */
.prijscalculator-wp .pcw-accordion-select {
  width: 100%;
  position: relative;
  z-index: 1;
}
.prijscalculator-wp .pcw-accordion-select.is-open {
  z-index: 40;
}
.prijscalculator-wp .pcw-accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.625rem 0.875rem;
  min-height: 2.75rem;
  background: var(--pcw-input-bg, #ffffff) !important;
  border: 1px solid var(--pcw-input-border, #ccc);
  border-radius: 8px;
  box-shadow: 0 1px 2px rgba(23, 24, 47, 0.06);
  cursor: pointer;
  text-align: left;
  font-family: 'Open Sans', sans-serif;
  font-size: 1rem;
  color: var(--pcw-input-text, #17182f) !important;
  color-scheme: light !important;
  box-sizing: border-box;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, border-radius 0.15s ease;
}
.prijscalculator-wp .pcw-accordion-trigger:hover {
  border-color: var(--pcw-primary, #004253);
  box-shadow: 0 2px 8px rgba(0, 66, 83, 0.1);
}
.prijscalculator-wp .pcw-accordion-trigger:focus {
  outline: none;
}
.prijscalculator-wp .pcw-accordion-trigger:focus-visible {
  outline: 2px solid var(--pcw-primary, #004253);
  outline-offset: 2px;
}
.prijscalculator-wp .pcw-accordion-select.is-open .pcw-accordion-trigger {
  border-radius: 8px 8px 0 0;
  border-bottom-color: transparent;
  box-shadow: none;
}
.prijscalculator-wp .pcw-accordion-trigger.is-placeholder .pcw-accordion-label {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.8125rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  color: var(--pcw-secondary-text, #666);
}
.prijscalculator-wp .pcw-accordion-chevron {
  display: inline-block;
  flex-shrink: 0;
  width: 0.5rem;
  height: 0.5rem;
  margin-top: -0.15rem;
  border-right: 2px solid var(--pcw-primary, #004253);
  border-bottom: 2px solid var(--pcw-primary, #004253);
  opacity: 0.85;
  transform: rotate(45deg);
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.prijscalculator-wp .pcw-accordion-select.is-open .pcw-accordion-chevron {
  transform: rotate(225deg);
  margin-top: 0.1rem;
}
.prijscalculator-wp .pcw-accordion-label {
  flex: 1;
  min-width: 0;
  line-height: 1.35;
}
/* MAR-250: soort rit — option icons (single trip, return, hourly) */
.prijscalculator-wp .pcw-accordion-trigger.is-placeholder .pcw-accordion-selected-icon {
  display: none !important;
}
.prijscalculator-wp .pcw-accordion-selected-icon.pcw-soort-icon {
  display: block;
}
.prijscalculator-wp .pcw-accordion-options li.pcw-accordion-option--with-icon {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}
.prijscalculator-wp .pcw-soort-icon {
  display: inline-block;
  width: 1.375rem;
  height: 1.375rem;
  flex-shrink: 0;
  background-color: currentColor;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
}
.prijscalculator-wp .pcw-soort-icon--transfer {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z'/%3E%3C/svg%3E");
}
.prijscalculator-wp .pcw-soort-icon--return {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M12 4V1L8 5l4 4V6c3.31 0 6 2.69 6 6 0 1.01-.25 1.97-.7 2.8l1.46 1.46C19.54 15.03 20 13.57 20 12c0-4.42-3.58-8-8-8zm0 14c-3.31 0-6-2.69-6-6 0-1.01.25-1.97.7-2.8L5.24 7.74C4.46 8.97 4 10.43 4 12c0 4.42 3.58 8 8 8v3l4-4-4-4v3z'/%3E%3C/svg%3E");
}
.prijscalculator-wp .pcw-soort-icon--disposal {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8zm.5-13H11v6l5.25 3.15.75-1.23-4.5-2.67z'/%3E%3C/svg%3E");
}
.prijscalculator-wp .pcw-accordion-options {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  border: 1px solid var(--pcw-input-border, #ccc);
  border-top: none;
  border-radius: 0 0 8px 8px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(23, 24, 47, 0.12);
  max-height: 16rem;
  overflow-y: auto;
  /* MAR-256 follow-up: list panel uses light theme so option text stays dark */
  color-scheme: light;
  color: var(--pcw-input-text, #17182f);
}
.prijscalculator-wp .pcw-accordion-select.is-open .pcw-accordion-options {
  display: block;
}
.prijscalculator-wp .pcw-accordion-options li {
  padding: 0.65rem 0.875rem;
  cursor: pointer;
  font-family: 'Open Sans', sans-serif;
  font-size: 1rem;
  border-bottom: 1px solid var(--pcw-input-border, #e5e5e5);
  transition: background 0.15s ease, color 0.15s ease;
  /* MAR-256 follow-up: dark text on white (dark site themes often inherit light body color here) */
  color: var(--pcw-input-text, #17182f) !important;
}
.prijscalculator-wp .pcw-accordion-options li .pcw-accordion-option-label {
  color: inherit;
}
.prijscalculator-wp .pcw-accordion-options li:last-child {
  border-bottom: none;
}
.prijscalculator-wp .pcw-accordion-options li:hover {
  background: var(--pcw-result-bg, #f0f9ff);
  color: var(--pcw-primary, #004253) !important;
}
.prijscalculator-wp .pcw-accordion-options li.is-selected {
  background: var(--pcw-result-bg, #f0f9ff);
  color: var(--pcw-primary, #004253) !important;
  font-weight: 600;
}
/* MAR-9: hide wrapper until dienst + type + soort rit are chosen (avoids theme/CSS overriding inline display on the button) */
.prijscalculator-wp .pcw-bereken-wrap--hidden {
  display: none !important;
}
.prijscalculator-wp .pcw-bereken-wrap:not(.pcw-bereken-wrap--hidden) {
  display: block;
  margin-top: 1rem;
}
.prijscalculator-wp button[type="submit"],
.prijscalculator-wp .pcw-cta {
  display: inline-block;
  width: 50%;
  box-sizing: border-box;
  padding: 0.75rem 1rem;
  background: transparent;
  color: var(--pcw-primary, #004253);
  border: 2px solid var(--pcw-primary, #004253);
  border-radius: 100px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: background 0.2s ease, color 0.2s ease;
}
.prijscalculator-wp button[type="submit"]:hover,
.prijscalculator-wp .pcw-cta:hover {
  background: var(--pcw-primary-hover, #004253);
  color: var(--pcw-btn-hover-text, #ffffff);
}
.prijscalculator-wp .pcw-result {
  margin-top: 1.5rem;
  padding: 1rem;
  background: var(--pcw-result-bg, #f0f9ff);
  border-radius: 8px;
  border: 1px solid var(--pcw-result-border, #bae6fd);
}
.prijscalculator-wp-form.pcw-result-open #pcw-result {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin-top: 0;
  z-index: 10;
  animation: pcw-overlay-in 0.2s ease both;
}
@keyframes pcw-overlay-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* MAR-249: slightly smaller result price so large amounts feel less dominant */
.prijscalculator-wp .pcw-result .pcw-price {
  font-family: 'Open Sans', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0.5rem 0;
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.prijscalculator-wp .pcw-result .pcw-vat-label {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--pcw-secondary-text, #666);
}
/* MAR-244: niet-BOB chauffeur — incl.-regel onder excl.-prijs */
.prijscalculator-wp .pcw-result .pcw-vat-incl-hint {
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--pcw-secondary-text, #666);
  margin: 0.15rem 0 0.5rem;
  line-height: 1.35;
}
.prijscalculator-wp .pcw-error {
  color: var(--pcw-error, #b91c1c);
  margin-top: 0.5rem;
}

/* Terug-knop in resultaatoverlay */
.prijscalculator-wp .pcw-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  background: none;
  border: none;
  padding: 0;
  margin-bottom: 0.75rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--pcw-secondary-text, #666);
  cursor: pointer;
  width: auto;
  white-space: nowrap;
}
.prijscalculator-wp .pcw-back-btn:hover {
  color: var(--pcw-primary, #004253);
  background: none;
}

/* Extra kosten noot (chauffeur, niet BOB) */
.prijscalculator-wp .pcw-extra-costs-note {
  font-size: 0.775rem;
  color: var(--pcw-secondary-text, #666);
  margin: 0.25rem 0 0;
  line-height: 1.5;
}

/* MAR-260: één regel ingevulde tijd + 1 u + €15 */
.prijscalculator-wp .pcw-driver-mar260-sum {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--pcw-input-text, #17182f);
  margin: 0.5rem 0 0;
  line-height: 1.45;
}

/* MAR-260: uitleg gefactureerde uren + reiskosten uit API */
.prijscalculator-wp .pcw-driver-billing-detail {
  font-size: 0.8125rem;
  color: var(--pcw-input-text, #17182f);
  margin: 0.5rem 0 0;
  line-height: 1.5;
}

/* MAR-243: Chauffeur (niet BOB), rit op uurbasis — boven Starttijd */
.prijscalculator-wp .pcw-driver-disposal-notes {
  margin: 0 0 0.75rem;
}
.prijscalculator-wp .pcw-driver-disposal-notes-line {
  font-size: 0.775rem;
  color: var(--pcw-secondary-text, #666);
  margin: 0 0 0.35rem;
  line-height: 1.5;
}
.prijscalculator-wp .pcw-driver-disposal-notes-line:last-child {
  margin-bottom: 0;
}

/* CTA intro tekst */
.prijscalculator-wp .pcw-cta-intro {
  font-size: 0.8rem;
  color: var(--pcw-secondary-text, #666);
  margin: 0.75rem 0 0.25rem;
}

/* MAR-248: Direct boeken — chauffeur CTAs */
.prijscalculator-wp .pcw-cta-book {
  margin-top: 0.75rem;
}
/* MAR-261: bus offerte-blok direct onder prijsrange */
.prijscalculator-wp .pcw-cta-book--bus {
  margin-top: 1rem;
}
/* MAR-263: Auto met chauffeur — alleen boek-blok (geen offerte-blok) */
.prijscalculator-wp .pcw-cta-book--taxi-book {
  margin-top: 1rem;
}
.prijscalculator-wp .pcw-cta-book-grid--taxi-book {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 640px) {
  .prijscalculator-wp .pcw-cta-book-grid--taxi-book {
    grid-template-columns: 1fr;
  }
}
.prijscalculator-wp .pcw-cta-book-title {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.95rem;
  margin: 0 0 0.25rem;
  color: var(--pcw-primary, #004253);
}
.prijscalculator-wp .pcw-cta-book-sub {
  font-size: 0.8rem;
  color: var(--pcw-secondary-text, #666);
  margin: 0 0 0.65rem;
  line-height: 1.45;
}
.prijscalculator-wp .pcw-cta-book-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem 0.75rem;
  margin-top: 0.25rem;
}
@media (max-width: 480px) {
  .prijscalculator-wp .pcw-cta-book-grid {
    grid-template-columns: 1fr;
  }
}
.prijscalculator-wp .pcw-cta-book-grid .pcw-cta {
  flex: none;
  width: 100%;
  text-align: center;
  box-sizing: border-box;
}

/* CTA wrapper */
.prijscalculator-wp .pcw-cta-wrap {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.75rem;
  margin-top: 0.75rem;
}
.prijscalculator-wp .pcw-cta-wrap .pcw-cta {
  flex: 1 1 0;
  width: auto;
  min-width: 0;
}
.prijscalculator-wp .pcw-cta-outline {
  background: transparent;
  color: var(--pcw-primary, #004253);
  border-color: var(--pcw-primary, #004253);
  opacity: 0.75;
}
.prijscalculator-wp .pcw-cta-outline:hover {
  background: var(--pcw-primary-hover, #004253);
  color: var(--pcw-btn-hover-text, #ffffff);
  opacity: 1;
}

/* BOB dubbele prijs */
.prijscalculator-wp .pcw-bob-prices {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.prijscalculator-wp .pcw-bob-discount-price {
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--pcw-result-border, #bae6fd);
}
.prijscalculator-wp .pcw-bob-normal-price {
  opacity: 0.7;
}
.prijscalculator-wp .pcw-bob-normal-price .pcw-price {
  font-size: 0.95rem;
}
.prijscalculator-wp .pcw-bob-discount-badge {
  display: inline-block;
  margin: 0 0 0.35rem;
  padding: 0.15rem 0.6rem;
  background: var(--pcw-primary, #004253);
  color: #fff;
  border-radius: 100px;
  font-size: 0.7rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.prijscalculator-wp .pcw-bob-app-note {
  font-size: 0.8rem;
  color: var(--pcw-secondary-text, #666);
  margin: 0.2rem 0 0;
}
.prijscalculator-wp .pcw-bob-app-note a {
  color: var(--pcw-primary, #004253);
  font-weight: 600;
}
.prijscalculator-wp .pcw-bob-normal-label {
  font-size: 0.8rem;
  color: var(--pcw-secondary-text, #666);
  margin: 0.2rem 0 0;
  font-style: italic;
}

.prijscalculator-wp #pcw-stops-list {
  list-style: none;
  padding: 0;
  margin: 0.25rem 0 0.5rem 0;
}
.prijscalculator-wp .pcw-stop-row {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 0.5rem;
}
.prijscalculator-wp .pcw-stop-row .pcw-stop-input {
  flex: 1;
  min-width: 0;
}
.prijscalculator-wp .pcw-stop-row .pcw-remove-stop {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: 1px solid var(--pcw-input-border, #ccc);
  border-radius: 4px;
  background: var(--pcw-result-bg, #f0f9ff);
  cursor: pointer;
  font-size: 1.25rem;
  line-height: 1;
  color: var(--pcw-secondary-text, #666);
}
.prijscalculator-wp .pcw-stop-row .pcw-remove-stop:hover {
  background: var(--pcw-result-border, #bae6fd);
  color: var(--pcw-primary, #004253);
}
.prijscalculator-wp .pcw-stops-label {
  display: block;
  margin-bottom: 0.25rem;
  font-weight: 600;
}
.prijscalculator-wp #pcw-add-stop {
  margin-top: 0.25rem;
  padding: 0.5rem 1.25rem;
  font-size: 0.8rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: transparent;
  color: var(--pcw-primary, #004253);
  border: 2px solid var(--pcw-primary, #004253);
  border-radius: 100px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.2s ease, color 0.2s ease;
}
.prijscalculator-wp #pcw-add-stop:hover:not(:disabled) {
  background: var(--pcw-primary-hover, #004253);
  color: var(--pcw-btn-hover-text, #ffffff);
}
.prijscalculator-wp #pcw-add-stop:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Mobile hardening: keep calculator visible/usable when themes hide widgets below 600px. */
@media (max-width: 600px) {
  #prijscalculator-wp-root.prijscalculator-wp {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  #prijscalculator-wp-root.prijscalculator-wp form.prijscalculator-wp-form {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  #prijscalculator-wp-root.prijscalculator-wp button[type="submit"],
  #prijscalculator-wp-root.prijscalculator-wp .pcw-cta {
    width: 100%;
  }
}

/* Bus prijsrange */
.prijscalculator-wp .pcw-price-range {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin: 0.5rem 0;
}
/* MAR-251: excl. hoofdlijn + kleinere incl.-range tussen haakjes */
.prijscalculator-wp .pcw-price-range-line {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.35rem 0.5rem;
  width: 100%;
}
.prijscalculator-wp .pcw-price-range-incl-bracket {
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--pcw-secondary-text, #666);
  line-height: 1.35;
}
.prijscalculator-wp .pcw-price-range-values {
  font-family: 'Open Sans', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
}
.prijscalculator-wp .pcw-price-range-sep {
  font-weight: 400;
  color: var(--pcw-secondary-text, #666);
}
.prijscalculator-wp .pcw-price-range-note {
  font-size: 0.775rem;
  color: var(--pcw-secondary-text, #666);
  margin: 0.25rem 0 0;
  line-height: 1.5;
}
