*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:#0c0d10;color:#f0ece4;font-family:'Outfit',sans-serif;font-size:16px;line-height:1.65;overflow-x:hidden}

:root{
  --black:#0c0d10;
  --dark:#13151b;
  --card:#181b23;
  --card2:#1e222c;
  --border:rgba(255,255,255,0.07);
  --gold:#d4a843;
  --gold2:#f0c96a;
  --gold-dim:rgba(212,168,67,0.12);
  --red:#c0392b;
  --white:#f0ece4;
  --muted:#8a8a9a;
  --radius:6px;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ── TOPBAR ── */
.topbar{
  background:var(--gold);color:#0c0d10;
  text-align:center;padding:9px 16px;
  font-size:13px;font-weight:700;letter-spacing:.04em;
  position:sticky;top:0;z-index:1000;
}
.topbar a{color:#0c0d10;text-decoration:none;font-weight:900}

/* ── NAV ── */
nav{
  background:rgba(13,15,20,.97);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  position:sticky;top:var(--topbar-h,37px);z-index:999;
}
.nav-inner{
  max-width:1280px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:72px;padding:0 28px;
}
.nav-logo{display:flex;align-items:center;gap:0;cursor:pointer;text-decoration:none}
.nav-logo img{height:60px;width:auto;display:block;filter:drop-shadow(0 2px 12px rgba(212,168,67,.35))}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a,.nav-drop>span{
  color:var(--muted);text-decoration:none;
  padding:8px 13px;border-radius:var(--radius);
  font-size:13.5px;font-weight:500;letter-spacing:.02em;
  transition:color .2s,background .2s;cursor:pointer;white-space:nowrap;
}
.nav-links a:hover,.nav-drop>span:hover,.nav-links a.active{color:var(--white);background:rgba(255,255,255,.05)}
.nav-drop{position:relative}
.nav-drop>span{display:flex;align-items:center;gap:5px}
.nav-drop>span::after{content:'▾';font-size:9px;opacity:.6}
.dropdown{
  display:none;position:absolute;top:calc(100% + 6px);left:0;
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;min-width:240px;
  box-shadow:0 20px 60px rgba(0,0,0,.7);overflow:hidden;
}
.nav-drop:hover .dropdown{display:block}
.dropdown a{
  display:block;padding:12px 20px;
  font-size:13.5px;color:var(--muted);
  border-bottom:1px solid var(--border);
  transition:background .15s,color .15s;text-decoration:none;
}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{background:var(--gold-dim);color:var(--gold)}
.nav-cta{
  background:var(--gold)!important;color:#0c0d10!important;
  padding:9px 22px!important;border-radius:var(--radius)!important;
  font-weight:700!important;font-size:13.5px!important;
  transition:background .2s,transform .15s!important;
}
.nav-cta:hover{background:var(--gold2)!important;transform:translateY(-1px)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:10px;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}

/* ── PAGE SYSTEM ── */
.page{display:none;animation:fadeIn .35s var(--ease)}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── BUTTONS ── */
.btn-gold{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--gold);color:#0c0d10;
  padding:14px 30px;border-radius:var(--radius);
  font-family:'Outfit',sans-serif;font-weight:700;font-size:14px;letter-spacing:.04em;
  text-decoration:none;border:none;cursor:pointer;
  transition:background .2s,transform .15s,box-shadow .2s;
  box-shadow:0 4px 24px rgba(212,168,67,.25);
}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 8px 32px rgba(212,168,67,.35)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:9px;
  background:transparent;color:var(--white);
  padding:13px 28px;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.18);
  font-family:'Outfit',sans-serif;font-weight:500;font-size:14px;
  text-decoration:none;cursor:pointer;
  transition:border-color .2s,color .2s,transform .15s;
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn-dark{
  display:inline-flex;align-items:center;gap:9px;
  background:#0c0d10;color:var(--gold);
  padding:14px 30px;border-radius:var(--radius);
  font-family:'Outfit',sans-serif;font-weight:700;font-size:14px;
  text-decoration:none;border:2px solid var(--gold);cursor:pointer;
  transition:background .2s,transform .15s;
}
.btn-dark:hover{background:#1a1c24;transform:translateY(-2px)}

/* ── LAYOUT ── */
.container{max-width:1280px;margin:0 auto;padding:0 28px}
section{padding:88px 0}
.section-eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;display:block;
}
.section-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(34px,4.5vw,58px);
  color:var(--white);line-height:1.08;margin-bottom:20px;
}
.section-body{font-size:15.5px;color:var(--muted);max-width:560px;line-height:1.75}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.two-col.flip>:first-child{order:2}
.two-col.flip>:last-child{order:1}

/* ── CARDS ── */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2px;background:var(--border);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-top:56px}
.card{
  background:var(--card);padding:38px 34px;
  cursor:pointer;position:relative;overflow:hidden;
  transition:background .2s;
}
.card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold2));
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.card:hover{background:var(--card2)}
.card:hover::after{transform:scaleX(1)}
.card-num{font-family:'Bebas Neue',sans-serif;font-size:52px;color:rgba(212,168,67,.1);line-height:1;margin-bottom:6px}
.card h3{font-family:'Playfair Display',serif;font-size:22px;margin-bottom:10px;color:var(--white)}
.card p{font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:20px}
.card-link{color:var(--gold);font-size:13px;font-weight:600;letter-spacing:.05em;display:flex;align-items:center;gap:6px}

/* ── FEATURES ── */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-top:56px}
.feature{padding:32px 28px;border:1px solid var(--border);border-radius:10px;background:var(--card);transition:border-color .2s,transform .2s}
.feature:hover{border-color:rgba(212,168,67,.3);transform:translateY(-3px)}
.feature-icon{font-size:32px;margin-bottom:16px}
.feature h4{font-size:17px;font-weight:600;margin-bottom:8px;color:var(--white)}
.feature p{font-size:14px;color:var(--muted);line-height:1.65}

/* ── REVIEWS ── */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:48px}
.review{background:var(--card);border:1px solid var(--border);padding:30px;border-radius:10px;transition:border-color .2s}
.review:hover{border-color:rgba(212,168,67,.25)}
.stars{color:var(--gold);letter-spacing:3px;font-size:14px;margin-bottom:14px}
.review-body{font-size:14.5px;color:var(--muted);line-height:1.75;font-style:italic;margin-bottom:18px}
.reviewer-name{font-weight:600;font-size:14px;color:var(--white)}
.reviewer-info{font-size:12.5px;color:var(--muted);margin-top:2px}

/* ── FAQ ── */
.faq{border-top:1px solid var(--border);margin-top:48px}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  width:100%;background:none;border:none;text-align:left;
  padding:22px 0;font-family:'Outfit',sans-serif;font-size:16px;font-weight:600;
  color:var(--white);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;
  transition:color .2s;
}
.faq-q:hover{color:var(--gold)}
.faq-q .ico{width:28px;height:28px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:transform .3s,border-color .2s}
.faq-item.open .faq-q .ico{transform:rotate(45deg);border-color:var(--gold)}
.faq-a{font-size:14.5px;color:var(--muted);max-height:0;overflow:hidden;transition:max-height .35s var(--ease),padding .35s;line-height:1.75}
.faq-item.open .faq-a{max-height:300px;padding-bottom:22px}

/* ── CTA STRIP ── */
.cta-strip{
  background:linear-gradient(135deg,#1a1408 0%,#2a1f08 50%,#1a1408 100%);
  border-top:1px solid rgba(212,168,67,.2);border-bottom:1px solid rgba(212,168,67,.2);
  padding:72px 0;text-align:center;position:relative;overflow:hidden;
}
.cta-strip::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(212,168,67,.08) 0%,transparent 70%);
}
.cta-strip h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(42px,6vw,80px);color:var(--gold);letter-spacing:.05em;margin-bottom:12px;position:relative}
.cta-strip p{font-size:16px;color:var(--muted);margin-bottom:32px;position:relative}
.cta-strip .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* ── FOOTER ── */
footer{background:var(--dark);border-top:1px solid var(--border);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo img{height:64px;width:auto;filter:drop-shadow(0 2px 8px rgba(212,168,67,.2))}
.footer-tagline{font-size:14px;color:var(--muted);margin-top:12px;max-width:280px;line-height:1.7}
.footer-contact{margin-top:20px}
.footer-contact a{display:block;color:var(--gold);text-decoration:none;font-size:14px;font-weight:600;margin-bottom:6px}
.footer-contact a:hover{text-decoration:underline}
.footer-col h5{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer-col a{display:block;color:var(--muted);text-decoration:none;font-size:14px;margin-bottom:10px;transition:color .2s;cursor:pointer}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:12.5px;color:var(--muted)}

/* ── PAGE HERO ── */
.page-hero{
  background:var(--dark);border-bottom:1px solid var(--border);
  padding:72px 0 60px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 100% at 10% 50%,rgba(212,168,67,.06) 0%,transparent 65%);
}
.page-hero .container{position:relative}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb span{cursor:pointer;transition:color .2s}
.breadcrumb span:hover,.breadcrumb .cur{color:var(--gold)}
.breadcrumb .sep{color:var(--border)}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(34px,5vw,60px);margin-bottom:16px;line-height:1.1}
.page-hero .lead{font-size:16.5px;color:var(--muted);max-width:640px;line-height:1.72}
.page-hero .hero-btns{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}

/* ── PROCESS LIST ── */
.process{list-style:none;margin-top:28px}
.process li{
  display:grid;grid-template-columns:48px 1fr;gap:20px;
  padding:22px 0;border-bottom:1px solid var(--border);align-items:start;
}
.process li:last-child{border-bottom:none}
.step-num{
  width:44px;height:44px;border-radius:50%;
  background:var(--gold-dim);border:1px solid rgba(212,168,67,.3);
  display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--gold);flex-shrink:0;
}
.step-body strong{display:block;font-size:15.5px;margin-bottom:5px;color:var(--white)}
.step-body p{font-size:14px;color:var(--muted);line-height:1.65}

/* ── SERVICES DETAIL ── */
.service-list{display:grid;gap:20px;margin-top:40px}
.service-item{
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:28px 30px;
  display:grid;grid-template-columns:56px 1fr;gap:20px;align-items:start;
  transition:border-color .2s,transform .2s;
}
.service-item:hover{border-color:rgba(212,168,67,.3);transform:translateX(4px)}
.svc-icon{width:52px;height:52px;border-radius:8px;background:var(--gold-dim);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.svc-body h4{font-size:17px;font-weight:600;margin-bottom:6px;color:var(--white)}
.svc-body p{font-size:14px;color:var(--muted);line-height:1.65}
.svc-badge{display:inline-block;margin-top:10px;font-size:12px;color:var(--gold);font-weight:600;letter-spacing:.04em}

/* ── CITY PAGE ── */
.city-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin:40px 0}
.stat{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:22px;text-align:center}
.stat-n{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--gold);line-height:1}
.stat-l{font-size:12px;color:var(--muted);letter-spacing:.05em;margin-top:4px}

/* ── AREA TILES ── */
.areas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;margin-top:40px}
.area-tile{
  background:var(--card);border:1px solid var(--border);
  padding:16px 20px;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;gap:12px;
  transition:border-color .2s,background .2s,transform .15s;
  text-decoration:none;
}
.area-tile:hover{border-color:var(--gold);background:var(--gold-dim);transform:translateY(-2px)}
.area-tile .dot{width:7px;height:7px;background:var(--gold);border-radius:50%;flex-shrink:0}
.area-tile span{font-size:14px;font-weight:500;color:var(--white)}

/* ── BRANDS BAR ── */
.brands-bar{background:var(--card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:32px 0}
.brands-label{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:center;margin-bottom:22px}
.brands-list{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.brand{padding:9px 22px;border:1px solid var(--border);border-radius:50px;font-size:13.5px;font-weight:600;color:var(--muted);background:var(--dark);transition:border-color .2s,color .2s}
.brand:hover{border-color:var(--gold);color:var(--gold)}

/* ── FORM ── */
.form-wrap{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:44px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg.full{grid-column:1/-1}
label{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
input,textarea,select{
  background:var(--dark);border:1px solid var(--border);
  color:var(--white);padding:13px 16px;border-radius:var(--radius);
  font-size:14px;font-family:'Outfit',sans-serif;
  transition:border-color .2s;-webkit-appearance:none;
}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold)}
textarea{min-height:120px;resize:vertical}
select option{background:var(--dark)}
.cb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-top:8px}
.cb-label{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);cursor:pointer;transition:color .2s}
.cb-label:hover{color:var(--white)}
.cb-label input{width:16px;height:16px;flex-shrink:0;accent-color:var(--gold)}

/* ── PHONE CALLOUT ── */
.phone-callout{
  background:var(--gold-dim);border:1px solid rgba(212,168,67,.3);
  border-radius:10px;padding:28px 32px;text-align:center;
}
.phone-callout .ph{font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--gold);letter-spacing:.05em;text-decoration:none;display:block}
.phone-callout .ph:hover{color:var(--gold2)}
.phone-callout .ph-sub{font-size:13px;color:var(--muted);margin-top:6px}

/* ── INLINE PHONE ── */
.ph-link{color:var(--gold);font-weight:700;text-decoration:none}
.ph-link:hover{text-decoration:underline}

/* ── DIVIDER ── */
.divider{height:1px;background:var(--border);margin:48px 0}

/* ── OWNER PHOTO ── */
.owner-photo{
  border-radius:12px;overflow:hidden;
  border:2px solid rgba(212,168,67,.4);
  box-shadow:0 16px 64px rgba(0,0,0,.6),0 0 0 6px rgba(212,168,67,.05);
  aspect-ratio:1/1;
}
.owner-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .two-col{grid-template-columns:1fr;gap:40px}
  .two-col.flip>:first-child{order:unset}
  .two-col.flip>:last-child{order:unset}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:700px){
  /* Compact topbar */
  .topbar{font-size:11.5px;padding:7px 12px}
  /* Remove backdrop-filter — it creates a containing block that traps position:fixed children */
  nav{backdrop-filter:none;background:#0d0f14}
  /* Compact nav */
  .nav-inner{height:56px;padding:0 16px}
  .nav-logo img{height:44px}
  /* Hero grid collapse */
  .hero-grid{grid-template-columns:1fr!important;gap:40px!important}
  /* Reduce page-hero padding on mobile */
  .page-hero{padding:36px 0 28px}
  /* Reduce homepage hero padding */
  .home-hero{min-height:auto!important;padding:0!important}
  .home-hero .container{padding-top:32px!important;padding-bottom:48px!important}
  /* Mobile menu overlay */
  .nav-links{
    display:none;position:fixed;
    top:0;left:0;right:0;bottom:0;
    background:#0d0f14;
    flex-direction:column;padding:0;gap:0;
    overflow-y:auto;z-index:9999;
  }
  .nav-links.open{display:flex}
  /* Spacer so items start below topbar+nav */
  .nav-links::before{
    content:'';display:block;flex-shrink:0;
    height:calc(var(--topbar-h,37px) + 56px);
  }
  /* Nav items */
  .nav-links a,.nav-links .nav-drop>span{
    color:#f0ece4;font-size:16px;font-weight:500;
    padding:14px 24px;display:block;
    border-bottom:1px solid rgba(255,255,255,.06);
  }
  .nav-links a:hover,.nav-links .nav-drop>span:hover{background:rgba(255,255,255,.04)}
  .nav-links .nav-cta{
    color:#0c0d10;background:var(--gold);
    text-align:center;margin:16px 24px 24px;
    border-radius:var(--radius);border-bottom:none;
    font-weight:700;
  }
  .nav-links .nav-cta:hover{background:var(--gold2)}
  /* Dropdowns */
  .nav-drop>span::after{content:none}
  .dropdown{
    position:static;box-shadow:none;border:none;
    border-left:2px solid var(--gold);margin:0 0 0 24px;
    border-radius:0;display:none;background:transparent;
  }
  .dropdown a{font-size:14.5px;padding:11px 20px;border-bottom:none;color:var(--muted)}
  .dropdown a:hover{color:var(--gold);background:transparent}
  .nav-drop.open-m .dropdown{display:block}
  /* Hamburger */
  .hamburger{display:flex;z-index:10000}
  /* Layout */
  .footer-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .card-grid{grid-template-columns:1fr}
  section{padding:56px 0}
  .container{padding:0 16px}
}

/* ── FIX 1.2: Hamburger X animation ── */
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── FIX 1.3: Breadcrumb & area pill links (replaces inline handlers) ── */
.breadcrumb-link{color:var(--muted);text-decoration:none;transition:color .2s}
.breadcrumb-link:hover{color:var(--gold)}
.area-pill{padding:7px 16px;border:1px solid var(--border);border-radius:50px;font-size:13px;color:var(--muted);text-decoration:none;background:var(--dark);transition:border-color .2s,color .2s}
.area-pill:hover{border-color:var(--gold);color:var(--gold)}

/* ── FIX 2.1: Sticky Mobile CTA Bar ── */
.mobile-cta{display:none}
@media(max-width:700px){
  .mobile-cta{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:9998;
    background:#0d0f14;border-top:1px solid rgba(212,168,67,.3);
    padding:10px 16px;gap:10px;align-items:center;justify-content:center;
  }
  .mobile-cta a{
    flex:1;text-align:center;padding:12px 0;border-radius:var(--radius);
    font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;
    text-decoration:none;letter-spacing:.03em;
  }
  .mobile-cta .mcta-call{background:var(--gold);color:#0c0d10}
  .mobile-cta .mcta-estimate{background:transparent;color:var(--gold);border:1px solid var(--gold)}
  body{padding-bottom:60px}
}
