/**
 * Capa visual «SaaS premium» para la home pública (body.index-page).
 * Desacopla la landing del aspecto genérico Techie: ritmo, cards, gradientes y header tipo producto B2B.
 */

/* ------------------------------------------------------------------------- */
/* Header (solo home)                                                          */
/* ------------------------------------------------------------------------- */
body.index-page #header.header {
    background: rgba(21, 14, 52, 0.55);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 14px;
    padding-bottom: 14px;
    box-shadow: none;
}

/* Solo escritorio: enlaces claros sobre header cristalino. En móvil el panel es blanco (Techie);
   si aplicamos color blanco aquí, gana por especificidad a .navmenu a y el texto queda invisible. */
@media (min-width: 1200px) {
    body.index-page #header .navmenu > ul > li > a {
        font-weight: 600;
        font-size: 14px;
        letter-spacing: 0.2px;
        color: rgba(255, 255, 255, 0.92);
    }

    body.index-page #header .navmenu > ul > li > a:hover {
        color: #fff;
    }
}

body.index-page #header .btn-getstarted {
    border-radius: 999px;
    padding: 10px 18px;
    font-weight: 700;
    font-size: 14px;
    background: #ffffff;
    color: #4d2be3 !important;
    border: 0;
    box-shadow: 0 10px 30px rgba(255, 255, 255, 0.18);
}

body.index-page #header .btn-getstarted:hover {
    background: #f4f0ff;
    color: #3a1faf !important;
}

body.index-page #header .sitename {
    color: #fff;
}

/* Techie asigna --background-color al hacer scroll; mantenemos cristal oscuro en home */
body.index-page.scrolled #header.header {
    background: rgba(21, 14, 52, 0.78) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.18);
}

/*
 * Móvil: backdrop-filter en #header hace que los hijos position:fixed (menú hamburguesa Techie)
 * se posicionen respecto al header, no al viewport; el ul queda con altura ~0. Quitar blur solo
 * con el menú abierto restaura el overlay a pantalla completa.
 */
@media (max-width: 1199.98px) {
    body.mobile-nav-active.index-page #header.header {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
}

/* ------------------------------------------------------------------------- */
/* Hero                                                                       */
/* ------------------------------------------------------------------------- */
body.index-page #hero.hero-section.landing-hero-saas {
    min-height: 0;
    /* Base oscura tipo landing B2B; halo de marca para no perder identidad morada */
    background:
        radial-gradient(ellipse 90% 70% at 50% -15%, rgba(106, 50, 239, 0.45), transparent 52%),
        radial-gradient(ellipse 60% 45% at 85% 25%, rgba(59, 31, 179, 0.35), transparent 45%),
        linear-gradient(180deg, #07050f 0%, #0c0818 38%, #100b1f 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
    padding: 112px 0 0;
    margin: 0;
}

body.index-page #hero.hero-section.landing-hero-saas::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 40% at 50% 0%, rgba(255, 255, 255, 0.06), transparent 55%);
    pointer-events: none;
}

body.index-page #hero.hero-section.landing-hero-saas .container {
    position: relative;
    z-index: 2;
}

body.index-page .hero-badge {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.3px;
    color: #fff;
}

body.index-page .hero-copy {
    position: relative;
    z-index: 2;
}

body.index-page .hero-title {
    font-size: clamp(2.75rem, 1.2rem + 3.5vw, 3.65rem);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.035em;
    max-width: 920px;
    color: #fff;
    margin-top: 1.35rem;
}

body.index-page .hero-subtitle {
    font-size: 1.06rem;
    line-height: 1.8;
    color: rgba(255, 255, 255, 0.88);
    max-width: 640px;
    margin-top: 1.5rem;
    opacity: 1;
}

body.index-page .hero-cta-row {
    margin-top: 2rem;
}

body.index-page .hero-cta-primary.btn {
    padding: 14px 30px;
    font-weight: 700;
    font-size: 1.06rem;
    border-radius: 999px;
    box-shadow: 0 14px 38px rgba(0, 0, 0, 0.24);
    border: 0;
}

body.index-page .hero-cta-primary.btn:hover {
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
    transform: translateY(-1px);
}

body.index-page .hero-cta-secondary.btn {
    padding: 14px 28px;
    font-weight: 700;
    font-size: 1.02rem;
    border-radius: 999px;
    border-width: 2px;
}

body.index-page .hero-mini-points {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 22px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.82);
    margin-top: 1.75rem;
}

body.index-page .hero-mini-points span {
    position: relative;
    padding-left: 18px;
}

body.index-page .hero-mini-points span::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #c4b5fd;
    position: absolute;
    left: 0;
    top: 7px;
}

/* Mockup bajo el copy: fundido inferior + laterales vía máscara; capa ::after evita “corte” con el fondo */
body.index-page .hero-mockup-wrap {
    position: relative;
    z-index: 1;
    margin-top: 2.75rem;
    padding-bottom: clamp(2rem, 6vw, 3.5rem);
}

/* Degradado que iguala el color base de la página (sin borde ni sombra inferior en el vídeo) */
body.index-page .hero-mockup-wrap::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: clamp(100px, 22vw, 200px);
    pointer-events: none;
    z-index: 2;
    /* Mismo #07050f que --si-page-base del body (fondo fijo de la home) */
    background: linear-gradient(
        to bottom,
        transparent 0%,
        rgba(7, 5, 15, 0.35) 35%,
        rgba(7, 5, 15, 0.88) 72%,
        rgba(7, 5, 15, 1) 100%
    );
}

body.index-page .hero-mockup-wrap .container {
    position: relative;
    z-index: 1;
}

body.index-page .hero-visual-depth {
    position: relative;
    z-index: 1;
    --hero-mask-v: linear-gradient(
        to bottom,
        #000 0%,
        #000 34%,
        rgba(0, 0, 0, 0.85) 52%,
        rgba(0, 0, 0, 0.45) 68%,
        rgba(0, 0, 0, 0.12) 82%,
        transparent 97%
    );
    --hero-mask-h: linear-gradient(
        to right,
        transparent 0%,
        #000 11%,
        #000 89%,
        transparent 100%
    );
    width: min(100%, 1100px);
    height: clamp(320px, 54vw, 580px);
    margin-left: auto;
    margin-right: auto;
    border-radius: 14px 14px 0 0;
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    /* Sin borde ni sombra hacia abajo: dibujaban la caja aunque la máscara fundiera el vídeo */
    border: none;
    box-shadow:
        0 0 0 1px rgba(167, 139, 250, 0.14) inset,
        0 -16px 40px rgba(106, 50, 239, 0.2);
    -webkit-mask-image: var(--hero-mask-v), var(--hero-mask-h);
    -webkit-mask-size: 100% 100%, 100% 100%;
    -webkit-mask-repeat: no-repeat, no-repeat;
    -webkit-mask-position: center, center;
    -webkit-mask-composite: source-in;
    mask-image: var(--hero-mask-v), var(--hero-mask-h);
    mask-size: 100% 100%, 100% 100%;
    mask-repeat: no-repeat, no-repeat;
    mask-position: center, center;
    mask-composite: intersect;
}

body.index-page video.hero-visual-depth {
    display: block;
    padding: 0;
    object-fit: cover;
    object-position: center top;
    /* Mismo tono base que body (--si-page-base) para que no se note banda bajo la máscara */
    background: #07050f;
}

@media (max-width: 991.98px) {
    body.index-page .hero-mockup-wrap {
        margin-top: 2rem;
    }

    body.index-page .hero-visual-depth {
        --hero-mask-h: linear-gradient(
            to right,
            transparent 0%,
            #000 6%,
            #000 94%,
            transparent 100%
        );
        height: clamp(260px, 68vw, 440px);
        border-radius: 12px 12px 0 0;
    }
}

/* ------------------------------------------------------------------------- */
/* Métricas (banda flotante)                                                   */
/* ------------------------------------------------------------------------- */
body.index-page .landing-metrics-wrap {
    position: relative;
    z-index: 5;
    background: linear-gradient(180deg, rgba(246, 248, 252, 0.97) 0%, #fff 38%, #fff 100%);
    /* Aire entre el vídeo/mockup del hero y las tarjetas (ritmo ~ otras secciones: pain/how) */
    padding: clamp(2.75rem, 5vw, 3.75rem) 0 4rem;
    margin-top: 0;
}

body.index-page .metrics-strip {
    margin-top: 0;
    position: relative;
    z-index: 4;
}

body.index-page .metric-card {
    background: #fff;
    border-radius: 18px;
    padding: 24px 18px 22px;
    text-align: center;
    box-shadow: 0 12px 32px rgba(20, 20, 43, 0.08);
    border: 1px solid #eef1f6;
    height: 100%;
    min-height: 148px;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

body.index-page .metric-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(20, 20, 43, 0.12);
}

body.index-page .metric-card-icon {
    font-size: 1.35rem;
    color: #5b3df5;
    line-height: 1;
    margin-bottom: 12px;
    opacity: 0.92;
}

body.index-page .metric-card .metric-number {
    font-size: 1.95rem;
    font-weight: 800;
    color: #5b3df5;
    line-height: 1;
    margin-bottom: 10px;
}

body.index-page .metric-card .metric-number .purecounter {
    font: inherit;
    color: inherit;
    line-height: inherit;
}

body.index-page .metric-card .metric-label {
    color: #667085;
    font-weight: 600;
    font-size: 0.9rem;
    line-height: 1.4;
    margin: 0;
}

body.index-page .metrics-cta .btn {
    font-weight: 600;
}

/* ------------------------------------------------------------------------- */
/* Segmentación (SaaS / DevOps / negocio) + H2 keywords comerciales            */
/* ------------------------------------------------------------------------- */
body.index-page .segments {
    padding-top: 2.75rem;
    padding-bottom: 2.5rem;
}

body.index-page .segments-head {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2rem;
}

body.index-page .segments-seo-title {
    font-size: clamp(1.35rem, 2.5vw, 1.85rem);
    font-weight: 800;
    color: #101828;
    letter-spacing: -0.02em;
    line-height: 1.25;
    margin-bottom: 0.65rem;
}

body.index-page .segments-mantra {
    font-size: clamp(1.5rem, 2.8vw, 2rem);
    font-weight: 800;
    color: #5b3df5;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin-bottom: 1rem;
}

body.index-page .segments-intro {
    max-width: 720px;
    font-size: 0.98rem;
    line-height: 1.65;
    color: #475467;
}

body.index-page .segments-row {
    margin-top: 0.25rem;
}

body.index-page .segments-card {
    background: #fff;
    border: 1px solid #eaecf0;
    border-radius: 20px;
    padding: 1.75rem 1.5rem;
    box-shadow: 0 12px 32px rgba(16, 24, 40, 0.06);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

body.index-page .segments-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(91, 61, 245, 0.12);
}

body.index-page .segments-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    color: #5b3df5;
    background: linear-gradient(135deg, rgba(91, 61, 245, 0.12), rgba(47, 128, 237, 0.1));
    margin-bottom: 1rem;
}

body.index-page .segments-card h3 {
    font-size: 1.2rem;
    font-weight: 800;
    color: #101828;
    margin-bottom: 0.5rem;
}

body.index-page .segments-card p {
    font-size: 0.92rem;
    line-height: 1.55;
    color: #667085;
}

/* Franja de confianza / métricas (entre segmentos y dolor) */
body.index-page .landing-trust-stats {
    position: relative;
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
    background: linear-gradient(180deg, #f3efff 0%, #faf9ff 45%, #ffffff 100%);
    border-top: 1px solid rgba(91, 61, 245, 0.14);
    border-bottom: 1px solid rgba(91, 61, 245, 0.12);
    box-shadow: 0 12px 40px rgba(91, 61, 245, 0.08);
}

body.index-page .landing-trust-stats-title {
    font-size: clamp(1.65rem, 3vw, 2.35rem);
    font-weight: 800;
    letter-spacing: -0.025em;
    line-height: 1.2;
    color: #101828;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

body.index-page .landing-trust-stat-value {
    font-size: clamp(2.1rem, 4.5vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.1;
    margin-bottom: 0.35rem;
    background: linear-gradient(135deg, #5b3df5 0%, #2f80ed 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}

body.index-page .landing-trust-stat-label {
    font-size: 0.95rem;
    font-weight: 600;
    color: #475467;
}

/* ------------------------------------------------------------------------- */
/* Pain / problema                                                             */
/* ------------------------------------------------------------------------- */
body.index-page .section-pain {
    background: #fff;
    padding-top: 3rem;
    padding-bottom: 3.5rem;
}

body.index-page .section-kicker {
    display: inline-block;
    font-size: 13px;
    font-weight: 700;
    color: #5f3df3;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

body.index-page .section-title-saas {
    font-size: clamp(1.85rem, 3vw, 2.65rem);
    font-weight: 800;
    color: #101828;
    line-height: 1.15;
    letter-spacing: -0.02em;
}

body.index-page .section-text-saas {
    color: #475467;
    font-size: 1.05rem;
    line-height: 1.75;
    max-width: 560px;
}

body.index-page .section-subtitle-saas {
    max-width: 620px;
    font-size: 1.02rem;
    line-height: 1.65;
    color: #667085;
}

body.index-page .pain-points,
body.index-page .pain-list {
    display: grid;
    gap: 12px;
}

body.index-page .pain-item {
    background: #fff;
    border: 1px solid #eceff5;
    border-radius: 14px;
    padding: 14px 16px 14px 42px;
    position: relative;
    color: #344054;
    font-weight: 600;
    font-size: 0.95rem;
    box-shadow: 0 6px 20px rgba(16, 24, 40, 0.04);
}

body.index-page .pain-item::before {
    content: "✕";
    position: absolute;
    left: 16px;
    top: 13px;
    color: #ef4444;
    font-weight: 800;
    font-size: 1rem;
}

/* Marco tipo mockup (alineado con feature-mockup / hero) + máscara para fundir bordes (imagen o video) */
body.index-page .pain-media-wrap {
    position: relative;
    display: block;
    width: 100%;
    max-width: 580px;
    margin-left: auto;
    margin-right: auto;
    padding: 12px 12px 14px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.07) 0%, rgba(12, 8, 26, 0.82) 100%);
    border: 1px solid rgba(167, 139, 250, 0.22);
    box-shadow:
        0 0 0 1px rgba(167, 139, 250, 0.1) inset,
        0 18px 48px rgba(0, 0, 0, 0.38);
}

body.index-page .pain-illustration {
    display: block;
    width: 100%;
    height: auto;
    max-width: 100%;
    border-radius: 16px;
    border: none;
    box-shadow: none;
    object-fit: cover;
    background: #07050f;
    --pain-mask-v: linear-gradient(
        to bottom,
        #000 0%,
        #000 62%,
        rgba(0, 0, 0, 0.55) 80%,
        rgba(0, 0, 0, 0.12) 94%,
        transparent 100%
    );
    --pain-mask-h: linear-gradient(
        to right,
        transparent 0%,
        #000 9%,
        #000 91%,
        transparent 100%
    );
    -webkit-mask-image: var(--pain-mask-v), var(--pain-mask-h);
    -webkit-mask-size: 100% 100%, 100% 100%;
    -webkit-mask-repeat: no-repeat, no-repeat;
    -webkit-mask-position: center, center;
    -webkit-mask-composite: source-in;
    mask-image: var(--pain-mask-v), var(--pain-mask-h);
    mask-size: 100% 100%, 100% 100%;
    mask-repeat: no-repeat, no-repeat;
    mask-position: center, center;
    mask-composite: intersect;
}

body.index-page .pain-impact {
    max-width: 580px;
    margin-left: auto;
    margin-right: auto;
}

body.index-page .pain-impact-title {
    font-size: clamp(1.28rem, 2.3vw, 1.65rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #101828;
    line-height: 1.22;
    margin-bottom: 0.85rem;
}

body.index-page .pain-impact-lead {
    font-size: 1.05rem;
    font-weight: 500;
    color: #475467;
    line-height: 1.65;
}

/* ------------------------------------------------------------------------- */
/* Cómo funciona                                                               */
/* ------------------------------------------------------------------------- */
body.index-page .how-section {
    background: #f9fafb;
    padding-top: 4rem;
    padding-bottom: 4rem;
}

body.index-page .how-card {
    background: #fff;
    border: 1px solid #edf1f7;
    border-radius: 18px;
    padding: 28px 22px;
    text-align: center;
    box-shadow: 0 8px 24px rgba(16, 24, 40, 0.05);
    height: 100%;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

body.index-page .how-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 18px 36px rgba(16, 24, 40, 0.08);
}

body.index-page .how-step {
    width: 52px;
    height: 52px;
    margin: 0 auto 16px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 1.2rem;
    background: linear-gradient(135deg, #5b3df5, #2f80ed);
    color: #fff;
}

body.index-page .how-card h3 {
    font-size: 1.05rem;
    font-weight: 800;
    color: #101828;
    margin-bottom: 8px;
}

body.index-page .how-card .how-card-text {
    color: #667085;
    font-size: 0.875rem;
    line-height: 1.55;
    margin: 0;
}

/* ------------------------------------------------------------------------- */
/* Servicios (cards)                                                           */
/* ------------------------------------------------------------------------- */
body.index-page .services-saas {
    background: #fff;
    padding-top: 3.75rem;
    padding-bottom: 2rem;
}

body.index-page .services-row-primary .service-card {
    padding: 32px 26px;
    border-radius: 22px;
    box-shadow: 0 12px 32px rgba(16, 24, 40, 0.06);
}

body.index-page .service-card {
    background: #fff;
    border: 1px solid #edf1f7;
    border-radius: 20px;
    padding: 28px 22px;
    height: 100%;
    transition: all 0.28s ease;
    box-shadow: 0 10px 25px rgba(16, 24, 40, 0.04);
}

body.index-page .service-card:hover {
    transform: translateY(-8px);
    border-color: #d8dfff;
    box-shadow: 0 24px 44px rgba(31, 52, 105, 0.1);
}

body.index-page .service-icon {
    width: 54px;
    height: 54px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(95, 61, 243, 0.12), rgba(59, 130, 246, 0.12));
    color: #5f3df3;
    font-size: 24px;
    margin-bottom: 18px;
}

body.index-page .service-card h4 {
    font-size: 1.1rem;
    font-weight: 800;
    color: #101828;
    margin-bottom: 10px;
}

body.index-page .service-card p {
    color: #475467;
    line-height: 1.65;
    margin-bottom: 0;
    font-size: 0.95rem;
}

body.index-page .services-row-secondary {
    margin-top: 0.25rem;
}

body.index-page .services-more-title {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #98a2b3;
    margin-bottom: 0.85rem;
}

body.index-page .service-card-secondary {
    padding: 16px 16px;
    border-radius: 14px;
    border: 1px solid #eaecf0;
    background: #fafbfc;
    height: 100%;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-shadow: 0 4px 14px rgba(16, 24, 40, 0.03);
}

body.index-page .service-card-secondary:hover {
    border-color: #d0d5dd;
    box-shadow: 0 8px 20px rgba(16, 24, 40, 0.06);
}

body.index-page .service-card-secondary h5 {
    font-size: 0.9rem;
    font-weight: 700;
    color: #101828;
    margin-bottom: 4px;
}

body.index-page .service-card-secondary p {
    font-size: 0.8rem;
    color: #667085;
    margin: 0;
    line-height: 1.45;
}

/* ------------------------------------------------------------------------- */
/* Por qué                                                                     */
/* ------------------------------------------------------------------------- */
body.index-page .why-us {
    background: #f9fafb;
    padding-top: 4.25rem;
    padding-bottom: 4.25rem;
}

body.index-page .why-card {
    background: #fff;
    border: 1px solid #eceff5;
    border-radius: 16px;
    padding: 22px 18px 24px;
    height: 100%;
    min-height: 168px;
    text-align: left;
    box-shadow: 0 8px 24px rgba(16, 24, 40, 0.04);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

body.index-page .why-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 34px rgba(16, 24, 40, 0.08);
}

body.index-page .why-card-icon {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(91, 61, 245, 0.1);
    color: #5b3df5;
    font-size: 1.15rem;
    margin-bottom: 14px;
}

body.index-page .why-card h4 {
    font-size: 1rem;
    font-weight: 800;
    color: #111827;
    margin-bottom: 8px;
}

body.index-page .why-card p {
    color: #667085;
    font-size: 0.92rem;
    line-height: 1.6;
    margin: 0;
}

/* ------------------------------------------------------------------------- */
/* Características (mini cards)                                                */
/* ------------------------------------------------------------------------- */
body.index-page .features-saas {
    background: #fff;
    padding-top: 3.5rem;
    padding-bottom: 3rem;
}

/* Vista “billboard”: vídeo ~58% ancho + puntos en 2 columnas para caber en una pantalla típica */
body.index-page .features-saas-billboard {
    padding-top: 2.25rem;
    padding-bottom: 2rem;
}

body.index-page .features-saas-billboard .features-saas-billboard-head .section-title-saas {
    font-size: clamp(1.65rem, 2.6vw, 2.35rem);
}

body.index-page .features-saas-billboard-row {
    min-height: 0;
}

body.index-page .feature-mockup-wrap {
    background: linear-gradient(180deg, #f8faff 0%, #fff 100%);
    border: 1px solid #eaecf0;
    border-radius: 24px;
    padding: 32px 24px;
    box-shadow: 0 14px 40px rgba(16, 24, 40, 0.06);
}

body.index-page .feature-mockup-wrap--hero {
    padding: 12px 12px 14px;
    box-shadow: 0 18px 48px rgba(16, 24, 40, 0.1);
}

body.index-page .feature-mockup-wrap video.features-mockup-video,
body.index-page .feature-mockup-wrap img.features-mockup-image {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 16px;
    background: #0f0d14;
    box-shadow: 0 12px 32px rgba(16, 24, 40, 0.12);
    border: 1px solid rgba(15, 13, 20, 0.08);
}

body.index-page .feature-mockup-wrap--hero video.features-mockup-video,
body.index-page .feature-mockup-wrap--hero img.features-mockup-image {
    width: 100%;
    min-height: min(52vh, 420px);
    max-height: min(58vh, 520px);
    height: min(58vh, 520px);
    object-fit: cover;
    object-position: top center;
}

body.index-page .features-saas-billboard .feature-item--compact {
    margin-bottom: 0;
    height: 100%;
    padding: 11px 12px;
    gap: 10px;
    border-radius: 14px;
}

body.index-page .features-saas-billboard .feature-item--compact .feature-icon {
    flex: 0 0 36px;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    font-size: 17px;
}

body.index-page .features-saas-billboard .feature-item--compact h5 {
    font-size: 0.88rem;
    font-weight: 800;
    margin-bottom: 4px;
    line-height: 1.25;
    color: #101828;
}

body.index-page .features-saas-billboard .feature-item--compact p {
    font-size: 0.78rem;
    line-height: 1.42;
    color: #667085;
}

@media (max-width: 991.98px) {
    body.index-page .feature-mockup-wrap--hero video.features-mockup-video,
    body.index-page .feature-mockup-wrap--hero img.features-mockup-image {
        min-height: 200px;
        max-height: 42vh;
        height: auto;
        aspect-ratio: 16 / 10;
        object-fit: cover;
    }

    body.index-page .features-saas-billboard .feature-item--compact p {
        font-size: 0.82rem;
    }
}

body.index-page .feature-item,
body.index-page .feature-saas-item {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: #fff;
    border: 1px solid #edf1f7;
    border-radius: 16px;
    padding: 18px;
    box-shadow: 0 8px 24px rgba(16, 24, 40, 0.04);
    margin-bottom: 14px;
}

body.index-page .feature-item:last-child,
body.index-page .feature-saas-item:last-child {
    margin-bottom: 0;
}

body.index-page .feature-icon,
body.index-page .feature-saas-item .icon-wrap {
    flex: 0 0 44px;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(91, 61, 245, 0.1);
    color: #5b3df5;
    font-size: 20px;
}

body.index-page .feature-item h5,
body.index-page .feature-saas-item h5 {
    margin: 0 0 6px;
    font-size: 1rem;
    font-weight: 800;
    color: #101828;
}

body.index-page .feature-item p,
body.index-page .feature-saas-item p {
    margin: 0;
    color: #667085;
    line-height: 1.6;
    font-size: 0.92rem;
}

body.index-page .feature-saas-item ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

body.index-page .feature-saas-item li {
    font-size: 0.88rem;
    color: #475467;
    line-height: 1.55;
    margin-bottom: 4px;
}

/* ------------------------------------------------------------------------- */
/* Planes (partial)                                                            */
/* ------------------------------------------------------------------------- */
body.index-page #pricing.pricing-saas {
    background: linear-gradient(180deg, #fafbfc 0%, #fff 45%);
    padding-top: 3rem;
    padding-bottom: 3.5rem;
}

body.index-page #pricing.pricing-saas .section-title h2 {
    font-weight: 800;
    font-size: clamp(1.85rem, 3vw, 2.5rem);
    color: #101828;
    letter-spacing: -0.02em;
}

/* Anula estilos genéricos .pricing de Techie sobre nuestras tarjetas */
body.index-page #pricing.pricing-saas .si-pricing-card ul {
    padding: 0;
    text-align: left;
    line-height: inherit;
    color: inherit;
}

body.index-page #pricing.pricing-saas .si-pricing-card ul li {
    padding: 0;
    display: block;
    list-style: none;
}

body.index-page .si-pricing-card {
    position: relative;
    background: #fff;
    border: 1px solid #eaecf0;
    border-radius: 24px;
    padding: 32px 24px;
    box-shadow: 0 10px 28px rgba(16, 24, 40, 0.05);
    height: 100%;
    display: flex;
    flex-direction: column;
}

body.index-page .si-pricing-featured {
    border: 2px solid #5b3df5;
    box-shadow: 0 24px 48px rgba(91, 61, 245, 0.18);
    transform: translateY(-12px);
    padding-top: 40px;
}

@media (max-width: 991.98px) {
    body.index-page .si-pricing-featured {
        transform: none;
        padding-top: 36px;
    }
}

body.index-page .si-pricing-badge {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, #5b3df5, #2f80ed);
    color: #fff;
    padding: 8px 16px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.02em;
    box-shadow: 0 8px 22px rgba(91, 61, 245, 0.35);
    white-space: nowrap;
}

body.index-page .si-pricing-card h3 {
    font-size: 1.35rem;
    font-weight: 800;
    color: #101828;
    margin-bottom: 4px;
}

body.index-page .si-pricing-price {
    font-size: 2.75rem;
    line-height: 1;
    font-weight: 800;
    color: #101828;
    margin: 12px 0 8px;
}

body.index-page .si-pricing-price .si-currency {
    font-size: 1.5rem;
    vertical-align: super;
    margin-right: 2px;
}

/* Subtítulo bajo el importe (p. ej. Pro: «Precio orientativo…»), no al lado en la misma línea. */
body.index-page .si-pricing-price .si-pricing-price-subline {
    display: block;
    margin-top: 0.5rem;
    font-size: 0.95rem;
    line-height: 1.4;
    color: #667085;
    font-weight: 600;
}

body.index-page .si-pricing-note {
    color: #5b3df5;
    font-weight: 700;
    font-size: 14px;
    margin-bottom: 10px;
}

body.index-page .si-pricing-commercial {
    font-size: 0.8rem;
    color: #667085;
    line-height: 1.45;
    margin: 0 0 14px;
    font-weight: 500;
}

body.index-page .si-pricing-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
    flex-grow: 1;
}

body.index-page .si-pricing-list li {
    position: relative;
    padding: 8px 0 8px 24px;
    color: #475467;
    font-size: 0.88rem;
    line-height: 1.42;
    border-bottom: 1px solid #f2f4f7;
}

body.index-page .si-pricing-list li:last-child {
    border-bottom: 0;
}

body.index-page .si-pricing-list li::before {
    content: "✓";
    position: relative;
    left: 0;
    color: #12b76a;
    font-weight: 800;
    margin-right: 10px;
}

/* Viñetas de exclusión (p. ej. API no incluida en Free): X roja en lugar de check verde. */
body.index-page .si-pricing-list li.si-pricing-li-excluded::before {
    content: "\2715";
    color: #d92d20;
}

body.index-page .si-pricing-card .btn-si-pro {
    font-weight: 700;
    padding: 12px;
    border-radius: 12px;
}

body.index-page .si-pricing-card .si-buy-secondary {
    display: block;
    text-align: center;
    padding: 12px;
    border-radius: 999px;
    border: 1px solid #5f3df3;
    color: #5f3df3;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}

body.index-page .si-pricing-card .si-buy-secondary:hover {
    background: #5f3df3;
    color: #fff;
}

/* Preview + urgencia + comparativa (venta) */
body.index-page .pricing-preview {
    padding-bottom: 0.5rem;
}

body.index-page .pricing-preview-title {
    font-weight: 800;
    font-size: clamp(1.85rem, 3vw, 2.5rem);
    color: #101828;
    letter-spacing: -0.02em;
    margin-bottom: 0.75rem;
}

body.index-page .pricing-preview-subtitle {
    max-width: 640px;
    color: #475467;
    font-size: 1.02rem;
    line-height: 1.65;
}

body.index-page .pricing-urgency-strip {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    max-width: 820px;
    margin: 1.75rem auto 0;
    padding: 14px 18px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(91, 61, 245, 0.1), rgba(47, 128, 237, 0.08));
    border: 1px solid rgba(91, 61, 245, 0.22);
}

body.index-page .pricing-urgency-dot {
    flex-shrink: 0;
    width: 10px;
    height: 10px;
    margin-top: 6px;
    border-radius: 50%;
    background: #12b76a;
    box-shadow: 0 0 0 4px rgba(18, 183, 106, 0.25);
    animation: si-urgency-pulse 2s ease-in-out infinite;
}

@keyframes si-urgency-pulse {
    0%,
    100% {
        box-shadow: 0 0 0 4px rgba(18, 183, 106, 0.25);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(18, 183, 106, 0.12);
    }
}

body.index-page .pricing-urgency-text {
    font-size: 0.92rem;
    line-height: 1.55;
    color: #344054;
}

body.index-page .pricing-value-anchor {
    margin-top: 1.5rem;
    margin-bottom: 0.25rem;
}

body.index-page .pricing-value-anchor-inner {
    display: inline-block;
    font-size: 0.95rem;
    color: #667085;
    max-width: 520px;
    line-height: 1.5;
}

body.index-page .pricing-plan-row {
    margin-top: 2rem;
}

body.index-page .pricing-full-cta-wrap {
    margin-top: 2rem;
    margin-bottom: 0.5rem;
}

body.index-page .pricing-full-cta {
    border-width: 2px;
}

body.index-page .pricing-comparison-wrap {
    padding-top: 2.75rem;
    padding-bottom: 0.25rem;
}

body.index-page .pricing-comparison-title {
    font-weight: 800;
    font-size: 1.35rem;
    color: #101828;
    margin-bottom: 0.5rem;
}

body.index-page .pricing-comparison-lead {
    max-width: 560px;
}

body.index-page .pricing-comparison-table {
    margin-top: 1.25rem;
    margin-bottom: 0;
    font-size: 0.9rem;
    border-collapse: separate;
    border-spacing: 0;
    border: 1px solid #eaecf0;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 28px rgba(16, 24, 40, 0.06);
}

body.index-page .pricing-comparison-table thead th {
    background: #f9fafb;
    font-weight: 700;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #475467;
    padding: 14px 12px;
    border-bottom: 1px solid #eaecf0;
}

body.index-page .pricing-comparison-table tbody th {
    font-weight: 600;
    color: #101828;
    text-align: left;
    padding: 12px 16px;
    background: #fff;
    border-bottom: 1px solid #f2f4f7;
}

body.index-page .pricing-comparison-table tbody td {
    padding: 12px 10px;
    border-bottom: 1px solid #f2f4f7;
    color: #475467;
}

body.index-page .pricing-comparison-table tbody tr:last-child th,
body.index-page .pricing-comparison-table tbody tr:last-child td {
    border-bottom: 0;
}

body.index-page .pricing-comparison-table .pricing-col-highlight {
    background: rgba(91, 61, 245, 0.06);
    font-weight: 600;
    color: #344054;
}

/* Diferenciación «no solo ping» */
body.index-page .differentiation {
    padding-top: 3rem;
    padding-bottom: 2rem;
}

body.index-page .differentiation-card {
    max-width: 800px;
    margin: 0 auto;
    padding: 2rem 1.75rem;
    border-radius: 20px;
    background: linear-gradient(145deg, rgba(91, 61, 245, 0.08), rgba(47, 128, 237, 0.06));
    border: 1px solid rgba(91, 61, 245, 0.2);
    box-shadow: 0 16px 40px rgba(91, 61, 245, 0.1);
}

body.index-page .differentiation-kicker {
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #5b3df5;
    margin-bottom: 0.5rem;
}

body.index-page .differentiation-title {
    font-weight: 800;
    font-size: clamp(1.65rem, 2.8vw, 2.15rem);
    color: #101828;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin-bottom: 1rem;
}

body.index-page .differentiation-lead {
    font-size: 1.05rem;
    line-height: 1.7;
    color: #475467;
}

body.index-page .differentiation-checklist {
    list-style: none;
    padding: 0;
    margin: 1.5rem 0 1.25rem;
}

body.index-page .differentiation-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    font-size: 0.98rem;
    line-height: 1.5;
    color: #344054;
    border-bottom: 1px solid rgba(16, 24, 40, 0.06);
}

body.index-page .differentiation-checklist li:last-child {
    border-bottom: 0;
}

body.index-page .differentiation-checklist li i {
    color: #12b76a;
    font-size: 1.1rem;
    margin-top: 2px;
    flex-shrink: 0;
}

body.index-page .differentiation-foot {
    font-size: 0.9rem;
    color: #667085;
    line-height: 1.55;
}

/* Layout dos columnas (sin .container de Bootstrap): ancho fluido con tope legible */
body.index-page .differentiation-shell {
    width: 100%;
    max-width: 1320px;
    margin-left: auto;
    margin-right: auto;
}

body.index-page .differentiation-split .differentiation-card {
    max-width: none;
    margin-left: 0;
    margin-right: 0;
}

body.index-page .differentiation-side-stack {
    min-height: 100%;
}

body.index-page .differentiation-side-box {
    padding: 1.15rem 1.35rem;
    border-radius: 16px;
    background: #fff;
    border: 1px solid #eaecf0;
    box-shadow: 0 8px 24px rgba(16, 24, 40, 0.06);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

body.index-page .differentiation-side-box:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(91, 61, 245, 0.1);
}

body.index-page .differentiation-side-box h5 {
    font-size: 1.02rem;
    font-weight: 800;
    color: #101828;
    letter-spacing: -0.02em;
    margin-bottom: 0.4rem;
}

body.index-page .differentiation-side-box p {
    font-size: 0.88rem;
    line-height: 1.5;
    color: #667085;
}

@media (max-width: 991.98px) {
    body.index-page .differentiation-side-stack {
        margin-top: 0.25rem;
    }
}

/* ------------------------------------------------------------------------- */
/* FAQ                                                                         */
/* ------------------------------------------------------------------------- */
body.index-page #faq.faq-saas {
    background: #fff;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
}

/* padding: 0 anula el 20px global de Techie sobre .faq-item; el ritmo lo marcan h3 + .faq-content */
body.index-page #faq.faq-saas .faq-container .faq-item {
    border: 1px solid #eceff5;
    border-radius: 14px !important;
    overflow: hidden;
    margin-bottom: 10px;
    padding: 0;
    box-shadow: 0 4px 16px rgba(16, 24, 40, 0.04);
    background: #fff;
}

body.index-page #faq.faq-saas .faq-container .faq-item h3 {
    font-weight: 700;
    color: #111827;
    font-size: 0.98rem;
    line-height: 1.45;
    padding: 14px 44px 14px 18px !important;
    margin: 0;
    background: #fff;
}

body.index-page #faq.faq-saas .faq-container .faq-item.faq-active h3 {
    color: #5b3df5 !important;
    background: #f9faff;
    box-shadow: none;
}

body.index-page #faq.faq-saas .faq-container .faq-item .faq-content {
    padding: 0 18px 0 !important;
    color: #667085;
    line-height: 1.65;
}

body.index-page #faq.faq-saas .faq-container .faq-item.faq-active .faq-content {
    padding: 0 18px 14px !important;
}

body.index-page #faq.faq-saas .faq-container .faq-item .faq-content p {
    margin: 0;
    font-size: 0.9rem;
}

body.index-page #faq.faq-saas .faq-container .faq-item .faq-toggle {
    right: 16px;
    top: 14px;
    font-size: 15px;
}

/* ------------------------------------------------------------------------- */
/* SEO                                                                         */
/* ------------------------------------------------------------------------- */
body.index-page .seo-block {
    background: #f6f8fc;
    padding-top: 3rem;
    padding-bottom: 3rem;
}

body.index-page .seo-card,
body.index-page .seo-box {
    background: #fff;
    border: 1px solid #eceff5;
    border-radius: 20px;
    padding: 34px 28px;
    box-shadow: 0 10px 28px rgba(16, 24, 40, 0.05);
    max-width: 900px;
    margin: 0 auto;
}

body.index-page .seo-card .section-title-saas {
    margin-bottom: 0.75rem;
}

body.index-page .seo-card .section-text-saas {
    max-width: none;
}

/* ------------------------------------------------------------------------- */
/* CTA final                                                                   */
/* ------------------------------------------------------------------------- */
body.index-page .final-cta {
    background: linear-gradient(135deg, #111827 0%, #0f172a 55%, #1e1b4b 100%);
    color: #fff;
    padding: 90px 0;
    text-align: center;
}

body.index-page .final-cta h2 {
    font-size: clamp(2rem, 2vw + 1.5rem, 2.45rem);
    font-weight: 800;
    margin-bottom: 12px;
    color: #fff;
    letter-spacing: -0.025em;
}

body.index-page .final-cta .lead {
    color: rgba(255, 255, 255, 0.78);
    font-size: 1.06rem;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.8;
}

body.index-page .final-cta .final-cta-actions {
    margin-top: 1.75rem;
}

body.index-page .final-cta .btn-light {
    font-weight: 700;
    border-radius: 999px;
    padding: 14px 28px;
    font-size: 1.05rem;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
    border: 0;
}

body.index-page .final-cta .btn-outline-light {
    font-weight: 700;
    border-radius: 999px;
    padding: 14px 28px;
    font-size: 1.02rem;
    border-width: 2px;
}

/* =============================================================================
 * Tema oscuro unificado (home): misma familia cromática que el hero (violeta / índigo).
 * Este bloque va al final para prevalecer sobre reglas anteriores del mismo archivo.
 * ============================================================================= */
body.index-page {
    --si-page-base: #07050f;
    --si-surface: rgba(255, 255, 255, 0.07);
    --si-surface-deep: rgba(12, 8, 24, 0.92);
    --si-border: rgba(167, 139, 250, 0.22);
    --si-border-soft: rgba(255, 255, 255, 0.1);
    --si-text: rgba(255, 255, 255, 0.9);
    --si-muted: rgba(224, 219, 245, 0.7);
    --si-heading: #f7f5ff;
    --si-kicker: #c4b5fd;
    color: var(--si-text);
    background-color: var(--si-page-base);
    background-image:
        radial-gradient(ellipse 110% 55% at 50% -8%, rgba(106, 50, 239, 0.34), transparent 58%),
        radial-gradient(ellipse 55% 40% at 100% 22%, rgba(59, 31, 179, 0.32), transparent 52%),
        radial-gradient(ellipse 50% 35% at 0% 70%, rgba(91, 61, 245, 0.14), transparent 48%),
        linear-gradient(180deg, #07050f 0%, #0b0718 38%, #0e0a20 100%);
    background-attachment: fixed;
}

body.index-page .main {
    background: transparent;
}

/* Techie fuerza `section { background-color: var(--background-color) }` (claro); anulamos en home oscura */
body.index-page #visibilidad-real.differentiation,
body.index-page section.differentiation {
    background-color: transparent !important;
    background-image: none !important;
    color: var(--si-text);
}

body.index-page section.segments,
body.index-page .segments.section {
    background-color: transparent !important;
    background-image: none !important;
    color: var(--si-text);
}

body.index-page .segments-seo-title {
    color: var(--si-heading);
}

body.index-page .segments-mantra {
    color: var(--si-kicker);
}

body.index-page .segments-intro {
    color: var(--si-muted);
}

body.index-page .segments-card {
    background: var(--si-surface-deep);
    border-color: var(--si-border);
    box-shadow: 0 16px 44px rgba(0, 0, 0, 0.35);
}

body.index-page .segments-card:hover {
    box-shadow: 0 22px 50px rgba(91, 61, 245, 0.2);
}

body.index-page .segments-card-icon {
    background: rgba(91, 61, 245, 0.2);
    color: #c4b5fd;
}

body.index-page .segments-card h3 {
    color: var(--si-heading);
}

body.index-page .segments-card p {
    color: var(--si-muted);
}

body.index-page #confianza.landing-trust-stats,
body.index-page section.landing-trust-stats {
    background-color: transparent !important;
    background-image: linear-gradient(
        180deg,
        rgba(91, 61, 245, 0.22) 0%,
        rgba(45, 27, 105, 0.35) 38%,
        rgba(7, 5, 15, 0.55) 100%
    ) !important;
    border-top: 1px solid rgba(167, 139, 250, 0.38);
    border-bottom: 1px solid rgba(167, 139, 250, 0.28);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 24px 56px rgba(0, 0, 0, 0.4);
    color: var(--si-text);
}

body.index-page .landing-trust-stats-title {
    color: var(--si-heading);
}

body.index-page .landing-trust-stat-value {
    background: linear-gradient(135deg, #f5f3ff 0%, #c4b5fd 40%, #7dd3fc 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}

body.index-page .landing-trust-stat-label {
    color: var(--si-muted);
}

body.index-page .section .text-muted {
    color: var(--si-muted) !important;
}

body.index-page .landing-metrics-wrap {
    background: linear-gradient(180deg, rgba(7, 5, 15, 0.55) 0%, transparent 100%);
    margin-top: 0;
}

body.index-page .metric-card {
    background: var(--si-surface-deep);
    border: 1px solid var(--si-border);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

body.index-page .metric-card:hover {
    box-shadow: 0 22px 50px rgba(91, 61, 245, 0.18);
}

body.index-page .metric-card .metric-label {
    color: var(--si-muted);
}

body.index-page .section-pain {
    background: transparent;
}

body.index-page .section-kicker {
    color: var(--si-kicker);
}

body.index-page .section-title-saas {
    color: var(--si-heading);
}

body.index-page .section-text-saas {
    color: var(--si-muted);
}

body.index-page .section-subtitle-saas {
    color: var(--si-muted);
}

body.index-page .pain-item {
    background: var(--si-surface);
    border: 1px solid var(--si-border-soft);
    color: rgba(255, 255, 255, 0.88);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.25);
}

body.index-page .pain-media-wrap {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(12, 8, 24, 0.88) 100%);
    border-color: var(--si-border);
    box-shadow:
        0 0 0 1px rgba(167, 139, 250, 0.12) inset,
        0 22px 56px rgba(0, 0, 0, 0.42);
}

body.index-page .pain-impact-title {
    color: var(--si-heading);
}

body.index-page .pain-impact-lead {
    color: var(--si-muted);
}

body.index-page .how-section {
    background: transparent;
}

body.index-page .how-card {
    /* Capa base opaca + velo: evita que el conector de la fila se vea a través del cristal (var(--si-surface)). */
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.07) 0%, rgba(255, 255, 255, 0.035) 100%),
        rgba(12, 8, 24, 0.9);
    border: 1px solid var(--si-border);
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.28);
}

body.index-page .how-card:hover {
    box-shadow: 0 20px 48px rgba(91, 61, 245, 0.15);
}

body.index-page .how-card h3 {
    color: var(--si-heading);
}

body.index-page .how-card .how-card-text {
    color: var(--si-muted);
}

body.index-page .services-saas {
    background: transparent;
}

body.index-page .service-card {
    background: var(--si-surface);
    border: 1px solid var(--si-border);
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.28);
}

body.index-page .service-card:hover {
    border-color: rgba(167, 139, 250, 0.45);
    box-shadow: 0 24px 52px rgba(91, 61, 245, 0.2);
}

body.index-page .service-card h4 {
    color: var(--si-heading);
}

body.index-page .service-card p {
    color: var(--si-muted);
}

body.index-page .services-more-title {
    color: rgba(200, 190, 230, 0.55);
}

body.index-page .service-card-secondary {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--si-border-soft);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

body.index-page .service-card-secondary:hover {
    border-color: rgba(167, 139, 250, 0.35);
}

body.index-page .service-card-secondary h5 {
    color: var(--si-heading);
}

body.index-page .service-card-secondary p {
    color: var(--si-muted);
}

body.index-page .why-us {
    background: transparent;
}

body.index-page .why-card {
    background: var(--si-surface);
    border: 1px solid var(--si-border);
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.26);
}

body.index-page .why-card:hover {
    box-shadow: 0 20px 48px rgba(91, 61, 245, 0.14);
}

body.index-page .why-card h4 {
    color: var(--si-heading);
}

body.index-page .why-card p {
    color: var(--si-muted);
}

body.index-page .features-saas {
    background: transparent;
}

body.index-page .features-saas-billboard-head .text-muted {
    color: var(--si-muted) !important;
}

body.index-page .feature-mockup-wrap {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(12, 8, 22, 0.65) 100%);
    border: 1px solid var(--si-border);
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.35);
}

body.index-page .feature-mockup-wrap--hero {
    box-shadow: 0 22px 56px rgba(0, 0, 0, 0.4);
}

body.index-page .feature-item,
body.index-page .feature-saas-item {
    background: var(--si-surface);
    border: 1px solid var(--si-border-soft);
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.22);
}

body.index-page .feature-item h5,
body.index-page .feature-saas-item h5 {
    color: var(--si-heading);
}

body.index-page .feature-item p,
body.index-page .feature-saas-item p {
    color: var(--si-muted);
}

body.index-page .features-saas-billboard .feature-item--compact h5 {
    color: var(--si-heading);
}

body.index-page .features-saas-billboard .feature-item--compact p {
    color: var(--si-muted);
}

body.index-page #pricing.pricing-saas {
    background: transparent;
}

body.index-page #pricing.pricing-saas .section-title h2 {
    color: var(--si-heading);
}

body.index-page #pricing.pricing-saas .section-title h2::after {
    background: linear-gradient(90deg, #7c3aed, #a78bfa);
}

body.index-page .si-pricing-card {
    background: var(--si-surface-deep);
    border: 1px solid var(--si-border);
    box-shadow: 0 16px 44px rgba(0, 0, 0, 0.35);
}

body.index-page .si-pricing-card h3 {
    color: var(--si-heading);
}

body.index-page .si-pricing-price {
    color: var(--si-heading);
}

body.index-page .si-pricing-price .si-pricing-price-subline {
    color: var(--si-muted);
}

body.index-page .si-pricing-commercial {
    color: var(--si-muted);
}

body.index-page .si-pricing-list li {
    color: var(--si-muted);
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

body.index-page .pricing-preview-title,
body.index-page .pricing-comparison-title {
    color: var(--si-heading);
}

body.index-page .pricing-preview-subtitle,
body.index-page .pricing-urgency-text,
body.index-page .pricing-value-anchor-inner,
body.index-page .pricing-comparison-lead {
    color: var(--si-muted);
}

body.index-page .pricing-urgency-strip {
    background: rgba(21, 14, 52, 0.55);
    border-color: rgba(167, 139, 250, 0.28);
}

body.index-page .pricing-comparison-table {
    border-color: var(--si-border);
    box-shadow: 0 16px 44px rgba(0, 0, 0, 0.35);
}

body.index-page .pricing-comparison-table thead th {
    background: rgba(21, 14, 52, 0.65);
    color: rgba(255, 255, 255, 0.82);
    border-bottom-color: rgba(255, 255, 255, 0.1);
}

body.index-page .pricing-comparison-table tbody th {
    color: var(--si-heading);
    background: var(--si-surface-deep);
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

body.index-page .pricing-comparison-table tbody td {
    color: var(--si-muted);
    border-bottom-color: rgba(255, 255, 255, 0.08);
    background: var(--si-surface-deep);
}

body.index-page .pricing-comparison-table .pricing-col-highlight {
    background: rgba(91, 61, 245, 0.15);
    color: rgba(255, 255, 255, 0.9);
}

/* Sin panel propio: mismo fondo que el body de la home (gradiente fijo) */
body.index-page .differentiation-card {
    background: transparent;
    border: none;
    box-shadow: none;
    border-radius: 0;
}

body.index-page .differentiation-title {
    color: var(--si-heading);
}

body.index-page .differentiation-lead,
body.index-page .differentiation-checklist li {
    color: rgba(255, 255, 255, 0.88);
}

body.index-page .differentiation-checklist li {
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

body.index-page .differentiation-foot {
    color: var(--si-muted);
}

body.index-page .differentiation-side-box {
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0;
    box-shadow: none;
}

body.index-page .differentiation-side-box:last-child {
    border-bottom: none;
}

body.index-page .differentiation-side-box:hover {
    transform: none;
    box-shadow: none;
    border-bottom-color: rgba(167, 139, 250, 0.28);
}

body.index-page .differentiation-side-box h5 {
    color: var(--si-heading);
}

body.index-page .differentiation-side-box p {
    color: var(--si-muted);
}

body.index-page #faq.faq-saas {
    background: transparent;
    padding-top: 2.25rem;
    padding-bottom: 2.25rem;
}

body.index-page #faq.faq-saas .section-title h2 {
    color: var(--si-heading);
}

body.index-page #faq.faq-saas .section-title h2::after {
    background: linear-gradient(90deg, #7c3aed, #a78bfa);
}

/* Cristal alineado con #header.header (misma familia rgba + blur) */
body.index-page #faq.faq-saas .faq-container .faq-item {
    isolation: isolate;
    background: rgba(21, 14, 52, 0.48);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.09);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
}

body.index-page #faq.faq-saas .faq-container .faq-item.faq-active {
    background: rgba(21, 14, 52, 0.62);
    border-color: rgba(167, 139, 250, 0.28);
    box-shadow:
        0 12px 36px rgba(0, 0, 0, 0.28),
        0 0 0 1px rgba(167, 139, 250, 0.1) inset;
}

body.index-page #faq.faq-saas .faq-container .faq-item h3 {
    color: rgba(255, 255, 255, 0.92);
    background: transparent;
}

body.index-page #faq.faq-saas .faq-container .faq-item.faq-active h3 {
    color: #ddd6fe !important;
    background: rgba(91, 61, 245, 0.14);
}

body.index-page #faq.faq-saas .faq-container .faq-item .faq-content {
    color: var(--si-muted);
}

body.index-page #faq.faq-saas .faq-container .faq-item.faq-active .faq-content {
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    margin: 0 14px;
    padding: 10px 4px 12px !important; /* sustituye el padding del bloque claro solo en tema oscuro */
}

body.index-page #faq.faq-saas .faq-container .faq-item .faq-toggle {
    color: rgba(255, 255, 255, 0.55);
}

body.index-page #faq.faq-saas .faq-container .faq-item.faq-active .faq-toggle {
    color: #c4b5fd;
}

body.index-page .seo-block {
    background: transparent;
}

body.index-page .seo-card,
body.index-page .seo-box {
    background: var(--si-surface);
    border: 1px solid var(--si-border);
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.28);
}

body.index-page .seo-card .section-text-saas {
    color: var(--si-muted);
}

body.index-page .contact.section {
    background: transparent;
}

body.index-page .contact .section-title h2 {
    color: var(--si-heading);
}

body.index-page .contact .section-title h2::after {
    background: linear-gradient(90deg, #7c3aed, #a78bfa);
}

body.index-page .contact .section-title p {
    color: var(--si-muted);
}

body.index-page .contact .info-item {
    background: var(--si-surface);
    border: 1px solid var(--si-border-soft);
    border-radius: 16px;
}

body.index-page .contact .info-item h3 {
    color: var(--si-heading);
}

body.index-page .contact .info-item p {
    color: var(--si-muted);
}

body.index-page .contact .info-item i {
    color: #c4b5fd;
}

body.index-page .contact a.btn-get-started {
    color: #0a0614;
    background: #f4f0ff;
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-radius: 999px;
    font-weight: 700;
}

body.index-page .contact a.btn-get-started:hover {
    background: #fff;
    color: #4d2be3;
}

body.index-page .final-cta {
    background: linear-gradient(135deg, #100a1c 0%, #0d0820 45%, #1a0f32 100%);
    border-top: 1px solid rgba(139, 92, 246, 0.25);
}

body.index-page #footer.footer.accent-background {
    --background-color: #06030d;
    --default-color: rgba(235, 230, 250, 0.82);
    --heading-color: #fff;
    --accent-color: #c4b5fd;
    --surface-color: rgba(255, 255, 255, 0.06);
    --contrast-color: #0a0614;
    background: linear-gradient(180deg, #0a0618 0%, #05030a 100%) !important;
    border-top: 1px solid rgba(139, 92, 246, 0.22);
}

body.index-page #footer.footer a {
    color: #d8ccff;
}

body.index-page #footer.footer a:hover {
    color: #fff;
}

body.index-page .btn-outline-primary {
    color: #d8ccff;
    border-color: rgba(200, 185, 255, 0.45);
}

body.index-page .btn-outline-primary:hover {
    color: #0a0614;
    background: #e9e4ff;
    border-color: #e9e4ff;
}

/* Encabezados dentro del contenido: Techie usa --heading-color oscuro en :root */
body.index-page main h1,
body.index-page main h2,
body.index-page main h3,
body.index-page main h4,
body.index-page main h5,
body.index-page main h6 {
    color: var(--si-heading);
}

/* Selector de idioma: estilos base en site.css (carga en toda la landing) */
