
:root{
  --bg:#f8fafc;
  --surface:#ffffff;
  --text:#0f172a;
  --muted:#475569;
  --border:#e2e8f0;
  --dark:#0f172a;
  --orange:#ea580c;
  --orange-dark:#c2410c;
  --amber:#fef3c7;
  --amber-border:#fcd34d;
  --amber-text:#92400e;
  --shadow:0 10px 30px rgba(15,23,42,.08);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.5;
}
img{max-width:100%;display:block}
a{color:inherit}
.container{width:min(1120px, calc(100% - 32px)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:20;
  border-bottom:1px solid var(--border);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand-logo{height:42px; width:auto; object-fit:contain}
.desktop-nav{display:none; gap:24px; font-size:14px}
.desktop-nav a,.mobile-quicklinks a{text-decoration:none}
.desktop-nav a:hover,.mobile-quicklinks a:hover{color:#475569}
.mobile-quicklinks{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  padding:10px 16px 12px;
  border-top:1px solid var(--border);
  background:#fff;
  font-size:13px;
  text-align:center;
}
.section{padding:72px 0}
.section-tight{padding-top:32px}
.section-alt{background:#fff; border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.hero{
  display:grid; gap:32px; padding:48px 0 72px;
}
.eyebrow{
  display:inline-flex; width:fit-content;
  border:1px solid var(--border); background:#fff;
  padding:6px 12px; border-radius:999px; color:#475569;
  font-size:14px; box-shadow:var(--shadow);
}
h1{
  font-size:clamp(2.3rem, 6vw, 4rem);
  line-height:1.05; letter-spacing:-0.03em;
  margin:16px 0 0; max-width:12ch;
}
h2{
  font-size:clamp(1.9rem, 4vw, 2.4rem);
  line-height:1.1; letter-spacing:-0.03em; margin:0;
}
h3{margin:8px 0 0; font-size:1.15rem}
.lead{font-size:1.08rem; color:var(--muted); max-width:42rem; margin:18px 0 0}
.trust-badge{
  margin-top:18px; display:inline-flex; width:fit-content; align-items:center;
  border:1px solid #fde68a; background:#fffbeb; color:var(--amber-text);
  padding:7px 12px; border-radius:999px; font-size:14px; font-weight:600;
  box-shadow:var(--shadow);
}
.hero-actions{display:flex; flex-direction:column; gap:12px; margin-top:24px}
.button{
  display:inline-flex; align-items:center; justify-content:center;
  text-decoration:none; border-radius:18px; padding:14px 20px; font-weight:600;
  transition:.18s ease;
}
.button-primary{background:var(--orange); color:#fff; border:none; cursor:pointer}
.button-primary:hover{background:var(--orange-dark)}
.button-secondary{
  background:var(--amber); color:var(--amber-text);
  border:1px solid var(--amber-border);
}
.button-secondary:hover{background:#fde68a}
.card{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow);
}
.hero-side{display:grid; gap:16px; align-content:start}
.small-heading{font-size:14px; font-weight:600; color:#64748b}
.small-heading-dark{color:#cbd5e1}
.feature-card{padding:24px}
.feature-list{margin:16px 0 0; padding-left:18px; color:#334155}
.feature-list li+li{margin-top:10px}
.quick-contact{
  background:var(--dark); color:#fff; border-radius:32px;
  padding:24px; box-shadow:var(--shadow);
}
.quick-contact p{margin:12px 0 0}
.quick-contact a{color:#fff}
.stats{display:grid; gap:16px; margin-top:0}
.stat-card{padding:18px; text-align:center}
.stat-title{font-size:1.8rem; font-weight:700}
.stat-sub{color:#64748b; margin-top:4px; font-size:14px}
.section-head{max-width:44rem}
.section-head p, .contact-lead{color:var(--muted)}
.grid-four, .services-grid{display:grid; gap:16px; margin-top:28px}
.process-card, .service-card{padding:24px}
.service-card{font-weight:600; background:#f8fafc}
.reviews-row{
  display:flex; gap:16px; overflow-x:auto; padding:8px 2px 8px 0; margin-top:28px;
  scroll-snap-type:x proximity;
}
.review-card{
  min-width:280px; max-width:360px; flex:0 0 auto; padding:24px; scroll-snap-align:start;
}
.review-card p{color:#334155}
.stars{color:#d97706; font-size:1.05rem}
.reviewer{margin-top:18px; font-weight:600}
.reviews-button-wrap{margin-top:24px; display:flex; justify-content:center}
.review-links-stack{flex-direction:column; align-items:center; gap:12px}
.review-prompt{font-size:14px; color:var(--muted); text-decoration:underline; text-underline-offset:4px}
.contact-section{background:var(--dark); color:#fff}
.contact-grid{display:grid; gap:40px}
.contact-details p{margin:12px 0 0; color:#e2e8f0}
.contact-details a{color:#fff}
.contact-form{padding:24px; color:var(--text)}
.form-grid{display:grid; gap:16px}
label{display:block; font-size:14px; font-weight:600; margin-bottom:8px}
input, select{
  width:100%; border:1px solid #cbd5e1; border-radius:14px; background:#fff;
  padding:14px 16px; font:inherit; color:var(--text);
}
input:focus, select:focus{
  outline:none; border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(234,88,12,.12);
}
.contact-form form > div + div, .contact-form .form-grid + div{margin-top:16px}
.form-submit{margin-top:20px}
.form-success{
  background:#f0fdf4;
  border:1px solid #86efac;
  color:#14532d;
  border-radius:18px;
  padding:20px;
}
.form-success h3{margin:0 0 8px}
.form-success p{margin:0}
.form-error{
  margin-top:14px;
  color:#991b1b;
  font-size:14px;
}
.hidden{display:none}
.details-card{padding:24px}
details summary{
  cursor:pointer; list-style:none; font-weight:700;
}
.details-content{margin-top:16px; color:var(--muted)}
.details-content p{margin:0 0 16px}
.site-footer{
  background:#fff; border-top:1px solid var(--border);
}
.footer-inner{
  display:flex; flex-direction:column; gap:14px; padding:28px 0;
  color:#64748b; font-size:14px;
}
.footer-links{display:flex; flex-wrap:wrap; gap:16px}
.footer-links a{text-decoration:none}
.footer-links a:hover{color:var(--text)}

@media (min-width: 640px){
  .hero-actions{flex-direction:row; flex-wrap:wrap}
  .stats{grid-template-columns:repeat(3,1fr)}
  .form-grid{grid-template-columns:repeat(2,1fr)}
  .brand-logo{height:48px}
  .review-card{min-width:320px}
  .hero{gap:40px; padding:56px 0 80px}
}
@media (min-width: 900px){
  .desktop-nav{display:flex}
  .mobile-quicklinks{display:none}
  .hero{grid-template-columns:1.02fr .98fr; align-items:start; padding:72px 0 100px}
  .grid-four{grid-template-columns:repeat(4,1fr)}
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:1fr 1.08fr; align-items:start}
  .footer-inner{flex-direction:row; justify-content:space-between; align-items:center}
}
