
:root{
  --black:#070707; --cream:#efe8dc; --paper:#f7f1e8; --line:#cfc3b2;
  --bronze:#b87a36; --olive:#454733; --text:#27231e; --muted:#6e655b;
}
*{box-sizing:border-box}
body{margin:0;background:var(--cream);color:var(--text);font-family:Inter,Arial,sans-serif}
h1,h2,h3,.brand-title{font-family:Georgia,'Times New Roman',serif;font-weight:400}
a{text-decoration:none;color:inherit}
.header{height:78px;background:var(--black);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 46px;position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:16px}
.logo{width:48px;height:48px;border:1px solid #efe8dc;border-radius:50%;display:grid;place-items:center;font-family:Georgia,serif;font-size:17px;background:#efe8dc;color:#111}
.brand-title{font-size:23px;letter-spacing:.05em}
.tag{font-size:10px;letter-spacing:.08em;color:#d7cbb9;margin-top:2px;text-transform:uppercase}
.nav{display:flex;gap:32px;align-items:center;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.nav a{opacity:.86}.nav a:hover{opacity:1;color:#d19a52}.nav .contact{border:1px solid var(--bronze);padding:12px 18px;color:#fff}
.hero{min-height:540px;background-size:cover;background-position:center;display:flex;align-items:center;position:relative;color:#fff}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.34),rgba(0,0,0,.08))}
.hero-inner{position:relative;max-width:1180px;margin:0 auto;width:100%;padding:70px}
.breadcrumb{font-size:13px;color:#ddd;margin-bottom:36px}
.hero h1{font-size:68px;line-height:.98;letter-spacing:.035em;margin:0 0 24px;max-width:820px;text-transform:uppercase}
.hero p{font-size:21px;line-height:1.45;margin:0 0 32px;max-width:680px}
.btn{display:inline-block;background:var(--bronze);color:#fff;padding:15px 22px;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.section{max-width:1180px;margin:0 auto;padding:58px 46px}
.section-title{display:flex;align-items:center;gap:22px;margin-bottom:34px}
.section-title:before,.section-title:after{content:"";height:1px;background:var(--line);flex:1}
.section-title h2{font-size:25px;letter-spacing:.06em;text-transform:uppercase;margin:0;text-align:center}
.service-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.service-card{background:var(--paper);border:1px solid var(--line);min-height:340px}
.service-card img,.idea img{width:100%;height:150px;object-fit:cover;display:block}
.service-card .body{padding:20px 16px 22px}.service-card h3{font-size:24px;line-height:1.02;margin:0 0 10px}.service-card p{font-size:13px;line-height:1.35;color:var(--muted);margin:0 0 25px}.service-card .link,.small-link{font-size:12px;color:var(--bronze)}
.band{background:var(--olive);color:#eee}.band .section{display:grid;grid-template-columns:repeat(4,1fr);gap:34px;padding-top:40px;padding-bottom:40px}.feature{display:flex;gap:18px}.circle{width:36px;height:36px;border:1px solid #c79552;border-radius:50%;flex:0 0 auto}.feature h3{font-size:18px;margin:0 0 5px}.feature p{font-size:12px;line-height:1.35;margin:0;color:#d8d2c4}
.page-grid{display:grid;grid-template-columns:1.05fr 1.05fr .8fr;border:1px solid var(--line);background:rgba(255,255,255,.25);margin-top:58px}
.panel{padding:34px 32px;min-height:430px;border-right:1px solid var(--line)}.panel:last-child{border-right:0}.panel h3{text-transform:uppercase;font-size:25px;line-height:1.03;margin:0 0 24px}.panel p{color:var(--muted);font-size:15px;line-height:1.45}.panel li{margin:16px 0;font-size:14px}.panel li::marker{color:var(--bronze)}
.ideas-row{display:grid;grid-template-columns:repeat(6,1fr);gap:22px}.idea{text-align:center}.idea img{height:96px;border:1px solid var(--line)}.idea h3{font-size:16px;line-height:1.05;margin:14px 0 0}
.story{display:grid;grid-template-columns:120px 1fr;gap:18px;margin-bottom:28px}.story img{width:120px;height:76px;object-fit:cover}.story h4{font-family:Georgia,serif;font-size:21px;margin:0 0 5px}.story p{font-size:13px;line-height:1.35;margin:0 0 6px}
.simple{max-width:1080px;margin:0 auto;padding:56px 46px;border-top:1px solid var(--line)}
.simple h2{font-size:28px;margin:0 0 12px;text-transform:uppercase}.simple p{color:var(--muted);max-width:660px}
.footer{background:var(--black);color:#fff;padding:34px 54px;display:flex;align-items:center;justify-content:space-between}.footer .brand-title{font-size:21px}.footer p{margin:4px 0;color:#d6cfc5;font-size:13px}
@media(max-width:900px){.header{height:auto;display:block;padding:18px 22px}.nav{flex-wrap:wrap;gap:16px;margin-top:14px}.hero{min-height:460px}.hero-inner{padding:44px 24px}.hero h1{font-size:42px}.service-grid,.ideas-row,.band .section{grid-template-columns:1fr 1fr}.page-grid{grid-template-columns:1fr}.panel{border-right:0;border-bottom:1px solid var(--line);min-height:auto}.footer{display:block}.section{padding:44px 24px}}

.logo-img{width:48px;height:48px;border-radius:50%;object-fit:cover;background:#efe8dc;display:block}
.contact-hero{min-height:760px;background-size:cover;background-position:center;position:relative;color:#fff;display:block}
.contact-hero:before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.68)}
.contact-form-wrap{position:relative;max-width:1120px;margin:0 auto;padding:70px 46px 82px}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:30px}
.contact-form input,.contact-form textarea{width:100%;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.35);color:#fff;padding:28px 30px;font-size:22px;font-family:Inter,Arial,sans-serif;outline:none}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#c9c9d1}
.contact-form textarea{grid-column:1/-1;min-height:190px;resize:vertical}
.upload-box{border:1px dashed rgba(255,255,255,.45);min-height:170px;padding:36px 40px;display:flex;flex-direction:column;justify-content:center;color:#d2d2da;font-size:21px;line-height:1.35}
.upload-box strong{color:#d8d8df;font-size:24px;margin-bottom:8px}
.submit-btn{border:0;background:#f4f4f4;color:#111;font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:18px;cursor:pointer}
.service-areas{position:relative;background:#080808;color:#9e9ca3;text-align:center;padding:34px 20px;letter-spacing:.28em;text-transform:uppercase;font-size:18px}
@media(max-width:900px){.contact-form{grid-template-columns:1fr}.contact-form-wrap{padding:48px 24px}.service-areas{font-size:13px;letter-spacing:.16em}}

.value-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.value-card{border:1px solid rgba(199,149,82,.35);padding:28px;border-radius:18px;background:rgba(255,255,255,.03);transition:.25s}
.value-card:hover{transform:translateY(-4px);border-color:#c79552}
.process-dark{background:#070707;color:#fff;padding:70px 0}
.process-dark .wrap{max-width:1180px;margin:auto;padding:0 46px}
.process-dark h2{font-size:64px;font-family:Inter,Arial,sans-serif;font-weight:300;margin:0 0 40px}
.process-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:22px}
.process-card{border:1px solid #2d2d2d;border-radius:24px;padding:28px;min-height:150px;transition:.25s}
.process-card:hover{border-color:#c79552;transform:translateY(-4px)}
.cta-center{text-align:center;padding:90px 20px}
.cta-center .btn{margin-top:20px}
@media(max-width:900px){.value-grid,.process-cards{grid-template-columns:1fr}}


/* Final polish */
.values-grid,.value-cards,.features-grid{
justify-content:center !important;
gap:32px !important;
}
.value-card,.feature-card{
min-width:260px !important;
max-width:300px !important;
min-height:240px !important;
}

.start-conversation h2,
.cta-section h2{
font-size:3.2rem !important;
}

.start-conversation p,
.cta-section p{
font-size:1.35rem !important;
max-width:900px !important;
margin-left:auto !important;
margin-right:auto !important;
}

.start-conversation,
.cta-section{
padding-top:120px !important;
padding-bottom:120px !important;
}


/* HTB final fixed update */
html{scroll-behavior:smooth;}
.anchor-offset{scroll-margin-top:118px;}

/* Values cards: narrower and centered */
.band .section{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  padding-top:70px !important;
  padding-bottom:70px !important;
}
.value-grid{
  display:grid !important;
  grid-template-columns:repeat(4, 230px) !important;
  justify-content:center !important;
  gap:38px !important;
  width:auto !important;
  max-width:1120px !important;
  margin:0 auto !important;
}
.value-card{
  width:230px !important;
  min-width:0 !important;
  max-width:230px !important;
  min-height:230px !important;
  padding:30px 28px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}
.value-card h3{font-size:24px !important;line-height:1.05 !important;margin:0 0 26px !important;}
.value-card p{font-size:18px !important;line-height:1.22 !important;margin:0 !important;}

/* Process: calmer and tighter */
.process-dark h2{
  font-size:54px !important;
  line-height:1.05 !important;
  max-width:980px !important;
}
.process-cards{
  gap:18px !important;
  max-width:1120px !important;
  margin:0 auto !important;
}
.process-card{
  min-height:150px !important;
  padding:26px !important;
}

/* CTA: larger copy, same button */
.cta-center h2{
  font-size:44px !important;
  line-height:1.1 !important;
  margin-bottom:28px !important;
}
.cta-center p{
  font-size:26px !important;
  line-height:1.45 !important;
  margin-bottom:36px !important;
}
.cta-center .btn{font-size:12px !important;}

/* Lightbox gallery */
.htb-lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.88);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding:48px;
}
.htb-lightbox.open{display:flex;}
.htb-lightbox img{
  max-width:88vw;
  max-height:82vh;
  object-fit:contain;
  box-shadow:0 20px 70px rgba(0,0,0,.5);
}
.htb-close,.htb-prev,.htb-next{
  position:absolute;
  background:transparent;
  border:0;
  color:white;
  cursor:pointer;
  font-family:Georgia,serif;
}
.htb-close{top:18px;right:30px;font-size:48px;}
.htb-prev,.htb-next{top:50%;transform:translateY(-50%);font-size:72px;padding:16px 22px;}
.htb-prev{left:24px;}
.htb-next{right:24px;}

@media(max-width:900px){
  .value-grid{grid-template-columns:1fr !important;width:100% !important;}
  .value-card{width:100% !important;max-width:100% !important;}
  .process-dark h2{font-size:38px !important;}
  .cta-center h2{font-size:34px !important;}
  .cta-center p{font-size:20px !important;}
}


/* HTB one-by-one approved adjustments */

/* 1. Olive values band: reduce section height about 30%, keep cards same */
.band .section{
  padding-top:45px !important;
  padding-bottom:45px !important;
}
.value-band,
.values-band{
  padding-top:45px !important;
  padding-bottom:45px !important;
}

/* 2. Black process section: reduce overall height about 25%, keep cards same */
.process-dark{
  padding-top:70px !important;
  padding-bottom:70px !important;
}
.process-dark .section,
#process.section,
section#process{
  padding-top:70px !important;
  padding-bottom:70px !important;
}

/* 3. Our Work: make project image/cards 15–20% bigger */
#work img,
.our-work img,
.work-card img,
.work-item img{
  width:120% !important;
  max-width:120% !important;
  height:auto !important;
}
#work .work-card,
.our-work .work-card,
#work .work-item,
.our-work .work-item{
  transform:scale(1.18);
  transform-origin:center top;
}
#work .work-grid,
.our-work-grid,
.work-grid{
  gap:52px !important;
  margin-top:42px !important;
}

/* 4. CTA cream section: reduce section height 25%, keep text size, make button 25% bigger */
.cta-center,
.cta-section,
.start-conversation{
  padding-top:70px !important;
  padding-bottom:70px !important;
}
.cta-center .btn,
.cta-section .btn,
.start-conversation .btn,
.cta-center button,
.cta-section button,
.start-conversation button{
  transform:scale(1.25);
  transform-origin:center center;
}

/* Lightbox */
.clickable-image{cursor:zoom-in !important;}
.htb-lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.9);
  z-index:999999;
  padding:48px;
}
.htb-lightbox.open{display:flex;}
.htb-lightbox img{
  max-width:88vw;
  max-height:82vh;
  object-fit:contain;
  box-shadow:0 22px 70px rgba(0,0,0,.55);
}
.htb-lightbox button{
  position:absolute;
  border:0;
  background:transparent;
  color:#fff;
  cursor:pointer;
  font-family:Georgia,serif;
}
.htb-close{top:20px;right:32px;font-size:52px;}
.htb-prev,.htb-next{top:50%;transform:translateY(-50%);font-size:76px;padding:20px;}
.htb-prev{left:26px;}
.htb-next{right:26px;}

@media(max-width:900px){
  #work img,.our-work img,.work-card img,.work-item img{
    width:100% !important;
    max-width:100% !important;
  }
  #work .work-card,.our-work .work-card,#work .work-item,.our-work .work-item{
    transform:none;
  }
}

/* Clickable process card details */
.process-card{
  cursor:pointer !important;
  position:relative;
}
.process-card .process-more{
  display:none;
  margin-top:18px;
  font-size:14px;
  line-height:1.35;
  color:rgba(255,255,255,.82);
}
.process-card.open .process-more{
  display:block;
}
.process-card.open{
  border-color:#b87a36 !important;
}

/* OUR WORK fixed layout + project story lightbox */
#work .work-grid,
.our-work-grid,
.work-grid{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:42px !important;
  max-width:1120px !important;
  margin:42px auto 0 !important;
  align-items:start !important;
}

#work .work-card,
.our-work .work-card,
#work .work-item,
.our-work .work-item{
  transform:none !important;
  width:100% !important;
  max-width:100% !important;
  text-align:center !important;
}

#work img,
.our-work img,
.work-card img,
.work-item img{
  width:100% !important;
  max-width:100% !important;
  height:250px !important;
  object-fit:cover !important;
  display:block !important;
  cursor:zoom-in !important;
}

#work h3,
.work-card h3,
.work-item h3{
  margin-top:22px !important;
  line-height:1.05 !important;
}

.project-link{
  display:inline-block;
  margin-top:14px;
  color:#b87a36;
  font-size:13px;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
}

.htb-project-lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.9);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:999999;
  padding:44px;
}

.htb-project-lightbox.open{display:flex;}

.htb-project-panel{
  background:#efe8dc;
  color:#27231e;
  max-width:980px;
  width:92vw;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  box-shadow:0 25px 80px rgba(0,0,0,.55);
}

.htb-project-panel img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
}

.htb-project-copy{
  padding:46px 42px;
}

.htb-project-copy h2{
  font-family:Georgia,'Times New Roman',serif;
  font-weight:400;
  font-size:36px;
  line-height:1.05;
  margin:0 0 24px;
}

.htb-project-copy p{
  font-size:17px;
  line-height:1.55;
  color:#5f574d;
}

.htb-project-close{
  position:absolute;
  top:22px;
  right:34px;
  background:transparent;
  border:0;
  color:white;
  font-size:52px;
  cursor:pointer;
  font-family:Georgia,serif;
}

@media(max-width:900px){
  #work .work-grid,.our-work-grid,.work-grid{
    grid-template-columns:1fr !important;
  }
  .htb-project-panel{
    grid-template-columns:1fr;
  }
  .htb-project-panel img{
    min-height:300px;
  }
}


/* HTB three approved updates: values strip, about hero, footer */
.values-strip{
  background:#454733;
  color:#efe8dc;
  padding:42px 46px;
}
.values-strip-inner{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  align-items:center;
}
.values-strip-item{
  padding:10px 34px;
  border-right:1px solid rgba(0,0,0,.55);
}
.values-strip-item:first-child{padding-left:0;}
.values-strip-item:last-child{
  border-right:0;
  padding-right:0;
}
.values-strip-item h3{
  font-family:Georgia,'Times New Roman',serif;
  font-size:19px;
  line-height:1.1;
  margin:0 0 14px;
  color:#f4eee3;
}
.values-strip-item p{
  margin:0;
  color:#ded7ca;
  font-size:14px;
  line-height:1.45;
}

.about-kicker{
  font-size:14px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#e8e1d7;
  margin-bottom:18px;
}
body .hero .about-kicker + h1{
  font-size:clamp(48px,7vw,86px) !important;
  line-height:1.02 !important;
  letter-spacing:.02em !important;
  text-transform:none !important;
  margin-bottom:22px !important;
}
body .hero .about-kicker + h1 + p{
  max-width:620px;
  font-size:20px;
  line-height:1.45;
  color:#eee8dd;
}

.htb-footer{
  background:#070707;
  color:#fff;
  display:grid !important;
  grid-template-columns:1.15fr 1fr .85fr;
  gap:0;
  align-items:center;
  padding:36px 54px !important;
}
.htb-footer .footer-col{
  min-height:96px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.htb-footer .footer-service-col{
  border-left:1px solid rgba(239,232,220,.28);
  border-right:1px solid rgba(239,232,220,.28);
  padding:0 44px;
}
.htb-footer .footer-contact-col{
  padding-left:44px;
  text-align:left;
}
.htb-footer h3{
  font-family:Inter,Arial,sans-serif;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin:0 0 12px;
  color:#efe8dc;
}
.htb-footer p{
  margin:4px 0;
  color:#d6cfc5;
  font-size:13px;
  line-height:1.45;
}
.htb-footer .brand{
  display:flex;
  align-items:center;
  gap:16px;
}
.htb-footer .brand-title{
  font-family:Georgia,'Times New Roman',serif;
  font-size:21px;
  letter-spacing:.05em;
  color:#fff;
}

@media(max-width:900px){
  .values-strip-inner{
    grid-template-columns:1fr;
  }
  .values-strip-item{
    border-right:0;
    border-bottom:1px solid rgba(0,0,0,.45);
    padding:22px 0;
  }
  .values-strip-item:last-child{border-bottom:0;}
  .htb-footer{
    grid-template-columns:1fr;
    gap:24px;
    padding:32px 26px !important;
  }
  .htb-footer .footer-service-col,
  .htb-footer .footer-contact-col{
    border-left:0;
    border-right:0;
    border-top:1px solid rgba(239,232,220,.25);
    padding:24px 0 0;
  }
}

/* HTB process timeline redesign */
.process-timeline-section{
  background:#050505;
  color:#fff;
  padding:76px 46px 86px !important;
}
.process-timeline-inner{
  max-width:1180px;
  margin:0 auto;
}
.process-label{
  font-size:15px;
  letter-spacing:.28em;
  color:#9f9f9f;
  margin-bottom:22px;
}
.process-timeline-section h2{
  font-family:Inter,Arial,sans-serif;
  font-weight:400;
  font-size:clamp(42px,5.2vw,78px);
  line-height:1.05;
  margin:0 0 54px;
}
.process-timeline{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:0;
  border-top:1px solid rgba(255,255,255,.22);
  border-bottom:1px solid rgba(255,255,255,.22);
}
.timeline-step{
  appearance:none;
  background:transparent;
  color:#f4f1ea;
  border:0;
  border-right:1px solid rgba(255,255,255,.22);
  padding:28px 28px;
  text-align:left;
  font-family:Inter,Arial,sans-serif;
  font-size:18px;
  font-weight:700;
  line-height:1.15;
  cursor:pointer;
  transition:.2s ease;
}
.timeline-step:last-child{border-right:0;}
.timeline-step span{
  display:block;
  font-size:13px;
  letter-spacing:.12em;
  color:#b87a36;
  margin-bottom:10px;
}
.timeline-step:hover,
.timeline-step.active{
  background:rgba(184,122,54,.12);
  color:#fff;
}
.timeline-detail{
  display:none;
  max-width:760px;
  margin-top:34px;
  padding-left:0;
}
.timeline-detail.active{display:block;}
.timeline-detail h3{
  font-family:Georgia,'Times New Roman',serif;
  font-size:28px;
  font-weight:400;
  margin:0 0 12px;
}
.timeline-detail p{
  color:#d9d4ca;
  font-size:18px;
  line-height:1.55;
  margin:0;
}
@media(max-width:900px){
  .process-timeline-section{padding:56px 24px 64px !important;}
  .process-timeline{grid-template-columns:1fr;}
  .timeline-step{border-right:0;border-bottom:1px solid rgba(255,255,255,.22);}
  .timeline-step:last-child{border-bottom:0;}
}

/* Clean About page + footer: HANDS THAT BUILD | SERVING PENINSULA HOMES | CONTACT */
.about-page-hero{
  min-height:calc(100vh - 78px);
  background-image:linear-gradient(90deg,rgba(0,0,0,.62),rgba(0,0,0,.28)), url('assets/residential_2-screenshot-2026-06-19-at-5-23-07-am.jpeg');
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
  padding:90px 70px;
  color:#fff;
}
.about-page-copy{max-width:900px;}
.about-kicker{
  font-size:15px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#e8e1d7;
  margin-bottom:20px;
}
.about-page-copy h1{
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(58px,8vw,118px);
  line-height:.98;
  font-weight:400;
  margin:0 0 28px;
}
.about-intro{
  max-width:720px;
  font-size:22px;
  line-height:1.45;
  color:#f1ebe2;
  margin:0 0 44px;
}
.about-divider{
  width:100%;
  max-width:820px;
  height:1px;
  background:rgba(239,232,220,.55);
  margin:0 0 42px;
}
.about-page-copy h2{
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(28px,3.1vw,48px);
  line-height:1.08;
  letter-spacing:.06em;
  font-weight:400;
  margin:0 0 22px;
}
.about-page-copy h2 + p{
  max-width:720px;
  font-size:20px;
  line-height:1.55;
  color:#f1ebe2;
  margin:0;
}
.htb-footer{
  background:#070707;
  color:#fff;
  display:grid !important;
  grid-template-columns:1fr 1fr 1fr;
  align-items:center;
  padding:46px 70px !important;
  gap:0;
  width:100%;
}
.htb-footer .footer-col{
  min-height:92px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.htb-footer h3{
  font-family:Inter,Arial,sans-serif;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 16px;
  color:#efe8dc;
}
.htb-footer p{
  color:#d6cfc5;
  font-size:14px;
  line-height:1.45;
  margin:3px 0;
}
.htb-footer .footer-left{
  text-align:left;
  padding-right:55px;
}
.htb-footer .footer-middle{
  text-align:center;
  padding:0 54px;
  border-left:1px solid rgba(239,232,220,.28);
  border-right:1px solid rgba(239,232,220,.28);
}
.htb-footer .footer-right{
  padding-left:88px;
  text-align:left;
}
@media(max-width:900px){
  .about-page-hero{padding:60px 26px;min-height:auto;}
  .htb-footer{
    grid-template-columns:1fr;
    padding:36px 26px !important;
  }
  .htb-footer .footer-left,
  .htb-footer .footer-middle,
  .htb-footer .footer-right{
    padding:22px 0;
    border-left:0;
    border-right:0;
    border-top:1px solid rgba(239,232,220,.24);
    text-align:left;
  }
  .htb-footer .footer-left{border-top:0;}
}

/* Footer final alignment fix */
.htb-footer{
  display:grid !important;
  grid-template-columns:1fr 1fr 1fr !important;
  align-items:start !important;
  padding:54px 72px !important;
  background:#070707 !important;
  color:#fff !important;
  width:100% !important;
}

.htb-footer .footer-col{
  min-height:auto !important;
  display:block !important;
}

.htb-footer .footer-left{
  text-align:left !important;
  justify-self:start !important;
  align-self:start !important;
  padding:0 56px 0 0 !important;
}

.htb-footer .footer-middle{
  text-align:center !important;
  justify-self:center !important;
  align-self:start !important;
  padding:0 56px !important;
  border-left:1px solid rgba(239,232,220,.28) !important;
  border-right:1px solid rgba(239,232,220,.28) !important;
  width:100% !important;
}

.htb-footer .footer-right{
  text-align:left !important;
  justify-self:end !important;
  align-self:start !important;
  padding:0 0 0 56px !important;
  min-width:260px !important;
}

.htb-footer h3{
  margin:0 0 18px !important;
  line-height:1 !important;
}

.htb-footer p{
  margin:0 0 9px !important;
  line-height:1.45 !important;
}

@media(max-width:900px){
  .htb-footer{
    grid-template-columns:1fr !important;
    padding:36px 26px !important;
  }
  .htb-footer .footer-left,
  .htb-footer .footer-middle,
  .htb-footer .footer-right{
    justify-self:stretch !important;
    text-align:left !important;
    padding:22px 0 !important;
    border-left:0 !important;
    border-right:0 !important;
    border-top:1px solid rgba(239,232,220,.24) !important;
    min-width:0 !important;
  }
  .htb-footer .footer-left{border-top:0 !important;}
}

/* Footer center column widened so city list stays on one line */
.htb-footer{
  grid-template-columns:22% 56% 22% !important;
}

.htb-footer .footer-middle{
  padding-left:36px !important;
  padding-right:36px !important;
  white-space:nowrap !important;
}

.htb-footer .footer-middle p{
  white-space:nowrap !important;
  font-size:14px !important;
  letter-spacing:.01em !important;
}

.htb-footer .footer-right{
  justify-self:end !important;
  padding-left:40px !important;
}

.htb-footer .footer-left{
  justify-self:start !important;
  padding-right:40px !important;
}

@media(max-width:900px){
  .htb-footer{
    grid-template-columns:1fr !important;
  }
  .htb-footer .footer-middle,
  .htb-footer .footer-middle p{
    white-space:normal !important;
  }
}

/* Footer equal left/right edge alignment */
.htb-footer{
  grid-template-columns:24% 52% 24% !important;
  padding-left:72px !important;
  padding-right:72px !important;
}

.htb-footer .footer-left{
  justify-self:start !important;
  padding-left:0 !important;
  padding-right:36px !important;
}

.htb-footer .footer-middle{
  justify-self:center !important;
  padding-left:34px !important;
  padding-right:34px !important;
}

.htb-footer .footer-right{
  justify-self:end !important;
  padding-left:36px !important;
  padding-right:0 !important;
  text-align:left !important;
  min-width:260px !important;
}

@media(max-width:900px){
  .htb-footer{
    grid-template-columns:1fr !important;
    padding-left:26px !important;
    padding-right:26px !important;
  }
}

/* Footer contact moved farther right */
.htb-footer{
  padding-left:72px !important;
  padding-right:40px !important;
  grid-template-columns:24% 50% 26% !important;
}

.htb-footer .footer-right{
  justify-self:end !important;
  padding-right:0 !important;
  padding-left:70px !important;
  min-width:280px !important;
}

.htb-footer .footer-middle{
  padding-left:34px !important;
  padding-right:34px !important;
}

@media(max-width:900px){
  .htb-footer{
    grid-template-columns:1fr !important;
    padding-left:26px !important;
    padding-right:26px !important;
  }
  .htb-footer .footer-right{
    padding-left:0 !important;
    min-width:0 !important;
  }
}

/* Contact section vertically centered */
.contact-cta,
.cta-section,
.start-conversation{
    padding-top: 90px !important;
    padding-bottom: 90px !important;
}

/* Final fix: reduce top white space above Start a Conversation */
.cta-center,
.cta-section,
.start-conversation,
.contact-cta {
  padding-top: 45px !important;
  padding-bottom: 90px !important;
}
