/* Respiro vertical da secao do video entre problema e jornada. */
.video-section {
  padding: 122px 0 136px;
}

/* Shell centraliza o card dentro da largura padrao do projeto. */
.video-shell {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  display: flex;
  justify-content: center;
}

/* O card inline mantem a mesma largura-base da capa anterior. */
.video-trigger {
  position: relative;
  display: block;
  width: min(100%, 824px);
}

/* O frame preserva a proporcao do node desktop e recorta o embed. */
.video-trigger__surface {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 824 / 476;
  overflow: hidden;
  border-radius: 60px;
  background: #0f172a;
}

/* A capa volta a ocupar o card inteiro ate o clique do usuario. */
.video-trigger__cover {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.video-trigger__cover[hidden] {
  display: none;
}

/* Base clara sob as camadas da capa. */
.video-trigger__base {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: rgba(226, 232, 240, 0.5);
}

/* Camadas visuais reconstruindo a thumbnail anterior. */
.video-trigger__layer {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  pointer-events: none;
}

.video-trigger__layer--front {
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.video-trigger__logo {
  position: absolute;
  left: 8.37%;
  top: 42.45%;
  width: 31.68%;
  height: 14.89%;
}

.video-trigger__logo img {
  width: 100%;
  height: 100%;
  display: block;
}

.video-trigger__play {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14.08%;
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
}

.video-trigger__play img {
  width: 100%;
  height: 100%;
  display: block;
}

.video-trigger__cover:focus-visible {
  outline: 4px solid rgba(87, 212, 255, 0.9);
  outline-offset: -8px;
}

/* O iframe ocupa toda a area antes usada pela imagem de capa. */
.video-trigger__iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  background: #000000;
}

.video-trigger__iframe[hidden] {
  display: none;
}

/* Overlay fixo do modal cobrindo a viewport inteira. */
.video-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

/* O atributo hidden precisa vencer o display definido no CSS da secao. */
.video-modal[hidden],
.video-modal__iframe[hidden],
.video-modal__player[hidden],
.video-modal__placeholder[hidden] {
  display: none;
}

/* Fundo escuro clicavel para fechar o modal. */
.video-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(15, 23, 42, 0.76);
  cursor: pointer;
}

/* Janela principal do modal. */
.video-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(960px, 100%);
  border-radius: 32px;
  background: #ffffff;
  box-shadow: 0 32px 80px rgba(15, 23, 42, 0.28);
  overflow: hidden;
}

/* Cabecalho com titulo e botao de fechar. */
.video-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 24px 0;
}

.video-modal__title {
  margin: 0;
  color: #1e293b;
  font-family: "Muring Display", system-ui, sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.2;
}

/* Botao circular de fechamento. */
.video-modal__close {
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  border: 0;
  border-radius: 50%;
  background: rgba(132, 92, 255, 0.12);
  color: #845cff;
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
}

/* Corpo do modal com espacamento interno. */
.video-modal__body {
  padding: 20px 24px 24px;
}

/* Area do video com proporcao do thumbnail. */
.video-modal__frame {
  position: relative;
  width: 100%;
  aspect-ratio: 824 / 476;
  border-radius: 24px;
  overflow: hidden;
  background: #0f172a;
}

/* Iframe e player ocupam toda a area quando ativos. */
.video-modal__iframe,
.video-modal__player {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  background: #000000;
}

/* Placeholder visivel enquanto o link do video nao estiver configurado. */
.video-modal__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  color: #ffffff;
  font-family: "Muring Text", system-ui, sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.47;
  text-align: center;
}

/* Tablet: mantem a centralizacao e reduz o respiro lateral. */
@media (max-width: 1180px) {
  .video-section {
    padding: 96px 0 108px;
  }

  .video-shell {
    width: min(720px, calc(100% - 48px));
  }
}

/* Mobile fiel ao node 924:3872, com raio e largura do frame do Figma. */
@media (max-width: 480px) {
  .video-section {
    padding: 86px 0 104px;
  }

  .video-shell {
    width: min(335px, calc(100% - 40px));
  }

  .video-trigger {
    width: 327px;
  }

  .video-trigger__surface {
    border-radius: 23.811px;
  }

  .video-trigger__cover:focus-visible {
    outline-width: 3px;
    outline-offset: -4px;
  }

  .video-modal {
    padding: 16px;
  }

  .video-modal__dialog {
    border-radius: 24px;
  }

  .video-modal__header {
    padding: 18px 18px 0;
  }

  .video-modal__title {
    font-size: 18px;
  }

  .video-modal__close {
    width: 40px;
    height: 40px;
    flex-basis: 40px;
    font-size: 24px;
  }

  .video-modal__body {
    padding: 16px 18px 18px;
  }

  .video-modal__frame {
    border-radius: 18px;
  }

  .video-modal__placeholder {
    font-size: 15px;
  }
}
