html {
    overflow-x: hidden;
}

.mouse-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: none;
    border: 1px solid #fff;
    opacity: 0.5;
    position: absolute;
    pointer-events: none;
    mix-blend-mode: difference;
    transform: translate(-50%, -50%);
    z-index: 9999999;
}

.tt-scrolling-btn {
    position: fixed;
    /* Inicialmente sin una posición inferior fija */
    right: 0px;
    transition: transform 0.5s ease;
    z-index: 9;
    transform-origin: bottom;
    transform: translate(0px, 50%);
    bottom: 200px;
}

.scr-btn-spinner {
    width: 260px;
    /* Ajusta el tamaño del contenedor */
    height: 260px;

}

.scr-btn-icon {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    left: 50%;
    top: 50%;
    width: 120px;
    height: 120px;
    font-size: 50px;
    color: #FFFFFF;
    background-color: #25D366;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: color .2s;
}


.scr-btn-text {
    font-size: 35px;
    font-weight: bold;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 14px;
    fill: var(--t-bright);
    transition: fill .2s;
}




.tt-scrolling-btn svg {
    width: 100%;
}

.tt-scrolling-btn:hover .scr-btn-icon {
    color: var(--t-bright);
}

.tt-scrolling-btn:hover .scr-btn-text {
    fill: var(--t-bright);
}

.margin-top-custom {
    margin-top: 25rem;
}

.margin-bottom-custom {
    margin-top: 25rem;
}

@media only screen and (min-width: 1200px) {
    .headline {
        bottom: inherit;
        transform: translate(0px, 50%);
    }



    .content__block-uno {
        padding: 10rem 0 0em 5rem;
    }

    .stack-offset {
        height: 0;
    }
}

@media (max-width: 991px) {
    .tt-scrolling-btn {
        transform: scale(.8);
    }
}

@media (max-width: 380px) {
    .tt-scrolling-btn {
        transform: scale(.7);
    }
}


/* -------------------------------------------------- */



/* -------------------------------------------------- */

/* conversacion whatsapp */
.iphoneWhats {
    width: 320px;
    height: 600px;
    background: #111;
    border-radius: 40px;
    padding: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.3);
}

.screenWhats {
    width: 100%;
    height: 100%;
    background: #efe5dc;
    /* Fondo de la conversación */
    border-radius: 30px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.headerWhats {
    background: #075e54;
    /* Color verde de WhatsApp */
    color: white;
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 14px;
}

.contact-infoWhats {
    display: flex;
    flex-direction: column;
}

.contact-nameWhats {
    font-weight: bold;
}

.statusWhats {
    font-size: 12px;
    color: #c9f7f5;
    /* Color de estado "En línea" */
}

.iconsWhats {
    display: flex;
    gap: 10px;
}

.iconWhats {
    cursor: pointer;
}

.chatWhats {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 15px 10px;
    overflow-y: auto;
}

.messageWhats {
    max-width: 80%;
    padding: 10px 15px;
    border-radius: 10px;
    font-size: 14px;
    line-height: 1.4;
    opacity: 0;
    transform: translateY(20px);
    word-wrap: break-word;
}

.user-messageWhats {
    align-self: flex-end;
    background-color: #dcf8c6;
    /* Verde claro para el mensaje del usuario */
    color: black;
}

.responseWhats {
    align-self: flex-start;
    background-color: #ffffff;
    /* Blanco para los mensajes recibidos */
    color: black;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
}

.whatsappConversation {
    display: flex;
    justify-content: center;
    align-items: center;
    /* min-height: 100vh; */
    margin: 25px 0;
    font-family: Arial, sans-serif;

}

/* conversacion whatsapp */

/* pricing */
/* Botón predeterminado */
.btn {
    transition: all 0.3s ease;
}

/* Botón cuando está en hover (será aplicado dinámicamente con GSAP) */
.btn-outline:hover {
    border: 2px solid white;
    color: white;
    background-color: transparent;
}

.card {
    padding: 15px;
    background: rgba(255, 255, 255, 0.8);
    border: 2px solid #aaa;
    /* Color de borde inicial */
    border-radius: 8px;
    text-align: center;
    transition: transform 0.3s;

}

.card {
    transition: background-color 0.3s ease, color 0.3s ease;
    overflow: hidden;
    /* Asegura que las animaciones no se salgan */
}

/* Texto oculto inicialmente */
.animated-hidden {
    opacity: 0;
    transform: translateX(-100%);
    /* Comienza fuera de la vista */
}

.card:hover {
    transform: scale(1.05);
    /* Efecto de aumento en hover */
}


.card-title {
    font-size: 24px;
    color: #333;
}

.card p {
    font-size: 16px;
    color: #666;
    margin: 10px 0;
}

/* custom colors */
.text-accent {
    color: var(--t-bright);
    font-weight: bold !important;
}

.btn-line-small {
    color: var(--t-bright);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--t-bright);
}

.section-name {
    color: var(--t-bright);
}

.text-primary {
    color: var(--t-bright) !important;
}

.btn-default {
    height: 6rem;
    line-height: 6rem;
    -moz-border-radius: 6rem;
    border-radius: 6rem;
    font-size: 1.8rem;
    padding: 0 5.6rem !important;
}

.no-touch .hover-default:hover {
    color: var(--t-opp-bright);
    background-color: var(--t-bright);
}

.pricing-plans__price.heading-m {
    font-size: max(2.5rem, min(4.41176vw - .919118rem, 4.375rem));
    margin: 1rem;
    overflow-wrap: break-word;
}

.heading-m {
    font-weight: 600;
    letter-spacing: -.01em;
    line-height: 1;
}

.pricing-plans__price {

    background: var(--panel-theme);
    -webkit-background-clip: text;
    background-clip: text;
}

.pricing-plans__price.heading-m {
    font-size: max(1.5rem, min(3.41176vw - .919118rem, 4.375rem));
    overflow-wrap: break-word;
    line-height: 2.5rem;
}

.heading-s {
    font-size: 1rem;
}

.heading-s {
    font-weight: 600;
    letter-spacing: -.01em;
    line-height: 1;
}

/* animacion de la grafica */
#grafica {
    margin-left: auto;
    width: 50%;
    /* max-width: 640px; */
    padding: 0 0px;
    transform: translate(0%, 30%);
}

.chart {
    height: 300px;
    position: relative;
}

.chart-x-axis {
    border: 2px solid #7f7f7f;
    bottom: -2px;
    left: 0;
    position: absolute;
    width: 100%;
}

.chart-bar {
    background-color: #3C6ABC;
    bottom: 0;
    height: 0;
    position: absolute;
    width: 18%;
    /* Ajuste para ancho en pantallas grandes */
    max-width: 105px;
    /* Ancho máximo de cada barra */
    transition: height 1s ease;
}

.chart-bar.pos-1 {
    left: 1%;
}

.chart-bar.pos-2 {
    left: 21%;
}

.chart-bar.pos-3 {
    left: 41%;
}

.chart-bar.pos-4 {
    left: 61%;
}

.chart-bar.pos-5 {
    left: 81%;
}

.chart-bar.gold {
    background-color: var(--t-medium--light);
}

.chart-bar-percentage,
.chart-bar-label {
    color: white;
    margin: 10px 0;
    text-align: center;
}


.chart-bar-label {
    font-size: 10px;
    /* Ajuste de fuente para etiquetas */
    font-weight: bold;
}

.testimonials-card {
    height: 100% !important;
}

.swiper-testimonials {
    display: grid;
}

.iconBack {
    width: 150px;
    height: auto;
    position: absolute;
    z-index: -1;
    /* Para que el SVG esté detrás del contenido */
    opacity: .3
}

.navigation {
    position: absolute;
    top: 50%;
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    pointer-events: none;
}

.nav-arrow {
    background: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 20px;
    cursor: pointer;
    pointer-events: auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

.bullets {
    position: absolute;
    bottom: 10%;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
}

.bullet {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    pointer-events: auto;
}

.bullet.active {
    background: white;
}



/* Media Queries para pantallas pequeñas */
@media (max-width: 768px) {
    .chart {
        height: 200px;
        /* Reduce la altura total de la gráfica */
    }

    .chart-bar {
        width: 15%;
        /* Ajusta el ancho de las barras */
        max-width: 80px;
        /* Ancho máximo reducido */
    }

    .chart-bar-percentage {
        font-size: 18px;
        /* Ajuste de fuente para pantallas pequeñas */
    }

    .chart-bar-label {
        font-size: 12px;
        /* Ajuste de fuente para etiquetas */
    }
}

@media (max-width: 480px) {
    .chart {
        height: 150px;
        /* Reduce aún más la altura total */
    }

    .chart-bar {
        width: 14%;
        max-width: 60px;
    }

    .chart-bar-percentage {
        font-size: 16px;
    }

    .chart-bar-label {
        font-size: 10px;
    }
}

blockquote {

    color: var(--base-tint);
}

p {
    color: var(--base-tint);
}

h1 {
    font: normal 300 3.6rem var(--_font-accent);
}

@media only screen and (min-width: 768px) {
    .services-stack__descr {
        bottom: inherit !important;
        transform: translate(0px, 50%);
    }

    .divider-image,
    .divider-video {
        height: 250px;
    }

    .header {
        background-color: rgba(255, 255, 255, 0.87);
    }

    h2 {
        font-size: 6rem !important;
        font-weight: 400;
    }

    .tauthor__avatar {
        width: 60px;
        min-width: 60px;
        height: 60px;
        margin-right: 3rem;
    }
}

/* pagina confirmaciones */
@media only screen and (min-width: 1200px) {
    h1 {
        font-size: 5.7rem;
        font-weight: 600;
    }

    .content__block.pre-grid-items {
        margin-bottom: 0;
    }

    .intro-bg-01__01 {
        top: -80px;

    }

    .main__intro {
        height: 100vh;
    }

    .intro-bg-01__02 {
        bottom: -60px;
        left: -160px;
        width: 500px;
        height: 500px;
    }

    .divider-image,
    .divider-video {
        height: 250px;
    }

    blockquote {
        font-size: 2.8rem !important;
        line-height: 3.5rem;
    }
}

@media only screen and (min-width: 1400px) {
    blockquote {
        font-size: 2.8rem;
        line-height: 3.5rem;
    }

    h1 {
        font-size: 7rem;
        font-weight: 600;
    }

    .divider-image,
    .divider-video {
        height: 250px;
    }
}

.main-image-1 {
    background-image: url("../img/about.webp");
}

.main-image-confirmaciones {
    background-image: url("../img/about.webp");
}

.img-logo {
    height: 65px;
    width: 100px;
}

.logo__link-custom{
    padding: 10px !important;
}

.link-small-160lh {
    font-size: 1.8rem;
    line-height: 1.6;
}

.achievements__number {
    font-size: 3rem;
    line-height: 3rem;
    font-weight: bold;
}

.achievements__descr {
    font-size: 1.8rem;
}

@media only screen and (min-width: 768px) {
    .achievements__item {
        width: 50%;
    }

    .intro-bg-01__01 {
        top: -20px;
        right: -90px;
    }
}









/* orblets */
/* Contenedor de los círculos */
.background-circles {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    pointer-events: none;
    z-index: -1;
}

/* Estilos de los círculos */
.circle {
    position: absolute;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.157);
}

/* Tamaños y posiciones iniciales de los círculos más pequeños */
.circle-1 {
    width: 150px;
    height: 150px;
    top: 20%;
    left: 10%;
}

.circle-2 {
    width: 120px;
    height: 120px;
    top: 40%;
    left: 60%;
}

.circle-3 {
    width: 180px;
    height: 180px;
    top: 10%;
    left: 80%;
}

.circle-4 {
    width: 160px;
    height: 160px;
    top: 70%;
    left: 20%;
}

.circle-5 {
    width: 100px;
    height: 100px;
    top: 80%;
    left: 70%;
}

.circle-6 {
    width: 90px;
    height: 90px;
    top: 30%;
    left: 30%;
}

.circle-7 {
    width: 130px;
    height: 130px;
    top: 60%;
    left: 50%;
}

.circle-8 {
    width: 110px;
    height: 110px;
    top: 50%;
    left: 15%;
}

.circle-9 {
    width: 140px;
    height: 140px;
    top: 25%;
    left: 85%;
}

[color-scheme=dark] {
    .card {
        background-color: #141414 !important;
        color: #ffffff !important;
    }

    .card:hover {
        background-color: #F2F5FC !important;
        color: #141414 !important;
    }

    .card p {
        color: #ffffff;
    }

    .card p:hover {
        color: #141414 !important;
    }

    .btn-default {
        color: #fff !important;
        /* Color inicial del texto */
        background-color: #141414 !important;
        /* Fondo inicial del botón */
        border-color: #ffffff !important;
    }

    .btn-default:hover {
        color: #3C6ABC !important;
        /* Texto azul al hover */
        border-color: #3C6ABC !important;
        background-color: #ffffff !important;
        /* Aseguramos fondo blanco */
    }
}

/* arrows para el fondo de pantalla confirmaciones */

/* Contenedor de las flechas */
.background-arrows {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
    pointer-events: none;
    z-index: -1;
    opacity: 0.2;
}


p.type-basic-160lh {
    line-height: 1.2;
}

.heading-ms {
    font-size: 2.5rem !important;
}

h3.orblets-caso-titles-custom {
    font-size: 3.4rem !important;
}

@media only screen and (min-width: 768px) {
    h3.orblets-caso-titles-custom {
        font-size: 3.4rem !important;
    }
}

@media only screen and (min-width: 1200px) {
    h3.orblets-caso-titles-custom {
        font-size: 3.4rem !important;
    }
}

@media only screen and (min-width: 1400px) {
    h3.orblets-caso-titles-custom {
        font-size: 4rem !important;
    }
}

@media only screen and (min-width: 1600px) {
    h3.orblets-caso-titles-custom {
        font-size: 5.4rem !important;
    }
}

/* fin orblets */



/* Flechas */
.arrow {
    position: absolute;
    width: 100px;
    /* Tamaño inicial, ajustable */
    height: auto;
    /* Mantén la proporción */
}

/* Posiciones iniciales de las flechas */
.arrow-1 {
    top: 10%;
    left: 20%;
}

.arrow-2 {
    top: 40%;
    left: 60%;
}

.arrow-3 {
    top: 70%;
    left: 30%;
}

.arrow-4 {
    top: 25%;
    left: 80%;
}

.arrow-5 {
    top: 50%;
    left: 10%;
}

.arrow-6 {
    top: 35%;
    left: 45%;
}

.arrow-7 {
    top: 65%;
    left: 75%;
}

.arrow-8 {
    top: 15%;
    left: 55%;
}

.arrow-9 {
    top: 85%;
    left: 40%;
}

/* Home - Index 1 */

.btn-circle-icon,
.btn-circle-icon-custom-home {
    width: 15rem !important;
    height: 15rem !important;
    font-size: 2.4rem;
}

.cta-mtcustom-porque-home {
    margin: -150px 0 0 0;
}

.headline-custom {
    padding: 0 10rem;
}


.headline-custom {
    padding: 0 10rem;
}

[color-scheme=dark] {
    .menu__link.active .menu__caption {
        color: #3c6abc;
    }

    .menu__link {
        color: #4c4c4c;
    }

    .menu__link:hover,
    .menu__caption:hover {
        color: #3c6abc !important;
    }
}

.testimonials-card {
    border: 2px solid var(--t-bright);
}

@media only screen and (min-width: 1200px) {
    .h3-custom {
        font-size: 4.5rem;
    }

    .portfolio-stack__descr {
        padding: 4rem 5rem 8rem 5rem;
    }
}

@media only screen and (min-width: 1400px) {
    .blockquote-custom {
        font-size: 5rem !important;
        line-height: 5.5rem;
    }

    .blockquote-custom-parrafo {
        font-size: 3rem;
        line-height: 4rem;
        text-align: justify;
    }
}

@media only screen and (max-width: 1200px) {

    .text-xl-desktop {
        font-size: 14px !important;
    }

    .content__block-uno {
        padding: 20rem 0 0em 5rem;
    }

    .custom-text {
        font-size: 3.2em;
    }

}

/* ------------------------------------------------- Home - Index ------------------------------------------------- */
.portfolio-item-5 {
    background-image: url("../img/Home/confirmaciones-beneficio-1.webp");
}

.portfolio-item-6 {
    background-image: url("../img/Home/confirmaciones-beneficio-2.webp");
}

.portfolio-item-7 {
    background-image: url("../img/Home/confirmaciones-beneficio-3.webp");
}

.btn-circle-icon,
.btn-circle-icon-custom-home {
    width: 15rem !important;
    height: 15rem !important;
    font-size: 2.4rem;
}

.cta-mtcustom-porque-home {
    margin: -150px 0 0 0;
}

.headline-custom {
    padding: 0 10rem;
}

.headline-custom {
    padding: 0 10rem;
}

[color-scheme=dark] {
    .menu__link.active .menu__caption {
        color: #3c6abc;
    }

    .menu__link {
        color: #4c4c4c;
    }

    .menu__link:hover,
    .menu__caption:hover {
        color: #3c6abc !important;
    }
}

.main-image-1-orblets {
    background-image: url();
}

.divider.main-image-1-orblets {
    position: relative;
    width: 100%;

    overflow: hidden;
}

.divider.main-image-1-orblets video {
    /* position: absolute; */
    /* top: 50%; */
    /* left: 50%; */
    /* transform: translate(-50%, -50%); */
    width: 100%;
    height: auto;
    object-fit: cover;

}


@media only screen and (min-width: 1200px) {
    .h3-custom {
        font-size: 4.5rem;
    }
}

@media only screen and (min-width: 1400px) {
    .blockquote-custom {
        font-size: 5rem !important;
        line-height: 5.5rem;
    }

    .blockquote-custom-parrafo {
        font-size: 3rem;
        line-height: 4rem;
        text-align: justify;
    }
}

@media only screen and (max-width: 1200px) {
    .text-xl-desktop {
        font-size: 14px !important;
    }
}

/* CARRUSEL */
.custom-wrapper {
    width: 100%;
    height: 100vh;
    background-color: #111;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
}

.custom-slider {
    width: 100%;
    height: 100vh;
    position: relative;
    overflow: hidden;
}

.custom-slide {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    color: white;
    font-size: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.custom-text {
    position: absolute;
    top: 60px;
    left: 120px;
    color: white;
    font-size: 2.8em;
    z-index: 10;
    opacity: 1;
    transform: translateY(-20px);
    width: 50%;
    line-height: 4.5rem;
}

.custom-nav {
    position: absolute;
    bottom: 80px;
    left: 80px;
    display: flex;
    flex-direction: row;
    z-index: 10;
    /* overflow: hidden; */
}

.custom-nav-item {
    display: flex;
    flex-direction: column;
    align-items: left;
    margin-right: 15px;
    cursor: pointer;
}

.custom-nav-item span {
    color: white;
    opacity: 0.5;
    transition: opacity 0.5s ease;
    font-size: 16px;
}

.custom-nav-item.active span {
    opacity: 1;
}

.custom-nav-bar {
    height: 5px;
    background-color: rgba(255, 255, 255, 0.5);
    position: relative;
    overflow: hidden;
    opacity: 0.5;
    transition: opacity 0.5s ease, width 0.5s ease;
    margin-top: 20px;
    width: 120px;
}

.menu__link.active {
    background-color: #3C6ABC !important;
}

@media only screen and (min-width: 1200px) {
    .custom-nav-item span {
        font-size: 16px;
    }

    .custom-nav-bar {
        width: 160px;
    }

    .custom-text {
        top: 120px;
    }
}

@media only screen and (min-width: 1400px) {
    .custom-nav-item span {
        font-size: 17px;
    }

    .custom-nav-bar {
        width: 200px;
    }

    .custom-text {
        top: 150px;
    }
}

.custom-nav-bar::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: white;
    transform: translateX(-100%);
    opacity: 1;
    transition: transform 0.5s ease, opacity 0.5s ease;
}

.custom-nav-item.active .custom-nav-bar::before {
    transform: translateX(0);
    opacity: 1;
}

.custom-nav-item.active .custom-nav-bar {
    opacity: 1;
}

.custom-button {
    position: absolute;
    bottom: 135px;
    left: 135px;
    transform: translate(-50%, -50%);
    border: 1px solid #fff;
    cursor: pointer;
    z-index: 10;
    color: #fff;
    padding: 2rem 2.2rem;
    border-radius: 50%;
    font-family: 'Urbanist';
    width: 8rem;
    height: 8rem;
    font-size: 2.4rem;
    background: transparent;
    text-align: center;
}

.circular-text {
    position: absolute;
    /* top: 50%;
    left: 50%; */
    transform: translate(-50%, -50%);
    /* width: 12rem;
    height: 12rem; */
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    font-size: 7.4rem;
}

@keyframes moveText {
    0% {
        transform: translateX(0);
        /* Centro */
    }

    25% {
        transform: translateX(10px);
        /* Hacia la derecha */
    }

    50% {
        transform: translateX(0);
        /* De vuelta al centro */
    }

    75% {
        transform: translateX(-10px);
        /* Hacia la izquierda */
    }

    100% {
        transform: translateX(0);
        /* Regreso al centro */
    }
}

.circular-text span {
    position: absolute;
    font-size: 1rem;
    color: #fff;
    text-transform: uppercase;
    white-space: nowrap;
    animation: moveText 1.7s linear infinite;
    /* Movimiento continuo sin pausas */
}

.fas.fa-arrow-right.size {
    font-size: 2.2rem;
}

/* INTRO 2 */
#page-header {
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.page-header-inner,
body.ph-image-on.ph-bg-image-on #page-header .page-header-inner {
    width: 100%;
    /* padding-top: 13vw;
    padding-bottom: 10vw; */
    z-index: 2;
}

body.ph-image-on #page-header .page-header-inner {
    padding-top: 16vw;
    padding-bottom: 13vw;
}

body:not(.tt-boxed) .page-header-inner,
.page-header-inner:not(.tt-wrap) {
    padding-left: 13%;
    padding-right: 13%;
}

@media (max-width: 1920px) {
    /* .page-header-inner {
        padding-top: 250px;
        padding-bottom: 140px;
    } */

    body.ph-image-on #page-header .page-header-inner {
        padding-top: 200px;
        padding-bottom: 140px;
    }
}

@media (max-width: 1400px) {
    body.tt-boxed .page-header-inner.tt-wrap {
        padding-left: 8%;
        padding-right: 5%;
    }
}

@media (max-width: 1024px) {}

@media (max-width: 540px) {
    body:not(.ph-center-on).ph-image-on #page-header .page-header-inner {
        padding-top: 240px;
        padding-bottom: 40vw;
    }
}

/* Video */
#page-header:not(.ph-image-cropped) .ph-video-wrap {
    position: relative;
    padding-bottom: 140%;
}

#page-header.ph-bg-image .ph-video-wrap {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

#page-header:not(.ph-bg-image).ph-image-cropped .ph-image-inner {
    position: relative;
    padding-bottom: 130%;
}

#page-header:not(.ph-bg-image).ph-image-cropped .ph-image-inner img {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
}

/* Make image to background image */
#page-header.ph-bg-image .ph-image {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    max-width: 100%;
    margin: 0;
    z-index: -1;
    transform: none;
    overflow: hidden;
}

#page-header.ph-bg-image .ph-image-inner {
    width: 100%;
    height: 100%;
}

#page-header.ph-bg-image .ph-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
}

#page-header.ph-bg-image .ph-video-wrap {
    padding-bottom: 0;
}

#page-header.ph-bg-image .ph-caption-title-ghost {
    /* disable title ghost if "ph-bg-image" is enabled */
    display: none;
}

#page-header:not(.ph-full) .tt-scroll-down {
    /* Display only on full scren page header! */
    display: none;
}

#page-header.ph-stroke .ph-caption-title {
    font-weight: bold;
    font-weight: 700;
    -webkit-text-stroke-width: 2px;
    -webkit-text-stroke-color: #FFF;
    -webkit-text-fill-color: transparent;
}

@media (max-width: 1024px) {
    #page-header.ph-stroke .ph-caption-title {
        -webkit-text-stroke-width: 1px;
    }
}

#page-header.ph-cap-sm .ph-caption-title {
    font-size: clamp(38px, 4vw, 68px);
}

/* Caption size lg */
#page-header.ph-cap-lg .ph-caption-title {
    font-size: clamp(18px, 3.8vw, 86px);
}

/* Caption size xlg */
#page-header.ph-cap-xlg .ph-caption-title {
    font-size: clamp(38px, 8vw, 142px);
}

/* Caption size xxlg */
#page-header.ph-cap-xxlg .ph-caption-title {
    font-size: clamp(38px, 10vw, 180px);
    line-height: 1;
}

@media (min-width: 1025px) {
    #page-header.ph-cap-xxlg.ph-stroke .ph-caption-title {
        -webkit-text-stroke-width: 3px;
    }
}

/* Page header full screen (no effect on smaller screens!) */
@media (min-width: 1025px) {
    #page-header.ph-full {
        display: flex;
        align-items: center;
        min-height: 80vh;
    }

    #page-header.ph-full.ph-center .page-header-inner {
        padding-top: 5% !important;
        padding-bottom: 5% !important;
    }

    #page-header.ph-full .ph-image {
        position: absolute;
        display: flex;
        align-items: center;
        top: 0;
        bottom: 0;
        height: 100%;
    }

    #page-header.ph-full:not(.ph-bg-image).ph-image-cropped .ph-image-inner {
        padding-bottom: 140%;
    }
}

#page-header.ph-center {
    text-align: center;
}

@media (min-width: 1025px) {
    #page-header.ph-center .page-header-inner {
        max-width: 100%;
        padding-left: 4% !important;
        padding-right: 4% !important;
    }
}

#page-header.ph-center .ph-caption {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

#page-header.ph-center .ph-caption-title-ghost {
    left: 50%;
    font-size: calc(16px + 12vw);
    transform: translate3d(-50%, 0, 0);
}

#page-header.ph-center .ph-caption-description,
#page-header.ph-center .ph-caption>p {
    margin-left: auto;
    margin-right: auto;
}

#page-header.ph-center:not(.ph-bg-image) .ph-image {
    right: 50%;
    transform: translate(50%, 0);
}

body:not(.page-header-on) .portfolio-interactive.pi-full {
    display: table;
    width: 100%;
    padding-top: 200px;
    padding-bottom: 200px;
}

body:not(.page-header-on) .portfolio-interactive.pi-full .pi-inner {
    display: table-cell;
    vertical-align: middle;
    height: 100%;

}

body:not(.page-header-on) .portfolio-interactive.pi-full {
    min-height: 100vh;
}

@media (max-width: 1024px) {
    body:not(.page-header-on) .portfolio-interactive.pi-full {
        min-height: calc(100vh - 25vh);
        padding-bottom: 40px;
    }

    body:not(.page-header-on) .portfolio-interactive.pi-full .portfolio-interactive-list {
        padding-bottom: 0;
    }
}

body.pi-full-on:not(.page-header-on) .portfolio-interactive-ghost {
    position: fixed;
    display: block;
    bottom: 0;
    left: 0;
    font-size: 22.5vw;
    font-weight: bold;
    font-weight: 600;
    color: #FFF;
    line-height: .7;
    opacity: .07;
    z-index: -1;
}

@media (max-width: 767px) {

    body:not(.page-header-on) .portfolio-interactive-ghost,
    body:not(.page-header-on).pi-inline-on .portfolio-interactive-ghost {
        top: 15%;
        bottom: auto;
    }
}

body.tt-light-bg-on #page-header.ph-stroke .ph-caption-title {
    -webkit-text-stroke-color: #111;
}

body.tt-boxed .tt-wrap {
    max-width: 1282px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 15px;
    padding-right: 15px;
}

body.tt-boxed .tt-wrap .tt-wrap {
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
}

body:not(.tt-boxed) .tt-header-inner,
.tt-header-inner:not(.tt-wrap) {
    padding-left: 3.5%;
    padding-right: 3.5%;
}

body:not(.tt-boxed) .page-header-inner,
.page-header-inner:not(.tt-wrap) {
    padding-left: 13%;
    padding-right: 13%;
}



body.tt-boxed .tt-wrap .ttgr-height {
    padding-bottom: 60%;
}

body.tt-boxed .tt-wrap .tt-grid.ttgr-gap-1 {
    margin-left: -0.2vw;
    margin-right: -0.2vw;
}

body:not(.tt-boxed) .tt-section-inner.tt-wrap .tt-grid.ttgr-gap-1 .tt-grid-top,
.tt-section-inner:not(.tt-wrap) .tt-grid.ttgr-gap-1 .tt-grid-top {
    padding-left: 3vw;
    padding-right: 3vw;
}

body:not(.tt-boxed) .tt-section-inner.tt-wrap .tt-grid.ttgr-gap-1 .tt-grid-top,
.tt-section-inner:not(.tt-wrap) .tt-grid.ttgr-gap-1 .tt-grid-top {
    padding-left: 3vw;
    padding-right: 3vw;
}

body.tt-boxed .tt-wrap .tt-grid.ttgr-gap-2 {
    margin-left: -1vw;
    margin-right: -1vw;
}

body:not(.tt-boxed) .tt-section-inner.tt-wrap .tt-grid.ttgr-gap-2 .tt-grid-top,
.tt-section-inner:not(.tt-wrap) .tt-grid.ttgr-gap-2 .tt-grid-top {
    padding-left: 1.5vw;
    padding-right: 1.5vw;
}

body:not(.tt-boxed) .tt-section-inner.tt-wrap .tt-grid.ttgr-gap-2 .tt-grid-top,
.tt-section-inner:not(.tt-wrap) .tt-grid.ttgr-gap-2 .tt-grid-top {
    padding-left: 1.5vw;
    padding-right: 1.5vw;
}

body.tt-boxed .tt-wrap .tt-grid.ttgr-gap-3 {
    margin-left: -2vw;
    margin-right: -2vw;
}

body.tt-boxed .tt-wrap .tt-grid.ttgr-gap-4 {
    margin-left: -3vw;
    margin-right: -3vw;
}

body.tt-boxed .tt-wrap .tt-grid.ttgr-gap-5 {
    margin-left: -4vw;
    margin-right: -4vw;
}

body.tt-boxed .tt-wrap .tt-grid.ttgr-gap-6 {
    margin-left: -5vw;
    margin-right: -5vw;
}

@media (min-width: 768px) {

    .ttgr-layout-2 .pgi-title,
    .ttgr-layout-1-2 .pgi-title,
    .ttgr-layout-2-1 .pgi-title,
    .ttgr-layout-creative-1 .pgi-title,
    .ttgr-layout-creative-2 .pgi-title {
        font-size: calc(19px + 0.4vw);
    }

    .ttgr-layout-3 .pgi-title,
    .ttgr-layout-2-3 .pgi-title,
    .ttgr-layout-3-2 .pgi-title {
        font-size: calc(19px + 0.2vw);
    }

    .ttgr-layout-4 .pgi-title,
    .ttgr-layout-3-4 .pgi-title,
    .ttgr-layout-4-3 .pgi-title {
        font-size: calc(19px + 0.1vw);
    }


    body.tt-boxed .tt-wrap .ttgr-layout-2 .pgi-title,
    body.tt-boxed .tt-wrap .ttgr-layout-1-2 .pgi-title,
    body.tt-boxed .tt-wrap .ttgr-layout-2-1 .pgi-title {
        font-size: calc(19px + 0.2vw);
    }

    body.tt-boxed .tt-wrap .ttgr-layout-3 .pgi-title,
    body.tt-boxed .tt-wrap .ttgr-layout-2-3 .pgi-title,
    body.tt-boxed .tt-wrap .ttgr-layout-3-2 .pgi-title {
        font-size: calc(19px + 0.1vw);
    }

    body.tt-boxed .tt-wrap .ttgr-layout-4 .pgi-title,
    body.tt-boxed .tt-wrap .ttgr-layout-3-4 .pgi-title,
    body.tt-boxed .tt-wrap .ttgr-layout-4-3 .pgi-title {
        font-size: calc(19px + 0.1vw);
    }
}

body.tt-boxed .tt-wrap .portfolio-interactive {
    padding-left: 3%;
    padding-right: 3%;
}

@media (max-width: 1400px) {
    body.tt-boxed .tt-wrap .tt-page-nav {
        padding-left: 8%;
        padding-right: 8%;
    }
}

body.tt-boxed .tt-wrap .tt-pagination {
    padding-left: 0;
    padding-right: 0;
}

/* if page boxed layout enabled */
body.tt-boxed .blog-single-inner.tt-wrap {
    padding-left: 15px;
    padding-right: 15px;
}

body:not(.tt-boxed) .tt-footer-inner,
.tt-footer-inner:not(.tt-wrap) {
    padding-left: 3.5%;
    padding-right: 3.5%;
}

.ph-caption {
    position: relative;
}

.ph-caption-title {
    position: relative;
    margin: 0;
    font-size: clamp(18px, 3.8vw, 56px);
    font-weight: bold;
    font-weight: 600;
    color: #FFF;
    line-height: 1.2;
    z-index: 9;
}

.ph-caption-title-ghost {
    position: absolute;
    display: flex;
    align-items: center;
    top: 0;
    bottom: 0;
    left: 6%;
    padding-top: 5%;
    font-size: calc(16px + 19.5vw);
    font-weight: bold;
    font-weight: 600;
    color: #FFF;
    white-space: nowrap;
    line-height: 1;
    opacity: .1;
    z-index: 1;
    pointer-events: none;
}

.ph-caption-title-ghost .phgh-text {
    /* cloned text by .js */
    display: inline-block;
    margin-right: 7vw;
}

#page-header.ph-bg-image .ph-caption-title-ghost {
    /* disable title ghost if "ph-bg-image" is enabled */
    display: none;
}

/* page header caption subtitle */
.ph-caption-subtitle {
    position: relative;
    margin-bottom: 20px;
    font-size: calc(15px + 0.3vw);
    font-weight: 500;
    color: #CCC;
    z-index: 9;
}

.ph-caption-title+.ph-caption-subtitle {
    margin-top: 20px;
    margin-bottom: 0;
}

.ph-caption-title+.ph-categories {
    margin-top: 20px;
    margin-bottom: 0;
}

.ph-caption-description {
    position: relative;
    max-width: 740px;
    margin-top: 30px;
    font-size: 24px;
    font-weight: 500;
    color: #FFF;
    z-index: 9;
}

/* page header caption paragraph */
.ph-caption>p {
    position: relative;
    max-width: 900px;
    z-index: 9;
}

.ph-caption .ph-caption-title+p,
.ph-caption .ph-caption-title-ghost+p,
.ph-caption .ph-caption-subtitle+p {
    margin-top: 30px;
}

.ph-caption>p:last-child {
    margin-bottom: 0;
}

body.tt-light-bg-on .ph-category,
body.tt-light-bg-on .ph-caption-title,
body.tt-light-bg-on .ph-caption-subtitle,
body.tt-light-bg-on .ph-meta,
body.tt-light-bg-on .ph-meta a {
    color: #111;
}

body.tt-light-bg-on #page-header.ph-stroke .ph-caption-title {
    -webkit-text-stroke-color: #111;
}

@media (max-width: 768px) {
    .hide-from-sm {
        display: none !important;
    }
}

.text-stroke-light {
    font-weight: bold;
    font-weight: 700;
    color: transparent;
    -webkit-text-stroke-width: 2px;
    -webkit-text-stroke-color: #FFF;
    -webkit-text-fill-color: transparent;
}

/* #creative-word {
    position: relative;
    transition: transform 0.1s ease-out;
    will-change: transform;
} */

.text-primary {
    color: #3C6ABC !important;
}

.text-stroke-dark {
    font-weight: bold;
    font-weight: 700;
    color: transparent;
    -webkit-text-stroke-width: 2px;
    -webkit-text-stroke-color: #3C6ABC;
    -webkit-text-fill-color: transparent;
}

.ph-caption-title-ghost-dark {
    position: absolute;
    display: flex;
    align-items: center;
    top: 0;
    bottom: 0;
    left: 6%;
    padding-top: 5%;
    font-size: calc(16px + 19.5vw);
    font-weight: bold;
    font-weight: 600;
    color: #3C6ABC;
    white-space: nowrap;
    line-height: 1;
    opacity: .1;
    z-index: 1;
    pointer-events: none;
}

.margin-top-custom-confirmaciones-home {
    margin-top: 12rem;
}

@media only screen and (min-width: 1200px) {
    .main__intro-custom {
        height: 90vh;
    }
}

/* * Page header image 
===================== */
.ph-image {
    position: relative;
    top: 0;
    /* right: 15vw; */
    width: 100%;
    z-index: 2;
    line-height: 0;
}

@media (max-width: 1920px) {}



.ph-image-inner {
    position: relative;
    width: 100%;
    padding-top: 15%;
}

/* Video */
#page-header:not(.ph-image-cropped) .ph-video-wrap {
    position: relative;
    padding-bottom: 140%;
}

.ph-video {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
}

[class*="ph-image-cover-"] .ph-image-inner::before {
    position: absolute;
    display: block;
    content: "";
    top: -1px;
    left: -1px;
    bottom: -1px;
    right: -1px;
    background-color: #040404;
    z-index: 1;
    opacity: 0;
}

.ph-image-cover-0 .ph-image-inner::before {
    opacity: 0;
}

.ph-image-cover-0-5 .ph-image-inner::before {
    opacity: .05;
}

.ph-image-cover-1 .ph-image-inner::before {
    opacity: .1;
}

.ph-image-cover-1-5 .ph-image-inner::before {
    opacity: .15;
}

.ph-image-cover-2 .ph-image-inner::before {
    opacity: .2;
}

.ph-image-cover-2-5 .ph-image-inner::before {
    opacity: .25;
}

.ph-image-cover-3 .ph-image-inner::before {
    opacity: .3;
}

.ph-image-cover-3-5 .ph-image-inner::before {
    opacity: .35;
}

.ph-image-cover-4 .ph-image-inner::before {
    opacity: .4;
}

.ph-image-cover-4-5 .ph-image-inner::before {
    opacity: .45;
}

.ph-image-cover-5 .ph-image-inner::before {
    opacity: .5;
}

.ph-image-cover-5-5 .ph-image-inner::before {
    opacity: .55;
}

.ph-image-cover-6 .ph-image-inner::before {
    opacity: .6;
}

.ph-image-cover-6-5 .ph-image-inner::before {
    opacity: .65;
}

.ph-image-cover-7 .ph-image-inner::before {
    opacity: .7;
}

.ph-image-cover-7-5 .ph-image-inner::before {
    opacity: .75;
}

.ph-image-cover-8 .ph-image-inner::before {
    opacity: .8;
}

.ph-image-cover-8-5 .ph-image-inner::before {
    opacity: .85;
}

.ph-image-cover-9 .ph-image-inner::before {
    opacity: .9;
}

.ph-image-cover-9-5 .ph-image-inner::before {
    opacity: .95;
}

@media only screen and (min-width: 1200px) {
    .headline-home {
        bottom: inherit;
        transform: translate(0px, 30%);
    }
}

@media only screen and (min-width: 1200px) {
    .menu__link.active {
        background-color: transparent !important;
    }

    .headline-home {
        position: absolute;
        bottom: 0;
        left: 0;
        margin-top: 1rem !important;
    }
}

@media only screen and (min-width: 768px) {
    .headline-home {
        padding: 0 5rem;
        margin-top: 14.2rem;
    }
}

.headline-home {
    position: relative;
    padding: 0 2rem;
    margin-top: 0rem;
}

@media only screen and (min-width: 1400px) {
    .footer__text {
        font-size: 7rem;
    }
}

@media only screen and (min-width: 1200px) {
    .footer__text {
        font-size: 6rem;
    }
}

@media only screen and (min-width: 768px) {
    .footer__text {
        font-size: 5rem;
    }
}

/* img-header */
/* .intro-bg-02__02-custom {
    bottom: 160px;
    top: 250px;
    left: -100px;
    width: 300px;
    height: auto;
} */
@media only screen and (max-width: 768px) {
    .intro-bg-02__02-custom {
        display: none;
    }
}

@media only screen and (max-width: 992px) {
    .intro-bg-02__02-custom {
        display: none;
    }
}

@media only screen and (max-width: 1200px) {

    .intro-bg-02__02-custom {
        bottom: 160px;
        top: 250px;
        left: -100px;
        width: 300px;
        height: auto;
    }

    blockquote {
        font-size: 2.8rem !important;
        line-height: 3.5rem;
    }
}

@media only screen and (min-width: 1400px) {
    .intro-bg-02__02 {
        bottom: auto;
        top: 215px;
        left: -80px;
        width: 300px;
        height: auto;
    }
}

@media only screen and (min-width: 1600px) {
    .intro-bg-02__02 {
        top: 260px;
        bottom: auto;
        left: -135px;
        width: 430px;
        height: auto;
    }
}

/* btn circular scroll */
.tt-scrolling-btn-home {
    position: absolute;
    right: -35px;
    transition: transform 0.5s ease;
    z-index: 9;
    transform-origin: bottom;
    transform: translate(0px, 50%);
    bottom: 110px;
}

.tt-scrolling-btn-home svg {
    width: 100%;
}

.tt-scrolling-btn-home:hover .scr-btn-icon-home {
    color: var(--t-bright);
}

.tt-scrolling-btn-home:hover .scr-btn-text-home {
    fill: var(--t-bright);
}

@media (max-width: 991px) {
    .tt-scrolling-btn-home {
        transform: scale(.8);
    }
}

@media (max-width: 380px) {
    .tt-scrolling-btn-home {
        transform: scale(.7);
    }

    #grafica {
        width: 100% !important;
        margin: 0;
    }
}


.services-stack__image {
    padding-left: 0 !important;
}

.scr-btn-icon-home {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    left: 50%;
    top: 50%;
    width: 120px;
    height: 120px;
    font-size: 50px;
    color: #3C6ABC;
    background-color: transparent;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: color .2s;
}

.scr-btn-icon-carousel {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    left: 50%;
    top: 50%;
    width: 120px;
    height: 120px;
    font-size: 30px;
    color: #3C6ABC;
    background-color: transparent;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: color .2s;
}

.tt-scrolling-btn-home:hover .scr-btn-icon-home {
    color: var(--t-bright);
}

.scr-btn-spinner-home {
    width: 260px;
    /* Ajusta el tamaño del contenedor */
    height: 260px;
}

.scr-btn-text-home {
    font-size: 35px;
    font-weight: bold;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 14px;
    fill: var(--t-bright);
    transition: fill .2s;
}

.scr-btn-text-carousel {
    font-size: 25px;
    font-weight: bold;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 22px;
    fill: var(--t-bright);
    transition: fill .2s;
}

.tt-scrolling-btn-home-header {
    position: absolute;
    right: 15px;
    transition: transform 0.5s ease;
    z-index: 9;
    transform-origin: bottom;
    transform: translate(0px, 50%);
    bottom: 0px;
}

.scr-btn-spinner-home-header {
    width: 260px;
    /* Ajusta el tamaño del contenedor */
    height: 260px;
}

.icon-go-back {
    top: 105px;
    left: 22px;
    z-index: 999;
}

/* Estilos para el dropdown */
.menu__item.dropdown {
    position: relative;
}

.dropdown-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: #fff;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    min-width: 160px;
}

.dropdown-menu .dropdown-item {

    display: block;
    text-decoration: none;
    color: #333;
}

.dropdown-menu .dropdown-item:hover {
    background-color: #f1f1f1;
}

/* Mostrar el dropdown al pasar el mouse */
.menu__item.dropdown:hover .dropdown-menu {
    display: block;
}



.headline-home {
    transform: translate(0px, 20%);
}


.contact-data__title {
    margin-bottom: 0rem;
}

[color-scheme=light] {
    .card {
        background-color: #ffffff !important;
        color: #3C6ABC !important;
    }

    .card:hover {
        background-color: #ffffff !important;
        color: #ffffff !important;
    }

    .btn-default {
        color: #3C6ABC !important;
        border-color: #3C6ABC !important;
        background-color: #ffffff !important;
    }

    .btn-default:hover {
        color: #83e7fc !important;
        border-color: #83e7fc !important;
        background-color: #ffffff !important;
    }

    /* h4.switch-color-static{
        color: #3C6ABC !important;
    } */

}

@media only screen and (min-width: 768px) {
    .contact-data__title {
        margin-bottom: 2.5rem;
    }

    .ph-image {
        position: absolute;
        top: 10px;
        right: 8vw;
        width: clamp(297px, 10vw, 800px);
        z-index: 2;
        line-height: 0;
    }
    
    .headline-home {
        transform: translate(0px, 40%);
    }

    h1 {
        font-size: 4.5rem;
        font-weight: 600;
    }
    

    .tt-scrolling-btn-home-header {
        bottom: 5px !important;
    }

    [color-scheme=light] {
        .card {
            background-color: #ffffff !important;
            color: #3C6ABC !important;
        }

        .card:hover {
            background-color: #3C6ABC !important;
            color: #ffffff !important;
        }

        .btn-default {
            color: #3C6ABC !important;
            border-color: #3C6ABC !important;
            background-color: #ffffff !important;
        }

        .btn-default:hover {
            color: #83e7fc !important;
            border-color: #83e7fc !important;
            background-color: #ffffff !important;
        }


    }
}
@media only screen and (min-width: 1200px) {

    .h1-home {
        font-size: 6.5rem !important;
    }

    .custom-wrapper {
        width: 100%;
        height: 100vh !important;
        background-color: #111;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        position: relative;
    }
    .custom-nav {
        position: absolute;
        bottom: 80px !important;
        left: 80px;
        display: flex;
        flex-direction: row;
        z-index: 10;
        /* overflow: hidden; */
    }
    .btn-projects-rsvp {
        position: absolute;
        right: inherit;
        transition: transform 0.5s ease;
        z-index: 9;
        transform-origin: bottom;
        transform: translate(-15%, 15px) !important;
        /* bottom: inherit; */
        left: 50px;
    }
    .ph-image-confirmaciones {
        right: 8vw;
        width: clamp(450px, 10vw, 800px);
    }
    .h1-confirmaciones {
        font-size: 6rem !important;
    }
}

@media only screen and (min-width: 1400px) {
    .h1-home {
        font-size: 7rem !important;
    }
    .ph-caption-title {
        font-size: clamp(45px, 9.8vw, 70px);
    }
}

@media only screen and (min-width: 1600px) {
    .h1-home {
        font-size: 9rem !important;
    }

    th {
        padding: 0rem 0.3rem !important;
    }
    .ph-image {
        right: 14vw;
        width: clamp(450px, 10vw, 800px);
    }
    .ph-image-confirmaciones{
        width: clamp(455px, 30vw, 800px)
    }

    .tt-scrolling-btn-home {
        right: 25px;
    }
}




/* Fin home */


/* Responsive - Loomtek */

@media only screen and (min-width: 280px) and (max-width: 720px) {
    .orblets-intro-bg-01 {
        top: -30px;
        right: -30px;
    }

    .socials-cards__item {
        width: 32%;
    }

    .tt-scrolling-btn-home-header {
        right: 30 !important;
    }

    .col-md-6.d-flex,
    .col-4.d-flex {
        padding-bottom: 20px;
        ;
    }

    .confirmaciones-bg-01 {
        top: -30px;
        right: -75px;
        width: 250px;
    }



    .socials-cards__link i {
        font-size: 3em;
    }

    .bottom-bg-01__01 {
        bottom: 60px
    }



    .cards__image-v2 {
        padding-left: 0 !important;
    }

    .cards__image {
        display: flex;
        justify-content: center;
        /* Centra horizontalmente */
        align-items: center;
        /* Centra verticalmente */
    }

    .whatsappConversation {
        margin: 0 auto;
        /* Asegura que esté centrado */
    }

    .tt-scrolling-btn.all-works-btn.not-hide-cursor {
        transform: translate(40px, 150px) scale(0.6, 0.6) !important;
    }
}

@media only screen and (min-width: 730px) and (max-width: 1024px) {

    .confirmaciones-bg-01 {
        top: -30px;
        right: -75px;
        width: 450px;
    }

    .tt-scrolling-btn-home-header {
        right: -40px;
    }

    .ph-caption-title,
    #page-header.ph-cap-lg .ph-caption-title {
        font-size: clamp(18px, 4.8vw, 56px);
    }

    .ph-image-inner {
        width: 130%;
    }

    #page-header:not(.ph-bg-image).ph-image-cropped .ph-image-inner {
        padding-bottom: 90%;
    }



    .headline-home {
        padding: 0 25rem 0 6rem;
    }

    .intro-bg-01__02 {
        bottom: 60px;
        right: 81px;
        width: 450px;
    }

    .col-md-6.d-flex,
    .col-4.d-flex {
        padding-bottom: 20px;
        ;
    }

    #page-header .page-header-inner {
        padding-top: 50px;
        padding-bottom: 50px;
    }

    .ph-image {
        top: 30px;
    }

    .services-stack__image {
        padding-left: 0 !important;
    }

}

@media only screen and (min-width: 768px) {

    .tauthor__avatar {
        margin-right: 1.5rem;
    }

    .btn-default {
        line-height: 3rem;
        padding: 0 5.6rem !important;
    }
}

.custom-h5 {
    color: #83e7fc;
}

@media (max-width: 450px) {
    .tt-scrolling-btn {
        transform: scale(0.8);
        transform-origin: center center;
        /* Escala desde el centro del componente */
    }

    .footer__link {
        margin-bottom: 14.8rem;
    }

    #grafica {
        width: 100% !important;
        margin: 0;
    }

    .services-stack__image {
        padding-left: 0 !important;
    }

    .padding-custom {
        padding-top: 5em;
    }

    .content__block.name-block {
        padding: 2rem;
    }

    .intro-bg-02__01 {
        bottom: -115px;
    }

    .margintop-custom {
        margin-top: 7em;
    }

    .margin-top-custom-confirmaciones-home {
        margin-top: 1rem
    }






    #page-header.ph-cap-lg .ph-caption-title,
    .ph-caption-title {
        font-size: clamp(18px, 8vw, 86px);
    }


    .custom-text {
        font-size: 25px;
        left: 40px;
        top: 200px;
        width: 80%;
    }



    .tt-scrolling-btn-home.scroll-rotate.not-hide-cursor.btn-projects-rsvp {
        bottom: 300px;
    }

    .scr-btn-inner.ph-appear.contact {
        padding-left: 15%;
    }

    .tt-scrolling-btn-home.contact-scrolling {
        position: static;
    }



    .contact-data__item {
        margin-bottom: 0;
    }

    .scr-btn-icon {
        width: 100px;
        height: 100px;
    }

    .scr-btn-spinner {
        width: 180px;
        height: 180px;
    }

    .services-stack__image {
        padding-left: 0 !important;
    }




    .divider-image,
    .divider-video {
        height: 150px !important;
    }

    .portfolio-stack__descr {
        display: block !important;
    }



    blockquote {
        font: normal 300 2.2rem/1.4 var(--_font-default) !important;
    }

    .h-white {
        background-color: rgba(255, 255, 255, 0.75);
    }
}

.btn-projects-rsvp {
    position: absolute;
    right: inherit;
    transition: transform 0.5s ease;
    z-index: 9;
    transform-origin: bottom;
    transform: translate(-15%, 15px);
    /* bottom: inherit; */
    left: 50px;
}

.services-stack__image {
    padding-left: 0 !important;
}

/* Estilo general del carrusel */
.custom-carousel {
    position: relative;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Contenedor interno */
.custom-carousel-inner {
    display: flex;
    transition: transform 0.5s ease-in-out;
}

/* Elementos individuales del carrusel */
.custom-carousel-item {
    flex: 0 0 100%;
    text-align: center;
    position: relative;
}

.custom-carousel-item img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* Subtítulos */
.custom-carousel-caption {
    position: absolute;
    bottom: 35%;
    /* Ajuste de la distancia desde el fondo */
    left: 50%;
    /* Centrado horizontal */
    transform: translateX(-50%) translateY(50%);
    /* Centrado tanto vertical como horizontal */
    background: rgba(0, 0, 0, 0.5);
    /* Fondo semi-transparente */
    color: white;
    /* Color de texto */
    padding: 15px;
    /* Espaciado interno */
    border-radius: 8px;
    /* Bordes redondeados */
    text-align: center;
    /* Alineación de texto */
    width: 80%;
    /* Ancho ajustado para no ocupar toda la pantalla */
    box-sizing: border-box;
    /* Incluye el padding en el ancho total */
}

.custom-carousel-caption h5 {
    font-size: 1.4rem;
    /* Ajuste del tamaño de la fuente del título */
    margin: 0;
}

.custom-carousel-caption p {
    font-size: 1rem;
    /* Tamaño de la fuente del párrafo */
    margin-top: 5px;
    /* Espaciado entre título y párrafo */
}


/* Controles del carrusel */
.custom-carousel-control {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 2rem;
    color: white;
    background: rgba(0, 0, 0, 0);
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 2;
    border-radius: 50%;
}

.custom-carousel-control.prev {
    left: 10px;
}

.custom-carousel-control.next {
    right: 10px;
}

.custom-carousel-control:hover {
    background: rgba(0, 0, 0, 0.8);
}

p.custom-p {
    color: #fff;
    font-size: 1.8rem;
}


[color-scheme="dark"] {
    a.menu__link.btn {
        color: #fff !important;
    }

    a.menu__link.btn.white {
        color: #fff !important;
    }

    @media screen and (max-width:768px) {
        .menu__link.active {
            background-color: #3C6ABC;
        }
    }

    @media only screen and (min-width: 768px) {
        .header {
            background-color: rgba(255, 255, 255, 0.57);
        }

    }
}

a.menu__link.btn.white {
    color: #fff !important;
}

/* --------------- */
.table {
    margin: 2rem 0 0 0 !important;
}

.table-bordered td,
.table-bordered th {
    border: 1px solid #dee2e6;
    /* Bordes completos para todos los td y th */
}

.table-bordered th {
    font-size: 1.5rem;
    line-height: 1.8rem;
    padding: 1rem !important;

}

.card-body {
    display: flex;
    flex-direction: column;
    /* Asegura que los elementos estén en columna */
    justify-content: space-between;
    /* Distribuye los elementos: arriba, centro y abajo */
    height: 100%;
    /* El contenedor ocupará toda la altura */
}
@media only screen and (min-width: 1024px) and (max-width: 1366px) {
    .intro-bg-02__02-custom {
        display: none;
    }
}

@media only screen and (min-width: 1024px) {
    .p-custom-section-porque {
        padding: 0 55px !important;
    }
}


/*  */
.word-custom{
    font-size: 3.79rem;
}
.tt-scrolling-btn-home-ir-confirmaciones, .tt-scrolling-btn-home-ir-confirmaciones-orblets{
    position: absolute;
    transform: translate(0%, 50%) !important;
    bottom: 0px !important;
}

@media only screen and (min-width: 768px) {

    blockquote,
    .h2__text {
        max-width: 100%;
    }
    .word-custom{
        font-size: 7rem;
    }
    .tt-scrolling-btn-home-ir-confirmaciones, .tt-scrolling-btn-home-ir-confirmaciones-orblets{
        position: static !important;
        transform: translate(0%, 0%) !important;
        bottom: 0px !important;
    }
    .icon-go-back {
        top: 120px;
        left: 50px;
    }
    /* .contact-data__item:nth-of-type(3), .contact-data__item:last-of-type {
        margin-bottom: 4.3rem;
    } */
    /* .inner__name {
        margin-bottom: 2.5rem;
    } */
}
@media only screen and (min-width: 992px) {

    .tt-scrolling-btn-home-ir-confirmaciones, .tt-scrolling-btn-home-ir-confirmaciones-orblets{
        position: absolute !important;
        transform: translate(0%, 50%) !important;
    }
    .custom-wrapper {
        width: 100%;
        height: 50vh;
        background-color: #111;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        position: relative;
    }
    .custom-nav{
        bottom: -200px;
    }
    .btn-projects-rsvp {
        transform: translate(-15%, 300px);
    }
    .custom-text {
        top: 100px;
    }

    .custom-text {
        top: 60px;
    }
    .h1-confirmaciones {
        font-size: 7.5rem !important;
    }
    .word-custom{
        font-size: 6rem;
    }
    
}
@media only screen and (min-width: 1300px) {
    .h1-home {
        font-size: 8.5rem !important;
    }
    .h1-confirmaciones {
        font-size: 8.5rem !important;
    }
}
.main__intro-custom{
    height:auto !important;
}

@media only screen and (max-width: 576px) {
    .intro-bg-01__01 {
        top: -82px !important;
        right: -50px !important;
        width: 290px !important;
        height: 290px !important;
    }
    .img-logo{
        height: 45px;
        width: 70px;
    }
    .logo {
        top: 1rem;
        left: 1rem;
    }
    .logo-custom{
        left: 50% !important; 
        transform: translateX(-50%) !important;
    }
}


