.elementor-2445 .elementor-element.elementor-element-1865aaa{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-f0c0a73 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2445 .elementor-element.elementor-element-d9c2cf4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-3f4f9c3{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-66c3a58 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2445 .elementor-element.elementor-element-b2d223e{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-dd32f17 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2445 .elementor-element.elementor-element-c6b05bc{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-50d16a4 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2445 .elementor-element.elementor-element-5c10e42{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-9806e25 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2445 .elementor-element.elementor-element-c41e6dc{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-651cc5e > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2445 .elementor-element.elementor-element-a6a5e97{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2445 .elementor-element.elementor-element-532b532 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2445 .elementor-element.elementor-element-02b0d2f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for html, class: .elementor-element-f0c0a73 *//* ===== HERO SECTION ===== */

.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #0B0D17;
    font-family: 'Inter', sans-serif;
}

/* Radial glow */
.hero-radial {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle, rgba(10,9,210,0.2) 0%, transparent 60%);
    opacity: 0.5;
}

/* Grid background */
.hero-grid {
    position: absolute;
    inset: 0;
    opacity: 0.08;
    background-image: 
        linear-gradient(rgba(35, 61, 255, 0.3) 1px, transparent 1px),
        linear-gradient(90deg, rgba(35, 61, 255, 0.3) 1px, transparent 1px);
    background-size: 50px 50px;
}

/* Container */
.hero-container {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 1100px;
    padding: 0 24px;
}

.hero-content {
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

/* Title */
.hero-title {
    font-size: 56px;
    font-weight: 700;
    color: #fff;
    line-height: 1.1;
    margin-bottom: 24px;
    letter-spacing: -0.02em;
}

.hero-highlight {
    background: linear-gradient(90deg, #0A09D2, #233DFF);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Subtitle */
.hero-subtitle {
    font-size: 20px;
    color: #c7c9d3;
    margin-bottom: 40px;
    line-height: 1.6;
}

/* Buttons */
.hero-buttons {
    display: flex;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
}

.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 16px 32px;
    background: #0A09D2;
    color: #fff;
    border-radius: 10px;
    font-weight: 600;
    text-decoration: none;
    transition: 0.3s ease;
    box-shadow: 0 0 30px rgba(10,9,210,0.4);
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 0 40px rgba(10,9,210,0.7);
}

.btn-secondary {
    padding: 16px 32px;
    border: 2px solid #233DFF;
    color: #fff;
    border-radius: 10px;
    font-weight: 600;
    text-decoration: none;
    transition: 0.3s ease;
}

.btn-secondary:hover {
    background: rgba(35,61,255,0.1);
}

.btn-icon {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
}
@media (max-width: 1024px) {
    .hero-title {
        font-size: 46px;
    }
}

@media (max-width: 768px) {
    .hero-title {
        font-size: 38px;
    }

    .hero-subtitle {
        font-size: 18px;
    }
}

@media (max-width: 426px) {
    .hero-title {
        font-size: 30px;
    }

    .hero-subtitle {
        font-size: 16px;
    }

    .btn-primary,
    .btn-secondary {
        width: 100%;
        justify-content: center;
    }
}

.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-secondary,
.btn-secondary:hover,
.btn-secondary:focus {
    color: #ffffff;
}


@media (max-width: 1024px) {

    .elementor-kit-106 h1 {
        margin-left: 5px;
        margin-right: 5px;
        font-family: "Inter", Sans-serif;
        font-size: 58px;
        font-weight: 700;
    }

    .break-tablet {
        display: block;
    }

}

@media (max-width: 426px) {
    .hero {
        padding-top: 8px !important;
        padding-bottom: 90px;
       
    }
}

.hero-radial {
    position: absolute;
    inset: 0;
    background: radial-gradient(
        circle at 50% 40%, 
        rgba(35, 61, 255, 0.25) 0%, 
        rgba(10, 9, 210, 0.15) 30%, 
        transparent 65%
    );
}

.hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, transparent 55%, #0B0D17 100%);
    pointer-events: none;
}

.hero-grid {
    opacity: 0.04;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-1865aaa */@media (max-width: 1024px) {
    .hero-subtitle {
        max-width: 520px;
        margin: 0 auto;
    }
}

@media (max-width: 1024px) {
    .hero-subtitle {
        margin-bottom: 30px;
    }
}

@media (max-width: 426px) {
    .elementor-kit-106 h1 {
        margin-left: 5px;
        margin-right: 5px;
        font-family: "Inter", Sans-serif;
        font-size: 35px;
        font-weight: 700;
    }
}
@media (max-width: 376px) {
    .elementor-kit-106 h1 {
        margin-left: 5px;
        margin-right: 5px;
        font-family: "Inter", Sans-serif;
        font-size: 32px;
        font-weight: 700;
    }
}

@media (max-width: 426px) {
    .hero-grid {
        opacity: 0.05;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6842c70 */.clients {
    padding: 70px 0;
    background: #0B0D17;
}

.clients-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 60px;
}

.clients-title {
    text-align: center;
    font-size: 13px;
    letter-spacing: 2px;
    font-weight: 700;
    color: #7a7f8f;
    margin-bottom: 50px;
}

.clients-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 40px;
    align-items: center;
}

.client-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.5;
    transition: all 0.3s ease;
    text-decoration: none;
}

.client-logo img {
    max-height: 45px;
    width: auto;
    filter: grayscale(100%) brightness(1.2);
    transition: 0.3s ease;
}

.client-logo:hover {
    opacity: 1;
    transform: translateY(-3px);
}

.client-logo:hover img {
    filter: grayscale(0%) brightness(1);
}

/* Claudia Fossas estilo real */
.claudia {
    flex-direction: column;
    font-family: "Playfair Display", serif;
    text-align: center;
}

.claudia-top {
    font-size: 14px;
    letter-spacing: 0.15em;
    font-weight: 600;
    color: #6B2C3E;
}

.claudia-sub {
    font-family: "Poppins", sans-serif;
    font-size: 8px;
    letter-spacing: 0.25em;
    font-weight: 300;
    color: #9B8E87;
    margin-top: 4px;
}

.client-logo {
    opacity: 0.9;
    transition: all 0.3s ease;
}

.client-logo img {
    max-height: 65px; /* antes 45 */
    width: auto;
    filter: none; /* mantiene colores originales */
    transition: 0.3s ease;
}

.client-logo:hover {
    opacity: 1;
    transform: translateY(-4px);
}

.clients {
    position: relative;
    padding: 80px 0;
    background: #0B0D17;
}

.clients {
    position: relative;
    padding: 80px 0;
    background: linear-gradient(
        to bottom,
        #0B0F1F 0%,
        #10162B 100%
    );
}

.clients-title {
    font-weight: 700;
    letter-spacing: 3px;
    color: rgba(255,255,255,0.75);}
    
    
    @media (max-width: 426px) {

    .clients {
        padding: 60px 0;
    }

    .clients-container {
        padding: 0 20px;
    }

    .clients-title {
        font-size: 11px;
        letter-spacing: 2px;
        text-align: center;
        line-height: 1.4;
        margin-bottom: 35px;
    }

    .clients-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 35px 20px;
    }

    .client-logo img {
        max-height: 55px;
    }

    .claudia-top {
        font-size: 12px;
    }

    .claudia-sub {
        font-size: 7px;
    }

}

.client-logo.defensa img {
    max-height: 75px; /* antes 65 aprox */
}

.clients {
    position: relative;
    padding: 80px 0;
    background: linear-gradient(
        180deg,
        #080C1A 0%,
        #0B0F1F 40%,
        #10162B 100%
    );
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-66c3a58 */.services-section {
    background: #0B0D17;
    padding: 120px 0;
    position: relative;
    font-family: Inter, sans-serif;
}

.services-container {
    max-width: 1200px;
    margin: auto;
    padding: 0 24px;
}

.services-header {
    text-align: center;
    margin-bottom: 60px;
}

.services-header h2 {
    font-size: 48px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 10px;
}

.services-header p {
    font-size: 18px;
    color: #9aa3b2;
}

/* 🔥 GRID REAL */
.services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

/* Cards */
.service-card {
    background: linear-gradient(145deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    transition: all 0.35s ease;
}

.service-card:hover {
    transform: translateY(-8px);
    border-color: rgba(35,61,255,0.6);
    box-shadow: 0 20px 60px rgba(35,61,255,0.18);
}

/* Icon */
.icon-box {
    width: 60px;
    height: 60px;
    border-radius: 14px;
    background: linear-gradient(135deg, #0A09D2, #233DFF);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    margin-bottom: 20px;
}

/* Textos */
.service-card h3 {
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 12px;
}

.service-card p {
    color: #a8b0c8;
    font-size: 15px;
    line-height: 1.6;
    flex-grow: 1;
}

/* Botón */
.service-btn {
    margin-top: 20px;
    padding: 12px;
    text-align: center;
    background: #0A09D2;
    color: white;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
    transition: 0.3s;
}

.service-btn:hover {
    box-shadow: 0 0 25px rgba(10,9,210,0.5);
    transform: translateY(-2px);
}

/* 🔥 Responsive correcto */
@media (max-width: 1024px) {
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .services-grid {
        grid-template-columns: 1fr;
    }

    .services-header h2 {
        font-size: 32px;
    }
}

.icon {
    width: 26px;
    height: 26px;
    stroke: white;
    stroke-width: 2;
}
/* ===== GRID ===== */

.services-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
}

/* ===== CARD BASE ===== */

.service-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 2rem;
    border-radius: 1rem;
    border: 1px solid rgba(255,255,255,0.08);

    background: linear-gradient(
        to bottom right,
        rgba(255,255,255,0.05),
        rgba(255,255,255,0.02)
    );

    backdrop-filter: blur(8px);
    position: relative;
    overflow: hidden;

    transition: all 0.3s ease;
}

/* ===== HOVER EXTERNO ===== */

.service-card:hover {
    border-color: rgba(35, 61, 255, 0.6);
    transform: translateY(-6px);
    box-shadow: 0 0 50px rgba(35, 61, 255, 0.15);
}

/* ===== GLOW INTERNO (EFECTO PREMIUM) ===== */

.service-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 1rem;
    background: radial-gradient(
        circle at 50% 50%,
        rgba(35, 61, 255, 0.25),
        transparent 70%
    );
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
}

.service-card:hover::after {
    opacity: 1;
}


/* ===== BOTÓN ===== */

.service-btn {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    background: linear-gradient(135deg, #0A09D2, #233DFF);
    color: white;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
}


/* ===== RESPONSIVE ===== */

@media (max-width: 1024px) {
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .services-grid {
        grid-template-columns: 1fr;
    }
}

.icon-box svg {
    stroke: #ffffff !important;
}

.service-btn:hover {
    color: #ffffff !important;
}


@media (max-width: 1024px) {
  .icon-box {
    margin-left: auto;
    margin-right: auto;
  }
}

@media (max-width: 1024px) {
  .service-card h3 {
    text-align: center;
  }
}

@media (max-width: 1024px) {
  .service-card p {
    text-align: center;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-dd32f17 *//* ============================= */
/* SECCIÓN PROYECTOS DESTACADOS */
/* ============================= */

section.py-32 {
    background: #08090F;
    padding-top: calc(var(--spacing) * 32);
    padding-bottom: calc(var(--spacing) * 32);
}

/* Container */
.container {
    width: 100%;
    max-width: var(--container-7xl);
    margin-left: auto;
    margin-right: auto;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

/* Header */
.text-center {
    text-align: center;
}

.mb-16 {
    margin-bottom: 4rem;
}

.text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--text-4xl--line-height);
}

.text-5xl {
    font-size: var(--text-5xl);
    line-height: var(--text-5xl--line-height);
}

.text-lg {
    font-size: var(--text-lg);
    line-height: var(--text-lg--line-height);
}

.text-white {
    color: #fff;
}

.text-gray-400 {
    color: #9ca3af;
}

.font-bold {
    font-weight: var(--font-weight-bold);
}

.font-semibold {
    font-weight: var(--font-weight-semibold);
}

.mb-4 { margin-bottom: 1rem; }

/* Grid */
.grid {
    display: grid;
    gap: 2rem;
}

.max-w-7xl {
    max-width: var(--container-7xl);
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

/* Responsive columns */
@media (min-width: 768px) {
    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, 1fr);
    }

    .md\:text-5xl {
        font-size: var(--text-5xl);
        line-height: var(--text-5xl--line-height);
    }
}

@media (min-width: 1024px) {
    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Card */
.group {
    position: relative;
    background: #0F111A;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.1);
    transition: all 0.3s var(--ease-in-out);
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
}

.group:hover {
    border-color: rgba(35,61,255,0.5);
}

/* Aspect ratio 16:9 */
.aspect-video {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.aspect-video img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s var(--ease-in-out);
}

.group:hover img {
    transform: scale(1.05);
}

/* Overlay */
.aspect-video .absolute {
    position: absolute;
    inset: 0;
    background: rgba(10,9,210,0.2);
    opacity: 0;
    transition: opacity 0.3s var(--ease-in-out);
}

.group:hover .absolute {
    opacity: 1;
}

/* Card Content */
.p-6 {
    padding: 1.5rem;
}

.text-xs {
    font-size: var(--text-xs);
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
}

.text-[#233DFF] {
    color: #233DFF;
}

.text-xl {
    font-size: var(--text-xl);
    line-height: var(--text-xl--line-height);
}

.text-sm {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
}

.leading-relaxed {
    line-height: var(--leading-relaxed);
}

.mb-2 { margin-bottom: .5rem; }
.mb-5 { margin-bottom: 1.25rem; }

/* Button */
a.px-5 {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: 0.625rem 1.25rem;
    background: #0A09D2;
    color: #fff;
    border-radius: var(--radius);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    text-decoration: none;
    transition: all 0.3s var(--ease-in-out);
    box-shadow: 0 0 20px rgba(10,9,210,0.3);
}

a.px-5:hover {
    transform: translateY(-2px);
    box-shadow: 0 0 25px rgba(10,9,210,0.6);
}

section.py-32 {
    padding-top: 120px !important;
    padding-bottom: 120px !important;
}

/* ============================= */
/* PROYECTOS – COMPACTO PREMIUM */
/* ============================= */

.group {
    padding: 0 !important;
}

/* Reducimos padding interno */
.group .p-6 {
    padding: 1.75rem !important;
}

/* Categoría */
.group .text-xs {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: #233DFF;
    margin-bottom: 0.75rem;
}

/* Título más compacto */
.group h3 {
    font-size: 1.6rem !important;
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: 0.75rem;
}

/* Texto descripción */
.group p.text-sm {
    font-size: 0.95rem;
    line-height: 1.55;
    color: #a8b0c8;
    margin-bottom: 1.4rem;
}

/* BOTÓN estilo Services */
.group a.px-5 {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    padding: 0.75rem 1.4rem;
    font-size: 0.9rem;
    font-weight: 600;

    background: linear-gradient(135deg, #0A09D2, #233DFF);
    border-radius: 8px;

    transition: all 0.3s ease;
}

/* Hover botón */
.group a.px-5:hover {
    transform: translateY(-2px);
    box-shadow: 0 0 25px rgba(10,9,210,0.45);
}

/* Imagen un poco más baja para compactar */
.aspect-video {
    aspect-ratio: 16 / 9;
}

/* Compactamos espacio general entre cards */
.grid {
    gap: 1.8rem !important;
}


/* ============================= */
/* HEADER MÁS COMPACTO */
/* ============================= */

section.py-32 {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
}

/* Título sección */
section.py-32 h2 {
    font-size: 38px !important;
    font-weight: 700 !important;
    margin-bottom: 12px !important;
}

/* Subtítulo */
section.py-32 .text-lg {
    font-size: 16px !important;
}

/* ============================= */
/* CARDS MÁS COMPACTAS */
/* ============================= */

.group .p-6 {
    padding: 1.4rem !important;
}

/* Categoría */
.group .text-xs {
    font-size: 0.7rem !important;
    margin-bottom: 0.6rem !important;
}

/* Título card */
.group h3 {
    font-size: 1.35rem !important;
    line-height: 1.25 !important;
    margin-bottom: 0.6rem !important;
}

/* Descripción */
.group p.text-sm {
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
    margin-bottom: 1.2rem !important;
}

/* BOTÓN MÁS CHICO */
.group a.px-5 {
    padding: 0.6rem 1.1rem !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
}

/* Reducimos gap entre cards */
.grid {
    gap: 1.5rem !important;
}

/* ============================= */
/* CONTENEDOR MÁS ANGOSTO */
/* ============================= */

section.py-32 .container {
    max-width: 1180px !important;
    padding-left: 60px !important;
    padding-right: 60px !important;
}

/* En pantallas muy grandes aún más aire */
@media (min-width: 1600px) {
    section.py-32 .container {
        max-width: 1100px !important;
    }
}

/* ============================= */
/* SECCIÓN MÁS COMPACTA */
/* ============================= */

section.py-32 {
    padding-top: 90px !important;
    padding-bottom: 90px !important;
}

/* Header más fino */
section.py-32 h2 {
    font-size: 36px !important;
    font-weight: 700 !important;
    margin-bottom: 10px !important;
}

section.py-32 .text-lg {
    font-size: 15px !important;
}

/* ============================= */
/* CARDS MÁS PROPORCIONADAS */
/* ============================= */

.group .p-6 {
    padding: 1.25rem 1.4rem !important;
}

/* Categoría */
.group .text-xs {
    font-size: 0.68rem !important;
    letter-spacing: 0.08em;
    margin-bottom: 0.5rem !important;
}

/* Título */
.group h3 {
    font-size: 1.28rem !important;
    line-height: 1.3 !important;
    margin-bottom: 0.5rem !important;
}

/* Texto */
.group p.text-sm {
    font-size: 0.88rem !important;
    line-height: 1.5 !important;
    margin-bottom: 1rem !important;
}

/* Botón más compacto */
.group a.px-5 {
    padding: 0.55rem 1.1rem !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    border-radius: 7px !important;
}

/* Grid menos apretado */
.grid {
    gap: 1.6rem !important;
}


/* Overlay azul en la imagen (hover) - versión degradado pro */
.aspect-video .absolute{
    background: linear-gradient(
        to top,
        rgba(10, 9, 210, 0.18),
        rgba(10, 9, 210, 0.05)
    ) !important;
}

/* ============================= */
/* TABLET – Centrar contenido */
/* ============================= */

@media (max-width: 1024px){

    /* Centrar contenido de cada card */
    .group .p-6{
        text-align: center;
    }

    /* Centrar botón */
    .group a.px-5{
        margin-left: auto;
        margin-right: auto;
    }

}

/* ============================= */
/* TABLET – Botón ancho completo */
/* ============================= */

@media (max-width: 1024px){

    .group a.px-5{
        width: 100%;
        justify-content: center;
        display: flex;
    }

}


/* ============================= */
/* MOBILE – Ajuste fino lateral */
/* ============================= */

@media (max-width: 426px){

    section.py-32 .container{
        padding-left: 40px !important;
        padding-right: 40px !important;
    }

}

/* ============================= */
/* MOBILE – Card integrada */
/* ============================= */

@media (max-width: 426px){

    /* Card más sólida */
    .group{
        border-radius: 14px !important;
        overflow: hidden !important;
    }

    /* Imagen respeta bordes */
    .aspect-video{
        border-top-left-radius: 14px !important;
        border-top-right-radius: 14px !important;
    }

    .aspect-video img{
        border-top-left-radius: 14px !important;
        border-top-right-radius: 14px !important;
    }

}

/* ============================= */
/* MOBILE – Más gap vertical */
/* ============================= */

@media (max-width: 426px){

    .grid{
        gap: 2rem !important;
    }

}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-50d16a4 *//* ============================= */
/* SECCIÓN NUESTRO PROCESO */
/* ============================= */

.process-section{
    background: #0B0D17;
    padding: 120px 0;
    position: relative;
    overflow: hidden;
}

/* Número gigante de fondo */
.process-bg-number{
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 260px;
    font-weight: 800;
    color: #233DFF;
    opacity: 0.05;
    pointer-events: none;
    z-index: 0;
}

/* Container */
.process-container{
    max-width: 1200px;
    margin: auto;
    padding: 0 24px;
    position: relative;
    z-index: 2;
}

/* Header */
.process-header{
    text-align: center;
    margin-bottom: 70px;
}

.process-header h2{
    font-size: 38px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 12px;
}

.process-header p{
    font-size: 16px;
    color: #9aa3b2;
}

/* Grid */
.process-grid{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    position: relative;
}

/* Item */
.process-item{
    position: relative;
}

/* Número outline */
.process-number{
    font-size: 60px;
    font-weight: 800;
    color: transparent;
    -webkit-text-stroke: 2px rgba(35, 61, 255, 0.3);
    margin-bottom: 24px;
}

/* Icono */
.process-icon{
    margin-bottom: 18px;
}

.process-icon svg{
    width: 40px;
    height: 40px;
    stroke: #233DFF;
    stroke-width: 2;
}

/* Título */
.process-item h3{
    font-size: 22px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 10px;
}

/* Texto */
.process-item p{
    color: #a8b0c8;
    line-height: 1.6;
    font-size: 15px;
}

/* Línea conectora desktop */
.process-item:not(:last-child)::after{
    content: "";
    position: absolute;
    top: 40px;
    left: 100%;
    width: 100%;
    height: 1px;
    background: linear-gradient(to right, rgba(35,61,255,0.5), transparent);
}

@media (max-width: 1024px){

    .process-grid{
        grid-template-columns: repeat(2, 1fr);
        gap: 50px;
    }

    .process-item::after{
        display: none;
    }

}

@media (max-width: 600px){

    .process-grid{
        grid-template-columns: 1fr;
        gap: 60px;
    }

    .process-bg-number{
        font-size: 180px;
    }

    .process-header h2{
        font-size: 32px;
    }

}

/* ============================= */
/* PROCESO – VERSIÓN MEJORADA */
/* ============================= */

.process-section{
    background: #0B0D17;
    padding: 120px 0;
    position: relative;
}

/* Número gigante fondo MÁS SUTIL */
.process-bg-number{
    font-size: 220px;
    opacity: 0.03;
}

/* Grid */
.process-grid{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 50px;
}

/* Item tipo card minimal */
.process-item{
    padding: 30px 20px;
    border-radius: 14px;
    transition: all 0.3s ease;
}

.process-item:hover{
    background: rgba(255,255,255,0.03);
}

/* Número outline más visible */
.process-number{
    font-size: 48px;
    margin-bottom: 18px;
    -webkit-text-stroke: 1.5px rgba(35,61,255,0.5);
}

/* Icon */
.process-icon{
    margin-bottom: 16px;
}

.process-icon svg{
    width: 36px;
    height: 36px;
    stroke: #233DFF;
}

/* Título */
.process-item h3{
    font-size: 20px;
    margin-bottom: 8px;
}

/* Texto */
.process-item p{
    font-size: 14px;
    color: #a8b0c8;
}

/* SACAR línea conectora */
.process-item::after{
    display: none !important;
}

.process-bg-number{
    opacity: 0.015;
}

.process-item{
    padding: 35px 25px;
    border-radius: 16px;
    transition: all 0.3s ease;
}

.process-item:hover{
    background: rgba(35,61,255,0.06);
}

.process-icon svg{
    width: 40px;
    height: 40px;
}

/* ============================= */
/* TABLET – PROCESO */
/* ============================= */

@media (max-width: 1024px){

    .process-section{
        padding: 110px 0;
    }

    /* Grid a 2 columnas */
    .process-grid{
        grid-template-columns: repeat(2, 1fr);
        gap: 60px 40px;
    }

    /* Centrar contenido */
    .process-item{
        text-align: center;
    }

    /* Número outline */
    .process-number{
        font-size: 42px;
        margin-bottom: 16px;
    }

    /* Icon más grande */
    .process-icon svg{
        width: 38px;
        height: 38px;
    }

    /* Número gigante fondo más chico */
    .process-bg-number{
        font-size: 180px;
        opacity: 0.02;
    }
}

/* ============================= */
/* MOBILE – PROCESO */
/* ============================= */

@media (max-width: 426px){

    .process-section{
        padding: 90px 0;
    }

    /* 1 sola columna */
    .process-grid{
        grid-template-columns: 1fr;
        gap: 70px;
    }

    /* Centrado total */
    .process-item{
        text-align: center;
        padding: 30px 15px;
    }

    /* Número más compacto */
    .process-number{
        font-size: 36px;
        margin-bottom: 14px;
    }

    /* Icon más grande para balance */
    .process-icon svg{
        width: 42px;
        height: 42px;
    }

    /* Título */
    .process-item h3{
        font-size: 19px;
    }

    /* Texto */
    .process-item p{
        font-size: 14px;
        max-width: 280px;
        margin-left: auto;
        margin-right: auto;
    }

    /* Número gigante casi invisible */
    .process-bg-number{
        font-size: 130px;
        opacity: 0.015;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-9806e25 *//* ============================= */
/* POR QUÉ BELMONT – PREMIUM */
/* ============================= */

.why-section{
    background: #0F111A;
    padding: 130px 0;
}

/* Container */
.why-section .container{
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 40px;
}

/* Header */
.why-header{
    text-align: center;
    margin-bottom: 70px;
}

.why-header h2{
    font-size: 38px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 12px;
}

.why-header p{
    font-size: 17px;
    color: #9ca3af;
}

/* Grid */
.why-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 50px 60px;
}

/* Item */
.why-item{
    display: flex;
    gap: 20px;
    padding: 25px;
    border-radius: 16px;
    transition: all 0.3s ease;
}

.why-item:hover{
    background: rgba(35,61,255,0.05);
    transform: translateY(-4px);
}

/* Icon Box */
.why-icon{
    min-width: 52px;
    height: 52px;
    border-radius: 12px;
    background: linear-gradient(135deg, #0A09D2, #233DFF);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 25px rgba(10,9,210,0.25);
}

.why-icon svg{
    width: 24px;
    height: 24px;
    stroke: #fff;
}

/* Content */
.why-content h3{
    font-size: 20px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 6px;
}

.why-content p{
    font-size: 15px;
    color: #a8b0c8;
    line-height: 1.6;
}

/* ============================= */
/* POR QUÉ BELMONT – MÁS COMPACTO */
/* ============================= */

/* Menos espacio vertical */
.why-section{
    padding: 100px 0 !important;
}

/* Header más compacto */
.why-header{
    margin-bottom: 50px !important;
}

.why-header h2{
    font-size: 34px;
}

.why-header p{
    font-size: 16px;
}

/* Grid más cerrado */
.why-grid{
    gap: 35px 45px !important;
}

/* Item más firme */
.why-item{
    padding: 18px 20px !important;
    gap: 16px !important;
}

/* Icono un poco más chico */
.why-icon{
    min-width: 46px !important;
    height: 46px !important;
    border-radius: 10px !important;
}

.why-icon svg{
    width: 20px !important;
    height: 20px !important;
}

/* Título */
.why-content h3{
    font-size: 18px !important;
    margin-bottom: 4px !important;
}

/* Texto */
.why-content p{
    font-size: 14px !important;
    line-height: 1.5 !important;
}

/* ============================= */
/* POR QUÉ BELMONT – MÁS CERCA (override) */
/* ============================= */

.why-section .container{
    max-width: 1080px !important;   /* antes 1200 */
    padding: 0 28px !important;     /* antes 40 */
}

/* Grid más pegado */
.why-grid{
    gap: 22px 28px !important;      /* antes 35px 45px */
}

/* Items más compactos (menos aire) */
.why-item{
    padding: 2px 14px !important;  /* antes 18px 20px */
    gap: 14px !important;           /* antes 16 */
}

/* Si querés todavía más cerca en desktop grande */
@media (min-width: 1200px){
    .why-grid{
        gap: 18px 24px !important;
    }
}

/* ============================= */
/* POR QUÉ BELMONT – TABLET */
/* ============================= */
@media (max-width: 1024px){

  .why-section{
    padding: 90px 0 !important;
  }

  .why-section .container{
    padding: 0 22px !important;
  }

  .why-header{
    margin-bottom: 38px !important;
  }

  .why-header h2{
    font-size: 32px !important;
  }

  .why-header p{
    font-size: 15px !important;
  }

  .why-grid{
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 18px 18px !important;
  }

  .why-item{
    padding: 14px 14px !important;
    gap: 12px !important;
  }

  .why-icon{
    min-width: 44px !important;
    height: 44px !important;
    border-radius: 10px !important;
  }

  .why-icon svg{
    width: 20px !important;
    height: 20px !important;
  }

  .why-content h3{
    font-size: 17px !important;
    margin-bottom: 4px !important;
  }

  .why-content p{
    font-size: 13.5px !important;
    line-height: 1.45 !important;
  }
}

/* ============================= */
/* POR QUÉ BELMONT – MOBILE (426) */
/* ============================= */
@media (max-width: 426px){

  .why-section{
    padding: 72px 0 !important;
  }

  .why-section .container{
    padding: 0 16px !important;
  }

  .why-header{
    margin-bottom: 28px !important;
  }

  .why-header h2{
    font-size: 28px !important;
    line-height: 1.15 !important;
  }

  .why-header p{
    font-size: 14px !important;
  }

  .why-grid{
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .why-item{
    padding: 14px 14px !important;
    gap: 12px !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.06);
  }

  .why-icon{
    min-width: 44px !important;
    height: 44px !important;
  }

  .why-content h3{
    font-size: 16.5px !important;
  }

  .why-content p{
    font-size: 13.5px !important;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-651cc5e *//* ============================= */
/* CTA ADVANTAGE SECTION – BELMONT */
/* ============================= */

.cta-advantage-section{
  position: relative;
  padding: 140px 0;
  background: linear-gradient(135deg, #0A09D2, #233DFF);
  overflow: hidden;
  text-align: center;
}

/* Radial glow */
.cta-advantage-overlay{
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 30%, rgba(255,255,255,0.15), transparent 60%);
  opacity: .6;
  pointer-events: none;
}

.cta-advantage-container{
  position: relative;
  z-index: 2;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 30px;
}

.cta-advantage-section h2{
  font-size: 48px;
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  margin-bottom: 26px;
}

.cta-advantage-section h2 span{
  display: block;
  opacity: .85;
}

.cta-advantage-section p{
  font-size: 22px;
  color: rgba(255,255,255,0.9);
  font-weight: 400;
}


/* ============================= */
/* TABLET */
/* ============================= */

@media (max-width: 1024px){

  .cta-advantage-section{
    padding: 110px 0;
  }

  .cta-advantage-section h2{
    font-size: 38px;
  }

  .cta-advantage-section p{
    font-size: 20px;
  }

}


/* ============================= */
/* MOBILE */
/* ============================= */

@media (max-width: 426px){

  .cta-advantage-section{
    padding: 90px 0;
  }

  .cta-advantage-container{
    padding: 0 18px;
  }

  .cta-advantage-section h2{
    font-size: 28px;
    line-height: 1.2;
    margin-bottom: 18px;
  }

  .cta-advantage-section p{
    font-size: 17px;
  }

}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-532b532 *//* ============================= */
/* FAQ – BELMONT */
/* ============================= */

.faq-section{
  background: #0B0D17;
  padding: 120px 0;
}

.faq-container{
  max-width: 900px;
  margin: 0 auto;
  padding: 0 30px;
}

/* Header */
.faq-header{
  text-align: center;
  margin-bottom: 60px;
}

.faq-header h2{
  font-size: 38px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
}

.faq-header p{
  font-size: 17px;
  color: #9ca3af;
}

/* List */
.faq-list{
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* Item */
.faq-item{
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
  backdrop-filter: blur(10px);
  transition: all .3s ease;
}

.faq-item:hover{
  border-color: rgba(35,61,255,0.5);
  background: rgba(35,61,255,0.05);
}

/* Question */
.faq-question{
  width: 100%;
  padding: 22px 26px;
  background: transparent;
  border: none;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}

/* Icon */
.faq-icon{
  font-size: 22px;
  color: #233DFF;
  transition: transform .3s ease;
}

/* Answer */
.faq-answer{
  max-height: 0;
  overflow: hidden;
  padding: 0 26px;
  color: #a8b0c8;
  font-size: 15px;
  line-height: 1.6;
  transition: all .35s ease;
}

/* Active state */
.faq-item.active .faq-answer{
  max-height: 300px;
  padding: 0 26px 22px 26px;
}

.faq-item.active .faq-icon{
  transform: rotate(45deg);
}

/* ============================= */
/* TABLET */
/* ============================= */

@media (max-width: 1024px){

  .faq-section{
    padding: 100px 0;
  }

  .faq-header h2{
    font-size: 32px;
  }

  .faq-question{
    font-size: 16px;
  }

}

/* ============================= */
/* MOBILE */
/* ============================= */

@media (max-width: 426px){

  .faq-section{
    padding: 80px 0;
  }

  .faq-container{
    padding: 0 18px;
  }

  .faq-header{
    margin-bottom: 40px;
  }

  .faq-header h2{
    font-size: 26px;
  }

  .faq-header p{
    font-size: 14px;
  }

  .faq-question{
    padding: 18px;
    font-size: 15px;
  }

  .faq-answer{
    font-size: 14px;
  }

}

/* ============================= */
/* FAQ – BELMONT CLEAN VERSION   */
/* ============================= */

.faq-section{
  background:#0B0D17;
  padding:120px 0;
  font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;
}

.faq-container{
  max-width:800px;
  margin:0 auto;
  padding:0 24px;
}

/* Header */
.faq-header{
  text-align:center;
  margin-bottom:60px;
}

.faq-header h2{
  font-size:36px;
  font-weight:700;
  color:#fff;
  margin-bottom:10px;
  letter-spacing:-0.5px;
}

.faq-header p{
  font-size:16px;
  color:#9ca3af;
}

/* List */
.faq-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}

/* Item */
.faq-item{
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  background:rgba(255,255,255,0.03);
  backdrop-filter:blur(10px);
  overflow:hidden;
  transition:all .3s ease;
}

.faq-item:hover{
  border-color:#233DFF;
  background:rgba(35,61,255,0.05);
}

/* Question */
.faq-question{
  width:100%;
  padding:22px 26px;
  background:transparent;
  border:none;
  color:#fff;
  font-size:17px;
  font-weight:600;
  text-align:left;
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
  transition:.3s ease;
}

.faq-question:hover{
  color:#fff;
}

/* Icon */
.faq-icon{
  font-size:22px;
  color:#233DFF;
  transition:transform .3s ease;
}

/* Answer */
.faq-answer{
  max-height:0;
  overflow:hidden;
  padding:0 26px;
  color:#a8b0c8;
  font-size:15px;
  line-height:1.6;
  transition:max-height .4s ease, padding .3s ease;
}

/* Active */
.faq-item.active .faq-answer{
  max-height:500px;
  padding:0 26px 24px 26px;
}

.faq-item.active .faq-icon{
  transform:rotate(45deg);
}

/* ============================= */
/* TABLET */
/* ============================= */

@media (max-width:1024px){

  .faq-section{
    padding:100px 0;
  }

  .faq-header h2{
    font-size:30px;
  }

  .faq-question{
    font-size:16px;
  }

}

/* ============================= */
/* MOBILE */
/* ============================= */

@media (max-width:426px){

  .faq-section{
    padding:80px 0;
  }

  .faq-container{
    padding:0 18px;
  }

  .faq-header{
    margin-bottom:40px;
  }

  .faq-header h2{
    font-size:26px;
  }

  .faq-header p{
    font-size:14px;
  }

  .faq-question{
    padding:18px;
    font-size:15px;
  }

  .faq-answer{
    font-size:14px;
  }

}

/* ===== FIX ESTADO ACTIVO ===== */

.faq-item.active{
  background: rgba(35,61,255,0.08) !important;
  border-color: #233DFF !important;
}

/* Pregunta cuando está activa */
.faq-item.active .faq-question{
  background: transparent !important;
  color: #fff !important;
  padding: 26px 26px 18px 26px; /* más aire abajo */
}

/* Más espacio real en la respuesta */
.faq-item.active .faq-answer{
  max-height: 600px;
  padding: 10px 26px 26px 26px; /* ← aire arriba agregado */
}

/* Mejor legibilidad del texto */
.faq-answer{
  line-height: 1.8;
  color: #b9c2d9;
}

/* Transición más suave */
.faq-item{
  transition: border .3s ease, background .3s ease;
}

/* FIX botón FAQ (evita fondo rosa global) */
.faq-question:hover,
.faq-question:focus {
  background: transparent !important;
  color: #fff !important;
  outline: none;
}


.faq-list{
  gap: 12px; /* antes 16-18 */
}

.faq-question{
  padding: 18px 22px; /* antes 22-26 */
  font-size: 16px;
}

.faq-item.active .faq-answer{
  padding: 6px 22px 20px 22px; /* menos aire arriba */
}


@media (max-width:426px){

  .faq-question{
    font-size:13px;   /* antes 15-16 */
    line-height:1.5;
    padding:14px 18px;  /* un poco menos alto */
  }

  .faq-item{
    border-radius:12px;
  }

}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-38e84cc *//* ============================= */
/* CTA FINAL – BELMONT (COMPACT - ISOLATED) */
/* ============================= */

.cta-section{
  position:relative;
  background:#08090F;
  padding:110px 0;
  overflow:hidden;
  font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;
}

/* Glow backgrounds */
.cta-section .cta-glow{
  position:absolute;
  width:320px;
  height:320px;
  border-radius:50%;
  filter:blur(80px);
  opacity:.22;
  z-index:0;
}

.cta-section .cta-glow-left{
  top:50%;
  left:18%;
  background:#233DFF;
  transform:translateY(-50%);
}

.cta-section .cta-glow-right{
  top:50%;
  right:18%;
  background:#0A09D2;
  transform:translateY(-50%);
}

/* Container */
.cta-section .cta-container{
  max-width:920px;
  margin:0 auto;
  padding:0 24px;
  position:relative;
  z-index:1;
}

.cta-section .cta-content{
  text-align:center;
}

/* Title */
.cta-section .cta-title{
  font-size:48px;
  font-weight:700;
  color:#fff;
  line-height:1.15;
  margin-bottom:22px;
  letter-spacing:-0.5px;
}

.cta-section .cta-gradient{
  background:linear-gradient(90deg,#0A09D2,#233DFF);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* Subtitle */
.cta-section .cta-subtitle{
  font-size:18px;
  color:#b9c2d9;
  margin-bottom:40px;
}

/* Buttons */
.cta-section .cta-buttons{
  display:flex;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
}

/* Base button */
.cta-section .cta-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 30px;
  font-size:15px;
  font-weight:600;
  border-radius:14px;
  text-decoration:none;
  transition:all .3s ease;
}

/* Primary */
.cta-section .cta-primary{
  background:#0A09D2;
  color:#fff;
  box-shadow:0 0 35px rgba(10,9,210,.4);
}

.cta-section .cta-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 0 55px rgba(10,9,210,.7);
}

/* Secondary */
.cta-section .cta-secondary{
  border:2px solid #233DFF;
  color:#fff;
}

.cta-section .cta-secondary:hover{
  background:rgba(35,61,255,.12);
  transform:translateY(-2px);
}

/* Icon */
.cta-section .cta-icon{
  width:16px;
  height:16px;
}

/* Mantener texto blanco en hover */
.cta-section .cta-btn:hover,
.cta-section .cta-btn:hover span{
  color:#fff !important;
}

/* ============================= */
/* TABLET */
/* ============================= */

@media (max-width:1024px){

  .cta-section .cta-title{
    font-size:40px;
  }

  .cta-section .cta-subtitle{
    font-size:17px;
  }

}

/* ============================= */
/* MOBILE 426px */
/* ============================= */

@media (max-width:426px){

  .cta-section{
    padding:70px 0;
  }

  .cta-section .cta-title{
    font-size:26px;
    line-height:1.25;
    margin-bottom:18px;
  }

  .cta-section .cta-subtitle{
    font-size:14px;
    margin-bottom:28px;
  }

  .cta-section .cta-buttons{
    flex-direction:column;
    gap:12px;
  }

  .cta-section .cta-btn{
    width:100%;
    padding:14px 18px;
    font-size:14px;
    justify-content:center;
  }

}

.cta-line{
  display:block;
}/* End custom CSS */