.hero-reservations {
  position: relative;
  padding-bottom: clamp(3rem, 2.5rem + 2vw, 4.5rem);
}

.hero-reservations__bg {
  background-image: url('/assets/images/reservation-hero-evening-lounge.webp');
  background-position: center;
  background-size: cover;
  opacity: 0.4;
}

.hero-reservations__overlay {
  background:
    radial-gradient(circle at 10% 0%, rgba(141, 210, 255, 0.3), transparent 55%),
    radial-gradient(circle at 90% 100%, rgba(18, 68, 150, 0.7), transparent 60%),
    linear-gradient(170deg, rgba(5, 8, 20, 0.96), rgba(5, 8, 20, 0.98));
}

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

.hero-reservations__copy {
  max-width: 640px;
}

.hero-reservations__badge {
  margin-bottom: var(--space-4);
}

.hero-reservations__lead {
  font-size: var(--font-size-lg);
  color: var(--color-silver-soft);
  max-width: 36rem;
}

.hero-reservations__highlights {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-5);
}

.hero-reservations__highlight-item {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(207, 212, 227, 0.3);
  background:
    linear-gradient(135deg, rgba(59, 124, 255, 0.18), rgba(141, 210, 255, 0.03)),
    linear-gradient(150deg, rgba(5, 10, 26, 0.98), rgba(3, 7, 18, 0.98));
  box-shadow: var(--shadow-soft-alt);
}

.hero-reservations__highlight-label {
  display: block;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.hero-reservations__highlight-value {
  font-size: var(--font-size-md);
  color: var(--color-silver);
}

.hero-reservations__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.hero-reservations__card-wrapper {
  max-width: 320px;
}

.hero-reservations__card-title {
  font-size: var(--font-size-xl);
  margin-bottom: var(--space-2);
}

.hero-reservations__card-subtitle {
  font-size: var(--font-size-sm);
}

.hero-reservations__mini-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.hero-reservations__mini-item dt {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.hero-reservations__mini-item dd {
  font-size: var(--font-size-sm);
  color: var(--color-silver);
}

.hero-reservations__card-footer {
  margin-top: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.hero-reservations__note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.hero-reservations__image-shell {
  position: absolute;
  inset: auto;
  right: 5%;
  bottom: -10%;
  width: 360px;
  max-width: 38vw;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
  opacity: 0.8;
}

.hero-reservations__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

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

  .hero-reservations__highlights {
    grid-template-columns: minmax(0, 1fr);
  }

  .hero-reservations__image-shell {
    position: static;
    width: 100%;
    max-width: 100%;
    margin-top: var(--space-6);
    opacity: 1;
  }
}

@media (max-width: 600px) {
  .hero-reservations__actions {
    flex-direction: column;
    align-items: flex-start;
  }
}

.reservation-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.reservation-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

.reservation-form__span-2 {
  grid-column: 1 / -1;
}

.reservation-form__preferences {
  border: 1px solid rgba(207, 212, 227, 0.25);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  background:
    linear-gradient(135deg, rgba(59, 124, 255, 0.1), rgba(141, 210, 255, 0.02)),
    linear-gradient(150deg, rgba(5, 10, 26, 0.98), rgba(3, 7, 18, 0.98));
}

.reservation-form__preferences legend {
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-silver-soft);
  margin-bottom: var(--space-2);
}

.reservation-form__preferences-hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}

.reservation-form__preferences-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.reservation-form__chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding-inline: var(--space-3);
  padding-block: 0.45rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(207, 212, 227, 0.4);
  background: linear-gradient(135deg, rgba(10, 18, 38, 0.96), rgba(3, 7, 20, 0.98));
  font-size: var(--font-size-xs);
  cursor: pointer;
}

.reservation-form__chip input {
  width: 1rem;
  height: 1rem;
}

.reservation-form__footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-2);
}

.reservation-form__consent {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.reservation-form__consent input {
  margin-top: 0.15rem;
}

.reservation-form__disclaimer {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

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

.reservation-sidebar {
  align-self: stretch;
}

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

.reservation-sidebar__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.reservation-sidebar__list h3 {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-1);
}

.reservation-sidebar__link {
  font-size: var(--font-size-sm);
  color: var(--color-ice);
}

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

.reservation-steps__list {
  position: relative;
  padding-left: var(--space-6);
}

.reservation-steps__list::before {
  content: "";
  position: absolute;
  top: 0.6rem;
  bottom: 0.6rem;
  left: 1.1rem;
  width: 2px;
  background: linear-gradient(to bottom, rgba(141, 210, 255, 0.8), rgba(59, 124, 255, 0.2));
}

.reservation-steps__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-4);
}

.reservation-steps__item + .reservation-steps__item {
  margin-top: var(--space-4);
}

.reservation-steps__icon {
  width: 2.4rem;
  height: 2.4rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(207, 212, 227, 0.6);
  background: radial-gradient(circle at 30% 0%, rgba(141, 210, 255, 0.45), transparent 55%),
    linear-gradient(135deg, rgba(3, 7, 18, 0.98), rgba(8, 17, 38, 0.98));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-sm);
}

.reservation-steps__content h3 {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-2);
}

.reservation-steps__figure {
  max-width: 480px;
  margin-inline: auto;
}

.reservation-groups__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.reservation-groups__list h3 {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-1);
}

.reservation-groups__cta {
  margin-top: var(--space-4);
}

.reservation-groups__card {
  height: 100%;
}

.reservation-groups__meta {
  display: grid;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.reservation-groups__meta dt {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.reservation-groups__meta dd {
  font-size: var(--font-size-sm);
}

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

.reservation-programs__grid {
  margin-top: var(--space-4);
}

.reservation-programs__figure {
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-4);
}

.reservation-programs__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.reservation-programs__meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.reservation-programs__hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.reservation-programs__link-wrap {
  display: flex;
  align-items: center;
}

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

  .reservation-programs__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.reservation-faq__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: var(--space-6);
}

.reservation-faq__items {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.reservation-faq__aside .card {
  height: 100%;
}

.reservation-faq__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.reservation-faq__links a {
  font-size: var(--font-size-sm);
  color: var(--color-ice);
}

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

.reservation-location__details {
  display: grid;
  gap: var(--space-3);
}

.reservation-location__details dt {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}

.reservation-location__details dd {
  font-size: var(--font-size-sm);
}

.reservation-location__map-card {
  height: 100%;
}

.reservation-location__map-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.reservation-location__map-placeholder {
  border-radius: var(--radius-lg);
  border: 1px dashed rgba(207, 212, 227, 0.4);
  padding: var(--space-5);
  background:
    radial-gradient(circle at 10% 0%, rgba(141, 210, 255, 0.18), transparent 55%),
    linear-gradient(145deg, rgba(5, 10, 26, 0.98), rgba(3, 7, 18, 0.98));
}

.reservation-location__map-title {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-2);
}

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

.reservation-location__small-text {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

@media (max-width: 900px) {
  .reservation-location__map-shell {
    order: -1;
  }
}
