:root{
  --ink:#121212;
  --muted:#5d6168;
  --line: rgba(18,18,18,.10);
  --soft: rgba(18,18,18,.045);
  --white:#fff;

  /* brand accents pulled from logo vibe */
  --forest:#2f3f32;
  --teal:#2d5144;
  --rust:#8a3f2a;
  --amber:#a35a2e;

  --max: 1140px;
  --radius: 16px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color: var(--ink);
  background: #fff;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.container{
  width: min(100% - 40px, var(--max));
  margin: 0 auto;
}

/* Header */
.header{
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 240px;
}
.brand img{
  width: 46px;
  height: 46px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background:#fff;
}
.brand .title{line-height:1.05}
.brand .title strong{
  display:block;
  font-size: 14px;
  letter-spacing:.45px;
}
.brand .title span{
  display:block;
  font-size: 12px;
  color: var(--muted);
  font-weight: 650;
}

.navlinks{
  display:flex;
  align-items:center;
  gap: 10px;
}
.navlinks a{
  font-weight:800;
  font-size: 13px;
  color: rgba(18,18,18,.78);
  padding: 10px 10px;
  border-radius: 12px;
}
.navlinks a:hover{background: var(--soft); color:#000}

.navcta{
  display:flex;
  align-items:center;
  gap: 10px;
}

.mobileToggle{
  display:none;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight:900;
}
.mobileMenu{
  display:none;
  padding: 10px 0 16px;
}
.mobileMenu a{
  display:block;
  padding: 12px 12px;
  border-radius: 12px;
  font-weight:900;
  border: 1px solid var(--line);
  background:#fff;
  margin: 8px 0;
}

/* Buttons */
.btn{
  display:inline-flex;
  gap:.55rem;
  align-items:center;
  justify-content:center;
  padding: 11px 16px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--white);
  font-weight: 900;
  cursor:pointer;
}
.btn.primary{
  background: linear-gradient(135deg, var(--forest), var(--teal));
  color: var(--white);
  border: 0;
}
.btn.rust{
  background: linear-gradient(135deg, var(--rust), var(--amber));
  color: var(--white);
  border: 0;
}
.btn.ghost{
  background: transparent;
}

/* Housecall Pro booking button */
.hcp-button{
  background: linear-gradient(135deg, var(--forest), var(--teal));
  color: #fff;
  border: 0;
  border-radius: 999px;
  padding: 11px 16px;
  font-weight: 900;
  cursor: pointer;
}

/* Sections */
.hero{
  padding: 58px 0 20px;
  border-bottom: 1px solid var(--line);
}
.heroGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 26px;
  align-items:start;
}
.heroTitle{
  font-size: clamp(30px, 4.2vw, 52px);
  line-height: 1.05;
  margin: 0 0 12px;
  letter-spacing: -0.02em;
}
.heroText{
  font-size: 16px;
  line-height: 1.7;
  color: rgba(18,18,18,.78);
  margin: 0 0 16px;
}
.heroActions{display:flex; gap:10px; flex-wrap:wrap}

.panel{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  background: #fff;
}
.panel h3{margin:0 0 6px; font-size: 15px}
.panel p{margin:0; color: rgba(18,18,18,.74); line-height:1.65; font-weight:650}
.panel ul{
  margin:10px 0 0;
  padding-left:18px;
  color: rgba(18,18,18,.74);
  line-height:1.7;
  font-weight:650;
}

.section{
  padding: 28px 0;
}
.section h2{
  font-size: 20px;
  margin: 0 0 10px;
}
.section p{
  margin: 0 0 14px;
  color: rgba(18,18,18,.76);
  line-height: 1.7;
}

.grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.card{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  background:#fff;
}
.card h3{margin:0 0 6px; font-size: 15px}
.card p{margin:0; color: rgba(18,18,18,.72); line-height:1.65; font-weight:650}

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items:start;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.82);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight:900;
  font-size: 12px;
}

.note{
  font-size: 12px;
  color: rgba(18,18,18,.60);
  line-height: 1.55;
}

/* Embeds */
.embedWrap{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  background:#fff;
}
.embedWrap iframe{
  width: 100%;
  border: 0;
}

/* Lead form sizing */
#hcp-lead-iframe{
  height: 980px;
}

/* Reviews sizing */
#hcp-reviews-iframe{
  height: 900px;
}

/* Footer */
.footer{
  margin-top: 22px;
  padding: 26px 0;
  background: #111;
  color: #fff;
}
.footerGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr .8fr;
  gap: 16px;
}
.footer a{color:#fff; opacity:.92}
.footer a:hover{opacity:1}
.footer small{opacity:.75}
.footer .mini{opacity:.85; line-height:1.6}

@media (max-width: 980px){
  .heroGrid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .footerGrid{grid-template-columns:1fr}
  .navlinks, .navcta{display:none}
  .mobileToggle{display:inline-flex}
  .mobileMenu{display:none}
  .mobileMenu.open{display:block}
}
