/* ==========================================================================
   Solução Hero — Badge + heading + CTA + mockup com ondas verdes
   ========================================================================== */

.solucao-hero {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: var(--hero-viewport-min);
    background-color: var(--color-bg);
    overflow: hidden;
}

.solucao-hero__container {
    position: relative;
    z-index: 2;
    flex: 0 0 auto;
    max-width: 1216px;
    margin: 0 auto;
    padding: clamp(40px, calc(22.86px + 1.79vw), 56px) var(--hero-pad-inline) 0;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.solucao-hero__content {
    max-width: 1024px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(16px, calc(10px + 0.75vw), 24px);
}

/* Badge */
.solucao-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: clamp(6px, 0.5vw, 8px);
    padding: clamp(5px, 0.4vw, 6px) clamp(12px, calc(8px + 0.5vw), 16px);
    background-color: var(--color-white);
    border-radius: 100px;
    font-family: 'Manrope', sans-serif;
    font-size: var(--hero-badge-size);
    font-weight: 500;
    line-height: 1.4;
    color: #252B37;
}

.solucao-hero__badge img {
    width: clamp(14px, calc(12px + 0.25vw), 16px);
    height: clamp(14px, calc(12px + 0.25vw), 16px);
}

/* Título */
.solucao-hero__title {
    font-family: var(--font-heading);
    font-weight: 500;
    font-size: var(--hero-title-size);
    line-height: var(--font-hero-lh);
    color: #252B37;
    letter-spacing: var(--font-hero-ls);
}

.solucao-hero__title-highlight {
    display: inline-block;
    padding: 4px 12px;
    background: url("data:image/svg+xml,%3Csvg width='538' height='66' viewBox='0 0 538 66' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21.0896 6.85816C23.0758 2.66981 27.2967 0 31.9322 0H525.324C534.317 0 540.115 9.52651 535.982 17.5139L514.254 59.5139C512.193 63.4981 508.082 66 503.596 66H12.0147C3.20302 66 -2.6036 56.8199 1.17209 48.8582L21.0896 6.85816Z' fill='%23AECA37'/%3E%3C/svg%3E") no-repeat center / 100% 100%;
}

/* Subtítulo */
.solucao-hero__subtitle {
    font-size: var(--hero-subtitle-size);
    line-height: 1.55;
    color: #414651;
    max-width: clamp(280px, 55vw, 850px);
}

/* Actions */
.solucao-hero__actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(16px, calc(10px + 0.75vw), 24px);
    margin-top: clamp(4px, 0.5vw, 8px);
}

.solucao-hero__btn {
    display: inline-flex;
    align-items: center;
    gap: clamp(6px, 0.5vw, 8px);
    background: var(--color-button);
    color: #FFFFFF;
    padding: clamp(10px, 0.75vw, 12px) clamp(20px, calc(14px + 0.75vw), 24px);
    border-radius: 999px;
    font-family: var(--font-body);
    font-size: var(--hero-cta-size);
    font-weight: 500;
    line-height: 1.5;
    text-decoration: none;
    transition: var(--transition-base);
}

.solucao-hero__btn svg {
    width: clamp(18px, calc(16px + 0.25vw), 20px);
    height: clamp(18px, calc(16px + 0.25vw), 20px);
    color: var(--color-button);
    background: rgba(255, 255, 255, 0.9);
    border-radius: 50%;
    padding: clamp(8px, 0.6vw, 10px);
    box-sizing: content-box;
    transition: var(--transition-base);
}

.solucao-hero__btn:hover {
    background: #6E7DB3;
}

.solucao-hero__btn:hover svg {
    background: rgba(255, 255, 255, 1);
}

.solucao-hero__link {
    font-family: var(--font-body);
    font-size: var(--hero-body-size);
    font-weight: 500;
    line-height: 1.4;
    color: #252B37;
    text-decoration: none;
    transition: var(--transition-fast);
}

.solucao-hero__link:hover {
    text-decoration: underline;
}

/* Visual — ondas e mockup */
.solucao-hero__visual {
    position: relative;
    flex: 1;
    min-height: 0;
    width: 100%;
    margin-top: clamp(12px, calc(4px + 0.75vw), 24px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
}

.solucao-hero__wave {
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 100%;
    max-width: 1920px;
    height: auto;
    transform: translateX(-50%);
    pointer-events: none;
}

.solucao-hero__mockup-wrap {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1024px;
    margin: 0 auto;
    padding: 0 var(--hero-pad-inline);
}

.solucao-hero__mockup {
    width: 100%;
    height: auto;
    max-height: var(--hero-mockup-max-h);
    object-fit: contain;
    display: block;
    margin-inline: auto;
}

.solucao-hero__mockup-wrap--module {
    padding-inline: 96px;
}

.solucao-hero__laptop-viewport {
    position: relative;
    width: 100%;
    max-width: 1024px;
    aspect-ratio: 1024 / 416;
    overflow: hidden;
    margin-inline: auto;
}

/* Laptop mockup — screenshot (contain) na área da tela + moldura por cima */
.solucao-hero__laptop {
    position: relative;
    width: 100%;
    aspect-ratio: 1024 / 589;
    margin: 0;
}

.solucao-hero__laptop-screen {
    position: absolute;
    top: 3.19%;
    left: 9.25%;
    width: 82.29%;
    /* Altura limitada à parte VISÍVEL do laptop (a viewport corta a base),
       para que object-position:center centralize a imagem no que aparece. */
    height: 67.44%;
    overflow: hidden;
    border-radius: 4px;
    background-color: var(--color-white);
}

.solucao-hero__laptop-screen img {
    width: 100%;
    height: 100%;
    display: block;
}

.solucao-hero__laptop-screen--contain img {
    object-fit: contain;
    object-position: center;
}

.solucao-hero__laptop-screen--cover img {
    object-fit: cover;
    object-position: top center;
}

.solucao-hero__laptop-frame {
    position: absolute;
    inset: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: fill;
    display: block;
    pointer-events: none;
}

/* ===== Carrossel deslizante na tela do laptop =====
   Track flex que translada no eixo X dentro da tela (que já tem overflow:hidden).
   Cada slide ocupa 100% da tela; o JS aplica translateX(-index*100%). Genérico:
   ativado por [data-laptop-carousel] e reutilizável em qualquer módulo com 'screens'. */
.solucao-hero__carousel {
    position: absolute;
    inset: 0;
    overflow: hidden;
    touch-action: pan-y; /* swipe horizontal vira pointer event; scroll vertical livre */
}

.solucao-hero__carousel-track {
    display: flex;
    width: 100%;
    height: 100%;
    will-change: transform;
    transition: transform 0.45s ease;
    touch-action: pan-y; /* permite o scroll vertical da página; swipe-X tratado no JS */
}

.solucao-hero__carousel.is-dragging .solucao-hero__carousel-track {
    transition: none; /* durante o arraste, o track segue o dedo sem easing */
}

.solucao-hero__carousel-slide {
    flex: 0 0 100%;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    background: var(--color-white);
    cursor: zoom-in; /* clique limpo amplia no lightbox */
    display: block;
}

.solucao-hero__carousel-slide img {
    width: 100%;
    height: 100%;
    display: block;
    user-select: none;
    -webkit-user-drag: none;
}

/* O "fit" vem do modificador da tela e vale para todos os slides */
.solucao-hero__laptop-screen--contain .solucao-hero__carousel-slide img {
    object-fit: contain;
    object-position: center;
}

.solucao-hero__laptop-screen--cover .solucao-hero__carousel-slide img {
    object-fit: cover;
    object-position: top center;
}

/* ===== Dots — sobrepostos à base da imagem (indicador leve, semitransparente) =====
   Ficam dentro da viewport (position:relative); a base dela coincide com a base da
   área visível da tela, então bottom posiciona os dots sobre a parte de baixo da imagem.
   A sombra dá legibilidade sobre dashboards claros ou escuros, sem pílula que tampe. */
.solucao-hero__dots {
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    z-index: 3; /* acima da moldura (z-index 1) e do carrossel */
    display: flex;
    justify-content: center;
    gap: 8px;
}

.solucao-hero__dot {
    width: 8px;
    height: 8px;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.55); /* semitransparente: não tampa a imagem */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
}

.solucao-hero__dot:hover {
    background: rgba(255, 255, 255, 0.85);
}

.solucao-hero__dot--active {
    background: #fff;
    transform: scale(1.25);
}

@media (prefers-reduced-motion: reduce) {
    .solucao-hero__carousel-track {
        transition: none;
    }
}

/* ===== Responsivo ===== */

@media (max-width: 768px) {
    .solucao-hero {
        min-height: auto;
    }

    .solucao-hero__container {
        padding: var(--hero-pad-block) var(--hero-pad-inline) 0;
    }

    .solucao-hero__mockup-wrap {
        padding: 0 var(--hero-pad-inline);
    }

    .solucao-hero__mockup-wrap--module {
        padding-inline: var(--hero-pad-inline);
    }
}
