﻿/* Container principal da hero em desktop, com a largura do frame do Figma. */
.hero {
  /* right max(-90px, calc(50vw - 730.5px)):
     - em 1281px (frame do Figma): max(-90, -90) = -90px  ← igual ao original
     - em 1920px: max(-90, +229px) = +229px  ← imagem recua junto ao frame
     - abaixo de 1281px: sempre -90px (hero-frame já cobre com #fafafa no tablet/mobile) */
  background: url("../assets/figma/background-hero.png") no-repeat bottom
    right max(-310px, calc(35vw - 730.5px));
}
.hero-frame {
  width: 1281px;
  max-width: 100%;
  height: 919px;
  margin: 0 auto;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  position: relative;
}

/* Coluna esquerda: logo + conteúdo textual + CTA. */
.hero-copy {
  width: 617px;
  height: 818px;
  display: flex;
  flex-direction: column;
  gap: 100px;
}

/* Logo da marca no tamanho do frame desktop. */
.hero-logo-link {
  display: block;
  width: fit-content;
  text-decoration: none;
}

.hero-logo {
  width: 210px;
  height: 57px;
  aspect-ratio: 210 / 57;
  display: block;
  object-fit: contain;
}

/* Agrupa texto e botão com o espaçamento vertical do layout. */
.hero-content {
  width: 617px;
  display: flex;
  flex-direction: column;
  gap: 60px;
}

/* Bloco interno para título, descrição, imagem mobile e checklist. */
.hero-text {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Título principal com o gradiente azul-roxo do Figma aplicado no texto. */
.hero-title {
  margin: 0;
  font-family: "Muring Display", system-ui, sans-serif;
  font-size: 60px;
  font-weight: 700;
  line-height: 1.356;
  letter-spacing: 1.2px;
  background-image: linear-gradient(164.4189deg, #57d4ff 0%, #845cff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Quebra do título em duas linhas no desktop. */
.hero-title span {
  display: block;
}

/* Texto de apoio abaixo do título. */
.hero-description {
  width: 527.522px;
  margin: 0;
  color: var(--text);
  font-size: 24px;
  line-height: 1.42;
  letter-spacing: 0.72px;
}

/* Destaque da palavra Doctor24 dentro da descrição. */
.hero-description strong {
  font-family: "Muring Display", system-ui, sans-serif;
  font-weight: 700;
}

/* Lista vertical de benefícios da seção. */
.hero-points {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Cada linha do checklist com ícone e tipografia de apoio. */
.hero-point {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-family: "Muring Display", system-ui, sans-serif;
  font-size: 24px;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0.72px;
}

/* Ícone do check usado em cada benefício. */
.hero-point img {
  width: 26px;
  height: 19px;
  flex: 0 0 26px;
}

/* CTA da hero usando o componente comum na variante escura. */
.hero-cta {
  width: 328.612px;
}

/* Texto interno do CTA com a largura específica do hero. */
.hero-cta-label {
  width: 240px;
}

/* Wrapper e imagem da seta com a escala do componente desktop. */
.hero-cta-icon,
.hero-cta-icon-img {
  width: 50px;
  height: 50px;
  flex: 0 0 50px;
}

/* Bloco visual da direita no desktop. */
.hero-visual {
  width: 565px;
  height: 837.519px;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

/* Background decorativo atrás do visual da direita, deslocado além da seção. */
.hero-visual-desktop-bg {
  position: absolute;
  top: 0;
  right: -142px;
  width: 983px;
  height: 920px;
  object-fit: cover;
  object-position: right top;
  pointer-events: none;
  z-index: 0;
}

/* Imagem principal da hero desktop. */
.hero-visual img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* Visual alternativo usado apenas em tablet/mobile. */
.hero-visual-mobile {
  display: none;
}

/* Breakpoint intermediário: aproxima o layout entre desktop e mobile para tablet. */
@media (max-width: 1024px) and (min-width: 481px) {
  /* Mantém o fundo neutro no estado tablet. */
  html,
  body {
    background: #fafafa;
  }

  /* A hero deixa de ter altura fixa e passa a empilhar o conteúdo. */
  .hero-frame {
    width: 100%;
    height: auto;
    padding: 48px 24px 0;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    background: #fafafa;
  }

  /* Coluna principal centralizada e mais estreita para tablet. */
  .hero-copy {
    width: min(100%, 720px);
    height: auto;
    gap: 34px;
    align-items: center;
  }

  /* Reduz a logo para a escala intermediária. */
  .hero-logo {
    width: 172px;
    height: auto;
  }

  /* Ajusta o espaçamento do conteúdo em modo tablet. */
  .hero-content {
    width: 100%;
    gap: 28px;
    align-items: center;
  }

  /* Centraliza e compacta o bloco textual no tablet. */
  .hero-text {
    width: 100%;
    gap: 24px;
    align-items: center;
    text-align: center;
  }

  /* Reduz o título e remove a quebra forçada em duas linhas. */
  .hero-title {
    width: min(100%, 560px);
    font-size: clamp(42px, 6.2vw, 54px);
    line-height: 1.12;
    letter-spacing: 0.72px;
  }

  /* Permite que o navegador faça a quebra do título em tablet. */
  .hero-title span {
    display: inline;
  }

  /* Descrição centralizada e mais curta para o viewport intermediário. */
  .hero-description {
    width: min(100%, 520px);
    font-size: 21px;
    line-height: 1.42;
    letter-spacing: 0.42px;
    text-align: center;
  }

  /* Esconde o visual desktop ao entrar no fluxo empilhado. */
  .hero-visual {
    display: none;
  }

  /* Remove o background decorativo grande fora da seção em tablet. */
  .hero-visual-desktop-bg {
    display: none;
  }

  /* Exibe o card visual empilhado inspirado na versão mobile. */
  .hero-visual-mobile {
    display: block;
    width: min(100%, 520px);
    aspect-ratio: 327 / 381;
    position: relative;
    border-radius: 30px;
    overflow: visible;
  }

  /* Tarja roxa por trás da imagem mobile/tablet. */
  .hero-visual-mobile::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 23.1%;
    height: 76.9%;
    border-radius: 30px;
    background: #845cff;
  }

  /* Imagem principal posicionada sobre a base roxa. */
  .hero-visual-mobile img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border-radius: 30px;
    object-fit: cover;
    object-position: center top;
  }

  /* Checklist mais estreito para manter boa leitura em tablet. */
  .hero-points {
    width: min(100%, 460px);
    align-items: flex-start;
  }

  /* Benefícios com tipografia intermediária entre desktop e mobile. */
  .hero-point {
    font-size: 19px;
    line-height: 1.3;
    letter-spacing: 0.32px;
  }

  /* CTA redimensionado para tablet e centralizado. */
  .hero-cta {
    width: 296px;
    height: auto;
    padding: 13px;
    gap: 7.5px;
    align-self: center;
  }

  /* Texto do botão em escala intermediária. */
  .hero-cta-label {
    width: 215px;
    font-size: 16px;
    letter-spacing: 0.24px;
  }

  /* Seta do botão redimensionada para tablet. */
  .hero-cta-icon,
  .hero-cta-icon-img {
    width: 44px;
    height: 44px;
    flex-basis: 44px;
  }
}

/* Breakpoint mobile fiel ao frame mobile do Figma. */
@media (max-width: 480px) {
  /* Mantém o fundo do app no mobile. */
  html,
  body {
    background: #fafafa;
  }

  /* Libera largura mínima fixa no celular. */
  body {
    min-width: 0;
  }

  /* A seção passa a ser uma coluna compacta centralizada. */
  .hero-frame {
    width: 100%;
    height: auto;
    padding: 42px 1px 0;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    background: #fafafa;
  }

  /* Largura exata do conteúdo mobile do Figma. */
  .hero-copy {
    width: 327px;
    height: auto;
    gap: 27px;
    align-items: center;
  }

  /* Logo reduzida para a versão mobile. */
  .hero-logo {
    width: 156px;
    height: 42.343px;
  }

  /* Espaçamento vertical compacto do conteúdo mobile. */
  .hero-content {
    width: 100%;
    gap: 20px;
    align-items: center;
  }

  /* Texto centralizado seguindo o frame mobile. */
  .hero-text {
    width: 100%;
    gap: 20px;
    align-items: center;
    text-align: center;
  }

  /* Título em escala mobile. */
  .hero-title {
    width: 313px;
    font-size: 30px;
    line-height: 1.356;
    letter-spacing: 0.6px;
  }

  /* Remove a quebra rígida do desktop no celular. */
  .hero-title span {
    display: inline;
  }

  /* Descrição compacta e centralizada. */
  .hero-description {
    width: 313px;
    font-size: 16px;
    line-height: 1.42;
    letter-spacing: 0.48px;
    text-align: center;
  }

  /* Oculta completamente o visual lateral desktop no celular. */
  .hero-visual {
    display: none;
  }

  /* Oculta o background decorativo desktop no celular. */
  .hero-visual-desktop-bg {
    display: none;
  }

  /* Exibe a composição mobile da imagem dentro do fluxo. */
  .hero-visual-mobile {
    display: block;
    width: 327px;
    height: 381px;
    position: relative;
    border-radius: 30px;
    overflow: visible;
  }

  /* Base roxa do card visual mobile. */
  .hero-visual-mobile::before {
    content: "";
    position: absolute;
    left: 0;
    top: 88px;
    width: 327px;
    height: 293px;
    border-radius: 30px;
    background: #845cff;
  }

  /* Imagem mobile no tamanho exato do mockup. */
  .hero-visual-mobile img {
    position: absolute;
    inset: 0;
    width: 327px;
    height: 381px;
    border-radius: 30px;
    object-fit: cover;
    object-position: center top;
  }

  /* Lista de benefícios ocupando toda a largura útil. */
  .hero-points {
    width: 100%;
    gap: 10px;
    align-items: flex-start;
    margin-left: 30px;
  }

  /* Tipografia reduzida para leitura em celular. */
  .hero-point {
    gap: 8px;
    font-size: 16px;
    line-height: 1.3;
    letter-spacing: 0.48px;
  }

  /* Mantém o tamanho do ícone de check no mobile. */
  .hero-point img {
    width: 26px;
    height: 19px;
  }

  /* CTA no tamanho do componente mobile do Figma. */
  .hero-cta {
    width: 272.308px;
    height: auto;
    padding: 12.43px;
    gap: 7.136px;
    align-self: center;
  }

  /* Texto do CTA na escala mobile. */
  .hero-cta-label {
    width: 198.879px;
    font-size: 14.92px;
    letter-spacing: 0.2984px;
  }

  /* Wrapper e imagem da seta no tamanho mobile. */
  .hero-cta-icon,
  .hero-cta-icon-img {
    width: 41.433px;
    height: 41.433px;
    flex-basis: 41.433px;
  }
}
