﻿
:root{
  --page-bg:#ffffff;
  --panel:#f6f4ef;
  --text:#65543c;
  --muted:#847451;
  --gold:#d8b86c;
  --gold-2:#bc943c;
  --ink:#65543c;
  --divider:#eae4d6;
  --max:1140px;
  --radius:20px;
  --shadow:0 12px 30px rgba(0,0,0,.12);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--page-bg);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold-2);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--divider)}
.nav{display:flex;align-items:center;gap:16px;padding:14px 0;justify-content:space-between}
.brand img{height:84px;width:auto;display:block}
.menu ul{display:flex;gap:18px;list-style:none;margin:0;padding:0}
.menu a{color:var(--ink);opacity:1;font-weight:600}
.header-cta{margin-left:auto;display:flex;align-items:center;gap:12px}
.phone{color:var(--ink)}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;font-weight:700;border:2px solid transparent;box-shadow:var(--shadow)}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#111}
.btn-outline{background:transparent;border-color:var(--gold-2);color:var(--gold-2)}
.nav-toggle{display:none;background:transparent;border:0;color:var(--ink);font-size:22px}
@media (max-width:860px){
  .menu{display:none;position:absolute;top:60px;left:0;right:0;background:#fff;border-bottom:1px solid var(--divider)}
  .menu.open{display:block}
  .menu ul{flex-direction:column;padding:10px 16px}
  .header-cta{display:none}
  .nav-toggle{display:block;margin-left:auto}
}
.hero{min-height:72vh;display:grid;place-items:center;background:var(--panel);background-image:var(--bg);background-size:cover;background-position:center;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.25))}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(.85);pointer-events:none;}
.hero-inner{position:relative;text-align:center;z-index:2;max-width:880px;padding:64px 0}
.hero h1{font-size:clamp(28px,5vw,48px);line-height:1.1;margin:10px 0 12px;color:#1c1a16}
.hero .sub{color:var(--muted);margin-bottom:20px}
.rating{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.8);padding:8px 12px;border:1px solid var(--divider);border-radius:999px;color:#1c1a16}
.stars{letter-spacing:2px;color:#f0c24f}
.cta-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:10px}
.section-head{margin:40px 0 18px}
.section-head h2{margin:0 0 8px;font-size:clamp(22px,3.5vw,34px);color:#1c1a16}
.section-head p{color:var(--muted)}
.trust-badges ul{display:flex;gap:10px;flex-wrap:wrap;list-style:none;padding:0;margin:18px 0 0}
.trust-badges li{background:var(--panel);border:1px solid var(--divider);padding:10px 12px;border-radius:999px}

.services .service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:900px){.services .service-grid{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--divider);border-radius:var(--radius);overflow:hidden}
.card-body{padding:14px 14px 18px}
.card h3{margin:8px 0 6px;color:#1c1a16}
.link{font-weight:700;color:var(--gold-2)}
.center{text-align:center;margin-top:16px}

.split{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;margin:28px 0}
.split.about-highlight{
  display:flex;
  justify-content:center;
  margin:28px 0;
}
.split.about-highlight.reverse{
  display:flex;
}
.split.about-highlight > *{
  max-width:720px;
  width:100%;
}
@media (max-width:900px){
  .split.about-highlight{
    flex-direction:column;
    align-items:flex-start;
  }
  .split.about-highlight > *{
    max-width:100%;
  }
}
.split.reverse{grid-template-columns:.9fr 1.1fr}
.split img{border-radius:var(--radius);border:1px solid var(--divider)}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid var(--divider);background:var(--panel);font-weight:700}

.kpi-section{margin-top:8px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;text-align:center;margin-top:8px}
.kpis .card{padding:14px}
.kpis .num{font-size:1.6rem;font-weight:800;color:#1c1a16}
@media (max-width:980px){.split{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,1fr)}}

.service-areas .areas-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start}
/* Map embed styling */
.map-wrap{width:100%}
.map-embed{width:100%;height:420px;border:0;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--divider)}
.areas-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;list-style:none;margin:0;padding-left:0}
@media (max-width:900px){.service-areas .areas-grid{grid-template-columns:1fr}.areas-list{grid-template-columns:1fr}}

.page-hero{background:var(--panel);border-bottom:1px solid var(--divider)}
.page-hero.slim{padding:40px 0}
.content{padding:24px 0}
.bullets{padding:24px 0}
.checklist{display:grid;gap:10px;list-style:none;padding:0}

.grid-contact{display:grid;grid-template-columns:.8fr 1.2fr;gap:24px;align-items:start;padding:24px 0}
@media (max-width:900px){.grid-contact{grid-template-columns:1fr}}
.form{background:#fff;border:1px solid var(--divider);border-radius:var(--radius);padding:16px}
.form label{display:grid;gap:6px;margin-bottom:10px;font-weight:600}
.form input,.form select,.form textarea{background:#fff;color:#1c1a16;border:1px solid var(--divider);border-radius:12px;padding:10px 12px}
.form-estimate .form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (max-width:780px){.form-estimate .form-grid{grid-template-columns:1fr}}

.site-footer{margin-top:40px;border-top:1px solid var(--divider);background:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1.4fr 1fr;gap:18px;padding:24px 0}
.footer-grid img{border-radius:12px;border:1px solid var(--divider);background:#fff}
.list-plain{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.two-col{grid-template-columns:repeat(2,1fr)}
.footer-bottom{padding:10px 0;border-top:1px solid var(--divider);text-align:center;opacity:.8}

/* Placeholder block for About section */
.ph{
  min-height:280px;
  border-radius:var(--radius);
  border:1px solid var(--divider);
  background: linear-gradient(135deg, #f5ecd6, #fff) padding-box,
              repeating-linear-gradient(45deg, rgba(0,0,0,.04) 0, rgba(0,0,0,.04) 6px, transparent 6px, transparent 12px) border-box;
}

/* About page enhancements */
.checklist{list-style:none;margin:14px 0;padding:0;display:grid;gap:10px}
.checklist.tight{gap:6px}
.checklist li{position:relative;padding-left:30px}
.checklist li::before{content:"\2713";position:absolute;left:0;top:4px;color:var(--gold-2);font-weight:800;font-size:16px}
.checklist.fancy{gap:14px}
.checklist.fancy li{padding:14px 18px 14px 54px;border-radius:18px;border:1px solid var(--divider);background:linear-gradient(180deg,#ffffff,#f8f3e5);box-shadow:0 12px 26px rgba(0,0,0,.08)}
.checklist.fancy li::before{left:18px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;background:var(--gold-2);color:#111;display:grid;place-items:center;font-size:14px;box-shadow:inset 0 0 0 2px rgba(255,255,255,.5)}
.checklist.tight li{padding-left:26px;border:none;background:transparent;box-shadow:none}
.checklist.tight li::before{left:0;top:4px;transform:none;width:auto;height:auto;background:none;color:var(--gold-2);box-shadow:none;font-size:14px}

.about-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:start;margin-top:18px}
.about-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.about-gallery figure{margin:0}
.about-gallery figure:first-child{grid-column:1 / -1}
.about-gallery img{border-radius:var(--radius);border:1px solid var(--divider);box-shadow:var(--shadow)}
.about-gallery figcaption{margin-top:6px;font-size:.92rem;color:var(--muted)}
@media (max-width:900px){
  .about-layout{grid-template-columns:1fr;gap:20px}
  .about-gallery{order:-1;grid-template-columns:1fr}
}

.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media (max-width:860px){.values-grid{grid-template-columns:1fr}}
.value{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;border:1px solid var(--divider);border-radius:16px;background:#fff;padding:12px}
.value-letter{width:46px;height:46px;display:grid;place-items:center;border-radius:12px;background:var(--panel);border:1px solid var(--divider);font-weight:900;font-size:1.2rem;color:#1c1a16}

/* Centered about text block */
.about-text .prose{
  max-width: 880px;
  margin: 0 auto;
}
.about-text .prose h2{ text-align:center; }

/* Why Hire Us benefits grid */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:900px){.benefits-grid{grid-template-columns:1fr}}
.benefits .card h3{margin:0 0 6px;color:#1c1a16}

/* Services page extras */
.services-extras ul{max-width:700px;margin:0 auto}
.steps{list-style:decimal;margin-left:1.4rem;display:grid;gap:8px;max-width:700px;margin:0 auto}
.faq details{margin-bottom:10px;padding:10px;border:1px solid var(--divider);border-radius:12px;background:#fff}
.faq summary{font-weight:600;cursor:pointer}

/* Services page enhancements */
.services-tiers .tiers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:980px){.services-tiers .tiers-grid{grid-template-columns:1fr}}
.tier img{height:200px;object-fit:cover;width:100%}
.tier .tier-title{margin:6px 0 4px;color:#1c1a16}

.addons .chips{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:0}
.addons .chips li{border:1px solid var(--divider);background:var(--panel);border-radius:999px;padding:8px 12px;font-weight:600}

.steps{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;list-style:none;padding:0;margin:0}
@media (max-width:900px){.steps{grid-template-columns:1fr}}
.steps li{background:#fff;border:1px solid var(--divider);border-radius:16px;padding:14px;box-shadow:var(--shadow)}
.steps li span{display:block;font-weight:800;color:#1c1a16;margin-bottom:6px}
.steps li::before{counter-increment:step;content:counter(step);display:inline-grid;place-items:center;width:34px;height:34px;border-radius:999px;background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#111;font-weight:800;margin-bottom:8px}

.faq .accordion{border:1px solid var(--divider);border-radius:12px;background:#fff;margin:8px 0}
.faq .accordion summary{cursor:pointer;padding:12px 14px;font-weight:700}
.faq .accordion[open] summary{border-bottom:1px solid var(--divider)}
.faq .accordion .a{padding:12px 14px}

/* Join our team button */
.btn-join{display:inline-block;padding:14px 28px;border-radius:30px;font-weight:700;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#111;box-shadow:var(--shadow);}
.btn-join:hover{opacity:0.9;text-decoration:none}

/* Nav layout adjustments */
.nav{justify-content:space-between}
.menu{margin-left:auto}
.header-cta{margin-left:12px}
/* Improved Apply button style */
.btn-apply{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;font-weight:800;
  border:0;background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#111;
  box-shadow:var(--shadow);text-decoration:none
}
.btn-apply .arrow{font-weight:900;transform:translateX(0);transition:transform .2s}
.btn-apply:hover .arrow{transform:translateX(4px)}

/* Why Hire Us: card-style checklist */
.why-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}
@media (max-width:900px){.why-cards{grid-template-columns:1fr}}
.why-card{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;background:#fff;border:1px solid var(--divider);border-radius:16px;padding:14px;box-shadow:var(--shadow)}
.why-card .mark{width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:var(--panel);border:1px solid var(--divider);font-weight:900}
.why-card h4{margin:0 0 6px;color:#1c1a16}
/* Flashy Join section */
.join-panel{background:linear-gradient(180deg,#fff8e1,#ffffff);border:1px solid var(--divider);border-radius:20px;padding:18px;box-shadow:var(--shadow)}
.join-panel .join-row{display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:center}
.join-panel .join-copy{display:flex;flex-direction:column;gap:12px}
.join-panel .join-photo{margin:0;display:flex;justify-content:center}
.join-panel .join-photo img{width:100%;max-width:360px;border-radius:var(--radius);border:1px solid var(--divider);box-shadow:var(--shadow)}
@media (max-width:900px){
  .join-panel .join-row{grid-template-columns:1fr}
  .join-panel .join-photo{order:-1}
  .join-panel .join-photo img{max-width:100%}
}

.lead-large{font-size:clamp(18px,2.4vw,22px);line-height:1.5;margin-bottom:12px}

/* Mobile spacing improvements */
@media (max-width: 600px){
  .container{padding:0 16px}
  .site-header .container{padding:0 16px}
  main > section{padding:16px 0}
  .hero-inner{padding:48px 0}
  .card-body{padding:12px}
  .form{padding:12px}
  .page-hero.slim{padding:28px 0}
}
/* Testimonials */
.section-head.center{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
  max-width:720px;
}
.testimonials{
  margin:48px 0;
}
.testimonial-carousel{
  position:relative;
  background:linear-gradient(180deg,#ffffff,#f8f3e5);
  border:1px solid var(--divider);
  border-radius:var(--radius);
  padding:36px 32px 80px;
  box-shadow:var(--shadow);
  width:100%;
  max-width:860px;
  margin:0 auto;
}
.testimonial-viewport{
  overflow:hidden;
  padding:0 18px;
}
.testimonial-track{
  display:flex;
  transition:transform .4s ease;
}

.testimonial-card{
  flex:0 0 100%;
  width:100%;
  padding:28px 36px;
  display:flex;
  flex-direction:column;
  gap:18px;
  background:rgba(255,255,255,.92);
  border-radius:18px;
  border:1px solid var(--divider);
  box-sizing:border-box;
}
.testimonial-card .quote{
  font-size:clamp(18px,2.4vw,22px);
  font-weight:600;
  color:#1c1a16;
}
.testimonial-card .name{
  font-weight:700;
  color:var(--muted);
}

.carousel-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid var(--divider);
  background:#fff;
  color:var(--gold-2);
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:var(--shadow);
}
.carousel-btn:hover,
.carousel-btn:focus-visible{
  background:var(--gold-2);
  color:#111;
  text-decoration:none;
  outline:none;
}
.carousel-btn.prev{
  left:16px;
}
.carousel-btn.next{
  right:16px;
}
.carousel-btn span{
  font-size:22px;
  line-height:1;
}
.carousel-dots{
  display:flex;
  justify-content:center;
  gap:10px;
  margin:24px 0 0;
}
.carousel-dots .dot{
  width:12px;
  height:12px;
  border-radius:50%;
  border:2px solid var(--gold-2);
  background:transparent;
  cursor:pointer;
  padding:0;
}
.carousel-dots .dot.is-active{
  background:var(--gold-2);
}
.carousel-dots .dot:focus-visible{
  outline:2px solid var(--gold-2);
  outline-offset:2px;
}
@media (max-width:700px){
  .testimonial-carousel{
    padding:28px 20px 72px;
  }
  .carousel-btn{
    width:38px;
    height:38px;
    top:auto;
    bottom:80px;
    transform:none;
  }
  .carousel-btn.prev{
    left:18px;
  }
  .carousel-btn.next{
    right:18px;
  }
  .testimonial-card{
    padding:22px 20px;
  }
}
/* --- PATCH: Center testimonials block and header even if nested in a grid --- */
.section-head.center{ text-align:center; }
.section-head.center p{ margin-left:auto; margin-right:auto; }

/* If testimonials got trapped inside a grid, span full width & center */
.container.testimonials{ grid-column:1 / -1 !important; margin-left:auto; margin-right:auto; }

/* Keep carousel centered */
.testimonial-viewport{ display:block; }
.testimonial-carousel{ margin-left:auto; margin-right:auto; }



















































/* Overrides: hero text colors */
.hero h1{ color:#ffffff !important; }
.hero .sub{ color:#ffd700 !important; }
