
:root{
  --bg:#0f1319;
  --bg-2:#141a22;
  --card:#171e27;
  --soft:#202a36;
  --text:#f5f3ee;
  --muted:#bcc5cf;
  --line:rgba(255,255,255,.08);
  --accent:#ef8d16;
  --accent-2:#ffb357;
  --radius:22px;
  --shadow:0 18px 45px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(239,141,22,.08), transparent 30%),
    linear-gradient(180deg,#0c1117 0%, #10161d 100%);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1120px,calc(100% - 32px));margin:0 auto}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.nav{
  position:sticky;top:0;z-index:80;
  backdrop-filter:blur(18px);
  background:rgba(11,16,22,.86);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  min-height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand-lockup{
  display:flex;align-items:center;gap:14px;min-width:0;flex:1;
}
.brand-logo{
  width:72px;height:72px;object-fit:contain;flex:0 0 auto;
  border-radius:16px;
  background:#111;
  padding:4px;
}
.brand-copy{
  min-width:0;
  display:flex;flex-direction:column;gap:2px;
}
.brand-name{
  font-size:clamp(1rem,3.8vw,1.35rem);
  line-height:1.1;font-weight:800;letter-spacing:-.03em;
  white-space:normal;
}
.brand-tag{
  color:var(--muted);
  font-size:clamp(.72rem,2.3vw,.9rem);
  line-height:1.3;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.menu-toggle{
  width:54px;height:54px;border-radius:18px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);display:flex;flex-direction:column;
  justify-content:center;gap:6px;align-items:center;cursor:pointer;flex:0 0 auto;
}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px}
.menu{
  position:absolute;left:16px;right:16px;top:calc(100% + 10px);
  background:#121821;border:1px solid var(--line);border-radius:22px;
  padding:10px;display:none;flex-direction:column;gap:4px;box-shadow:var(--shadow);
}
.menu.open{display:flex}
.menu a{
  padding:14px 16px;border-radius:14px;color:var(--text);font-weight:600
}
.menu a:hover,.menu a:focus{background:rgba(255,255,255,.05)}
.menu .nav-cta{background:var(--accent);color:#fff}
.hero{
  position:relative;
  min-height:clamp(420px,68vh,700px);
  display:flex;align-items:flex-end;
}
.hero-media{
  position:absolute;inset:0;
  background:url('assets/hero.jpg') center center/cover no-repeat;
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(11,16,22,.18) 10%, rgba(11,16,22,.62) 55%, rgba(11,16,22,.92) 100%),
    linear-gradient(90deg,rgba(11,16,22,.78) 0%, rgba(11,16,22,.2) 55%, rgba(11,16,22,.7) 100%);
}
.hero-content{
  position:relative;z-index:1;
  padding:14px 0 34px;
}
.eyebrow,.section-kicker{
  display:inline-flex;align-items:center;gap:10px;
  color:#ffd3a0;
  border:1px solid rgba(239,141,22,.45);
  background:rgba(239,141,22,.1);
  padding:10px 14px;border-radius:999px;
  font-size:.92rem;font-weight:700;letter-spacing:.01em;
  margin-bottom:12px;
}
.hero h1,.page-hero h1{
  margin:18px 0 14px;
  font-size:clamp(2.35rem,9vw,4.9rem);
  line-height:.97;letter-spacing:-.055em;
  max-width:10ch;
}
.hero p,.page-hero p{
  margin:0;max-width:760px;color:#ebeff4;font-size:clamp(1rem,2.8vw,1.28rem)
}
.hero-actions{
  display:flex;flex-wrap:wrap;gap:12px;margin-top:18px
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:54px;padding:0 22px;border-radius:999px;font-weight:800;
  transition:.2s ease; border:1px solid transparent;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:#fff}
.btn-secondary{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}
.btn-facebook{
  background:#1877f2;color:#fff;gap:10px;
  box-shadow:0 12px 28px rgba(24,119,242,.35);
  position:relative;overflow:hidden;isolation:isolate;
}
.btn-facebook::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,#1877f2 0%,#3b5bff 60%,#6a3bff 100%);
  opacity:0;transition:opacity .25s ease;
}
.btn-facebook:hover::before{opacity:1}
.btn-facebook:hover{box-shadow:0 16px 36px rgba(59,91,255,.45)}
.btn-facebook svg{width:22px;height:22px;flex:none}
.fb-cta{
  margin-top:22px;padding:22px;border-radius:var(--radius);
  border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(24,119,242,.12), rgba(255,255,255,.02));
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
}
.fb-cta-copy{display:flex;flex-direction:column;gap:4px;min-width:0}
.fb-cta-kicker{
  color:#7aa7ff;font-weight:800;font-size:.8rem;
  text-transform:uppercase;letter-spacing:.14em
}
.fb-cta-title{
  margin:0;font-size:clamp(1.1rem,3.6vw,1.35rem);
  line-height:1.15;letter-spacing:-.01em;color:var(--text)
}
.section{padding:34px 0}
.section-dark{
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.stats-grid,.service-grid,.review-grid,.contact-grid,.photo-grid{
  display:grid;gap:18px
}
.stats-grid{grid-template-columns:1fr}
.stat-card,.service-card,.review-card,.contact-card,.contact-form,.feature-panel,.gallery-card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
}
.stat-card,.service-card,.review-card,.contact-card,.contact-form{padding:26px}
.accent-left{border-left:4px solid var(--accent)}
.stat-number{
  display:block;color:#ffd3a0;font-weight:800;font-size:.95rem;text-transform:uppercase;letter-spacing:.12em;
  margin-bottom:10px
}
.stat-card h2,.service-card h2,.review-card h2,.contact-card h2,.split-feature h2,.section-head h2{
  margin:0 0 10px;line-height:1.06;letter-spacing:-.03em;
  font-size:clamp(1.4rem,5.4vw,2.1rem)
}
.stat-card p,.service-card p,.review-card p,.contact-card p,.split-feature p{margin:0;color:var(--muted)}
.split-feature{
  display:grid;gap:24px;align-items:center
}
.tick-list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:10px}
.tick-list li{
  position:relative;padding-left:28px;color:var(--text);font-weight:600
}
.tick-list li::before{
  content:"";position:absolute;left:0;top:.6em;width:12px;height:12px;border-radius:999px;background:var(--accent)
}
.feature-panel{overflow:hidden}
.feature-panel img{width:100%;height:100%;object-fit:cover;min-height:320px}
.section-head{
  display:flex;align-items:end;justify-content:space-between;gap:14px;margin-bottom:10px;flex-wrap:wrap
}
.text-link{
  color:#ffd3a0;font-weight:800
}
.home-gallery{
  display:grid;grid-template-columns:1fr;gap:14px
}
.home-gallery img,.gallery-card img{
  width:100%;height:100%;object-fit:cover
}
.home-gallery img{
  border-radius:22px;border:1px solid var(--line);
  min-height:180px;box-shadow:var(--shadow)
}
.page-main{padding-bottom:120px}
.page-hero.compact{
  padding:26px 0 2px;border-bottom:1px solid var(--line)
}
.service-grid{grid-template-columns:1fr}
.service-card h2{margin-bottom:8px}
.photo-grid{grid-template-columns:1fr;gap:14px}
.gallery-card{overflow:hidden}
.gallery-card img{aspect-ratio:4/3}
.gallery-card figcaption{
  padding:12px 14px;color:var(--muted);font-weight:700
}
.stars{color:var(--accent-2);font-size:1.35rem;letter-spacing:.18em;margin-bottom:12px}
.review-links{
  display:flex;flex-wrap:wrap;gap:12px;margin-top:18px
}
.contact-grid{grid-template-columns:1fr}
.contact-form label{
  display:grid;gap:8px;font-weight:700;margin-bottom:14px
}
.contact-form input,.contact-form textarea{
  width:100%;border-radius:16px;border:1px solid rgba(255,255,255,.12);
  background:#0e141b;color:var(--text);padding:15px 16px;font:inherit
}
.contact-form textarea{resize:vertical}
.hidden-field{display:none}
.site-footer{
  border-top:1px solid var(--line);
  background:#0c1117;
  padding:22px 0 104px
}
.footer-grid{
  display:grid;gap:14px
}
.footer-brand{display:grid;gap:6px}
.footer-brand h3{margin:0;font-size:1.2rem;line-height:1.15}
.footer-brand p,.footer-contact p,.footer-bottom{margin:0;color:var(--muted)}
.footer-contact{display:grid;gap:8px}
.footer-contact a{font-weight:700}
.footer-bottom{
  padding-top:14px;margin-top:14px;border-top:1px solid var(--line);font-size:.95rem
}
.mobile-cta{
  position:fixed;left:12px;right:12px;bottom:max(10px, env(safe-area-inset-bottom));
  display:grid;grid-template-columns:1fr 1fr;gap:10px;z-index:90
}
.mobile-cta a{
  min-height:54px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  font-weight:900;box-shadow:var(--shadow)
}
.mobile-cta-call{background:var(--accent);color:#fff}
.mobile-cta-quote{background:rgba(22,30,39,.92);border:1px solid rgba(255,255,255,.08)}
.thankyou-wrap{padding-bottom:42px}
@media (min-width:700px){
  .container{width:min(1120px,calc(100% - 48px))}
  .stats-grid,.service-grid,.review-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .home-gallery{grid-template-columns:1.15fr .85fr .85fr}
  .split-feature{grid-template-columns:1.15fr .85fr}
  .contact-grid{grid-template-columns:.85fr 1.15fr}
  .footer-grid{grid-template-columns:1.2fr .8fr}
}
@media (min-width:980px){
  .nav-inner{min-height:92px}
  .menu-toggle{display:none}
  .menu{
    position:static;display:flex !important;flex-direction:row;align-items:center;
    gap:4px;background:none;border:none;box-shadow:none;padding:0;left:auto;right:auto;top:auto
  }
  .menu a{padding:12px 14px}
  .brand-lockup{flex:0 1 auto;max-width:520px}
  .brand-logo{width:74px;height:74px}
  .hero-content{padding:96px 0 78px}
  .stats-grid{grid-template-columns:1.1fr .95fr .95fr}
  .service-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .photo-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .mobile-cta{display:none}
  .site-footer{padding-bottom:34px}
  .page-main{padding-bottom:0}
}

@media (max-width:699px){
  .hero h1,.page-hero h1{margin:12px 0 10px;max-width:11ch}
  .hero p,.page-hero p{font-size:1rem}
  .stat-card,.service-card,.review-card,.contact-card,.contact-form{padding:22px}
  .tick-list{margin:14px 0 0;gap:8px}
  .split-feature{gap:18px}
  .feature-panel img{min-height:220px}
  .review-links{margin-top:16px}
  .section{padding:28px 0}
  .section-kicker{margin-bottom:12px}
  .site-footer{padding:18px 0 102px}
}

.customer-gallery-head{margin-bottom:14px}
.customer-gallery-head p{margin:10px 0 0;color:var(--muted)}
.review-page-stack{display:grid;gap:14px}
.google-review-card{padding:22px;background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.google-review-top{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.google-review-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex:0 0 auto}
.google-review-meta h2{margin:0;font-size:1.15rem;line-height:1.2}
.google-badge{display:inline-flex;align-items:center;gap:8px;margin:0 0 14px;color:var(--muted);font-weight:700;font-size:.95rem}
.google-dot{width:9px;height:9px;border-radius:50%;background:#4285f4;display:inline-block}
.review-body{color:#e9edf2;font-size:1rem;line-height:1.7;margin:0}
.review-photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px}
.review-photo-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:18px;border:1px solid var(--line)}
.review-more-link{margin-top:20px;display:flex;flex-wrap:wrap;gap:12px}
.review-intro{margin-top:18px}
@media (min-width: 720px){
  .brand-logo{width:82px;height:82px}
  .review-photo-grid{grid-template-columns:repeat(3,1fr)}
}


.gallery-intro{display:grid;gap:18px}
.gallery-head-simple{margin-bottom:6px}
.gallery-showcase{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.gallery-tile,
.clean-card{
  display:block;
  overflow:hidden;
  border-radius:24px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  box-shadow:var(--shadow);
}
.gallery-tile img,
.clean-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio:4/3;
  transition:transform .25s ease;
}
.gallery-tile:hover img,
.clean-card:hover img{transform:scale(1.02)}
.project-gallery-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.clean-card{padding:0}
.clean-card figcaption{display:none}
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(5,8,12,.94);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:200;
}
.lightbox.open{display:flex}
.lightbox-stage{
  width:min(92vw,1200px);
  height:min(84vh,900px);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}
.lightbox-image{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.45);
}
.lightbox-close,
.lightbox-nav{
  position:absolute;
  border:none;
  color:#fff;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  cursor:pointer;
  z-index:1;
}
.lightbox-close{
  top:18px;
  right:18px;
  width:52px;
  height:52px;
  border-radius:18px;
  font-size:2rem;
  line-height:1;
}
.lightbox-nav{
  top:50%;
  transform:translateY(-50%);
  width:52px;
  height:52px;
  border-radius:999px;
  font-size:2rem;
  line-height:1;
}
.lightbox-prev{left:18px}
.lightbox-next{right:18px}
body.lightbox-open{overflow:hidden}
@media (min-width:700px){
  .gallery-showcase{grid-template-columns:1.18fr .82fr .82fr}
  .gallery-tile-large{grid-row:span 2}
  .project-gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (min-width:980px){
  .project-gallery-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
