/*
Theme Name: MD Crackower 2026
Theme URI: https://mdcrackower.com
Description: Custom Genesis child theme for the MD Crackower author site. Editorial Ink palette + Literary Editorial typography (Playfair Display + Cormorant Garamond + Inter). Built to translate the locked Figma brand system at high fidelity. Forked from genesis-sample 3.4.3.
Author: Felix Kade
Author URI: https://mdcrackower.com
Template: genesis
Version: 1.0.0
Text Domain: mdcrackower-2026
Tags: editorial, author, literary, accessibility-ready, custom-colors, custom-logo, custom-menu, editor-style, footer-widgets, threaded-comments, translation-ready
Requires at least: 6.4
Requires PHP: 8.0
*/

/* ============================================================
   EDITORIAL INK · DESIGN TOKENS
   ============================================================ */

:root {
  /* Palette · Editorial Ink (locked in Figma 3:15) */
  --color-paper:    #F6F1E6; /* Base — page backgrounds */
  --color-ink:      #1A1A1A; /* Body text + dark surfaces */
  --color-oxblood:  #6B2737; /* Italic accents, links, primary CTA */
  --color-gilt:     #C9A961; /* Decorative on Ink only — fails AA on Paper */
  --color-walnut:   #8B7355; /* Secondary text, borders, low-emphasis meta */
  --color-vellum:   #E8DCC4; /* Alt-section / card surfaces */
  --color-ink-soft: #3A3A3A; /* Lede color (Ink-tint) */
  --color-walnut-soft: rgba(139, 115, 85, 0.35); /* Hairline rules on Paper */
  --color-gilt-soft: rgba(201, 169, 97, 0.35);   /* Hairline rules on Ink */

  /* Typography · Literary Editorial (locked in Figma 16:15) */
  --font-display: "Playfair Display", "Times New Roman", Georgia, serif;
  --font-italic:  "Cormorant Garamond", "Garamond", Georgia, serif;
  --font-utility: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;

  /* Type scale (px values from Figma) */
  --fs-display:  3.5rem;     /* H1 56 */
  --fs-h2:       2rem;       /* H2 32 */
  --fs-h3:       1.5rem;     /* H3 24 */
  --fs-h4:       1.1875rem;  /* H4 19 */
  --fs-lede:     1.375rem;   /* Lede 22 */
  --fs-body:     1.0625rem;  /* Body 17 */
  --fs-meta:     0.6875rem;  /* Meta 11 */
  --fs-eyebrow:  0.5625rem;  /* Eyebrow 9 */

  /* Line heights */
  --lh-display: 1.05;
  --lh-h2:      1.15;
  --lh-h3:      1.25;
  --lh-lede:    1.4;
  --lh-body:    1.6;
  --lh-meta:    1;

  /* Tracking */
  --ls-display: -0.012em;
  --ls-meta:    0.32em;
  --ls-eyebrow: 0.27em;
  --ls-wordmark: 0.18em;

  /* Layout */
  --content-max: 720px;       /* Body copy max width */
  --container-max: 1280px;    /* Page container max width */
  --gutter: clamp(1.25rem, 4vw, 2.5rem);

  /* Spacing scale */
  --space-3xs: 0.25rem;
  --space-2xs: 0.5rem;
  --space-xs:  0.75rem;
  --space-s:   1rem;
  --space-m:   1.5rem;
  --space-l:   2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;
  --space-3xl: 8rem;

  /* Hairline */
  --rule: 1px;
}

/* ============================================================
   FONT LOADING · Bunny Fonts (open Google Fonts mirror, no GDPR)
   ============================================================ */

/* Imported via @import for simplicity; functions.php also enqueues
   a preconnect to fonts.bunny.net for faster handshake. */
@import url("https://fonts.bunny.net/css?family=playfair-display:400,500,600,700|cormorant-garamond:400,400i,500i|inter:400,500&display=swap");

/* ============================================================
   RESET · BASE
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

html {
  font-size: 17px; /* Base unit so 1rem ≈ 17px (matches Figma body) */
  scroll-behavior: smooth;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  background-color: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-italic);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg, video { max-width: 100%; height: auto; display: block; }

a {
  color: var(--color-oxblood);
  text-decoration: none;
  text-underline-offset: 0.2em;
  text-decoration-thickness: 0.06em;
  border-bottom: 1px solid currentColor;
  transition: opacity 0.15s ease;
}
a:hover, a:focus-visible { opacity: 0.7; }
a:focus-visible {
  outline: 2px solid var(--color-oxblood);
  outline-offset: 3px;
  border-radius: 1px;
}

/* ============================================================
   TYPOGRAPHY · LITERARY EDITORIAL
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-ink);
  margin: 0 0 var(--space-m);
  text-wrap: balance;
}

h1, .h1 {
  font-size: clamp(2.5rem, 5vw, var(--fs-display));
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  margin-bottom: var(--space-l);
}

h2, .h2 {
  font-size: clamp(1.625rem, 3vw, var(--fs-h2));
  line-height: var(--lh-h2);
}

h3, .h3 { font-size: var(--fs-h3); line-height: var(--lh-h3); }
h4, .h4 { font-size: var(--fs-h4); line-height: 1.3; }

p { margin: 0 0 var(--space-m); }

/* Italic display accent — used inside H1/H2 to highlight 1-3 words in Cormorant Italic + Oxblood */
.italic-accent,
em.accent,
h1 em, h2 em, h3 em {
  font-family: var(--font-italic);
  font-weight: 400;
  font-style: italic;
  color: var(--color-oxblood);
  letter-spacing: 0;
}

/* Lede paragraph */
.lede,
.entry-lede,
.has-lede-style {
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-lede);
  line-height: var(--lh-lede);
  color: var(--color-ink-soft);
  margin-bottom: var(--space-l);
  max-width: 56ch;
}

/* Meta / eyebrow text — uppercase Inter tracked */
.meta,
.eyebrow,
.entry-meta,
.has-meta-style {
  font-family: var(--font-utility);
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-meta);
  text-transform: uppercase;
  font-weight: 400;
  line-height: var(--lh-meta);
  color: var(--color-ink);
}

.eyebrow-small {
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
}

.eyebrow-walnut { color: var(--color-walnut); }
.eyebrow-gilt   { color: var(--color-gilt); }

/* Drop cap on first paragraph of essays */
.entry-content > p:first-of-type::first-letter,
.has-drop-cap::first-letter {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-oxblood);
  font-size: 4.5rem;
  line-height: 0.85;
  float: left;
  padding: 0.1em 0.12em 0 0;
  margin-top: 0.04em;
}

/* Pull quote (used inline in body) */
blockquote, .pull-quote,
.wp-block-quote {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: var(--fs-lede);
  line-height: var(--lh-lede);
  color: var(--color-oxblood);
  border-left: 2px solid var(--color-walnut);
  padding-left: var(--space-m);
  margin: var(--space-l) 0;
  max-width: 56ch;
}

blockquote cite, .pull-quote cite {
  display: block;
  margin-top: var(--space-2xs);
  font-family: var(--font-utility);
  font-style: normal;
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-meta);
  text-transform: uppercase;
  color: var(--color-walnut);
}

/* Hairline rules */
hr, .hairline {
  border: 0;
  border-top: var(--rule) solid var(--color-walnut-soft);
  margin: var(--space-xl) 0;
}

.hairline-tight { margin: var(--space-m) 0; }
.hairline-ink   { border-top-color: var(--color-ink); }
.hairline-gilt  { border-top-color: var(--color-gilt-soft); }

/* ============================================================
   LAYOUT CONTAINERS
   ============================================================ */

.site-container,
.wrap,
.entry-content {
  max-width: var(--container-max);
  padding-inline: var(--gutter);
  margin-inline: auto;
}

.entry-content {
  max-width: var(--content-max);
}

.full-width-content .entry-content,
.section-full > * { max-width: var(--container-max); }

/* ============================================================
   HEADER · NAV
   ============================================================ */

.site-header {
  background-color: var(--color-paper);
  border-bottom: var(--rule) solid var(--color-ink);
  padding: var(--space-l) 0 var(--space-m);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: saturate(150%) blur(10px);
  -webkit-backdrop-filter: saturate(150%) blur(10px);
  background-color: rgba(246, 241, 230, 0.92);
}

.site-header .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-l);
}

.site-title,
.site-title a,
.brand-wordmark {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: var(--ls-wordmark);
  text-transform: uppercase;
  color: var(--color-ink);
  border: 0;
  margin: 0;
  text-decoration: none;
}

.site-title a:hover { opacity: 0.7; }

.site-description { display: none; } /* tagline hidden — covered by other surfaces */

/* Primary nav */
.genesis-nav-menu,
.nav-primary ul,
.site-nav ul {
  display: flex;
  gap: var(--space-l);
  list-style: none;
  margin: 0;
  padding: 0;
}

.genesis-nav-menu a,
.nav-primary a,
.site-nav a {
  font-family: var(--font-utility);
  font-size: var(--fs-meta);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-ink);
  border: 0;
  font-weight: 400;
}

.genesis-nav-menu .current-menu-item a,
.nav-primary .current-menu-item a,
.site-nav .current-menu-item a {
  color: var(--color-oxblood);
}

/* ============================================================
   HERO BLOCK (front page + page hero variants)
   ============================================================ */

.hero {
  padding: var(--space-2xl) 0 var(--space-xl);
  border-bottom: var(--rule) solid var(--color-walnut-soft);
}

.hero .wrap {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
}

.hero-headline {
  font-size: clamp(2.25rem, 5vw, var(--fs-display));
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  margin-bottom: var(--space-m);
  text-wrap: balance;
}

.hero-lede { max-width: 32rem; }

.hero-cta {
  display: inline-block;
  background-color: var(--color-ink);
  color: var(--color-paper);
  font-family: var(--font-utility);
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  padding: var(--space-xs) var(--space-m);
  border: 0;
  margin-top: var(--space-m);
}
.hero-cta:hover { opacity: 0.85; }

.hero-badge {
  width: clamp(140px, 14vw, 200px);
  aspect-ratio: 1;
  border-radius: 50%;
  border: var(--rule) solid var(--color-oxblood);
  display: grid;
  place-items: center;
  text-align: center;
  font-family: var(--font-italic);
  font-style: italic;
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-oxblood);
  line-height: 1.3;
  justify-self: end;
}

@media (max-width: 768px) {
  .hero { padding: var(--space-xl) 0; }
  .hero .wrap { grid-template-columns: 1fr; gap: var(--space-l); }
  .hero-badge { justify-self: start; width: 130px; }
}

/* ============================================================
   SECTION · GENERIC
   ============================================================ */

.section {
  padding: var(--space-xl) 0;
  border-bottom: var(--rule) solid var(--color-walnut-soft);
}

.section:last-child { border-bottom: 0; }
.section-vellum { background-color: var(--color-vellum); border-color: transparent; }
.section-ink {
  background-color: var(--color-ink);
  color: var(--color-paper);
  border-color: transparent;
}
.section-ink h1, .section-ink h2, .section-ink h3 { color: var(--color-paper); }
.section-ink em.accent, .section-ink .italic-accent { color: var(--color-gilt); }
.section-ink a { color: var(--color-gilt); }

.section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--space-l);
  padding-bottom: var(--space-s);
  border-bottom: var(--rule) solid var(--color-walnut-soft);
}

.section-header .eyebrow { color: var(--color-walnut); }

/* ============================================================
   POST CARD · ARTICLE GRID
   ============================================================ */

.post-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-l);
}

@media (max-width: 900px) { .post-grid { grid-template-columns: 1fr; gap: var(--space-l); } }

.post-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
}

.post-card .eyebrow { color: var(--color-walnut); margin-bottom: var(--space-2xs); }

.post-card .title {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: var(--fs-h3);
  font-weight: 500;
  color: var(--color-ink);
  line-height: 1.25;
  margin: 0;
}
.post-card .title a { color: inherit; border: 0; }

.post-card .excerpt {
  color: var(--color-ink-soft);
  font-size: var(--fs-body);
}

.post-card .byline {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-walnut);
  margin-top: var(--space-2xs);
}

/* Featured row variant (single full-width card) */
.post-card-featured {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--space-xl);
  align-items: center;
  margin-bottom: var(--space-xl);
}
.post-card-featured .featured-image {
  background-color: var(--color-ink);
  aspect-ratio: 16 / 10;
  display: grid;
  place-items: center;
  color: var(--color-walnut);
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .post-card-featured { grid-template-columns: 1fr; }
}

/* ============================================================
   BOOK CARD
   ============================================================ */

.book-row {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-xl);
  border-bottom: var(--rule) solid var(--color-walnut-soft);
}
.book-row:last-of-type { border-bottom: 0; }

.book-cover {
  aspect-ratio: 2/3;
  background-color: var(--color-ink);
  color: var(--color-paper);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--space-m);
  font-family: var(--font-display);
  position: relative;
}
.book-cover::before {
  content: "";
  position: absolute;
  top: var(--space-m); left: var(--space-m);
  width: 30px; height: 1px;
  background-color: var(--color-gilt);
}
.book-cover .wordmark {
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  font-family: var(--font-utility);
  color: var(--color-paper);
  margin-top: var(--space-l);
}
.book-cover .title {
  font-size: 1.625rem;
  line-height: 1.15;
  font-weight: 500;
}
.book-cover .title em { font-family: var(--font-italic); color: var(--color-gilt); font-style: italic; }
.book-cover .footer {
  font-family: var(--font-italic);
  font-style: italic;
  font-size: var(--fs-meta);
  color: var(--color-paper);
  align-self: flex-end;
}

.book-meta { font-family: var(--font-utility); font-size: var(--fs-eyebrow); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--color-walnut); margin-bottom: var(--space-s); }

.book-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: 1.15;
  margin-bottom: var(--space-s);
}
.book-title em { font-family: var(--font-italic); color: var(--color-oxblood); font-style: italic; }

.book-tagline { font-family: var(--font-italic); font-style: italic; color: var(--color-ink-soft); font-size: var(--fs-h3); margin-bottom: var(--space-m); }

.book-buy {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-m);
  margin-top: var(--space-m);
  padding-top: var(--space-m);
  border-top: var(--rule) solid var(--color-walnut-soft);
}
.book-buy a {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-oxblood);
  border-bottom: 1px solid currentColor;
}

@media (max-width: 768px) {
  .book-row { grid-template-columns: 140px 1fr; gap: var(--space-l); }
  .book-cover .title { font-size: 1.25rem; }
}

/* ============================================================
   NEWSLETTER FORM
   ============================================================ */

.newsletter {
  background-color: var(--color-vellum);
  padding: var(--space-2xl) var(--gutter);
  text-align: center;
}

.newsletter .eyebrow {
  color: var(--color-walnut);
  margin-bottom: var(--space-s);
  display: inline-block;
}

.newsletter h2 {
  font-size: clamp(1.625rem, 3.5vw, var(--fs-h2));
  margin-bottom: var(--space-s);
  text-wrap: balance;
}

.newsletter p { color: var(--color-ink-soft); max-width: 36rem; margin-inline: auto; margin-bottom: var(--space-l); }

.newsletter-form {
  display: flex;
  gap: 0;
  max-width: 30rem;
  margin: 0 auto;
  border-bottom: var(--rule) solid var(--color-ink);
}

.newsletter-form input[type="email"] {
  flex: 1;
  background: transparent;
  border: 0;
  padding: var(--space-s) 0;
  font-family: var(--font-italic);
  font-style: italic;
  font-size: var(--fs-body);
  color: var(--color-ink);
}
.newsletter-form input[type="email"]:focus-visible { outline: 0; }
.newsletter-form input[type="email"]::placeholder { color: var(--color-walnut); opacity: 0.7; }

.newsletter-form button {
  background-color: var(--color-ink);
  color: var(--color-paper);
  font-family: var(--font-utility);
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  border: 0;
  padding: var(--space-s) var(--space-m);
  cursor: pointer;
}
.newsletter-form button:hover { opacity: 0.85; }

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer {
  background-color: var(--color-ink);
  color: var(--color-paper);
  padding: var(--space-2xl) 0 var(--space-xl);
  margin-top: var(--space-2xl);
}

.site-footer::before {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background-color: var(--color-gilt);
  margin: 0 var(--gutter) var(--space-l);
}

.site-footer .wrap {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1.5fr;
  gap: var(--space-2xl);
}

@media (max-width: 768px) {
  .site-footer .wrap { grid-template-columns: 1fr; gap: var(--space-xl); }
}

.site-footer h4,
.site-footer .footer-eyebrow {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-paper);
  margin-bottom: var(--space-m);
  font-weight: 400;
}

.site-footer .brand-wordmark {
  color: var(--color-paper);
  font-size: 1rem;
  display: block;
  margin-bottom: var(--space-2xs);
}
.site-footer .brand-tagline {
  font-family: var(--font-italic);
  font-style: italic;
  color: var(--color-walnut);
  font-size: var(--fs-meta);
}

.site-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2xs); }
.site-footer a {
  color: var(--color-paper);
  font-family: var(--font-utility);
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  border: 0;
}
.site-footer a:hover { color: var(--color-gilt); }

.site-footer .credit {
  border-top: var(--rule) solid var(--color-gilt-soft);
  margin-top: var(--space-xl);
  padding-top: var(--space-m);
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-walnut);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-m);
}

/* ============================================================
   ENTRY · SINGLE POST
   ============================================================ */

.single-essay .entry-header,
.single .entry-header,
.single-essay-header {
  text-align: left;
  padding: var(--space-xl) 0 var(--space-l);
}

.single-essay-header .eyebrow { color: var(--color-walnut); margin-bottom: var(--space-m); display: inline-block; }
.single-essay-header h1 { margin-bottom: var(--space-l); }
.single-essay-header .lede { margin-bottom: var(--space-m); }
.single-essay-header .byline {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-ink);
}

.entry-content {
  font-family: var(--font-italic);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  font-style: normal;
}
.entry-content p { max-width: var(--content-max); }
.entry-content h2 { margin-top: var(--space-xl); }
.entry-content h2 em.accent, .entry-content h2 em { font-style: italic; color: var(--color-oxblood); font-family: var(--font-italic); }

/* ============================================================
   ARCHIVE · CATEGORY FILTER
   ============================================================ */

.archive-header {
  text-align: center;
  padding: var(--space-2xl) 0 var(--space-l);
}
.archive-header h1 { margin-bottom: var(--space-s); }
.archive-header .lede { margin-inline: auto; }

.term-filter {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-l);
  padding: var(--space-l) 0;
  border-top: var(--rule) solid var(--color-walnut-soft);
  border-bottom: var(--rule) solid var(--color-walnut-soft);
  margin-bottom: var(--space-xl);
}
.term-filter a {
  font-family: var(--font-utility);
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-ink);
  border: 0;
}
.term-filter a.is-active,
.term-filter .current-cat a {
  color: var(--color-oxblood);
  border-bottom: 1px solid currentColor;
}

/* Pagination */
.pagination, .archive-pagination {
  display: flex;
  justify-content: center;
  gap: var(--space-m);
  padding: var(--space-xl) 0;
  font-family: var(--font-utility);
  font-size: var(--fs-meta);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
}
.pagination a, .pagination .current { border: 0; }
.pagination .current { color: var(--color-oxblood); border-bottom: 1px solid currentColor; }

/* ============================================================
   ABOUT PAGE · CREDENTIALS
   ============================================================ */

.about-bio {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: var(--space-2xl);
  padding: var(--space-xl) 0;
}
@media (max-width: 768px) {
  .about-bio { grid-template-columns: 1fr; gap: var(--space-l); }
}

.about-bio .headshot {
  aspect-ratio: 3/4;
  background-color: var(--color-vellum);
  display: grid;
  place-items: center;
  color: var(--color-walnut);
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
}

.credentials {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2xl) var(--space-xl);
  padding: var(--space-xl) 0;
}
@media (max-width: 768px) {
  .credentials { grid-template-columns: 1fr; gap: var(--space-l); }
}
.credentials h3 {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  margin-bottom: var(--space-m);
  color: var(--color-walnut);
  font-weight: 400;
}
.credentials ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-m); }

/* ============================================================
   PRESS · DOWNLOADABLE CARDS
   ============================================================ */

.press-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-l);
  padding: var(--space-xl) 0;
}
@media (max-width: 768px) { .press-cards { grid-template-columns: 1fr; } }

.press-card {
  background-color: var(--color-vellum);
  padding: var(--space-l);
  display: flex;
  flex-direction: column;
}
.press-card .eyebrow { color: var(--color-walnut); margin-bottom: var(--space-m); }
.press-card h3 { margin-bottom: var(--space-m); font-size: var(--fs-h3); }
.press-card .preview { color: var(--color-ink-soft); flex: 1; margin-bottom: var(--space-m); }
.press-card .download {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-oxblood);
  margin-top: auto;
  border: 0;
  padding-top: var(--space-m);
  border-top: var(--rule) solid var(--color-walnut-soft);
  display: block;
}

/* Coverage list */
.coverage-list { list-style: none; padding: 0; margin: 0; border-top: var(--rule) solid var(--color-walnut-soft); }
.coverage-list li {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--space-l);
  padding: var(--space-m) 0;
  border-bottom: var(--rule) solid var(--color-walnut-soft);
  align-items: baseline;
}
.coverage-list .date {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-walnut);
}
.coverage-list .title { font-family: var(--font-italic); font-style: italic; }
.coverage-list .outlet {
  display: block;
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-walnut);
  margin-top: var(--space-3xs);
}

/* ============================================================
   GENESIS-SPECIFIC OVERRIDES
   ============================================================ */

/* Hide the Genesis Sample's default footer credit (we'll output our own) */
.site-footer .creds, .site-footer .footer-credits { display: none; }

/* Sidebar widget styling */
.sidebar .widget {
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-l);
  border-bottom: var(--rule) solid var(--color-walnut-soft);
}
.sidebar .widget:last-child { border-bottom: 0; }
.sidebar .widget-title {
  font-family: var(--font-utility);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--color-walnut);
  font-weight: 400;
  margin-bottom: var(--space-m);
}

/* ============================================================
   UTILITY · ACCESSIBILITY
   ============================================================ */

.visually-hidden,
.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-link {
  position: absolute;
  top: 0; left: 0;
  padding: var(--space-s);
  background: var(--color-ink);
  color: var(--color-paper);
  transform: translateY(-100%);
  z-index: 100;
}
.skip-link:focus-visible { transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; animation: none !important; }
  html { scroll-behavior: auto; }
}
