/*
Theme Name: Fringe Podcast
Theme URI: https://thefringefeed.com
Author: The Fringe Feed
Author URI: https://thefringefeed.com
Description: A retro paranormal magazine-style podcast theme for The Fringe Feed. Requires the Fringe Feed plugin.
Version: 1.6.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: Private
Text Domain: fringe-podcast
*/

/* ════════════════════════════════════════════════════════════════════
   FRINGE PODCAST THEME — Retro Paranormal Magazine
   ════════════════════════════════════════════════════════════════════ */

/* ── Google Fonts ────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Courier+Prime:ital,wght@0,400;0,700;1,400&family=Crimson+Pro:ital,wght@0,400;0,600;1,400&family=IM+Fell+English:ital@0;1&display=swap');

/* ── Design Tokens ───────────────────────────────────────────────── */
:root {
  /* Palette */
  --ink:         #0d0b08;
  --ink-soft:    #1a1712;
  --ink-mid:     #2c2820;
  --parchment:   #f2ead8;
  --parchment-2: #e8dfc8;
  --parchment-3: #d4c9b0;
  --cream:       #faf6ee;
  --gold:        #b8860b;
  --gold-light:  #d4a017;
  --gold-dim:    #7a5c08;
  --blood:       #8b0000;
  --blood-light: #a01010;
  --moss:        #2d4a2d;
  --rust:        #7a3b1e;
  --slate:       #3d4840;

  /* Typography */
  --font-head:   'Playfair Display', 'IM Fell English', Georgia, serif;
  --font-deck:   'IM Fell English', 'Playfair Display', Georgia, serif;
  --font-body:   'Crimson Pro', Georgia, serif;
  --font-mono:   'Courier Prime', 'Courier New', monospace;

  /* Spacing */
  --gap:    24px;
  --gap-lg: 48px;
  --gap-xl: 80px;
  --radius: 2px;

  /* Max widths */
  --w-site: 1200px;
  --w-text: 720px;

  /* Grain overlay (CSS-only noise texture) */
  --grain: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.08'/%3E%3C/svg%3E");
}

/* ── Reset & Base ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 18px; scroll-behavior: smooth; }

body {
  background: var(--ink);
  color: var(--parchment);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.65;
  min-height: 100vh;
  /* Grain overlay */
  background-image:
    var(--grain),
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 2px,
      rgba(0,0,0,.03) 2px,
      rgba(0,0,0,.03) 4px
    );
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--gold); text-decoration: none; transition: color .18s; }
a:hover { color: var(--gold-light); }

/* ── Typography scale ────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-head);
  line-height: 1.15;
  color: var(--parchment);
  font-weight: 700;
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.5rem, 3.5vw, 2.4rem); }
h3 { font-size: clamp(1.15rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.1rem; }

p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

/* Decorative rule */
.fp-rule {
  border: none;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold-dim), var(--gold), var(--gold-dim), transparent);
  margin: var(--gap-lg) 0;
}
.fp-rule--thin {
  height: 1px;
  background: linear-gradient(to right, transparent, var(--parchment-3) 30%, var(--parchment-3) 70%, transparent);
  opacity: .25;
  margin: var(--gap) 0;
}

/* ── Layout helpers ──────────────────────────────────────────────── */
.fp-container {
  max-width: var(--w-site);
  margin: 0 auto;
  padding: 0 var(--gap);
}
.fp-container--narrow {
  max-width: var(--w-text);
  margin: 0 auto;
  padding: 0 var(--gap);
}

/* ══════════════════════════════════════════════════════════════════
   SITE HEADER
   ══════════════════════════════════════════════════════════════════ */
.fp-site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--ink);
  border-bottom: 1px solid var(--gold-dim);
  /* Double border effect */
  box-shadow: 0 2px 0 var(--ink), 0 3px 0 var(--gold-dim);
}

.fp-site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--gap);
  max-width: var(--w-site);
  margin: 0 auto;
  height: 77px;
  gap: 29px;
}

/* Masthead / Logo */
.fp-masthead {
  display: flex;
  flex-direction: column;
  line-height: 1;
  text-decoration: none;
  flex-shrink: 0;
}
.fp-masthead__title {
  font-family: var(--font-deck);
  font-style: italic;
  font-size: 1.5rem;
  color: var(--parchment);
  letter-spacing: .03em;
}
.fp-masthead__sub {
  font-family: var(--font-mono);
  font-size: .55rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 2px;
}

/* Nav */
.fp-nav { display: flex; align-items: center; gap: 2px; flex-wrap: nowrap; }
.fp-nav__link {
  font-family: var(--font-mono);
  font-size: .67rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--parchment-3);
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  transition: color .18s, border-color .18s, background .18s;
  white-space: nowrap;
}
.fp-nav__link:hover,
.fp-nav__link.fp-nav__link--active {
  color: var(--gold);
  border-color: var(--gold-dim);
  background: rgba(184,134,11,.06);
}

/* Search */
.fp-header-search { position: relative; }
.fp-header-search input {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--ink-mid);
  color: var(--parchment);
  font-family: var(--font-mono);
  font-size: .72rem;
  padding: 6px 12px 6px 32px;
  border-radius: var(--radius);
  width: 180px;
  transition: border-color .18s, width .3s;
}
.fp-header-search input:focus { outline: none; border-color: var(--gold-dim); width: 240px; }
.fp-header-search input::placeholder { color: var(--parchment-3); opacity: .4; }
.fp-header-search__icon {
  position: absolute; left: 9px; top: 50%; transform: translateY(-50%);
  color: var(--gold-dim); font-size: .8rem; pointer-events: none;
}

/* Mobile hamburger */
.fp-nav-toggle { display: none; background: none; border: 1px solid var(--gold-dim); color: var(--parchment); padding: 6px 10px; cursor: pointer; font-size: 1rem; border-radius: var(--radius); }

/* ══════════════════════════════════════════════════════════════════
   SITE FOOTER
   ══════════════════════════════════════════════════════════════════ */
.fp-site-footer {
  border-top: 1px solid var(--gold-dim);
  box-shadow: 0 -2px 0 var(--ink), 0 -3px 0 var(--gold-dim);
  margin-top: var(--gap-xl);
  padding: var(--gap-lg) 0 var(--gap);
  background: var(--ink-soft);
}
.fp-footer__inner {
  max-width: var(--w-site);
  margin: 0 auto;
  padding: 0 var(--gap);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--gap-lg);
}
.fp-footer__brand .fp-masthead__title { font-size: 1.8rem; }
.fp-footer__brand p { font-size: .85rem; color: var(--parchment-3); margin-top: 10px; line-height: 1.5; }
.fp-footer__col h4 {
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--gold-dim);
}
.fp-footer__col ul { list-style: none; }
.fp-footer__col ul li { margin-bottom: 6px; }
.fp-footer__col ul li a { font-size: .85rem; color: var(--parchment-3); }
.fp-footer__col ul li a:hover { color: var(--gold-light); }
.fp-footer__bottom {
  max-width: var(--w-site);
  margin: var(--gap-lg) auto 0;
  padding: var(--gap) var(--gap) 0;
  border-top: 1px solid rgba(255,255,255,.06);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .1em;
  color: var(--parchment-3);
  opacity: .5;
}

/* ══════════════════════════════════════════════════════════════════
   BREADCRUMB
   ══════════════════════════════════════════════════════════════════ */
.fp-breadcrumb {
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--parchment-3);
  opacity: .6;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: var(--gap);
  flex-wrap: wrap;
}
.fp-breadcrumb a { color: inherit; }
.fp-breadcrumb a:hover { color: var(--gold); opacity: 1; }
.fp-breadcrumb__sep { color: var(--gold-dim); }

/* ══════════════════════════════════════════════════════════════════
   CATEGORY PILLS
   ══════════════════════════════════════════════════════════════════ */
.fp-cat-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: 3px 10px;
  border: 1px solid;
  border-radius: 0; /* sharp magazine look */
  color: var(--cat-color, var(--gold));
  border-color: var(--cat-color, var(--gold));
  background: color-mix(in srgb, var(--cat-color, var(--gold)) 8%, transparent);
}

/* ══════════════════════════════════════════════════════════════════
   HOMEPAGE — HERO STRIP (Latest Episode)
   ══════════════════════════════════════════════════════════════════ */
.fp-hero {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border-bottom: 3px double var(--gold-dim);
}
.fp-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(.35) sepia(.4);
  transition: transform 8s ease;
}
.fp-hero:hover .fp-hero__bg { transform: scale(1.04); }
.fp-hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--ink) 0%, rgba(0,0,0,.6) 50%, transparent 100%);
}
.fp-hero__content {
  position: relative;
  z-index: 2;
  padding: var(--gap-lg) var(--gap);
  max-width: var(--w-site);
  margin: 0 auto;
  width: 100%;
}
.fp-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.fp-hero__eyebrow::before,
.fp-hero__eyebrow::after {
  content: '';
  height: 1px;
  width: 40px;
  background: var(--gold-dim);
  display: block;
}
.fp-hero__title {
  font-size: clamp(2rem, 5vw, 3.8rem);
  font-style: italic;
  max-width: 700px;
  margin-bottom: 16px;
  text-shadow: 0 2px 12px rgba(0,0,0,.8);
}
.fp-hero__meta {
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .08em;
  color: var(--parchment-3);
  display: flex;
  gap: 16px;
  align-items: center;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.fp-hero__meta-sep { color: var(--gold-dim); }
.fp-hero__play {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--blood);
  color: var(--parchment);
  border: 1px solid var(--blood-light);
  padding: 12px 24px;
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .18s, transform .18s;
  text-decoration: none;
}
.fp-hero__play:hover { background: var(--blood-light); color: var(--parchment); transform: translateY(-1px); }
.fp-hero__play-icon { font-size: 1rem; }

/* ══════════════════════════════════════════════════════════════════
   HOMEPAGE — SECTION HEADERS
   ══════════════════════════════════════════════════════════════════ */
.fp-section-head {
  display: flex;
  align-items: center;
  gap: var(--gap);
  margin-bottom: var(--gap);
}
.fp-section-head__title {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  white-space: nowrap;
}
.fp-section-head::before,
.fp-section-head::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, var(--gold-dim), transparent);
}
.fp-section-head::after {
  background: linear-gradient(to left, var(--gold-dim), transparent);
}

/* ══════════════════════════════════════════════════════════════════
   SHOW CARDS (grid + archive)
   ══════════════════════════════════════════════════════════════════ */
.fp-shows-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--gap);
}

.fp-show-card {
  background: var(--ink-soft);
  border: 1px solid rgba(184,134,11,.15);
  position: relative;
  overflow: hidden;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  /* Vintage corner ornaments via box-shadow */
  box-shadow: inset 0 0 0 4px var(--ink-soft), inset 0 0 0 5px rgba(184,134,11,.1);
}
.fp-show-card::before {
  content: '';
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(184,134,11,.08);
  pointer-events: none;
  z-index: 1;
}
.fp-show-card:hover {
  border-color: var(--gold-dim);
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(0,0,0,.5), inset 0 0 0 4px var(--ink-soft), inset 0 0 0 5px rgba(184,134,11,.15);
}

.fp-show-card__art {
  aspect-ratio: 1;
  overflow: hidden;
  position: relative;
  background: var(--ink-mid);
}
.fp-show-card__art img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
  filter: sepia(.15) contrast(1.05);
}
.fp-show-card:hover .fp-show-card__art img { transform: scale(1.05); }
.fp-show-card__art-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 4rem; opacity: .2;
}
/* Vintage halftone overlay on art */
.fp-show-card__art::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 60%, rgba(0,0,0,.4) 100%);
  pointer-events: none;
}

.fp-show-card__body {
  padding: 16px;
  position: relative;
  z-index: 2;
}
.fp-show-card__cat {
  margin-bottom: 8px;
}
.fp-show-card__title {
  font-size: 1rem;
  font-weight: 700;
  font-style: italic;
  color: var(--parchment);
  line-height: 1.3;
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fp-show-card__host {
  font-family: var(--font-mono);
  font-size: .62rem;
  color: var(--parchment-3);
  opacity: .65;
  letter-spacing: .05em;
  margin-bottom: 8px;
}
.fp-show-card__desc {
  font-size: .82rem;
  color: var(--parchment-3);
  opacity: .7;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 12px;
}
.fp-show-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
  border-top: 1px solid rgba(184,134,11,.1);
  font-family: var(--font-mono);
  font-size: .6rem;
  letter-spacing: .08em;
  color: var(--parchment-3);
  opacity: .55;
}
.fp-show-card__cta {
  color: var(--gold);
  opacity: 1;
  font-weight: 700;
}

/* ══════════════════════════════════════════════════════════════════
   EPISODE LIST (used on show page + homepage strips)
   ══════════════════════════════════════════════════════════════════ */
.fp-ep-list { display: flex; flex-direction: column; gap: 0; }

.fp-ep-row {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 16px 0;
  border-bottom: 1px solid rgba(184,134,11,.08);
  transition: background .18s;
  cursor: pointer;
}
.fp-ep-row:last-child { border-bottom: none; }
.fp-ep-row:hover { background: rgba(184,134,11,.04); margin: 0 -16px; padding-left: 16px; padding-right: 16px; }

.fp-ep-row__num {
  font-family: var(--font-mono);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--gold-dim);
  text-align: center;
  opacity: .5;
  line-height: 1;
}
.fp-ep-row__art {
  width: 72px; height: 72px;
  border-radius: 0;
  object-fit: cover;
  border: 1px solid rgba(184,134,11,.2);
  filter: sepia(.2);
  flex-shrink: 0;
}
.fp-ep-row__art-placeholder {
  width: 72px; height: 72px;
  background: var(--ink-mid);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; opacity: .3;
  border: 1px solid rgba(184,134,11,.1);
}

.fp-ep-row__body { min-width: 0; }
.fp-ep-row__meta {
  font-family: var(--font-mono);
  font-size: .6rem;
  letter-spacing: .1em;
  color: var(--gold);
  margin-bottom: 4px;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.fp-ep-row__meta-sep { color: var(--gold-dim); opacity: .5; }
.fp-ep-row__title {
  font-family: var(--font-head);
  font-size: .95rem;
  font-style: italic;
  color: var(--parchment);
  line-height: 1.35;
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fp-ep-row__title a { color: inherit; text-decoration: none; }
.fp-ep-row__title a:hover { color: var(--gold-light); }
.fp-ep-row__desc {
  font-size: .78rem;
  color: var(--parchment-3);
  opacity: .55;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.fp-ep-row__controls { display: flex; flex-direction: column; align-items: center; gap: 6px; flex-shrink: 0; }
.fp-play-btn {
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 1px solid var(--gold-dim);
  background: rgba(184,134,11,.08);
  color: var(--gold);
  font-size: .9rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .18s, border-color .18s, transform .18s;
  flex-shrink: 0;
}
.fp-play-btn:hover { background: var(--blood); border-color: var(--blood-light); color: var(--parchment); transform: scale(1.08); }
.fp-play-btn--playing { background: var(--blood); border-color: var(--blood-light); color: var(--parchment); }
.fp-ep-row__dur {
  font-family: var(--font-mono);
  font-size: .58rem;
  color: var(--parchment-3);
  opacity: .45;
  letter-spacing: .05em;
}

/* Inline audio player */
.fp-inline-player {
  grid-column: 1 / -1;
  padding: 12px 16px;
  background: var(--ink-mid);
  border: 1px solid var(--gold-dim);
  display: none;
  animation: fp-slide-in .2s ease;
}
.fp-inline-player.is-open { display: block; }
@keyframes fp-slide-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fp-inline-player audio {
  width: 100%;
  height: 36px;
  accent-color: var(--blood);
}

/* ══════════════════════════════════════════════════════════════════
   SINGLE SHOW PAGE
   ══════════════════════════════════════════════════════════════════ */
.fp-show-page { padding: var(--gap-lg) 0; }

.fp-show-hero {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--gap-lg);
  align-items: start;
  margin-bottom: var(--gap-lg);
  padding-bottom: var(--gap-lg);
  border-bottom: 1px solid rgba(184,134,11,.15);
  position: relative;
}
/* Double-rule top border */
.fp-show-hero::before {
  content: '';
  position: absolute;
  top: -3px; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(to right, var(--blood), var(--gold), var(--blood));
  opacity: .7;
}

.fp-show-cover {
  width: 220px; height: 220px;
  object-fit: cover;
  border: 2px solid var(--gold-dim);
  filter: sepia(.15) contrast(1.05);
  box-shadow: 6px 6px 0 var(--gold-dim);
}
.fp-show-cover-placeholder {
  width: 220px; height: 220px;
  background: var(--ink-mid);
  border: 2px solid var(--gold-dim);
  display: flex; align-items: center; justify-content: center;
  font-size: 5rem; opacity: .25;
}

.fp-show-meta { }
.fp-show-meta__title {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-style: italic;
  margin: 12px 0 10px;
  line-height: 1.1;
}
.fp-show-meta__host {
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .1em;
  color: var(--parchment-3);
  margin-bottom: 14px;
  opacity: .75;
}
.fp-show-meta__desc {
  font-size: 1rem;
  color: var(--parchment-3);
  line-height: 1.65;
  max-width: 560px;
  margin-bottom: 20px;
  opacity: .85;
}
.fp-show-meta__stats {
  display: flex;
  gap: 20px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .08em;
  color: var(--parchment-3);
  opacity: .6;
  flex-wrap: wrap;
}
.fp-show-meta__stats a { color: var(--gold); opacity: 1; }

/* Subscribe / external link button */
.fp-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  border: 1px solid;
  cursor: pointer;
  text-decoration: none;
  transition: background .18s, color .18s, transform .12s;
  border-radius: 0;
}
.fp-btn--primary { background: var(--blood); color: var(--parchment); border-color: var(--blood-light); }
.fp-btn--primary:hover { background: var(--blood-light); color: var(--parchment); transform: translateY(-1px); }
.fp-btn--outline { background: transparent; color: var(--gold); border-color: var(--gold-dim); }
.fp-btn--outline:hover { background: rgba(184,134,11,.08); color: var(--gold-light); border-color: var(--gold); }

/* Episodes section header on show page */
.fp-episodes-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--gold-dim);
}
.fp-episodes-header h2 {
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
}
.fp-episodes-count {
  font-family: var(--font-mono);
  font-size: .62rem;
  color: var(--parchment-3);
  opacity: .5;
  letter-spacing: .06em;
}

/* ══════════════════════════════════════════════════════════════════
   SINGLE EPISODE PAGE
   ══════════════════════════════════════════════════════════════════ */
.fp-episode-page { padding: var(--gap-lg) 0; }

.fp-episode-hero {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: var(--gap-lg);
  align-items: start;
  margin-bottom: var(--gap-lg);
}

.fp-episode-cover {
  width: 180px;
  height: 180px;
  object-fit: cover;
  border: 2px solid var(--gold-dim);
  filter: sepia(.2);
  box-shadow: 4px 4px 0 var(--gold-dim);
}

.fp-episode-player {
  background: var(--ink-soft);
  border: 1px solid var(--gold-dim);
  padding: 20px;
  margin: var(--gap) 0 var(--gap-lg);
  /* Vintage ticket/receipt style */
  position: relative;
}
.fp-episode-player::before {
  content: '— NOW PLAYING —';
  position: absolute;
  top: -9px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: .55rem;
  letter-spacing: .25em;
  background: var(--ink-soft);
  padding: 0 10px;
  color: var(--gold);
}
.fp-episode-player audio {
  width: 100%;
  height: 40px;
  accent-color: var(--blood);
  margin-bottom: 8px;
}
.fp-episode-player__actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}
.fp-episode-player__download {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .1em;
  color: var(--parchment-3);
  opacity: .6;
  text-decoration: none;
}
.fp-episode-player__download:hover { color: var(--gold); opacity: 1; }

.fp-episode-desc {
  max-width: var(--w-text);
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--parchment);
  opacity: .9;
}
.fp-episode-desc p { margin-bottom: 1.2em; }

/* ══════════════════════════════════════════════════════════════════
   CATEGORY ARCHIVE PAGE
   ══════════════════════════════════════════════════════════════════ */
.fp-cat-header {
  padding: var(--gap-lg) 0 var(--gap);
  text-align: center;
  border-bottom: 3px double var(--gold-dim);
  margin-bottom: var(--gap-lg);
  position: relative;
}
.fp-cat-header__icon { font-size: 3rem; margin-bottom: 12px; }
.fp-cat-header__title {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-style: italic;
  color: var(--cat-color, var(--gold));
}
.fp-cat-header__sub {
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--parchment-3);
  opacity: .55;
  margin-top: 8px;
}

/* ══════════════════════════════════════════════════════════════════
   SEARCH PAGE
   ══════════════════════════════════════════════════════════════════ */
.fp-search-wrap { padding: var(--gap-lg) 0; }
.fp-search-form {
  display: flex;
  gap: 0;
  max-width: 560px;
  margin: 0 auto var(--gap-lg);
  border: 2px solid var(--gold-dim);
}
.fp-search-form input {
  flex: 1;
  background: var(--ink-soft);
  border: none;
  color: var(--parchment);
  font-family: var(--font-body);
  font-size: 1.1rem;
  padding: 12px 16px;
}
.fp-search-form input:focus { outline: none; }
.fp-search-form button {
  background: var(--blood);
  color: var(--parchment);
  border: none;
  padding: 0 24px;
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .18s;
}
.fp-search-form button:hover { background: var(--blood-light); }

/* ══════════════════════════════════════════════════════════════════
   404 PAGE
   ══════════════════════════════════════════════════════════════════ */
.fp-404 {
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--gap-xl) var(--gap);
}
.fp-404__code {
  font-family: var(--font-deck);
  font-size: clamp(6rem, 20vw, 12rem);
  font-style: italic;
  color: var(--blood);
  line-height: 1;
  opacity: .6;
  text-shadow: 4px 4px 0 var(--gold-dim);
}
.fp-404__title {
  font-size: clamp(1.2rem, 3vw, 2rem);
  font-style: italic;
  margin: 16px 0 8px;
  color: var(--parchment);
}
.fp-404__sub {
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--parchment-3);
  opacity: .5;
  margin-bottom: 32px;
}

/* ══════════════════════════════════════════════════════════════════
   GENERIC PAGE (About, Contact)
   ══════════════════════════════════════════════════════════════════ */
.fp-page-wrap { padding: var(--gap-lg) 0; }
.fp-page-header {
  margin-bottom: var(--gap-lg);
  padding-bottom: var(--gap);
  border-bottom: 1px solid rgba(184,134,11,.2);
}
.fp-page-header h1 { font-style: italic; }
.fp-page-content {
  max-width: var(--w-text);
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--parchment);
}
.fp-page-content h2, .fp-page-content h3 { margin: 1.5em 0 .6em; }
.fp-page-content p { margin-bottom: 1.2em; }
.fp-page-content a { color: var(--gold); border-bottom: 1px solid var(--gold-dim); }
.fp-page-content a:hover { color: var(--gold-light); border-bottom-color: var(--gold); }
.fp-page-content blockquote {
  border-left: 3px solid var(--gold-dim);
  padding-left: 20px;
  margin: 1.5em 0;
  font-style: italic;
  color: var(--parchment-3);
  opacity: .8;
}

/* ══════════════════════════════════════════════════════════════════
   PAGINATION
   ══════════════════════════════════════════════════════════════════ */
.fp-pagination {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-top: var(--gap-lg);
}
.fp-pagination a,
.fp-pagination span {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .1em;
  padding: 8px 14px;
  border: 1px solid var(--gold-dim);
  color: var(--parchment-3);
  text-decoration: none;
  transition: background .18s, color .18s;
}
.fp-pagination a:hover { background: rgba(184,134,11,.1); color: var(--gold); }
.fp-pagination .current { background: var(--blood); color: var(--parchment); border-color: var(--blood-light); }

/* ══════════════════════════════════════════════════════════════════
   HOMEPAGE CATEGORY STRIP
   ══════════════════════════════════════════════════════════════════ */
.fp-cat-strip { margin-bottom: var(--gap-xl); }
.fp-cat-strip__scroll {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding-bottom: 8px;
  scrollbar-width: none;
}
.fp-cat-strip__scroll::-webkit-scrollbar { display: none; }

/* Reuse ep-row styles inside strip */

/* ══════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .fp-footer__inner { grid-template-columns: 1fr 1fr; gap: var(--gap); }
  .fp-show-hero { grid-template-columns: 1fr; }
  .fp-show-cover, .fp-show-cover-placeholder { width: 160px; height: 160px; }
  .fp-episode-hero { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  :root { --gap: 16px; --gap-lg: 32px; }
  .fp-site-header__inner { height: 56px; }
  .fp-nav { display: none; position: absolute; top: 56px; left: 0; right: 0; background: var(--ink); flex-direction: column; border-bottom: 1px solid var(--gold-dim); padding: 12px; gap: 2px; }
  .fp-nav.fp-nav--open { display: flex; }
  .fp-nav-toggle { display: block; }
  .fp-header-search { display: none; }
  .fp-footer__inner { grid-template-columns: 1fr; }
  .fp-footer__bottom { flex-direction: column; gap: 8px; text-align: center; }
  .fp-ep-row { grid-template-columns: 48px 1fr auto; }
  .fp-shows-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
}

/* ══════════════════════════════════════════════════════════════════
   VINTAGE DECORATIVE ELEMENTS
   ══════════════════════════════════════════════════════════════════ */
/* Ornamental divider */
.fp-ornament {
  text-align: center;
  color: var(--gold-dim);
  font-size: 1.2rem;
  letter-spacing: .5em;
  margin: var(--gap-lg) 0;
  opacity: .5;
}
.fp-ornament::before { content: '✦ ✦ ✦'; }

/* Pull quote */
.fp-pullquote {
  font-family: var(--font-deck);
  font-style: italic;
  font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  color: var(--gold);
  border-top: 2px solid var(--gold-dim);
  border-bottom: 2px solid var(--gold-dim);
  padding: 20px 0;
  margin: var(--gap-lg) 0;
  text-align: center;
  line-height: 1.4;
}

/* "NEW EPISODE" badge */
.fp-badge-new {
  font-family: var(--font-mono);
  font-size: .5rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  background: var(--blood);
  color: var(--parchment);
  padding: 2px 6px;
  vertical-align: middle;
  margin-left: 6px;
}

/* WP admin bar offset */
.admin-bar .fp-site-header { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .fp-site-header { top: 46px; }
}

/* ════════════════════════════════════════════════════════════════════
   NEWS FEED INTEGRATION
   Override Fringe Feed plugin CSS variables to match retro theme
   ════════════════════════════════════════════════════════════════════ */

/* ── Re-skin the plugin's ff-* components ───────────────────────── */
:root {
  /* Map plugin vars to our retro palette */
  --ff-bg:           var(--ink);
  --ff-surface:      var(--ink-soft);
  --ff-surface2:     var(--ink-mid);
  --ff-text:         var(--parchment);
  --ff-hero-h:       clamp(340px, 45vw, 540px);
  --ff-font-display: 'Playfair Display', Georgia, serif;
  --ff-font-body:    'Crimson Pro', Georgia, serif;
}

/* Override card borders to match vintage feel */
.ff-card {
  border: 1px solid rgba(184,134,11,.12) !important;
  border-radius: 0 !important;
  box-shadow: inset 0 0 0 3px var(--ink-soft), inset 0 0 0 4px rgba(184,134,11,.06) !important;
}
.ff-card:hover {
  border-color: rgba(184,134,11,.35) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 10px 32px rgba(0,0,0,.45), inset 0 0 0 3px var(--ink-soft), inset 0 0 0 4px rgba(184,134,11,.1) !important;
}

/* Card image — sepia tint for vintage look */
.ff-card__img { filter: sepia(.12) contrast(1.04) !important; }
.ff-hero__img { filter: sepia(.18) contrast(1.06) brightness(.95) !important; }

/* Hero overlay — darker, more dramatic */
.ff-hero__overlay {
  background: linear-gradient(
    to top,
    rgba(13,11,8,.92) 0%,
    rgba(13,11,8,.55) 45%,
    rgba(13,11,8,.12) 100%
  ) !important;
}

/* Hero title — use our serif */
.ff-hero__title {
  font-family: var(--font-head) !important;
  font-style: italic !important;
}

/* Card title — serif */
.ff-card__title { font-family: var(--font-head) !important; font-style: italic !important; }

/* Category pills — sharp corners */
.ff-pill { border-radius: 0 !important; font-family: var(--font-mono) !important; font-size: .58rem !important; letter-spacing: .12em !important; }

/* Search bar */
.ff-search-input, .ff-search-btn {
  border-radius: 0 !important;
  font-family: var(--font-mono) !important;
}
.ff-search-btn {
  background: var(--blood) !important;
  border-color: var(--blood-light) !important;
}
.ff-search-btn:hover { background: var(--blood-light) !important; }

/* Load more button */
.ff-load-more {
  border-radius: 0 !important;
  font-family: var(--font-mono) !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  background: transparent !important;
  border: 1px solid var(--gold-dim) !important;
  color: var(--gold) !important;
}
.ff-load-more:hover {
  background: rgba(184,134,11,.08) !important;
  border-color: var(--gold) !important;
}

/* Pagination */
.ff-page-btn {
  border-radius: 0 !important;
  font-family: var(--font-mono) !important;
  font-size: .68rem !important;
  letter-spacing: .1em !important;
  border-color: var(--gold-dim) !important;
  color: var(--parchment-3) !important;
}
.ff-page-btn:hover { background: rgba(184,134,11,.08) !important; color: var(--gold) !important; }

/* Story page (fsp-*) retro overrides */
.fsp-wrap { font-family: var(--font-body) !important; }
.fsp-title { font-family: var(--font-head) !important; font-style: italic !important; }
.fsp-breadcrumb { font-family: var(--font-mono) !important; }
.fsp-cta__btn {
  border-radius: 0 !important;
  font-family: var(--font-mono) !important;
  background: var(--blood) !important;
  border-color: var(--blood-light) !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
}
.fsp-cta__btn:hover { background: var(--blood-light) !important; }

/* Carousel retro overrides */
.ffc-section { border-left-color: inherit; }
.ffc-title { font-family: var(--font-mono) !important; letter-spacing: .12em !important; text-transform: uppercase !important; font-size: .72rem !important; }
.ffc-card { border-radius: 0 !important; border-color: rgba(184,134,11,.12) !important; }
.ffc-card:hover { border-color: rgba(184,134,11,.35) !important; }
.ffc-card__img { filter: sepia(.12) !important; }
.ffc-card__title { font-family: var(--font-head) !important; font-style: italic !important; }

/* ── News feed wrapper on theme pages ───────────────────────────── */
.fp-news-section {
  padding: var(--gap-lg) 0;
}

.fp-news-section .ff-wrap {
  background: transparent;
}

/* Category filter nav for news pages */
.fp-cat-nav {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: var(--gap-lg);
  padding-bottom: var(--gap);
  border-bottom: 1px solid rgba(184,134,11,.15);
}
.fp-cat-nav__link {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 12px;
  border: 1px solid rgba(184,134,11,.2);
  color: var(--parchment-3);
  text-decoration: none;
  transition: background .18s, color .18s, border-color .18s;
}
.fp-cat-nav__link:hover,
.fp-cat-nav__link.fp-cat-nav__link--active {
  background: rgba(184,134,11,.1);
  color: var(--gold);
  border-color: var(--gold-dim);
}

/* ── WP blog post (personal stories) card ───────────────────────── */
.fp-post-card {
  background: var(--ink-soft);
  border: 1px solid rgba(184,134,11,.12);
  padding: 20px;
  position: relative;
  transition: border-color .2s, transform .2s;
}
.fp-post-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, var(--blood), var(--gold));
  opacity: .6;
}
.fp-post-card:hover {
  border-color: rgba(184,134,11,.3);
  transform: translateY(-2px);
}
.fp-post-card__badge {
  font-family: var(--font-mono);
  font-size: .55rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--blood-light);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.fp-post-card__badge::before { content: '✦'; color: var(--gold-dim); }
.fp-post-card__title {
  font-family: var(--font-head);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--parchment);
  line-height: 1.3;
  margin-bottom: 8px;
  text-decoration: none;
  display: block;
}
.fp-post-card__title:hover { color: var(--gold-light); }
.fp-post-card__meta {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .08em;
  color: var(--parchment-3);
  opacity: .55;
  margin-bottom: 10px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.fp-post-card__excerpt {
  font-size: .88rem;
  color: var(--parchment-3);
  line-height: 1.6;
  opacity: .75;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fp-post-card__read {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .1em;
  color: var(--gold);
  text-decoration: none;
  display: inline-block;
  margin-top: 12px;
}
.fp-post-card__read:hover { color: var(--gold-light); }

/* Posts grid */
.fp-posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--gap);
}

/* ── Single WP post (personal story page) ───────────────────────── */
.fp-single-post { padding: var(--gap-lg) 0; }
.fp-single-post__header { margin-bottom: var(--gap-lg); }
.fp-single-post__badge {
  font-family: var(--font-mono);
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--blood-light);
  margin-bottom: 10px;
}
.fp-single-post__title {
  font-style: italic;
  margin-bottom: 14px;
}
.fp-single-post__meta {
  font-family: var(--font-mono);
  font-size: .65rem;
  letter-spacing: .08em;
  color: var(--parchment-3);
  opacity: .6;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(184,134,11,.15);
}
.fp-single-post__thumbnail {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  margin-bottom: var(--gap-lg);
  border: 1px solid rgba(184,134,11,.2);
  filter: sepia(.1) contrast(1.04);
}
.fp-single-post__content {
  max-width: var(--w-text);
  font-size: 1.08rem;
  line-height: 1.8;
  color: var(--parchment);
}
.fp-single-post__content h2,
.fp-single-post__content h3 { margin: 1.5em 0 .6em; }
.fp-single-post__content p { margin-bottom: 1.3em; }
.fp-single-post__content a { color: var(--gold); border-bottom: 1px solid var(--gold-dim); }
.fp-single-post__content a:hover { color: var(--gold-light); border-bottom-color: var(--gold); }
.fp-single-post__content blockquote {
  border-left: 3px solid var(--gold-dim);
  padding-left: 20px;
  margin: 1.5em 0;
  font-family: var(--font-deck);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--parchment-3);
}
.fp-single-post__content img {
  max-width: 100%;
  height: auto;
  border: 1px solid rgba(184,134,11,.2);
  margin: 1em 0;
  filter: sepia(.08);
}

/* Related posts on single post */
.fp-related-posts {
  margin-top: var(--gap-xl);
  padding-top: var(--gap-lg);
  border-top: 1px solid rgba(184,134,11,.15);
}

/* ════════════════════════════════════════════════════════════════════
   NEWS CARDS  (page-news.php grid — matches show card style)
   ════════════════════════════════════════════════════════════════════ */

.fp-news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--gap);
}

.fp-news-card {
  background: var(--ink-soft);
  border: 1px solid rgba(184,134,11,.12);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  box-shadow: inset 0 0 0 4px var(--ink-soft), inset 0 0 0 5px rgba(184,134,11,.06);
}
.fp-news-card::before {
  content: '';
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(184,134,11,.06);
  pointer-events: none;
  z-index: 1;
}
.fp-news-card:hover {
  border-color: rgba(184,134,11,.35);
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(0,0,0,.45),
              inset 0 0 0 4px var(--ink-soft),
              inset 0 0 0 5px rgba(184,134,11,.12);
}

/* 4:3 image ratio */
.fp-news-card__art {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ink-mid);
  flex-shrink: 0;
}
.fp-news-card__art img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: sepia(.12) contrast(1.04);
  transition: transform .4s ease;
}
.fp-news-card:hover .fp-news-card__art img { transform: scale(1.05); }
.fp-news-card__art::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.35) 100%);
  pointer-events: none;
}
.fp-news-card__art-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; opacity: .2;
}

.fp-news-card__body {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.fp-news-card__cat { margin-bottom: 2px; }
.fp-news-card__title {
  margin: 0;
  font-family: var(--font-head);
  font-style: italic;
  font-size: .95rem;
  font-weight: 700;
  color: var(--parchment);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fp-news-card__excerpt {
  margin: 0;
  font-size: .78rem;
  color: var(--parchment-3);
  opacity: .65;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fp-news-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid rgba(184,134,11,.08);
  font-family: var(--font-mono);
  font-size: .6rem;
  letter-spacing: .06em;
}
.fp-news-card__source {
  color: var(--parchment-3);
  opacity: .5;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 60%;
}
.fp-news-card__time { color: var(--gold); opacity: .8; flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════════════
   DAILY NEWS STORY CARDS  (page-our-stories.php — 4:3 image)
   ════════════════════════════════════════════════════════════════════ */

.fp-stories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--gap);
}

.fp-story-card {
  background: var(--ink-soft);
  border: 1px solid rgba(184,134,11,.12);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.fp-story-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, var(--blood), var(--gold));
  opacity: .5;
}
.fp-story-card:hover {
  border-color: rgba(184,134,11,.32);
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(0,0,0,.45);
}

/* 4:3 image */
.fp-story-card__art {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--ink-mid);
  flex-shrink: 0;
}
.fp-story-card__art img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: sepia(.1) contrast(1.03);
  transition: transform .4s ease;
}
.fp-story-card:hover .fp-story-card__art img { transform: scale(1.04); }
.fp-story-card__art-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; opacity: .2;
}

.fp-story-card__body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.fp-story-card__cat { margin-bottom: 2px; }
.fp-story-card__title {
  margin: 0;
  font-family: var(--font-head);
  font-style: italic;
  font-size: 1rem;
  font-weight: 700;
  color: var(--parchment);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fp-story-card__excerpt {
  margin: 0;
  font-size: .82rem;
  color: var(--parchment-3);
  opacity: .7;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fp-story-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid rgba(184,134,11,.08);
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .06em;
}
.fp-story-card__date { color: var(--parchment-3); opacity: .5; }
.fp-story-card__cta  { color: var(--gold); }

/* ════════════════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE — full responsive pass
   ════════════════════════════════════════════════════════════════════ */

/* ── Tablet (≤900px) ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  /* Footer */
  .fp-footer__inner { grid-template-columns: 1fr 1fr; gap: var(--gap); }

  /* Show page */
  .fp-show-hero { grid-template-columns: 1fr; }
  .fp-show-cover, .fp-show-cover-placeholder { width: 140px; height: 140px; }

  /* Episode page */
  .fp-episode-hero { grid-template-columns: 1fr; }
  .fp-episode-cover { max-width: 200px; }

  /* Homepage split grid → stack */
  .fp-homepage-split { grid-template-columns: 1fr !important; }

  /* News hero grid → stack */
  .fp-news-hero-grid { grid-template-columns: 1fr !important; }

  /* Grids — tighter min */
  .fp-news-grid    { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
  .fp-stories-grid { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
  .fp-shows-grid   { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}

/* ── Mobile (≤640px) ─────────────────────────────────────────────── */
@media (max-width: 640px) {
  /* Base spacing */
  :root {
    --gap: 14px;
    --gap-lg: 28px;
    --gap-xl: 48px;
  }

  /* Header */
  .fp-site-header__inner { height: 52px; gap: 8px; }
  .fp-nav {
    display: none;
    position: fixed;
    top: 52px; left: 0; right: 0; bottom: 0;
    background: var(--ink);
    flex-direction: column;
    border-top: 1px solid var(--gold-dim);
    padding: 20px 16px;
    gap: 4px;
    overflow-y: auto;
    z-index: 99;
  }
  .fp-nav.fp-nav--open { display: flex; }
  .fp-nav__link { padding: 12px 16px; font-size: .8rem; border-bottom: 1px solid rgba(184,134,11,.08); }
  .fp-nav-toggle { display: block; }
  .fp-header-search { display: none; }
  .admin-bar .fp-nav { top: 98px; }

  /* Footer */
  .fp-footer__inner { grid-template-columns: 1fr; gap: var(--gap); }
  .fp-footer__bottom { flex-direction: column; gap: 6px; text-align: center; }
  .fp-footer__brand { text-align: center; }

  /* Hero */
  .fp-hero { min-height: 380px; }
  .fp-hero__title { font-size: 1.5rem; }
  .fp-hero__content { padding: var(--gap-lg) var(--gap); }
  .fp-hero__play { padding: 10px 18px; font-size: .65rem; }
  .fp-hero__eyebrow { font-size: .55rem; }

  /* Episode rows */
  .fp-ep-row {
    grid-template-columns: 56px 1fr 36px;
    gap: 10px;
    padding: 12px 0;
  }
  .fp-ep-row__art, .fp-ep-row__art-placeholder { width: 56px; height: 56px; }
  .fp-ep-row__title { font-size: .85rem; }
  .fp-ep-row__desc  { display: none; } /* too cramped on mobile */
  .fp-play-btn { width: 34px; height: 34px; font-size: .75rem; }
  .fp-ep-row__dur { display: none; }

  /* Show page hero */
  .fp-show-hero { grid-template-columns: 1fr; }
  .fp-show-cover, .fp-show-cover-placeholder { width: 120px; height: 120px; box-shadow: 3px 3px 0 var(--gold-dim); }
  .fp-show-meta__title { font-size: 1.6rem; }
  .fp-show-meta__desc { font-size: .88rem; }
  .fp-episodes-header { flex-direction: column; align-items: flex-start; gap: 4px; }

  /* Episode page */
  .fp-episode-hero { grid-template-columns: 1fr; }
  .fp-episode-cover { max-width: 100%; height: 200px; object-fit: cover; }
  .fp-episode-player { padding: 14px; }
  .fp-episode-player__actions { flex-direction: column; align-items: flex-start; gap: 8px; }

  /* Grids — 2 columns on mobile */
  .fp-shows-grid   { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .fp-news-grid    { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .fp-stories-grid { grid-template-columns: 1fr; } /* single col — wider cards look better */
  .fp-posts-grid   { grid-template-columns: 1fr; }

  /* Show card — compact on mobile */
  .fp-show-card__body { padding: 10px 12px 12px; }
  .fp-show-card__title { font-size: .88rem; -webkit-line-clamp: 2; }
  .fp-show-card__desc  { display: none; }
  .fp-show-card__host  { font-size: .58rem; }

  /* News cards */
  .fp-news-card__body  { padding: 10px 12px 12px; }
  .fp-news-card__title { font-size: .88rem; }
  .fp-news-card__excerpt { display: none; }

  /* Story cards */
  .fp-story-card__body   { padding: 12px 14px 14px; }
  .fp-story-card__title  { font-size: .92rem; }
  .fp-story-card__excerpt { -webkit-line-clamp: 2; }

  /* Section heads */
  .fp-section-head__title { font-size: .6rem; }

  /* Category pills — slightly smaller */
  .fp-cat-pill { font-size: .55rem; padding: 2px 7px; }

  /* Cat nav wraps better */
  .fp-cat-nav { gap: 5px; }
  .fp-cat-nav__link { padding: 4px 8px; font-size: .58rem; }

  /* Archive cat filter */
  .fp-cat-header__title { font-size: 1.8rem; }

  /* Breadcrumb — smaller */
  .fp-breadcrumb { font-size: .58rem; gap: 5px; }

  /* Pagination */
  .fp-pagination { gap: 3px; }
  .fp-pagination a, .fp-pagination span { padding: 6px 10px; font-size: .62rem; }

  /* Buttons */
  .fp-btn { padding: 9px 16px; font-size: .62rem; }

  /* Single post */
  .fp-single-post__content { font-size: 1rem; }
  .fp-single-post__thumbnail { max-height: 240px; object-fit: cover; }

  /* Player */
  .fp-inline-player audio { height: 32px; }

  /* Ornament */
  .fp-ornament { margin: var(--gap-lg) 0; }

  /* Rule */
  .fp-rule { margin: var(--gap-lg) 0; }
}

/* ── Small mobile (≤380px) ───────────────────────────────────────── */
@media (max-width: 380px) {
  .fp-shows-grid,
  .fp-news-grid { grid-template-columns: 1fr; }
  .fp-hero__title { font-size: 1.3rem; }
}
