/* ==========================================================================
   NEWS + POST — shared layout
   Used by: news.html, post-*.html
   ========================================================================== */

/* ---------- Page frame ---------- */
body.news,
body.post{
  background:var(--color-cream);
  color:var(--color-forest);
}

/* subtle grain texture for editorial feel */
body.news::before,
body.post::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(65,89,76,.04), transparent 45%),
    radial-gradient(circle at 80% 90%, rgba(155,203,156,.05), transparent 40%);
}

/* ==========================================================================
   NEWS INDEX
   ========================================================================== */

/* ---------- Hero strip ---------- */
.news-hero{
  position:relative;
  padding:calc(var(--nav-h) + 72px) 0 96px;
  background:
    radial-gradient(circle at 22% 30%, rgba(155,203,156,.22), transparent 55%),
    radial-gradient(circle at 88% 16%, rgba(232,231,183,.16), transparent 48%),
    linear-gradient(180deg,#2B3D35 0%, #41594C 100%);
  color:var(--color-cream);
  overflow:hidden;isolation:isolate;
  text-align:center;
}
.news-hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background-image:
    repeating-linear-gradient(135deg, rgba(255,253,250,.03) 0 1px, transparent 1px 64px);
}
.news-hero__inner{
  display:flex;flex-direction:column;align-items:center;gap:22px;
  max-width:var(--rail);margin:0 auto;
}
.news-hero__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:clamp(40px,5vw,80px);
  line-height:1.02;letter-spacing:-.015em;
  text-align:center;
}
.news-hero__title em{
  font-family:var(--title-font);font-weight:var(--title-em-weight);font-style:var(--title-em-style);
  color:var(--color-sage);
}
.news-hero__sub{
  font-size:var(--lede-size);line-height:var(--lede-lh);color:var(--prose-on-dark);
  max-width:var(--measure-lede);margin:0 auto;text-align:center;font-weight:var(--lede-weight);}

/* ---------- Category filter bar — unified glass, matches Ricette ---------- */
/* Static element between hero and featured — no sticky scroll. */
.news-filter{
  position:relative;z-index:2;
  padding:16px 0;margin-top:-40px;
}
.news-filter__wrap{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:6px;
  padding:10px 14px;border-radius:999px;
  background:rgba(43,61,53,.68);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  border:1px solid rgba(255,253,250,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,253,250,.08),
    0 12px 40px rgba(28,40,32,.22);
}
.news-filter__group{
  display:inline-flex;flex-wrap:wrap;align-items:center;gap:4px;
}
.news-filter__chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:999px;
  font-family:var(--font-sans);font-size:13px;font-weight:400;letter-spacing:.01em;
  color:var(--color-cream);background:transparent;
  border:0;cursor:pointer;white-space:nowrap;
  min-height:36px;
  transition:background .25s var(--easing-out),color .25s,transform .25s var(--easing-out);
}
.news-filter__chip:hover{background:rgba(255,253,250,.1)}
.news-filter__chip:focus-visible{
  outline:2px solid rgba(155,203,156,.7);outline-offset:2px;
}
.news-filter__chip.is-active{
  background:var(--color-sage);color:var(--color-forest-900);
  font-weight:500;
}
/* Fallback for browsers without backdrop-filter */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){
  .news-filter__wrap{background:rgba(43,61,53,.92)}
}
/* Mobile — horizontal scroll to avoid cramping */
@media (max-width:760px){
  .news-filter__wrap{
    flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;
    scrollbar-width:none;-ms-overflow-style:none;
    padding:8px 10px;
  }
  .news-filter__wrap::-webkit-scrollbar{display:none}
  .news-filter__group{flex-wrap:nowrap}
  .news-filter__chip{padding:10px 14px;font-size:12.5px}
}

/* ---------- Featured post ---------- */
.news-featured{
  padding:72px 0 56px;position:relative;
}
.news-featured__grid{
  display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center;
}
.news-featured__media{
  position:relative;aspect-ratio:5/4;border-radius:24px;overflow:hidden;
  max-width:100%;
  background:linear-gradient(135deg,#41594C 0%, #2B3D35 60%,#1C2820 100%);
  box-shadow:0 30px 80px -20px rgba(43,61,53,.35);
}
.news-featured__media svg{
  position:absolute;inset:0;width:100%;height:100%;
}
.news-featured__media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;
}
.news-featured__badge{
  position:absolute;top:24px;left:24px;z-index:2;
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;border-radius:999px;
  background:rgba(255,253,250,.94);color:var(--color-forest);
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;font-weight:600;
  backdrop-filter:blur(12px);
}
.news-featured__badge--star::before{
  content:"★";color:#C59A52;font-size:12px;letter-spacing:0;
}
.news-featured__body{
  display:flex;flex-direction:column;justify-content:center;
  padding:0;min-width:0;
}
.news-featured__meta{
  display:flex;align-items:center;gap:14px;margin-bottom:22px;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--color-forest);opacity:.6;font-weight:500;
}
.news-featured__meta span::after{
  content:"·";margin-left:14px;opacity:.5;
}
.news-featured__meta span:last-child::after{content:none}
.news-featured__cat{
  color:var(--color-forest-900) !important;opacity:1 !important;
  background:rgba(155,203,156,.24);padding:6px 12px;border-radius:999px;
  letter-spacing:.18em;
}
.news-featured__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:clamp(36px,3.8vw,56px);line-height:1.05;letter-spacing:-.015em;
  color:var(--color-forest-900);margin-bottom:20px;
}
.news-featured__title em{font-style:italic;color:var(--color-forest)}
.news-featured__excerpt{
  font-size:var(--body-size);line-height:var(--body-lh);color:var(--prose-ink);
  opacity:.82;max-width:540px;margin-bottom:32px;font-weight:var(--body-weight);}
.news-featured__cta{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 28px;border-radius:999px;
  background:var(--color-forest);color:var(--color-cream);
  text-decoration:none;font-size:13px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  transition:background .25s var(--easing-out),transform .25s;
  align-self:flex-start;
}
.news-featured__cta:hover{background:var(--color-forest-900);transform:translateX(3px)}
.news-featured__cta svg{transition:transform .25s}
.news-featured__cta:hover svg{transform:translateX(4px)}

/* ---------- Grid section ---------- */
.news-grid-wrap{
  padding:56px 0 120px;position:relative;
}
.news-grid-head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:40px;
  margin-bottom:48px;flex-wrap:wrap;
}
.news-grid-head__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:clamp(32px,3.2vw,48px);line-height:1;letter-spacing:-.01em;
  color:var(--color-forest-900);
}
.news-grid-head__title em{font-style:italic;color:var(--color-forest)}
.news-grid-head__meta{
  font-size:13px;color:var(--color-forest);opacity:.6;
  letter-spacing:.06em;
}

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

/* ---------- Post card — matches Ricette card aesthetic ---------- */
.post-card{
  display:flex;flex-direction:column;text-decoration:none;color:inherit;
  background:var(--color-cream);border-radius:22px;overflow:hidden;
  border:1px solid rgba(65,89,76,.08);
  transition:transform .4s var(--easing-out),box-shadow .4s,border-color .3s;
}
.post-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 60px -16px rgba(43,61,53,.22);
  border-color:rgba(65,89,76,.18);
}
.post-card__media{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  background:linear-gradient(135deg,#41594C 0%,#2B3D35 60%,#1C2820 100%);
  margin-bottom:0;box-shadow:none;border-radius:0;
}
.post-card__media svg,
.post-card__media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s var(--easing-out);
}
.post-card:hover .post-card__media img{transform:scale(1.04)}
.post-card:hover .post-card__media svg{transform:scale(1.04)}
.post-card__media::after{display:none}
.post-card__chip{
  position:absolute;top:14px;left:14px;bottom:auto;
  padding:6px 12px;border-radius:999px;
  background:rgba(255,253,250,.92);color:var(--color-forest-900);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  backdrop-filter:blur(10px);
}
.post-card__meta{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--color-forest);opacity:.55;font-weight:500;
  padding:22px 24px 0;
}
.post-card__title{
  font-family:var(--font-sans);font-weight:700;
  font-size:20px;line-height:1.25;letter-spacing:-.005em;
  color:var(--color-forest-900);margin:10px 0 10px;
  padding:0 24px;
}
.post-card__title em{font-style:italic;font-weight:700;color:var(--color-sage-700)}
.post-card__excerpt{
  font-family:var(--font-sans);font-size:var(--body-sm-size);line-height:var(--body-sm-lh);
  color:var(--prose-ink);opacity:.82;
  padding:0 24px;margin-bottom:18px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;font-weight:var(--body-sm-weight);}
.post-card__read{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--color-forest-900);font-weight:600;
  display:inline-flex;align-items:center;gap:8px;
  margin-top:auto;padding:0 24px 26px;
}
.post-card__read::after{
  content:"→";transition:transform .25s var(--easing-out);
}
.post-card:hover .post-card__read::after{transform:translateX(4px)}

/* Variant — small "compact" card used at the bottom of post pages */
.post-card--compact .post-card__media{aspect-ratio:4/3}
.post-card--compact .post-card__title{font-size:18px}
.post-card--compact .post-card__excerpt{display:none}

/* ---------- Newsletter band ---------- */
.news-newsletter{
  margin:80px 0 0;padding:72px 0;
  background:
    radial-gradient(circle at 20% 50%, rgba(155,203,156,.3), transparent 50%),
    linear-gradient(135deg,#41594C 0%,#2B3D35 100%);
  color:var(--color-cream);
  position:relative;overflow:hidden;
}
.news-newsletter::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, rgba(255,253,250,.02) 0 1px, transparent 1px 40px);
  pointer-events:none;
}
.news-newsletter__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  position:relative;
}
.news-newsletter__label{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,253,250,.6);margin-bottom:18px;font-weight:500;
}
.news-newsletter__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:clamp(34px,3.4vw,52px);line-height:1.05;letter-spacing:-.015em;
}
.news-newsletter__title em{font-style:italic;color:var(--color-sage)}
.news-newsletter__text{
  font-size:var(--body-size);line-height:var(--body-lh);color:var(--prose-on-dark);
  margin-top:18px;max-width:440px;font-weight:var(--body-weight);}
.news-newsletter__form{
  display:flex;gap:10px;align-items:stretch;
  padding:8px;border-radius:999px;
  background:rgba(255,253,250,.08);
  border:1px solid rgba(255,253,250,.18);
  backdrop-filter:blur(12px);
}
.news-newsletter__form input{
  flex:1;background:transparent;border:0;outline:0;
  color:var(--color-cream);padding:0 20px;font-size:15px;
  font-family:inherit;
}
.news-newsletter__form input::placeholder{color:rgba(255,253,250,.45)}
.news-newsletter__form button{
  padding:14px 28px;border-radius:999px;border:0;cursor:pointer;
  background:var(--color-cream);color:var(--color-forest-900);
  font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  transition:background .25s var(--easing-out);
  font-family:inherit;
}
.news-newsletter__form button:hover{background:var(--color-sage)}

/* Testi di testa centrati (equilibrio col form centrato) */
.news-newsletter__inner{text-align:center;}
.news-newsletter__eyebrow,
.news-newsletter__label,
.news-newsletter__title,
.news-newsletter__sub,
.news-newsletter__text{text-align:center;font-size:var(--body-size);line-height:var(--body-lh);font-weight:var(--body-weight);}
.news-newsletter__sub,
.news-newsletter__text{margin-left:auto;margin-right:auto;font-size:var(--body-size);line-height:var(--body-lh);font-weight:var(--body-weight);}

/* ──────────────────────────────────────────────────────────────
   Fluent Forms dentro della sezione newsletter (tema scuro NVI).
   Allinea il form (input/label/bottone) alla palette verde.
   ────────────────────────────────────────────────────────────── */
.news-newsletter .fluentform{max-width:760px;margin:26px auto 0;position:relative;}
/* Nasconde titolo/descrizione propri del form: la sezione ha già i suoi */
.news-newsletter .ff-form-title,
.news-newsletter .ff_form_title,
.news-newsletter .ff-section-break,
.news-newsletter .ff-el-section-break{display:none !important;}
.news-newsletter .ff-el-group{margin-bottom:16px;}
/* Label */
.news-newsletter .ff-el-input--label label,
.news-newsletter .ff-el-input--label{
  color:rgba(255,253,250,.85) !important;font-family:var(--font-sans);
  font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
}
.news-newsletter .ff-el-input--label .text-danger{color:var(--color-sage);}
.news-newsletter .ff-el-tooltip{display:none !important;}
/* Campi input/email */
.news-newsletter .ff-el-form-control,
.news-newsletter input[type="text"],
.news-newsletter input[type="email"]{
  width:100% !important;background:rgba(255,253,250,.10) !important;
  border:1px solid rgba(255,253,250,.22) !important;border-radius:12px !important;
  color:var(--color-cream) !important;padding:14px 16px !important;
  font-family:inherit !important;font-size:15px !important;box-shadow:none !important;
  min-height:52px;
}
.news-newsletter .ff-el-form-control::placeholder{color:rgba(255,253,250,.45) !important;}
.news-newsletter .ff-el-form-control:focus{
  outline:none !important;border-color:var(--color-sage) !important;
  background:rgba(255,253,250,.15) !important;
}
/* Bottone Subscribe → palette NVI (sovrascrive lo stile inline del form) */
.news-newsletter .ff-btn-submit,
.news-newsletter button.ff-btn,
.news-newsletter .ff_submit_btn_wrapper button{
  background:var(--color-cream) !important;color:var(--color-forest-900) !important;
  border:0 !important;border-radius:999px !important;padding:14px 32px !important;cursor:pointer;
  font-family:inherit !important;font-size:12px !important;font-weight:600 !important;
  letter-spacing:.14em !important;text-transform:uppercase !important;box-shadow:none !important;
  transition:background .25s ease,transform .25s ease;
}
.news-newsletter .ff-btn-submit:hover,
.news-newsletter button.ff-btn:hover{background:var(--color-sage) !important;transform:translateY(-1px);}

/* Reset dell'allineamento: la sezione centra i testi di testa, ma il FORM
   deve restare allineato a sinistra (label sopra il campo, a sinistra). */
.news-newsletter .fluentform{text-align:left;}
.news-newsletter .ff-el-input--label{margin-bottom:8px;}
.news-newsletter .ff-el-input--label label{display:block;text-align:left;}
/* Submit: per default a destra, sotto i campi */
.news-newsletter .ff_submit_btn_wrapper,
.news-newsletter .ff-el-group.ff_submit_btn_wrapper{
  text-align:right;display:flex;justify-content:flex-end;align-items:flex-end;margin-top:4px;
}
/* Se l'Email e il bottone Subscribe sono vicini, mettili sulla STESSA riga
   (Email cresce, bottone a destra). Progressive enhancement con :has(). */
.news-newsletter .fluentform form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:16px 18px;}
.news-newsletter .fluentform form > .ff-el-group{flex:0 0 100%;margin:0;}
.news-newsletter .fluentform form > .ff-el-group:has(input[type="email"]){flex:1 1 60%;}
.news-newsletter .fluentform form > .ff-el-group:has(.ff-btn-submit){flex:0 0 auto;}
.news-newsletter .fluentform form > .ff-message-success{flex:0 0 100%;}
/* Messaggi */
.news-newsletter .ff-message-success{color:var(--color-sage-300,#C3DFC4) !important;}
.news-newsletter .ff-el-is-error .text-danger,
.news-newsletter .error.text-danger{color:#F2C6B4 !important;}

/* ==========================================================================
   POST DETAIL
   ========================================================================== */

/* ---------- Post header ---------- */
.post-hero{
  position:relative;
  padding:calc(var(--nav-h) + 32px) 0 72px;
  background:
    radial-gradient(circle at 22% 30%, rgba(155,203,156,.22), transparent 55%),
    radial-gradient(circle at 88% 16%, rgba(232,231,183,.14), transparent 48%),
    linear-gradient(180deg,#2B3D35 0%, #41594C 100%);
  color:var(--color-cream);
  overflow:hidden;isolation:isolate;
  text-align:center;
}
.post-hero > .container{
  display:flex;flex-direction:column;align-items:center;
  max-width:var(--rail);
}
.post-hero__crumbs{
  display:inline-flex;align-items:center;gap:10px;justify-content:center;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,253,250,.6);margin-bottom:22px;font-weight:500;
}
.post-hero__crumbs a{color:inherit;text-decoration:none}
.post-hero__crumbs a:hover{color:var(--color-sage)}
.post-hero__crumbs span{opacity:.4}
.post-hero__cat{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:rgba(155,203,156,.24);color:var(--color-sage);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  margin-bottom:20px;
}
.post-hero__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:clamp(34px,4.2vw,64px);line-height:1.04;letter-spacing:-.015em;
  max-width:var(--measure-display-wide);text-align:center;
}
.post-hero__title em{font-style:italic;color:var(--color-sage)}
.post-hero__deck{
  font-size:var(--lede-size);line-height:var(--lede-lh);color:var(--prose-on-dark);
  max-width:var(--measure-lede);margin:20px auto 0;text-align:center;font-weight:var(--lede-weight);}
.post-hero__meta{
  display:flex;align-items:center;justify-content:center;gap:20px 28px;
  margin:28px auto 0;flex-wrap:wrap;
  padding-top:22px;border-top:1px solid rgba(255,253,250,.12);
  width:100%;max-width:720px;
}
.post-hero__author{
  display:flex;align-items:center;gap:12px;
}
.post-hero__avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#9BCB9C,#41594C);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:600;color:var(--color-cream);
  letter-spacing:.04em;flex:none;
}
.post-hero__author-info{
  display:flex;flex-direction:column;line-height:1.3;text-align:left;
}
.post-hero__author-name{font-size:13.5px;font-weight:500;color:var(--color-cream)}
.post-hero__author-role{font-size:12px;color:rgba(255,253,250,.6);letter-spacing:.04em}
.post-hero__info{
  display:flex;gap:20px;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,253,250,.6);flex-wrap:wrap;justify-content:center;
}

/* ---------- Feature image ---------- */
.post-feature{
  margin:0 auto;max-width:var(--container);padding:0 24px;
  margin-top:-28px;position:relative;z-index:2;
}
.post-feature__frame{
  aspect-ratio:16/7;border-radius:24px;overflow:hidden;position:relative;
  background:linear-gradient(135deg,#2B3D35,#41594C);
  box-shadow:0 40px 100px -30px rgba(43,61,53,.5);
}
.post-feature__frame svg{position:absolute;inset:0;width:100%;height:100%}
.post-feature__caption{
  font-size:12px;letter-spacing:.14em;color:var(--color-forest);opacity:.55;
  margin-top:18px;text-align:center;font-style:italic;
}

/* ---------- Article ---------- */
.post-article{
  padding:80px 0 60px;position:relative;
}
.post-article__grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,720px) minmax(0,1fr);
  gap:0 40px;
}
.post-article__rail{
  position:relative;padding-top:12px;
}
.post-article__rail-sticky{
  position:sticky;top:calc(var(--nav-h) + 32px);
  display:flex;flex-direction:column;gap:18px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--color-forest);opacity:.6;font-weight:500;
}
.post-article__rail-sticky a{
  display:flex;align-items:center;gap:10px;
  color:var(--color-forest);text-decoration:none;
  width:40px;height:40px;border-radius:50%;
  background:rgba(65,89,76,.06);justify-content:center;
  transition:background .25s var(--easing-out);
}
.post-article__rail-sticky a:hover{background:rgba(65,89,76,.14)}
.post-article__rail-sticky svg{width:16px;height:16px}

.post-article__body{
  grid-column:2;
  font-size:18px;line-height:1.75;color:var(--color-forest);
}
.post-article__body > *{margin-bottom:1.4em}
.post-article__body p{
  font-size:18px;line-height:1.75;color:var(--color-forest-900);opacity:.9;
}
.post-article__body p:first-of-type::first-letter{
  font-family:var(--font-display);font-size:4.5em;
  float:left;line-height:.85;padding-right:14px;padding-top:6px;
  color:var(--color-forest);font-style:italic;
}
.post-article__body h2{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:clamp(28px,2.6vw,40px);line-height:1.18;letter-spacing:-.01em;
  color:var(--color-forest-900);margin-top:2em;margin-bottom:.6em;
}
.post-article__body h2 em{
  font-family:var(--title-font);font-weight:var(--title-em-weight);font-style:var(--title-em-style);
  color:var(--color-forest);
}
.post-article__body h3{
  font-family:var(--font-sans);font-weight:600;
  font-size:19px;line-height:1.3;letter-spacing:.02em;
  color:var(--color-forest-900);margin-top:2em;margin-bottom:.4em;
  text-transform:uppercase;letter-spacing:.08em;
}
.post-article__body ul,
.post-article__body ol{padding-left:0;list-style:none}
.post-article__body li{
  position:relative;padding:6px 0 6px 28px;
  color:var(--color-forest-900);opacity:.9;
}
.post-article__body ul li::before{
  content:"";position:absolute;left:0;top:18px;
  width:10px;height:1px;background:var(--color-forest);
}
.post-article__body ol{counter-reset:item}
.post-article__body ol li::before{
  counter-increment:item;content:counter(item,decimal-leading-zero);
  position:absolute;left:0;top:8px;
  font-family:var(--font-display);font-style:italic;
  font-size:14px;color:var(--color-forest);opacity:.6;
}
.post-article__body blockquote{
  margin:2.2em 0;padding:28px 36px;
  border-left:3px solid var(--color-forest);
  background:linear-gradient(90deg, rgba(155,203,156,.12), transparent);
  font-family:var(--font-display);font-style:italic;font-weight:400;
  font-size:24px;line-height:1.35;color:var(--color-forest-900);
  letter-spacing:-.005em;
}
.post-article__body blockquote cite{
  display:block;margin-top:16px;font-family:var(--font-sans);font-style:normal;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--color-forest);opacity:.65;font-weight:500;
}
.post-article__body strong{color:var(--color-forest-900);font-weight:600}
.post-article__body a:not(.post-article__pill){
  color:var(--color-forest-900);text-decoration:underline;
  text-decoration-thickness:1px;text-underline-offset:3px;
  text-decoration-color:rgba(65,89,76,.35);
  transition:text-decoration-color .25s;
}
.post-article__body a:not(.post-article__pill):hover{
  text-decoration-color:var(--color-forest);
}

/* inline figure */
.post-figure{
  margin:2.2em 0;
}
.post-figure__frame{
  aspect-ratio:16/10;border-radius:20px;overflow:hidden;position:relative;
  background:linear-gradient(135deg,#41594C,#2B3D35);
}
.post-figure__frame svg{position:absolute;inset:0;width:100%;height:100%}
.post-figure figcaption{
  font-size:13px;letter-spacing:.08em;color:var(--color-forest);opacity:.6;
  margin-top:14px;font-style:italic;text-align:center;
}

/* Stat cluster */
.post-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin:2.4em 0;padding:32px;
  background:rgba(155,203,156,.1);
  border:1px solid rgba(65,89,76,.08);
  border-radius:20px;
}
.post-stats__item{text-align:center}
.post-stats__num{
  font-family:var(--font-display);font-weight:400;
  font-size:42px;line-height:1;color:var(--color-forest-900);
  letter-spacing:-.02em;
}
.post-stats__num em{font-style:italic;color:var(--color-forest)}
.post-stats__label{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--color-forest);opacity:.7;margin-top:10px;font-weight:500;
}

/* Tags */
.post-tags{
  margin:3em 0 1em;padding-top:32px;
  border-top:1px solid rgba(65,89,76,.15);
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
}
.post-tags__label{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--color-forest);opacity:.55;margin-right:8px;font-weight:500;
}
.post-tags a{
  padding:8px 16px;border-radius:999px;
  background:rgba(65,89,76,.06);color:var(--color-forest-900);
  font-size:12px;letter-spacing:.06em;text-decoration:none;
  transition:background .25s var(--easing-out);
}
.post-tags a:hover{background:rgba(155,203,156,.22)}

/* Share bar at end */
.post-share{
  display:flex;align-items:center;gap:16px;
  margin:2em 0 0;padding:20px 28px;border-radius:16px;
  background:rgba(65,89,76,.04);
}
.post-share__label{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--color-forest);opacity:.65;font-weight:500;
}
.post-share__links{display:flex;gap:10px;margin-left:auto}
.post-share__links a{
  width:38px;height:38px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--color-cream);color:var(--color-forest);
  text-decoration:none;transition:background .25s,color .25s;
}
.post-share__links a:hover{background:var(--color-forest);color:var(--color-cream)}
.post-share__links svg{width:15px;height:15px}

/* ---------- Related ---------- */
.post-related{
  padding:80px 0 100px;
  border-top:1px solid rgba(65,89,76,.1);
  margin-top:40px;
}
.post-related__head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:40px;
  margin-bottom:44px;flex-wrap:wrap;
}
.post-related__title{
  font-family:var(--title-font);font-weight:var(--title-weight);
  font-size:clamp(28px,2.8vw,40px);line-height:1;letter-spacing:-.01em;
  color:var(--color-forest-900);
}
.post-related__title em{font-style:italic;color:var(--color-forest)}
.post-related__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px 24px;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1024px){
  .news-featured__grid{grid-template-columns:1fr;gap:36px}
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .news-newsletter__grid{grid-template-columns:1fr;gap:30px}
  .post-article__grid{grid-template-columns:1fr;gap:0}
  .post-article__rail{display:none}
  .post-article__body{grid-column:1}
  .post-related__grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:640px){
  .news-hero{padding:calc(var(--nav-h) + 40px) 0 72px}
  .news-hero__title{font-size:clamp(36px,9vw,56px)}
  .news-featured{padding:40px 0 32px}
  .news-featured__title{font-size:32px}
  .news-grid-wrap{padding:32px 0 72px}
  .news-grid{grid-template-columns:1fr;gap:36px}
  .news-newsletter{padding:56px 0;margin-top:40px}
  .news-newsletter__form{flex-direction:column;border-radius:20px}
  .news-newsletter__form button{padding:14px}

  .post-hero{padding:calc(var(--nav-h) + 24px) 0 56px}
  .post-hero__title{font-size:clamp(30px,7.5vw,44px)}
  .post-hero__deck{font-size:15.5px}
  .post-hero__meta{gap:14px 20px;padding-top:18px;margin-top:22px}
  .post-hero__info{gap:14px;font-size:11px}
  .post-feature{margin-top:-20px}
  .post-feature__frame{aspect-ratio:4/3;border-radius:18px}
  .post-article{padding:48px 0 40px}
  .post-article__body{font-size:16px}
  .post-article__body p{font-size:16px;line-height:1.7}
  .post-article__body p:first-of-type::first-letter{font-size:3.6em}
  .post-stats{grid-template-columns:1fr;padding:24px}
  .post-related__grid{grid-template-columns:1fr}
}
