/*
  PromptHacker blog theme — v5 light paper design system.
  Exact match to ph-system.css design tokens.
  Light paper (#F7F3EA) background, dark navy nav/footer.
*/

/* =====================================================================
 * V5 DESIGN TOKENS — exact from ph-system.css
 * ===================================================================*/

:root {
  /* Navy scale */
  --ph-navy-950: #050B14;
  --ph-navy-900: #07111F;
  --ph-navy-850: #091422;
  --ph-navy-800: #0D1B2A;
  --ph-navy-700: #13243A;

  /* Accent palette */
  --ph-gold:    #FFC300;
  --ph-gold-2:  #FFD04A;
  --ph-blue:    #36A2EB;
  --ph-green:   #28D17C;
  --ph-purple:  #A56CFF;

  /* Light surface tokens */
  --ph-paper:     #F7F3EA;
  --ph-card:      #FFFFFF;
  --ph-card-soft: #FBF7EF;
  --ph-ink:       #181D29;
  --ph-muted:     #596579;
  --ph-faint:     #7D8796;
  --ph-line:      #E6DCCB;
  --ph-line-dark: rgba(224, 225, 221, .16);

  /* Shadow & shape */
  --ph-shadow: 0 26px 70px rgba(5, 11, 20, .16);
  --ph-radius: 18px;

  /* Typography stacks */
  --ph-serif: Georgia, "Times New Roman", ui-serif, serif;
  --ph-sans:  Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --ph-mono:  "JetBrains Mono", "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;

  /* Derived / convenience */
  --ph-gold-dim:    rgba(255, 195, 0, .14);
  --ph-gold-glow:   rgba(255, 195, 0, .28);
  --ph-green-dim:   rgba(40, 209, 124, .14);
  --ph-purple-dim:  rgba(165, 108, 255, .15);
  --ph-blue-dim:    rgba(54, 162, 235, .13);

  /* Layout */
  --wide-width:        1180px;
  --content-width:     760px;
  --nav-height:         64px;
  --ph-sidebar-width:  300px;

  /* Legacy radius aliases (used in older components) */
  --ph-radius-sm:   10px;
  --ph-radius-md:   16px;
  --ph-radius-lg:   24px;
  --ph-radius-pill: 999px;

  /* Map EmDash core tokens onto v5 */
  --color-bg:              var(--ph-paper);
  --color-bg-subtle:       var(--ph-card-soft);
  --color-text:            var(--ph-ink);
  --color-text-secondary:  var(--ph-muted);
  --color-muted:           var(--ph-muted);
  --color-border:          var(--ph-line);
  --color-border-subtle:   rgba(230, 220, 203, .45);
  --color-surface:         var(--ph-card);
  --color-accent:          var(--ph-gold);
  --color-accent-hover:    var(--ph-gold-2);
  --color-on-accent:       var(--ph-navy-950);
  --color-accent-ring:     var(--ph-gold-glow);

  /* Font map */
  --font-sans: var(--ph-sans);
}

/* Force light scheme — no dark-mode inversion */
:root,
:root.light,
:root.dark {
  color-scheme: light;
}

/* =====================================================================
 * GLOBAL RESET & BASE
 * ===================================================================*/

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

html { scroll-behavior: smooth; }

html, body {
  margin: 0;
  background: var(--ph-paper);
  color: var(--ph-ink);
  font-family: var(--ph-sans);
  font-size: 16px;
  line-height: 1.55;
}

/* Remove dark-theme body gradient */
body::before { display: none; }
body > * { position: static; z-index: auto; }

img { display: block; max-width: 100%; }
a   { color: inherit; }

/* Wrappers */
.ph-wrap { width: min(1240px, calc(100% - 40px)); margin-inline: auto; }
.ph-wide { width: min(1360px, calc(100% - 40px)); margin-inline: auto; }
.ph-page { min-height: 100vh; background: var(--ph-paper); }

/* =====================================================================
 * TYPOGRAPHY HELPERS
 * ===================================================================*/

.ph-eyebrow,
.ph-kicker {
  font-family: var(--ph-mono);
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .14em;
}
.ph-eyebrow { font-size: 12px; color: var(--ph-gold); }
.ph-kicker  { font-size: 11px; color: var(--ph-faint); }

.ph-h1, .ph-h2, .ph-h3 {
  font-family: var(--ph-serif);
  letter-spacing: -.045em;
  line-height: 1.02;
  margin: 0;
  color: var(--ph-ink);
}
.ph-h1 { font-size: clamp(44px, 7vw, 96px); }
.ph-h2 { font-size: clamp(30px, 4vw, 54px); }
.ph-h3 { font-size: clamp(22px, 2vw, 32px); }

.ph-lede {
  font-size: clamp(18px, 1.55vw, 22px);
  line-height: 1.55;
  color: var(--ph-muted);
}
.ph-muted { color: var(--ph-muted); }
.ph-gold  { color: var(--ph-gold); }

/* =====================================================================
 * BUTTONS (pill-style — v5 exact)
 * ===================================================================*/

.ph-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 999px;
  padding: 12px 20px;
  font-family: var(--ph-mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 900;
  text-decoration: none;
  border: 1px solid transparent;
  white-space: nowrap;
  cursor: pointer;
}
.ph-btn-gold   { background: var(--ph-gold);       color: var(--ph-navy-950); }
.ph-btn-dark   { background: var(--ph-navy-950);   color: var(--ph-gold); }
.ph-btn-ghost  { border-color: rgba(255,255,255,.22); color: #fff; background: rgba(255,255,255,.03); }
.ph-btn-paper  { border-color: var(--ph-line); background: #fff; color: var(--ph-ink); }

/* Legacy aliases (used in Astro templates) */
.ph-btn-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 20px;
  background: var(--ph-gold);
  color: var(--ph-navy-950);
  font-family: var(--ph-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 900;
  text-decoration: none;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  white-space: nowrap;
}
.ph-btn-cta:hover { opacity: .9; }

/* =====================================================================
 * TAGS (pill badges)
 * ===================================================================*/

.ph-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 6px 10px;
  font-family: var(--ph-mono);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 900;
  text-decoration: none;
}
.ph-tag-gold   { background: var(--ph-gold); color: var(--ph-navy-950); }
.ph-tag-blue   { background: rgba(54,162,235,.13); color: #155E94; border: 1px solid rgba(54,162,235,.28); }
.ph-tag-green  { background: rgba(40,209,124,.13); color: #0D7A4B; border: 1px solid rgba(40,209,124,.28); }
.ph-tag-purple { background: rgba(165,108,255,.15); color: #5B21B6; border: 1px solid rgba(165,108,255,.28); }
.ph-tag-line   { border: 1px solid var(--ph-line); background: #fff; color: var(--ph-muted); }

/* =====================================================================
 * NAVIGATION (dark — v5 exact)
 * ===================================================================*/

.ph-nav,
.site-header,
.ph-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(5, 11, 20, .92);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--ph-line-dark);
}

.ph-nav-inner,
.ph-header-inner {
  width: min(1360px, calc(100% - 32px));
  min-height: 64px;
  margin: auto;
  display: flex;
  align-items: center;
  gap: 22px;
}

/* Brand mark (serif PH on gold square) */
.ph-brand {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #fff;
  text-decoration: none;
  flex: 0 0 auto;
}

.ph-logo-group {
  display: flex;
  align-items: center;
  gap: 9px;
  text-decoration: none;
  flex-shrink: 0;
}

.ph-mark,
.ph-logo-box {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(--ph-gold);
  color: var(--ph-navy-950);
  display: grid;
  place-items: center;
  font-family: var(--ph-serif);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: -.06em;
  box-shadow: 0 0 0 1px rgba(255,255,255,.12);
}

/* Legacy .ph-logo-ph inner text */
.ph-logo-ph {
  font-family: var(--ph-serif);
  font-size: 11px;
  font-weight: 900;
  color: var(--ph-navy-950);
  letter-spacing: -.06em;
  line-height: 1;
}

.ph-brand-text,
.ph-logo-text {
  font-family: var(--ph-mono);
  font-size: 12px;
  letter-spacing: .08em;
  font-weight: 900;
  color: #fff;
}
.ph-brand-text .ai { color: var(--ph-gold); }

/* Nav links */
.ph-nav-links {
  display: flex;
  gap: 17px;
  align-items: center;
  margin-left: auto;
}
.ph-nav-links a,
.ph-nav-link {
  font-family: var(--ph-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #C9D1D9;
  text-decoration: none;
  font-weight: 800;
}
.ph-nav-links a:hover,
.ph-nav-links a.current,
.ph-nav-link:hover,
.ph-nav-link[aria-current="page"] { color: var(--ph-gold); }

/* Search pill */
.ph-search-link,
.ph-header-ctas .ph-btn-ghost {
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  color: #C9D1D9;
  padding: 8px 13px;
  font-family: var(--ph-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-decoration: none;
}
.ph-kbd {
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 5px;
  padding: 2px 5px;
  margin-left: 6px;
  color: var(--ph-gold);
}

.ph-nav-actions,
.ph-header-ctas {
  display: flex;
  gap: 10px;
  align-items: center;
}

/* Mobile menu */
.ph-mobile-menu-btn {
  display: none;
  background: transparent;
  border: none;
  padding: 6px;
  cursor: pointer;
}
.ph-mobile-menu-btn span {
  display: block;
  width: 20px;
  height: 2px;
  background: #C9D1D9;
  margin: 4px 0;
  border-radius: 2px;
}

.ph-mobile-nav {
  display: none;
  flex-direction: column;
  padding: 12px 24px 16px;
  border-top: 1px solid var(--ph-line-dark);
  background: rgba(5, 11, 20, .96);
  gap: 10px;
}
.ph-mobile-nav.open { display: flex; }
.ph-mobile-nav .ph-nav-link { padding: 8px 0; }

@media (max-width: 980px) {
  .ph-nav-inner {
    height: auto;
    min-height: 64px;
    flex-wrap: wrap;
    padding: 13px 0;
  }
  .ph-nav-links {
    order: 3;
    width: 100%;
    overflow: auto;
    margin-left: 0;
    padding-bottom: 4px;
  }
  .ph-nav-actions { margin-left: auto; }
}

@media (max-width: 820px) {
  .ph-nav-links,
  .ph-header-ctas { display: none; }
  .ph-mobile-menu-btn {
    display: inline-flex;
    flex-direction: column;
  }
}

/* =====================================================================
 * HERO (dark gradient — v5 exact)
 * ===================================================================*/

.ph-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(48px, 7vw, 96px) 0;
}

.ph-hero-dark {
  background:
    radial-gradient(circle at 75% 12%, rgba(54,162,235,.24), transparent 32rem),
    radial-gradient(circle at 62% 84%, rgba(255,195,0,.22), transparent 30rem),
    linear-gradient(180deg, var(--ph-navy-950), var(--ph-navy-900));
  color: #fff;
}
.ph-hero-dark .ph-h1,
.ph-hero-dark .ph-h2,
.ph-hero-dark .ph-h3 { color: #fff; }
.ph-hero-dark .ph-lede { color: #D4DBE5; }

.ph-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(380px, .88fr);
  gap: clamp(30px, 5vw, 70px);
  align-items: center;
}

.ph-meta-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
  font-family: var(--ph-mono);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #9DA8B8;
}
.ph-meta-row b { color: var(--ph-gold); }

.ph-hero-media,
.ph-featured-media {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  background: var(--ph-navy-950);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 28px 100px rgba(0,0,0,.35);
}
.ph-hero-media img,
.ph-featured-media img {
  width: 100%;
  height: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.ph-hero-media::after,
.ph-featured-media::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.10);
  pointer-events: none;
}
.ph-img-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--ph-gold);
  color: var(--ph-navy-950);
  border-radius: 999px;
  padding: 7px 11px;
  font-family: var(--ph-mono);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 900;
  z-index: 2;
}

/* =====================================================================
 * CARDS & SECTIONS
 * ===================================================================*/

.ph-card {
  background: #fff;
  border: 1px solid var(--ph-line);
  border-radius: var(--ph-radius);
  box-shadow: 0 1px 0 rgba(5,11,20,.03);
}

.ph-dark-card {
  background: linear-gradient(145deg, rgba(13,27,42,.98), rgba(5,11,20,.98));
  border: 1px solid var(--ph-line-dark);
  border-radius: var(--ph-radius);
  box-shadow: var(--ph-shadow);
  color: #fff;
}

.ph-section {
  padding: clamp(50px, 7vw, 92px) 0;
}
.ph-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 28px;
}

/* =====================================================================
 * ARTICLE CARD GRID (3-col)
 * ===================================================================*/

.ph-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.ph-article-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .16s ease, box-shadow .16s ease;
}
.ph-article-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 55px rgba(5,11,20,.10);
}
.ph-article-card figure {
  margin: 0;
  background: var(--ph-navy-950);
  position: relative;
  overflow: hidden;
}
.ph-article-card figure img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  transition: transform .25s ease;
}
.ph-article-card:hover figure img { transform: scale(1.025); }
.ph-article-card-body {
  padding: 20px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.ph-article-card h3 {
  font-family: var(--ph-serif);
  font-size: 22px;
  letter-spacing: -.025em;
  line-height: 1.16;
  margin: 0;
  color: var(--ph-ink);
}
.ph-article-card p {
  margin: 0;
  color: var(--ph-muted);
  font-size: 14.5px;
  line-height: 1.55;
}

/* Mini list (homepage sidebar strip) */
.ph-mini-list { display: grid; gap: 14px; }
.ph-mini-card {
  display: grid;
  grid-template-columns: 128px 1fr;
  gap: 16px;
  align-items: center;
  padding: 14px;
  text-decoration: none;
  color: inherit;
}
.ph-mini-card img {
  width: 128px;
  aspect-ratio: 4/3;
  object-fit: cover;
  object-position: center;
  border-radius: 12px;
  background: var(--ph-navy-950);
}
.ph-mini-card h3 { font-size: 18px; margin: 0 0 4px; }
.ph-mini-card p  { font-size: 13.5px; margin: 0; color: var(--ph-muted); }

/* =====================================================================
 * OUTCOME GRID (5-col icons)
 * ===================================================================*/

.ph-outcome-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}
.ph-outcome { padding: 22px; }
.ph-outcome h3 {
  margin: 8px 0 6px;
  font-family: var(--ph-serif);
  font-size: 22px;
  line-height: 1.1;
}
.ph-outcome p { margin: 0; color: var(--ph-muted); font-size: 14px; }

/* =====================================================================
 * HOME FEATURE SECTION
 * ===================================================================*/

.ph-home-feature {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, .85fr);
  gap: 24px;
  align-items: stretch;
}

.ph-home-promise {
  border-top: 1px solid var(--ph-line);
  border-bottom: 1px solid var(--ph-line);
  background: var(--ph-gold);
}

.ph-home-promise-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-left: 1px solid rgba(13, 27, 42, .22);
}

.ph-home-promise-grid div {
  min-width: 0;
  padding: 22px 20px;
  border-right: 1px solid rgba(13, 27, 42, .22);
}

.ph-home-promise-grid b {
  display: block;
  margin-bottom: 8px;
  font-family: var(--ph-mono);
  font-size: 12px;
  letter-spacing: .12em;
  color: var(--ph-ink);
}

.ph-home-promise-grid span {
  display: block;
  color: rgba(13, 27, 42, .78);
  font-size: 14px;
  line-height: 1.55;
}

.ph-page-hero-light {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(rgba(13, 27, 42, .05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13, 27, 42, .05) 1px, transparent 1px),
    #fff;
  background-size: 40px 40px;
  border-bottom: 1px solid var(--ph-line);
  padding: clamp(58px, 8vw, 104px) 0;
}

.ph-page-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .72fr);
  gap: 48px;
  align-items: center;
}

.ph-dossier-card {
  padding: 30px;
  border-color: var(--ph-ink);
  border-radius: 0;
  box-shadow: 6px 6px 0 var(--ph-gold);
  background: #fff;
}

.ph-dossier-card h2 {
  margin: 8px 0 12px;
  font-family: var(--ph-serif);
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.05;
}

.ph-dossier-card p {
  margin: 0;
  color: var(--ph-muted);
  font-size: 16px;
  line-height: 1.65;
}

.ph-about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: start;
}

.ph-timeline {
  padding: 28px;
  border-radius: 0;
}

.ph-timeline-item {
  position: relative;
  padding: 18px 0 18px 24px;
  border-left: 2px solid var(--ph-line);
}

.ph-timeline-item::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 24px;
  width: 12px;
  height: 12px;
  border: 2px solid var(--ph-ink);
  background: var(--ph-gold);
}

.ph-timeline-item b {
  display: block;
  font-family: var(--ph-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ph-blue);
  margin-bottom: 6px;
}

.ph-timeline-item span {
  display: block;
  color: var(--ph-muted);
  font-size: 14px;
  line-height: 1.55;
}

.ph-principle-grid,
.ph-pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.ph-principle {
  padding: 24px;
  border-radius: 0;
}

.ph-principle b {
  font-family: var(--ph-mono);
  font-size: 12px;
  color: var(--ph-blue);
}

.ph-principle h3,
.ph-price-card h3 {
  margin: 10px 0 8px;
  font-family: var(--ph-serif);
  font-size: 24px;
  line-height: 1.08;
}

.ph-principle p {
  margin: 0;
  color: var(--ph-muted);
  font-size: 14px;
  line-height: 1.55;
}

.ph-pricing-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
}

.ph-price-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 28px;
  border-radius: 0;
}

.ph-price-card-featured {
  border-color: var(--ph-ink);
  box-shadow: 5px 5px 0 var(--ph-gold);
}

.ph-price-card-dark {
  background:
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px),
    var(--ph-ink);
  background-size: 40px 40px;
  color: #fff;
  border-color: var(--ph-ink);
}

.ph-price-card-dark .ph-eyebrow,
.ph-price-card-dark .ph-price-line strong {
  color: var(--ph-gold);
}

.ph-price-card-dark p,
.ph-price-card-dark li,
.ph-price-card-dark .ph-price-line span {
  color: #C9D1D9;
}

.ph-price-line {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.ph-price-line strong {
  font-family: var(--ph-serif);
  font-size: 46px;
  line-height: 1;
  color: var(--ph-ink);
}

.ph-price-line span {
  color: var(--ph-muted);
  font-size: 14px;
}

.ph-price-card p {
  margin: 0;
  color: var(--ph-muted);
  font-size: 15px;
  line-height: 1.6;
}

.ph-price-card ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ph-price-card li {
  position: relative;
  padding-left: 18px;
  color: var(--ph-muted);
  font-size: 14px;
  line-height: 1.5;
}

.ph-price-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .62em;
  width: 7px;
  height: 7px;
  background: var(--ph-gold);
  border: 1px solid var(--ph-ink);
}

.ph-price-card .ph-btn {
  margin-top: auto;
  align-self: stretch;
  text-align: center;
}

.ph-faq-grid {
  display: grid;
  grid-template-columns: minmax(240px, .55fr) minmax(0, 1fr);
  gap: 36px;
  align-items: start;
}

.ph-faq-intro {
  padding: 24px;
  background: #fff;
  border: 1px solid var(--ph-line);
  box-shadow: 5px 5px 0 rgba(255, 195, 0, .34);
}

.ph-faq-intro .ph-eyebrow {
  margin-bottom: 14px;
}

.ph-faq-intro .ph-h2 {
  margin-bottom: 0;
}

.ph-faq-list {
  border-top: 1px solid var(--ph-line);
}

.ph-faq-list details {
  border-bottom: 1px solid var(--ph-line);
  padding: 18px 0;
}

.ph-faq-list summary {
  cursor: pointer;
  font-family: var(--ph-serif);
  font-size: 22px;
  line-height: 1.15;
  color: var(--ph-ink);
}

.ph-faq-list p {
  margin: 12px 0 0;
  color: var(--ph-muted);
  font-size: 15px;
  line-height: 1.65;
}

.ph-feature-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .78fr);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
}
.ph-feature-card > * { min-width: 0; }
.ph-feature-card figure {
  margin: 0;
  background:
    radial-gradient(circle at 68% 72%, rgba(255,195,0,.28), transparent 16rem),
    radial-gradient(circle at 30% 20%, rgba(54,162,235,.22), transparent 18rem),
    var(--ph-navy-950);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  min-height: 340px;
}
.ph-feature-card img {
  width: 100%;
  height: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
}
.ph-feature-copy {
  padding: 26px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}
.ph-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin: 22px 0;
}
.ph-stats span {
  font-family: var(--ph-mono);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #9DA8B8;
}
.ph-stats b { color: var(--ph-gold); }
.ph-hero-sample {
  display: block;
  max-width: 620px;
  padding: 18px 20px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 14px;
  background: rgba(255,255,255,.07);
  color: #fff;
  text-decoration: none;
}
.ph-hero-sample:hover {
  border-color: rgba(255,195,0,.55);
  background: rgba(255,255,255,.10);
}
.ph-hero-sample span {
  display: block;
  font-family: var(--ph-mono);
  font-size: 10px;
  line-height: 1.4;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ph-gold);
  font-weight: 900;
}
.ph-hero-sample strong {
  display: block;
  margin-top: 7px;
  font-family: var(--ph-serif);
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.06;
  color: #fff;
}
.ph-hero-sample p {
  margin: 9px 0 0;
  color: #D4DBE5;
  font-size: 15px;
  line-height: 1.55;
}
.ph-three-moves {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 24px 0;
}
.ph-move {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 14px;
  padding: 14px;
}
.ph-move .ph-kicker { color: var(--ph-gold); font-size: 9px; }
.ph-move p { margin: 5px 0 0; color: #D4DBE5; font-size: 14px; }

/* =====================================================================
 * ARTICLE CONTENT LAYOUT (2-col: prose | rail)
 * ===================================================================*/

.ph-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 900px) 300px;
  gap: 36px;
  align-items: start;
  justify-content: center;
}
.ph-content-layout > * { min-width: 0; }

.ph-article-main {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.ph-toc {
  position: static;
  padding: 18px 20px;
  background: var(--ph-card);
  border: 1px solid var(--ph-line);
  border-radius: var(--ph-radius-md);
  font-family: var(--ph-mono);
  font-size: 12px;
  color: var(--ph-muted);
}
.ph-toc strong {
  display: block;
  color: var(--ph-gold);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 10px;
  margin-bottom: 12px;
}
.ph-toc a {
  display: block;
  text-decoration: none;
  border-bottom: 1px solid var(--ph-line);
  padding: 8px 0;
  color: var(--ph-muted);
  line-height: 1.45;
}
.ph-toc a:hover { color: var(--ph-ink); }

/* Prose column */
.ph-prose { padding: 46px; }
.ph-prose h2 {
  font-family: var(--ph-serif);
  font-size: 32px;
  letter-spacing: -.03em;
  line-height: 1.1;
  margin: 34px 0 12px;
  color: var(--ph-ink);
}
.ph-prose h3 {
  font-family: var(--ph-serif);
  font-size: 26px;
  letter-spacing: -.03em;
  line-height: 1.1;
  margin: 30px 0 10px;
  color: var(--ph-ink);
}
.ph-prose p,
.ph-prose li {
  font-family: var(--ph-serif);
  font-size: 18px;
  line-height: 1.65;
  color: var(--ph-muted);
}
.ph-prose p     { margin: 0 0 18px; }
.ph-prose ol,
.ph-prose ul    { padding-left: 24px; }
.ph-prose pre   { white-space: pre-wrap; word-wrap: break-word; }
.ph-prose a     { color: var(--ph-ink); text-decoration: underline; text-underline-offset: 3px; }
.ph-prose a:hover { color: var(--ph-gold); }
.ph-prose strong { color: var(--ph-ink); font-weight: 700; }
.ph-prose blockquote {
  border-left: 3px solid var(--ph-gold);
  padding: 6px 0 6px 18px;
  margin: 1.5em 0;
  color: var(--ph-ink);
  font-style: italic;
}

.ph-paywall {
  display: block;
}

.ph-subscriber-gate {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 24px;
  align-items: center;
  margin: 34px 0 12px;
  padding: 28px;
  border: 1px solid rgba(180, 135, 43, .32);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(180, 135, 43, .13), rgba(255,255,255,.92) 44%),
    #fff;
  box-shadow: 0 18px 50px rgba(19, 23, 31, .08);
}

.ph-subscriber-gate.paid {
  border-color: rgba(27, 31, 42, .24);
  background:
    linear-gradient(135deg, rgba(27, 31, 42, .1), rgba(255,255,255,.94) 46%),
    #fff;
}

.ph-subscriber-gate-kicker {
  margin: 0 0 10px;
  font-family: var(--ph-mono);
  font-size: 11px;
  line-height: 1.3;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ph-gold);
}

.ph-subscriber-gate h2 {
  max-width: 720px;
  margin: 0;
  font-family: var(--ph-serif);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.04;
  letter-spacing: 0;
  color: var(--ph-ink);
}

.ph-subscriber-gate p {
  margin: 14px 0 0;
  color: var(--ph-muted);
}

.ph-subscriber-gate-form {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid rgba(27, 31, 42, .12);
  border-radius: 8px;
  background: rgba(255,255,255,.78);
}

.ph-subscriber-gate-form input[type="email"] {
  width: 100%;
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid rgba(27, 31, 42, .22);
  border-radius: 6px;
  background: #fff;
  color: var(--ph-ink);
  font: 14px/1.3 var(--ph-sans);
}

.ph-subscriber-gate-form p {
  margin: 0;
  font-size: 12px;
  color: var(--ph-faint);
}

.ph-subscriber-gate-form .ph-subscriber-gate-error {
  margin: 0;
  padding: 10px 12px;
  border: 1px solid rgba(150, 52, 42, .24);
  border-radius: 6px;
  background: rgba(150, 52, 42, .08);
  color: #7a2d26;
  font-size: 13px;
  line-height: 1.4;
}

.ph-gate-note {
  margin: 18px 0 0;
  padding-top: 16px;
  border-top: 1px solid var(--ph-line);
  font-family: var(--ph-mono);
  font-size: 12px;
  line-height: 1.55;
  letter-spacing: .04em;
  color: var(--ph-faint);
}
.ph-prose img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  border: 1px solid var(--ph-line);
  margin: 1.5em 0;
}

/* Code in prose */
.ph-code,
pre {
  position: relative;
  background: var(--ph-navy-950);
  color: #E0E1DD;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  padding: 20px;
  font-family: var(--ph-mono);
  font-size: 13px;
  line-height: 1.55;
  overflow: auto;
}

/* Callout box */
.ph-callout {
  border: 1px solid var(--ph-line);
  background: linear-gradient(135deg, #FFF8DF, #F2FAFF);
  border-radius: 16px;
  padding: 20px;
  margin: 24px 0;
}

/* Rail (right sticky column) */
.ph-rail {
  position: sticky;
  top: 94px;
  display: grid;
  gap: 16px;
}

.ph-panel {
  border: 1px solid var(--ph-line);
  border-radius: 16px;
  background: #fff;
  padding: 22px;
  overflow: hidden;
}
.ph-panel.dark {
  background: var(--ph-navy-950);
  color: #fff;
  border-color: var(--ph-line-dark);
}
.ph-panel.gold {
  background: var(--ph-gold);
  color: var(--ph-navy-950);
  border-color: transparent;
}
.ph-panel .label {
  font-family: var(--ph-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ph-gold);
  font-weight: 900;
}
.ph-panel h4 {
  font-family: var(--ph-serif);
  font-size: 23px;
  letter-spacing: -.03em;
  line-height: 1.08;
  margin: 8px 0;
}
.ph-panel p           { font-size: 14px; margin: 0 0 16px; color: var(--ph-muted); }
.ph-panel.dark p      { color: #C9D1D9; }
.ph-panel.gold p      { color: #1B1F2A; }
.ph-panel a           { display: block; text-decoration: none; line-height: 1.45; }
.ph-panel .toc-link   { padding: 8px 0; border-bottom: 1px solid var(--ph-line); }
.ph-panel .toc-link:last-child { border-bottom: 0; }
.ph-panel .ph-sidebar-tip-link {
  width: max-content;
  max-width: 100%;
  color: var(--ph-blue);
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-reader-intent {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* =====================================================================
 * NEWSLETTER SAFE-GRID (v5 exact — 760px + 300px)
 * ===================================================================*/

.ph-newsletter-safe {
  width: min(var(--wide-width), calc(100% - 40px));
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(0, 760px) 300px;
  gap: 32px;
  align-items: start;
  justify-content: center;
}

.ph-newsletter-main {
  min-width: 0;
  width: 100%;
  display: grid;
  gap: 20px;
}

.ph-newsletter-sidebar {
  min-width: 0;
  width: 100%;
  position: sticky;
  top: 88px;
  display: grid;
  gap: 16px;
  align-self: start;
}

/* Overflow safety */
.ph-newsletter-safe .ph-card,
.ph-newsletter-safe .ph-ad,
.ph-newsletter-safe .ph-issue-section,
.ph-newsletter-safe .ph-update,
.ph-newsletter-safe .ph-panel { min-width: 0; max-width: 100%; overflow-wrap: anywhere; }

/* =====================================================================
 * NEWSLETTER COMPONENTS
 * ===================================================================*/

.ph-brief-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 24px;
}
.ph-brief-card {
  padding: 22px;
  background: #fff;
  border: 1px solid var(--ph-line);
  border-radius: 16px;
}
.ph-brief-card h3 {
  font-family: var(--ph-serif);
  font-size: 26px;
  line-height: 1.05;
  margin: 8px 0;
  color: var(--ph-ink);
}

.ph-search-brief {
  padding: 30px;
  overflow-wrap: anywhere;
}
.ph-search-brief h2 {
  font-family: var(--ph-serif);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.05;
  letter-spacing: -.035em;
  margin: 0 0 12px;
  color: var(--ph-ink);
}
.ph-search-brief p {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  color: var(--ph-muted);
}
.ph-search-brief-facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 22px 0;
}
.ph-search-brief-facts div {
  padding: 14px;
  border: 1px solid var(--ph-line);
  border-radius: 12px;
  background: var(--ph-card-soft);
}
.ph-search-brief-facts span,
.ph-search-brief-list h3 {
  display: block;
  font-family: var(--ph-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ph-faint);
}
.ph-search-brief-facts b {
  display: block;
  margin-top: 6px;
  font-size: 14px;
  line-height: 1.25;
  color: var(--ph-ink);
}
.ph-search-brief-list {
  margin-top: 18px;
}
.ph-search-brief-list ul {
  margin: 10px 0 0;
  padding-left: 18px;
}
.ph-search-brief-list li {
  margin: 0 0 8px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ph-muted);
}
.ph-search-brief-list a {
  color: var(--ph-ink);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.ph-issue-body { display: grid; gap: 20px; min-width: 0; }

.ph-issue-section { padding: 34px; }
.ph-issue-section h2 {
  font-family: var(--ph-serif);
  font-size: 38px;
  line-height: 1.05;
  letter-spacing: -.035em;
  margin: 0 0 18px;
  color: var(--ph-ink);
}
.ph-issue-section h3 {
  font-family: var(--ph-serif);
  font-size: 28px;
  line-height: 1.08;
  letter-spacing: -.03em;
  margin: 0 0 12px;
  color: var(--ph-ink);
}
.ph-issue-section p,
.ph-issue-section li { font-size: 17px; color: var(--ph-muted); }
.ph-issue-section a { color: var(--ph-ink); }

.ph-newsletter-sections {
  display: grid;
  gap: 22px;
}

.ph-newsletter-block {
  position: relative;
  border-radius: 8px;
  border-left: 6px solid var(--ph-gold);
  box-shadow: 3px 3px 0 rgba(17, 24, 39, .08);
}

.ph-newsletter-block-welcome { border-left-color: var(--ph-gold); }
.ph-newsletter-block-quick-hits { border-left-color: var(--ph-blue); }
.ph-newsletter-block-top-updates { border-left-color: var(--ph-ink); }
.ph-newsletter-block-productivity { border-left-color: #4F8BFF; }
.ph-newsletter-block-pro-tip { border-left-color: #B58100; }
.ph-newsletter-block-health-tip { border-left-color: #1F9D67; }
.ph-newsletter-block-kids-tip { border-left-color: #8B5CF6; }
.ph-newsletter-block-outro { border-left-color: #64748B; }

.ph-section-label {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.ph-section-label span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--ph-ink);
  background: var(--ph-gold);
  box-shadow: 2px 2px 0 var(--ph-ink);
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  color: var(--ph-ink);
}

.ph-section-label b {
  font-family: var(--ph-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ph-faint);
}

.ph-section-copy > :first-child {
  margin-top: 0;
}

.ph-section-copy strong {
  color: var(--ph-ink);
}

.ph-quick-hit {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 16px;
  border-top: 1px solid var(--ph-line);
  padding: 16px 0;
}
.ph-quick-hit b { font-family: var(--ph-mono); color: var(--ph-gold); }

.ph-quick-hit h3 {
  margin-bottom: 6px;
}

.ph-read-more-link {
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}

.ph-top-update-item {
  padding-top: 18px;
  border-top: 1px solid var(--ph-line);
}

.ph-top-update-item:first-child {
  padding-top: 0;
  border-top: 0;
}

.ph-section-action-grid {
  display: grid;
  gap: 16px;
  margin-top: 22px;
}

.ph-section-action-card {
  padding: 22px;
  border: 1px solid var(--ph-line);
  background: #F9FAFB;
  display: grid;
  gap: 10px;
}

.ph-section-action-card > span {
  width: max-content;
  max-width: 100%;
  padding: 8px 10px;
  background: var(--ph-ink);
  color: var(--ph-gold);
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.ph-section-action-card h3,
.ph-section-action-card p {
  margin: 0;
}

.ph-context-link {
  margin: 10px 0 18px;
  padding: 6px 0 6px 12px;
  border-left: 2px solid var(--ph-gold);
  background: transparent;
  font-size: 14px;
  line-height: 1.45;
  color: var(--ph-ink);
}

.ph-context-link span {
  display: inline;
  margin-right: 8px;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ph-faint);
}

.ph-context-link a {
  color: var(--ph-ink);
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.ph-section-action-card .ph-context-link {
  width: max-content;
  max-width: 100%;
  margin: 4px 0 0;
  padding: 0;
  border-left: 0;
  color: var(--ph-blue);
  font-weight: 900;
  text-decoration: none;
}

.ph-section-action-card .ph-context-link span {
  color: var(--ph-blue);
}

.ph-context-link-standalone {
  margin-top: 18px;
}

.ph-executive-plan {
  color: var(--ph-ink);
}

.ph-executive-list {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.ph-panel .ph-executive-link {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(27, 31, 42, .28);
  border-radius: 8px;
  background: rgba(255, 255, 255, .52);
  color: inherit;
}

.ph-executive-link span {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 1px solid var(--ph-ink);
  background: #fff;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
}

.ph-executive-link b {
  display: block;
  margin-bottom: 3px;
  font-family: var(--ph-mono);
  font-size: 9px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(27, 31, 42, .68);
}

.ph-executive-link strong {
  display: block;
  font-family: var(--ph-serif);
  font-size: 15px;
  line-height: 1.18;
  color: var(--ph-ink);
}

.ph-update {
  border: 1px solid var(--ph-line);
  border-radius: 18px;
  background: #fff;
  padding: 28px;
  margin: 18px 0;
}

.ph-impact {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 18px 0;
}
.ph-impact div {
  background: var(--ph-card-soft);
  border: 1px solid var(--ph-line);
  border-radius: 12px;
  padding: 13px;
  font-size: 14px;
}

.ph-action-list {
  background: #FFF8DF;
  border: 1px solid #F0DC9F;
  border-radius: 14px;
  padding: 18px;
}

.ph-ad {
  background: linear-gradient(145deg, var(--ph-navy-950), var(--ph-navy-800));
  color: #fff;
  border-radius: 18px;
  padding: 28px;
}

.ph-module-blue   { background: #E8F2FF; border-color: #BBD7FF; }
.ph-module-yellow { background: #FFF7D6; border-color: #ECD78D; }
.ph-module-purple { background: #F2E8FF; border-color: #DAC2FF; }

.ph-stat-box {
  background: var(--ph-card-soft);
  border: 1px solid var(--ph-line);
  border-radius: 14px;
  padding: 18px;
}
.ph-split-two { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ph-small-list { padding-left: 20px; margin: 0; }
.ph-small-list li { margin: 0 0 8px; }

/* =====================================================================
 * SUBSCRIBE BAND (dark — v5 exact)
 * ===================================================================*/

.ph-subscribe-band {
  background:
    radial-gradient(circle at 82% 20%, rgba(54,162,235,.20), transparent 28rem),
    linear-gradient(135deg, var(--ph-navy-950), var(--ph-navy-800));
  color: #fff;
  padding: 64px 0;
  border-top: 1px solid var(--ph-line-dark);
  border-bottom: 1px solid var(--ph-line-dark);
}
.ph-subscribe-box {
  display: grid;
  grid-template-columns: 1.2fr .85fr;
  gap: 42px;
  align-items: center;
}
.ph-subscribe-band .ph-h2 { color: #fff; }
.ph-subscribe-band .ph-lede { color: #9DA8B8; }

.ph-subscribe-form {
  display: flex;
  gap: 10px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  padding: 8px;
}
.ph-subscribe-form input {
  flex: 1;
  min-width: 0;
  background: transparent;
  border: 0;
  color: #fff;
  padding: 0 14px;
  outline: none;
  font-family: var(--ph-sans);
}
.ph-subscribe-form input::placeholder { color: #9DA8B8; }

/* =====================================================================
 * FOOTER (dark — v5 exact 4-column grid)
 * ===================================================================*/

.ph-footer,
.site-footer {
  background: var(--ph-navy-950);
  color: #C9D1D9;
  padding: 54px 0 26px;
  border-top: 1px solid var(--ph-line-dark);
  margin-top: 0;
}

.ph-footer-grid {
  display: grid;
  grid-template-columns: 1.6fr repeat(3, 1fr);
  gap: 36px;
}

.ph-footer h4 {
  font-family: var(--ph-mono);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ph-gold);
  margin: 0 0 14px;
}
.ph-footer a {
  display: block;
  color: #C9D1D9;
  text-decoration: none;
  margin: 8px 0;
  font-size: 14px;
}
.ph-footer a:hover { color: #fff; }
.ph-footer p {
  margin: 12px 0 0;
  max-width: 390px;
  color: #9DA8B8;
  font-size: 14px;
}

.ph-footer-bar {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  border-top: 1px solid var(--ph-line-dark);
  margin-top: 34px;
  padding-top: 20px;
  font-family: var(--ph-mono);
  font-size: 11px;
  color: #7E8A9A;
}

/* Legacy footer aliases */
.ph-footer-inner    { max-width: 1360px; margin: 0 auto; padding: 0 20px; }
.ph-footer-nav      { display: flex; gap: 24px; flex-wrap: wrap; }
.ph-footer-nav a    { color: #9DA8B8; font-size: 13px; text-decoration: none; }
.ph-footer-nav a:hover { color: #fff; }
.ph-footer-legal    { max-width: 1360px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: 12px; color: #7E8A9A; padding: 0 20px; }
.ph-footer-legal p  { margin: 0; }
.ph-footer-legal-links a { color: #7E8A9A; text-decoration: none; margin-left: 18px; }
.ph-footer-legal-links a:hover { color: #9DA8B8; }

/* Hide stock EmDash chrome */
.theme-switcher  { display: none !important; }
.footer-bottom   { display: none !important; }

/* =====================================================================
 * SOURCE NOTE
 * ===================================================================*/

.ph-source-note {
  padding: 14px;
  border: 1px dashed var(--ph-line);
  border-radius: 12px;
  color: var(--ph-muted);
  font-size: 13px;
  background: #fffef9;
}

/* =====================================================================
 * PAGE LAYOUT
 * Pages own their own layout via .ph-wide / .ph-wrap.
 * Override any EmDash defaults that would constrain main.
 * ===================================================================*/

main {
  min-height: 0;
  max-width: none !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  box-sizing: border-box;
}

/* =====================================================================
 * ISSUE HERO (dark card, newsletter opener)
 * ===================================================================*/

.ph-issue-hero {
  background: linear-gradient(180deg, var(--ph-navy-800) 0%, var(--ph-navy-900) 100%);
  border: 1px solid var(--ph-line-dark);
  border-radius: var(--ph-radius);
  padding: 36px 36px 32px;
  margin-bottom: 8px;
  color: #fff;
}
.ph-issue-hero-kicker {
  display: inline-block;
  background: var(--ph-gold);
  color: var(--ph-navy-950);
  padding: 4px 12px;
  border-radius: 999px;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.ph-issue-hero-title {
  font-family: var(--ph-serif);
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.035em;
  color: #fff;
  margin: 0 0 12px;
}
.ph-issue-hero-dek {
  font-size: 17px;
  line-height: 1.55;
  color: #D4DBE5;
  margin: 0 0 16px;
}
.ph-issue-hero-meta {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-family: var(--ph-mono);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #9DA8B8;
}

/* =====================================================================
 * QUICK HITS MODULE
 * ===================================================================*/

.ph-quick-hits {
  background: var(--ph-card);
  border: 1px solid var(--ph-line);
  border-radius: var(--ph-radius-md);
  padding: 24px 28px 16px;
}
.ph-quick-hits-title {
  font-family: var(--ph-mono);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ph-gold);
  margin: 0 0 16px;
}
.ph-quick-hits-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: phqh;
}
.ph-quick-hits-list > li {
  counter-increment: phqh;
  padding: 14px 0 16px;
  border-top: 1px solid var(--ph-line);
  position: relative;
  padding-left: 36px;
}
.ph-quick-hits-list > li:first-child { border-top: none; }
.ph-quick-hits-list > li::before {
  content: counter(phqh, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 16px;
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  color: var(--ph-gold);
  letter-spacing: .04em;
}
.ph-quick-hit-title  { font-size: 16px; font-weight: 700; color: var(--ph-ink); margin: 0 0 4px; }
.ph-quick-hit-summary { font-size: 14.5px; line-height: 1.55; color: var(--ph-muted); margin: 0 0 6px; }
.ph-quick-hit-take   { font-size: 13px; line-height: 1.5; color: var(--ph-faint); font-style: italic; margin: 0; }

/* =====================================================================
 * TOP UPDATE MODULE
 * ===================================================================*/

.ph-top-update {
  background: var(--ph-card);
  border: 1px solid var(--ph-line);
  border-radius: var(--ph-radius-md);
  padding: 28px 32px;
}
.ph-top-update-kicker {
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ph-blue);
  margin-bottom: 8px;
}
.ph-top-update-title {
  font-family: var(--ph-serif);
  font-size: 24px;
  font-weight: 900;
  line-height: 1.2;
  color: var(--ph-ink);
  margin: 0 0 12px;
}
.ph-top-update-summary {
  font-size: 16px;
  line-height: 1.6;
  color: var(--ph-muted);
  margin: 0 0 20px;
}
.ph-top-update-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 24px;
  margin: 0 0 20px;
}
.ph-top-update-block-label {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ph-faint);
  margin-bottom: 6px;
  font-family: var(--ph-mono);
}
.ph-top-update-block ul {
  margin: 0;
  padding: 0 0 0 18px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--ph-muted);
}
.ph-top-update-action-list {
  background: rgba(40, 209, 124, .06);
  border: 1px solid var(--ph-green-dim);
  border-radius: var(--ph-radius-sm);
  padding: 16px 20px;
}
.ph-top-update-action-list .ph-top-update-block-label { color: var(--ph-green); }
.ph-top-update-action-list ol {
  margin: 0;
  padding: 0 0 0 18px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--ph-ink);
}
@media (max-width: 700px) {
  .ph-top-update-grid { grid-template-columns: 1fr; }
}

/* =====================================================================
 * PROMPT BLOCK
 * ===================================================================*/

.ph-prompt-block {
  background: var(--ph-card-soft);
  border: 1px solid var(--ph-line);
  border-radius: var(--ph-radius-md);
  padding: 18px 20px 20px;
  position: relative;
}
.ph-prompt-block-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.ph-prompt-block-title {
  font-family: var(--ph-mono);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ph-gold);
  margin: 0;
}
.ph-prompt-block-copy {
  background: transparent;
  border: 1px solid var(--ph-line);
  color: var(--ph-muted);
  padding: 4px 10px;
  border-radius: var(--ph-radius-sm);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  font-family: var(--ph-mono);
  transition: all 0.15s;
}
.ph-prompt-block-copy:hover { border-color: var(--ph-gold); color: var(--ph-gold); }
.ph-prompt-block-copy[data-copied="true"] { color: var(--ph-green); border-color: var(--ph-green-dim); }
.ph-prompt-block-body {
  font-family: var(--ph-mono);
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--ph-ink);
  margin: 0;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

/* =====================================================================
 * SIDEBAR CARD (legacy alias)
 * ===================================================================*/

.ph-sidebar-card {
  background: var(--ph-card);
  border: 1px solid var(--ph-line);
  border-radius: var(--ph-radius-md);
  padding: 18px 20px;
}
.ph-sidebar-card-label {
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ph-gold);
  font-family: var(--ph-mono);
  margin: 0 0 10px;
}
.ph-sidebar-card-title {
  font-family: var(--ph-serif);
  font-size: 16px;
  font-weight: 700;
  line-height: 1.25;
  color: var(--ph-ink);
  margin: 0 0 8px;
}
.ph-sidebar-card-body {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ph-muted);
  margin: 0;
}
.ph-sidebar-card-toc {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ph-sidebar-card-toc a { font-size: 13.5px; color: var(--ph-muted); text-decoration: none; }
.ph-sidebar-card-toc a:hover { color: var(--ph-gold); }

/* =====================================================================
 * SEARCH INPUT
 * ===================================================================*/

.site-search-input {
  background: var(--ph-card);
  border: 1px solid var(--ph-line);
  color: var(--ph-ink);
  border-radius: 999px;
  padding: 7px 14px;
  font-size: 13px;
  width: 180px;
  font-family: var(--ph-sans);
}
.site-search-input::placeholder { color: var(--ph-faint); }
.site-search-results {
  background: var(--ph-card);
  border: 1px solid var(--ph-line);
  color: var(--ph-ink);
  border-radius: 12px;
}

/* =====================================================================
 * LEGACY ARTICLE PAGE (fallback for non-v5 posts)
 * ===================================================================*/

.article-title,
h1.article-title {
  font-family: var(--ph-serif);
  font-size: clamp(32px, 4.5vw, 52px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.035em;
  color: var(--ph-ink);
  margin: 0 0 20px;
}
.article-excerpt {
  font-size: 19px;
  line-height: 1.55;
  color: var(--ph-muted);
  max-width: 68ch;
  margin: 0 0 8px;
}
.article-content,
article.article .article-content {
  max-width: 68ch;
  margin: 0 auto;
  color: var(--ph-muted);
  font-size: 1.0625rem;
  line-height: 1.75;
}
.article-content p           { margin: 0 0 1.25em; color: var(--ph-muted); }
.article-content h2          { font-family: var(--ph-serif); font-size: 1.75rem; font-weight: 700; line-height: 1.2; letter-spacing: -.02em; color: var(--ph-ink); margin: 2.5em 0 .6em; }
.article-content h3          { font-family: var(--ph-serif); font-size: 1.25rem; font-weight: 700; color: var(--ph-ink); margin: 2em 0 .5em; }
.article-content ul,
.article-content ol          { margin: 1em 0 1.25em 1.5em; padding: 0; line-height: 1.75; }
.article-content li          { margin-bottom: .45em; color: var(--ph-muted); }
.article-content li::marker  { color: var(--ph-gold); }
.article-content strong      { color: var(--ph-ink); font-weight: 700; }
.article-content em          { color: var(--ph-ink); font-style: italic; }
.article-content a           { color: var(--ph-gold); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.article-content a:hover     { color: var(--ph-ink); }
.article-content blockquote  { border-left: 3px solid var(--ph-gold); padding: 6px 0 6px 18px; margin: 1.5em 0; color: var(--ph-ink); font-style: italic; font-size: 1.05rem; }
.article-content pre,
.article-content code        { font-family: var(--ph-mono); }
.article-content pre         { background: var(--ph-navy-950); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; padding: 16px 18px; overflow-x: auto; margin: 1.25em 0; font-size: .95rem; color: #E0E1DD; }
.article-content code        { background: rgba(230,220,203,.5); border: 1px solid var(--ph-line); border-radius: 4px; padding: 1px 6px; font-size: .92em; color: var(--ph-ink); }
.article-content pre code    { background: transparent; border: none; padding: 0; color: #E0E1DD; }
.article-content img         { width: 100%; height: auto; border-radius: 10px; border: 1px solid var(--ph-line); margin: 1.5em 0; }

/* Hero image */
article .article-hero img,
article > div:first-child img {
  width: 100%;
  height: auto;
  border-radius: 14px;
  border: 1px solid var(--ph-line);
  display: block;
}

/* Featured section (legacy homepage) */
.featured-section { margin-bottom: 56px; }
.featured-title,
h1.featured-title  {
  font-family: var(--ph-serif);
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -.02em;
  color: var(--ph-ink);
  margin: 16px 0;
}
.featured-title-link          { text-decoration: none; color: inherit; }
.featured-title-link:hover .featured-title { color: var(--ph-gold); }
.featured-excerpt { font-size: 18px; line-height: 1.6; color: var(--ph-muted); max-width: 720px; }

/* Post grid (legacy) */
.posts-section   { margin-top: 48px; }
.section-title,
h2.section-title {
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ph-gold);
  margin-bottom: 24px;
}
.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 32px;
}
.post-card {
  background: var(--ph-card);
  border: 1px solid var(--ph-line);
  border-radius: var(--ph-radius);
  overflow: hidden;
  transition: transform .2s ease, border-color .2s ease;
}
.post-card:hover { transform: translateY(-2px); border-color: rgba(255,195,0,.35); }
.card-image          { aspect-ratio: 16/10; overflow: hidden; background: var(--ph-card-soft); border-radius: 0; margin: 0; }
.card-image img      { width: 100%; height: 100%; object-fit: cover; }
.card-body           { padding: 20px 22px 24px; }
.card-meta           { font-family: var(--ph-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--ph-faint); margin-bottom: 10px; }
.card-title,
h2.card-title        { font-family: var(--ph-serif); font-size: 19px; font-weight: 700; line-height: 1.3; color: var(--ph-ink); margin-bottom: 10px; }
.card-link:hover .card-title { color: var(--ph-gold); }
.card-excerpt        { font-size: 14.5px; line-height: 1.55; color: var(--ph-muted); }

/* =====================================================================
 * RESPONSIVE BREAKPOINTS (v5 exact)
 * ===================================================================*/

@media (max-width: 1180px) {
  .ph-home-feature          { grid-template-columns: 1fr; }
  .ph-feature-card          { grid-template-columns: 1fr; }
  .ph-feature-card figure   { min-height: 300px; }
  .ph-newsletter-safe       { grid-template-columns: 1fr; width: min(860px, calc(100% - 40px)); }
  .ph-newsletter-sidebar    { position: static; grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
  .ph-content-layout        { grid-template-columns: 1fr; }
  .ph-toc, .ph-rail         { position: static; }
  .ph-toc                   { display: none; }
  .ph-outcome-grid          { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 980px) {
  .ph-hero-grid             { grid-template-columns: 1fr; }
  .ph-card-grid             { grid-template-columns: repeat(2, 1fr); }
  .ph-impact                { grid-template-columns: 1fr; }
  .ph-reader-intent         { grid-template-columns: 1fr; }
  .ph-mini-card             { grid-template-columns: 112px 1fr; }
  .ph-mini-card img         { width: 112px; }
  .ph-split-two             { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
  .ph-card-grid,
  .ph-newsletter-sidebar,
  .ph-subscribe-box,
  .ph-footer-grid,
  .ph-outcome-grid          { grid-template-columns: 1fr; }
  .ph-search-page-form      { grid-template-columns: 1fr; }
  .ph-subscribe-form        { border-radius: 18px; flex-direction: column; }
  .ph-nav-actions .ph-btn   { display: none; }
  .ph-brand-text            { font-size: 11px; }
  .ph-hero                  { padding: 42px 0; }
  .ph-prose                 { padding: 28px; }
  .ph-prose p,
  .ph-prose li              { font-size: 17px; }
  .ph-footer-brand          { grid-column: 1 / -1; }
  .ph-mini-card             { grid-template-columns: 96px 1fr; }
  .ph-mini-card img         { width: 96px; }
  .ph-section-head          { display: block; }
  .ph-section-head .ph-btn  { margin-top: 16px; }
  .ph-issue-section         { padding: 24px; }
  .ph-search-brief          { padding: 24px; }
  .ph-search-brief-facts    { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ph-subscriber-gate       { grid-template-columns: 1fr; padding: 22px; }
  .ph-update                { padding: 22px; }
  .ph-brief-grid            { grid-template-columns: 1fr; }
  .posts-grid               { grid-template-columns: 1fr; }
}

/* =====================================================================
 * LIGHT DOSSIER REFERENCE STYLE
 * ===================================================================*/

:root {
  --ph-navy-950: #0D1B2A;
  --ph-navy-900: #0D1B2A;
  --ph-navy-850: #13243A;
  --ph-navy-800: #0D1B2A;
  --ph-gold: #FFC300;
  --ph-gold-2: #FFD43B;
  --ph-blue: #336AEB;
  --ph-paper: #FFFFFF;
  --ph-card: #FFFFFF;
  --ph-card-soft: #F4F4F5;
  --ph-ink: #0D1B2A;
  --ph-muted: #6B7280;
  --ph-faint: #9CA3AF;
  --ph-line: #E0E1DD;
  --ph-line-dark: rgba(255,255,255,.12);
  --ph-radius: 0;
  --ph-radius-sm: 0;
  --ph-radius-md: 0;
  --ph-radius-lg: 0;
  --ph-serif: "Merriweather", Georgia, serif;
  --ph-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --ph-shadow: 4px 4px 0 #FFC300;
}

html,
body {
  background: #fff;
  color: var(--ph-ink);
}

.ph-wrap,
.ph-wide {
  width: min(1152px, calc(100% - 48px));
}

.ph-h1,
.ph-h2,
.ph-h3,
.ph-prose h2,
.ph-prose h3,
.ph-issue-section h2,
.ph-issue-section h3,
.ph-article-card h3,
.ph-feature-copy h3,
.ph-panel h4 {
  letter-spacing: 0;
}

.ph-h1 {
  font-size: clamp(36px, 5.2vw, 56px);
  line-height: 1.1;
  font-weight: 700;
}

.ph-h2 {
  font-size: clamp(28px, 3.6vw, 44px);
  line-height: 1.15;
}

.ph-h3 {
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.2;
}

.ph-lede {
  max-width: 600px;
  font-size: clamp(17px, 1.6vw, 20px);
  line-height: 1.7;
  font-weight: 300;
  color: var(--ph-muted);
}

.ph-card,
.ph-brief-card,
.ph-panel,
.ph-update,
.ph-action-list,
.ph-search-brief-facts div,
.ph-stat-box,
.ph-sidebar-card,
.ph-quick-hits,
.ph-top-update,
.ph-prompt-block,
.post-card {
  border: 1px solid var(--ph-line);
  border-radius: 0;
  box-shadow: none;
}

.ph-btn,
.ph-btn-cta,
.ph-subscribe-form button {
  border-radius: 0;
  border: 2px solid var(--ph-ink);
  box-shadow: 4px 4px 0 var(--ph-ink);
  transition: transform .1s ease, box-shadow .1s ease, background .15s ease;
}

.ph-btn:hover,
.ph-btn-cta:hover,
.ph-subscribe-form button:hover {
  opacity: 1;
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--ph-ink);
}

.ph-btn:active,
.ph-btn-cta:active,
.ph-subscribe-form button:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--ph-ink);
}

.ph-btn-gold,
.ph-btn-cta {
  background: var(--ph-gold);
  color: var(--ph-ink);
}

.ph-btn-paper,
.ph-btn-ghost {
  background: #fff;
  color: var(--ph-ink);
  border-color: var(--ph-ink);
}

.ph-tag {
  border-radius: 0;
  border: 1px solid var(--ph-line);
  background: #F9FAFB;
  color: var(--ph-muted);
}

.ph-tag-gold {
  background: var(--ph-gold);
  color: var(--ph-ink);
  border-color: var(--ph-ink);
}

.ph-tag-blue {
  background: #EFF6FF;
  color: var(--ph-blue);
  border-color: #BFDBFE;
}

.ph-tag-green {
  background: #ECFDF5;
  color: #059669;
  border-color: #A7F3D0;
}

.ph-tag-purple {
  background: #F5F3FF;
  color: #6D28D9;
  border-color: #DDD6FE;
}

.ph-nav,
.site-header,
.ph-header {
  background: #fff;
  border-bottom: 1px solid var(--ph-line);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.ph-nav-inner,
.ph-header-inner {
  min-height: 80px;
}

.ph-brand,
.ph-logo-group {
  color: var(--ph-ink);
}

.ph-mark,
.ph-logo-box {
  width: 24px;
  height: 24px;
  border: 2px solid var(--ph-ink);
  border-radius: 0;
  background: var(--ph-gold);
  color: transparent;
  font-size: 0;
  box-shadow: none;
}

.ph-brand-text,
.ph-logo-text {
  font-family: var(--ph-sans);
  font-size: 18px;
  letter-spacing: 0;
  color: var(--ph-ink);
}

.ph-brand-text .ai {
  color: inherit;
}

.ph-nav-links a,
.ph-nav-link {
  font-family: var(--ph-sans);
  font-size: 14px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ph-muted);
  font-weight: 500;
}

.ph-nav-links a:hover,
.ph-nav-links a.current,
.ph-nav-link:hover,
.ph-nav-link[aria-current="page"] {
  color: var(--ph-ink);
}

.ph-search-link,
.ph-header-ctas .ph-btn-ghost {
  border: 2px solid var(--ph-ink);
  border-radius: 0;
  color: var(--ph-ink);
  background: transparent;
  padding: 8px 16px;
  font-family: var(--ph-sans);
  font-size: 14px;
  letter-spacing: 0;
  text-transform: none;
  font-weight: 600;
}

.ph-kbd {
  border: 1px solid var(--ph-line);
  border-radius: 0;
  color: var(--ph-blue);
}

.site-search-input {
  border-radius: 0;
  border-color: var(--ph-line);
  background: #F9FAFB;
}

.ph-search-page-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  width: min(680px, 100%);
  margin-top: 28px;
  padding: 10px;
  background: rgba(255, 255, 255, .10);
  border: 1px solid rgba(255, 255, 255, .32);
  box-shadow: 6px 6px 0 rgba(255, 195, 0, .22);
}

.ph-search-page-input.site-search-input {
  width: 100%;
  height: 52px;
  padding: 0 18px;
  background: #fff;
  border: 2px solid rgba(255, 255, 255, .55);
  color: var(--ph-ink);
  font-size: 16px;
  box-shadow: inset 0 0 0 1px rgba(13, 27, 42, .10);
}

.ph-search-page-input.site-search-input::placeholder {
  color: #6B7280;
}

.ph-search-page-input.site-search-input:focus {
  border-color: var(--ph-gold);
  box-shadow: 0 0 0 4px rgba(255, 195, 0, .22);
}

.ph-mobile-menu-btn span {
  background: var(--ph-ink);
  border-radius: 0;
}

.ph-mobile-nav {
  background: #fff;
  border-top: 1px solid var(--ph-line);
}

.ph-mobile-nav .ph-btn {
  align-self: flex-start;
}

.ph-hero {
  padding: clamp(56px, 8vw, 96px) 0;
}

.ph-hero-dark {
  background: #fff;
  color: var(--ph-ink);
}

.ph-hero-dark::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(13,27,42,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,27,42,.05) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: .7;
  pointer-events: none;
}

.ph-hero > * {
  position: relative;
}

.ph-hero-dark .ph-h1,
.ph-hero-dark .ph-h2,
.ph-hero-dark .ph-h3 {
  color: var(--ph-ink);
}

.ph-hero-dark .ph-lede {
  color: var(--ph-muted);
}

.ph-hero-grid {
  grid-template-columns: minmax(0, 7fr) minmax(320px, 5fr);
  gap: clamp(42px, 5.4vw, 64px);
}

.ph-hero-dark .ph-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 6px 16px;
  margin-bottom: 28px;
  border: 1px solid var(--ph-line);
  background: #F9FAFB;
  color: var(--ph-muted);
  letter-spacing: .05em;
}

.ph-hero-dark .ph-eyebrow::before {
  content: "";
  width: 8px;
  height: 8px;
  background: var(--ph-blue);
}

.ph-kicker {
  color: var(--ph-faint);
  letter-spacing: .05em;
}

.ph-meta-row {
  color: var(--ph-faint);
}

.ph-meta-row b {
  color: var(--ph-blue);
}

.ph-hero-media,
.ph-featured-media {
  border: 1px solid var(--ph-line);
  border-radius: 0;
  background: #fff;
  box-shadow: 8px 8px 0 var(--ph-gold);
  transform: rotate(1.5deg);
}

.ph-hero-media img,
.ph-featured-media img {
  object-fit: cover;
}

.ph-hero-media::after,
.ph-featured-media::after {
  border-radius: 0;
  box-shadow: inset 0 0 0 1px rgba(13,27,42,.05);
}

.ph-img-badge {
  border-radius: 0;
  border: 2px solid var(--ph-ink);
  background: var(--ph-gold);
  color: var(--ph-ink);
}

.ph-hero-sample {
  color: var(--ph-ink);
  border: 1px solid var(--ph-line);
  border-radius: 0;
  background: #fff;
  box-shadow: 4px 4px 0 var(--ph-gold);
}

.ph-hero-sample:hover {
  border-color: var(--ph-ink);
  background: #fff;
}

.ph-hero-sample span {
  color: var(--ph-blue);
  letter-spacing: .05em;
}

.ph-hero-sample strong {
  color: var(--ph-ink);
}

.ph-hero-sample p {
  color: var(--ph-muted);
}

.ph-stats span {
  color: var(--ph-faint);
  letter-spacing: .05em;
}

.ph-stats b {
  color: var(--ph-blue);
}

.ph-move {
  border: 1px solid var(--ph-line);
  border-radius: 0;
  background: #F9FAFB;
}

.ph-move p {
  color: var(--ph-muted);
}

.ph-section {
  padding: clamp(48px, 7vw, 88px) 0;
}

.ph-section:nth-of-type(even) {
  background: #F4F4F5;
  border-top: 1px solid var(--ph-line);
  border-bottom: 1px solid var(--ph-line);
}

.ph-article-card,
.ph-feature-card,
.ph-mini-card,
.ph-outcome {
  border-radius: 0;
}

.ph-article-card {
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}

.ph-article-card:hover,
.ph-feature-card:hover,
.ph-mini-card:hover,
.ph-outcome:hover {
  border-color: var(--ph-ink);
  box-shadow: 4px 4px 0 var(--ph-gold);
  transform: none;
}

.ph-article-card figure,
.ph-mini-card img,
.ph-feature-card figure {
  background: #F4F4F5;
}

.ph-article-card figure img,
.ph-article-card:hover figure img {
  transform: none;
}

.ph-mini-card img {
  border-radius: 0;
}

.ph-feature-card figure {
  background: #F4F4F5;
  padding: 18px;
}

.ph-feature-card img {
  object-fit: cover;
}

.ph-feature-copy {
  background: #fff;
}

.ph-article-card h3 {
  font-size: 21px;
  line-height: 1.24;
}

.ph-article-card p,
.ph-mini-card p,
.ph-outcome p {
  color: var(--ph-muted);
}

.ph-content-layout {
  grid-template-columns: minmax(0, 900px) 300px;
  gap: 36px;
  justify-content: center;
}

.ph-prose,
.ph-issue-section {
  padding: 42px;
}

.ph-prose p,
.ph-prose li,
.ph-issue-section p,
.ph-issue-section li {
  color: var(--ph-muted);
}

.ph-prose blockquote,
.article-content blockquote {
  border-left: 4px solid var(--ph-gold);
  background: #FFF8DF;
  padding: 16px 18px;
}

.ph-author-note {
  margin: 34px 0 0;
  display: grid;
  gap: 18px;
}

.ph-bottom-line,
.ph-author-card {
  background: #F8FAFC;
  border: 1px solid #D8DEE8;
}

.ph-bottom-line {
  padding: 22px 24px;
  border-left: 5px solid var(--ph-gold);
}

.ph-bottom-line p {
  margin: 0;
  color: #334155;
  font-size: 16px;
  line-height: 1.7;
}

.ph-bottom-line .ph-author-kicker {
  margin: 0 0 8px;
  color: #B58100;
}

.ph-author-card {
  display: grid;
  grid-template-columns: 70px minmax(0, 1fr);
  gap: 20px;
  padding: 24px;
  box-shadow: 8px 8px 0 rgba(255, 195, 0, .9);
}

.ph-author-mark {
  display: inline-grid;
  place-items: center;
  width: 58px;
  height: 58px;
  background: var(--ph-ink);
  color: var(--ph-gold);
  font-family: var(--ph-mono);
  font-size: 16px;
  font-weight: 900;
  letter-spacing: .08em;
}

.ph-author-kicker {
  margin: 0 0 8px;
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-author-name-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.ph-author-name-row .ph-author-name {
  display: inline-block;
  color: var(--ph-ink);
  font-family: var(--ph-serif);
  font-size: 27px;
  line-height: 1.1;
}

.ph-author-name-row span {
  color: #64748B;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ph-author-copy p {
  margin: 0 0 12px;
  color: #475569;
  font-size: 15px;
  line-height: 1.65;
}

.ph-author-copy .ph-author-contact {
  color: var(--ph-ink);
}

.ph-author-copy a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 16px;
  background: var(--ph-ink);
  color: #fff;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-decoration: none;
  text-transform: uppercase;
}

.ph-author-copy a:hover {
  background: #1B2B44;
}

.ph-author-note-newsletter {
  margin-top: 28px;
}

.ph-search-brief {
  border-color: var(--ph-ink);
  box-shadow: 4px 4px 0 var(--ph-gold);
}

.ph-search-brief .ph-eyebrow {
  color: var(--ph-blue);
  letter-spacing: .05em;
}

.ph-search-brief-facts div,
.ph-impact div {
  background: #F9FAFB;
}

.ph-update:hover,
.ph-panel:hover {
  border-color: var(--ph-ink);
}

.ph-panel.dark,
.ph-ad,
.ph-issue-hero {
  background:
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px),
    var(--ph-ink);
  background-size: 40px 40px;
  color: #fff;
  border-color: var(--ph-ink);
}

.ph-panel.dark h4,
.ph-panel.dark .label,
.ph-ad h3,
.ph-issue-hero-title {
  color: #fff;
}

.ph-panel.dark .label {
  color: var(--ph-gold);
}

.ph-action-list {
  background: #FFF8DF;
  border-color: #F0DC9F;
}

.ph-subscribe-band {
  background:
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px),
    var(--ph-ink);
  background-size: 40px 40px;
  border-top: 1px solid var(--ph-ink);
  border-bottom: 1px solid var(--ph-ink);
}

.ph-subscribe-band .ph-eyebrow {
  color: var(--ph-gold);
  letter-spacing: .05em;
}

.ph-subscribe-form {
  border-radius: 0;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.08);
}

.ph-subscribe-form input {
  color: #fff;
}

.ph-footer,
.site-footer {
  background: var(--ph-ink);
  border-top: 1px solid var(--ph-ink);
}

.ph-footer .ph-brand {
  color: #fff;
}

.ph-footer .ph-brand-text {
  color: #fff;
}

.ph-footer .ph-mark {
  color: transparent;
}

.ph-footer h4 {
  color: var(--ph-gold);
  letter-spacing: .08em;
}

.ph-footer a:hover {
  color: var(--ph-gold);
}

pre,
.article-content pre {
  border-radius: 0;
}

@media (max-width: 980px) {
  .ph-hero-grid {
    grid-template-columns: 1fr;
  }

  .ph-hero-media,
  .ph-featured-media {
    transform: none;
  }

  .ph-page-hero-grid,
  .ph-about-grid,
  .ph-faq-grid {
    grid-template-columns: 1fr;
  }

  .ph-pricing-grid {
    grid-template-columns: 1fr;
  }

  .ph-principle-grid,
  .ph-home-promise-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .ph-wrap,
  .ph-wide {
    width: min(100% - 32px, 1152px);
  }

  .ph-content-layout,
  .ph-newsletter-safe {
    width: calc(100% - 32px);
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
    overflow: hidden;
  }

  .ph-article-main,
  .ph-newsletter-main,
  .ph-rail,
  .ph-newsletter-sidebar {
    width: 100%;
    min-width: 0;
    max-width: 100%;
  }

  .ph-rail,
  .ph-newsletter-sidebar {
    position: static;
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .ph-panel,
  .ph-card,
  .ph-prose,
  .ph-issue-section,
  .ph-search-brief,
  .ph-section-action-card {
    max-width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
  }

  .ph-nav-inner,
  .ph-header-inner {
    min-height: 64px;
  }

  .ph-brand-text,
  .ph-logo-text {
    font-size: 15px;
  }

  .ph-prose,
  .ph-issue-section,
  .ph-search-brief {
    padding: 22px;
  }

  .ph-issue-section h2 {
    font-size: clamp(28px, 9vw, 36px);
    line-height: 1.08;
  }

  .ph-issue-section h3,
  .ph-section-action-card h3 {
    font-size: clamp(22px, 7vw, 30px);
    line-height: 1.12;
  }

  .ph-issue-section p,
  .ph-issue-section li,
  .ph-prose p,
  .ph-prose li {
    font-size: 16px;
    line-height: 1.62;
  }

  .ph-quick-hit {
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 12px;
  }

  .ph-context-link,
  .ph-section-action-card .ph-context-link {
    width: 100%;
    white-space: normal;
  }

  .ph-page-hero-light {
    padding: 48px 0;
  }

  .ph-home-promise-grid,
  .ph-principle-grid {
    grid-template-columns: 1fr;
  }

  .ph-dossier-card,
  .ph-price-card,
  .ph-timeline,
  .ph-principle {
    padding: 22px;
  }

  .ph-price-line strong {
    font-size: 38px;
  }
}

/* =====================================================================
 * HOMEPAGE DOSSIER STRUCTURE
 * ===================================================================*/

.ph-home-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #fff;
  border-bottom: 1px solid #E0E1DD;
}

.ph-home-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 80px;
  max-width: 1152px;
  margin: 0 auto;
  padding: 0 16px;
}

.ph-home-logo,
.ph-home-footer-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: #0D1B2A;
}

.ph-home-logo-box,
.ph-home-footer-logo-box {
  width: 24px;
  height: 24px;
  background: #FFC300;
  border: 2px solid #0D1B2A;
}

.ph-home-logo-text,
.ph-home-footer-logo-text {
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -.025em;
}

.ph-home-nav {
  display: flex;
  gap: 32px;
  font-size: 14px;
  font-weight: 600;
  color: #6B7280;
}

.ph-home-nav a,
.ph-home-footer-nav a,
.ph-home-mobile-nav a {
  text-decoration: none;
  color: inherit;
}

.ph-home-nav a:hover,
.ph-home-footer-nav a:hover {
  color: #0D1B2A;
}

.ph-home-header-ctas {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ph-home-btn-outline,
.ph-home-btn-primary,
.ph-home-email-btn,
.ph-home-inline-btn,
.ph-home-tier-cta {
  font-family: var(--ph-mono);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 900;
  text-decoration: none;
  border-radius: 0;
}

.ph-home-btn-outline {
  padding: 8px 16px;
  font-size: 14px;
  color: #0D1B2A;
  border: 2px solid #0D1B2A;
  background: transparent;
}

.ph-home-btn-primary {
  padding: 10px 24px;
  font-size: 14px;
  color: #0D1B2A;
  background: #FFC300;
  border: 2px solid #0D1B2A;
}

.ph-home-tactile {
  box-shadow: 4px 4px 0 #0D1B2A;
  transition: transform .1s ease, box-shadow .1s ease;
}

.ph-home-tactile:hover {
  box-shadow: 6px 6px 0 #0D1B2A;
  transform: translate(-2px, -2px);
}

.ph-home-tactile:active {
  box-shadow: 2px 2px 0 #0D1B2A;
  transform: translate(2px, 2px);
}

.ph-home-mobile-menu-btn {
  display: none;
  position: relative;
  width: 40px;
  height: 40px;
  background: none;
  border: 0;
  cursor: pointer;
  padding: 8px;
}

.ph-home-mobile-menu-btn span {
  display: block;
  position: absolute;
  left: 9px;
  top: 19px;
  width: 22px;
  height: 2px;
  background: #0D1B2A;
  transition: all .2s ease;
  transform-origin: center;
}

.ph-home-mobile-menu-btn span:nth-child(1) { transform: translateY(-7px); }
.ph-home-mobile-menu-btn span:nth-child(3) { transform: translateY(7px); }
.ph-home-mobile-menu-btn.active span:nth-child(1) { transform: rotate(45deg); }
.ph-home-mobile-menu-btn.active span:nth-child(2) { opacity: 0; }
.ph-home-mobile-menu-btn.active span:nth-child(3) { transform: rotate(-45deg); }

.ph-home-mobile-nav {
  display: none;
  flex-direction: column;
  background: #fff;
  border-top: 1px solid #E0E1DD;
}

.ph-home-mobile-nav.open { display: flex; }

.ph-home-mobile-nav a {
  padding: 16px 24px;
  font-size: 15px;
  font-weight: 600;
  color: #374151;
  border-bottom: 1px solid #F3F4F6;
}

.ph-home-mobile-nav-cta {
  background: #FFC300;
  color: #0D1B2A;
  font-weight: 900;
  text-align: center;
}

.ph-home-grid-bg,
.ph-home-grid-bg-white {
  background-size: 40px 40px;
}

.ph-home-grid-bg {
  background-image:
    linear-gradient(rgba(13, 27, 42, .05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13, 27, 42, .05) 1px, transparent 1px);
}

.ph-home-grid-bg-white {
  background-image:
    linear-gradient(rgba(255, 255, 255, .10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .10) 1px, transparent 1px);
}

.ph-home-container {
  max-width: 1152px;
  margin: 0 auto;
  padding: 0 16px;
}

.ph-home-hero {
  position: relative;
  background: #fff;
  overflow: hidden;
}

.ph-home-hero-bg {
  position: absolute;
  inset: 0;
  opacity: .5;
}

.ph-home-hero-inner {
  position: relative;
  max-width: 1152px;
  margin: 0 auto;
  padding: 96px 24px;
}

.ph-home-hero-grid {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: 64px;
  align-items: center;
}

.ph-home-badge {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 6px 16px;
  margin-bottom: 32px;
  border: 1px solid #E0E1DD;
  background: #F9FAFB;
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #6B7280;
}

.ph-home-badge-dot {
  width: 8px;
  height: 8px;
  background: #336AEB;
}

.ph-home-hero h1 {
  font-family: var(--ph-serif);
  font-size: clamp(42px, 5.6vw, 64px);
  font-weight: 700;
  line-height: 1.1;
  margin: 0 0 32px;
  letter-spacing: -.025em;
  color: #0D1B2A;
}

.ph-home-hero h1 .noise {
  font-style: italic;
  color: #9CA3AF;
  font-weight: 300;
}

.ph-home-underline {
  text-decoration: underline;
  text-decoration-color: #FFC300;
  text-decoration-thickness: 4px;
  text-underline-offset: 8px;
}

.ph-home-hero-subhead {
  max-width: 512px;
  margin: 0 0 24px;
  color: #6B7280;
  font-size: 20px;
  line-height: 1.7;
  font-weight: 300;
}

.ph-home-edge-list {
  display: grid;
  gap: 10px;
  max-width: 540px;
  margin: 0 0 32px;
  padding: 0;
  list-style: none;
}

.ph-home-edge-list li {
  position: relative;
  padding-left: 26px;
  color: #334155;
  font-size: 15px;
  line-height: 1.45;
}

.ph-home-edge-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 10px;
  height: 10px;
  background: #FFC300;
  border: 2px solid #0D1B2A;
  box-shadow: 2px 2px 0 #0D1B2A;
}

.ph-home-email-form,
.ph-home-inline-form {
  display: flex;
  gap: 12px;
}

.ph-home-email-form {
  max-width: 640px;
}

.ph-home-inline-form {
  max-width: 448px;
}

.ph-home-email-input,
.ph-home-inline-input {
  flex: 1;
  min-width: 0;
  background: #F9FAFB;
  border: 1px solid #D1D5DB;
  outline: none;
  color: #0D1B2A;
}

.ph-home-email-input {
  min-width: 260px;
  padding: 16px 20px;
  font-size: 16px;
}

.ph-home-inline-input {
  padding: 12px 16px;
  font-size: 14px;
}

.ph-home-email-input:focus,
.ph-home-inline-input:focus {
  border-color: #336AEB;
}

.ph-home-email-btn {
  padding: 16px 32px;
  background: #FFC300;
  color: #0D1B2A;
  font-size: 14px;
  border: 2px solid #0D1B2A;
  white-space: nowrap;
}

.ph-home-inline-btn {
  padding: 12px 24px;
  background: #FFC300;
  color: #0D1B2A;
  font-size: 12px;
  border: 2px solid #0D1B2A;
  white-space: nowrap;
}

.ph-home-microcopy,
.ph-home-form-microcopy {
  margin: 16px 0 0;
  font-family: var(--ph-mono);
  font-size: 12px;
  color: #9CA3AF;
}

.ph-home-form-microcopy {
  margin-top: 12px;
  text-align: center;
}

.ph-home-inside-strip {
  max-width: 560px;
  margin-top: 28px;
  border: 1px solid #E0E1DD;
  background: rgba(255,255,255,.82);
  box-shadow: 8px 8px 0 rgba(13, 27, 42, .08);
}

.ph-home-inside-strip > p {
  margin: 0;
  padding: 10px 14px;
  border-bottom: 1px solid #E0E1DD;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #0D1B2A;
}

.ph-home-inside-strip > div {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.ph-home-inside-strip a {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  padding: 14px;
  color: inherit;
  text-decoration: none;
  border-right: 1px solid #E0E1DD;
}

.ph-home-inside-strip a:last-child {
  border-right: 0;
}

.ph-home-inside-strip a:hover {
  background: #FFF8D7;
}

.ph-home-inside-strip span {
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  color: #336AEB;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.ph-home-inside-strip strong {
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 15px;
  line-height: 1.25;
  letter-spacing: 0;
}

.ph-home-dossier-wrapper {
  position: relative;
  display: block;
  text-decoration: none;
  color: inherit;
}

.ph-home-dossier-card {
  position: relative;
  z-index: 1;
  border: 1px solid #E5E7EB;
  background: #fff;
  padding: 32px;
  box-shadow: 0 25px 50px -12px rgba(0,0,0,.25);
  transform: rotate(2deg);
  transition: transform .5s ease;
}

.ph-home-dossier-wrapper:hover .ph-home-dossier-card {
  transform: rotate(0deg);
}

.ph-home-dossier-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 16px;
  margin-bottom: 24px;
  border-bottom: 1px solid #F3F4F6;
  gap: 16px;
}

.ph-home-dossier-header span {
  font-family: var(--ph-mono);
  font-size: 12px;
  color: #9CA3AF;
  text-transform: uppercase;
}

.ph-home-dossier-header span:last-child {
  color: #336AEB;
  font-weight: 900;
}

.ph-home-dossier-card h2 {
  margin: 0 0 16px;
  font-family: var(--ph-serif);
  font-size: clamp(24px, 2.5vw, 32px);
  line-height: 1.3;
  color: #0D1B2A;
  letter-spacing: -.025em;
}

.ph-home-dossier-card p {
  margin: 0 0 20px;
  color: #6B7280;
  font-size: 14px;
  line-height: 1.55;
  font-weight: 300;
  font-style: italic;
}

.ph-home-dossier-lines {
  margin-bottom: 24px;
}

.ph-home-dossier-lines div {
  height: 12px;
  background: #0D1B2A;
  opacity: .2;
  margin-bottom: 12px;
}

.ph-home-dossier-lines div:nth-child(3) { width: 83%; }
.ph-home-dossier-lines div:nth-child(4) { width: 66%; }

.ph-home-dossier-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.ph-home-dossier-tags span {
  padding: 4px 12px;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  background: #F9FAFB;
  color: #6B7280;
}

.ph-home-dossier-tags .primary {
  background: #EFF6FF;
  color: #336AEB;
}

.ph-home-dossier-shadow {
  position: absolute;
  z-index: 0;
  top: 24px;
  right: -24px;
  width: 100%;
  height: 100%;
  border: 1px solid #0D1B2A;
  background: #FFC300;
}

.ph-home-roundup-section {
  background: #F4F4F5;
  padding: 96px 0;
  border-top: 1px solid #E0E1DD;
  border-bottom: 1px solid #E0E1DD;
}

.ph-home-section-copy {
  max-width: 768px;
}

.ph-home-section-copy h2,
.ph-home-newsletters-section h2,
.ph-home-free-section h2,
.ph-home-trust-section h2 {
  margin: 0 0 16px;
  font-family: var(--ph-serif);
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.2;
  color: #0D1B2A;
  letter-spacing: -.025em;
}

.ph-home-section-copy p,
.ph-home-subhead {
  margin: 0 0 48px;
  color: #6B7280;
  font-size: 18px;
  line-height: 1.65;
  font-weight: 300;
}

.ph-home-features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.ph-home-feature-card {
  display: flex;
  flex-direction: column;
  min-height: 280px;
  background: #fff;
  padding: 24px;
  border: 1px solid #E0E1DD;
  color: inherit;
  text-decoration: none;
  transition: border-color .2s ease;
}

.ph-home-feature-card:hover {
  border-color: #0D1B2A;
}

.ph-home-feature-label {
  display: inline-flex;
  align-self: flex-start;
  margin-bottom: 20px;
  padding: 5px 8px;
  background: #0D1B2A;
  color: #FFC300;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-home-feature-card h3 {
  margin: 0 0 12px;
  font-family: var(--ph-serif);
  color: #0D1B2A;
  font-size: 22px;
  line-height: 1.18;
  letter-spacing: 0;
}

.ph-home-feature-card p {
  margin: 0 0 22px;
  color: #6B7280;
  font-size: 14px;
  line-height: 1.6;
}

.ph-home-feature-link {
  margin-top: auto;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  color: #336AEB;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-home-feature-card:hover .ph-home-feature-link {
  color: #0D1B2A;
}

.ph-home-section-cta {
  margin-top: 48px;
  text-align: center;
}

.ph-home-section-cta .ph-home-inline-form,
.ph-home-trust-section .ph-home-inline-form {
  margin: 0 auto;
}

.ph-home-newsletters-section {
  background: #fff;
  padding: 96px 0;
}

.ph-home-editorial-byline {
  margin: -24px 0 40px;
  padding: 12px 16px;
  border-left: 3px solid #FFC300;
  background: #FAFAFA;
  color: #6B7280;
  font-size: 13px;
  line-height: 1.6;
}

.ph-home-editorial-byline strong {
  color: #0D1B2A;
  font-weight: 700;
}

.ph-home-editorial-byline a {
  color: #336AEB;
  text-decoration: none;
  font-weight: 700;
  margin-left: 8px;
}

.ph-home-newsletters-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.ph-home-newsletter-card {
  display: block;
  border: 2px solid #E0E1DD;
  padding: 24px;
  background: #fff;
  color: inherit;
  text-decoration: none;
  transition: border-color .2s ease;
}

.ph-home-newsletter-card:hover {
  border-color: #0D1B2A;
}

.ph-home-newsletter-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.ph-home-newsletter-meta span {
  font-family: var(--ph-mono);
  font-size: 12px;
  color: #9CA3AF;
  text-transform: uppercase;
}

.ph-home-newsletter-card h3 {
  margin: 0 0 12px;
  font-family: var(--ph-serif);
  font-size: 20px;
  line-height: 1.3;
  color: #0D1B2A;
  letter-spacing: -.025em;
  transition: color .2s ease;
}

.ph-home-newsletter-card:hover h3 {
  color: #336AEB;
}

.ph-home-newsletter-card p {
  margin: 0 0 16px;
  color: #6B7280;
  font-size: 14px;
  line-height: 1.6;
}

.ph-home-newsletter-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.ph-home-newsletter-tags span {
  padding: 4px 8px;
  background: #F3F4F6;
  color: #6B7280;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.ph-home-newsletter-link {
  display: inline-flex;
  font-family: var(--ph-mono);
  font-size: 12px;
  color: #336AEB;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 900;
}

.ph-home-want-next {
  margin: 0 0 16px;
  color: #6B7280;
}

.ph-home-free-section {
  position: relative;
  overflow: hidden;
  background: #0D1B2A;
  padding: 96px 0;
}

.ph-home-free-bg {
  position: absolute;
  inset: 0;
  opacity: .1;
}

.ph-home-free-glow-1,
.ph-home-free-glow-2 {
  position: absolute;
  border-radius: 999px;
  filter: blur(48px);
}

.ph-home-free-glow-1 {
  top: 0;
  right: 0;
  width: 256px;
  height: 256px;
  background: rgba(255,195,0,.10);
}

.ph-home-free-glow-2 {
  bottom: 0;
  left: 0;
  width: 192px;
  height: 192px;
  background: rgba(51,106,235,.20);
}

.ph-home-free-inner {
  position: relative;
  max-width: 1024px;
  margin: 0 auto;
  padding: 0 16px;
}

.ph-home-free-header {
  text-align: center;
  margin-bottom: 48px;
}

.ph-home-free-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
  margin-bottom: 24px;
  border: 1px solid rgba(255,195,0,.30);
  background: rgba(255,195,0,.10);
  color: #FFC300;
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.ph-home-free-section h2 {
  color: #fff;
}

.ph-home-free-header p {
  max-width: 620px;
  margin: 0 auto;
  color: #D1D5DB;
  font-size: 18px;
  line-height: 1.7;
}

.ph-home-free-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.ph-home-free-card {
  position: relative;
  padding: 32px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.15);
}

.ph-home-free-card-featured {
  background: rgba(255,195,0,.06);
  border-color: rgba(255,195,0,.40);
}

.ph-home-free-card-step {
  display: flex;
  flex-direction: column;
}

.ph-home-featured-badge {
  position: absolute;
  top: -1px;
  right: 24px;
  background: #FFC300;
  color: #0D1B2A;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 4px 12px;
}

.ph-home-free-top {
  margin-bottom: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}

.ph-home-free-label {
  margin-bottom: 12px;
  color: #FFC300;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.ph-home-free-price {
  margin-bottom: 12px;
  color: #fff;
  font-size: 40px;
  line-height: 1;
  font-weight: 900;
}

.ph-home-free-price span {
  color: #9CA3AF;
  font-size: 18px;
  font-weight: 400;
}

.ph-home-free-top p {
  margin: 0;
  color: #D1D5DB;
  font-size: 14px;
  line-height: 1.55;
}

.ph-home-free-card ul {
  flex: 1;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0;
  padding: 0;
}

.ph-home-free-card li {
  display: flex;
  gap: 10px;
  color: #D1D5DB;
  font-size: 14px;
  line-height: 1.5;
}

.ph-home-free-card li span {
  flex: 0 0 auto;
  color: #FFC300;
  font-weight: 900;
}

.ph-home-free-actions {
  display: flex;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 32px;
}

.ph-home-tier-cta {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 14px 24px;
  font-size: 14px;
  transition: all .1s ease;
}

.ph-home-tier-cta-primary {
  background: rgba(255,255,255,.12);
  color: #fff;
  border: 2px solid rgba(255,255,255,.80);
  box-shadow: 4px 4px 0 rgba(255,255,255,.30);
}

.ph-home-tier-cta-featured {
  background: #FFC300;
  color: #0D1B2A;
  border: 2px solid #FFC300;
  box-shadow: 4px 4px 0 rgba(255,195,0,.40);
}

.ph-home-tier-cta:hover {
  transform: translate(-2px, -2px);
}

.ph-home-trust-section {
  background: #fff;
  padding: 96px 0;
}

.ph-home-trust-inner {
  max-width: 768px;
  margin: 0 auto;
  padding: 0 16px;
  text-align: center;
}

.ph-home-trust-inner p {
  margin: 0 0 32px;
  color: #6B7280;
  font-size: 18px;
  line-height: 1.65;
  font-weight: 300;
}

.ph-home-footer {
  background: #0D1B2A;
  color: #fff;
  padding: 48px 0;
}

.ph-home-footer-inner {
  max-width: 1152px;
  margin: 0 auto;
  padding: 0 16px;
}

.ph-home-footer-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 32px;
}

.ph-home-footer-logo {
  color: #fff;
  margin-bottom: 12px;
}

.ph-home-footer-logo-box {
  border-color: #0D1B2A;
}

.ph-home-footer-tagline {
  margin: 0;
  color: #9CA3AF;
  font-size: 14px;
  font-weight: 300;
}

.ph-home-footer-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  color: #D1D5DB;
  font-size: 14px;
}

.ph-home-footer-nav a:hover {
  color: #FFC300;
}

.ph-home-footer-bottom {
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,.10);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.ph-home-footer-social {
  display: flex;
  gap: 16px;
}

.ph-home-footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255,255,255,.20);
  color: #9CA3AF;
  text-decoration: none;
  transition: all .2s ease;
}

.ph-home-footer-social svg {
  display: block;
  width: 17px;
  height: 17px;
  fill: currentColor;
}

.ph-home-footer-social a:hover {
  border-color: #FFC300;
  color: #FFC300;
}

.ph-home-footer-bottom p {
  max-width: 400px;
  margin: 0;
  color: #6B7280;
  font-family: var(--ph-mono);
  font-size: 11px;
  line-height: 1.5;
}

/* =====================================================================
 * MARKETING SUPPORT PAGES
 * ===================================================================*/

.ph-info-hero {
  position: relative;
  overflow: hidden;
  background: #fff;
  border-bottom: 1px solid #E0E1DD;
}

.ph-info-hero-inner {
  position: relative;
  max-width: 1152px;
  margin: 0 auto;
  padding: 96px 24px;
}

.ph-info-hero-grid {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: 64px;
  align-items: center;
}

.ph-info-hero h1 {
  margin: 0 0 28px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(42px, 5.6vw, 64px);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -.025em;
}

.ph-info-lede {
  max-width: 620px;
  margin: 0;
  color: #6B7280;
  font-size: 20px;
  font-weight: 300;
  line-height: 1.7;
}

.ph-info-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 32px;
}

.ph-info-paper-card {
  position: relative;
  background: #fff;
  border: 1px solid #E5E7EB;
  padding: 32px;
  box-shadow: 18px 18px 0 #FFC300, 0 25px 50px -18px rgba(0,0,0,.25);
  transform: rotate(1.25deg);
}

.ph-info-paper-card h2 {
  margin: 0 0 14px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(24px, 2.5vw, 32px);
  line-height: 1.2;
  letter-spacing: -.025em;
}

.ph-info-paper-card p {
  margin: 0;
  color: #6B7280;
  font-size: 14px;
  line-height: 1.6;
}

.ph-info-card-label {
  margin: 0 0 18px;
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-info-card-rule {
  height: 1px;
  margin: 22px 0;
  background: #E5E7EB;
}

.ph-info-paper-card ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ph-info-paper-card li {
  position: relative;
  padding-left: 22px;
  color: #334155;
  font-size: 14px;
  line-height: 1.45;
}

.ph-info-paper-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 8px;
  height: 8px;
  background: #FFC300;
  border: 2px solid #0D1B2A;
  box-shadow: 2px 2px 0 #0D1B2A;
}

.ph-info-section {
  background: #fff;
  padding: 96px 0;
}

.ph-info-section-muted {
  background: #F4F4F5;
  border-top: 1px solid #E0E1DD;
  border-bottom: 1px solid #E0E1DD;
}

.ph-info-section h2,
.ph-info-cta h2 {
  margin: 0 0 16px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1.16;
  letter-spacing: -.025em;
}

.ph-info-section p,
.ph-info-cta p {
  margin: 0 0 18px;
  color: #6B7280;
  font-size: 17px;
  font-weight: 300;
  line-height: 1.7;
}

.ph-info-split,
.ph-info-reader-grid,
.ph-sponsor-fit-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: 48px;
  align-items: start;
}

.ph-info-stat-grid,
.ph-info-reader-list,
.ph-sponsor-fit-list {
  display: grid;
  gap: 14px;
}

.ph-info-stat-grid div,
.ph-info-reader-list div,
.ph-sponsor-fit-list div {
  padding: 18px 20px;
  background: #fff;
  border: 1px solid #E0E1DD;
}

.ph-info-stat-grid strong {
  display: block;
  margin-bottom: 6px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 34px;
  line-height: 1;
}

.ph-info-stat-grid span,
.ph-info-reader-list span,
.ph-sponsor-fit-list span {
  display: block;
  color: #6B7280;
  font-size: 14px;
  line-height: 1.5;
}

.ph-info-reader-list strong,
.ph-sponsor-fit-list strong {
  display: block;
  margin-bottom: 6px;
  color: #0D1B2A;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-info-section-head {
  max-width: 760px;
  margin-bottom: 42px;
}

.ph-info-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.ph-info-card-grid article {
  min-height: 230px;
  padding: 24px;
  background: #fff;
  border: 1px solid #E0E1DD;
}

.ph-info-card-grid article span {
  display: inline-flex;
  margin-bottom: 24px;
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
}

.ph-info-card-grid h3 {
  margin: 0 0 12px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: 0;
}

.ph-info-card-grid p {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
}

.ph-info-cta {
  background: #fff;
  padding: 96px 0;
  border-top: 1px solid #E0E1DD;
}

.ph-info-cta .ph-home-trust-inner {
  display: grid;
  justify-items: center;
}

.ph-info-cta .ph-home-inline-form,
.ph-home-section-cta .ph-home-inline-form,
.ph-home-trust-section .ph-home-inline-form {
  width: min(640px, 100%);
  max-width: 640px;
  margin: 0 auto;
}

.ph-info-cta .ph-home-inline-input {
  min-height: 48px;
  font-size: 15px;
}

.ph-info-cta .ph-home-inline-btn {
  min-height: 48px;
  padding-inline: 30px;
}

.ph-info-cta .ph-home-form-microcopy,
.ph-home-trust-inner .ph-home-form-microcopy {
  margin: 10px 0 0;
  color: #9CA3AF;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  line-height: 1.45;
  text-align: center;
}

.ph-archive-stat-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.ph-archive-stat-row span {
  padding: 12px;
  background: #F9FAFB;
  color: #6B7280;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.ph-archive-stat-row strong {
  display: block;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 28px;
  line-height: 1;
}

.ph-archive-feature-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
  gap: 24px;
}

.ph-archive-issue-feature,
.ph-archive-guide-list a {
  color: inherit;
  text-decoration: none;
  background: #fff;
  border: 1px solid #E0E1DD;
}

.ph-archive-issue-feature {
  display: flex;
  flex-direction: column;
  min-height: 320px;
  padding: 32px;
}

.ph-archive-issue-feature:hover,
.ph-archive-guide-list a:hover,
.ph-info-card-grid article:hover,
.ph-info-stat-grid div:hover,
.ph-info-reader-list div:hover,
.ph-sponsor-fit-list div:hover {
  border-color: #0D1B2A;
}

.ph-archive-issue-feature h3 {
  margin: 0 0 14px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.15;
  letter-spacing: -.025em;
}

.ph-archive-issue-feature p {
  margin: 0 0 24px;
  color: #6B7280;
  font-size: 16px;
  line-height: 1.65;
}

.ph-archive-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid #F3F4F6;
}

.ph-archive-meta span {
  color: #9CA3AF;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.ph-archive-guide-list {
  display: grid;
  gap: 14px;
}

.ph-archive-guide-list a {
  display: grid;
  gap: 8px;
  padding: 20px;
}

.ph-archive-guide-list span {
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-archive-guide-list strong {
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 19px;
  line-height: 1.25;
}

.ph-page-kicker {
  margin: 0 0 18px;
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* Reference-adapted About page */

.ph-about-hero,
.ph-archive-landing,
.ph-contact-hero,
.ph-sponsor-media-hero {
  position: relative;
  overflow: hidden;
  background: #fff;
  border-bottom: 1px solid #E0E1DD;
}

.ph-about-hero-inner,
.ph-archive-landing-inner,
.ph-contact-hero-inner,
.ph-sponsor-media-inner {
  position: relative;
  max-width: 1152px;
  margin: 0 auto;
  padding: 94px 24px;
}

.ph-about-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
  gap: 56px;
  align-items: end;
}

.ph-contact-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(340px, .72fr);
  gap: 56px;
  align-items: center;
}

.ph-about-hero h1,
.ph-archive-landing h1,
.ph-contact-hero h1,
.ph-sponsor-media-hero h1 {
  margin: 0 0 26px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(52px, 7vw, 92px);
  font-weight: 700;
  line-height: .96;
  letter-spacing: 0;
}

.ph-about-lede,
.ph-contact-lede,
.ph-sponsor-media-copy p,
.ph-archive-landing p {
  max-width: 680px;
  margin: 0;
  color: #5F6B7A;
  font-size: 20px;
  font-weight: 300;
  line-height: 1.7;
}

.ph-contact-topic-card {
  display: grid;
  gap: 16px;
  padding: 28px;
  background: #0D1B2A;
  color: #fff;
  border: 1px solid #0D1B2A;
  box-shadow: 16px 16px 0 #FFC300, 0 28px 50px -28px rgba(13, 27, 42, .35);
}

.ph-contact-topic-card span,
.ph-contact-card > span {
  color: #FFC300;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-contact-topic-card strong {
  color: #fff;
  font-family: var(--ph-serif);
  font-size: 28px;
  line-height: 1.16;
}

.ph-contact-topic-card p {
  margin: 0;
  color: rgba(255, 255, 255, .76);
  font-size: 15px;
  line-height: 1.65;
}

.ph-about-dossier {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid #D8DEE8;
  background: #fff;
  box-shadow: 18px 18px 0 #FFC300, 0 28px 50px -28px rgba(13, 27, 42, .3);
}

.ph-about-dossier div {
  min-height: 160px;
  padding: 24px;
  border-right: 1px solid #E5E7EB;
  border-bottom: 1px solid #E5E7EB;
}

.ph-about-dossier div:nth-child(2n) {
  border-right: 0;
}

.ph-about-dossier div:nth-last-child(-n + 2) {
  border-bottom: 0;
}

.ph-about-dossier strong {
  display: block;
  margin-bottom: 12px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(34px, 4vw, 48px);
  line-height: 1;
}

.ph-about-dossier span {
  display: block;
  color: #6B7280;
  font-size: 13px;
  line-height: 1.55;
}

.ph-about-story-section,
.ph-about-reader-section,
.ph-contact-section,
.ph-sponsor-principle-section,
.ph-sponsor-fit-section,
.ph-sponsor-faq-section {
  background: #fff;
  padding: 96px 0;
}

.ph-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.ph-contact-card {
  display: flex;
  min-height: 320px;
  flex-direction: column;
  padding: 28px;
  background: #fff;
  border: 1px solid #D8DEE8;
}

.ph-contact-card > span {
  color: #336AEB;
}

.ph-contact-card h2 {
  margin: 28px 0 12px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 29px;
  line-height: 1.12;
}

.ph-contact-card p {
  margin: 0 0 22px;
  color: #6B7280;
  font-size: 15px;
  line-height: 1.65;
}

.ph-contact-card a {
  margin-top: auto;
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-decoration: none;
  text-transform: uppercase;
}

.ph-about-story-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .8fr);
  gap: 72px;
  align-items: start;
}

.ph-about-story-copy h2,
.ph-about-filter-intro h2,
.ph-about-reader-head h2,
.ph-about-personal-band h2,
.ph-sponsor-principle-grid h2,
.ph-sponsor-section-head h2,
.ph-sponsor-faq-grid h2 {
  margin: 0 0 20px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(34px, 4.5vw, 54px);
  line-height: 1.08;
  letter-spacing: 0;
}

.ph-about-story-copy p,
.ph-about-filter-intro p,
.ph-about-reader-head p,
.ph-about-personal-grid p,
.ph-sponsor-principle-grid p,
.ph-sponsor-section-head p {
  margin: 0 0 18px;
  color: #5F6B7A;
  font-size: 17px;
  font-weight: 300;
  line-height: 1.75;
}

.ph-about-timeline {
  position: relative;
  display: grid;
  gap: 0;
  padding-left: 28px;
}

.ph-about-timeline::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: #D8DEE8;
}

.ph-about-timeline div {
  position: relative;
  padding: 0 0 30px 24px;
}

.ph-about-timeline div::before {
  content: "";
  position: absolute;
  left: -27px;
  top: 5px;
  width: 14px;
  height: 14px;
  background: #FFC300;
  border: 2px solid #0D1B2A;
  box-shadow: 3px 3px 0 #0D1B2A;
}

.ph-about-timeline span {
  display: block;
  margin-bottom: 8px;
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-about-timeline strong {
  display: block;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 22px;
  line-height: 1.2;
}

.ph-about-timeline p {
  margin: 8px 0 0;
  color: #6B7280;
  font-size: 14px;
  line-height: 1.6;
}

.ph-about-filter-section,
.ph-sponsor-packages-section {
  background: #F4F4F5;
  padding: 96px 0;
  border-top: 1px solid #E0E1DD;
  border-bottom: 1px solid #E0E1DD;
}

.ph-about-filter-grid,
.ph-sponsor-principle-grid,
.ph-sponsor-faq-grid {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(380px, 1.1fr);
  gap: 56px;
  align-items: start;
}

.ph-about-quote {
  padding: 24px;
  background: #fff;
  border-left: 5px solid #FFC300;
  color: #0D1B2A !important;
  font-family: var(--ph-serif);
  font-size: 24px !important;
  line-height: 1.35 !important;
}

.ph-about-filter-rail {
  display: grid;
  gap: 14px;
}

.ph-about-filter-rail article {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 22px;
  align-items: baseline;
  padding: 22px 24px;
  background: #fff;
  border: 1px solid #D8DEE8;
}

.ph-about-filter-rail h3 {
  margin: 0;
  color: #0D1B2A;
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-about-filter-rail p {
  margin: 0;
  color: #6B7280;
  font-size: 15px;
  line-height: 1.55;
}

.ph-about-reader-head,
.ph-sponsor-section-head {
  max-width: 780px;
  margin-bottom: 42px;
}

.ph-about-reader-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.ph-about-reader-cards article {
  min-height: 260px;
  padding: 28px;
  background: #fff;
  border: 1px solid #D8DEE8;
}

.ph-about-reader-cards span {
  display: block;
  color: #336AEB;
  font-family: var(--ph-serif);
  font-size: clamp(44px, 5vw, 64px);
  font-weight: 900;
  line-height: .9;
}

.ph-about-reader-cards h3 {
  margin: 24px 0 12px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 26px;
  line-height: 1.15;
}

.ph-about-reader-cards p {
  margin: 0;
  color: #6B7280;
  font-size: 15px;
  line-height: 1.65;
}

.ph-about-personal-band {
  background: #0D1B2A;
  color: #fff;
  padding: 82px 0;
}

.ph-about-personal-grid {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(420px, 1.05fr);
  gap: 54px;
  align-items: start;
}

.ph-about-personal-band h2 {
  color: #fff;
}

.ph-about-personal-band .ph-page-kicker {
  color: #FFC300;
}

.ph-about-personal-grid p {
  color: rgba(255, 255, 255, .78);
}

/* Reference-adapted Archive page */

.ph-archive-landing-inner {
  text-align: center;
}

.ph-archive-landing h1 {
  font-size: clamp(58px, 10vw, 112px);
}

.ph-archive-landing p {
  margin-left: auto;
  margin-right: auto;
}

.ph-archive-scope-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  max-width: 780px;
  margin: 38px auto 0;
}

.ph-archive-scope-list span {
  padding: 10px 13px;
  background: #fff;
  border: 1px solid #D8DEE8;
  color: #0D1B2A;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 4px 4px 0 rgba(255, 195, 0, .85);
}

.ph-archive-landing-stats {
  display: inline-grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 42px;
  border: 1px solid #D8DEE8;
  background: #fff;
  box-shadow: 10px 10px 0 #FFC300;
}

.ph-archive-landing-stats span {
  display: grid;
  gap: 6px;
  min-width: 180px;
  padding: 20px 24px;
  border-right: 1px solid #E5E7EB;
  color: #6B7280;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-archive-landing-stats span:last-child {
  border-right: 0;
}

.ph-archive-landing-stats strong {
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 36px;
  line-height: 1;
}

.ph-archive-current-section {
  padding: 48px 0;
  background: #F4F4F5;
  border-bottom: 1px solid #E0E1DD;
}

.ph-archive-current-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 32px;
  align-items: center;
  padding: 28px;
  background: #fff;
  border: 1px solid #D8DEE8;
  color: inherit;
  text-decoration: none;
}

.ph-archive-current-card:hover {
  border-color: #0D1B2A;
}

.ph-archive-current-card h2 {
  margin: 16px 0 10px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.12;
  letter-spacing: 0;
}

.ph-archive-current-card p {
  max-width: 720px;
  margin: 0;
  color: #6B7280;
  font-size: 16px;
  line-height: 1.65;
}

.ph-archive-current-meta {
  display: grid;
  gap: 12px;
  padding-left: 26px;
  border-left: 1px solid #E5E7EB;
}

.ph-archive-current-meta span,
.ph-ref-archive-card-topline > span:last-child,
.ph-ref-archive-card-footer {
  color: #9CA3AF;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-archive-current-meta strong {
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-archive-tool-section {
  position: sticky;
  top: 0;
  z-index: 10;
  padding: 20px 0;
  background: rgba(255, 255, 255, .94);
  border-bottom: 1px solid #E0E1DD;
  backdrop-filter: blur(12px);
}

.ph-archive-tool-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px) auto;
  gap: 16px;
  align-items: end;
}

.ph-archive-filter-block {
  display: grid;
  gap: 8px;
}

.ph-archive-type-block {
  grid-column: 1 / -1;
}

.ph-archive-control-label {
  color: #6B7280;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-archive-filter-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.ph-archive-range-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ph-archive-filter-row button,
.ph-archive-range-row button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  justify-content: space-between;
  min-height: 44px;
  padding: 0 12px;
  background: #fff;
  border: 1px solid #D8DEE8;
  color: #0D1B2A;
  cursor: pointer;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ph-archive-filter-row button {
  width: 100%;
  min-width: 0;
  padding: 0 14px;
}

.ph-archive-filter-row button[aria-pressed="true"],
.ph-archive-range-row button[aria-pressed="true"] {
  background: #0D1B2A;
  border-color: #0D1B2A;
  color: #fff;
}

.ph-archive-filter-row button strong {
  display: inline-grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  background: #FFC300;
  color: #0D1B2A;
  font-size: 10px;
}

.ph-archive-search-box {
  display: grid;
  gap: 6px;
}

.ph-archive-search-box span {
  color: #6B7280;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-archive-search-box input {
  width: 100%;
  height: 44px;
  padding: 0 14px;
  background: #F8FAFC;
  border: 1px solid #D8DEE8;
  color: #0D1B2A;
  font: inherit;
}

.ph-archive-results-meta {
  margin: 0;
  color: #6B7280;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.ph-archive-library-section {
  padding: 72px 0 96px;
  background: #fff;
}

.ph-ref-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.ph-ref-archive-card {
  background: #fff;
  border: 1px solid #D8DEE8;
}

.ph-ref-archive-card[hidden] {
  display: none;
}

.ph-ref-archive-card:hover {
  border-color: #0D1B2A;
}

.ph-ref-archive-card a {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 100%;
  color: inherit;
  text-decoration: none;
}

.ph-ref-archive-card figure {
  aspect-ratio: 4 / 3;
  margin: 0;
  overflow: hidden;
  background: #F4F4F5;
  border-bottom: 1px solid #E5E7EB;
}

.ph-ref-archive-card-body {
  display: flex;
  flex-direction: column;
  padding: 22px;
}

.ph-ref-archive-card-topline,
.ph-ref-archive-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.ph-ref-archive-card h2 {
  margin: 18px 0 12px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 24px;
  line-height: 1.18;
  letter-spacing: 0;
}

.ph-ref-archive-card p {
  margin: 0 0 22px;
  color: #6B7280;
  font-size: 15px;
  line-height: 1.6;
}

.ph-ref-archive-card-footer {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid #F1F5F9;
}

.ph-ref-author {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.ph-ref-author b {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  background: #0D1B2A;
  color: #FFC300;
  font-size: 9px;
}

.ph-ref-archive-card .ph-home-feature-link {
  margin-top: 18px;
}

.ph-archive-empty {
  margin-top: 28px;
  padding: 42px;
  background: #F8FAFC;
  border: 1px solid #D8DEE8;
  text-align: center;
}

.ph-archive-empty h2 {
  margin: 0 0 10px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 32px;
}

.ph-archive-empty p {
  margin: 0;
  color: #6B7280;
}

/* Reference-adapted Sponsor page */

.ph-sponsor-media-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .82fr);
  gap: 56px;
  align-items: center;
}

.ph-sponsor-media-hero h1 {
  font-size: clamp(46px, 6.4vw, 78px);
  line-height: 1.02;
}

.ph-sponsor-media-card {
  background: #0D1B2A;
  color: #fff;
  border: 1px solid #0D1B2A;
  box-shadow: 18px 18px 0 #FFC300, 0 28px 50px -28px rgba(13, 27, 42, .35);
}

.ph-sponsor-media-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 24px;
  border-bottom: 1px solid rgba(255, 255, 255, .16);
}

.ph-sponsor-media-card-head span,
.ph-sponsor-media-notes span {
  color: #FFC300;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-sponsor-media-card-head strong {
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-sponsor-media-notes {
  display: grid;
}

.ph-sponsor-media-notes div {
  padding: 24px;
  border-bottom: 1px solid rgba(255, 255, 255, .12);
}

.ph-sponsor-media-notes div:last-child {
  border-bottom: 0;
}

.ph-sponsor-media-notes strong {
  display: block;
  margin-top: 10px;
  color: rgba(255, 255, 255, .86);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
}

.ph-sponsor-principle-grid {
  align-items: center;
}

.ph-sponsor-package-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.ph-sponsor-package-card {
  display: flex;
  flex-direction: column;
  min-height: 440px;
  padding: 26px;
  background: #fff;
  border: 1px solid #D8DEE8;
}

.ph-sponsor-package-featured {
  border-color: #0D1B2A;
  box-shadow: 10px 10px 0 #FFC300;
}

.ph-sponsor-package-card > span {
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-sponsor-package-card h3 {
  margin: 28px 0 12px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 28px;
  line-height: 1.12;
  letter-spacing: 0;
}

.ph-sponsor-package-card p {
  margin: 0 0 22px;
  color: #6B7280;
  font-size: 15px;
  line-height: 1.6;
}

.ph-sponsor-package-card ul {
  display: grid;
  gap: 10px;
  margin: 0 0 28px;
  padding: 0;
  list-style: none;
}

.ph-sponsor-package-card li {
  position: relative;
  padding-left: 20px;
  color: #334155;
  font-size: 14px;
  line-height: 1.45;
}

.ph-sponsor-package-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .52em;
  width: 7px;
  height: 7px;
  background: #FFC300;
  border: 1px solid #0D1B2A;
}

.ph-sponsor-package-card a {
  margin-top: auto;
  color: #336AEB;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
}

.ph-sponsor-fit-table {
  border: 1px solid #D8DEE8;
  background: #fff;
}

.ph-sponsor-fit-table > div {
  display: grid;
  grid-template-columns: 240px 1fr;
  border-bottom: 1px solid #E5E7EB;
}

.ph-sponsor-fit-table > div:last-child {
  border-bottom: 0;
}

.ph-sponsor-fit-table strong,
.ph-sponsor-fit-table span {
  padding: 22px 24px;
}

.ph-sponsor-fit-table strong {
  background: #F8FAFC;
  color: #0D1B2A;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ph-sponsor-fit-table span {
  color: #5F6B7A;
  font-size: 16px;
  line-height: 1.65;
}

.ph-sponsor-faq-section {
  background: #F4F4F5;
  border-top: 1px solid #E0E1DD;
}

.ph-sponsor-faq-list {
  display: grid;
  gap: 12px;
}

.ph-sponsor-faq-list details {
  background: #fff;
  border: 1px solid #D8DEE8;
}

.ph-sponsor-faq-list summary {
  cursor: pointer;
  padding: 22px 24px;
  color: #0D1B2A;
  font-family: var(--ph-serif);
  font-size: 22px;
  line-height: 1.25;
}

.ph-sponsor-faq-list p {
  margin: 0;
  padding: 0 24px 24px;
  color: #6B7280;
  font-size: 15px;
  line-height: 1.65;
}

.ph-honeypot {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.ph-signup-page {
  position: relative;
  overflow: hidden;
  background: #0D1B2A;
  color: #fff;
  min-height: calc(100vh - 220px);
  padding: 96px 24px;
}

.ph-signup-page .ph-home-hero-bg {
  opacity: .62;
}

.ph-signup-shell {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(420px, 1fr);
  gap: 48px;
  align-items: center;
}

.ph-signup-copy h1 {
  margin: 12px 0 18px;
  color: #fff;
  font-size: clamp(42px, 6vw, 76px);
  line-height: .93;
  letter-spacing: 0;
}

.ph-signup-copy p {
  max-width: 590px;
  margin: 0;
  color: #C9D1D9;
  font-size: 18px;
  line-height: 1.65;
}

.ph-signup-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.ph-signup-proof span {
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.07);
  color: #F9FAFB;
  padding: 9px 12px;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.ph-signup-card,
.ph-signup-next-card {
  background: #fff;
  color: #0D1B2A;
  border: 1px solid #E5E7EB;
  box-shadow: 14px 14px 0 rgba(255,195,0,.95);
  padding: 28px;
}

.ph-signup-alert {
  margin: 0 0 16px;
  padding: 12px 14px;
  background: #FFF4D6;
  border: 1px solid #FFD166;
  color: #6A4700;
  font-weight: 800;
  font-size: 13px;
}

.ph-signup-email-label {
  display: block;
  margin-bottom: 8px;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #4B5563;
}

.ph-signup-email {
  width: 100%;
  min-height: 54px;
  padding: 0 16px;
  background: #F9FAFB;
  border: 1px solid #D1D5DB;
  color: #0D1B2A;
  font: inherit;
  outline: none;
}

.ph-signup-email:focus {
  border-color: #336AEB;
  box-shadow: 0 0 0 4px rgba(51,106,235,.12);
}

.ph-intent-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 18px 0 22px;
}

.ph-intent-option {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 12px;
  align-items: start;
  padding: 14px;
  border: 1px solid #E5E7EB;
  background: #fff;
  cursor: pointer;
}

.ph-intent-option:hover,
.ph-intent-option:has(input:checked) {
  border-color: #0D1B2A;
  background: #F9FAFB;
}

.ph-intent-option input {
  margin-top: 3px;
  accent-color: #0D1B2A;
}

.ph-intent-option strong,
.ph-intent-option small {
  display: block;
}

.ph-intent-option strong {
  color: #0D1B2A;
  font-size: 15px;
  line-height: 1.25;
}

.ph-intent-option small {
  margin-top: 4px;
  color: #5F6B7A;
  font-size: 13px;
  line-height: 1.45;
}

.ph-signup-submit {
  width: 100%;
  min-height: 52px;
  border: 2px solid #0D1B2A;
  background: #FFC300;
  color: #0D1B2A;
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.ph-signup-microcopy {
  margin: 12px 0 0;
  color: #7D8796;
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 800;
  text-align: center;
}

.ph-signup-thanks-shell {
  grid-template-columns: minmax(0, 1fr) 360px;
}

.ph-signup-next-card {
  align-self: stretch;
  display: grid;
  align-content: center;
  gap: 12px;
}

.ph-signup-next-card span {
  font-family: var(--ph-mono);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #7D8796;
}

.ph-signup-next-card strong {
  font-size: 26px;
  line-height: 1.05;
}

.ph-signup-next-card p {
  margin: 0;
  color: #5F6B7A;
  line-height: 1.55;
}

.ph-signup-next-card a {
  color: #0D1B2A;
  font-family: var(--ph-mono);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

@media (max-width: 900px) {
  .ph-signup-page {
    padding: 72px 20px;
  }

  .ph-signup-shell,
  .ph-signup-thanks-shell {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .ph-signup-copy h1 {
    font-size: 48px;
  }

  .ph-signup-card,
  .ph-signup-next-card {
    box-shadow: 10px 10px 0 rgba(255,195,0,.95);
  }

  .ph-home-nav,
  .ph-home-header-ctas {
    display: none;
  }

  .ph-home-mobile-menu-btn {
    display: flex;
  }

  .ph-home-hero-inner {
    padding: 64px 24px;
  }

  .ph-home-hero-grid,
  .ph-info-hero-grid,
  .ph-info-split,
  .ph-info-reader-grid,
  .ph-sponsor-fit-grid,
  .ph-archive-feature-grid,
  .ph-about-hero-grid,
  .ph-about-story-grid,
  .ph-about-filter-grid,
  .ph-about-personal-grid,
  .ph-contact-hero-grid,
  .ph-sponsor-media-inner,
  .ph-sponsor-principle-grid,
  .ph-sponsor-faq-grid,
  .ph-archive-current-card,
  .ph-archive-tool-panel {
    grid-template-columns: 1fr;
  }

  .ph-home-features-grid,
  .ph-home-newsletters-grid,
  .ph-info-card-grid,
  .ph-about-reader-cards,
  .ph-ref-archive-grid,
  .ph-contact-grid,
  .ph-sponsor-package-grid {
    grid-template-columns: 1fr 1fr;
  }

  .ph-about-filter-rail article,
  .ph-sponsor-fit-table > div {
    grid-template-columns: 1fr;
  }

  .ph-archive-tool-section {
    position: static;
  }

  .ph-archive-current-meta {
    padding-left: 0;
    padding-top: 22px;
    border-left: 0;
    border-top: 1px solid #E5E7EB;
  }

  .ph-archive-filter-row {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .ph-home-footer-top,
  .ph-home-footer-bottom {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 900px) {
  .ph-home-free-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .ph-archive-filter-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .ph-signup-page {
    padding: 56px 16px;
  }

  .ph-signup-copy h1 {
    font-size: 38px;
    line-height: 1;
  }

  .ph-signup-copy p {
    font-size: 16px;
  }

  .ph-signup-card,
  .ph-signup-next-card {
    padding: 20px;
    box-shadow: 8px 8px 0 rgba(255,195,0,.95);
  }

  .ph-intent-option {
    padding: 12px;
  }

  .ph-home-header-inner {
    min-height: 68px;
  }

  .ph-home-logo-text,
  .ph-home-footer-logo-text {
    font-size: 16px;
  }

  .ph-home-hero-inner,
  .ph-info-hero-inner,
  .ph-about-hero-inner,
  .ph-contact-hero-inner,
  .ph-archive-landing-inner,
  .ph-sponsor-media-inner,
  .ph-home-container,
  .ph-home-free-inner,
  .ph-home-trust-inner,
  .ph-home-footer-inner {
    padding-left: 16px;
    padding-right: 16px;
  }

  .ph-home-hero h1 {
    font-size: 38px;
  }

  .ph-info-hero h1 {
    font-size: 38px;
  }

  .ph-home-hero-subhead {
    font-size: 18px;
    margin-bottom: 22px;
  }

  .ph-home-email-form,
  .ph-home-inline-form {
    flex-direction: column;
  }

  .ph-home-email-btn,
  .ph-home-inline-btn {
    width: 100%;
  }

  .ph-home-edge-list li {
    font-size: 14px;
  }

  .ph-home-inside-strip > div {
    grid-template-columns: 1fr;
  }

  .ph-home-inside-strip a {
    border-right: 0;
    border-bottom: 1px solid #E0E1DD;
  }

  .ph-home-inside-strip a:last-child {
    border-bottom: 0;
  }

  .ph-home-dossier-wrapper {
    margin-top: 20px;
  }

  .ph-home-dossier-card {
    padding: 24px;
    transform: none;
  }

  .ph-home-dossier-shadow {
    top: 14px;
    right: -14px;
  }

  .ph-home-roundup-section,
  .ph-home-newsletters-section,
  .ph-home-free-section,
  .ph-home-trust-section,
  .ph-info-section,
  .ph-info-cta,
  .ph-about-story-section,
  .ph-about-reader-section,
  .ph-about-filter-section,
  .ph-about-personal-band,
  .ph-contact-section,
  .ph-sponsor-principle-section,
  .ph-sponsor-packages-section,
  .ph-sponsor-fit-section,
  .ph-sponsor-faq-section,
  .ph-archive-library-section {
    padding: 64px 0;
  }

  .ph-home-features-grid,
  .ph-home-newsletters-grid,
  .ph-info-card-grid,
  .ph-about-reader-cards,
  .ph-ref-archive-grid,
  .ph-contact-grid,
  .ph-sponsor-package-grid,
  .ph-about-dossier,
  .ph-archive-landing-stats {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .ph-home-feature-card,
  .ph-home-newsletter-card,
  .ph-home-free-card,
  .ph-info-card-grid article {
    padding: 20px;
  }

  .ph-author-card {
    grid-template-columns: 1fr;
    padding: 20px;
    box-shadow: 6px 6px 0 rgba(255, 195, 0, .9);
  }

  .ph-author-mark {
    width: 50px;
    height: 50px;
  }

  .ph-info-paper-card {
    padding: 24px;
    transform: none;
    box-shadow: 12px 12px 0 #FFC300, 0 20px 45px -22px rgba(0,0,0,.24);
  }

  .ph-about-hero h1,
  .ph-archive-landing h1,
  .ph-contact-hero h1,
  .ph-sponsor-media-hero h1 {
    font-size: 44px;
    line-height: 1.04;
  }

  .ph-about-dossier {
    box-shadow: 10px 10px 0 #FFC300, 0 20px 45px -24px rgba(13, 27, 42, .25);
  }

  .ph-about-dossier div,
  .ph-about-dossier div:nth-child(2n),
  .ph-about-dossier div:nth-last-child(-n + 2),
  .ph-archive-landing-stats span {
    border-right: 0;
    border-bottom: 1px solid #E5E7EB;
  }

  .ph-about-dossier div:last-child,
  .ph-archive-landing-stats span:last-child {
    border-bottom: 0;
  }

  .ph-archive-tool-panel {
    align-items: stretch;
  }

  .ph-archive-results-meta {
    white-space: normal;
  }

  .ph-archive-filter-row {
    grid-template-columns: 1fr;
  }

  .ph-sponsor-media-card,
  .ph-contact-topic-card,
  .ph-sponsor-package-featured {
    box-shadow: 10px 10px 0 #FFC300;
  }
}
