/* ============================================================
   ACTION PLUMBING, HEATING & AIR — Custom CSS
   Colors: Navy #1B2F5E | Red #C41230 | Gold #F5A623
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy: #1B2F5E;
  --navy-dark: #0f1e3d;
  --red: #C41230;
  --red-dark: #a00e27;
  --gold: #F5A623;
  --white: #ffffff;
  --light: #f7f8fa;
  --gray: #6b7280;
  --dark: #1a1a1a;
  --radius: 8px;
  --shadow: 0 2px 16px rgba(0,0,0,0.10);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.16);
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Roboto', system-ui, sans-serif;
  color: var(--dark);
  line-height: 1.6;
  overflow-x: hidden;
}

body.nav-open .mobile-nav { transform: translateX(0); }
body.nav-open .nav-toggle span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
body.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
body.nav-open .nav-toggle span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

h1,h2,h3,h4 { font-family: 'Oswald', system-ui, sans-serif; line-height: 1.2; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.container { max-width: 1180px; margin: 0 auto; padding: 0 20px; }
.section-header { text-align: center; margin-bottom: 3rem; }
.section-header h2 { font-size: clamp(1.8rem, 3vw, 2.6rem); color: var(--navy); margin-bottom: .75rem; }
.section-header p { font-size: 1.05rem; color: var(--gray); max-width: 600px; margin: 0 auto; }

/* BUTTONS */
.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--red); color: var(--white);
  padding: 14px 28px; border-radius: var(--radius);
  font-weight: 700; font-size: 1rem; font-family: 'Oswald', sans-serif;
  letter-spacing: .03em; transition: background .2s, transform .1s;
  border: none; cursor: pointer;
}
.btn-primary:hover { background: var(--red-dark); transform: translateY(-1px); }
.btn-primary.btn-large { padding: 18px 36px; font-size: 1.15rem; }

.btn-secondary {
  display: inline-flex; align-items: center;
  background: transparent; color: var(--white);
  padding: 13px 28px; border-radius: var(--radius);
  font-weight: 700; font-size: 1rem; font-family: 'Oswald', sans-serif;
  border: 2px solid rgba(255,255,255,0.7); transition: all .2s;
}
.btn-secondary:hover { background: rgba(255,255,255,0.15); border-color: white; }

.btn-emergency {
  display: inline-flex; align-items: center;
  background: var(--white); color: var(--red);
  padding: 16px 32px; border-radius: var(--radius);
  font-weight: 700; font-size: 1.1rem; font-family: 'Oswald', sans-serif;
  white-space: nowrap; transition: all .2s; border: none; cursor: pointer;
}
.btn-emergency:hover { background: var(--gold); color: var(--dark); }

.btn-outline {
  display: inline-flex; align-items: center;
  background: transparent; color: var(--navy);
  padding: 12px 24px; border-radius: var(--radius);
  font-weight: 700; font-family: 'Oswald', sans-serif;
  border: 2px solid var(--navy); transition: all .2s;
}
.btn-outline:hover { background: var(--navy); color: white; }

.btn-outline-sm {
  display: inline-block;
  background: transparent; color: var(--white);
  padding: 10px 20px; border-radius: var(--radius);
  font-weight: 600; font-size: .9rem;
  border: 2px solid rgba(255,255,255,0.5); transition: all .2s; margin-top: 12px;
}
.btn-outline-sm:hover { background: var(--white); color: var(--navy); }

.btn-submit {
  width: 100%; background: var(--red); color: white;
  padding: 16px; border: none; border-radius: var(--radius);
  font-size: 1.1rem; font-weight: 700; font-family: 'Oswald', sans-serif;
  cursor: pointer; transition: background .2s; letter-spacing: .03em;
}
.btn-submit:hover { background: var(--red-dark); }

/* ANNOUNCE BAR */
.announce-bar {
  background: var(--navy-dark); color: var(--white);
  padding: 8px 0; font-size: .84rem;
}
.announce-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 20px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.announce-left { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.announce-addr { opacity:.85; }
.announce-div { opacity:.3; }
@media (max-width:600px) { .announce-addr { display:none; } .announce-bar { justify-content:center; } }
.announce-cta {
  background: var(--gold); color: var(--dark);
  padding: 4px 14px; border-radius: 20px; font-weight: 700; font-size: .85rem;
  transition: opacity .2s;
}
.announce-cta:hover { opacity: .85; }

/* HEADER */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--white);
  border-bottom: 3px solid var(--red);
  transition: box-shadow .2s;
}
.site-header.scrolled { box-shadow: 0 2px 20px rgba(0,0,0,0.15); }

.header-inner {
  max-width: 1180px; margin: 0 auto; padding: 0 20px;
  display: flex; align-items: center; gap: 24px; height: 68px;
}

.logo-wrap { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.site-logo { height: 52px; width: auto; display: block; }

.main-nav { display: flex; gap: 4px; margin: 0 auto; }
.main-nav a { padding: 8px 12px; font-weight: 500; font-size: .9rem; color: var(--dark); border-radius: 4px; transition: all .2s; white-space: nowrap; }
.main-nav a:hover { color: var(--red); background: #fef2f2; }

.btn-call {
  display: flex; align-items: center; gap: 8px;
  background: var(--red); color: var(--white);
  padding: 10px 18px; border-radius: var(--radius);
  font-weight: 700; font-size: .95rem; white-space: nowrap;
  transition: background .2s; flex-shrink: 0;
}
.btn-call:hover { background: var(--red-dark); }

.nav-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--dark); transition: all .3s; }

/* MOBILE NAV */
.mobile-nav {
  position: fixed; top: 0; right: 0; width: 280px; height: 100vh;
  background: var(--navy-dark); z-index: 200;
  display: flex; flex-direction: column; padding: 80px 24px 24px;
  transform: translateX(100%); transition: transform .3s ease;
}
.mobile-nav a { color: white; font-size: 1.05rem; font-weight: 500; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.08); }
.mob-call { background: var(--red); border-radius: var(--radius); padding: 14px 20px !important; text-align: center; border: none !important; margin-bottom: 8px; font-weight: 700 !important; }

/* HERO */
.hero {
  position: relative; min-height: 88vh;
  display: flex; align-items: center;
  background: var(--navy-dark); overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  background-image: url('/img/hero-slider1.jpg');
  background-size: cover; background-position: center center;
  filter: brightness(0.55);
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(27,47,94,0.72) 30%, rgba(10,18,45,0.93) 100%);
}
.hero-content {
  position: relative; z-index: 2;
  max-width: 800px; margin: 0 auto; padding: 60px 20px;
  text-align: center;
}
.hero-badges { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 1.5rem; }
.badge-pill {
  background: rgba(245,166,35,0.15); color: var(--gold);
  border: 1px solid rgba(245,166,35,0.35);
  padding: 6px 16px; border-radius: 20px; font-size: .85rem; font-weight: 600;
}
.hero h1 {
  font-size: clamp(2.4rem, 5.5vw, 4.2rem); color: var(--white);
  margin-bottom: 1.25rem; text-shadow: 0 3px 30px rgba(0,0,0,0.5);
  line-height: 1.1;
}
.hero-accent { display:block; width:60px; height:4px; background:var(--red); margin:0 auto 1.2rem; border-radius:2px; }
.hero-sub { font-size: 1.1rem; color: rgba(255,255,255,0.82); margin-bottom: 2.5rem; max-width: 580px; margin-left: auto; margin-right: auto; }
.hero-ctas { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-bottom: 3rem; }

.hero-trust {
  display: flex; align-items: center; justify-content: center; gap: 0;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius); padding: 20px; flex-wrap: wrap; gap: 4px;
}
.trust-item { display: flex; flex-direction: column; align-items: center; padding: 0 28px; }
.trust-item strong { font-size: 1.6rem; font-family: 'Oswald', sans-serif; color: var(--gold); }
.trust-item span { font-size: .78rem; color: rgba(255,255,255,0.65); text-align: center; margin-top: 2px; }
.trust-div { width: 1px; height: 40px; background: rgba(255,255,255,0.2); }

/* SERVICE PILLARS */
.services-bar { padding: 60px 0; background: var(--light); }
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.pillar {
  background: var(--white); border-radius: 12px;
  padding: 36px 28px; text-align: center;
  box-shadow: var(--shadow); transition: all .3s;
  border-top: 4px solid transparent; display: block;
  padding-top: 0; overflow: hidden;
}
.pillar:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-top-color: var(--red); }
.pillar-accent { border-top-color: var(--red); }
.pillar-img { width: calc(100% + 56px); height: 180px; overflow: hidden; border-radius: 8px 8px 0 0; margin: 0 -28px 24px; }
.pillar-img img { width: 100%; height: 100%; object-fit: cover; }
.pillar h3 { font-size: 1.5rem; color: var(--navy); margin-bottom: 10px; }
.pillar p { color: var(--gray); font-size: .95rem; margin-bottom: 16px; }
.pillar-link { color: var(--red); font-weight: 600; font-size: .9rem; }

/* EMERGENCY BAND */
.emergency-band { background: var(--red); padding: 40px 0; }
.emerg-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.emerg-text h2 { font-size: clamp(1.4rem, 2.5vw, 2rem); color: var(--white); margin-bottom: 8px; }
.emerg-text p { color: rgba(255,255,255,0.85); font-size: .95rem; }

/* WHY SECTION */
.why-section { padding: 80px 0; background: var(--white); }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.why-card {
  background: var(--light); border-radius: 12px; padding: 32px 24px;
  border-left: 4px solid var(--gold); transition: transform .2s;
}
.why-card:hover { transform: translateY(-3px); }
.why-icon { margin-bottom: 12px; color: var(--gold); }
.why-icon svg { stroke: var(--gold); }
.why-card h3 { font-size: 1.1rem; color: var(--navy); margin-bottom: 10px; }
.why-card p { color: var(--gray); font-size: .93rem; }

/* SERVICES DETAIL */
.services-detail { padding: 80px 0; background: var(--navy); }
.services-detail .section-header h2 { color: var(--white); }
.services-detail .section-header p { color: rgba(255,255,255,0.65); }
.services-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.services-col h3 { font-size: 1.3rem; color: var(--gold); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.services-col ul { list-style: none; }
.services-col ul li { border-bottom: 1px solid rgba(255,255,255,0.06); }
.services-col ul li a { display: block; padding: 10px 0; color: rgba(255,255,255,0.82); font-size: .95rem; transition: color .2s, padding .2s; }
.services-col ul li a:hover { color: var(--gold); padding-left: 8px; }

/* SERVICE AREAS */
.areas-section { padding: 80px 0; background: var(--light); }
.areas-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.area-card {
  background: var(--white); border-radius: var(--radius); padding: 20px 12px;
  text-align: center; font-weight: 600; color: var(--navy);
  box-shadow: var(--shadow); transition: all .2s;
  display: flex; flex-direction: column; gap: 4px; font-size: .95rem;
}
.area-card:hover { background: var(--navy); color: white; transform: translateY(-2px); }
.area-card span { font-size: .72rem; color: var(--gold); font-weight: 500; }
.area-primary { background: var(--navy); color: white; }
.area-primary span { color: var(--gold); }
.area-more { background: var(--red); color: white; }
.area-more:hover { background: var(--red-dark); color: white; }

/* REVIEWS */
.reviews-section { padding: 80px 0; background: var(--white); }
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 2.5rem; }
.review-card {
  background: var(--light); border-radius: 12px; padding: 28px 24px;
  box-shadow: var(--shadow); position: relative;
}
.review-card::before { content: '"'; font-size: 4rem; color: var(--gold); opacity: .3; position: absolute; top: 8px; left: 16px; font-family: Georgia, serif; line-height: 1; }
.stars { color: #f59e0b; font-size: 1.1rem; margin-bottom: 12px; }
.review-card p { color: #444; font-size: .95rem; line-height: 1.65; margin-bottom: 16px; }
.reviewer { font-weight: 600; color: var(--navy); font-size: .88rem; }
.reviews-cta { text-align: center; }

/* CONTACT */
.contact-section { padding: 80px 0; background: var(--navy-dark); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
.contact-info h2 { font-size: 2.2rem; color: var(--white); margin-bottom: 1rem; }
.contact-info > p { color: rgba(255,255,255,0.75); margin-bottom: 2rem; font-size: 1rem; }
.contact-details { margin-top: 2rem; display: flex; flex-direction: column; gap: 10px; }
.contact-detail { color: rgba(255,255,255,0.78); font-size: .95rem; }
.contact-detail strong { color: var(--gold); }

.contact-form-wrap { background: white; border-radius: 12px; padding: 36px; box-shadow: var(--shadow-lg); }
.form-row { margin-bottom: 14px; }
.form-row input, .form-row select, .form-row textarea {
  width: 100%; padding: 13px 16px; border: 2px solid #e5e7eb;
  border-radius: var(--radius); font-size: 1rem; font-family: inherit;
  transition: border-color .2s; background: white;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus {
  outline: none; border-color: var(--navy);
}
.form-note { font-size: .8rem; color: var(--gray); text-align: center; margin-top: 10px; }

/* FOOTER */
.site-footer { background: var(--navy-dark); border-top: 3px solid var(--red); padding: 60px 0 0; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.footer-brand p { color: rgba(255,255,255,0.6); font-size: .9rem; margin: 12px 0 10px; }
.footer-license { color: rgba(255,255,255,0.4); font-size: .78rem; }
.footer-logo-img { display: block; }
.footer-col h4 { color: var(--gold); font-size: .85rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 16px; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.footer-col ul li a { color: rgba(255,255,255,0.65); font-size: .9rem; transition: color .2s; }
.footer-col ul li a:hover { color: var(--white); }
.footer-phone { display: block; font-size: 1.4rem; font-family: 'Oswald', sans-serif; color: var(--white); font-weight: 700; margin-bottom: 10px; }
.footer-col p { color: rgba(255,255,255,0.6); font-size: .9rem; line-height: 1.7; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding: 20px 0; text-align: center; }
.footer-bottom p { color: rgba(255,255,255,0.4); font-size: .82rem; }

/* STICKY CALL BAR (mobile only) */
.sticky-call-bar {
  display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 150;
  background: var(--red); padding: 0;
}
.sticky-call-bar a {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  color: white; font-weight: 700; font-size: 1.1rem; font-family: 'Oswald', sans-serif;
  padding: 16px; width: 100%;
}


/* FLEET SECTION */
.fleet-section { padding: 80px 0; background: var(--white); }
.fleet-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.fleet-images { display: flex; flex-direction: column; gap: 12px; }
.fleet-img { width: 100%; border-radius: 12px; object-fit: cover; box-shadow: var(--shadow-lg); }
.fleet-img-sm { height: 220px; object-fit: cover; object-position: center; }
.fleet-label { font-size: .8rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--red); margin-bottom: 12px; }
.fleet-content h2 { font-size: clamp(1.6rem, 2.5vw, 2.2rem); color: var(--navy); margin-bottom: 1rem; }
.fleet-content p { color: var(--gray); margin-bottom: 1rem; font-size: .97rem; line-height: 1.7; }
.fleet-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin: 2rem 0; padding: 20px; background: var(--light); border-radius: var(--radius); }
.fstat { text-align: center; }
.fstat strong { display: block; font-size: 1.4rem; font-family: 'Oswald', sans-serif; color: var(--navy); }
.fstat span { font-size: .75rem; color: var(--gray); }
.fleet-img-placeholder { background: var(--navy); border-radius: 12px; height: 240px; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.4); font-family: 'Oswald', sans-serif; font-size: 1.2rem; text-align: center; }
@media (max-width: 768px) {
  .fleet-grid { grid-template-columns: 1fr; }
  .fleet-stats { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .main-nav { gap: 0; }
  .main-nav a { font-size: .83rem; padding: 8px 8px; }
  .why-grid, .reviews-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .areas-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .main-nav, .header-cta { display: none; }
  .nav-toggle { display: flex; margin-left: auto; }
  .announce-bar { font-size: .8rem; padding: 8px 16px; }

  .hero { min-height: 100svh; }
  .trust-item { padding: 0 14px; }
  .hero-trust { gap: 0; }
  .trust-div { display: none; }

  .pillars { grid-template-columns: 1fr; }
  .emerg-inner { flex-direction: column; text-align: center; }
  .why-grid { grid-template-columns: 1fr; }
  .services-cols { grid-template-columns: 1fr; }
  .areas-grid { grid-template-columns: repeat(2, 1fr); }
  .reviews-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }

  .sticky-call-bar { display: block; }
  body { padding-bottom: 60px; }
}

@media (max-width: 480px) {
  .hero h1 { font-size: 2rem; }
  .hero-trust { flex-direction: column; gap: 12px; }
  .footer-grid { grid-template-columns: 1fr; }
  .areas-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-form-wrap { padding: 24px 18px; }
}

/* ── Footer social links ── */
.footer-social { display:flex; gap:16px; margin-top:16px; align-items:center; flex-wrap:wrap; }
.social-link { display:flex; align-items:center; gap:6px; color:rgba(255,255,255,.65); text-decoration:none; font-size:13px; font-weight:500; transition:color .2s; }
.social-link:hover { color:#fff; }
.social-link svg { flex-shrink:0; }

/* ── Reviews CTA dual buttons ── */
.reviews-cta { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:2rem; }
.reviews-cta .btn-outline { display:inline-flex; align-items:center; font-size:15px; }
.btn-yelp { border-color:#d32323; color:#d32323; }
.btn-yelp:hover { background:#d32323; color:#fff; }

/* Hero review strip */
.hero-review-strip {
  display:flex; align-items:center; justify-content:center; gap:14px;
  flex-wrap:wrap; margin-bottom:1.6rem;
}
.hero-review-badge {
  display:flex; align-items:center; gap:7px;
  background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.2);
  border-radius:30px; padding:6px 14px; color:#fff; font-size:.85rem; font-weight:600;
  backdrop-filter:blur(4px);
}
.star-gold { color:#F5A623; }
/* Review platform badge */
.review-platform { display:flex; align-items:center; gap:5px; margin-bottom:.6rem; font-size:.78rem; font-weight:700; letter-spacing:.02em; text-transform:uppercase; }
.review-platform.google-badge { color:#4285F4; }
.review-platform.yelp-badge { color:#d32323; }

/* Footer address */
.footer-address { font-style:normal; margin:8px 0 10px; color:rgba(255,255,255,.7); font-size:.9rem; line-height:1.6; }
.footer-address a { color:rgba(255,255,255,.7); text-decoration:none; border-bottom:1px solid rgba(255,255,255,.2); }
.footer-address a:hover { color:#fff; }

.contact-map { width:100%; height:300px; border-radius:var(--radius); overflow:hidden; margin-top:24px; border:2px solid rgba(255,255,255,.1); }
.contact-map iframe { width:100%; height:100%; border:0; display:block; }

/* ========================================
   INNER PAGE STYLES
   ======================================== */
.page-hero{background:linear-gradient(135deg,var(--navy) 0%,#0a122d 100%);padding:80px 0 55px;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url('/img/hero-slider1.jpg') center/cover no-repeat;opacity:.12}
.page-hero-inner{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:0 20px}
.page-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(1.9rem,4.5vw,3rem);color:#fff;margin:0 0 .8rem;line-height:1.15}
.page-hero .hero-sub{font-size:1.1rem;color:rgba(255,255,255,.85);max-width:660px;margin:0 auto 1.5rem}
.page-hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.breadcrumb{background:rgba(27,47,94,.95);border-bottom:1px solid rgba(255,255,255,.08);padding:9px 0}
.breadcrumb-inner{max-width:1200px;margin:0 auto;padding:0 20px;font-size:.84rem;color:rgba(255,255,255,.55);display:flex;flex-wrap:wrap;gap:2px;align-items:center}
.breadcrumb-inner a{color:var(--gold);text-decoration:none}
.breadcrumb-inner a:hover{text-decoration:underline}
.breadcrumb-inner .sep{margin:0 5px;opacity:.5}
.page-wrap{max-width:1200px;margin:0 auto;padding:55px 20px;display:grid;grid-template-columns:1fr 330px;gap:50px;align-items:start}
.page-main h2{font-family:'Oswald',sans-serif;font-size:1.75rem;color:var(--navy);margin:2.2rem 0 .9rem;border-left:4px solid var(--red);padding-left:14px;line-height:1.25}
.page-main h2:first-child{margin-top:0}
.page-main h3{font-family:'Oswald',sans-serif;font-size:1.25rem;color:var(--navy);margin:1.6rem 0 .6rem}
.page-main p{color:#444;line-height:1.82;margin-bottom:1rem}
.page-main ul,.page-main ol{color:#444;line-height:1.82;margin-bottom:1rem;padding-left:1.6rem}
.page-main ul li,.page-main ol li{margin-bottom:.35rem}
.page-main a{color:var(--red);text-decoration:none}
.page-main a:hover{text-decoration:underline}
.cost-box{background:#f8f9fa;border:2px solid var(--gold);border-radius:var(--radius);padding:26px;margin:2rem 0}
.cost-box h3{font-family:'Oswald',sans-serif;color:var(--navy);margin:0 0 .8rem;font-size:1.25rem}
.cost-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e0e0e0;font-size:.94rem;color:#333}
.cost-row:last-of-type{border-bottom:none;font-weight:700;color:var(--navy);font-size:1rem}
.cost-note{font-size:.8rem;color:#777;margin-top:8px;line-height:1.5}
.process-steps{counter-reset:step;margin:1.5rem 0}
.step{display:grid;grid-template-columns:52px 1fr;gap:14px;margin-bottom:1.4rem;align-items:start}
.step::before{counter-increment:step;content:counter(step);display:flex;align-items:center;justify-content:center;width:52px;height:52px;background:var(--red);color:#fff;font-family:'Oswald',sans-serif;font-size:1.5rem;font-weight:700;border-radius:50%;flex-shrink:0}
.step h4{font-family:'Oswald',sans-serif;font-size:1.05rem;color:var(--navy);margin:8px 0 3px}
.step p{margin:0;font-size:.93rem;color:#555;line-height:1.7}
.faq-section{background:#f2f4f8;padding:60px 0}
.faq-inner{max-width:900px;margin:0 auto;padding:0 20px}
.faq-section h2{font-family:'Oswald',sans-serif;font-size:2rem;color:var(--navy);text-align:center;margin:0 0 2.5rem}
.faq-item{background:#fff;border-radius:8px;margin-bottom:10px;border:1px solid #dce3ef}
.faq-q{font-family:'Oswald',sans-serif;font-size:1.02rem;color:var(--navy);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:10px}
.faq-a{padding:0 20px 16px;color:#555;line-height:1.77;font-size:.93rem}
.page-sidebar{position:sticky;top:95px}
.sidebar-box{background:var(--navy);border-radius:var(--radius);padding:26px;text-align:center;color:#fff;margin-bottom:18px}
.sidebar-box h3{font-family:'Oswald',sans-serif;font-size:1.35rem;margin:0 0 .65rem;color:#fff}
.sidebar-box p{font-size:.88rem;color:rgba(255,255,255,.78);margin:0 0 1.2rem;line-height:1.6}
.sidebar-phone{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--red);color:#fff;text-decoration:none;padding:13px 18px;border-radius:6px;font-family:'Oswald',sans-serif;font-size:1.35rem;font-weight:700;letter-spacing:.5px;margin-bottom:9px;transition:background .2s}
.sidebar-phone:hover{background:#c0392b}
.sidebar-est-link{display:block;color:var(--gold);text-decoration:none;font-size:.88rem;font-weight:600;padding:9px;border:2px solid var(--gold);border-radius:6px;transition:all .2s}
.sidebar-est-link:hover{background:var(--gold);color:#000}
.sidebar-links-box{background:#f4f6f9;border-radius:var(--radius);padding:20px;margin-bottom:18px}
.sidebar-links-box h4{font-family:'Oswald',sans-serif;font-size:1.05rem;color:var(--navy);margin:0 0 .9rem;padding-bottom:7px;border-bottom:2px solid var(--red)}
.sidebar-links-box ul{list-style:none;padding:0;margin:0}
.sidebar-links-box li{padding:5px 0;border-bottom:1px solid #e2e8f0;font-size:.88rem}
.sidebar-links-box li:last-child{border-bottom:none}
.sidebar-links-box a{color:var(--navy);text-decoration:none;font-weight:500}
.sidebar-links-box a:hover{color:var(--red)}
.sidebar-hours-box{background:#fff;border:2px solid var(--gold);border-radius:var(--radius);padding:18px 20px;font-size:.88rem}
.sidebar-hours-box h4{font-family:'Oswald',sans-serif;color:var(--navy);margin:0 0 .8rem;font-size:1.05rem}
.hours-row{display:flex;justify-content:space-between;padding:4px 0;color:#444;border-bottom:1px solid #f0f0f0}
.hours-row:last-child{border-bottom:none;font-weight:700;color:var(--red)}
.cta-band{background:var(--red);padding:55px 20px;text-align:center}
.cta-band h2{font-family:'Oswald',sans-serif;font-size:2rem;color:#fff;margin:0 0 .7rem}
.cta-band p{color:rgba(255,255,255,.9);font-size:1.05rem;margin:0 auto 1.5rem;max-width:600px}
.cta-band-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;margin:1.5rem 0}
.svc-card{background:#fff;border:1px solid #dce3ef;border-radius:var(--radius);padding:22px;transition:box-shadow .2s,transform .2s}
.svc-card:hover{box-shadow:0 8px 28px rgba(27,47,94,.12);transform:translateY(-3px)}
.svc-card h3{font-family:'Oswald',sans-serif;font-size:1.15rem;color:var(--navy);margin:0 0 .5rem}
.svc-card p{font-size:.88rem;color:#555;margin:0 0 .9rem;line-height:1.65}
.svc-card a.learn{color:var(--red);font-size:.88rem;font-weight:600;text-decoration:none}
.area-tags{display:flex;flex-wrap:wrap;gap:9px;margin:1.2rem 0}
.area-tag{background:var(--navy);color:#fff;padding:6px 15px;border-radius:20px;font-size:.85rem;text-decoration:none;transition:background .2s;font-weight:500}
.area-tag:hover{background:var(--red)}
.trust-row{display:flex;flex-wrap:wrap;gap:12px;margin:1.5rem 0}
.trust-badge{display:flex;align-items:center;gap:8px;background:#f4f6f9;border-radius:8px;padding:10px 16px;font-size:.88rem;color:var(--navy);font-weight:600}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin:2rem 0}
.contact-info h3{font-family:'Oswald',sans-serif;color:var(--navy);font-size:1.3rem;margin:0 0 1rem}
.contact-detail-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:1rem}
.contact-detail-row svg{flex-shrink:0;margin-top:2px}
.contact-detail-row div strong{display:block;font-family:'Oswald',sans-serif;color:var(--navy);font-size:1rem}
.contact-detail-row div span{font-size:.9rem;color:#555}
.contact-form-box h3{font-family:'Oswald',sans-serif;color:var(--navy);font-size:1.3rem;margin:0 0 1rem}
.form-row{margin-bottom:14px}
.form-row label{display:block;font-size:.88rem;font-weight:600;color:var(--navy);margin-bottom:4px}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:11px 14px;border:2px solid #dce3ef;border-radius:6px;font-size:.95rem;font-family:'Roboto',sans-serif;color:#333;outline:none;transition:border-color .2s;box-sizing:border-box}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--navy)}
.form-row textarea{height:110px;resize:vertical}
.btn-submit{width:100%;background:var(--red);color:#fff;border:none;padding:14px;border-radius:6px;font-family:'Oswald',sans-serif;font-size:1.2rem;font-weight:700;cursor:pointer;letter-spacing:.5px;transition:background .2s}
.btn-submit:hover{background:#c0392b}
.contact-map{width:100%;height:300px;border-radius:var(--radius);overflow:hidden;margin-top:20px;border:2px solid rgba(27,47,94,.15)}
.contact-map iframe{width:100%;height:100%;border:0;display:block}
.city-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:1.5rem 0}
.city-stat{background:var(--navy);color:#fff;border-radius:8px;padding:16px;text-align:center}
.city-stat strong{display:block;font-family:'Oswald',sans-serif;font-size:1.6rem;color:var(--gold)}
.city-stat span{font-size:.82rem;opacity:.8}
.emerg-strip{background:var(--red);color:#fff;text-align:center;padding:16px 20px;font-family:'Oswald',sans-serif;font-size:1.15rem;letter-spacing:.3px}
.emerg-strip a{color:#fff;font-weight:700}
@media(max-width:900px){.page-wrap{grid-template-columns:1fr}.page-sidebar{position:static}.contact-grid{grid-template-columns:1fr}.city-stats{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.page-hero{padding:55px 0 40px}.faq-section{padding:40px 0}.cta-band{padding:40px 20px}.city-stats{grid-template-columns:1fr}}

/* ═══════════════════════════════════════
   DROPDOWN NAVIGATION v2
   ═══════════════════════════════════════ */
.main-nav{display:flex;align-items:center;gap:1px}
.nav-item{position:relative}
.nav-item>a,.main-nav>a{display:flex;align-items:center;gap:5px;padding:8px 10px;color:rgba(255,255,255,.9);font-size:.84rem;font-weight:500;text-decoration:none;border-radius:5px;white-space:nowrap;transition:background .18s,color .18s;letter-spacing:.15px}
.nav-item>a:hover,.main-nav>a:hover,.nav-item>a[aria-current],.main-nav>a[aria-current]{background:rgba(255,255,255,.13);color:#fff}
.nav-emerg{background:var(--red)!important;border-radius:5px!important;font-weight:700!important;color:#fff!important;padding:8px 12px!important}
.nav-emerg:hover{background:#c0392b!important}
.dd-arrow{opacity:.55;flex-shrink:0;transition:transform .2s,opacity .2s}
.nav-item:hover>a .dd-arrow{transform:rotate(180deg);opacity:1}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border-radius:10px;box-shadow:0 16px 48px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.06);padding:8px 0;min-width:210px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s,visibility .18s,transform .18s;z-index:2000}
.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown a{display:block;padding:8px 18px;color:var(--navy);font-size:.84rem;font-weight:500;text-decoration:none;transition:background .12s,color .12s}
.nav-dropdown a:hover,.nav-dropdown a[aria-current]{background:#f4f6f9;color:var(--red)}
.dd-label{display:block;padding:6px 18px 3px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#aaa}
.dd-divider{height:1px;background:#eee;margin:5px 0}
.dd-all{color:var(--red)!important;font-weight:600!important;font-size:.82rem!important}
.dd-all:hover{background:#fff5f5!important}
/* Mobile Nav v2 */
.mobile-nav{background:var(--navy);display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;overflow-y:auto;padding:0 0 40px}
body.nav-open .mobile-nav{display:block}
body.nav-open{overflow:hidden}
.mob-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:4px}
.mob-close-btn{background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:0 4px;line-height:1}
.mob-section-btn{width:100%;text-align:left;padding:13px 20px;color:#fff;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.07);font-family:'Oswald',sans-serif;font-size:1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;letter-spacing:.2px}
.mob-section-btn::after{content:'+';font-size:1.3rem;opacity:.5;margin-left:8px}
.mob-section.open .mob-section-btn::after{content:'−';opacity:1}
.mob-section-body{display:none;background:rgba(0,0,0,.2)}
.mob-section.open .mob-section-body{display:block}
.mob-sub{display:block;padding:10px 20px 10px 30px;color:rgba(255,255,255,.78);text-decoration:none;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.04)}
.mob-sub:hover{color:#fff;background:rgba(255,255,255,.05)}
.mob-top-link{display:block;padding:13px 20px;color:#fff;text-decoration:none;font-family:'Oswald',sans-serif;font-size:1rem;border-bottom:1px solid rgba(255,255,255,.07)}
.mob-top-link:hover{background:rgba(255,255,255,.06)}
.mob-emerg{background:var(--red)!important;font-weight:700;text-align:center;font-size:1.05rem!important}
.mob-cta-wrap{margin:18px 20px 0}
.mob-cta-wrap a{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--red);color:#fff;padding:14px;border-radius:8px;font-family:'Oswald',sans-serif;font-size:1.15rem;font-weight:700;text-decoration:none}

/* ═══════════════════════ BLOG STYLES ═══════════════════════ */
.blog-hero{background:linear-gradient(135deg,var(--navy) 0%,#0a122d 100%);padding:70px 0 50px;text-align:center;position:relative;overflow:hidden}
.blog-hero::before{content:'';position:absolute;inset:0;background:url('/img/hero-slider1.jpg') center/cover no-repeat;opacity:.1}
.blog-hero-inner{position:relative;z-index:1;max-width:800px;margin:0 auto;padding:0 20px}
.blog-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(1.8rem,4vw,2.8rem);color:#fff;margin:0 0 .7rem}
.blog-hero p{color:rgba(255,255,255,.8);font-size:1.05rem}
.blog-grid{max-width:1100px;margin:0 auto;padding:55px 20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}
.blog-card{background:#fff;border:1px solid #dce3ef;border-radius:var(--radius);overflow:hidden;transition:box-shadow .2s,transform .2s}
.blog-card:hover{box-shadow:0 8px 30px rgba(27,47,94,.12);transform:translateY(-3px)}
.blog-card-body{padding:22px}
.blog-cat{display:inline-block;background:var(--navy);color:#fff;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 10px;border-radius:3px;margin-bottom:.7rem}
.blog-card h2{font-family:'Oswald',sans-serif;font-size:1.2rem;color:var(--navy);margin:0 0 .6rem;line-height:1.3}
.blog-card h2 a{color:inherit;text-decoration:none}
.blog-card h2 a:hover{color:var(--red)}
.blog-card p{font-size:.88rem;color:#555;line-height:1.65;margin:0 0 1rem}
.blog-card .read-more{color:var(--red);font-size:.85rem;font-weight:600;text-decoration:none}
.blog-card .post-meta{font-size:.78rem;color:#999;margin-top:.5rem}
/* Article styles */
.article-hero{background:linear-gradient(135deg,var(--navy) 0%,#0a122d 100%);padding:70px 0 50px;position:relative;overflow:hidden}
.article-hero::before{content:'';position:absolute;inset:0;background:url('/img/hero-slider1.jpg') center/cover no-repeat;opacity:.1}
.article-hero-inner{position:relative;z-index:1;max-width:820px;margin:0 auto;padding:0 20px}
.article-cat{display:inline-block;background:var(--red);color:#fff;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 12px;border-radius:4px;margin-bottom:.8rem}
.article-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(1.8rem,4vw,2.7rem);color:#fff;margin:0 0 .8rem;line-height:1.2}
.article-hero .hero-meta{color:rgba(255,255,255,.65);font-size:.88rem}
.article-wrap{max-width:1100px;margin:0 auto;padding:55px 20px;display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start}
.article-body h2{font-family:'Oswald',sans-serif;font-size:1.65rem;color:var(--navy);margin:2.2rem 0 .8rem;border-left:4px solid var(--red);padding-left:14px}
.article-body h2:first-child{margin-top:0}
.article-body h3{font-family:'Oswald',sans-serif;font-size:1.2rem;color:var(--navy);margin:1.6rem 0 .5rem}
.article-body p{color:#444;line-height:1.85;margin-bottom:1rem}
.article-body ul,.article-body ol{color:#444;line-height:1.85;margin-bottom:1rem;padding-left:1.6rem}
.article-body ul li,.article-body ol li{margin-bottom:.4rem}
.article-body a{color:var(--red);text-decoration:none}
.article-body a:hover{text-decoration:underline}
.article-body table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.92rem}
.article-body th{background:var(--navy);color:#fff;padding:10px 14px;text-align:left;font-family:'Oswald',sans-serif}
.article-body td{padding:9px 14px;border-bottom:1px solid #e0e6f0;color:#444}
.article-body tr:nth-child(even) td{background:#f8f9fa}
.article-cta-inline{background:var(--navy);border-radius:var(--radius);padding:24px;margin:2rem 0;color:#fff;display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.article-cta-inline p{margin:0;font-size:.95rem;color:rgba(255,255,255,.85);flex:1}
.article-cta-inline a{white-space:nowrap}
@media(max-width:900px){.article-wrap{grid-template-columns:1fr}}

/* ── Coupon Cards ── */
.coupon-card{background:#fff;border:2px dashed #d1d5db;border-radius:var(--radius);padding:24px;position:relative;overflow:hidden}
.coupon-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--red)}
.coupon-card--cta{background:var(--navy);color:#fff;border-color:rgba(255,255,255,.2)}
.coupon-card--cta h3{color:#fff}
.coupon-card--cta p{color:rgba(255,255,255,.8)}
.coupon-badge{display:inline-block;background:var(--red);color:#fff;font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:600;padding:6px 14px;border-radius:4px;margin-bottom:12px;letter-spacing:.5px}
.coupon-card h3{font-family:'Oswald',sans-serif;font-size:1.2rem;color:var(--navy);margin:0 0 8px}
.coupon-card p{font-size:.9rem;color:#555;margin:0 0 10px;line-height:1.5}
.coupon-code{font-family:monospace;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:6px 12px;display:inline-block;font-size:.95rem;font-weight:700;letter-spacing:1px;color:var(--navy);margin:8px 0}
.coupon-exp{font-size:.78rem;color:#888;margin:0}

/* ── Reviews Grid ── */
.review-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.review-card{background:#fff;border:1px solid #dce3ef;border-radius:var(--radius);padding:24px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.review-stars{display:flex;gap:2px;margin-bottom:12px}
.review-text{font-style:italic;color:#374151;line-height:1.6;margin:0 0 16px;font-size:.95rem}
.review-author{display:flex;align-items:center;gap:10px;font-size:.88rem}
.review-author strong{color:var(--navy)}
.review-author span{color:#888}
.review-author::before{content:'';display:block;width:32px;height:32px;background:var(--navy);border-radius:50%;flex-shrink:0}

/* ── HTML Sitemap ── */
.sm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.sm-section{background:#fff;border:1px solid #dce3ef;border-radius:var(--radius);padding:20px}
.sm-section h3{font-family:'Oswald',sans-serif;font-size:1rem;color:var(--navy);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #eef0f5}
.sm-section ul{list-style:none;margin:0;padding:0}
.sm-section li{margin-bottom:5px}
.sm-section a{color:#374151;font-size:.88rem;text-decoration:none;transition:color .15s}
.sm-section a:hover{color:var(--red)}
