/* hero.css — ported from sass/blocks/homepage-banner-block.scss.
 * Color literals swapped for tokens where the hex matched the audit:
 *   #009fed -> --color-brand, #2B55BF -> --color-blue-700,
 *   #ffffff -> --color-white, #212121 -> --color-gray-900,
 *   #60D8AC -> --color-teal-300.
 */

.homepage-banner .content {
  width: 90%;
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
}
@media only screen and (min-width: 601px) {
  .homepage-banner .content { width: 85%; }
}
@media only screen and (min-width: 993px) {
  .homepage-banner .content { width: 80%; }
}
@media only screen and (min-width: 1201px) {
  .homepage-banner .content { width: 70%; }
}
.homepage-banner .content:before,
.homepage-banner .content:after {
  display: table;
  content: " ";
}
.homepage-banner .content:after {
  clear: both;
}

/* ---- Video popup (Alpine-driven) ---- */
.homepage-banner .popup-banner-window {
  z-index: 100;
  position: fixed;
  top: 50%;
  left: 50%;
  width: 90%;
  max-width: 90%;
  transform: translate(-50%, -50%);
}
@media only screen and (min-width: 768px) {
  .homepage-banner .popup-banner-window {
    min-height: 500px;
  }
}
.homepage-banner .popup-banner-window #cboxClose.cbox-close-plain,
.homepage-banner .popup-banner-window #cboxClose {
  top: -50px;
  right: -15px;
  position: absolute;
  width: 30px;
  height: 30px;
  background: transparent;
  border: 0;
  cursor: pointer;
}
.homepage-banner .popup-banner-window #cboxClose:before,
.homepage-banner .popup-banner-window #cboxClose:after {
  content: '';
  position: absolute;
  left: 14px;
  top: 0;
  height: 30px;
  width: 2px;
  background: var(--color-white);
}
.homepage-banner .popup-banner-window #cboxClose:before { transform: rotate(45deg); }
.homepage-banner .popup-banner-window #cboxClose:after { transform: rotate(-45deg); }

.homepage-banner .popup-banner-overlay {
  visibility: visible;
  z-index: 99;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--color-black);
  cursor: pointer;
  opacity: 0.85;
}

.homepage-banner iframe {
  width: 100%;
  height: auto;
  min-height: 250px;
  border: 0;
}
@media only screen and (min-width: 768px) {
  .homepage-banner iframe {
    min-height: 500px;
  }
}

/* ---- Gradient banner + layout ---- */
.homepage-banner .banner-wrapper {
  padding-top: 35px;
  padding-bottom: 35px;
  background-image: linear-gradient(45deg, var(--color-brand) 0%, var(--color-blue-700) 100%);
}
.homepage-banner .banner-wrapper .content {
  display: flex;
  flex-direction: column;
}
.homepage-banner .banner-wrapper .content.open-iframe {
  align-items: center;
}
.homepage-banner .banner-wrapper .content.open-iframe iframe {
  display: block;
}
.homepage-banner .banner-wrapper .content.open-iframe .iframe-wrapper {
  margin-top: 0;
}
.homepage-banner .banner-wrapper .content.open-iframe .iframe-wrapper:before,
.homepage-banner .banner-wrapper .content.open-iframe .iframe-wrapper:after {
  display: none;
}
.homepage-banner .banner-wrapper .content .iframe-wrapper {
  position: relative;
  width: 100%;
  height: 300px;
  cursor: pointer;
}
.homepage-banner .banner-wrapper .content .iframe-wrapper img {
  height: 100%;
  width: 100%;
  object-fit: contain;
}
.homepage-banner .banner-wrapper .content .iframe-wrapper .play-button {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100px;
  height: 100px;
  padding: 0;
  background: transparent;
  border: 0;
  color: var(--color-white);
  transform: translate(-50%, -50%);
  cursor: pointer;
}
.homepage-banner .banner-wrapper .content .iframe-wrapper .play-button i {
  font-size: 100px;
  text-shadow: 2px 2px #8080807a;
  transition: text-shadow 0.1s linear;
}
.homepage-banner .banner-wrapper .content .iframe-wrapper .play-button:hover i {
  text-shadow: 3px 2px #8080807a;
}
.homepage-banner .banner-wrapper .content .left {
  text-align: center;
}
.homepage-banner .banner-wrapper .content .title {
  margin-bottom: 24px;
}
.homepage-banner .banner-wrapper .content .title h2 {
  font-size: 24px;
  line-height: 32px;
  letter-spacing: 0;
  font-weight: 700;
  text-transform: inherit;
  margin: 0;
  color: var(--color-white);
}
@media only screen and (min-width: 768px) {
  .homepage-banner .banner-wrapper .content .title h2 {
    font-size: 34px;
    line-height: 42px;
    margin: 0;
    color: var(--color-white);
  }
}
.homepage-banner .banner-wrapper .content .subtitle,
.homepage-banner .banner-wrapper .content .subtitle * {
  font-size: 16px;
  line-height: 22px;
  letter-spacing: 0.1px;
  font-weight: 400;
  color: var(--color-white);
}
.homepage-banner .banner-wrapper .content .subtitle p {
  margin: 0 0 10px;
}
.homepage-banner .banner-wrapper .content .subtitle p:last-child {
  margin-bottom: 0;
}
.homepage-banner .banner-wrapper .content .subtitle a {
  text-decoration: underline;
  color: var(--color-white);
}
.homepage-banner .banner-wrapper .content .additional-info,
.homepage-banner .banner-wrapper .content .additional-info * {
  font-size: 14px;
  line-height: 20px;
  letter-spacing: 0.1px;
  font-weight: 400;
  color: var(--color-white);
  text-align: center;
}
.homepage-banner .banner-wrapper .content .button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 50px 0 20px;
  padding: 15px 20px;
  background: var(--color-teal-300);
  border-radius: var(--radius-lg);
  box-shadow: 0 0 0 5px rgba(96, 216, 172, 0.4);
  transition: 0.3s linear;
}
.homepage-banner .banner-wrapper .content .button:hover {
  box-shadow: none;
  transition: 0.3s linear;
}
.homepage-banner .banner-wrapper .content .button a {
  display: inline-block;
  width: 100%;
  padding: 0;
  color: var(--color-white);
  font-weight: 700;
  font-size: 16px;
  line-height: 20px;
  letter-spacing: 0.28px;
  text-align: center;
  text-transform: uppercase;
}

@media only screen and (min-width: 993px) {
  .homepage-banner .banner-wrapper .content {
    flex-direction: row;
    justify-content: space-between;
  }
  .homepage-banner .banner-wrapper .content .title {
    margin-bottom: 28px;
  }
  .homepage-banner .banner-wrapper .content .button {
    margin: 10px 0 15px;
  }
  .homepage-banner .banner-wrapper .content .left,
  .homepage-banner .banner-wrapper .content .right {
    width: 47%;
    text-align: left;
  }
  .homepage-banner .banner-wrapper .content .iframe-wrapper {
    height: 100%;
    margin-top: 10px;
    position: absolute;
    /* No transform here: this element is the Alpine root that contains the
       position:fixed video overlay + popup window, and a transformed ancestor
       becomes their containing block — which trapped the backdrop inside this
       47%-wide column and pushed the modal off-centre. `height:100%` already
       fills the banner row, so `top:0` centres the thumbnail without a
       transform and lets the popup resolve against the viewport. */
    top: 0;
    right: 0;
    width: 47%;
  }
}
