.gtg-event-checkout__intro {
  margin: 0;
  color: var(--gtg-checkout-muted);
  max-width: 720px;
}

.gtg-event-checkout__choice-grid,
.gtg-event-checkout__tickets,
.gtg-event-checkout__attendees,
.gtg-event-checkout__review {
  display: grid;
  gap: .75rem;
}

.gtg-event-checkout__event-summary,
.gtg-event-checkout__choice-card,
.gtg-event-checkout__ticket-row,
.gtg-event-checkout__review-card,
.gtg-event-checkout__payment-box,
.gtg-event-checkout__summary-card {
  border: 1.5px solid rgba(37,32,29,.25);
  border-radius: 12px;
  background: #fffaf2;
  padding: .85rem;
}

.gtg-event-checkout__choice-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .75rem;
  cursor: pointer;
}

.gtg-event-checkout__choice-card input {
  margin-top: .25rem;
}

.gtg-event-checkout__choice-card strong,
.gtg-event-checkout__ticket-row strong {
  display: block;
  color: var(--gtg-checkout-ink);
}

.gtg-event-checkout__choice-card small,
.gtg-event-checkout__ticket-row small {
  display: block;
  color: var(--gtg-checkout-muted);
  line-height: 1.35;
}

.gtg-event-checkout__ticket-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .85rem;
  align-items: center;
}

.gtg-event-checkout__qty {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
}

.gtg-event-checkout__qty button {
  width: 2rem;
  height: 2rem;
  border: 1.5px solid var(--gtg-checkout-ink);
  border-radius: 8px;
  background: var(--gtg-checkout-paper);
  box-shadow: 2px 2px 0 var(--gtg-checkout-shadow);
  font-weight: 950;
  cursor: pointer;
}

.gtg-event-checkout__qty output {
  min-width: 1.5rem;
  text-align: center;
  font-weight: 950;
}

.gtg-event-checkout__consent {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .55rem;
  align-items: start;
  margin-top: 1rem;
}

.gtg-event-checkout__summary-line {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 1px dashed rgba(37,32,29,.25);
  padding: .35rem 0;
}

.gtg-event-checkout__summary-total {
  margin-top: .7rem;
  font-size: 1.15rem;
  font-weight: 950;
}

@media (max-width: 720px) {
  .gtg-event-checkout .gtg-rest-checkout__layout {
    grid-template-columns: 1fr;
  }

  .gtg-event-checkout__ticket-row {
    grid-template-columns: 1fr;
  }
}

.gtg-event-series-builder,
.gtg-event-series-builder * {
  box-sizing: border-box;
}

.gtg-event-series-builder {
  width: min(100%, 1120px);
  margin: 0 auto;
}

.gtg-event-series-builder__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 1rem;
  align-items: start;
}

.gtg-event-series-builder__list {
  display: grid;
  gap: .85rem;
}

.gtg-event-series-date {
  border: 1.5px solid rgba(37,32,29,.25);
  border-radius: 12px;
  background: #fffaf2;
  padding: .9rem;
}

.gtg-event-series-date__header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .7rem;
  align-items: start;
  cursor: pointer;
}

.gtg-event-series-date__header strong,
.gtg-event-series-ticket strong {
  display: block;
}

.gtg-event-series-date__header small,
.gtg-event-series-ticket small {
  display: block;
  color: var(--gtg-checkout-muted);
}

.gtg-event-series-date__tickets {
  display: grid;
  gap: .6rem;
  margin-top: .85rem;
  padding-top: .85rem;
  border-top: 1px dashed rgba(37,32,29,.25);
}

.gtg-event-series-ticket {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: center;
}

.gtg-event-series-builder__summary {
  position: sticky;
  top: 1rem;
  display: grid;
  gap: .85rem;
}

@media (max-width: 820px) {
  .gtg-event-series-builder__layout {
    grid-template-columns: 1fr;
  }

  .gtg-event-series-builder__summary {
    position: static;
  }

  .gtg-event-series-ticket {
    grid-template-columns: 1fr;
  }
}

.gtg-event-series-builder__more {
  justify-self: center;
  margin-top: .25rem;
}

.gtg-event-series-date__header {
  display: block;
  cursor: default;
}

.gtg-event-series-date__header span {
  display: grid;
  gap: .18rem;
}

.gtg-event-series-builder__hero {
  grid-template-columns: minmax(0, 1fr) minmax(220px, 340px);
  align-items: start;
}

.gtg-event-series-builder__image {
  margin: 0;
  overflow: hidden;
  border: 2px solid var(--gtg-checkout-ink);
  border-radius: 14px;
  background: #fffaf2;
  box-shadow: 4px 4px 0 var(--gtg-checkout-shadow);
}

.gtg-event-series-builder__image img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.gtg-event-series-builder__info {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 1rem;
  align-items: start;
}

.gtg-event-series-builder__description,
.gtg-event-series-builder__details {
  border: 2px solid var(--gtg-checkout-ink);
  border-radius: 14px;
  background: var(--gtg-checkout-paper);
  box-shadow: 4px 4px 0 var(--gtg-checkout-shadow);
  padding: clamp(1rem, 3vw, 1.35rem);
}

.gtg-event-series-builder__description h3,
.gtg-event-series-builder__details h3 {
  margin-top: 0;
  text-transform: uppercase;
  letter-spacing: .015em;
}

.gtg-event-series-builder__content {
  color: var(--gtg-checkout-muted);
  line-height: 1.6;
}

.gtg-event-series-builder__content > :first-child {
  margin-top: 0;
}

.gtg-event-series-builder__content > :last-child {
  margin-bottom: 0;
}

.gtg-event-series-builder__details dl {
  display: grid;
  gap: .75rem;
  margin: 0;
}

.gtg-event-series-builder__details dl > div {
  border-bottom: 1px dashed rgba(37,32,29,.25);
  padding-bottom: .65rem;
}

.gtg-event-series-builder__details dl > div:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.gtg-event-series-builder__details dt {
  color: var(--gtg-checkout-accent-dark);
  font-size: .78rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.gtg-event-series-builder__details dd {
  margin: .15rem 0 0;
  color: var(--gtg-checkout-ink);
  font-weight: 750;
}

.gtg-event-series-builder__details small {
  color: var(--gtg-checkout-muted);
  font-weight: 600;
}

.gtg-event-series-builder__map {
  margin-top: 1rem;
  overflow: hidden;
  border: 1.5px solid rgba(37,32,29,.25);
  border-radius: 12px;
  background: #fffaf2;
}

.gtg-event-series-builder__map iframe {
  display: block;
  width: 100%;
  min-height: 230px;
  border: 0;
}

@media (max-width: 860px) {
  .gtg-event-series-builder__hero,
  .gtg-event-series-builder__info {
    grid-template-columns: 1fr;
  }

  .gtg-event-series-builder__image img {
    aspect-ratio: 16 / 9;
  }
}

.gtg-event-series-builder__hero {
  display: block;
  max-width: 760px;
}

.gtg-event-series-builder__side {
  display: grid;
  gap: 1rem;
  align-self: start;
}

.gtg-event-series-builder__side .gtg-event-series-builder__image,
.gtg-event-series-builder__side .gtg-event-series-builder__details {
  width: 100%;
}

.gtg-event-series-builder__side .gtg-event-series-builder__image img {
  aspect-ratio: 1 / 1;
}

@media (max-width: 860px) {
  .gtg-event-series-builder__hero {
    max-width: none;
  }

  .gtg-event-series-builder__side .gtg-event-series-builder__image img {
    aspect-ratio: 16 / 9;
  }
}

/**
 * Single event page layout refinement:
 * let the right event details column float beside the description so the
 * ticket selector can rise into the space below the description instead of
 * waiting for the full details/map column height.
 */
.gtg-event-series-builder__info {
  display: block;
}

.gtg-event-series-builder__side {
  float: right;
  width: min(34vw, 360px);
  margin: 0 0 1.25rem 1.25rem;
}

.gtg-event-series-builder__layout {
  display: block;
}

.gtg-event-series-builder__dates {
  display: grid;
  gap: 1rem;
  min-width: 0;
}

.gtg-event-series-builder__layout > .gtg-rest-checkout__summary {
  display: none;
}

.gtg-event-series-builder__description {
  margin-bottom: 1.25rem;
}

@media (max-width: 860px) {
  .gtg-event-series-builder__side {
    float: none;
    width: 100%;
    margin: 0 0 1rem;
  }

  .gtg-event-series-builder__layout > .gtg-rest-checkout__summary {
    display: block;
  }
}

/**
 * Proper single-event page grid:
 * description and ticket selector stay in the left column;
 * image, details, map and selected tickets stay aligned in the right column.
 */
.gtg-event-series-builder__shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 1rem;
  align-items: start;
}

.gtg-event-series-builder__hero {
  grid-column: 1 / -1;
}

.gtg-event-series-builder__info {
  display: contents;
}

.gtg-event-series-builder__description {
  grid-column: 1;
  margin-bottom: 0;
}

.gtg-event-series-builder__side {
  float: none;
  grid-column: 2;
  grid-row: 2 / span 2;
  width: auto;
  margin: 0;
}

.gtg-event-series-builder__layout {
  grid-column: 1;
  display: block;
}

.gtg-event-series-builder__dates {
  display: grid;
  gap: 1rem;
}

.gtg-event-series-builder__layout > .gtg-rest-checkout__summary {
  display: none !important;
}

@media (max-width: 860px) {
  .gtg-event-series-builder__shell {
    grid-template-columns: 1fr;
  }

  .gtg-event-series-builder__hero,
  .gtg-event-series-builder__description,
  .gtg-event-series-builder__side,
  .gtg-event-series-builder__layout {
    grid-column: 1;
    grid-row: auto;
  }

  .gtg-event-series-builder__side {
    width: 100%;
    margin: 0;
  }
}

/**
 * Final single event layout:
 * left column = description, event details/map, date selector;
 * right column = image and selected tickets.
 */
.gtg-event-series-builder__shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 1rem;
  align-items: start;
}

.gtg-event-series-builder__hero {
  grid-column: 1 / -1;
}

.gtg-event-series-builder__info {
  display: contents;
}

.gtg-event-series-builder__description {
  grid-column: 1;
  grid-row: 2;
  margin-bottom: 0;
}

.gtg-event-series-builder__details {
  grid-column: 1;
  grid-row: 3;
}

.gtg-event-series-builder__layout {
  grid-column: 1;
  grid-row: 4;
  display: block;
}

.gtg-event-series-builder__side {
  float: none;
  grid-column: 2;
  grid-row: 2 / span 3;
  width: auto;
  margin: 0;
  align-self: start;
}

.gtg-event-series-builder__side .gtg-event-series-builder__image,
.gtg-event-series-builder__side .gtg-event-series-builder__summary {
  width: 100%;
}

.gtg-event-series-builder__layout > .gtg-rest-checkout__summary {
  display: none !important;
}

@media (max-width: 860px) {
  .gtg-event-series-builder__shell {
    grid-template-columns: 1fr;
  }

  .gtg-event-series-builder__hero,
  .gtg-event-series-builder__description,
  .gtg-event-series-builder__details,
  .gtg-event-series-builder__layout,
  .gtg-event-series-builder__side {
    grid-column: 1;
    grid-row: auto;
  }

  .gtg-event-series-builder__side {
    width: 100%;
    margin: 0;
  }
}

/**
 * Keep the selected tickets box visible while choosing event dates on desktop.
 */
@media (min-width: 861px) {
  .gtg-event-series-builder__summary--side {
    position: sticky;
    top: 1rem;
    z-index: 2;
  }
}

@media (min-width: 861px) {
  .admin-bar .gtg-event-series-builder__summary--side {
    top: calc(32px + 1rem);
  }
}

/**
 * Sticky event sidebar on desktop.
 * The selected tickets box cannot reliably stick by itself because it is inside
 * a short sidebar parent; sticking the whole sidebar keeps the checkout summary
 * visible while selecting tickets.
 */
@media (min-width: 861px) {
  .gtg-event-series-builder__side {
    position: sticky !important;
    top: 1rem;
    z-index: 5;
    align-self: start;
  }

  .admin-bar .gtg-event-series-builder__side {
    top: calc(32px + 1rem);
  }

  .gtg-event-series-builder__summary--side {
    position: static !important;
    top: auto !important;
  }
}

/**
 * Single event page layout:
 * top row = description 70%, image 30%;
 * below = details/tickets left, sticky selected tickets right.
 */
@media (min-width: 861px) {
  .gtg-event-series-builder__shell {
    display: grid;
    grid-template-columns: minmax(0, 7fr) minmax(260px, 3fr);
    gap: 1rem;
    align-items: start;
  }

  .gtg-event-series-builder__hero {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .gtg-event-series-builder__info {
    display: contents;
  }

  .gtg-event-series-builder__description {
    grid-column: 1;
    grid-row: 2;
    margin-bottom: 0;
  }

  .gtg-event-series-builder__image-column {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
  }

  .gtg-event-series-builder__image-column .gtg-event-series-builder__image {
    width: 100%;
    margin: 0;
  }

  .gtg-event-series-builder__image-column .gtg-event-series-builder__image img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
  }

  .gtg-event-series-builder__details {
    grid-column: 1;
    grid-row: 3;
  }

  .gtg-event-series-builder__layout {
    grid-column: 1;
    grid-row: 4;
    display: block;
  }

  .gtg-event-series-builder__side {
    grid-column: 2;
    grid-row: 3 / span 2;
    position: sticky !important;
    top: 1rem;
    width: auto;
    margin: 0;
    align-self: start;
    z-index: 5;
  }

  .admin-bar .gtg-event-series-builder__side {
    top: calc(32px + 1rem);
  }

  .gtg-event-series-builder__side .gtg-event-series-builder__summary {
    width: 100%;
  }

  .gtg-event-series-builder__layout > .gtg-rest-checkout__summary {
    display: none !important;
  }
}

@media (max-width: 860px) {
  .gtg-event-series-builder__shell {
    grid-template-columns: 1fr;
  }

  .gtg-event-series-builder__hero,
  .gtg-event-series-builder__description,
  .gtg-event-series-builder__image-column,
  .gtg-event-series-builder__details,
  .gtg-event-series-builder__layout,
  .gtg-event-series-builder__side {
    grid-column: 1;
    grid-row: auto;
  }

  .gtg-event-series-builder__image-column .gtg-event-series-builder__image img {
    aspect-ratio: 16 / 9;
  }

  .gtg-event-series-builder__side {
    position: static !important;
    width: 100%;
    margin: 0;
  }
}

/**
 * Account for the sticky site header/admin bar when keeping selected tickets
 * visible on desktop event pages.
 */
@media (min-width: 861px) {
  .gtg-event-series-builder__side {
    top: 8.5rem !important;
  }

  .admin-bar .gtg-event-series-builder__side {
    top: calc(32px + 8.5rem) !important;
  }
}

@media (min-width: 861px) {
  .gtg-event-series-builder__side {
    grid-row: 4 !important;
  }
}

/**
 * Align sticky selected tickets with the first date/ticket card rather than
 * the "Choose dates and tickets" heading.
 */
@media (min-width: 861px) {
  .gtg-event-series-builder__side {
    grid-row: 4 !important;
    margin-top: 5.25rem !important;
    top: 8.5rem !important;
  }

  .admin-bar .gtg-event-series-builder__side {
    top: calc(32px + 8.5rem) !important;
  }
}

/**
 * Align sticky selected tickets with the first date/ticket card rather than
 * the "Choose dates and tickets" heading.
 */
@media (min-width: 861px) {
  .gtg-event-series-builder__side {
    grid-row: 4 !important;
    margin-top: 4.75rem !important;
    top: 8.5rem !important;
  }

  .admin-bar .gtg-event-series-builder__side {
    top: calc(32px + 8.5rem) !important;
  }
}

.gtg-event-checkout-modal[hidden] {
  display: none !important;
}

.gtg-event-checkout-modal {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: grid;
  place-items: center;
  padding: clamp(.75rem, 3vw, 2rem);
}

.gtg-event-checkout-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(37, 32, 29, .58);
}

.gtg-event-checkout-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(980px, 100%);
  max-height: min(92vh, 920px);
  overflow: auto;
  border-radius: 18px;
}

.gtg-event-checkout-modal__close {
  position: absolute;
  top: .75rem;
  right: .75rem;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 2.35rem;
  height: 2.35rem;
  border: 2px solid var(--gtg-checkout-ink);
  border-radius: 10px;
  background: var(--gtg-checkout-paper);
  box-shadow: 3px 3px 0 var(--gtg-checkout-shadow);
  color: var(--gtg-checkout-ink);
  font-size: 1.35rem;
  font-weight: 950;
  cursor: pointer;
}

html.gtg-event-checkout-modal-open,
body.gtg-event-checkout-modal-open {
  overflow: hidden;
}

.gtg-event-modal-review,
.gtg-event-modal-attendees__group {
  display: grid;
  gap: .85rem;
}

.gtg-event-modal-review__item,
.gtg-event-modal-attendees__group {
  border: 1.5px solid rgba(37,32,29,.25);
  border-radius: 12px;
  background: #fffaf2;
  padding: .85rem;
}

.gtg-event-modal-review__item small {
  display: block;
  color: var(--gtg-checkout-muted);
  margin-top: .2rem;
}

.gtg-event-modal-review__remove {
  justify-self: start;
  border: 0;
  background: transparent;
  color: var(--gtg-checkout-accent-dark);
  font: inherit;
  font-weight: 900;
  text-decoration: underline;
  cursor: pointer;
}

.gtg-event-modal-attendees__toggle {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .55rem;
  align-items: start;
  margin-bottom: 1rem;
  font-weight: 850;
}

@media (max-width: 720px) {
  .gtg-event-checkout-modal {
    padding: .5rem;
    place-items: stretch;
  }

  .gtg-event-checkout-modal__dialog {
    max-height: 100%;
  }

  .gtg-event-checkout-modal .gtg-rest-checkout__progress {
    grid-template-columns: 1fr;
  }
}

.gtg-event-inline-progress {
  margin-bottom: 1rem;
}

.gtg-event-inline-checkout {
  grid-column: 1;
  margin-top: 1rem;
}

.gtg-event-inline-checkout .gtg-rest-checkout__shell {
  padding: 0;
  border: 0;
  box-shadow: none;
  background: transparent;
}

.gtg-event-inline-attendees {
  display: grid;
  gap: .85rem;
  margin-top: 1rem;
}

.gtg-event-inline-attendees__toggle {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .55rem;
  align-items: start;
  font-weight: 850;
}

@media (min-width: 861px) {
  .gtg-event-inline-checkout {
    grid-column: 1;
  }
}

/**
 * Inline event checkout step behaviour.
 * Stepper spans the full page grid. Ticket selector content only shows during
 * Step 1; Details/Payment use the same space afterwards.
 */
.gtg-event-inline-progress {
  grid-column: 1 / -1;
  width: 100%;
  margin: 0 0 1rem;
}

.gtg-event-series-builder[data-checkout-step="details"] .gtg-event-series-builder__dates > .gtg-rest-checkout__step-heading,
.gtg-event-series-builder[data-checkout-step="details"] .gtg-event-series-builder__list,
.gtg-event-series-builder[data-checkout-step="details"] .gtg-event-series-builder__more,
.gtg-event-series-builder[data-checkout-step="payment"] .gtg-event-series-builder__dates > .gtg-rest-checkout__step-heading,
.gtg-event-series-builder[data-checkout-step="payment"] .gtg-event-series-builder__list,
.gtg-event-series-builder[data-checkout-step="payment"] .gtg-event-series-builder__more {
  display: none !important;
}

.gtg-event-series-builder[data-checkout-step="details"] .gtg-event-inline-checkout,
.gtg-event-series-builder[data-checkout-step="payment"] .gtg-event-inline-checkout {
  margin-top: 0;
}

@media (min-width: 861px) {
  .gtg-event-inline-progress {
    grid-column: 1 / -1;
  }
}

/**
 * Full-width progress bar directly above the ticket cards.
 */
@media (min-width: 861px) {
  .gtg-event-inline-progress {
    grid-column: 1 / -1 !important;
    grid-row: 4 !important;
    width: 100% !important;
    margin: 0 0 1rem !important;
  }

  .gtg-event-series-builder__layout {
    grid-column: 1 !important;
    grid-row: 5 !important;
  }

  .gtg-event-series-builder__side {
    grid-column: 2 !important;
    grid-row: 5 !important;
  }

  .gtg-event-inline-checkout {
    grid-column: 1 !important;
    grid-row: 6 !important;
  }
}

@media (max-width: 860px) {
  .gtg-event-inline-progress {
    width: 100% !important;
    margin: 0 0 1rem !important;
  }
}

/**
 * Force the event checkout stepper to use the full available event page width.
 */
.gtg-event-inline-progress.gtg-rest-checkout__progress {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  max-width: none !important;
  inline-size: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .55rem !important;
  margin: 0 0 1rem !important;
  padding: 0 !important;
}

.gtg-event-inline-progress.gtg-rest-checkout__progress > li,
.gtg-event-inline-progress.gtg-rest-checkout__progress > li > button {
  width: 100% !important;
  max-width: none !important;
}

.gtg-event-inline-progress.gtg-rest-checkout__progress > li > button {
  display: grid !important;
  gap: .35rem !important;
}

.gtg-event-inline-progress.gtg-rest-checkout__progress span {
  width: 100% !important;
}
