/* ============================================================
   Harold Washington Cultural Center | shared stylesheet
   Source design: deploy-slim/index.html (approved homepage)
   2026-06-09 revisions per Todd's feedback:
   - Header roundel enlarged 52px -> 78px -> 96px (header bar 84 -> 96 -> 114px)
     per client note "make the header logo bigger"; mobile roundel 68px in an 84px bar
   - Hero scrim strengthened: flat rgba(10,8,6,.58) layer added
     over the existing gradient so headline sits on confident dark
   - Rent/Support image-band overlays deepened for text legibility
   - Footer stays solid near-black (no background image; any future
     footer image must carry a rgba(10,8,6,.6) overlay)
   - .page-hero pattern added for interior pages
   ============================================================ */
:root{
  --dark:#121212;
  --ivory:#FFFFF0;
  --gold:#D99311;
  --gold-deep:#b8790c;
  --crimson:#A62C21;
  --navy:#023E74;
  --ink:#1a1a1a;
  --ivory-muted:#e9e6d6;
  --gray-line:rgba(255,255,255,.16);
  --maxw:1280px;
  --pad:clamp(20px,5vw,72px);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--ivory);
  line-height:1.65;
  font-size:17px;
  overflow-x:clip;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}

/* ---------- Type ---------- */
.cinzel{font-family:'Cinzel',Georgia,'Times New Roman',serif;}
.anton{font-family:'Anton',Impact,sans-serif;font-weight:400;letter-spacing:.01em;}
h1,h2,h3,h4{font-family:'Cinzel',Georgia,serif;font-weight:600;line-height:1.12;text-transform:uppercase;letter-spacing:.04em;}
h2{font-size:clamp(28px,4vw,46px);}
h3{font-size:clamp(21px,2.4vw,28px);}
h4{font-size:clamp(17px,1.6vw,20px);letter-spacing:.06em;}
p{margin:0 0 1em;}
.eyebrow{
  font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.22em;font-size:12.5px;
}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
section{padding:clamp(60px,8vw,110px) 0;}
.section-dark{background:var(--dark);color:var(--ivory);}
.section-ivory{background:var(--ivory);color:var(--ink);}
.gold-rule{width:64px;height:3px;background:var(--gold);border:0;margin:0 0 26px;}
.center .gold-rule{margin-left:auto;margin-right:auto;}
.center{text-align:center;}
.lede{font-size:clamp(17px,1.5vw,19px);max-width:62ch;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-family:'Montserrat',sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:.13em;font-size:13px;
  padding:15px 30px;border:2px solid transparent;cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
  line-height:1;white-space:nowrap;
}
.btn-gold{background:var(--gold);color:#1a1300;border-color:var(--gold);}
.btn-gold:hover{background:var(--gold-deep);border-color:var(--gold-deep);color:#1a1300;}
.btn-ghost{background:transparent;color:var(--ivory);border-color:rgba(255,255,255,.55);}
.btn-ghost:hover{background:var(--ivory);color:var(--ink);border-color:var(--ivory);}
.btn-outline-dark{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-outline-dark:hover{background:var(--ink);color:var(--ivory);}
.btn-crimson{background:var(--crimson);color:#fff;border-color:var(--crimson);}
.btn-crimson:hover{background:#8c241b;border-color:#8c241b;color:#fff;}
.textlink{
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:13px;text-transform:uppercase;
  letter-spacing:.1em;border-bottom:1px solid var(--gold);padding-bottom:3px;display:inline-block;
}
.textlink:hover{color:var(--gold);}

.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--gold);color:#1a1300;
  padding:10px 16px;z-index:2000;font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;
}
.skip-link:focus{left:0;}

/* ================= HEADER ================= */
.site-header{
  position:sticky;top:0;z-index:1000;background:rgba(18,18,18,.96);
  border-bottom:1px solid var(--gray-line);backdrop-filter:saturate(120%) blur(6px);
}
.header-inner{
  max-width:1440px;margin:0 auto;padding:0 clamp(20px,3vw,44px);
  display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:114px;
}
.brand{display:flex;align-items:center;gap:14px;flex-shrink:0;}
.brand img{height:96px;width:auto;}
.brand .brand-word{
  font-family:'Cinzel',serif;color:var(--ivory);text-transform:uppercase;line-height:1.04;
  font-size:13px;letter-spacing:.1em;font-weight:600;max-width:165px;
}
.nav-desktop{display:flex;align-items:center;gap:22px;margin-left:auto;}
.nav-desktop a.navlink{
  font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;font-size:11.5px;color:var(--ivory);padding:6px 0;position:relative;white-space:nowrap;
}
.nav-desktop a.navlink::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .22s ease;
}
.nav-desktop a.navlink:hover::after,.nav-desktop a.navlink:focus::after{transform:scaleX(1);}
.header-actions{display:flex;align-items:center;gap:18px;}
.header-actions .donate{
  font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;font-size:11.5px;color:var(--ivory);opacity:.85;
}
.header-actions .donate:hover{opacity:1;color:var(--gold);}
.btn-sm{padding:12px 22px;font-size:12px;}

/* mobile nav (pure CSS checkbox) */
.nav-toggle{display:none;}
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;
  cursor:pointer;border:1px solid var(--gray-line);flex-shrink:0;
}
.hamburger span{display:block;width:22px;height:2px;background:var(--ivory);margin:0 auto;transition:.25s;}
.mobile-menu{display:none;}

/* ================= HERO (homepage) ================= */
.hero{
  position:relative;min-height:clamp(560px,86vh,860px);display:flex;align-items:flex-end;
  background:#0c0c0c;color:var(--ivory);overflow:hidden;
}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%;}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(rgba(10,8,6,.58),rgba(10,8,6,.58)),
    linear-gradient(180deg,rgba(12,12,12,.50) 0%,rgba(12,12,12,.22) 28%,rgba(12,12,12,.55) 62%,rgba(12,12,12,.88) 88%,rgba(12,12,12,.96) 100%),
    radial-gradient(110% 80% at 18% 100%,rgba(217,147,17,.18) 0%,rgba(217,147,17,0) 55%);
}
.hero-content{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(54px,8vw,92px);}
.hero h1{
  font-size:clamp(40px,7.2vw,92px);line-height:1.02;letter-spacing:.02em;color:#fff;
  text-shadow:0 2px 30px rgba(0,0,0,.55);max-width:16ch;font-weight:700;
}
.hero .hero-sub{
  font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.26em;font-size:12.5px;
  font-weight:700;color:var(--gold);margin-bottom:22px;
  text-shadow:0 1px 14px rgba(0,0,0,.85),0 0 2px rgba(0,0,0,.6);
}
.hero .btn{margin-top:30px;}
.hero-credit{
  position:absolute;right:var(--pad);bottom:14px;z-index:2;
  font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.62);text-transform:uppercase;
}

/* ============ PAGE HERO (interior pages) ============ */
/* Compact dark band: eyebrow (optional) + Cinzel H1 + optional lede.
   Interior pages use this, NOT the full homepage hero. */
.page-hero{background:var(--dark);color:var(--ivory);padding:clamp(64px,9vw,120px) 0 clamp(44px,6vw,72px);border-bottom:2px solid var(--gold);}
.page-hero .eyebrow{color:var(--gold);display:block;margin-bottom:14px;}
.page-hero h1{font-size:clamp(34px,5vw,60px);line-height:1.06;color:#fff;max-width:22ch;}
.page-hero .lede{color:var(--ivory-muted);margin:18px 0 0;}
/* optional image-backed variant: photo sits behind the same dark scrim */
.page-hero.has-img{position:relative;overflow:hidden;}
.page-hero.has-img .ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%;}
.page-hero.has-img .ph-overlay{position:absolute;inset:0;background:linear-gradient(rgba(10,8,6,.72),rgba(10,8,6,.72));}
.page-hero.has-img .wrap{position:relative;z-index:2;}

/* ============ IDENTITY STRIP ============ */
.identity-strip{background:#0d0d0d;color:var(--ivory);text-align:center;padding:24px var(--pad);border-top:2px solid var(--gold);border-bottom:2px solid var(--gold);}
.identity-strip .line1{font-family:'Cinzel',serif;text-transform:uppercase;letter-spacing:.22em;font-size:clamp(12px,1.5vw,15px);font-weight:600;}
.identity-strip .line2{font-family:'Montserrat',sans-serif;font-style:italic;font-size:13px;letter-spacing:.04em;color:var(--ivory-muted);margin-top:8px;opacity:.85;}

/* ============ UPCOMING EVENTS (empty state) ============ */
.events-empty{
  border:1px solid rgba(26,26,26,.16);background:#fffef7;
  text-align:center;padding:clamp(44px,6vw,72px) clamp(24px,5vw,60px);max-width:780px;margin:38px auto 0;
}
.events-empty .badge{
  font-family:'Anton',sans-serif;color:var(--gold);font-size:13px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;
}
.events-empty h3{margin-bottom:14px;}
.events-empty p{color:#4a4a44;max-width:46ch;margin:0 auto 26px;}
.section-head .eyebrow{color:var(--crimson);}

/* ============ BROADWAY IN BRONZEVILLE ============ */
.bib{background:#15110f;color:var(--ivory);position:relative;overflow:hidden;}
.bib-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;}
.bib-figure{position:relative;}
.bib-figure img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 30%;}
.bib-figure .crimson-edge{position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--crimson);}
.bib .eyebrow{color:var(--crimson);background:rgba(166,44,33,.14);display:inline-block;padding:7px 14px;letter-spacing:.18em;}
.bib h2{color:#fff;margin:18px 0 22px;}
.bib .gold-rule{background:var(--crimson);}
.bib p{color:var(--ivory-muted);max-width:56ch;}
.bib .photo-credit{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;margin-top:12px;}

/* ============ LEGACY BAND ============ */
.legacy{background:var(--dark);color:var(--ivory);}
.legacy-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(32px,5vw,68px);align-items:center;}
.legacy-figure img{width:100%;aspect-ratio:5/4;object-fit:cover;object-position:center 45%;}
.legacy h2{color:#fff;}
.legacy p{color:var(--ivory-muted);max-width:60ch;}
.stat-strip{display:flex;flex-wrap:wrap;gap:0;margin:30px 0 30px;border-top:1px solid var(--gray-line);border-bottom:1px solid var(--gray-line);}
.stat-strip .stat{display:flex;align-items:baseline;gap:10px;padding:20px 26px 20px 0;}
.stat-strip .stat:not(:last-child){border-right:1px solid var(--gray-line);margin-right:26px;}
.stat-strip .stat .num{font-family:'Anton',sans-serif;color:var(--gold);font-size:clamp(26px,3vw,38px);line-height:1;}
.stat-strip .stat .lbl{font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--ivory-muted);}
.legacy .photo-credit{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;margin-top:10px;}

/* ============ CARD DUO / CARD GRID ============ */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,44px);}
.card{background:#fffef7;border:1px solid rgba(26,26,26,.1);display:flex;flex-direction:column;}
.card .card-img{position:relative;aspect-ratio:3/2;overflow:hidden;}
.card .card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.card:hover .card-img img{transform:scale(1.04);}
.card .card-credit{position:absolute;right:10px;bottom:8px;font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:.06em;color:#fff;text-transform:uppercase;background:rgba(0,0,0,.45);padding:3px 8px;}
.card .card-body{padding:clamp(26px,3vw,40px);display:flex;flex-direction:column;flex:1;}
.card .card-body .gold-rule{margin-bottom:18px;}
.card h3{margin-bottom:14px;}
.card p{color:#4a4a44;flex:1;}
.card .btn{margin-top:22px;align-self:flex-start;}

/* ============ RENT THE CENTER (image band) ============ */
.rent{position:relative;color:var(--ivory);background:#101010;overflow:hidden;}
.rent-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 50%;opacity:.34;}
.rent-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(16,16,16,.95) 0%,rgba(16,16,16,.80) 55%,rgba(16,16,16,.64) 100%);}
.rent-inner{position:relative;z-index:2;max-width:760px;}
.rent h2{color:#fff;}
.rent .capacity{font-family:'Cinzel',serif;font-size:clamp(19px,2.1vw,25px);line-height:1.4;color:var(--ivory);text-transform:none;letter-spacing:.01em;margin-bottom:20px;font-weight:500;}
.rent p{color:var(--ivory-muted);}

/* ============ PLAN YOUR VISIT ============ */
.visit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,40px);margin-top:44px;}
.visit-card{background:#fffef7;border:1px solid rgba(26,26,26,.1);padding:clamp(26px,3vw,38px);}
.visit-card .vnum{font-family:'Anton',sans-serif;color:var(--gold);font-size:30px;line-height:1;margin-bottom:14px;}
.visit-card h4{margin-bottom:12px;}
.visit-card p{color:#4a4a44;font-size:15.5px;}
.visit-card .textlink{margin-top:6px;}
.visit-cta{margin-top:44px;text-align:center;}

/* ============ SUPPORT BAND (image band) ============ */
.support{position:relative;color:var(--ivory);background:#101010;overflow:hidden;}
.support-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%;opacity:.30;}
.support-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,16,16,.92) 0%,rgba(16,16,16,.80) 50%,rgba(16,16,16,.93) 100%),radial-gradient(120% 100% at 80% 0%,rgba(217,147,17,.14),rgba(217,147,17,0) 60%);}
.support-inner{position:relative;z-index:2;max-width:680px;}
.support h2{color:#fff;}
.support p{color:var(--ivory-muted);}
.support .btn{margin-right:18px;}
.support .support-actions{display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin-top:10px;}
.support .photo-credit{position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;}

/* ============ FIRST ROW ============ */
.firstrow{background:var(--ivory);text-align:center;border-top:3px solid var(--gold);}
.firstrow .eyebrow{color:var(--gold-deep);}
.firstrow h2{margin:14px 0 12px;}
.firstrow .subhead{font-family:'Cinzel',serif;text-transform:none;font-size:clamp(17px,1.8vw,21px);color:#3a3a34;margin-bottom:10px;letter-spacing:.01em;}
.firstrow p.lede{margin:0 auto 30px;color:#4a4a44;}
.firstrow-form{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:640px;margin:0 auto;}
.firstrow-form .field{flex:1;min-width:180px;text-align:left;}
.firstrow-form label{display:block;font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:#5a5a52;margin-bottom:6px;}
.firstrow-form input{
  width:100%;padding:14px 16px;border:1px solid #cfc8b0;background:#fff;font-family:'Montserrat',sans-serif;font-size:15px;color:var(--ink);
}
.firstrow-form input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
.firstrow-form .submit-wrap{display:flex;align-items:flex-end;}
.firstrow-form .btn{height:48px;padding-top:0;padding-bottom:0;}
.firstrow .microcopy{font-size:12.5px;color:#7a7468;margin-top:18px;letter-spacing:.02em;}

/* ============ FOOTER ============ */
/* Footer sits on clean, solid near-black (no background image).
   If a background image or texture is ever added, it MUST carry a
   full-bleed dark overlay: linear-gradient(rgba(10,8,6,.6),rgba(10,8,6,.6)). */
.site-footer{background:var(--dark);color:var(--ivory);padding-top:clamp(56px,7vw,84px);}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.1fr;gap:clamp(24px,3vw,44px);}
.footer-identity img{height:96px;width:auto;margin-bottom:20px;}
.footer-identity .id-line{font-family:'Cinzel',serif;font-size:14px;line-height:1.5;color:var(--ivory-muted);text-transform:none;letter-spacing:.01em;max-width:34ch;margin-bottom:20px;}
.footer-identity .contact{font-family:'Montserrat',sans-serif;font-size:14px;color:var(--ivory-muted);line-height:1.7;}
.footer-col h4{font-family:'Montserrat',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:var(--gold);margin-bottom:18px;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:11px;}
.footer-col a{font-size:14.5px;color:var(--ivory-muted);}
.footer-col a:hover{color:#fff;}
.footer-signup .mini-line{font-size:13px;color:var(--ivory-muted);margin:14px 0 12px;line-height:1.5;}
.footer-signup form{display:flex;flex-direction:column;gap:10px;}
.footer-signup input{padding:12px 14px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.04);color:var(--ivory);font-family:'Montserrat',sans-serif;font-size:14px;}
.footer-signup input::placeholder{color:rgba(255,255,255,.45);}
.footer-signup input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
.footer-signup .btn{text-align:center;}
.social-row{display:flex;gap:14px;margin-top:46px;padding-top:26px;border-top:1px solid var(--gray-line);align-items:center;}
.social-row a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--gray-line);color:var(--ivory-muted);transition:.2s;}
.social-row a:hover{border-color:var(--gold);color:var(--gold);}
.social-row svg{width:18px;height:18px;fill:currentColor;}
.legal-bar{margin-top:30px;padding:24px 0 40px;border-top:1px solid var(--gray-line);display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;justify-content:space-between;}
.legal-bar .copyright{font-size:12.5px;color:rgba(255,255,255,.5);}
.legal-bar .legal-links{display:flex;flex-wrap:wrap;gap:8px 18px;}
.legal-bar a{font-size:12.5px;color:rgba(255,255,255,.55);}
.legal-bar a:hover{color:var(--gold);}
.legal-bar .sep{color:rgba(255,255,255,.3);}

/* ============ RESPONSIVE ============ */
@media (max-width:1320px){
  .brand .brand-word{display:none;}
  .nav-desktop{gap:18px;}
  .nav-desktop a.navlink{font-size:10.5px;letter-spacing:.06em;}
}
@media (max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr 1fr;gap:34px;}
  .footer-identity{grid-column:1 / -1;}
  .footer-signup{grid-column:1 / -1;max-width:420px;}
}
@media (max-width:1080px){
  .nav-desktop,.header-actions .donate{display:none;}
  .hamburger{display:flex;}
  .header-actions{gap:12px;}
  /* touch targets: header button to 44px min on mobile */
  .header-actions .btn-sm{padding:14px 22px;min-height:44px;display:inline-flex;align-items:center;}
  .bib-grid,.legacy-grid{grid-template-columns:1fr;gap:34px;}
  .bib-figure{order:-1;}
  .legacy-figure{order:-1;}
  .duo{grid-template-columns:1fr;}
  .visit-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
  /* keep hero text legible regardless of crop on small screens */
  .hero-content{position:relative;}
  .hero-content::before{
    content:"";position:absolute;left:calc(var(--pad) * -1);right:calc(var(--pad) * -1);
    top:-26px;bottom:-26px;z-index:-1;
    background:linear-gradient(90deg,rgba(10,10,10,.78) 0%,rgba(10,10,10,.58) 70%,rgba(10,10,10,0) 100%);
  }

  /* mobile menu reveal */
  .nav-toggle:checked ~ .mobile-menu{display:block;}
  .mobile-menu{
    position:fixed;top:114px;left:0;right:0;bottom:0;background:#0f0f0f;z-index:999;
    padding:30px var(--pad) 60px;overflow-y:auto;
  }
  .mobile-menu a{
    display:block;font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;
    letter-spacing:.1em;font-size:15px;color:var(--ivory);padding:18px 0;border-bottom:1px solid var(--gray-line);
  }
  .mobile-menu a:hover{color:var(--gold);}
  .mobile-menu .mobile-cta{margin-top:26px;display:flex;flex-direction:column;gap:14px;}
  .mobile-menu .mobile-cta .btn{text-align:center;}
  .nav-toggle:checked ~ .site-header .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle:checked ~ .site-header .hamburger span:nth-child(2){opacity:0;}
  .nav-toggle:checked ~ .site-header .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
}
@media (max-width:560px){
  body{font-size:16px;}
  .brand .brand-word{display:none;}
  .header-inner{min-height:84px;}
  .brand img{height:68px;}
  .mobile-menu{top:84px;}
  .footer-top{grid-template-columns:1fr;}
  .footer-col{margin-bottom:6px;}
  .stat-strip{flex-direction:column;align-items:flex-start;}
  .stat-strip .stat{border-right:0 !important;margin-right:0 !important;padding:14px 0;width:100%;border-bottom:1px solid var(--gray-line);}
  .stat-strip .stat:last-child{border-bottom:0;}
  .firstrow-form{flex-direction:column;}
  .firstrow-form .submit-wrap .btn{width:100%;}
  .support .support-actions{flex-direction:column;align-items:flex-start;}
  .legal-bar{flex-direction:column;align-items:flex-start;}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none !important;scroll-behavior:auto !important;}
  .card:hover .card-img img{transform:none;}
}

/* ============================================================
   page: arts-partners
   Page-specific classes only. Appended per build rules;
   no existing rules above were modified.
   ============================================================ */
/* Featured partner (M.A.D.D. Rhythms): largest block, text + figure grid on ivory */
.partner-feature{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;}
.partner-feature .eyebrow{color:var(--gold-deep);display:block;margin-bottom:14px;}
.partner-feature h2{margin-bottom:20px;}
.partner-feature .gold-rule{margin-bottom:22px;}
.partner-feature p{color:#4a4a44;max-width:56ch;}
.partner-feature .btn{margin-top:14px;}
.pf-figure{position:relative;}
.pf-figure img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 32%;}
.pf-credit{
  position:absolute;right:10px;bottom:8px;font-family:'Montserrat',sans-serif;font-size:10px;
  letter-spacing:.06em;color:#fff;text-transform:uppercase;background:rgba(0,0,0,.45);padding:3px 8px;
}
/* Resident partner card row beneath the featured block */
.partner-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,40px);
  margin-top:clamp(48px,7vw,84px);padding-top:clamp(40px,5vw,64px);border-top:1px solid rgba(26,26,26,.14);
}
.partner-card{background:#fffef7;border:1px solid rgba(26,26,26,.1);padding:clamp(26px,3vw,38px);display:flex;flex-direction:column;}
.partner-card .gold-rule{margin-bottom:18px;}
.partner-card h3{margin-bottom:12px;}
.partner-card p{color:#4a4a44;font-size:15.5px;margin:0;}
/* Become an Arts Partner band: image-backed dark band per .rent/.support pattern */
.become-partner{position:relative;color:var(--ivory);background:#101010;overflow:hidden;border-bottom:2px solid var(--gold);}
.bp-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 35%;opacity:.38;}
.bp-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(16,16,16,.90) 0%,rgba(16,16,16,.76) 50%,rgba(16,16,16,.92) 100%),
    radial-gradient(120% 100% at 50% 0%,rgba(217,147,17,.12),rgba(217,147,17,0) 60%);
}
.become-partner .wrap{position:relative;z-index:2;}
.bp-inner{max-width:680px;margin:0 auto;}
.become-partner h2{color:#fff;}
.become-partner p{color:var(--ivory-muted);margin-left:auto;margin-right:auto;}
.bp-contact{
  font-family:'Cinzel',serif;font-size:clamp(17px,1.9vw,22px);letter-spacing:.04em;
  color:var(--ivory);line-height:1.7;margin:6px auto 30px;
}
.become-partner .photo-credit{
  position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;
  font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;
}
@media (max-width:1080px){
  .partner-feature{grid-template-columns:1fr;gap:34px;}
  .pf-figure{order:-1;}
  .partner-row{grid-template-columns:1fr;}
}

/* ============================================================
   page: events
   Page-specific classes for /events/ only. Appended per build
   rules; no existing rules above were modified.
   ============================================================ */
/* Group Sales image band (reuses the .rent/.support pattern:
   low-opacity photo + dark overlay + z-indexed inner content) */
.group-sales{position:relative;color:var(--ivory);background:#101010;overflow:hidden;}
.group-sales .gs-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:.32;}
.group-sales .gs-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(16,16,16,.95) 0%,rgba(16,16,16,.82) 55%,rgba(16,16,16,.66) 100%);}
.group-sales .gs-inner{position:relative;z-index:2;max-width:680px;}
.group-sales h2{color:#fff;}
.group-sales p{color:var(--ivory-muted);}
.group-sales .gs-note{font-size:15.5px;margin-bottom:30px;}
.group-sales .photo-credit{position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;}

/* Plan Your Visit cross-link card (Before the Show) */
.crosslink-card{display:grid;grid-template-columns:1fr 1.1fr;background:#fffef7;border:1px solid rgba(26,26,26,.12);overflow:hidden;}
.crosslink-card .cl-img{position:relative;min-height:320px;}
.crosslink-card .cl-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 38%;}
.crosslink-card .cl-body{padding:clamp(30px,4.5vw,60px);display:flex;flex-direction:column;align-items:flex-start;justify-content:center;}
.crosslink-card .cl-body p{color:#4a4a44;max-width:56ch;}
.crosslink-card .cl-body .btn{margin-top:12px;}
@media (max-width:1080px){
  .crosslink-card{grid-template-columns:1fr;}
  .crosslink-card .cl-img{min-height:240px;}
}

/* First Row capture strip, dark band variant (per events page spec) */
.events-firstrow{background:var(--dark);color:var(--ivory);text-align:center;border-top:3px solid var(--gold);border-bottom:1px solid var(--gray-line);}
.events-firstrow .eyebrow{color:var(--gold);display:block;margin-bottom:14px;}
.events-firstrow .gold-rule{margin-left:auto;margin-right:auto;}
.events-firstrow h2{color:#fff;margin-bottom:12px;}
.events-firstrow .lede{color:var(--ivory-muted);margin:0 auto 32px;}
.events-firstrow .fr-form{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:560px;margin:0 auto;}
.events-firstrow .fr-form input{flex:1;min-width:220px;padding:14px 16px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.05);color:var(--ivory);font-family:'Montserrat',sans-serif;font-size:15px;}
.events-firstrow .fr-form input::placeholder{color:rgba(255,255,255,.45);}
.events-firstrow .fr-form input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
@media (max-width:560px){
  .events-firstrow .fr-form{flex-direction:column;}
  .events-firstrow .fr-form .btn{width:100%;}
}

/* ============================================================
   page: accessibility
   Appended 2026-06-09. By-need editorial rows, accommodation
   request card, closing CTA image band. APPEND-ONLY block; do
   not modify shared rules above.
   ============================================================ */
.acc-needs .needs-head{max-width:760px;margin:0 auto;}
.acc-needs .needs-head h2{margin-bottom:18px;}
.acc-needs .needs-head p{color:#4a4a44;font-size:clamp(17px,1.5vw,19px);max-width:62ch;margin-left:auto;margin-right:auto;}
.need-list{max-width:1080px;margin:clamp(40px,5.5vw,64px) auto 0;border-top:1px solid rgba(26,26,26,.16);}
.need-row{display:grid;grid-template-columns:minmax(200px,.85fr) 2fr;gap:clamp(18px,4vw,64px);padding:clamp(32px,4.5vw,52px) 0;border-bottom:1px solid rgba(26,26,26,.16);}
.need-row h2{font-size:clamp(20px,2.2vw,26px);line-height:1.22;}
.need-rule{width:44px;height:3px;background:var(--gold);border:0;margin:14px 0 0;}
.need-copy p{font-size:clamp(17px,1.45vw,18.5px);color:#3a3a34;max-width:60ch;line-height:1.72;}
.need-copy p:last-child{margin-bottom:0;}
@media (max-width:760px){
  .need-row{grid-template-columns:1fr;gap:16px;}
}
/* accommodation request card (dark band) */
.acc-request h2{color:#fff;}
.request-card{background:#181818;border:1px solid var(--gray-line);border-top:3px solid var(--gold);max-width:860px;margin:44px auto 0;padding:clamp(36px,5vw,60px) clamp(24px,4vw,60px);text-align:center;}
.req-label{display:block;font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:var(--ivory-muted);margin-bottom:12px;}
.req-phone{font-family:'Anton',Impact,sans-serif;font-size:clamp(36px,5.5vw,58px);line-height:1;color:var(--gold);letter-spacing:.02em;display:inline-block;}
.req-phone:hover,.req-phone:focus{color:var(--gold-deep);}
.req-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,40px);margin-top:36px;padding-top:32px;border-top:1px solid var(--gray-line);}
/* with the email item removed until a verified inbox exists, a lone item centers */
.req-split .req-item:only-child{grid-column:1 / -1;}
.req-value{font-family:'Montserrat',sans-serif;font-size:16px;color:var(--ivory);line-height:1.6;}
.request-note{max-width:56ch;margin:32px auto;text-align:center;color:var(--ivory-muted);font-size:clamp(16px,1.4vw,18px);}
@media (max-width:640px){
  .req-split{grid-template-columns:1fr;}
}
/* this website (ivory band) */
.acc-website-inner{max-width:760px;}
.acc-website-inner p{font-size:clamp(17px,1.45vw,18.5px);color:#3a3a34;max-width:60ch;line-height:1.72;}
.acc-website-inner p:last-child{margin-bottom:0;}
.acc-website-inner h2{margin-bottom:18px;}
/* closing CTA image band (rent/support overlay pattern) */
.acc-cta{position:relative;color:var(--ivory);background:#101010;overflow:hidden;border-bottom:2px solid var(--gold);}
.acc-cta-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 45%;opacity:.32;}
.acc-cta-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,16,16,.92) 0%,rgba(16,16,16,.78) 50%,rgba(16,16,16,.93) 100%);}
.acc-cta-inner{position:relative;z-index:2;}
.acc-cta h2{color:#fff;max-width:26ch;margin:0 auto;}
.acc-cta-actions{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-top:36px;}
.acc-cta .photo-credit{position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;}
@media (max-width:560px){
  .acc-cta-actions{flex-direction:column;align-items:center;}
}

/* ============================================================
   page: plan-your-visit
   Page-specific classes only (appended 2026-06-09).
   Do not modify shared rules above this block.
   ============================================================ */

/* Getting Here */
.gh-grid{display:grid;grid-template-columns:.95fr 1.35fr;gap:clamp(28px,4vw,60px);margin-top:42px;align-items:start;}
.gh-address{background:#fffef7;border:1px solid rgba(26,26,26,.14);padding:clamp(28px,3.2vw,44px);}
.gh-address .gh-label{font-family:'Montserrat',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:12px;color:var(--gold-deep);display:block;margin-bottom:14px;}
.gh-address address{font-style:normal;font-family:'Cinzel',Georgia,serif;font-size:clamp(18px,1.9vw,23px);line-height:1.55;color:var(--ink);margin-bottom:10px;}
.gh-address .gh-alt{font-size:14px;color:#6a6458;margin-bottom:26px;max-width:34ch;}
.travel-item{padding:22px 0;border-top:1px solid rgba(26,26,26,.14);}
.travel-item:first-child{padding-top:6px;border-top:0;}
.travel-item:last-child{padding-bottom:0;}
.travel-item h3{font-size:clamp(15px,1.5vw,17px);letter-spacing:.08em;display:flex;align-items:center;gap:14px;margin-bottom:8px;}
.travel-item h3::before{content:"";width:20px;height:3px;background:var(--gold);flex-shrink:0;}
.travel-item p{margin:0;color:#4a4a44;font-size:15.5px;max-width:62ch;}

/* Box Office band */
.box-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;}
.pyv-box h2{color:#fff;}
.pyv-box p{color:var(--ivory-muted);max-width:54ch;}
.pyv-box .btn{margin-top:10px;}
.box-hours{border:1px solid var(--gray-line);padding:clamp(26px,3vw,40px);}
.box-hours .bh-label{font-family:'Montserrat',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:12px;color:var(--gold);display:block;margin-bottom:12px;}
.box-hours .bh-line{font-family:'Cinzel',Georgia,serif;font-size:clamp(17px,1.8vw,21px);line-height:1.5;color:var(--ivory);margin:0;}

/* What to Expect */
.expect .visit-grid{margin-top:42px;}
.expect .visit-card h3{font-size:clamp(17px,1.8vw,21px);letter-spacing:.05em;margin-bottom:12px;}
.expect-figure{margin-top:clamp(30px,4vw,52px);}
.expect-figure img{width:100%;aspect-ratio:21/9;object-fit:cover;object-position:center 60%;}

/* Accessibility summary band */
.pyv-access h2{color:#fff;}
.pyv-access p{color:var(--ivory-muted);max-width:62ch;}
.pyv-access .btn{margin-top:8px;}

/* FAQ accordion (CSS-only details/summary) */
.faq-list{max-width:880px;margin:38px auto 0;}
.faq-item{background:#fffef7;border:1px solid rgba(26,26,26,.14);margin-bottom:14px;}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:20px;cursor:pointer;padding:20px clamp(20px,2.6vw,28px);list-style:none;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary h3{font-size:clamp(15.5px,1.6vw,19px);letter-spacing:.05em;line-height:1.3;margin:0;text-align:left;}
.faq-item summary .faq-mark{font-family:'Anton',Impact,sans-serif;color:var(--gold);font-size:24px;line-height:1;flex-shrink:0;transition:transform .25s ease;}
.faq-item[open] summary .faq-mark{transform:rotate(45deg);}
.faq-item summary:hover h3{color:var(--gold-deep);}
.faq-item summary:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.faq-item .faq-body{padding:0 clamp(20px,2.6vw,28px) 24px;}
.faq-item .faq-body p{margin:0;color:#4a4a44;max-width:72ch;}

/* Closing CTA image band (per .rent/.support image-band pattern) */
.pyv-close{position:relative;color:var(--ivory);background:#101010;overflow:hidden;}
.pyv-close-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 45%;opacity:.32;}
.pyv-close-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,16,16,.93) 0%,rgba(16,16,16,.78) 50%,rgba(16,16,16,.94) 100%);}
.pyv-close-inner{position:relative;z-index:2;max-width:720px;}
.pyv-close h2{color:#fff;}
.pyv-close p{color:var(--ivory-muted);}
.pyv-close .pyv-close-actions{display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin-top:10px;}

@media (max-width:1080px){
  .gh-grid{grid-template-columns:1fr;}
  .box-grid{grid-template-columns:1fr;gap:30px;}
}
@media (max-width:560px){
  .pyv-close .pyv-close-actions{flex-direction:column;align-items:flex-start;}
  .expect-figure img{aspect-ratio:4/3;}
}

/* ============================================================
   page: support  (/support/)
   Page-specific classes only. Nothing above this block is modified.
   ============================================================ */

/* hero: gold rule under the H1, CTA row, photo credit */
.support-hero .gold-rule{margin:26px 0 0;}
.support-hero .lede{max-width:66ch;}
.support-hero .hero-actions{display:flex;flex-wrap:wrap;align-items:center;gap:16px 28px;margin-top:34px;}
.support-hero .hero-alt{font-family:'Montserrat',sans-serif;font-size:15px;color:var(--ivory-muted);margin:0;}
.support-hero .hero-alt a{border-bottom:1px solid var(--gold);padding-bottom:2px;font-weight:600;white-space:nowrap;}
.support-hero .hero-alt a:hover{color:var(--gold);}
.support-hero .ph-credit{position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.55);text-transform:uppercase;}

/* ways to give: 2x2 grid of text cards (no card images) */
.give-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,44px);margin-top:48px;}

/* sponsorship and partnership inquiry */
.inquiry{border-top:1px solid rgba(26,26,26,.12);}
.inquiry-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(32px,5vw,64px);align-items:start;}
.inquiry-intro p{color:#4a4a44;max-width:46ch;margin-top:16px;}
.inquiry-intro a{border-bottom:1px solid var(--gold);padding-bottom:2px;font-weight:600;white-space:nowrap;}
.inquiry-intro a:hover{color:var(--gold-deep);}
.inquiry-panel{background:#fffef7;border:1px solid rgba(26,26,26,.12);padding:clamp(26px,3.4vw,44px);}
.inquiry-form{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px;}
.inquiry-form .field{display:flex;flex-direction:column;}
.inquiry-form .field.full{grid-column:1 / -1;}
.inquiry-form label{font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:#5a5a52;margin-bottom:7px;}
.inquiry-form .req{color:var(--gold-deep);}
.inquiry-form input,.inquiry-form select,.inquiry-form textarea{width:100%;padding:13px 14px;border:1px solid #cfc8b0;background:#fff;font-family:'Montserrat',sans-serif;font-size:15px;color:var(--ink);}
.inquiry-form textarea{min-height:132px;resize:vertical;}
.inquiry-form input:focus,.inquiry-form select:focus,.inquiry-form textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
.inquiry-form .btn{grid-column:1 / -1;justify-self:start;margin-top:8px;}

/* first row capture, dark variant for this page (band above footer) */
.firstrow-dark{background:#0d0d0d;color:var(--ivory);text-align:center;border-top:3px solid var(--gold);border-bottom:1px solid var(--gray-line);}
.firstrow-dark h2{color:#fff;}
.firstrow-dark .lede{margin:14px auto 30px;color:var(--ivory-muted);}
.firstrow-dark .firstrow-form label{color:var(--ivory-muted);}
.firstrow-dark .firstrow-form input{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.25);color:var(--ivory);}
.firstrow-dark .firstrow-form input::placeholder{color:rgba(255,255,255,.45);}
.firstrow-dark .firstrow-form input:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}

@media (max-width:1080px){
  .give-grid{grid-template-columns:1fr;}
  .inquiry-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .inquiry-form{grid-template-columns:1fr;}
  .support-hero .hero-actions{flex-direction:column;align-items:flex-start;}
}
/* ============ end page: support ============ */

/* ============================================================
   page: membership  (Heritage in Harmony, HIDDEN at launch)
   Appended 2026-06-09. Page-specific classes only. Do not edit
   any shared rules above this block.
   ============================================================ */
/* hero refinements, scoped to .ph-membership so other interior
   pages are untouched */
.ph-membership .gold-rule{margin:24px 0 18px;}
.ph-membership .ph-subhead{
  font-family:'Cinzel',Georgia,serif;font-weight:500;text-transform:uppercase;
  letter-spacing:.16em;font-size:clamp(15px,1.7vw,20px);color:var(--ivory);margin:0;
}
.ph-membership .lede{margin-top:16px;max-width:68ch;}

/* tier cards (Membership Levels) */
.tier-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,28px);margin-top:48px;}
.tier-card{
  background:#fffef7;border:1px solid rgba(26,26,26,.1);color:var(--ink);
  padding:clamp(26px,2.6vw,36px) clamp(20px,2vw,28px);
  display:flex;flex-direction:column;text-align:left;
}
.tier-card .gold-rule{width:44px;margin:0 0 16px;}
.tier-card h3{font-size:clamp(19px,1.5vw,22px);margin-bottom:2px;}
@media (min-width:1101px){
  .tier-card h3{min-height:2.3em;} /* reserves two title lines so prices align across the row */
}
.tier-card .tier-price{font-family:'Anton',Impact,sans-serif;color:var(--gold);font-size:clamp(36px,3.2vw,46px);line-height:1;margin:16px 0 10px;}
.tier-card .tier-avail{
  font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.14em;font-size:11px;color:#5a5a52;margin:0 0 12px;
}
.tier-card .tier-copy{color:#4a4a44;font-size:15.5px;flex:1;margin-bottom:0;}
.tier-card .btn{
  margin-top:24px;width:100%;text-align:center;white-space:normal;line-height:1.45;
  padding:12px 14px;font-size:12px;letter-spacing:.11em;
}

/* how to join (interest form) */
.join-section{border-top:3px solid var(--gold);}
.join-form{display:grid;grid-template-columns:1fr 1fr;gap:20px 24px;max-width:860px;margin:38px auto 0;text-align:left;}
.join-form .field-full{grid-column:1 / -1;}
.join-form label{
  display:block;font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;font-size:11px;color:#5a5a52;margin-bottom:6px;
}
.join-form label .req-note{font-weight:500;text-transform:none;letter-spacing:.02em;color:#8a8478;}
.join-form input,.join-form select,.join-form textarea{
  width:100%;padding:14px 16px;border:1px solid #cfc8b0;background:#fff;border-radius:0;
  font-family:'Montserrat',sans-serif;font-size:15px;color:var(--ink);
}
.join-form textarea{min-height:150px;resize:vertical;}
.join-form input:focus,.join-form select:focus,.join-form textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
.join-form .join-submit{grid-column:1 / -1;display:flex;justify-content:center;margin-top:6px;}

@media (max-width:1100px){
  .tier-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:640px){
  .tier-grid{grid-template-columns:1fr;}
  .join-form{grid-template-columns:1fr;}
  .join-form .join-submit .btn{width:100%;}
}

/* ============================================================
   page: venue-rentals
   Page-specific classes only (vr- prefix). Appended 2026-06-09.
   Never modifies shared rules above.
   ============================================================ */
/* hero CTA inside the compact page-hero */
.vr-hero .btn{margin-top:30px;}
.vr-hero .hero-call{margin:18px 0 0;font-size:14px;color:var(--ivory-muted);}
.vr-hero .hero-call a{border-bottom:1px solid var(--gold);padding-bottom:2px;}
.vr-hero .hero-call a:hover{color:var(--gold);}

/* space cards: capacity line, Anton numerals */
.vr-cap{display:flex;align-items:baseline;gap:9px;margin-bottom:16px;}
.vr-cap .cap-num{font-family:'Anton',Impact,sans-serif;font-weight:400;color:var(--gold);font-size:clamp(28px,2.6vw,36px);line-height:1;letter-spacing:.01em;}
.vr-cap .cap-lbl{font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:11.5px;color:#5a5a52;}
.vr-card-flat{border-top:4px solid var(--gold);}

/* What You Can Host: dark image band (rent/support overlay pattern) */
.vr-host{position:relative;color:var(--ivory);background:#101010;overflow:hidden;}
.vr-host-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:.30;}
.vr-host-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,16,16,.93) 0%,rgba(16,16,16,.78) 50%,rgba(16,16,16,.93) 100%),radial-gradient(120% 100% at 15% 0%,rgba(217,147,17,.12),rgba(217,147,17,0) 55%);}
.vr-host .wrap{position:relative;z-index:2;}
.vr-host h2{color:#fff;}
.vr-host-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,40px);margin-top:48px;}
.vr-host-item .gold-rule{margin-bottom:16px;}
.vr-host-item h3{color:#fff;font-size:clamp(17px,1.5vw,20px);margin-bottom:12px;}
.vr-host-item p{color:var(--ivory-muted);font-size:15px;margin:0;}
.vr-host .photo-credit{position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;}

/* Good to Know strip */
.vr-know{padding:clamp(52px,7vw,90px) 0;}
.vr-know-list{list-style:none;max-width:860px;margin:30px 0 36px;}
.vr-know-list li{padding:15px 0;border-bottom:1px solid rgba(26,26,26,.12);color:#4a4a44;font-size:16px;}
.vr-know-list li:first-child{border-top:1px solid rgba(26,26,26,.12);}
.vr-know-list strong{color:var(--ink);}

/* How It Works steps (reuses .visit-grid / .visit-card) */
.vr-steps{border-top:1px solid rgba(26,26,26,.1);}
.vr-steps .visit-card h3{font-size:clamp(18px,1.9vw,23px);margin-bottom:12px;}
.vr-steps .visit-card .vnum{font-size:38px;}

/* Inquiry form: dark band, single column */
.vr-inquiry .form-head{max-width:720px;margin:0 auto;text-align:center;}
.vr-inquiry .form-head .gold-rule{margin-left:auto;margin-right:auto;}
.vr-inquiry .form-head h2{color:#fff;}
.vr-inquiry .form-head p{color:var(--ivory-muted);margin:16px auto 0;max-width:54ch;}
.vr-inquiry .form-head a{border-bottom:1px solid var(--gold);padding-bottom:2px;}
.vr-inquiry .form-head a:hover{color:var(--gold);}
.vr-form{max-width:720px;margin:42px auto 0;display:flex;flex-direction:column;gap:24px;color-scheme:dark;}
.vr-form label{display:block;font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:11.5px;color:var(--ivory-muted);margin-bottom:8px;}
.vr-form .req{color:var(--gold);}
.vr-form input,.vr-form select,.vr-form textarea{width:100%;padding:14px 16px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.05);color:var(--ivory);font-family:'Montserrat',sans-serif;font-size:15px;}
.vr-form input::placeholder,.vr-form textarea::placeholder{color:rgba(255,255,255,.42);}
.vr-form input:focus,.vr-form select:focus,.vr-form textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
.vr-form select option{color:var(--ink);background:#fff;}
.vr-form textarea{min-height:150px;resize:vertical;line-height:1.6;}
.vr-form .helper{font-size:12.5px;color:rgba(255,255,255,.55);margin:7px 0 0;}
.vr-form .btn{align-self:flex-start;margin-top:6px;}

/* closing CTA band */
.vr-close{position:relative;color:var(--ivory);background:#101010;overflow:hidden;text-align:center;}
.vr-close-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 60%;opacity:.30;}
.vr-close-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,16,16,.92) 0%,rgba(16,16,16,.82) 50%,rgba(16,16,16,.94) 100%),radial-gradient(120% 100% at 50% 100%,rgba(217,147,17,.14),rgba(217,147,17,0) 60%);}
.vr-close-inner{position:relative;z-index:2;max-width:780px;margin:0 auto;}
.vr-close-inner h2{color:#fff;}
.vr-close-inner .lede{margin:18px auto 0;color:var(--ivory-muted);}
.vr-close-actions{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-top:30px;}
.vr-close-call{font-size:14px;color:var(--ivory-muted);margin:26px 0 0;}
.vr-close-call a{border-bottom:1px solid var(--gold);padding-bottom:2px;}
.vr-close-call a:hover{color:var(--gold);}
.vr-close-addr{font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin:12px 0 0;}

@media (max-width:1080px){
  .vr-host-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:560px){
  .vr-host-grid{grid-template-columns:1fr;}
  .vr-form .btn{width:100%;text-align:center;}
  .vr-close-actions{flex-direction:column;align-items:center;}
}

/* ============================================================
   page: our-story
   Page-specific classes only. Appended 2026-06-09.
   Do not modify shared rules above this block.
   ============================================================ */
.page-hero .story-intro{color:var(--ivory-muted);max-width:66ch;margin:22px 0 0;font-size:16px;line-height:1.7;}

/* two-column story sections (ivory bands) */
.story-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;}
.story-grid.flip{grid-template-columns:1fr 1.05fr;}
.story-figure img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.story-figure .photo-credit{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:#8a8478;text-transform:uppercase;margin-top:10px;}
.story-text p{color:#3a3a34;max-width:60ch;}
.duotone{filter:grayscale(1) sepia(.5) saturate(1.35) brightness(.92) contrast(1.05);}

/* narrow centered copy (Harold Washington band) */
.narrow{max-width:62ch;margin-left:auto;margin-right:auto;}

/* building facts stat band (ivory variant of the stat strip) */
.facts-band{display:flex;flex-wrap:wrap;border-top:1px solid rgba(26,26,26,.16);border-bottom:1px solid rgba(26,26,26,.16);margin:36px 0 40px;}
.facts-band .fact{display:flex;align-items:baseline;gap:12px;padding:22px 30px 22px 0;}
.facts-band .fact:not(:last-child){border-right:1px solid rgba(26,26,26,.16);margin-right:30px;}
.facts-band .num{font-family:'Anton',sans-serif;color:var(--gold);font-size:clamp(30px,3.4vw,44px);line-height:1;}
.facts-band .lbl{font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:11.5px;color:#5a5a52;}

/* building feature list */
.building-list{list-style:none;columns:2;column-gap:clamp(28px,4vw,56px);max-width:1020px;}
.building-list li{break-inside:avoid;padding:13px 0 13px 26px;position:relative;border-bottom:1px solid rgba(26,26,26,.12);color:#3a3a34;font-size:16px;}
.building-list li::before{content:"";position:absolute;left:0;top:24px;width:12px;height:3px;background:var(--gold);}
.building-list strong{color:var(--ink);}
.building-duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,36px);margin:44px 0 32px;}
.building-duo img{width:100%;aspect-ratio:3/2;object-fit:cover;}

/* mission and values */
.mission-line{font-family:'Cinzel',Georgia,serif;font-size:clamp(24px,3.4vw,40px);font-weight:600;line-height:1.3;color:var(--ink);max-width:26ch;margin:10px auto 22px;}
.values-rows{max-width:920px;margin:42px auto 0;text-align:left;border-top:1px solid rgba(26,26,26,.16);}
.value-row{display:grid;grid-template-columns:300px 1fr;gap:clamp(20px,4vw,48px);padding:22px 0;border-bottom:1px solid rgba(26,26,26,.16);align-items:baseline;}
.value-row h3{font-size:clamp(17px,1.6vw,20px);letter-spacing:.06em;position:relative;padding-left:26px;}
.value-row h3::before{content:"";position:absolute;left:0;top:.5em;width:13px;height:3px;background:var(--gold);}
.value-row p{margin:0;color:#4a4a44;font-size:16px;}

/* global director */
.director-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(32px,5vw,68px);align-items:start;margin-top:46px;}
.portrait-frame{border:1px solid rgba(26,26,26,.22);background:#fffef7;padding:clamp(12px,1.5vw,18px);max-width:440px;}
.portrait-inner{background:var(--dark);aspect-ratio:3/4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;position:relative;}
.portrait-inner::before{content:"";position:absolute;inset:12px;border:1px solid rgba(217,147,17,.55);pointer-events:none;}
.portrait-inner .pf-mono{font-family:'Cinzel',Georgia,serif;font-weight:600;color:var(--gold);font-size:clamp(42px,4.6vw,62px);letter-spacing:.1em;line-height:1;}
.portrait-inner .pf-label{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ivory-muted);}
.director-name{margin-bottom:6px;}
.director-title{font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--gold-deep);margin:0 0 22px;}
.director-bio p{color:#3a3a34;max-width:62ch;}

/* 20+ years of moments: vertical timeline */
.moments-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,5vw,72px);align-items:start;margin-top:50px;}
.moments-figure img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center 30%;}
.moments-figure .photo-credit{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;margin-top:10px;}
.timeline{position:relative;padding-top:6px;}
.timeline::before{content:"";position:absolute;left:132px;top:10px;bottom:10px;width:1px;background:linear-gradient(180deg,var(--gold) 0%,rgba(217,147,17,.18) 100%);}
.tl-item{display:grid;grid-template-columns:104px 1fr;gap:clamp(40px,5vw,64px);position:relative;padding-bottom:clamp(30px,4vw,46px);}
.tl-item:last-child{padding-bottom:0;}
.tl-year{font-family:'Anton',sans-serif;color:var(--gold);font-size:clamp(28px,3vw,40px);line-height:1;text-align:right;}
.tl-item::after{content:"";position:absolute;left:128px;top:13px;width:9px;height:9px;background:var(--gold);transform:rotate(45deg);}
.tl-text{color:var(--ivory-muted);font-size:16px;max-width:52ch;padding-top:7px;}

/* closing CTA band */
.story-cta{border-top:1px solid var(--gray-line);}
.story-cta h2{color:#fff;}
.story-cta p.lede{margin-left:auto;margin-right:auto;margin-bottom:32px;color:var(--ivory-muted);}
.story-cta .cta-actions{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;}

@media (max-width:1080px){
  .story-grid,.story-grid.flip,.director-grid,.moments-grid{grid-template-columns:1fr;gap:32px;}
  .story-figure{order:-1;}
  .portrait-frame{max-width:360px;}
}
@media (max-width:700px){
  .building-list{columns:1;}
  .building-duo{grid-template-columns:1fr;}
  .facts-band{flex-direction:column;}
  .facts-band .fact{border-right:0 !important;margin-right:0 !important;padding:14px 0;width:100%;border-bottom:1px solid rgba(26,26,26,.16);}
  .facts-band .fact:last-child{border-bottom:0;}
  .value-row{grid-template-columns:1fr;gap:6px;padding:18px 0;}
  .timeline::before{left:4px;}
  .tl-item{grid-template-columns:1fr;gap:10px;padding-left:32px;}
  .tl-year{text-align:left;}
  .tl-item::after{left:0;top:10px;}
}

/* ============================================================
   page: contact
   Page-specific classes only. Appended per build rules;
   no existing rules above were modified.
   ============================================================ */
/* Contact card (dark card on ivory band, gold rule per copy spec) */
.contact-card{background:var(--dark);color:var(--ivory);padding:clamp(30px,4vw,52px);max-width:720px;margin:38px auto 0;}
.contact-card .gold-rule{margin-bottom:24px;}
.contact-lines{list-style:none;display:grid;gap:16px;margin:0 0 26px;}
.contact-lines li{display:grid;grid-template-columns:110px 1fr;gap:16px;align-items:baseline;font-size:16.5px;}
.contact-lines .lab{font-family:'Montserrat',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--gold);}
.contact-lines a:hover{color:var(--gold);}
.contact-card .group-line{color:var(--ivory-muted);font-size:15px;border-top:1px solid var(--gray-line);padding-top:20px;margin:0;}

/* Find Us map band */
.map-frame{border:1px solid var(--gray-line);margin-top:38px;background:#0d0d0d;}
.map-frame iframe{display:block;width:100%;height:clamp(320px,42vw,480px);border:0;}
.map-caption{color:var(--ivory-muted);font-size:15px;max-width:62ch;margin:20px 0 0;}

/* Who to Ask For department cards */
.dept-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(22px,3vw,40px);margin-top:44px;}
.dept-card{background:#fffef7;border:1px solid rgba(26,26,26,.1);padding:clamp(26px,3vw,38px);display:flex;flex-direction:column;}
.dept-card .gold-rule{width:48px;margin-bottom:16px;}
.dept-card h3{margin-bottom:10px;}
.dept-card .desc{color:#4a4a44;font-size:15.5px;margin-bottom:6px;}
.dept-lines{list-style:none;display:grid;gap:9px;margin:8px 0 0;}
.dept-lines li{display:grid;grid-template-columns:130px 1fr;gap:12px;align-items:baseline;font-size:15px;color:#3a3a34;}
.dept-lines .lab{font-family:'Montserrat',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:10.5px;color:var(--gold-deep);}
.dept-lines a:hover{color:var(--gold-deep);}
.dept-card .textlink{margin-top:auto;padding-top:22px;align-self:flex-start;}

/* Send Us a Message inquiry form (dark band) */
.form-lede{color:var(--ivory-muted);margin:14px 0 0;}
.contact-form{max-width:760px;margin-top:36px;display:grid;gap:20px;}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.contact-form label{display:block;font-family:'Montserrat',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:#bdb9a8;margin-bottom:7px;}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:14px 16px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.04);
  color:var(--ivory);font-family:'Montserrat',sans-serif;font-size:15px;
}
.contact-form select{
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23D99311' stroke-width='2'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:42px;
}
.contact-form select:invalid{color:rgba(255,255,255,.45);}
.contact-form select option{color:var(--ink);background:#fff;}
.contact-form textarea{min-height:170px;resize:vertical;line-height:1.55;}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold);}
.contact-form .form-actions{margin-top:4px;}

/* Follow the Center social row on ivory band */
.social-row.social-ivory{justify-content:center;margin-top:34px;padding-top:0;border-top:0;}
.social-row.social-ivory a{border-color:rgba(26,26,26,.28);color:#3a3a34;}
.social-row.social-ivory a:hover{border-color:var(--gold-deep);color:var(--gold-deep);}

/* Closing CTA band (image-backed dark, .rent/.support overlay pattern) */
.contact-cta{position:relative;color:var(--ivory);background:#101010;overflow:hidden;text-align:center;}
.contact-cta-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;opacity:.32;}
.contact-cta-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,16,16,.93) 0%,rgba(16,16,16,.82) 50%,rgba(16,16,16,.94) 100%);}
.contact-cta .cta-inner{position:relative;z-index:2;max-width:760px;margin:0 auto;}
.contact-cta .gold-rule{margin-left:auto;margin-right:auto;}
.contact-cta .cta-line{font-family:'Cinzel',Georgia,serif;font-weight:600;font-size:clamp(24px,3.2vw,38px);line-height:1.3;color:#fff;letter-spacing:.01em;margin:0 0 6px;}
.contact-cta .cta-actions{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-top:30px;}
.contact-cta .firstrow-note{font-size:13px;color:var(--ivory-muted);margin:18px 0 0;letter-spacing:.02em;}
.contact-cta .photo-credit{position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;}

@media (max-width:900px){
  .dept-grid{grid-template-columns:1fr;}
}
@media (max-width:700px){
  .contact-form .form-row{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .contact-lines li{grid-template-columns:1fr;gap:3px;}
  .dept-lines li{grid-template-columns:1fr;gap:2px;}
  .contact-cta .cta-actions{flex-direction:column;align-items:center;}
}
/* ============ end page: contact ============ */

/* ============================================================
   page: broadway-in-bronzeville
   Flagship page additions only. Crimson is reserved for BiB
   brand moments (marquee accents, featured production callout).
   Never gold text on crimson, never crimson text on black.
   ============================================================ */
/* hero: flagship variant of .page-hero.has-img (taller, with actions + credit) */
.bb-hero{padding:clamp(96px,13vw,180px) 0 clamp(56px,8vw,104px);}
.bb-hero .lede{max-width:52ch;}
.bb-hero-actions{display:flex;flex-wrap:wrap;gap:16px;margin-top:32px;}
.bb-hero .ph-credit{
  position:absolute;right:var(--pad);bottom:12px;z-index:2;
  font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;
  color:rgba(255,255,255,.62);text-transform:uppercase;
}

/* two-column story split (ivory bands) */
.bb-split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;}
.bb-split-figure{position:relative;}
.bb-split-figure img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 35%;}
.bb-split-text p{color:#4a4a44;max-width:58ch;}
.bb-split-text .textlink{margin-top:8px;}
.bb-credit{font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:#8a8273;text-transform:uppercase;margin-top:12px;}

/* Off the Streets and On the Stage: three-column highlights */
.bb-highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,40px);margin-top:clamp(40px,5vw,64px);}
.bb-highlight{background:#fffef7;border:1px solid rgba(26,26,26,.1);padding:clamp(26px,3vw,38px);}
.bb-highlight .gold-rule{width:40px;margin-bottom:16px;}
.bb-highlight h3{font-size:clamp(17px,1.7vw,21px);letter-spacing:.06em;margin-bottom:12px;}
.bb-highlight p{color:#4a4a44;font-size:15.5px;margin:0;}
.bb-crosslink{text-align:center;margin-top:clamp(30px,4vw,44px);}

/* On the Marquee: stacked marquee list, Cinzel uppercase, gold rules between entries */
.marquee-list{
  list-style:none;columns:2;column-gap:clamp(48px,7vw,96px);
  max-width:1040px;margin:clamp(36px,5vw,56px) auto 0;
}
.marquee-list li{
  break-inside:avoid;display:flex;align-items:center;gap:18px;
  font-family:'Cinzel',Georgia,serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;font-size:clamp(17px,1.8vw,23px);line-height:1.25;color:var(--ivory);
  padding:17px 0;border-bottom:1px solid rgba(217,147,17,.34);
}
.marquee-list li::before{content:"";width:9px;height:9px;background:var(--crimson);transform:rotate(45deg);flex-shrink:0;}

/* featured production callout (crimson brand moment) */
.bb-featured{
  background:#1a1311;border-left:6px solid var(--crimson);
  max-width:1040px;margin:clamp(44px,6vw,72px) auto 0;
  padding:clamp(30px,4vw,50px) clamp(26px,4vw,56px);
}
.bb-featured .eyebrow{background:var(--crimson);color:#fff;display:inline-block;padding:7px 14px;letter-spacing:.18em;}
.bb-featured h3{color:#fff;margin:18px 0 14px;font-size:clamp(22px,2.6vw,32px);}
.bb-featured .bb-featured-date{color:var(--ivory-muted);font-weight:500;white-space:nowrap;}
.bb-featured p{color:var(--ivory-muted);max-width:62ch;margin:0;}

/* Tony Awards tradition: image-backed dark band (rent/support pattern) */
.bb-tony{position:relative;color:var(--ivory);background:#101010;overflow:hidden;}
.bb-tony-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 45%;opacity:.32;}
.bb-tony-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(16,16,16,.95) 0%,rgba(16,16,16,.82) 55%,rgba(16,16,16,.66) 100%);}
.bb-tony .wrap{position:relative;z-index:2;}
.bb-tony-inner{max-width:740px;}
.bb-tony h2{color:#fff;}
.bb-tony p{color:var(--ivory-muted);max-width:60ch;}

/* gallery: From the Stage */
.bb-gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,24px);margin-top:clamp(38px,5vw,56px);}
.bb-gallery-grid figure{position:relative;margin:0;overflow:hidden;}
.bb-gallery-grid img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .5s ease;}
.bb-gallery-grid figure:hover img{transform:scale(1.04);}
.bb-gallery-grid figcaption{
  position:absolute;right:10px;bottom:8px;white-space:nowrap;
  font-family:'Montserrat',sans-serif;font-size:10px;letter-spacing:.06em;
  color:#fff;text-transform:uppercase;background:rgba(0,0,0,.45);padding:3px 8px;
}

/* CTA band + First Row heading size (copy specifies H3 here) */
.bb-cta .lede{max-width:46ch;}
.bb-firstrow h3{font-size:clamp(26px,3.4vw,40px);margin-bottom:14px;}
.bb-firstrow .lede{margin-bottom:30px;color:#4a4a44;}

@media (max-width:1080px){
  .bb-split{grid-template-columns:1fr;gap:34px;}
  .bb-split-figure{order:-1;}
  .bb-highlights{grid-template-columns:1fr;}
  .marquee-list{columns:1;max-width:640px;}
  .bb-gallery-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:560px){
  .bb-hero-actions{flex-direction:column;align-items:stretch;}
  .bb-hero-actions .btn{text-align:center;}
  .bb-gallery-grid figcaption{font-size:8.5px;letter-spacing:.04em;padding:2px 6px;right:6px;bottom:6px;}
}
@media (prefers-reduced-motion:reduce){
  .bb-gallery-grid figure:hover img{transform:none;}
}
/* ============ end page: broadway-in-bronzeville ============ */

/* ============================================================
   page: education-community
   Page-specific classes only (appended 2026-06-09). Reuses
   shared vocabulary (.card, .visit-grid, .inquiry-panel,
   .inquiry-form, .crosslink-card, .pf-credit). Nothing above
   this block is modified.
   ============================================================ */

/* OTS flagship block: text + figure grid on ivory (legacy-grid rhythm) */
.ots-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;}
.ots-text h2{margin-bottom:20px;}
.ots-text p{color:#4a4a44;max-width:56ch;}
.ots-text .btn{margin-top:14px;}
.ots-figure{position:relative;}
.ots-figure img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 45%;}

/* Our Programs: Ailey-style image card grid, 2x2 on a dark band */
.edu-programs h2{color:#fff;}
.edu-programs .card{color:var(--ink);}
.programs-head{margin-bottom:48px;}
.programs-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,44px);}

/* Impact band: near-black, giant Anton numeral, gold frame */
.impact{position:relative;color:var(--ivory);background:#0f0d0a;overflow:hidden;text-align:center;border-top:2px solid var(--gold);border-bottom:2px solid var(--gold);}
.impact-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;opacity:.26;}
.impact-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,10,8,.88) 0%,rgba(12,10,8,.74) 50%,rgba(12,10,8,.9) 100%),
    radial-gradient(110% 90% at 50% 100%,rgba(217,147,17,.14),rgba(217,147,17,0) 60%);
}
.impact .wrap{position:relative;z-index:2;}
.impact-line{margin:0;}
.impact-lead{display:block;font-family:'Cinzel',Georgia,serif;text-transform:uppercase;letter-spacing:.18em;font-weight:600;font-size:clamp(16px,2vw,24px);color:#fff;}
.impact-num{display:block;font-family:'Anton',Impact,sans-serif;color:var(--gold);font-size:clamp(88px,13vw,180px);line-height:1;margin:14px 0;letter-spacing:.01em;}
.impact-values{color:var(--ivory-muted);max-width:58ch;margin:30px auto 0;font-size:clamp(15.5px,1.4vw,17.5px);}
.impact .photo-credit{position:absolute;right:var(--pad);bottom:12px;z-index:2;font-family:'Montserrat',sans-serif;font-size:10.5px;letter-spacing:.08em;color:rgba(255,255,255,.5);text-transform:uppercase;}

/* How to Get Involved: contact panel + interest form below the 3 cards */
#get-involved{scroll-margin-top:128px;}
.involve-grid{
  display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(28px,4vw,56px);align-items:stretch;
  margin-top:clamp(48px,7vw,84px);padding-top:clamp(40px,5vw,64px);border-top:1px solid rgba(26,26,26,.14);
}
.involve-contact{background:var(--dark);color:var(--ivory);padding:clamp(28px,3.4vw,44px);display:flex;flex-direction:column;justify-content:center;}
.involve-contact .gold-rule{margin-bottom:20px;}
.involve-contact .org{font-family:'Cinzel',Georgia,serif;text-transform:uppercase;letter-spacing:.06em;font-size:clamp(19px,2vw,24px);line-height:1.3;color:#fff;margin-bottom:16px;}
.involve-contact .lines{font-family:'Montserrat',sans-serif;font-size:16px;line-height:1.9;color:var(--ivory-muted);margin:0;}
.involve-grid .inquiry-panel h3{margin-bottom:22px;}
.involve-grid .form-privacy{font-size:12.5px;color:#7a7468;margin:16px 0 0;letter-spacing:.02em;}

/* Arts Partners cross-link band (dark, reuses .crosslink-card) */
.edu-partners{border-bottom:1px solid var(--gray-line);}
.edu-partners .crosslink-card{color:var(--ink);border-color:rgba(255,255,255,.08);}

@media (max-width:1080px){
  .ots-grid{grid-template-columns:1fr;gap:34px;}
  .ots-figure{order:-1;}
  .programs-grid{grid-template-columns:1fr;}
  .involve-grid{grid-template-columns:1fr;}
}
/* ============ end page: education-community ============ */
