/*
 * Critical path stabilizer: hero + main intro paint from first <style> before Nitro combined CSS.
 * Selectors match vitrin.php / index.php / homepage.css / mobile-hero.css / index-homepage.css.
 */
body.home .site-showcase { min-height: 580px; box-sizing: border-box; }
body.home .hero-slider.flexslider { min-height: 580px; box-sizing: border-box; }
body.home .hero-slider.flexslider .flex-viewport {
  min-height: 580px;
  box-sizing: border-box;
}
body.home .hero-slider.flexslider > ul.slides,
body.home .hero-slider.flexslider ul.slides > li.parallax.hero-slide {
  min-height: 580px;
  box-sizing: border-box;
}
body.home .hero-slider.flexslider .slides > li:first-child {
  display: block !important;
}
body.home .hero-slider .hero-slide-photo-slot .hero-slide-photo {
  max-width: none;
  object-fit: cover;
  object-position: center;
}

/* --- Main shell (index-homepage.css) so <main> / featured-blocks are not “unstyled” until Nitro --- */
body.home main.main {
  display: block !important;
  visibility: visible !important;
  box-sizing: border-box;
}
body.home main.main #content.content.full,
body.home main.main .featured-blocks.page-section {
  display: block !important;
  visibility: visible !important;
  box-sizing: border-box;
}

@media (max-width: 991px) {
  body.home main.main { margin-top: 10px !important; }
}
@media (min-width: 992px) {
  body.home main.main { margin-top: 20px !important; }
  body.home .site-showcase,
  body.home .hero-slider.flexslider,
  body.home .hero-slider.flexslider .flex-viewport,
  body.home .hero-slider.flexslider > ul.slides,
  body.home .hero-slider.flexslider ul.slides > li.parallax.hero-slide {
    min-height: 620px;
    box-sizing: border-box;
  }
  body.home .site-showcase,
  body.home .site-showcase .hero-slider.hidden-xs,
  body.home .site-showcase .hero-slider {
    min-height: 620px !important;
    height: 620px !important;
    box-sizing: border-box;
  }
}

/*
 * MOBILE hero band + LCP logo frame (mobile-hero.css) — deterministic before deferred mobile-hero.css / Nitro.
 */
@media (max-width: 991px) {
  /* Collapse hidden desktop search strip immediately (mobile-hero.css) — avoids <main> gap / reflow when late CSS loads */
  body.home .page-section.desktop-hero-system,
  body.home .site-showcase + .page-section.desktop-hero-system {
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    border: none !important;
  }
  body.home .mobile-hero-system.site-showcase {
    display: block !important;
    visibility: visible !important;
    position: relative !important;
    height: 580px !important;
    min-height: 580px !important;
    max-height: 580px !important;
    overflow: visible !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 1 !important;
    box-sizing: border-box !important;
  }
  body.home .mobile-hero-system .hero-slider.hidden-xs,
  body.home .mobile-hero-system .hero-slider.flexslider,
  body.home .mobile-hero-system .hero-slider {
    display: block !important;
    visibility: visible !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 580px !important;
    min-height: 580px !important;
    max-height: 580px !important;
    z-index: 1 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }
  body.home .mobile-hero-system .hero-slider .flex-viewport,
  body.home .mobile-hero-system .hero-slider .slides {
    height: 580px !important;
    min-height: 580px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  /* Slide <li> box matches mobile-hero.css — positioning/height must not wait on Nitro */
  body.home .mobile-hero-system .hero-slider .slides > li.parallax.hero-slide {
    position: relative !important;
    display: block !important;
    height: 100% !important;
    min-height: 100% !important;
    box-sizing: border-box !important;
  }
  body.home .mobile-hero-system .hero-slider .slides li.hero-slide--mobile-brand {
    background: linear-gradient(165deg, #153d5c 0%, #0c2d45 45%, #061824 100%) !important;
    opacity: 1 !important;
    filter: none !important;
  }
  body.home .mobile-hero-system .hero-slider .slides li .mobile-hero-brand-band {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 2 !important;
    pointer-events: none !important;
    padding: 24px 16px !important;
    box-sizing: border-box !important;
  }
  /* Logo painted area must dominate text LCP candidates (~322×96 in lab) — 360×128 ≈ 46k px² */
  body.home .mobile-hero-system .mobile-hero-brand-logo {
    max-width: min(94vw, 360px) !important;
    width: 360px !important;
    height: auto !important;
    aspect-ratio: 360 / 128 !important;
    object-fit: contain !important;
    display: block !important;
    box-sizing: border-box !important;
  }
  body.home .mobile-search-overlay-wrapper {
    position: absolute !important;
    top: 52% !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    transform: translateY(-50%) !important;
    z-index: 99999 !important;
    padding: 0 15px !important;
    box-sizing: border-box !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: none !important;
  }
  body.home .mobile-search-overlay-wrapper * {
    pointer-events: auto !important;
  }
}

/* MOBILE intro: defer off-screen paint so LCP cannot commit on <p.intro-verification>; intrinsic reserves space */
@media (max-width: 991px) {
  body.home main.main .homepage-intro-container {
    padding-top: 40px !important;
    padding-bottom: 60px !important;
    margin-bottom: 15px !important;
    min-height: 360px !important;
    box-sizing: border-box;
    content-visibility: auto !important;
    contain-intrinsic-block-size: 420px !important;
  }
  body.home main.main .homepage-h1 {
    font-family: Tahoma, Arial, sans-serif !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    line-height: 28px !important;
    letter-spacing: -0.45px;
    color: #111827 !important;
    margin: 0 0 14px 0 !important;
    text-align: right !important;
    min-height: 112px !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
  body.home main.main .intro-trust {
    font-family: Tahoma, Arial, sans-serif !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 26px !important;
    min-height: 52px !important;
    color: #444 !important;
    margin: 8px 0 18px 0 !important;
    text-align: right !important;
    display: block !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
  body.home main.main .intro-primary {
    font-family: Tahoma, Arial, sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 26px !important;
    min-height: 78px !important;
    color: #333 !important;
    margin-bottom: 26px !important;
    text-align: right !important;
    display: block !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
  body.home main.main .intro-verification {
    font-family: Tahoma, Arial, sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 22px !important;
    min-height: 0 !important;
    color: #555 !important;
    margin-bottom: 22px !important;
    text-align: right !important;
    display: block !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
}

/* DESKTOP intro: px line-heights + min-heights so Montserrat swap does not reflow boxes (Nitro bundle loads later) */
@media (min-width: 992px) {
  body.home .featured-blocks .homepage-intro-container {
    padding-top: 40px !important;
    padding-bottom: 60px !important;
    margin-bottom: 15px !important;
    margin-top: 20px !important;
    box-sizing: border-box;
  }
  body.home .featured-blocks .homepage-h1 {
    font-family: 'Montserrat', Tahoma, Arial, sans-serif !important;
    font-size: 32px !important;
    font-weight: 700 !important;
    line-height: 36px !important;
    letter-spacing: -0.45px !important;
    color: #111827 !important;
    margin: 0 0 25px 0 !important;
    text-align: right !important;
    min-height: 144px !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
  body.home .featured-blocks .intro-trust {
    font-family: 'Montserrat', Tahoma, Arial, sans-serif !important;
    font-size: 24px !important;
    font-weight: 600 !important;
    line-height: 34px !important;
    min-height: 68px !important;
    color: #444 !important;
    margin: 10px 0 20px 0 !important;
    text-align: right !important;
    display: block !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
  body.home .featured-blocks .intro-primary {
    font-family: 'Montserrat', Tahoma, Arial, sans-serif !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 29px !important;
    min-height: 116px !important;
    color: #333 !important;
    margin-bottom: 30px !important;
    text-align: right !important;
    display: block !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
  body.home .featured-blocks .intro-verification {
    font-family: 'Montserrat', Tahoma, Arial, sans-serif !important;
    font-size: 15px !important;
    font-weight: 400 !important;
    line-height: 24px !important;
    min-height: 0 !important;
    color: #555 !important;
    margin-bottom: 25px !important;
    text-align: right !important;
    display: block !important;
    box-sizing: border-box;
    font-synthesis: none;
  }
}
