:root {
  --brand-bg: #0e1318;
  --brand-fg: #ffffff;
  --brand-accent: #00c4cc;
  --brand-muted: #9aa3ab;
  --radius-xl: 1.25rem;
}

html {
  scroll-behavior: smooth;
}

html,
body {
  overflow-x: hidden;
}

body {
  font-family: "Noto Sans", "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
}

.section {
  padding: 72px 0;
}

hr.soft {
  border-color: #00000033;
}

footer a {
  text-decoration: none;
}

.card-xl {
  border-radius: var(--radius-xl);
  box-shadow: 0 16px 36px rgba(0, 0, 0, .08);
}

.badge-accent {
  background: var(--brand-accent);
  color: #000;
  font-weight: 700;
}

.text-accent {
  color: var(--brand-accent) !important;
}

.navbar-transparent {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

.navbar-white {
  background: #fff !important;
  box-shadow: none !important;
  border: 0 !important;
}

.navbar .navbar-nav .nav-link {
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-weight: 600;
  letter-spacing: .02em;
  color: #0e1318;
}

.navbar .nav-link:hover {
  opacity: .75;
}

.navbar .navbar-brand .brand-text {
  font-family: 'Bebas Neue', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-size: 1.5rem;
  letter-spacing: .02em;
}

.navbar-light .navbar-toggler {
  border-color: rgba(0, 0, 0, .25);
}

.hero-bleed {
  position: relative;
  width: 100%;
  max-width: 1320px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 12px;
  padding-right: 12px;
}

.hero-video {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
}

.hero-video video {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  position: relative;
  z-index: 1;
}

.hero-virgin {
  width: 100%;
  text-align: center;
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-weight: 600;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: -9rem;
}

.hero-virgin-logo {
  object-fit: cover; 
  display: block;
  width: clamp(100px, 5.8vw, 180px);

  img {
    width: 100%;
    height: auto;
    object-fit: contain;
  }
}


.hero-cta {
  position: absolute;
  top: var(--cta-top, 77%);
  left: var(--cta-left, 65%);
  transform: translate(-50%, -50%);
  z-index: 2;
}

.hero-cta {
  font-size: clamp(0.62rem, 2.4vw, 0.95rem);
  padding: clamp(0.32rem, 1.6vw, 0.55rem) clamp(0.64rem, 3.4vw, 1.00rem);
}

@media (max-width: 576px) {
  .hero-cta {

    font-size: clamp(0.56rem, 2.0vw, 0.85rem);
    padding: clamp(0rem, 0vw, 0.48rem) clamp(0.56rem, 1vw, 0.88rem);
  }
}

@media (max-width: 1399.98px) {
  .hero-bleed {
    max-width: 1140px;
  }
}

@media (max-width: 1199.98px) {
  .hero-bleed {
    max-width: 960px;
  }
}

@media (max-width: 991.98px) {
  .hero-bleed {
    max-width: 720px;
  }
}

@media (max-width: 767.98px) {
  .hero-bleed {
    max-width: 540px;
  }
}

@media (max-width: 575.98px) {
  .hero-bleed {
    width: 100vw;
    max-width: 100vw;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    padding-left: 0;
    padding-right: 0;
  }
}

.btn {
  --btn-bg: #fee16e;
  --btn-fg: #0e1318;
  --btn-bg-hover: #f9d94e;
  --btn-bg-active: #f3cf35;

  background: var(--btn-bg);
  color: var(--btn-fg);
  border-color: var(--btn-bg);
  border-radius: 9999px;
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-weight: 700;
  box-shadow: 0 6px 14px rgba(0, 0, 0, .08);
}

.btn:hover {
  background: var(--btn-bg-hover);
  border-color: var(--btn-bg-hover);
  color: var(--btn-fg);
}

.btn:active,
.btn:focus {
  background: var(--btn-bg-active);
  border-color: var(--btn-bg-active);
  color: var(--btn-fg);
}

.btn-outline-dark,
.btn-outline-light,
.btn-light,
.btn-dark,
.btn-accent {
  background: var(--btn-bg) !important;
  border-color: var(--btn-bg) !important;
  color: var(--btn-fg) !important;
}

.what-section {
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.what-title {

  font-weight: 400;
  letter-spacing: .01em;
  font-size: clamp(2.1rem, 3.8vw, 2.9rem);
  margin-bottom: .5rem;
}

.what-body {
  color: #000;
  font-weight: 450;
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  line-height: 1.75;
  max-width: 59rem;
  margin: 0 auto;
}

.event-details {
  margin-top: 1.25rem;
  max-width: 34rem;
  margin-left: auto;
  margin-right: auto;
}

.event-details .detail {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin: 0.35rem 0;
}

.event-details .icon-date {
  color: #ed8fa9;
}

.event-details .icon-location {
  color: #62c7d1;
}

.event-details .icon-time {
  color: #8f7bd9;
}

.event-details .title {
  color: #000;
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-weight: 550;
  font-size: 1.05rem;
  line-height: 1.35;
}

@media (max-width: 576px) {
  .event-details {
    max-width: 100%;
    padding: 0 12px;
  }

  .event-details .title {
    font-size: 1rem;
  }
}

.event-details .text {
  color: #000;
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  line-height: 1.35;
}

@media (max-width: 576px) {
  .event-details {
    max-width: 100%;
    padding: 0 12px;
  }

  .event-details .text {
    font-size: 1rem;
  }
}

/* ===== Tickets section ===== */
.tickets-section{
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  /* background: url('../assets/img/tickets-bg.jpg') center / cover no-repeat; */
  position: relative;
}

/* optional overlay: if your background is busy, uncomment and tune alpha */
/*
.tickets-overlay{
  background: rgba(255,255,255,.65);
  padding: clamp(12px, 2vw, 20px) 0;
}
*/

.tickets-title{
  color: #0e1318;
  font-weight: 400;
  letter-spacing: .01em;
  font-size: clamp(2rem, 3.5vw, 2.6rem);
  margin-bottom: .5rem;
  text-align: center;
}
.tickets-sub{
  color: #000;
  font-weight: 400;
  font-size: clamp(1rem, 1.25vw, 1.125rem);
  line-height: 1.65;
  max-width: 58rem;
  margin: 0 auto 1.25rem auto;
  text-align: center;
}

/* grid for the three options */
.tickets-grid{
  display: grid;
  gap: clamp(12px, 2.2vw, 24px);
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 991.98px){ .tickets-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px){ .tickets-grid{ grid-template-columns: 1fr; } }

/* keep your existing grid exactly as you posted */
.booth-tickets-grid{
  display: grid;
  gap: clamp(12px, 2.2vw, 24px);
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 991.98px){ .booth-tickets-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px){ .booth-tickets-grid{ grid-template-columns: 1fr; } }

/* booths-only: make each card a column flex so the CTA can sit at the bottom */
.booth-tickets-grid > .ticket-card{
  display: flex;
  flex-direction: column;
  height: 100%;             /* let the card fill its grid cell */
}

/* push the CTA down; keep width tidy */
.booth-tickets-grid > .ticket-card .btn{
  margin-top: auto;         /* anchors to bottom of the flex column */
  align-self: center;       /* optional center */
  min-width: 160px;         /* optional consistency */
}


.ticket-card{
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: var(--radius-xl);
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  padding: clamp(14px, 2vw, 22px);
  text-align: center;
}
.ticket-name{
  color: #0e1318;
  font-weight: 700;
  font-size: clamp(1.1rem, 1.3vw, 1.25rem);
  margin-bottom: .25rem;
}
/* Tickets: price display w/ crossed-out door price */
.ticket-price{
  display:flex;
  align-items: baseline;
  justify-content: center;
  gap: .5rem;
  margin-bottom:.5rem;
}

.price-current{
  font-weight: 800;
  font-size: clamp(1.05rem, 1.3vw, 1.25rem);
  color:#0e1318;
}

.price-door{
  font-weight: 600;
  color:#000;
  opacity:.65;
  text-decoration: line-through;
  white-space: nowrap;
}

/* On small screens, let them wrap so the door price can sit above */
@media (max-width: 575.98px){
  .ticket-price{ flex-wrap: wrap; }
  .price-door{ width:100%; text-align:center; }
}

.ticket-desc{
  color: #000;
  opacity: .85;
  font-size: .95rem;
  line-height: 1.5;
  margin-bottom: .9rem;
}

.event-day {
  background-color: #f495b0;
}

.after-party {
  background-color: #6f53cb;
}

.combo {
  background-color: #44c7d7;
}

/* modal: keep typography consistent */
#purchaseModal .modal-content{
  border-radius: var(--radius-xl);
}
#purchaseModal .modal-title{
  font-weight: 700;
}
#purchaseModal label{
  font-weight: 600;
  font-size: .92rem;
}
#purchaseModal .form-text{
  font-size: .85rem;
}


.includes-section {
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  color: white;
  background: url('../assets/img/includes-bg.png') top / cover no-repeat;
  padding-top: 14rem;
}

.includes-grid {
  padding-top: 3rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(12px, 2vw, 24px);
  align-items: stretch;
}

.includes-tile {
  aspect-ratio: 3 / 4;
  border-radius: 0;
  overflow: hidden;
}

.includes-tile img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.forms-section {
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.forms-list {
  display: grid;
  grid-auto-rows: auto;
  gap: clamp(12px, 2.2vw, 24px);
}

.forms-item {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.forms-item img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.cta-overlay {
  position: absolute;
  top: var(--cta-top, 80%);
  left: var(--cta-left, 50%);
  transform: translate(-50%, -50%);
  z-index: 2;
}

.cta-overlay {
  font-size: clamp(1rem, 2.4vw, 0.95rem);
  padding: clamp(0.32rem, 1.6vw, 0.55rem) clamp(4rem, 4vw, 1.00rem);
}

@media (max-width: 576px) {
  .cta-overlay {
    font-size: clamp(0.56rem, 2.5vw, 0.85rem);
    padding: clamp(0rem, 0vw, 0.48rem) clamp(0.56rem, 3.8vw, 0.88rem);
  }
}

.about-section {
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
}

.about-title {
  font-weight: 500;
  letter-spacing: .01em;
  font-size: clamp(2rem, 3.6vw, 2.6rem);
  margin-bottom: .5rem;
  color: #0e1318;
}

.about-body {
  color: #000;
  font-weight: 400;
  font-size: clamp(1rem, 1.2vw, 1.125rem);
  line-height: 1.75;
  max-width: 62rem;
  margin: 0 auto;
}

.about-block {
  text-align: center;
  padding: clamp(18px, 3.5vw, 36px) 0;
}

.about-logo {
  display: block;
  margin: 0 auto clamp(12px, 2vw, 18px);
  width: clamp(120px, 18vw, 220px);
  height: auto;
  object-fit: contain;
}

.about-text {
  color: #000;
  font-weight: 400;
  font-size: clamp(0.95rem, 1.1vw, 1.1rem);
  line-height: 1.7;
  max-width: 62rem;
  margin: 0 auto;
}

.about-sep {
  border: 0;
  border-top: 1px solid rgba(0, 0, 0, .10);
  margin: clamp(16px, 3vw, 28px) auto;
  max-width: 62rem;
}

.contact-section {
  position: relative;
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  color: white !important;
  background: url('../assets/img/contact-bg.png') bottom / cover no-repeat;
  padding-bottom: 20rem;
}

.contact-overlay {
  position: relative;
  background: rgba(255, 255, 255, 0);
}

.contact-inner {
  max-width: 56rem;
  margin: 0 auto;
  text-align: center;
}

.contact-title {
  font-weight: 600;
  letter-spacing: .01em;
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  margin-bottom: .2rem;
}

.contact-subtitle {
  font-weight: 500;
  font-size: clamp(1.1rem, 1.8vw, 1.35rem);
  margin-bottom: .75rem;
}

.contact-body {
  font-weight: 400;
  font-size: clamp(0.95rem, 1.2vw, 1.125rem);
  line-height: 1.75;
  margin-bottom: 1.25rem;
}

.contact-cta {
  margin: .5rem 0 1rem 0;
}

.contact-note {
  font-weight: 400;
  font-size: clamp(0.9rem, 1.1vw, 1rem);
  margin-bottom: .75rem;
}

.contact-emails {
  font-weight: 600;
  font-size: clamp(0.95rem, 1.1vw, 1.05rem);
  margin-bottom: .9rem;
}

.contact-emails a {
  color: inherit;
  text-decoration: none;
}

.contact-emails a:hover {
  text-decoration: underline;
}

.contact-socials {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.contact-socials a {
  text-decoration: none;
}

.contact-socials a:hover {
  opacity: .8;
}

.contact-socials .bi {
  font-size: 1.4rem;
  display: inline-block;
  line-height: 1;
}