
:root{
  --bg:#0b0b0b;
  --bg-soft:#111111;
  --bg-panel:#121212;
  --text:#ffffff;
  --muted:rgba(255,255,255,.68);
  --muted-2:rgba(255,255,255,.52);
  --line:rgba(255,255,255,.10);
  --accent:#ff4d2d;
  --accent-dark:#e54326;
  --max:1200px;
  --radius:0px;
  --shadow:0 18px 50px rgba(255,77,45,.12);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-width:320px;
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit}

.container{
  width:min(var(--max), calc(100% - 2rem));
  margin:0 auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  border-bottom:1px solid var(--line);
  background:rgba(11,11,11,.90);
  backdrop-filter:blur(16px);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
}
.brand-name{
  font-size:1rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.brand-sub{
  margin-top:.2rem;
  font-size:.68rem;
  text-transform:uppercase;
  letter-spacing:.20em;
  color:var(--muted-2);
}
.desktop-nav{
  display:none;
  align-items:center;
  gap:2rem;
}
.desktop-nav a{
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--muted);
}
.desktop-nav a:hover{color:var(--text)}
.nav-outline{
  border:1px solid rgba(255,255,255,.15);
  padding:.8rem 1rem;
}
.nav-call{
  background:var(--accent);
  color:white !important;
  padding:.8rem 1rem;
}
.mobile-actions{
  display:flex;
  align-items:center;
  gap:.5rem;
}
.mobile-call-top{
  background:var(--accent);
  padding:.75rem .85rem;
  font-size:.68rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
}
.menu-toggle{
  width:42px;
  height:42px;
  border:1px solid rgba(255,255,255,.15);
  background:transparent;
  color:white;
  cursor:pointer;
}
.mobile-menu{
  display:none;
  border-top:1px solid var(--line);
  background:var(--bg);
}
.mobile-menu.open{display:block}
.mobile-menu-inner{
  display:grid;
  gap:.5rem;
  padding:1rem 0;
}
.mobile-menu-inner a{
  border:1px solid var(--line);
  padding:.95rem 1rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.82rem;
  color:rgba(255,255,255,.84);
}

.hero{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-media{
  position:absolute;
  inset:0;
}
.hero-media img{
  width:100%;
  height:108%;
  object-fit:cover;
  opacity:.35;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at top right, rgba(255,77,45,.22), transparent 32%),
    linear-gradient(90deg, rgba(11,11,11,.94) 0%, rgba(11,11,11,.84) 45%, rgba(11,11,11,.62) 100%);
}
.hero-grid{
  position:relative;
  display:grid;
  gap:2rem;
  padding:3.2rem 0;
}
.eyebrow,.section-eyebrow,.small-label{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:rgba(255,255,255,.62);
}
.hero h1{
  margin:.8rem 0 0;
  font-size:2.7rem;
  line-height:.92;
  letter-spacing:-.05em;
  text-transform:uppercase;
}
.hero p{
  max-width:43rem;
  margin:1rem 0 0;
  font-size:1rem;
  line-height:1.8;
  color:rgba(255,255,255,.74);
}
.hero-ctas{
  display:flex;
  flex-direction:column;
  gap:.75rem;
  margin-top:1.5rem;
}
.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  padding:1rem 1.2rem;
  text-align:center;
  font-size:.82rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  transition:.2s ease;
}
.btn-primary{
  background:var(--accent);
}
.btn-primary:hover{background:var(--accent-dark)}
.btn-secondary{
  border:1px solid rgba(255,255,255,.20);
}
.btn-secondary:hover{border-color:rgba(255,255,255,.4)}

.stats{
  display:grid;
  grid-template-columns:1fr;
  gap:1px;
  margin-top:2rem;
  border:1px solid var(--line);
  background:var(--line);
}
.stat{
  background:#101010;
  padding:1.25rem;
}
.stat-value{
  font-size:2rem;
  font-weight:700;
}
.stat-label{
  margin-top:.2rem;
  font-size:.9rem;
  color:var(--muted-2);
}

.hero-panels{
  display:grid;
  gap:1px;
  align-self:end;
  border:1px solid var(--line);
  background:var(--line);
}
.panel{
  background:var(--bg-panel);
  padding:1.35rem;
}
.panel-title{
  font-size:1.1rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.panel p{
  margin:.8rem 0 0;
  font-size:.95rem;
  line-height:1.8;
  color:var(--muted);
}

.section{
  padding:4rem 0;
}
.section-dark{
  background:var(--bg-soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section-head{
  display:flex;
  flex-direction:column;
  gap:1rem;
  margin-bottom:2.25rem;
}
.section-head.single{
  margin-bottom:2rem;
}
.section-head h2, .split-copy h2, .contact-copy h2{
  margin:.6rem 0 0;
  font-size:2rem;
  line-height:1;
  letter-spacing:-.04em;
  text-transform:uppercase;
}
.section-head p{
  max-width:34rem;
  margin:0;
  color:var(--muted);
  line-height:1.8;
}

.services-grid{
  display:grid;
  gap:1.2rem;
}
.service-card{
  border:1px solid var(--line);
  background:var(--bg-soft);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.service-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,77,45,.60);
  box-shadow:var(--shadow);
}
.service-card img{
  width:100%;
  height:220px;
  object-fit:cover;
}
.service-body{
  padding:1.25rem;
}
.service-number{
  font-size:.8rem;
  letter-spacing:.25em;
  color:var(--accent);
}
.service-card h3{
  margin:.75rem 0 0;
  font-size:1.5rem;
  text-transform:uppercase;
}
.service-card p{
  margin:.85rem 0 0;
  color:var(--muted);
  line-height:1.8;
}

.split-section{
  padding:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.split-image img{
  width:100%;
  height:320px;
  object-fit:cover;
}
.split-copy{
  padding:3rem 1rem;
  background:#0f0f0f;
}
.split-copy p{
  margin:1rem 0 0;
  max-width:38rem;
  color:var(--muted);
  line-height:1.85;
}
.mini-grid{
  display:grid;
  gap:1px;
  margin-top:1.5rem;
  border:1px solid var(--line);
  background:var(--line);
}
.mini-card{
  background:var(--bg-soft);
  padding:1.1rem;
  color:rgba(255,255,255,.75);
  line-height:1.8;
}

.before-after-grid{
  display:grid;
  gap:1.2rem;
}
.before-after-card{
  border:1px solid var(--line);
  background:var(--bg-soft);
  overflow:hidden;
}
.before-after-card > img{
  width:100%;
  height:240px;
  object-fit:cover;
}
.before-after-panels{
  display:grid;
  gap:1px;
  background:var(--line);
}
.before-panel,.after-panel{
  padding:1.2rem;
}
.before-panel{
  background:#131313;
}
.after-panel{
  background:var(--accent);
}
.before-after-card h3{
  margin:.75rem 0 0;
  font-size:1.4rem;
  text-transform:uppercase;
}
.before-after-card p{
  margin:1rem 0 0;
  line-height:1.8;
}
.before-panel p{color:rgba(255,255,255,.66)}
.after-panel .small-label, .contact-copy .small-label.light{color:rgba(255,255,255,.72)}
.after-panel p{color:rgba(255,255,255,.90)}

.reviews-layout{
  display:grid;
  gap:1.2rem;
}
.review-highlight{
  border:1px solid var(--line);
  background:#0d0d0d;
  padding:1.4rem;
}
.stars{
  color:var(--accent);
  letter-spacing:.25em;
  font-size:.95rem;
}
blockquote{
  margin:1.25rem 0 0;
  font-size:1.35rem;
  line-height:1.7;
  color:rgba(255,255,255,.88);
}
.review-name{
  margin-top:1.35rem;
  font-size:.82rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:rgba(255,255,255,.74);
}
.review-side{
  display:grid;
  gap:1px;
  border:1px solid var(--line);
  background:var(--line);
}
.review-note{
  background:#0d0d0d;
  padding:1.2rem;
  line-height:1.8;
  color:var(--muted);
}
.review-note-accent{
  background:var(--accent);
  color:rgba(255,255,255,.92);
}
.review-controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:#0d0d0d;
  padding:1.2rem;
}
.review-controls button{
  width:46px;
  height:46px;
  border:1px solid rgba(255,255,255,.15);
  background:transparent;
  color:white;
  font-size:1.5rem;
  cursor:pointer;
}
.review-controls button:hover{border-color:rgba(255,255,255,.35)}
#reviewCounter{
  font-size:.8rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted-2);
}

.faq-list{
  display:grid;
  gap:1px;
  border:1px solid var(--line);
  background:var(--line);
}
.faq-item{
  background:var(--bg-soft);
  padding:1.2rem;
}
.faq-item h3{
  margin:0;
  font-size:1.1rem;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.faq-item p{
  margin:.8rem 0 0;
  color:var(--muted);
  line-height:1.8;
}

.location-layout{
  display:grid;
  gap:0;
  border:1px solid var(--line);
  overflow:hidden;
}
.location-copy{
  padding:1.25rem;
  background:#0d0d0d;
}
.location-item + .location-item{margin-top:1.8rem}
.location-value{
  display:block;
  margin-top:.65rem;
  font-size:1.35rem;
  font-weight:700;
  line-height:1.35;
}
.location-map{
  border-top:1px solid var(--line);
}
.location-map img{
  width:100%;
  height:170px;
  object-fit:cover;
  border-bottom:1px solid var(--line);
}
.location-map iframe{
  width:100%;
  min-height:320px;
  border:0;
  display:block;
}

.contact-section{
  background:var(--accent);
  color:white;
}
.contact-layout{
  display:grid;
  gap:1px;
  background:rgba(255,255,255,.20);
}
.contact-copy{
  background:var(--accent-dark);
  padding:3rem 1rem;
}
.section-eyebrow-light{color:rgba(255,255,255,.72)}
.contact-copy p{
  margin:1rem 0 0;
  max-width:38rem;
  color:rgba(255,255,255,.90);
  line-height:1.85;
}
.contact-boxes{
  display:grid;
  gap:1px;
  margin-top:1.8rem;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.20);
}
.contact-box{
  background:var(--accent-dark);
  padding:1.1rem;
}
.contact-box a{
  display:inline-block;
  margin-top:.55rem;
  font-size:1.35rem;
  font-weight:700;
}
.contact-form{
  display:grid;
  gap:1rem;
  background:#0f0f0f;
  padding:3rem 1rem;
}
.contact-form input,
.contact-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.15);
  background:#171717;
  color:white;
  padding:1rem;
  outline:none;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color:rgba(255,255,255,.35);
}
.contact-form input:focus,
.contact-form textarea:focus{
  border-color:var(--accent);
}
.contact-form button{
  border:0;
  background:var(--accent);
  color:white;
  padding:1rem;
  font-size:.82rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.15em;
  cursor:pointer;
}
.contact-form button:hover{background:var(--accent-dark)}

.site-footer{
  border-top:1px solid var(--line);
  background:black;
}
.footer-inner{
  display:flex;
  flex-direction:column;
  gap:1.2rem;
  padding:2rem 0 6rem;
  color:rgba(255,255,255,.55);
}
.footer-brand{
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:white;
}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:1.2rem;
  text-transform:uppercase;
  letter-spacing:.14em;
}
.footer-links a:hover{color:white}

.mobile-bottom-bar{
  position:fixed;
  inset:auto 0 0 0;
  z-index:80;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.75rem;
  padding:.75rem;
  padding-bottom:calc(env(safe-area-inset-bottom) + .75rem);
  border-top:1px solid var(--line);
  background:var(--bg);
}
.mobile-bottom-bar a{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  text-align:center;
  font-size:.82rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.bottom-call{
  border:1px solid rgba(255,255,255,.15);
}
.bottom-inquiry{
  background:var(--accent);
}

@media (min-width: 640px){
  .container{width:min(var(--max), calc(100% - 3rem))}
  .hero-grid{padding:4rem 0}
  .hero h1{font-size:4rem}
  .hero-ctas{flex-direction:row;flex-wrap:wrap}
  .stats{grid-template-columns:1fr 1fr}
  .stat-wide{grid-column:1 / -1}
  .services-grid,.before-after-grid{grid-template-columns:1fr 1fr}
  .split-image img{height:420px}
  .before-after-card > img{height:280px}
  .review-highlight{padding:2rem}
  blockquote{font-size:1.75rem}
  .location-copy{padding:1.75rem}
  .contact-copy,.contact-form{padding:3.2rem 1.5rem}
  .footer-inner{padding-bottom:6.5rem}
}

@media (min-width: 768px){
  .desktop-nav{display:flex}
  .mobile-actions{display:none}
  .hero-grid{grid-template-columns:1.1fr .9fr;align-items:end;padding:5rem 0 6rem}
  .hero h1{font-size:5rem}
  .stats{grid-template-columns:1fr 1fr 1fr}
  .stat-wide{grid-column:auto}
  .section{padding:5rem 0}
  .section-head{flex-direction:row;justify-content:space-between;align-items:end}
  .services-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .split-copy{padding:4rem 2rem}
  .mini-grid{grid-template-columns:1fr 1fr}
  .before-after-panels{grid-template-columns:1fr 1fr}
  .reviews-layout{grid-template-columns:1.15fr .85fr}
  .location-layout{grid-template-columns:.9fr 1.1fr}
  .location-map{border-top:0;border-left:1px solid var(--line)}
  .contact-layout{grid-template-columns:.9fr 1.1fr}
  .footer-inner{flex-direction:row;align-items:center;justify-content:space-between;padding-bottom:2rem}
}

@media (min-width: 1024px){
  .hero h1{font-size:6.2rem}
  .services-grid{grid-template-columns:repeat(3, minmax(0,1fr))}
  .split-section{display:grid;grid-template-columns:1.05fr .95fr}
  .split-image img{height:100%}
  .split-copy{padding:4.5rem 2.5rem}
  .before-after-card > img{height:320px}
}

@media (min-width: 1025px){
  .mobile-bottom-bar{display:none}
}

@media (prefers-reduced-motion:no-preference){
  .service-card,
  .btn,
  .nav-call,
  .mobile-call-top,
  .bottom-inquiry,
  .contact-form button{
    transition:all .25s ease;
  }
  .hero-media img{
    animation:heroFloat 16s ease-in-out infinite alternate;
  }
  @keyframes heroFloat{
    from{transform:scale(1) translateY(0)}
    to{transform:scale(1.04) translateY(-18px)}
  }
}
