  /* Estilos generales */
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        :root {
            --primary: #8cc529;
            --primary-dark: #c9fe6e;
            --primary-light: rgba(37, 99, 235, 0.1);
            --primary-lighter: rgba(37, 99, 235, 0.05);
            --accent: #f59e0b;
            --accent-light: rgba(245, 158, 11, 0.15);
            --slate-900: #0f172a;
            --slate-800: #1e293b;
            --slate-700: #334155;
            --slate-600: #475569;
            --slate-500: #64748b;
            --slate-400: #94a3b8;
            --slate-300: #cbd5e1;
            --slate-200: #e2e8f0;
            --slate-100: #f1f5f9;
            --slate-50: #f8fafc;
            --white: #ffffff;
            --red-500: #ef4444;
            --green-500: #c9fe6e;
            --blue-500: #3b82f6;
            --yellow-500: #f59e0b;
            --accent-color: #c9fe6e;
            --dark-gray: #333333;
            --medium-gray: #666666;
            --light-gray: #f5f5f5;
        }

        body {
            color: var(--slate-800);
            background-color: var(--slate-50);
            position: relative;
            overflow-x: hidden;
            /* width responsive del background */
            background-size: cover;
            background-position: center;
            min-height: 100%;
            padding-top: 80px;
            width: 100%;
            max-width: 100%;
        }

        html, body {
            overflow-x: hidden;
            overflow-y: auto;
        }

        body::before {
            content: "";
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-image:
                radial-gradient(circle at 20% 30%, var(--primary-lighter) 0%, transparent 20%),
                radial-gradient(circle at 80% 70%, var(--accent-light) 0%, transparent 20%);
            z-index: -1;
        }

    


        .container {
            width: 100%;
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 1.5rem;
            position: relative;
        }

        /* T�tulo */
        .section-title {
            text-align: center;
            margin-bottom: 5rem;
            position: relative;
        }

        .section-subtitle {
            display: inline-block;
            font-size: 0.875rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 2px;
            color: var(--primary);
            background-color: var(--primary-light);
            padding: 0.5rem 1rem;
            border-radius: 50px;
            margin-bottom: 1rem;
        }



        @media (min-width: 768px) {
            .section-title h2 {
                font-size: 3.5rem;
            }
        }


        /* Insignia de LegalCheck */
        .legalcheck-badge {
            position: absolute;
            bottom: -30px;
            right: 20px;
            background: linear-gradient(135deg, var(--primary), var(--primary-dark));
            color: var(--white);
            padding: 0.75rem 1.5rem;
            border-radius: 50px;
            font-weight: 600;
            font-size: 0.875rem;
            box-shadow: 0 10px 20px rgba(37, 99, 235, 0.3);
            display: flex;
            align-items: center;
            gap: 0.5rem;
            z-index: 10;
        }

        .legalcheck-badge i {
            font-size: 1.25rem;
        }


        .number-circle {
            background-color: #b3ee50 !important;
            width: 42px;
            height: 42px;
            border-radius: 50%;
            background-color: var(--mint-dark);
            display: flex;
            align-items: center;
            justify-content: center;
            color: #000;
            font-weight: 600;
            margin: 0 auto;
        }

        .feature-card {
            border: 1px solid #ddd;
            border-radius: 10px;
            padding: 20px;
            height: 100%;
            transition: all 0.3s ease;
        }

        .feature-card:hover {
            box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
        }

        .icon-container {
            text-align: center;
            margin-bottom: 15px;
        }

        .material-symbols-rounded {
            font-size: 36px;
            color: #333;
        }

        .benefit-card {
            border-radius: 10px;
            box-shadow: 1px 3px 3px rgba(0, 0, 0, 0.3);
            height: 100%;
            transition: all 0.3s ease;
        }

        .benefit-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
        }

        .benefit-img {
            border-radius: 10px 10px 0 0;
            width: 100%;
            height: 200px;
            object-fit: cover;
        }

        .timeline-container {
            position: relative;
        }

        .timeline-line {
            position: absolute;
            top: 42px;
            bottom: 0;
            left: 50%;
            width: 6px;
            background-color: #e9ecef;
            transform: translateX(-50%);
        }

        .timeline-item {
            position: relative;
            padding-bottom: 50px;
        }

        .timeline-content-right {
            padding-left: 60px;
        }

        .timeline-content-left {
            padding-right: 60px;
            text-align: right;
        }

        .timeline-number {
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            z-index: 2;
        }

        .example-card {
            background: #f2f2f2;
            border-radius: 10px;
            padding: 30px;
            box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
        }

        .section-title {
            margin-bottom: 1.5rem;
        }

        .section-subtitle {
            color: #6c757d;
            text-transform: uppercase;
            font-weight: 600;
            font-size: 0.9rem;
            margin-bottom: 0.5rem;
        }

        @media (max-width: 767.98px) {
            .timeline-line {
                left: 5px;
            }

            .timeline-number {
                left: 21px;
            }

            .timeline-content-left,
            .timeline-content-right {
                padding-left: 60px;
                text-align: left;
            }

            /* Mobile fixes */
            .display-5 {
                font-size: 2rem;
            }

            .section-title {
                padding: 0 10px;
            }

            .benefit-card {
                margin-bottom: 20px;
            }

            .timeline-item ul.list-unstyled {
                padding-left: 0;
            }

            .timeline-item ul.list-unstyled li {
                text-align: left;
            }

            /* Fix for mobile menu */
            .mobile-menu-toggle {
                display: block;
            }

            /* Adjust spacing for mobile */
            .py-5 {
                padding-top: 2rem !important;
                padding-bottom: 2rem !important;
            }

            /* Adjust hero section for mobile */
            #inicio .text-lg-start {
                text-align: center !important;
            }

            #inicio .text-end {
                text-align: center !important;
            }

            /* Fix for timeline on mobile */
            .timeline-content-left {
                margin-top: 20px;
            }

            /* Adjust feature cards for mobile */
            .feature-card {
                margin-bottom: 15px;
            }

            /* Adjust benefit cards for mobile */
            .benefit-card {
                max-width: 300px;
                margin-left: auto;
                margin-right: auto;
            }
        }

        .nav-container {
            position: relative;
            display: flex;
            gap: 1.5rem;
            padding: 10px 0;
        }

        .nav-link {
            position: relative;
            text-decoration: none;
            color: #6c757d;
            font-size: 1rem;
            padding: 10px 15px;
            transition: color 0.3s ease;
            z-index: 2;
        }

        .nav-link:hover {
            color: rgb(0, 0, 0);
        }

        /* Fondo animado detr�s de los enlaces */
        .hover-background {
            position: absolute;
            bottom: 10px;
            left: 0;
            height: 40px;
            width: 0;
            background-color: #c9fe6e;
            border-radius: 5px;
            transition: all 0.3s ease-in-out;
            z-index: 1;
        }

        /* Resalta el elemento (le agrega una linea abajo) */
        .hover-active-background {
            position: relative;
            border-bottom: 2px solid #c9fe6e;
        }
        #typed-text {
            display: inline-block;
            position: relative;
        }

        #typed-text::after {
            content: "|"; /* El cursor */
            position: relative;
            right: 0; /* Ajusta la posici�n del cursor */
            animation: blink 1s steps(2, start) infinite;
            color: var(--slate-800); /* Color del cursor */
        }

        /* Animaci�n del parpadeo */
        @keyframes blink {
            0% {
                opacity: 1;
            }
            40% {
                opacity: 1;
            }
            50% {
                opacity: 0;
            }
            90% {
                opacity: 0;
            }
            100% {
                opacity: 1;
            }
        }

        .stats-container {
            background: white;
            border-radius: 12px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08), 
                        0 6px 12px rgba(0, 0, 0, 0.05);
            padding: 2rem;
            max-width: 1000px;
            margin: 2rem auto;
        }
        
        
        .stats-row {
            display: flex;
            justify-content: space-around;
        }
        
        .stat-item {
            text-align: center;
            padding: 0 1rem;
        }
        
        .stat-value {
            font-size: 3.5rem;
            font-weight: 300;
            color: var(--dark-gray);
            line-height: 1;
            margin-bottom: 0.5rem;
        }
        
        .stat-label {
            color: var(--medium-gray);
            font-size: 1rem;
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        
        .control-buttons {
            display: flex;
            justify-content: center;
            gap: 0.5rem;
            margin-top: 0.5rem;
        }
        
        .informe-imagen {
            position: relative;
        }
        
        .informe-imagen img {
            border-radius: 0.5rem;
            box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
        }
        
        .informe-titulo {
            font-size: 2.5rem;
            font-weight: 800;
            margin-bottom: 1.5rem;
        }
        
        .informe-descripcion {
            color: var(--legalcheck-gray);
            margin-bottom: 2rem;
            font-size: 1.1rem;
        }
        
        .feature-item {
            display: flex;
            align-items: flex-start;
            margin-bottom: 1.5rem;
        }
        
        .feature-icon {
            flex-shrink: 0;
            width: 24px;
            height: 24px;
            background-color: var(--legalcheck-green-light);
            color: var(--legalcheck-dark);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin-right: 1rem;
            margin-top: 0.25rem;
        }
        
        .feature-content h4 {
            font-weight: 600;
            font-size: 1.1rem;
            margin-bottom: 0.5rem;
        }
        
        .feature-content p {
            color: var(--legalcheck-gray);
            font-size: 0.95rem;
            margin-bottom: 0;
        }
        header {
            background-color: rgba(255, 255, 255, 0.7); /* Fondo semitransparente */
            backdrop-filter: blur(10px); /* Desenfoque */
            z-index: 1030; /* Asegura que est� por encima de otros elementos */
            border-bottom: 1px solid rgba(255, 255, 255, 0.2); /* L�nea sutil en la parte inferior */
            transition: box-shadow 0.3s ease; /* Transici�n suave para la sombra */
        }

        .header-shadow {
            box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Sombra para mayor profundidad */
        }
        /* Clase para eliminar el efecto sepia */
        .remove-sepia {
            filter: none !important; /* Elimina cualquier filtro aplicado */
            transition: filter 0.3s ease; /* Transici�n suave */
        }

        /* Opcional: efecto hover para mostrar sin sepia */
        .benefit-img:hover {
            filter: none !important;
        }
        .viable-button {
                                background-color: var(--primary-dark);
                                border-radius: 40px;
                                padding: 3px;
                                margin: 0;
                                border: 0;
                                width: 60%;
                                font-weight: 600;
                                text-align: center;
                            }
                            /* Reusable circle indicators */
                            .circle-indicator {
                                display: flex;
                                flex-direction: column;
                                position: absolute;
                                width: 160px;
                                height: 160px;
                                background-color: #f2f2f2;
                                border-radius: 50%;
                                display: flex;
                                align-items: center;
                                justify-content: center;
                                box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
                                left: -10%;
                            }
                            
                            .circle-indicator-top {
                                top: 5%;
                            }
                            
                            .circle-indicator-middle {
                                top: 50%;
                            }
                            
                            .circle-text {
                                font-size: 1.25rem;
                                font-weight: bold;
                                color: #000;
                                text-align: center;
                            }
                            
                            .circle-text-small {
                                font-size: 0.875rem;
                            }
                            
                        
#titulo{
font-size: 4.5rem;
}
#homer{
   width: 80%; margin: 0 auto; 
}

#mobil{
display: none;
}   
#web{
display: ;
}   
#contenidos_homer .text{
    line-height:4.2rem; font-weight: 650; 
    font-size: 4rem; 
}

.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1040;
  width: 100vw;
  height: 100vh;
  background-color: transparent !important;
}


@media (max-width: 455px) {
#titulo{
font-size: 1.8rem;
padding-bottom: 0px;
line-height: 9px;
}

.offcanvas-body {
  flex-grow: 1;
  padding: 1rem 1rem;
  overflow-y: auto;
  background-color: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  -moz-backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  -0-backdrop-filter: blur(10px);
  -ms-backdrop-filter: blur(10px);
  z-index: 1030;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  transition: box-shadow 0.3s ease;
}

#homer{
   width: 100%; margin: 0 auto; 
}
 #mobil{
    display: block;
 }   
 #mobil .img-fluid{
    
 }
 #web{
    display: none;
 }
.pt-5 {
  padding-top: 5px !important;
}  
      .circle-indicator {
                                
                                display: flex;
                                flex-direction: column;
                                position: absolute;
                                width: 90px;
                                height: 90px;
                                background-color: #f2f2f2;
                                border-radius: 50%;
                                display: flex;
                                align-items: center;
                                justify-content: center;
                                box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
                                left: 73%;
                                margin-top: -40px;
                                margin-left: -3px;
                            }
.viable-button {
            background-color: var(--primary-dark);
            border-radius: 40px;
            padding: 3px;
            margin: 0;
            border: 0;
            width: 60%;
            font-weight: 600;
            font-size: 10px;
            text-align: center;
}
   #contenidos_homer{
    padding-top: 20px;
   }
   #contenidos_homer .text{
    
    line-height:2.3rem; font-weight: 650; 
    font-size: 2rem; 
}
 #text-even{
    min-height:150px;
 } 
 
 #inicio{
   padding-bottom: 0px !important; 
 }
   .py-5 {
    padding-top: 2rem !important;
    padding-bottom: 0rem !important;
  }
 
 
}    

/***. Carousel ***/
.carousel-item img {
    max-width: 100%;
    max-height: 90vh;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}
/* Ajusta la posición de los botones del carrusel */
.carousel-control-prev,
.carousel-control-next {
position: absolute;
top: 50%; /* Centra verticalmente */
transform: translateY(-50%);
width: auto; /* Ajusta el ancho */
height: auto; /* Ajusta la altura */
background: none; /* Elimina cualquier fondo predeterminado */
border: none; /* Elimina bordes */
z-index: 10; /* Asegura que estén por encima del contenido */
transition: transform 0.3s ease; /* Agrega la transición para la animación */
animation: moveButtons 1s infinite alternate; /* Agrega animación continua */
}

.carousel-control-prev {
left: 0; /* Mueve el botón al borde izquierdo */
animation: movePrevButton 1s infinite alternate; /* Animación específica para el botón previo */
}

.carousel-control-next {
right: 0; /* Mueve el botón al borde derecho */
animation: moveNextButton 1s infinite alternate; /* Animación específica para el botón siguiente */
}

/* Mejora la visibilidad de los íconos */
.carousel-control-prev-icon,
.carousel-control-next-icon {
background-color: rgba(0, 0, 0, 0.5); /* Fondo semitransparente */
border-radius: 50%; /* Hace que los íconos sean circulares */
width: 40px;
height: 40px;
}

.carousel-control-prev-icon:hover,
.carousel-control-next-icon:hover {
background-color: rgba(0, 0, 0, 0.8); /* Cambia el color al pasar el mouse */
}

/* Animación de movimiento continuo para el botón previo */
@keyframes movePrevButton {
0% {
    transform: translateY(-50%) translateX(0);
}
100% {
    transform: translateY(-50%) translateX(-10px); /* Mueve hacia la izquierda */
}
}

/* Animación de movimiento continuo para el botón siguiente */
@keyframes moveNextButton {
0% {
    transform: translateY(-50%) translateX(0);
}
100% {
    transform: translateY(-50%) translateX(10px); /* Mueve hacia la derecha */
}
}

.viable-button {
    background-color: var(--primary-dark);
    border-radius: 40px;
    padding: 3px;
    margin: 0;
    border: 0;
    width: 60%;
    font-weight: 600;
    text-align: center;
}
/* Reusable circle indicators */
.circle-indicator {
    display: flex;
    flex-direction: column;
    position: absolute;
    width: 160px;
    height: 160px;
    background-color: #f2f2f2;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    left: -10%;
}
.circle-indicator-top {
    top: 5%;
}
.circle-indicator-middle {
    top: 50%;
}
.circle-text {
    font-size: 1.25rem;
    font-weight: bold;
    color: #000;
    text-align: center;
}
.circle-text-small {
    font-size: 0.875rem;
}
#titulo{
font-size: 4.5rem;
}

#titulo_terminos{
font-size: 3.5rem;
}
#homer{
width: 80%; margin: 0 auto; 
}
#mobil{
display: none;
}   
#web{
display: ;
}   
#contenidos_homer .text{
line-height:4.2rem; font-weight: 650; 
font-size: 4rem; 
}
.modal-backdrop {
position: fixed;
top: 0;
left: 0;
z-index: 1040;
width: 100vw;
height: 100vh;
background-color: transparent !important;
}
#footer-web{
display: block;
}
#footer-movil{
display: none;
}
#footer{
padding-bottom: 0rem !important; 
}
#footer .py-5 {
padding-top: 2rem !important;
padding-bottom: 0rem !important;
}
.text-secondary li{
padding-bottom: 5px;
}



@media (max-width: 767px) {
#titulo{
font-size: 1.8rem;
padding-bottom: 0px;
line-height: 9px;
}

#titulo_terminos{
font-size: 2rem;
}
.offcanvas-body {
flex-grow: 1;
padding: 1rem 1rem;
overflow-y: auto;
background-color: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
-moz-backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
-0-backdrop-filter: blur(10px);
-ms-backdrop-filter: blur(10px);
z-index: 1030;
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
transition: box-shadow 0.3s ease;
}
#politica .informe-titulo {
font-size: 1.7rem;
font-weight: 600;
margin-bottom: 1.5rem;
}

#homer{
width: 100%; margin: 0 auto; 
}
#mobil{
display: block;
}   
#mobil .img-fluid{
}
#web{
display: none;
}
.pt-5 {
padding-top: 5px !important;
}  
.circle-indicator {
    display: flex;
    flex-direction: column;
    position: absolute;
    width: 90px;
    height: 90px;
    background-color: #f2f2f2;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    left: 73%;
    margin-top: -40px;
    margin-left: -3px;
}
.viable-button {
background-color: var(--primary-dark);
border-radius: 40px;
padding: 3px;
margin: 0;
border: 0;
width: 60%;
font-weight: 600;
font-size: 10px;
text-align: center;
}
#contenidos_homer{
padding-top: 20px;
}
#contenidos_homer .text{
line-height:2.3rem; font-weight: 650; 
font-size: 2rem; 
}
#text-even{
min-height:150px;
} 
#inicio{
padding-bottom: 0px !important; 
}
#footer .py-5 {
padding-top: 2rem !important;
padding-bottom: 0rem !important;
}
#footer-web{
display:none ;
}
#footer-movil{
display:block;
} 
#footer{
padding-bottom: 0rem !important; 
}
}  

.hidden {
    opacity: 0;
    pointer-events: none;
}

.hide-header {
    display: none !important;
}


.highlight {
    background-color: #f5f5f5;
    padding: 20px;
    border-left: 4px solid #c6ff33;
    margin: 20px 0;
}

.blurn-elegante {
    backdrop-filter: blur(7px) brightness(100%) contrast(100%) grayscale(0%) 
                     hue-rotate(0deg) invert(0%) opacity(100%) saturate(100%) sepia(0%);
    -webkit-backdrop-filter: blur(7px) brightness(100%) contrast(100%) grayscale(0%) 
                             hue-rotate(0deg) invert(0%) opacity(100%) saturate(100%) sepia(0%);
}