/* ===========================
   Base
   =========================== */
:root{
	--sb-bg-dark:   #111;
	--sb-bg-darker: #0b0b0b;
	--sb-text:      #eee;
	--sb-muted:     #bbb;
	--sb-accent:    #FFFFFF; /* borders/accents */
	--media-gap:    24px;
}

/* Global font import + token */
@import url('https://fonts.googleapis.com/css2?family=Freeman&display=swap');

:root {
    --sb-font-nav: "Freeman", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* Make the entire navbar family inherit the token */
.navbar,
.navbar .navbar-brand,
.navbar .nav-link,
.navbar .dropdown-menu,
.navbar .dropdown-item {
    font-family: var(--sb-font-nav);
}

html, body{ height: 100%; }

body{
	background-color: var(--sb-bg-dark);
	color: var(--sb-text);
	font-family: var(--bs-body-font-family, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif);
	overflow-x: hidden;
}

/* Navbar */
.navbar{
	background: rgba(0,0,0,0.1) !important;
	transition: transform .25s ease;
	font-family: "Freeman", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}
.navbar .navbar-brand,
.navbar .nav-link{ font-family: inherit; }
.navbar.hidden{ transform: translateY(-100%); }

/* Social icons */
.social-icons .icon-img{
	width: 22px; height: 22px; display: block;
	filter: brightness(0) invert(1);
	transition: transform .2s ease, opacity .2s ease;
	opacity: .95;
}
.social-icons .nav-link:hover .icon-img{ transform: translateY(-1px); opacity: 1; }

/* ===== Intro Overlay ===== */
.intro{
	position: fixed;
	inset: 0;
	display: grid;
	place-items: center;
	z-index: 9999;
	pointer-events: none;
	background: #000;
}
.intro__video{
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	filter: brightness(.6);
}
.intro__inner{ position: relative; z-index: 1; }
.intro__typed{
	color: #fff;
	font-weight: 900;
	letter-spacing: .18em;
	text-transform: uppercase;
	font-size: clamp(1rem, 2.6vw, 1.5rem);
	white-space: pre;
}
@keyframes bounceDot{
	0%,100%{ transform: translateY(0); }
	30%{ transform: translateY(-8px); }
	60%{ transform: translateY(0); }
	80%{ transform: translateY(-4px); }
}
.intro__dot{ display: inline-block; animation: bounceDot .8s ease; }

/* Reveal page under intro */
body.intro-active > :not(#intro){
	transform: translateY(24px);
	filter: blur(2px);
	opacity: .9;
	transition: none;
}
body.intro-done > :not(#intro){
	transform: translateY(0);
	filter: blur(0);
	opacity: 1;
	transition: transform 900ms cubic-bezier(.22,.61,.36,1), filter 900ms ease, opacity 900ms ease;
}
#intro.intro-hide{ animation: introFade 900ms ease forwards; }
@keyframes introFade{ to{ opacity: 0; } }
@media (prefers-reduced-motion: reduce){
	body.intro-active > :not(#intro),
	body.intro-done > :not(#intro){
		transform: none !important;
		filter: none !important;
		opacity: 1 !important;
		transition: none !important;
	}
	#intro.intro-hide{ animation: none !important; }
}

/* ===========================
   Hero
   =========================== */
.hero{ position: relative; z-index: 0; height: 100vh; }
.hero__video{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.hero__content{
	position: relative; z-index: 1; height: 100%;
	display: flex; align-items: center; justify-content: center; flex-direction: column; gap: .75rem; text-align: center;
}
.fade-in{ opacity: 0; transform: translateY(6px); animation: fadeInUp .6s ease .15s forwards; }
.delay-04{ animation-delay: .4s; }
@keyframes fadeInUp{ to{ opacity: 1; transform: none; } }

/* Keep hero text line from pushing logo */
.hero__content .lead{
	min-height: 1.6em; margin: 0;
	display: flex; align-items: center; justify-content: center;
}
.hero__content .typed{ display: inline-block; white-space: nowrap; }

/* ===========================
   Sections + reveal
   =========================== */
.section-dark{   background: var(--sb-bg-dark);   position: relative; z-index: 1; }
.section-darker{ background: var(--sb-bg-darker); position: relative; z-index: 1; }

.reveal{
	opacity: 0 !important;
	translate: 0 24px;
	transition: opacity .6s ease, translate .6s ease;
	will-change: opacity, transform;
}
.reveal.in-view{
	opacity: 1 !important;
	translate: 0 0;
}

/* ===========================
   Artists Strip
   =========================== */
.artists-strip{
	border-top: 2px solid var(--sb-accent);
	border-bottom: 2px solid var(--sb-accent);
	position: relative;
}
.artists-strip::before,
.artists-strip::after{
	content: "";
	position: absolute; width: 28px; height: 28px; opacity: .6;
}
.artists-strip::before{ top: 16px; left: 16px; border-top: 2px solid var(--sb-accent); border-left: 2px solid var(--sb-accent); }
.artists-strip::after{ right: 16px; bottom: 16px; border-right: 2px solid var(--sb-accent); border-bottom: 2px solid var(--sb-accent); }
.artists-strip__tagline{
	color: var(--sb-muted);
	text-transform: uppercase;
	letter-spacing: .18em;
	opacity: .9;
	font-weight: 600;
	font-size: clamp(.9rem, 1.1vw + .5rem, 1.15rem);
}
.artists-strip__name-wrap{ min-height: 3.2em; display: grid; place-items: center; }
.artists-strip__name{
	font-weight: 900;
	letter-spacing: .06em;
	font-size: clamp(2rem, 6.5vw, 4.5rem);
	line-height: 1.05;
	margin-top: .25rem;
	transition: opacity .42s ease;
	text-shadow: 0 0 10px rgba(255,255,255,.06);
}
#artists-strip .is-hidden{ opacity: 0; transition: opacity .42s ease; }

/* ===========================
   About Us
   =========================== */
#about .about-text p{
	font-weight: 600;
	line-height: 1.25;
	color: #fff;
	margin: 0;
}
@media (min-width: 992px){ #about .about-text p{ font-size: 2.25rem; } }
@media (max-width: 991.98px){ #about .about-text p{ font-size: 1.75rem; } }

/* ===========================
   Media Carousels (Past/Merch)
   =========================== */
.media-wrap{ position: relative; }
.media-track{
	--card-h: 360px;
	display: flex;
	gap: var(--media-gap);
	overflow-x: auto;
	padding: 4px 2px 12px;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
}
.media-card{
	flex: 0 0 calc((100% - (var(--media-gap) * 2)) / 3); /* three visible */
	height: var(--card-h);
	border-radius: 12px;
	overflow: hidden;
	background: #000;
	border: 1px solid rgba(255,255,255,.08);
	scroll-snap-align: start;
	position: relative;
}
.media-card img,
.media-card video{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
@media (max-width: 991.98px){
	.media-card{
		flex-basis: calc(80vw);
		height: calc(80vw * 0.6);
	}
}

/* Arrows */
.media-arrow{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px; height: 44px;
	border-radius: 999px;
	border: 1px solid rgba(255,255,255,.28);
	background: rgba(0,0,0,.38);
	color: #fff;
	display: grid;
	place-items: center;
	z-index: 2;
	cursor: pointer;
	transition: background .2s ease, border-color .2s ease, opacity .2s ease;
}
.media-arrow:hover{ background: rgba(0,0,0,.55); border-color: rgba(255,255,255,.6); }
.media-arrow.left{  left: 8px; }
.media-arrow.right{ right: 8px; }

/* ===========================
   Experience Line
   =========================== */
.experience-line{ font-weight: 600; line-height: 1.25; }
@media (min-width: 992px){ .experience-line{ font-size: 2rem; } }
@media (max-width: 991.98px){ .experience-line{ font-size: 1.4rem; } }

/* ===========================
   Events
   =========================== */
.event-img{ width: 100%; height: auto; border-radius: .5rem; }

/* ===========================
   Merch placeholders
   =========================== */
.media-card--placeholder .media-placeholder{
	width: 100%; height: 100%;
	display: grid; place-items: center;
	color: #fff;
	font-weight: 800;
	letter-spacing: .22em;
	text-transform: uppercase;
	text-align: center;
	padding: 0 12px;
	background: linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.02) 100%);
	user-select: none;
}

/* ===========================
   Signup Banner (compact card)
   =========================== */
.signup-banner{
	position: fixed;
	left: 0; right: 0;
	bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
	width: clamp(300px, 90vw, 640px);
	margin: 0 auto;
	transform: none;
	box-sizing: border-box;
	background: rgba(0,0,0,.92);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 20px;
	padding: 16px 16px 16px 20px;
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	column-gap: 16px;
	z-index: 1040;
	box-shadow: 0 10px 28px rgba(0,0,0,.45);
	overflow: visible; /* let the X float outside */
}
.signup-banner__left{ display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.signup-banner__title{
	font-weight: 900;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-size: .95rem;
	line-height: 1.15;
	color: #fff;
}
.signup-banner__subtitle{
	font-size: .85rem;
	line-height: 1.3;
	color: rgba(255,255,255,.85);
	margin: 0;
}
.signup-banner__cta{
	white-space: nowrap;
	font-size: .9rem;
	line-height: 1.1;
	padding: 8px 16px;
	min-width: 112px;
	border-radius: 999px;
	box-shadow: none !important;
	border: 0;
}
.signup-banner__cta:focus,
.signup-banner__cta:active{ box-shadow: none !important; transform: none !important; }

/* Edge-floating X button */
.signup-banner__close{
	position: absolute;
	top: -18px;
	right: -18px;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	background: rgba(255,255,255,.95);
	color: #111;
	border: 0;
	display: grid;
	place-items: center;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 6px 18px rgba(0,0,0,.25);
	z-index: 1041;
	pointer-events: auto;
}
.signup-banner__close:hover{ background: #fff; }

@media (max-width: 575.98px){
	.signup-banner{
		grid-template-columns: 1fr;
		row-gap: 10px;
		padding-right: 44px; /* space for the X */
	}
	.signup-banner__cta{ justify-self: start; }
}

/* Old fixed button (ensure it never shows) */
.signup-fixed-btn{ display: none !important; }

/* Modal backdrop: solid black at 10%, instant open/close */
#signupModal,
#signupModal .modal-dialog,
#signupModal .modal-content{ transition: none !important; animation: none !important; }
#signupModal .modal-dialog{ transform: none !important; }
.modal-backdrop{ background-color: #000 !important; opacity: .10 !important; transition: none !important; animation: none !important; }
.modal-backdrop.show{ opacity: .10 !important; }

/* ===========================
   Mobile full-screen menu
   =========================== */
@media (max-width: 991.98px){
	.navbar .navbar-toggler{ z-index: 1101; }
	.navbar:has(#navMain.show),
	.navbar.hidden:has(#navMain.show){ transform: none !important; }

	#navMain.collapsing,
	#navMain.collapse.show{
		position: fixed !important;
		inset: 0 !important;
		padding: calc(var(--nav-offset, 56px) + 24px) 24px 22vh !important;
		width: 100vw !important;
		max-width: 100vw !important;
		min-height: 100vh !important;
		background: #000 !important;
		overflow-y: auto !important;
		height: auto !important;
		max-height: none !important;
		display: block !important;
		transition: none !important;
		animation: none !important;
		z-index: 1030 !important;
	}

	.navbar .navbar-nav .nav-link{
		display: block;
		width: 100%;
		font-weight: 800;
		letter-spacing: .12em;
		text-transform: uppercase;
		font-size: clamp(1.25rem, 2.5vw + 1rem, 1.75rem);
		padding: .55rem 0;
	}

	#mobileSocials .nav-link{
		font-weight: 700;
		letter-spacing: .14em;
		font-size: clamp(1rem, 2vw + .5rem, 1.25rem);
		opacity: .95;
		padding: .4rem 0;
	}
	#mobileSocials .navbar-nav{ margin-top: .25rem; margin-bottom: .5rem; }

	/* Hide desktop icons in mobile overlay */
	.social-icons{ display: none !important; }

	/* Hide BUY TICKETS button inside overlay (you already have TICKETS link) */
	#navMain .btn{ display: none !important; }
}

/* === Signup banner close button: perfect 22x22 with centered X === */
.signup-banner__close{
  width: 22px !important;
  height: 22px !important;
  top: -11px !important;                 /* straddles the card edge */
  right: -11px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.95) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.22) !important;

  /* center container */
  position: absolute;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 0 !important;
  line-height: 1 !important;

  /* hide the font glyph and use CSS lines instead */
  color: transparent !important;
  font-size: 0 !important;
}

/* Draw the X with two centered lines */
.signup-banner__close::before,
.signup-banner__close::after{
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  width: 12px;                           /* length of each stroke */
  height: 2px;                           /* thickness */
  background: #111;
  border-radius: 2px;
  transform-origin: center;
}

.signup-banner__close::before{
  transform: translate(-50%, -50%) rotate(45deg);
}
.signup-banner__close::after{
  transform: translate(-50%, -50%) rotate(-45deg);
}

.signup-banner__close:hover{ background: #fff !important; }



/* ===========================
   Footer (compact + stacked on mobile)
   =========================== */
#footer{ font-size: .9rem; }
#footer h3{ font-size: 1.2rem; margin-bottom: .5rem; }
#footer h6{ font-size: .8rem; letter-spacing: .08em; margin-bottom: .35rem; }
#footer .list-unstyled li{ margin-bottom: .25rem; }
#footer .btn{ padding: .35rem .6rem; font-size: .85rem; }

@media (max-width: 767.98px){
	#footer .row.g-4 > .col-lg-4,
	#footer .row.g-4 > .col-lg-8{ flex: 0 0 100% !important; max-width: 100% !important; }
	#footer .col-6{ flex: 0 0 100% !important; max-width: 100% !important; }
	#footer .col-lg-4{ margin-bottom: 1rem; }
	#footer .row.g-3 > [class*="col-"]{ margin-bottom: .5rem; }
}

/* ===========================
   Utilities
   =========================== */
.py-6{ padding-top: 4.5rem; padding-bottom: 4.5rem; }
