@layer components {
  /* ==========================================================================
     Blog: technical specimen notebook
     ========================================================================== */
  .blog-hero,
  .blog-article__opening {
    --blog-carbon: oklch(14% 0.01 245);
    --blog-graphite: oklch(21% 0.012 245);
    --blog-porcelain: oklch(96.5% 0.012 80);
    --blog-paper: oklch(91% 0.012 80);
    --blog-ink: oklch(20% 0.012 245);
    --blog-smoke: oklch(48% 0.012 245);
    --blog-steel: oklch(73% 0.008 245);
    --blog-cyan: oklch(76% 0.16 215);
    --blog-cyan-soft: oklch(91% 0.065 215);
    --blog-burgundy: oklch(29% 0.085 20);
    --blog-brass: oklch(66% 0.035 78);
  }

  .blog-hero {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding-block: clamp(3rem, 6vw, 5rem);
    color: var(--blog-porcelain);
    background:
      linear-gradient(90deg, color-mix(in oklch, var(--blog-cyan) 62%, transparent) 1px, transparent 1px) 0 0 / 7.5rem 100%,
      linear-gradient(180deg, color-mix(in oklch, var(--blog-steel) 20%, transparent) 1px, transparent 1px) 0 0 / 100% 4.5rem,
      linear-gradient(90deg, var(--blog-carbon) 0 42%, var(--blog-porcelain) 42% 100%);
    border-block-end: 1px solid var(--blog-steel);
  }

  .blog-hero__grid {
    display: grid;
    grid-template-columns: minmax(12rem, 0.72fr) minmax(0, 1fr);
    align-items: stretch;
    min-height: clamp(19rem, 36vw, 28rem);
  }

  .blog-hero__panel {
    position: relative;
    min-height: 19rem;
    border: 1px solid color-mix(in oklch, var(--blog-cyan) 54%, var(--blog-carbon));
    border-inline-end: 0;
    background:
      linear-gradient(90deg, transparent 0 47%, color-mix(in oklch, var(--blog-cyan) 58%, transparent) 47% 48%, transparent 48% 100%),
      linear-gradient(180deg, color-mix(in oklch, var(--blog-porcelain) 9%, transparent) 1px, transparent 1px) 0 0 / 100% 3rem,
      var(--blog-carbon);
  }

  .blog-hero__coordinate,
  .blog-hero__rule,
  .blog-hero__signal {
    position: absolute;
    display: block;
  }

  .blog-hero__coordinate {
    inset-block-start: 1.25rem;
    inset-inline-start: 1.25rem;
    color: var(--blog-cyan);
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0;
    text-transform: uppercase;
  }

  .blog-hero__signal {
    inset-block-start: 43%;
    inset-inline: 18% 0;
    height: 2px;
    background: var(--blog-cyan);
    box-shadow: 0 0 1.25rem color-mix(in oklch, var(--blog-cyan) 80%, transparent);
  }

  .blog-hero__signal::after {
    content: "";
    position: absolute;
    inset-block-start: -0.42rem;
    inset-inline-end: -0.42rem;
    width: 0.85rem;
    aspect-ratio: 1;
    border: 2px solid var(--blog-cyan);
    background: var(--blog-carbon);
  }

  .blog-hero__rule--one {
    inset-block-end: 24%;
    inset-inline-start: 1.25rem;
    width: 42%;
    height: 1px;
    background: var(--blog-brass);
  }

  .blog-hero__rule--two {
    inset-block-end: 1.25rem;
    inset-inline: 1.25rem 24%;
    height: 1px;
    background: color-mix(in oklch, var(--blog-porcelain) 30%, transparent);
  }

  .blog-hero__copy {
    align-self: end;
    padding: clamp(2rem, 6vw, 5rem);
    color: var(--blog-ink);
    background:
      linear-gradient(180deg, color-mix(in oklch, var(--blog-paper) 72%, transparent) 1px, transparent 1px) 0 0 / 100% 3rem,
      var(--blog-porcelain);
    border: 1px solid var(--blog-steel);
  }

  .blog-hero__eyebrow {
    margin: 0 0 1rem;
    color: var(--blog-burgundy);
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
  }

  .blog-hero__eyebrow a {
    color: inherit;
    text-decoration-color: color-mix(in oklch, var(--blog-burgundy) 34%, transparent);
    text-underline-offset: 0.22em;
  }

  .blog-hero h1 {
    max-width: 11ch;
    margin: 0;
    color: var(--blog-ink);
    font-family: var(--font-heading);
    font-size: clamp(3.25rem, 7.2vw, 6.9rem);
    font-weight: 600;
    line-height: 0.92;
    letter-spacing: 0;
    text-wrap: balance;
  }

  .blog-hero__subtitle {
    max-width: 45rem;
    margin: clamp(1.25rem, 3vw, 2rem) 0 0;
    color: var(--blog-smoke);
    font-size: clamp(1.125rem, 1.9vw, 1.45rem);
    line-height: 1.58;
    text-wrap: pretty;
  }

  .blog-listing {
    --blog-carbon: oklch(14% 0.01 245);
    --blog-porcelain: oklch(96.5% 0.012 80);
    --blog-paper: oklch(91% 0.012 80);
    --blog-ink: oklch(20% 0.012 245);
    --blog-smoke: oklch(48% 0.012 245);
    --blog-steel: oklch(73% 0.008 245);
    --blog-cyan: oklch(76% 0.16 215);
    --blog-cyan-soft: oklch(91% 0.065 215);
    --blog-burgundy: oklch(29% 0.085 20);
    padding-block: clamp(3rem, 7vw, 7rem);
    background:
      linear-gradient(90deg, color-mix(in oklch, var(--blog-steel) 34%, transparent) 1px, transparent 1px) 0 0 / 8rem 100%,
      var(--blog-porcelain);
  }

  .blog-listing__inner {
    display: grid;
    gap: clamp(2rem, 5vw, 4rem);
  }

  .blog-empty {
    margin: 0;
    padding: clamp(3rem, 7vw, 6rem);
    color: var(--blog-smoke);
    text-align: center;
    border: 1px solid var(--blog-steel);
    background: color-mix(in oklch, var(--blog-paper) 64%, var(--blog-porcelain));
  }

  /* ==========================================================================
     Featured specimen
     ========================================================================== */
  .blog-featured {
    border: 1px solid var(--blog-steel);
    background: var(--blog-porcelain);
  }

  .blog-featured__link {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(20rem, 0.72fr);
    color: inherit;
    text-decoration: none;
  }

  .blog-featured__media {
    position: relative;
    overflow: hidden;
    min-height: clamp(24rem, 46vw, 38rem);
    background: var(--blog-carbon);
  }

  .blog-featured__media img {
    width: 100%;
    height: 100%;
    min-height: inherit;
    display: block;
    object-fit: cover;
    filter: saturate(0.88) contrast(1.04);
    transition: transform 800ms var(--ease-out-expo), filter 800ms var(--ease-out-expo);
  }

  .blog-featured__media::before,
  .blog-featured__media::after,
  .blog-featured__scanline {
    content: "";
    position: absolute;
    pointer-events: none;
  }

  .blog-featured__media::before {
    inset: 0;
    background:
      linear-gradient(90deg, color-mix(in oklch, var(--blog-carbon) 68%, transparent), transparent 52%),
      linear-gradient(180deg, transparent 0 62%, color-mix(in oklch, var(--blog-carbon) 64%, transparent));
  }

  .blog-featured__media::after {
    inset-block-start: 12%;
    inset-inline: 11% 0;
    height: 2px;
    background: var(--blog-cyan);
  }

  .blog-featured__scanline {
    inset-block-end: 18%;
    inset-inline: 0 16%;
    height: 1px;
    background: color-mix(in oklch, var(--blog-brass, oklch(66% 0.035 78)) 85%, transparent);
  }

  .blog-featured__body {
    display: grid;
    align-content: end;
    gap: clamp(0.9rem, 1.8vw, 1.35rem);
    padding: clamp(1.5rem, 4.5vw, 4rem);
    background:
      linear-gradient(180deg, color-mix(in oklch, var(--blog-paper) 80%, transparent) 1px, transparent 1px) 0 0 / 100% 3rem,
      var(--blog-porcelain);
  }

  .blog-featured__index,
  .blog-featured__category,
  .blog-featured__meta,
  .blog-ledger__heading,
  .blog-card__index,
  .blog-card__category,
  .blog-card__meta,
  .blog-breadcrumb,
  .blog-article__kicker,
  .blog-article__meta,
  .blog-article__hero-caption {
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0;
  }

  .blog-featured__index,
  .blog-card__index {
    color: var(--blog-cyan);
  }

  .blog-featured__category,
  .blog-card__category,
  .blog-article__category {
    margin: 0;
    color: var(--blog-burgundy);
    font-weight: 700;
    text-transform: uppercase;
  }

  .blog-featured__title {
    margin: 0;
    color: var(--blog-ink);
    font-family: var(--font-heading);
    font-size: clamp(2.4rem, 4.6vw, 5rem);
    font-weight: 600;
    line-height: 0.98;
    letter-spacing: 0;
    text-wrap: balance;
  }

  .blog-featured__summary {
    max-width: 52ch;
    margin: 0;
    color: var(--blog-smoke);
    font-size: var(--font-size-lg);
    line-height: 1.62;
    text-wrap: pretty;
  }

  .blog-featured__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: clamp(0.75rem, 2vw, 1.5rem) 0 0;
    padding-block-start: 1rem;
    color: var(--blog-smoke);
    border-block-start: 1px solid var(--blog-steel);
  }

  .blog-featured__cta,
  .blog-card__meta span {
    color: var(--blog-ink);
    font-weight: 700;
  }

  .blog-featured:hover img {
    transform: scale(1.035);
    filter: saturate(0.96) contrast(1.08);
  }

  /* ==========================================================================
     Ledger entries
     ========================================================================== */
  .blog-ledger {
    border-block-start: 1px solid var(--blog-steel);
  }

  .blog-ledger__heading {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding-block: 0.85rem;
    color: var(--blog-smoke);
    border-block-end: 1px solid var(--blog-steel);
    text-transform: uppercase;
  }

  .blog-ledger__heading span:first-child {
    color: var(--blog-ink);
    font-weight: 700;
  }

  .blog-grid {
    display: grid;
    gap: 0;
    padding: 0;
    margin: 0;
    list-style: none;
  }

  .blog-card {
    border-block-end: 1px solid var(--blog-steel);
  }

  .blog-card__link {
    display: grid;
    grid-template-columns: 4rem minmax(0, 12rem) minmax(0, 1fr);
    gap: clamp(1rem, 3vw, 2.5rem);
    align-items: stretch;
    min-height: 12rem;
    padding-block: clamp(1.25rem, 3vw, 2.25rem);
    color: inherit;
    text-decoration: none;
  }

  .blog-card__index {
    padding-block-start: 0.2rem;
    font-weight: 700;
  }

  .blog-card__media {
    overflow: hidden;
    align-self: stretch;
    min-height: 9rem;
    background: var(--blog-carbon);
    border: 1px solid var(--blog-steel);
  }

  .blog-card__media img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    filter: saturate(0.82) contrast(1.04);
    transition: transform 700ms var(--ease-out-expo);
  }

  .blog-card__body {
    display: grid;
    align-content: center;
    gap: 0.75rem;
  }

  .blog-card__title {
    max-width: 22ch;
    margin: 0;
    color: var(--blog-ink);
    font-family: var(--font-heading);
    font-size: clamp(1.9rem, 3vw, 3.15rem);
    font-weight: 600;
    line-height: 1.03;
    letter-spacing: 0;
    text-wrap: balance;
    transition: color 220ms var(--ease-out-expo);
  }

  .blog-card__summary {
    max-width: 72ch;
    margin: 0;
    color: var(--blog-smoke);
    font-size: var(--font-size-base);
    line-height: 1.62;
    text-wrap: pretty;
  }

  .blog-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1.5rem;
    margin: 0.25rem 0 0;
    color: var(--blog-smoke);
  }

  .blog-card:hover .blog-card__title,
  .blog-card:focus-within .blog-card__title {
    color: var(--blog-burgundy);
  }

  .blog-card:hover img,
  .blog-card:focus-within img {
    transform: scale(1.035);
  }

  /* ==========================================================================
     Pagination
     ========================================================================== */
  .blog-pagination {
    display: flex;
    justify-content: center;
    margin-block-start: clamp(1rem, 3vw, 2rem);
  }

  .blog-pagination .pagination {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0;
    margin: 0;
    list-style: none;
  }

  .blog-pagination .pagination a,
  .blog-pagination .pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.75rem;
    min-height: 2.75rem;
    padding-inline: 0.85rem;
    color: var(--blog-ink);
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    text-decoration: none;
    border: 1px solid var(--blog-steel);
    background: var(--blog-porcelain);
  }

  .blog-pagination .pagination a:hover,
  .blog-pagination .pagination a:focus-visible {
    border-color: var(--blog-cyan);
    outline: 2px solid color-mix(in oklch, var(--blog-cyan) 45%, transparent);
    outline-offset: 2px;
  }

  .blog-pagination .pagination .current {
    color: var(--blog-porcelain);
    border-color: var(--blog-carbon);
    background: var(--blog-carbon);
  }

  .blog-pagination .pagination .disabled {
    color: var(--blog-smoke);
    opacity: 0.58;
  }

  /* ==========================================================================
     Article opening
     ========================================================================== */
  .blog-article {
    --blog-carbon: oklch(14% 0.01 245);
    --blog-graphite: oklch(21% 0.012 245);
    --blog-porcelain: oklch(96.5% 0.012 80);
    --blog-paper: oklch(91% 0.012 80);
    --blog-ink: oklch(20% 0.012 245);
    --blog-smoke: oklch(44% 0.012 245);
    --blog-steel: oklch(73% 0.008 245);
    --blog-cyan: oklch(76% 0.16 215);
    --blog-cyan-soft: oklch(91% 0.065 215);
    --blog-burgundy: oklch(29% 0.085 20);
    --blog-brass: oklch(66% 0.035 78);
    color: var(--blog-ink);
    background: var(--blog-porcelain);
  }

  .blog-article__opening {
    padding-block: clamp(1.25rem, 3vw, 2rem) clamp(2.5rem, 5vw, 4rem);
    background: var(--blog-carbon);
  }

  .blog-breadcrumb {
    color: color-mix(in oklch, var(--blog-porcelain) 70%, var(--blog-steel));
  }

  .blog-breadcrumb ol {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.6rem;
    padding: 0;
    margin: 0;
    list-style: none;
  }

  .blog-breadcrumb li + li::before {
    content: "/";
    margin-inline-end: 0.6rem;
    color: var(--blog-cyan);
  }

  .blog-breadcrumb a {
    color: inherit;
    text-decoration-color: color-mix(in oklch, var(--blog-cyan) 46%, transparent);
    text-underline-offset: 0.22em;
  }

  .blog-breadcrumb a:hover,
  .blog-breadcrumb a:focus-visible {
    color: var(--blog-cyan);
  }

  .blog-breadcrumb [aria-current="page"] {
    color: color-mix(in oklch, var(--blog-porcelain) 82%, var(--blog-steel));
  }

  .blog-article__header {
    display: grid;
    gap: clamp(1rem, 2vw, 1.5rem);
    max-width: 68rem;
    padding-block: clamp(2rem, 5vw, 4.5rem) clamp(1.5rem, 4vw, 3rem);
    color: var(--blog-porcelain);
  }

  .blog-article__kicker {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem 1.25rem;
    align-items: center;
    color: color-mix(in oklch, var(--blog-porcelain) 72%, var(--blog-steel));
    text-transform: uppercase;
  }

  .blog-article__category a {
    color: var(--blog-cyan);
    text-decoration: none;
  }

  .blog-article__category a:hover,
  .blog-article__category a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 0.22em;
  }

  .blog-article__title {
    max-width: 13ch;
    margin: 0;
    color: var(--blog-porcelain);
    font-family: var(--font-heading);
    font-size: clamp(3.1rem, 8.5vw, 8.5rem);
    font-weight: 600;
    line-height: 0.92;
    letter-spacing: 0;
    text-wrap: balance;
  }

  .blog-article__summary {
    max-width: 64ch;
    margin: 0;
    color: color-mix(in oklch, var(--blog-porcelain) 78%, var(--blog-steel));
    font-size: clamp(1.125rem, 2vw, 1.45rem);
    line-height: 1.62;
    text-wrap: pretty;
  }

  .blog-article__meta {
    margin: 0;
    color: color-mix(in oklch, var(--blog-porcelain) 68%, var(--blog-steel));
  }

  .blog-article__hero {
    position: relative;
    overflow: hidden;
    width: min(100% - 2rem, 86rem);
    min-height: clamp(22rem, 56vw, 48rem);
    margin: 0 auto;
    border: 1px solid color-mix(in oklch, var(--blog-cyan) 58%, var(--blog-steel));
    background: var(--blog-carbon);
  }

  .blog-article__hero img {
    width: 100%;
    height: 100%;
    min-height: inherit;
    display: block;
    object-fit: cover;
    filter: saturate(0.9) contrast(1.05);
  }

  .blog-article__hero::before,
  .blog-article__hero::after {
    content: "";
    position: absolute;
    pointer-events: none;
  }

  .blog-article__hero::before {
    inset: 0;
    background:
      linear-gradient(90deg, color-mix(in oklch, var(--blog-carbon) 72%, transparent), transparent 42%),
      linear-gradient(180deg, transparent 50%, color-mix(in oklch, var(--blog-carbon) 70%, transparent));
  }

  .blog-article__hero::after {
    inset-block-start: 18%;
    inset-inline: 0 12%;
    height: 2px;
    background: var(--blog-cyan);
    box-shadow: 0 0 1.5rem color-mix(in oklch, var(--blog-cyan) 64%, transparent);
  }

  .blog-article__hero-caption {
    position: absolute;
    inset-inline: clamp(1rem, 4vw, 3rem);
    inset-block-end: clamp(1rem, 4vw, 2.5rem);
    display: flex;
    align-items: center;
    gap: 1rem;
    color: var(--blog-porcelain);
    text-transform: uppercase;
  }

  .blog-article__hero-caption span:last-child {
    flex: 1;
    height: 1px;
    background: color-mix(in oklch, var(--blog-porcelain) 44%, transparent);
  }

  /* ==========================================================================
     Article body
     ========================================================================== */
  .blog-article__body {
    width: min(calc(100% - 3rem), 44rem);
    max-width: none;
    margin-inline: auto;
    padding-block: clamp(2rem, 5vw, 4.5rem) clamp(4rem, 8vw, 7rem);
    color: var(--blog-ink);
    font-size: clamp(1.08rem, 1.25vw, 1.22rem);
    line-height: 1.78;
  }

  .blog-article__body > * {
    margin-block: 0;
  }

  .blog-article__body > * + * {
    margin-block-start: 1.45em;
  }

  .blog-article__body h2,
  .blog-article__body h3,
  .blog-article__body h4 {
    color: var(--blog-ink);
    font-family: var(--font-heading);
    font-weight: 600;
    letter-spacing: 0;
    text-wrap: balance;
  }

  .blog-article__body h2 {
    margin-block-start: clamp(3.2rem, 7vw, 5rem);
    padding-block-start: 1rem;
    font-size: clamp(2.2rem, 4vw, 3.8rem);
    line-height: 1.02;
    border-block-start: 1px solid var(--blog-steel);
  }

  .blog-article__body h3 {
    margin-block-start: 2.25em;
    font-size: clamp(1.55rem, 2.8vw, 2.45rem);
    line-height: 1.12;
  }

  .blog-article__body h2 .anchor,
  .blog-article__body h3 .anchor {
    display: none;
  }

  .blog-article__body p {
    text-wrap: pretty;
  }

  .blog-article__body a {
    color: var(--blog-burgundy);
    font-weight: 700;
    text-decoration-color: color-mix(in oklch, var(--blog-cyan) 60%, transparent);
    text-decoration-thickness: 0.08em;
    text-underline-offset: 0.2em;
  }

  .blog-article__body a:hover,
  .blog-article__body a:focus-visible {
    color: var(--blog-ink);
    text-decoration-color: var(--blog-cyan);
  }

  .blog-article__body ul,
  .blog-article__body ol {
    display: grid;
    gap: 0.45em;
    padding-inline-start: 1.35em;
  }

  .blog-article__body li::marker {
    color: var(--blog-burgundy);
    font-weight: 700;
  }

  .blog-article__body blockquote {
    margin-inline: clamp(-1rem, -3vw, -2rem);
    padding: clamp(1.25rem, 3vw, 2rem);
    color: var(--blog-ink);
    font-family: var(--font-heading);
    font-size: clamp(1.65rem, 3.5vw, 3rem);
    font-weight: 600;
    line-height: 1.14;
    background: color-mix(in oklch, var(--blog-cyan-soft) 30%, var(--blog-porcelain));
    border: 1px solid color-mix(in oklch, var(--blog-cyan) 46%, var(--blog-steel));
  }

  .blog-article__body blockquote > * + * {
    margin-block-start: 0.75em;
  }

  .blog-article__body code {
    padding: 0.14em 0.34em;
    color: var(--blog-ink);
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 0.88em;
    font-variant-ligatures: none;
    background: color-mix(in oklch, var(--blog-cyan-soft) 42%, var(--blog-porcelain));
    border: 1px solid color-mix(in oklch, var(--blog-cyan) 30%, var(--blog-steel));
  }

  .blog-article__body pre {
    overflow-x: auto;
    padding: clamp(1rem, 3vw, 1.5rem);
    color: var(--blog-porcelain);
    background: var(--blog-carbon);
    border: 1px solid var(--blog-steel);
  }

  .blog-article__body pre code {
    padding: 0;
    color: inherit;
    background: transparent;
    border: 0;
  }

  .blog-article__body img {
    width: min(100%, 62rem);
    height: auto;
    display: block;
    margin-block: clamp(2rem, 5vw, 3.5rem);
    margin-inline: auto;
    border: 1px solid var(--blog-steel);
  }

  .blog-article__body figure {
    margin-block: clamp(2rem, 5vw, 3.5rem);
    margin-inline: min(-8vw, -5rem);
  }

  .blog-article__body figure img {
    width: 100%;
    max-width: none;
    margin: 0;
  }

  .blog-article__body figcaption {
    margin-block-start: 0.65rem;
    color: var(--blog-smoke);
    font-size: var(--font-size-sm);
    line-height: 1.45;
  }

  .blog-article__body hr {
    height: 1px;
    margin-block: clamp(2rem, 5vw, 3.5rem);
    background: var(--blog-steel);
    border: 0;
  }

  .blog-article__body table {
    display: block;
    overflow-x: auto;
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-base);
    border: 1px solid var(--blog-steel);
  }

  .blog-article__body th,
  .blog-article__body td {
    padding: 0.75rem 1rem;
    text-align: start;
    vertical-align: top;
    border: 1px solid var(--blog-steel);
  }

  .blog-article__body th {
    color: var(--blog-ink);
    background: color-mix(in oklch, var(--blog-paper) 72%, var(--blog-porcelain));
  }

  /* ==========================================================================
     Related posts
     ========================================================================== */
  .blog-related {
    padding-block: clamp(3rem, 7vw, 6rem);
    background: var(--blog-carbon);
    border-block-start: 1px solid var(--blog-steel);
  }

  .blog-related .container {
    display: grid;
    gap: clamp(1.5rem, 4vw, 3rem);
  }

  .blog-related__heading {
    margin: 0;
    color: var(--blog-porcelain);
    font-family: var(--font-heading);
    font-size: clamp(2.3rem, 5vw, 4.6rem);
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0;
  }

  .blog-related .blog-grid {
    border-block-start: 1px solid color-mix(in oklch, var(--blog-porcelain) 28%, transparent);
  }

  .blog-related .blog-card {
    border-block-end-color: color-mix(in oklch, var(--blog-porcelain) 28%, transparent);
  }

  .blog-related .blog-card__link,
  .blog-related .blog-card__title,
  .blog-related .blog-card__meta span {
    color: var(--blog-porcelain);
  }

  .blog-related .blog-card__summary,
  .blog-related .blog-card__meta {
    color: color-mix(in oklch, var(--blog-porcelain) 68%, var(--blog-steel));
  }

  @media (max-width: 64rem) {
    .blog-hero {
      background:
        linear-gradient(180deg, var(--blog-carbon) 0 45%, var(--blog-porcelain) 45% 100%);
    }

    .blog-hero__grid,
    .blog-featured__link {
      grid-template-columns: 1fr;
    }

    .blog-hero__panel {
      border-inline-end: 1px solid color-mix(in oklch, var(--blog-cyan) 54%, var(--blog-carbon));
    }

    .blog-card__link {
      grid-template-columns: 3.25rem minmax(0, 1fr);
    }

    .blog-card__media {
      display: none;
    }
  }

  @media (max-width: 44rem) {
    .blog-hero {
      padding-block: 2rem 3rem;
    }

    .blog-hero__grid {
      min-height: auto;
    }

    .blog-hero__panel {
      min-height: 11rem;
    }

    .blog-hero__copy,
    .blog-featured__body {
      padding: 1.25rem;
    }

    .blog-hero h1,
    .blog-article__title {
      max-width: 100%;
    }

    .blog-featured__media,
    .blog-article__hero {
      min-height: 18rem;
    }

    .blog-card__link {
      grid-template-columns: 1fr;
      gap: 0.75rem;
    }

    .blog-card__summary {
      display: -webkit-box;
      overflow: hidden;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 4;
    }

    .blog-ledger__heading,
    .blog-featured__meta,
    .blog-article__kicker {
      display: grid;
    }

    .blog-article__body figure,
    .blog-article__body blockquote {
      margin-inline: 0;
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .blog-featured__media img,
    .blog-card__media img,
    .blog-card__title {
      transition: none;
    }
  }
}
