/* PTJF Master CSS - Clean rebuild 2026-05-29 */

/* === FONTS === */
@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@400;500;600;700;800&display=swap');

h1, h2, h3, h4, h5, h6,
.wp-block-heading,
.wp-block-button__link,
body, p, li, td, th {
  font-family: 'Raleway', sans-serif !important;
}

/* === LAYOUT === */

/* Kill sidebar */
#secondary, .widget-area, .sidebar-primary, #sidebar-primary {
  display: none !important;
}

/* Full width content area */
#primary, .content-area {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
}

/* Entry content: zero padding, full width */
.entry-content, .wp-block-post-content {
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  box-sizing: border-box;
  overflow-x: hidden;
}

/* alignfull sections: edge-to-edge, no horizontal overflow */
.wp-block-group.alignfull,
.wp-block-cover.alignfull {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box;
  position: relative !important;
  left: auto !important;
}

/* Inner containers: zero padding base */
.wp-block-group.alignfull > .wp-block-group__inner-container,
.wp-block-cover.alignfull > .wp-block-cover__inner-container {
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box;
}

/* alignwide columns: max 1200px centered */
.wp-block-columns.alignwide {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 2rem !important;
  padding-right: 2rem !important;
  box-sizing: border-box;
}

/* Hero image: always flush */
.hero-image, .hero-image.alignfull {
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  display: block;
}
.hero-image img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 !important;
}

/* Footer */
.footer-widget-area { padding: 24px !important; box-sizing: border-box; }

/* === DESKTOP (1025px+) === */
@media (min-width: 1025px) {
  .wp-block-group.alignfull > .wp-block-group__inner-container,
  .wp-block-cover.alignfull > .wp-block-cover__inner-container {
    padding-left: 80px !important;
    padding-right: 80px !important;
  }
  .hero-section > .wp-block-group__inner-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .footer-widget-area { padding: 32px 28px !important; }
}

/* === TABLET (768-1024px) === */
@media (min-width: 768px) and (max-width: 1024px) {
  .wp-block-group.alignfull > .wp-block-group__inner-container,
  .wp-block-cover.alignfull > .wp-block-cover__inner-container {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
  .hero-section > .wp-block-group__inner-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

/* === MOBILE (max 767px) === */
@media (max-width: 767px) {

  /* Prevent any horizontal scroll or overflow */
  html, body {
    overflow-x: hidden !important;
    max-width: 100% !important;
  }

  /* Full-width sections fill the screen properly */
  .wp-block-group.alignfull,
  .wp-block-cover.alignfull {
    width: 100% !important;
    max-width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Inner containers: equal padding both sides */
  .wp-block-group.alignfull > .wp-block-group__inner-container,
  .wp-block-cover.alignfull > .wp-block-cover__inner-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box;
    max-width: 100% !important;
  }

  /* Hero section stays flush (image must be edge-to-edge) */
  .hero-section > .wp-block-group__inner-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Font sizes - large enough for older eyes */
  body, p, li, td, th, .wp-block-paragraph {
    font-size: 17px !important;
    line-height: 1.9 !important;
  }
  h1 { font-size: 1.8rem !important; line-height: 1.3 !important; }
  h2 { font-size: 1.5rem !important; line-height: 1.3 !important; }
  h3 { font-size: 1.2rem !important; line-height: 1.4 !important; }

  /* Buttons */
  .wp-block-button__link {
    font-size: 1rem !important;
    padding: 0.85rem 1.5rem !important;
    min-height: 44px !important;
    display: inline-block;
  }
  .wp-block-buttons {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }

  /* Footer */
  .footer-widget-area {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    padding: 20px 24px 8px 24px !important;
  }

  /* Johnson County notice banner: stack columns vertically */
  .entry-content > .wp-block-group.alignfull:first-child .wp-block-columns {
    flex-direction: column !important;
    gap: 0.75rem !important;
  }
  .entry-content > .wp-block-group.alignfull:first-child .wp-block-column {
    flex-basis: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  .entry-content > .wp-block-group.alignfull:first-child .wp-block-buttons {
    flex-direction: row !important;
    justify-content: flex-start !important;
  }

}

/* === FINAL CTA COVER BLOCK (cowgirl/sunset) - MOBILE FIX === */
@media (max-width: 767px) {
  /* Keep cover block flush, no horizontal overflow */
  .wp-block-cover.alignfull {
    overflow: hidden !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .wp-block-cover__image-background {
    width: 100% !important;
    max-width: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
  }
  /* Ensure text inside cover is readable with generous padding */
  .wp-block-cover__inner-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box !important;
    max-width: 100% !important;
  }
  /* Gold and white text — force visibility over any background */
  .wp-block-cover .wp-block-heading,
  .wp-block-cover .wp-block-paragraph,
  .wp-block-cover p {
    text-shadow: 0 1px 6px rgba(0,0,0,0.8), 0 0 20px rgba(0,0,0,0.6) !important;
  }
}
/* === SUNSET COVER + LOGO BOX FIX (mobile) === */
@media (max-width: 767px) {
  .wp-block-cover.alignfull .wp-block-cover__background { opacity: 0.62 !important; }
  .wp-block-cover__inner-container { position: relative !important; z-index: 2 !important; }
  .hero-logo img { background: transparent !important; border: none !important; box-shadow: none !important; padding: 0 !important; }
  .wp-block-image.hero-logo { background: transparent !important; border: none !important; box-shadow: none !important; }
}

/* Vignette overlay for all screens */
@media (max-width: 767px) {
  .wp-block-cover.alignfull { position: relative !important; }
}
/* === RADIAL VIGNETTE - softens sunset glow at center === */
@media (max-width: 767px) {
  .wp-block-cover.alignfull {
    position: relative !important;
  }
  .wp-block-cover.alignfull::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, transparent 30%, rgba(10,42,86,0.55) 100%);
    pointer-events: none;
    z-index: 1;
  }
}

/* Navbar - white background */
.site-header,
header.site-header,
#masthead,
.kadence-sticky-header,
.kadence-header {
  background-color: #ffffff !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.10) !important;
}
.site-header .header-inner,
.site-header .header-container {
  background-color: #ffffff !important;
}