:root{
  --green:#243b2f;
  --sage:#7f9274;
  --cream:#f7f3ea;
  --paper:#fffaf1;
  --gold:#b99156;
  --ink:#1e241f;
  --muted:#596057;
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:var(--cream);
  color:var(--ink);
}

a{
  text-decoration:none;
  color:inherit;
}

.site-header{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:22px 6%;
  background:rgba(255,250,241,.96);
  border-bottom:1px solid rgba(36,59,47,.12);
  backdrop-filter:blur(10px);
}

.brand{
  color:var(--green);
  line-height:1;
  white-space:nowrap;
}

.brand-name{
  display:block;
  font-size:23px;
  font-weight:500;
  letter-spacing:.01em;
}

nav{
  display:flex;
  gap:28px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:2px;
  font-weight:800;
  color:var(--green);
}

.phone{
  background:var(--green);
  color:white;
  padding:13px 22px;
  border-radius:999px;
  font-weight:800;
  white-space:nowrap;
}

.hero{
  min-height:760px;
  display:grid;
  grid-template-columns:1fr 1.05fr;
  overflow:hidden;
  background:var(--paper);
}

.hero-copy{
  padding:105px 7%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  z-index:2;
}

.kicker,
.section-label{
  color:var(--gold);
  letter-spacing:3px;
  text-transform:uppercase;
  font-weight:900;
  font-size:13px;
  margin:0 0 14px;
}

h1{
  font-size:68px;
  line-height:.98;
  margin:0 0 24px;
  color:var(--green);
  letter-spacing:-3px;
}

.hero-copy p{
  font-size:20px;
  line-height:1.65;
  max-width:640px;
  color:#4d544d;
}

.buttons{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  margin-top:24px;
}

.btn{
  display:inline-block;
  background:var(--green);
  color:white;
  padding:17px 28px;
  border-radius:999px;
  font-weight:900;
  border:0;
  font-size:16px;
  cursor:pointer;
}

.btn.secondary{
  background:white;
  color:var(--green);
  border:1px solid rgba(36,59,47,.25);
}

.hero-photo{
  position:relative;
  background:url('https://images.squarespace-cdn.com/content/v1/696fbf94301d7612ea63d030/082834de-d4f8-4331-afb6-cb9422a64ae3/6I9A9736.png') center/cover no-repeat;
}

.hero-photo:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,var(--paper) 0%,rgba(255,250,241,.65) 17%,rgba(255,250,241,.05) 50%);
}

section{
  padding:88px 7%;
}

.center{
  text-align:center;
  max-width:900px;
  margin:0 auto 45px;
}

h2{
  font-size:44px;
  line-height:1.08;
  color:var(--green);
  margin:0 0 16px;
  letter-spacing:-1px;
}

.lead{
  font-size:20px;
  line-height:1.6;
  color:var(--muted);
}

.grid{
  display:grid;
  gap:24px;
}

.guarantees{
  grid-template-columns:repeat(4,1fr);
}

.card{
  background:white;
  border:1px solid rgba(36,59,47,.1);
  border-radius:28px;
  padding:30px;
  box-shadow:0 16px 40px rgba(36,59,47,.06);
}

.icon{
  width:48px;
  height:48px;
  border-radius:16px;
  background:var(--cream);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  margin-bottom:18px;
  color:var(--green);
}

.card h3{
  font-size:23px;
  color:var(--green);
  margin:0 0 10px;
}

.card p{
  color:#5b625b;
  line-height:1.6;
  margin:0;
}

.split{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:55px;
  align-items:center;
}

.points{
  display:grid;
  gap:18px;
  margin-top:30px;
}

.point{
  display:flex;
  gap:18px;
  background:white;
  border-radius:22px;
  padding:22px;
  border:1px solid rgba(36,59,47,.08);
}

.point .icon{
  flex:0 0 48px;
  margin:0;
}

.point h3{
  margin:0 0 7px;
  color:var(--green);
}

.point p{
  margin:0;
  line-height:1.6;
  color:var(--muted);
}

.feature-panel{
  min-height:580px;
  border-radius:36px;
  padding:50px;
  background:
    linear-gradient(180deg,rgba(36,59,47,.05),rgba(36,59,47,.82)),
    url('https://images.unsplash.com/photo-1521791136064-7986c2920216?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
  color:white;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  box-shadow:0 18px 45px rgba(36,59,47,.16);
}

.feature-panel .quote-mark{
  font-size:80px;
  line-height:1;
  margin:0;
  color:rgba(255,255,255,.8);
}

.feature-panel h3{
  font-size:32px;
  line-height:1.18;
  margin:0 0 12px;
}

.feature-panel p{
  margin:0;
  color:#edf4ed;
}

.soft-band{
  background:var(--green);
  color:white;
  margin:0 7%;
  border-radius:42px;
}

.soft-band h2{
  color:white;
}

.soft-band .lead{
  color:#edf4ed;
}

.soft-band .btn{
  margin-top:10px;
  background:white;
  color:var(--green);
}

.testimonials{
  grid-template-columns:repeat(3,1fr);
}

.faq{
  max-width:1000px;
  margin:0 auto;
  display:grid;
  gap:15px;
}

details{
  background:white;
  border-radius:18px;
  padding:23px 26px;
  border:1px solid rgba(36,59,47,.1);
}

summary{
  font-weight:900;
  color:var(--green);
  font-size:18px;
  cursor:pointer;
}

details p{
  color:var(--muted);
  line-height:1.65;
}

.form-wrap{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:38px;
  align-items:start;
}

form{
  background:white;
  border-radius:30px;
  padding:34px;
  border:1px solid rgba(36,59,47,.1);
}

input,
textarea,
select{
  width:100%;
  padding:16px 14px;
  margin:8px 0 16px;
  border:1px solid #d8d8d0;
  border-radius:12px;
  font-size:16px;
  font-family:inherit;
}

textarea{
  min-height:120px;
}

.quote-photo{
  height:330px;
  border-radius:34px;
  background:url('https://images.squarespace-cdn.com/content/v1/696fbf94301d7612ea63d030/082834de-d4f8-4331-afb6-cb9422a64ae3/6I9A9736.png') center/cover no-repeat;
  margin-top:28px;
  box-shadow:0 18px 45px rgba(36,59,47,.12);
}

.form-note{
  font-size:13px;
  line-height:1.5;
  color:#687068;
  margin:4px 0 0;
}

.hp-field{
  display:none!important;
}

footer{
  background:#17261f;
  color:white;
  padding:55px 7%;
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:30px;
}

footer a{
  display:block;
  margin:9px 0;
  color:#e8efe8;
}

.footer-brand{
  color:white;
}

.copy{
  background:#101a15;
  color:#dfe8df;
  text-align:center;
  padding:18px;
}

@media(max-width:1100px){
  .guarantees{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:900px){
  .site-header{
    flex-wrap:wrap;
  }

  nav{
    display:none;
  }

  .hero,
  .split,
  .form-wrap,
  footer{
    grid-template-columns:1fr;
  }

  h1{
    font-size:48px;
  }

  h2{
    font-size:36px;
  }

  .hero-photo{
    min-height:520px;
  }

  .testimonials{
    grid-template-columns:1fr;
  }

  .soft-band{
    margin:0;
    border-radius:0;
  }
}

@media(max-width:640px){
  .guarantees{
    grid-template-columns:1fr;
  }

  .phone{
    width:100%;
    text-align:center;
  }

  .brand-name{
    font-size:21px;
  }
}


.faith-note{
  background:#fffaf1;
  border-top:1px solid rgba(36,59,47,.08);
  border-bottom:1px solid rgba(36,59,47,.08);
}