:root{
  --bg:#0b0b0d;
  --panel:#141419;
  --panel-2:#1b1b22;
  --text:#f3f1ec;
  --muted:#b9b2a7;
  --line:#2a2a33;
  --accent:#b54b3f;
  --accent-2:#d4a15f;
  --max:1200px;
  --radius:18px;
  --shadow:0 20px 60px rgba(0,0,0,.35);
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Inter, Arial, sans-serif;
  background:linear-gradient(180deg,#09090b 0%, #101014 100%);
  color:var(--text);
  line-height:1.6;
}

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

a{color:inherit}

.container{
  width:min(var(--max), calc(100% - 32px));
  margin:0 auto;
}

.eyebrow{
  color:var(--accent-2);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.8rem;
  margin-bottom:.5rem;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(10,10,12,.75);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.site-header .inner{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.brand{
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  text-decoration:none;
}

.nav{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  align-items:center;
}

.nav a{
  text-decoration:none;
  color:var(--muted);
  font-size:.95rem;
}

.nav a:hover,
.nav a.active{
  color:var(--text);
}

.hero{
  position:relative;
  min-height:72vh;
  display:grid;
  align-items:start;
  overflow:visible;
  background:
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.70)),
    url('../images/JayDavids3Small.png') center 35% / cover no-repeat;
}

.hero.small{
  min-height:72vh;
}

.hero.mission{
  min-height:72vh;
  overflow:visible;
  background:
    linear-gradient(180deg, rgba(0,0,0,.24), rgba(0,0,0,.78)),
    url('../images/mission.png') center center / cover no-repeat;
}

.hero.live-hero{
  background-size:cover;
  background-position:center 28%;
  background-repeat:no-repeat;
}

.hero .content{
  padding:120px 0 64px;
  max-width:760px;
}
.hero h1 {
  font-size: clamp(36px, 6vw, 72px);
  font-weight: 700;
  letter-spacing: -0.02em;
}

h1,h2,h3{
  font-family:Oswald, Inter, Arial, sans-serif;
  line-height:1.05;
  margin:0 0 14px;
  letter-spacing:.01em;
}

h1{font-size:clamp(2.6rem, 6vw, 4.6rem)}
h2{font-size:clamp(2rem, 4vw, 3.3rem)}
h3{font-size:clamp(1.2rem, 2vw, 1.6rem)}

.lead{
  font-size:clamp(1.05rem, 1.7vw, 1.3rem);
  color:#ebe6de;
  max-width:60ch;
}

.subtle{color:var(--muted)}

.actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:26px;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 18px;
  border-radius:999px;
  text-decoration:none;
  border:1px solid transparent;
  font-weight:700;
}

.button.primary{
  background:var(--accent);
  color:white;
}

.button.primary:hover{
  filter:brightness(1.05);
}

.button.secondary{
  border-color:rgba(255,255,255,.16);
  color:var(--text);
  background:rgba(255,255,255,.02);
}

.button.secondary:hover{
  background:rgba(255,255,255,.05);
}

.button.ghost{color:var(--accent-2)}

.section{padding:72px 0}

.grid-2{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

.grid-4{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.card-body{padding:22px}

.media{
  aspect-ratio:16/10;
  background:#1a1a20 center/cover no-repeat;
}

.media.tall{aspect-ratio:4/5}
.media.square{aspect-ratio:1/1}

.feature{
  display:grid;
  grid-template-columns:420px 1fr;
  gap:28px;
  align-items:start;
}

.feature .cover{
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow);
}

.cover-art{
  background:url('../images/music-placeholder.svg') center/cover no-repeat;
  aspect-ratio:1/1;
}

.list-clean{
  list-style:none;
  padding:0;
  margin:0;
}

.song-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}

.song-card{
  text-decoration:none;
  color:inherit;
  display:block;
}

.song-card .media{
  background-image:url('../images/music-placeholder.svg');
}

.song-card .title{
  font-weight:700;
  margin-bottom:4px;
}

.song-card .meta{
  font-size:.92rem;
  color:var(--muted);
}

.tour-list{
  display:grid;
  gap:16px;
}

.tour-row{
  display:grid;
  grid-template-columns:120px 1fr auto;
  gap:18px;
  align-items:center;
  padding:18px 20px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.07);
  border-radius:16px;
}

.tour-date{
  font-weight:800;
  font-size:1.15rem;
}

.kicker{
  color:var(--accent-2);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.8rem;
}

.quote{
  padding:24px;
  border-left:3px solid var(--accent);
  background:rgba(255,255,255,.02);
  border-radius:12px;
}

.cta-band{
  padding:34px;
  background:linear-gradient(135deg, rgba(181,75,63,.18), rgba(212,161,95,.10));
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
}

.footer{
  border-top:1px solid rgba(255,255,255,.08);
  padding:34px 0 52px;
  color:var(--muted);
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:22px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  color:var(--muted);
  border:1px solid rgba(255,255,255,.07);
  font-size:.9rem;
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.field{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:#121218;
  color:var(--text);
  padding:14px 16px;
  font:inherit;
}

.field::placeholder{color:#928a80}

textarea.field{
  min-height:150px;
  resize:vertical;
}

.note{
  font-size:.9rem;
  color:var(--muted);
}

.embed{
  width:100%;
  aspect-ratio:16/9;
  border:0;
  border-radius:18px;
  background:#1b1b22;
}

.center{text-align:center}

.support-card{
  text-align:center;
  text-decoration:none;
  color:inherit;
  transition:transform .2s ease, box-shadow .2s ease;
}

.support-card:hover{
  transform:translateY(-4px);
}

.epk-portrait{
  width:100%;
  aspect-ratio:4/5;
  display:block;
  background-color:#1a1a20;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}

.live-image-card{
  display:flex;
  min-height:100%;
}

.live-fill-image{
  flex:1;
  width:100%;
  min-height:100%;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}

/* About page photo */
.about-photo{
  float:right;
  width:380px;
  aspect-ratio:4/5;
  margin:0 0 20px 40px;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.about-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}

/* Signup form */
.signup-form label{
  display:block;
  margin-bottom:6px;
  font-size:.92rem;
  color:var(--muted);
}

.signup-form select.field{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
}

.signup-form button{
  cursor:pointer;
}

/* Homepage featured show */
.shows-section{
  max-width:900px;
  margin:0 auto;
  padding:72px 20px;
  text-align:center;
}

.section-title{
  margin-bottom:10px;
}

.featured-show{
  margin-top:30px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:40px;
  flex-wrap:wrap;
}

.show-date{
  font-size:42px;
  font-weight:800;
  letter-spacing:.08em;
  color:var(--accent-2);
  min-width:120px;
}

.show-details{
  text-align:left;
  max-width:420px;
}

.show-venue{
  font-size:1.5rem;
  margin-bottom:6px;
}

.show-location{
  color:var(--muted);
  margin-bottom:18px;
}

.show-buttons{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
}

.show-empty{
  color:var(--muted);
  text-align:center;
}

/* Bandsintown widget */
.bit-widget-initializer{
  display:block;
}

.bit-widget-initializer ~ div a,
.bit-widget-initializer ~ div button{
  min-width:150px !important;
  width:150px !important;
  text-align:center !important;
  justify-content:center !important;
  box-sizing:border-box !important;
}

.bit-widget-initializer ~ div svg{
  display:none !important;
}

/* Mission46 Hero Adjustments */
.hero.mission .content{
  text-align:center;
  max-width:900px;
  margin:0 auto;
}

.hero.mission h1{
  font-size:2.6rem;
  line-height:1.35;
  font-weight:500;
  max-width:800px;
  margin:0 auto 10px;
}

.hero.mission .lead{
  font-size:1rem;
  opacity:.8;
}

.hero.mission .actions{
  justify-content:center;
}

/* Mission 46 centered text section */
.section .center{
  text-align:center;
}

.section .center h2{
  max-width:900px;
  margin:0 auto 20px auto;
}

.section .center .lead{
  max-width:720px;
  margin:0 auto;
  text-align:center;
}

@media (max-width:980px){
  .grid-2,
  .feature,
  .footer-grid,
  .grid-3,
  .grid-4,
  .song-grid{
    grid-template-columns:1fr;
  }

  .tour-row{
    grid-template-columns:1fr;
    align-items:start;
  }

  .hero .content{
    padding-top:110px;
  }

  .bit-widget-initializer ~ div a,
  .bit-widget-initializer ~ div button{
    min-width:100% !important;
    width:100% !important;
  }
}

@media (max-width:800px){
  .about-photo{
    float:none;
    width:100%;
    max-width:380px;
    margin:0 auto 20px;
  }
}

@media (max-width:700px){
  .featured-show{
    flex-direction:column;
    text-align:center;
  }

  .show-details{
    text-align:center;
  }

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

  .hero{
    min-height:72vh;
  }

  .hero .content{
    padding:110px 0 56px;
  }

  .hero.mission{
    min-height:auto;
    overflow:visible;
  }

  .hero.mission h1{
    font-size:2rem;
    line-height:1.25;
    max-width:100%;
  }

  .hero.mission .content{
    max-width:100%;
    padding:110px 0 56px;
  }

  .hero.mission .lead{
    margin-bottom:18px;
  }

  .hero.mission .actions{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:12px;
    margin-top:18px;
  }

  .hero.mission .actions .button{
    width:100%;
    max-width:320px;
  }
}