        
#fullscreen-container {
    --core-main-hero-overlap-size: var(--core-main-hero-overlap, var(--site-shell-radius, 24px));
    --core-main-carousel-card-radius: var(--site-shell-radius, 24px);
        position: relative;
        width: 100%;
        height: 100vh;
        margin-top: calc(var(--core-main-hero-overlap-size, 0px) * -1);
        padding-top: var(--core-main-hero-overlap-size, 0px); /* permite que o header sobreponha apenas o raio */
        overflow: hidden;
        display: flex;
        align-items: center;
        justify-content: center;
        perspective: 2000px;
        z-index: 1; /* Mantém o conteúdo sobre a imagem */
        /* Variáveis de layout do carrossel/overlay */
        --core-main-carousel-left-offset: 16%;   /* deslocamento do #drag-container */
        --core-main-carousel-overlay-gap: -400px;    /* espaço entre overlay e carrossel */
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        overscroll-behavior: none;
    }

    #fullscreen-container > [data-carousel-background] {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        /* Preencher 100% do container mantendo proporção */
        object-fit: cover;
        object-position: center;
        z-index: -1; /* Coloca a imagem no fundo */
        pointer-events: none;
        opacity: 1;
        animation: coreMainCarouselBgFade 1.4s ease both;
        transition: opacity 0.6s ease, transform 0.6s ease;
    }

    #fullscreen-container > [data-carousel-background].is-transitioning {
        opacity: 0;
        transform: scale(1.02);
    }

    /* Película escura acima da imagem de fundo para destacar o texto */
    #fullscreen-container::before {
        content: "";
        position: absolute;
        inset: 0;
        /* Tom escuro com leve matiz da primária para harmonizar com a paleta */
        background:
            linear-gradient(
                180deg,
                rgba(var(--bs-primary-rgb), 0.45) 0%,
                rgba(0, 0, 0, 0.65) 100%
            );
        z-index: 0;           /* acima do background (-1) e abaixo do conteúdo */
        pointer-events: none;  /* não interfere em cliques/drag */
    }


    #drag-container, #spin-container {
        position: relative;
        left: var(--core-main-carousel-left-offset);
        top: -10px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        margin: auto;
        -webkit-transform-style: preserve-3d;
        transform-style: preserve-3d;
        -webkit-transform: rotateX(-15.55deg);
        transform: rotateX(-15.55deg);
        -webkit-transform-origin: center center;
        transform-origin: center center;
        will-change: transform;
        z-index: 5; /* Garante que o conteúdo fique na frente da imagem mas atrás do overlay em mobile */
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;

    }

    #drag-container {
        cursor: grab;
    }

    /* Overlay à esquerda do carrossel mantendo 20px do centro (ajustado via JS) */
.carousel-left-overlay {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: max(0px, calc(var(--core-main-carousel-left-offset) - var(--core-main-carousel-overlay-gap)));
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    pointer-events: auto;
    color: var(--color-neutral-0);
}

.carousel-overlay-surface {
    --core-main-carousel-overlay-surface-gap: clamp(1.25rem, 2.8vw, 2.5rem);
    display: flex;
    flex-direction: column;
    justify-content:normal;
    align-items: stretch;
    width: 100%;
    height: 100%;
    padding: clamp(1rem, 1.5vw, 2rem);
    background-color: transparent;
    border-top-right-radius: var(--site-shell-radius, 24px);
    border-bottom-right-radius: var(--site-shell-radius, 24px);
    gap: var(--core-main-carousel-overlay-surface-gap);
}

.carousel-overlay-content {
    --core-main-carousel-overlay-enter-duration: 400ms;
    --core-main-carousel-overlay-exit-duration: 300ms;
    --core-main-carousel-overlay-stagger: 80ms;
    --core-main-carousel-overlay-enter-x: -1.6rem;
    --core-main-carousel-overlay-enter-y: 0px;
    --core-main-carousel-overlay-exit-x: 1.6rem;
    --core-main-carousel-overlay-exit-y: 0px;
    --core-main-carousel-overlay-enter-easing: cubic-bezier(0.215, 0.61, 0.355, 1);
    --core-main-carousel-overlay-exit-easing: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    position: relative;
    width: 100%;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(1.25rem, 3vw, 2.4rem);
    padding-inline: clamp(0.5rem, 1.4vw, 1rem) clamp(0.5rem, 1.4vw, 1rem);
    padding-inline-start: clamp(1.15rem, 2.5vw, 1.75rem);
    text-align: left;
}

/* CTA oculto até o conteúdo estar pronto para evitar deslocamento inicial */
.carousel-overlay-content [data-overlay-cta] {
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s ease;
}
.carousel-overlay-content[data-overlay-ready="1"] [data-overlay-cta] {
    opacity: 1;
    visibility: visible;
}

.carousel-overlay-content.is-entering .carousel-overlay-item,
.carousel-overlay-content.is-exiting .carousel-overlay-item {
    animation-duration: var(--core-main-carousel-overlay-enter-duration);
    animation-delay: calc(var(--core-main-carousel-overlay-stagger) * var(--core-main-carousel-overlay-item-index));
    animation-fill-mode: both;
    animation-timing-function: var(--core-main-carousel-overlay-enter-easing);
}

.carousel-overlay-content.is-exiting .carousel-overlay-item {
    animation-name: carousel-overlay-exit;
    animation-duration: var(--core-main-carousel-overlay-exit-duration);
    animation-timing-function: var(--core-main-carousel-overlay-exit-easing);
}

.carousel-overlay-content.is-entering .carousel-overlay-item {
    animation-name: carousel-overlay-enter;
}

/* Estilos base para o H1 principal fixo */
.carousel-overlay-h1 {
    margin: 0;
    color: var(--color-neutral-0);
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.1;
    margin-bottom: 1rem;
    text-wrap: balance;
    max-width: 90%;
}

.carousel-overlay-title,
.carousel-overlay-subtitle,
.carousel-overlay-text,
.carousel-overlay-cta {
    margin: 0;
    color: var(--color-neutral-0);
}

.carousel-overlay-title {
    font-weight: 700;
    font-size: clamp(2.15rem, 4.2vw, 3.3rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
}

.carousel-overlay-subtitle {
    font-weight: 600;
    font-size: clamp(0.85rem, 1.6vw, 1rem);
    line-height: 1.2;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 0.4rem;
    padding: 0.4rem 1rem;
    border-radius: 999px;
    background: linear-gradient(135deg,
        rgba(var(--bs-primary-rgb), 0.28) 0%,
        rgba(var(--bs-primary-rgb), 0.14) 100%);
    box-shadow: 0 0 0 1px rgba(var(--bs-primary-rgb), 0.25);
    color: var(--color-neutral-0);
}

.carousel-overlay-text {
    font-size: clamp(1.05rem, 1.9vw, 1.2rem);
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.9);
    max-width: 60ch;
}

.carousel-overlay-cta {
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    white-space: nowrap;
    font-weight: 600;
    padding-inline: clamp(1.35rem, 3.2vw, 2.6rem);
    padding-block: 0.95rem;
    border-radius: calc(var(--site-shell-radius, 24px) / 1.6);
    min-width: clamp(170px, 24vw, 240px);
    font-size: clamp(1.02rem, 2vw, 1.18rem);
    box-shadow: 0 22px 45px rgba(var(--bs-primary-rgb), 0.28);
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.carousel-overlay-cta:hover,
.carousel-overlay-cta:focus {
    transform: translateY(-2px);
    box-shadow: 0 26px 55px rgba(var(--bs-primary-rgb), 0.35);
}

.carousel-overlay-item {
    --core-main-carousel-overlay-item-index: 0;
}

.carousel-overlay-item[data-overlay-index="1"] {
    --core-main-carousel-overlay-item-index: 1;
}

.carousel-overlay-item[data-overlay-index="2"] {
    --core-main-carousel-overlay-item-index: 2;
}

.carousel-overlay-item[data-overlay-index="3"] {
    --core-main-carousel-overlay-item-index: 3;
}

@keyframes carousel-overlay-enter {
    0% {
        opacity: 0;
        transform: translate3d(var(--core-main-carousel-overlay-enter-x), var(--core-main-carousel-overlay-enter-y), 0);
    }
    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes carousel-overlay-exit {
    0% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
    100% {
        opacity: 0;
        transform: translate3d(var(--core-main-carousel-overlay-exit-x), var(--core-main-carousel-overlay-exit-y), 0);
    }
}

.carousel-overlay-title,
.carousel-overlay-subtitle,
.carousel-overlay-text,
.carousel-overlay-cta {
    display: block;
}

.carousel-overlay-title,
.carousel-overlay-subtitle,
.carousel-overlay-text {
    text-wrap: balance;
}

.carousel-overlay-content[data-overlay-fallback="true"] .carousel-overlay-title,
.carousel-overlay-content[data-overlay-fallback="true"] .carousel-overlay-subtitle,
.carousel-overlay-content[data-overlay-fallback="true"] .carousel-overlay-text {
    opacity: 0.96;
}

.carousel-overlay-content[data-overlay-fallback="true"] .carousel-overlay-cta {
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.28);
}

@media (max-width: 992px) {
    .carousel-overlay-title {
        font-size: clamp(1.9rem, 4.6vw, 2.7rem);
    }

    .carousel-overlay-subtitle {
        font-size: clamp(0.78rem, 2.1vw, 0.92rem);
        padding: 0.35rem 0.85rem;
        letter-spacing: 0.18em;
    }
}

@media (max-width: 768px) {
    .carousel-left-overlay {
        align-items: flex-end;
    }

    .carousel-overlay-surface {
        border-radius: var(--site-shell-radius, 24px);
        padding: clamp(1.15rem, 4vw, 1.5rem);
        gap: clamp(1rem, 3.5vw, 1.5rem);
    }

    .carousel-overlay-content {
        --core-main-carousel-overlay-enter-duration: 380ms;
        --core-main-carousel-overlay-exit-duration: 280ms;
        --core-main-carousel-overlay-stagger: 70ms;
        --core-main-carousel-overlay-enter-x: 0px;
        --core-main-carousel-overlay-enter-y: 1.5rem;
        --core-main-carousel-overlay-exit-x: 0px;
        --core-main-carousel-overlay-exit-y: -1.25rem;
        max-width: 100%;
        padding-inline: clamp(0.75rem, 4vw, 1rem);
        padding-inline-start: clamp(1rem, 4vw, 1.3rem);
    }

    .carousel-overlay-content {
        gap: clamp(0.85rem, 3.2vw, 1.25rem);
    }

    .carousel-overlay-title,
    .carousel-overlay-text {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .carousel-overlay-title {
        -webkit-line-clamp: 2;
        line-clamp: 2;
        font-size: clamp(1.6rem, 6vw, 2.1rem);
    }

    .carousel-overlay-subtitle {
        font-size: clamp(0.72rem, 3vw, 0.9rem);
        padding: 0.35rem 0.75rem;
        justify-content: center;
    }

    .carousel-overlay-text {
        -webkit-line-clamp: 4;
        line-clamp: 4;
        font-size: clamp(0.98rem, 3.9vw, 1.08rem);
        line-height: 1.5;
    }

    .carousel-overlay-cta {
        align-self: flex-start;
        justify-content: center;
        width: auto;
        min-width: clamp(150px, 55vw, 220px);
        max-width: 100%;
        padding-block: 0.85rem;
        padding-inline: clamp(1rem, 6vw, 1.6rem);
        font-size: clamp(0.95rem, 3.6vw, 1.05rem);
    }
}

@media (prefers-reduced-motion: reduce) {
    .carousel-overlay-content.is-entering .carousel-overlay-item,
    .carousel-overlay-content.is-exiting .carousel-overlay-item {
        animation: none !important;
    }
}

.carousel-selection-anchor {
    position: absolute;
    left: 0;
    top: 0;
    width: var(--core-main-carousel-anchor-width, 36px);
    height: var(--core-main-carousel-anchor-height, 36px);
    opacity: 0;
    pointer-events: none;
    will-change: left, top;
    z-index: 3;
}

#drag-container img,
#drag-container video {
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        line-height: 200px;
        font-size: 50px;
        text-align: center;
        -webkit-box-shadow: 0 0 8px #fff;
        box-shadow: 0 0 8px #fff;
        -webkit-box-reflect: below 10px linear-gradient(transparent, transparent, #0005);
        cursor: inherit;
        -webkit-user-drag: none;
        -khtml-user-drag: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
    transition: box-shadow 0.3s ease, filter 0.3s ease, outline 0.3s ease;
    border-radius: var(--core-main-carousel-card-radius, 24px);
}

    #drag-container img:hover,
    #drag-container video:hover {
        -webkit-box-shadow: 0 0 15px #fffd;
        box-shadow: 0 0 15px #fffd;
        -webkit-box-reflect: below 10px linear-gradient(transparent, transparent, #0007);
    }

    #drag-container .carousel-item-active {
        outline: 2px solid rgba(var(--bs-primary-rgb), 0.35);
        box-shadow: 0 0 18px rgba(var(--bs-primary-rgb), 0.55);
        filter: brightness(1.1);
        z-index: 3;
    }

    #drag-container p {
        font-family: Serif;
        position: absolute;
        top: 100%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%) rotateX(90deg);
        transform: translate(-50%, -50%) rotateX(90deg);
        color: var(--color-neutral-0);
    }

    #ground {
        width: 900px;
        height: 900px;
        position: absolute;
        top: 100%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%) rotateX(90deg);
        transform: translate(-50%, -50%) rotateX(90deg);
        background: -webkit-radial-gradient(center center, farthest-side, #9993, transparent);
    }

    @-webkit-keyframes spin {
        from {
            -webkit-transform: rotateY(0deg);
            transform: rotateY(0deg);
        }
        to {
            -webkit-transform: rotateY(360deg);
            transform: rotateY(360deg);
        }
    }

    @keyframes spin {
        from {
            -webkit-transform: rotateY(0deg);
            transform: rotateY(0deg);
        }
        to {
            -webkit-transform: rotateY(360deg);
            transform: rotateY(360deg);
        }
    }

    @-webkit-keyframes spinRevert {
        from {
            -webkit-transform: rotateY(360deg);
            transform: rotateY(360deg);
        }
        to {
            -webkit-transform: rotateY(0deg);
            transform: rotateY(0deg);
        }
    }

    @keyframes spinRevert {
        from {
            -webkit-transform: rotateY(360deg);
            transform: rotateY(360deg);
        }
        to {
            -webkit-transform: rotateY(0deg);
            transform: rotateY(0deg);
        }
    }

    /* Estilos da timeline movidos para css/core/timilnecolor.css */

    .core-main-simulator-section {
        width: 100%;
        padding: clamp(3rem, 6vw, 6rem) 0;
        background-color: var(--core-main-band-bg, var(--bs-body-bg, #ffffff));
    }

    .core-main-full-height {
        width: 100%;
        min-height: 100vh; /* ocupa ao menos a altura total da tela */
        background-color: var(--core-main-band-bg, var(--bs-body-bg, #ffffff));
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: clamp(1.5rem, 2.5vw, 2rem);
        font-weight: 600;
        text-align: center;
        padding: 2rem;
        /* alinhar com o topo arredondado do footer */
        border-bottom-left-radius: var(--site-shell-radius, 20px);
        border-bottom-right-radius: var(--site-shell-radius, 20px);
        overflow: hidden;
    }

    .core-main-band {
        background-color: var(--core-main-band-bg, transparent);
    }

    .core-main-band--light {
        --core-main-band-bg: var(--color-primary-50, #f3f5fb);
    }

    .core-main-band--mid {
        --core-main-band-bg: var(--color-primary-200, #bfc5e8);
    }

    /* ====== Touch improvements (mobile) ====== */
    /* Evita que o gesto de arraste dispare rolagem da página */
    #drag-container,
    #spin-container {
        touch-action: none;
        -ms-touch-action: none;
    }

    #spin-container img,
    #spin-container video {
        touch-action: none;
        -ms-touch-action: none;
    }

    /* ====== Ajustes para telas intermediárias (tablets e laptops pequenos) ====== */
    @media (max-width: 1200px) and (min-width: 769px) {
      #fullscreen-container {
        /* Reduz ligeiramente o offset do carousel para dar mais espaço ao overlay */
        --core-main-carousel-left-offset: 12%;
        --core-main-carousel-overlay-gap: -320px;
      }

      .carousel-overlay-content {
        gap: clamp(1rem, 2.5vw, 1.8rem);
        padding-inline: clamp(0.5rem, 1.2vw, 0.85rem);
        padding-inline-start: clamp(1rem, 2vw, 1.5rem);
      }

      .carousel-overlay-h1 {
        font-size: clamp(1.9rem, 3.5vw, 2.3rem) !important;
        line-height: 1.15 !important;
        margin-bottom: 0.75rem !important;
      }

      .carousel-overlay-title {
        font-size: clamp(1.8rem, 3.2vw, 2.6rem);
      }

      .carousel-overlay-text {
        font-size: clamp(0.98rem, 1.6vw, 1.1rem);
        max-width: 55ch;
      }

      .carousel-overlay-cta {
        min-width: clamp(160px, 20vw, 200px);
        padding-block: 0.85rem;
        font-size: clamp(0.98rem, 1.7vw, 1.1rem);
      }
    }

    /* ====== Ajustes Mobile ====== */
    @media (max-width: 768px) {
      #fullscreen-container {
        height: 100vh;
        --core-main-carousel-left-offset: 0%;
        position: relative;
      }

      #drag-container,
      #spin-container {
        position: absolute;
        left: 33%;
        top: 62%;
        transform: translate(-50%, -50%) rotateX(-15.55deg);
        margin: 0;
      }

      /* No mobile, o overlay muda para a orientação horizontal (topo) */
      .carousel-left-overlay {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: auto;
        max-height: 50vh;
        background: transparent;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        justify-content: flex-start;
        align-items: flex-start;
        padding-top: clamp(1rem, 3vh, 2rem);
        padding-bottom: 0;
        z-index: 10;
        border-top: none;
      }

      .carousel-overlay-surface {
        padding-top: clamp(1.5rem, 4vh, 2.5rem);
        padding-bottom: clamp(0.5rem, 2vh, 1rem);
        padding-inline: clamp(1rem, 4vw, 1.5rem);
        border-top: none;
        border-top-left-radius: 0;
        border-top-right-radius: 0;
        height: auto;
        min-height: auto;
      }

      .carousel-overlay-content {
        gap: clamp(0.65rem, 2vw, 0.95rem);
        padding-bottom: 0;
        padding-inline: 0;
        align-items: flex-start;
        text-align: left;
        width: 100%;
        max-width: 100%;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
      }

      /* Centraliza o botão CTA */
      .carousel-overlay-cta {
        align-self: center; /* Centraliza o botão */
      }

      /* Ajustes específicos para o H1 principal em mobile */
      .carousel-overlay-h1 {
        font-size: clamp(1.3rem, 5vw, 1.7rem) !important;
        line-height: 1.15 !important;
        margin-bottom: clamp(0.4rem, 1.5vh, 0.6rem) !important;
        text-align: left;
        max-width: 100%;
        width: 100%;
        text-wrap: pretty;
        padding-inline: 0;
      }

      .carousel-overlay-subtitle {
        font-size: clamp(0.7rem, 2.5vw, 0.85rem) !important;
        padding: clamp(0.3rem, 1vh, 0.4rem) clamp(0.7rem, 2vw, 0.9rem) !important;
      }

      .carousel-overlay-title {
        font-size: clamp(1.2rem, 4.5vw, 1.6rem) !important;
        line-height: 1.1 !important;
        margin-bottom: clamp(0.3rem, 1vh, 0.5rem) !important;
      }

      .carousel-overlay-text {
        font-size: clamp(0.85rem, 3.2vw, 1rem) !important;
        line-height: 1.35 !important;
        -webkit-line-clamp: 3;
        line-clamp: 3;
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
      }

      .carousel-overlay-cta {
        padding-block: clamp(0.7rem, 2vh, 0.85rem) !important;
        padding-inline: clamp(1rem, 4vw, 1.3rem) !important;
        font-size: clamp(0.9rem, 3.5vw, 1.05rem) !important;
        min-width: auto;
        width: auto;
        max-width: 90%;
      }

      /* Fallback suave caso o JS não calcule: metade da altura útil menos gap padrão */
      .carousel-left-overlay[data-nojs-fallback="1"] {
        /* Em mobile, usa altura automática baseada no conteúdo */
        height: auto;
        min-height: auto;
      }

    }

    /* ====== Ajustes para modo landscape em mobile ====== */
    @media (max-width: 768px) and (max-height: 500px) and (orientation: landscape) {
      #fullscreen-container {
        height: 100vh;
        flex-direction: row;
        justify-content: space-between;
      }

      .carousel-left-overlay {
        position: absolute;
        left: 0;
        top: 0;
        width: 45%;
        height: 100%;
        min-height: unset;
        max-height: unset;
        padding-top: clamp(1rem, 3vh, 1.5rem);
        justify-content: center;
      }

      #drag-container,
      #spin-container {
        right: 5%;
        left: auto;
        bottom: auto;
        top: 60%;
        transform: translateY(-50%) rotateX(-15.55deg) scale(0.85);
      }

      .carousel-overlay-h1 {
        font-size: clamp(1.1rem, 4vw, 1.5rem) !important;
        line-height: 1.15 !important;
      }

      .carousel-overlay-content {
        gap: clamp(0.5rem, 2vh, 0.85rem);
      }

      .carousel-overlay-title {
        font-size: clamp(1.2rem, 3.5vw, 1.6rem);
      }

      .carousel-overlay-text {
        font-size: clamp(0.85rem, 2.5vw, 0.95rem);
        -webkit-line-clamp: 2;
        line-clamp: 2;
      }
    }

    /* ====== Ajustes para smartphones pequenos ====== */
    @media (max-width: 480px) {
      #fullscreen-container {
        height: 100vh; /* Usa altura total */
        justify-content: center; /* Mantém centralizado */
        padding-top: 0;
        padding-bottom: clamp(1.5rem, 4vh, 3rem);
      }

      #drag-container,
      #spin-container {
        transform: translateX(-50%) scale(0.85) rotateX(-15.55deg); /* Centraliza e reduz levemente */
        margin-top: 10px; /* Mantém 10px de distância do botão */
      }

      .carousel-left-overlay {
        min-height: auto;
        max-height: none;
        padding-top: 0; /* Remove padding superior */
        border-top: none; /* Remove borda superior */
      }

      .carousel-overlay-surface {
        padding-top: clamp(1rem, 3vh, 2rem);
        border-top: none; /* Remove borda superior */
        border-top-left-radius: 0;
        border-top-right-radius: 0;
      }

      .carousel-overlay-h1 {
        font-size: clamp(1.25rem, 5vw, 1.6rem) !important;
        line-height: 1.25 !important;
        margin-bottom: 0.5rem !important;
      }

      .carousel-overlay-content {
        gap: clamp(0.7rem, 2.5vw, 1rem);
        padding-inline: clamp(0.5rem, 3vw, 0.75rem);
      }

      .carousel-overlay-title {
        font-size: clamp(1.4rem, 5.5vw, 1.8rem);
      }

      .carousel-overlay-text {
        font-size: clamp(0.9rem, 3.5vw, 1rem);
        -webkit-line-clamp: 3; /* Reduz para 3 linhas em telas muito pequenas */
        line-clamp: 3;
      }

      .carousel-overlay-cta {
        min-width: clamp(140px, 50vw, 200px);
        font-size: clamp(0.88rem, 3.2vw, 0.98rem);
        padding-block: 0.75rem;
      }
    }

    @keyframes coreMainCarouselBgFade {
        from {
            opacity: 0;
            transform: scale(1.04);
        }
        to {
            opacity: 1;
            transform: scale(1);
        }
    }
