
:root {
  --accent: #c9242f;
  --accent-dark: #8c1620;
  --ink: #111111;
  --charcoal: #1f2225;
  --sand: #f4efe7;
  --mist: #f6f8f7;
  --gold: #d8a83f;
  --max: 1160px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Arial, Helvetica, sans-serif; color: var(--ink); background: #fff; line-height: 1.55; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.site-header { position: fixed; top: 14px; left: 0; right: 0; z-index: 50; display: flex; justify-content: center; padding: 0 16px; pointer-events: none; }
.nav-pill { width: fit-content; max-width: calc(100vw - 32px); margin: 0 auto; display: inline-flex; align-items: center; gap: 22px; padding: 9px 10px 9px 14px; border-radius: 999px; background: rgba(255,255,255,.9); box-shadow: 0 20px 60px rgba(0,0,0,.18); backdrop-filter: blur(18px); pointer-events: auto; }
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: 0; font-weight: 900; text-transform: uppercase; font-size: 13px; letter-spacing: 0; }
.brand img { width: 42px; height: 42px; border-radius: 8px; }
.brand span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 182px; }
.desktop-nav { display: none; align-items: center; gap: 18px; font-size: 14px; font-weight: 750; }
.desktop-nav a { padding: 8px 0; }
.nav-cta, .btn { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 0 18px; border-radius: 6px; font-weight: 850; border: 1px solid transparent; cursor: pointer; }
.nav-cta { background: var(--accent); color: #fff; white-space: nowrap; }
.mobile-menu-toggle { display: inline-flex; width: 44px; height: 44px; border: 0; border-radius: 8px; background: var(--ink); align-items: center; justify-content: center; flex-direction: column; gap: 5px; }
.mobile-menu-toggle span { display: block; width: 19px; height: 2px; background: #fff; }
.mobile-panel { position: fixed; top: 74px; left: 16px; right: 16px; display: none; flex-direction: column; gap: 6px; padding: 14px; border-radius: 8px; background: #fff; box-shadow: 0 22px 60px rgba(0,0,0,.24); z-index: 45; }
.mobile-panel.open { display: flex; }
.mobile-panel a { padding: 13px 12px; border-radius: 6px; font-weight: 800; background: var(--mist); }
.mobile-panel .mobile-primary { background: var(--accent); color: #fff; text-align: center; }
.hero { min-height: 92vh; display: grid; align-items: stretch; position: relative; overflow: hidden; background: var(--ink); color: #fff; }
.hero-media { position: absolute; inset: 0; }
.hero-picture, .hero-picture img { width: 100%; height: 100%; object-fit: cover; }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.84), rgba(0,0,0,.46) 48%, rgba(0,0,0,.12)); }
.hero-content { position: relative; z-index: 1; width: min(var(--max), calc(100% - 32px)); margin: 0 auto; padding: 176px 0 76px; align-self: center; }
.eyebrow { margin: 0 0 12px; color: var(--accent); text-transform: uppercase; font-size: 12px; font-weight: 900; letter-spacing: 0; }
.hero .eyebrow, .owner-band .eyebrow, .services-band .eyebrow { color: var(--gold); }
h1, h2, h3, p { margin-top: 0; }
h1 { max-width: 800px; margin-bottom: 18px; font-size: clamp(44px, 8vw, 92px); line-height: .92; letter-spacing: 0; text-transform: uppercase; }
h2 { font-size: clamp(28px, 4vw, 52px); line-height: 1; letter-spacing: 0; margin-bottom: 16px; }
.hero p { max-width: 620px; font-size: 20px; }
.hero-actions, .button-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-outline { color: #fff; border-color: rgba(255,255,255,.55); background: rgba(255,255,255,.08); }
.btn-dark { background: var(--ink); color: #fff; }
.btn-light { background: #fff; color: var(--ink); }
.proof-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.proof-row span { border: 1px solid rgba(255,255,255,.28); border-radius: 999px; padding: 8px 13px; font-size: 13px; font-weight: 800; }
section { padding: 90px 20px; }
.intro-grid, .contact-split, .page-hero.split { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 36px; align-items: center; }
.intro-grid { background: #fff; }
.rounded-img img, .page-img img { border-radius: 8px; aspect-ratio: 4 / 3; object-fit: cover; }
.check-list { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 10px; }
.check-list li { padding-left: 28px; position: relative; font-weight: 760; }
.check-list li::before { content: ""; position: absolute; left: 0; top: .45em; width: 11px; height: 11px; border-radius: 50%; background: var(--accent); }
.services-band { background: var(--charcoal); color: #fff; }
.section-head { width: min(var(--max), calc(100% - 32px)); margin: 0 auto 34px; display: grid; gap: 8px; }
.section-head p { max-width: 680px; color: rgba(255,255,255,.74); }
.service-grid, .services-detail { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 16px; }
.service-card { border: 1px solid rgba(255,255,255,.13); border-radius: 8px; padding: 26px; background: rgba(255,255,255,.055); min-height: 260px; display: flex; flex-direction: column; align-items: flex-start; }
.services-detail .service-card { background: var(--mist); color: var(--ink); border-color: #dfe4e1; }
.service-card span { color: var(--gold); font-weight: 900; text-transform: uppercase; font-size: 12px; }
.service-card h2 { font-size: 28px; margin-top: 10px; }
.service-card p { color: inherit; opacity: .8; }
.text-link { margin-top: auto; font-weight: 900; color: var(--accent); }
.owner-band { background: var(--accent-dark); color: #fff; display: grid; grid-template-columns: 1fr; gap: 28px; align-items: center; }
.owner-band > * { width: min(var(--max), calc(100% - 32px)); margin-left: auto; margin-right: auto; }
.owner-band.compact { grid-template-columns: 1fr; }
.stat-stack { display: grid; grid-template-columns: 1fr; gap: 12px; }
.stat-stack span { display: grid; gap: 4px; padding: 18px; background: rgba(255,255,255,.10); border-radius: 8px; }
.stat-stack strong { font-size: 30px; line-height: 1; color: var(--gold); }
.contact-split { padding-top: 0; }
.lead-form { display: grid; grid-template-columns: 1fr; gap: 14px; padding: 20px; border-radius: 8px; background: var(--mist); border: 1px solid #dfe4e1; }
.lead-form.large { padding: 0; border: 0; background: transparent; }
.field { display: grid; gap: 6px; }
label { font-weight: 850; font-size: 13px; }
input, textarea, select { width: 100%; border: 1px solid #cfd6d2; border-radius: 6px; padding: 13px 12px; min-height: 46px; font: inherit; background: #fff; color: var(--ink); }
textarea { resize: vertical; }
.page-hero { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; padding-top: 150px; }
.page-hero h1 { color: var(--ink); font-size: clamp(40px, 7vw, 78px); }
.page-hero p { max-width: 740px; font-size: 19px; }
.page-hero .btn-outline { color: var(--ink); border-color: #cfd6d2; background: #fff; }
.address-card { margin-top: 24px; border-left: 6px solid var(--accent); padding: 16px 0 16px 18px; display: grid; gap: 5px; background: var(--mist); }
.content-grid { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 18px; padding-top: 0; }
.content-grid article, .content-grid aside, .form-panel { border-radius: 8px; background: var(--mist); padding: 26px; border: 1px solid #dfe4e1; }
.faq-strip { background: var(--sand); }
.faq-strip h2, .faq-list.full { width: min(var(--max), calc(100% - 32px)); margin-left: auto; margin-right: auto; }
.faq-list { display: grid; gap: 10px; }
.faq-list.full { padding-top: 0; }
details { border: 1px solid #d9dedb; border-radius: 8px; padding: 16px 18px; background: #fff; }
summary { cursor: pointer; font-weight: 900; }
details p { margin: 12px 0 0; }
.site-footer { background: var(--ink); color: #fff; padding: 58px 20px 92px; }
.footer-inner { width: min(var(--max), calc(100% - 32px)); margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 28px; }
.footer-brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 900; text-transform: uppercase; }
.footer-brand img { border-radius: 8px; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.site-footer h2 { font-size: 15px; text-transform: uppercase; color: var(--gold); }
.site-footer p, .site-footer a, .footer-bottom { color: rgba(255,255,255,.76); }
.site-footer .btn-light { color: var(--ink); }
.footer-credit a { color: #fff; text-decoration: underline; }
.footer-bottom { width: min(var(--max), calc(100% - 32px)); margin: 38px auto 0; font-size: 13px; }
.sticky-cta { position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; display: grid; grid-template-columns: 1fr 1fr; min-height: 58px; }
.sticky-cta a { display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 900; }
.sticky-cta .call-half { background: var(--accent); }
.sticky-cta .msg-half { background: #0a0a0a; }
.page-contact .sticky-cta { display: none; }
@media (min-width: 720px) {
  .brand span { max-width: none; }
  .lead-form { grid-template-columns: 1fr 1fr; }
  .field.full, .lead-form button { grid-column: 1 / -1; }
  .service-grid, .services-detail { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .stat-stack { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .footer-inner { grid-template-columns: 1.45fr .7fr .9fr 1fr; }
}
@media (min-width: 1024px) {
  .mobile-menu-toggle { display: none !important; }
  .desktop-nav { display: flex; }
  .mobile-panel { display: none !important; }
  .intro-grid, .contact-split, .page-hero.split { grid-template-columns: 1fr 1fr; }
  .content-grid { grid-template-columns: 1.25fr .75fr; }
  .owner-band { grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr); padding-left: calc((100vw - min(var(--max), calc(100vw - 32px))) / 2); padding-right: calc((100vw - min(var(--max), calc(100vw - 32px))) / 2); }
  .owner-band > * { width: auto; }
  .sticky-cta { display: none; }
}
@media (max-width: 460px) {
  .nav-pill { gap: 8px; }
  .nav-cta { display: none; }
  .brand span { max-width: 145px; font-size: 12px; }
  h1 { font-size: 42px; }
  section { padding-left: 16px; padding-right: 16px; }
  .hero-content { width: calc(100% - 32px); }
}
