
:root{
  --ink:#14110C;
  --char:#1E1A13;
  --char-2:#272118;
  --steel:#16202B;
  --gold:#E0A93E;
  --gold-bright:#F6CD6B;
  --gold-deep:#9A7322;
  --bronze:#BC6E36;
  --ember:#D8763A;
  --crimson:#9E2B2B;
  --crimson-soft:#C96A6A;
  --paper:#F6F1E7;
  --paper-2:#ECE2CF;
  --paper-line:rgba(20,17,12,.12);
  --display:'Saira Condensed',system-ui,sans-serif;
  --body:'Source Sans 3',system-ui,sans-serif;
  --mono:'Spline Sans Mono',ui-monospace,monospace;
  --maxw:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--paper);color:var(--ink);line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
::selection{background:var(--gold);color:var(--ink)}

.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.75em;font-weight:500}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--gold)}
.on-dark .eyebrow{color:var(--gold)}

.btn{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;font-weight:500;cursor:pointer;border:none;padding:13px 26px;transition:all .22s;display:inline-flex;align-items:center;gap:.6em}
.btn--gold{background:var(--gold);color:var(--ink)}
.btn--gold:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 12px 30px rgba(224,169,62,.32)}
.btn--ghost{background:transparent;color:var(--paper);border:1.5px solid rgba(246,205,107,.55)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold);background:rgba(224,169,62,.08)}
.btn--lg{padding:17px 38px;font-size:.8rem}

/* ticker */
.ticker{background:var(--ink);color:#d8cdb6;font-family:var(--mono);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;overflow:hidden;white-space:nowrap;border-bottom:1px solid rgba(224,169,62,.2)}
.ticker__track{display:inline-block;padding:8px 0;animation:slide 40s linear infinite}
.ticker__track span{padding:0 2.4rem;color:#9b9079}
.ticker__track b{color:var(--gold);font-weight:500}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* nav */
.nav{position:fixed;top:34px;left:0;right:0;z-index:80;transition:background .35s,border-color .35s,box-shadow .35s,top .35s;border-bottom:1px solid transparent}
.nav.solid{top:0;background:rgba(20,17,12,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(224,169,62,.18);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:13px}
.brand__mark{width:44px;height:44px;flex:0 0 auto;background:#fff;border-radius:50%;object-fit:cover;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.brand__txt{font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--paper);font-size:1.16rem;line-height:1}
.brand__txt small{display:block;font-family:var(--mono);font-size:.54rem;letter-spacing:.32em;color:var(--gold);font-weight:400;margin-top:4px}
.nav__links{display:flex;align-items:center;gap:32px}
.nav__links a{font-family:var(--mono);font-size:.73rem;letter-spacing:.16em;text-transform:uppercase;color:#d3c8b3;transition:color .2s}
.nav__links a:hover{color:var(--gold)}
.nav__toggle{display:none;background:none;border:none;cursor:pointer;width:32px;height:24px}
.nav__toggle span{display:block;height:2px;background:var(--gold);margin:6px 0;transition:.25s}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;color:var(--paper);overflow:hidden;padding:140px 0 64px}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%}
.hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,17,12,.66) 0%,rgba(20,17,12,.34) 36%,rgba(20,17,12,.62) 70%,rgba(20,17,12,.95) 100%),linear-gradient(95deg,rgba(20,17,12,.8) 0%,rgba(20,17,12,.18) 55%,transparent 100%)}
.hero__waves{position:absolute;right:-6%;top:50%;transform:translateY(-50%);width:min(720px,62vw);z-index:1;opacity:.5;pointer-events:none}
.hero__waves svg{width:100%;height:auto;overflow:visible}
.ring-s{fill:none;stroke:rgba(224,169,62,.22);stroke-width:1}
.ring-p{fill:none;stroke:var(--gold);stroke-width:1.5;transform-origin:center;opacity:0}
.hp1{animation:emanate 5.6s ease-out infinite}
.hp2{animation:emanate 5.6s ease-out infinite 1.9s}
.hp3{animation:emanate 5.6s ease-out infinite 3.8s}
@keyframes emanate{0%{transform:scale(.28);opacity:0}14%{opacity:.7}100%{transform:scale(1.55);opacity:0}}
.sweep{transform-origin:center;animation:spin 16s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hero__content{position:relative;z-index:3;width:100%}
.hero__tag{margin-bottom:26px}
.hero h1{font-family:var(--display);font-weight:800;text-transform:uppercase;line-height:.9;letter-spacing:.004em;font-size:clamp(3.2rem,8.2vw,7.2rem);margin-bottom:26px;text-shadow:0 4px 40px rgba(0,0,0,.5)}
.hero h1 .em{color:var(--gold)}
.hero__sub{font-size:clamp(1.05rem,1.7vw,1.32rem);color:#e8e0cf;max-width:46ch;margin-bottom:36px;font-weight:400}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero__strip{margin-top:54px;display:grid;grid-template-columns:repeat(3,auto);gap:0;border-top:1px solid rgba(224,169,62,.28);padding-top:26px;max-width:660px}
.hero__strip div{padding-right:42px}
.hero__strip b{display:block;font-family:var(--display);font-weight:700;font-size:2.1rem;color:var(--gold);letter-spacing:.02em;line-height:1}
.hero__strip span{font-family:var(--mono);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:#b9af98;margin-top:8px;display:block}
.scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;font-family:var(--mono);font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:#b9af98;display:flex;flex-direction:column;align-items:center;gap:10px}
.scrollcue::after{content:"";width:1px;height:34px;background:linear-gradient(var(--gold),transparent);animation:cue 2.2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* generic blocks */
.block{padding:104px 0;position:relative}
.block--paper{background:var(--paper)}
.block--paper2{background:var(--paper-2)}
.block--char{background:var(--char);color:var(--paper)}
.block--ink{background:var(--ink);color:var(--paper)}
.block__head{max-width:780px;margin-bottom:56px}
.block__title{font-family:var(--display);font-weight:700;text-transform:uppercase;line-height:.98;letter-spacing:.005em;font-size:clamp(2.2rem,4.6vw,3.7rem);margin:18px 0 0}

/* creed */
.creed{position:relative}
.creed__big{font-family:var(--display);text-transform:none;font-weight:700;font-size:clamp(1.9rem,4.4vw,3.4rem);line-height:1.04;letter-spacing:.01em;max-width:20ch}
.creed__big em{color:var(--bronze);font-style:normal}
.creed .lead{max-width:64ch;font-size:1.18rem;color:#4a4334;margin-top:30px}

/* brotherhood gallery */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:170px;gap:14px}
.gallery img{width:100%;height:100%}
.g1{grid-column:span 7;grid-row:span 2}
.g2{grid-column:span 5;grid-row:span 1}
.g3{grid-column:span 5;grid-row:span 1}
.g4{grid-column:span 4;grid-row:span 1}
.g5{grid-column:span 4;grid-row:span 1}
.g6{grid-column:span 4;grid-row:span 1}
.gallery__cap{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:#7a715c;margin-top:22px;max-width:62ch}

/* timeline */
.tl{position:relative;margin-top:20px;padding-left:0}
.tl__line{position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--gold),rgba(224,169,62,.15))}
.tl__item{position:relative;padding:0 0 46px 46px}
.tl__item:last-child{padding-bottom:0}
.tl__dot{position:absolute;left:0;top:5px;width:16px;height:16px;border-radius:50%;background:var(--ink);border:2px solid var(--gold)}
.tl__yr{font-family:var(--display);font-weight:700;color:var(--gold);font-size:1.7rem;letter-spacing:.04em;line-height:1}
.tl__h{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:1.3rem;letter-spacing:.03em;margin:6px 0 6px;color:var(--paper)}
.tl__p{color:#c7bca6;max-width:54ch;font-size:1rem}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(2,1fr);border:1px solid var(--paper-line)}
.pillar{padding:44px 40px;border-right:1px solid var(--paper-line);border-bottom:1px solid var(--paper-line);position:relative;transition:background .25s}
.pillar:nth-child(2n){border-right:none}
.pillar:nth-child(n+3){border-bottom:none}
.pillar:hover{background:#fff}
.pillar__code{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;color:var(--bronze);text-transform:uppercase}
.pillar__icon{width:48px;height:48px;margin:18px 0 20px}
.pillar h3{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:1.55rem;letter-spacing:.02em;margin-bottom:12px}
.pillar p{color:#4a4334;font-size:1.02rem}
.pillar__ring{transform-origin:center;transition:transform .5s ease}
.pillar:hover .pillar__ring{transform:scale(1.12)}

/* remembrance */
.honor{position:relative;overflow:hidden}
.honor__media{position:absolute;inset:0;z-index:0}
.honor__media img{width:100%;height:100%}
.honor__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,12,8,.86),rgba(15,12,8,.94)),radial-gradient(70% 60% at 50% 30%,rgba(158,43,43,.28),transparent 70%)}
.honor__in{position:relative;z-index:2;text-align:center}
.honor .eyebrow{justify-content:center;color:var(--crimson-soft)}
.honor .eyebrow::before{background:var(--crimson)}
.honor h2{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:clamp(2.4rem,5.4vw,4.4rem);line-height:1;margin:22px 0 26px}
.honor p{max-width:56ch;margin:0 auto;color:#d8cdb6;font-size:1.16rem}
.honor__flame{margin:46px auto 0;width:14px;height:46px;position:relative}
.honor__flame::before{content:"";position:absolute;inset:0;border-radius:50% 50% 50% 50%/60% 60% 40% 40%;background:radial-gradient(circle at 50% 70%,var(--gold-bright),var(--ember) 55%,transparent 75%);animation:flick 2.6s ease-in-out infinite;filter:blur(.4px)}
@keyframes flick{0%,100%{transform:scaleY(1) scaleX(1);opacity:.9}50%{transform:scaleY(1.18) scaleX(.92);opacity:1}}
.honor__tag{font-family:var(--mono);font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--crimson-soft);margin-top:20px}

/* muster */
.muster{display:grid;grid-template-columns:1fr 1.05fr;gap:0;background:var(--char);color:var(--paper);overflow:hidden;border:1px solid rgba(224,169,62,.25)}
.muster__media{position:relative;min-height:420px}
.muster__media img{position:absolute;inset:0;width:100%;height:100%}
.muster__badge{position:absolute;left:24px;top:24px;z-index:2;font-family:var(--mono);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);background:var(--gold);padding:7px 14px}
.muster__body{padding:58px 52px;align-self:center}
.muster__date{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(2.6rem,5vw,4.4rem);line-height:.88;color:var(--gold)}
.muster__where{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;font-size:.82rem;color:#d3c8b3;margin:18px 0 26px}
.muster p{color:#c7bca6;max-width:42ch;margin-bottom:30px}

/* tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.tier{background:#fff;border:1px solid var(--paper-line);padding:36px 30px;display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s}
.tier:hover{transform:translateY(-5px);box-shadow:0 24px 52px rgba(30,26,19,.14)}
.tier--feat{background:var(--char);color:var(--paper);border-color:var(--gold);position:relative}
.tier--feat::after{content:"Most chosen";position:absolute;top:-11px;left:30px;background:var(--gold);color:var(--ink);font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;padding:5px 12px}
.tier__tag{font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bronze)}
.tier--feat .tier__tag{color:var(--gold)}
.tier h3{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:1.85rem;margin:14px 0 4px;letter-spacing:.02em}
.tier__price{font-family:var(--display);font-weight:600;font-size:2.5rem;line-height:1}
.tier__price span{font-family:var(--mono);font-size:.8rem;letter-spacing:.1em;opacity:.6}
.tier ul{list-style:none;margin:22px 0 28px;flex:1}
.tier li{font-size:.96rem;padding:9px 0;border-top:1px dashed var(--paper-line);display:flex;gap:10px;align-items:flex-start}
.tier--feat li{border-color:rgba(224,169,62,.25)}
.tier li::before{content:"›";color:var(--bronze);font-weight:700}
.tier--feat li::before{color:var(--gold)}
.tier .btn{justify-content:center}

/* foundation */
.found{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.found__stat{font-family:var(--display);font-weight:800;color:var(--gold);font-size:clamp(3.4rem,8vw,6rem);line-height:.88}
.found__stat small{display:block;font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;color:#c7bca6;text-transform:uppercase;margin-top:12px;font-weight:400}
.found p{color:#c7bca6;font-size:1.12rem;margin-bottom:26px;max-width:46ch}

/* mission */
.mission__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start}
.mission__stmt{font-family:var(--display);text-transform:none;font-weight:700;font-size:clamp(1.7rem,3.2vw,2.6rem);line-height:1.06;letter-spacing:.01em;max-width:18ch}
.mission__stmt em{color:var(--bronze);font-style:normal}
.mission__card{background:var(--char);color:var(--paper);padding:40px 36px;border-left:3px solid var(--gold)}
.mission__card h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:500}
.mission__card p{color:#cabfa9;font-size:1.06rem}
.mission__card p+p{margin-top:16px}

/* initiatives */
.inits{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.init{background:#fff;border:1px solid var(--paper-line);padding:30px 26px;display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s;border-top:3px solid var(--gold)}
.init:hover{transform:translateY(-5px);box-shadow:0 22px 46px rgba(30,26,19,.13)}
.init__n{font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;color:var(--bronze);text-transform:uppercase}
.init h3{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:1.32rem;letter-spacing:.02em;margin:14px 0 10px}
.init p{color:#4a4334;font-size:.96rem;flex:1}
.init__link{margin-top:18px;font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
.init__link:hover{color:var(--bronze)}

/* events */
.events{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.event{background:var(--char);color:var(--paper);border:1px solid rgba(224,169,62,.22);overflow:hidden;display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s}
.event:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(0,0,0,.34)}
.event__media{position:relative;height:200px}
.event__media img{position:absolute;inset:0;width:100%;height:100%}
.event__tag{position:absolute;left:14px;top:14px;z-index:2;font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;background:var(--gold);color:var(--ink);padding:6px 12px}
.event__body{padding:28px 26px;display:flex;flex-direction:column;flex:1}
.event h3{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:1.55rem;letter-spacing:.02em;margin-bottom:6px}
.event__when{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;margin-bottom:14px}
.event p{color:#c7bca6;font-size:.97rem;flex:1;margin-bottom:20px}

/* join steps */
.join{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:56px 0 0}
.step{padding:26px 0 0;border-top:2px solid var(--gold)}
.step__n{font-family:var(--display);font-weight:800;font-size:2.6rem;color:var(--gold);line-height:1}
.step h4{font-family:var(--display);text-transform:uppercase;font-weight:700;font-size:1.18rem;margin:8px 0 8px;letter-spacing:.02em}
.step p{color:#c7bca6;font-size:.95rem}

/* give / donate */
.give{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
.donate__amts{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0 24px}
.amt{font-family:var(--display);font-weight:700;font-size:1.3rem;letter-spacing:.02em;padding:13px 22px;border:1.5px solid rgba(224,169,62,.42);background:transparent;color:var(--paper);cursor:pointer;transition:all .2s}
.amt:hover,.amt.sel{background:var(--gold);color:var(--ink);border-color:var(--gold)}

/* sponsors */
.sponsors{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:8px}
.sponsor{background:#fff;border:1px solid var(--paper-line);aspect-ratio:3/2;display:grid;place-items:center;padding:0;transition:box-shadow .2s,transform .2s}
.sponsor:hover{box-shadow:0 8px 22px rgba(20,17,12,.10);transform:translateY(-2px)}
.sponsor img{width:100%;height:100%}
.sponsor img{width:100%;height:100%;object-fit:contain;padding:15px 20px;box-sizing:border-box;display:block}
.sponsors__note{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;color:#7a715c;margin-top:24px;text-align:center}
.sponsors__note a{color:var(--gold-deep);text-decoration:underline}

/* contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:start}
.contact__row{display:flex;gap:16px;align-items:baseline;padding:16px 0;border-bottom:1px solid rgba(224,169,62,.16)}
.contact__row b{font-family:var(--mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);min-width:96px;flex:0 0 auto}
.contact__row span{color:#d3c8b3;font-size:1.02rem}
.form{display:grid;gap:14px}
.form input,.form textarea{font-family:var(--body);font-size:1rem;padding:14px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(224,169,62,.25);color:var(--paper);width:100%}
.form textarea{min-height:120px;resize:vertical}
.form input::placeholder,.form textarea::placeholder{color:#8a8068}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.08)}

/* CTA band */
.cta{background:linear-gradient(100deg,var(--char-2),var(--ink));color:var(--paper);text-align:center;padding:96px 0}
.cta h2{font-family:var(--display);text-transform:uppercase;font-weight:800;font-size:clamp(2.4rem,5.4vw,4.2rem);line-height:.96;margin:16px auto 18px;max-width:18ch}
.cta p{color:#c7bca6;max-width:50ch;margin:0 auto 34px;font-size:1.12rem}

/* footer */
.foot{background:var(--ink);color:#b3a98f;padding:74px 0 38px;border-top:1px solid rgba(224,169,62,.2)}
.foot__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:44px;margin-bottom:50px}
.foot__brand{display:flex;gap:16px;align-items:flex-start}
.foot__brand img{width:62px;height:62px;flex:0 0 auto}
.foot h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:500}
.foot a{display:block;padding:5px 0;font-size:.94rem;transition:color .2s}
.foot a:hover{color:var(--gold)}
.foot__bottom{border-top:1px solid rgba(224,169,62,.16);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:#7a715c}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.1s}
.reveal[data-d="2"]{transition-delay:.2s}
.reveal[data-d="3"]{transition-delay:.3s}

@media(max-width:900px){
  .nav__links{position:fixed;inset:74px 0 auto 0;background:var(--ink);flex-direction:column;gap:0;padding:8px 0;transform:translateY(-130%);transition:transform .3s;border-bottom:1px solid rgba(224,169,62,.2)}
  .nav__links.open{transform:none}
  .nav__links a{padding:15px 30px;width:100%;border-bottom:1px solid rgba(224,169,62,.08)}
  .nav__links .btn{margin:12px 30px;text-align:center;justify-content:center}
  .nav__toggle{display:block}
  .muster,.found,.foot__grid{grid-template-columns:1fr}
  .muster__media{min-height:300px}
  .pillars{grid-template-columns:1fr}
  .pillar{border-right:none!important;border-bottom:1px solid var(--paper-line)!important}
  .pillar:last-child{border-bottom:none!important}
  .tiers{grid-template-columns:1fr}
  .gallery{grid-auto-rows:130px}
  .g1{grid-column:span 12;grid-row:span 2}
  .g2,.g3{grid-column:span 6}
  .g4,.g5,.g6{grid-column:span 4}
  .hero__strip{grid-template-columns:repeat(3,auto)}
  .mission__grid,.give,.contact{grid-template-columns:1fr;gap:36px}
  .belong{grid-template-columns:1fr!important;gap:28px!important}
  .inits,.events,.join{grid-template-columns:1fr 1fr}
  .sponsors{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:560px){
  .hero__strip b{font-size:1.6rem}
  .gallery{grid-template-columns:repeat(6,1fr)}
  .g4,.g5,.g6{grid-column:span 6}
  .inits,.events,.join{grid-template-columns:1fr}
  .sponsors{grid-template-columns:repeat(3,1fr)}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto}.reveal{opacity:1;transform:none}.ring-p{opacity:.35}}


/* ===== subpage header ===== */
.subhero{position:relative;overflow:hidden;background:linear-gradient(100deg,var(--char-2),var(--ink));color:var(--paper);padding:150px 0 64px}
.subhero .eyebrow{color:var(--gold)}
.subhero h1{font-family:var(--display);text-transform:uppercase;font-weight:800;font-size:clamp(2.6rem,6vw,4.6rem);line-height:.95;margin:16px 0 14px;letter-spacing:.004em}
.subhero p{color:#c7bca6;max-width:62ch;font-size:1.12rem}
.subhero__rings{position:absolute;right:-3%;top:50%;transform:translateY(-50%);width:min(420px,46vw);opacity:.4;pointer-events:none;z-index:0}
.subhero__rings svg{width:100%;height:auto;overflow:visible}
.subhero .wrap{position:relative;z-index:2}
/* nav forced solid on subpages */
.nav.always-solid{top:0;background:rgba(20,17,12,.95);backdrop-filter:blur(14px);border-bottom:1px solid rgba(224,169,62,.18);box-shadow:0 8px 30px rgba(0,0,0,.3)}
.nav__links a.active{color:var(--gold)}
/* page top offset so content clears fixed nav when no hero */
body.haspage{padding-top:0}

/* ===== photographic background washes ===== */
/* donate / CTA bands — former operators, shoulder to shoulder */
.cta{
  position:relative;overflow:hidden;
  background-image:
    linear-gradient(100deg, rgba(26,22,15,.90), rgba(15,13,9,.92)),
    url('/assets/photos/wash-cta.jpg');
  background-size:cover;background-position:center 32%;background-repeat:no-repeat;
}
/* subpage headers — communications / transmission imagery */
.subhero{
  background-image:
    linear-gradient(100deg, rgba(30,26,19,.93), rgba(15,13,9,.88)),
    url('/assets/photos/wash-comms.jpg');
  background-size:cover;background-position:center 30%;background-repeat:no-repeat;
}
/* heritage / character band on About — comms tower, faint */
.block--char.has-comms-bg{
  position:relative;
  background-image:
    linear-gradient(180deg, rgba(34,28,20,.95), rgba(34,28,20,.97)),
    url('/assets/photos/wash-comms.jpg');
  background-size:cover;background-position:center;background-repeat:no-repeat;
}

/* ── compiled from DC export (image-slot → <img>) ──────────────────── */
/* restore the cover fit the runtime used to apply via fit="cover" */
.hero__media img,.honor__media img,.event__media img,.muster__media img,
.gallery img,.card__media img{width:100%;height:100%;object-fit:cover}
/* local photo placeholders — swap real JCU photos into /assets/photos/ later */
.ph{position:relative;width:100%;height:100%;min-height:160px;border:1px solid var(--paper-line);
  background:repeating-linear-gradient(135deg,rgba(20,17,12,.04) 0 14px,rgba(20,17,12,.07) 14px 28px),var(--paper-2)}
.ph::after{content:attr(data-label);position:absolute;inset:0;display:grid;place-items:center;text-align:center;
  padding:14px;font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:#8a8068}
.on-dark .ph,.honor .ph{border-color:rgba(224,169,62,.18);
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.03) 0 14px,rgba(255,255,255,.06) 14px 28px),rgba(255,255,255,.02)}
.on-dark .ph::after,.honor .ph::after{color:#b9af98}
