.reciev-booking-form {
  max-width: 1020px;
  font-family: inherit;
}

/* ── Products table ── */
.reciev-products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.reciev-products-table { margin-bottom: 16px; }
.reciev-products-table input[type='number'] { width: 90px; }
.reciev-product-option {
  border: 1px solid #d0d4d9;
  border-radius: 8px;
  padding: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: #fff;
}

/* ── Accordion card ── */
.reciev-attendee-card {
  border: 1px solid #b0bcc8;
  border-radius: 12px;
  margin-bottom: 12px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(0,0,0,.07);
}
.reciev-accordion-header {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
  user-select: none;
  background: #e8eef5;
  border-bottom: 1px solid transparent;
}
.reciev-attendee-card.reciev-accordion-open .reciev-accordion-header {
  border-bottom-color: #b0bcc8;
  background: #dce5ef;
}
.reciev-accordion-header:hover { background: #dce5ef; }
.reciev-accordion-title { font-weight: 700; font-size: 16px; color: #1a2a3a; }
.reciev-accordion-arrow { font-size: 13px; color: #556; margin-left: 8px; }
.reciev-accordion-body { padding: 20px; }

/* ── Attendee field grid ── */
.reciev-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin-bottom: 8px;
}
.reciev-field label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: #445;
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: .4px;
}
.reciev-field input { width: 100%; font-size: 15px; padding: 6px 8px; }

/* ── Events section title ── */
.reciev-events-wrap { margin-top: 22px; }
.reciev-events-wrap > h5 {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: #667;
  margin: 0 0 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid #d8e0ea;
}

/* ── Groups layout ── */
.reciev-groups-layout { width: 100%; }

.reciev-groups-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  width: 100%;
  border: 2px solid #b0bcc8;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

.reciev-groups-col--left,
.reciev-groups-col--right {
  min-width: 0;
  padding: 16px 18px;
}
.reciev-groups-col--left  { background: #f7f9fc; border-right: 2px solid #b0bcc8; }
.reciev-groups-col--right { background: #f7f9fc; }

/* Column headers */
.reciev-groups-col--left::before,
.reciev-groups-col--right::before {
  display: block;
  font-size: 25px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: #2a3a4a;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid #c8d4e0;
}
.reciev-groups-col--left::before  { content: attr(data-col-label); }
.reciev-groups-col-subtitle {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: #556;
  margin-top: -8px;
  margin-bottom: 14px;
  letter-spacing: .2px;
}

.reciev-groups-col--right::before { content: attr(data-col-label); }

/* Center block */
.reciev-groups-col--center {
  margin-top: 12px;
  border: 2px solid #b0bcc8;
  border-radius: 12px;
  background: #f7f9fc;
  padding: 16px 18px;
  width: 100%;
  box-sizing: border-box;
}
.reciev-groups-col--center::before {
  display: block;
  font-size: 25px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: #2a3a4a;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid #c8d4e0;
  content: attr(data-col-label);
}

/* ── Individual date group box ── */
.reciev-event-group {
  margin-bottom: 12px;
  border: 1px solid #c8d4df;
  border-radius: 10px;
  padding: 14px 16px;
  background: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.reciev-event-group:last-child { margin-bottom: 0; }

.reciev-event-group-title {
  margin: 0 0 12px;
  font-weight: 800;
  font-size: 20px;
  color: #1a2a3a;
  padding-bottom: 8px;
  border-bottom: 1px solid #dde6f0;
}

/* ── Radio options: flat single column ── */
.reciev-event-cols { display: block !important; }
.reciev-event-col--left,
.reciev-event-col--right,
.reciev-event-col--extra {
  display: block !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* "Non partecipo" option */
.reciev-event-choice--none {
  display: flex;
  gap: 10px;
  align-items: center;
  margin: 0 0 10px;
  padding: 8px 10px;
  background: #f0f4f8;
  border-radius: 6px;
  font-size: 15px;
  font-style: italic;
  color: #667;
  cursor: pointer;
}
.reciev-event-choice--none input[type="radio"] {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  cursor: pointer;
}

/* Event radio option — card style */
.reciev-event-choice {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin: 6px 0;
  padding: 10px 12px;
  border: 1px solid #dde6f0;
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
  transition: background .12s, border-color .12s;
  font-size: 15px;
  line-height: 1.5;
}
.reciev-event-choice:hover {
  background: #eef4fb;
  border-color: #90aacc;
}
.reciev-event-choice input[type="radio"] {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
  cursor: pointer;
  accent-color: #2060b0;
}
/* Highlight selected option */
.reciev-event-choice:has(input:checked) {
  background: #e6f0fb;
  border-color: #2060b0;
  border-width: 2px;
}

.reciev-event-choice-content { display: flex; flex-direction: column; gap: 4px; }
.reciev-event-main-label { font-size: 15px; line-height: 1.5; color: #1a2a3a; font-weight: 500; }
.reciev-event-choice.is-disabled { opacity: 0.5; cursor: not-allowed; }

.reciev-event-linked-product {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: #9a5a00;
  background: #fff4dd;
  border: 1px solid #f1d7aa;
  border-radius: 6px;
  padding: 3px 8px;
}
.reciev-event-full {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: #8f1d1d;
}

/* ── Note textarea ── */
.reciev-event-note-wrap { display: none; margin-top: 8px; }
.reciev-event-note-label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.reciev-event-note { width: 100%; min-height: 72px; resize: vertical; font-size: 15px; }

/* ── Responsive ── */
@media (max-width: 700px) {
  .reciev-groups-row { grid-template-columns: 1fr !important; }
  .reciev-groups-col--left { border-right: none; border-bottom: 2px solid #b0bcc8; }
}
