    #promo-video.local-hero-video {
      position: relative;
      overflow: hidden;
      background: #0a0f16;
    }

    #promo-video.local-hero-video:before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 1;
      background: rgba(0, 0, 0, 0.46);
      pointer-events: none;
    }

    #promo-video .hero-poster,
    #promo-video .hero-background-video {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    #promo-video .hero-poster {
      z-index: 0;
    }

    #promo-video .hero-video-layer {
      position: absolute;
      inset: 0;
      z-index: 0;
      pointer-events: none;
    }

    #promo-video .hero-background-video {
      opacity: 0;
      transition: opacity 0.8s ease;
    }

    #promo-video .hero-background-video.is-ready {
      opacity: 1;
    }

    #promo-video.local-hero-video .container {
      position: relative;
      z-index: 2;
    }

    .hero-video-toggle {
      display: none;
      position: absolute;
      right: 24px;
      bottom: 24px;
      z-index: 3;
      width: 42px;
      height: 42px;
      border: 1px solid rgba(255, 255, 255, 0.42);
      border-radius: 50%;
      background: rgba(0, 0, 0, 0.38);
      color: #fff;
      align-items: center;
      justify-content: center;
    }

    .hero-video-toggle.is-visible {
      display: inline-flex;
    }

    .hero-video-toggle:focus,
    .hero-video-toggle:hover {
      color: #fff;
      background: rgba(0, 0, 0, 0.62);
      outline: none;
    }

    .home-video-section {
      margin: 0 auto;
      padding-top: 20px !important;
      padding-bottom: 20px !important;
    }

    .home-video-section .video-section-title {
      margin-bottom: 24px;
    }

    .home-video-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }

    .home-video-card {
      background: #fff;
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    }

    .home-video-frame {
      position: relative;
      width: 100%;
      aspect-ratio: 16 / 9;
      background: #000;
    }

    .home-video-frame iframe,
    .home-video-trigger,
    .home-video-thumb {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
    }

    .home-video-frame iframe {
      border: 0;
    }

    .home-video-trigger {
      display: block;
      border: 0;
      background: #111;
      color: #fff;
      cursor: pointer;
      overflow: hidden;
      text-decoration: none;
    }

    .home-video-thumb {
      object-fit: cover;
      opacity: 0.82;
      transition: opacity 0.2s ease, transform 0.2s ease;
    }

    .home-video-play {
      position: absolute;
      left: 50%;
      top: 50%;
      width: 64px;
      height: 64px;
      margin-left: -32px;
      margin-top: -32px;
      border-radius: 50%;
      background: rgba(28, 79, 130, 0.92);
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
    }

    .home-video-play:before {
      content: "";
      position: absolute;
      left: 25px;
      top: 19px;
      border-left: 20px solid #fff;
      border-top: 13px solid transparent;
      border-bottom: 13px solid transparent;
    }

    .home-video-trigger:hover .home-video-thumb,
    .home-video-trigger:focus .home-video-thumb {
      opacity: 0.68;
      transform: scale(1.03);
    }

    .home-video-trigger:focus {
      outline: 3px solid #1c4f82;
      outline-offset: 3px;
    }

    .home-video-caption {
      padding: 14px 16px;
      font-size: 15px;
      line-height: 1.45;
      color: #333;
    }

    @media (max-width: 991px) {
      .home-video-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    @media (max-width: 560px) {
      .home-video-grid {
        grid-template-columns: 1fr;
      }
    }

/* Font-display swap overrides — improves FCP by preventing invisible text during font load */
@font-face {
  font-family: 'FontAwesome';
  font-display: swap;
  src: url('../plugins/font-awesome/fonts/fontawesome-webfont.woff2?v=4.3.0') format('woff2'),
       url('../plugins/font-awesome/fonts/fontawesome-webfont.woff?v=4.3.0') format('woff');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Simple-Line-Icons';
  font-display: swap;
  src: url('../plugins/line-icons/fonts/Simple-Line-Icons.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Glyphicons Halflings';
  font-display: swap;
  src: url('../plugins/bootstrap/fonts/glyphicons-halflings-regular.woff2') format('woff2'),
       url('../plugins/bootstrap/fonts/glyphicons-halflings-regular.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}
