@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700;800&display=swap");

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Playfair Display", Georgia, "Times New Roman", serif;
  background:
    linear-gradient(rgba(6, 6, 6, 0.5), rgba(6, 6, 6, 0.8)),
    url("../images/vintage-bg.png")
      center center / cover fixed no-repeat;
  color: #f3ecdf;
  min-height: 100vh;
}

.container {
  max-width: 1280px;
  margin: 36px auto;
  padding: 0 20px;
  display: grid;
  grid-template-columns: minmax(0, 2.1fr) minmax(280px, 1fr);
  gap: 20px;
}

.container.single {
  grid-template-columns: 1fr;
  max-width: 920px;
}

.card {
  background:
    linear-gradient(180deg, rgba(15, 15, 15, 0.95) 0%, rgba(9, 9, 9, 0.95) 100%),
    radial-gradient(circle at top right, rgba(191, 153, 88, 0.15) 0%, transparent 50%);
  border-radius: 20px;
  padding: 30px;
  border: 1px solid rgba(198, 161, 99, 0.42);
  box-shadow:
    0 20px 50px rgba(0, 0, 0, 0.55),
    inset 0 1px 0 rgba(255, 232, 191, 0.12);
  backdrop-filter: blur(4px);
}

.narrow {
  max-width: 460px;
  margin: 0 auto;
}

h1, h2, h3, h4 {
  margin-top: 0;
  color: #f7e4bf;
  letter-spacing: 0.4px;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.5);
}

h1 {
  font-size: clamp(30px, 4.6vw, 42px);
  margin-bottom: 10px;
}

h2 {
  font-size: clamp(21px, 3vw, 30px);
  margin-bottom: 8px;
}

h3 {
  font-size: 21px;
}

.grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

input {
  width: 100%;
  padding: 13px 14px;
  margin-bottom: 12px;
  border: 1px solid #826a47;
  border-radius: 11px;
  font-size: 15px;
  background: rgba(10, 10, 10, 0.78);
  color: #f2f2f2;
  font-family: "Segoe UI", Arial, sans-serif;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

input::placeholder {
  color: #b7a386;
}

input:focus {
  border-color: #d7b47a;
  outline: none;
  box-shadow: 0 0 0 3px rgba(215, 180, 122, 0.2);
}

.attendee-block {
  border: 1px solid rgba(168, 136, 87, 0.4);
  border-radius: 12px;
  padding: 14px;
  margin: 10px 0;
  background: rgba(19, 19, 19, 0.86);
}

.primary-btn {
  background: linear-gradient(135deg, #b08a54 0%, #8d6b3f 100%);
  color: #fff8ea;
  border: none;
  border-radius: 11px;
  padding: 13px 20px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.35px;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.primary-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 18px rgba(176, 138, 84, 0.32);
}

.primary-btn.inline {
  text-decoration: none;
  display: inline-block;
}

.small {
  font-size: 14px;
  line-height: 1.5;
  font-family: "Segoe UI", Arial, sans-serif;
}

.muted {
  color: #d8cab3;
  font-family: "Segoe UI", Arial, sans-serif;
}

.status {
  margin-top: 12px;
  font-weight: 600;
  font-family: "Segoe UI", Arial, sans-serif;
}

.status.error,
.error {
  color: #ff8f8f;
}

.status.success {
  color: #a4ffbf;
}

.ticket-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(265px, 1fr));
  gap: 14px;
}

.ticket-card {
  border: 1px dashed #8c6d45;
  border-radius: 14px;
  padding: 16px;
  background: rgba(16, 16, 16, 0.84);
}

.ticket-card img {
  max-width: 160px;
  width: 100%;
}

.qr-svg img {
  width: 170px;
  height: 170px;
  background: #fff;
  padding: 6px;
  border-radius: 8px;
}

#reader {
  width: 100%;
  max-width: 420px;
  margin-bottom: 12px;
}

.top-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.top-row a {
  text-decoration: none;
  color: #f6e1bb;
  font-weight: 600;
}

.hero {
  margin-bottom: 10px;
}

.badge {
  display: inline-block;
  background: linear-gradient(135deg, #dac19a 0%, #b38f60 100%);
  color: #1a1309;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 6px 12px;
  margin-bottom: 12px;
  box-shadow: 0 5px 14px rgba(179, 143, 96, 0.3);
}

.success-badge {
  background: linear-gradient(135deg, #e9d4b4 0%, #b7905b 100%);
  color: #1a1207;
}

.meta-grid {
  display: grid;
  gap: 8px;
  font-family: "Segoe UI", Arial, sans-serif;
}

.section-block {
  margin-top: 12px;
}

hr {
  border: 0;
  border-top: 1px solid rgba(171, 137, 88, 0.42);
  margin: 20px 0;
}

ul {
  color: #efe4d3;
  padding-left: 18px;
  font-family: "Segoe UI", Arial, sans-serif;
  line-height: 1.55;
}

a {
  color: #f3d7a7;
  text-underline-offset: 3px;
}

/* Booking page theme matching provided reference style */
.booking-page {
  font-family: "Segoe UI", Arial, sans-serif;
}

.booking-page .booking-shell {
  max-width: 1180px;
  margin: 30px auto;
  padding: 0 16px;
}

.booking-page .page-title {
  text-align: center;
  margin: 0 0 16px;
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(34px, 5.3vw, 56px);
  color: #f8f5ef;
  letter-spacing: 1px;
}

.booking-page .booking-panel {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  border: 1px solid rgba(255, 208, 122, 0.35);
  background: rgba(10, 10, 10, 0.68);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.booking-page .left-panel,
.booking-page .right-panel {
  padding: 28px;
}

.booking-page .left-panel {
  background: rgba(0, 0, 0, 0.45);
  border-right: 1px solid rgba(255, 208, 122, 0.3);
}

.booking-page .left-panel h2 {
  font-size: 38px;
  margin-bottom: 14px;
}

.booking-page .left-panel ul {
  margin: 0 0 18px;
  padding-left: 18px;
}

.booking-page .left-panel li {
  margin-bottom: 10px;
  color: #f9edd8;
}

.booking-page .event-box {
  border: 1px solid rgba(255, 208, 122, 0.4);
  background: rgba(12, 12, 12, 0.72);
  padding: 14px;
}

.booking-page .event-box p {
  margin: 0 0 8px;
  color: #f8ecd8;
}

.booking-page .right-panel h3 {
  text-align: center;
  font-size: 34px;
  margin-bottom: 14px;
  color: #f7e8cc;
  font-family: "Playfair Display", Georgia, serif;
}

.booking-page label {
  display: block;
  margin: 6px 0 6px;
  color: #f3e3c4;
}

.booking-page .grid {
  grid-template-columns: repeat(2, 1fr);
}

.booking-page input {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255, 224, 169, 0.8);
  border-radius: 0;
  padding: 11px 2px;
}

.booking-page input:focus {
  box-shadow: none;
  border-bottom-color: #ffffff;
}

.booking-page .attendee-block {
  border: 1px solid rgba(255, 217, 145, 0.25);
  background: rgba(0, 0, 0, 0.27);
}

.booking-page .primary-btn {
  width: 100%;
  margin-top: 6px;
  border-radius: 0;
  background: linear-gradient(0deg, #d19b2c 0%, #edbc56 100%);
  color: #101010;
  font-size: 16px;
}

.booking-page .primary-btn:hover {
  box-shadow: 0 10px 20px rgba(228, 182, 86, 0.35);
}

.booking-page #totalAmount,
.booking-page .status {
  color: #ffeac0;
  font-weight: 700;
}

.legal-footer {
  margin-top: 12px;
  padding: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  background: rgba(0, 0, 0, 0.6);
  border: 1px solid rgba(255, 208, 122, 0.35);
}

.legal-footer a {
  color: #f3d7a7;
  text-decoration: none;
  font-weight: 600;
}

@media (max-width: 900px) {
  .container {
    grid-template-columns: 1fr;
    margin: 20px auto;
  }

  .booking-page .booking-panel {
    grid-template-columns: 1fr;
  }

  .booking-page .left-panel {
    border-right: none;
    border-bottom: 1px solid rgba(255, 208, 122, 0.3);
  }
}

@media (max-width: 520px) {
  .card {
    padding: 20px;
    border-radius: 16px;
  }

  .grid {
    grid-template-columns: 1fr;
  }

  .booking-page .right-panel h3 {
    font-size: 28px;
  }
}
