/* Add-on-Personen-Komponente: Stepper "+ weiteres Kind / + weiterer Erwachsener"
   mit eigener Leinwand-Wahl pro Add-on. Wird auf /activity-painting/ und
   /eventkalender/ verwendet. Klassen sind page-agnostisch (`ap-extras`),
   das `ap-` ist historisch und steht hier für Activity-Painting-Komponente. */

/* Mount-Container: stapelt Basis-Personen-Fieldsets und den optionalen
   Add-on-Block mit gleichem Abstand wie der umgebende Form-Grid. */
[data-painting-extras]:not([hidden]),
[data-ek-booking-extras]:not([hidden]) {
  display: grid;
  gap: 16px;
}

.ap-extras {
  border: 1px solid var(--mauve-light-30);
  border-radius: 6px;
  padding: var(--space-md);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.ap-extras legend {
  padding-inline: var(--space-xs);
  font-family: var(--font-ui);
  font-size: var(--font-size-md);
  color: var(--color-midnight);
}

.ap-extras__row {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.ap-extras__row-head {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: nowrap;
}

.ap-extras__row-label {
  font-family: var(--font-ui);
  font-size: var(--font-size-md);
  font-weight: 600;
  color: var(--color-midnight);
  flex: 1 1 0;
  min-width: 0;
}

.ap-extras__row-price {
  font-family: var(--font-ui);
  font-size: 13px;
  color: rgba(26, 0, 8, 0.6);
  white-space: nowrap;
  flex: 0 0 auto;
}

.ap-extras__add {
  appearance: none;
  border: 1px solid var(--color-brand-red);
  background: transparent;
  color: var(--color-brand-red);
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  flex: 0 0 auto;
  white-space: nowrap;
}

.ap-extras__add:hover:not(:disabled) {
  background: var(--color-brand-red);
  color: #fff;
}

.ap-extras__add:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.ap-extras__person {
  border: 1px dashed var(--mauve-light-30);
  border-radius: 6px;
  padding: var(--space-sm) var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ap-extras__person-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ap-extras__person-name {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-midnight);
}

.ap-extras__remove {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--color-bordeaux);
  font-size: 22px;
  line-height: 1;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  transition: background 0.15s;
}

.ap-extras__remove:hover {
  background: rgba(139, 26, 45, 0.1);
}

.ap-extras__canvas {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ap-extras__canvas-opt {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--color-midnight);
  cursor: pointer;
}

.ap-extras__canvas-opt input {
  margin: 0;
  accent-color: var(--color-brand-red);
}

.ap-extras__cap {
  font-family: var(--font-ui);
  font-size: 12px;
  color: rgba(26, 0, 8, 0.55);
  margin: 0;
  font-style: italic;
}

/* Live-Summe oben/unten im Buchungs-Form. */
.ap-extras-total {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-brand-red);
  margin: 0 0 var(--space-sm);
}
