:root{--bg:#0a0a0a;--ink:#0a0a0a;--bone:#f4f0e8;--bone-soft:#e8e1cf;--accent:#d2222d;--gold:#d4a73a;--rule:#2a2a2a;--display:"Anton","Bebas Neue",Impact,sans-serif;--display2:"Bebas Neue",Impact,sans-serif;--sans:"Inter",system-ui,sans-serif;--frame-pad:clamp(20px,5vw,72px);--max:1280px}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bone);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}
.masthead{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:14px var(--frame-pad);z-index:50;color:var(--bone);background:rgba(10,10,10,.96);border-bottom:2px solid var(--accent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.wordmark{display:inline-flex;align-items:center;gap:14px;color:var(--bone)}
.wm-logo{height:80px;width:auto;display:block;filter:drop-shadow(0 4px 12px rgba(0,0,0,.5))}
.wm-tag{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,240,232,.6);font-weight:600}
.primary{display:flex;gap:clamp(10px,1.4vw,20px);font-family:var(--display2);font-size:14px;letter-spacing:.16em;text-transform:uppercase}
.primary a{color:#efebe3;padding:8px 4px;transition:color .25s}
.primary a:hover{color:var(--accent)}
.primary-cta{background:var(--accent);color:var(--bone)!important;padding:10px 20px!important}
.primary-cta:hover{background:#a01820}
.menu-toggle{display:none;width:48px;height:48px;background:transparent;border:1px solid rgba(244,240,232,.5);align-items:center;justify-content:center;flex-direction:column;gap:6px;cursor:pointer;padding:0}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--bone);transition:transform .3s}
.menu-open .menu-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-open .menu-toggle span:nth-child(2){opacity:0}
.menu-open .menu-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.mobile-nav{position:fixed;top:0;left:0;right:0;height:100vh;height:100dvh;z-index:49;background:rgba(10,10,10,.98);opacity:0;visibility:hidden;transition:opacity .32s,visibility .32s;overflow-y:auto;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}
.menu-open .mobile-nav{opacity:1;visibility:visible}
.menu-open{overflow:hidden}
.mobile-nav-inner{padding:calc(env(safe-area-inset-top,0) + 88px) 28px 40px;max-width:480px;margin:0 auto;display:flex;flex-direction:column}
.mobile-nav a{font-family:var(--display);font-size:32px;color:var(--bone);padding:18px 0;border-bottom:1px solid rgba(244,240,232,.1);letter-spacing:.04em}
.mobile-nav a:hover{color:var(--accent)}
.mobile-nav-fine{margin-top:24px;font-size:14px}
.mobile-nav-fine a{font-size:14px!important;border:none!important;padding:8px 0!important;color:rgba(244,240,232,.7)!important;font-family:var(--sans)!important}
.hero{position:relative;min-height:clamp(480px,72vh,640px);display:flex;align-items:center;background:#000;overflow:hidden;color:var(--bone)}
.hero-image{position:absolute;inset:0;z-index:0}
.hero-image img{width:100%;height:100%;object-fit:cover;filter:saturate(.7) contrast(1.15) brightness(.6)}
.hero-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.5),rgba(0,0,0,.1) 30%,rgba(0,0,0,.6) 65%,rgba(0,0,0,.92)),linear-gradient(90deg,rgba(0,0,0,.7),rgba(0,0,0,.05) 40%,transparent)}
.hero-frame{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:clamp(96px,12vh,140px) var(--frame-pad) clamp(40px,6vh,64px);width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);background:rgba(0,0,0,.55);padding:9px 18px;border:1px solid rgba(212,167,58,.45);margin-bottom:32px;font-weight:600}
.hero-eyebrow .dot{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--accent)}
.hero-title{font-family:var(--display);text-transform:uppercase;font-size:clamp(48px,9vw,118px);line-height:.92;color:var(--bone);margin-bottom:24px;text-shadow:0 4px 32px rgba(0,0,0,.7)}
.ht-1,.ht-2,.ht-3{display:block}
.ht-2{padding-left:.4em;font-size:.7em;color:rgba(244,240,232,.7)}
.ht-3 em{font-style:normal;color:var(--accent);text-shadow:0 4px 32px rgba(210,34,45,.4)}
.hero-sub{font-size:clamp(16px,1.6vw,21px);line-height:1.55;color:rgba(244,240,232,.92);max-width:60ch;text-shadow:0 1px 8px rgba(0,0,0,.7);margin-bottom:32px}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:14px}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:var(--bone);font-family:var(--display);font-size:18px;letter-spacing:.08em;text-transform:uppercase;padding:18px 32px;border:none;cursor:pointer;transition:background .25s,transform .25s}
.btn-primary:hover{background:#a01820;transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;color:var(--bone);font-size:14px;font-weight:600;letter-spacing:.04em;padding:18px 24px;border:1px solid rgba(244,240,232,.4);background:transparent;transition:border-color .25s,color .25s}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.link-cta{display:inline-flex;font-family:var(--display);font-size:18px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);border-bottom:2px solid currentColor;padding-bottom:4px}
.link-back{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid currentColor;padding-bottom:2px}
.alumni-strip{padding:clamp(36px,5vh,56px) var(--frame-pad);text-align:center;background:#000;color:var(--bone)}
.ps-eyebrow{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:600}
.al-row{font-family:var(--display);font-size:clamp(20px,2.6vw,34px);line-height:1.2;color:var(--bone);text-transform:uppercase;letter-spacing:.04em;display:flex;flex-wrap:wrap;justify-content:center;gap:.4em 1em;max-width:1100px;margin:0 auto}
.al-more{margin-top:24px;font-size:13px}
.al-more a{color:var(--accent);font-weight:600;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid currentColor}
.creds{padding:clamp(64px,9vh,100px) var(--frame-pad);background:var(--bone-soft);text-align:center}
.sec-h{font-family:var(--display);font-size:clamp(28px,4vw,48px);text-transform:uppercase;color:var(--ink);margin-bottom:28px}
.cred-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px;max-width:var(--max);margin:0 auto}
.cred{padding:32px 24px;background:var(--bone);border-top:4px solid var(--accent);text-align:center}
.cr-num{display:block;font-family:var(--display);font-size:clamp(44px,5.5vw,72px);color:var(--accent);line-height:1;margin-bottom:14px}
.cr-h{display:block;font-family:var(--display);font-size:22px;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.cr-d{display:block;font-size:14px;color:var(--ink);opacity:.7}
.learn{padding:clamp(64px,10vh,120px) var(--frame-pad);background:var(--bone)}
.lr-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:clamp(40px,6vw,80px);align-items:center}
.lr-img{aspect-ratio:4/5;overflow:hidden;background:var(--ink)}
.lr-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.9)}
.lr-list{display:grid;gap:16px;margin:24px 0;font-size:17px;line-height:1.55}
.lr-list li{padding-left:24px;position:relative}
.lr-list li::before{content:"";position:absolute;left:0;top:.7em;width:14px;height:2px;background:var(--accent)}
.contact-cta{padding:clamp(72px,10vh,120px) var(--frame-pad);background:var(--ink);color:var(--bone);text-align:center}
.contact-cta .sec-h{color:var(--bone)}
.cc-sub{font-size:18px;line-height:1.55;color:rgba(244,240,232,.85);max-width:560px;margin:0 auto 48px}
.cc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;max-width:1080px;margin:0 auto}
.cc-card{padding:32px 24px;background:rgba(244,240,232,.06);border:1px solid rgba(244,240,232,.12);text-align:center}
.cc-h{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;font-weight:600}
.cc-v{font-family:var(--display);font-size:clamp(24px,2.6vw,34px);color:var(--bone);line-height:1.1;margin-bottom:8px}
.cc-v.sm{font-size:20px;margin-bottom:2px}
.cc-v a{color:var(--bone);transition:color .25s}
.cc-v a:hover{color:var(--accent)}
.cc-d{font-size:13px;color:rgba(244,240,232,.65)}
.page{padding-top:0}
.page-frame{max-width:var(--max);margin:0 auto;padding:clamp(120px,16vh,160px) var(--frame-pad) clamp(80px,10vh,120px)}
.page-head{text-align:center;margin-bottom:64px;padding-bottom:36px;border-bottom:2px solid var(--accent)}
.page-h{font-family:var(--display);font-size:clamp(40px,6vw,80px);text-transform:uppercase;color:var(--ink);line-height:.95;margin-bottom:16px}
.page-lede{font-size:18px;line-height:1.5;color:var(--ink);opacity:.75;max-width:60ch;margin:0 auto}
.al-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.al-card{padding:0;background:var(--bone-soft);border-left:4px solid var(--accent);overflow:hidden;display:flex;flex-direction:column;transition:transform .35s,box-shadow .35s}
.al-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -22px rgba(0,0,0,.45)}
.al-img{aspect-ratio:1/1;overflow:hidden;background:var(--ink);position:relative}
.al-img img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:saturate(.92) contrast(1.06);transition:transform .9s}
.al-card:hover .al-img img{transform:scale(1.06)}
.al-card h3{font-family:var(--display);font-size:18px;text-transform:uppercase;color:var(--ink);padding:14px 16px 16px;line-height:1.1;letter-spacing:.02em}
.wp-extra{background:#000;color:var(--bone);padding:64px 0;border-top:2px solid var(--accent)}
.wp-extra-frame{max-width:var(--max);margin:0 auto;padding:0 var(--frame-pad)}
.wp-extra-h{font-family:var(--display);font-size:32px;text-transform:uppercase;color:var(--gold);margin-bottom:32px;text-align:center;letter-spacing:.04em}
.wp-extra-body{font-size:15px;line-height:1.7;color:rgba(244,240,232,.85);max-width:920px;margin:0 auto}
.wp-extra-body h1,.wp-extra-body h2{font-family:var(--display);text-transform:uppercase;color:var(--bone);margin:1.5em 0 .5em;letter-spacing:.02em}
.wp-extra-body h2{font-size:24px}
.wp-extra-body h3{font-family:var(--display);font-size:18px;color:var(--accent);margin:1.2em 0 .4em;text-transform:uppercase}
.wp-extra-body p{margin-bottom:1em}
.wp-extra-body img{max-width:100%;height:auto;margin:18px 0;border:1px solid rgba(244,240,232,.1)}
.wp-extra-body a{color:var(--accent);border-bottom:1px solid currentColor}
.wp-extra-body figure{margin:20px 0}
.wp-extra-body figcaption{font-size:12px;color:rgba(244,240,232,.55);margin-top:6px;font-style:italic}
.wp-extra-body ul,.wp-extra-body ol{margin:1em 0;padding-left:1.4em}
.wp-extra-body ul li,.wp-extra-body ol li{margin-bottom:.4em;list-style:disc}
/* Portal homepage — KetiService-style template adapted for WUW */
.portal{padding-top:0}
.ph-hero{position:relative;min-height:clamp(540px,82vh,720px);display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden;isolation:isolate;text-align:center;color:var(--bone)}
.ph-image{position:absolute;inset:0;z-index:0}
.ph-image img{width:100%;height:100%;object-fit:cover;object-position:center 30%;filter:saturate(.7) contrast(1.15) brightness(.55);animation:phZoom 24s ease-in-out infinite alternate}
@keyframes phZoom{0%{transform:scale(1.02)}100%{transform:scale(1.14) translate(-1.5%,-1.5%)}}
.ph-veil{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 50% 50%,rgba(0,0,0,.4) 0%,rgba(0,0,0,.7) 60%,rgba(0,0,0,.95)),linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.85))}
.ph-frame{position:relative;z-index:2;max-width:1080px;margin:0 auto;padding:clamp(120px,16vh,160px) var(--frame-pad) clamp(48px,6vh,72px)}
.ph-eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);background:rgba(0,0,0,.55);padding:9px 18px;border:1px solid rgba(212,167,58,.4);margin-bottom:32px;font-weight:600;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.ph-eyebrow .rule{display:inline-block;width:28px;height:1px;background:var(--accent)}
.ph-title{font-family:var(--display);text-transform:uppercase;font-size:clamp(54px,9.5vw,128px);line-height:.92;letter-spacing:-.005em;color:var(--bone);margin-bottom:28px;text-shadow:0 4px 32px rgba(0,0,0,.7)}
.ph-line{display:block;overflow:hidden;padding-bottom:.04em}
.ph-word{display:inline-block;opacity:0;transform:translateY(110%) skew(0deg,2deg);animation:phWordRise 1.05s cubic-bezier(.2,.7,.2,1) forwards;will-change:transform,opacity}
.ph-w1{animation-delay:.30s}
.ph-w2{animation-delay:.50s;font-size:.55em;color:rgba(244,240,232,.78);letter-spacing:.04em}
.ph-w3{animation-delay:.72s}
.ph-em{color:var(--accent);text-shadow:0 4px 32px rgba(210,34,45,.4)}
@keyframes phWordRise{0%{opacity:0;transform:translateY(110%) skew(0deg,2deg)}60%{opacity:1}100%{opacity:1;transform:translateY(0) skew(0,0)}}
.ph-sub{font-family:var(--sans);font-size:clamp(16px,1.6vw,21px);line-height:1.55;color:rgba(244,240,232,.92);max-width:60ch;margin:0 auto;text-shadow:0 1px 8px rgba(0,0,0,.65)}
.ph-sub em{font-style:normal;color:var(--gold);font-weight:600}

/* Three-card portal grid */
.pc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,24px);padding:clamp(40px,6vh,72px) var(--frame-pad) clamp(72px,10vh,120px);max-width:var(--max);margin:0 auto;background:var(--bone)}
.pc-card{position:relative;display:block;aspect-ratio:3/4;overflow:hidden;background:var(--ink);color:var(--bone);text-decoration:none;transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .4s;isolation:isolate;min-height:460px}
.pc-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(0,0,0,.55)}
.pc-img{position:absolute;inset:0;z-index:0}
.pc-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.2,.7,.2,1);filter:saturate(.85) contrast(1.1) brightness(.7)}
.pc-card:hover .pc-img img{transform:scale(1.08)}
.pc-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.15) 35%,rgba(0,0,0,.65) 70%,rgba(0,0,0,.96) 100%)}
.pc-train .pc-veil{background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.15) 35%,rgba(60,10,15,.7) 75%,rgba(0,0,0,.96) 100%)}
.pc-alumni .pc-veil{background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.15) 35%,rgba(80,55,15,.65) 75%,rgba(0,0,0,.96) 100%)}
.pc-events .pc-veil{background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.15) 35%,rgba(50,15,25,.72) 75%,rgba(0,0,0,.96) 100%)}
.pc-body{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(28px,3.5vw,48px);gap:10px}
.pc-eyebrow{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:rgba(244,240,232,.78);margin:0;font-weight:600}
.pc-train .pc-eyebrow,.pc-events .pc-eyebrow{color:#f4a4ac}
.pc-alumni .pc-eyebrow{color:var(--gold)}
.pc-h{font-family:var(--display);font-size:clamp(48px,6.5vw,86px);line-height:.95;text-transform:uppercase;color:var(--bone);margin:0;text-shadow:0 2px 28px rgba(0,0,0,.55)}
.pc-meta{font-family:var(--sans);font-size:clamp(13px,1.05vw,15px);line-height:1.55;color:rgba(244,240,232,.86);margin:0 0 6px;max-width:36ch;text-shadow:0 1px 8px rgba(0,0,0,.55)}
.pc-cta{display:inline-flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--bone);border-top:1px solid rgba(244,240,232,.4);padding-top:16px;margin:6px 0 0;width:fit-content;font-weight:600}
.pc-cta svg{transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.pc-card:hover .pc-cta svg{transform:translateX(8px)}

/* Meet Johnny */
.meet-johnny{background:var(--bone-soft);border-top:1px solid var(--rule);padding:clamp(72px,11vh,120px) var(--frame-pad)}
.mj-frame{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:clamp(40px,6vw,80px);align-items:center}
.mj-photo{aspect-ratio:4/5;overflow:hidden;border-radius:0;background:var(--ink);position:relative}
.mj-photo::after{content:"";position:absolute;inset:10px;border:1px solid rgba(255,255,255,.16);pointer-events:none;z-index:1}
.mj-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.05)}
.mj-h{font-family:var(--display);font-weight:400;font-size:clamp(34px,4.4vw,58px);line-height:1.05;letter-spacing:-.005em;color:var(--ink);margin:18px 0 22px;text-transform:uppercase}
.mj-h em{font-style:normal;color:var(--accent);font-size:.7em}
.mj-lede{font-family:var(--sans);font-size:clamp(17px,1.5vw,20px);line-height:1.5;color:var(--ink);margin-bottom:18px;font-weight:500}
.mj-bio{font-size:16px;line-height:1.7;color:var(--ink-soft);margin-bottom:24px;max-width:56ch}
.mj-bio strong{color:var(--accent);font-weight:600}
.mj-contact{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));gap:14px 28px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:18px 0;margin:0 0 28px;max-width:680px}
.mj-contact div{display:flex;flex-direction:column;gap:2px;min-width:0}
.mj-contact dt{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-mute);font-weight:600}
.mj-contact dd{font-family:var(--display);font-size:18px;color:var(--ink);text-transform:uppercase;letter-spacing:.02em;line-height:1.2;word-break:break-word}
.mj-contact a{border-bottom:1px solid transparent;transition:border-color .25s,color .25s}
.mj-contact a:hover{color:var(--accent);border-color:var(--accent)}
.mj-cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.mj-cta-row .btn-ghost{color:var(--ink);border-color:var(--ink)}
.mj-cta-row .btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

@media (max-width:900px){
  .pc-cards{grid-template-columns:1fr;gap:14px}
  .pc-card{aspect-ratio:4/5;min-height:380px}
  .mj-frame{grid-template-columns:1fr;gap:32px}
  .mj-photo{max-width:380px;aspect-ratio:1/1;margin:0 auto}
}
@media (prefers-reduced-motion:reduce){
  .ph-image img{animation:none}
  .ph-word{opacity:1;transform:none;animation:none}
}

/* (legacy) Hero animation kept for any other pages still using .hero */
.ht-1,.ht-2,.ht-3{display:block;opacity:0;transform:translateY(50px) skew(0deg,2deg);animation:wuwSlam 1.1s cubic-bezier(.2,.7,.2,1) forwards;will-change:transform,opacity}
.ht-1{animation-delay:.15s}
.ht-2{animation-delay:.55s}
.ht-3{animation-delay:.85s}
@keyframes wuwSlam{0%{opacity:0;transform:translateY(50px) skew(0,3deg)}60%{opacity:1}100%{opacity:1;transform:translateY(0) skew(0,0)}}
.hero-image img{animation:wuwZoom 28s ease-in-out infinite alternate}
@keyframes wuwZoom{0%{transform:scale(1.02)}100%{transform:scale(1.14) translate(-1.5%,-1.5%)}}
@media (prefers-reduced-motion:reduce){.ht-1,.ht-2,.ht-3{opacity:1;transform:none;animation:none}.hero-image img{animation:none}}
.memorial{padding:32px;background:#000;color:var(--bone);margin-bottom:48px;text-align:center;border:1px solid var(--gold)}
.me-cross{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.memorial h2{font-family:var(--display);font-size:32px;text-transform:uppercase;margin-bottom:14px}
.roster-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:48px}
.roster-list li{font-family:var(--display);font-size:24px;text-transform:uppercase;color:var(--ink);padding:18px 22px;background:var(--bone-soft);border-left:4px solid var(--accent);letter-spacing:.02em}
.title-list{display:grid;gap:0;border-top:1px solid var(--rule);max-width:760px;margin:0 auto 48px}
.title-list li{display:flex;justify-content:space-between;align-items:center;padding:24px 0;border-bottom:1px solid var(--rule);gap:24px}
.tt-belt{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);opacity:.7;font-weight:600}
.tt-holder{font-family:var(--display);font-size:clamp(20px,2.4vw,30px);text-transform:uppercase;color:var(--accent);text-align:right}
.rl-foot{text-align:center;font-size:14px;color:var(--ink);opacity:.7}
.rl-foot.small{font-size:12px}
.ev-card{padding:32px;background:var(--bone-soft);margin-bottom:18px;border-left:4px solid var(--accent)}
.ev-card h2{font-family:var(--display);font-size:28px;text-transform:uppercase;margin-bottom:10px;color:var(--ink)}
.ev-card p{margin-bottom:18px;font-size:16px}
.ab-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:48px;align-items:start;margin-bottom:48px}
.ab-photo{aspect-ratio:4/5;overflow:hidden;background:var(--ink)}
.ab-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:contrast(1.05)}
.ab-body p{margin-bottom:18px;font-size:17px;line-height:1.7}
.ab-body strong{font-weight:600;color:var(--accent)}
.ab-quote{padding:48px;background:#000;color:var(--bone);font-family:var(--display);font-size:clamp(24px,3vw,40px);text-align:center;line-height:1.25;border-top:4px solid var(--accent)}
.ab-quote cite{display:block;margin-top:18px;font-family:var(--sans);font-size:14px;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;font-style:normal}
.ct-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-bottom:48px}
.ct-card{padding:32px;background:var(--bone-soft);border-top:4px solid var(--accent);text-align:center}
.ct-h{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;font-weight:600}
.ct-big{display:block;font-family:var(--display);font-size:32px;color:var(--ink);text-transform:uppercase;line-height:1.1;margin-bottom:8px}
.ct-big a{color:var(--ink);transition:color .25s}
.ct-big a:hover{color:var(--accent)}
.ct-d{font-size:14px;color:var(--ink);opacity:.7}
.sch-list li{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;border-bottom:1px dashed rgba(0,0,0,.1)}
.sch-list li span:first-child{font-weight:600}
.news-list{display:grid;gap:0;border-top:1px solid var(--rule);max-width:880px;margin:0 auto}
.news-list li{padding:18px 0;border-bottom:1px solid var(--rule)}
.news-list a{font-size:16px;color:var(--ink);border-bottom:1px solid transparent;word-break:break-word;display:inline-block}
.news-list a:hover{color:var(--accent);border-color:var(--accent)}
.post-page{padding:clamp(120px,16vh,160px) var(--frame-pad) clamp(64px,10vh,100px);max-width:760px;margin:0 auto}
.post-head{margin-bottom:32px;padding-bottom:18px;border-bottom:2px solid var(--accent)}
.post-date{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-weight:600}
.post-title{font-family:var(--display);font-size:clamp(40px,7vw,72px);text-transform:uppercase;color:var(--ink);line-height:.95}
.post-body{font-size:18px;line-height:1.75;color:var(--ink)}
.post-body p{margin-bottom:1.2em}
.post-body img{margin:32px 0;width:100%;height:auto}
.post-body a{color:var(--accent);border-bottom:1px solid currentColor}
.post-body h2,.post-body h3{font-family:var(--display);text-transform:uppercase;color:var(--ink);margin:1.5em 0 .5em;line-height:1.1}
.post-body h2{font-size:32px}
.post-body h3{font-size:26px}
.post-foot{margin-top:48px;padding-top:24px;border-top:1px solid var(--rule)}
.colophon{background:#000;color:var(--bone)}
.colophon-frame{max-width:var(--max);margin:0 auto;padding:64px var(--frame-pad);display:grid;grid-template-columns:1fr 1fr 1fr;gap:48px;align-items:start}
.col-mark{font-family:var(--display);font-size:36px;color:var(--bone);text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:8px}
.col-logo{height:90px;width:auto;display:block;margin-bottom:14px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.5))}
/* Johnny Rodz bio page */
.rodz-page{padding-top:0}
.rodz-hero{position:relative;min-height:480px;display:flex;align-items:flex-end;background:#000;overflow:hidden;color:var(--bone)}
.rodz-hero-image{position:absolute;inset:0;z-index:0}
.rodz-hero-image img{width:100%;height:100%;object-fit:cover;object-position:center 35%;filter:saturate(.8) contrast(1.1) brightness(.6)}
.rodz-hero-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,rgba(0,0,0,.1) 30%,rgba(0,0,0,.65) 75%,rgba(0,0,0,.95))}
.rodz-hero-frame{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:clamp(120px,18vh,180px) var(--frame-pad) clamp(48px,7vh,72px);width:100%}
.rodz-h{font-family:var(--display);font-size:clamp(48px,8vw,108px);text-transform:uppercase;line-height:.92;color:var(--bone);margin-bottom:18px;text-shadow:0 4px 32px rgba(0,0,0,.7)}
.rodz-h em{font-style:normal;color:var(--accent);text-shadow:0 4px 32px rgba(210,34,45,.4)}
.rodz-sub{font-size:clamp(16px,1.6vw,21px);line-height:1.55;color:rgba(244,240,232,.92);max-width:60ch;text-shadow:0 1px 8px rgba(0,0,0,.7)}
.rodz-body{font-size:18px;line-height:1.75;color:var(--ink)}
.rodz-body h1,.rodz-body h2{font-family:var(--display);text-transform:uppercase;color:var(--ink);margin:1.5em 0 .5em;letter-spacing:.02em}
.rodz-body h2{font-size:32px;color:var(--accent)}
.rodz-body h3{font-family:var(--display);font-size:24px;color:var(--ink);margin:1.2em 0 .4em;text-transform:uppercase}
.rodz-body p{margin-bottom:1.1em}
.rodz-body img{margin:24px 0;border-left:4px solid var(--accent)}
.rodz-body a{color:var(--accent);border-bottom:1px solid currentColor}
.rodz-body strong{color:var(--ink);font-weight:700}
.rodz-body ul{margin:1em 0;padding-left:1.4em}
.rodz-body ul li{margin-bottom:.5em;list-style:disc}
.rodz-cta-line{font-family:var(--display);text-transform:uppercase;font-size:18px;letter-spacing:.06em;margin-top:36px;padding-top:24px;border-top:2px solid var(--accent);display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.rodz-cta-line a{color:var(--accent);border-bottom:2px solid currentColor;padding-bottom:2px}
.col-tag{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,240,232,.55);font-weight:600}
.col-h{font-family:var(--display);font-size:18px;text-transform:uppercase;color:var(--accent);margin-bottom:14px;letter-spacing:.04em}
.col-contact p,.col-social p{font-size:14px;line-height:1.7;margin-bottom:6px}
.col-contact a,.col-social a{color:var(--bone);border-bottom:1px solid transparent;transition:border-color .25s}
.col-contact a:hover,.col-social a:hover{border-color:var(--accent);color:var(--accent)}
.col-fine{padding:18px var(--frame-pad);border-top:1px solid rgba(244,240,232,.1);font-size:11px;color:rgba(244,240,232,.4);text-align:center}
.bg-refs{padding:14px var(--frame-pad);border-top:1px solid rgba(244,240,232,.06);font-size:10px;line-height:1.8;color:rgba(244,240,232,.32);display:flex;flex-wrap:wrap;gap:6px 14px}
.bg-refs a{color:rgba(244,240,232,.42);transition:color .25s}
.bg-refs a:hover{color:var(--accent)}
@media (max-width:900px){.primary{display:none}.menu-toggle{display:flex!important}.wm-tag{display:none}.colophon-frame{grid-template-columns:1fr;gap:32px}.lr-grid,.ab-grid{grid-template-columns:1fr;gap:32px}.lr-img,.ab-photo{max-width:420px;aspect-ratio:1/1;margin:0 auto}.ht-2{padding-left:0}}
