:root{
  /* Helvetica, bold, black-on-white */
  --bg:#e6f3ff;
  --panel:#e6f3ff;
  --muted:#555555;
  --text:#000000;
  --accent:#000000; /* buttons / highlights */
  --btn-text:#ffffff;
  --album-tint:#d4e9ff; /* light blue tint for album backgrounds */
  --glass: rgba(0,0,0,0.04);
  --max-width:1100px;
  --radius:12px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;font-family:Helvetica, "Helvetica Neue", Arial, sans-serif;font-weight:700;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5;
}
.container{max-width:var(--max-width);margin:0 auto;padding:28px;width:100%;box-sizing:border-box}

/* Header */
.site-header{backdrop-filter:blur(6px);position:sticky;top:0;z-index:40;background:rgba(255,255,255,0.9);border-bottom:1px solid rgba(0,0,0,0.06)}
.header-row{display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:700;color:var(--text);text-decoration:none;font-size:18px}
.nav{display:flex;gap:18px}
.nav a{color:var(--muted);text-decoration:none}
.nav-toggle{display:none;background:transparent;border:0;color:var(--muted);font-size:20px}
.theme-toggle{background:transparent;border:0;color:var(--muted);font-size:18px;margin-left:8px}

/* Hero */
.hero{padding:64px 0;min-height:70vh;display:flex;align-items:center;justify-content:center}
.hero-inner{display:grid;grid-template-columns:auto 1fr;gap:80px;align-items:center;padding-top:40px;max-width:var(--max-width);margin:0 auto;width:100%}
.hero-nav{display:flex;flex-direction:column;gap:clamp(8px,1.5vw,16px)}
.hero-nav-link{color:var(--text);text-decoration:underline;font-weight:700;font-size:clamp(20px,3vw,42px);line-height:1.2;font-family:Helvetica,Arial,sans-serif;transition:opacity 0.2s}
.hero-nav-link:hover{opacity:0.6}
.hero-image{display:flex;flex-direction:column;align-items:center;justify-content:center}
.hero-image img{width:100%;max-width:650px;height:auto;border-radius:0;background:var(--glass);padding:12px;display:block}
.btn{background:var(--accent);color:var(--btn-text);padding:10px 16px;border-radius:8px;text-decoration:none;border:0;cursor:pointer}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--text)}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:32px;text-align:center}
  .hero-nav{align-items:center}
  .hero-image{justify-content:center}
  .hero-image img{max-width:90vw}
}

/* Sections */
.section{padding:56px 28px;width:100%;clear:both;display:block;box-sizing:border-box}
.section .container{display:flex;flex-direction:column;align-items:flex-start;width:100%;max-width:100%;padding:0}
.section h2{font-family:Merriweather,serif;margin:0 0 18px;font-size:clamp(28px,4.5vw,56px);line-height:1;margin-bottom:22px;letter-spacing:-0.5px;text-align:left;width:100%;padding:0}
.grid{display:flex;flex-direction:column;gap:18px;width:100%;align-items:stretch}

/* Make album cards in the Sound section stack vertically */
.sound .grid{display:flex;flex-direction:column;gap:18px}

/* Album hero style (text left, large cover right) inspired by provided reference image */
.album-hero{display:flex;align-items:center;justify-content:space-between;gap:60px;padding:40px 28px;border-radius:0;background:var(--album-tint);margin:40px -28px;width:calc(100% + 56px);box-sizing:border-box}
.album-hero .content{flex:1;max-width:50%;padding-left:0;text-align:left}
.album-hero h3{font-size:clamp(32px,5vw,56px);margin:0 0 12px;line-height:1.1;font-weight:700}
.album-hero p{color:var(--text);font-size:clamp(16px,2vw,20px);margin:0 0 20px;line-height:1.4}
.album-hero .get-btn{display:inline-block;background:var(--text);color:var(--bg);padding:12px 28px;border-radius:0;text-decoration:none;font-weight:700;font-size:18px;letter-spacing:0.5px}
.album-hero .cover{flex:0 0 auto;max-width:650px;padding-right:0}
.album-hero .cover img{width:100%;height:auto;border-radius:0;box-shadow:0 8px 24px rgba(0,0,0,0.15);display:block}

@media(max-width:900px){
  .album-hero{flex-direction:column-reverse;align-items:flex-start;padding:20px}
  .album-hero .cover{width:100%;flex:auto;text-align:left}
  .album-hero h3{font-size:28px}
}
.card{background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent);border-radius:12px;padding:12px;overflow:hidden}
.card img{width:100%;height:auto;object-fit:contain;border-radius:8px;background:var(--glass);padding:8px}
.card-body{padding:10px}
.card h3{margin:0 0 8px}
.card p{margin:0 0 10px;color:var(--muted)}
.card-links a{color:var(--accent);text-decoration:none;margin-right:10px}

/* Full-bleed video block (pink band behind video, edge-to-edge on wide screens) */
.full-bleed-video{padding:0;border-radius:0;background:transparent;margin:40px 0}
.full-bleed-video .full-bleed-wrap{position:relative;width:100vw;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;background:var(--bg);padding:40px 0;box-sizing:border-box}
.full-bleed-video .embed-container{max-width:1100px!important;width:90%!important;margin:0 auto;background:#000;border-radius:6px;overflow:visible;position:relative;aspect-ratio:16/9}
.full-bleed-video .embed-container iframe{position:absolute;inset:0;width:100%;height:100%;border:0;object-fit:contain}
/* hide overlay titles but keep caption block */
.full-bleed-video .video-overlay{display:none!important}
.full-bleed-video .video-title{margin:0;color:var(--text);font-size:clamp(28px,6vw,72px);line-height:0.9;font-weight:700}
.caption-center{text-align:center;margin-top:20px}
.caption-center h3{font-size:clamp(22px,3.6vw,44px);margin:0}
.card h3{font-size:clamp(22px,3.6vw,44px);margin:0}
.caption-center .subtitle{color:var(--muted);max-width:900px;margin:10px auto 0;font-size:clamp(14px,1.6vw,18px)}

@media(max-width:900px){
  .full-bleed-video .full-bleed-wrap{padding:28px 0}
  .full-bleed-video .embed-container{width:95%!important;height:auto!important}
  .full-bleed-video .video-title{font-size:28px}
}

.about-grid{display:grid;grid-template-columns:220px 1fr;gap:20px;align-items:start}
.about-photo{width:100%;border-radius:12px}

.contact-form{display:flex;flex-direction:column;gap:10px;max-width:560px;margin-left:0}
.contact-form input,.contact-form textarea{padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:transparent;color:var(--text)}
.contact-note{color:var(--muted)}

.site-footer{padding:28px 0;color:var(--muted);font-size:14px}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(12px);transition:all 560ms cubic-bezier(.2,.9,.2,1)}
.reveal.visible{opacity:1;transform:none}

/* Media layout for cards with video */
.card.media-with-video .media-row{display:flex;gap:12px;align-items:flex-start}
.card.media-with-video .media-row img{width:32%;max-width:360px}
/* Use aspect-ratio for true landscape (16:9) and allow embed to grow to viewport height */
.card.media-with-video .embed-container{width:68%;position:relative;aspect-ratio:16/9;min-height:320px;background:#000;border-radius:6px;overflow:hidden}
.card.media-with-video .embed-container iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* On small screens stack media and reduce height */
@media(max-width:900px){
  .card.media-with-video .media-row{flex-direction:column}
  .card.media-with-video .embed-container{width:100%;min-height:40vh}
  .card.media-with-video .media-row img{width:100%;max-width:100%}
}

/* On wide screens make embeds large enough to fill much of the viewport */
@media(min-width:900px){
  .card.media-with-video .embed-container{min-height:60vh}
}

/* Live section: make videos full-width for larger viewing */
.live .card .media-row{display:block}
.live .card .embed-container{width:100%;aspect-ratio:16/9;background:#000;border-radius:6px;overflow:hidden;min-height:60vh}
.live .card .embed-container iframe{width:100%;height:100%}

/* Ensure Live section videos stack vertically in chronological order */
.live-grid{display:flex;flex-direction:column;gap:20px}

/* Feature video size (used for official/featured videos) */
.feature-video .embed-container{aspect-ratio:16/9;min-height:420px;background:#000;border-radius:6px;overflow:hidden}
.feature-video .embed-container iframe{border-radius:6px}

@media(min-width:900px){
  /* Make featured video much larger on wider screens */
  .feature-video .embed-container{padding-bottom:0;height:640px;min-height:640px}
  .feature-video .embed-container{min-height:75vh}
  .feature-video .card-body{padding-top:14px}
}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;}
  .about-grid{grid-template-columns:1fr}
  .nav{display:none !important}
  .nav-toggle{display:inline-block !important}
  .container{padding:28px 20px}
  .header-row{position:relative}
  .header-row .nav{position:absolute;top:100%;left:0;right:0;background:#e6f3ff;flex-direction:column;padding:20px;border-bottom:1px solid rgba(0,0,0,0.06);z-index:50}
  .header-row .nav a{padding:12px 0;font-size:18px;color:var(--text);font-weight:700}
  .header-row .nav.active{display:flex !important}
  .site-header{z-index:100}
}

@media(prefers-reduced-motion:reduce){
  .reveal{transition:none}
}
