/* =========================================================================
   How Your Father Dressed — JT · Father's Day 2026
   Warm Editorial Memoir set as a real magazine feature: body text runs in
   balanced TWO COLUMNS that fill the width, images go big / full-bleed, and
   pull quotes span the full measure. No thin centred ribbon, no empty right
   channel. All classes scoped under .fd.
   ========================================================================= */

.fd {
  --paper:      #f3ecdf;
  --paper-deep: #ece2cf;
  --ink:        #221c14;
  --ink-soft:   #574d41;
  --ink-faint:  #8a7e6d;
  --rule:       #d6c8ad;
  --accent:     #9a6326;
  --accent-deep:#6e3f15;
  --dark:       #1c150d;
  --dark-soft:  #d2c4ab;
  --dark-gold:  #caa15f;

  --serif:   "Newsreader", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --display: "Fraunces", "Newsreader", Georgia, serif;
  --label:   "DM Sans", "Helvetica Neue", Arial, sans-serif;

  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  position: relative;
  overflow-x: clip;
}
.fd * { box-sizing: border-box; }
.fd ::selection { background: rgba(154,99,38,0.22); }

.fd::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* the feature frame is intentionally tight so text fills it, not floats in it */
.fd-shell { position: relative; z-index: 1; max-width: 1140px; margin: 0 auto; padding: 0 44px; }

/* shared body type */
.fd-prose { font-size: 19px; line-height: 1.62; color: var(--ink); text-wrap: pretty; }
.fd-prose p { margin: 0 0 1.25em; }
.fd-prose p:last-child { margin-bottom: 0; }

/* the workhorse: two balanced columns that fill the width */
.fd-2col { display: grid; grid-template-columns: 1fr 1fr; column-gap: 60px; }
.fd-2col .c { min-width: 0; }

/* =========================================================================
   TOPPER
   ========================================================================= */
.fd-topper {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 24px; flex-wrap: wrap; padding: 32px 0 20px;
  border-bottom: 1px solid var(--rule);
  font-family: var(--label); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
}
.fd-crumb { display: flex; align-items: center; gap: 10px; color: var(--ink-faint); }
.fd-crumb a { color: var(--ink-soft); text-decoration: none; }
.fd-crumb a:hover { color: var(--accent); }
.fd-crumb .sep { color: var(--rule); }
.fd-crumb .here { color: var(--ink); }
.fd-stamp { color: var(--accent); font-weight: 500; }
.fd-stamp .dot { display: inline-block; width: 4px; height: 4px; border-radius: 50%; background: var(--accent); margin: 0 8px 2px; }

/* =========================================================================
   HEAD — big, centred, fills the width
   ========================================================================= */
.fd-head { padding: 70px 0 52px; text-align: center; }
.fd-kicker { font-family: var(--label); font-size: 13px; letter-spacing: 0.34em; text-transform: uppercase; color: var(--accent); margin-bottom: 26px; }
.fd-h1 {
  font-family: var(--display); font-weight: 380; font-optical-sizing: auto;
  font-size: clamp(52px, 10vw, 150px); line-height: 0.9; letter-spacing: -0.025em;
  margin: 0 auto; max-width: 14ch; text-wrap: balance;
}
.fd-h1 .it { font-style: italic; font-weight: 340; }
.fd-sub {
  font-family: var(--display); font-style: italic; font-weight: 340;
  font-size: clamp(21px, 2.8vw, 32px); line-height: 1.24; color: var(--ink-soft);
  margin: 24px auto 0; max-width: 30ch; text-wrap: balance;
}
.fd-byline {
  display: flex; align-items: center; justify-content: center; gap: 16px;
  margin: 42px auto 0; padding-top: 24px; border-top: 1px solid var(--rule);
  max-width: 560px; font-family: var(--label);
}
.fd-byline .avatar { width: 48px; height: 48px; border-radius: 50%; background-size: cover; background-position: center top; background-color: var(--paper-deep); border: 1px solid var(--rule); flex: none; }
.fd-byline .who { text-align: left; line-height: 1.4; }
.fd-byline .by { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint); }
.fd-byline .name { font-size: 16px; color: var(--ink); }
.fd-byline .name a { color: inherit; text-decoration: none; border-bottom: 1px solid var(--rule); }
.fd-byline .name a:hover { border-color: var(--accent); color: var(--accent); }
.fd-byline .meta { margin-left: auto; font-size: 12px; letter-spacing: 0.05em; color: var(--ink-faint); text-align: right; line-height: 1.6; }

/* =========================================================================
   IMAGES — full-bleed bands + captions
   ========================================================================= */
.fd-figure { margin: 0; }
.fd-cap {
  display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap;
  margin: 13px auto 0; max-width: 1140px; padding: 0 44px;
  font-family: var(--label); font-size: 12.5px; letter-spacing: 0.04em; color: var(--ink-faint);
}
.fd-cap .accent { color: var(--accent); letter-spacing: 0.12em; text-transform: uppercase; font-size: 11px; }

.fd-band { width: 100%; }
.fd-band .img { width: 100%; background-size: cover; background-position: center; background-color: var(--paper-deep); }
.fd-band.hero .img { aspect-ratio: 16 / 8; background-position: center 42%; }
.fd-band.wide .img { aspect-ratio: 16 / 8.5; }

.fd-hero-wrap { margin-top: 2px; }
.fd-band-sec { margin: 78px 0; }

/* =========================================================================
   DECK — the opening line, big, full width
   ========================================================================= */
.fd-deck { padding: 74px 0 14px; }
.fd-deck p {
  font-family: var(--display); font-weight: 360; font-optical-sizing: auto;
  font-size: clamp(30px, 4.6vw, 58px); line-height: 1.04; letter-spacing: -0.02em;
  margin: 0; color: var(--ink); max-width: 20ch; text-wrap: balance;
}

/* =========================================================================
   BODY BLOCKS — two filled columns
   ========================================================================= */
.fd-block { padding: 26px 0; }
.fd-block.first { padding-top: 30px; }
/* drop cap on the very first column's first paragraph */
.fd-block.lead .c:first-child > p:first-child::first-letter {
  font-family: var(--display); font-weight: 440; float: left;
  font-size: 4.4em; line-height: 0.74; padding: 8px 12px 0 0; color: var(--accent-deep);
}
.fd-beat {
  font-family: var(--display); font-style: italic; font-size: clamp(22px, 2.2vw, 27px);
  line-height: 1.32; color: var(--accent-deep); margin: 0.2em 0 0.7em !important;
}

/* =========================================================================
   IMAGE + TEXT ROW — image fills one column, text the other (vertically
   centred so it reads as a balanced plate, never a gap)
   ========================================================================= */
.fd-row { padding: 60px 0; align-items: center; column-gap: 60px; }
.fd-row .im .ph { width: 100%; aspect-ratio: 1 / 1; background-size: cover; background-position: center; background-color: var(--paper-deep); }
.fd-row .im .rcap { font-family: var(--label); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-top: 12px; }
.fd-row.rev .im { order: 2; }
.fd-row .tx .kick { font-family: var(--label); font-size: 12px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--accent); margin-bottom: 20px; }
.fd-row .tx p { font-size: 20px; line-height: 1.62; }
.fd-row .tx .hl { font-family: var(--display); font-style: italic; color: var(--accent-deep); }
.fd-row.lead .tx > p:first-child::first-letter {
  font-family: var(--display); font-weight: 440; float: left;
  font-size: 4em; line-height: 0.74; padding: 8px 12px 0 0; color: var(--accent-deep);
}

/* =========================================================================
   PULL QUOTE — spans the full measure
   ========================================================================= */
.fd-pull { padding: 70px 0; text-align: center; }
.fd-pull blockquote {
  font-family: var(--display); font-weight: 360; font-size: clamp(32px, 5.4vw, 70px);
  line-height: 1.06; letter-spacing: -0.02em; color: var(--ink); margin: 0 auto;
  max-width: 17ch; text-wrap: balance;
}
.fd-pull blockquote .it { font-style: italic; color: var(--accent-deep); }
.fd-pull.line { border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.fd-pull.line { padding: 84px 0; }

/* =========================================================================
   DARK CHAPTER — full-bleed, two filled columns + big punch
   ========================================================================= */
.fd-dark { background: var(--dark); color: var(--paper); padding: 104px 0; margin: 86px 0; }
.fd-dark .inner { max-width: 1140px; margin: 0 auto; padding: 0 44px; }
.fd-dark .eyebrow { font-family: var(--label); font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--dark-gold); margin-bottom: 36px; }
.fd-dark .fd-2col p { font-size: 19px; line-height: 1.66; color: var(--dark-soft); margin: 0; }
.fd-dark .fd-2col .c p + p { margin-top: 1.1em; }
.fd-dark .punch {
  font-family: var(--display); font-style: italic; font-weight: 350;
  font-size: clamp(32px, 5vw, 62px); line-height: 1.06; letter-spacing: -0.015em;
  color: #f6efe2; margin: 60px 0 0; max-width: 20ch; text-wrap: balance;
}

/* =========================================================================
   CLOSER — full-bleed image with the final line
   ========================================================================= */
.fd-closer { width: 100%; position: relative; margin-top: 86px; }
.fd-closer .img { width: 100%; aspect-ratio: 16 / 8; background-size: cover; background-position: center 34%; background-color: var(--dark); }
.fd-closer .veil { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(20,15,9,0.85) 0%, rgba(20,15,9,0.5) 48%, rgba(20,15,9,0.12) 100%); display: flex; align-items: center; }
.fd-closer .veil .inner { max-width: 1140px; margin: 0 auto; padding: 0 44px; width: 100%; }
.fd-closer .final {
  font-family: var(--display); font-weight: 360; font-size: clamp(36px, 6.4vw, 86px);
  line-height: 0.98; letter-spacing: -0.025em; color: #f7f1e5; margin: 0; max-width: 13ch; text-wrap: balance;
}

/* =========================================================================
   SIGNOFF + RELATED
   ========================================================================= */
.fd-sign { display: flex; align-items: center; gap: 18px; margin: 70px 0 0; padding-top: 38px; border-top: 1px solid var(--rule); }
.fd-sign .avatar { width: 62px; height: 62px; border-radius: 50%; background-size: cover; background-position: center top; background-color: var(--paper-deep); border: 1px solid var(--rule); flex: none; }
.fd-sign .txt { font-family: var(--label); line-height: 1.5; }
.fd-sign .txt .n { font-family: var(--display); font-size: 22px; font-style: italic; color: var(--ink); }
.fd-sign .txt .r { font-size: 12.5px; color: var(--ink-faint); letter-spacing: 0.05em; }

.fd-related { padding: 70px 0 104px; }
.fd-related .ey { font-family: var(--label); font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--accent); margin-bottom: 32px; }
.fd-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.fd-card { display: block; text-decoration: none; color: inherit; border: 1px solid var(--rule); background: rgba(255,255,255,0.28); padding: 0 0 24px; transition: transform 0.35s ease, border-color 0.35s ease, background 0.35s ease; }
.fd-card:hover { transform: translateY(-4px); border-color: var(--accent); background: rgba(255,255,255,0.5); }
.fd-card .ci { width: 100%; aspect-ratio: 3 / 2; background-size: cover; background-position: center; background-color: var(--paper-deep); margin-bottom: 20px; }
.fd-card .ck { font-family: var(--label); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); padding: 0 22px; }
.fd-card .ct { font-family: var(--display); font-size: 24px; line-height: 1.12; margin: 11px 22px 0; }
.fd-card .cd { font-size: 15px; line-height: 1.5; color: var(--ink-soft); margin: 11px 22px 0; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 860px) {
  .fd-shell, .fd-cap, .fd-dark .inner, .fd-closer .veil .inner { padding-left: 24px; padding-right: 24px; }
  .fd-2col { grid-template-columns: 1fr; row-gap: 1.25em; }
  .fd-block.lead .c:first-child > p:first-child::first-letter { font-size: 3.8em; }
  .fd-row { grid-template-columns: 1fr; row-gap: 26px; }
  .fd-row.rev .im { order: -1; }
  .fd-row .im { order: -1; }
  .fd-band.hero .img, .fd-band.wide .img { aspect-ratio: 4 / 5; }
}
@media (max-width: 560px) {
  .fd-shell { padding: 0 20px; }
  .fd-byline { flex-wrap: wrap; }
  .fd-byline .meta { margin-left: 0; text-align: left; width: 100%; }
  .fd-cards { grid-template-columns: 1fr; }
  .fd-closer .veil { background: linear-gradient(180deg, rgba(20,15,9,0.45) 0%, rgba(20,15,9,0.84) 100%); }
}
