.reservation-shell {
  background:
    radial-gradient(circle at top left, rgba(238, 183, 43, 0.1), transparent 24%),
    radial-gradient(circle at top right, rgba(147, 31, 51, 0.14), transparent 30%),
    hsl(var(--background));
}

.reservation-hero {
  padding: 5.5rem 0 2.5rem;
}

.reservation-hero__grid {
  display: grid;
  gap: 1.5rem;
}

.reservation-hero__copy,
.reservation-summary-card,
.reservation-form-card,
.reservation-success-card {
  border-radius: 1.5rem;
}

.reservation-hero__copy {
  padding: 1.5rem;
  border: 1px solid rgba(238, 183, 43, 0.14);
  background:
    linear-gradient(145deg, rgba(24, 18, 16, 0.88), rgba(18, 13, 11, 0.94)),
    rgba(255, 255, 255, 0.02);
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.24);
}

.reservation-hero__lead {
  max-width: 44rem;
  color: hsl(var(--muted-foreground));
  font-size: 1.08rem;
  line-height: 1.8;
}

.reservation-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1.5rem;
}

.reservation-payment-strip {
  display: grid;
  gap: 0.75rem;
  margin-top: 1.15rem;
}

.reservation-payment-strip__label {
  color: hsl(var(--muted-foreground));
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.reservation-payment-strip__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.reservation-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.6rem 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: hsl(var(--foreground));
  font-size: 0.9rem;
}

.reservation-chip--accent {
  border-color: rgba(238, 183, 43, 0.18);
  background: rgba(238, 183, 43, 0.08);
}

.reservation-chip--recommended {
  border-color: rgba(238, 183, 43, 0.3);
  background: linear-gradient(135deg, rgba(238, 183, 43, 0.14), rgba(147, 31, 51, 0.08));
}

.reservation-summary-card {
  padding: 1.5rem;
  border: 1px solid rgba(238, 183, 43, 0.18);
  background:
    radial-gradient(circle at top right, rgba(238, 183, 43, 0.14), transparent 36%),
    rgba(20, 15, 13, 0.94);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22);
}

.reservation-summary-card__eyebrow {
  display: inline-flex;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 0.72rem;
  color: hsl(var(--muted-foreground));
}

.reservation-summary-card__title {
  margin-top: 0.75rem;
  font-family: "Playfair Display", serif;
  font-size: 1.85rem;
  font-weight: 700;
  color: hsl(var(--foreground));
}

.reservation-summary-list {
  display: grid;
  gap: 1rem;
  margin-top: 1.25rem;
}

.reservation-summary-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.9rem;
  align-items: start;
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
}

.reservation-summary-item__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 0.9rem;
  background: rgba(238, 183, 43, 0.12);
  color: hsl(var(--accent));
}

.reservation-summary-item__title {
  color: hsl(var(--foreground));
  font-weight: 600;
}

.reservation-summary-item__copy {
  margin-top: 0.35rem;
  color: hsl(var(--muted-foreground));
  font-size: 0.92rem;
  line-height: 1.55;
}

.reservation-section {
  padding: 0.5rem 0 4rem;
}

.reservation-stage {
  max-width: 76rem;
  margin: 0 auto;
}

.reservation-form-card {
  padding: 1.5rem;
  border: 1px solid rgba(238, 183, 43, 0.14);
  background:
    linear-gradient(180deg, rgba(28, 21, 18, 0.96), rgba(18, 13, 11, 0.98)),
    rgba(255, 255, 255, 0.02);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
}

.reservation-summary-card:hover,
.reservation-form-card:hover,
.reservation-success-card:hover {
  transform: none;
  border-color: rgba(238, 183, 43, 0.18);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
}

.reservation-form-card__head {
  margin-bottom: 1.4rem;
  padding-bottom: 1.15rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.reservation-form-card__intro {
  max-width: 52rem;
  margin-top: 0.85rem;
  color: hsl(var(--muted-foreground));
  line-height: 1.7;
}

.reservation-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 1rem;
}

.reservation-field {
  min-width: 0;
}

.reservation-field--full {
  grid-column: 1 / -1;
}

.reservation-label-wrap {
  margin-bottom: 0.7rem;
}

.reservation-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: hsl(var(--foreground));
  font-size: 0.95rem;
  font-weight: 600;
}

.reservation-help {
  margin-top: 0.35rem;
  color: hsl(var(--muted-foreground));
  font-size: 0.86rem;
}

.reservation-control {
  width: 100%;
  min-height: 3.2rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 1rem;
  background: rgba(70, 48, 31, 0.84);
  color: hsl(var(--foreground));
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.reservation-control:focus {
  outline: none;
  border-color: rgba(238, 183, 43, 0.42);
  box-shadow: 0 0 0 3px rgba(238, 183, 43, 0.08);
}

.reservation-control--textarea {
  min-height: 7.5rem;
  resize: vertical;
}

.reservation-control--file {
  padding: 0.75rem 1rem;
  background: rgba(255, 255, 255, 0.04);
}

.reservation-control--file::file-selector-button {
  margin-right: 0.85rem;
  padding: 0.55rem 0.9rem;
  border: 0;
  border-radius: 0.7rem;
  background: linear-gradient(135deg, rgba(238, 183, 43, 0.95), rgba(179, 128, 25, 0.95));
  color: hsl(var(--accent-foreground));
  font-weight: 700;
  cursor: pointer;
}

.reservation-type-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 0.9rem;
}

.reservation-type-card {
  display: grid;
  gap: 0.55rem;
  min-height: 100%;
  padding: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 1.15rem;
  background: rgba(255, 255, 255, 0.02);
  text-align: left;
  transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.reservation-type-card:hover {
  transform: translateY(-2px);
  border-color: rgba(238, 183, 43, 0.26);
  background: rgba(255, 255, 255, 0.04);
}

.reservation-type-card.is-active {
  border-color: rgba(238, 183, 43, 0.42);
  background: linear-gradient(135deg, rgba(238, 183, 43, 0.14), rgba(147, 31, 51, 0.1));
  box-shadow: inset 0 0 0 1px rgba(238, 183, 43, 0.1);
}

.reservation-type-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.7rem;
  height: 2.7rem;
  border-radius: 0.95rem;
  background: rgba(238, 183, 43, 0.14);
  color: hsl(var(--accent));
}

.reservation-type-card__title {
  color: hsl(var(--foreground));
  font-weight: 700;
}

.reservation-type-card__copy {
  color: hsl(var(--muted-foreground));
  font-size: 0.88rem;
  line-height: 1.55;
}

.reservation-notice {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.85rem;
  padding: 1rem 1.05rem;
  border-radius: 1rem;
}

.reservation-notice--accent {
  border: 1px solid rgba(238, 183, 43, 0.26);
  background: rgba(238, 183, 43, 0.1);
}

.reservation-notice i {
  color: hsl(var(--accent));
  margin-top: 0.1rem;
}

.reservation-notice__title {
  color: hsl(var(--foreground));
  font-weight: 700;
}

.reservation-notice__copy {
  margin-top: 0.3rem;
  color: hsl(var(--muted-foreground));
  font-size: 0.92rem;
  line-height: 1.6;
}

.reservation-inline-check {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.8rem;
  align-items: start;
  padding: 1rem 1.05rem;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.reservation-inline-check input {
  width: 1rem;
  height: 1rem;
  margin-top: 0.25rem;
  accent-color: hsl(var(--accent));
}

.reservation-inline-check span {
  display: grid;
  gap: 0.28rem;
}

.reservation-inline-check strong {
  color: hsl(var(--foreground));
  font-size: 0.96rem;
}

.reservation-inline-check small {
  color: hsl(var(--muted-foreground));
  font-size: 0.86rem;
  line-height: 1.55;
}

.reservation-payment-choice {
  padding: 1.2rem;
  border-radius: 1.15rem;
  border: 1px solid rgba(238, 183, 43, 0.18);
  background: rgba(238, 183, 43, 0.06);
}

.reservation-payment-choice__eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  color: hsl(var(--muted-foreground));
}

.reservation-payment-choice__title {
  margin-top: 0.45rem;
  color: hsl(var(--foreground));
  font-size: 1.15rem;
  font-weight: 700;
}

.reservation-payment-choice__copy {
  margin-top: 0.4rem;
  color: hsl(var(--muted-foreground));
  font-size: 0.92rem;
  line-height: 1.6;
}

.reservation-payment-choice__grid {
  display: grid;
  gap: 0.85rem;
  margin-top: 1rem;
}

.reservation-payment-card {
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: 0.85rem;
  align-items: start;
  padding: 1rem;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.reservation-payment-card:hover {
  transform: translateY(-2px);
  border-color: rgba(238, 183, 43, 0.24);
  background: rgba(255, 255, 255, 0.04);
}

.reservation-payment-card.is-active {
  border-color: rgba(238, 183, 43, 0.42);
  background: linear-gradient(135deg, rgba(238, 183, 43, 0.14), rgba(147, 31, 51, 0.08));
}

.reservation-payment-card input[type="radio"] {
  margin-top: 0.3rem;
  accent-color: hsl(var(--accent));
}

.reservation-payment-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.9rem;
  background: rgba(238, 183, 43, 0.14);
  color: hsl(var(--accent));
}

.reservation-payment-card__body {
  display: grid;
  gap: 0.35rem;
}

.reservation-payment-card__label {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  color: hsl(var(--foreground));
  font-weight: 700;
}

.reservation-payment-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  background: rgba(238, 183, 43, 0.16);
  color: hsl(var(--accent));
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.reservation-payment-card__hint {
  color: hsl(var(--muted-foreground));
  font-size: 0.88rem;
  line-height: 1.55;
}

.reservation-payment-details {
  margin-top: 1rem;
}

.reservation-payment-details__panel {
  padding: 1rem 1.05rem;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(20, 15, 13, 0.55);
}

.reservation-payment-details__text {
  color: hsl(var(--muted-foreground));
  font-size: 0.92rem;
  line-height: 1.7;
}

.reservation-payment-qr {
  display: grid;
  gap: 0.9rem;
  justify-items: start;
}

.reservation-payment-qr__image {
  width: min(100%, 15rem);
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: 0.8rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.95);
}

.reservation-payment-qr__copy {
  color: hsl(var(--muted-foreground));
  font-size: 0.92rem;
  line-height: 1.6;
}

.reservation-proof-card {
  padding: 1.1rem 1.15rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(238, 183, 43, 0.18);
  background: rgba(255, 255, 255, 0.03);
}

.reservation-proof-card__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.8rem;
  margin-bottom: 0.9rem;
}

.reservation-proof-card__head i {
  margin-top: 0.15rem;
  color: hsl(var(--accent));
}

.reservation-proof-card__title {
  color: hsl(var(--foreground));
  font-size: 1rem;
  font-weight: 700;
}

.reservation-proof-card__copy,
.reservation-proof-card__note {
  color: hsl(var(--muted-foreground));
  font-size: 0.9rem;
  line-height: 1.6;
}

.reservation-proof-card__copy {
  margin-top: 0.25rem;
}

.reservation-proof-card__note {
  margin-top: 0.45rem;
}

.reservation-policy-grid {
  display: grid;
  gap: 1rem;
  margin-top: 1.35rem;
}

.reservation-policy-card {
  padding: 1.15rem 1.2rem;
  border-radius: 1.1rem;
}

.reservation-policy-card--payment {
  border: 1px solid rgba(238, 183, 43, 0.18);
  background: rgba(238, 183, 43, 0.08);
}

.reservation-policy-card--cancellation {
  border: 1px solid rgba(147, 31, 51, 0.18);
  background: rgba(147, 31, 51, 0.1);
}

.reservation-policy-card__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.8rem;
  margin-bottom: 0.85rem;
}

.reservation-policy-card__head i {
  margin-top: 0.12rem;
}

.reservation-policy-card__head h3 {
  font-size: 1.04rem;
  font-weight: 700;
  color: hsl(var(--foreground));
}

.reservation-policy-card__head p,
.reservation-policy-card__subline,
.reservation-policy-list {
  color: hsl(var(--muted-foreground));
  font-size: 0.92rem;
  line-height: 1.6;
}

.reservation-policy-card__line {
  font-weight: 600;
}

.reservation-policy-card__line--ok {
  color: hsl(var(--foreground));
}

.reservation-policy-card__line--warning {
  color: hsl(var(--accent));
}

.reservation-policy-card__subline {
  margin-top: 0.4rem;
}

.reservation-policy-list {
  display: grid;
  gap: 0.45rem;
  padding-left: 1rem;
  list-style: disc;
}

.reservation-actions {
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
}

.reservation-submit {
  min-width: min(100%, 20rem);
}

.reservation-success-card {
  max-width: 40rem;
  margin: 0 auto;
  padding: 2rem 1.5rem;
  text-align: center;
  border: 1px solid rgba(238, 183, 43, 0.18);
  background:
    radial-gradient(circle at top center, rgba(238, 183, 43, 0.14), transparent 38%),
    rgba(20, 15, 13, 0.96);
}

.reservation-success-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 5.5rem;
  height: 5.5rem;
  margin: 0 auto 1.25rem;
  border-radius: 999px;
  background: rgba(238, 183, 43, 0.14);
  color: hsl(var(--accent));
}

.reservation-success-card__copy {
  max-width: 32rem;
  margin: 1rem auto 1.5rem;
  color: hsl(var(--muted-foreground));
  line-height: 1.75;
}

@media (min-width: 768px) {
  .reservation-hero {
    padding-top: 6.5rem;
  }

  .reservation-hero__copy,
  .reservation-summary-card,
  .reservation-form-card,
  .reservation-success-card {
    padding: 2rem;
  }

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

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

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

  .reservation-payment-choice__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .reservation-hero__grid {
    grid-template-columns: minmax(0, 1.5fr) minmax(20rem, 0.9fr);
    align-items: stretch;
  }

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