/* ================================================
   AL-AIR BRAND DESIGN SYSTEM
   Generated April 2026
   ================================================ */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;800&family=Open+Sans:wght@400;500;600&display=swap');

/* Brand Color Variables */
:root {
  --color-navy:      #1B3A6B;
  --color-orange:    #F47920;
  --color-white:     #FFFFFF;
  --color-text:      #2D2D2D;
  --color-muted:     #6B7280;
  --color-bg-light:  #F5F7FA;
  --color-border:    #E5E7EB;
}

/* ---- BASE TYPOGRAPHY ---- */
body {
  font-family: 'Open Sans', sans-serif;
  color: var(--color-text);
  background-color: var(--color-white);
  font-size: 16px;
  line-height: 1.7;
}
h1, h2, h3, h4, h5, h6 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  color: var(--color-navy);
  line-height: 1.2;
}
h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }

/* ---- LINKS ---- */
a { color: var(--color-navy); text-decoration: none; }
a:hover { color: var(--color-orange); }

/* ---- BUTTONS ---- */
.button, .wp-block-button__link, input[type="submit"] {
  background-color: var(--color-orange) !important;
  color: var(--color-white) !important;
  border: none;
  border-radius: 4px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 16px;
  padding: 14px 28px;
  cursor: pointer;
  transition: background-color 0.2s ease;
  text-decoration: none;
  display: inline-block;
}
.button:hover, .wp-block-button__link:hover, input[type="submit"]:hover {
  background-color: #d96a10 !important;
  color: var(--color-white) !important;
}

/* ---- PRIMARY CTA: PHONE ---- */
.cta-phone {
  background-color: var(--color-orange);
  color: var(--color-white) !important;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
  font-size: 18px;
  padding: 12px 24px;
  border-radius: 4px;
  display: inline-block;
  text-decoration: none;
  white-space: nowrap;
}
.cta-phone:hover { background-color: #d96a10; color: var(--color-white) !important; }

/* ---- SECONDARY CTA ---- */
.cta-secondary {
  background-color: var(--color-navy);
  color: var(--color-white) !important;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  padding: 12px 24px;
  border-radius: 4px;
  display: inline-block;
  text-decoration: none;
}
.cta-secondary:hover { background-color: #152d54; color: var(--color-white) !important; }

/* ---- HEADER ---- */
.site-header {
  position: sticky !important;
  top: 0;
  z-index: 1000;
  background-color: var(--color-white);
  border-bottom: 2px solid var(--color-border);
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

/* ---- NAVIGATION ---- */
.main-navigation a, .nav-links a {
  color: var(--color-navy);
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 15px;
}
.main-navigation a:hover,
.main-navigation .current-menu-item > a {
  color: var(--color-orange);
}

/* ---- SECTION VARIANTS ---- */
.section-light { background-color: var(--color-bg-light); }
.section-dark {
  background-color: var(--color-navy);
  color: var(--color-white);
}
.section-dark h1, .section-dark h2,
.section-dark h3, .section-dark p { color: var(--color-white); }

/* ---- FOOTER ---- */
.site-footer, footer {
  background-color: var(--color-navy);
  color: var(--color-white);
}
.site-footer a, footer a { color: #A8C4E8; }
.site-footer a:hover, footer a:hover { color: var(--color-orange); }

/* ---- TRUST BAR ---- */
.trust-bar {
  background-color: var(--color-navy);
  color: var(--color-white);
  padding: 8px 0;
  font-size: 14px;
  font-family: 'Montserrat', sans-serif;
  text-align: center;
}

/* ---- UTILITY ---- */
.text-navy   { color: var(--color-navy); }
.text-orange { color: var(--color-orange); }
.bg-navy     { background-color: var(--color-navy); }
.bg-orange   { background-color: var(--color-orange); }
.bg-light    { background-color: var(--color-bg-light); }

/* ---- PAGES WITH CUSTOM HERO: Hide WP entry-header title (hero has its own H1) ---- */
.home .entry-header,
.home .page-header,
.page-id-2530 .entry-header,
.page-id-2530 .page-header {
  display: none !important;
}

/* ---- PAGES WITH CUSTOM HERO: Remove default entry padding ---- */
.home .entry-content,
.page-id-2530 .entry-content {
  padding: 0 !important;
  margin: 0 !important;
}

/* ---- Responsive: Mobile hero font sizes ---- */
@media (max-width: 768px) {
  .hero-section h1 {
    font-size: 28px !important;
  }
  .hero-section p {
    font-size: 16px !important;
  }
  .cta-phone {
    font-size: 16px !important;
    padding: 14px 20px !important;
  }
}

/* HVAC Service Pages — hide entry-header */
.page-id-100 .entry-header,
.page-id-134 .entry-header,
.page-id-160 .entry-header,
.page-id-158 .entry-header { display: none !important; }
.page-id-2653 .entry-header { display: none !important; }

/* Electrical Service Pages — hide entry-header */
.page-id-243 .entry-header,
.page-id-204 .entry-header,
.page-id-162 .entry-header,
.page-id-206 .entry-header,
.page-id-208 .entry-header { display: none !important; }

/* City Landing Pages — hide entry-header */
.page-id-301 .entry-header,
.page-id-348 .entry-header,
.page-id-362 .entry-header,
.page-id-383 .entry-header,
.page-id-408 .entry-header,
.page-id-410 .entry-header,
.page-id-414 .entry-header,
.page-id-416 .entry-header,
.page-id-418 .entry-header,
.page-id-2665 .entry-header,
.page-id-2664 .entry-header { display: none !important; }

/* Core Pages — hide entry-header */
.page-id-2542 .entry-header,
.page-id-420 .entry-header,
.page-id-2679 .entry-header,
.page-id-2680 .entry-header { display: none !important; }

/* =============================================
   MOBILE: Stack 2-column content sections
   Targets all 1fr 1fr grid layouts built into
   service, city, and core pages
   ============================================= */
@media (max-width: 768px) {
  section > div[style*="grid-template-columns:1fr 1fr"],
  section > div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
  }
  /* Reduce hero padding on mobile */
  section[style*="padding:80px"],
  section[style*="padding:88px"],
  section[style*="padding:72px"] {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
  }
  /* Ensure full-width CTAs on mobile */
  section[style*="background:#F47920"] div[style*="display:flex"] {
    flex-direction: column !important;
    align-items: center !important;
  }
  section[style*="background:#F47920"] div[style*="display:flex"] a {
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }
}