/* Signal — a structured, authoritative technology magazine.
 *
 * The contract (docs/research/templates/ieee-spectrum.md):
 *   · the grid IS the design — hairline separations, strict alignment, visible
 *     structure; separation by 1px rules + whitespace, never shadows
 *   · heavy serif for feature headlines (with the inline headline→dek run-on),
 *     bold grotesque for news headlines, mono for ALL metadata
 *   · ONE red-family accent: topic chips, links, active states — nothing else
 *   · corners 0–2px; motion is nearly none — 90ms linear color/underline shifts
 *     at most. The restraint IS the character.
 *
 * Knob vars (with fallbacks): --smedja-radius, --smedja-section-y.
 */

:root {
  --sg-r: var(--smedja-radius, 0px);
  --sg-section-y: var(--smedja-section-y, clamp(3.25rem, 3vw + 1.8rem, 5rem));
  --sg-ink: var(--wp--preset--color--contrast);
  --sg-chrome: var(--wp--preset--color--base);
  --sg-plate: var(--wp--preset--color--surface);
  --sg-red: var(--wp--preset--color--primary);
  --sg-red-deep: var(--wp--preset--color--primary-soft);
  --sg-steel: var(--wp--preset--color--accent);
  --sg-gray: var(--wp--preset--color--muted);
  --sg-line: var(--wp--preset--color--line);
  --sg-serif: var(--wp--preset--font-family--display);
  --sg-sans: var(--wp--preset--font-family--body);
  --sg-mono: var(--wp--preset--font-family--mono);
  --sg-fast: 90ms linear;
}

html {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
[id] {
  scroll-margin-top: 6rem;
}
::selection {
  background: color-mix(in srgb, var(--sg-red) 18%, var(--sg-chrome));
}

/* Links: ink or red, underline that answers instantly. */
a:not(.wp-element-button) {
  text-underline-offset: 0.16em;
  text-decoration-thickness: 1px;
  transition: color var(--sg-fast), text-decoration-color var(--sg-fast);
}
:where(a, button, input, summary, [tabindex]):focus-visible {
  outline: 2px solid var(--sg-red);
  outline-offset: 2px;
  border-radius: var(--sg-r);
}

/* == The mono metadata voice ========================================== */
.sg-meta {
  font-family: var(--sg-mono);
  font-size: 0.71rem;
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--sg-gray);
  margin: 0;
  line-height: 1.6;
}
.sg-meta__sep {
  color: var(--sg-line);
  padding-inline: 0.55em;
}
.sg-credit {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--sg-gray);
  margin: 0.5rem 0 0;
}

/* Boxed chips — the category system. Gray box = kind, red = topic. */
.sg-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin: 0;
}
.sg-chip {
  display: inline-flex;
  align-items: center;
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--sg-gray);
  background: var(--sg-plate);
  border: 1px solid var(--sg-line);
  border-radius: var(--sg-r);
  padding: 0.3em 0.65em 0.26em;
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--sg-fast), background-color var(--sg-fast), border-color var(--sg-fast);
}
.sg-chip--topic {
  color: var(--sg-red);
  border-color: color-mix(in srgb, var(--sg-red) 45%, var(--sg-line));
}
a.sg-chip:hover {
  color: var(--sg-plate);
  background: var(--sg-ink);
  border-color: var(--sg-ink);
}
a.sg-chip--topic:hover {
  background: var(--sg-red);
  border-color: var(--sg-red);
}

/* == Headlines ======================================================== */
/* Feature headline: heavy serif; the dek runs on inline after the mark. */
.sg-headline {
  font-family: var(--sg-serif);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: -0.01em;
  margin: 0;
  overflow-wrap: break-word;
  hyphens: auto;
}
.sg-headline a {
  color: var(--sg-ink);
  text-decoration: none;
}
.sg-headline a:hover {
  text-decoration: underline;
  text-decoration-thickness: 3px;
  text-decoration-color: var(--sg-red);
  text-underline-offset: 0.12em;
}
.sg-headline__sep {
  color: var(--sg-red);
  font-weight: 700;
}
.sg-headline__dek {
  font-size: 0.55em;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1.28;
  color: var(--sg-gray);
}

/* Plates — imagery sits on framed light-gray plates, never floats. */
.sg-plate {
  margin: 0;
  overflow: hidden;
  background: color-mix(in srgb, var(--sg-ink) 4%, var(--sg-plate));
  border: 1px solid var(--sg-line);
  border-radius: var(--sg-r);
}
.sg-plate img {
  display: block;
  width: 100%;
  height: auto;
}

/* == Bands ============================================================ */
.sg-band {
  padding-top: calc(var(--sg-section-y) * 0.55);
  padding-bottom: calc(var(--sg-section-y) * 0.55);
}
.sg-band--lede {
  padding-top: calc(var(--sg-section-y) * 0.6);
}
.sg-band--rail-nav {
  padding-top: 0;
  padding-bottom: 0;
}
/* Long-form flow: prose, figures and data sit closer — article rhythm,
   not landing-page rhythm. */
.sg-band--prose,
.sg-band--figure,
.sg-band--data {
  padding-top: calc(var(--sg-section-y) * 0.3);
  padding-bottom: calc(var(--sg-section-y) * 0.3);
}
.sg-section-head {
  max-width: 46rem;
  margin-bottom: 1.6rem;
  display: grid;
  gap: 0.55rem;
}
.sg-eyebrow {
  font-family: var(--sg-mono);
  font-size: 0.71rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--sg-red);
  margin: 0;
}
.sg-section-title {
  font-family: var(--sg-sans);
  font-size: var(--wp--preset--font-size--xl);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0;
}
.sg-section-lede {
  font-size: var(--wp--preset--font-size--base);
  line-height: 1.55;
  color: var(--sg-gray);
  margin: 0;
}

/* == Masthead ========================================================= */
/* WP wraps template parts in .wp-block-template-part — sticky must live on
   the wrapper, or the header only sticks within its own height. */
.wp-block-template-part:has(> .sg-masthead) {
  position: sticky;
  top: 0;
  z-index: 60;
}
.sg-masthead {
  background: var(--sg-chrome);
  border-bottom: 1px solid var(--sg-ink);
}
.sg-utility {
  background: var(--sg-ink);
}
.sg-masthead.is-condensed .sg-utility {
  display: none; /* instant — this template does not animate its chrome */
}
.sg-utility__note,
.sg-utility__links {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--sg-plate) 78%, var(--sg-ink));
  margin: 0;
  padding: 0.5rem 0;
}
.sg-utility__links {
  display: flex;
  gap: 1.6rem;
}
.sg-utility__links a {
  color: inherit;
  text-decoration: none;
}
.sg-utility__links a:hover {
  color: var(--sg-plate);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.25em;
}
.sg-masthead__main {
  padding-top: 0.9rem;
  padding-bottom: 0.75rem;
}
.sg-masthead.is-condensed .sg-masthead__main {
  padding-top: 0.55rem;
  padding-bottom: 0.5rem;
}
.sg-brand {
  gap: 0.9rem;
}
.sg-wordmark {
  font-size: 1.9rem;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 0.95;
  white-space: nowrap;
}
.sg-masthead.is-condensed .sg-wordmark {
  font-size: 1.5rem;
}
.sg-wordmark a {
  color: var(--sg-ink);
  text-decoration: none;
}
.sg-wordmark a::after,
.sg-footer__wordmark::after {
  content: ".";
  color: var(--sg-red);
}
.sg-tagline {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sg-gray);
  margin: 0 0 0.3rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: min(48ch, 34vw);
}
.sg-masthead__nav {
  gap: 1.5rem;
}
.sg-nav a {
  font-family: var(--sg-sans);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--sg-ink);
  text-decoration: none;
}
.sg-nav a:hover {
  color: var(--sg-red);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.4em;
}
.sg-nav .wp-block-navigation__container {
  gap: 1.4rem;
}
.sg-masthead__cta {
  font-family: var(--sg-mono);
  font-size: 0.71rem;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--sg-red);
  text-decoration: none;
  border: 1px solid color-mix(in srgb, var(--sg-red) 55%, var(--sg-line));
  border-radius: var(--sg-r);
  padding: 0.5em 0.95em 0.45em;
  white-space: nowrap;
  transition: color var(--sg-fast), background-color var(--sg-fast), border-color var(--sg-fast);
}
.sg-masthead__cta:hover {
  color: var(--sg-plate);
  background: var(--sg-red);
  border-color: var(--sg-red);
}

/* == The lede: feature-left + hairline-separated news rail ============ */
.sg-lede {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 19rem;
  column-gap: 0;
}
/* The feature: text left, art right — IEEE's lede architecture, our bones. */
.sg-lede__feature {
  display: grid;
  grid-template-columns: minmax(0, 10fr) minmax(0, 9fr);
  gap: clamp(1.4rem, 2.6vw, 2.4rem);
  align-items: center;
  min-width: 0;
  padding-inline-end: clamp(1.5rem, 3vw, 2.6rem);
}
.sg-lede__body {
  display: grid;
  gap: 1.1rem;
  min-width: 0;
}
.sg-lede__img img {
  aspect-ratio: 3 / 2;
  object-fit: cover;
}
.sg-lede__title {
  font-size: var(--wp--preset--font-size--3-xl);
}
.sg-lede > .sg-rail {
  border-inline-start: 1px solid var(--sg-line);
  padding-inline-start: clamp(1.5rem, 3vw, 2.6rem);
  min-width: 0;
}

/* The news rail — hairline rows, bold sans titles, mono meta. */
.sg-rail__head {
  font-family: var(--sg-mono);
  font-size: 0.71rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sg-ink);
  border-bottom: 3px solid var(--sg-ink);
  padding-bottom: 0.55rem;
  margin: 0;
}
.sg-rail__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sg-rail__list li {
  border-bottom: 1px solid var(--sg-line);
}
.sg-rail__list a {
  display: grid;
  gap: 0.35rem;
  padding: 0.85rem 0;
  text-decoration: none;
  color: inherit;
}
.sg-rail__topic {
  font-family: var(--sg-mono);
  font-size: 0.6563rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--sg-red);
}
.sg-rail__title {
  font-family: var(--sg-sans);
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: var(--sg-ink);
  overflow-wrap: break-word;
}
.sg-rail__list a:hover .sg-rail__title {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-decoration-color: var(--sg-red);
  text-underline-offset: 0.18em;
}

/* == Topic bands — black top rule, boxed chip, divided story row ====== */
.sg-topic {
  border-top: 3px solid var(--sg-ink);
  padding-top: 1rem;
}
.sg-topic__head {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.sg-topic__all {
  margin-inline-start: auto;
  font-family: var(--sg-mono);
  font-size: 0.71rem;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--sg-red);
  text-decoration: none;
  white-space: nowrap;
}
.sg-topic__all:hover {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.3em;
}
.sg-topic__grid {
  display: grid;
}
.sg-topic__grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.sg-topic__grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.sg-topic__grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.sg-topic__grid > * {
  min-width: 0;
  padding-inline: clamp(1.1rem, 2vw, 1.6rem);
  border-inline-start: 1px solid var(--sg-line);
}
.sg-topic__grid > *:first-child {
  padding-inline-start: 0;
  border-inline-start: 0;
}
.sg-topic__grid > *:last-child {
  padding-inline-end: 0;
}

.sg-story {
  display: grid;
  gap: 0.6rem;
  align-content: start;
}
.sg-story__img {
  margin-bottom: 0.25rem;
}
.sg-story__img img {
  aspect-ratio: 3 / 2;
  object-fit: cover;
}
.sg-story__title {
  font-family: var(--sg-sans);
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.28;
  letter-spacing: -0.01em;
  margin: 0;
  overflow-wrap: break-word;
  hyphens: auto;
}
.sg-story__title a {
  color: var(--sg-ink);
  text-decoration: none;
}
.sg-story__title a:hover {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-decoration-color: var(--sg-red);
  text-underline-offset: 0.16em;
}
.sg-story__dek {
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--sg-gray);
  margin: 0;
}

/* == Topic rail — boxed uppercase links to the hubs =================== */
.sg-topicrail {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  border-top: 1px solid var(--sg-line);
  border-bottom: 1px solid var(--sg-line);
  padding: 0.9rem 0;
}
.sg-topicrail__chip {
  font-family: var(--sg-sans);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--sg-ink);
  background: var(--sg-plate);
  border: 1px solid var(--sg-ink);
  border-radius: var(--sg-r);
  padding: 0.5em 1em 0.44em;
  text-decoration: none;
  transition: color var(--sg-fast), background-color var(--sg-fast);
}
.sg-topicrail__chip:hover {
  color: var(--sg-plate);
  background: var(--sg-ink);
}

/* == Briefing — "5 saker att veta" ==================================== */
.sg-brief {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 3px solid var(--sg-ink);
}
.sg-brief li {
  display: grid;
  grid-template-columns: 2.8rem minmax(0, 1fr);
  gap: 1.2rem;
  padding: 1.05rem 0;
  border-bottom: 1px solid var(--sg-line);
}
.sg-brief__no {
  font-family: var(--sg-mono);
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--sg-red);
  line-height: 1.5;
}
.sg-brief__title {
  font-family: var(--sg-sans);
  font-size: 1.0625rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.3;
  margin: 0;
}
.sg-brief__text {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--sg-gray);
  margin: 0.3rem 0 0;
  max-width: 40rem;
}

/* == Data table — mono numerals, hairlines, one red rule ============== */
.sg-data {
  overflow-x: auto;
  background: var(--sg-plate);
  border: 1px solid var(--sg-line);
  border-radius: var(--sg-r);
}
.sg-data table {
  border-collapse: collapse;
  width: 100%;
  min-width: 36rem;
  font-family: var(--sg-mono);
  font-size: 0.8125rem;
  font-variant-numeric: tabular-nums;
}
.sg-data th,
.sg-data td {
  text-align: left;
  padding: 0.7rem 1rem;
  border-bottom: 1px solid var(--sg-line);
}
.sg-data thead th {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--sg-gray);
  border-bottom: 2px solid var(--sg-ink);
}
.sg-data tbody th {
  font-family: var(--sg-sans);
  font-size: 0.875rem;
  font-weight: 600;
}
.sg-data tbody tr:last-child th,
.sg-data tbody tr:last-child td {
  border-bottom: 0;
}
.sg-data tr.is-highlight th {
  box-shadow: inset 3px 0 0 var(--sg-red);
}
.sg-data tr.is-highlight th,
.sg-data tr.is-highlight td {
  background: color-mix(in srgb, var(--sg-red) 5%, var(--sg-plate));
}
.sg-data__source {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--sg-gray);
  margin: 0.65rem 0 0;
}

/* == Article lede (long-form features) ================================ */
.sg-article-lede {
  max-width: 56rem;
  display: grid;
  gap: 1.1rem;
}
.sg-article-lede__media {
  max-width: 60rem;
}
.sg-article-lede__title {
  font-size: var(--wp--preset--font-size--3-xl);
  line-height: 1.06;
}
.sg-article-lede .sg-meta {
  border-top: 1px solid var(--sg-ink);
  border-bottom: 1px solid var(--sg-line);
  padding: 0.7rem 0;
}
.sg-article-lede__media {
  margin-top: 1.6rem;
}

/* == Figures — numbered caption discipline ============================ */
.sg-figure {
  margin: 0;
}
.sg-figure__cap {
  font-family: var(--sg-mono);
  font-size: 0.75rem;
  line-height: 1.6;
  color: var(--sg-gray);
  border-bottom: 1px solid var(--sg-line);
  padding: 0.6rem 0 0.85rem;
  margin: 0;
}
.sg-figure__no {
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--sg-red);
  padding-inline-end: 0.8em;
}

/* == Redaktion ======================================================== */
.sg-crew {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(13rem, 1fr));
  gap: 1.6rem 2rem;
}
.sg-crew__member {
  border-top: 3px solid var(--sg-ink);
  padding-top: 0.75rem;
  min-width: 0;
}
.sg-crew__name {
  font-family: var(--sg-sans);
  font-size: 1.0625rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0;
}
.sg-crew__role {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--sg-red);
  margin: 0.3rem 0 0.45rem;
}
.sg-crew__focus {
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--sg-gray);
  margin: 0;
}

/* == Newsletter — the black band ====================================== */
.sg-news {
  background: var(--sg-ink);
  border-radius: var(--sg-r);
  padding: clamp(1.8rem, 3.5vw, 3rem);
  display: grid;
  gap: 1.2rem;
}
.sg-news__title {
  font-family: var(--sg-serif);
  font-size: var(--wp--preset--font-size--xl);
  font-weight: 900;
  letter-spacing: -0.01em;
  line-height: 1.1;
  color: var(--sg-plate);
  margin: 0 0 0.45rem;
}
.sg-news__lede {
  font-size: 1rem;
  line-height: 1.55;
  color: color-mix(in srgb, var(--sg-plate) 72%, var(--sg-ink));
  margin: 0;
  max-width: 36rem;
}
.sg-news__form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: center;
  position: relative;
}
.sg-news__form input[type="email"] {
  flex: 1 1 16rem;
  font-family: var(--sg-mono);
  font-size: 0.9375rem;
  color: var(--sg-plate);
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--sg-plate) 35%, var(--sg-ink));
  border-radius: var(--sg-r);
  padding: 0.75em 1em;
  transition: border-color var(--sg-fast);
}
.sg-news__form input[type="email"]::placeholder {
  color: color-mix(in srgb, var(--sg-plate) 45%, var(--sg-ink));
}
.sg-news__form input[type="email"]:focus {
  outline: none;
  border-color: var(--sg-plate);
}
.sg-news__form button {
  font-family: var(--sg-mono);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sg-plate);
  background: var(--sg-red);
  border: 0;
  border-radius: var(--sg-r);
  padding: 0.95em 1.5em 0.9em;
  cursor: pointer;
  transition: background-color var(--sg-fast);
}
.sg-news__form button:hover {
  background: var(--sg-red-deep);
}
.sg-news__status {
  font-family: var(--sg-mono);
  font-size: 0.8125rem;
  color: var(--sg-plate);
}
.sg-news__note {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--sg-plate) 55%, var(--sg-ink));
  margin: 0;
}

/* == Page hero ======================================================== */
.sg-page-hero {
  display: grid;
  gap: 0.9rem;
  max-width: 46rem;
  border-bottom: 1px solid var(--sg-line);
  padding-bottom: 1.6rem;
}
.sg-page-hero__title {
  font-family: var(--sg-serif);
  font-size: var(--wp--preset--font-size--2-xl);
  font-weight: 900;
  line-height: 1.06;
  letter-spacing: -0.01em;
  margin: 0;
  overflow-wrap: break-word;
  hyphens: auto;
}
.sg-page-hero__dek {
  font-size: var(--wp--preset--font-size--md);
  line-height: 1.5;
  color: var(--sg-gray);
  margin: 0;
}

/* == Post list (query loop) & archives ================================ */
.sg-postlist {
  border-top: 3px solid var(--sg-ink);
  margin: 0;
  padding: 0;
}
.sg-postrow {
  display: grid;
  grid-template-columns: minmax(7rem, 10rem) minmax(0, 1fr);
  gap: 0.4rem 1rem;
  align-items: start;
  padding: 1.15rem 0;
  border-bottom: 1px solid var(--sg-line);
}
.sg-postrow__img {
  grid-row: 1 / span 4;
  margin: 0;
}
.sg-postrow__img img {
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.sg-postrow__topic,
.sg-postrow__topic a {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--sg-red);
  text-decoration: none;
  margin: 0;
}
.sg-postrow__topic a:hover {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.25em;
}
.sg-postrow__title {
  font-family: var(--sg-sans);
  font-weight: 800;
  letter-spacing: -0.015em;
  line-height: 1.2;
  margin: 0;
  overflow-wrap: break-word;
  hyphens: auto;
}
.sg-postrow__title a {
  color: var(--sg-ink);
  text-decoration: none;
}
.sg-postrow__title a:hover {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-decoration-color: var(--sg-red);
  text-underline-offset: 0.14em;
}
.sg-postrow__dek {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--sg-gray);
  margin: 0;
  max-width: 46rem;
}
.sg-postrow__date {
  font-family: var(--sg-mono);
  font-size: 0.71rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--sg-gray);
  margin: 0;
}
@media (max-width: 42rem) {
  .sg-postrow {
    grid-template-columns: 1fr;
  }
  .sg-postrow__img {
    grid-row: auto;
  }
}

/* == Article (single post) ============================================ */
.sg-main {
  padding-top: calc(var(--sg-section-y) * 0.55);
  padding-bottom: var(--sg-section-y);
}
.sg-main--wide {
  padding-top: 0;
  padding-bottom: 0;
}
.sg-page-head {
  margin-bottom: 2rem;
}
.sg-page-head h1 {
  font-family: var(--sg-serif);
  font-weight: 900;
  letter-spacing: -0.01em;
}
.sg-post__meta {
  margin-bottom: 1rem;
}
.sg-post__topic,
.sg-post__topic a {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--sg-red);
  text-decoration: none;
  margin: 0;
}
.sg-post__topic a {
  display: inline-flex;
  border: 1px solid color-mix(in srgb, var(--sg-red) 45%, var(--sg-line));
  border-radius: var(--sg-r);
  padding: 0.3em 0.65em 0.26em;
}
.sg-post__topic a:hover {
  color: var(--sg-plate);
  background: var(--sg-red);
  border-color: var(--sg-red);
}
.sg-post__title {
  margin-bottom: 0.8rem;
}
.sg-post__dek p {
  font-size: var(--wp--preset--font-size--md);
  line-height: 1.5;
  color: var(--sg-gray);
  margin: 0 0 1.1rem;
}
.sg-post__byline {
  font-family: var(--sg-mono);
  font-size: 0.71rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--sg-gray);
  gap: 0.9rem;
  border-top: 1px solid var(--sg-ink);
  border-bottom: 1px solid var(--sg-line);
  padding: 0.7rem 0;
  margin-bottom: 1.8rem;
}
.sg-post__author {
  font-weight: 600;
  color: var(--sg-ink);
}
.sg-post__author::before {
  content: "Av ";
}
.sg-post__date::before {
  content: "|";
  color: var(--sg-line);
  padding-inline-end: 0.9rem;
}
.sg-post__hero {
  margin-bottom: 2rem;
}
.sg-post__body > * {
  margin-block-start: 1.25em;
}
.sg-post__body h2 {
  margin-block-start: 1.9em;
}
.sg-post__footer {
  border-top: 3px solid var(--sg-ink);
  margin-top: 3rem;
  padding-top: 1.2rem;
}
.sg-post__nav a {
  font-family: var(--sg-mono);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--sg-ink);
}
.sg-post__nav a:hover {
  color: var(--sg-red);
  text-decoration: underline;
}

/* Hub head (archives) */
.sg-hub-head {
  margin-bottom: 2rem;
  border-bottom: 1px solid var(--sg-line);
  padding-bottom: 1.4rem;
}
.sg-hub-head__title {
  font-family: var(--sg-serif);
  font-size: var(--wp--preset--font-size--2-xl);
  font-weight: 900;
  letter-spacing: -0.01em;
  margin: 0;
}
.sg-pagination {
  font-family: var(--sg-mono);
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 2.6rem;
  border-top: 1px solid var(--sg-line);
  padding-top: 1.1rem;
}

/* == Footer — the black base ========================================== */
/* WP wraps the part in .wp-block-template-part, so the breathing room lives
   on the wrapper; wide pages end in their own band and need none. */
.wp-block-template-part:has(> .sg-footer) {
  margin-top: var(--sg-section-y);
}
.sg-main--wide + .wp-block-template-part:has(> .sg-footer) {
  margin-top: 0;
}
.sg-footer {
  background: var(--sg-ink);
  color: color-mix(in srgb, var(--sg-plate) 80%, var(--sg-ink));
  padding-top: calc(var(--sg-section-y) * 0.7);
  padding-bottom: 2rem;
}
.sg-footer__wordmark {
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--sg-plate);
}
.sg-footer__tagline {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--sg-plate) 55%, var(--sg-ink));
  margin-top: 0.5rem;
}
.sg-footer__note {
  font-size: 0.8125rem;
  line-height: 1.6;
  color: color-mix(in srgb, var(--sg-plate) 62%, var(--sg-ink));
  margin-top: 1.1rem;
  max-width: 26rem;
}
.sg-footer__head {
  font-family: var(--sg-mono);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--sg-plate) 48%, var(--sg-ink));
  margin: 0 0 0.7rem;
}
.sg-footer__links {
  display: grid;
  gap: 0.5rem;
  margin: 0;
}
.sg-footer__links a {
  font-family: var(--sg-sans);
  font-weight: 500;
  color: color-mix(in srgb, var(--sg-plate) 82%, var(--sg-ink));
  text-decoration: none;
}
.sg-footer__links a:hover {
  color: var(--sg-plate);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.25em;
}
.sg-footer__base {
  border-top: 1px solid color-mix(in srgb, var(--sg-plate) 16%, var(--sg-ink));
  margin-top: 2.4rem;
  padding-top: 1.1rem;
}
.sg-footer__copy {
  font-family: var(--sg-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--sg-plate) 48%, var(--sg-ink));
  margin: 0;
}

/* == Motion =========================================================== */
/* There is none. 90ms linear color/underline shifts are the whole budget —
   no reveals, no transforms, no parallax. The precision IS the personality. */

/* == Responsive ======================================================= */
@media (max-width: 1023px) {
  .sg-lede {
    grid-template-columns: 1fr;
  }
  .sg-lede__feature {
    padding-inline-end: 0;
  }
  .sg-lede > .sg-rail {
    border-inline-start: 0;
    padding-inline-start: 0;
    margin-top: 2.2rem;
  }
}
@media (max-width: 760px) {
  .sg-lede__feature {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 920px) {
  .sg-utility__links {
    display: none;
  }
  .sg-brand .sg-tagline {
    display: none;
  }
  .sg-masthead__nav {
    gap: 1rem;
  }
  .sg-nav .wp-block-navigation__container {
    gap: 1rem;
  }
}
@media (max-width: 900px) {
  .sg-topic__grid--2,
  .sg-topic__grid--3,
  .sg-topic__grid--4 {
    grid-template-columns: 1fr;
  }
  .sg-topic__grid > * {
    padding-inline: 0;
    border-inline-start: 0;
    border-top: 1px solid var(--sg-line);
    padding-top: 1.2rem;
    margin-top: 1.2rem;
  }
  .sg-topic__grid > *:first-child {
    border-top: 0;
    padding-top: 0;
    margin-top: 0;
  }
}
@media (max-width: 640px) {
  .sg-masthead__cta {
    display: none;
  }
  .sg-brief li {
    grid-template-columns: 2.1rem minmax(0, 1fr);
    gap: 0.8rem;
  }
}
