/* ============================================================
   TOWNSVILLE ROBOT COMBAT — shared stylesheet
   Aesthetic: industrial / armored-plate / electric lightning
   ============================================================ */

:root{
  /* surfaces */
  --bg:        #0E1318;
  --bg-2:      #11171E;
  --panel:     #1B2129;
  --panel-2:   #232B34;
  --steel:     #2C3742;

  /* brand accents */
  --blue:      #2BB8F0;   /* electric / lightning */
  --blue-deep: #1689C2;
  --orange:    #FF7A1A;   /* heat */
  --amber:     #FFC400;
  --gold:      #E8B23A;   /* sunburst */

  /* text + lines */
  --ink:       #E8EEF3;
  --ink-dim:   #9FB0BD;
  --ink-faint: #6C7B88;
  --line:      #34414D;
  --silver:    #8A99A6;

  --maxw: 1180px;
  --radius: 4px;

  --font-display: 'Saira Condensed', 'Arial Narrow', sans-serif;
  --font-tech:    'Chakra Petch', monospace;
  --font-body:    'Barlow', system-ui, sans-serif;

  --shadow: 0 18px 50px -20px rgba(0,0,0,.8);
  --glow-blue: 0 0 24px -2px rgba(43,184,240,.55);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:84px; }

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:
    radial-gradient(900px 600px at 75% -10%, rgba(43,184,240,.10), transparent 60%),
    radial-gradient(800px 500px at -5% 20%, rgba(255,122,26,.06), transparent 55%),
    var(--bg);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* subtle brushed-metal noise behind everything */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    repeating-linear-gradient(115deg, rgba(255,255,255,.012) 0 2px, transparent 2px 5px);
  mix-blend-mode:overlay; opacity:.6;
}

img{ max-width:100%; display:block; }
a{ color:var(--blue); text-decoration:none; }

.wrap{ width:min(100% - 40px, var(--maxw)); margin-inline:auto; position:relative; z-index:1; }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:800; line-height:.98; letter-spacing:.5px; text-transform:uppercase; }
h2{ font-size:clamp(2rem, 5vw, 3.4rem); }
h3{ font-size:clamp(1.4rem, 3vw, 2rem); }

.eyebrow{
  font-family:var(--font-tech); font-weight:600; font-size:.78rem;
  letter-spacing:.32em; text-transform:uppercase; color:var(--blue);
  display:inline-flex; align-items:center; gap:.6em; margin-bottom:.9rem;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:linear-gradient(90deg,var(--blue),transparent); }

.lead{ font-size:1.12rem; color:var(--ink-dim); max-width:60ch; }
.muted{ color:var(--ink-dim); }

.heat{ background:linear-gradient(180deg,var(--amber),var(--orange));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.cold{ color:var(--blue); }

/* ---------- buttons ---------- */
.btn{
  --c1:var(--blue); --c2:var(--blue-deep);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-tech); font-weight:700; font-size:.92rem;
  letter-spacing:.12em; text-transform:uppercase; color:#04121b;
  padding:.85rem 1.6rem; border:none; cursor:pointer;
  background:linear-gradient(180deg,var(--c1),var(--c2));
  clip-path:polygon(10px 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%, 0 10px);
  transition:transform .15s ease, box-shadow .25s ease, filter .2s ease;
  box-shadow:var(--glow-blue);
}
.btn:hover{ transform:translateY(-2px); filter:brightness(1.08);
  box-shadow:0 0 32px -2px rgba(43,184,240,.8); }
.btn:active{ transform:translateY(0); }
.btn--heat{ --c1:var(--amber); --c2:var(--orange); color:#1a0c00;
  box-shadow:0 0 24px -4px rgba(255,140,20,.6); }
.btn--heat:hover{ box-shadow:0 0 32px -2px rgba(255,140,20,.85); }
.btn--ghost{
  background:transparent; color:var(--ink); border:1.5px solid var(--line);
  box-shadow:none; clip-path:none;
}
.btn--ghost:hover{ border-color:var(--blue); color:var(--blue); box-shadow:var(--glow-blue); }
.btn svg{ width:1.05em; height:1.05em; }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:linear-gradient(180deg, rgba(14,19,24,.96), rgba(14,19,24,.82));
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(8px);
  transition:box-shadow .3s ease, background .3s ease;
}
.site-header.scrolled{ box-shadow:0 10px 30px -12px rgba(0,0,0,.9); }
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; height:68px; }

.brand{ display:flex; align-items:center; gap:.7rem; font-family:var(--font-display);
  font-weight:900; text-transform:uppercase; letter-spacing:.5px; line-height:.85; }
.brand .name{ font-size:1.42rem; }
.brand .name b{ display:block; }
.brand .t{ background:linear-gradient(180deg,var(--amber),var(--orange));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.brand .b{ color:var(--ink); letter-spacing:1px; }

.nav{ display:flex; align-items:center; gap:.3rem; }
.nav a{
  font-family:var(--font-tech); font-weight:600; font-size:.82rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink-dim);
  padding:.5rem .8rem; border-radius:3px; transition:color .2s ease, background .2s ease;
}
.nav a:hover{ color:var(--ink); }
.nav a.active{ color:var(--blue); }
.nav a.active::after{ content:""; display:block; height:2px; margin-top:3px;
  background:linear-gradient(90deg,var(--blue),transparent); }

.nav-toggle{ display:none; background:none; border:1px solid var(--line);
  color:var(--ink); width:42px; height:38px; border-radius:3px; cursor:pointer; }
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; display:block; width:18px; height:2px; background:var(--ink);
  margin-inline:auto; transition:.25s; }
.nav-toggle span::before{ transform:translateY(-6px); }
.nav-toggle span::after{ transform:translateY(4px); }

@media (max-width:820px){
  .nav-toggle{ display:block; }
  .nav{
    position:absolute; top:68px; left:0; right:0; flex-direction:column; gap:0;
    background:var(--bg-2); border-bottom:1px solid var(--line);
    max-height:0; overflow:hidden; transition:max-height .3s ease;
  }
  .nav.open{ max-height:380px; }
  .nav a{ width:100%; padding:1rem 20px; border-top:1px solid var(--line); }
}

/* ---------- sections ---------- */
section{ padding:clamp(3.5rem,7vw,6rem) 0; position:relative; }
.section-head{ margin-bottom:2.5rem; max-width:760px; }
.section-head h2{ margin-top:.2rem; }
.section-head h2 + .lead{ margin-top:1rem; }

/* soft section seam — feathered top and bottom, no hard line */
.seam{ height:40px; width:100%; position:relative; z-index:1; border:0;
  background:linear-gradient(180deg,
    transparent 0%,
    rgba(138,153,166,0) 30%,
    rgba(138,153,166,.08) 44%,
    rgba(184,198,208,.30) 50%,
    rgba(138,153,166,.08) 56%,
    rgba(138,153,166,0) 70%,
    transparent 100%);
}

/* ---------- hero ---------- */
.hero{ text-align:center; padding-top:clamp(2.5rem,6vw,4.5rem);
  padding-bottom:clamp(3rem,6vw,5rem); position:relative; overflow:hidden; }
.hero::before{ /* lightning bloom */
  content:""; position:absolute; top:8%; left:50%; transform:translateX(-50%);
  width:min(120%,1100px); height:680px;
  background:radial-gradient(closest-side, rgba(43,184,240,.22), transparent 70%);
  filter:blur(8px); z-index:0; animation:pulse 5s ease-in-out infinite;
}
@keyframes pulse{ 0%,100%{opacity:.6} 50%{opacity:1} }
.hero .flyer{
  width:min(100%,860px); margin-inline:auto; position:relative; z-index:1;
  filter:drop-shadow(0 24px 60px rgba(0,0,0,.7)) drop-shadow(0 0 40px rgba(43,184,240,.25));
  animation:rise .8s cubic-bezier(.2,.7,.2,1) both;
}
.hero .tagline{ margin:2rem auto 0; max-width:760px; position:relative; z-index:1; }
.hero h1{ font-size:clamp(2.1rem,6vw,3.6rem); animation:rise .8s .12s cubic-bezier(.2,.7,.2,1) both; }
.hero .sub{ color:var(--ink-dim); font-size:1.12rem; margin:1.1rem auto 0; max-width:54ch;
  animation:rise .8s .22s cubic-bezier(.2,.7,.2,1) both; }
.hero .cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:2rem;
  animation:rise .8s .32s cubic-bezier(.2,.7,.2,1) both; }
@keyframes rise{ from{opacity:0; transform:translateY(26px)} to{opacity:1; transform:none} }

.locbar{ display:flex; gap:1.4rem; justify-content:center; flex-wrap:wrap; margin-top:2.4rem;
  font-family:var(--font-tech); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-faint); position:relative; z-index:1; }
.locbar span{ display:inline-flex; align-items:center; gap:.5em; }
.locbar b{ color:var(--blue); font-weight:600; }

/* ---------- page hero (inner pages) ---------- */
.page-hero{ padding:clamp(3rem,6vw,4.5rem) 0 clamp(2rem,4vw,3rem); border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, rgba(43,184,240,.06), transparent); }
.page-hero h1{ font-size:clamp(2.4rem,7vw,4.2rem); }
.page-hero .lead{ margin-top:1rem; }

/* ---------- panels / cards ---------- */
.panel{
  background:linear-gradient(160deg,var(--panel-2),var(--panel));
  border:1px solid var(--line); border-radius:var(--radius);
  padding:1.8rem; position:relative;
}
/* riveted corners */
.riveted::after{
  content:""; position:absolute; inset:8px; pointer-events:none; border-radius:2px;
  background-image:
    radial-gradient(circle at 0 0, rgba(255,255,255,.35) 1.4px, transparent 2px),
    radial-gradient(circle at 100% 0, rgba(255,255,255,.35) 1.4px, transparent 2px),
    radial-gradient(circle at 0 100%, rgba(255,255,255,.35) 1.4px, transparent 2px),
    radial-gradient(circle at 100% 100%, rgba(255,255,255,.35) 1.4px, transparent 2px);
  background-repeat:no-repeat;
}

.grid{ display:grid; gap:1.4rem; }
.grid.cols-2{ grid-template-columns:repeat(2,1fr); }
.grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.grid.cols-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .grid.cols-3,.grid.cols-4{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .grid.cols-2,.grid.cols-3,.grid.cols-4{ grid-template-columns:1fr;} }

/* feature blurb cards (compete / get started on home) */
.feature{ display:flex; flex-direction:column; gap:1rem; min-height:100%;
  border-top:3px solid var(--blue); }
.feature.heat-top{ border-top-color:var(--orange); }
.feature h3{ color:var(--ink); }
.feature .icon{ font-size:1.8rem; line-height:1; }
.feature .btn{ align-self:flex-start; margin-top:auto; }

/* ---------- weight divisions ---------- */
.div-card{
  background:linear-gradient(160deg,var(--panel-2),var(--panel));
  border:1px solid var(--line); border-radius:var(--radius);
  padding:1.5rem 1.4rem 1.4rem; position:relative; overflow:hidden;
  transition:transform .2s ease, border-color .2s ease, box-shadow .25s ease;
}
.div-card:hover{ transform:translateY(-4px); border-color:var(--blue); box-shadow:var(--glow-blue); }
.div-card .idx{ font-family:var(--font-tech); font-size:.72rem; letter-spacing:.2em;
  color:var(--ink-faint); }
.div-card h3{ font-size:1.5rem; margin:.2rem 0 .1rem; color:var(--ink); }
.div-card .wt{ font-family:var(--font-display); font-weight:800; font-size:1.9rem;
  background:linear-gradient(180deg,var(--amber),var(--orange));
  -webkit-background-clip:text; background-clip:text; color:transparent; line-height:1; }
.div-card .wt small{ font-family:var(--font-tech); font-size:.7rem; letter-spacing:.1em;
  -webkit-text-fill-color:var(--ink-faint); display:block; margin-top:.3rem; }
.div-card .badges{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:1rem; }
.badge{ font-family:var(--font-tech); font-size:.66rem; font-weight:600; letter-spacing:.12em;
  text-transform:uppercase; padding:.3em .7em; border-radius:2px; }
.badge.plastic{ color:var(--blue); border:1px solid rgba(43,184,240,.4); background:rgba(43,184,240,.08); }
.badge.open{ color:var(--amber); border:1px solid rgba(255,196,0,.35); background:rgba(255,196,0,.07); }
.div-card .note{ font-size:.86rem; color:var(--ink-dim); margin-top:.9rem; }

.plastic-rule{ margin-top:1.6rem; display:flex; gap:1rem; align-items:flex-start;
  border-left:3px solid var(--blue); background:rgba(43,184,240,.05);
  padding:1.1rem 1.3rem; border-radius:0 var(--radius) var(--radius) 0; }
.plastic-rule .big{ font-family:var(--font-display); font-weight:900; font-size:2.2rem;
  color:var(--blue); line-height:1; }
.plastic-rule p{ font-size:.95rem; color:var(--ink-dim); }
.plastic-rule b{ color:var(--ink); }

/* ---------- events placeholder ---------- */
.event-card{ text-align:center; border:1px dashed var(--line); border-radius:var(--radius);
  padding:2.6rem 1.5rem; background:rgba(255,255,255,.015); }
.event-card .tag{ font-family:var(--font-tech); letter-spacing:.2em; text-transform:uppercase;
  color:var(--orange); font-size:.8rem; }
.event-card h3{ color:var(--ink); margin:.6rem 0 .8rem; font-size:2rem; }

/* ---------- info lists / steps ---------- */
.steps{ counter-reset:s; display:grid; gap:1.1rem; }
.steps li{ list-style:none; display:flex; gap:1rem; align-items:flex-start; }
.steps li::before{ counter-increment:s; content:counter(s,decimal-leading-zero);
  font-family:var(--font-display); font-weight:800; font-size:1.2rem; color:var(--blue);
  background:var(--panel); border:1px solid var(--line); width:42px; height:42px; flex:none;
  display:grid; place-items:center; border-radius:3px; }
.steps li b{ color:var(--ink); }

.checklist{ display:grid; gap:.7rem; }
.checklist li{ list-style:none; display:flex; gap:.7rem; align-items:flex-start; color:var(--ink-dim); }
.checklist li::before{ content:"▹"; color:var(--blue); font-weight:700; flex:none; margin-top:.05em; }

.linklist{ display:grid; gap:.8rem; }
.linklist a{ display:flex; justify-content:space-between; align-items:center; gap:1rem;
  padding:.95rem 1.1rem; background:var(--panel); border:1px solid var(--line); border-radius:3px;
  color:var(--ink); transition:.2s; }
.linklist a:hover{ border-color:var(--blue); color:var(--blue); transform:translateX(4px); }
.linklist a span{ font-size:.82rem; color:var(--ink-faint); font-family:var(--font-tech); }
.linklist a:hover span{ color:var(--blue); }

/* ---------- callout / rules pdf ---------- */
.callout{ display:flex; flex-direction:column; align-items:flex-start; gap:1.3rem;
  background:linear-gradient(120deg,var(--panel-2),var(--panel)); border:1px solid var(--line);
  border-left:4px solid var(--orange); border-radius:var(--radius); padding:1.6rem 1.8rem; }
.callout .txt h3{ color:var(--ink); }
.callout .txt p{ color:var(--ink-dim); font-size:.95rem; margin-top:.3rem; }

/* ---------- form ---------- */
.form{ display:grid; gap:1.1rem; }
.field{ display:grid; gap:.4rem; }
.field label{ font-family:var(--font-tech); font-size:.78rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ink-dim); }
.field input,.field textarea,.field select{
  font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:var(--bg-2); border:1px solid var(--line); border-radius:3px;
  padding:.85rem 1rem; transition:border-color .2s, box-shadow .2s; width:100%;
}
.field select{ appearance:none; -webkit-appearance:none; cursor:pointer;
  background-image:linear-gradient(45deg,transparent 50%,var(--ink-dim) 50%),linear-gradient(135deg,var(--ink-dim) 50%,transparent 50%);
  background-position:calc(100% - 18px) 1.25rem, calc(100% - 13px) 1.25rem;
  background-size:5px 5px,5px 5px; background-repeat:no-repeat; padding-right:2.4rem; }
.field .opt{ text-transform:none; letter-spacing:0; color:var(--ink-faint); font-weight:400; font-size:.72rem; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(43,184,240,.15); }
.field textarea{ resize:vertical; min-height:140px; }

.contact-grid{ display:grid; grid-template-columns:1.3fr .9fr; gap:2.5rem; align-items:start; }
@media (max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-line{ display:flex; gap:.9rem; align-items:flex-start; padding:1.1rem 0; border-bottom:1px solid var(--line); }
.contact-line .ic{ width:40px; height:40px; flex:none; display:grid; place-items:center;
  border:1px solid var(--line); border-radius:3px; color:var(--blue); font-size:1.2rem;
  background:var(--panel); }
.contact-line .ic.fb{ color:#fff; background:#1877F2; border-color:#1877F2; }
.contact-line h4{ font-family:var(--font-tech); font-size:.78rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-dim); font-weight:600; }
.contact-line a,.contact-line p{ color:var(--ink); font-size:1.02rem; word-break:break-word; }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--line); background:var(--bg-2); padding:3rem 0 2rem;
  margin-top:2rem; }
.foot-grid{ display:flex; flex-wrap:wrap; gap:2rem; justify-content:space-between; align-items:flex-start; }
.foot-brand .name{ font-family:var(--font-display); font-weight:900; font-size:1.4rem;
  text-transform:uppercase; }
.foot-brand p{ color:var(--ink-faint); font-size:.9rem; margin-top:.5rem; max-width:34ch; }
.foot-nav{ display:flex; flex-wrap:wrap; gap:.4rem 1.4rem; }
.foot-nav a{ font-family:var(--font-tech); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-dim); }
.foot-nav a:hover{ color:var(--blue); }
.foot-bottom{ margin-top:2.4rem; padding-top:1.4rem; border-top:1px solid var(--line);
  display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; justify-content:space-between;
  font-size:.8rem; color:var(--ink-faint); font-family:var(--font-tech); letter-spacing:.06em; }
.foot-bottom .ph{ color:var(--orange); }

/* ---------- scroll reveal (progressive enhancement) ----------
   Without JS the .js class is never added, so content stays fully
   visible. With JS, elements start hidden and animate in on scroll. */
.reveal{ transition:opacity .7s ease, transform .7s ease; }
html.js .reveal{ opacity:0; transform:translateY(24px); }
html.js .reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  html.js .reveal{ opacity:1; transform:none; }
}

/* ---------- sponsor strip ---------- */
.sponsor-strip{ text-align:center; padding:2.6rem 0; border-top:1px solid var(--line);
  border-bottom:1px solid var(--line); background:var(--bg-2); }
.sponsor-strip .eyebrow{ justify-content:center; color:var(--ink-faint); }
.sponsor-strip .eyebrow::before{ display:none; }
.sponsor-lockup{ display:inline-flex; align-items:center; gap:.5rem; margin-top:.4rem;
  text-decoration:none; }
/* text placeholder styled like the RSFPV badge — swap for official logo <img> when supplied */
.sponsor-lockup .rsfpv{
  font-family:var(--font-display); font-weight:900; font-style:italic; font-size:1.5rem;
  letter-spacing:1px; color:var(--orange); padding:.25em .7em; border:2px solid var(--orange);
  border-radius:6px; text-transform:uppercase; line-height:1;
  text-shadow:0 1px 0 rgba(0,0,0,.4); transition:.2s;
}
.sponsor-lockup:hover .rsfpv{ background:rgba(255,122,26,.1); box-shadow:0 0 18px -4px rgba(255,122,26,.6); }
.sponsor-lockup img{ max-height:54px; width:auto; }

/* prose helper for content pages */
.prose p{ color:var(--ink-dim); margin-bottom:1rem; max-width:68ch; }
.prose p:last-child{ margin-bottom:0; }
.prose strong{ color:var(--ink); }
.stack{ display:grid; gap:1.6rem; }
.note-line{ font-size:.86rem; color:var(--ink-faint); font-family:var(--font-tech); letter-spacing:.04em; }

/* ===== Weight-class "Coming Soon" badge + hover/focus reveal strip ===== */
.div-card .idx .soon{ display:inline-block; margin-left:.5rem; font-family:var(--font-tech);
  font-size:.58rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--amber);
  border:1px solid rgba(255,196,0,.4); background:rgba(255,196,0,.08);
  padding:.18em .5em; border-radius:2px; vertical-align:middle; }

.class-detail{ display:none; margin-top:1.4rem; border-left:3px solid var(--orange);
  background:rgba(255,122,26,.06); border-radius:0 var(--radius) var(--radius) 0;
  padding:1.2rem 1.4rem; }
.class-detail.show{ display:block; animation:cdfade .25s ease; }
@keyframes cdfade{ from{ opacity:0; transform:translateY(-5px); } to{ opacity:1; transform:none; } }
.class-detail .cd-panel{ display:none; }
.class-detail[data-active="01"] .cd-panel[data-for="01"],
.class-detail[data-active="02"] .cd-panel[data-for="02"],
.class-detail[data-active="03"] .cd-panel[data-for="03"],
.class-detail[data-active="04"] .cd-panel[data-for="04"]{ display:block; }
.cd-panel h4{ font-size:1.2rem; color:var(--orange); margin-bottom:.55rem; }
.cd-panel h4 .cd-wt{ font-family:var(--font-tech); font-weight:600; font-size:.62rem;
  letter-spacing:.16em; color:var(--ink-faint); margin-left:.6rem; }
.cd-panel p{ font-size:.92rem; line-height:1.6; color:var(--ink-dim); margin-bottom:.7rem; }
.cd-panel p:last-child{ margin-bottom:0; }
.cd-soonbanner{ text-align:center; font-family:var(--font-display); font-weight:900; font-size:1.4rem;
  letter-spacing:.18em; text-transform:uppercase; margin-bottom:.9rem;
  background:linear-gradient(180deg,var(--amber),var(--orange));
  -webkit-background-clip:text; background-clip:text; color:transparent; }

/* anchor targets clear the sticky header when jumped to */
section[id]{ scroll-margin-top:86px; }

/* "What is combat robotics?" — text + animation split */
.about-split{ display:grid; grid-template-columns:1.05fr .95fr; gap:2rem; align-items:center; }
.about-split .about-text > p:last-child{ margin-bottom:0; }
.about-media img{ width:100%; height:auto; display:block; border-radius:6px;
  border:1px solid var(--line); box-shadow:0 6px 22px rgba(0,0,0,.4); }
@media (max-width:820px){ .about-split{ grid-template-columns:1fr; } }

.about-media .media-credit{ margin:.55rem 0 0; text-align:center; color:#fff;
  font-family:var(--font-tech); font-size:.7rem; letter-spacing:.04em; opacity:.85; }

/* events: two-column cards with left label */
.event-card.ev-split{ display:flex; gap:2rem; align-items:center; text-align:left; padding:2rem 2rem; }
.event-card .ev-label{ flex:0 0 24%; font-family:var(--font-display); font-weight:900;
  font-size:2.4rem; line-height:.9; text-transform:uppercase; color:var(--ink);
  border-right:1px solid var(--line); padding-right:1.6rem; }
.event-card .ev-body{ flex:1; }
.event-card.ev-split h3{ margin:.45rem 0 .7rem; }
.event-card.ev-split .cta{ justify-content:flex-start; }
@media (max-width:760px){
  .event-card.ev-split{ flex-direction:column; gap:1.1rem; align-items:stretch; text-align:center; }
  .event-card .ev-label{ flex-basis:auto; border-right:0; border-bottom:1px solid var(--line);
    padding:0 0 .9rem; font-size:1.9rem; }
  .event-card.ev-split .cta{ justify-content:center; }
}
