*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Arial,Helvetica,sans-serif;background:#f7f3ed;color:#25272b;line-height:1.7}.container{width:min(1120px,calc(100% - 40px));margin:0 auto}.site-header{position:sticky;top:0;z-index:50;background:rgba(13,28,51,.94);backdrop-filter:blur(14px);border-bottom:1px solid rgba(197,161,111,.25)}.nav{display:flex;align-items:center;justify-content:space-between;min-height:72px}.brand{display:flex;align-items:center;gap:14px;color:#fff;text-decoration:none}.brand img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(197,161,111,.75)}.brand span{font-weight:800;letter-spacing:.03em}.nav-links{display:flex;gap:22px;align-items:center}.nav-links a{color:rgba(255,255,255,.84);text-decoration:none;font-weight:700;font-size:.92rem}.nav-links a:hover,.nav-links a.active{color:#d8b77d}.mobile-toggle{display:none;background:transparent;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:10px;padding:8px 10px}.hero{background:radial-gradient(circle at top left,rgba(197,161,111,.18),transparent 32rem),linear-gradient(135deg,#081526 0%,#112747 54%,#091322 100%);color:#fff;padding:92px 0 80px}.hero-grid{display:grid;grid-template-columns:.86fr 1.14fr;gap:56px;align-items:center}.portrait{width:min(360px,100%);border-radius:30px;box-shadow:0 28px 70px rgba(0,0,0,.28);border:1px solid rgba(197,161,111,.32)}.eyebrow{color:#c5a16f;text-transform:uppercase;letter-spacing:.26em;font-size:.76rem;font-weight:800;margin-bottom:14px}.hero h1,.page-hero h1{font-size:clamp(2.7rem,6vw,5.25rem);line-height:1.03;letter-spacing:-.055em;margin-bottom:26px}.hero p,.page-hero p{font-size:clamp(1.08rem,2vw,1.34rem);color:rgba(255,255,255,.78);max-width:820px}.hero-mark{margin-top:34px;display:flex;align-items:center;gap:16px;color:rgba(255,255,255,.68);font-size:.9rem}.hero-mark img{height:54px;max-width:190px;filter:drop-shadow(0 3px 10px rgba(0,0,0,.35))}.button-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:12px 20px;border-radius:999px;text-decoration:none;font-weight:800;transition:.18s}.btn:hover{transform:translateY(-1px)}.btn.primary{background:#c5a16f;color:#071322}.btn.secondary{border:1px solid #c5a16f;color:#fff;background:transparent}.btn.dark{background:#112747;color:#fff}.btn.light{border:1px solid #c5a16f;color:#112747}.section{padding:88px 0;border-top:1px solid #e6dccf}.section.alt{background:rgba(255,255,255,.55)}.section-intro{max-width:860px;margin-bottom:38px}.section-intro h2,.text-block h2{font-size:clamp(2rem,4vw,3.35rem);line-height:1.12;letter-spacing:-.04em;color:#112747;margin-bottom:20px}.section-intro p,.text-block p{color:#5f6670;font-size:1.06rem;margin-bottom:16px}.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.card-grid.two{grid-template-columns:repeat(2,1fr)}.card{background:rgba(255,255,255,.76);border:1px solid #e6dccf;border-radius:24px;padding:28px;box-shadow:0 16px 45px rgba(17,39,71,.08)}.card h3{color:#112747;font-size:1.2rem;line-height:1.3;margin-bottom:10px}.card p{color:#5f6670;font-size:.99rem}.card a{color:#112747;font-weight:800;text-decoration:none}.grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}.image-card{border-radius:28px;overflow:hidden;border:1px solid #e6dccf;box-shadow:0 18px 50px rgba(17,39,71,.12);background:#fff}.image-card img{display:block;width:100%;height:auto}.quote{background:#112747;color:#fff;border-radius:26px;padding:38px;box-shadow:0 18px 50px rgba(17,39,71,.15)}.quote p{color:#fff;font-size:1.26rem}.page-hero{background:linear-gradient(135deg,#081526,#112747);color:#fff;padding:74px 0}.content-block{max-width:900px}.content-block h2{font-size:2rem;color:#112747;margin:34px 0 12px}.content-block p{color:#5f6670;margin-bottom:16px;font-size:1.05rem}.initiative{margin-bottom:24px}.initiative h2{color:#112747;font-size:1.8rem;margin-bottom:16px}.initiative .label{font-weight:800;color:#c5a16f;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;margin-top:20px}.article-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.article-body{max-width:870px;margin:0 auto}.article-body h1{font-size:clamp(2.2rem,4vw,3.7rem);line-height:1.1;color:#112747;margin-bottom:22px}.article-body p{color:#4d5660;font-size:1.08rem;margin-bottom:20px}.article-body h2{color:#112747;margin:36px 0 14px;font-size:1.7rem}.back-links{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap}.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px}.impact-card{background:#fff;border:1px solid #e6dccf;border-radius:20px;padding:22px;color:#112747;font-weight:800}.proof-strip{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px}.proof-strip img{width:100%;border-radius:18px;border:1px solid #e6dccf;box-shadow:0 12px 30px rgba(17,39,71,.08)}footer{background:#081526;color:rgba(255,255,255,.76);padding:42px 0}.footer-grid{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center}.footer-logo{height:54px;filter:drop-shadow(0 2px 10px rgba(0,0,0,.35))}.footer-links{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px}.footer-links a{color:#d8b77d;text-decoration:none;font-weight:800}.footer-line{color:#d8b77d;font-weight:800;margin-top:8px}.to-top{display:inline-block;margin-top:20px;color:#d8b77d;text-decoration:none;font-weight:800}.clean-list{list-style:none;margin-top:16px}.clean-list li{padding-left:24px;position:relative;margin-bottom:10px;color:#5f6670}.clean-list li:before{content:"";position:absolute;left:0;top:.7em;width:8px;height:8px;background:#c5a16f;border-radius:50%}@media(max-width:920px){.hero-grid,.grid,.footer-grid{grid-template-columns:1fr}.portrait{max-width:240px}.card-grid,.card-grid.two,.article-list,.impact-grid,.proof-strip{grid-template-columns:1fr}.nav{flex-wrap:wrap}.mobile-toggle{display:block}.nav-links{display:none;width:100%;padding:0 0 18px;flex-direction:column;align-items:flex-start}.nav-links.open{display:flex}.hero{padding:60px 0}.section{padding:62px 0}.hero-mark img{height:44px}.hero h1,.page-hero h1{font-size:2.6rem}}@media(max-width:520px){.container{width:min(100% - 28px,1120px)}.button-row{flex-direction:column}.btn{width:100%}.hero-mark{flex-direction:column;align-items:flex-start}.eyebrow{letter-spacing:.18em}.card{padding:22px}}


/* V2.2 validation refinements */
body.home .hero{min-height:calc(100vh - 72px);display:flex;align-items:center;padding:42px 0 34px;}
body.home .hero-grid{grid-template-columns:.72fr 1.28fr;gap:38px;}
body.home .portrait{width:min(270px,100%);max-height:48vh;object-fit:cover;object-position:center top;}
body.home .hero h1{font-size:clamp(2.15rem,4.4vw,3.85rem);line-height:1.04;margin-bottom:18px;}
body.home .hero p{font-size:clamp(1rem,1.5vw,1.18rem);}
body.home .button-row{margin-top:22px;}
.brand{gap:12px;}
.brand-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:0 14px 14px 0;background:#f7f3ed;margin-left:-20px;box-shadow:8px 0 20px rgba(0,0,0,.16);border-right:1px solid rgba(197,161,111,.35);}
.brand-icon-wrap img{width:36px!important;height:36px!important;border:0!important;border-radius:0!important;object-fit:contain!important;background:transparent!important;}
.hero-mark{gap:12px;margin-top:24px;}
.mark-cutout{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:#f7f3ed;box-shadow:0 12px 28px rgba(0,0,0,.25);}
.mark-cutout img{width:42px;height:42px;object-fit:contain;filter:none!important;}
.hero-mark>img{display:none;}
.footer-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;}
.footer-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:14px;background:#f7f3ed;box-shadow:0 14px 34px rgba(0,0,0,.28);margin-top:-10px;}
.footer-icon-wrap img{width:44px;height:44px;object-fit:contain;}
.footer-note{color:rgba(255,255,255,.76);font-size:.96rem;}
.footer-links{justify-content:center;margin-top:6px;}
.footer-links a{color:rgba(255,255,255,.86);}
.footer-links a:hover{color:#d8b77d;}
.copyright{font-size:.78rem;color:rgba(255,255,255,.48);margin-top:12px;align-self:flex-end;}
.footer-grid,.footer-logo{display:none!important;}
.impact-card{font-weight:700;line-height:1.55;}
.scroll-cue{position:fixed;right:22px;bottom:22px;z-index:60;width:42px;height:42px;border-radius:50%;background:#c5a16f;color:#071322;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:1.55rem;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.22);transition:opacity .2s ease,transform .2s ease;}
.scroll-cue.hidden{opacity:0;pointer-events:none;transform:translateY(8px);}
.clickable-card a{font-weight:800;color:#112747;text-decoration:none;}
@media(max-width:920px){body.home .hero{min-height:auto;padding:52px 0 42px;}body.home .hero-grid{grid-template-columns:1fr;gap:28px;}body.home .portrait{width:190px;max-height:none}.brand-icon-wrap{margin-left:0;width:44px;height:44px}.brand-icon-wrap img{width:32px!important;height:32px!important}.copyright{align-self:center}.scroll-cue{right:16px;bottom:16px;width:38px;height:38px}}



/* ===== V2.3 targeted stabilization patch, 27 May ===== */

/* Header: light logo zone, dark ribbon from name/nav onwards */
.site-header{
  background:linear-gradient(90deg,#f7f3ed 0 118px,rgba(13,28,51,.96) 118px 100%)!important;
}
.nav{
  min-height:66px!important;
}
.brand{
  gap:18px!important;
  min-width:230px!important;
}
.brand-icon-wrap{
  width:70px!important;
  height:58px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.brand img{
  width:56px!important;
  height:56px!important;
  border:0!important;
  border-radius:0!important;
  object-fit:contain!important;
  filter:none!important;
}
.nav-links{
  gap:16px!important;
}
.nav-links a{
  font-size:.86rem!important;
  white-space:nowrap!important;
}

/* Homepage hero: stable split background, smaller typography, first-fold friendly */
body.home .hero{
  background:linear-gradient(90deg,#f7f3ed 0 38%,#112747 38% 100%)!important;
  padding:44px 0 38px!important;
  min-height:calc(100vh - 66px)!important;
  display:flex!important;
  align-items:center!important;
}
body.home .hero-grid{
  grid-template-columns:minmax(260px,.82fr) minmax(420px,1.18fr)!important;
  gap:44px!important;
  align-items:center!important;
}
body.home .portrait{
  width:min(310px,100%)!important;
  border-radius:28px!important;
  box-shadow:0 20px 46px rgba(17,39,71,.18)!important;
}
body.home .hero .eyebrow{
  margin-bottom:12px!important;
}
body.home .hero h1{
  font-size:clamp(2.15rem,3.9vw,3.55rem)!important;
  line-height:1.06!important;
  letter-spacing:-.045em!important;
  max-width:780px!important;
  margin-bottom:20px!important;
}
body.home .hero p{
  font-size:clamp(1rem,1.45vw,1.18rem)!important;
  line-height:1.58!important;
  max-width:760px!important;
}
body.home .button-row{
  margin-top:26px!important;
}
body.home .hero-mark{
  display:none!important;
}

/* Footer: compressed and cleaner */
footer{
  padding:24px 0 20px!important;
}
.footer-inner{
  text-align:center!important;
}
.footer-icon-wrap,
.footer-note{
  display:none!important;
}
.footer-line{
  margin-top:0!important;
  font-size:1rem!important;
}
.footer-links{
  justify-content:center!important;
  margin-top:14px!important;
}
.copyright{
  margin-top:16px!important;
  font-size:.84rem!important;
  color:rgba(255,255,255,.52)!important;
}

/* Contact page: cards are the links, not raw URLs */
.contact-grid .contact-action{
  display:block!important;
  text-decoration:none!important;
  color:inherit!important;
  cursor:pointer!important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease!important;
}
.contact-grid .contact-action:hover{
  transform:translateY(-2px)!important;
  border-color:#c5a16f!important;
  box-shadow:0 16px 42px rgba(17,39,71,.12)!important;
}
.contact-grid .contact-action h3{
  color:#112747!important;
}
.contact-grid .contact-action p{
  color:#5f6670!important;
}

/* Medium screens: reduce nav and hero pressure before mobile collapse */
@media(max-width:1120px){
  .nav-links{gap:11px!important;}
  .nav-links a{font-size:.78rem!important;}
  .brand{min-width:200px!important;}
  body.home .hero-grid{
    grid-template-columns:minmax(220px,.72fr) minmax(390px,1.28fr)!important;
    gap:32px!important;
  }
  body.home .hero h1{
    font-size:clamp(2rem,3.6vw,3.05rem)!important;
  }
  body.home .portrait{
    width:min(280px,100%)!important;
  }
}

/* Mobile/tablet: single-column, calm, no clipping */
@media(max-width:920px){
  .site-header{
    background:linear-gradient(90deg,#f7f3ed 0 84px,rgba(13,28,51,.96) 84px 100%)!important;
  }
  .brand{
    min-width:auto!important;
    gap:12px!important;
  }
  .brand-icon-wrap{
    width:52px!important;
    height:50px!important;
  }
  .brand img{
    width:46px!important;
    height:46px!important;
  }
  body.home .hero{
    background:linear-gradient(180deg,#f7f3ed 0 42%,#112747 42% 100%)!important;
    min-height:auto!important;
    padding:44px 0 46px!important;
  }
  body.home .hero-grid{
    grid-template-columns:1fr!important;
    gap:30px!important;
  }
  body.home .portrait{
    width:min(260px,78vw)!important;
    margin:0 auto!important;
    display:block!important;
  }
  body.home .hero h1{
    font-size:clamp(2rem,9vw,3.1rem)!important;
  }
  body.home .hero p{
    font-size:1.03rem!important;
  }
}



/* ===== V2.3 focused patch 2: homepage left-light system + compact contact page ===== */

/* Header left area fully light across logo + name. Dark navigation begins after identity area. */
.site-header{
  background:linear-gradient(90deg,#f7f3ed 0 42%,rgba(13,28,51,.96) 42% 100%)!important;
}
.nav{
  min-height:64px!important;
}
.brand{
  color:#112747!important;
  min-width:360px!important;
  gap:18px!important;
}
.brand span{
  color:#112747!important;
  text-shadow:none!important;
}
.brand-icon-wrap{
  width:62px!important;
  height:54px!important;
}
.brand img{
  width:52px!important;
  height:52px!important;
}
.nav-links{
  margin-left:auto!important;
}

/* Homepage: left light column covers logo/name/profile and brings portrait closer to dark panel. */
body.home .hero{
  background:linear-gradient(90deg,#f7f3ed 0 42%,#112747 42% 100%)!important;
  padding:36px 0 34px!important;
  min-height:calc(100vh - 64px)!important;
}
body.home .hero-grid{
  grid-template-columns:minmax(360px,42%) minmax(540px,58%)!important;
  gap:0!important;
  align-items:center!important;
}
body.home .hero-grid > div:first-child{
  display:flex!important;
  justify-content:flex-end!important;
  padding-right:42px!important;
}
body.home .hero-grid > div:nth-child(2){
  padding-left:64px!important;
  overflow:visible!important;
}
body.home .portrait{
  width:min(340px,86%)!important;
  max-height:58vh!important;
  object-fit:cover!important;
  object-position:center top!important;
  border-radius:28px!important;
}
body.home .hero h1{
  font-size:clamp(2.05rem,3.45vw,3.35rem)!important;
  max-width:760px!important;
  overflow-wrap:normal!important;
}
body.home .hero p{
  max-width:720px!important;
}
body.home .button-row{
  gap:14px!important;
}
body.home .btn{
  padding:11px 18px!important;
  min-height:44px!important;
}

/* Contact page: make it fit as a one-screen page on desktop. */
body.contact-page .page-hero{
  padding:42px 0 34px!important;
  min-height:auto!important;
}
body.contact-page .page-hero h1{
  font-size:clamp(2.4rem,4.4vw,4rem)!important;
  max-width:650px!important;
}
body.contact-page .page-hero p{
  max-width:720px!important;
  font-size:1.04rem!important;
}
body.contact-page .section{
  padding:34px 0 30px!important;
}
body.contact-page .card-grid{
  grid-template-columns:repeat(4,1fr)!important;
  gap:16px!important;
}
body.contact-page .card{
  min-height:112px!important;
  padding:22px 22px!important;
}
body.contact-page .back-links{
  margin-top:22px!important;
}
body.contact-page footer{
  padding:14px 0 12px!important;
}
body.contact-page .footer-line{
  font-size:.88rem!important;
}
body.contact-page .footer-links{
  margin-top:8px!important;
}
body.contact-page .copyright{
  margin-top:8px!important;
}

/* Prevent desktop clipping before menu collapse by reducing header pressure. */
@media(max-width:1280px){
  .brand{min-width:300px!important;}
  .nav-links{gap:12px!important;}
  .nav-links a{font-size:.78rem!important;}
  body.home .hero-grid{
    grid-template-columns:minmax(320px,42%) minmax(470px,58%)!important;
  }
  body.home .hero-grid > div:nth-child(2){
    padding-left:42px!important;
  }
  body.home .hero h1{
    font-size:clamp(1.95rem,3.25vw,3rem)!important;
  }
  body.home .portrait{
    width:min(310px,86%)!important;
  }
}

/* Earlier mobile collapse to protect nav and hero. */
@media(max-width:1080px){
  .site-header{
    background:rgba(13,28,51,.96)!important;
  }
  .brand,.brand span{
    color:#fff!important;
  }
  .brand{min-width:auto!important;}
  body.home .hero{
    background:linear-gradient(180deg,#f7f3ed 0 42%,#112747 42% 100%)!important;
  }
  body.home .hero-grid{
    grid-template-columns:1fr!important;
    gap:30px!important;
  }
  body.home .hero-grid > div:first-child{
    justify-content:center!important;
    padding-right:0!important;
  }
  body.home .hero-grid > div:nth-child(2){
    padding-left:0!important;
  }
  body.contact-page .card-grid{
    grid-template-columns:repeat(2,1fr)!important;
  }
}
@media(max-width:680px){
  body.contact-page .card-grid{
    grid-template-columns:1fr!important;
  }
}



/* ===== V2.3 Patch 3: white header, clean logo, stable home hero, one-screen contact ===== */

/* Universal patched header: clean white ribbon, dark text */
.site-header{
  background:#f7f3ed!important;
  border-bottom:1px solid #e5d9ca!important;
  backdrop-filter:none!important;
}
.nav{
  min-height:66px!important;
}
.brand{
  color:#112747!important;
  min-width:300px!important;
  gap:16px!important;
}
.brand span{
  color:#112747!important;
  text-shadow:none!important;
}
.brand-icon-wrap{
  width:72px!important;
  height:56px!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.brand img{
  width:68px!important;
  height:52px!important;
  border:0!important;
  border-radius:0!important;
  object-fit:contain!important;
  filter:none!important;
}
.nav-links{
  margin-left:auto!important;
  gap:18px!important;
}
.nav-links a{
  color:#112747!important;
  font-size:.88rem!important;
  white-space:nowrap!important;
}
.nav-links a:hover,
.nav-links a.active{
  color:#8b6a36!important;
}
.mobile-toggle{
  color:#112747!important;
  border-color:rgba(17,39,71,.25)!important;
}

/* Homepage: stable split, less empty white space, stronger portrait presence */
body.home .hero{
  background:linear-gradient(90deg,#f7f3ed 0 41%,#112747 41% 100%)!important;
  padding:24px 0 24px!important;
  min-height:calc(100vh - 66px)!important;
  display:flex!important;
  align-items:center!important;
}
body.home .hero-grid{
  grid-template-columns:minmax(390px,41%) minmax(560px,59%)!important;
  gap:0!important;
  align-items:center!important;
  width:100%!important;
}
body.home .hero-grid > div:first-child{
  display:flex!important;
  justify-content:flex-end!important;
  align-items:center!important;
  padding-right:34px!important;
}
body.home .hero-grid > div:nth-child(2){
  padding-left:60px!important;
  padding-right:20px!important;
  overflow:visible!important;
}
body.home .portrait{
  width:min(410px,92%)!important;
  max-height:68vh!important;
  object-fit:cover!important;
  object-position:center top!important;
  border-radius:30px!important;
  box-shadow:0 20px 50px rgba(17,39,71,.18)!important;
}
body.home .hero h1{
  font-size:clamp(2.05rem,3.35vw,3.25rem)!important;
  line-height:1.06!important;
  max-width:760px!important;
  letter-spacing:-.045em!important;
  margin-bottom:18px!important;
}
body.home .hero p{
  font-size:clamp(1rem,1.35vw,1.15rem)!important;
  line-height:1.55!important;
  max-width:720px!important;
}
body.home .button-row{
  margin-top:24px!important;
  gap:12px!important;
}
body.home .btn{
  min-height:42px!important;
  padding:10px 17px!important;
}
body.home .hero-mark{
  display:none!important;
}

/* Contact page: compact full-screen layout */
body.contact-compact{
  background:#081526!important;
}
body.contact-compact .contact-main{
  background:#081526!important;
}
body.contact-compact .contact-screen{
  min-height:calc(100vh - 66px - 102px)!important;
  padding:42px 0 28px!important;
  background:linear-gradient(135deg,#081526 0%,#112747 62%,#091322 100%)!important;
  color:#fff!important;
  display:flex!important;
  align-items:center!important;
}
body.contact-compact .contact-screen-grid{
  display:grid!important;
  grid-template-columns:1.05fr .95fr!important;
  gap:42px!important;
  align-items:center!important;
}
body.contact-compact .contact-copy h1{
  font-size:clamp(2.45rem,4.5vw,4.25rem)!important;
  line-height:1.05!important;
  letter-spacing:-.05em!important;
  margin-bottom:20px!important;
  max-width:720px!important;
}
body.contact-compact .contact-copy p:not(.eyebrow){
  color:rgba(255,255,255,.78)!important;
  font-size:clamp(1rem,1.35vw,1.15rem)!important;
  line-height:1.6!important;
  max-width:720px!important;
}
body.contact-compact .contact-card-panel{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:16px!important;
}
body.contact-compact .card{
  background:#f7f3ed!important;
  min-height:128px!important;
  padding:24px!important;
  border-radius:22px!important;
  border:1px solid rgba(197,161,111,.34)!important;
}
body.contact-compact .card h3{
  color:#112747!important;
  margin-bottom:12px!important;
}
body.contact-compact .card p{
  color:#5f6670!important;
}
body.contact-compact .contact-action{
  text-decoration:none!important;
  color:inherit!important;
  transition:transform .18s ease, box-shadow .18s ease!important;
}
body.contact-compact .contact-action:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 18px 48px rgba(0,0,0,.22)!important;
}
body.contact-compact footer{
  padding:14px 0 12px!important;
}
body.contact-compact .footer-icon-wrap,
body.contact-compact .footer-note{
  display:none!important;
}
body.contact-compact .footer-line{
  font-size:.86rem!important;
  margin:0!important;
}
body.contact-compact .footer-links{
  margin-top:8px!important;
  justify-content:center!important;
}
body.contact-compact .copyright{
  margin-top:8px!important;
  font-size:.78rem!important;
}

/* Header and hero pressure control */
@media(max-width:1280px){
  .brand{min-width:260px!important;}
  .nav-links{gap:12px!important;}
  .nav-links a{font-size:.78rem!important;}
  body.home .hero-grid{
    grid-template-columns:minmax(340px,41%) minmax(490px,59%)!important;
  }
  body.home .hero-grid > div:nth-child(2){
    padding-left:42px!important;
  }
  body.home .portrait{
    width:min(360px,92%)!important;
  }
  body.home .hero h1{
    font-size:clamp(1.9rem,3.15vw,2.95rem)!important;
  }
  body.contact-compact .contact-screen{
    padding:34px 0 22px!important;
  }
  body.contact-compact .contact-copy h1{
    font-size:clamp(2.2rem,4vw,3.55rem)!important;
  }
  body.contact-compact .card{
    min-height:112px!important;
    padding:20px!important;
  }
}

/* Mobile/tablet */
@media(max-width:1080px){
  .brand{min-width:auto!important;}
  .nav-links a{font-size:.86rem!important;}
  body.home .hero{
    background:linear-gradient(180deg,#f7f3ed 0 43%,#112747 43% 100%)!important;
    min-height:auto!important;
    padding:38px 0 42px!important;
  }
  body.home .hero-grid{
    grid-template-columns:1fr!important;
    gap:28px!important;
  }
  body.home .hero-grid > div:first-child{
    justify-content:center!important;
    padding-right:0!important;
  }
  body.home .hero-grid > div:nth-child(2){
    padding-left:0!important;
    padding-right:0!important;
  }
  body.home .portrait{
    width:min(340px,82vw)!important;
  }
  body.contact-compact .contact-screen{
    min-height:auto!important;
  }
  body.contact-compact .contact-screen-grid{
    grid-template-columns:1fr!important;
  }
}
@media(max-width:680px){
  body.contact-compact .contact-card-panel{
    grid-template-columns:1fr!important;
  }
}



/* ===== V2.3 Patch 4: softened hero edge + contact vertical card stack ===== */

/* Homepage: soften dark frame edge without losing strong executive contrast */
body.home .hero{
  background:#f7f3ed!important;
  position:relative!important;
  overflow:hidden!important;
}
body.home .hero::before{
  content:""!important;
  position:absolute!important;
  top:0!important;
  bottom:0!important;
  left:41%!important;
  right:0!important;
  background:#112747!important;
  border-top-left-radius:34px!important;
  border-bottom-left-radius:34px!important;
  z-index:0!important;
}
body.home .hero .container{
  position:relative!important;
  z-index:1!important;
}
body.home .hero-grid > div:nth-child(2){
  background:transparent!important;
}

/* Home portrait: slightly stronger visual presence and less stranded white-space feel */
body.home .portrait{
  width:min(430px,94%)!important;
  max-height:70vh!important;
}
body.home .hero-grid > div:first-child{
  padding-right:26px!important;
}

/* Contact: keep everything inside first-screen dark frame */
body.contact-compact .contact-screen{
  min-height:calc(100vh - 66px - 74px)!important;
  padding:30px 0 20px!important;
}
body.contact-compact .contact-screen-grid{
  grid-template-columns:1.12fr .72fr!important;
  gap:34px!important;
  align-items:center!important;
}
body.contact-compact .contact-copy h1{
  font-size:clamp(2.15rem,3.75vw,3.6rem)!important;
  max-width:680px!important;
  margin-bottom:16px!important;
}
body.contact-compact .contact-copy p:not(.eyebrow){
  font-size:1.02rem!important;
  max-width:690px!important;
}
body.contact-compact .contact-card-panel{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:10px!important;
  align-content:center!important;
}
body.contact-compact .card{
  min-height:74px!important;
  padding:16px 20px!important;
  border-radius:18px!important;
}
body.contact-compact .card h3{
  margin-bottom:5px!important;
  font-size:1.06rem!important;
}
body.contact-compact .card p{
  font-size:.94rem!important;
  line-height:1.35!important;
}
body.contact-compact footer{
  padding:8px 0 8px!important;
  min-height:0!important;
}
body.contact-compact .footer-line{
  font-size:.78rem!important;
}
body.contact-compact .footer-links{
  margin-top:5px!important;
  gap:12px!important;
}
body.contact-compact .footer-links a{
  font-size:.82rem!important;
}
body.contact-compact .copyright{
  display:block!important;
  margin-top:5px!important;
  font-size:.72rem!important;
  color:rgba(255,255,255,.5)!important;
}

/* Zoom / width pressure refinements */
@media(max-width:1280px){
  body.home .hero::before{
    left:41%!important;
    border-top-left-radius:28px!important;
    border-bottom-left-radius:28px!important;
  }
  body.home .portrait{
    width:min(390px,94%)!important;
  }
  body.home .hero-grid > div:first-child{
    padding-right:22px!important;
  }
  body.contact-compact .contact-screen-grid{
    grid-template-columns:1fr .72fr!important;
    gap:26px!important;
  }
  body.contact-compact .contact-copy h1{
    font-size:clamp(2rem,3.5vw,3.2rem)!important;
  }
  body.contact-compact .card{
    min-height:68px!important;
    padding:14px 18px!important;
  }
}

@media(max-width:1080px){
  body.home .hero::before{
    display:none!important;
  }
  body.home .hero{
    background:linear-gradient(180deg,#f7f3ed 0 43%,#112747 43% 100%)!important;
  }
  body.contact-compact .contact-screen-grid{
    grid-template-columns:1fr!important;
  }
  body.contact-compact .contact-card-panel{
    grid-template-columns:1fr 1fr!important;
  }
}
@media(max-width:680px){
  body.contact-compact .contact-card-panel{
    grid-template-columns:1fr!important;
  }
}



/* ===== FINAL RELEASE PATCH : Typography Harmonization ===== */

/* Align remaining internal page headers with Home / Contact visual language */
.internal-hero h1,
.page-hero h1,
.executive-hero h1,
.strategic-hero h1,
.perspectives-hero h1,
.conversations-hero h1{
    font-size: clamp(3rem, 5vw, 5.2rem)!important;
    line-height: .96!important;
    letter-spacing: -0.03em!important;
    font-weight: 800!important;
    max-width: 900px!important;
}

/* improve eyebrow consistency */
.internal-hero .eyebrow,
.page-hero .eyebrow{
    font-size: .95rem!important;
    letter-spacing: .32em!important;
    font-weight: 700!important;
}

/* improve paragraph alignment consistency */
.internal-hero p,
.page-hero p{
    font-size: 1.08rem!important;
    line-height: 1.72!important;
    max-width: 760px!important;
}

/* responsive tuning */
@media(max-width:1280px){
    .internal-hero h1,
    .page-hero h1,
    .executive-hero h1,
    .strategic-hero h1,
    .perspectives-hero h1,
    .conversations-hero h1{
        font-size: clamp(2.6rem, 4.4vw, 4.4rem)!important;
    }
}

@media(max-width:768px){
    .internal-hero h1,
    .page-hero h1,
    .executive-hero h1,
    .strategic-hero h1,
    .perspectives-hero h1,
    .conversations-hero h1{
        font-size: clamp(2.1rem, 8vw, 3.2rem)!important;
        line-height: 1.02!important;
    }
}
