/* VILIANTE INNER PAGE HERO FINAL v1 */
/*
  Canonical shared hero system for Viliante inner pages.

  Target contract:
  <section class="viliante-inner-page-hero viliante-inner-page-hero--PAGE">
    <picture class="viliante-inner-page-hero-media">...</picture>
    <div class="viliante-inner-page-hero-overlay"></div>
    <div class="container viliante-inner-page-hero-content">
      <span class="viliante-inner-page-hero-kicker">...</span>
      <h1>...</h1>
      <p>...</p>
    </div>
  </section>

  Owner:
  - hero layout
  - hero image behavior
  - overlay
  - hero text color
  - mobile/tablet hero behavior

  Page-specific CSS should not own hero text color/layout.
*/

/* Base */
.viliante-inner-page-hero{
  position:relative !important;
  min-height:100vh !important;
  height:100vh !important;
  overflow:hidden !important;
  margin:0 !important;
  padding:0 !important;
  background:#071225 !important;
  isolation:isolate !important;
}

.viliante-inner-page-hero-media{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  display:block !important;
  margin:0 !important;
  padding:0 !important;
  z-index:0 !important;
}

.viliante-inner-page-hero-media img{
  width:100% !important;
  height:100% !important;
  min-width:100% !important;
  min-height:100% !important;
  display:block !important;
  object-fit:cover !important;
  object-position:center center !important;
  transform:none !important;
  filter:none !important;
}

.viliante-inner-page-hero-overlay{
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  pointer-events:none !important;
  background:
    linear-gradient(90deg, rgba(7,18,37,.76) 0%, rgba(7,18,37,.48) 44%, rgba(7,18,37,.18) 100%),
    linear-gradient(180deg, rgba(7,18,37,.08) 0%, rgba(7,18,37,.38) 100%) !important;
}

.viliante-inner-page-hero::before,
.viliante-inner-page-hero::after{
  content:none !important;
  display:none !important;
}

.viliante-inner-page-hero-content{
  position:absolute !important;
  z-index:2 !important;
  left:clamp(32px, 7vw, 128px) !important;
  right:clamp(24px, 5vw, 72px) !important;
  bottom:clamp(72px, 12vh, 132px) !important;
  max-width:1120px !important;
  margin:0 !important;
  padding:0 !important;
  color:#ffffff !important;
}

.viliante-inner-page-hero-kicker{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:max-content !important;
  max-width:100% !important;
  margin:0 0 42px !important;
  padding:13px 26px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.92) !important;
  border:1px solid rgba(255,255,255,.72) !important;
  color:#1559b7 !important;
  -webkit-text-fill-color:#1559b7 !important;
  font-family:Manrope, Inter, system-ui, sans-serif !important;
  font-size:12px !important;
  font-weight:800 !important;
  line-height:1 !important;
  letter-spacing:.16em !important;
  text-transform:uppercase !important;
  text-shadow:none !important;
  box-shadow:0 14px 36px rgba(8,12,20,.16) !important;
}

.viliante-inner-page-hero-content h1{
  max-width:980px !important;
  margin:0 0 34px !important;
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
  font-family:Manrope, Inter, system-ui, sans-serif !important;
  font-size:clamp(58px, 7.1vw, 112px) !important;
  font-weight:800 !important;
  line-height:.92 !important;
  letter-spacing:-.065em !important;
  text-shadow:0 4px 24px rgba(0,0,0,.42) !important;
}

.viliante-inner-page-hero-content p{
  max-width:820px !important;
  margin:0 !important;
  color:rgba(255,255,255,.92) !important;
  -webkit-text-fill-color:rgba(255,255,255,.92) !important;
  font-family:Manrope, Inter, system-ui, sans-serif !important;
  font-size:clamp(17px, 1.25vw, 22px) !important;
  font-weight:500 !important;
  line-height:1.55 !important;
  letter-spacing:-.01em !important;
  text-shadow:0 3px 18px rgba(0,0,0,.36) !important;
}

/* Desktop refinements */
@media (min-width:1025px){
  .viliante-inner-page-hero{
    min-height:100vh !important;
    height:100vh !important;
  }

  .viliante-inner-page-hero--benefits .viliante-inner-page-hero-media img{
    object-position:center center !important;
  }
}

/* Mobile/tablet */
@media (max-width:1024px){
  .viliante-inner-page-hero{
    min-height:calc(100svh - 0px) !important;
    height:100svh !important;
  }

  .viliante-inner-page-hero-overlay{
    background:
      linear-gradient(180deg, rgba(7,18,37,.18) 0%, rgba(7,18,37,.46) 48%, rgba(7,18,37,.74) 100%) !important;
  }

  .viliante-inner-page-hero-content{
    left:24px !important;
    right:24px !important;
    bottom:76px !important;
    max-width:none !important;
  }

  .viliante-inner-page-hero-kicker{
    margin-bottom:28px !important;
    padding:12px 22px !important;
    font-size:11px !important;
    letter-spacing:.14em !important;
  }

  .viliante-inner-page-hero-content h1{
    max-width:92vw !important;
    margin-bottom:24px !important;
    font-size:clamp(42px, 10vw, 76px) !important;
    line-height:.94 !important;
    letter-spacing:-.06em !important;
  }

  .viliante-inner-page-hero-content p{
    max-width:92vw !important;
    font-size:clamp(15px, 4vw, 18px) !important;
    line-height:1.45 !important;
  }
}

@media (max-width:430px){
  .viliante-inner-page-hero-content{
    left:20px !important;
    right:20px !important;
    bottom:64px !important;
  }

  .viliante-inner-page-hero-kicker{
    margin-bottom:22px !important;
  }

  .viliante-inner-page-hero-content h1{
    font-size:clamp(38px, 11.5vw, 54px) !important;
    margin-bottom:18px !important;
  }

  .viliante-inner-page-hero-content p{
    font-size:15px !important;
  }
}

/* Safety net: canonical hero text must always render on first paint.
   Neutralizes any global reveal class (.viliante-reveal) applied inside the hero. */
.viliante-inner-page-hero .viliante-reveal{
  opacity:1 !important;
  transform:none !important;
  filter:none !important;
}
