/*
Theme Name: ClimateStructure Resilience
Theme URI: https://climatestructure.com/
Author: ClimateStructure
Author URI: https://climatestructure.com/
Description: A premium environmental WordPress theme for climate-resilient modular homes, commercial facilities, resort structures, off-grid living, and developer partnerships.
Version: 1.0.6
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: climatestructure
Tags: custom-logo, custom-menu, featured-images, full-width-template, blog, portfolio, sustainability
*/

:root {
  --cs-forest: #0f3128;
  --cs-forest-2: #1b4839;
  --cs-moss: #86a982;
  --cs-sage: #e5eee7;
  --cs-stone: #f7f5ef;
  --cs-sand: #d7c6a2;
  --cs-earth: #9c6f43;
  --cs-sky: #cfe4e7;
  --cs-ink: #14201c;
  --cs-muted: #66736d;
  --cs-line: rgba(20, 32, 28, .14);
  --cs-white: #fffdf8;
  --cs-card: rgba(255, 253, 248, .82);
  --cs-shadow: 0 24px 70px rgba(9, 22, 18, .14);
  --cs-radius-xl: 34px;
  --cs-radius-lg: 24px;
  --cs-radius-md: 16px;
  --cs-max: 1180px;
  --cs-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
  --cs-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--cs-sans);
  color: var(--cs-ink);
  background:
    radial-gradient(circle at top left, rgba(134,169,130,.16), transparent 32rem),
    linear-gradient(180deg, #fcfbf7 0%, #f6f3ec 40%, #edf2ed 100%);
  line-height: 1.62;
  text-rendering: optimizeLegibility;
}
body.admin-bar .cs-site-header { top: 32px; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
:focus-visible { outline: 3px solid rgba(127,155,111,.75); outline-offset: 4px; }

.cs-site-header {
  position: sticky;
  top: 0;
  z-index: 99;
  backdrop-filter: blur(18px);
  background: rgba(251,250,245,.88);
  border-bottom: 1px solid var(--cs-line);
}
.cs-header-inner {
  max-width: var(--cs-max);
  margin: 0 auto;
  padding: 16px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.cs-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  font-weight: 800;
  letter-spacing: -.04em;
  color: var(--cs-forest);
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  white-space: nowrap;
}
.cs-brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: var(--cs-white);
  background: linear-gradient(135deg, var(--cs-forest), #2f5c49 56%, var(--cs-moss));
  box-shadow: 0 12px 24px rgba(16,37,30,.18);
}
.cs-brand small {
  display: block;
  font-size: .62rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cs-muted);
  font-weight: 800;
  margin-top: -5px;
}

.cs-logo-img {
  display: block;
  width: clamp(205px, 24vw, 292px);
  max-height: 58px;
  object-fit: contain;
}
.cs-brand .custom-logo-link,
.cs-brand .custom-logo { display: block; }
.cs-brand .custom-logo { width: auto; max-width: 292px; max-height: 58px; }
.cs-nav-wrap { display: flex; align-items: center; gap: 14px; }
.cs-menu-toggle {
  display: none;
  border: 1px solid var(--cs-line);
  background: var(--cs-white);
  padding: 10px 12px;
  border-radius: 14px;
  color: var(--cs-forest);
  font-weight: 800;
}
.cs-primary-menu,
.cs-primary-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.cs-primary-menu {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-wrap: wrap;
}
.cs-primary-menu a {
  text-decoration: none;
  display: inline-flex;
  padding: 10px 12px;
  border-radius: 999px;
  font-size: .92rem;
  font-weight: 700;
  color: rgba(20,32,28,.76);
}
.cs-primary-menu a:hover,
.cs-primary-menu .current-menu-item > a { background: rgba(127,155,111,.17); color: var(--cs-forest); }
.cs-header-cta {
  text-decoration: none;
  background: var(--cs-forest);
  color: var(--cs-white);
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 800;
  box-shadow: 0 14px 30px rgba(16,37,30,.18);
  white-space: nowrap;
}

.cs-main { min-height: 68vh; }
.cs-container,
.cs-entry-content > .alignwide,
.cs-narrow {
  max-width: var(--cs-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: 22px;
  padding-right: 22px;
}
.cs-narrow { max-width: 880px; }
.cs-entry-content > *:first-child { margin-top: 0; }

.cs-hero {
  max-width: calc(var(--cs-max) + 44px);
  margin: 22px auto 0;
  padding: clamp(34px, 6vw, 78px) 22px;
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(300px, .86fr);
  gap: clamp(26px, 5vw, 64px);
  align-items: center;
  position: relative;
  overflow: hidden;
}
.cs-hero::before {
  content: "";
  position: absolute;
  inset: 0 22px;
  border-radius: var(--cs-radius-xl);
  background: linear-gradient(135deg, rgba(255,253,248,.92), rgba(223,232,220,.72));
  border: 1px solid rgba(255,255,255,.85);
  box-shadow: var(--cs-shadow);
  z-index: -2;
}
.cs-hero::after {
  content: "";
  position: absolute;
  right: 6%;
  bottom: -7rem;
  width: 24rem;
  height: 24rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(127,155,111,.28), transparent 67%);
  z-index: -1;
}
.cs-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  color: var(--cs-earth);
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
  font-size: .74rem;
}
.cs-eyebrow::before {
  content: "";
  width: 32px;
  height: 2px;
  background: currentColor;
}
h1, h2, h3, h4 {
  font-family: var(--cs-serif);
  color: var(--cs-forest);
  letter-spacing: -.045em;
  line-height: 1.02;
  margin: 0 0 18px;
}
h1 { font-size: clamp(2.85rem, 6.4vw, 6.05rem); max-width: 11.5ch; }
.cs-hero h1 { max-width: 12ch; }
.cs-hero p { font-size: clamp(1.08rem, 1.9vw, 1.35rem); max-width: 720px; color: rgba(20,32,28,.78); margin: 0 0 24px; }
.cs-hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.cs-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 13px 18px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 900;
  border: 1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.cs-btn:hover { transform: translateY(-1px); }
.cs-btn-primary { background: var(--cs-forest); color: var(--cs-white); box-shadow: 0 18px 42px rgba(16,37,30,.24); }
.cs-btn-secondary { background: rgba(255,253,248,.72); color: var(--cs-forest); border-color: var(--cs-line); }
.cs-btn-light { background: var(--cs-white); color: var(--cs-forest); }
.cs-hero-visual,
.cs-visual-card {
  border-radius: var(--cs-radius-xl);
  overflow: hidden;
  background: rgba(255,253,248,.7);
  border: 1px solid rgba(255,255,255,.75);
  box-shadow: 0 20px 60px rgba(16,37,30,.14);
}
.cs-hero-visual img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.cs-proofbar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 26px 0 0;
  max-width: 760px;
}
.cs-proofbar li {
  border: 1px solid var(--cs-line);
  background: rgba(255,253,248,.56);
  border-radius: 18px;
  padding: 12px 13px;
  font-size: .85rem;
  font-weight: 900;
  color: var(--cs-forest);
}

.cs-section { padding: clamp(52px, 7vw, 96px) 22px; }
.cs-section-inner { max-width: var(--cs-max); margin: 0 auto; }
.cs-section-head { max-width: 780px; margin-bottom: 34px; }
.cs-section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.cs-section-head h2,
.cs-page-hero h1 { font-size: clamp(2.4rem, 5vw, 5rem); }
.cs-section-head p { color: var(--cs-muted); font-size: 1.1rem; margin: 0; }
.cs-grid { display: grid; gap: 18px; }
.cs-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.cs-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cs-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.cs-card {
  background: var(--cs-card);
  border: 1px solid rgba(255,255,255,.76);
  border-radius: var(--cs-radius-lg);
  padding: clamp(20px, 3vw, 30px);
  box-shadow: 0 12px 34px rgba(16,37,30,.08);
  position: relative;
  overflow: hidden;
}
.cs-card::after {
  content: "";
  position: absolute;
  inset: auto -3rem -4rem auto;
  width: 9rem;
  height: 9rem;
  border-radius: 50%;
  background: rgba(127,155,111,.13);
}
.cs-card h3 { font-size: clamp(1.45rem, 2.4vw, 2.15rem); margin-bottom: 10px; }
.cs-card p { color: var(--cs-muted); margin: 0 0 14px; }
.cs-card a:not(.cs-btn) { font-weight: 900; color: var(--cs-forest); text-decoration-thickness: 2px; text-underline-offset: 4px; }
.cs-icon {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  color: var(--cs-forest);
  background: linear-gradient(135deg, rgba(127,155,111,.25), rgba(207,228,231,.28));
  font-size: 1.35rem;
}
.cs-feature {
  display: grid;
  grid-template-columns: minmax(0,.95fr) minmax(0,1.05fr);
  gap: clamp(24px, 5vw, 58px);
  align-items: center;
}
.cs-feature.reverse { grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr); }
.cs-feature.reverse .cs-feature-media { order: -1; }
.cs-feature-media { border-radius: var(--cs-radius-xl); overflow: hidden; box-shadow: var(--cs-shadow); border: 1px solid rgba(255,255,255,.7); }
.cs-feature-media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.cs-kicker { font-size: .82rem; text-transform: uppercase; letter-spacing: .13em; font-weight: 900; color: var(--cs-earth); margin-bottom: 10px; }
.cs-feature h2 { font-size: clamp(2.25rem, 4.6vw, 4.6rem); }
.cs-feature p, .cs-feature li { color: var(--cs-muted); }
.cs-checklist { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 10px; }
.cs-checklist li { position: relative; padding-left: 30px; }
.cs-checklist li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--cs-moss); font-weight: 900; }

.cs-band {
  background: linear-gradient(135deg, var(--cs-forest), var(--cs-forest-2));
  color: var(--cs-white);
  position: relative;
  overflow: hidden;
}
.cs-band::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 85% 10%, rgba(127,155,111,.35), transparent 28rem); }
.cs-band .cs-section-inner { position: relative; }
.cs-band h2, .cs-band h3 { color: var(--cs-white); }
.cs-band p, .cs-band li { color: rgba(255,253,248,.76); }
.cs-band .cs-card { background: rgba(255,253,248,.08); border-color: rgba(255,255,255,.14); box-shadow: none; }
.cs-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 30px; }
.cs-metric { border: 1px solid rgba(255,255,255,.14); border-radius: 22px; padding: 22px; background: rgba(255,255,255,.06); }
.cs-metric strong { display: block; font-family: var(--cs-serif); font-size: clamp(2rem, 4vw, 4rem); line-height: 1; letter-spacing: -.05em; color: var(--cs-white); }
.cs-metric span { display: block; margin-top: 8px; color: rgba(255,253,248,.76); font-size: .92rem; }

.cs-page-hero {
  padding: clamp(58px, 8vw, 110px) 22px clamp(38px, 6vw, 72px);
  position: relative;
  overflow: hidden;
}
.cs-page-hero::before {
  content: "";
  position: absolute;
  right: -12rem;
  top: -12rem;
  width: 34rem;
  height: 34rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(127,155,111,.22), transparent 66%);
}
.cs-page-hero-inner {
  position: relative;
  max-width: var(--cs-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(300px,.82fr);
  gap: clamp(22px, 5vw, 58px);
  align-items: center;
}
.cs-page-hero p { font-size: clamp(1.1rem, 1.9vw, 1.35rem); color: var(--cs-muted); max-width: 720px; }
.cs-pill-row { display: flex; flex-wrap: wrap; gap: 8px; margin: 24px 0 0; }
.cs-pill { display: inline-flex; border: 1px solid var(--cs-line); border-radius: 999px; padding: 8px 12px; background: rgba(255,253,248,.7); font-weight: 800; font-size: .86rem; color: var(--cs-forest); }
.cs-split-callout { border-left: 5px solid var(--cs-moss); padding: 20px 24px; background: rgba(255,253,248,.7); border-radius: 0 22px 22px 0; box-shadow: 0 12px 32px rgba(16,37,30,.07); }

.cs-process { counter-reset: step; display: grid; gap: 14px; }
.cs-step { display: grid; grid-template-columns: 62px 1fr; gap: 16px; align-items: start; padding: 22px; border-radius: 24px; background: rgba(255,253,248,.72); border: 1px solid rgba(255,255,255,.8); }
.cs-step::before { counter-increment: step; content: counter(step, decimal-leading-zero); width: 52px; height: 52px; border-radius: 18px; display: grid; place-items: center; background: var(--cs-forest); color: var(--cs-white); font-weight: 900; }
.cs-step h3 { font-size: 1.35rem; margin-bottom: 6px; }
.cs-step p { margin: 0; color: var(--cs-muted); }

.cs-faq details { background: rgba(255,253,248,.82); border: 1px solid rgba(255,255,255,.78); border-radius: 18px; padding: 18px 20px; margin-bottom: 12px; box-shadow: 0 8px 26px rgba(16,37,30,.06); }
.cs-faq summary { cursor: pointer; font-weight: 900; color: var(--cs-forest); }
.cs-faq p { color: var(--cs-muted); margin-bottom: 0; }

.cs-post-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.cs-post-card { display: flex; flex-direction: column; min-height: 100%; background: var(--cs-card); border: 1px solid rgba(255,255,255,.76); border-radius: 24px; overflow: hidden; box-shadow: 0 12px 34px rgba(16,37,30,.08); text-decoration: none; }
.cs-post-card img { width: 100%; aspect-ratio: 16/10; object-fit: cover; background: var(--cs-sage); }
.cs-post-card-body { padding: 22px; }
.cs-post-card h2, .cs-post-card h3 { font-size: 1.65rem; margin-bottom: 8px; }
.cs-post-card p { color: var(--cs-muted); margin: 0; }
.cs-post-meta { display: flex; gap: 8px; flex-wrap: wrap; font-size: .78rem; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; color: var(--cs-earth); margin-bottom: 10px; }
.cs-entry { max-width: 900px; margin: 0 auto; padding: clamp(44px, 7vw, 88px) 22px; }
.cs-entry h1 { max-width: 12ch; font-size: clamp(2.7rem, 6vw, 5.8rem); }
.cs-entry-content h2 { font-size: clamp(2rem, 3.8vw, 3.5rem); margin-top: 1.35em; }
.cs-entry-content p, .cs-entry-content li { color: rgba(20,32,28,.78); font-size: 1.06rem; }
.cs-entry-content .wp-block-image { margin: 34px 0; }

.cs-contact-form { display: grid; gap: 14px; }
.cs-contact-form label { font-weight: 900; color: var(--cs-forest); }
.cs-contact-form input,
.cs-contact-form textarea,
.cs-contact-form select {
  width: 100%;
  border: 1px solid var(--cs-line);
  background: rgba(255,253,248,.85);
  border-radius: 16px;
  min-height: 50px;
  padding: 13px 14px;
  font: inherit;
  color: var(--cs-ink);
}
.cs-contact-form textarea { min-height: 140px; resize: vertical; }
.cs-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.cs-form-note { padding: 14px 16px; border-radius: 16px; background: rgba(127,155,111,.17); color: var(--cs-forest); font-weight: 800; }

.cs-site-footer { background: var(--cs-forest); color: rgba(255,253,248,.78); padding: 56px 22px 24px; margin-top: 48px; }
.cs-footer-brand { display: inline-flex; margin-bottom: 18px; }
.cs-footer-brand img { width: min(330px, 100%); height: auto; }

.cs-footer-inner { max-width: var(--cs-max); margin: 0 auto; display: grid; grid-template-columns: 1.2fr .8fr .8fr; gap: 30px; }
.cs-footer-inner h2, .cs-footer-inner h3 { color: var(--cs-white); }
.cs-footer-inner a { color: var(--cs-white); text-decoration-thickness: 1px; text-underline-offset: 4px; }
.cs-footer-menu { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.cs-footer-bottom { max-width: var(--cs-max); margin: 34px auto 0; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; font-size: .9rem; }

@media (max-width: 960px) {
  .cs-menu-toggle { display: inline-flex; }
  .cs-nav-wrap { position: relative; }
  .cs-primary-menu {
    display: none;
    position: absolute;
    right: 0;
    top: calc(100% + 12px);
    width: min(86vw, 340px);
    padding: 12px;
    background: rgba(255,253,248,.98);
    border: 1px solid var(--cs-line);
    border-radius: 22px;
    box-shadow: var(--cs-shadow);
    align-items: stretch;
  }
  .cs-primary-menu.is-open { display: grid; }
  .cs-primary-menu a { width: 100%; border-radius: 14px; }
  .cs-header-cta { display: none; }
  .cs-hero, .cs-page-hero-inner, .cs-feature, .cs-feature.reverse { grid-template-columns: 1fr; }
  .cs-feature.reverse .cs-feature-media { order: 0; }
  .cs-proofbar, .cs-metrics, .cs-grid-4 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .cs-grid-3, .cs-post-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .cs-footer-inner { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  body.admin-bar .cs-site-header { top: 0; }
  .cs-header-inner { padding: 12px 16px; }
  .cs-brand { font-size: 1.08rem; }
  .cs-logo-img { width: 185px; max-height: 46px; }
  .cs-brand .custom-logo { max-width: 185px; max-height: 46px; }
  .cs-brand-mark { width: 38px; height: 38px; }
  .cs-hero { margin-top: 0; padding: 24px 16px 46px; }
  .cs-hero::before { inset: 0; border-radius: 0 0 28px 28px; }
  h1 { font-size: clamp(2.65rem, 15vw, 4.25rem); }
  .cs-hero p, .cs-page-hero p { font-size: 1.05rem; }
  .cs-section, .cs-page-hero { padding-left: 16px; padding-right: 16px; }
  .cs-proofbar, .cs-metrics, .cs-grid-2, .cs-grid-3, .cs-grid-4, .cs-post-grid, .cs-form-grid { grid-template-columns: 1fr; }
  .cs-step { grid-template-columns: 1fr; }
}


/* ClimateStructure v1.0.3 refresh */
.cs-logo-img { width: clamp(240px, 24vw, 330px); max-height: 64px; }
.cs-brand .custom-logo { max-width: 330px; max-height: 64px; }
.cs-site-header { background: rgba(252,251,247,.92); }
.cs-header-inner { padding: 18px 22px; gap: 20px; }
.cs-primary-menu a { color: rgba(20,32,28,.8); font-weight: 800; }
.cs-primary-menu a:hover, .cs-primary-menu .current-menu-item > a { background: rgba(134,169,130,.17); }
.cs-header-cta { background: linear-gradient(135deg, #0f3128, #1a4a3b); padding: 13px 18px; }
.cs-hero::before { background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(234,241,236,.92)); border: 1px solid rgba(255,255,255,.92); }
h1 { font-size: clamp(2.8rem, 5.6vw, 5.15rem); max-width: 13ch; }
.cs-hero h1 { max-width: 12.8ch; }
.cs-hero p { color: rgba(20,32,28,.72); }
.cs-proofbar li { background: rgba(255,255,255,.68); }
.cs-card { background: rgba(255,255,255,.84); border: 1px solid rgba(20,32,28,.07); box-shadow: 0 18px 44px rgba(16,37,30,.08); }
.cs-card-visual { margin: -30px -30px 18px; aspect-ratio: 4 / 2.55; overflow: hidden; border-radius: 22px 22px 16px 16px; background: #e6ece8; }
.cs-card-visual img { width: 100%; height: 100%; object-fit: cover; }
.cs-band { background: linear-gradient(135deg, #0e3027 0%, #1b4739 58%, #0c221d 100%); }
.cs-band .cs-section-head p, .cs-band .cs-section-head .cs-eyebrow, .cs-band .cs-metric span, .cs-band p, .cs-band li { color: rgba(255,253,248,.82); }
.cs-band .cs-card { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.16); }
.cs-band .cs-card h3, .cs-band .cs-card a:not(.cs-btn) { color: #fffdf8; }
.cs-band .cs-card p { color: rgba(255,253,248,.84); }
.cs-band .cs-card::after { background: rgba(255,255,255,.08); }
.cs-band .cs-card-visual { margin: -30px -30px 18px; }
.cs-feature-media img, .cs-hero-visual img, .cs-post-card img { filter: saturate(1.02) contrast(1.02); }
.cs-site-footer { background: #0c241d; }
@media (max-width: 640px) {
  .cs-logo-img { width: 210px; max-height: 52px; }
  .cs-brand .custom-logo { max-width: 210px; max-height: 52px; }
  .cs-card-visual { margin: -20px -20px 16px; }
}


/* ClimateStructure v1.0.4 spacing and process flow fixes */
.cs-hero {
  padding: clamp(42px, 7vw, 86px) clamp(34px, 4.2vw, 48px);
}
.cs-hero::before {
  inset: 0 10px;
}
.cs-hero-visual {
  margin-right: 10px;
}
.cs-page-hero {
  padding: clamp(64px, 8vw, 116px) 28px clamp(42px, 6vw, 78px);
}
.cs-step {
  grid-template-columns: 62px minmax(0, 1fr);
  column-gap: 18px;
  row-gap: 6px;
  align-items: start;
}
.cs-step::before {
  grid-column: 1;
  grid-row: 1 / span 2;
}
.cs-step > * {
  grid-column: 2;
  min-width: 0;
}
.cs-step h3 {
  margin: 2px 0 0;
}
.cs-step p {
  margin: 0;
  max-width: 72ch;
}
@media (max-width: 960px) {
  .cs-hero {
    padding: 38px 28px 54px;
  }
}
@media (max-width: 640px) {
  .cs-hero {
    padding: 26px 18px 48px;
  }
  .cs-hero::before {
    inset: 0 8px;
    border-radius: 20px 20px 28px 28px;
  }
  .cs-page-hero {
    padding: 42px 18px 34px;
  }
}


/* ClimateStructure v1.0.5 homepage full-bleed hero */
.cs-hero-home {
  max-width: none;
  width: 100%;
  margin: 0;
  padding-top: clamp(50px, 7vw, 92px);
  padding-bottom: clamp(50px, 7vw, 92px);
  padding-left: max(24px, calc((100vw - var(--cs-max)) / 2 + 22px));
  padding-right: max(24px, calc((100vw - var(--cs-max)) / 2 + 22px));
}

.cs-hero-home::before {
  inset: 0;
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  box-shadow: none;
  background:
    radial-gradient(circle at 78% 30%, rgba(134,169,130,.22), transparent 30rem),
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(235,243,238,.94));
}

.cs-hero-home::after {
  right: 8%;
}

.cs-hero-home .cs-hero-visual {
  border-radius: var(--cs-radius-xl);
  margin-right: 0;
}

@media (max-width: 960px) {
  .cs-hero-home {
    padding-left: 22px;
    padding-right: 22px;
  }
}

@media (max-width: 640px) {
  .cs-hero-home {
    padding: 30px 18px 48px;
  }

  .cs-hero-home::before {
    inset: 0;
    border-radius: 0;
  }

  .cs-hero-home .cs-hero-visual {
    border-radius: 24px;
  }
}
