/*
Theme Name: PrimaGround
Template: astra
Description: Premium wellness brand child theme with editorial magazine support.
Version: 1.0.7
Text Domain: primaground
*/

/* ===========================================================
   BRAND TOKENS
   =========================================================== */
:root {
  --pg-bg: #FAFAF7;
  --pg-bg-alt: #F2EFE8;
  --pg-text: #1A1F1B;
  --pg-text-muted: #6B7B6D;
  --pg-rule: #E3DED2;
  --pg-primary: #2C3E2F;
  --pg-primary-deep: #1F2D22;
  --pg-accent: #C8A876;
  --pg-accent-deep: #9A7E55;
  --pg-white: #FFFFFF;
  --pg-serif: "Fraunces", "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --pg-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --pg-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;
  --pg-max: 1280px;
  --pg-read: 700px;
}

/* ===========================================================
   GLOBAL TYPOGRAPHY + COLOR
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@300;400;500;600;700&display=swap');

html, body {
  background: var(--pg-bg);
  color: var(--pg-text);
  font-family: var(--pg-sans);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, .pg-serif {
  font-family: var(--pg-serif);
  color: var(--pg-text);
  letter-spacing: -0.01em;
  font-weight: 500;
}

h1 { font-size: clamp(2.5rem, 5vw, 4.25rem); line-height: 1.05; font-weight: 500; }
h2 { font-size: clamp(2rem, 3.5vw, 2.75rem); line-height: 1.15; }
h3 { font-size: clamp(1.4rem, 2.2vw, 1.75rem); line-height: 1.3; }

a { color: var(--pg-primary); text-decoration: none; transition: color .18s ease; }
a:hover { color: var(--pg-accent-deep); }

p { margin: 0 0 1.1em; }

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

/* ===========================================================
   ASTRA OVERRIDES
   =========================================================== */
.ast-container, .site-content > .container, .ast-archive-description {
  max-width: var(--pg-max);
}
.site-header { background: var(--pg-bg); border-bottom: 1px solid var(--pg-rule); }
.main-header-menu a { font-family: var(--pg-sans); font-weight: 500; font-size: 0.92rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--pg-text); }
.main-header-menu a:hover { color: var(--pg-accent-deep); }
/* legacy text-logo styles removed — using image logo only */
.pg-footer { background: var(--pg-text); color: #DCE0DD; padding: 4rem 1.5rem 2.5rem; }
.pg-footer a { color: var(--pg-bg-alt); }
.pg-footer a:hover { color: var(--pg-accent); }
/* Suppress Astra's default footer (HFB builder) — we render our own. */
.site-footer, footer.site-footer, #colophon { display: none !important; }

/* ===========================================================
   BUTTONS
   =========================================================== */
.pg-btn, .wp-block-button .wp-block-button__link, .button, .ast-button, button.single_add_to_cart_button, .woocommerce a.button, .woocommerce button.button {
  display: inline-flex !important;
  align-items: center;
  gap: 0.55em;
  background: var(--pg-text) !important;
  color: var(--pg-white) !important;
  border: 1px solid var(--pg-text) !important;
  padding: 0.95rem 1.6rem !important;
  font-family: var(--pg-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.13em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  transition: background .2s ease, color .2s ease, border-color .2s ease !important;
  line-height: 1 !important;
}
.pg-btn:hover, .wp-block-button .wp-block-button__link:hover, .button:hover, .woocommerce a.button:hover, .woocommerce button.button:hover, button.single_add_to_cart_button:hover {
  background: var(--pg-primary) !important;
  border-color: var(--pg-primary) !important;
  color: var(--pg-white) !important;
}
.pg-btn--ghost, .is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: var(--pg-text) !important;
}
.pg-btn--ghost:hover, .is-style-outline .wp-block-button__link:hover {
  background: var(--pg-text) !important;
  color: var(--pg-white) !important;
}

/* ===========================================================
   HOMEPAGE
   =========================================================== */
.pg-hero {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  min-height: clamp(560px, 78vh, 760px);
  align-items: stretch;
  background: var(--pg-bg);
  border-bottom: 1px solid var(--pg-rule);
}
.pg-hero__copy {
  padding: clamp(3rem, 7vw, 6rem) clamp(2rem, 6vw, 5rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.pg-hero__eyebrow {
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--pg-accent-deep);
  font-weight: 500;
  margin-bottom: 1.6rem;
}
.pg-hero__title {
  font-family: var(--pg-serif);
  font-weight: 500;
  font-size: clamp(2.8rem, 5.5vw, 4.6rem);
  line-height: 1.02;
  margin: 0 0 1.4rem;
  letter-spacing: -0.02em;
}
.pg-hero__title em { font-style: italic; color: var(--pg-primary); }
.pg-hero__lede {
  font-size: 1.12rem;
  color: var(--pg-text-muted);
  line-height: 1.6;
  max-width: 38rem;
  margin: 0 0 2.2rem;
}
.pg-hero__cta { display: flex; gap: 0.8rem; flex-wrap: wrap; }
.pg-hero__media {
  background-size: cover;
  background-position: center;
  border-left: 1px solid var(--pg-rule);
  min-height: 320px;
}
@media (max-width: 900px) {
  .pg-hero { grid-template-columns: 1fr; }
  .pg-hero__media { min-height: 360px; border-left: 0; border-top: 1px solid var(--pg-rule); }
}

/* Sections */
.pg-section { padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 5vw, 4rem); }
.pg-section--alt { background: var(--pg-bg-alt); }
.pg-section__head { max-width: var(--pg-max); margin: 0 auto 3rem; text-align: center; }
.pg-section__eyebrow { font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--pg-accent-deep); font-weight: 500; margin-bottom: 0.8rem; }
.pg-section__title { font-family: var(--pg-serif); font-weight: 500; font-size: clamp(2rem, 3.5vw, 2.8rem); line-height: 1.1; margin: 0 0 0.9rem; letter-spacing: -0.015em; }
.pg-section__sub { color: var(--pg-text-muted); font-size: 1.05rem; max-width: 38rem; margin: 0 auto; }

.pg-grid { display: grid; gap: 2rem; max-width: var(--pg-max); margin: 0 auto; }
.pg-grid--3 { grid-template-columns: repeat(3, 1fr); }
.pg-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .pg-grid--3, .pg-grid--4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .pg-grid--3, .pg-grid--4 { grid-template-columns: 1fr; } }

/* Product card (homepage featured) */
.pg-card {
  background: var(--pg-white);
  border: 1px solid var(--pg-rule);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, box-shadow .25s ease;
}
.pg-card:hover { transform: translateY(-3px); box-shadow: 0 12px 36px -18px rgba(28,32,28,.18); }
.pg-card__media { aspect-ratio: 1/1.05; overflow: hidden; background: var(--pg-bg-alt); }
.pg-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.pg-card:hover .pg-card__media img { transform: scale(1.04); }
.pg-card__body { padding: 1.4rem 1.4rem 1.6rem; display: flex; flex-direction: column; gap: 0.5rem; }
.pg-card__cat { font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--pg-accent-deep); font-weight: 500; }
.pg-card__name { font-family: var(--pg-serif); font-size: 1.25rem; font-weight: 500; line-height: 1.25; color: var(--pg-text); }
.pg-card__price { font-size: 0.98rem; color: var(--pg-text-muted); margin-top: auto; }

/* Magazine card */
.pg-mag-card { display: flex; flex-direction: column; gap: 1rem; text-decoration: none; color: inherit; }
.pg-mag-card__media { aspect-ratio: 4/3; overflow: hidden; background: var(--pg-bg-alt); }
.pg-mag-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.pg-mag-card:hover .pg-mag-card__media img { transform: scale(1.04); }
.pg-mag-card__kicker { font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--pg-accent-deep); font-weight: 500; }
.pg-mag-card__title { font-family: var(--pg-serif); font-size: 1.55rem; font-weight: 500; line-height: 1.2; color: var(--pg-text); margin: 0; }
.pg-mag-card__byline { font-size: 0.85rem; color: var(--pg-text-muted); }

/* Pillars / value props */
.pg-pillars { max-width: var(--pg-max); margin: 0 auto; }
.pg-pillar { padding: 2rem; text-align: left; border-top: 1px solid var(--pg-rule); }
.pg-pillar__icon { display: inline-flex; width: 2rem; height: 2rem; border: 1px solid var(--pg-text); border-radius: 999px; align-items: center; justify-content: center; margin-bottom: 1rem; font-family: var(--pg-serif); font-weight: 500; }
.pg-pillar__title { font-family: var(--pg-serif); font-size: 1.4rem; font-weight: 500; margin: 0 0 0.4rem; }
.pg-pillar__copy { font-size: 0.95rem; color: var(--pg-text-muted); margin: 0; }

/* ===========================================================
   EDITORIAL ARTICLE
   =========================================================== */
.pg-article-header {
  text-align: left;
  max-width: 920px;
  margin: clamp(2rem, 5vw, 4rem) auto clamp(2rem, 4vw, 3rem);
  padding: 0 1.5rem;
}
.pg-article-kicker {
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--pg-accent-deep);
  font-weight: 500;
  margin-bottom: 1.3rem;
}
.pg-article-title {
  font-family: var(--pg-serif);
  font-size: clamp(2.4rem, 5.5vw, 4.5rem);
  font-weight: 500;
  line-height: 1.04;
  letter-spacing: -0.022em;
  color: var(--pg-text);
  margin: 0 0 1.4rem;
}
.pg-article-dek {
  font-family: var(--pg-serif);
  font-size: clamp(1.15rem, 1.5vw, 1.35rem);
  font-weight: 400;
  font-style: italic;
  color: var(--pg-text-muted);
  line-height: 1.45;
  max-width: 50rem;
  margin: 0 0 2.2rem;
}
.pg-byline {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.4rem 0;
  border-top: 1px solid var(--pg-rule);
  border-bottom: 1px solid var(--pg-rule);
}
.pg-byline__avatar { width: 56px; height: 56px; border-radius: 999px; overflow: hidden; flex-shrink: 0; }
.pg-byline__avatar img { width: 100%; height: 100%; object-fit: cover; }
.pg-byline__meta { display: flex; flex-direction: column; line-height: 1.3; }
.pg-byline__by { font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--pg-text-muted); }
.pg-byline__name { font-family: var(--pg-serif); font-size: 1.1rem; font-weight: 500; color: var(--pg-text); }
.pg-byline__date { font-size: 0.85rem; color: var(--pg-text-muted); }
.pg-byline__role { font-size: 0.78rem; color: var(--pg-text-muted); }

.pg-article-hero {
  width: 100%;
  max-width: 1480px;
  margin: 0 auto clamp(2rem, 5vw, 4rem);
  aspect-ratio: 16/8;
  overflow: hidden;
}
.pg-article-hero img { width: 100%; height: 100%; object-fit: cover; }
.pg-article-hero__caption { max-width: var(--pg-read); margin: 0.8rem auto 0; padding: 0 1.5rem; font-size: 0.82rem; color: var(--pg-text-muted); font-style: italic; }

.pg-article-body {
  max-width: var(--pg-read);
  margin: 0 auto;
  padding: 0 1.5rem clamp(3rem, 6vw, 5rem);
  font-size: 1.18rem;
  line-height: 1.78;
  color: var(--pg-text);
}
.pg-article-body p { margin: 0 0 1.4em; }
.pg-article-body p:first-of-type::first-letter {
  font-family: var(--pg-serif);
  font-weight: 500;
  float: left;
  font-size: 4.4rem;
  line-height: 0.88;
  padding: 0.32rem 0.55rem 0 0;
  color: var(--pg-primary);
}
.pg-article-body h2 {
  font-family: var(--pg-serif);
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 2.6rem 0 1rem;
  line-height: 1.18;
}
.pg-article-body h3 {
  font-family: var(--pg-serif);
  font-size: clamp(1.25rem, 1.8vw, 1.5rem);
  font-weight: 500;
  margin: 2rem 0 0.8rem;
  line-height: 1.25;
}
.pg-article-body blockquote {
  border: 0;
  border-left: 3px solid var(--pg-accent);
  margin: 2.4rem 0;
  padding: 0.2rem 0 0.2rem 1.6rem;
  font-family: var(--pg-serif);
  font-size: 1.5rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.45;
  color: var(--pg-primary);
}
.pg-article-body ul, .pg-article-body ol { margin: 1.2rem 0 1.8rem 1.4rem; }
.pg-article-body li { margin: 0.4rem 0; }
.pg-article-body figure { margin: 2rem 0; }
.pg-article-body figcaption { font-size: 0.85rem; color: var(--pg-text-muted); font-style: italic; margin-top: 0.6rem; }
.pg-article-body a { color: var(--pg-primary); border-bottom: 1px solid var(--pg-accent); padding-bottom: 1px; }
.pg-article-body a:hover { color: var(--pg-accent-deep); }

/* Pull-quote */
.pg-pullquote {
  font-family: var(--pg-serif);
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  font-style: italic;
  line-height: 1.3;
  font-weight: 400;
  text-align: center;
  color: var(--pg-primary);
  max-width: 760px;
  margin: 3rem auto;
  padding: 2.5rem 0;
  border-top: 1px solid var(--pg-rule);
  border-bottom: 1px solid var(--pg-rule);
}

/* Final CTA card embedded in article */
.pg-article-cta {
  max-width: var(--pg-read);
  margin: 3rem auto 0;
  padding: 0 1.5rem;
}
.pg-article-cta__inner {
  display: grid;
  grid-template-columns: 1.1fr 1.4fr;
  background: var(--pg-bg-alt);
  border: 1px solid var(--pg-rule);
  overflow: hidden;
  align-items: stretch;
}
.pg-article-cta__media { background-size: cover; background-position: center; min-height: 280px; }
.pg-article-cta__copy { padding: 2.4rem; display: flex; flex-direction: column; justify-content: center; }
.pg-article-cta__kicker { font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--pg-accent-deep); font-weight: 500; margin-bottom: 0.7rem; }
.pg-article-cta__title { font-family: var(--pg-serif); font-size: 1.7rem; line-height: 1.18; font-weight: 500; margin: 0 0 0.7rem; }
.pg-article-cta__desc { font-size: 0.98rem; color: var(--pg-text-muted); margin: 0 0 1.4rem; line-height: 1.55; }
.pg-article-cta__row { display: flex; gap: 0.9rem; align-items: center; flex-wrap: wrap; }
.pg-article-cta__price { font-family: var(--pg-serif); font-size: 1.2rem; color: var(--pg-primary); font-weight: 500; }
@media (max-width: 780px) {
  .pg-article-cta__inner { grid-template-columns: 1fr; }
}

/* Magazine index page */
.pg-mag-index { padding: clamp(3rem, 6vw, 5rem) 1.5rem; max-width: 1280px; margin: 0 auto; }
.pg-mag-feature { display: grid; grid-template-columns: 1.2fr 1fr; gap: 3rem; align-items: center; border-bottom: 1px solid var(--pg-rule); padding-bottom: 4rem; margin-bottom: 4rem; }
.pg-mag-feature__media { aspect-ratio: 5/4; overflow: hidden; background: var(--pg-bg-alt); }
.pg-mag-feature__media img { width: 100%; height: 100%; object-fit: cover; }
.pg-mag-feature__kicker { font-size: 0.78rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--pg-accent-deep); font-weight: 500; margin-bottom: 1rem; }
.pg-mag-feature__title { font-family: var(--pg-serif); font-size: clamp(2rem, 3.5vw, 2.9rem); line-height: 1.08; font-weight: 500; margin: 0 0 1rem; letter-spacing: -0.015em; }
.pg-mag-feature__dek { font-family: var(--pg-serif); font-style: italic; color: var(--pg-text-muted); font-size: 1.2rem; line-height: 1.45; margin-bottom: 1.4rem; max-width: 38rem; }
.pg-mag-feature__byline { font-size: 0.85rem; color: var(--pg-text-muted); }
@media (max-width: 900px) { .pg-mag-feature { grid-template-columns: 1fr; } }

/* WooCommerce niceties */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--pg-serif) !important;
  font-weight: 500 !important;
  font-size: 1.2rem !important;
  color: var(--pg-text) !important;
}
.woocommerce ul.products li.product .price {
  font-family: var(--pg-serif) !important;
  font-size: 1.05rem !important;
  color: var(--pg-primary) !important;
}
.woocommerce-product-gallery img { background: var(--pg-bg-alt); }
.woocommerce div.product .product_title {
  font-family: var(--pg-serif) !important;
  font-weight: 500 !important;
  font-size: clamp(2rem, 3vw, 2.6rem) !important;
  letter-spacing: -0.015em !important;
  line-height: 1.1 !important;
}
.woocommerce div.product p.price, .woocommerce div.product span.price {
  font-family: var(--pg-serif) !important;
  font-size: 1.5rem !important;
  color: var(--pg-primary) !important;
}

/* Footer */
.pg-footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 3rem; max-width: var(--pg-max); margin: 0 auto; }
.pg-footer-grid h4 { font-family: var(--pg-sans); color: var(--pg-white); font-size: 0.8rem; letter-spacing: 0.2em; text-transform: uppercase; margin: 0 0 1.2rem; font-weight: 500; }
.pg-footer-grid ul { list-style: none; padding: 0; margin: 0; }
.pg-footer-grid li { margin: 0.4rem 0; font-size: 0.92rem; }
.pg-footer-brand { font-family: var(--pg-serif); font-size: 1.8rem; color: var(--pg-white); margin: 0 0 0.6rem; letter-spacing: -0.015em; font-weight: 500; }
.pg-footer-tagline { font-size: 0.92rem; color: #B6BEB7; max-width: 22rem; margin: 0 0 1rem; line-height: 1.5; }
.pg-footer-legal { max-width: var(--pg-max); margin: 3rem auto 0; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,.08); display: flex; justify-content: space-between; font-size: 0.78rem; color: #8E978F; }
@media (max-width: 800px) { .pg-footer-grid { grid-template-columns: 1fr 1fr; } .pg-footer-legal { flex-direction: column; gap: 0.6rem; } }

/* Utility */
.pg-clean-list { list-style: none; padding: 0; margin: 0; }
.pg-rule { height: 1px; background: var(--pg-rule); border: 0; margin: 2rem 0; }

/* ===========================================================
   HEADER LOGO  — prominent, image-only across every page
   =========================================================== */
.ast-site-title-wrap,
.site-title, .site-description,
.ast-site-identity .site-title, .ast-site-identity .site-description,
.ast-header-break-point .site-title, .ast-header-break-point .site-description,
.site-branding .site-title, .site-branding .site-description,
header .site-title, header .site-description,
.ast-builder-html-element .site-title, .ast-builder-html-element .site-description,
p.site-title, p.site-description { display: none !important; visibility: hidden !important; height: 0 !important; width: 0 !important; overflow: hidden !important; }
.site-branding, .ast-site-identity { display: inline-flex !important; align-items: center !important; }
.site-branding .custom-logo-link,
.custom-logo-link { display: inline-block !important; }
.site-branding .custom-logo-link img,
.custom-logo-link img,
img.custom-logo,
.ast-header-break-point .site-logo-img img { max-height: 88px !important; width: auto !important; height: auto !important; }
.site-header, .ast-primary-header-bar, .main-header-bar { padding-top: 1.1rem !important; padding-bottom: 1.1rem !important; }
@media (max-width: 768px) {
  .site-branding .custom-logo-link img, .custom-logo-link img, img.custom-logo { max-height: 56px !important; }
}

/* ===========================================================
   SHOP PAGE  — kill default Woo chrome, add brand hero
   =========================================================== */
.woocommerce-page .page-title,
.woocommerce-page h1.page-title,
.woocommerce .woocommerce-breadcrumb,
.woocommerce-page .woocommerce-result-count,
.woocommerce-page .woocommerce-ordering { display: none !important; }

.pg-shop-hero {
  background: var(--pg-bg-alt);
  border-bottom: 1px solid var(--pg-rule);
  margin: 0;
  width: 100%;
}
.pg-shop-hero__inner {
  max-width: var(--pg-max);
  margin: 0 auto;
  padding: clamp(3rem, 6vw, 5rem) 1.5rem;
  text-align: center;
}
.woocommerce-products-header { display: none !important; }
.pg-shop-hero__eyebrow { color: var(--pg-accent); letter-spacing: 0.18em; text-transform: uppercase; font-size: 0.78rem; font-weight: 600; }
.pg-shop-hero__title { font-family: var(--pg-serif); font-weight: 500; font-size: clamp(2.2rem, 4.5vw, 3.4rem); line-height: 1.05; letter-spacing: -0.02em; margin: 0.4rem 0 0.9rem; color: var(--pg-text); }
.pg-shop-hero__sub { color: var(--pg-text-muted); max-width: 38rem; margin: 0 auto; font-size: 1.05rem; line-height: 1.6; }
.pg-shop-hero__meta { margin-top: 1.75rem; display: inline-flex; gap: 1.75rem; padding: 0.75rem 1.5rem; background: rgba(255,255,255,0.7); border-radius: 999px; font-size: 0.82rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--pg-text-muted); }
.pg-shop-hero__meta span::before { content: '◦'; color: var(--pg-accent); margin-right: 0.5rem; }

/* ===========================================================
   OUR STORY  — editorial split-layout sections
   =========================================================== */
.pg-story { max-width: 1240px; margin: 0 auto; padding: 0 1.5rem clamp(4rem, 8vw, 7rem); }
.pg-story-hero { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; padding: clamp(3.5rem, 6vw, 6rem) 0 clamp(3rem, 5vw, 5rem); }
.pg-story-hero h1 { font-family: var(--pg-serif); font-weight: 500; font-size: clamp(2.2rem, 4.4vw, 3.6rem); line-height: 1.06; letter-spacing: -0.02em; margin: 0.5rem 0 1.2rem; color: var(--pg-text); }
.pg-story-hero p { color: var(--pg-text-muted); font-size: 1.12rem; line-height: 1.65; }
.pg-story-hero__media img { width: 100%; height: 100%; max-height: 560px; object-fit: cover; border-radius: 4px; box-shadow: 0 30px 80px -40px rgba(0,0,0,0.35); }

.pg-story-split { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; padding: clamp(2.5rem, 5vw, 4.5rem) 0; border-top: 1px solid var(--pg-rule); }
.pg-story-split--reverse .pg-story-split__media { order: 2; }
.pg-story-split--reverse .pg-story-split__copy { order: 1; }
.pg-story-split__media img { width: 100%; max-height: 520px; object-fit: cover; border-radius: 4px; box-shadow: 0 20px 60px -30px rgba(0,0,0,0.3); }
.pg-story-split__copy h2 { font-family: var(--pg-serif); font-weight: 500; font-size: clamp(1.8rem, 3.2vw, 2.6rem); line-height: 1.12; letter-spacing: -0.015em; margin: 0.4rem 0 1rem; color: var(--pg-text); }
.pg-story-split__copy p { color: var(--pg-text-muted); font-size: 1.05rem; line-height: 1.65; margin: 0 0 1rem; }

.pg-story-values { padding: clamp(3rem, 6vw, 5rem) 0; border-top: 1px solid var(--pg-rule); }
.pg-story-values__grid { margin-top: 2.5rem; }
.pg-value-card { padding: 2rem; background: var(--pg-bg-alt); border-radius: 4px; }
.pg-value-card h3 { font-family: var(--pg-serif); font-size: 1.45rem; font-weight: 500; margin: 0 0 0.7rem; color: var(--pg-text); }
.pg-value-card p { color: var(--pg-text-muted); font-size: 1rem; line-height: 1.6; margin: 0; }

.pg-story-cta { padding: clamp(3rem, 6vw, 5rem) 1.5rem; text-align: center; background: var(--pg-primary); color: #DCE0DD; border-radius: 4px; margin-top: 3rem; }
.pg-story-cta h2 { font-family: var(--pg-serif); font-weight: 500; font-size: clamp(1.8rem, 3.2vw, 2.6rem); line-height: 1.12; color: #fff; margin: 0 0 1rem; }
.pg-story-cta p { max-width: 36rem; margin: 0 auto 1.8rem; color: rgba(255,255,255,0.78); font-size: 1.05rem; line-height: 1.6; }
.pg-story-cta .pg-btn--solid { background: var(--pg-accent); color: var(--pg-text); }
.pg-story-cta .pg-btn--solid:hover { background: #d4b889; }

@media (max-width: 860px) {
  .pg-story-hero, .pg-story-split { grid-template-columns: 1fr; }
  .pg-story-split--reverse .pg-story-split__media { order: 0; }
  .pg-story-split--reverse .pg-story-split__copy { order: 0; }
}

/* Magazine index — give the feature article more breathing room */
.pg-mag-index { padding-top: 2.5rem; }
