/* ================================================================
   MUSIC HEALS MINDS — Shared Stylesheet
   Brand system v1.0 · Effective 2026-04-22 · Flinthaus
   ================================================================ */

:root{
  /* Brand palette — locked */
  --purple:       #7A6BA8;
  --purple-deep:  #5D5084;
  --purple-soft:  #B5A5D8;
  --cream:        #F4EFE6;
  --cream-deep:   #EDE6D8;
  --cream-warm:   #F9F5EC;
  --ink:          #2B2319;
  --warm-gray:    #5A4D3E;
  --warm-gray-lt: #D8D2C4;
  --ochre:        #C4932D;
  --ochre-soft:   #E5C987;

  /* Type scale */
  --fs-xxl: clamp(44px, 7vw, 84px);
  --fs-xl:  clamp(32px, 5vw, 54px);
  --fs-lg:  clamp(24px, 3.5vw, 36px);
  --fs-md:  clamp(18px, 2vw, 22px);
  --fs-body: 16px;
  --fs-sm:   14px;
  --fs-xs:   12px;
  --fs-micro: 11px;

  /* Rhythm */
  --lh-tight: 1.05;
  --lh-body:  1.65;

  /* Spacing */
  --s-1: 6px;  --s-2: 10px; --s-3: 14px; --s-4: 20px;
  --s-5: 28px; --s-6: 36px; --s-7: 48px; --s-8: 64px; --s-9: 96px;
}

/* ---------- Reset + base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:var(--fs-body);
  line-height:var(--lh-body);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:var(--purple-deep);text-decoration:none}
a:hover{color:var(--purple)}
button{font-family:inherit}

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5,.serif{
  font-family:'Fraunces',Georgia,serif;
  font-variation-settings:"SOFT" 50;
  color:var(--ink);
  letter-spacing:-0.02em;
  line-height:var(--lh-tight);
  font-weight:700;
  margin:0;
}
h1{font-size:var(--fs-xxl);letter-spacing:-0.035em;font-variation-settings:"SOFT" 50,"opsz" 144}
h2{font-size:var(--fs-xl)}
h3{font-size:var(--fs-lg)}
h4{font-size:var(--fs-md)}
.dek,.lead{
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:var(--fs-md);
  line-height:1.55;
  color:var(--warm-gray);
  max-width:640px;
  margin:0;
}
p{margin:0 0 14px;max-width:680px}
.eyebrow{
  font-size:var(--fs-micro);
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--purple);
  font-weight:700;
}

/* ---------- Layout primitives ---------- */
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
@media (max-width:720px){.wrap{padding:0 16px}}
.section{padding:80px 0}
@media (max-width:720px){.section{padding:56px 0}}
.section.tight{padding:48px 0}
.section.alt{background:var(--cream-warm)}
.section.ink{background:var(--ink);color:var(--cream)}
.section.ink h1,.section.ink h2,.section.ink h3,.section.ink h4{color:var(--cream)}
.section.ink .dek,.section.ink .lead{color:var(--ochre-soft)}

/* ---------- NAV ---------- */
.nav{
  position:sticky;top:0;z-index:100;
  background:var(--cream);
  border-bottom:1px solid var(--warm-gray-lt);
  backdrop-filter:saturate(1.2) blur(8px);
  background:rgba(244,239,230,0.95);
}
.nav-inner{
  max-width:1140px;margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.nav-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.nav-logo img{height:72px;width:auto;display:block}
@media (max-width:720px){.nav-logo img{height:52px}}
.nav-logo .text{
  font-family:'Fraunces',serif;font-weight:700;
  font-size:17px;color:var(--ink);letter-spacing:-0.01em;
  display:none;
}
@media (min-width:900px){.nav-logo .text{display:block}}
.nav-links{
  display:flex;align-items:center;gap:4px;
  list-style:none;padding:0;margin:0;
}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--ink);
  padding:8px 14px;border-radius:6px;text-decoration:none;
  transition:all 0.15s;
}
.nav-links a:hover{background:var(--cream-deep);color:var(--purple-deep)}
.nav-links a.active{color:var(--purple-deep);font-weight:700}
.nav-links a.cta{
  background:var(--ochre);color:#fff;font-weight:700;padding:8px 16px;
  margin-left:8px;
}
.nav-links a.cta:hover{background:#B8862A;color:#fff}

/* Hamburger (mobile) */
.nav-hamburger{
  display:none;background:none;border:0;padding:8px;cursor:pointer;
  color:var(--ink);
}
.nav-hamburger svg{width:24px;height:24px}
@media (max-width:780px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--warm-gray-lt);flex-direction:column;padding:12px 0;align-items:stretch}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 24px;border-radius:0}
  .nav-links a.cta{margin:8px 24px;border-radius:6px;padding:12px}
  .nav-hamburger{display:block}
}

/* ---------- HERO ---------- */
.hero{
  background:linear-gradient(180deg,var(--cream) 0%,var(--cream-warm) 60%,var(--cream-deep) 100%);
  padding:80px 0 60px;border-bottom:1px solid var(--warm-gray-lt);
  position:relative;overflow:hidden;
}
@media (max-width:720px){.hero{padding:56px 0 44px}}
.hero-inner{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media (min-width:900px){.hero-inner{grid-template-columns:1.1fr 1fr;gap:60px}}
.hero h1{margin-bottom:20px}
.hero .lead{font-size:clamp(17px,2.2vw,22px);margin-bottom:28px;max-width:520px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}
.hero-photo{
  border-radius:14px;overflow:hidden;
  box-shadow:0 20px 60px rgba(43,35,25,0.22);
  aspect-ratio:4/5;background:var(--ink);
}
.hero-photo img{width:100%;height:100%;object-fit:cover}

/* ---------- Event countdown strip ---------- */
.countdown-strip{
  background:var(--ink);color:var(--cream);
  padding:14px 0;font-size:13px;
  border-top:3px solid var(--ochre);
}
.countdown-strip .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.countdown-strip .label{font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ochre-soft);font-weight:700}
.countdown-strip .event{font-family:'Fraunces',serif;font-weight:700;font-size:16px}
.countdown-strip .days{font-family:'Fraunces',serif;font-size:22px;color:#fff;font-weight:700}
.countdown-strip a{color:var(--ochre-soft);font-weight:700;border-bottom:1px solid var(--ochre);padding-bottom:2px}
.countdown-strip a:hover{color:#fff}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 24px;border-radius:10px;
  font-size:15px;font-weight:700;letter-spacing:0.01em;
  text-decoration:none;border:0;cursor:pointer;
  transition:all 0.15s;
  font-family:inherit;
}
.btn-primary{background:var(--ochre);color:#fff}
.btn-primary:hover{background:#B8862A;color:#fff;transform:translateY(-1px);box-shadow:0 8px 20px rgba(196,147,45,0.35)}
.btn-secondary{background:var(--ink);color:var(--cream)}
.btn-secondary:hover{background:#1f1913;color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--warm-gray-lt)}
.btn-ghost:hover{background:var(--cream-deep);border-color:var(--warm-gray)}
.btn-purple{background:var(--purple);color:#fff}
.btn-purple:hover{background:var(--purple-deep);color:#fff}

/* ---------- Impact strip ---------- */
.impact{background:var(--ink);color:var(--cream);padding:60px 0}
.impact-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:30px;
  text-align:center;
}
@media (min-width:720px){.impact-grid{grid-template-columns:repeat(4,1fr)}}
.impact-n{
  font-family:'Fraunces',serif;
  font-size:clamp(44px,5vw,64px);font-weight:700;
  color:var(--ochre);line-height:1;
  font-variation-settings:"SOFT" 50,"opsz" 144;
}
.impact-l{
  font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--cream);font-weight:600;margin-top:6px;
}

/* ---------- Kelly's Letter ---------- */
.letter{
  max-width:720px;margin:0 auto;
  padding:60px 0;
}
.letter-mark{margin:0 auto 28px;width:128px;height:128px}
.letter-mark img{width:100%;height:100%;object-fit:contain}
.letter-body{
  font-family:'Fraunces',serif;
  font-size:clamp(17px,1.8vw,20px);
  line-height:1.7;
  color:var(--ink);
}
.letter-body p{margin-bottom:16px}
.letter-sig{
  margin-top:28px;padding-top:22px;border-top:2px solid var(--warm-gray-lt);
}
.letter-sig .name{font-family:'Fraunces',serif;font-weight:700;font-size:18px}
.letter-sig .title{font-size:13px;color:var(--warm-gray)}
.letter-draft-note{
  font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--ochre);font-weight:700;margin-top:14px;
}

/* ---------- Cole card (home teaser) ---------- */
.cole-teaser{
  background:var(--cream-warm);border:1px solid var(--warm-gray-lt);
  border-radius:14px;padding:40px;
  display:grid;grid-template-columns:1fr;gap:24px;align-items:center;
}
@media (min-width:720px){.cole-teaser{grid-template-columns:140px 1fr auto;gap:32px}}
.cole-teaser-mark img{max-width:140px;max-height:140px}
.cole-teaser h3{margin-bottom:8px}
.cole-teaser p{margin:0;color:var(--warm-gray);font-family:'Fraunces',serif;font-style:italic;font-size:16px}

/* ---------- Card grid ---------- */
.card{
  background:#fff;border:1px solid var(--warm-gray-lt);border-radius:14px;
  overflow:hidden;display:flex;flex-direction:column;
}
.card-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-body h3{font-size:22px}
.card-img{aspect-ratio:3/2;overflow:hidden;background:var(--cream-deep)}
.card-img img{width:100%;height:100%;object-fit:cover}

/* ---------- Sunny Day album card ---------- */
.album{
  display:grid;grid-template-columns:1fr;gap:28px;align-items:center;
  background:linear-gradient(135deg,var(--cream-warm) 0%,var(--cream-deep) 100%);
  border-radius:14px;padding:40px;
}
@media (min-width:720px){.album{grid-template-columns:220px 1fr}}
.album-art{max-width:220px}
.album-copy h3{margin-bottom:8px}
.album-copy .meta{font-size:13px;color:var(--warm-gray);margin-bottom:16px}
.album-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.album-links a{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:6px;background:#fff;
  font-size:13px;font-weight:600;color:var(--ink);
  border:1px solid var(--warm-gray-lt);text-decoration:none;
}
.album-links a:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* ---------- Photo strip ---------- */
.photo-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media (min-width:720px){.photo-strip{grid-template-columns:repeat(3,1fr)}}
.photo-strip img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;box-shadow:0 4px 14px rgba(43,35,25,0.12)}

/* ---------- Sponsor wall ---------- */
.sponsor-head{text-align:center;margin-bottom:24px}
.sponsor-head .eyebrow{display:block;margin-bottom:8px}
.sponsor-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
  margin-bottom:24px;
}
@media (min-width:720px){.sponsor-grid{grid-template-columns:repeat(4,1fr)}}
.sponsor-cell{
  background:#fff;border:1px solid var(--warm-gray-lt);border-radius:10px;
  height:100px;display:flex;align-items:center;justify-content:center;padding:16px;
}
.sponsor-cell img{max-height:70px;max-width:100%;object-fit:contain}
.sponsor-cell.empty{
  background:repeating-linear-gradient(45deg,transparent 0,transparent 8px,var(--cream-deep) 8px,var(--cream-deep) 16px);
  color:var(--warm-gray);font-size:12px;font-style:italic;
}
.sponsor-cta{text-align:center}

/* ---------- Section-head (shared) ---------- */
.sh{text-align:center;margin-bottom:48px}
.sh .eyebrow{display:block;margin-bottom:10px}
.sh h2{margin-bottom:14px}
.sh .dek{margin:0 auto}

/* ---------- Mission blocks ---------- */
.mission-grid{
  display:grid;grid-template-columns:1fr;gap:30px;margin-top:40px;
}
@media (min-width:720px){.mission-grid{grid-template-columns:repeat(3,1fr)}}
.mission-block{text-align:center;padding:20px}
.mission-block-icon{width:56px;height:56px;margin:0 auto 14px;color:var(--purple)}
.mission-block h3{font-size:22px;margin-bottom:8px}
.mission-block p{color:var(--warm-gray)}

/* ---------- FOOTER ---------- */
.footer{background:var(--ink);color:var(--cream);padding:60px 0 30px;margin-top:40px}
.footer-grid{
  display:grid;grid-template-columns:1fr;gap:36px;
  padding-bottom:36px;border-bottom:1px solid rgba(244,239,230,0.15);
}
@media (min-width:720px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}}
.footer h4{font-size:13px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ochre);font-weight:700;margin-bottom:14px}
.footer ul{list-style:none;padding:0;margin:0}
.footer ul li{margin-bottom:8px;font-size:14px}
.footer ul li a{color:var(--cream);text-decoration:none;opacity:0.85}
.footer ul li a:hover{color:var(--ochre-soft);opacity:1}
.footer-logo{margin-bottom:18px}
.footer-logo img{height:120px;width:auto;margin-bottom:0;display:block}
@media (max-width:720px){.footer-logo img{height:96px}}
.footer-tagline{font-family:'Fraunces',serif;font-style:italic;font-size:15px;color:var(--ochre-soft);margin-bottom:20px;line-height:1.55}
.footer-meta{padding-top:24px;display:flex;gap:20px;justify-content:space-between;flex-wrap:wrap;font-size:11px;color:var(--warm-gray-lt);letter-spacing:0.04em}
.footer-meta .legal{opacity:0.7}
.footer-meta .legal code{font-family:'JetBrains Mono',monospace;font-size:10px}

/* ---------- Utility ---------- */
.center{text-align:center}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- Tabs (for Get Involved page) ---------- */
.tabs{display:flex;gap:4px;border-bottom:2px solid var(--warm-gray-lt);margin-bottom:32px;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab-btn{
  flex-shrink:0;padding:14px 24px;border:0;background:transparent;
  font-family:inherit;font-size:15px;font-weight:600;color:var(--warm-gray);
  cursor:pointer;border-bottom:3px solid transparent;
  transition:all 0.15s;margin-bottom:-2px;
}
.tab-btn:hover{color:var(--purple-deep)}
.tab-btn.active{color:var(--purple-deep);border-bottom-color:var(--purple)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ---------- Event page specific ---------- */
.event-hero{
  background:linear-gradient(135deg,rgba(122,107,168,0.08) 0%,rgba(196,147,45,0.10) 100%);
  padding:52px 0 44px;position:relative;overflow:hidden;
}
@media (max-width:720px){.event-hero{padding:40px 0 36px}}
.event-hero h1{font-size:clamp(34px,4.8vw,56px);letter-spacing:-0.03em}
.event-hero .lead{font-size:clamp(16px,1.7vw,19px);max-width:560px}
.event-seal-wrap{text-align:center;margin-bottom:22px}
.event-seal-wrap img{max-width:300px;height:auto;margin:0 auto}
@media (max-width:720px){.event-seal-wrap img{max-width:220px}}

/* Paired hero marks: Music Heals wordmark + Nov 6 event seal side-by-side */
.event-hero-marks{
  display:flex;align-items:center;justify-content:center;
  gap:48px;margin:0 auto 28px;flex-wrap:wrap;max-width:100%;
}
.event-hero-marks .event-hero-wordmark{
  width:380px;max-width:42vw;height:auto;display:block;
}
.event-hero-marks .event-hero-seal{
  width:240px;max-width:28vw;height:auto;display:block;
}
@media (max-width:720px){
  .event-hero-marks{flex-direction:column;gap:22px;margin-bottom:22px}
  .event-hero-marks .event-hero-wordmark{width:260px;max-width:72vw}
  .event-hero-marks .event-hero-seal{width:190px;max-width:54vw}
}

/* ---------- Page header (non-home pages) ---------- */
.page-header{padding:60px 0 40px;border-bottom:1px solid var(--warm-gray-lt)}
.page-header .wrap{text-align:center}
.page-header .eyebrow{display:block;margin-bottom:10px}
.page-header h1{margin-bottom:16px;font-size:clamp(36px,5vw,58px)}

/* ---------- Responsive image caption ---------- */
figure{margin:0}
figcaption{font-family:'Fraunces',serif;font-style:italic;font-size:13px;color:var(--warm-gray);margin-top:8px;text-align:center}

/* ---------- Gallery page ---------- */
.gallery-section-head{margin:0 0 28px}
.gallery-section-head .eyebrow{display:block;margin-bottom:8px}
.gallery-section-head h2{font-size:clamp(26px,3.2vw,38px);margin-bottom:8px}
.gallery-section-head .dek{margin:0;max-width:720px}
.gallery-grid{
  display:grid;grid-template-columns:1fr;gap:14px;
}
@media (min-width:640px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media (min-width:960px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:18px}}
.gallery-item{
  position:relative;overflow:hidden;border-radius:12px;
  background:var(--ink);aspect-ratio:4/3;
  box-shadow:0 4px 14px rgba(43,35,25,0.12);
  cursor:zoom-in;
}
.gallery-item.portrait{aspect-ratio:3/4}
.gallery-item.tall{aspect-ratio:2/3}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 0.5s cubic-bezier(0.2,0.7,0.2,1), filter 0.3s;
}
.gallery-item:hover img{transform:scale(1.035);filter:brightness(1.04)}
.gallery-item figcaption{
  position:absolute;inset:auto 0 0 0;
  padding:14px 16px 12px;margin:0;text-align:left;
  background:linear-gradient(180deg,rgba(43,35,25,0) 0%,rgba(43,35,25,0.78) 100%);
  color:var(--cream);font-family:'Fraunces',serif;font-style:italic;font-size:13px;
  opacity:0;transform:translateY(6px);transition:opacity 0.25s, transform 0.25s;
  line-height:1.35;
}
.gallery-item:hover figcaption{opacity:1;transform:translateY(0)}
@media (max-width:720px){
  .gallery-item figcaption{opacity:1;transform:none;font-size:12px;padding:12px 12px 10px}
}
