:root {
  --bg: #f7f5f2;
  --surface: #ffffff;
  --surface-muted: #f3f5f7;
  --text: #1f2a37;
  --muted: #5f6b76;
  --line: #e6e0d8;
  --primary: #1b2a41;
  --primary-2: #24476b;
  --accent: #e57200;
  --accent-hover: #c95f00;
  --warm-soft: #fff1e2;
  --shadow: 0 12px 28px rgba(31, 48, 71, 0.08);
  --radius: 20px;
  --section-space: 6rem;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; min-height: 100vh;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background:
    radial-gradient(circle at top left, rgba(229, 114, 0, 0.08), transparent 22%),
    linear-gradient(180deg, #fbfaf8 0%, #f3f5f7 100%);
  color: var(--text); line-height: 1.65;
}
a { color: inherit; text-decoration: none; }
img { display:block; max-width:100%; }
.site-shell { width: min(1160px, calc(100% - 2rem)); margin: 0 auto; padding: 1.25rem 0 4rem; }
.topbar, .band-card, .feature-card, .process-list article, .review-card, .footer, .split-card, .callout-card, .contact-card, .service-area-card, .check-card, .mini-card {
  background: rgba(255,255,255,0.94); border: 1px solid var(--line); box-shadow: var(--shadow);
}
.topbar {
  display:flex; justify-content:space-between; align-items:center;
  padding:1rem 1.4rem; border-radius:14px; position:sticky; top:1rem; z-index:10;
  backdrop-filter: blur(10px);
}
.brand { font-size:1rem; font-weight:800; letter-spacing:0.04em; color:var(--primary); text-transform:uppercase; }
.nav-links { display:flex; gap:1.25rem; color:var(--muted); font-size:0.95rem; font-weight:600; flex-wrap:wrap; }
.nav-links a:hover { color: var(--primary); }
.hero.small, .hero { padding: 0.5rem 0 2.5rem; }
.hero-grid {
  display:grid; grid-template-columns:1.02fr 0.98fr; gap:2rem; align-items:center; margin-top:1.5rem;
}
.hero-copy { padding:1.25rem 0 0; }
.eyebrow, .card-label {
  display:inline-flex; align-items:center; min-height:36px; padding:0 14px; border-radius:999px;
  background: var(--warm-soft); color: var(--accent); border:1px solid #f4dfc2;
  font-size:0.76rem; font-weight:800; letter-spacing:0.11em; text-transform:uppercase;
}
.card-label { min-height:30px; padding:0 12px; }
h1,h2,h3 { margin:0; color:var(--primary); letter-spacing:-0.02em; }
h1 { margin-top:1rem; max-width:11ch; font-size:clamp(2.6rem, 4.8vw, 4.4rem); line-height:0.99; }
.lede, .section-copy, .feature-card p, .process-list p, .footer-copy, .split-copy p, .band-card p, .review-card p, .contact-card p, .check-card p, .mini-card p, .stats-grid span {
  color:var(--muted); line-height:1.8;
}
.lede {
  margin: 1.25rem 0 0;
  max-width: 55ch; font-size:1.05rem; }
.hero-points { margin:1.5rem 0 0; padding:0; list-style:none; display:grid; gap:0.75rem; }
.hero-points li { position:relative; padding-left:1.45rem; color:var(--text); font-weight:600; }
.hero-points li::before {
  content:""; position:absolute; top:0.58rem; left:0; width:0.52rem; height:0.52rem; border-radius:50%; background:var(--accent);
}
.hero-actions, .footer-actions, .contact-actions, .quick-actions {
  display:flex;
  flex-wrap:wrap;
  gap:1.2rem;
  margin-top:2.2rem;
}
.quick-actions { margin-top:1.25rem; }
.quick-action, .service-badge {
  display:inline-flex; align-items:center; justify-content:center; min-height:2.8rem; padding:0.65rem 1rem; border-radius:999px;
  background:#eef3f8; color:var(--primary-2); border:1px solid rgba(36,71,107,0.12); font-weight:700;
}
.button {
  display:inline-flex; align-items:center; justify-content:center; min-height:3.5rem; padding:1rem 1.6rem;
  border-radius:12px; border:1px solid transparent; cursor:pointer; font-weight:800;
  transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
}
.button:hover { transform: translateY(-1px); }
.button-primary { background:var(--accent); color:#fff; }
.button-primary:hover { background:var(--accent-hover); }
.button-secondary {
  background: #ffffff;
  color: #1b2a41;
  border: 2px solid #1b2a41;
}
.hero-trust { margin-top:1.25rem; max-width:56ch; color:var(--primary); font-weight:700; }
.hero-visual {
  position:relative; overflow:hidden; min-height:460px; border-radius:28px; box-shadow:var(--shadow);
}
.hero-visual img { width:100%; height:100%; object-fit:cover; }
.hero-badge {
  position:absolute; left:18px; bottom:18px; display:inline-flex; align-items:center; min-height:2.5rem; padding:0.5rem 0.9rem;
  border-radius:999px; background:rgba(255,255,255,0.96); color:var(--primary); font-size:0.85rem; font-weight:800; box-shadow:var(--shadow);
}
.section { padding-top:var(--section-space); }
.band-card, .footer, .service-area-card {
  display:flex; justify-content:space-between; align-items:center; gap:1.5rem; padding:2rem; border-radius:22px;
}
.section-heading {
  margin-bottom: 2.5rem; padding-bottom:0.9rem; border-bottom:1px solid var(--line); }
.section h2, .footer h2 { font-size:clamp(2rem, 3.4vw, 3rem); line-height:1.14; max-width:15ch; }
.stats-grid, .feature-grid, .process-list, .reviews-grid, .mini-grid, .contact-grid, .check-grid {
  display:grid; gap:1.25rem;
}
.stats-grid { grid-template-columns:repeat(3,1fr); }
.stats-grid article { padding:1.75rem; border-radius:var(--radius); border-top:4px solid var(--primary-2); }
.stats-grid strong { display:block; margin-bottom:0.55rem; font-size:2rem; line-height:1.1; color:var(--primary-2); }
.feature-grid { grid-template-columns:repeat(4,1fr); }
.feature-card, .review-card, .check-card, .contact-card { padding:1.6rem; border-radius:var(--radius); border-top:4px solid var(--accent); }
.feature-card h3, .process-list h3, .mini-card h3, .split-copy h3, .contact-card h3, .check-card h3 {
  margin-bottom:0.75rem; font-size:1.16rem; line-height:1.3;
}
.process-list.three { grid-template-columns:repeat(3,1fr); }
.process-list.four { grid-template-columns:repeat(4,1fr); }
.process-list article { padding:1.6rem; border-radius:var(--radius); border-top:4px solid var(--primary-2); }
.process-list span {
  display:inline-flex; width:2.55rem; height:2.55rem; margin-bottom:1rem; align-items:center; justify-content:center;
  border-radius:50%; background:var(--accent); color:#ffffff; font-weight:800;
}
.reviews-grid { grid-template-columns:repeat(3,1fr); }
.review-card.featured { background: linear-gradient(180deg, rgba(255,255,255,1), rgba(255,248,239,1)); }
.review-card strong { display:block; margin-top:0.25rem; font-size:1.08rem; line-height:1.45; color:var(--primary); }
.review-card span { display:inline-block; margin-top:1rem; color:var(--primary); font-size:0.92rem; font-weight:800; }
.stars { color:var(--accent); letter-spacing:2px; font-size:1rem; margin-bottom:0.35rem; }
.split-card { display:grid; grid-template-columns:1fr 1fr; border-radius:24px; overflow:hidden; }
.split-copy { padding:2rem; }
.split-copy h2 { margin:1rem 0 0.85rem; max-width:14ch; }
.split-image { min-height:340px; }
.split-image img { width:100%; height:100%; object-fit:cover; }
.mini-grid { grid-template-columns:1fr 1fr; margin-top:1.5rem; }
.mini-card { padding:1.1rem 1rem; border-radius:16px; background:var(--surface-muted); }
.contact-grid { grid-template-columns:1.1fr 1fr 1fr; }
.contact-card.primary { border-top:4px solid var(--accent); }
.contact-card h3 { margin-top:0.9rem; font-size:1.25rem; line-height:1.25; word-break:break-word; }
.callout-card { padding:2rem; border-radius:24px; border-top:4px solid var(--primary-2); }
.callout-card h2 { margin-top:1rem; max-width:12ch; font-size:clamp(1.8rem, 3vw, 2.4rem); line-height:1.1; }
.check-grid { grid-template-columns:repeat(2,1fr); }
.footer {
  margin:0 0 1rem; background:linear-gradient(135deg, var(--primary-2) 0%, var(--primary) 100%); color:#ffffff; border-color:transparent;
}
.footer .eyebrow { background:rgba(255,255,255,0.14); border-color:rgba(255,255,255,0.15); color:#ffffff; }
.footer h2, .footer .footer-copy { color:#ffffff; }
.footer-secondary { background:transparent; color:#ffffff; border-color:rgba(255,255,255,0.22); }
@media (max-width: 980px) {
  .hero-grid, .feature-grid, .process-list.three, .process-list.four, .split-card, .mini-grid, .reviews-grid, .contact-grid, .check-grid, .stats-grid {
    grid-template-columns:1fr;
  }
  .band-card, .footer, .service-area-card { flex-direction:column; align-items:flex-start; }
  .hero-visual { min-height:360px; }
}
@media (max-width: 760px) { .nav-links { display:none; } }
@media (max-width: 640px) {
  .site-shell { width:min(100% - 1rem, 1160px); }
  .hero-actions, .button, .footer-actions, .contact-actions, .quick-actions { width:100%; }
}


.mobile-sticky-bar {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 50;
  display: none;
  gap: 10px;
  padding: 10px;
  border-radius: 18px;
  background: rgba(255,255,255,0.96);
  border: 1px solid var(--line);
  box-shadow: 0 18px 40px rgba(24,37,56,0.14);
  backdrop-filter: blur(10px);
}
.mobile-sticky-bar .button {
  flex: 1;
  min-height: 46px;
  box-shadow: none;
  padding: 0.85rem 1rem;
}
@media (max-width: 760px) {
  .mobile-sticky-bar { display: flex; }
  body { padding-bottom: 92px; }
}


.button-secondary:hover {
  background: #1b2a41;
  color: #ffffff;
}


.social-intro {
  margin: 1.2rem 0 0.6rem;
  color: rgba(255,255,255,0.86);
  line-height: 1.6;
}
.social-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
  margin-top: 0.2rem;
}
.social-links a {
  color: #ffffff;
  font-weight: 700;
  text-decoration: none;
}
.social-links a:hover {
  text-decoration: underline;
}
@media (max-width: 640px) {
  .section {
    padding-top: 4rem;
  }
  .hero-actions {
    gap: 1rem;
  }
}
