/* =========================================================
   CAREKA DIGITAL — V105 HERO LAYOUT EXATO COM VÍDEO
   Objetivo:
   - reproduzir o layout aprovado do print;
   - manter vídeo real no fundo;
   - título, legenda, CTA e card institucional perfeitamente visíveis;
   - comportamento responsivo para smartphone, tablet, notebook e desktop.
   ========================================================= */

:root{
  --ck105-header-h: 86px;
  --ck105-gold: #F5A623;
  --ck105-gold-soft: #FFD76A;
  --ck105-orange: #E7791F;
  --ck105-white: #F9F4EC;
  --ck105-muted: rgba(249,244,236,.90);
  --ck105-line: rgba(245,166,35,.20);
  --ck105-line-strong: rgba(245,166,35,.34);
  --ck105-shadow: 0 28px 90px rgba(0,0,0,.42);
}

html body #hero.ckHeroV103{
  position: relative !important;
  isolation: isolate !important;
  width: 100% !important;
  max-width: 100vw !important;
  min-height: calc(100svh - var(--ck105-header-h)) !important;
  margin: 0 !important;
  padding: clamp(12px, 1.2vw, 18px) clamp(18px, 2.25vw, 34px) clamp(20px, 2vw, 30px) !important;
  overflow: hidden !important;
  background: #020202 !important;
  border: 0 !important;
}

html body #hero.ckHeroV103 > .ckHeroFinal__video{
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
  filter: brightness(.48) contrast(1.08) saturate(1.03) !important;
  transform: scale(1.02) !important;
  opacity: 1 !important;
}

html body #hero.ckHeroV103 > .ckHeroFinal__overlay{
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(0,0,0,.92) 0%, rgba(0,0,0,.82) 31%, rgba(0,0,0,.54) 58%, rgba(0,0,0,.74) 100%),
    linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.26) 52%, rgba(0,0,0,.50) 100%),
    radial-gradient(900px 500px at 72% 54%, rgba(245,166,35,.12), transparent 70%) !important;
}

html body #hero.ckHeroV103::before{
  content: "" !important;
  position: absolute !important;
  inset: clamp(12px,1.2vw,18px) clamp(18px,2.25vw,34px) clamp(20px,2vw,30px) !important;
  z-index: 1 !important;
  border: 1px solid rgba(245,166,35,.12) !important;
  border-radius: 0 0 26px 26px !important;
  pointer-events: none !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03) !important;
}

html body #hero.ckHeroV103 > .ckHeroFinal__layout{
  position: relative !important;
  z-index: 3 !important;
  width: min(100%, 1620px) !important;
  min-height: calc(100svh - var(--ck105-header-h) - clamp(32px, 3.2vw, 48px)) !important;
  margin: 0 auto !important;
  padding: clamp(42px, 4.2vw, 70px) clamp(28px, 2.2vw, 40px) clamp(28px, 2vw, 36px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .92fr) !important;
  grid-template-rows: 1fr auto !important;
  gap: clamp(26px, 2.2vw, 34px) clamp(44px, 3.8vw, 80px) !important;
  align-items: stretch !important;
  align-content: stretch !important;
  overflow: visible !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__copy{
  grid-column: 1 !important;
  grid-row: 1 !important;
  align-self: center !important;
  width: min(100%, 920px) !important;
  max-width: 920px !important;
  display: grid !important;
  gap: clamp(18px, 1.8vw, 26px) !important;
  margin: 0 !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__copy h1{
  margin: 0 !important;
  color: var(--ck105-white) !important;
  font-family: var(--font-display, "Anton", "Bebas Neue", Impact, sans-serif) !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .01em !important;
  line-height: .91 !important;
  font-size: clamp(64px, 5.3vw, 90px) !important;
  max-width: none !important;
  text-wrap: initial !important;
  text-shadow: 0 20px 50px rgba(0,0,0,.52) !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__copy h1 span{
  color: var(--ck105-gold) !important;
  background: linear-gradient(180deg, var(--ck105-gold-soft) 0%, var(--ck105-gold) 55%, var(--ck105-orange) 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__copy h1 .ckHeroFinal__titleLine{
  display: block !important;
  white-space: nowrap !important;
  background: none !important;
  -webkit-background-clip: border-box !important;
  background-clip: border-box !important;
  -webkit-text-fill-color: var(--ck105-white) !important;
  color: var(--ck105-white) !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__copy h1 .ckHeroFinal__titleLine > span{
  color: var(--ck105-gold) !important;
  background: linear-gradient(180deg, var(--ck105-gold-soft) 0%, var(--ck105-gold) 55%, var(--ck105-orange) 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__copy p{
  margin: 0 !important;
  width: min(100%, 790px) !important;
  max-width: 790px !important;
  color: var(--ck105-muted) !important;
  font-size: clamp(17px, 1.08vw, 22px) !important;
  line-height: 1.58 !important;
  font-weight: 600 !important;
  letter-spacing: -.02em !important;
  text-shadow: 0 10px 26px rgba(0,0,0,.42) !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__cta{
  position: relative !important;
  width: min(100%, 460px) !important;
  min-height: 74px !important;
  padding: 0 78px 0 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255,215,106,.40) !important;
  background: linear-gradient(135deg, #FFD76A 0%, #F5B935 40%, #E78322 100%) !important;
  color: #070707 !important;
  font-size: clamp(13px, .86vw, 16px) !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  letter-spacing: .10em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  box-shadow: 0 16px 44px rgba(245,166,35,.18), inset 0 1px 0 rgba(255,255,255,.32) !important;
  transition: transform .24s ease, box-shadow .24s ease, filter .24s ease !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__cta::after{
  content: "→" !important;
  position: absolute !important;
  right: 28px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  color: #0a0a0a !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__cta:hover,
html body #hero.ckHeroV103 .ckHeroFinal__cta:focus-visible{
  transform: translateY(-2px) !important;
  filter: brightness(1.03) saturate(1.03) !important;
  box-shadow: 0 20px 54px rgba(245,166,35,.24), inset 0 1px 0 rgba(255,255,255,.40) !important;
  outline: none !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__card{
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  align-self: end !important;
  justify-self: end !important;
  position: relative !important;
  width: min(100%, 950px) !important;
  max-width: 950px !important;
  margin: 0 !important;
  padding: clamp(16px, 1.2vw, 22px) !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 1fr) minmax(360px, .92fr) !important;
  gap: clamp(18px, 1.6vw, 26px) !important;
  border-radius: 24px !important;
  border: 1px solid var(--ck105-line-strong) !important;
  background: linear-gradient(135deg, rgba(11,11,11,.80), rgba(7,7,7,.72)) !important;
  box-shadow: var(--ck105-shadow), inset 0 1px 0 rgba(255,255,255,.05) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  overflow: hidden !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__card::before{
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0) 32%), linear-gradient(90deg, rgba(245,166,35,.04), transparent 36%) !important;
  pointer-events: none !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__identity,
html body #hero.ckHeroV103 .ckHeroFinal__meta{
  position: relative !important;
  z-index: 1 !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__identity{
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 122px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 18px !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__photo{
  width: 122px !important;
  height: 122px !important;
  object-fit: cover !important;
  border-radius: 18px !important;
  border: 1px solid rgba(245,166,35,.28) !important;
  box-shadow: 0 14px 36px rgba(0,0,0,.28) !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__person{
  min-width: 0 !important;
  display: grid !important;
  gap: 6px !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__person b,
html body #hero.ckHeroV103 .ckHeroFinal__metaItem b{
  display: block !important;
  margin: 0 !important;
  color: var(--ck105-gold-soft) !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__person strong{
  display: block !important;
  margin: 0 !important;
  color: var(--ck105-white) !important;
  font-family: var(--font-display, "Anton", "Bebas Neue", Impact, sans-serif) !important;
  font-size: clamp(34px, 2.4vw, 48px) !important;
  line-height: .92 !important;
  letter-spacing: .01em !important;
  text-transform: uppercase !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__person span,
html body #hero.ckHeroV103 .ckHeroFinal__metaItem span,
html body #hero.ckHeroV103 .ckHeroFinal__metaItem small{
  display: block !important;
  margin: 0 !important;
  color: rgba(249,244,236,.92) !important;
  font-size: clamp(14px, .9vw, 18px) !important;
  line-height: 1.48 !important;
  font-weight: 600 !important;
  letter-spacing: -.015em !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__meta{
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 0 !important;
  align-items: stretch !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__metaItem{
  min-width: 0 !important;
  padding: 10px 22px !important;
  display: grid !important;
  align-content: center !important;
  gap: 12px !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__metaItem:first-child{
  border-left: 1px solid rgba(245,166,35,.28) !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__metaItem + .ckHeroFinal__metaItem{
  border-left: 1px solid rgba(245,166,35,.28) !important;
}

html body #hero.ckHeroV103 .ckHeroFinal__metaItem:last-child span,
html body #hero.ckHeroV103 .ckHeroFinal__metaItem:last-child small{
  white-space: nowrap !important;
}

@media (max-width: 1480px){
  html body #hero.ckHeroV103 > .ckHeroFinal__layout{
    grid-template-columns: minmax(0,1fr) minmax(300px,.82fr) !important;
    padding-inline: clamp(24px, 2vw, 34px) !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy h1{
    font-size: clamp(58px, 4.7vw, 82px) !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__card{
    width: min(100%, 900px) !important;
  }
}

@media (max-width: 1220px){
  html body #hero.ckHeroV103{
    min-height: auto !important;
  }

  html body #hero.ckHeroV103 > .ckHeroFinal__layout{
    min-height: auto !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    padding-top: clamp(34px, 4vw, 48px) !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy{
    width: min(100%, 900px) !important;
    max-width: 900px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy h1{
    max-width: none !important;
    font-size: clamp(52px, 6vw, 72px) !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__card{
    justify-self: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
  }
}

@media (max-width: 860px){
  html body #hero.ckHeroV103{
    padding: 10px 14px 18px !important;
  }

  html body #hero.ckHeroV103::before{
    inset: 10px 14px 18px !important;
    border-radius: 0 0 22px 22px !important;
  }

  html body #hero.ckHeroV103 > .ckHeroFinal__layout{
    padding: 28px 18px 20px !important;
    gap: 22px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy h1{
    font-size: clamp(34px, 7vw, 52px) !important;
    max-width: none !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy p{
    font-size: 16px !important;
    line-height: 1.56 !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__cta{
    width: min(100%, 420px) !important;
    min-height: 66px !important;
    padding: 0 68px 0 22px !important;
    border-radius: 16px !important;
    font-size: 13px !important;
    letter-spacing: .08em !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__cta::after{
    right: 22px !important;
    font-size: 28px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__card{
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    padding: 16px !important;
    border-radius: 20px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__identity{
    grid-template-columns: 88px minmax(0,1fr) !important;
    gap: 14px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__photo{
    width: 88px !important;
    height: 88px !important;
    border-radius: 14px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__person strong{
    font-size: clamp(28px, 7vw, 40px) !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__meta{
    grid-template-columns: 1fr 1fr !important;
    border-top: 1px solid rgba(245,166,35,.18) !important;
    padding-top: 4px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__metaItem:first-child{
    border-left: 0 !important;
  }
}

@media (max-width: 560px){
  html body #hero.ckHeroV103{
    min-height: auto !important;
    padding: 8px 10px 16px !important;
  }

  html body #hero.ckHeroV103::before{
    inset: 8px 10px 16px !important;
    border-radius: 0 0 18px 18px !important;
  }

  html body #hero.ckHeroV103 > .ckHeroFinal__layout{
    min-height: auto !important;
    padding: 22px 14px 16px !important;
    gap: 18px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy{
    gap: 16px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy h1{
    font-size: clamp(28px, 7.8vw, 40px) !important;
    line-height: .92 !important;
    letter-spacing: 0 !important;
    max-width: none !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__copy p{
    font-size: 15px !important;
    line-height: 1.58 !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__cta{
    width: 100% !important;
    min-height: 62px !important;
    padding: 0 56px 0 18px !important;
    font-size: 12px !important;
    letter-spacing: .06em !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__cta::after{
    right: 18px !important;
    font-size: 24px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__meta{
    grid-template-columns: 1fr !important;
    padding-top: 6px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__metaItem{
    padding: 12px 0 !important;
    gap: 8px !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__metaItem + .ckHeroFinal__metaItem{
    border-left: 0 !important;
    border-top: 1px solid rgba(245,166,35,.20) !important;
  }

  html body #hero.ckHeroV103 .ckHeroFinal__metaItem:last-child span,
  html body #hero.ckHeroV103 .ckHeroFinal__metaItem:last-child small{
    white-space: normal !important;
  }
}
