/* Reset & Base */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: Arial, Helvetica, sans-serif; color: #1a1a1a; background: #fff; line-height: 1.65; font-size: 16px; }
a { color: #e8610a; text-decoration: none; }
a:hover { text-decoration: underline; }
ul { padding-left: 20px; }
img { max-width: 100%; height: auto; display: block; }

/* Layout */
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }

/* ─── Header ─── */
.site-header { background: #1a2e4a; padding: 14px 0; }
.header-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.header-phone { font-size: 1.2rem; font-weight: bold; }
.header-phone a { color: #fff; }
.header-phone a:hover { color: #e8610a; text-decoration: none; }
.site-nav { display: flex; gap: 24px; flex-wrap: wrap; }
.site-nav a { color: #d4dde8; font-size: 0.95rem; font-weight: 600; letter-spacing: 0.03em; }
.site-nav a:hover { color: #e8610a; text-decoration: none; }

/* ─── Hero ─── */
.hero { background: #f0f4f9; padding: 56px 0 48px; }
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: start; }
.hero-text h1 { font-size: 2rem; color: #1a2e4a; line-height: 1.2; margin-bottom: 14px; }
.hero-phone { font-size: 1.6rem; font-weight: bold; color: #e8610a; display: block; margin-bottom: 20px; }
.hero-phone:hover { text-decoration: none; }
.hero-bullets { list-style: none; padding: 0; margin-bottom: 22px; }
.hero-bullets li { padding: 5px 0 5px 26px; position: relative; }
.hero-bullets li::before { content: "✓"; position: absolute; left: 0; color: #e8610a; font-weight: bold; font-size: 1.05rem; }
.hero-tagline { color: #555; font-size: 0.95rem; }

/* ─── Lead Form ─── */
.lead-form { background: #fff; border: 2px solid #1a2e4a; border-radius: 6px; padding: 28px; }
.lead-form h2 { font-size: 1.15rem; color: #1a2e4a; margin-bottom: 18px; font-weight: bold; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-group { margin-bottom: 13px; }
.form-group label { display: block; font-size: 0.83rem; font-weight: 700; color: #333; margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.04em; }
.form-group input,
.form-group textarea,
.form-group select { width: 100%; padding: 10px 12px; border: 1px solid #bbb; border-radius: 4px; font-size: 0.95rem; font-family: inherit; color: #1a1a1a; background: #fff; }
.form-group input:focus,
.form-group textarea:focus { outline: 2px solid #1a2e4a; border-color: #1a2e4a; }
.form-group textarea { height: 86px; resize: vertical; }

/* ─── Buttons ─── */
.btn { display: inline-block; background: #e8610a; color: #fff; padding: 14px 28px; border: none; border-radius: 4px; font-size: 1rem; font-weight: bold; cursor: pointer; width: 100%; text-align: center; font-family: inherit; transition: background 0.15s; }
.btn:hover { background: #c9520a; color: #fff; text-decoration: none; }
.btn-secondary { background: #1a2e4a; }
.btn-secondary:hover { background: #142340; }
.btn-outline { background: transparent; border: 2px solid #e8610a; color: #e8610a; }
.btn-outline:hover { background: #e8610a; color: #fff; }
.btn-sm { padding: 10px 20px; font-size: 0.9rem; width: auto; }

/* ─── Trust Bar ─── */
.trust-bar { background: #1a2e4a; color: #d4dde8; padding: 14px 0; text-align: center; font-size: 0.95rem; font-weight: 600; letter-spacing: 0.02em; }

/* ─── Sections ─── */
.section { padding: 52px 0; }
.section-alt { background: #f0f4f9; }
.section-sm { padding: 36px 0; }
.section h2 { font-size: 1.65rem; color: #1a2e4a; margin-bottom: 14px; }
.section h3 { font-size: 1.15rem; color: #1a2e4a; margin-bottom: 10px; }
.section p { margin-bottom: 14px; }
.section p:last-child { margin-bottom: 0; }
.section-intro { max-width: 720px; margin-bottom: 32px; }

/* ─── Service Cards ─── */
.service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; margin-top: 28px; }
.service-card { border: 1px solid #dde3ec; border-radius: 6px; padding: 26px; }
.service-card h2 { font-size: 1.15rem; color: #1a2e4a; margin-bottom: 10px; }
.service-card p { font-size: 0.95rem; margin-bottom: 10px; }
.service-card .price-note { font-size: 0.88rem; color: #555; font-style: italic; margin-bottom: 14px; }
.service-card a { font-size: 0.9rem; font-weight: bold; }

/* ─── FAQ ─── */
.faq-list { margin-top: 28px; }
.faq-item { border-bottom: 1px solid #dde3ec; padding: 22px 0; }
.faq-item:first-child { padding-top: 0; }
.faq-item h2 { font-size: 1.05rem; color: #1a2e4a; margin-bottom: 10px; font-weight: 700; }
.faq-item p { font-size: 0.95rem; }

/* ─── Pricing Table ─── */
.price-table { width: 100%; border-collapse: collapse; margin: 28px 0; }
.price-table th,
.price-table td { padding: 13px 16px; text-align: left; border-bottom: 1px solid #dde3ec; font-size: 0.95rem; }
.price-table th { background: #1a2e4a; color: #fff; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.04em; }
.price-table tr:nth-child(even) td { background: #f7f9fc; }
.price-table td:last-child { color: #e8610a; font-weight: bold; }
.price-note-disclaimer { font-size: 0.88rem; color: #666; font-style: italic; margin-top: 8px; }

/* ─── Factors List ─── */
.factors-list { list-style: none; padding: 0; margin: 16px 0; }
.factors-list li { padding: 7px 0 7px 24px; position: relative; border-bottom: 1px solid #eee; }
.factors-list li:last-child { border-bottom: none; }
.factors-list li::before { content: "→"; position: absolute; left: 0; color: #e8610a; }

/* ─── CTA Section ─── */
.cta-section { background: #1a2e4a; color: #fff; padding: 54px 0; text-align: center; }
.cta-section h2 { color: #fff; font-size: 1.8rem; margin-bottom: 12px; }
.cta-section p { color: #d4dde8; margin-bottom: 28px; max-width: 560px; margin-left: auto; margin-right: auto; }
.cta-phone { font-size: 2.2rem; font-weight: bold; color: #e8610a; display: block; margin-bottom: 20px; }
.cta-phone:hover { text-decoration: none; color: #ff7a2a; }

/* ─── Towns ─── */
.towns-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; margin-top: 28px; }
.town-card { padding: 22px; border-left: 4px solid #e8610a; background: #fff; }
.town-card h2 { font-size: 1.05rem; color: #1a2e4a; margin-bottom: 8px; }
.town-card p { font-size: 0.93rem; margin-bottom: 10px; }
.town-card a { font-size: 0.88rem; font-weight: bold; }

/* ─── Contact Page ─── */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.contact-info h2 { font-size: 1.4rem; color: #1a2e4a; margin-bottom: 14px; }
.contact-phone-large { font-size: 2rem; font-weight: bold; color: #e8610a; display: block; margin-bottom: 24px; }
.contact-phone-large:hover { text-decoration: none; }
.hours-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.hours-table td { padding: 8px 0; font-size: 0.93rem; vertical-align: top; }
.hours-table td:first-child { font-weight: 600; color: #1a2e4a; width: 130px; }

/* ─── About Page ─── */
.about-lead { font-size: 1.1rem; color: #333; margin-bottom: 24px; }

/* ─── Thank You / Confirmation ─── */
.thankyou-section { text-align: center; padding: 90px 0; }
.thankyou-section h1 { font-size: 2rem; color: #1a2e4a; margin-bottom: 14px; }
.thankyou-section p { font-size: 1.05rem; color: #555; margin-bottom: 18px; }
.thankyou-phone { font-size: 1.5rem; font-weight: bold; color: #e8610a; display: inline-block; margin: 12px 0; }

/* ─── Privacy / Legal ─── */
.legal-content h2 { font-size: 1.2rem; color: #1a2e4a; margin: 28px 0 10px; }
.legal-content p,
.legal-content li { font-size: 0.93rem; margin-bottom: 10px; }
.legal-content ul { margin-bottom: 14px; }

/* ─── Footer ─── */
.site-footer { background: #111; color: #bbb; padding: 32px 0; font-size: 0.88rem; }
.footer-inner { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 20px; }
.footer-phone { font-size: 1.05rem; font-weight: bold; margin-bottom: 6px; }
.footer-phone a { color: #e8610a; }
.footer-phone a:hover { text-decoration: none; color: #ff7a2a; }
.footer-disclaimer { max-width: 460px; font-size: 0.8rem; color: #888; line-height: 1.5; }
.footer-links a { color: #bbb; margin-left: 0; display: inline-block; }
.footer-links a:hover { color: #e8610a; text-decoration: none; }

/* ─── Responsive ─── */
@media (max-width: 768px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-text h1 { font-size: 1.55rem; }
  .hero-phone { font-size: 1.3rem; }
  .form-row { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .header-inner { flex-direction: column; align-items: flex-start; gap: 10px; }
  .site-nav { gap: 14px; }
  .cta-section h2 { font-size: 1.4rem; }
  .cta-phone { font-size: 1.6rem; }
  .contact-phone-large { font-size: 1.5rem; }
  .price-table th,
  .price-table td { padding: 10px 10px; font-size: 0.88rem; }
}

@media (max-width: 480px) {
  .section { padding: 38px 0; }
  .hero { padding: 36px 0 32px; }
  .lead-form { padding: 20px; }
  .site-nav { gap: 10px; }
  .site-nav a { font-size: 0.88rem; }
}

/* ─── Form Consent Notice ─── */
.form-consent { font-size: .78rem; color: rgba(0,0,0,.5); margin: .5rem 0 .4rem; line-height: 1.45; }
.form-consent a { color: #1a2e4a; text-decoration: underline; }

/* ─── Mobile Floating Call Button ─── */
.mobile-call-btn {
  display: none;
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 999;
  background: #e8610a;
  color: #fff;
  font-size: 1.1rem;
  font-weight: bold;
  padding: 14px 32px;
  border-radius: 50px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: 0.02em;
}
.mobile-call-btn:hover { background: #cf5409; color: #fff; text-decoration: none; }

@media (max-width: 768px) {
  .mobile-call-btn { display: block; }
}
