:root{
  --ink:#16202b;
  --ink-soft:#3c4a59;
  --muted:#6c7a89;
  --line:#e4e1d9;
  --paper:#fbfaf7;
  --paper-2:#f4f1ea;
  --navy:#1b2a3a;
  --accent:#9a7b4f;
  --accent-deep:#7d6238;
  --white:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.15;letter-spacing:-.01em;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1140px;margin:0 auto;padding:0 32px}
.eyebrow{
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent-deep);
}

/* Header */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,250,247,.88);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.brand-logo{
  width:46px;height:46px;border-radius:50%;object-fit:cover;flex:0 0 auto;
  box-shadow:0 0 0 1px rgba(154,123,79,.24),0 10px 24px rgba(22,32,43,.14);
}
.brand-text{display:flex;align-items:baseline;gap:10px;min-width:0}
.brand .mark{font-family:'Fraunces',serif;font-size:23px;font-weight:600;letter-spacing:.01em;color:var(--ink)}
.brand .llc{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
nav.links{display:flex;gap:38px;align-items:center}
nav.links a{font-size:14.5px;color:var(--ink-soft);font-weight:500;transition:color .2s;position:relative}
nav.links a:hover{color:var(--accent-deep)}
nav.links a.active{color:var(--ink)}
nav.links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--accent)}
.btn{
  display:inline-block;background:var(--navy);color:var(--white);
  padding:13px 26px;border-radius:2px;font-size:14.5px;font-weight:500;
  letter-spacing:.02em;transition:background .25s;
  border:1px solid var(--navy);cursor:pointer;
}
.btn:hover{background:#0f1c29}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--white)}
.menu-toggle{display:none;background:none;border:0;font-size:26px;color:var(--ink);cursor:pointer}

/* Page banner (inner pages) */
.banner{background:var(--white);border-bottom:1px solid var(--line);padding:78px 0 70px}
.banner .eyebrow{margin-bottom:18px;display:block}
.banner h1{font-size:52px;margin-bottom:20px}
.banner p{font-size:19px;color:var(--ink-soft);max-width:640px}
.crumb{font-size:13px;color:var(--muted);margin-bottom:24px;letter-spacing:.02em}
.crumb a:hover{color:var(--accent-deep)}

/* Hero (home) */
.hero{
  position:relative;overflow:hidden;min-height:500px;padding:58px 0 42px;
  background:
    linear-gradient(90deg,rgba(8,12,17,.94) 0%,rgba(8,12,17,.78) 42%,rgba(8,12,17,.18) 74%),
    url("logo-full.jpg") center right / cover no-repeat;
  border-bottom:1px solid #211c15;
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(219,178,83,.7),transparent);
}
.hero-content{position:relative;z-index:1;max-width:1140px}
.hero .eyebrow{color:#d8b866}
.hero h1{font-size:58px;margin:20px 0 20px;color:#fff;max-width:640px;text-shadow:0 14px 34px rgba(0,0,0,.4)}
.hero p.lead{font-size:20px;color:#e4e0d7;max-width:560px;margin-bottom:36px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero .btn{background:#d8b866;color:#111820;border-color:#d8b866}
.hero .btn:hover{background:#efcf78;border-color:#efcf78}
.hero .btn.ghost{background:rgba(255,255,255,.03);color:#fff;border-color:rgba(255,255,255,.72)}
.hero .btn.ghost:hover{background:#fff;color:#111820}
.hero-proof{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;
  max-width:680px;margin-top:28px;padding-top:16px;border-top:1px solid rgba(216,184,102,.45);
}
.hero-proof div{min-width:0}
.hero-proof span{
  display:block;font-size:12px;letter-spacing:.16em;color:#d8b866;font-weight:600;margin-bottom:7px;
}
.hero-proof strong{display:block;color:#fff;font-size:15px;font-weight:600;letter-spacing:.02em}
.rule{width:64px;height:2px;background:var(--accent);margin:0 0 4px}

/* Image bands */
.imgband{position:relative;width:100%;height:clamp(300px,44vw,560px);overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.imgband img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.imgband.tint::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(22,32,43,.55),rgba(22,32,43,.05) 55%)}
.imgband .caption{position:absolute;left:0;right:0;bottom:0;z-index:2}
.imgband .caption .wrap{padding-bottom:38px}
.imgband .caption .eyebrow{color:#e7d9c4;display:block;margin-bottom:10px}
.imgband .caption h3{color:#fff;font-size:30px;max-width:600px}
.figure{border:1px solid var(--line);overflow:hidden;background:var(--paper-2)}
.figure img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}

/* Sections */
section{padding:96px 0}
.home-services{padding-top:58px}
.section-head{max-width:680px;margin-bottom:62px}
.section-head h2{font-size:42px;margin:18px 0 18px}
.section-head p{font-size:18px;color:var(--ink-soft)}
.center{margin-left:auto;margin-right:auto;text-align:center}

/* Services */
.bg-white{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.svc{padding:44px 38px 48px;border-right:1px solid var(--line);transition:background .3s}
.svc:last-child{border-right:0}
.svc:hover{background:var(--paper)}
.svc .ix{font-family:'Fraunces',serif;font-size:15px;color:var(--accent);margin-bottom:26px}
.svc h3{font-size:24px;margin-bottom:14px}
.svc p{font-size:16px;color:var(--ink-soft)}
.svc ul{list-style:none;margin-top:20px}
.svc li{font-size:14.5px;color:var(--muted);padding:7px 0;border-top:1px solid var(--line)}

/* Detailed service blocks */
.svc-row{display:grid;grid-template-columns:.8fr 1.2fr;gap:64px;align-items:start;padding:64px 0;border-top:1px solid var(--line)}
.svc-row:first-of-type{border-top:0}
.svc-row .ix{font-family:'Fraunces',serif;font-size:54px;color:var(--accent);line-height:1}
.svc-row h3{font-size:30px;margin:14px 0 0}
.svc-row .body p{font-size:17px;color:var(--ink-soft);margin-bottom:22px;max-width:640px}
.svc-row .deliverables{display:grid;grid-template-columns:1fr 1fr;gap:0 40px}
.svc-row .deliverables div{font-size:15.5px;color:var(--ink-soft);padding:12px 0;border-top:1px solid var(--line);display:flex;gap:12px}
.svc-row .deliverables div::before{content:"—";color:var(--accent)}

/* Approach / values */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;align-items:start}
.values{display:grid;gap:2px}
.value{padding:30px 0;border-top:1px solid var(--line)}
.value:last-child{border-bottom:1px solid var(--line)}
.value h4{font-size:20px;margin-bottom:8px;display:flex;align-items:baseline;gap:14px}
.value h4 .vix{font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--accent-deep);letter-spacing:.1em}
.value p{font-size:16px;color:var(--ink-soft);padding-left:34px}

/* Strip */
.strip{background:var(--navy);color:#eef1f4}
.strip .wrap{padding:84px 32px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.strip h2{color:#fff;font-size:38px}
.strip p{color:#b9c4d0;font-size:18px;margin-top:18px}
.strip .rule{background:var(--accent)}
.strip blockquote{
  font-family:'Fraunces',serif;font-size:25px;line-height:1.45;color:#fff;font-style:italic;
  border-left:2px solid var(--accent);padding-left:30px;
}
.strip cite{display:block;font-family:'Inter',sans-serif;font-style:normal;font-size:14px;color:#9fb0bf;margin-top:20px;letter-spacing:.04em}

/* Process */
.bg-2{background:var(--paper-2)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:34px;margin-top:14px}
.step .n{font-family:'Fraunces',serif;font-size:17px;color:var(--accent);border-top:2px solid var(--accent);padding-top:18px;display:inline-block;width:100%}
.step h4{font-size:19px;margin:14px 0 10px}
.step p{font-size:15px;color:var(--ink-soft)}
.steps.vert{grid-template-columns:1fr;gap:0}
.steps.vert .step{display:grid;grid-template-columns:140px 1fr;gap:40px;padding:38px 0;border-top:1px solid var(--line);margin:0}
.steps.vert .step:last-child{border-bottom:1px solid var(--line)}
.steps.vert .step .n{border-top:0;padding-top:0;font-size:40px}
.steps.vert .step h4{margin-top:0;font-size:23px}
.steps.vert .step p{font-size:16.5px;max-width:680px}

/* CTA band */
.cta-band{background:var(--white);border-top:1px solid var(--line)}
.cta-band .wrap{padding:78px 32px;text-align:center}
.cta-band h2{font-size:38px;margin-bottom:18px}
.cta-band p{font-size:18px;color:var(--ink-soft);max-width:560px;margin:0 auto 32px}

/* Contact */
.contact-card{background:var(--white);border:1px solid var(--line);padding:46px 44px}
.contact-card h3{font-size:26px;margin-bottom:22px}
.field{display:block;margin-bottom:20px}
.field label,.field>span{display:block;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line);background:var(--paper);
  font-family:inherit;font-size:15.5px;color:var(--ink);border-radius:2px;transition:border-color .2s;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:120px}
.form-status{font-size:14.5px;margin-top:16px;padding:0}
.form-status.ok{color:#2f5d3a;background:#eef5ef;border:1px solid #cfe2d4;padding:12px 14px;border-radius:2px}
.form-status.err{color:#8a2b2b;background:#f7eeee;border:1px solid #e6cccc;padding:12px 14px;border-radius:2px}
#submitBtn:disabled{opacity:.6;cursor:default}
.detail{padding:18px 0;border-top:1px solid var(--line)}
.detail:first-of-type{border-top:0}
.detail .k{font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-deep);font-weight:600;margin-bottom:6px}
.detail .v{font-size:17px;color:var(--ink-soft)}
.detail .v a:hover{color:var(--accent-deep)}

/* Footer */
footer{background:var(--ink);color:#aeb8c2;padding:56px 0 40px}
footer .wrap{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:30px}
footer .mark{font-family:'Fraunces',serif;font-size:21px;color:#fff;margin-bottom:8px}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.footer-logo{width:46px;height:46px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 1px rgba(255,255,255,.12)}
footer .fnote{font-size:13.5px;max-width:340px;line-height:1.7}
footer .fcol h5{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#7f8b97;margin-bottom:14px;font-weight:600}
footer .fcol a,footer .fcol p{display:block;font-size:14.5px;color:#aeb8c2;margin-bottom:8px;transition:color .2s}
footer .fcol a:hover{color:#fff}
.legal{border-top:1px solid #2a3744;margin-top:46px;padding-top:24px;font-size:13px;color:#7f8b97}

@media(max-width:920px){
  .hero{
    min-height:500px;
    background:
      linear-gradient(90deg,rgba(8,12,17,.94),rgba(8,12,17,.72)),
      url("logo-full.jpg") center / cover no-repeat;
  }
  .grid3{grid-template-columns:1fr}
  .svc{border-right:0;border-bottom:1px solid var(--line)}
  .split,.strip .wrap{grid-template-columns:1fr;gap:46px}
  .steps{grid-template-columns:1fr 1fr}
  .svc-row{grid-template-columns:1fr;gap:20px;padding:48px 0}
  .svc-row .ix{font-size:42px}
}
@media(max-width:640px){
  body{font-size:16px}
  .wrap{padding:0 22px}
  .nav{height:66px}
  nav.links{display:none}
  .menu-toggle{display:block}
  header .btn{display:none}
  .brand{gap:10px}
  .brand-logo{width:38px;height:38px}
  .brand-text{display:block;line-height:1.05}
  .brand .mark{font-size:20px}
  .brand .llc{display:block;font-size:10px;margin-top:3px}
  .hero{min-height:auto;padding:54px 0 42px;background-position:center}
  .hero h1{font-size:42px}
  .hero p.lead{font-size:17.5px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{text-align:center}
  .hero-proof{grid-template-columns:1fr;gap:15px;margin-top:36px;padding-top:20px}
  .banner{padding:52px 0 48px}
  .banner h1{font-size:36px}
  .banner p{font-size:17px}
  section{padding:64px 0}
  .section-head{margin-bottom:42px}
  .section-head h2,.strip h2,.cta-band h2{font-size:30px}
  .steps{grid-template-columns:1fr}
  .steps.vert .step{grid-template-columns:1fr;gap:8px}
  .svc{padding:34px 26px 38px}
  .svc-row .deliverables{grid-template-columns:1fr}
  .contact-card{padding:34px 26px}
  .hero-aside{flex-direction:column;gap:30px}
  .strip .wrap{padding:60px 22px}
  .strip blockquote{font-size:21px}
  footer .wrap{flex-direction:column;gap:26px}
}
