:root{
  --bg:#0b0b0c;
  --card:#eee;
  --accent:#aa0000;
  --muted:#9aa0a6;
  --text:#f5f5f7;
  --max-width:1100px;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter,system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial}
body{background:linear-gradient(180deg, var(--bg), #000000);color:var(--text);-webkit-font-smoothing:antialiased}
.container{width:90%;max-width:var(--max-width);margin:0 auto}

.site-header{position:sticky;top:0;background:rgba(10,10,10,0.5);backdrop-filter:blur(6px);z-index:40}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.logo{
  font-family: 'Limelight', Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  font-weight:700;
  text-decoration:none;
  color:var(--text);
  font-size:1.2rem;
}
.site-nav{display:flex;gap:16px}
.site-nav a{color:var(--text);text-decoration:none;padding:8px;border-radius:6px}
.site-nav a:hover{background:rgba(255,255,255,0.03)}
.nav-toggle{display:none;background:transparent;border:0;color:var(--text);font-size:1.25rem}

.hero{
  display:flex;
  align-items:flex-start;
  padding:60px 0;
  background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,1)), url("../assets/HotClubPortrait.jpg");
  background-size: contain;
  background-position: top center;
  background-repeat: no-repeat;
}
.hero-inner{max-width:800px;padding-top:50vh}
.hero-logo{display:block;width:100%;height:auto;margin-bottom:2rem}
.band-name{font-size:3rem;margin:0 0 8px}
.tagline{color:var(--muted);margin:0 0 18px}
.hero-ctas{display:flex;gap:12px}
.btn{display:inline-block;padding:10px 16px;background:transparent;color:var(--text);border:1px solid rgba(255,255,255,0.06);border-radius:8px;text-decoration:none}
.btn.primary{background:linear-gradient(90deg,var(--accent),#800000);color:var(--text);border:0}

.section{padding:48px 0}
.section h2{margin-top:0}
.music audio{width:100%;max-width:640px;margin-top:10px}
.links{margin-top:12px;display:flex;gap:8px}

.contact label{display:flex;flex-direction:column;font-size:0.9rem;word-break:break-word}
.contact a{color:#aa0000}

.site-footer{border-top:1px solid rgba(255,255,255,0.03);padding:18px 0;text-align:center;color:var(--muted)}

@media(max-width:800px){
  .site-nav{display:none;position:absolute;right:16px;top:64px;background:var(--bg);padding:8px;border-radius:8px;flex-direction:column}
  .nav-toggle{display:block}
  .gallery .grid{grid-template-columns:repeat(2,1fr)}
  .band-name{font-size:2.2rem}
}

/* Larger viewports: prioritize showing the whole image */
@media(min-width:1000px){
  .hero{
    /* make hero nearly full viewport height (minus sticky header) 
    min-height:calc(80vh - 64px);
    /* use contain so the full image is visible without cropping */
    background-size: contain;
    background-position: center top;
    background-repeat: no-repeat;
  }
}

@media(max-width:460px){
  .gallery .grid{grid-template-columns:1fr}
}

/* Orientation-specific hero backgrounds
   - Portrait (tall) uses the portrait image for mobile-like aspect ratios
   - Landscape (wide) uses the hero image for wider screens */
@media (orientation: portrait) {
  .hero {
    background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,1)), url("../assets/HotClubPortrait.jpg");
    background-size: cover;
    background-position: center top;
  }
}

@media (orientation: landscape) {
  .hero {
    background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,1)), url("../assets/HotClubHero.jpg");
    background-size: contain;
    background-position: center;
  }
}
