/* ====================================================================
   Rowan Evolution — styles.css v1.23
   Consolidated from v1.22 (ChatGPT) + v1.19 (targeted fixes)
   Dead override blocks removed; layout bugs at 390px and 1100px fixed.
   ==================================================================== */

/* Base */
:root{
  --bg:#F6F1E8;
  --paper:#FFFDF8;
  --ink:#101010;
  --muted:#625D55;
  --green:#1F4A3F;
  --green-dark:#0D241F;
  --accent:#B58B5C;
  --line:#DDD5C9;
  --soft-green:#ECF2ED;
  --radius:14px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.55}
img{max-width:100%}
a{color:inherit}
.skip-link{position:absolute;left:-999px;top:12px;background:#fff;color:#000;padding:10px 14px;z-index:100}
.skip-link:focus{left:12px}
.container{width:min(var(--max),calc(100% - 44px));margin:0 auto}
.section{padding:86px 0}.compact{padding:64px 0}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,253,248,.94);backdrop-filter:blur(14px);border-bottom:1px solid rgba(16,16,16,.08)}
.nav-wrap{height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;text-decoration:none}.logo img{width:210px;height:auto;object-fit:contain;display:block}
.nav-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-weight:800}
.nav-list{list-style:none;display:flex;align-items:center;gap:26px;margin:0;padding:0}
.nav-list a{text-decoration:none;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.nav-list a:hover{color:var(--green)}
.nav-cta{border:1px solid var(--green);border-radius:999px;padding:10px 16px;background:var(--green);color:#fff!important}
.editorial-hero{display:grid;grid-template-columns:minmax(0,1.85fr) minmax(380px,.85fr);min-height:560px;border-bottom:1px solid rgba(16,16,16,.08)}
.hero-image-panel{position:relative;min-height:560px;overflow:hidden}.hero-image-panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-image-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(246,241,232,.94),rgba(246,241,232,.72) 35%,rgba(246,241,232,.14) 70%,rgba(246,241,232,0))}
.hero-copy{position:relative;z-index:2;max-width:740px;padding:58px 0 54px clamp(28px,6vw,120px)}
.eyebrow{margin:0 0 16px;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--green)}
.hero-copy h1{margin:0;max-width:10ch;font-size:clamp(52px,6.5vw,104px);line-height:.92;font-weight:900;letter-spacing:-.07em;text-transform:uppercase}
.hero-copy p:not(.eyebrow){max-width:560px;margin:24px 0;font-size:19px;line-height:1.55;color:rgba(16,16,16,.82)}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 18px;border-radius:999px;border:1px solid var(--ink);text-decoration:none;font-size:12px;font-weight:900;letter-spacing:.10em;text-transform:uppercase}
.button.primary{background:var(--green);border-color:var(--green);color:#fff}.button.secondary{background:rgba(255,255,255,.54)}
.button:hover{transform:translateY(-1px)}
.hero-stat-panel{padding:34px clamp(24px,4vw,58px);background:radial-gradient(circle at 88% 12%,rgba(181,139,92,.16),transparent 28%),linear-gradient(135deg,#143329,var(--green-dark));color:#fff;display:flex;flex-direction:column;justify-content:center}
.stat-row{display:grid;grid-template-columns:54px 112px 1fr;gap:20px;align-items:center;padding:28px 0;border-bottom:1px solid rgba(255,255,255,.22)}.stat-row:last-child{border-bottom:0}
.stat-icon{width:50px;height:50px;border-radius:50%;border:1px solid rgba(255,255,255,.32);display:grid;place-items:center;color:rgba(255,255,255,.76);font-size:12px;font-weight:800;letter-spacing:.08em}
.stat-row strong{font-size:clamp(54px,5vw,84px);line-height:.9;font-weight:300;color:#F6F1E8;letter-spacing:-.07em}
.stat-row p{margin:0;font-size:15.5px;line-height:1.5;color:rgba(255,255,255,.8)}.stat-row b{display:inline-block;margin-bottom:4px;color:#fff;font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.visual-tiles{display:grid;grid-template-columns:repeat(4,1fr);min-height:230px;border-bottom:1px solid rgba(16,16,16,.08)}
.visual-tile{position:relative;min-height:230px;overflow:hidden;color:#fff;text-decoration:none;display:flex;align-items:flex-end;justify-content:center;padding:28px;border-right:1px solid rgba(255,255,255,.22)}
.visual-tile:last-child{border-right:0}.visual-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .55s ease}.visual-tile:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.58))}
.visual-tile div{position:relative;z-index:2;text-align:center}.visual-tile span{display:block;font-size:15px;font-weight:900;letter-spacing:.09em;text-transform:uppercase}.visual-tile p{margin:8px auto 0;max-width:260px;color:rgba(255,255,255,.86)}.visual-tile:hover img{transform:scale(1.06)}
.decision-strip{display:grid;grid-template-columns:1.15fr repeat(4,1fr);background:rgba(255,253,248,.88);border-bottom:1px solid rgba(16,16,16,.08)}
.decision-heading,.decision-item{padding:26px clamp(18px,3vw,44px);border-right:1px solid rgba(16,16,16,.12)}.decision-item:last-child{border-right:0}
.decision-heading h2{margin:0;font-size:32px;line-height:1.06;letter-spacing:-.04em}.decision-item span{display:block;margin-bottom:12px;color:var(--accent);font-weight:900}.decision-item h3{margin:0 0 8px;font-size:13px;letter-spacing:.11em;text-transform:uppercase}.decision-item p{margin:0;color:var(--muted);font-size:14px}
.section-header{max-width:760px;margin-bottom:28px}.section-header h2{margin:0 0 16px;font-size:clamp(38px,5vw,72px);line-height:.92;letter-spacing:-.07em;text-transform:uppercase}.section-header p{margin:0;color:var(--muted);font-size:18px}
.editorial-section{background:linear-gradient(180deg,var(--paper),#F6F1E8)}.editorial-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid rgba(16,16,16,.10)}
.image-card{min-height:430px;overflow:hidden;background:var(--paper);border-right:1px solid rgba(16,16,16,.10)}.image-card:last-child{border-right:0}.image-card img{width:100%;height:235px;object-fit:cover;display:block}.image-card div{padding:28px}.image-card h3{margin:0 0 12px;font-size:30px;line-height:1.05;letter-spacing:-.04em}.image-card p{margin:0;color:var(--muted)}.dark-card{background:var(--green);color:#fff}.dark-card p{color:rgba(255,255,255,.80)}
.mandate-section{background:linear-gradient(180deg,var(--soft-green),#F6F1E8)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.card,.contact-card,.useful-panel,.cta-panel{background:var(--paper);border:1px solid rgba(16,16,16,.10);border-radius:var(--radius);padding:24px;box-shadow:0 14px 34px rgba(31,74,63,.08)}
.card h3,.contact-card h3{margin:0 0 10px;font-size:24px;line-height:1.1}.card p,.contact-card p{margin:0;color:var(--muted)}.mandate-label{font-size:12px;font-weight:900;letter-spacing:.14em;color:var(--accent);margin:0 0 20px!important}
.approach-feature{background:var(--paper)}.media-feature-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center}.media-feature-image{margin:0;overflow:hidden;background:var(--paper);border:1px solid rgba(16,16,16,.10);box-shadow:0 16px 34px rgba(31,74,63,.10)}.media-feature-image img{width:100%;height:460px;object-fit:cover;display:block}.media-feature-image figcaption{padding:12px 16px 14px;font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.media-feature-copy h2{max-width:13ch}
.process-mini{display:grid;gap:10px;margin-top:22px}.process-mini span{display:block;padding:13px 15px;border-radius:999px;border:1px solid rgba(16,16,16,.10);background:#fff;font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.experience-mosaic{background:linear-gradient(180deg,#F6F1E8,var(--soft-green))}.experience-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.experience-card{padding:24px;min-height:260px;background:rgba(255,253,248,.9);border:1px solid rgba(16,16,16,.10);border-radius:var(--radius)}.experience-card h3{margin:0 0 12px;font-size:22px}.experience-card p{margin:0;color:var(--muted)}
.image-backed{position:relative;overflow:hidden;color:#fff}.image-backed img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.image-backed:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.20),rgba(0,0,0,.72))}.image-backed h3,.image-backed p{position:relative;z-index:1;color:#fff}
.about-editorial{background:var(--paper)}.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:34px;align-items:center}.about-photo{overflow:hidden;border:1px solid rgba(16,16,16,.10);border-radius:var(--radius)}.about-photo img{display:block;width:100%;height:520px;object-fit:cover}.text-block p{color:var(--muted)}.independent-note{margin-top:22px;padding:18px;border-left:4px solid var(--green);background:var(--soft-green);border-radius:10px}.independent-note h3{margin:0 0 8px}.badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.badges span{padding:8px 10px;border:1px solid var(--line);border-radius:999px;background:#fff;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.split{display:grid;grid-template-columns:.75fr 1fr;gap:30px}.useful-panel ul{margin:18px 0 0;padding-left:20px}.useful-panel li{margin:8px 0}.cta-panel{display:flex;align-items:center;justify-content:space-between;gap:24px}.cta-panel h2{margin:0 0 10px;font-size:clamp(34px,4vw,58px);line-height:.94;letter-spacing:-.06em;text-transform:uppercase}.cta-panel p{margin:0;color:var(--muted)}.contact-grid{margin-top:22px}
.site-footer{background:var(--green-dark);color:#fff;padding:24px 0}.footer-grid{display:flex;justify-content:space-between;gap:18px;align-items:center}.footer-grid p{margin:0;color:rgba(255,255,255,.72)}.footer-links{display:flex;gap:18px}.footer-links a{color:#fff;text-decoration:none;font-size:12px;font-weight:800;letter-spacing:.10em;text-transform:uppercase}
.legal-main{padding:50px 0 80px}.legal-main article{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:34px}.legal-main h1{font-size:clamp(42px,6vw,76px);line-height:.9;letter-spacing:-.07em;text-transform:uppercase}.legal-main h2{margin-top:30px}.legal-main p,.legal-main li{color:var(--muted)}
.reveal{opacity:1;transform:none}.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}.js .reveal.visible{opacity:1;transform:none}.reveal-delay-1{transition-delay:.08s}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}
@media(max-width:1180px){.editorial-hero{grid-template-columns:1fr}.hero-stat-panel{display:grid;grid-template-columns:repeat(3,1fr)}.stat-row{grid-template-columns:1fr;gap:12px;border-bottom:0;border-right:1px solid rgba(255,255,255,.22);padding:22px}.stat-row:last-child{border-right:0}.visual-tiles,.decision-strip,.experience-grid{grid-template-columns:repeat(2,1fr)}.editorial-card-grid,.media-feature-grid,.about-grid,.split{grid-template-columns:1fr}}
@media(max-width:820px){.nav-toggle{display:inline-flex}.site-nav{display:none;position:absolute;left:22px;right:22px;top:72px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:0 20px 44px rgba(0,0,0,.12)}.site-nav.is-open{display:block}.nav-list{display:grid;gap:14px}.nav-wrap{height:74px}.logo img{width:168px}.hero-image-panel{min-height:620px}.hero-copy{padding:42px 22px}.hero-stat-panel,.visual-tiles,.decision-strip,.experience-grid,.grid-3,.grid-2{grid-template-columns:1fr}.stat-row{grid-template-columns:54px 96px 1fr;border-right:0;border-bottom:1px solid rgba(255,255,255,.22)}.stat-row:last-child{border-bottom:0}.decision-heading,.decision-item{border-right:0;border-bottom:1px solid rgba(16,16,16,.12)}.image-card{border-right:0;border-bottom:1px solid rgba(16,16,16,.10)}.image-card:last-child{border-bottom:0}.media-feature-image img,.about-photo img{height:310px}.cta-panel{display:grid}.footer-grid{display:grid}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}


/* Nav link underline animation (was v1.4, dead selectors removed) */
.nav-list{
  align-items:center;
}

.nav-list a{
  position:relative;
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 2px 8px;
  line-height:1;
}

.nav-list a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:2px;
  background:var(--green);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .22s ease;
}

.nav-list a:hover::after,
.nav-list a:focus-visible::after{
  transform:scaleX(1);
}
.nav-list .nav-link-contact{
  border:0;
  border-radius:0;
  background:transparent;
  color:inherit!important;
  padding:0 2px 8px;
}

.nav-list .nav-link-contact:hover,
.nav-list .nav-link-contact:focus-visible{
  color:var(--green)!important;
}

/* Editorial polish (was v1.5) */
.scroll-progress{
  position:fixed;
  top:0;
  left:0;
  right:0;
  height:2px;
  z-index:120;
  background:transparent;
  pointer-events:none;
}
.scroll-progress span{
  display:block;
  height:100%;
  width:100%;
  background:var(--green);
  transform:scaleX(0);
  transform-origin:left center;
}

.nav-list a.is-active::after{
  transform:scaleX(1);
}

.nav-list a.is-active{
  color:var(--green);
}

.section-header[data-section-label]::before,
.text-block[data-section-label]::before{
  content:attr(data-section-label);
  display:block;
  margin:0 0 14px;
  color:var(--accent);
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.field-note-section{
  padding:26px 0;
  background:linear-gradient(180deg,var(--bg),var(--paper));
}

.field-note-secondary{
  background:linear-gradient(180deg,var(--paper),var(--bg));
}

.field-note{
  position:relative;
  max-width:880px;
  margin:0 auto;
  padding:24px 30px 26px;
  border-left:4px solid var(--green);
  border-top:1px solid rgba(16,16,16,.10);
  border-bottom:1px solid rgba(16,16,16,.10);
  background:rgba(255,253,248,.82);
}

.field-note::after{
  content:"";
  position:absolute;
  right:24px;
  top:24px;
  width:52px;
  height:52px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(181,139,92,.25),transparent 68%);
  pointer-events:none;
}

.field-note span{
  display:block;
  margin:0 0 8px;
  color:var(--accent);
  font-size:12px;
  font-weight:900;
  letter-spacing:.15em;
  text-transform:uppercase;
}

.field-note p{
  max-width:760px;
  margin:0;
  font-size:20px;
  line-height:1.48;
  letter-spacing:-.015em;
}

.visual-tile img,
.image-card img,
.media-feature-image img,
.about-photo img,
.image-backed img{
  filter:saturate(.90) contrast(1.03) brightness(.98);
}

.visual-tile:hover img,
.image-card:hover img,
.media-feature-image:hover img,
.about-photo:hover img{
  filter:saturate(.98) contrast(1.06) brightness(1);
}

.visual-tile div{
  transform:translateY(0);
  transition:transform .28s ease;
}

.visual-tile:hover div,
.visual-tile:focus-visible div{
  transform:translateY(-6px);
}

.image-card img,
.media-feature-image img,
.about-photo img{
  transition:transform .45s ease, filter .35s ease;
}

.image-card:hover img,
.media-feature-image:hover img,
.about-photo:hover img{
  transform:scale(1.025);
}

.closing-line{
  margin:0 0 14px;
  color:var(--accent)!important;
  font-size:12px;
  font-weight:900;
  letter-spacing:.15em;
  text-transform:uppercase;
}

.contact-editorial{
  background:
    radial-gradient(circle at 15% 20%,rgba(181,139,92,.14),transparent 28%),
    linear-gradient(180deg,var(--soft-green),var(--bg));
}

.contact-editorial .cta-panel{
  border-radius:18px;
  background:
    linear-gradient(135deg,rgba(255,253,248,.96),rgba(236,242,237,.96));
}

@media(max-width:820px){
  .field-note{
    padding:22px;
  }

  .field-note p{
    font-size:18px;
  }
}

/* Text-wrap pretty (was v1.16) */
.service-card p,
.package-card p,
.proof-card p,
.useful-list li{
  text-wrap:pretty;
}

/* Section labels for media-feature-copy and text-block (was v1.19) */
/* Section labels for the approach (.media-feature-copy) and about
   (.text-block) blocks now that they carry data-section-label. */
.media-feature-copy[data-section-label]::before,
.text-block[data-section-label]::before{
  content:attr(data-section-label);
  display:block;
  margin:0 0 14px;
  color:var(--accent);
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

/* Hero h1 base sizing (was v1.19) */
/* Hero h1: spans should display as block lines (intended look), and
   the h1 needs enough width that the longest span "Structure the capital"
   doesn't wrap inside itself. */
.hero-copy h1.hero-stacked{
  max-width:none;
  font-size:clamp(44px,5.2vw,82px);
}
.hero-copy h1.hero-stacked span{
  display:block;
  white-space:nowrap;
}

/* Header consolidation (was v1.20) */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
}

.site-header .header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  min-height:56px;
  padding-top:8px;
  padding-bottom:8px;
}

.logo-link{
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
  text-decoration:none;
}

.logo-link img{
  display:block;
  width:118px;
  height:auto;
  max-width:118px;
  max-height:none;
  object-fit:contain;
  object-position:left center;
}

@media(min-width:821px){
  .site-header .site-nav{
    display:flex;
    align-items:center;
    align-self:stretch;
  }

  .site-header .nav-list{
    display:flex;
    align-items:center;
    gap:24px;
    height:100%;
    margin:0;
    padding:0;
    list-style:none;
  }

  .site-header .nav-list a,
  .site-header .nav-list .nav-link-contact{
    position:relative;
    display:inline-flex;
    align-items:center;
    min-height:40px;
    padding:0 2px;
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    color:inherit!important;
    line-height:1;
    text-decoration:none;
  }

  .site-header .nav-list a::after,
  .site-header .nav-list .nav-link-contact::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:2px;
    height:2px;
    background:var(--green);
    transform:scaleX(0);
    transform-origin:left center;
    transition:transform .22s ease;
  }

  .site-header .nav-list a:hover,
  .site-header .nav-list a:focus-visible,
  .site-header .nav-list a.is-active{
    color:var(--green)!important;
  }

  .site-header .nav-list a:hover::after,
  .site-header .nav-list a:focus-visible::after,
  .site-header .nav-list a.is-active::after{
    transform:scaleX(1);
  }
}

@media(max-width:820px){
  .site-header .header-inner{
    min-height:56px;
    padding-top:8px;
    padding-bottom:8px;
  }

  .logo-link img{
    width:104px;
    max-width:104px;
    height:auto;
  }

  .site-nav{
    top:56px;
  }

  .site-header .nav-list a,
  .site-header .nav-list .nav-link-contact{
    border:0!important;
    border-radius:0!important;
    background:transparent!important;
    color:inherit!important;
  }
}

/* Keep anchor jumps below the compact sticky header */
html{
  scroll-padding-top:88px;
}

section[id],
main [id]{
  scroll-margin-top:88px;
}

/* Visual consistency, subpage hero (was v1.21) */
.hero-image-panel{
  isolation:isolate;
}

.hero-copy{
  max-width:min(740px,calc(100% - clamp(32px,7vw,128px)));
  padding-right:clamp(28px,6vw,96px);
}

.hero-copy h1.hero-stacked{
  font-size:clamp(42px,4.8vw,76px);
}

.field-note::after{
  display:none;
}

.media-feature-copy h2{
  margin:0 0 16px;
  font-size:clamp(38px,5vw,72px);
  line-height:.92;
  letter-spacing:-.07em;
  text-transform:uppercase;
  max-width:13ch;
}

.experience-card{
  color:var(--ink);
}

.experience-card img{
  display:none;
}

.legal-main{
  padding:0 0 80px;
}

.subpage-visual{
  display:none;
}

.subpage-hero{
  position:relative;
  min-height:420px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  border-bottom:1px solid rgba(16,16,16,.08);
}

.subpage-hero > img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.90) contrast(1.03) brightness(.86);
}

.subpage-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(13,36,31,.86),rgba(13,36,31,.58) 42%,rgba(13,36,31,.20) 72%,rgba(13,36,31,.04));
}

.subpage-hero-copy{
  position:relative;
  z-index:2;
  padding-top:72px;
  padding-bottom:64px;
  padding-right:clamp(28px,6vw,96px);
  color:#fff;
}

.subpage-hero-copy .eyebrow{
  color:rgba(255,255,255,.76);
}

.subpage-hero-copy h1{
  max-width:12ch;
  margin:0;
  font-size:clamp(48px,6vw,86px);
  line-height:.92;
  letter-spacing:-.07em;
  text-transform:uppercase;
}

.subpage-hero-copy p:not(.eyebrow){
  max-width:640px;
  margin:22px 0 0;
  font-size:19px;
  line-height:1.55;
  color:rgba(255,255,255,.86);
}

.legal-body{
  margin-top:42px;
}

@media(max-width:1180px){
  .hero-copy{
    max-width:740px;
  }
}

@media(max-width:820px){
  .hero-copy{
    max-width:none;
    padding-right:22px;
  }

  .subpage-hero{
    min-height:360px;
  }

  .subpage-hero-copy{
    padding-top:52px;
    padding-bottom:46px;
    padding-right:22px;
  }

  .subpage-hero-copy h1{
    font-size:clamp(42px,12vw,64px);
  }
}

/* ====================================================================
   v1.22 layout pass — kept and merged with v1.23 fixes below
   ==================================================================== */

/* Hero: full-width left column, padding protects the right edge. */
.editorial-hero{
  grid-template-columns:minmax(0,1.72fr) minmax(400px,.88fr);
}

.hero-copy{
  width:100%;
  max-width:none;
  box-sizing:border-box;
  padding-top:58px;
  padding-bottom:54px;
  padding-left:clamp(28px,6vw,120px);
  padding-right:clamp(56px,8vw,132px);
}

.hero-copy h1.hero-stacked{
  max-width:none;
  font-size:clamp(40px,4.35vw,72px);
  line-height:.90;
  letter-spacing:-.066em;
}

.hero-copy h1.hero-stacked span{
  white-space:nowrap;
}

.hero-copy p:not(.eyebrow){
  max-width:560px;
}

/* ====================================================================
   v1.23 — bug fixes (390px overflow, 1100px hero-stat overflow)
   ==================================================================== */

/* Allow grid items to shrink past their min-content; otherwise long
   uppercase tracked-out text forces tracks wider than viewport. */
.editorial-hero,
.editorial-hero > *,
.hero-stat-panel,
.hero-stat-panel .stat-row,
.hero-stat-panel .stat-row > *{
  min-width:0;
}

/* Stat-row text col must be able to wrap on narrow viewports. */
.hero-stat-panel .stat-row p{
  overflow-wrap:anywhere;
}

/* Below 1280px: hero stacks, image full width, copy spans full container. */
@media(max-width:1280px){
  .editorial-hero{grid-template-columns:1fr}
  .hero-image-panel{min-height:540px}
  .hero-copy{max-width:980px;padding-right:clamp(34px,7vw,110px)}
}

/* Below 1180px: stat panel becomes a single vertical column of stat-rows.
   The previous 3-column horizontal arrangement could not fit between
   980 and 1280 because long uppercase labels forced each track wider
   than 1/3 of the container. Vertical at this width is also more
   readable than the cramped 3-col version. */
@media(max-width:1180px){
  .hero-stat-panel{grid-template-columns:1fr;padding:30px clamp(24px,5vw,48px)}
  .hero-stat-panel .stat-row{
    grid-template-columns:54px minmax(110px,auto) 1fr;
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.22);
    padding:24px 0;
  }
  .hero-stat-panel .stat-row:last-child{border-bottom:0}
  /* Decision strip: heading on its own row, items in 2x2 grid. */
  .decision-strip{grid-template-columns:repeat(2,1fr)}
  .decision-heading{grid-column:1/-1;border-right:0}
  .decision-item:nth-child(odd){border-right:1px solid rgba(16,16,16,.12)}
  .decision-item:nth-child(even){border-right:0}
  .decision-item:nth-child(-n+3){border-bottom:1px solid rgba(16,16,16,.12)}
}

@media(max-width:980px){
  .hero-copy h1.hero-stacked{font-size:clamp(42px,9vw,68px)}
  .hero-copy h1.hero-stacked span{white-space:normal}
  /* Below 980, also tighten the experience grid to 2 columns so cards
     are balanced and the short "Renewable energy finance" card pairs up. */
  .experience-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:620px){
  /* At true mobile width, experience cards in 2-col are too cramped
     (long words like "sustainable" wrap awkwardly). Go single column. */
  .experience-grid{grid-template-columns:1fr}
}

@media(max-width:820px){
  .hero-image-panel{min-height:620px}
  .hero-copy{padding:42px 22px 46px}
  .hero-copy h1.hero-stacked{font-size:clamp(39px,12vw,62px)}
  /* Stat panel: tighter horizontal padding so the row fits within viewport. */
  .hero-stat-panel{padding:24px 18px}
  .hero-stat-panel .stat-row{
    grid-template-columns:48px minmax(96px,auto) 1fr;
    gap:14px;
    padding:20px 0;
  }
  /* Decision strip on mobile: single column stack. */
  .decision-strip{grid-template-columns:1fr}
  .decision-heading,.decision-item{border-right:0!important;border-bottom:1px solid rgba(16,16,16,.12)}
  .decision-item:last-child{border-bottom:0}
}

@media(max-width:420px){
  .container{width:min(var(--max),calc(100% - 32px))}
  .hero-copy h1.hero-stacked{font-size:clamp(36px,11.2vw,48px);letter-spacing:-.055em}
  .hero-copy p:not(.eyebrow){font-size:17px}
  .button{width:100%}
  /* Smaller stat number font so 300+ does not push the row wider than viewport. */
  .hero-stat-panel .stat-row strong{font-size:42px}
  .hero-stat-panel .stat-row{grid-template-columns:44px minmax(78px,auto) 1fr;gap:12px}
  .hero-stat-panel .stat-row p{font-size:14px}
  .hero-stat-panel .stat-row b{font-size:12px;letter-spacing:.08em}
}

/* Dense card rows: ensure text does not create cramped or uneven cards. */
.card,
.experience-card,
.contact-card,
.useful-panel,
.cta-panel,
.legal-main article{
  overflow-wrap:anywhere;
}

/* Footer */
.footer-grid,
.footer-links{
  flex-wrap:wrap;
}

@media(max-width:520px){
  .footer-links{display:grid;gap:10px}
}

/* Subpage heroes: keep text safely inside the image on all widths. */
.subpage-hero-copy{box-sizing:border-box;max-width:980px}

@media(max-width:520px){
  .subpage-hero-copy h1{font-size:clamp(38px,11vw,54px)}
  .subpage-hero-copy p:not(.eyebrow){font-size:17px}
  .legal-main article{padding:24px 20px}
}


/* Version 1.27 live stylesheet reset from user-uploaded v1_23
   Base: Claude-corrected v1_23 stylesheet.
   Purpose: keep the v1_23 bug fixes, remove the field-note smudge, and keep
   the safe hero layout with side-by-side restored only on very wide screens. */

/* Remove the circular smudge on Field Note / Implementation Note cards. */
.field-note::after{
  content:none !important;
  display:none !important;
  background:none !important;
}

.field-note{
  background:rgba(255,253,248,.86) !important;
}

/* Keep the hero safe on laptops and normal desktop widths. */
.editorial-hero{
  display:grid !important;
  grid-template-columns:1fr !important;
  min-height:auto !important;
}

.hero-image-panel{
  width:100% !important;
  min-width:0 !important;
  min-height:clamp(560px,56vw,760px) !important;
  overflow:hidden !important;
}

.hero-copy{
  width:auto !important;
  max-width:min(860px,calc(100vw - 48px)) !important;
  padding:clamp(54px,7vw,96px) 24px clamp(58px,7vw,104px) clamp(28px,8vw,112px) !important;
  box-sizing:border-box !important;
}

.hero-copy h1.hero-stacked{
  max-width:min(10.8ch,calc(100vw - 48px)) !important;
  font-size:clamp(46px,7vw,96px) !important;
  line-height:.9 !important;
  letter-spacing:-.065em !important;
  overflow:visible !important;
}

.hero-copy h1.hero-stacked span{
  display:block !important;
  white-space:normal !important;
}

.hero-copy p:not(.eyebrow){
  max-width:min(620px,calc(100vw - 48px)) !important;
}

/* Statistics panel below the hero on laptops and normal desktop widths. */
.hero-stat-panel{
  width:100% !important;
  min-width:0 !important;
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  padding:28px clamp(22px,4vw,52px) !important;
  box-sizing:border-box !important;
}

.hero-stat-panel .stat-row{
  display:grid !important;
  grid-template-columns:1fr !important;
  grid-template-rows:auto auto auto !important;
  gap:12px !important;
  align-items:start !important;
  padding:22px !important;
  border-bottom:0 !important;
  border-right:1px solid rgba(255,255,255,.22) !important;
}

.hero-stat-panel .stat-row:last-child{
  border-right:0 !important;
}

.hero-stat-panel .stat-icon{
  grid-column:1 !important;
  grid-row:1 !important;
  align-self:start !important;
  justify-self:start !important;
}

.hero-stat-panel .stat-row strong{
  grid-column:1 !important;
  grid-row:2 !important;
  display:block !important;
  width:auto !important;
  min-width:0 !important;
  max-width:none !important;
  margin:0 !important;
  white-space:nowrap !important;
  justify-self:start !important;
  font-size:clamp(50px,5.8vw,82px) !important;
  line-height:.86 !important;
  letter-spacing:-.055em !important;
}

.hero-stat-panel .stat-row p{
  grid-column:1 !important;
  grid-row:3 !important;
  display:block !important;
  width:auto !important;
  min-width:0 !important;
  max-width:320px !important;
  margin:0 !important;
  padding:0 !important;
  justify-self:start !important;
  text-align:left !important;
  font-size:15.5px !important;
  line-height:1.45 !important;
  overflow-wrap:normal !important;
  word-break:normal !important;
}

.hero-stat-panel .stat-row b{
  display:block !important;
  margin:0 0 5px !important;
  white-space:normal !important;
  text-align:left !important;
}

/* Mobile: return to the compact three-part stat row. */
@media(max-width:900px){
  .hero-image-panel{
    min-height:620px !important;
  }

  .hero-copy{
    padding:42px 22px 46px !important;
    max-width:100% !important;
  }

  .hero-copy h1.hero-stacked{
    max-width:9.4ch !important;
    font-size:clamp(39px,12vw,62px) !important;
  }

  .hero-stat-panel{
    grid-template-columns:1fr !important;
    padding:24px 18px !important;
  }

  .hero-stat-panel .stat-row{
    grid-template-columns:48px minmax(96px,auto) minmax(0,1fr) !important;
    grid-template-rows:auto !important;
    gap:14px !important;
    align-items:center !important;
    border-right:0 !important;
    border-bottom:1px solid rgba(255,255,255,.22) !important;
    padding:20px 0 !important;
  }

  .hero-stat-panel .stat-row:last-child{
    border-bottom:0 !important;
  }

  .hero-stat-panel .stat-icon{
    grid-column:1 !important;
    grid-row:1 !important;
  }

  .hero-stat-panel .stat-row strong{
    grid-column:2 !important;
    grid-row:1 !important;
    font-size:clamp(48px,14vw,70px) !important;
  }

  .hero-stat-panel .stat-row p{
    grid-column:3 !important;
    grid-row:1 !important;
    max-width:none !important;
    font-size:15px !important;
  }
}

/* Very wide screens only: restore the editorial side-by-side hero. */
@media(min-width:1760px){
  .editorial-hero{
    grid-template-columns:minmax(980px,1.65fr) minmax(560px,.85fr) !important;
    min-height:640px !important;
  }

  .hero-image-panel{
    min-height:640px !important;
  }

  .hero-copy{
    max-width:900px !important;
    padding:clamp(70px,6vw,112px) 40px clamp(70px,6vw,112px) clamp(80px,7vw,132px) !important;
  }

  .hero-copy h1.hero-stacked{
    max-width:11.2ch !important;
    font-size:clamp(68px,5.1vw,100px) !important;
    line-height:.88 !important;
    letter-spacing:-.07em !important;
  }

  .hero-copy h1.hero-stacked span{
    white-space:normal !important;
  }

  .hero-copy p:not(.eyebrow){
    max-width:620px !important;
  }

  .hero-stat-panel{
    display:flex !important;
    flex-direction:column !important;
    justify-content:center !important;
    width:auto !important;
    padding:34px clamp(34px,3vw,58px) !important;
  }

  .hero-stat-panel .stat-row{
    display:grid !important;
    grid-template-columns:54px minmax(0,1fr) !important;
    grid-template-rows:auto auto !important;
    column-gap:26px !important;
    row-gap:10px !important;
    align-items:center !important;
    padding:28px 0 !important;
    border-right:0 !important;
    border-bottom:1px solid rgba(255,255,255,.22) !important;
  }

  .hero-stat-panel .stat-row:last-child{
    border-bottom:0 !important;
  }

  .hero-stat-panel .stat-icon{
    grid-column:1 !important;
    grid-row:1 / span 2 !important;
    align-self:center !important;
    justify-self:start !important;
  }

  .hero-stat-panel .stat-row strong{
    grid-column:2 !important;
    grid-row:1 !important;
    width:auto !important;
    min-width:0 !important;
    max-width:none !important;
    margin:0 !important;
    white-space:nowrap !important;
    font-size:clamp(56px,4vw,78px) !important;
    line-height:.86 !important;
    letter-spacing:-.055em !important;
  }

  .hero-stat-panel .stat-row p{
    grid-column:2 !important;
    grid-row:2 !important;
    width:auto !important;
    min-width:0 !important;
    max-width:360px !important;
    margin:0 !important;
    padding:0 !important;
    font-size:15.5px !important;
    line-height:1.46 !important;
    text-align:left !important;
  }

  .hero-stat-panel .stat-row b{
    display:block !important;
    margin:0 0 5px !important;
    white-space:normal !important;
  }
}
