@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Cormorant+Garamond:ital,wght@0,400;1,400;1,500&display=swap');

:root {
  --taupe-hero:  #b8aa9c;
  --taupe-dark:  #a89888;
  --taupe-mid:   #cbbfb4;
  --taupe-light: #ddd5cc;
  --cream:       #ece7df;
  --cream-light: #f3ede6;
  --off-white:   #f8f4ef;
  --nav-bg:      #f0ebe3;

  --text-dark:   #1a1815;
  --text-body:   #3d3a36;
  --text-muted:  #6e6760;
  --text-light:  #9e9690;
  --border:      rgba(26,24,21,0.10);
  --border-dk:   rgba(26,24,21,0.18);

  --font:        'Instrument Sans', sans-serif;
  --serif:       'Cormorant Garamond', serif;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--cream-light);
  color: var(--text-dark);
  font-family: var(--font);
  font-weight: 400;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

/* NAV */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 52px; height:68px;
  background:var(--nav-bg);
  border-bottom:1px solid var(--border);
}
.wordmark { font-size:17px; font-weight:500; color:var(--text-dark); text-decoration:none; letter-spacing:-0.01em; }
.nav-links { display:flex; align-items:center; gap:32px; list-style:none; }
.nav-links a {
  font-size:13.5px; font-weight:400; color:var(--text-body);
  text-decoration:none; transition:color 0.2s; position:relative; padding-bottom:2px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:1px; background:var(--text-dark); transform:scaleX(0);
  transform-origin:left; transition:transform 0.25s;
}
.nav-links a:hover, .nav-links a.active { color:var(--text-dark); }
.nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }
.nav-cta {
  background:var(--text-dark) !important; color:var(--off-white) !important;
  padding:10px 22px; border-radius:100px; font-size:12px !important;
  letter-spacing:0.07em; text-transform:uppercase; font-weight:500 !important;
  text-decoration:none; transition:opacity 0.2s;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { opacity:0.8; }

.nav-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
.nav-toggle span { display:block; width:22px; height:1px; background:var(--text-body); }
.mobile-menu {
  display:none; position:fixed; top:68px; left:0; right:0; z-index:199;
  background:var(--nav-bg); border-bottom:1px solid var(--border);
  padding:24px 32px; flex-direction:column; gap:18px;
}
.mobile-menu.open { display:flex; }
.mobile-menu a { font-size:14px; color:var(--text-body); text-decoration:none; }
.mobile-menu a:hover { color:var(--text-dark); }

/* PAGE */
.page { padding-top:68px; }

/* HERO SPLIT */
.hero-split { display:grid; grid-template-columns:1fr 1fr; min-height:calc(100vh - 68px); }
.hero-left {
  background:var(--taupe-hero);
  display:flex; flex-direction:column; justify-content:center;
  padding:80px 64px;
}
.hero-eyebrow { font-size:12px; letter-spacing:0.13em; text-transform:uppercase; color:var(--text-muted); font-weight:500; margin-bottom:22px; }
.hero-title {
  font-family:var(--font); font-size:clamp(34px,4vw,54px);
  font-weight:400; line-height:1.08; color:var(--text-dark);
  margin-bottom:20px; letter-spacing:-0.02em;
}
.hero-title em { font-family:var(--serif); font-style:italic; font-weight:400; }
.hero-sub-label { font-size:13px; font-weight:500; color:var(--text-body); margin-bottom:10px; }
.hero-sub { font-size:14px; font-weight:400; line-height:1.8; color:var(--text-body); max-width:440px; margin-bottom:44px; }
.hero-right { background:var(--taupe-mid); position:relative; overflow:hidden; }
.hero-right img { width:100%; height:100%; object-fit:cover; display:block; }

/* INNER PAGE HERO */
.page-hero { background:var(--taupe-hero); padding:100px 64px 80px; border-bottom:1px solid var(--border); }
.page-hero .hero-title { font-size:clamp(34px,5vw,60px); max-width:700px; margin-bottom:20px; }

/* SECTIONS */
.section { padding:96px 64px; }
.section-inner { max-width:1120px; margin:0 auto; }
.eyebrow { font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--text-muted); font-weight:500; margin-bottom:14px; }
.section-title { font-family:var(--font); font-size:clamp(28px,3.2vw,46px); font-weight:400; line-height:1.1; color:var(--text-dark); margin-bottom:18px; letter-spacing:-0.015em; }
.section-sub { font-size:14px; font-weight:400; line-height:1.85; color:var(--text-body); max-width:580px; }
.rule { width:36px; height:1px; background:var(--border-dk); margin:20px 0; }

/* TRUST BAR */
.trust-bar { display:grid; grid-template-columns:repeat(3,1fr); background:var(--off-white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.trust-item { padding:44px 52px; border-right:1px solid var(--border); }
.trust-item:last-child { border-right:none; }
.trust-num { font-size:50px; font-weight:300; color:var(--text-dark); line-height:1; margin-bottom:6px; letter-spacing:-0.03em; }
.trust-label { font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-muted); font-weight:500; }
.trust-desc { font-size:13px; color:var(--text-muted); margin-top:8px; line-height:1.6; }

/* IMAGE GRID */
.img-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-top:64px; }
.img-tile { aspect-ratio:4/3; overflow:hidden; background:var(--taupe-mid); }
.img-tile img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.6s; }
.img-tile:hover img { transform:scale(1.04); }

/* CARDS */
.card-wrap { display:grid; gap:1px; }
.card-wrap-2 { grid-template-columns:1fr 1fr; }
.card-wrap-3 { grid-template-columns:repeat(3,1fr); }
.card-item { background:var(--off-white); padding:44px 36px; }
.card-item:nth-child(even) { background:var(--cream); }
.card-num { font-size:11px; letter-spacing:0.14em; color:var(--text-light); font-weight:500; margin-bottom:18px; }
.card-title { font-size:19px; font-weight:500; color:var(--text-dark); margin-bottom:10px; line-height:1.2; }
.card-body { font-size:13.5px; font-weight:400; line-height:1.8; color:var(--text-muted); }
.card-divider { border:none; border-top:1px solid var(--border); margin:18px 0; }
.card-promise-label { font-size:10px; letter-spacing:0.13em; text-transform:uppercase; color:var(--text-muted); font-weight:500; margin-bottom:7px; }
.card-promise-text { font-size:13px; font-style:italic; color:var(--text-body); line-height:1.75; }

/* SPLIT SECTION */
.split-section { display:grid; grid-template-columns:1fr 1fr; min-height:500px; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.split-text { padding:80px 64px; display:flex; flex-direction:column; justify-content:center; background:var(--cream-light); }
.split-img { background:var(--taupe-mid); overflow:hidden; }
.split-img img { width:100%; height:100%; object-fit:cover; display:block; }

/* CALLOUT */
.callout { background:var(--taupe-hero); padding:80px 64px; }
.callout-inner { max-width:760px; }
.callout-quote { font-family:var(--serif); font-size:clamp(22px,2.8vw,34px); font-weight:400; font-style:italic; line-height:1.45; color:var(--text-dark); margin-bottom:20px; }
.callout-attr { font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--text-muted); font-weight:500; }

/* FEATURE LIST */
.feature-list { display:flex; flex-direction:column; }
.feature-item { padding:22px 0; border-bottom:1px solid var(--border); }
.feature-item:first-child { border-top:1px solid var(--border); }
.feature-title { font-size:16px; font-weight:500; color:var(--text-dark); margin-bottom:5px; line-height:1.3; }
.feature-body { font-size:13.5px; color:var(--text-muted); line-height:1.75; }

/* PROVIDER STRIP */
.provider-strip { display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--border); }
.provider-half { padding:72px 56px; display:flex; flex-direction:column; justify-content:flex-end; }
.provider-half:first-child { background:var(--off-white); border-right:1px solid var(--border); }
.provider-half:last-child { background:var(--taupe-hero); }
.provider-label { font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--text-muted); font-weight:500; margin-bottom:10px; }
.provider-title { font-size:26px; font-weight:400; color:var(--text-dark); margin-bottom:14px; line-height:1.2; letter-spacing:-0.01em; }
.provider-body { font-size:13.5px; color:var(--text-body); line-height:1.75; margin-bottom:28px; }

/* BUTTONS */
.btn { display:inline-block; text-decoration:none; font-family:var(--font); font-size:12px; font-weight:500; letter-spacing:0.08em; text-transform:uppercase; padding:14px 28px; transition:all 0.22s; cursor:pointer; border:none; border-radius:100px; }
.btn-dark { background:var(--text-dark); color:var(--off-white); }
.btn-dark:hover { opacity:0.8; }
.btn-outline { background:transparent; color:var(--text-body); border:1px solid var(--border-dk); }
.btn-outline:hover { background:rgba(26,24,21,0.06); color:var(--text-dark); }

/* STAT GRID */
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:1px; }
.stat-box { background:var(--cream); padding:32px 28px; }
.stat-box:nth-child(odd) { background:var(--off-white); }
.stat-num { font-size:44px; font-weight:300; color:var(--text-dark); line-height:1; margin-bottom:6px; letter-spacing:-0.03em; }
.stat-label { font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-muted); }

/* TWO COL */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }

/* SERVICE ROWS */
.service-row { display:grid; grid-template-columns:1fr 2fr; gap:64px; padding:64px 0; border-bottom:1px solid var(--border); }
.service-row:first-child { padding-top:0; }
.service-row:last-child { border-bottom:none; padding-bottom:0; }
.service-row .section-title { font-size:clamp(22px,2.5vw,32px); }
.sdg { display:grid; grid-template-columns:1fr 1fr; gap:1px; margin-top:28px; }
.sdg-item { background:var(--off-white); padding:22px 20px; }
.sdg-item:nth-child(even) { background:var(--cream); }
.sdg-label { font-size:10px; letter-spacing:0.13em; text-transform:uppercase; color:var(--text-muted); font-weight:500; margin-bottom:7px; }
.sdg-text { font-size:13px; color:var(--text-body); line-height:1.7; }

/* FORM */
.form-outer { padding:96px 64px; background:var(--cream-light); }
.form-wrap { display:grid; grid-template-columns:1fr 1.6fr; gap:96px; max-width:1100px; margin:0 auto; }
.form-info { position:sticky; top:88px; }
.inquiry-form { display:flex; flex-direction:column; gap:16px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label { font-size:10px; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-muted); font-weight:500; }
.form-group input, .form-group select, .form-group textarea {
  background:var(--off-white); border:1px solid var(--border-dk);
  color:var(--text-dark); font-family:var(--font); font-size:14px; font-weight:400;
  padding:13px 16px; outline:none; transition:border-color 0.2s; width:100%;
  -webkit-appearance:none; appearance:none; border-radius:0;
}
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--text-light); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--text-body); }
.form-group select option { background:var(--off-white); }
.form-group textarea { resize:vertical; min-height:110px; }
.form-submit { background:var(--text-dark); color:var(--off-white); font-family:var(--font); font-size:12px; font-weight:500; letter-spacing:0.08em; text-transform:uppercase; border:none; padding:15px 30px; cursor:pointer; border-radius:100px; align-self:flex-start; margin-top:6px; transition:opacity 0.2s; }
.form-submit:hover { opacity:0.8; }
.form-note { font-size:12px; color:var(--text-light); line-height:1.65; margin-top:6px; }

/* INFO BADGES */
.info-row { display:flex; align-items:flex-start; gap:14px; padding:18px 0; border-bottom:1px solid var(--border); }
.info-row:first-child { border-top:1px solid var(--border); }
.info-icon { width:34px; height:34px; border:1px solid var(--border-dk); display:flex; align-items:center; justify-content:center; flex-shrink:0; border-radius:4px; margin-top:2px; }
.info-icon svg { width:14px; height:14px; }
.info-label { font-size:13px; font-weight:500; color:var(--text-dark); margin-bottom:3px; }
.info-desc { font-size:12px; color:var(--text-muted); line-height:1.6; }

/* FOOTER */
footer { background:var(--nav-bg); border-top:1px solid var(--border); padding:56px 64px; display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.footer-brand .wordmark { font-size:17px; display:block; margin-bottom:10px; }
.footer-tagline { font-size:12px; color:var(--text-muted); margin-bottom:18px; }
.footer-copy { font-size:11px; color:var(--text-light); }
.footer-col h4 { font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--text-muted); font-weight:500; margin-bottom:16px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a { font-size:13px; color:var(--text-body); text-decoration:none; transition:color 0.2s; }
.footer-col ul a:hover { color:var(--text-dark); }

/* RESPONSIVE */
@media (max-width:960px) {
  nav { padding:0 24px; }
  .nav-links { display:none; }
  .nav-toggle { display:flex; }
  .hero-split { grid-template-columns:1fr; }
  .hero-right { min-height:320px; }
  .hero-left { padding:56px 28px; }
  .section { padding:64px 28px; }
  .page-hero { padding:80px 28px 56px; }
  .callout { padding:56px 28px; }
  .form-outer { padding:64px 28px; }
  .form-wrap { grid-template-columns:1fr; gap:48px; }
  .form-info { position:static; }
  .form-row { grid-template-columns:1fr; }
  .trust-bar, .card-wrap-2, .card-wrap-3, .two-col, .stat-grid { grid-template-columns:1fr; }
  .trust-item { border-right:none; border-bottom:1px solid var(--border); }
  .trust-item:last-child { border-bottom:none; }
  .split-section { grid-template-columns:1fr; }
  .split-img { min-height:280px; }
  .split-text { padding:56px 28px; }
  .provider-strip { grid-template-columns:1fr; }
  .provider-half:first-child { border-right:none; border-bottom:1px solid var(--border); }
  .img-grid { grid-template-columns:1fr; }
  footer { grid-template-columns:1fr; padding:40px 28px; }
  .service-row { grid-template-columns:1fr; gap:32px; }
  .sdg { grid-template-columns:1fr; }
}
