/* ============================================================
   AiDEX - Section components (added on top of styles.css)
   About snapshot · Sustainability · Products · Contact CTA ·
   Policy library · Insights cards · Forms · Map · Page header
   ============================================================ */

/* ---------- shared section head ---------- */
.sec-head{ max-width:var(--maxw); }
.sec-head .index{ display:block; margin-bottom:1.4rem; }
.sec-title{ font-family:var(--font-display); font-weight:340; font-size:var(--step-3); line-height:1.05; letter-spacing:-0.02em; max-width:20ch; }
.sec-intro{ margin-top:1.4rem; font-size:var(--step-1); color:var(--cream-2); max-width:48ch; }
.link-arrow{ display:inline-flex; align-items:center; gap:0.55em; font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.12em; text-transform:uppercase; color:var(--cream); border-bottom:1px solid var(--line); padding-bottom:0.35em; transition:color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.link-arrow:hover{ color:var(--gold); border-color:var(--gold); }
.link-arrow .arr{ transition:transform var(--dur) var(--ease); }
.link-arrow:hover .arr{ transform:translateX(3px); }

/* ============================================================
   01 · ABOUT snapshot
   ============================================================ */
.about-snap{ border-top:1px solid var(--line); padding-block:clamp(3.5rem,6vw,6rem); }
.about-snap__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,5vw,5rem); align-items:center; }
.about-snap__title{ font-family:var(--font-display); font-weight:340; color:var(--cream); font-size:clamp(2.5rem,5vw,4rem); line-height:1.04; letter-spacing:-0.02em; max-width:14ch; }
.about-snap__text{ margin-top:1.6rem; font-size:1.3rem; line-height:1.5; color:var(--cream-2); max-width:46ch; }
.about-snap__text b{ font-weight:inherit; color:var(--gold); }
.about-snap__lead .link-arrow{ margin-top:2rem; }
.about-steps{ display:flex; flex-direction:column; border-top:1px solid var(--line); }
.about-step{ display:flex; gap:1.3rem; padding:1.25rem 0; border-bottom:1px solid var(--line); align-items:baseline; }
.about-step__no{ font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.1em; color:var(--gold); flex:none; }
.about-step__name{ font-family:var(--font-display); font-weight:360; font-size:var(--step-1); line-height:1.1; color:var(--cream); }
.about-step__body p{ margin-top:0.35rem; font-size:var(--step-0); color:var(--moss); line-height:1.5; }
@media (max-width:820px){ .about-snap__grid{ grid-template-columns:1fr; gap:2.6rem; } .about-snap__text{ font-size:1.15rem; } }

/* ============================================================
   03 · SUSTAINABILITY
   ============================================================ */
.sustain{ background:var(--forest); border-top:1px solid var(--line); }
.sustain__blocks{
  margin-top:clamp(2.5rem,5vw,4rem);
  display:grid; grid-template-columns:1fr 1fr;
  border-top:1px solid var(--line); border-left:1px solid var(--line);
}
.s-block{ padding:clamp(1.8rem,3vw,2.6rem); border-right:1px solid var(--line); border-bottom:1px solid var(--line); }
.s-block__kicker{ font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); display:flex; align-items:baseline; gap:0.8em; }
.s-block__kicker span{ color:var(--moss); }
.s-block__title{ font-family:var(--font-display); font-weight:360; font-size:var(--step-2); margin:0.7rem 0 0.8rem; line-height:1.1; }
.s-block p{ color:var(--cream-2); font-size:var(--step-0); }
.sustain__foot{ margin-top:2.4rem; }
@media (max-width:720px){ .sustain__blocks{ grid-template-columns:1fr; } }

/* ============================================================
   04 · PRODUCTS grid (landing) + shared product card
   ============================================================ */
.products{ border-top:1px solid var(--line); }
.facility-band{ aspect-ratio:21/9; border:1px solid var(--line); border-radius:4px; overflow:hidden; background:var(--forest-deep); margin-top:clamp(2rem,4vw,3rem); }
.facility-band img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.88) brightness(0.9) contrast(1.02); }
.facility-band .card__ph{ height:100%; }
@media (max-width:560px){ .facility-band{ aspect-ratio:16/10; } }
/* Section-header media band: image behind the header text, like the hero */
.sechdr{ position:relative; isolation:isolate; overflow:hidden; border-radius:6px; border:1px solid var(--line); margin-top:clamp(1.6rem,3vw,2.4rem); padding:clamp(3.2rem,8vw,6.5rem) clamp(1.5rem,4vw,3.2rem); }
.sechdr__media{ position:absolute; inset:0; z-index:-2; }
.sechdr__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.8) brightness(0.55) contrast(1.05); }
.sechdr__overlay{ position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg,rgba(14,42,28,0.78),rgba(14,42,28,0.9)); }
.sechdr .index{ display:block; margin-bottom:1.3rem; }
.sechdr .sec-title{ max-width:22ch; }

.prod-group{ margin-top:clamp(2.5rem,5vw,3.5rem); }
.prod-group__label{
  display:flex; align-items:center; gap:1rem; margin-bottom:1.8rem;
  font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.16em; text-transform:uppercase; color:var(--moss);
}
.prod-group__label::after{ content:""; flex:1; height:1px; background:var(--line); }

.prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2vw,1.6rem); }
.prod-grid--2{ grid-template-columns:repeat(2,1fr); max-width:840px; }
@media (max-width:860px){ .prod-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .prod-grid,.prod-grid--2{ grid-template-columns:1fr; } }

.card{ display:flex; flex-direction:column; background:var(--forest); border:1px solid var(--line); border-radius:4px; overflow:hidden; transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.card:hover{ border-color:rgba(224,181,74,0.5); transform:translateY(-2px); }
.card__media{ position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--forest-deep); }
.card__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.86) brightness(0.9) contrast(1.02); transition:transform 620ms var(--ease); }
.card:hover .card__media img{ transform:scale(1.04); }
.card__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(14,42,28,0) 55%,rgba(14,42,28,0.45)); pointer-events:none; }
.card__ph{ display:flex; align-items:center; justify-content:center; height:100%; background:linear-gradient(135deg,var(--forest),var(--forest-deep)); color:var(--moss); font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.14em; text-transform:uppercase; }
.card__body{ padding:1.3rem 1.4rem 1.5rem; display:flex; flex-direction:column; gap:0.5rem; flex:1; }
.card__name{ font-family:var(--font-display); font-weight:380; font-size:var(--step-1); line-height:1.1; }
.card__spec{ font-size:var(--step--1); color:var(--moss); line-height:1.5; flex:1; }
.card__link{ margin-top:0.7rem; font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--cream); display:inline-flex; align-items:center; gap:0.5em; }
.card:hover .card__link{ color:var(--gold); }
.card__link .arr{ transition:transform var(--dur) var(--ease); }
.card:hover .card__link .arr{ transform:translateX(3px); }

/* ============================================================
   CONTACT CTA band
   ============================================================ */
.cta-band{ position:relative; isolation:isolate; overflow:hidden; border-top:1px solid var(--line); }
.cta-band__media{ position:absolute; inset:0; z-index:-2; }
.cta-band__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.8) brightness(0.5) contrast(1.05); }
.cta-band__overlay{ position:absolute; inset:0; z-index:-1; background:linear-gradient(90deg,rgba(14,42,28,0.92),rgba(14,42,28,0.6)); }
.cta-band__inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:2rem; }
.cta-band__title{ font-family:var(--font-display); font-weight:340; font-size:var(--step-3); line-height:1.08; letter-spacing:-0.02em; max-width:18ch; }

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.page-head{ padding-top:clamp(8rem,12vh,11rem); padding-bottom:var(--section-y); border-bottom:1px solid var(--line); }
.page-head--media{ position:relative; isolation:isolate; overflow:hidden; }
.page-head__media{ position:absolute; inset:0; z-index:-2; }
.page-head__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.8) brightness(0.4) contrast(1.05); }
.page-head__overlay{ position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg,rgba(14,42,28,0.82),rgba(14,42,28,0.93)); }
.page-head .index{ display:block; margin-bottom:1.4rem; }
.page-head h1{ font-family:var(--font-display); font-weight:330; font-size:var(--display); line-height:1.02; letter-spacing:-0.02em; max-width:16ch; }
.page-head p{ margin-top:1.6rem; font-size:var(--step-1); color:var(--cream-2); max-width:52ch; }
@media (max-width:720px){
  /* trim the large vertical void between the media header and the content below it */
  .page-head{ padding-top:6.5rem; padding-bottom:2.25rem; }
}

/* ============================================================
   POLICY library (compliance page)
   ============================================================ */
.policy-list{ border-top:1px solid var(--line); }
.policy{ display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1rem,3vw,2.5rem); align-items:baseline; padding:clamp(1.6rem,3vw,2.2rem) 0; border-bottom:1px solid var(--line); transition:background var(--dur) var(--ease); }
.policy:hover{ background:rgba(242,238,227,0.02); }
.policy__no{ font-family:var(--font-mono); font-size:var(--step--1); color:var(--gold); letter-spacing:0.1em; padding-top:0.4em; }
.policy__title{ font-family:var(--font-display); font-weight:360; font-size:var(--step-2); line-height:1.1; }
.policy__sum{ margin-top:0.6rem; color:var(--cream-2); font-size:var(--step-0); max-width:62ch; }
.policy__meta{ margin-top:0.5rem; font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; color:var(--moss); }
.policy__dl{ white-space:nowrap; }
@media (max-width:760px){ .policy{ grid-template-columns:auto 1fr; } .policy__dl{ grid-column:2; justify-self:start; margin-top:0.8rem; } }

/* ============================================================
   PRODUCT detail blocks (products page)
   ============================================================ */
.pdetail{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; padding-block:var(--section-y); border-bottom:1px solid var(--line); }
.pdetail:nth-child(even) .pdetail__media{ order:2; }
.pdetail__media{ aspect-ratio:4/3; border-radius:4px; overflow:hidden; border:1px solid var(--line); background:var(--forest-deep); }
.pdetail__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.88) brightness(0.92) contrast(1.02); }
.pdetail__no{ font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); }
.pdetail__name{ font-family:var(--font-display); font-weight:340; font-size:var(--step-3); line-height:1.05; margin:0.8rem 0 0.6rem; letter-spacing:-0.02em; }
.pdetail__pos{ color:var(--cream-2); font-size:var(--step-1); margin-bottom:1.6rem; max-width:46ch; }
.spec{ border-top:1px solid var(--line); margin-bottom:1.8rem; }
.spec div{ display:flex; justify-content:space-between; gap:1.5rem; padding:0.7rem 0; border-bottom:1px solid var(--line); font-size:var(--step-0); }
.spec dt{ color:var(--moss); font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.06em; text-transform:uppercase; }
.spec dd{ margin:0; color:var(--cream); text-align:right; }
@media (max-width:820px){ .pdetail{ grid-template-columns:1fr; gap:2rem; } .pdetail:nth-child(even) .pdetail__media{ order:0; } }

/* ============================================================
   INSIGHTS cards (blog index + landing preview)
   ============================================================ */
.insights{ border-top:1px solid var(--line); }
.art-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,2.5vw,2rem); margin-top:clamp(2.5rem,5vw,3.5rem); }
@media (max-width:860px){ .art-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .art-grid{ grid-template-columns:1fr; } }
.art-card{ display:flex; flex-direction:column; }
.art-card__media{ aspect-ratio:3/2; border-radius:4px; overflow:hidden; border:1px solid var(--line); background:var(--forest); margin-bottom:1.1rem; }
.art-card__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.85) brightness(0.85); transition:transform 620ms var(--ease); }
.art-card:hover .art-card__media img{ transform:scale(1.04); }
.art-card__cat{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); }
.art-card__title{ font-family:var(--font-display); font-weight:360; font-size:var(--step-1); line-height:1.15; margin:0.6rem 0; transition:color var(--dur) var(--ease); }
.art-card:hover .art-card__title{ color:var(--gold); }
.art-card__excerpt{ color:var(--moss); font-size:var(--step-0); }
.art-card__date{ margin-top:0.7rem; font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; color:var(--moss); }

/* ============================================================
   FORM
   ============================================================ */
.form{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem 1.6rem; }
.field{ display:flex; flex-direction:column; gap:0.5rem; }
.field--full{ grid-column:1 / -1; }
.field label{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--moss); }
.field label .req{ color:var(--gold); }
.field input,.field select,.field textarea{
  background:transparent; border:0; border-bottom:1px solid var(--line); color:var(--cream);
  padding:0.7rem 0; font-size:var(--step-0); border-radius:0;
  transition:border-color var(--dur) var(--ease);
}
.field textarea{ resize:vertical; min-height:120px; }
.field select option{ background:var(--forest-deep); color:var(--cream); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-bottom-color:var(--gold); }
.field input:invalid:not(:placeholder-shown){ border-bottom-color:var(--rust); }
.form__actions{ grid-column:1 / -1; display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; margin-top:0.5rem; }
.form__status{ font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.06em; }
.form__status.is-ok{ color:var(--gold); }
.form__status.is-err{ color:var(--rust); }
@media (max-width:620px){
  .form{ grid-template-columns:1fr; }
  .form__actions{ flex-direction:column; align-items:stretch; gap:1rem; }
  .form__actions .btn{ width:100%; justify-content:center; }
}

/* ---- contact meta ---- */
.contact-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:clamp(2rem,5vw,4.5rem); }
.contact-meta h3{ font-family:var(--font-mono); font-weight:500; font-size:var(--step--1); letter-spacing:0.16em; text-transform:uppercase; color:var(--moss); margin:2rem 0 0.9rem; }
.contact-meta h3:first-child{ margin-top:0; }
.contact-meta a{ color:var(--cream); border-bottom:1px solid var(--line); }
.contact-meta a:hover{ color:var(--gold); border-color:var(--gold); }
.contact-meta address{ font-style:normal; line-height:1.8; color:var(--cream-2); }
@media (max-width:820px){ .contact-grid{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTPRINT MAP (05 · REACH)
   Self-contained inline SVG (in index.html). All content lives
   in the markup and paints with JS and CSS animation disabled.
   ============================================================ */
.reach{ background:var(--forest-deep); border-top:1px solid var(--line); }

/* bordered panel, forest-deep ground, hairline */
.reach__map{ position:relative; margin-top:clamp(2rem,4vw,3rem); border:1px solid var(--line); border-radius:4px; background:var(--forest-deep); overflow:hidden; padding:clamp(1rem,3vw,2.4rem); }
.map-svg{ width:100%; height:auto; display:block; }

/* optional lane draw-in: enhancement only, disabled under reduced motion
   and harmless without it (base lanes are fully drawn) */
@media (prefers-reduced-motion: no-preference){
  .map-svg .lane{ stroke-dasharray:340; stroke-dashoffset:340; animation:lane-draw 1.3s var(--ease) forwards; }
  .map-svg .lane:nth-of-type(2){ animation-delay:0.10s; }
  .map-svg .lane:nth-of-type(3){ animation-delay:0.20s; }
  .map-svg .lane:nth-of-type(4){ animation-delay:0.30s; }
  .map-svg .lane:nth-of-type(5){ animation-delay:0.40s; }
  .map-svg .lane:nth-of-type(6){ animation-delay:0.50s; }
  .map-svg .lane:nth-of-type(7){ animation-delay:0.60s; }
  @keyframes lane-draw{ to{ stroke-dashoffset:0; } }
}

/* markets caption (full 28-name list intentionally omitted; anchors are labelled on the map) */
.reach__statline{ margin-top:clamp(1.6rem,3vw,2.4rem); padding-top:1.3rem; border-top:1px solid var(--line); font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.14em; text-transform:uppercase; color:var(--moss); }

/* social / linkedin */
.social{ display:inline-flex; align-items:center; gap:0.5em; color:var(--cream); transition:color var(--dur) var(--ease); }
.social:hover{ color:var(--gold); }
.social svg{ width:18px; height:18px; }
.nav__social{ display:inline-flex; align-items:center; color:var(--cream); opacity:0.86; }
.nav__social:hover{ color:var(--gold); opacity:1; }
@media (max-width:900px){ .nav__cta .nav__social{ display:none; } }

/* ============================================================
   ABOUT PAGE (B2B story)
   ============================================================ */
.about-story{ display:grid; grid-template-columns:1.15fr 0.85fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.about-story__text > * + *{ margin-top:1.4rem; }
.about-story__lead{ font-family:var(--font-display); font-weight:340; font-size:clamp(1.3rem,1rem+1vw,1.7rem); line-height:1.42; letter-spacing:-0.01em; color:var(--cream); max-width:48ch; }
.about-story__text p{ font-size:var(--step-1); color:var(--cream-2); line-height:1.6; max-width:56ch; }
.about-story__media{ border:1px solid var(--line); border-radius:4px; overflow:hidden; position:sticky; top:6rem; aspect-ratio:4/5; }
.about-story__media img{ width:100%; height:100%; object-fit:cover; display:block; filter:saturate(0.92) brightness(0.9); }
.about-story__cap{ margin-top:0.8rem; font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.08em; color:var(--moss); }
@media (max-width:860px){ .about-story{ grid-template-columns:1fr; } .about-story__media{ position:static; aspect-ratio:16/10; } }

.about-mission{ background:var(--forest); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.about-mission .index{ display:block; margin-bottom:1.6rem; }
.about-mission p{ font-family:var(--font-display); font-weight:340; font-size:clamp(1.9rem,1rem+3.4vw,3.4rem); line-height:1.16; letter-spacing:-0.015em; color:var(--cream); max-width:24ch; }
.about-mission b{ font-weight:340; color:var(--gold); }

.about-values{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1.8rem,3.5vw,3rem) clamp(2rem,5vw,5rem); margin-top:clamp(2rem,4vw,3rem); }
.value{ border-top:1px solid var(--line); padding-top:1.5rem; }
.value__no{ font-family:var(--font-mono); font-size:var(--step--1); color:var(--gold); letter-spacing:0.12em; }
.value__name{ font-family:var(--font-display); font-weight:360; font-size:var(--step-2); margin-top:0.7rem; color:var(--cream); line-height:1.1; }
.value__text{ margin-top:0.9rem; color:var(--cream-2); font-size:var(--step-0); line-height:1.6; max-width:48ch; }
@media (max-width:680px){ .about-values{ grid-template-columns:1fr; } }

.about-renew{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.4rem,3vw,2.5rem); align-items:start; border:1px solid var(--line); border-radius:4px; padding:clamp(1.6rem,3vw,2.4rem); background:rgba(242,238,227,0.02); }
.about-renew__kicker{ font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); white-space:nowrap; padding-top:0.3em; }
.about-renew p{ font-size:var(--step-1); color:var(--cream-2); line-height:1.6; max-width:64ch; }
@media (max-width:680px){ .about-renew{ grid-template-columns:1fr; gap:0.8rem; } }

.about-supply__list{ columns:2; column-gap:2.5rem; margin-top:clamp(1.6rem,3vw,2.2rem); font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.05em; color:var(--cream-2); }
.about-supply__list li{ padding:0.45rem 0; border-bottom:1px solid var(--line); break-inside:avoid; }
@media (max-width:560px){ .about-supply__list{ columns:1; } }

/* ============================================================
   ABOUT v8 - editorial redesign
   ============================================================ */
/* Story: drop-capped lead, two-column body, offset hi-res image */
.about-story-sec .index{ display:block; margin-bottom:clamp(1.4rem,3vw,2rem); }
.story2{ display:grid; grid-template-columns:1.18fr 0.82fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.story2__lead{ font-family:var(--font-display); font-weight:340; font-size:clamp(1.5rem, 1.05rem + 1.5vw, 2.15rem); line-height:1.32; letter-spacing:-0.015em; color:var(--cream); }
.story2__lead .dropcap{ float:left; font-family:var(--font-display); font-weight:400; font-size:3.3em; line-height:0.68; padding:0.04em 0.12em 0 0; color:var(--gold); }
.story2__cols{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.4rem,3vw,2.4rem); margin-top:clamp(1.8rem,3.2vw,2.6rem); }
.story2__cols p{ font-size:var(--step-0); color:var(--cream-2); line-height:1.64; }
.story2__figure{ position:sticky; top:6rem; }
.story2__media{ border:1px solid var(--line); border-radius:4px; overflow:hidden; aspect-ratio:4/5; }
.story2__media img{ width:100%; height:100%; object-fit:cover; display:block; filter:saturate(0.95) brightness(0.92); }
.story2__cap{ margin-top:0.8rem; font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.08em; color:var(--moss); }
@media (max-width:860px){ .story2{ grid-template-columns:1fr; } .story2__figure{ position:static; } .story2__media{ aspect-ratio:16/10; } .story2__cols{ grid-template-columns:1fr; } }

/* Pull quote */
.story2__quote{ margin-top:clamp(2.6rem,5vw,4.2rem); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:clamp(1.8rem,4vw,3rem) 0; }
.story2__quote p{ font-family:var(--font-display); font-weight:340; font-size:clamp(1.7rem, 1rem + 2.4vw, 2.8rem); line-height:1.2; letter-spacing:-0.02em; color:var(--cream); max-width:26ch; }
.story2__quote .q-mark{ color:var(--gold); }

/* Mission as a centred hero moment */
.about-mission--hero{ padding-block:clamp(5rem,10vw,9rem); text-align:center; }
.about-mission--hero .index{ display:block; margin-bottom:1.8rem; }
.about-mission--hero .mission-statement{ font-family:var(--font-display); font-weight:340; font-size:clamp(2.4rem, 1rem + 5vw, 5rem); line-height:1.08; letter-spacing:-0.02em; color:var(--cream); max-width:17ch; margin-inline:auto; }
.about-mission--hero .mission-statement b{ font-weight:340; color:var(--gold); }

/* Renewable line with image */
.renew2{ display:grid; grid-template-columns:0.92fr 1.08fr; border:1px solid var(--line); border-radius:6px; overflow:hidden; background:rgba(242,238,227,0.02); }
.renew2__media{ position:relative; min-height:300px; border-right:1px solid var(--line); }
.renew2__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(0.9) brightness(0.9); }
.renew2__body{ padding:clamp(2rem,4vw,3.4rem); display:flex; flex-direction:column; justify-content:center; }
.renew2__kicker{ font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.14em; text-transform:uppercase; color:var(--gold); }
.renew2__text{ margin-top:1.1rem; font-family:var(--font-display); font-weight:340; font-size:clamp(1.3rem, 0.95rem + 1vw, 1.75rem); line-height:1.4; letter-spacing:-0.01em; color:var(--cream); max-width:42ch; }
@media (max-width:680px){ .renew2{ grid-template-columns:1fr; } .renew2__media{ min-height:0; aspect-ratio:16/10; border-right:0; border-bottom:1px solid var(--line); } }

/* ============================================================
   INSIGHTS (v9) - card grid + article reading layout
   ============================================================ */
.insight-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.4rem,2.6vw,2.1rem); margin-top:clamp(2rem,4vw,3rem); }
@media (max-width:860px){ .insight-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .insight-grid{ grid-template-columns:1fr; } }
.icard{ display:flex; flex-direction:column; background:var(--forest); border:1px solid var(--line); border-radius:6px; overflow:hidden; transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.icard:hover{ border-color:rgba(224,181,74,0.5); transform:translateY(-2px); }
.icard__media{ aspect-ratio:16/10; overflow:hidden; background:var(--forest-deep); }
.icard__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.9) brightness(0.9) contrast(1.02); transition:transform 620ms var(--ease); }
.icard:hover .icard__media img{ transform:scale(1.04); }
.icard__body{ padding:1.4rem 1.5rem 1.6rem; display:flex; flex-direction:column; gap:0.75rem; flex:1; }
.icard__meta{ display:flex; align-items:center; gap:0.8rem; font-family:var(--font-mono); font-size:11px; letter-spacing:0.13em; text-transform:uppercase; }
.icard__cat{ color:var(--gold); }
.icard__date{ color:var(--moss); }
.icard__title{ font-family:var(--font-display); font-weight:360; font-size:var(--step-1); line-height:1.16; letter-spacing:-0.01em; color:var(--cream); }
.icard__excerpt{ font-size:var(--step--1); color:var(--cream-2); line-height:1.55; flex:1; }
.icard__link{ margin-top:0.3rem; font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--cream); display:inline-flex; align-items:center; gap:0.5em; }
.icard:hover .icard__link{ color:var(--gold); }
.icard__link .arr{ transition:transform var(--dur) var(--ease); }
.icard:hover .icard__link .arr{ transform:translateX(3px); }

.insights-foot{ margin-top:clamp(2rem,4vw,3rem); }

/* Article reading layout */
.article{ max-width:46rem; margin-inline:auto; }
.article__meta{ display:flex; gap:1rem; align-items:center; font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.12em; text-transform:uppercase; margin-bottom:1.5rem; }
.article__cat{ color:var(--gold); }
.article__date{ color:var(--moss); }
.article__title{ font-family:var(--font-display); font-weight:330; font-size:clamp(2rem, 1.3rem + 2.6vw, 3.2rem); line-height:1.07; letter-spacing:-0.02em; color:var(--cream); }
.article__hero{ margin:clamp(2rem,4vw,3rem) 0; border:1px solid var(--line); border-radius:6px; overflow:hidden; aspect-ratio:16/9; background:var(--forest-deep); }
.article__hero img{ width:100%; height:100%; object-fit:cover; filter:saturate(0.92) brightness(0.94); }
.article__body p{ font-size:var(--step-1); line-height:1.72; color:var(--cream-2); }
.article__body p + p{ margin-top:1.4rem; }
.article__refs{ margin-top:clamp(2.4rem,5vw,3.5rem); padding-top:1.6rem; border-top:1px solid var(--line); }
.article__refs h2{ font-family:var(--font-mono); font-size:var(--step--1); letter-spacing:0.16em; text-transform:uppercase; color:var(--moss); margin-bottom:1.1rem; }
.article__refs ol{ list-style:decimal; padding-left:1.3rem; display:flex; flex-direction:column; gap:0.7rem; }
.article__refs li{ font-size:var(--step-0); color:var(--cream-2); line-height:1.5; }
.article__refs a{ color:var(--gold); text-decoration:underline; text-underline-offset:3px; word-break:break-word; }
.article__back{ margin-top:clamp(2.2rem,4vw,3rem); }
.article__back a{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--cream); display:inline-flex; gap:0.5em; }
.article__back a:hover{ color:var(--gold); }
