.reservation-hero {
  padding-top: var(--space-20);
}

.reservation-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: center;
}

@media (max-width: 900px) {
  .reservation-hero__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.reservation-hero__lead {
  font-size: var(--font-size-lg);
}

.reservation-hero__cta-group {
  margin-top: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.reservation-hero__info {
  margin-top: var(--space-8);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-4);
}

@media (max-width: 768px) {
  .reservation-hero__info {
    grid-template-columns: minmax(0, 1fr);
  }
}

.reservation-hero__info-item p {
  margin-top: var(--space-2);
  margin-bottom: 0;
}

.reservation-hero__image {
  max-width: 520px;
  margin-left: auto;
}

.reservation-breadcrumbs ol {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.reservation-breadcrumbs li+li::before {
  content: "/";
  margin-right: var(--space-2);
  opacity: 0.6;
}

.reservation-form-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: flex-start;
}

@media (max-width: 1024px) {
  .reservation-form-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

.reservation-section-header {
  margin-bottom: var(--space-6);
}

.reservation-form__group {
  margin-bottom: var(--space-6);
}

.reservation-form__legend {
  font-family: var(--font-serif);
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-3);
}

.reservation-subtitle {
  font-size: var(--font-size-xl);
  margin-bottom: var(--space-3);
}

.reservation-form__options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-4);
}

.reservation-radio-card,
.reservation-checkbox-card {
  position: relative;
  display: flex;
  cursor: pointer;
}

.reservation-radio-card input,
.reservation-checkbox-card input {
  position: absolute;
  opacity: 0;
  inset: 0;
}

.reservation-radio-card__body,
.reservation-checkbox-card__body {
  width: 100%;
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: radial-gradient(circle at top left, rgba(224, 160, 75, 0.12), transparent 55%), var(--color-surface);
  transition: border-color var(--transition-normal), box-shadow var(--transition-normal), transform var(--transition-fast), background var(--transition-normal);
}

.reservation-radio-card__title,
.reservation-checkbox-card__title {
  display: block;
  font-family: var(--font-serif);
  margin-bottom: var(--space-1);
}

.reservation-radio-card__desc,
.reservation-checkbox-card__desc {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.reservation-radio-card input:checked + .reservation-radio-card__body,
.reservation-checkbox-card input:checked + .reservation-checkbox-card__body {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-soft);
  transform: translateY(-1px);
}

.reservation-form__footer {
  margin-top: var(--space-6);
}

.reservation-form__disclaimer {
  margin-bottom: var(--space-4);
}

.reservation-checkbox {
  width: 1.1rem;
  height: 1.1rem;
}

.reservation-callback {
  align-items: flex-start;
}

.reservation-choice__row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  padding: 0.35rem 0;
}

.reservation-choice__label {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.reservation-choice__value {
  font-size: var(--font-size-sm);
  text-align: right;
}

.reservation-calendar__image {
  max-width: 340px;
}

.reservation-calendar__legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.reservation-calendar__legend-item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.reservation-calendar__dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.reservation-calendar__dot--free {
  background: var(--color-success);
}

.reservation-calendar__dot--limited {
  background: var(--color-warning);
}

.reservation-calendar__dot--full {
  background: var(--color-danger);
}

.reservation-info__grid {
  gap: var(--space-6);
}

.reservation-info__card .card__body {
  margin-bottom: var(--space-3);
}

.reservation-contact__cta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

@media (max-width: 768px) {
  .reservation-contact__cta {
    align-items: stretch;
    width: 100%;
  }
}

.reservation-contact__cta .button {
  width: 100%;
}
