/* ===========================================================
   PMS LIVE — design system extracted from Figma "PMS Live"
   Colors / type / spacing reproduced 1:1 from the mock-up
   =========================================================== */
:root{
  --bg:#0a0a0a;
  --bg-alt:#161616;
  --bg-darkred:#0f0005;
  --red:#c0000a;
  --red-20:rgba(192,0,10,.20);
  --red-10:rgba(192,0,10,.10);
  --text:#f5f5f0;
  --text-80:rgba(245,245,240,.80);
  --text-70:rgba(245,245,240,.70);
  --text-50:rgba(245,245,240,.50);
  --line:rgba(245,245,240,.12);

  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --display:'Bebas Neue',Impact,sans-serif;
  --heading:'Oswald',sans-serif;

  --maxw:1440px; /* Figma frame 1440 = 1280 content + 80 padding each side */
  --pad:80px;
}

*{box-sizing:border-box;margin:0;padding:0}
/* overflow-x:clip locks horizontal scroll WITHOUT breaking the sticky
   header (unlike overflow:hidden which would create a scroll container).
   Stops the torn-paper seams (drawn a bit wider than the viewport) from
   letting the page drift sideways. */
/* hidden attribute must win over any display:flex/.block set by component classes */
[hidden]{display:none!important}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--mono);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
  max-width:100%;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
ul{list-style:none}

.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);width:100%}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--display);font-weight:400;
  text-transform:uppercase;cursor:pointer;border:none;
  transition:transform .15s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--red);color:var(--text)}
.btn--primary:hover{background:#000;color:var(--text)}
.btn--outline{background:transparent;color:var(--red);border:2px solid var(--red)}
.btn--outline:hover{background:var(--red);color:var(--text)}
.btn--ghost{background:transparent;color:var(--red);border:2px solid var(--red)}
.btn--ghost:hover{background:var(--red);color:var(--text)}
.btn--lg{height:64px;padding:0 40px;font-size:24px;letter-spacing:1.2px}
.btn--md{height:48px;padding:0 20px;font-size:18px;letter-spacing:1px}
.btn--sm{height:40px;padding:0 16px;font-size:16px;letter-spacing:.5px}
.btn--block{width:100%}

/* ---------- Header ---------- */
.header{
  position:sticky;top:0;z-index:100;
  height:80px;background:var(--bg);
  border-bottom:1px solid var(--red);
}
.header__inner{
  height:80px;display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
}
.logo{display:flex;align-items:center;height:48px}
.logo img{height:48px;width:auto}
.nav{display:flex;align-items:center;gap:32px}
.nav a{font-family:var(--mono);font-size:14px;line-height:18px;letter-spacing:.7px;
  text-transform:uppercase;color:var(--text);transition:color .2s}
.nav a:hover,.nav a.active{color:var(--red)}
.header__cta{display:flex;align-items:center;gap:12px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{display:block;width:24px;height:2px;background:var(--text);transition:.25s}

/* ---------- Mobile nav overlay (Figma "Navigation" 390 frame) ---------- */
.mobile-nav{
  position:fixed;inset:0;z-index:250;background:var(--bg);
  opacity:0;visibility:hidden;pointer-events:none;
  overflow:hidden;overscroll-behavior:none;
  transition:opacity .25s ease,visibility .25s ease;
}
.mobile-nav.open{opacity:1;visibility:visible;pointer-events:auto}
.mobile-nav__head{
  position:absolute;top:0;left:0;right:0;
  height:80px;padding:16px 24px;box-sizing:border-box;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--red);
}
.mobile-nav__close{
  width:32px;height:32px;padding:0;border:none;background:none;
  color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
}
/* 80px header + 48px gap (Figma mobile feel — laconic, not centered) */
.mobile-nav__links{
  position:absolute;top:128px;left:0;right:0;
  display:flex;flex-direction:column;align-items:center;
  gap:8px;padding:0 24px;margin:0;
}
.mobile-nav__links a{
  font-family:var(--display);font-size:60px;line-height:72px;letter-spacing:3.6px;
  color:var(--text);text-transform:none;
}
body.mobile-nav-open{overflow:hidden;position:fixed;inset:0;width:100%}
html.mobile-nav-open{overflow:hidden}

.marquee{background:var(--red);overflow:hidden;height:44px;display:flex;align-items:center}
.marquee--dark{background:var(--bg-alt)}
.marquee__track{display:flex;white-space:nowrap;animation:marquee 30s linear infinite;will-change:transform}
.marquee__track span{
  font-family:var(--mono);font-size:14px;line-height:20px;letter-spacing:4.2px;
  text-transform:uppercase;color:var(--text);padding-right:0;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Sections ---------- */
.section{padding:100px 0;position:relative;isolation:isolate}
.section--alt{background:var(--bg-alt)}
/* texture = #0a0a0a base + d11ddf41 LINEAR_BURN @50% (dark, very subtle) */
.section--texture{background-color:var(--bg)}
.section--texture::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:url(../img/d11ddf41dad5ca327f4091eb1c5edc1127bd1e43.png) center/cover;
  mix-blend-mode:multiply;opacity:.5}
.section--darkred{background:var(--bg-darkred)}
/* big faint index number — background watermark BEHIND eyebrow + heading */
.section__index{
  position:absolute;left:var(--pad);top:100px;
  font-family:var(--display);font-size:128px;line-height:128px;color:var(--text);
  opacity:.10;pointer-events:none;z-index:1;
}
.eyebrow{font-family:var(--mono);font-size:14px;line-height:20px;color:var(--red);
  letter-spacing:1.4px;text-transform:uppercase}
.section__head{position:relative;z-index:2;margin-bottom:48px}
.section>.container{position:relative;z-index:2}

/* big display headings */
.display{font-family:var(--display);font-weight:400;line-height:1;text-transform:uppercase}
.display--128{font-size:128px;letter-spacing:6.4px}
.display--96{font-size:96px;letter-spacing:4.8px}
.display--72{font-size:72px}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:684px;display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding:100px var(--pad)}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
/* Figma hero: black + red 10% diagonal glass; darkened strongly so white title stays legible */
.hero__overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top right, rgba(0,0,0,0) 0 3%, rgba(192,0,10,.10) 3%), rgba(0,0,0,.72)}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw)}
/* Home hero photos differ desktop vs mobile (separate Figma frames).
   Figma image fill has filters.saturation=-1 -> grayscale */
.hero--home .hero__bg{background:#1d1d1d url(../img/88a59962482932622f03fdb8c9495fe606279ae3.png) center/cover no-repeat;filter:grayscale(1)}
.hero__title{font-family:var(--display);font-weight:400;font-size:128px;line-height:160px;
  letter-spacing:6.4px;text-transform:uppercase;color:var(--text)}
.hero__sub{font-family:var(--mono);font-size:20px;line-height:28px;color:var(--red);margin:24px 0}
.hero__btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:0;padding-top:0}

/* ---------- Cards (Latest actions) ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
/* Figma card stroke: ONLY a 4px red top bar, no side/bottom borders */
.card{background:var(--bg);border:none;border-top:4px solid var(--red);display:flex;flex-direction:column;
  transition:transform .2s ease}
.card:hover{transform:translateY(-4px)}
/* Figma action photos are grayscale (saturation -1) */
.card__img{aspect-ratio:302/192;background:#1d1d1d center/cover no-repeat;position:relative;filter:grayscale(1)}
.card__body{padding:24px;display:flex;flex-direction:column;gap:8px;flex:1}
.card__date{font-family:var(--mono);font-size:12px;line-height:16px;color:var(--red)}
.card__title{font-family:var(--display);font-size:24px;line-height:32px;letter-spacing:1.2px;text-transform:uppercase}
.card__loc{font-family:var(--mono);font-size:12px;line-height:16px;letter-spacing:.6px;text-transform:uppercase;color:var(--red)}
.link-arrow{font-family:var(--mono);font-size:16px;line-height:21px;letter-spacing:.7px;text-transform:uppercase;color:var(--red);display:inline-flex;gap:8px;transition:gap .2s}
.link-arrow:hover{gap:14px}

/* ---------- Torn paper seam (Figma "Paper 52" between sec 01/02) ---------- */
.paper-seam{position:relative;height:0;z-index:6;overflow:visible}
.paper-seam::before,.paper-seam::after{content:"";position:absolute;left:50%;
  top:-45px;width:calc(100% + 80px);height:124px;
  background:url(../img/paper_seam.png) center/100% 100% no-repeat;pointer-events:none}
/* ::before = right half visible; ::after = left half (mirrored X) fills the gap */
.paper-seam::before{transform:translateX(-50%)}
.paper-seam::after{transform:translateX(-50%) scaleX(-1)}
/* torn edge pointing DOWN (rip bites into the lighter section below) */
.paper-seam--down::before{transform:translateX(-50%) scaleY(-1)}
.paper-seam--down::after{transform:translateX(-50%) scaleX(-1) scaleY(-1)}

/* ---------- Who we are ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
/* VerticalBorder: 72px tall red line; text TOP-aligned (Figma counterAxis=MIN) so line runs below the text */
.quote{height:72px;display:flex;align-items:flex-start;
  border-left:2px solid var(--red);padding-left:12px;
  font-family:var(--display);font-weight:400;font-size:30px;line-height:36px;white-space:nowrap}
.lead{font-family:var(--mono);font-size:16px;color:var(--text-80);max-width:883px;line-height:26px}

/* WHO WE ARE photo collage (Figma: lead top-left, tall photo right, two below)
   1280 content: cols 323/323/455, ~89px (6.95%) gaps, photos bottom-aligned */
.who-collage{display:grid;grid-template-columns:323fr 323fr 455fr;
  grid-template-rows:minmax(165px,auto) 408px;column-gap:6.95%;align-items:end;margin-top:48px}
.who-collage__lead{grid-column:1 / 3;grid-row:1;align-self:start;margin:0;max-width:none}
.who-collage__a{grid-column:3;grid-row:1 / 3}
.who-collage__b{grid-column:2;grid-row:2}
.who-collage__c{grid-column:1;grid-row:2}
.who-photo{width:100%;height:100%;background:#1d1d1d center/cover no-repeat;position:relative}
/* Figma overlay: red #c0000a 20% on top (fill[4]) + black 20% below (fill[3]) – blend=NORMAL */
.who-photo::after{content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(rgba(192,0,10,.20),rgba(192,0,10,.20)),
    linear-gradient(rgba(0,0,0,.20),rgba(0,0,0,.20))}

/* ---------- Merch / shop teaser ---------- */
.merch{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.merch__head{font-size:96px;letter-spacing:4.8px;line-height:1;margin-bottom:24px}
.merch__imgs{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
/* tiles are flat PNGs rendered from Figma (grayscale + red wash + skull print baked in 1:1) */
.merch__imgs .ph{aspect-ratio:296/192;background:#1d1d1d center/cover no-repeat;position:relative}
.merch__imgs .ph:nth-child(2){margin-top:56px}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}
.stat{display:flex;flex-direction:column;gap:8px;align-items:center}
.stat__num{font-family:var(--display);font-size:72px;line-height:72px;display:flex;align-items:center;justify-content:center;height:72px}
/* Figma infinity glyph ~47px wide, crossed figure-8 (bold loops, pinched centre) */
.stat__inf{width:48px;height:auto;color:var(--text);display:block}
.stat__label{font-family:var(--mono);font-size:14px;line-height:20px;letter-spacing:.7px;text-transform:uppercase;color:var(--red)}

/* ---------- CTA ---------- */
.cta{text-align:center}
.cta .display{margin-bottom:24px}
.cta__text{max-width:768px;margin:0 auto 32px;color:var(--text-80);font-size:16px}

/* ---------- Footer ---------- */
.footer{background:var(--bg);border-top:1px solid var(--red);padding:64px 0 32px}
.footer__top{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;padding-bottom:0}
.footer__brand{padding-right:48px}
.footer__brand .logo{margin-bottom:16px;height:43px}
.footer__brand .logo img{height:43px}
.footer__brand p{color:var(--text-70);font-family:var(--mono);font-size:14px;line-height:23px;white-space:pre-line}
.footer h4{font-family:var(--heading);font-weight:700;font-size:16px;line-height:24px;color:var(--red);text-transform:uppercase;margin-bottom:16px;letter-spacing:.8px}
.footer__nav{display:flex;flex-direction:column;gap:8px}
.footer__nav a{font-family:var(--mono);font-size:14px;line-height:18px;letter-spacing:.7px;text-transform:uppercase;color:var(--text);transition:color .2s}
.footer__nav a:hover{color:var(--red)}
.footer__social{display:flex;gap:16px;margin-bottom:24px}
.footer__social a{width:24px;height:24px;display:flex}
.footer__social img{width:24px;height:24px;filter:brightness(0) invert(1);opacity:.8;transition:opacity .2s}
.footer__social a:hover img{opacity:1}
.footer__bottom{border-top:1px solid #2a2a2a;margin-top:48px;padding-top:32px;text-align:center}
.footer__bottom p{font-family:var(--mono);font-size:12px;line-height:16px;color:var(--text-50)}

/* ---------- About: split hero (720|720, 630h) ---------- */
.split-hero{display:grid;grid-template-columns:1fr 1fr;min-height:630px}
.split-hero__left{display:flex;align-items:center;justify-content:center;padding:48px 48px 48px 80px;background:var(--bg)}
.split-hero__left .display{font-size:128px;line-height:128px;letter-spacing:6.4px;text-align:left}
.split-hero__right{position:relative;background:#1d1d1d;overflow:hidden}
.split-hero__photo{position:absolute;inset:0;background:center/cover no-repeat;
  background-image:url(../img/f558e59cf838a5e9c3c6aa9d6e093d9164f955e6.png)}
.split-hero__right::after{content:"";position:absolute;inset:0;background:var(--red-20)}

/* ---------- Manifesto ---------- */
.manifesto{position:relative;overflow:hidden}
.manifesto .container{position:relative;z-index:1}
.manifesto__inner{max-width:896px;margin:0 auto;position:relative}
.manifesto__watermark{position:absolute;left:50%;top:240px;transform:translate(-50%,-50%);
  font-family:var(--display);font-size:320px;line-height:1;color:var(--red);opacity:.10;
  white-space:nowrap;pointer-events:none;z-index:0}
.manifesto__inner .eyebrow{position:relative;z-index:1;display:block;margin-bottom:48px}
.manifesto__list{position:relative;z-index:1}
.manifesto__list{display:flex;flex-direction:column;gap:48px}
.manifesto__item{display:grid;grid-template-columns:60px 1fr;border-top:1px solid var(--red);padding-top:32px}
.manifesto__num{font-family:var(--display);font-size:36px;line-height:40px;color:var(--red)}
.manifesto__item h3{font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:12px}
.manifesto__item p{color:var(--text-80);font-size:16px;line-height:26px}

/* ---------- How we began (alternating text/photo) ---------- */
.history{display:flex;flex-direction:column;gap:64px}
/* Figma: row 777px text + 48px gap + 455px photo; counterAxisAlignItems=CENTER */
.history__row{display:grid;gap:48px;align-items:center}
.history__row:nth-child(odd){grid-template-columns:777fr 455fr}
.history__row:nth-child(even){grid-template-columns:455fr 777fr}
.history__text h3{font-family:var(--display);font-size:36px;line-height:43px;letter-spacing:1.8px;text-transform:uppercase;color:var(--text);margin-bottom:16px}
.history__text p{color:var(--text-80);font-size:16px;line-height:26px}
/* Figma: photo container 455x573 (portrait) – color photo + black 20% + red 20% overlay */
.history__img{aspect-ratio:455/573;background:#1d1d1d;position:relative;overflow:hidden}
.history__photo{position:absolute;inset:0;background:center/cover no-repeat}
.history__img::after{content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(rgba(192,0,10,.20),rgba(192,0,10,.20)),
    linear-gradient(rgba(0,0,0,.20),rgba(0,0,0,.20))}

/* ---------- Values grid (6 cards, 4px red top bar) ---------- */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value{background:#141414;border-top:4px solid var(--red);padding:32px;display:flex;flex-direction:column;gap:15px}
.value h3{font-family:var(--display);font-size:24px;line-height:28.8px;letter-spacing:1.2px;text-transform:uppercase;color:var(--text)}
.value p{color:var(--text-70);font-size:14px;line-height:22.75px}

/* ---------- Support strip (red, 160 side padding) ---------- */
.support-strip{background:var(--red);display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:64px 160px}
.support-strip__img{aspect-ratio:536/302;background:#1d1d1d center/cover no-repeat;position:relative}
.support-strip__img::after{content:"";position:absolute;inset:0;background:var(--red-20)}
.support-strip h2{font-family:var(--display);font-size:48px;line-height:48px;letter-spacing:2.4px;text-transform:uppercase;margin-bottom:24px}
.support-strip p{color:var(--text-80);margin-bottom:24px;font-size:16px;line-height:26px}
.btn--white{background:var(--text);color:var(--red)}
.btn--white:hover{background:#fff}

/* ---------- Filter chips ---------- */
.chips{display:flex;gap:12px;flex-wrap:wrap}
.chip{height:48px;padding:0 20px;display:inline-flex;align-items:center;font-family:var(--display);
  font-size:18px;text-transform:uppercase;letter-spacing:1px;border:2px solid var(--red);
  color:var(--red);background:transparent;cursor:pointer;transition:.2s}
.chip:hover{background:var(--red);color:var(--text)}
.chip.active{background:var(--red);border-color:var(--red);color:var(--text)}

/* ---------- Big action cards (628x506, 2-col) ---------- */
.actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.action-card{background:#141414;border:none;display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s}
.action-card:hover{transform:translateY(-4px);box-shadow:0 0 0 1px var(--red)}
.action-card__img{aspect-ratio:628/320;background:#1d1d1d center/cover no-repeat;filter:grayscale(1)}
.action-card__body{padding:24px;display:flex;flex-direction:column;gap:8px}
.action-card__date{font-family:var(--mono);font-size:12px;color:var(--red);text-transform:uppercase}
.action-card__title{font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;text-transform:uppercase}
.action-card__loc{font-family:var(--mono);font-size:12px;color:var(--red);text-transform:uppercase;letter-spacing:.6px}
.action-card__desc{font-family:var(--mono);font-size:14px;line-height:22.75px;color:var(--text-70);white-space:pre-line}

/* ---------- Article (Actions Inner) — content column 960, 240px gutters ---------- */
.article{max-width:960px;margin:0 auto;padding:0 var(--pad)}
.article-hero .article{display:flex;flex-direction:column;align-items:flex-start}
.back-link{font-family:var(--mono);font-size:16px;line-height:20.8px;letter-spacing:.7px;text-transform:uppercase;color:var(--red);display:inline-block;margin-bottom:24px}
.back-link:hover{opacity:.8}
.article-meta{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:24px;font-family:var(--mono);font-size:14px;color:var(--text)}
.meta-item{display:inline-flex;align-items:center;gap:10px;letter-spacing:.6px;text-transform:uppercase}
.meta-icon{width:20px;height:20px;color:var(--red);flex:0 0 auto}
.article-hero__title{font-family:var(--display);font-size:128px;line-height:128px;letter-spacing:6.4px;text-transform:uppercase;margin-bottom:12px}
.badge{display:inline-flex;align-items:center;height:48px;padding:0 20px;background:var(--red);
  color:var(--text);font-family:var(--display);font-size:18px;letter-spacing:1px;text-transform:uppercase}
.featured-img{display:block;width:100%;aspect-ratio:960/489;object-fit:cover;background:#1d1d1d;filter:grayscale(1);margin-top:36px}
.prose__lead{font-family:var(--mono);font-size:18px;line-height:23.4px;color:var(--text-70)}
.article-block{margin-top:64px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.block-title{font-family:var(--display);font-size:36px;line-height:43px;letter-spacing:1.8px;text-transform:uppercase;color:var(--red);margin-bottom:24px}
.checklist{display:flex;flex-direction:column;gap:16px}
.checklist li{display:grid;grid-template-columns:auto 1fr;gap:12px;font-family:var(--mono);font-size:16px;line-height:26px;color:var(--text-80)}
.checklist .tick{color:var(--red);font-weight:700}
.timeline{display:flex;flex-direction:column;gap:16px;border-left:2px solid var(--red);padding-left:24px}
.timeline__row{display:flex;flex-direction:column;gap:8px}
.timeline__time{font-family:var(--mono);font-weight:700;font-size:16px;line-height:26px;color:var(--red)}
.timeline__row p{font-family:var(--mono);color:var(--text-80);font-size:16px;line-height:26px}
.ground-quotes{display:flex;flex-direction:column;gap:16px}
.ground-quote{background:var(--bg);border-left:2px solid var(--red);padding:24px}
.ground-quote blockquote{font-family:var(--mono);font-size:16px;line-height:26px;color:var(--text);margin:0 0 8px}
.ground-quote cite{font-family:var(--mono);font-size:16px;line-height:26px;color:var(--red);font-style:normal;text-transform:uppercase}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.related-card{background:var(--bg);border-top:4px solid var(--red);display:flex;flex-direction:column;
  overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.related-card:hover{transform:translateY(-6px);box-shadow:0 12px 28px rgba(0,0,0,.5),0 0 0 1px var(--red)}
.related-card__img{aspect-ratio:304/192;background:#1d1d1d center/cover no-repeat;filter:grayscale(1);
  transition:transform .4s ease,filter .4s ease}
.related-card:hover .related-card__img{transform:scale(1.06);filter:grayscale(0)}
.related-card__title{transition:color .3s ease}
.related-card:hover .related-card__title{color:var(--red)}
.related-card__body{padding:24px;display:flex;flex-direction:column;gap:8px}
.related-card__date{font-family:var(--mono);font-size:12px;color:var(--red)}
.related-card__title{font-family:var(--display);font-size:24px;line-height:32px;letter-spacing:1.2px;text-transform:uppercase}
.related-card__loc{font-family:var(--mono);font-size:12px;color:var(--red);letter-spacing:.6px;text-transform:uppercase}
.article-cta{text-align:center;padding:64px var(--pad)}
.article-cta h2{font-family:var(--display);font-size:48px;line-height:48px;letter-spacing:2.4px;text-transform:uppercase;margin-bottom:24px}
.article-cta p{font-family:var(--mono);font-size:16px;line-height:26px;color:var(--text-80);max-width:682px;margin:0 auto 32px}

/* ---------- Shop ---------- */
.shop-hero{background:#141414;padding:100px 0;text-align:center;position:relative}
.shop-hero .display{margin-bottom:24px}
.shop-hero .eyebrow{font-size:20px;line-height:28px;display:block;margin-bottom:24px;color:var(--red)}
.shop-hero p{max-width:800px;margin:0 auto;color:var(--text);font-size:18px;line-height:28px}
.products{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.product{background:#141414;display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease}
.product:hover{transform:translateY(-4px);box-shadow:0 0 0 1px var(--red)}
.product__img{aspect-ratio:302/300;background:#1d1d1d center/cover no-repeat;filter:grayscale(1);overflow:hidden}
.product__body{padding:24px;display:flex;flex-direction:column;gap:16px;flex:1}
.product__add{height:48px;background:var(--red);color:var(--text);width:100%;
  border:none;font-family:var(--display);font-size:18px;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:background .2s}
.product__add:hover{background:#d8000c}
.product__title{font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;text-transform:uppercase}
.product__desc{font-family:var(--mono);font-size:12px;color:var(--text-70);line-height:16px}
.product__price{font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;color:var(--red)}
.product__size-label{font-family:var(--mono);font-size:12px;line-height:15.6px;color:var(--text)}
.sizes{display:flex;gap:8px;flex-wrap:wrap}
.size{height:32px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--red);background:transparent;color:var(--red);
  font-family:var(--display);font-size:12px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:.15s}
.size:hover,.size.active{background:var(--red);color:var(--text)}

/* shop bottom CTA (red band) */
.shop-cta{background:var(--red);text-align:center;padding:64px var(--pad)}
.shop-cta h2{font-family:var(--display);font-size:48px;line-height:48px;letter-spacing:2.4px;text-transform:uppercase;margin-bottom:24px}
.shop-cta p{font-family:var(--mono);font-size:18px;line-height:28px;color:var(--text);max-width:752px;margin:0 auto}
/* cart icon in shop hero (lower-right, below the paragraph) */
.cart-icon{position:fixed;right:24px;bottom:24px;z-index:150;
  width:56px;height:56px;border-radius:50%;background:var(--red);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:transform .2s;
  box-shadow:0 6px 20px rgba(0,0,0,.45)}
.cart-icon:hover{transform:scale(1.06)}
.cart-icon svg{width:24px;height:24px;stroke:#fff}
.cart-icon__badge{position:absolute;top:-6px;right:-6px;min-width:24px;height:24px;border-radius:50%;
  background:#fff;color:var(--red);font-family:var(--mono);font-size:14px;font-weight:500;
  display:flex;align-items:center;justify-content:center;padding:0 5px}

/* slide-out cart drawer (fixed window sliding from the right) */
.cart-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:200}
.cart-drawer-overlay.open{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:#0a0a0a;
  border-left:1px solid #2a2a2a;transform:translateX(100%);transition:transform .3s ease;z-index:201;
  display:flex;flex-direction:column}
.cart-drawer.open{transform:translateX(0)}
.cart-drawer__head{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;
  border-bottom:1px solid #2a2a2a}
.cart-drawer__head h3{font-family:var(--display);font-size:36px;line-height:1;letter-spacing:1.8px;text-transform:uppercase}
.cart-drawer__close{background:none;border:none;color:var(--text);font-size:32px;line-height:1;cursor:pointer}
.cart-drawer__close:hover{color:var(--red)}
.cart-drawer__items{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:16px}
.cart-drawer__empty{font-family:var(--mono);font-size:14px;color:var(--text-70);padding:24px 0}
.drawer-item{display:grid;grid-template-columns:72px 1fr;gap:16px;background:#141414;padding:16px}
.drawer-item__img{width:72px;aspect-ratio:1/1;background:#1d1d1d center/cover no-repeat;filter:grayscale(1)}
.drawer-item__body{display:flex;flex-direction:column;gap:6px}
.drawer-item__title{font-family:var(--display);font-size:22px;line-height:1;letter-spacing:1px;text-transform:uppercase}
.drawer-item__meta{font-family:var(--mono);font-size:12px;color:var(--text-70)}
.drawer-item__price{font-family:var(--display);font-size:20px;letter-spacing:1px;color:var(--red)}
.drawer-item__row{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.cart-drawer__foot{padding:20px 24px 24px;border-top:1px solid #2a2a2a;display:flex;flex-direction:column;gap:16px}
.cart-drawer__foot .btn{width:100%;height:56px;font-size:22px;letter-spacing:1px}

/* ---------- Cart ---------- */
.cart-head{padding:64px 0}
.cart-head h1{font-family:var(--display);font-size:128px;line-height:128px;letter-spacing:6.4px;text-transform:uppercase}
.cart-layout{display:grid;grid-template-columns:1fr 400px;gap:64px;align-items:start;padding-bottom:100px}
.cart-item{background:#141414;border-left:2px solid var(--red);padding:24px 36px;
  display:grid;grid-template-columns:121px 1fr;grid-template-areas:"img info" "img row";
  column-gap:24px;row-gap:16px;align-items:start;margin-bottom:24px}
.cart-item__img{grid-area:img;width:121px;aspect-ratio:121/120;background:#1d1d1d center/cover no-repeat;filter:grayscale(1)}
.cart-item__info{grid-area:info;display:flex;flex-direction:column;gap:16px}
.cart-item__head{display:flex;flex-direction:column;gap:8px}
.cart-item__title{font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;text-transform:uppercase}
.cart-item__meta{font-family:var(--mono);font-size:12px;line-height:16px;color:var(--text-70)}
.cart-item__price{font-family:var(--display);font-size:24px;line-height:32px;letter-spacing:1.2px;color:var(--red)}
.cart-item__row{grid-area:row;display:flex;justify-content:space-between;align-items:center}
.qty{display:inline-flex;align-items:center;gap:24px}
.qty button{width:36px;height:36px;background:none;border:1px solid #2a2a2a;color:var(--text);font-size:18px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s}
.qty button:hover{border-color:var(--red)}
.qty span{font-family:var(--mono);font-size:18px;line-height:28px}
.cart-remove{background:none;border:none;color:var(--red);cursor:pointer;font-family:var(--mono);font-size:16px;
  line-height:24px;letter-spacing:.8px;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.cart-remove:hover{opacity:.8}
.summary{background:#141414;border-top:2px solid var(--red);padding:24px 36px;display:flex;flex-direction:column;gap:24px}
.summary h3{font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;text-transform:uppercase}
.summary__block{display:flex;flex-direction:column;gap:12px;padding-bottom:24px;border-bottom:1px solid #2a2a2a}
.summary__row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;line-height:16px;color:var(--text-70)}
.summary__free{font-family:var(--mono);font-size:12px;line-height:16px;color:var(--red)}
.summary__total{display:flex;justify-content:space-between;align-items:center;
  font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;text-transform:uppercase}
.summary__total span:last-child{color:var(--red)}
.summary .btn{width:100%;height:64px;font-size:24px;letter-spacing:1.2px}
.summary__note{font-family:var(--mono);font-size:12px;line-height:16px;color:var(--text-70);text-align:center}
.summary__continue{align-self:center;display:inline-flex;font-family:var(--mono);font-size:14px;color:var(--red)}
.empty-cart{text-align:center;padding:80px 0}
.empty-cart .display{margin-bottom:16px}

/* ---------- Forms ---------- */
.form-step{margin-bottom:48px}
/* Checkout step titles: white label, red number ("01"), red lock icon */
.form-step__title{font-family:var(--display);font-size:36px;line-height:43px;letter-spacing:1.8px;
  text-transform:uppercase;color:var(--text);margin-bottom:24px;display:flex;align-items:center;
  gap:12px;white-space:nowrap}
.form-step__title .n{color:var(--red)}
.form-step__title svg{width:28px;height:28px;stroke:var(--red)}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.field label{font-family:var(--mono);font-size:14px;font-weight:700;line-height:20px;letter-spacing:.7px;
  text-transform:uppercase;color:var(--text)}
.field input,.field select,.field textarea{
  background:#141414;border:2px solid #2a2a2a;color:var(--text);
  font-family:var(--mono);font-size:14px;padding:14px 16px;width:100%;height:52px;transition:border-color .2s}
.field select{height:52px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red)}
.field input::placeholder,.field textarea::placeholder{color:rgba(245,245,240,.4)}
.field textarea{resize:vertical;min-height:120px;height:auto}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px}
.checkbox{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:14px;font-weight:700;color:var(--text);margin-bottom:24px}
.checkbox input{appearance:none;-webkit-appearance:none;width:20px;height:20px;flex:none;
  border:1px solid #767676;border-radius:2.5px;background:transparent;cursor:pointer;position:relative}
.checkbox input:checked{background:var(--red);border-color:var(--red)}
.checkbox input:checked::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.secure-bar{display:flex;align-items:center;gap:10px;border:2px solid var(--red);background:#141414;
  padding:14px 16px;margin-bottom:24px;font-family:var(--mono);font-size:14px;font-weight:700;color:var(--text)}
.secure-bar svg{width:24px;height:24px;stroke:var(--red);flex:none}
.checkout-item{display:grid;grid-template-columns:101px 1fr;gap:0;padding-bottom:24px;border-bottom:1px solid #2a2a2a}
.checkout-item__img{width:101px;aspect-ratio:101/100;background:#1d1d1d center/cover no-repeat;filter:grayscale(1)}
.checkout-item__body{padding-left:24px;display:flex;flex-direction:column;justify-content:center;gap:4px}
.checkout-item__title{font-family:var(--display);font-size:18px;line-height:28px;letter-spacing:.9px;text-transform:uppercase}
.checkout-item__meta{font-family:var(--mono);font-size:12px;line-height:16px;color:var(--text-70)}
.checkout-item__price{font-family:var(--mono);font-size:16px;line-height:24px;letter-spacing:.8px;color:var(--red)}

/* ---------- Join ---------- */
/* Join hero = split hero (Figma "Join": red title + subtitle left, photo right).
   .split-hero__left already centers; copy fills the 592px column with left-aligned text. */
.join-hero__copy{display:flex;flex-direction:column;gap:24px;max-width:592px;width:100%;text-align:left}
.join-hero__copy h1{font-family:var(--display);font-weight:400;font-size:128px;line-height:128px;
  letter-spacing:6.4px;text-transform:uppercase;color:var(--red)}
.join-hero__copy p{font-family:var(--mono);font-size:18px;line-height:28px;color:var(--text)}
.split-hero__photo--join{background-image:url(../img/f558e59cf838a5e9c3c6aa9d6e093d9164f955e6.png)}
.join-features{background:#161616;padding:100px 120px}
.feature-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.feature{background:#0a0a0a;border-top:4px solid var(--red);padding:32px;display:flex;flex-direction:column;gap:12px}
.feature__icon svg{width:48px;height:48px;stroke:var(--text)}
.feature h3{font-family:var(--display);font-size:24px;line-height:28.8px;letter-spacing:1.2px;text-transform:uppercase;color:var(--text)}
.feature p{color:var(--text-70);font-family:var(--mono);font-size:14px;white-space:pre-line;line-height:22px}
.join-form-section{position:relative;background:#0a0a0a;padding:100px 0}
.join-form-section::before{content:"";position:absolute;inset:0;
  background:linear-gradient(rgba(8,8,8,.965),rgba(8,8,8,.965)),url(../img/d11ddf41dad5ca327f4091eb1c5edc1127bd1e43.png) center/cover no-repeat;
  z-index:0;pointer-events:none}
.join-form-section .container{position:relative;z-index:1}
.join-form{max-width:670px;margin:0 auto;display:flex;flex-direction:column;gap:24px}
.join-form .field{margin-bottom:0}
.join-form .checkbox{margin-bottom:0}
.join-form .btn{width:100%;height:76px;font-size:30px;letter-spacing:1.5px}
.join-form__note{font-family:var(--mono);font-size:12px;line-height:16px;color:var(--text-50);text-align:center}
.join-next{background:#161616;padding:100px 0}
.join-next h2{font-family:var(--display);font-size:48px;line-height:48px;letter-spacing:2.4px;text-transform:uppercase;text-align:center;margin-bottom:48px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:80px}
.step{text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}
.step__n{font-family:var(--display);font-size:72px;line-height:72px;color:var(--red)}
.step h3{font-family:var(--display);font-size:24px;line-height:32px;letter-spacing:1.2px;text-transform:uppercase}
.step p{color:var(--text-70);font-family:var(--mono);font-size:14px;line-height:22.75px;white-space:pre-line}

/* ---------- Support: split hero ---------- */
.support-hero{display:grid;grid-template-columns:1fr 1fr;min-height:630px;position:relative;z-index:2}
.support-hero__left{display:flex;align-items:center;justify-content:center;
  padding:48px 48px 48px 80px;background:var(--bg)}
.support-hero__left .display{font-family:var(--display);font-size:128px;line-height:128px;
  letter-spacing:6.4px;text-transform:uppercase;text-align:left}
.support-hero__right{display:flex;align-items:center;justify-content:center;
  padding:48px;background:var(--red)}
.support-hero__right p{font-family:var(--mono);font-size:18px;line-height:29.25px;
  color:var(--text);max-width:432px}

/* ---------- Support: section heads ---------- */
.support-head{text-align:center;margin-bottom:48px}
.support-head__title{font-family:var(--display);font-size:48px;line-height:48px;
  letter-spacing:2.4px;text-transform:uppercase}
.support-head__sub{font-family:var(--mono);font-size:16px;line-height:24px;
  color:var(--text-70);margin-top:16px}

/* ---------- Support: pricing tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;align-items:stretch}
.tier{border:2px solid #2a2a2a;background:#141414;padding:32px;
  display:flex;flex-direction:column;justify-content:space-between;gap:48px}
.tier--featured{background:var(--red);border-color:var(--red)}
.tier__body{display:flex;flex-direction:column;gap:16px}
.tier__name{font-family:var(--heading);font-weight:400;font-size:14px;line-height:20px;
  letter-spacing:1.4px;color:var(--red);text-transform:uppercase}
.tier--featured .tier__name{color:var(--text)}
.tier__price{font-family:var(--display);font-size:60px;line-height:60px;display:flex;align-items:baseline;gap:6px}
.tier__price small{font-family:var(--mono);font-size:14px;line-height:20px;font-weight:400;color:var(--text)}
.tier__tag{font-family:var(--mono);font-size:14px;line-height:20px;color:var(--text-70)}
.tier--featured .tier__tag{color:rgba(245,245,240,.9)}
.tier__features{display:flex;flex-direction:column;gap:12px}
.tier__features li{display:flex;align-items:flex-start;gap:8px;
  font-family:var(--mono);font-size:12px;line-height:16px;color:var(--text-70)}
.tier--featured .tier__features li{color:rgba(245,245,240,.9)}
.tier__features .tick{color:var(--red);flex:0 0 auto}
.tier--featured .tier__features .tick{color:var(--text)}
.tier__btn{height:52px;border:none;cursor:pointer;background:var(--red);color:var(--text);
  font-family:var(--display);font-size:20px;line-height:28px;letter-spacing:1px;
  text-transform:uppercase;transition:.15s}
.tier__btn:hover{filter:brightness(1.1)}
.tier--featured .tier__btn{background:var(--text);color:var(--red)}

/* ---------- Support: one-time donation ---------- */
/* One-Time section: flat solid #161616 (exact Figma fill, NO texture).
   The torn-paper look comes only from the seams above & below it. */
.onetime-sec{background-color:#161616}
.onetime{max-width:672px;margin:0 auto;text-align:center}
.donate-amounts{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:16px}
.donate-amt{height:65px;display:flex;align-items:center;justify-content:center;
  border:2px solid var(--red);background:transparent;color:var(--red);
  font-family:var(--display);font-size:24px;line-height:28.8px;cursor:pointer;transition:.15s}
.donate-amt:hover{background:var(--red-20)}
.donate-amt.active{background:var(--red);color:var(--text)}
.donate-amt:active{transform:scale(.96)}
.donate-submit{width:100%;height:76px;border:none;cursor:pointer;background:var(--red);color:var(--text);
  font-family:var(--display);font-size:30px;line-height:36px;letter-spacing:1.5px;
  text-transform:uppercase;transition:.15s}
.donate-submit:hover{filter:brightness(1.12)}
.donate-submit:active{transform:scale(.99);filter:brightness(.9)}

/* ---------- Support: where your money goes ---------- */
.where{max-width:896px;margin:0 auto;text-align:center}
.where__title{font-family:var(--display);font-size:48px;line-height:48px;
  letter-spacing:2.4px;text-transform:uppercase;margin-bottom:32px}
.where__bar{display:flex;height:64px;width:100%;overflow:hidden}
.where__bar span{display:block;height:100%}
.where__legend{display:grid;grid-template-columns:1fr 1fr;gap:24px 24px;margin-top:32px;text-align:left}
.legend{display:flex;align-items:center;gap:16px}
.legend__sw{flex:0 0 auto;width:24px;height:24px}
.legend__txt{display:flex;flex-direction:column}
.legend__name{font-family:var(--display);font-size:20px;line-height:28px;text-transform:uppercase}
.legend__pct{font-family:var(--mono);font-size:14px;line-height:20px;color:var(--red)}
.where__note{margin-top:32px;background:#141414;border-left:4px solid var(--red);
  padding:32px;text-align:left;font-family:var(--mono);font-size:14px;font-weight:700;
  line-height:22.75px;color:var(--text)}

/* ---------- Support: report banner ---------- */
.report-banner{background:var(--red);text-align:center;padding:64px var(--pad);position:relative;z-index:2}
.report-banner h2{font-family:var(--display);font-size:48px;line-height:48px;letter-spacing:2.4px;
  text-transform:uppercase;white-space:pre-line;margin-bottom:24px}
.report-banner a{font-family:var(--mono);font-size:14px;line-height:18px;letter-spacing:.7px;
  text-transform:uppercase;color:var(--text)}

/* ---------- Generic page header / breadcrumb ---------- */
.page-hero{padding:120px 0 60px;position:relative;border-bottom:1px solid var(--line)}
.page-hero .display{margin-top:12px}
.page-hero p{color:var(--text-80);max-width:760px;margin-top:16px}

/* line-break helpers (desktop vs mobile copy from Figma frames) */
.only-mobile{display:none}
.only-desktop{display:inline}

/* ---------- Tablet ---------- */
@media (max-width:1100px){
  :root{--pad:40px}
  .display--128,.hero__title{font-size:96px;line-height:108px;letter-spacing:4px}
  .cards{grid-template-columns:repeat(2,1fr)}
  .footer__top{gap:24px}
}

/* ---------- Mobile (Figma "Home Mobile" 390px frame) ---------- */
@media (max-width:600px){
  :root{--pad:24px}
  .only-mobile{display:inline}
  .only-desktop{display:none}
  .hide-on-mobile{display:none !important}

  /* header: padding 16/24, hamburger */
  .header{height:80px}
  .header__inner{height:80px}
  .nav,.header__cta{display:none}
  .burger{display:flex}

  .section{padding:100px 0}

  /* hero: 72/86, 3 lines, full-width stacked buttons */
  .hero--home .hero__bg{background-image:url(../img/f558e59cf838a5e9c3c6aa9d6e093d9164f955e6.png)}
  /* mobile hero photo is light (white wall) -> stronger darkening to match mockup */
  .hero--home .hero__overlay{background:linear-gradient(to top right, rgba(0,0,0,0) 0 3%, rgba(192,0,10,.08) 3%), rgba(0,0,0,.72)}
  .hero{min-height:730px;padding:100px var(--pad)}
  .hero__title{font-size:72px;line-height:86px;letter-spacing:3.6px}
  .hero__sub{font-size:18px;line-height:28px}
  .hero__btns{flex-direction:column;width:100%;max-width:342px;margin:0 auto}
  .hero__btns .btn{width:100%}

  /* latest actions: horizontal scroll, cards 320px */
  .cards{display:flex;grid-template-columns:none;gap:24px;overflow-x:auto;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    margin:0 calc(-1*var(--pad));padding:0 var(--pad) 8px}
  .cards .card{flex:0 0 320px;scroll-snap-align:start}

  /* who we are: stacked quotes, 2 lines (per mobile frame) */
  .quotes{grid-template-columns:1fr;gap:24px}
  .quote{padding-left:24px;white-space:normal}

  /* who we are collage: stacks full-width (Figma Home Mobile order: a,b,c) */
  .who-collage{grid-template-columns:1fr;grid-template-rows:none;column-gap:0;row-gap:24px;align-items:stretch}
  .who-collage__lead,.who-collage__a,.who-collage__b,.who-collage__c{grid-column:1;grid-row:auto}
  .who-collage__lead{margin:0 0 4px}
  .who-photo{aspect-ratio:342/431;height:auto}

  /* merch: stacked */
  .merch{grid-template-columns:1fr;gap:24px}
  .merch__head{font-size:72px;letter-spacing:3.6px}
  .merch__imgs .ph:nth-child(2){margin-top:0}

  /* stats: 2x2 grid */
  .stats{grid-template-columns:1fr 1fr;gap:24px}

  /* display headings down-scaled per mobile frame */
  .display--128{font-size:72px;letter-spacing:3.6px}
  /* Home CTA "Are you ready to fight?" — Figma Home Mobile = 60/60 ls 3.0 */
  .display--96{font-size:60px;line-height:60px;letter-spacing:3px}

  /* torn seam smaller on mobile frame */
  .paper-seam::before,.paper-seam::after{top:-26px;height:71px;width:calc(100% + 48px)}

  /* footer stacks */
  .footer__top{grid-template-columns:1fr;gap:32px}
  .footer__brand{padding-right:0}
  .section__index{font-size:128px;left:var(--pad)}

  /* ===== ABOUT (mobile frame 390) ===== */
  .split-hero{grid-template-columns:1fr;min-height:0}
  .split-hero__left{padding:48px;justify-content:flex-start}
  .split-hero__left .display{font-size:96px;line-height:96px;letter-spacing:4.8px}
  /* Figma About/Join Mobile: hero photo is full portrait (390x537) */
  .split-hero__right{aspect-ratio:390/537}
  .split-hero__photo{background-image:url(../img/f558e59cf838a5e9c3c6aa9d6e093d9164f955e6.png)}

  .manifesto__watermark{display:none}
  .manifesto__inner{max-width:none}
  .manifesto__item h3{white-space:normal}

  .history__row,.history__row:nth-child(odd),.history__row:nth-child(even){grid-template-columns:1fr;gap:24px}
  .history__row .history__text{order:1}
  .history__row .history__img{order:2;aspect-ratio:342/430}

  .values{grid-template-columns:1fr}

  .support-strip{grid-template-columns:1fr;gap:48px;padding:64px 24px}
  .support-strip__img{aspect-ratio:342/192}

  /* ===== ACTIONS (mobile frame 390) ===== */
  .actions-grid{grid-template-columns:1fr}
  .action-card__img{aspect-ratio:342/174}

  /* ===== ACTION INNER (mobile frame 390) ===== */
  .article-hero__title{font-size:72px;line-height:72px;letter-spacing:3.6px}
  .featured-img{aspect-ratio:342/174}
  .two-col{grid-template-columns:1fr}
  .related{grid-template-columns:1fr}

  /* ===== SHOP (mobile frame 390) ===== */
  .products{grid-template-columns:1fr}

  /* ===== JOIN (mobile frame 390) ===== */
  /* Join split hero: text block centered on top, photo below (Figma Join Mobile) */
  .split-hero--join .split-hero__left{padding:48px;justify-content:center;align-items:center}
  .split-hero--join .join-hero__copy{align-items:center;text-align:center;max-width:none}
  .split-hero--join .join-hero__copy h1{font-size:72px;line-height:72px;letter-spacing:3.6px;text-align:center}
  .join-features{padding:64px 0}
  .feature-3{grid-template-columns:1fr;gap:32px}
  .join-form-section{padding:100px 0}
  .steps{grid-template-columns:1fr;gap:32px}

  /* ===== CART / CHECKOUT (mobile frame 390) ===== */
  .cart-head{padding:48px 0 32px}
  .cart-head h1{font-size:72px;line-height:72px;letter-spacing:3.6px}
  .cart-layout{grid-template-columns:1fr;gap:24px;padding-bottom:64px}
  .cart-item{padding:24px 16px;column-gap:24px;row-gap:16px;
    grid-template-columns:64px 1fr;grid-template-areas:"img info" "row row"}
  .cart-item__img{width:64px;aspect-ratio:1/1}
  .summary{padding:24px}
  .field-row,.field-row-3{grid-template-columns:1fr;gap:0}

  /* cart drawer = full-width separate window on phones */
  .cart-drawer{width:100vw;max-width:100vw;border-left:none}

  /* ===== SUPPORT (mobile frame 390) ===== */
  .support-hero{grid-template-columns:1fr;min-height:0}
  .support-hero__left{padding:48px 24px;justify-content:center}
  .support-hero__left .display{font-size:72px;line-height:90px;letter-spacing:3.6px}
  .support-hero__right{padding:48px 24px;justify-content:center}
  .tiers{grid-template-columns:1fr;gap:24px}
  .donate-amounts{grid-template-columns:repeat(3,1fr)}
  .where__legend{grid-template-columns:1fr;gap:16px}
  /* Support torn seams flip on mobile frame (Figma rot 0) */
  .paper-seam--sup::before{transform:translateX(-50%) scaleY(-1)}
  .paper-seam--sup::after{transform:translateX(-50%) scaleX(-1) scaleY(-1)}
}

/* ========== Floating music player (homepage) ========== */
.music-player{
  position:fixed;bottom:24px;right:24px;z-index:1100;
  display:flex;align-items:center;gap:12px;
  background:#141414;border:1px solid var(--red);
  padding:12px 16px;max-width:300px;
  box-shadow:0 4px 24px rgba(0,0,0,.6);
  animation:mplayer-in .35s cubic-bezier(.22,1,.36,1);
}
@keyframes mplayer-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.music-player__btn{
  flex-shrink:0;width:40px;height:40px;border-radius:50%;
  background:var(--red);color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.music-player__btn:hover{background:#000}
.music-player--playing .music-player__btn{background:#000}
.music-player--playing .music-player__btn:hover{background:var(--red)}
.music-player__info{flex:1;min-width:0;overflow:hidden}
.music-player__label{display:block;font-family:var(--mono);font-size:9px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--red);margin-bottom:2px}
.music-player__name{display:block;font-family:var(--mono);font-size:12px;font-weight:700;
  color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.5px;
  text-transform:uppercase}
.music-player__close{flex-shrink:0;background:none;border:none;color:var(--text-50);
  cursor:pointer;font-size:14px;line-height:1;padding:4px;transition:color .15s}
.music-player__close:hover{color:var(--text)}
@media(max-width:480px){
  .music-player{bottom:12px;right:12px;left:12px;max-width:none}
}
