/* ═══════════════════════════════════════════════════════════
   THE CORRIDOR AFRICA — Shared Stylesheet
   thecorridorafrica.com
   Version 3.0 — Editorial Rebuild · April 2026
   FT/Economist density · African intersection · Standing departments
   ═══════════════════════════════════════════════════════════ */

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

:root {
  --red: #B30000;
  --red-deep: #7B241C;
  --ink: #1a1a1a;
  --paper: #FFF1E5;
  --cream: #F8F3EC;
  --mid: #4a4a4a;
  --muted: #8a8a8a;
  --rule: #d9d3c7;
  --rule-light: #ebe6da;
  --white: #ffffff;
}

html { scroll-behavior: smooth; }
body { font-family: 'Source Serif 4', Georgia, serif; background: white; color: var(--ink); line-height: 1.5; -webkit-font-smoothing: antialiased; }

a { color: var(--red); }

/* ── SKIP TO CONTENT ──────────────────────────────────────── */
.skip-link { position: absolute; top: -100px; left: 16px; background: var(--red); color: white; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; padding: 10px 20px; z-index: 9999; text-decoration: none; transition: top 0.2s; }
.skip-link:focus { top: 16px; }

/* ── MASTHEAD STRIP ───────────────────────────────────────── */
.tc-masthead { background: var(--paper); border-bottom: 1px solid var(--rule); padding: 12px 32px 14px; display: flex; align-items: baseline; justify-content: space-between; }
.tc-masthead-left { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--mid); }
.tc-masthead-left strong { color: var(--ink); }
.tc-masthead-right { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--mid); display: flex; gap: 18px; }
.tc-masthead-right a { color: var(--mid); text-decoration: none; }
.tc-masthead-right a:hover { color: var(--red); }

/* ── FLAG / BANNER ────────────────────────────────────────── */
.tc-banner { background: white; padding: 22px 32px 14px; text-align: center; border-bottom: 2px solid var(--ink); }
.tc-banner.tc-banner-large { padding: 28px 32px 18px; }
.tc-flag { font-family: 'Playfair Display', serif; font-size: 38px; font-weight: 900; color: var(--ink); letter-spacing: 1px; line-height: 1; }
.tc-banner.tc-banner-large .tc-flag { font-size: 56px; }
.tc-flag em { color: var(--red); font-style: italic; }
.tc-flag a { color: inherit; text-decoration: none; }
.tc-tagline { font-family: 'Source Serif 4', serif; font-style: italic; font-size: 12px; color: var(--mid); margin-top: 6px; letter-spacing: 0.3px; }
.tc-banner.tc-banner-large .tc-tagline { font-size: 13px; margin-top: 8px; }

/* ── STANDING SECTIONS NAV ────────────────────────────────── */
.tc-sections { background: white; border-bottom: 1px solid var(--rule); display: flex; justify-content: center; gap: 0; padding: 0 32px; overflow-x: auto; }
.tc-section-link { font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 600; color: var(--ink); text-decoration: none; padding: 14px 20px; border-bottom: 2px solid transparent; white-space: nowrap; letter-spacing: 0.4px; }
.tc-section-link:hover { color: var(--red); border-bottom-color: var(--red); }
.tc-section-link.active { color: var(--red); border-bottom-color: var(--red); }
.tc-section-divider { color: var(--rule); padding: 14px 0; }

/* ── BREADCRUMB STRIP ─────────────────────────────────────── */
.tc-dept-strip { background: var(--cream); border-bottom: 1px solid var(--rule); padding: 14px 32px; }
.tc-dept-inner { max-width: 1200px; margin: 0 auto; font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--mid); }
.tc-dept-inner a { color: var(--mid); text-decoration: none; }
.tc-dept-inner a:hover { color: var(--red); }
.tc-dept-inner strong { color: var(--ink); }
.tc-dept-sep { padding: 0 8px; color: var(--rule); }

/* ════════════════════════════════════════════════════════════
   HOMEPAGE / FRONT PAGE
   ════════════════════════════════════════════════════════════ */

/* COVER FEATURE */
.tc-cover { background: white; padding: 56px 32px 64px; max-width: 1200px; margin: 0 auto; }
.tc-cover-grid { display: grid; grid-template-columns: 1fr 420px; gap: 64px; align-items: start; }
.tc-cover-meta { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--red); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 20px; display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.tc-cover-meta-sep { color: var(--rule); }
.tc-cover-headline { font-family: 'Playfair Display', serif; font-size: clamp(36px, 5vw, 56px); font-weight: 900; line-height: 1.05; letter-spacing: -1px; color: var(--ink); margin-bottom: 24px; }
.tc-cover-headline em { font-style: italic; color: var(--red); font-weight: 700; }
.tc-cover-rule { width: 56px; height: 4px; background: var(--ink); margin-bottom: 24px; }
.tc-cover-standfirst { font-family: 'Source Serif 4', serif; font-size: 19px; font-style: italic; color: var(--mid); line-height: 1.65; margin-bottom: 28px; }
.tc-cover-byline { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--muted); margin-bottom: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--rule); }
.tc-cover-byline strong { color: var(--ink); }
.tc-cover-cta { display: inline-block; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; color: white; background: var(--ink); padding: 12px 28px; text-decoration: none; letter-spacing: 0.3px; }
.tc-cover-cta:hover { background: var(--red); }

.tc-cover-aside { border-left: 1px solid var(--rule); padding-left: 40px; }
.tc-cover-aside-label { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--red); margin-bottom: 18px; padding-bottom: 12px; border-bottom: 1px solid var(--rule); }
.tc-stat { padding: 14px 0; border-bottom: 1px solid var(--rule-light); }
.tc-stat:last-child { border-bottom: none; }
.tc-stat-num { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 900; color: var(--ink); line-height: 1; }
.tc-stat-num.red { color: var(--red); }
.tc-stat-label { font-family: 'Source Serif 4', serif; font-size: 13px; color: var(--mid); margin-top: 4px; line-height: 1.45; }
.tc-stat-source { font-family: 'DM Sans', sans-serif; font-size: 10px; color: var(--muted); font-style: italic; margin-top: 4px; }

/* ARCHIVE GRID (FT-density columns) */
.tc-archive-wrap { background: var(--cream); border-top: 1px solid var(--rule); padding: 48px 32px 64px; }
.tc-archive-inner { max-width: 1200px; margin: 0 auto; }
.tc-archive-head { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 18px; margin-bottom: 24px; border-bottom: 2px solid var(--ink); flex-wrap: wrap; gap: 12px; }
.tc-archive-title { font-family: 'Playfair Display', serif; font-size: 22px; font-weight: 700; color: var(--ink); }
.tc-archive-meta { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--mid); font-style: italic; }
.tc-archive-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; background: var(--rule); border: 1px solid var(--rule); }
.tc-archive-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.tc-piece { background: white; padding: 24px 22px; display: flex; flex-direction: column; min-height: 240px; text-decoration: none; color: var(--ink); transition: background 0.15s; }
.tc-piece:hover { background: #faf8f4; }
.tc-piece-meta { font-family: 'DM Sans', sans-serif; font-size: 10px; color: var(--red); font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 10px; }
.tc-piece-headline { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700; line-height: 1.25; color: var(--ink); margin-bottom: 10px; }
.tc-piece-standfirst { font-family: 'Source Serif 4', serif; font-size: 14px; color: var(--mid); line-height: 1.6; margin-bottom: 14px; flex: 1; }
.tc-piece-byline { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--muted); padding-top: 10px; border-top: 1px solid var(--rule-light); }

/* DEPARTMENTS GRID */
.tc-departments-wrap { background: white; padding: 56px 32px; border-top: 1px solid var(--rule); }
.tc-departments-inner { max-width: 1200px; margin: 0 auto; }
.tc-departments-head { padding-bottom: 18px; margin-bottom: 28px; border-bottom: 2px solid var(--ink); }
.tc-departments-kicker { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 8px; }
.tc-departments-title { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 700; color: var(--ink); }
.tc-departments-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.tc-dept { background: white; padding: 28px 26px; text-decoration: none; color: var(--ink); display: block; transition: background 0.15s; }
.tc-dept:hover { background: #faf8f4; }
.tc-dept-name { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.tc-dept-name em { color: var(--red); font-style: italic; }
.tc-dept-frame { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--red); font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 14px; }
.tc-dept-desc { font-family: 'Source Serif 4', serif; font-size: 14px; color: var(--mid); line-height: 1.65; margin-bottom: 16px; }
.tc-dept-count { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--muted); padding-top: 14px; border-top: 1px solid var(--rule-light); }

/* ════════════════════════════════════════════════════════════
   ARTICLE PAGE
   ════════════════════════════════════════════════════════════ */

.tc-article-head { background: white; padding: 56px 32px 32px; border-bottom: 1px solid var(--rule); }
.tc-article-head-inner { max-width: 800px; margin: 0 auto; }
.tc-article-meta { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--red); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 24px; display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.tc-article-meta-sep { color: var(--rule); }
.tc-article-headline { font-family: 'Playfair Display', serif; font-size: clamp(34px, 5vw, 52px); font-weight: 900; line-height: 1.05; letter-spacing: -1px; color: var(--ink); margin-bottom: 24px; }
.tc-article-headline em { font-style: italic; color: var(--red); font-weight: 700; }
.tc-article-rule { width: 56px; height: 4px; background: var(--ink); margin-bottom: 24px; }
.tc-article-standfirst { font-family: 'Source Serif 4', serif; font-size: 19px; font-style: italic; color: var(--mid); line-height: 1.65; margin-bottom: 28px; }
.tc-article-byline { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--muted); padding: 14px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); display: flex; gap: 18px; flex-wrap: wrap; }
.tc-article-byline strong { color: var(--ink); }
.tc-article-byline-sep { color: var(--rule); }

/* LEAD IMAGE */
.tc-lead-img { background: var(--cream); padding: 0; }
.tc-lead-img-wrap { max-width: 1200px; margin: 0 auto; position: relative; }
.tc-lead-img-wrap img { width: 100%; height: auto; max-height: 520px; object-fit: cover; display: block; }
.tc-lead-caption { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--muted); padding: 8px 32px; max-width: 1200px; margin: 0 auto; font-style: italic; border-bottom: 1px solid var(--rule); }

/* SHARE BAR */
.tc-share { background: white; border-bottom: 1px solid var(--rule); padding: 12px 32px; }
.tc-share-inner { max-width: 800px; margin: 0 auto; display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.tc-share-label { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); }
.tc-share-link { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--mid); text-decoration: none; padding: 4px 10px; border: 1px solid var(--rule); transition: all 0.15s; cursor: pointer; background: white; }
.tc-share-link:hover { background: var(--ink); color: white; border-color: var(--ink); }

/* ARTICLE BODY */
.tc-article-body { max-width: 800px; margin: 0 auto; padding: 48px 32px 32px; }
.tc-article-body p { font-family: 'Source Serif 4', serif; font-size: 18px; line-height: 1.75; color: var(--ink); margin-bottom: 22px; }
.tc-article-body p.tc-lead-para::first-letter { font-family: 'Playfair Display', serif; font-size: 72px; font-weight: 900; float: left; line-height: 0.85; padding: 6px 8px 0 0; color: var(--red); }
.tc-article-body p.tc-lead-para { font-size: 19px; }
.tc-article-body h2 { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 700; color: var(--ink); line-height: 1.25; margin: 40px 0 18px; }
.tc-article-body h2::before { content: ''; display: block; width: 32px; height: 3px; background: var(--red); margin-bottom: 14px; }
.tc-article-body ul, .tc-article-body ol { margin: 0 0 22px 24px; padding: 0; }
.tc-article-body li { font-family: 'Source Serif 4', serif; font-size: 17px; line-height: 1.7; color: var(--ink); margin-bottom: 8px; }

/* PULL QUOTE */
.tc-pullquote { margin: 36px 0; padding: 24px 0; border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.tc-pullquote p { font-family: 'Playfair Display', serif !important; font-size: 24px !important; font-style: italic; color: var(--ink); line-height: 1.4 !important; margin: 0 !important; font-weight: 400; }

/* INLINE STAT BLOCK */
.tc-inline-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin: 36px 0; padding: 28px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.tc-inline-stat-num { font-family: 'Playfair Display', serif; font-size: 32px; font-weight: 900; color: var(--ink); line-height: 1; margin-bottom: 6px; }
.tc-inline-stat-num.red { color: var(--red); }
.tc-inline-stat-label { font-family: 'Source Serif 4', serif; font-size: 13px; color: var(--mid); line-height: 1.5; }

/* FOOTNOTE MARKERS */
.tc-fn { font-size: 0.7em; vertical-align: super; color: var(--red); font-weight: 700; padding: 0 1px; text-decoration: none; }
.tc-fn:hover { background: var(--red); color: white; }

/* FOOTNOTES BLOCK */
.tc-footnotes { max-width: 800px; margin: 32px auto 0; padding: 32px; border-top: 2px solid var(--ink); }
.tc-footnotes-label { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 18px; }
.tc-footnotes ol { list-style: none; padding: 0; counter-reset: fn; margin: 0; }
.tc-footnotes ol li { font-family: 'Source Serif 4', serif; font-size: 14px; line-height: 1.65; color: var(--mid); padding: 8px 0 8px 28px; position: relative; counter-increment: fn; margin: 0; }
.tc-footnotes ol li::before { content: counter(fn) "."; position: absolute; left: 0; top: 8px; color: var(--red); font-weight: 700; }
.tc-footnotes em { font-style: italic; }

/* MORE FROM DEPARTMENT */
.tc-more { background: var(--cream); border-top: 1px solid var(--rule); padding: 48px 32px; }
.tc-more-inner { max-width: 1200px; margin: 0 auto; }
.tc-more-head { padding-bottom: 18px; margin-bottom: 24px; border-bottom: 2px solid var(--ink); display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 12px; }
.tc-more-title { font-family: 'Playfair Display', serif; font-size: 22px; font-weight: 700; color: var(--ink); }
.tc-more-link { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--red); text-decoration: none; font-weight: 700; letter-spacing: 0.5px; }
.tc-more-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }

/* ════════════════════════════════════════════════════════════
   DEPARTMENT / LENS PAGE
   ════════════════════════════════════════════════════════════ */

.tc-dept-header { background: white; padding: 56px 32px 40px; border-bottom: 2px solid var(--ink); }
.tc-dept-header-inner { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 320px; gap: 56px; align-items: end; }
.tc-dept-kicker { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--red); margin-bottom: 14px; }
.tc-dept-title { font-family: 'Playfair Display', serif; font-size: clamp(40px, 5.5vw, 64px); font-weight: 900; color: var(--ink); line-height: 1; letter-spacing: -1px; margin-bottom: 18px; }
.tc-dept-title em { font-style: italic; color: var(--red); }
.tc-dept-rule { width: 56px; height: 4px; background: var(--ink); margin-bottom: 22px; }
.tc-dept-standfirst { font-family: 'Source Serif 4', serif; font-size: 18px; font-style: italic; color: var(--mid); line-height: 1.65; max-width: 600px; }
.tc-dept-meta { border-left: 1px solid var(--rule); padding-left: 32px; }
.tc-dept-meta-label { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.tc-dept-meta-row { padding: 12px 0; border-bottom: 1px solid var(--rule-light); display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.tc-dept-meta-row:last-child { border-bottom: none; }
.tc-dept-meta-row-label { font-family: 'Source Serif 4', serif; font-size: 13px; color: var(--mid); }
.tc-dept-meta-row-val { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; color: var(--ink); text-align: right; }

/* FEATURED PIECE */
.tc-featured-wrap { background: white; padding: 48px 32px; border-bottom: 1px solid var(--rule); }
.tc-featured-inner { max-width: 1100px; margin: 0 auto; }
.tc-featured-label { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--red); margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--rule); }
.tc-featured-grid { display: grid; grid-template-columns: 1fr 380px; gap: 56px; align-items: start; }
.tc-featured-meta { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--red); font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; margin-bottom: 14px; }
.tc-featured-headline { font-family: 'Playfair Display', serif; font-size: clamp(28px, 4vw, 40px); font-weight: 900; line-height: 1.1; letter-spacing: -0.5px; color: var(--ink); margin-bottom: 18px; }
.tc-featured-headline em { font-style: italic; color: var(--red); font-weight: 700; }
.tc-featured-headline a { color: inherit; text-decoration: none; }
.tc-featured-headline a:hover { color: var(--red); }
.tc-featured-standfirst { font-family: 'Source Serif 4', serif; font-size: 17px; color: var(--mid); line-height: 1.7; margin-bottom: 22px; font-style: italic; }
.tc-featured-byline { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--muted); margin-bottom: 22px; padding-bottom: 22px; border-bottom: 1px solid var(--rule); }
.tc-featured-byline strong { color: var(--ink); }
.tc-featured-cta { display: inline-block; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; color: white; background: var(--ink); padding: 11px 24px; text-decoration: none; letter-spacing: 0.3px; }
.tc-featured-cta:hover { background: var(--red); }

.tc-featured-stats-label { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--red); margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--rule); }

/* DEPT ARCHIVE */
.tc-dept-archive { background: var(--cream); padding: 48px 32px 64px; }
.tc-dept-archive-inner { max-width: 1100px; margin: 0 auto; }
.tc-dept-archive .tc-archive-grid { grid-template-columns: repeat(2, 1fr); }
.tc-dept-archive .tc-piece-headline { font-size: 22px; letter-spacing: -0.3px; }
.tc-dept-archive .tc-piece { padding: 28px; min-height: 220px; }
.tc-dept-archive .tc-piece-standfirst { font-size: 15px; }

/* CROSS-DEPARTMENT BLOCK */
.tc-cross-wrap { background: white; padding: 48px 32px; border-top: 1px solid var(--rule); }
.tc-cross-inner { max-width: 1100px; margin: 0 auto; }
.tc-cross-head { padding-bottom: 16px; margin-bottom: 24px; border-bottom: 2px solid var(--ink); }
.tc-cross-kicker { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 6px; }
.tc-cross-title { font-family: 'Playfair Display', serif; font-size: 22px; font-weight: 700; color: var(--ink); }
.tc-cross-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); }
.tc-cross-item { background: white; padding: 22px 18px; text-decoration: none; color: var(--ink); transition: background 0.15s; }
.tc-cross-item:hover { background: #faf8f4; }
.tc-cross-name { font-family: 'Playfair Display', serif; font-size: 15px; font-weight: 700; color: var(--ink); margin-bottom: 6px; line-height: 1.25; }
.tc-cross-name em { color: var(--red); font-style: italic; }
.tc-cross-frame { font-family: 'DM Sans', sans-serif; font-size: 9px; color: var(--red); font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 8px; }
.tc-cross-count { font-family: 'DM Sans', sans-serif; font-size: 10px; color: var(--muted); padding-top: 8px; border-top: 1px solid var(--rule-light); }

/* ════════════════════════════════════════════════════════════
   SHARED COMPONENTS — bottom of every page
   ════════════════════════════════════════════════════════════ */

/* ABOUT STRIP (homepage only) */
.tc-about { background: var(--ink); color: white; padding: 56px 32px; }
.tc-about-inner { max-width: 880px; margin: 0 auto; text-align: center; }
.tc-about-rule { width: 48px; height: 3px; background: var(--red); margin: 0 auto 18px; }
.tc-about-title { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 700; line-height: 1.3; margin-bottom: 18px; }
.tc-about-body { font-family: 'Source Serif 4', serif; font-size: 17px; color: rgba(255,255,255,0.7); line-height: 1.75; font-style: italic; margin-bottom: 24px; }
.tc-about-cta { display: inline-block; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; color: white; background: var(--red); padding: 12px 28px; text-decoration: none; letter-spacing: 0.3px; }

/* SUBSCRIBE STRIP (article + dept pages) */
.tc-subscribe { background: var(--ink); padding: 48px 32px; }
.tc-subscribe-inner { max-width: 720px; margin: 0 auto; text-align: center; }
.tc-subscribe-rule { width: 48px; height: 3px; background: var(--red); margin: 0 auto 16px; }
.tc-subscribe-title { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 700; color: white; line-height: 1.3; margin-bottom: 14px; }
.tc-subscribe-body { font-family: 'Source Serif 4', serif; font-size: 16px; color: rgba(255,255,255,0.7); line-height: 1.7; font-style: italic; margin-bottom: 22px; }
.tc-subscribe-cta { display: inline-block; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; color: white; background: var(--red); padding: 12px 28px; text-decoration: none; letter-spacing: 0.3px; }

/* COLOPHON */
.tc-colophon { background: var(--paper); padding: 32px; border-top: 1px solid var(--rule); }
.tc-colophon-inner { max-width: 1200px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.tc-colophon-brand { font-family: 'Playfair Display', serif; font-size: 14px; font-weight: 900; color: var(--ink); letter-spacing: 1px; }
.tc-colophon-links { display: flex; gap: 18px; flex-wrap: wrap; }
.tc-colophon-links a { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--mid); text-decoration: none; }
.tc-colophon-links a:hover { color: var(--red); }
.tc-colophon-copy { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--muted); }

/* ════════════════════════════════════════════════════════════
   LEGAL / SUPPORTING PAGES
   ════════════════════════════════════════════════════════════ */

.tc-page-header { background: white; padding: 48px 32px; border-bottom: 2px solid var(--ink); }
.tc-page-header-inner { max-width: 800px; margin: 0 auto; }
.tc-page-kicker { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 14px; }
.tc-page-title { font-family: 'Playfair Display', serif; font-size: clamp(34px, 5vw, 48px); font-weight: 900; color: var(--ink); line-height: 1.05; letter-spacing: -0.5px; }
.tc-page-body { max-width: 800px; margin: 0 auto; padding: 48px 32px; }
.tc-page-body p { font-family: 'Source Serif 4', serif; font-size: 17px; line-height: 1.75; color: var(--ink); margin-bottom: 22px; }
.tc-page-body h2 { font-family: 'Playfair Display', serif; font-size: 24px; font-weight: 700; color: var(--ink); margin: 36px 0 16px; }
.tc-page-body h2::before { content: ''; display: block; width: 32px; height: 3px; background: var(--red); margin-bottom: 12px; }
.tc-page-body ul, .tc-page-body ol { margin: 0 0 22px 24px; padding: 0; }
.tc-page-body li { font-family: 'Source Serif 4', serif; font-size: 16px; line-height: 1.7; color: var(--mid); margin-bottom: 8px; }
.tc-page-body a { color: var(--red); }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
  .tc-masthead { padding: 10px 16px 12px; flex-direction: column; align-items: flex-start; gap: 6px; }
  .tc-banner { padding: 18px 16px 12px; }
  .tc-banner.tc-banner-large { padding: 22px 16px 14px; }
  .tc-flag { font-size: 28px; }
  .tc-banner.tc-banner-large .tc-flag { font-size: 36px; }
  .tc-sections { padding: 0 8px; }
  .tc-section-link { padding: 12px 12px; font-size: 11px; }
  .tc-dept-strip { padding: 12px 16px; }

  .tc-cover { padding: 32px 20px; }
  .tc-cover-grid { grid-template-columns: 1fr; gap: 32px; }
  .tc-cover-aside { border-left: none; border-top: 1px solid var(--rule); padding-left: 0; padding-top: 24px; }

  .tc-archive-wrap { padding: 36px 20px; }
  .tc-archive-grid { grid-template-columns: 1fr; }

  .tc-departments-wrap { padding: 36px 20px; }
  .tc-departments-grid { grid-template-columns: 1fr 1fr; }

  .tc-about { padding: 40px 20px; }

  .tc-article-head { padding: 36px 20px 24px; }
  .tc-article-headline { font-size: clamp(26px, 6vw, 38px); }
  .tc-article-body { padding: 32px 20px 24px; }
  .tc-article-body p { font-size: 17px; }
  .tc-article-body p.tc-lead-para { font-size: 18px; }
  .tc-inline-stats { grid-template-columns: 1fr 1fr; }
  .tc-share { padding: 12px 20px; }
  .tc-footnotes { padding: 24px 20px; }
  .tc-more { padding: 36px 20px; }
  .tc-more-grid { grid-template-columns: 1fr; }
  .tc-subscribe { padding: 36px 20px; }

  .tc-dept-header { padding: 36px 20px 28px; }
  .tc-dept-header-inner { grid-template-columns: 1fr; gap: 28px; }
  .tc-dept-meta { border-left: none; border-top: 1px solid var(--rule); padding-left: 0; padding-top: 20px; }
  .tc-featured-wrap { padding: 32px 20px; }
  .tc-featured-grid { grid-template-columns: 1fr; gap: 32px; }
  .tc-dept-archive { padding: 36px 20px; }
  .tc-dept-archive .tc-archive-grid { grid-template-columns: 1fr; }
  .tc-cross-wrap { padding: 36px 20px; }
  .tc-cross-grid { grid-template-columns: repeat(2, 1fr); }

  .tc-page-header { padding: 32px 20px; }
  .tc-page-body { padding: 32px 20px; }
}

@media (max-width: 600px) {
  .tc-departments-grid { grid-template-columns: 1fr; }
  .tc-cross-grid { grid-template-columns: 1fr; }
  .tc-inline-stats { grid-template-columns: 1fr; }
  .tc-article-body p.tc-lead-para::first-letter { font-size: 56px; }
}

/* ════════════════════════════════════════════════════════════
   PRINT
   ════════════════════════════════════════════════════════════ */

@media print {
  .tc-masthead, .tc-sections, .tc-share, .tc-more, .tc-cross-wrap, .tc-subscribe, .tc-colophon, .tc-departments-wrap, .tc-about, .skip-link { display: none !important; }
  body { font-family: Georgia, serif; font-size: 11pt; color: #000; background: white; }
  .tc-banner { padding: 8pt 0; border-bottom: 2pt solid #000; }
  .tc-flag { font-size: 18pt; color: #000; }
  .tc-flag em { color: #000; font-style: italic; }
  .tc-tagline { display: none; }
  .tc-article-head { padding: 16pt 0; border: none; }
  .tc-article-head-inner, .tc-article-body { max-width: 100%; padding: 0; }
  .tc-article-headline { font-size: 22pt; color: #000; }
  .tc-article-headline em { color: #000; }
  .tc-article-rule { background: #000; }
  .tc-article-standfirst { font-size: 13pt; color: #444; }
  .tc-article-body p { font-size: 11pt; line-height: 1.6; color: #000; }
  .tc-article-body h2 { font-size: 14pt; color: #000; page-break-after: avoid; }
  .tc-article-body h2::before { background: #000; }
  .tc-pullquote { border-color: #000; }
  .tc-pullquote p { font-size: 14pt !important; }
  .tc-fn { color: #000; }
  .tc-footnotes { padding: 12pt 0; border-top: 1pt solid #000; }
  .tc-footnotes ol li { font-size: 10pt; color: #000; }
  .tc-footnotes ol li::before { color: #000; }
  @page { margin: 2cm; }
}


/* ════════════════════════════════════════════════════════════════
   SEARCH PAGE — added v3.1
   ════════════════════════════════════════════════════════════════ */

.tc-search-header { background: white; padding: 56px 32px 32px; border-bottom: 2px solid var(--ink); }
.tc-search-header-inner { max-width: 1100px; margin: 0 auto; }
.tc-search-kicker { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--red); margin-bottom: 14px; }
.tc-search-title { font-family: 'Playfair Display', serif; font-size: clamp(40px, 5.5vw, 64px); font-weight: 900; color: var(--ink); line-height: 1; letter-spacing: -1px; margin-bottom: 18px; }
.tc-search-rule { width: 56px; height: 4px; background: var(--ink); margin-bottom: 22px; }
.tc-search-standfirst { font-family: 'Source Serif 4', serif; font-size: 18px; font-style: italic; color: var(--mid); line-height: 1.65; max-width: 700px; }

.tc-search-body { background: var(--cream); padding: 40px 32px 64px; min-height: 60vh; }
.tc-search-box { max-width: 800px; margin: 0 auto 24px; }
#tc-search-input { width: 100%; padding: 18px 22px; font-family: 'Source Serif 4', serif; font-size: 19px; border: 2px solid var(--ink); background: white; color: var(--ink); outline: none; transition: border-color 0.15s; box-sizing: border-box; -webkit-appearance: none; }
#tc-search-input:focus { border-color: var(--red); }
#tc-search-input::placeholder { color: var(--muted); font-style: italic; }
.tc-search-stats { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--muted); margin-top: 10px; letter-spacing: 0.3px; }

.tc-search-filters { max-width: 800px; margin: 0 auto 28px; display: flex; gap: 0; border-bottom: 1px solid var(--rule); flex-wrap: wrap; }
.tc-filter { font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 600; color: var(--mid); background: transparent; border: none; padding: 12px 18px; cursor: pointer; border-bottom: 2px solid transparent; letter-spacing: 0.4px; transition: all 0.15s; }
.tc-filter:hover { color: var(--ink); }
.tc-filter.active { color: var(--red); border-bottom-color: var(--red); }

.tc-search-results { max-width: 800px; margin: 0 auto; }
.tc-search-result { display: block; background: white; padding: 22px 24px; margin-bottom: 1px; text-decoration: none; color: var(--ink); border: 1px solid var(--rule); transition: background 0.12s, transform 0.12s; }
.tc-search-result + .tc-search-result { border-top: none; }
.tc-search-result:hover { background: #faf8f4; }
.tc-search-result-meta { font-family: 'DM Sans', sans-serif; font-size: 10px; color: var(--red); font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 8px; }
.tc-search-result-headline { font-family: 'Playfair Display', serif; font-size: 19px; font-weight: 700; line-height: 1.25; color: var(--ink); margin-bottom: 6px; }
.tc-search-result-standfirst { font-family: 'Source Serif 4', serif; font-size: 14px; color: var(--mid); line-height: 1.6; }
.tc-search-result mark { background: #fff3a8; color: var(--ink); padding: 0 2px; font-weight: inherit; }
.tc-search-empty { font-family: 'Source Serif 4', serif; font-size: 16px; color: var(--mid); text-align: center; padding: 48px 20px; font-style: italic; }
.tc-search-empty a { color: var(--red); }

@media (max-width: 900px) {
  .tc-search-header { padding: 36px 20px 24px; }
  .tc-search-body { padding: 28px 20px 48px; }
  #tc-search-input { padding: 14px 16px; font-size: 16px; }
  .tc-search-result { padding: 18px 18px; }
  .tc-search-result-headline { font-size: 17px; }
}


/* ════════════════════════════════════════════════════════════════
   COVER WITH IMAGE — Issue 011 onwards
   ════════════════════════════════════════════════════════════════ */

.tc-cover-with-image { padding: 56px 32px 64px; }
.tc-cover-grid-img { display: grid; grid-template-columns: 1fr 480px; gap: 56px; align-items: start; max-width: 1200px; margin: 0 auto; }
.tc-cover-figure { margin: 0; }
.tc-cover-figure img { width: 100%; height: auto; display: block; aspect-ratio: 4 / 3; object-fit: cover; }
.tc-cover-figcaption { font-family: 'Source Serif 4', serif; font-size: 12px; font-style: italic; color: var(--mid); line-height: 1.5; padding: 8px 0 0; border-top: 1px solid var(--rule); margin-top: 8px; }

@media (max-width: 900px) {
  .tc-cover-grid-img { grid-template-columns: 1fr; gap: 28px; }
  .tc-cover-with-image { padding: 32px 20px; }
}
