/* Google Fonts: Cormorant Garamond variable style */
.cormorant-garamond-heading {
  font-family: "Cormorant Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}

.cormorant-garamond-light {
  font-family: "Cormorant Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

:root{
  /* Updated brand palette */
  --primary-text:#2F2923;
  --brown:#766659;
  --brown-deep:#4F4036;
  --text-soft:#4A4038;
  --brown-soft:#8B7A6E;
  --strong-text:#2F2923;

  --background:#E2DED3;
  --hero-bg:#E2DED3;
  --section-light:#F7F3EC;
  --section-soft:#EFE8DC;
  --card-bg:#FBF8F3;

  --accent:#D1B796;
  --accent-deep:#B89B73;
  --accent-hover:#E3C9A7;

  --border:rgba(47,41,35,.16);
  --border-light:rgba(118,102,89,.18);
  --shadow:0 18px 45px rgba(47,41,35,.11);
  --radius:24px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--primary-text);
  background:var(--background);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}
.container{width:min(1180px,92%);margin:auto}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(226,222,211,.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:24px}
.brand-link{display:flex;align-items:center;gap:12px;text-decoration:none;min-width:0}
.brand-logo{width:58px;height:58px;border-radius:50%;object-fit:cover;box-shadow:0 10px 24px rgba(0,0,0,.12)}
.brand-text{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:700;
  letter-spacing:.18em;
  font-size:1.15rem;
  text-transform:uppercase;
  line-height:1;
  color:var(--primary-text);
}
.brand-sub{
  display:block;
  font-family:Inter,sans-serif;
  letter-spacing:.24em;
  font-size:.66rem;
  color:var(--brown);
  opacity:1;
  margin-top:2px;
  text-transform:uppercase;
}
.nav{display:flex;align-items:center;gap:22px}
.nav a{text-decoration:none;font-weight:700;font-size:.95rem;color:var(--primary-text)}
.nav a:hover,.nav a.active{color:var(--brown)}

.btn,.nav .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  padding:13px 21px;
  text-decoration:none;
  font-weight:800;
  line-height:1;
  border:1px solid transparent;
  transition:.22s ease;
}
.btn-primary{
  background:var(--accent);
  color:var(--strong-text);
  box-shadow:0 12px 26px rgba(47,41,35,.17);
}
.btn-primary:hover{transform:translateY(-1px);background:var(--accent-hover)}
.btn-outline{
  border-color:rgba(47,41,35,.28);
  color:var(--primary-text);
  background:rgba(255,255,255,.44);
}
.btn-outline:hover{background:#fff}
.mobile-toggle{display:none;background:none;border:0;font-size:1.9rem;color:var(--primary-text);padding:0}

.hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 88% 10%,rgba(184,155,115,.16),transparent 30%),
    radial-gradient(circle at 8% 90%,rgba(255,255,255,.44),transparent 34%),
    linear-gradient(135deg,#E2DED3 0%,#EFE8DC 100%);
  border-bottom:1px solid var(--border);
  color:var(--primary-text);
}
.hero-grid{position:relative;display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center;padding:88px 0 82px}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.24em;
  color:var(--accent);
  font-weight:700;
  font-size:.76rem;
}
.hero h1,.page-hero h1,.section-header h2,.split h2,.cta h2,.card h2,.resource-card h2,.contact-panel h2,.faq h2,h1,h2,h3{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-optical-sizing:auto;
  font-weight:650;
  font-style:normal;
  line-height:1.05;
  letter-spacing:.01em;
}
.hero h1,.page-hero h1{
  font-size:clamp(3rem,5vw,5.2rem);
  margin:14px 0 20px;
  color:var(--primary-text);
}
.hero p{font-size:1.14rem;max-width:680px;color:#4A4038}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero-card{
  background:rgba(255,255,255,.45);
  border:1px solid rgba(47,41,35,.14);
  border-radius:32px;
  padding:18px;
  box-shadow:var(--shadow);
}
.hero-card img{border-radius:24px;width:100%;aspect-ratio:1/1;object-fit:cover}
.quick-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.trust-item{
  border-left:2px solid var(--accent-deep);
  padding-left:14px;
  color:var(--primary-text);
  font-weight:600;
  font-size:.96rem;
}

.section{
  padding:84px 0;
  background:var(--section-light);
  color:var(--brown);
}
.section-soft{
  background:var(--section-soft);
  color:var(--brown);
}
.section-dark{
  background:#E2DED3;
  color:var(--primary-text);
}
.section-header{display:flex;align-items:end;justify-content:space-between;gap:28px;margin-bottom:32px}
.section-header h2,.split h2,.cta h2,.card h2,.resource-card h2,.contact-panel h2,.faq h2{
  font-size:clamp(2.15rem,3.3vw,3.5rem);
  margin:0 0 14px;
  color:var(--brown-deep);
}
.section-header p{max-width:620px;color:var(--brown);margin:0}
.section-dark .section-header h2,.section-dark .cta h2,.section-dark h2{color:var(--primary-text)}
.section-dark .section-header p,.section-dark p{color:#4A4038}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card,.resource-card,.contact-panel{
  background:var(--card-bg);
  color:var(--brown);
  border-radius:var(--radius);
  padding:28px;
  border:1px solid var(--border-light);
  box-shadow:var(--shadow);
}
.card h3,.step h3{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:650;
  font-size:1.75rem;
  margin:12px 0 10px;
  color:var(--brown-deep);
}
.card p,.resource-card p,.muted{color:var(--brown)}
.icon{
  width:50px;
  height:50px;
  border-radius:16px;
  background:rgba(209,183,150,.28);
  display:grid;
  place-items:center;
  font-size:1.35rem;
}
.split{display:grid;grid-template-columns:.94fr 1.06fr;gap:52px;align-items:center}
.split img{border-radius:30px;box-shadow:var(--shadow)}
.check-list{list-style:none;padding:0;margin:22px 0}
.check-list li{margin:12px 0;padding-left:30px;position:relative}
.check-list li:before{content:"✦";position:absolute;left:0;color:var(--accent-deep);font-weight:900}

.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.step{
  background:var(--card-bg);
  color:var(--brown);
  border-radius:20px;
  padding:24px;
  border:1px solid var(--border-light);
  box-shadow:0 8px 22px rgba(47,41,35,.06);
}
.step p{color:var(--brown);margin:8px 0 0}
.step-num{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:700;
  color:var(--accent-deep);
  font-size:2rem;
  line-height:1;
}
.gallery-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:18px}
.gallery-grid img{height:100%;min-height:240px;object-fit:cover;border-radius:24px;box-shadow:var(--shadow)}
.gallery-grid .tall{grid-row:span 2}

.cta{
  background:var(--card-bg);
  color:var(--primary-text);
  border:1px solid var(--border-light);
  border-radius:34px;
  padding:48px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:28px;
  align-items:center;
  box-shadow:var(--shadow);
}
.cta h2{color:var(--primary-text)}
.cta p{color:#4A4038;margin:0}

.page-hero{
  padding:76px 0;
  background:linear-gradient(135deg,#E2DED3,#EFE8DC);
  color:var(--primary-text);
  border-bottom:1px solid var(--border);
}
.page-hero p{max-width:760px;color:#4A4038;font-size:1.12rem}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.service-list{display:grid;gap:20px}
.service-row{
  display:grid;
  grid-template-columns:180px 1fr;
  gap:0;
  background:var(--card-bg);
  color:var(--brown);
  border-radius:26px;
  overflow:hidden;
  border:1px solid var(--border-light);
  box-shadow:var(--shadow);
}
.service-row img{height:100%;width:100%;object-fit:cover;background:var(--section-soft)}
.service-row div{padding:28px}
.service-row h2{margin:0 0 10px;font-size:2rem;color:var(--brown-deep)}

.faq{border-top:1px solid var(--border-light)}
.faq details{border-bottom:1px solid var(--border-light);padding:18px 0}
.faq summary{font-weight:700;cursor:pointer;color:var(--brown-deep)}

.contact-panel a{color:var(--brown-deep);font-weight:800}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid label{display:grid;gap:6px;font-weight:700;color:var(--brown-deep)}
.form-grid input,.form-grid select,.form-grid textarea{
  width:100%;
  border:1px solid var(--border-light);
  border-radius:14px;
  padding:14px;
  font:inherit;
  background:#fff;
  color:var(--brown);
}
.form-grid textarea,.full{grid-column:1/-1}
.form-grid input[name="_gotcha"]{display:none!important;position:absolute;left:-9999px}

.resource-card{padding:28px}
.site-footer{
  background:#E2DED3;
  color:var(--primary-text);
  padding:46px 0 24px;
}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:28px}
.site-footer h3{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:2rem;
  margin:0 0 10px;
  color:var(--primary-text);
}
.site-footer a{color:var(--primary-text);text-decoration:none;font-weight:700}
.footer-bottom{margin-top:30px;padding-top:18px;border-top:1px solid var(--border);font-size:.92rem;color:var(--brown)}
.page-intro{max-width:760px;color:var(--brown)}

@media(max-width:980px){
  .mobile-toggle{display:block}
  .nav{
    display:none;
    position:absolute;
    left:0;
    right:0;
    top:91px;
    background:#E2DED3;
    padding:20px 4%;
    box-shadow:0 18px 40px rgba(0,0,0,.16);
    flex-direction:column;
    align-items:flex-start;
  }
  .nav.open{display:flex}
  .hero-grid,.split,.two-col,.cta,.service-row{grid-template-columns:1fr}
  .cards,.steps{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr}
  .footer-grid,.quick-trust,.form-grid{grid-template-columns:1fr}
  .section-header{display:block}
  .service-row img{height:240px}
  .hero-grid{padding:62px 0}
  .cta{padding:34px}
}
@media(max-width:620px){
  .cards,.steps{grid-template-columns:1fr}
  .brand-text{font-size:.95rem}
  .brand-logo{width:52px;height:52px}
  .hero-actions .btn{width:100%}
  .section{padding:60px 0}
  .hero h1,.page-hero h1{font-size:clamp(2.5rem,10vw,4.1rem)}
  .cta{padding:30px}
  .nav-wrap{padding:14px 0}
}
