/* ── Pretix widget – deep theming ── */

/* Container */
.pretix-widget {
  border: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 0.5rem !important;
  background: transparent !important;
  color: var(--text) !important;
  font-family: "FKRomanBoldOblique", sans-serif !important;
  border-radius: 0 !important;
}

.pretix-widget-attribution {
  display: none !important;
}

/* Loading overlay */
.pretix-widget .pretix-widget-loading {
  background: rgba(6, 53, 58, 0.6) !important;
}

/* ── Categories ── */
.pretix-widget .pretix-widget-category {
  margin: 1.25rem 0 0.5rem !important;
}

.pretix-widget .pretix-widget-category-name {
  color: var(--accent) !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 1.1rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.22em !important;
  padding: 0 1.25rem !important;
  margin: 0 0 0.5rem !important;
  text-align: left !important;
}

.pretix-widget .pretix-widget-category-description {
  color: var(--muted) !important;
  font-size: 0.75rem !important;
  padding: 0 0.25rem !important;
}

/* ── Item rows (ticket-style cards) ── */
.pretix-widget .pretix-widget-item-row {
  border: 1px solid var(--stroke) !important;
  border-radius: 20px !important;
  background: rgba(6, 51, 56, 0.44) !important;
  backdrop-filter: blur(12px) !important;
  padding: 1rem 1.25rem !important;
  margin-bottom: 0.6rem !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 0.35rem 0.75rem !important;
}

/* Price + quantity on the same line */
.pretix-widget .pretix-widget-item-row > .pretix-widget-item-price-col,
.pretix-widget .pretix-widget-item-row > .pretix-widget-item-availability-col {
  flex: 0 0 auto !important;
}

.pretix-widget .pretix-widget-item-row > .pretix-widget-clear {
  display: none !important;
}

/* Hide the thumbnail on tee rows (showcase replaces it) */
.pretix-widget .pretix-widget-item-row.tee-row-hidden {
  display: none !important;
}

.pretix-widget .pretix-widget-item-info-col {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
  margin-bottom: 0.25rem !important;
}

/* Hide item picture thumbnail (our showcase card replaces it for tees) */
.pretix-widget .pretix-widget-item-picture-link {
  border-radius: 8px !important;
  overflow: hidden !important;
}

.pretix-widget .pretix-widget-item-title {
  color: var(--text) !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 1rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
}

.pretix-widget .pretix-widget-item-description {
  color: var(--muted) !important;
  font-size: 0.75rem !important;
  line-height: 1.45 !important;
}

.pretix-widget .pretix-widget-item-description p {
  margin: 0.2rem 0 !important;
}

.pretix-widget .pretix-widget-item-meta {
  color: var(--muted) !important;
  font-size: 0.7rem !important;
}

/* Price column */
.pretix-widget .pretix-widget-item-price-col {
  width: auto !important;
  float: none !important;
  padding: 0 !important;
  text-align: left !important;
  margin-bottom: 0 !important;
}

.pretix-widget .pretix-widget-item-price-col strong,
.pretix-widget .pretix-widget-item-row .pretix-widget-item-price-col strong,
.pretix-widget .pretix-widget-pricebox-new-price,
.pretix-widget .pretix-widget-item-price-col .pretix-widget-pricebox,
.pretix-widget .pretix-widget-item-price-col .pretix-widget-pricebox *,
.pretix-widget .pretix-widget-item-price-col span,
.ticket-panel .pretix-widget .pretix-widget-item-price-col strong {
  color: #ffde59 !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.08em !important;
  text-decoration: none !important;
}

.pretix-widget del.pretix-widget-pricebox-original-price {
  color: var(--muted) !important;
}

.pretix-widget .pretix-widget-pricebox-tax {
  color: var(--muted) !important;
  font-size: 0.62rem !important;
}

/* Availability column */
.pretix-widget .pretix-widget-item-availability-col {
  width: auto !important;
  float: none !important;
  padding: 0 !important;
  text-align: left !important;
  margin-bottom: 0 !important;
}

.pretix-widget .pretix-widget-availability-gone {
  color: #ffde59 !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.08em !important;
  line-height: 1.3 !important;
}

/* Hide SOLD OUT label only on V5 rows (waiting-list link stays visible) */
.pretix-widget .pretix-widget-item-row.v5-row .pretix-widget-availability-gone {
  display: none !important;
}

.pretix-widget .pretix-widget-availability-unavailable {
  color: #ffde59 !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.08em !important;
  line-height: 1.3 !important;
  text-transform: uppercase !important;
}

/* Waiting list link */
.pretix-widget .pretix-widget-item-availability-col .pretix-widget-availability-gone + a,
.pretix-widget .pretix-widget-item-availability-col a[href*="waitinglist"] {
  display: inline-block !important;
  margin-top: 0 !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.55) !important;
  text-decoration: none !important;
  padding: 0 !important;
  opacity: 1 !important;
  line-height: 1.3 !important;
}

.pretix-widget .pretix-widget-item-availability-col a[href*="waitinglist"]:hover {
  color: #fff !important;
  opacity: 1 !important;
}

/* "Only available with a voucher" link */
.pretix-widget .pretix-widget-item-availability-col a {
  color: var(--muted) !important;
  font-size: 0.65rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  opacity: 0.75;
  transition: opacity 180ms ease !important;
}

.pretix-widget .pretix-widget-item-availability-col a:hover {
  opacity: 1;
  color: var(--accent) !important;
}

/* Quantity spinner group */
.pretix-widget .pretix-widget-item-count-group {
  border: 1px solid var(--stroke) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  overflow: hidden !important;
  display: inline-flex !important;
  align-items: stretch !important;
}

.pretix-widget .pretix-widget-item-count-group input[type="number"],
.pretix-widget-use-custom-spinners input[type="number"] {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  color: var(--text) !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.1em !important;
  text-align: center !important;
  box-shadow: none !important;
  min-height: 2rem !important;
  width: 2.5rem !important;
  -moz-appearance: textfield !important;
}

.pretix-widget .pretix-widget-item-count-dec,
.pretix-widget .pretix-widget-item-count-inc,
.pretix-widget button.pretix-widget-item-count-dec,
.pretix-widget button.pretix-widget-item-count-inc {
  background: rgba(255, 222, 89, 0.16) !important;
  color: var(--text) !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 1rem !important;
  min-height: 2rem !important;
  width: 2rem !important;
  transition: background 180ms ease !important;
  padding: 0 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
}

.pretix-widget .pretix-widget-item-count-dec:hover,
.pretix-widget .pretix-widget-item-count-inc:hover,
.pretix-widget button.pretix-widget-item-count-dec:hover,
.pretix-widget button.pretix-widget-item-count-inc:hover {
  background: rgba(255, 222, 89, 0.3) !important;
  color: var(--accent) !important;
}

/* Single-item checkbox / label */
.pretix-widget .pretix-widget-item-count-single-label {
  color: var(--muted) !important;
  font-size: 0.7rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
}

.pretix-widget label.pretix-widget-btn-checkbox {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: var(--stroke) !important;
  color: var(--text) !important;
  border-radius: 999px !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.35rem !important;
  padding: 0.4rem 0.9rem !important;
  min-height: 2rem !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  text-align: center !important;
}

.pretix-widget label.pretix-widget-btn-checkbox input {
  position: static !important;
  margin: 0 !important;
  width: 14px !important;
  height: 14px !important;
  accent-color: var(--accent) !important;
}

.pretix-widget label.pretix-widget-btn-checkbox:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
}

.pretix-widget label.pretix-widget-btn-checkbox:has(input:checked) {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #000 !important;
}

/* ── Variation rows (sizes – compact inline layout) ── */
.pretix-widget .pretix-widget-item-variations {
  border-top: none !important;
  margin-top: 0.25rem !important;
  padding-top: 0 !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-item-row {
  border: none !important;
  background: transparent !important;
  backdrop-filter: none !important;
  padding: 0.55rem 0.25rem !important;
  margin-bottom: 0 !important;
  border-radius: 0 !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 0 !important;
  float: none !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-item-row:last-child {
  border-bottom: none !important;
}

/* Variation row columns */
.pretix-widget .pretix-widget-item-variations .pretix-widget-item-info-col {
  display: block !important;
  width: 15% !important;
  float: none !important;
  flex: 0 0 15% !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-item-title {
  font-size: 0.85rem !important;
  letter-spacing: 0.16em !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-item-price-col {
  display: block !important;
  width: auto !important;
  float: none !important;
  flex: 1 1 auto !important;
  margin-bottom: 0 !important;
  text-align: right !important;
  padding: 0 0.5rem 0 0 !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-item-price-col strong,
.pretix-widget .pretix-widget-item-variations .pretix-widget-pricebox-new-price {
  font-size: 0.78rem !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-item-availability-col {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  width: 7rem !important;
  float: none !important;
  flex: 0 0 7rem !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
  text-align: right !important;
  gap: 0.1rem !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-availability-gone {
  font-size: 0.6rem !important;
  letter-spacing: 0.1em !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  color: var(--muted) !important;
}

.pretix-widget .pretix-widget-item-variations .pretix-widget-item-availability-col a {
  font-size: 0.45rem !important;
  letter-spacing: 0.06em !important;
  margin-top: 0 !important;
  opacity: 0.45 !important;
  line-height: 1 !important;
}

/* Collapse indicator (Show/Hide Variants button) */
.pretix-widget .pretix-widget-collapse-indicator,
.pretix-widget .pretix-widget-item-availability-col .pretix-widget-collapse-indicator {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid var(--stroke) !important;
  color: var(--text) !important;
  border-radius: 999px !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  padding: 0.55rem 1.2rem !important;
  cursor: pointer !important;
  transition: background 180ms ease, border-color 180ms ease !important;
  width: 100% !important;
  text-align: center !important;
}

.pretix-widget .pretix-widget-collapse-indicator:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
}

.pretix-widget .pretix-widget-collapse-indicator::before {
  display: none !important;
}

/* Shopping cart icon inside select labels — hidden */
.pretix-widget .pretix-widget-icon-cart {
  display: none !important;
}

/* ── Action button (Add to cart / checkout) ── */
.pretix-widget .pretix-widget-action {
  width: 100% !important;
  margin-left: 0 !important;
  padding: 0 0.25rem !important;
  margin-top: 0.75rem !important;
}

.pretix-widget .pretix-widget-action button {
  background: var(--accent) !important;
  color: #000 !important;
  border: none !important;
  border-radius: 999px !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  padding: 0.8rem 1.5rem !important;
  cursor: pointer !important;
  transition: background 180ms ease, transform 150ms ease !important;
  width: 100% !important;
}

.pretix-widget .pretix-widget-action button:hover {
  background: var(--accent-strong) !important;
  transform: translateY(-2px) !important;
}

.pretix-widget .pretix-widget-action button:active {
  transform: translateY(0) !important;
}

/* ── Voucher section (hidden for now) ── */
.pretix-widget .pretix-widget-voucher {
  display: none !important;
}

.pretix-widget .pretix-widget-voucher-headline {
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--accent) !important;
}

.pretix-widget .pretix-widget-voucher-text {
  color: var(--muted) !important;
  font-size: 0.72rem !important;
}

.pretix-widget .pretix-widget-voucher-input-wrap {
  padding: 0 !important;
}

.pretix-widget .pretix-widget-voucher-button-wrap {
  padding: 0 !important;
}

.pretix-widget .pretix-widget-voucher input[type="text"] {
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid var(--stroke) !important;
  border-radius: var(--radius-sm) !important;
  color: var(--text) !important;
  padding: 0.6rem 1rem !important;
  font-family: "FKRomanBoldOblique", sans-serif !important;
  font-size: 0.78rem !important;
  box-shadow: none !important;
}

.pretix-widget .pretix-widget-voucher input[type="text"]::placeholder {
  color: var(--muted) !important;
  opacity: 0.5 !important;
}

.pretix-widget .pretix-widget-voucher input[type="text"]:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 16px rgba(255, 222, 89, 0.12) !important;
  outline: none !important;
}

.pretix-widget .pretix-widget-voucher button {
  background: var(--accent) !important;
  color: #000 !important;
  border-radius: var(--radius-sm) !important;
  font-family: "TerminaTestBold", sans-serif !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  border: none !important;
  padding: 0.65rem 1.2rem !important;
}

.pretix-widget .pretix-widget-voucher button:hover {
  background: var(--accent-strong) !important;
}

.pretix-widget .pretix-widget-voucher {
  margin-bottom: 1.5rem !important;
}

/* ── Info / error messages ── */
.pretix-widget .pretix-widget-info-message {
  background: rgba(6, 51, 56, 0.6) !important;
  border-color: var(--accent) !important;
  color: var(--text) !important;
  border-radius: var(--radius-md) !important;
}

.pretix-widget .pretix-widget-error-message {
  background: rgba(6, 51, 56, 0.6) !important;
  border-color: var(--red) !important;
  color: var(--text) !important;
  border-radius: var(--radius-md) !important;
}

/* General text/link inside widget */
.pretix-widget a {
  color: var(--accent) !important;
  font-size: 0.72rem !important;
}

.pretix-widget a:hover,
.pretix-widget a:focus {
  color: var(--accent-strong) !important;
}

/* Clear floats fix */
.pretix-widget .pretix-widget-clear {
  clear: both !important;
}

/* Hide clear divs inside variation rows (breaks flex) */
.pretix-widget .pretix-widget-item-variations .pretix-widget-clear {
  display: none !important;
}

/* ── Tee product showcase (injected by JS) ── */
.tee-showcase {
  border: 1px solid var(--stroke);
  border-radius: 20px;
  background: rgba(6, 51, 56, 0.44);
  backdrop-filter: blur(12px);
  padding: 1.4rem;
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: 1.4rem;
  align-items: center;
  margin-bottom: 0.6rem;
}

.tee-carousel {
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
}

.carousel-track {
  display: flex;
  transition: transform 400ms ease;
}

.carousel-slide {
  min-width: 100%;
  flex: 0 0 100%;
}

.carousel-slide img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

.carousel-dots {
  display: flex;
  justify-content: center;
  gap: 0.45rem;
  padding-top: 0.5rem;
}

.carousel-dot {
  width: 6px !important;
  height: 6px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  border-radius: 50% !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: rgba(255, 255, 255, 0.4) !important;
  padding: 0 !important;
  margin: 0;
  cursor: pointer;
  transition: background 200ms ease;
  -webkit-appearance: none;
  appearance: none;
  line-height: 0 !important;
  font-size: 0 !important;
  transform: none !important;
}

.carousel-dot:focus,
.carousel-dot:active,
.carousel-dot:hover {
  outline: none !important;
  box-shadow: none !important;
  transform: none !important;
}

.carousel-dot.active {
  background: #fff !important;
}

.tee-showcase .tee-details {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.tee-showcase .tee-name {
  margin: 0;
  font-family: "FKRomanBoldOblique", sans-serif;
  font-size: clamp(1.1rem, 2.8vw, 1.5rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.2;
  color: var(--text);
}

.tee-showcase .tee-price {
  margin: 0;
  font-family: "TerminaTestBold", sans-serif;
  font-size: clamp(1.4rem, 3.5vw, 2rem);
  color: var(--accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.tee-showcase .tee-price .price-note {
  font-size: 0.55em;
  color: var(--muted);
  vertical-align: middle;
  letter-spacing: 0.12em;
}

.tee-showcase .tee-specs {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 0.7rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.tee-showcase .spec-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.8rem;
}

.tee-showcase .spec-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.tee-showcase .spec-value {
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
}

.tee-showcase .spec-value-fk {
  font-family: "FKRomanBoldOblique", sans-serif;
}

.tee-showcase .sizing-hint {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.tee-showcase .hint-true {
  color: var(--accent);
}

.tee-showcase .hint-sep {
  color: rgba(255, 255, 255, 0.25);
}

.tee-showcase .hint-over {
  color: var(--muted);
}

.tee-showcase .shipping-info {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  padding-top: 0.7rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.tee-showcase .ship-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.tee-showcase .ship-row span {
  color: var(--muted);
}

.tee-showcase .ship-row strong {
  color: var(--text);
  font-family: "TerminaTestBold", sans-serif;
}

@media (max-width: 640px) {
  .tee-showcase {
    grid-template-columns: 1fr;
    padding: 1.1rem;
    gap: 1.2rem;
  }

  .tee-showcase .tee-carousel {
    max-width: 320px;
    margin: 0 auto;
  }

  .tee-showcase .spec-row {
    flex-wrap: wrap;
    row-gap: 0.2rem;
  }
}

.ticket-error {
  text-align: center;
}

/* ── Fonts ── */
@font-face {
  font-family: "TerminaTestBold";
  src: url("../fonts/TerminaTest-Bold.woff2") format("woff2"),
       url("../fonts/TerminaTest-Bold.woff") format("woff"),
       url("../fonts/TerminaTest-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "FKRomanBoldOblique";
  src: url("../fonts/FKRomanStandard-BoldOblique.woff2") format("woff2"),
       url("../fonts/FKRomanStandard-BoldOblique.woff") format("woff"),
       url("../fonts/FKRomanStandard-BoldOblique.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "SweetSansProHeavy";
  src: url("../fonts/SweetSansProHeavy.woff2") format("woff2"),
       url("../fonts/SweetSansProHeavy.woff") format("woff"),
       url("../fonts/Sweet Sans Pro Heavy.otf") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

/* ── Variables ── */
:root {
  --page-bg: #0b91c4;
  --overlay: rgba(0, 0, 0, 0.72);
  --card-bg: rgba(6, 53, 58, 0.72);
  --card-strong: rgba(5, 36, 52, 0.9);
  --stroke: rgba(255, 255, 255, 0.28);
  --text: #ffffff;
  --muted: rgba(255, 255, 255, 0.7);
  --accent: #ffde59;
  --accent-strong: #ffcc1a;
  --shadow: rgba(0, 29, 34, 0.35);
  --ink: #03131c;
  --green: #34d399;
  --red: #f87171;
  --radius-lg: 24px;
  --radius-md: 16px;
  --radius-sm: 10px;
  --transition: 200ms cubic-bezier(.4, 0, .2, 1);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background-color: var(--page-bg);
  color: var(--text);
  font-family: "FKRomanBoldOblique", "TerminaTestBold", sans-serif;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* ── Page Shell & Background ── */
.page-shell {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
}

.backdrop {
  position: fixed;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%),
    url("./output-640.webp") center top / cover no-repeat;
  filter: blur(18px) saturate(1.2) brightness(0.55);
  transform: scale(1.08);
}

@media (min-width: 641px) {
  .backdrop {
    background:
      linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%),
      url("./output-1024.webp") center top / cover no-repeat;
  }
}

@media (min-width: 1025px) {
  .backdrop {
    background:
      linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.55) 100%),
      url("./output-1920.webp") center top / cover no-repeat;
  }
}

/* ── Main Layout ── */
.ticket-card {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  max-width: 1100px;
  margin: 0 auto;
  padding: 4rem 1.5rem 6rem;
}

/* ── Masthead ── */
.masthead {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.5rem;
}

.masthead-title {
  width: min(360px, 70vw);
}

.masthead-date-text {
  font-family: "TerminaTestBold", sans-serif;
  font-size: clamp(1.5rem, 4vw, 2.5rem);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--accent);
}

/* ── Event Info Strip ── */
.event-info {
  border: 1px solid var(--stroke);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(8, 63, 69, 0.56), rgba(4, 41, 46, 0.58));
  backdrop-filter: blur(16px);
  padding: 1.5rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  box-shadow: 0 18px 48px var(--shadow);
}

.info-row {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.info-row--all {
  justify-content: center;
  flex-wrap: nowrap;
  gap: clamp(0.35rem, 1.2vw, 1rem);
  white-space: nowrap;
}

.info-inline {
  display: flex;
  align-items: baseline;
  gap: clamp(0.35rem, 0.5vw, 0.45rem);
  white-space: nowrap;
}

.info-block {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  flex: 1;
  min-width: 100px;
  text-align: center;
}

.info-label {
  font-family: "TerminaTestBold", sans-serif;
  font-size: clamp(0.36rem, 1.1vw, 0.6rem);
  letter-spacing: clamp(0.05em, 0.4vw, 0.15em);
  text-transform: uppercase;
  color: var(--muted);
}

.info-value {
  font-family: "TerminaTestBold", sans-serif;
  font-size: clamp(0.48rem, 2vw, 1.35rem);
  letter-spacing: clamp(0.01em, 0.2vw, 0.08em);
  text-transform: uppercase;
  color: var(--text);
  line-height: 1.2;
}

.info-sub {
  font-family: "FKRomanBoldOblique", sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.info-badge {
  color: var(--accent);
}

.amp {
  font-family: "SweetSansProHeavy", sans-serif;
}

.genres-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  gap: 0.35rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  font-family: "FKRomanBoldOblique", sans-serif;
  font-size: clamp(0.48rem, 1.4vw, 0.78rem);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.genre-dot {
  color: rgba(255, 255, 255, 0.25);
  font-size: 0.5em;
}

/* ── V5 Release Notice (inline inside widget row) ── */
.v5-release-notice {
  flex: 1 1 auto;
  text-align: left;
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #ffde59;
  padding: 0;
  text-decoration: none;
}

.v5-release-notice strong {
  color: #ffde59;
}

/* ── Ticket Panel (holds the pretix-styled content) ── */
.ticket-panel {
  border: 1px solid var(--stroke);
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(8, 63, 69, 0.58), rgba(4, 41, 46, 0.6));
  backdrop-filter: blur(16px);
  box-shadow: 0 25px 60px var(--shadow);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding: 2rem;
}

.ticket-action {
  display: flex;
  flex-direction: column;
}

.pretix-target {
  padding: 1.25rem;
  text-align: left;
  min-height: 160px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1rem;
  font-family: "FKRomanBoldOblique", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--muted);
}

/* ── Section Label (shared by ticket & tee panels) ── */
.section-label {
  font-family: "TerminaTestBold", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--accent);
  margin: 0;
  font-size: 1rem;
  text-align: center;
}

/* ── Ticket tier cards ── */
.ticket-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr));
  gap: 1rem;
}

.tier-card {
  border: 1px solid var(--stroke);
  border-radius: 20px;
  padding: 1.25rem;
  background: rgba(6, 51, 56, 0.44);
  backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.tier-title-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.tier-head h3 {
  margin: 0;
  font-size: 1.15rem;
  letter-spacing: 0.15em;
  color: white;
}

.tier-price {
  margin: 0;
  font-family: "TerminaTestBold", sans-serif;
  font-size: 1.1rem;
  letter-spacing: 0.15em;
  color: var(--accent);
  text-align: right;
  white-space: nowrap;
}

.tier-status {
  margin: 0;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: pre-line;
}

.tier-status--members-note {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  font-size: clamp(0.5rem, 1.35vw, 0.72rem);
  line-height: 1.2;
  letter-spacing: clamp(0.02em, 0.24vw, 0.12em);
}

.tier-status--members-note .members-note-line {
  white-space: nowrap;
}

.tier-status--members-note .members-note-heading {
  font-size: clamp(0.55rem, 1.5vw, 0.78rem);
  letter-spacing: clamp(0.03em, 0.3vw, 0.14em);
}

.tier-card[data-status="soldout"] {
  opacity: 0.55;
}

.tier-actions {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  padding-top: 0.5rem;
}

.tier-purchase-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
}

/* ── Quantity Selector ── */
.quantity-selector {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  align-self: stretch;
  width: 100%;
  gap: 0.45rem;
  padding: 0.35rem 0.5rem;
  border: 1px solid var(--stroke);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
}

.quantity-selector__label {
  font-family: "TerminaTestBold", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.65rem;
  color: var(--muted);
  margin-right: auto;
  padding-left: 0.2rem;
  white-space: nowrap;
}

.quantity-selector__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 222, 89, 0.16);
  color: var(--text);
  font-family: "TerminaTestBold", sans-serif;
  font-size: 1.05rem;
  line-height: 1;
  cursor: pointer;
  transition: background 180ms ease, transform 150ms ease, opacity 180ms ease;
}

.quantity-selector__icon {
  display: block;
  line-height: 1;
}

.quantity-selector__icon--decrement {
  transform: translateY(-0.02em);
}

.quantity-selector__icon--increment {
  transform: translateY(-0.06em);
}

.quantity-selector__button:hover,
.quantity-selector__button:focus-visible {
  background: rgba(255, 222, 89, 0.28);
  transform: translateY(-1px);
}

.quantity-selector__button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.quantity-selector__input {
  width: 3.25rem;
  height: 2rem;
  border: none;
  border-radius: 999px;
  background: transparent;
  color: var(--text);
  text-align: center;
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.9rem;
  letter-spacing: 0.15em;
  appearance: textfield;
  -moz-appearance: textfield;
}

.quantity-selector__input::-webkit-outer-spin-button,
.quantity-selector__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* ── Action Buttons (Pretix & general) ── */
.pretix-button {
  display: block;
  width: 100%;
  border: none;
  border-radius: 999px;
  background: var(--accent);
  color: #000;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  padding: 0.85rem 1.5rem;
  cursor: pointer;
  transition: background 180ms ease, transform 150ms ease;
  text-align: center;
}

.pretix-button:hover,
.pretix-button:focus-visible {
  background: var(--accent-strong);
  transform: translateY(-2px);
}

pretix-button {
  display: block;
  width: 100%;
  padding: 0;
  background: none;
  border: none;
}

.tier-actions pretix-button,
.tier-actions .ig-button {
  width: 100%;
}

pretix-button button,
.pretix-widget-button,
.tier-actions pretix-button button,
.tier-actions .pretix-widget-button,
.inline-pretix-button button,
.ig-button {
  display: flex;
  width: 100%;
  border: none;
  border-radius: 999px;
  background: var(--accent);
  color: #000;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  min-height: 2.6rem;
  padding: 0 1.5rem;
  cursor: pointer;
  transition: background 180ms ease, transform 150ms ease, color 180ms ease;
  text-align: center;
  text-decoration: none;
  box-sizing: border-box;
  line-height: 1;
  white-space: nowrap;
  align-items: center;
  justify-content: center;
}

.tier-actions pretix-button button:hover,
.tier-actions pretix-button button:focus-visible,
.tier-actions .pretix-widget-button:hover,
.tier-actions .pretix-widget-button:focus-visible,
.inline-pretix-button button:hover,
.inline-pretix-button button:focus-visible,
.pretix-widget-button:hover,
.pretix-widget-button:focus-visible,
.ig-button:hover,
.ig-button:focus-visible {
  background: var(--accent-strong);
  transform: translateY(-2px);
  color: #000;
}

.tier-actions pretix-button button:active,
.tier-actions .pretix-widget-button:active,
.inline-pretix-button button:active,
.pretix-widget-button:active,
.ig-button:active {
  transform: translateY(0);
}

.soldout-button {
  background: #b9ad63;
  color: #3f3a1d;
  cursor: not-allowed;
  opacity: 0.7;
  pointer-events: none;
}

/* ── Size Buttons (for tee-type items with variations) ── */
.size-options {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  width: 100%;
}

.size-btn {
  appearance: none;
  border: 1.5px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.5rem 1rem;
  cursor: pointer;
  transition: all var(--transition);
  min-width: 3rem;
  text-align: center;
}

.size-btn:hover:not(.unavailable) {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.4);
}

.size-btn.selected {
  background: var(--accent);
  color: var(--ink);
  border-color: var(--accent);
  box-shadow: 0 0 14px rgba(255, 225, 93, 0.3);
}

.size-btn.unavailable {
  opacity: 0.28;
  cursor: not-allowed;
  text-decoration: line-through;
}

.pretix-button.no-size {
  background: rgba(255, 255, 255, 0.06);
  color: var(--muted);
  border: 1.5px dashed rgba(255, 255, 255, 0.2);
  cursor: not-allowed;
}

.pretix-button.no-size:hover {
  transform: none;
  background: rgba(255, 255, 255, 0.06);
}

/* ── Email Sign-up Section ── */
.email-signup {
  border: 1px solid var(--stroke);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(8, 63, 69, 0.56), rgba(4, 41, 46, 0.58));
  backdrop-filter: blur(16px);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  text-align: center;
  transition: border-color 300ms ease;
}

.email-signup:hover {
  border-color: rgba(255, 222, 89, 0.25);
}

.signup-label {
  font-family: "TerminaTestBold", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--accent);
  margin: 0;
  font-size: 1rem;
}

.signup-sublabel {
  font-family: "FKRomanBoldOblique", sans-serif;
  font-style: italic;
  color: var(--muted);
  margin: 0 0 0.75rem;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
}

.signup-form {
  width: 100%;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.signup-fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}

.signup-fields input {
  width: 100%;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.4);
  padding: 0.75rem 1rem;
  color: var(--text);
  font-family: "FKRomanBoldOblique", sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  outline: none;
  transition: border-color 250ms ease, box-shadow 250ms ease;
}

.signup-fields input::placeholder {
  color: rgba(255, 255, 255, 0.3);
}

.signup-fields input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 20px rgba(255, 222, 89, 0.1);
}

.signup-input-group {
  display: flex;
  gap: 0;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  overflow: hidden;
  background: rgba(0, 0, 0, 0.4);
  transition: border-color 250ms ease, box-shadow 250ms ease;
}

.signup-input-group:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 20px rgba(255, 222, 89, 0.1);
}

.signup-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  border-radius: 999px;
  background: var(--accent);
  color: #000;
  border: none;
  padding: 0.75rem 1.5rem;
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  transition: background 180ms ease, transform 150ms ease;
}

.signup-btn:hover,
.signup-btn:focus-visible {
  background: var(--accent-strong);
  transform: translateY(-1px);
}

.signup-btn:active {
  transform: translateY(0);
}

.signup-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.signup-btn-loader {
  width: 14px;
  height: 14px;
  border: 2px solid rgba(0, 0, 0, 0.2);
  border-top-color: #000;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.signup-status {
  margin: 0;
  font-family: "FKRomanBoldOblique", sans-serif;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  text-align: center;
  min-height: 1.2em;
  transition: color 250ms ease, opacity 250ms ease;
}

.signup-status.success {
  color: #4ade80;
}

.signup-status.error {
  color: #f87171;
}

.signup-status.info {
  color: var(--muted);
}

/* ── Social Strip ── */
.social-strip {
  border-top: 1px solid var(--stroke);
  padding-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  align-items: center;
}

.social-label {
  font-family: "TerminaTestBold", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.4em;
  color: var(--muted);
  margin: 0;
}

.social-links {
  list-style: none;
  display: flex;
  gap: 0.75rem;
  margin: 0;
  padding: 0;
}

.social-links a {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--stroke);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  transition: border 150ms ease, color 150ms ease;
}

.social-links .social-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--stroke);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
}

.social-links a:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.social-links svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

/* ── Footer ── */
.site-footer {
  text-align: center;
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--muted);
}

.site-footer a {
  color: var(--accent);
  text-decoration: none;
}

/* ── Toast ── */
.toast {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  z-index: 200;
  background: rgba(2, 20, 34, 0.92);
  backdrop-filter: blur(12px);
  border: 1px solid var(--stroke);
  border-radius: var(--radius-md);
  padding: 0.7rem 1.2rem;
  font-family: "TerminaTestBold", sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text);
  box-shadow: 0 12px 36px var(--shadow);
  opacity: 0;
  transition: transform 350ms cubic-bezier(.4, 0, .2, 1), opacity 350ms ease;
  pointer-events: none;
  white-space: nowrap;
}

.toast.visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

/* ── Modal (Disclaimer) ── */
.fixed {
  position: fixed;
}

.inset-0 {
  inset: 0;
}

.z-\[10000\] {
  z-index: 10000;
}

.flex {
  display: flex;
}

.items-center {
  align-items: center;
}

.justify-center {
  justify-content: center;
}

.bg-black\/75 {
  background-color: rgba(0, 0, 0, 0.75);
}

.relative {
  position: relative;
}

.bg-neutral-900\/50 {
  background-color: rgba(23, 23, 23, 0.5);
}

.text-white {
  color: #fff;
}

.rounded-2xl {
  border-radius: 1rem;
}

.max-w-lg {
  max-width: 32rem;
}

.w-\[92vw\] {
  width: 92vw;
}

.p-6 {
  padding: 1.5rem;
}

.shadow-2xl {
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.border {
  border-style: solid;
  border-width: 1px;
}

.border-neutral-700 {
  border-color: #404040;
}

.max-h-\[90vh\] {
  max-height: 90vh;
}

.overflow-y-auto {
  overflow-y: auto;
}

.backdrop-blur-sm {
  backdrop-filter: blur(4px);
}

.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.font-bold {
  font-weight: 700;
}

.text-yellow-300 {
  color: #fde047;
}

.tracking-wider {
  letter-spacing: 0.05em;
}

.uppercase {
  text-transform: uppercase;
}

.mb-4 {
  margin-bottom: 1rem;
}

.list-disc {
  list-style-type: disc;
}

.pl-5 {
  padding-left: 1.25rem;
}

.space-y-3> :not([hidden])~ :not([hidden]) {
  margin-top: 0.75rem;
}

.text-base {
  font-size: 1rem;
}

.text-neutral-300 {
  color: #d4d4d4;
}

.font-semibold {
  font-weight: 600;
}

.absolute {
  position: absolute;
}

.top-4 {
  top: 1rem;
}

.right-5 {
  right: 1.25rem;
}

.text-3xl {
  font-size: 1.875rem;
  line-height: 2.25rem;
}

.text-neutral-400 {
  color: #a3a3a3;
}

.hover\:text-yellow-400:hover {
  color: #facc15;
}

.focus\:outline-none:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

#disclaimer-close {
  width: 2.25rem;
  height: 2.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(0, 0, 0, 0.45);
  color: rgba(255, 255, 255, 0.85);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
  transition: transform 150ms ease, background 180ms ease, color 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

#disclaimer-close:hover,
#disclaimer-close:focus-visible {
  background: var(--accent);
  color: #000;
  border-color: var(--accent-strong);
  transform: translateY(-1px) scale(1.04);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35);
}

#disclaimer-close:active {
  transform: translateY(0) scale(0.98);
}

#disclaimer-close:focus-visible {
  outline: 2px solid var(--accent-strong);
  outline-offset: 2px;
}

/* ── Responsive ── */
@media (max-width: 640px) {
  .ticket-card {
    padding: 3rem 1rem 4rem;
  }

  .ticket-panel {
    padding: 0rem;
    border-radius: 28px;
  }

  .tier-card {
    padding: 1rem;
    border-radius: 16px;
  }

  .pretix-widget .pretix-widget-action {
    padding-bottom: 1rem !important;
  }

  .pretix-widget .pretix-widget-item-row {
    justify-content: flex-end !important;
  }

  .pretix-widget .pretix-widget-item-row.v5-row {
    justify-content: flex-start !important;
  }

  .pretix-widget .pretix-widget-item-row > .pretix-widget-item-info-col {
    width: 100% !important;
    flex: 1 0 100% !important;
  }

  .pretix-widget .pretix-widget-item-row > .pretix-widget-item-price-col {
    text-align: left !important;
  }

  .pretix-widget .pretix-widget-item-row > .pretix-widget-item-availability-col {
    margin-left: auto !important;
    text-align: right !important;
  }

  .pretix-widget .pretix-widget-item-row.v5-row > .pretix-widget-item-availability-col {
    margin-left: 0 !important;
    text-align: left !important;
    float: none !important;
  }

  .pretix-widget .pretix-widget-item-row > .pretix-widget-item-availability-col a[href*="waitinglist"] {
    text-align: left !important;
    display: block !important;
    margin-left: 0 !important;
  }

  /* Variation rows (sizes) – override the general mobile rules */
  .pretix-widget .pretix-widget-item-variations .pretix-widget-item-row {
    flex-wrap: wrap !important;
    gap: 0.4rem !important;
    padding: 0.5rem 0.25rem !important;
  }

  .pretix-widget .pretix-widget-item-variations .pretix-widget-item-row > .pretix-widget-item-info-col {
    width: auto !important;
    flex: 0 0 auto !important;
    min-width: 2.5rem !important;
  }

  .pretix-widget .pretix-widget-item-variations .pretix-widget-item-row > .pretix-widget-item-price-col {
    text-align: right !important;
    flex: 1 1 auto !important;
  }

  .pretix-widget .pretix-widget-item-variations .pretix-widget-item-row > .pretix-widget-item-availability-col {
    flex: 0 0 auto !important;
    margin-left: 0 !important;
  }

  .event-info {
    padding: 1.1rem;
    border-radius: 20px;
  }

  .info-block {
    width: 100%;
    text-align: center;
  }

  .email-signup {
    padding: 1.25rem;
    border-radius: 20px;
  }

  .signup-input-group {
    flex-direction: column;
    border-radius: 16px;
  }

  .signup-btn {
    border-radius: 0 0 16px 16px;
    padding: 0.75rem;
    justify-content: center;
  }

  .signup-input-group input[type="email"] {
    text-align: center;
    padding: 0.75rem;
  }
}
@media (max-width: 480px) {
.pretix-widget-alert-holder{
  top:20vh;
  color:white;
}
}