
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#F6F6F4;
  --bg-soft:#F4F0EA;
  --bg-tint:#F1ECE4;
  --bg-gradient:linear-gradient(180deg,#F6F6F4 0%,#EFEAE2 50%,#EAE4DA 100%);
  --card:#FFFFFF;
  --text:#1B1B1B;
  --muted:rgba(27,27,27,.72);
  --line:rgba(0,0,0,.08);
  --green:#35544D;
  --green-dark:#2E4943;
  --shadow:0 18px 50px rgba(0,0,0,.06);
  --shadow-soft:0 14px 35px rgba(0,0,0,.035);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,sans-serif;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(1120px,calc(100% - 48px));margin:0 auto}
.section{padding:88px 0}
.eyebrow{
  margin:0 0 18px;
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:rgba(27,27,27,.7);
  font-weight:600;
}
h1,h2,h3,.serif{
  font-family:'Cormorant Garamond', Georgia, serif;
  font-weight:600;
}
h1{margin:0;font-size:clamp(3.3rem,7vw,5.4rem);line-height:.9;letter-spacing:-.04em}
h2{margin:0;font-size:clamp(2.2rem,5vw,3.5rem);line-height:1.02;letter-spacing:-.02em}
h3{margin:0;font-size:clamp(1.8rem,4vw,2.35rem);line-height:1.04}
p{margin:0}
.lead{font-size:clamp(1.25rem,2.8vw,2.1rem);line-height:1.15;letter-spacing:-.02em;color:#2B2B2B;font-family:'Cormorant Garamond',Georgia,serif}
.copy{font-size:1.08rem;line-height:1.95;color:var(--muted)}
.btns{display:flex;flex-wrap:wrap;gap:12px}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  border-radius:999px;padding:14px 22px;
  font-size:.95rem;font-weight:600;
  border:1px solid rgba(0,0,0,.12);
  transition:.2s ease;
  background:#fff;
  color:var(--green);
}
.btn:hover{transform:translateY(-1px);background:#F7F7F5}
.btn.primary{background:var(--green);color:white;border-color:transparent;box-shadow:0 8px 24px rgba(53,84,77,.18)}
.btn.primary:hover{background:var(--green-dark)}
.icon{width:16px;height:16px;display:inline-block;vertical-align:middle}

/* header */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(246,246,244,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,.05);
}
.site-header .inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 0;
}
.brand-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.35rem}
.brand-sub{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(0,0,0,.6)}
.nav{display:none;gap:28px;font-size:.95rem}
.nav a{transition:.2s}.nav a:hover{opacity:.6}
@media(min-width:900px){.nav{display:flex}}

/* hero */
.hero{
  position:relative;overflow:hidden;background:#F3F0EA;
}
.hero-media,.hero-grad,.hero-grad-2{position:absolute;inset:0}
.hero-media img{
  width:100%;height:100%;object-fit:cover;object-position:72% 35%;
  filter:brightness(.96) contrast(.96) saturate(.9);
}
.hero-grad{background:linear-gradient(90deg,rgba(246,246,244,.96) 0%,rgba(246,246,244,.92) 26%,rgba(246,246,244,.7) 42%,rgba(246,246,244,.08) 66%,rgba(246,246,244,0) 100%)}
.hero-grad-2{background:linear-gradient(180deg,rgba(246,246,244,.18) 0%,rgba(246,246,244,0) 18%,rgba(246,246,244,0) 82%,rgba(246,246,244,.16) 100%)}
.hero .inner{
  position:relative;display:grid;align-items:center;min-height:700px;padding:72px 0 0;
}
.hero-copy{max-width:32rem;padding-bottom:68px}
.hero-location{margin-bottom:20px;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--green);font-weight:600}
.hero-smallname{margin:0 0 10px;font-size:clamp(2rem,3vw,2.3rem);line-height:1;letter-spacing:.01em}
.hero .lead{max-width:26rem;margin-top:24px}
.hero .copy{max-width:31rem;margin-top:26px}
.hero .btns{margin-top:32px}
@media(max-width:899px){
  .container{width:min(1120px,calc(100% - 32px))}
  .hero .inner{min-height:620px}
  .hero-media img{object-position:68% 30%}
  .hero-smallname{font-size:1.85rem}
}

/* strip */
.stats-strip{border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);background:var(--bg-soft)}
.stats-grid{display:grid;gap:18px;padding:24px 0}
.stat-item{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;padding:8px 14px}
.stat-item p{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.22rem;line-height:1.35;color:#2A2A2A}
@media(min-width:900px){
 .stats-grid{grid-template-columns:repeat(4,1fr);gap:0}
 .stat-item:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:1px;height:40px;background:rgba(0,0,0,.1)}
}

/* about */
.about-grid{display:grid;gap:48px;align-items:start}
.about-copy{display:flex;flex-direction:column;gap:24px}
.divider-line{width:min(26rem,100%);height:1px;background:rgba(0,0,0,.1);position:relative;margin-top:8px}
.divider-line span{position:absolute;left:0;top:0;width:80px;height:1px;background:#7A9A94}
.about-image{
  overflow:hidden;border-radius:32px;border:1px solid rgba(0,0,0,.05);box-shadow:var(--shadow);
  width:min(100%,30rem);justify-self:center
}
.about-image img{width:100%;aspect-ratio:4/4.7;object-fit:cover;object-position:center 18%}
@media(min-width:900px){
 .about-grid{grid-template-columns:.95fr 1.05fr;gap:64px}
}

/* expertise */
.expertise-intro{display:grid;gap:20px;align-items:end;margin-bottom:36px}
.expertise-note{border:1px solid rgba(0,0,0,.05);background:#fff;border-radius:28px;padding:22px;color:var(--muted);font-size:.96rem;line-height:1.8}
.expertise-grid{display:grid;gap:22px}
.card{
  display:block;overflow:hidden;border-radius:28px;border:1px solid rgba(0,0,0,.05);background:#fff;transition:.25s ease;
}
.card:hover{transform:translateY(-3px);background:#F1ECE4}
.card-image{height:220px;overflow:hidden}
.card-image img{width:100%;height:100%;object-fit:cover}
.card-body{padding:28px}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.card-top h3{font-size:2rem;line-height:1.02}
.card-arrow{width:18px;height:18px;margin-top:6px;opacity:.58;color:var(--green)}
.card-rule{width:56px;height:1px;background:rgba(31,58,55,.25);margin:18px 0;transition:.25s ease}
.card:hover .card-rule{width:96px}
.card-text{color:var(--muted);line-height:1.9}
.card-link{margin-top:20px;color:var(--green);font-weight:600;font-size:.95rem}
@media(min-width:900px){
 .expertise-intro{grid-template-columns:1.1fr .9fr}
 .expertise-grid{grid-template-columns:repeat(2,1fr)}
}

/* credibility */
.credibility{background:var(--bg-gradient)}
.cred-grid{display:grid;gap:28px;align-items:start}
.slide-panel{
  border-radius:32px;border:1px solid rgba(0,0,0,.06);background:#fff;padding:32px;box-shadow:0 16px 40px rgba(0,0,0,.04)
}
.slide-eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--green);font-weight:600}
.slide-title{margin-top:20px}
.slide-text{margin-top:24px;color:var(--muted);font-size:1.05rem;line-height:1.95}
.slide-controls{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:28px}
.dots{display:flex;gap:8px;align-items:center}
.dot{width:10px;height:10px;border-radius:999px;background:rgba(0,0,0,.15);border:0;cursor:pointer}
.dot.active{width:32px;background:var(--green)}
.arrow-btn{
  width:44px;height:44px;border-radius:999px;border:1px solid rgba(0,0,0,.1);display:grid;place-items:center;cursor:pointer;background:#F7F4EE;color:#2B2B2B
}
.arrow-btn.primary{background:var(--green);color:#fff}
.cred-cards{display:grid;gap:16px}
.cred-card{border-radius:28px;border:1px solid rgba(0,0,0,.06);background:#fff;padding:26px;box-shadow:var(--shadow-soft)}
.cred-card .kicker{margin-top:10px;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--green);font-weight:600}
.cred-card .value{font-family:'Cormorant Garamond',Georgia,serif;font-size:2rem;line-height:1}
.cred-card p:last-child{margin-top:14px;color:var(--muted);line-height:1.75}
@media(min-width:900px){
 .cred-grid{grid-template-columns:.92fr 1.08fr;gap:48px}
 .cred-cards{grid-template-columns:repeat(2,1fr)}
}

/* approach */
.pillars-grid{display:grid;gap:24px;margin-top:40px}
.pillar{border-radius:28px;border:1px solid rgba(0,0,0,.05);background:#fff;padding:32px}
.pillar h3{font-size:2rem;line-height:1}
.pillar .mini-rule{width:48px;height:1px;background:rgba(31,58,55,.2);margin-top:16px}
.pillar p{margin-top:20px;color:var(--muted);line-height:1.85}
.cta-panel{
  margin-top:52px;display:flex;flex-direction:column;gap:22px;justify-content:space-between;
  border-radius:32px;border:1px solid rgba(0,0,0,.06);background:var(--bg-tint);padding:30px
}
.cta-panel h3{font-size:2.2rem;line-height:1.05}
.cta-panel p{margin-top:10px;color:var(--muted);line-height:1.8;max-width:42rem}
@media(min-width:900px){
 .pillars-grid{grid-template-columns:repeat(3,1fr)}
 .cta-panel{flex-direction:row;align-items:center}
}

/* contact */
.contact-section{background:#1F3A37;color:#fff}
.contact-grid{display:grid;gap:28px}
.contact-lead{max-width:32rem;color:rgba(255,255,255,.82);font-size:1.08rem;line-height:1.9}
.contact-info{
  margin-top:18px;border-radius:32px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);padding:28px;backdrop-filter:blur(8px)
}
.contact-block + .contact-block{margin-top:20px}
.contact-label{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:600}
.contact-value{margin-top:8px}
.contact-value.phone{font-family:'Cormorant Garamond',Georgia,serif;font-size:2rem;color:#fff}
.form-card{
  border-radius:32px;background:#fff;color:#111;padding:28px;box-shadow:0 22px 60px rgba(0,0,0,.12)
}
.form-grid{display:grid;gap:16px}
.field label{display:block;margin-bottom:8px;font-size:.92rem;color:rgba(0,0,0,.7)}
.field input,.field textarea{
  width:100%;border-radius:18px;border:1px solid rgba(0,0,0,.1);background:#F7F7F5;padding:14px 16px;
  font:inherit;outline:none
}
.field input:focus,.field textarea:focus{border-color:#1F3A37}
.form-note{font-size:.9rem;color:rgba(0,0,0,.55)}
.map-wrap{margin-top:30px;overflow:hidden;border-radius:32px;border:1px solid rgba(255,255,255,.12)}
@media(min-width:900px){
 .contact-grid{grid-template-columns:.9fr 1.1fr}
 .form-grid.two{grid-template-columns:repeat(2,1fr)}
}

/* footer */
.site-footer{border-top:1px solid rgba(0,0,0,.05);padding:40px 0;background:var(--bg)}
.footer-grid{display:grid;gap:20px}
.footer-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:2rem}
.footer-sub{margin-top:6px;font-size:.75rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(0,0,0,.55)}
.footer-lines{margin-top:24px;display:grid;gap:8px;color:rgba(0,0,0,.7)}
.footer-side{color:rgba(0,0,0,.55);font-size:.95rem}
@media(min-width:900px){
  .footer-grid{grid-template-columns:1fr auto;align-items:end}
  .footer-side{text-align:right}
}

/* expertise page */
.page-hero{padding:72px 0 40px;background:var(--bg-soft);border-bottom:1px solid rgba(0,0,0,.06)}
.breadcrumbs{font-size:.9rem;color:rgba(0,0,0,.55);margin-bottom:16px}
.hero-page-grid{display:grid;gap:28px;align-items:center}
.hero-page-image{border-radius:32px;overflow:hidden;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow)}
.hero-page-image img{width:100%;height:100%;min-height:340px;object-fit:cover}
.page-body{padding:70px 0}
.content-grid{display:grid;gap:36px}
.prose{display:grid;gap:18px}
.prose p{color:var(--muted);line-height:1.9}
.side-card{border-radius:28px;background:#fff;border:1px solid rgba(0,0,0,.06);padding:24px;box-shadow:var(--shadow-soft)}
.side-card h3{font-size:1.8rem}
.list{display:grid;gap:10px;padding-left:18px;color:var(--muted)}
@media(min-width:900px){
 .hero-page-grid{grid-template-columns:1fr .9fr}
 .content-grid{grid-template-columns:1.15fr .85fr}
}


/* v2.1 additions */
.more-link{display:inline-flex;align-items:center;gap:8px;margin-top:6px;font-size:.95rem;font-weight:600;color:var(--green);transition:.2s ease}
.more-link:hover{opacity:.72}
.expertise-intro.centered{display:flex;justify-content:center;margin-bottom:36px}
.expertise-intro.centered .copy{max-width:48rem;text-align:center}
.map-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:0 0 16px}
.map-eyebrow{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:600}
.map-copy{margin-top:8px;color:rgba(255,255,255,.85)}
.map-link{font-size:.95rem;font-weight:600;color:rgba(255,255,255,.9);transition:.2s ease;display:inline-flex;gap:8px;align-items:center}
.map-link:hover{color:#fff}
.ap-header-link{font-size:.95rem;transition:.2s ease}
.ap-header-link:hover{opacity:.65}
.ap-hero{background:#F3F0EA}
.ap-hero-grid{display:grid;gap:40px;align-items:center;padding:72px 0}
.ap-hero-image{border-radius:32px;overflow:hidden;border:1px solid rgba(0,0,0,.05);box-shadow:var(--shadow)}
.ap-hero-image img{width:100%;height:420px;object-fit:cover;object-position:center 18%}
.ap-section-grid{display:grid;gap:40px;align-items:start}
.ap-note{border-radius:28px;border:1px solid rgba(0,0,0,.06);background:#fff;padding:24px;box-shadow:var(--shadow-soft)}
.ap-note ul{margin:18px 0 0;padding-left:18px;display:grid;gap:10px;color:var(--muted)}
.ap-cards{display:grid;gap:18px}
.ap-card{border-radius:28px;border:1px solid rgba(0,0,0,.06);background:#F6F3EE;padding:24px}
.ap-card h3{font-size:1.6rem;margin:0}
.ap-card p{margin-top:14px;color:var(--muted);line-height:1.85}
.ap-cta{text-align:center;padding:84px 0}
@media(min-width:900px){
  .ap-hero-grid{grid-template-columns:.9fr 1.1fr;padding:92px 0}
  .ap-section-grid.two{grid-template-columns:1fr .95fr}
  .ap-section-grid.reverse{grid-template-columns:1.05fr .95fr;align-items:center}
  .ap-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:899px){
  .map-head{flex-direction:column;align-items:flex-start}
}
