/* ===================================
   CSS Variables & Reset
   =================================== */
:root {
    /* Colors */
    --primary-color: #277ED5;
    --primary-hover: #005a9e;
    --secondary-color: #27d045;
    --text-dark: #0a0a0a;
    --text-medium: #4a4a4a;
    --text-light: #6a6a6a;
    --bg-light: #ffffff;
    --bg-white: #ffffff;
    --border-color: #e0e0e0;
    --highlight-bg: #ffffff;
    --price-blue: #C7DCE8;
    
    /* Spacing */
    --container-max: 1140px;
    --spacing-xs: 0.5rem;
    --spacing-sm: 1rem;
    --spacing-md: 2rem;
    --spacing-lg: 3rem;
    --spacing-xl: 4rem;
    
    /* Typography */
    --font-family: 'Montserrat', sans-serif;
    --font-size-base: 16px;
    --line-height-base: 1.6;
}

@font-face {
  font-family: 'Montserrat';
  src: url('../font/Montserrat-VariableFont_wght.woff2') format('woff2');
  font-weight: 100 900;   /* intervalo completo */
  font-style: normal;
  font-display: swap;
}


* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: var(--font-size-base);
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-family);
    line-height: var(--line-height-base);
    color: var(--text-dark);
    background-color: var(--bg-white);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    text-decoration: none;
    color: inherit;
}

button {
    font-family: inherit;
    cursor: pointer;
}

/* ===================================
   Container & Layout
   =================================== */
.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--spacing-sm);
}

section {
    padding: var(--spacing-lg) 0;
}

/* ===================================
   Typography
   =================================== */
.section-title {
    font-size: clamp(3rem, 4vw, 2.5rem);
    font-weight: 500;
    text-align: center;
    margin-bottom: var(--spacing-md);
    color: var(--text-dark);
    line-height: 48px;
}

/* ===================================
   Buttons
   =================================== */
.btn {
    display: inline-block;
    padding: 1rem 2rem;
    font-size: 1rem;
    font-weight: 600;
    text-align: center;
    border: none;
    border-radius: 50px;
    transition: all 0.3s ease;
    cursor: pointer;
}

.btn-primary {
    background-color: var(--primary-color);
    color: white;
}

.btn-large {
    padding: 1.25rem 2.5rem;
    font-size: 1.125rem;
}

.btn-whatsapp {
    background-color: var(--secondary-color);
    color: white;
}

.btn-whatsapp:hover {
    background-color: #1fb838;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(39, 208, 69, 0.3);
}

.logo {
    max-width: 200px;
    margin: 0 auto;
    margin-bottom: 24px;
}

/* ===================================
   Hero Section
   =================================== */
.hero {
    background-color: var(--bg-light);
    text-align: center;
}

.hero__title {
    font-size: clamp(1.75rem, 5vw, 3rem);
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    line-height: 1.2;
    color: var(--text-dark);
}

.hero__subtitle {
    font-size: 20px;
    line-height: 30px;
    font-weight: 400;
    color: var(--text-medium);
    margin-bottom: var(--spacing-lg);
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
}

.hero__video {
  margin: var(--spacing-lg) 0;
}

.video-wrapper {
  position: relative;
  width: 80%;
  margin: 0 auto;
  aspect-ratio: 16 / 9; /* forma moderna e mais simples */
  background: #000;
  overflow: hidden;
}

.video-wrapper iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

/* 3 colunas no desktop */
.hero__features{
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  margin-top: var(--spacing-xl);
}

@media (min-width: 900px){
  .hero__features{
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Item: ícone + texto */
.feature-card{
  display: grid;
  grid-template-columns: 48px 1fr;
  column-gap: 14px;
  row-gap: 6px;
  text-align: left;
  align-items: start; /* mantém o bloco no topo; o título vai centralizar no ícone */
}

/* Ícone (coluna 1) */
.feature-card__icon{
  grid-column: 1;
  grid-row: 1 / span 2;   /* ocupa as duas linhas (titulo + descrição) */
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;    /* centro vertical */
  justify-content: center;
}

.feature-card__icon img{
  width: 36px;
  height: 36px;
  display: block;
}

/* Título alinhado ao centro do ícone */
.feature-card__title{
  grid-column: 2;
  grid-row: 1;
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 48px;  /* faz o texto “sentar” no centro do ícone */
  align-self: center; /* redundância útil */
}

/* Descrição abaixo */
.feature-card__text{
  grid-column: 2;
  grid-row: 2;
  margin: 0;
  font-size: 14px;
  line-height: 1.4;
  color: var(--text-medium);
}

.video-wrapper {
  width: 100%;
  max-width: 720px;         /* seu limite */
  margin: 0 auto;
  margin-bottom: 32px;;
}

.video-cover,
.video-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;     /* força 16:9 */
  display: block;
  overflow: hidden;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

/* botão clicável ocupa tudo */
.video-cover {
  appearance: none;
  -webkit-appearance: none;
}

/* garante que a imagem preencha 16:9 sem deformar */
.video-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;        /* recorta se necessário, mantém 16:9 */
  display: block;
}

/* iframe ocupa o mesmo 16:9 */
.video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* ícone opcional */
.play-icon {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 72px;
  height: 72px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(2px);
}

.play-icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 52%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
  border-left: 18px solid #fff;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
}



/* ===================================
   Curriculum Section
   =================================== */
.curriculum{
  background-color: var(--bg-white);
  padding: 64px 0; /* ajuste se quiser mais/menos respiro */
}

.curriculum .section-title{
  text-align: center;
  margin-bottom: 40px;
}

.curriculum__grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;              /* espaço entre as colunas no mobile */
  align-items: start;
  justify-items: center;  /* centraliza as colunas dentro do container */
}

@media (min-width: 900px){
  .curriculum__grid{
    grid-template-columns: 1fr 1fr;
    column-gap: 120px;    /* “vão” grande entre as colunas, como na imagem */
    row-gap: 0;
  }
}

.curriculum__column{
  width: 100%;
  max-width: 520px;       /* evita coluna larga demais e mantém look do print */
}

.curriculum__list{
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: center;     /* centraliza os itens */
}

.curriculum__list li{
  display: block;
  padding: 6px 0;         /* espaçamento vertical semelhante ao print */
  border: 0;              /* remove as linhas */
  font-size: 18px;
  line-height: 1.35;
}


/* ===================================
   Pricing Highlight Section
   =================================== */
.pricing-highlight {
    background-color: #F3F3F3;
    padding: 0;
}

.pricing-card {
    padding: var(--spacing-lg);
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}

.pricing-card__badge {
    background-color: #C7DCE8;
    color: #005d9d;
    padding: 8px 24px;
    border-radius: 20px;
    font-weight: 700;
    display: inline-block;
    margin-bottom: var(--spacing-sm);
    font-size: 14px;
}

.pricing-card__old-price {
    text-decoration: line-through;
    color: var(--text-dark);
    font-size: 20px;
    line-height: 24px;
    font-weight: 500;
    margin-bottom: var(--spacing-xs);
}

.pricing-card__label {
    color: var(--text-dark);
    font-size: 20px;
    line-height: 24px;
    margin-bottom: var(--spacing-sm);
}

.pricing-card__installment {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: var(--spacing-xs);
}

.installment__times {
    font-size: 24px;
    line-height: 32px;
    font-weight: 900;
    color: var(--primary-color);
}

.installment__price {
    font-size: 64px;
    font-weight: 900;
    line-height: 80px;
    color: var(--primary-color);
}

.pricing-card__full-price {
    font-size: 18px;
    line-height: 32px;
    font-weight: 700;
    margin-bottom: var(--spacing-md);
    color: var(--primary-color);
}

/* ===================================
   Showcase / Before-After Section
   =================================== */
.showcase {
    background-color: var(--bg-light);
}

.before-after__group {
    margin-bottom: var(--spacing-xl);
}

.before-after__title {
    font-size: 24px;
    font-weight: 600;
    text-align: center;
    line-height: 32px;
    margin-bottom: var(--spacing-md);
}

.before-after__images {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
}

.before-after__item h4 {
    font-size: 18px;
    font-weight: 500;
    line-height: 32px;
    margin-bottom: var(--spacing-sm);
    text-align: center;
}

.before-after__item img {
    width: 100%;
}

/* ===================================
   Gallery / Masonry Section
   =================================== */
.gallery {
    background-color: var(--bg-white);
}

.masonry-grid {
    column-count: 1;
    column-gap: 8px;
    margin-top: 8px;
}

.masonry-item {
    break-inside: avoid;
    margin-bottom: 8px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s ease;
}

.masonry-item:hover {
    transform: translateY(-4px);
}

.masonry-item__content {
    position: relative;
}

.masonry-item__image {
    width: 100%;
    display: block;
}

/* ===================================
   Bonuses Section
   =================================== */
.bonuses {
    background-color: var(--bg-light);
}

.bonus-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    background-color: #F7F7F8;
    border-radius: 12px;
    padding: 64px;

}

.bonus-card__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.bonus-card__title {
    font-family: "Montserrat", Sans-serif;
    font-size: 40px;
    font-weight: 500;
    text-transform: none;
    line-height: 48px;
}

.bonus-card__text {
    font-family: "Montserrat", Sans-serif;
    font-size: 18px;
    font-weight: 400;
    text-transform: none;
    line-height: 32px;
    margin-top: 24px;
    margin-bottom: 24px;
}

.bonus-card__image img {
    border-radius: 8px;
    width: 100%;
}

/* ===================================
   Instructor Section (fix overflow)
   =================================== */
.instructor{
  background-color: var(--bg-white);
}

.instructor__content{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-md);
  text-align: center;
}

/* garante que o bloco pode encolher no flex */
.instructor__text{
  width: 100%;
  min-width: 0;
}

/* troca width fixa por responsivo */
.instructor__greeting{
  width: 100%;
  max-width: 560px;          /* mantém o “tamanho” original no desktop */
  margin: 0;
  font-family: "Montserrat", Sans-serif;
  font-size: 18px;
  font-weight: 400;
  text-transform: none;
  line-height: 27px;
  color: var(--text-dark);
  text-align: justify;
  overflow-wrap: anywhere;   /* evita estouro por palavras longas */
  word-break: break-word;
}

@media (max-width: 600px){
  .instructor__greeting{ text-align: left; }
}

/* Não mexe em tamanho/posição da imagem; só garante que não cause overflow */
.instructor__image{
  max-width: 100%;
}
.instructor__image img{
  display: block;
  height: auto;
}


/* ===================================
   Guarantee Section (fix overflow)
   =================================== */
.guarantee{
  background-color: var(--bg-light);
}

.guarantee__content{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-lg);
  text-align: center;
}

.guarantee__text{
  width: 100%;
  min-width: 0;
}

.guarantee__text p{
  width: 100%;
  max-width: 600px;          /* mantém o “tamanho” original no desktop */
  margin: 0 auto;
  font-family: "Montserrat", Sans-serif;
  font-size: 16px;
  font-weight: 400;
  text-transform: none;
  line-height: 27px;
  color: var(--text-dark);
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* idem: sem alterar tamanho/posição da imagem */
.guarantee__badge{
  max-width: 100%;
}
.guarantee__badge img{
  display: block;
  height: auto;
}

/* ===================================
   Final Pricing Section
   =================================== */
.pricing-final {
    background-color: var(--bg-white);
    padding: var(--spacing-xl) 0;
}

.pricing-card-final{
  background-color: #FAFAFA;
  border-radius: 20px;
  padding: var(--spacing-lg);
  width: 100%;
  max-width: 520px;   /* era 700px */
  margin: 0 auto;
  box-sizing: border-box;
}



.pricing-card-final__header {
    text-align: center;
    margin-bottom: var(--spacing-sm);
}

.pricing-card-final__header h2 {
    font-size: 1.5rem;
    margin-bottom: var(--spacing-sm);
}

h2 {
    text-align: center;
    font-size: 24px;
    font-weight: 600;
    text-transform: none;
    line-height: 32px;
    color: #0071E3;
    margin-bottom: 24px;
}

.pricing-badge {
    background-color: #C7DCE8;
    color: #005D9D;;
    padding: 8px 24px;
    border-radius: 20px;
    font-weight: 600;
    display: inline-block;
    font-size: 14px;
}

.pricing-card-final__price {
    text-align: center;
    margin-bottom: var(--spacing-sm);
}

.old-price {
    font-size: 20px;
    font-weight: 600;
    text-transform: none;
    line-height: 30px;
    margin-bottom: var(--spacing-sm);
}

.current-label {
    font-size: 20px;
    font-weight: 400;
    text-transform: none;
    line-height: 24px;
    margin-bottom: var(--spacing-sm);
}

.installment-price {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: var(--spacing-xs);
}

.installment-price .times {
    font-size: 24px;
    font-weight: 900;
    font-style: normal;
    line-height: 32px;
    color: var(--primary-color);
}

.installment-price .amount {
    font-size: 64px;
    font-weight: 900;
    line-height: 80px;
    color: var(--primary-color);
}

.full-price {
    margin-bottom: var(--spacing-sm);
    font-size: 18px;
    font-weight: 700;
    text-transform: none;
    font-style: normal;
    line-height: 32px;
    color: #0071E3;
}

.pricing-card-final__features {
    margin-bottom: var(--spacing-sm);
}

.pricing-card-final__features ul{
  list-style: none;
  padding: 0;
  margin: 0;
}

.pricing-card-final__features li{
  position: relative;
  padding-left: 28px; /* espaço para o check */
  margin-bottom: 10px;
  font-size: 14px;
}

/* REMOVE o content: '✓' antigo */
.pricing-card-final__features li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 4px; /* ajuste fino vertical */
  width: 18px;
  height: 18px;
  background-image: url("../img/check.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.payment-methods {
    margin-top: var(--spacing-md);
    text-align: center;
}

.payment-methods img {
    margin: 0 auto var(--spacing-sm);
    max-width: 150px;
}

.payment-icons {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

.payment-icons img {
    max-width: 50px;
    margin: 0;
}

.pricing-card-final .btn{
  display: block;         /* faz virar bloco */
  width: fit-content;     /* botão do tamanho do texto */
  max-width: 100%;
  margin: 24px auto 0;    /* centraliza */
  text-align: center;
}


@media (max-width: 600px){
  .pricing-final .container{
    padding-left: 16px;
    padding-right: 16px;
  }

  .pricing-card-final{
    padding: 20px;           /* ou var(--spacing-md) */
  }

  /* evita o preço gigante quebrar layout */
  .installment-price{
    flex-wrap: wrap;
  }
  .installment-price .amount{
    font-size: 44px;
    line-height: 52px;
  }
  .installment-price .times{
    font-size: 18px;
    line-height: 24px;
  }
}


/* ===================================
   FAQ Section
   =================================== */
.faq {
    background-color: var(--bg-white);
}

.faq__accordion {
    max-width: 800px;
    margin: 0 auto;
}

.faq__item {
    border-bottom: 1px solid var(--border-color);
}

.faq__question {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) 0;
    background: none;
    border: none;
    font-size: 1.125rem;
    font-weight: 600;
    text-align: left;
    color: var(--text-dark);
    transition: color 0.3s ease;
}

.faq__question:hover {
    color: var(--primary-color);
}

.faq__icon {
    font-size: 1.5rem;
    font-weight: 300;
    color: var(--primary-color);
    transition: transform 0.3s ease;
    flex-shrink: 0;
    margin-left: var(--spacing-sm);
}

.faq__question[aria-expanded="true"] .faq__icon {
    transform: rotate(45deg);
}

.faq__answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.faq__answer p {
    padding-bottom: var(--spacing-md);
    color: var(--text-medium);
    line-height: 1.7;
}

/* ===================================
   Contact CTA
   =================================== */
.contact-cta {
    background-color: var(--bg-light);
    text-align: center;
}

.contact-cta p {
    max-width: 600px;
    margin: 0 auto var(--spacing-md);
    font-size: 1.125rem;
    color: var(--text-medium);
}

/* ===================================
   Footer
   =================================== */
.footer {
    background-color: var(--text-dark);
    color: white;
    padding: var(--spacing-md) 0;
    text-align: center;
}

.footer__links {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    align-items: center;
}

.footer__links a {
    color: white;
    font-size: 0.9375rem;
    transition: color 0.3s ease;
}

.footer__links a:hover {
    color: var(--primary-color);
}

/* ===================================
   WhatsApp Float Button
   =================================== */
.whatsapp-float {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 60px;
    height: 60px;
    z-index: 1000;
    transition: transform 0.3s ease;
}

.whatsapp-float:hover {
    transform: scale(1.1);
}

.whatsapp-float svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.2));
}

/* ===================================
   Lightbox Modal
   =================================== */
.lightbox {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.95);
    z-index: 9999;
    align-items: center;
    justify-content: center;
}

.lightbox.active {
    display: flex;
}

.lightbox__close {
    position: absolute;
    top: 20px;
    right: 40px;
    font-size: 3rem;
    color: white;
    background: none;
    border: none;
    cursor: pointer;
    z-index: 10000;
    transition: color 0.3s ease;
}

.lightbox__close:hover {
    color: var(--primary-color);
}

.lightbox__content {
    max-width: 90%;
    max-height: 90%;
    position: relative;
}

.lightbox__image,
.lightbox__video {
    max-width: 100%;
    max-height: 90vh;
    display: none;
}

.lightbox__image.active,
.lightbox__video.active {
    display: block;
}

/* ===================================
   Responsive Design
   =================================== */

/* Tablet */
@media (min-width: 768px) {
    .hero__features {
        grid-template-columns: repeat(3, 1fr);
    }

    .curriculum__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-lg);
    }

    .before-after__images {
        grid-template-columns: repeat(2, 1fr);
    }

    .masonry-grid {
        column-count: 2;
    }

    .bonus-card {
        grid-template-columns: 1fr 1fr;
        align-items: center;
    }

    .bonus-card--reverse {
        direction: rtl;
    }

    .bonus-card--reverse > * {
        direction: ltr;
    }

    .instructor__content {
        flex-direction: row;
        text-align: left;
    }

    .guarantee__content {
        flex-direction: row;
        text-align: left;
    }

    .footer__links {
        flex-direction: row;
        justify-content: center;
        gap: var(--spacing-md);
    }
}

/* Desktop */
@media (min-width: 1024px) {
    section {
        padding: var(--spacing-xl) 0;
    }

    .masonry-grid {
        column-count: 3;
    }

    .container {
        padding: 0 var(--spacing-md);
    }
}

/* Large Desktop */
@media (min-width: 1200px) {
    .masonry-grid {
        column-count: 3;
    }
}

/* ===================================
   Accessibility
   =================================== */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* Focus styles */
a:focus,
button:focus {
    outline: 2px solid var(--primary-color);
    outline-offset: 2px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Remove o focus "azul" quando o foco NÃO é visível (normalmente clique com mouse) */
:focus:not(:focus-visible){
  outline: none;
  box-shadow: none;
}

/* (Opcional) se você tiver algum style aplicando borda/box-shadow no focus */
button:focus:not(:focus-visible),
a:focus:not(:focus-visible),
summary:focus:not(:focus-visible){
  outline: none;
  box-shadow: none;
}

 /* WhatsApp float */
    .whatsapp-float {
      position: fixed;
      width: 60px;
      height: 60px;
      bottom: 40px;
      right: 20px;
      background-color: #25D366;
      color: #fff;
      border-radius: 50%;
      text-align: center;
      box-shadow: 2px 2px 5px rgba(0,0,0,0.3);
      z-index: 1000;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: transform 0.3s;
    }

    .whatsapp-float:hover {
      transform: scale(1.1);
    }

    .whatsapp-float img {
      width: 35px;
      height: 35px;
    }

/* ===================================
   Position Highlight
   =================================== */
.position-highlight{
  background-color: #F3F3F3;
  padding: var(--spacing-xl) 0;
}

.position-card{  
  padding: var(--spacing-lg);
  max-width: 620px;
  margin: 0 auto;
  text-align: left;
  box-sizing: border-box;
}

/* título */
.position__subtitle{
  font-size: 24px;
  line-height: 1.25;
  font-weight: 700;
  color: var(--text-dark);
  margin: 0 0 16px 0;
  max-width: 100%;
}

/* parágrafos "Quem aprende agora:" / "Quem adia:" */
.position-card > p{
  margin: 18px 0 10px 0;
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  color: var(--text-medium);
}

/* lista */
.position__features{
  margin: 0 0 8px 0;
}

.position__features ul{
  list-style: none;
  padding: 0;
  margin: 0;
}

.position__features li{
  position: relative;
  padding-left: 30px;
  margin: 10px 0;
  font-size: 15px;
  line-height: 1.4;
  color: var(--text-dark);
}

/* check */
.position__features li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0.15em;
  width: 18px;
  height: 18px;
  background-image: url("../img/check.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* CTA centralizada */
.position-card .btn{
  display: block;
  width: 100%;
  max-width: 420px;
  margin: 22px auto 0;
  text-align: center;
}

/* mobile: respiro e tipografia */
@media (max-width: 600px){
  .position-highlight .container{
    padding-left: 16px;
    padding-right: 16px;
  }

  .position-card{
    padding: 20px;
  }

  .position__subtitle{
    font-size: 20px;
  }

  .position-card > p{
    font-size: 15px;
  }

  .position__features li{
    font-size: 14px;
  }
}

.lightbox__media{ display:none; }

.lightbox__media.active{ display:block; }

.lightbox__vimeo{
  width: 92vw;
  max-width: 1000px;
  aspect-ratio: 16 / 9;
}

.lightbox__vimeo iframe{
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  border-radius: 12px;
}

.masonry-item[data-type="video"]::after{
  content: "▶";
  position: absolute;
  font-size: 36px;
  color: white;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

/* =========================
   Urgency Section (match site identity)
========================= */
.urgency{
  background-color: #F3F3F3;       /* igual às seções cinza */
  padding: var(--spacing-xl) 0;
}



.urgency__card{
  max-width: 900px;
  margin: 0 auto;
  background: var(--bg-white);
  border: 1px solid var(--border-color);
  border-radius: 20px;
  padding: var(--spacing-lg);
  box-sizing: border-box;
}

.urgency__header{
  text-align: left;
  margin-bottom: var(--spacing-md);
}

.urgency__title{
  margin: 0 0 10px 0;
  font-size: 24px;
  font-weight: 700;
  line-height: 32px;
  color: var(--text-dark);
}

.urgency__subtitle{
  margin: 0;
  font-size: 16px;
  line-height: 24px;
  color: var(--text-medium);
  max-width: 72ch;
}

.urgency__list{
  list-style: none;
  padding: 0;
  margin: 0 0 var(--spacing-md) 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.urgency__item{
  position: relative;
  padding: 14px 14px 14px 42px; /* espaço do check */
  border: 1px solid var(--border-color);
  border-radius: 12px;
  background: #FAFAFA;          /* mesmo feel do pricing final */
}

.urgency__item::before{
  content: "";
  position: absolute;
  left: 14px;
  top: 16px;
  width: 18px;
  height: 18px;
  background-image: url("../img/check.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.urgency__itemTitle{
  display: block;
  font-size: 15px;
  font-weight: 700;
  line-height: 22px;
  color: var(--text-dark);
  margin-bottom: 4px;
}

.urgency__itemText{
  display: block;
  font-size: 14px;
  line-height: 21px;
  color: var(--text-medium);
}

.urgency__cta{
  display: flex;
  flex-direction: column;
  align-items: center;   /* seu site usa CTA centralizado nas seções */
  gap: 10px;
  text-align: center;
}

.urgency__cta .btn{
  width: 100%;
  max-width: 520px;
}

.urgency__microcopy{
  margin: 0;
  font-size: 13px;
  line-height: 18px;
  color: var(--text-light);
}

@media (min-width: 768px){
  .urgency__list{
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
}

@media (max-width: 600px){
  .urgency__card{
    padding: 20px;
  }

  .urgency__title{
    font-size: 20px;
    line-height: 28px;
  }
}