*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--bone);
  font-family:'Inter',-apple-system,sans-serif;min-width:0}
*::-webkit-scrollbar{width:0;height:0}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
/* ── Content rail — the ONE spatial system ───────────────────────────────────
 * Two mechanisms, IDENTICAL content edges, so nothing "jumps" between pages:
 *  (1) `.wrap` — an inner element: max-width:var(--rail) + auto margins + the
 *      single horizontal gutter. Used where a template already nests content
 *      (footer, media, support, contact, single, index).
 *  (2) `.ss-rail` (the shared list below) — applied to a full-bleed BAND so its
 *      BACKGROUND spans the viewport while its CONTENT is constrained to the
 *      same rail, via padding-inline:max(gutter,(100% - rail)/2). No wrapper.
 * Both reference --rail and --gap-x, so every header, band, grid and the footer
 * share the exact same left/right content edge. Bands set only their own
 * padding-block (vertical rhythm) + background; the rail owns the gutter.
 * Bands that ALREADY nest a `.wrap` get padding-block ONLY (no padding-inline),
 * or content would be inset twice. */
.wrap{padding-inline:max(var(--gap-x),(100% - var(--rail)) / 2)}
.wrap--narrow,.ss-narrow,.ss-narrow--sm,.ss-article__wrap{padding-inline:max(var(--gap-x),(100% - var(--rail-narrow)) / 2)}

.ss-statusbar,.ss-nav,.ss-hero,.ss-tagline,.ss-newsletter,.ss-pressrow,
.ss-pageintro,.ss-pullquote,.ss-bio,.ss-rotations,.ss-insignia,.ss-memorial,
.ss-network,.ss-block,.ss-callcongress,.ss-advhero__overlay,.ss-filterstrip,
.ss-count,.ss-cable,.ss-pagination,.ss-empty{
  padding-inline:max(var(--gap-x),(100% - var(--rail)) / 2);
}
/* Feature-tile band paints its dividers via its own background, which would
   show as grey bars in the rail gutter — so it rails via max-width, not
   padding-inline (background stays exactly grid-width). */
.ss-tiles{padding-inline:max(var(--gap-x),(100% - var(--rail)) / 2);background-clip:content-box}
/* No border-radius anywhere (HARD DON'T) except the memorial circles (Task 9). */

/* BMono primitive — HANDOFF §"Mono helper" */
.bmono{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10.5px;
  letter-spacing:0.12em;text-transform:uppercase;color:var(--dim)}
/* Color modifiers — bmono() maps a recognized `color` arg to one of these so the
   accent color is a class, not an inline style. */
.bmono--orange{color:var(--orange)}
.bmono--bg{color:var(--bg)}
.bmono--bone{color:var(--bone)}
.bmono--dim{color:var(--dim)}
.bmono--dim2{color:var(--dim-2)}

/* PhotoSlot frame — HANDOFF §Assets */
.photoslot{position:relative;border:1px solid var(--rule-2);background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.photoslot__caption{position:absolute;left:8px;bottom:8px;backdrop-filter:blur(2px);
  background:rgba(11,11,12,0.55);padding:4px 8px;max-width:90%}
.photoslot__crosshair::before,.photoslot__crosshair::after{content:"";position:absolute;
  background:var(--rule-2)}
.photoslot__crosshair::before{left:50%;top:0;bottom:0;width:1px}
.photoslot__crosshair::after{top:50%;left:0;right:0;height:1px}

.ss-navlink{transition:border-color 120ms}
.ss-navlink:hover{border-color:var(--bone)!important}
.feature-tile,.cable-row{transition:background 160ms}
.feature-tile:hover,.cable-row:hover{background:var(--surface)}
.factsheet-card{transition:transform 180ms ease, box-shadow 180ms ease}
.factsheet-card:hover{transform:translateY(-6px);box-shadow:0 12px 28px rgba(216,99,58,0.20)}
.reduce-motion .factsheet-card{transition:none!important;transform:none!important;box-shadow:none!important}

/* ============================================================================
 * PAGE LAYOUT — mobile-first, class-based. (front-page.php, page-about.php)
 *
 * The reference pattern for de-inlining the rest of the theme: every layout
 * rule lives here keyed off a class; templates carry `class=` only, never
 * `style=`. Base rules target phones (single column); larger layouts are
 * additive via `min-width` media queries. Because nothing is inline, none of
 * this needs `!important` — the cascade is doing its job.
 *
 * Breakpoints: 600px = large phone / small tablet, 768px = tablet,
 *              1024px = desktop. The two big asymmetric splits (hero, bio)
 *              only go side-by-side at 1024px so iPad portrait stacks cleanly.
 * ========================================================================== */

/* ── Shared headline primitive ──────────────────────────────────────────── */
.ss-h1{font-family:var(--sans);font-weight:800;text-transform:uppercase;
  color:var(--bone);letter-spacing:0.02em;line-height:1.15;
  font-size:clamp(22px,6vw,30px)}

/* ─────────────────────────── HOME (front-page) ─────────────────────────── */

/* 2. Half-bleed hero — single column on phone/tablet, 60/40 on desktop */
.ss-hero{display:grid;grid-template-columns:1fr;border-bottom:1px solid var(--rule-2)}
.ss-hero__media{position:relative;display:flex;min-height:300px}
/* Hero photo is portrait in a 16:9 box; weight the cover-crop toward the top so the
   three subjects' faces stay in frame (full image preserved; see docs/image-credits.json). */
.ss-hero__media .photoslot > img{object-position:50% 25%}
.ss-hero__panel{background:var(--surface);padding:28px 18px;display:flex;flex-direction:column}
.ss-hero__panel-head{display:flex;justify-content:space-between;
  border-bottom:1px solid var(--rule-2);padding-bottom:12px}
.ss-hero__next{margin-top:auto;padding-top:18px;border-top:1px solid var(--rule-2)}
.ss-hero__next-text{font-family:var(--mono);font-size:13px;color:var(--bone);
  margin-top:6px;line-height:1.45}
.ss-dossier{width:100%;margin-top:18px;font-family:var(--mono);font-size:12px;
  color:var(--bone);border-collapse:collapse}
.ss-dossier tr{border-bottom:1px solid var(--rule)}
.ss-dossier td{padding:10px 0}
.ss-dossier__k{color:var(--dim);letter-spacing:0.1em}
.ss-dossier__v{text-align:right}
@media (min-width:1024px){
  .ss-hero{grid-template-columns:60% 40%}
  .ss-hero__media{min-height:540px}
  .ss-hero__panel{padding:36px 28px;border-left:1px solid var(--rule-2)}
}

/* 3. Tagline band */
.ss-tagline{padding-block:var(--section-y);background:var(--bg);border-bottom:1px solid var(--rule-2)}
.ss-tagline .ss-h1{max-width:1100px}
.ss-tagline__hl{color:var(--orange)}
.ss-tagline__sub{font-family:var(--mono);font-size:13px;color:var(--dim-2);
  margin-top:14px;max-width:880px;line-height:1.55}
@media (min-width:768px){
  .ss-tagline .ss-h1{font-size:36px;line-height:1.05;letter-spacing:0.02em}
}

/* 4. Newsletter band — orange */
.ss-newsletter{background:var(--orange);padding-block:var(--section-y);display:grid;
  grid-template-columns:1fr;gap:24px;border-bottom:1px solid var(--rule-2)}
.ss-newsletter .ss-h1{color:var(--bg);margin-top:12px;letter-spacing:0.01em}
.ss-newsletter__embed{background:var(--bg)}
.ss-newsletter__form{display:flex;background:var(--bg)}
.ss-newsletter__input{flex:1;padding:18px;border:none;background:transparent;
  color:var(--bone);font-family:var(--mono);font-size:13px;outline:none;letter-spacing:0.08em}
.ss-newsletter__btn{padding:0 24px;background:var(--bone);color:var(--bg);border:none;
  font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:0.18em;
  text-transform:uppercase;cursor:pointer}
@media (min-width:768px){
  .ss-newsletter{grid-template-columns:1fr 1fr;gap:32px;align-items:center}
  .ss-newsletter .ss-h1{font-size:26px;line-height:1.1}
}

/* 5. Three feature tiles */
.ss-tiles{display:grid;grid-template-columns:1fr;gap:1px;background:var(--rule-2);
  border-bottom:1px solid var(--rule-2)}
.feature-tile{background:var(--bg);padding:28px 24px;display:flex;flex-direction:column;gap:10px}
.feature-tile__head{display:flex;justify-content:space-between}
.feature-tile__title{font-family:var(--sans);font-weight:800;letter-spacing:0.04em;
  text-transform:uppercase;font-size:17px;color:var(--bone);line-height:1.2;margin-top:6px}
.feature-tile__dek{font-family:var(--sans);font-size:13.5px;color:var(--dim-2);line-height:1.5}
.feature-tile__link{font-family:var(--mono);font-size:11px;color:var(--orange);margin-top:6px;
  letter-spacing:0.16em;text-transform:uppercase}
@media (min-width:600px){.ss-tiles{grid-template-columns:1fr 1fr}}
@media (min-width:1024px){.ss-tiles{grid-template-columns:1fr 1fr 1fr}}

/* 6. Press row */
.ss-pressrow{padding-block:var(--s-3);border-bottom:1px solid var(--rule-2)}
.ss-pressrow__list{display:flex;gap:12px 24px;flex-wrap:wrap;margin-top:14px;
  font-family:var(--mono);font-size:12px;color:var(--dim-2);letter-spacing:0.16em;text-transform:uppercase}
/* Each outlet links to a specific Sampson article. Keep each wordmark on one line
   (no mid-name wrap) and brighten on hover to signal the link; primary outlet = bold. */
.ss-pressrow__item{white-space:nowrap;transition:color 120ms}
.ss-pressrow__item:hover{color:var(--bone)}
.ss-pressrow__item--emph{font-weight:700}

/* Page intro — one-line "what this page is" + cross-links, so Dispatches / Media /
   Press read as distinct lenses rather than three overlapping mystery lists. */
.ss-pageintro{padding-block:var(--s-4) var(--s-1)}
.ss-pageintro__lead{font-family:var(--sans);font-size:15px;color:var(--dim-2);
  line-height:1.6;max-width:780px;margin:10px 0 0}
.ss-inline-link{color:var(--orange);border-bottom:1px solid rgba(216,99,58,0.45)}
.ss-inline-link:hover{border-bottom-color:var(--orange)}

/* 7. Pull-quote band */
.ss-pullquote{padding-block:var(--section-y-lg);background:var(--surface-2);border-bottom:1px solid var(--rule-2)}
.ss-pullquote .ss-h1{max-width:1100px;letter-spacing:0.005em}
@media (min-width:768px){
  .ss-pullquote .ss-h1{font-size:28px;line-height:1.25}
}

/* ─────────────────────────────── ABOUT ─────────────────────────────────── */

/* 1. Bio hero — portrait + bio (stacks until desktop) */
.ss-bio{display:grid;grid-template-columns:1fr;border-bottom:1px solid var(--rule-2)}
.ss-bio__portrait{display:flex}
/* Keep his face in frame however the 3:4 slot is cropped (cover crops vertically). */
.ss-bio__portrait .photoslot > img{object-position:50% 18%}
.ss-bio__body{padding:24px}
.ss-bio .ss-h1{margin-top:14px;max-width:920px}
.ss-bio__lede{font-family:var(--sans);font-size:16px;line-height:1.55;color:var(--dim-2);margin-top:22px}
.ss-bio__text{font-family:var(--sans);font-size:14px;line-height:1.6;color:var(--dim-2);margin-top:14px}
.ss-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:28px;padding:20px;
  background:var(--surface);border:1px solid var(--rule-2)}
.ss-stat__num{font-family:var(--sans);font-weight:800;letter-spacing:0.02em;font-size:28px;color:var(--orange)}
@media (min-width:768px){.ss-stats{grid-template-columns:repeat(4,1fr)}}
/* Sidebar portrait from tablet up. Below 1024 this avoided a full-width 3:4 portrait
   that grew to ~940x1250 and cropped his head; the 320px column keeps him fully framed. */
@media (min-width:768px){
  .ss-bio{grid-template-columns:320px 1fr}
  .ss-bio__portrait{border-right:1px solid var(--rule-2)}
  .ss-bio__body{padding:36px}
  .ss-bio .ss-h1{font-size:36px;line-height:1.06}
}

/* 2. Four-rotation stepper */
.ss-rotations{padding-block:var(--section-y);border-bottom:1px solid var(--rule-2)}
.ss-rotations__grid{display:grid;grid-template-columns:1fr;gap:12px}
.ss-rotation{background:var(--surface);padding:20px;border:1px solid var(--rule-2);
  border-top:2px solid var(--orange)}
.ss-rotation__loc{font-family:var(--sans);font-weight:800;letter-spacing:0.04em;
  text-transform:uppercase;font-size:14px;color:var(--bone);margin-top:10px}
.ss-rotation__body{font-family:var(--sans);font-size:13px;color:var(--dim-2);line-height:1.5;margin-top:8px}
@media (min-width:600px){.ss-rotations__grid{grid-template-columns:1fr 1fr}}
@media (min-width:1024px){.ss-rotations__grid{grid-template-columns:repeat(4,1fr)}}

/* 3. Insignia row */
.ss-insignia{padding-block:var(--s-3);display:grid;grid-template-columns:1fr;gap:12px;
  border-bottom:1px solid var(--rule-2)}
@media (min-width:600px){.ss-insignia{grid-template-columns:repeat(3,1fr)}}

/* 4. Memorial band — pure black; the ONE allowed border-radius:50% */
.ss-memorial{padding-block:var(--section-y-lg);background:#000;border-bottom:1px solid var(--rule-2)}
.ss-memorial__inner{max-width:700px;margin:0 auto;text-align:center}
.ss-memorial__quote{font-family:var(--sans);font-size:20px;line-height:1.55;color:#bdb8ad;font-style:italic}
.ss-memorial__circles{display:flex;justify-content:center;gap:24px;margin-top:30px}
.ss-memorial__circle{width:88px;height:88px;border-radius:50%;border:1px solid var(--rule-2);
  display:flex;align-items:center;justify-content:center;font-family:var(--mono);
  font-size:9px;color:var(--dim);letter-spacing:0.14em;text-align:center}

/* 5. Network + Downloads */
.ss-network{padding-block:var(--section-y);display:grid;grid-template-columns:1fr;gap:32px;
  border-bottom:1px solid var(--rule-2)}
.ss-network__grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule)}
.ss-network__cell{background:var(--surface);padding:14px 18px;font-family:var(--mono);
  font-size:12.5px;color:var(--bone);letter-spacing:0.04em}
.ss-network__cell--link{display:flex;justify-content:space-between;align-items:center;gap:12px;
  text-decoration:none;transition:color 120ms}
.ss-network__cell--link:hover{color:var(--orange)}
.ss-network__ext{color:var(--orange);flex-shrink:0}
.ss-downloads__link{display:flex;justify-content:space-between;padding:12px 18px;
  border:1px solid var(--rule-2);margin-bottom:8px;font-family:var(--mono);font-size:12px;
  color:var(--bone);letter-spacing:0.06em}
.ss-downloads__link span:last-child{color:var(--orange)}
@media (min-width:768px){
  .ss-network{grid-template-columns:2fr 1fr}
  /* When Downloads is hidden (no real files), Network takes the full width. */
  .ss-network--solo{grid-template-columns:1fr}
}

/* ============================================================================
 * DE-INLINED THEME CHROME + INNER PAGES — same convention as HOME/ABOUT above:
 * mobile-first base, additive `min-width` queries, CSS-variable tokens, no
 * inline `style=` in templates, no `!important` (the cascade does the work).
 * The legacy `responsive.css` !important layer still governs the mobile nav
 * drawer, the .ss-cable collapse, and the cross-grid min-width:0 overflow safety.
 * ========================================================================== */

/* ── Shared section primitives ──────────────────────────────────────────── */
.ss-section{padding-block:var(--section-y)}
.ss-block{padding-block:var(--section-y);border-bottom:1px solid var(--rule-2)}
/* Top matches .ss-pageintro (--s-4) so the page header starts at the SAME height
   as Dispatches/Media/Press and doesn't jump when switching tabs; bottom keeps
   the normal section rhythm before the footer. */
.ss-pagesection{padding-block:var(--s-4) var(--section-y)}
.ss-lead{font-family:var(--sans);font-size:16px;color:var(--dim-2);line-height:1.55;margin:12px 0 28px}
.ss-note{font-family:var(--sans);font-size:14px;color:var(--dim-2);line-height:1.55;margin-top:12px}
.ss-pagetitle{font-family:var(--sans);font-weight:800;letter-spacing:0.015em;text-transform:uppercase;
  font-size:clamp(22px,5vw,28px);line-height:1.1;color:var(--bone);margin-top:10px;max-width:880px}
.ss-meta{display:flex;gap:14px;flex-wrap:wrap}
.ss-card{background:var(--surface);border:1px solid var(--rule-2);border-top:2px solid var(--orange);padding:22px}
.ss-embed{position:relative;width:100%;min-height:520px}
.ss-embed--tall{min-height:640px}
.ss-embed__frame{position:absolute;inset:0;width:100%;height:100%;border:0}
/* Primary action button — Ukraine yellow (Donate CTA, Email Directly). */
.ss-btn{display:block;font-family:var(--mono);font-size:12px;padding:14px 16px;letter-spacing:0.16em;
  text-transform:uppercase;background:var(--yellow);color:var(--bg)}
.ss-btn:hover{background:var(--yellow-2)}
.ss-btn--ghost{background:transparent;color:var(--bone);border:1px solid var(--rule-2)}
.ss-btn + .ss-btn{margin-top:10px}

/* Shared quote band (press pull-quotes + advocacy endorsements) */
.ss-quotegrid{display:grid;grid-template-columns:1fr;gap:16px}
.ss-quote{border-top:2px solid var(--orange);padding-top:14px}
.ss-quote__text{font-family:var(--sans);font-weight:800;letter-spacing:0.04em;text-transform:uppercase;
  font-size:16px;line-height:1.35;color:var(--bone)}
@media (min-width:768px){.ss-quotegrid{grid-template-columns:1fr 1fr 1fr}}

/* ── PhotoSlot aspect-ratio modifiers (was an inline `aspect-ratio:` style) ── */
.photoslot{aspect-ratio:16/9}
.photoslot--r16x9{aspect-ratio:16/9}
.photoslot--r3x4{aspect-ratio:3/4}
.photoslot--r4x3{aspect-ratio:4/3}
.photoslot--r16x10{aspect-ratio:16/10}
.photoslot--r21x9{aspect-ratio:21/9}
.photoslot > img{width:100%;height:100%;object-fit:cover}

/* ── Header / nav ───────────────────────────────────────────────────────── */
/* Ukrainian flag accent — a 4px blue-over-yellow band. Sits at the top of the
   sticky header (always visible) and as a divider above the footer. Decorative. */
.ss-flagbar{height:4px;background:linear-gradient(to bottom,var(--blue) 0 50%,var(--yellow) 50% 100%)}
.ss-header{position:sticky;top:0;z-index:10;background:var(--bg)}
.ss-statusbar{background:var(--surface-2);padding-block:10px 6px;border-bottom:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:center;line-height:1.3}
.ss-nav{padding-block:14px;display:flex;align-items:center;justify-content:space-between}
.ss-brand{display:flex;align-items:center;gap:10px}
.ss-brand__dot{width:8px;height:8px;background:linear-gradient(to bottom,var(--blue) 0 50%,var(--yellow) 50% 100%);display:inline-block}
.ss-brand__name{font-weight:700;letter-spacing:0.04em;text-transform:uppercase}
.ss-navmenu{display:flex;align-items:center;gap:8px}
.ss-navitems{display:flex;flex-wrap:wrap;gap:8px}
.ss-navcta{display:flex;align-items:center;gap:14px}
.ss-navlink{padding:6px 12px;border:1px solid var(--rule);color:var(--bone)}
.ss-navlink--active{background:var(--blue);color:#fff;border-color:var(--blue)}
.ss-donate{background:var(--yellow);color:var(--bg);padding:8px 14px;font-weight:700}
.ss-donate:hover{background:var(--yellow-2)}
/* On the Support page the Donate nav button goes blue like an active tab, handing
   the yellow "click me" emphasis to the main DONATE VIA GIVEBUTTER button. */
.ss-donate--active{background:var(--blue);color:#fff}
.ss-donate--active:hover{background:var(--blue-2)}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.ss-sitefooter{background:var(--surface-2);border-top:1px solid var(--rule-2);padding-block:var(--section-y)}
.ss-footer{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
/* Social channels sit inline (not stacked) under their label. */
.ss-channels{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}
.ss-footer__brand{font-weight:800;text-transform:uppercase}
/* Footer site nav (sitemap) — compact 2-column grid under the NAVIGATE label
   so 8 routes stay short (4 rows) instead of one tall stack. */
.ss-footer__nav{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;margin-top:8px}
.ss-footer__nav a{text-decoration:none;transition:color 120ms}
.ss-footer__nav a:hover{color:var(--orange)}

/* ── Single dispatch + media card (shared with /media) ──────────────────── */
.ss-article{padding-block:var(--section-y)}
/* No max-width here: the element already gets the narrow rail via the .wrap +
   .ss-article__wrap padding-inline rule above, which centers an 860px content
   column. Adding max-width:860 too would cap the ELEMENT to 860 and then the rail
   padding (~(parent-860)/2 per side) would squeeze content to a narrow left-pinned
   strip — the "mobile layout on desktop" bug. */
.ss-backlink{display:inline-block;margin-bottom:20px}
.ss-article__title{font-family:var(--sans);font-size:30px;line-height:1.12;font-weight:800;
  text-transform:uppercase;color:var(--bone);margin:14px 0 0;letter-spacing:0.015em}
.ss-article__dek{font-family:var(--sans);font-size:16px;line-height:1.55;color:var(--dim-2);margin:14px 0 0}
.ss-content{font-family:var(--sans);font-size:16px;line-height:1.75;color:var(--bone)}
.ss-content p{margin:0 0 18px}
.ss-content p:last-child{margin-bottom:0}
.ss-content a{color:var(--orange);text-decoration:underline;text-underline-offset:2px}
.ss-content em{color:var(--dim-2)}
.ss-content blockquote{margin:26px 0;padding:4px 0 4px 22px;border-left:3px solid var(--orange);
  font-family:var(--sans);font-weight:700;font-size:21px;line-height:1.4;color:var(--bone)}
/* "Read the original" external-source button on a dispatch */
.ss-source{display:inline-flex;align-items:center;gap:10px;margin-top:32px;padding:14px 18px;
  background:var(--surface);border:1px solid var(--rule-2);border-left:3px solid var(--orange);
  font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--bone);transition:background 160ms}
.ss-source:hover{background:var(--surface-2)}
.ss-source__host{color:var(--dim-2);text-transform:none;letter-spacing:0.04em}
.ss-source__arrow{color:var(--orange)}
.media-card{background:var(--surface);padding:0;cursor:pointer}
.ss-article .media-card{margin-bottom:28px}
.media-card__thumb{position:relative;aspect-ratio:16/9;background:var(--surface-2)}
.media-card__thumb > img{width:100%;height:100%;object-fit:cover}
.media-card__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:40px;color:var(--orange)}
.media-card__body{padding:16px}
.media-card__title{font-weight:800;text-transform:uppercase;font-size:17px;margin:8px 0 0}

/* ── Dispatches archive (cable index) ───────────────────────────────────── */
/* Dock flush under the (variable-height) sticky header. --ss-header-h is set by site.js;
   the fallback stays just under the header so no scrolling content bleeds through the gap. */
.ss-filterstrip{position:sticky;top:var(--ss-header-h,80px);z-index:5;background:var(--bg);padding-block:var(--s-2);
  border-bottom:1px solid var(--rule-2);display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.ss-chip{padding:7px 12px;font-family:var(--mono);font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;border:1px solid var(--rule-2);background:transparent;color:var(--bone)}
.ss-chip--active{border-color:var(--orange);background:var(--orange);color:var(--bg)}
.ss-chip__n{opacity:.55;font-weight:400}
.ss-cable{display:grid;grid-template-columns:160px 1fr auto;gap:24px;padding-block:var(--s-3);
  border-bottom:1px solid var(--rule-2);align-items:start;color:inherit}
.ss-cable__thumb{width:160px}
.ss-cable__title{font-family:var(--sans);font-size:22px;line-height:1.18;font-weight:800;
  text-transform:uppercase;color:var(--bone);margin-top:8px;letter-spacing:0.01em}
.ss-cable__dek{font-family:var(--sans);font-size:14px;line-height:1.5;color:var(--dim-2);margin-top:8px}
.ss-cable__arrow{font-family:var(--mono);font-size:14px;color:var(--orange);padding-top:4px}
.ss-pagination{display:flex;justify-content:center;padding-block:var(--s-4);border-bottom:1px solid var(--rule-2)}
.ss-empty{padding-block:var(--s-5)}

/* ── Media grid ─────────────────────────────────────────────────────────── */
.media-grid{display:grid;grid-template-columns:1fr;gap:1px}
@media (min-width:600px){.media-grid{grid-template-columns:1fr 1fr}}
@media (min-width:1024px){.media-grid{grid-template-columns:repeat(3,1fr)}}

/* ── Press: appearances cable rows ──────────────────────────────────────── */
.ss-presscable{display:grid;grid-template-columns:1fr;gap:8px;align-items:baseline;
  padding-block:18px;border-bottom:1px solid var(--rule);background:var(--bg)}
.ss-presscable__title{font-family:var(--sans);font-weight:800;letter-spacing:0.04em;
  text-transform:uppercase;font-size:16px;color:var(--bone);line-height:1.2}
.ss-presscable__dek{font-family:var(--sans);font-size:13.5px;color:var(--dim-2);line-height:1.5;margin-top:6px}
@media (min-width:768px){.ss-presscable{grid-template-columns:140px 1fr 110px;gap:16px}}

/* ── Advocacy ───────────────────────────────────────────────────────────── */
.ss-advhero{position:relative;height:300px;border-bottom:1px solid var(--rule-2);overflow:hidden}
.ss-advhero__media{position:absolute;inset:0}
/* The hero is a fixed-height band: the photoslot must FILL it, not impose its own
   21:9 aspect-ratio (which computed ~550px tall at full width and bled past the box). */
.ss-advhero__media .photoslot{height:100%;width:100%;aspect-ratio:auto}
.ss-advhero__overlay{position:absolute;inset:0;padding-block:30px;display:flex;flex-direction:column;
  justify-content:flex-end;color:var(--bone);
  background:linear-gradient(to top,rgba(11,11,12,0.85) 0%,rgba(11,11,12,0.35) 45%,transparent 75%)}
.ss-advhero__title{font-family:var(--sans);font-weight:800;letter-spacing:0.015em;text-transform:uppercase;
  font-size:clamp(22px,5vw,30px);line-height:1.1;margin-top:10px;max-width:1100px}
.ss-uasgrid{display:grid;grid-template-columns:1fr;gap:12px}
.ss-uas{background:var(--surface);padding:16px;border:1px solid var(--rule-2)}
.ss-uas__outcome{font-family:var(--sans);font-size:13px;color:var(--bone);line-height:1.45;margin-top:8px}
/* Real summit photos (.jpg) are portrait in a 4:3 cell; weight the cover-crop to the top
   so the Capitol dome and subject stay in frame. Stand-in .png tiles keep centered crop. */
.ss-uas--photo .photoslot > img{object-position:50% 0%}
/* uas-1 (4th Summit): dome at top, subject lower in frame — slide the crop window
   down so both the Capitol dome and Sampson stay in the 4:3 cell. */
.ss-uas--photo1 .photoslot > img{object-position:50% 38%}
@media (min-width:600px){.ss-uasgrid{grid-template-columns:repeat(3,1fr)}}
@media (min-width:1024px){.ss-uasgrid{grid-template-columns:repeat(5,1fr)}}
.ss-factgrid{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:768px){.ss-factgrid{grid-template-columns:repeat(3,1fr)}}
.factsheet-card{background:var(--surface);padding:22px;border:1px solid var(--rule-2);
  border-top:2px solid var(--orange);cursor:pointer}
.ss-fact__head{display:flex;justify-content:space-between;align-items:baseline}
.ss-fact__bill{font-family:var(--sans);font-weight:800;letter-spacing:0.04em;text-transform:uppercase;
  font-size:22px;color:var(--bone)}
.ss-fact__body{font-family:var(--sans);font-size:13.5px;color:var(--dim-2);line-height:1.55;margin-top:12px}
.ss-fact__dl{display:inline-block;margin-top:14px;font-family:var(--mono);font-size:11px;color:var(--bg);
  background:var(--bone);padding:10px 16px;letter-spacing:0.16em;text-transform:uppercase}
.ss-callcongress{padding-block:var(--section-y);background:var(--surface);border-bottom:1px solid var(--rule-2)}
.ss-callcongress__grid{display:grid;grid-template-columns:1fr;gap:24px}
.ss-callcongress__head{font-family:var(--sans);font-weight:800;letter-spacing:0.04em;text-transform:uppercase;
  font-size:24px;line-height:1.15;color:var(--bone);margin-top:12px}
.ss-callcongress__form{background:var(--bg);padding:20px;border:1px solid var(--rule-2)}
.ss-callcongress__input{width:100%;margin-top:10px;padding:14px 16px;border:1px solid var(--rule-2);
  background:var(--surface);color:var(--bone);font-family:var(--mono);font-size:14px;outline:none;letter-spacing:0.08em}
.ss-callcongress__btn{margin-top:12px;width:100%;padding:14px;background:var(--yellow);color:var(--bg);border:none;
  font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;cursor:pointer}
/* Anchor variant of the action button (links out instead of submitting a form). */
.ss-callcongress__btn--link{display:block;box-sizing:border-box;text-align:center;text-decoration:none}
@media (min-width:768px){.ss-callcongress__grid{grid-template-columns:1fr 1fr;gap:32px;align-items:center}}

/* ── Support ────────────────────────────────────────────────────────────── */
.ss-funds{display:grid;grid-template-columns:1fr;gap:1px;background:var(--rule-2);
  border:1px solid var(--rule-2);margin-bottom:28px}
.ss-funds__cell{background:var(--bg);padding:18px 16px}
.ss-funds__v{font-family:var(--sans);font-size:13px;color:var(--dim-2);line-height:1.45;margin-top:8px}
@media (min-width:600px){.ss-funds{grid-template-columns:1fr 1fr}}
@media (min-width:768px){.ss-funds{grid-template-columns:repeat(4,1fr)}}

/* ── Contact ────────────────────────────────────────────────────────────── */
/* Sits as the first child of .ss-block (which supplies its own top padding), so
   no extra top margin — keeps the banner-to-content rhythm matching /advocacy. */
.ss-contactgrid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start}
.ss-booking{width:100%;margin-top:12px;border-collapse:collapse;font-family:var(--mono);font-size:12px;color:var(--bone)}
.ss-booking tr{border-bottom:1px solid var(--rule)}
.ss-booking td{padding:12px 0}
.ss-booking__k{color:var(--dim);letter-spacing:0.1em}
.ss-booking__v{text-align:right}
/* Long unbreakable strings (the booking/footer email address) must wrap instead
   of forcing the column — and the page — wider than the viewport. Class-based,
   applies at every width. */
.ss-booking__v,.ss-funds__v,.ss-card a[href^="mailto:"],.ss-footer .bmono{
  overflow-wrap:anywhere;word-break:break-word}
.ss-booking__channels{margin-top:22px;padding-top:18px;border-top:1px solid var(--rule-2)}
.ss-booking__handles{font-family:var(--mono);font-size:13px;color:var(--bone);margin-top:8px;line-height:1.6}
@media (min-width:768px){.ss-contactgrid{grid-template-columns:1fr 1fr}}
.ss-contact-addr{font-family:var(--mono);font-size:13px;margin-top:14px}
.ss-contact-addr a{color:var(--dim);text-decoration:none;overflow-wrap:anywhere}
.ss-contact-addr a:hover{color:var(--orange)}
.ss-contact-form{margin-top:24px}

/* Channel directory: one row per channel — dim mono key + value, ruled rows so the
   numbers read as a scannable list instead of a wrapped run-on cluster. */
.ss-comms{margin-top:10px}
.ss-comms__row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  padding:11px 0;border-bottom:1px solid var(--rule)}
.ss-comms__row:last-child{border-bottom:0}
.ss-comms__k{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--dim);white-space:nowrap}
.ss-comms__v{font-family:var(--mono);font-size:13px;color:var(--bone);text-align:right;
  overflow-wrap:anywhere}
.ss-comms__v a{color:var(--bone);text-decoration:none}
.ss-comms__v a:hover{color:var(--orange)}
.ss-comms__sep{margin-top:20px}

/* ── Index / generic post ───────────────────────────────────────────────── */
.ss-index{padding-block:var(--s-5)}
.ss-index__item{margin-bottom:32px}
.ss-index__title{font-weight:800}
