        :root {
            /* Colores Corporativos */
            --corporate-dark-grey: rgba(105,105,105,1); /* Gris oscuro principal */
            --corporate-light-grey: rgba(250,250,250,1); /* Casi blanco */
            --background-dark: #222222; /* Un negro/gris muy oscuro para el fondo general */
            --text-color: var(--corporate-light-grey); /* Texto principal en casi blanco */

            /* Color de acento para CTAs y highlights (manteniendo un azul sutil para impacto) */
            --cta-accent-blue: #007bff;
            --cta-accent-blue-dark: #0056b3;

            /* Colores secundarios y derivados */
            --card-background: #333333; /* Fondo de tarjetas un poco más claro que el principal */
            --border-color: rgba(250,250,250,0.2); /* Borde sutil del casi blanco */
        }

        body {
            font-family: 'Montserrat', sans-serif;
            background-color: var(--background-dark);
            color: var(--text-color);
            line-height: 1.7;
        }

        /* General Heading Styles */
        h1, h2, h3, h4, h5, h6 {
            font-family: 'Montserrat', sans-serif;
            color: var(--corporate-light-grey);
            font-weight: 600;
        }

        h2 {
            text-align: center;
            font-size: 2.8em;
            margin-bottom: 3.5rem;
            color: var(--corporate-light-grey); /* Títulos también en casi blanco */
            text-transform: uppercase;
            letter-spacing: 2px;
        }

        /* Hero Section */
        .hero {
            background: linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)) no-repeat center center/cover; /* Imagen de fondo más oscura */
            color: var(--corporate-light-grey);
            text-align: center;
            padding: 8rem 1rem;
            position: relative;
            overflow: hidden;
            border-bottom: 3px solid var(--cta-accent-blue); /* Borde inferior de acento */
        }

        .hero h1 {
            font-size: 4.2em;
            margin-bottom: 1.5rem;
            line-height: 1.1;
            font-weight: 700;
            text-shadow: 2px 2px 5px rgba(0,0,0,0.5);
            color: var(--corporate-light-grey);
        }

        .hero p {
            font-family: 'Roboto', sans-serif;
            font-size: 1.6em;
            margin-bottom: 3rem;
            max-width: 900px;
            margin-left: auto;
            margin-right: auto;
            opacity: 0.9;
        }

        .hero .btn-cta {
            background: linear-gradient(45deg, var(--cta-accent-blue), var(--cta-accent-blue-dark));
            color: var(--white); /* Botones CTA siempre blancos para contraste */
            padding: 1rem 2rem;
            border-radius: 50px;
            font-weight: 700;
            transition: all 0.3s ease;
            box-shadow: 0 5px 15px rgba(0, 123, 255, 0.4);
            letter-spacing: 1px;
            text-transform: uppercase;
            border: none;
        }

        .hero .btn-cta:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 20px rgba(0, 123, 255, 0.6);
            background: linear-gradient(45deg, var(--cta-accent-blue-dark), var(--cta-accent-blue));
        }

        /* Sections General */
        section {
            padding: 5rem 0;
            position: relative;
            z-index: 1;
        }

        /* ¿Quiénes Somos? */
        .about-us {
            background-color: var(--corporate-dark-grey); /* Fondo de la sección en gris oscuro corporativo */
            text-align: center;
        }

        .about-us p {
            max-width: 1000px;
            margin: 0 auto 2.5rem auto;
            font-size: 1.15em;
            font-family: 'Roboto', sans-serif;
            color: var(--corporate-light-grey);
        }

        .about-us .card {
            background-color: var(--card-background); /* Fondo de tarjeta más oscuro */
            padding: 2.5rem;
            border-radius: 0.75rem;
            box-shadow: 0 0.5rem 1.25rem rgba(0, 0, 0, 0.3);
            border: 1px solid var(--border-color); /* Borde sutil */
            text-align: left;
            transition: transform 0.3s ease;
        }

        .about-us .card:hover {
            transform: translateY(-0.625rem);
             border-color: var(--cta-accent-blue);
            box-shadow: 0 0.5rem 1.5625rem rgba(0, 123, 255, 0.2);
        }

        .about-us .card-title {
            color: var(--cta-accent-blue); /* Títulos de misión/visión en acento azul */
            margin-bottom: 1.25rem;
            font-size: 1.6em;
            font-weight: 700;
        }

        .about-us .card-text {
            font-size: 1.1em;
            color: var(--text-color);
            margin: 0;
        }

     /* Nuevo estilo para la sub-sección de valores */
        .values-section {
            margin-top: 5rem; /* Espacio superior para separar de Misión/Visión */
            padding-top: 3rem; /* Padding interno */
            border-top: 1px solid rgba(250, 250, 250, 0.1); /* Separador visual */
        }

        .values-section h3 {
            color: var(--corporate-light-grey);
            font-size: 2.2em;
            margin-bottom: 2.5rem;
            font-weight: 700;
            text-align: center;
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        .value-item {
            background-color: var(--card-background);
            padding: 2rem;
            border-radius: 0.625rem;
            box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
            text-align: left;
            transition: all 0.3s ease;
            border: 1px solid var(--border-color);
            display: flex;
            align-items: flex-start; /* Alinea icono y texto arriba */
            gap: 1rem; /* Espacio entre icono y texto */
        }

        .value-item:hover {
            transform: translateY(-0.5rem);
            border-color: var(--cta-accent-blue);
            box-shadow: 0 0.5rem 1.5625rem rgba(0, 123, 255, 0.2);
        }

        .value-item i {
            font-size: 2.5em; /* Tamaño del icono */
            color: var(--cta-accent-blue);
            margin-right: 0.5rem;
            flex-shrink: 0; /* Evita que el icono se encoja */
        }

        .value-item h4 {
            color: var(--corporate-light-grey);
            font-size: 1.5em;
            margin-bottom: 0.5rem;
            font-weight: 700;
        }

        .value-item p {
            font-size: 1em;
            color: var(--text-color);
            margin-bottom: 0; /* Elimina margen inferior extra */
        }

        /* Nuestros Servicios */
        .services {
            background-color: var(--background-dark); /* Fondo de la sección servicios */
        }

        .service-card {
            background-color: var(--card-background); /* Fondo de tarjeta de servicio */
            padding: 2rem;
            border-radius: 0.625rem;
            box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
            text-align: center;
            transition: all 0.3s ease;
            border: 1px solid transparent;
            position: relative;
            overflow: hidden;
        }

        .service-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 5px;
            background: linear-gradient(90deg, transparent, var(--cta-accent-blue), transparent);
            transform: translateX(-100%);
            transition: transform 0.4s ease-out;
        }

        .service-card:hover::before {
            transform: translateX(0);
        }

        .service-card:hover {
            transform: translateY(-0.5rem);
            border-color: var(--cta-accent-blue);
            box-shadow: 0 0.5rem 1.5625rem rgba(0, 123, 255, 0.2);
        }

        .service-card .h3 {
            color: var(--cta-accent-blue); /* Títulos de servicio en acento azul */
            font-size: 1.6em;
            margin-bottom: 1rem;
            font-weight: 700;
        }

        .service-card p {
            font-size: 1em;
            color: var(--text-color);
        }

        /* Sectores y Tecnologías */
        .sectors-tech {
            background-color: var(--corporate-dark-grey); /* Fondo de sección en gris oscuro corporativo */
        }

        .sectors-tech .card {
            background-color: var(--card-background);
            padding: 2.5rem;
            border-radius: 0.75rem;
            box-shadow: 0 0.5rem 1.25rem rgba(0, 0, 0, 0.3);
            border: 1px solid var(--border-color);
            text-align: left;
        }

        .sectors-tech .h3 {
            color: var(--cta-accent-blue); /* Títulos de secciones en acento azul */
            font-size: 2.2em;
            margin-bottom: 1.875rem;
            font-weight: 700;
            text-align: center;
        }

        .sectors-tech ul {
            list-style: none;
            padding: 0;
        }

        .sectors-tech ul li {
            padding: 0.75rem 0;
            border-bottom: 1px solid rgba(250, 250, 250, 0.1); /* Borde sutil del casi blanco */
            font-size: 1.1em;
            color: var(--text-color);
        }

        .sectors-tech ul li:last-child {
            border-bottom: none;
        }

        /* Nuestro Equipo */
        .team {
            background-color: var(--background-dark); /* Fondo de sección equipo */
        }

        .team-member-card {
            background-color: var(--card-background);
            padding: 2rem;
            border-radius: 0.625rem;
            box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
            text-align: center;
            transition: transform 0.3s ease;
            border: 1px solid var(--border-color);
        }

        .team-member-card:hover {
            transform: translateY(-0.5rem);
            box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.3);
        }

        .team-member-card .h4 {
            color: var(--corporate-light-grey); /* Nombres de roles en casi blanco */
            margin-top: 1rem;
            font-size: 1.4em;
            font-weight: 600;
        }

        .team-member-card p {
            margin: 0.3125rem 0;
            font-size: 1em;
            color: var(--text-color);
        }

        /* Por qué elegir NeoLogic SpA */
        .why-choose-us {
            background: linear-gradient(45deg, var(--cta-accent-blue-dark), var(--cta-accent-blue)); /* Mantiene el gradiente azul para el impacto */
            color: var(--white);
            text-align: center;
            box-shadow: inset 0 0.3125rem 0.9375rem rgba(0,0,0,0.3);
        }

        .why-choose-us h2 {
            color: var(--white);
            font-size: 3em;
            text-shadow: 1px 1px 3px rgba(0,0,0,0.3);
        }

        .why-choose-us-item {
            background-color: rgba(250, 250, 250, 0.1); /* Fondo translúcido del casi blanco */
            padding: 2rem;
            border-radius: 0.625rem;
            font-size: 1.2em;
            font-weight: 600;
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
            min-height: 7.5rem;
            border: 1px solid rgba(250, 250, 250, 0.2); /* Borde translúcido del casi blanco */
            transition: background-color 0.3s ease, transform 0.3s ease;
        }

        .why-choose-us-item:hover {
            background-color: rgba(250, 250, 250, 0.2);
            transform: translateY(-0.3125rem);
        }

        /* Casos de Éxito */
        .success-stories {
            background-color: var(--corporate-dark-grey); /* Fondo de sección en gris oscuro corporativo */
            text-align: center;
        }

        .case-study-item {
            background-color: var(--card-background);
            padding: 2rem;
            border-radius: 0.625rem;
            box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
            text-align: left;
            margin-bottom: 1.5625rem;
            border: 1px solid var(--border-color);
            transition: transform 0.3s ease;
        }

        .case-study-item:hover {
            transform: translateY(-0.3125rem);
        }

        .success-stories .btn-view-more {
            background: linear-gradient(45deg, var(--corporate-light-grey), var(--corporate-dark-grey)); /* Gradiente de grises para este CTA */
            color: var(--background-dark); /* Texto oscuro para contraste */
            padding: 0.9375rem 1.875rem;
            border-radius: 50px;
            font-weight: 700;
            transition: all 0.3s ease;
            box-shadow: 0 0.3125rem 0.9375rem rgba(105, 105, 105, 0.4);
            letter-spacing: 1px;
            text-transform: uppercase;
            border: none;
        }

        .success-stories .btn-view-more:hover {
            transform: translateY(-0.3125rem);
            box-shadow: 0 0.625rem 1.25rem rgba(105, 105, 105, 0.6);
            background: linear-gradient(45deg, var(--corporate-dark-grey), var(--corporate-light-grey));
        }
 /* Carrusel de Proyectos */
        .projects-carousel {
            background-color: var(--background-dark);
            text-align: center;
        }

        .carousel-item img {
            border-radius: 0.75rem;
            box-shadow: 0 0.5rem 1.25rem rgba(0, 0, 0, 0.3);
            border: 1px solid var(--border-color);
        }
        /* Testimonios */
        .testimonials {
            background-color: var(--corporate-dark-grey); /* Fondo de sección testimonios */
        }

        .testimonial-item {
            background-color: var(--card-background);
            padding: 2.1875rem;
            border-radius: 0.625rem;
            box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.2);
            max-width: 500px;
            text-align: left;
            border: 1px solid var(--border-color);
            transition: transform 0.3s ease;
        }

        .testimonial-item:hover {
            transform: translateY(-0.3125rem);
        }

        .testimonial-item p {
            font-style: italic;
            margin-bottom: 1.25rem;
            font-size: 1.1em;
            color: var(--text-color);
        }

        .testimonial-item span {
            display: block;
            font-weight: bold;
            color: var(--cta-accent-blue); /* Nombre del testimonial en acento azul */
            font-size: 1.1em;
        }

          /* Nuevo estilo para el botón de WhatsApp */
        .btn-whatsapp {
            background-color: #25D366; /* Color de WhatsApp */
            color: white;
            padding: 1rem 2rem;
            border-radius: 50px;
            font-weight: 700;
            transition: all 0.3s ease;
            box-shadow: 0 5px 15px rgba(37, 211, 102, 0.4);
            letter-spacing: 1px;
            text-transform: uppercase;
            border: none;
            display: inline-flex; /* Para alinear el icono y el texto */
            align-items: center;
            gap: 0.5rem; /* Espacio entre icono y texto */
        }

        .btn-whatsapp:hover {
            background-color: #1DA851; /* Tono más oscuro al pasar el mouse */
            transform: translateY(-5px);
            box-shadow: 0 10px 20px rgba(37, 211, 102, 0.6);
            color: white; /* Asegurar que el color del texto no cambie */
        }


        /* Contacto */
        .contact {
            background-color: var(--background-dark); /* Fondo de sección contacto */
            color: var(--corporate-light-grey);
        }

        .contact h2 {
            color: var(--corporate-light-grey);
        }

        .contact-info p {
            margin: 0;
            color: var(--text-color);
            font-size: 1.2em;
        }

        .contact-form {
            max-width: 700px;
            margin: 0 auto;
            background-color: var(--card-background);
            padding: 2.5rem;
            border-radius: 0.75rem;
            box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.3);
            border: 1px solid var(--border-color);
            text-align: left;
        }

        .contact-form label {
            display: block;
            margin-bottom: 0.625rem;
            color: var(--corporate-light-grey); /* Labels en casi blanco */
            font-weight: 600;
            font-size: 1.1em;
        }

        .contact-form .form-control {
            padding: 0.75rem;
            margin-bottom: 1.5625rem;
            border: 1px solid var(--border-color);
            border-radius: 0.375rem;
            font-size: 1.05em;
            background-color: #444444; /* Un gris medio para los campos de entrada */
            color: var(--text-color);
            outline: none;
            transition: border-color 0.3s ease;
        }

        .contact-form .form-control:focus {
            border-color: var(--cta-accent-blue);
            box-shadow: 0 0 0 0.25rem rgba(0, 123, 255, 0.25);
        }

        .contact-form textarea.form-control {
            min-height: 9.375rem;
        }

        .contact-form .btn-submit {
            background: linear-gradient(45deg, var(--cta-accent-blue), var(--cta-accent-blue-dark));
            color: var(--white);
            padding: 0.9375rem 1.875rem;
            border: none;
            border-radius: 50px;
            cursor: pointer;
            font-size: 1.1em;
            font-weight: 700;
            transition: all 0.3s ease;
            box-shadow: 0 0.3125rem 0.9375rem rgba(0, 123, 255, 0.4);
            letter-spacing: 1px;
            text-transform: uppercase;
        }

        .contact-form .btn-submit:hover {
            transform: translateY(-0.1875rem);
            box-shadow: 0 0.5rem 1.25rem rgba(0, 123, 255, 0.6);
        }

        .btn-schedule-meeting {
            background: linear-gradient(45deg, var(--corporate-light-grey), var(--corporate-dark-grey));
            color: var(--background-dark);
            padding: 0.9375rem 1.875rem;
            border-radius: 50px;
            font-weight: 700;
            transition: all 0.3s ease;
            box-shadow: 0 0.3125rem 0.9375rem rgba(105, 105, 105, 0.4);
            letter-spacing: 1px;
            text-transform: uppercase;
            border: none;
        }

        .btn-schedule-meeting:hover {
            transform: translateY(-0.3125rem);
            box-shadow: 0 0.625rem 1.25rem rgba(105, 105, 105, 0.6);
        }

        /* Social Media */
        .social-media {
            text-align: center;
        }

        .social-media h3 {
            color: var(--corporate-light-grey);
            margin-bottom: 1.5rem;
            font-size: 1.8em;
            font-weight: 600;
        }

        .social-media a {
            color: var(--corporate-light-grey); /* Íconos sociales en casi blanco */
            font-size: 2.2em;
            margin: 0 1rem;
            text-decoration: none;
            transition: color 0.3s ease, transform 0.3s ease;
        }

        .social-media a:hover {
            color: var(--cta-accent-blue); /* Hover azul para íconos sociales */
            transform: translateY(-0.3125rem) scale(1.1);
        }

        /* Footer */
        footer {
            background-color: var(--corporate-dark-grey);
            color: var(--text-color);
            text-align: center;
            padding: 1.5rem;
            border-top: 1px solid rgba(250, 250, 250, 0.05); /* Borde sutil del casi blanco */
            font-size: 0.95em;
            opacity: 0.8;
        }

        footer a {
            color: var(--text-color);
            text-decoration: none;
            margin: 0 0.75rem;
            transition: color 0.3s ease;
        }

        footer a:hover {
            color: var(--cta-accent-blue);
        }

        /* Responsive overrides for Bootstrap */
        @media (max-width: 767.98px) {
            .hero h1 {
                font-size: 2.8em;
            }

            .hero p {
                font-size: 1.2em;
            }

            h2 {
                font-size: 2.2em;
            }

            .hero .btn-cta {
                display: block;
                width: 100%;
                max-width: 300px;
                margin: 1rem auto;
            }

            .about-us .card {
                padding: 1.5rem;
            }

            .about-us .card-title {
                font-size: 1.4em;
            }

            .sectors-tech .card {
                padding: 1.5rem;
            }

            .sectors-tech .h3 {
                font-size: 1.8em;
            }
        }

        @media (max-width: 575.98px) {
            .hero h1 {
                font-size: 2.2em;
            }

            .hero p {
                font-size: 1em;
            }

            h2 {
                font-size: 1.8em;
            }
            .contact-form {
                padding: 1.5rem;
            }
        }
