
        /* Reset y configuración base */
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        body {
            font-family: 'Roboto', sans-serif;
            line-height: 1.6;
            color: #333;
            overflow-x: hidden;
        }

        /* Variables CSS para colores corporativos */
        :root {
            --verde-lima: #C6E400;
            --azul-marino: #0A1A3C;
            --blanco: #FFFFFF;
            --gris-claro: #f8f9fa;
            --gris-medio: #6c757d;
            --negro: #000000;
        }

        /* Header */
        header {
            background: var(--azul-marino);
            color: var(--blanco);
            padding: 1rem 0;
            position: fixed;
            width: 100%;
            top: 0;
            z-index: 1000;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1);
            transition: all 0.3s ease;
        }

        .header-container {
            max-width: 1200px;
            margin: 0 auto;
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 0 2rem;
        }

        .logo {
            display: flex;
            align-items: center;
            font-size: 1.8rem;
            font-weight: 700;
            color: var(--verde-lima);
        }

        .logo .logo-icon {
            width: 50px;
            height: 50px;
            margin-right: 15px;
            background: var(--verde-lima);
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 2rem;
            color: var(--azul-marino);
            font-weight: bold;
        }

        nav ul {
            display: flex;
            list-style: none;
            gap: 2rem;
        }

        nav a {
            color: var(--blanco);
            text-decoration: none;
            font-weight: 500;
            transition: color 0.3s ease;
            position: relative;
        }

        nav a:hover {
            color: var(--verde-lima);
        }

        nav a::after {
            content: '';
            position: absolute;
            width: 0;
            height: 2px;
            bottom: -5px;
            left: 0;
            background: var(--verde-lima);
            transition: width 0.3s ease;
        }

        nav a:hover::after {
            width: 100%;
        }

        .cta-button {
            background: var(--verde-lima);
            color: var(--azul-marino);
            padding: 0.8rem 1.5rem;
            border: none;
            border-radius: 25px;
            font-weight: 600;
            text-decoration: none;
            transition: all 0.3s ease;
            cursor: pointer;
            box-shadow: 0 4px 15px rgba(198, 228, 0, 0.3);
        }

        .cta-button:hover {
            background: var(--azul-marino);
            color: var(--verde-lima);
            transform: translateY(-2px);
            box-shadow: 0 6px 20px rgba(198, 228, 0, 0.4);
        }

        /* Menú móvil */
        .mobile-menu-toggle {
            display: none;
            background: none;
            border: none;
            color: var(--blanco);
            font-size: 1.5rem;
            cursor: pointer;
        }

        /* Main content */
        main {
            margin-top: 80px;
        }

        /* Sección Héroe */
        .hero {
            background: linear-gradient(135deg, var(--azul-marino) 0%, #1a2f5c 100%);
            color: var(--blanco);
            padding: 6rem 0;
            text-align: center;
            position: relative;
            overflow: hidden;
        }

        .hero::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><polygon fill="%23C6E400" fill-opacity="0.1" points="0,1000 1000,0 1000,1000"/></svg>');
            background-size: cover;
        }

        .hero-content {
            max-width: 800px;
            margin: 0 auto;
            padding: 0 2rem;
            position: relative;
            z-index: 2;
        }

        .hero h1 {
            font-size: 3.5rem;
            font-weight: 700;
            margin-bottom: 1rem;
            line-height: 1.2;
        }

        .hero .tagline {
            font-size: 1.5rem;
            color: var(--verde-lima);
            font-weight: 600;
            margin-bottom: 1rem;
        }

        .hero p {
            font-size: 1.3rem;
            margin-bottom: 2.5rem;
            opacity: 0.9;
        }

        .hero .cta-button {
            font-size: 1.1rem;
            padding: 1rem 2rem;
        }

        /* Secciones generales */
        .section {
            padding: 5rem 0;
        }

        .container {
            max-width: 1200px;
            margin: 0 auto;
            padding: 0 2rem;
        }

        .section-title {
            text-align: center;
            font-size: 2.5rem;
            font-weight: 700;
            color: var(--azul-marino);
            margin-bottom: 3rem;
            position: relative;
        }

        .section-title::after {
            content: '';
            position: absolute;
            bottom: -10px;
            left: 50%;
            transform: translateX(-50%);
            width: 80px;
            height: 4px;
            background: var(--verde-lima);
            border-radius: 2px;
        }

        /* Sección Servicios */
        .servicios {
            background: var(--gris-claro);
        }

        .servicios-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 2rem;
            margin-top: 3rem;
        }

        .servicio-card {
            background: var(--blanco);
            padding: 2.5rem;
            border-radius: 15px;
            text-align: center;
            box-shadow: 0 10px 30px rgba(0,0,0,0.1);
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
        }

        .servicio-card::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 4px;
            background: var(--verde-lima);
            transform: scaleX(0);
            transition: transform 0.3s ease;
        }

        .servicio-card:hover {
            transform: translateY(-10px);
            box-shadow: 0 20px 40px rgba(0,0,0,0.15);
        }

        .servicio-card:hover::before {
            transform: scaleX(1);
        }

        .servicio-icon {
            width: 80px;
            height: 80px;
            background: var(--verde-lima);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 1.5rem;
            font-size: 2rem;
            color: var(--azul-marino);
            transition: all 0.3s ease;
        }

        .servicio-card:hover .servicio-icon {
            background: var(--azul-marino);
            color: var(--verde-lima);
            transform: scale(1.1);
        }

        .servicio-card h3 {
            font-size: 1.5rem;
            font-weight: 600;
            color: var(--azul-marino);
            margin-bottom: 1rem;
        }

        .servicio-card p {
            color: var(--gris-medio);
            line-height: 1.6;
        }

        /* Sección Acerca de */
        .acerca-de {
            background: var(--blanco);
        }

        .acerca-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
            gap: 3rem;
            margin-top: 3rem;
        }

        .acerca-item {
            text-align: center;
            padding: 2rem;
        }

        .acerca-item h3 {
            font-size: 1.8rem;
            font-weight: 600;
            color: var(--azul-marino);
            margin-bottom: 1.5rem;
            position: relative;
        }

        .acerca-item h3::after {
            content: '';
            position: absolute;
            bottom: -8px;
            left: 50%;
            transform: translateX(-50%);
            width: 50px;
            height: 3px;
            background: var(--verde-lima);
            border-radius: 2px;
        }

        .acerca-item p {
            color: var(--gris-medio);
            line-height: 1.8;
            font-size: 1.1rem;
        }

        /* Sección Ventajas Competitivas */
        .ventajas {
            background: var(--gris-claro);
        }

        .ventajas-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 2rem;
            margin-top: 3rem;
        }

        .ventaja-item {
            background: var(--blanco);
            padding: 2rem;
            border-radius: 10px;
            text-align: center;
            box-shadow: 0 5px 15px rgba(0,0,0,0.1);
            transition: all 0.3s ease;
        }

        .ventaja-item:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 25px rgba(0,0,0,0.15);
        }

        .ventaja-icon {
            font-size: 3rem;
            color: var(--verde-lima);
            margin-bottom: 1rem;
        }

        .ventaja-item h4 {
            font-size: 1.3rem;
            font-weight: 600;
            color: var(--azul-marino);
            margin-bottom: 1rem;
        }

        .ventaja-item p {
            color: var(--gris-medio);
            line-height: 1.6;
        }

        /* Sección Clientes/Testimonios */
        .clientes {
            background: var(--blanco);
        }

        .testimonios-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
            gap: 2rem;
            margin-top: 3rem;
        }

        .testimonio {
            background: var(--gris-claro);
            padding: 2.5rem;
            border-radius: 15px;
            box-shadow: 0 10px 30px rgba(0,0,0,0.1);
            position: relative;
            transition: all 0.3s ease;
        }

        .testimonio:hover {
            transform: translateY(-5px);
            box-shadow: 0 15px 35px rgba(0,0,0,0.15);
        }

        .testimonio::before {
            content: '"';
            position: absolute;
            top: -10px;
            left: 20px;
            font-size: 4rem;
            color: var(--verde-lima);
            font-weight: bold;
        }

        .testimonio p {
            font-style: italic;
            margin-bottom: 1.5rem;
            color: var(--gris-medio);
            line-height: 1.6;
        }

        .cliente-info {
            display: flex;
            align-items: center;
            gap: 1rem;
        }

        .cliente-avatar {
            width: 50px;
            height: 50px;
            background: var(--verde-lima);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: bold;
            color: var(--azul-marino);
        }

        .cliente-datos h4 {
            font-weight: 600;
            color: var(--azul-marino);
        }

        .cliente-datos span {
            color: var(--gris-medio);
            font-size: 0.9rem;
        }

        /* Sección FAQs */
        .faqs {
            background: var(--gris-claro);
        }

        .faq-item {
            background: var(--blanco);
            margin-bottom: 1rem;
            border-radius: 10px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.1);
            overflow: hidden;
            transition: all 0.3s ease;
        }

        .faq-item:hover {
            box-shadow: 0 8px 25px rgba(0,0,0,0.15);
        }

        .faq-question {
            padding: 1.5rem 2rem;
            background: var(--blanco);
            border: none;
            width: 100%;
            text-align: left;
            font-size: 1.1rem;
            font-weight: 600;
            color: var(--azul-marino);
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            transition: all 0.3s ease;
        }

        .faq-question:hover {
            background: var(--gris-claro);
            color: var(--verde-lima);
        }

        .faq-question.active {
            background: var(--verde-lima);
            color: var(--azul-marino);
        }

        .faq-icon {
            font-size: 1.2rem;
            transition: transform 0.3s ease;
        }

        .faq-question.active .faq-icon {
            transform: rotate(180deg);
        }

        .faq-answer {
            padding: 0 2rem;
            max-height: 0;
            overflow: hidden;
            transition: all 0.3s ease;
            background: var(--blanco);
        }

        .faq-answer.active {
            padding: 1.5rem 2rem;
            max-height: 500px;
        }

        .faq-answer p {
            color: var(--gris-medio);
            line-height: 1.6;
            margin: 0;
        }

        /* Formulario de Contacto */
        .contacto {
            background: var(--azul-marino);
            color: var(--blanco);
        }

        .contacto .section-title {
            color: var(--blanco);
        }

        .contacto-content {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 4rem;
            margin-top: 3rem;
        }

        .contacto-info h3 {
            color: var(--verde-lima);
            font-size: 1.5rem;
            margin-bottom: 1.5rem;
        }

        .contacto-item {
            display: flex;
            align-items: center;
            gap: 1rem;
            margin-bottom: 1.5rem;
        }

        .contacto-icon {
            width: 40px;
            height: 40px;
            background: var(--verde-lima);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--azul-marino);
            font-weight: bold;
        }

        .contacto-form {
            background: rgba(255,255,255,0.1);
            padding: 3rem;
            border-radius: 15px;
            backdrop-filter: blur(10px);
        }

        .form-group {
            margin-bottom: 1.5rem;
        }

        .form-group label {
            display: block;
            margin-bottom: 0.5rem;
            font-weight: 500;
            color: var(--verde-lima);
        }

        .form-group input,
        .form-group textarea,
        .form-group select {
            width: 100%;
            padding: 1rem;
            border: 2px solid transparent;
            border-radius: 8px;
            background: rgba(255,255,255,0.9);
            color: var(--azul-marino);
            font-size: 1rem;
            transition: all 0.3s ease;
        }

        .form-group input:focus,
        .form-group textarea:focus,
        .form-group select:focus {
            outline: none;
            border-color: var(--verde-lima);
            background: var(--blanco);
            box-shadow: 0 0 0 3px rgba(198, 228, 0, 0.2);
        }

        .form-group textarea {
            resize: vertical;
            min-height: 120px;
        }

        .error-message {
            color: #ff6b6b;
            font-size: 0.9rem;
            margin-top: 0.5rem;
            display: none;
        }

        .form-group.error input,
        .form-group.error textarea,
        .form-group.error select {
            border-color: #ff6b6b;
        }

        .form-group.error .error-message {
            display: block;
        }

        .submit-button {
            width: 100%;
            background: var(--verde-lima);
            color: var(--azul-marino);
            padding: 1rem 2rem;
            border: none;
            border-radius: 8px;
            font-size: 1.1rem;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
            margin-top: 1rem;
        }

        .submit-button:hover {
            background: var(--blanco);
            transform: translateY(-2px);
            box-shadow: 0 5px 15px rgba(0,0,0,0.2);
        }

        .submit-button:disabled {
            opacity: 0.6;
            cursor: not-allowed;
            transform: none;
        }

        /* Modal para mensaje de éxito */
        .modal {
            display: none;
            position: fixed;
            z-index: 2000;
            left: 0;
            top: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0,0,0,0.5);
            backdrop-filter: blur(5px);
        }

        .modal-content {
            background-color: var(--blanco);
            margin: 15% auto;
            padding: 2rem;
            border-radius: 15px;
            width: 90%;
            max-width: 500px;
            text-align: center;
            box-shadow: 0 20px 40px rgba(0,0,0,0.2);
            animation: modalAppear 0.3s ease-out;
        }

        @keyframes modalAppear {
            from {
                opacity: 0;
                transform: translateY(-50px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        .modal-icon {
            width: 80px;
            height: 80px;
            background: var(--verde-lima);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto 1rem;
            font-size: 2.5rem;
            color: var(--azul-marino);
        }

        .modal h3 {
            color: var(--azul-marino);
            font-size: 1.5rem;
            margin-bottom: 1rem;
        }

        .modal p {
            color: var(--gris-medio);
            margin-bottom: 2rem;
            line-height: 1.6;
        }

        .modal-button {
            background: var(--verde-lima);
            color: var(--azul-marino);
            padding: 0.8rem 2rem;
            border: none;
            border-radius: 25px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
        }

        .modal-button:hover {
            background: var(--azul-marino);
            color: var(--verde-lima);
        }

        /* Footer */
        footer {
            background: var(--azul-marino);
            color: var(--blanco);
            padding: 3rem 0 1rem;
        }

        .footer-content {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 2rem;
            margin-bottom: 2rem;
        }

        .footer-section h3 {
            color: var(--verde-lima);
            margin-bottom: 1rem;
            font-size: 1.3rem;
        }

        .footer-section p,
        .footer-section li {
            color: rgba(255,255,255,0.8);
            line-height: 1.6;
        }

        .footer-section ul {
            list-style: none;
        }

        .footer-section ul li {
            margin-bottom: 0.5rem;
        }

        .footer-section a {
            color: rgba(255,255,255,0.8);
            text-decoration: none;
            transition: color 0.3s ease;
        }

        .footer-section a:hover {
            color: var(--verde-lima);
        }

        .phone-link {
            color: inherit;
            text-decoration: none;
        }

        .phone-link:hover {
            color: var(--verde-lima);
        }

        .footer-bottom {
            border-top: 1px solid rgba(255,255,255,0.1);
            padding-top: 1rem;
            text-align: center;
            color: rgba(255,255,255,0.6);
        }

        /* Responsive Design */
        @media (max-width: 1024px) {
            .container {
                padding: 0 1.5rem;
            }

            .hero h1 {
                font-size: 3rem;
            }

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

            .servicios-grid {
                grid-template-columns: repeat(2, 1fr);
                gap: 1.5rem;
            }

            .ventajas-grid {
                grid-template-columns: repeat(2, 1fr);
                gap: 1.5rem;
            }

            .testimonios-grid {
                grid-template-columns: 1fr;
            }
        }

        @media (max-width: 768px) {
            .header-container {
                padding: 0 1rem;
                flex-wrap: nowrap;
            }

            .logo {
                font-size: 1.5rem;
            }

            .logo .logo-icon {
                width: 40px;
                height: 40px;
                margin-right: 10px;
                font-size: 1.5rem;
            }

            nav {
                display: none;
            }

            .mobile-menu-toggle {
                display: block;
            }

            .cta-button {
                padding: 0.6rem 1rem;
                font-size: 0.9rem;
            }

            .hero {
                padding: 4rem 0 3rem;
                text-align: center;
            }

            .hero h1 {
                font-size: 2.2rem;
                line-height: 1.3;
                margin-bottom: 1rem;
            }

            .hero .tagline {
                font-size: 1.2rem;
                margin-bottom: 0.8rem;
            }

            .hero p {
                font-size: 1rem;
                margin-bottom: 2rem;
                padding: 0 1rem;
                line-height: 1.6;
            }

            .hero .cta-button {
                font-size: 1rem;
                padding: 0.8rem 1.5rem;
            }

            .section {
                padding: 3rem 0;
            }

            .container {
                padding: 0 1rem;
                max-width: 100%;
            }

            .section-title {
                font-size: 1.8rem;
                margin-bottom: 2rem;
                line-height: 1.3;
            }

            .servicios-grid {
                grid-template-columns: 1fr;
                gap: 1.5rem;
            }

            .servicio-card {
                padding: 2rem 1.5rem;
                margin: 0 auto;
                max-width: 400px;
            }

            .servicio-card h3 {
                font-size: 1.3rem;
                line-height: 1.4;
            }

            .servicio-card p {
                font-size: 0.95rem;
                line-height: 1.6;
            }

            .acerca-grid {
                grid-template-columns: 1fr;
                gap: 2rem;
            }

            .acerca-item {
                padding: 1.5rem 1rem;
                max-width: 500px;
                margin: 0 auto;
            }

            .acerca-item h3 {
                font-size: 1.5rem;
                margin-bottom: 1rem;
            }

            .acerca-item p {
                font-size: 1rem;
                line-height: 1.7;
            }

            .ventajas-grid {
                grid-template-columns: 1fr;
                gap: 1.5rem;
            }

            .ventaja-item {
                padding: 1.5rem;
                max-width: 400px;
                margin: 0 auto;
            }

            .ventaja-item h4 {
                font-size: 1.2rem;
                line-height: 1.4;
            }

            .ventaja-item p {
                font-size: 0.95rem;
                line-height: 1.6;
            }

            .testimonios-grid {
                grid-template-columns: 1fr;
                gap: 1.5rem;
            }

            .testimonio {
                padding: 2rem 1.5rem;
                margin: 0 auto;
                max-width: 450px;
            }

            .testimonio p {
                font-size: 0.95rem;
                line-height: 1.6;
            }

            .faq-item {
                margin-bottom: 0.8rem;
            }

            .faq-question {
                padding: 1.2rem 1.5rem;
                font-size: 1rem;
                line-height: 1.4;
            }

            .faq-answer.active {
                padding: 1.2rem 1.5rem;
            }

            .faq-answer p {
                font-size: 0.95rem;
                line-height: 1.6;
            }

            .contacto-content {
                grid-template-columns: 1fr;
                gap: 2rem;
            }

            .contacto-info {
                order: 2;
            }

            .contacto-form {
                padding: 2rem 1.5rem;
                order: 1;
            }

            .contacto-item {
                margin-bottom: 1rem;
            }

            .footer-content {
                grid-template-columns: 1fr;
                text-align: center;
                gap: 2rem;
            }

            .footer-section {
                max-width: 400px;
                margin: 0 auto;
            }

            .footer-section p,
            .footer-section li {
                font-size: 0.95rem;
                line-height: 1.6;
            }
        }

        @media (max-width: 480px) {
            .header-container {
                padding: 0 0.8rem;
            }

            .logo {
                font-size: 1.3rem;
            }

            .logo .logo-icon {
                width: 35px;
                height: 35px;
                margin-right: 8px;
                font-size: 1.3rem;
            }

            .cta-button {
                padding: 0.5rem 0.8rem;
                font-size: 0.8rem;
            }

            .hero {
                padding: 3rem 0 2.5rem;
            }

            .hero h1 {
                font-size: 1.8rem;
                line-height: 1.3;
                margin-bottom: 0.8rem;
                padding: 0 0.5rem;
            }

            .hero .tagline {
                font-size: 1.1rem;
                margin-bottom: 0.6rem;
            }

            .hero p {
                font-size: 0.95rem;
                margin-bottom: 1.8rem;
                padding: 0 0.8rem;
                line-height: 1.6;
            }

            .section {
                padding: 2.5rem 0;
            }

            .container {
                padding: 0 0.8rem;
            }

            .section-title {
                font-size: 1.6rem;
                margin-bottom: 1.8rem;
                line-height: 1.3;
                padding: 0 0.5rem;
            }

            .servicio-card {
                padding: 1.8rem 1.2rem;
                max-width: 350px;
            }

            .servicio-card h3 {
                font-size: 1.2rem;
                line-height: 1.4;
                margin-bottom: 0.8rem;
            }

            .servicio-card p {
                font-size: 0.9rem;
                line-height: 1.6;
            }

            .acerca-item {
                padding: 1.2rem 0.8rem;
                max-width: 400px;
            }

            .acerca-item h3 {
                font-size: 1.4rem;
                margin-bottom: 0.8rem;
            }

            .acerca-item p {
                font-size: 0.95rem;
                line-height: 1.7;
            }

            .ventaja-item {
                padding: 1.2rem;
                max-width: 350px;
            }

            .ventaja-item h4 {
                font-size: 1.1rem;
                line-height: 1.4;
            }

            .ventaja-item p {
                font-size: 0.9rem;
                line-height: 1.6;
            }

            .testimonio {
                padding: 1.8rem 1.2rem;
                max-width: 350px;
            }

            .testimonio p {
                font-size: 0.9rem;
                line-height: 1.6;
                margin-bottom: 1.2rem;
            }

            .cliente-info {
                gap: 0.8rem;
            }

            .cliente-avatar {
                width: 40px;
                height: 40px;
                font-size: 0.9rem;
            }

            .cliente-datos h4 {
                font-size: 0.95rem;
            }

            .cliente-datos span {
                font-size: 0.8rem;
            }

            .faq-question {
                padding: 1rem 1.2rem;
                font-size: 0.95rem;
                line-height: 1.4;
            }

            .faq-answer.active {
                padding: 1rem 1.2rem;
            }

            .faq-answer p {
                font-size: 0.9rem;
                line-height: 1.6;
            }

            .contacto-form {
                padding: 1.5rem 1rem;
            }

            .form-group {
                margin-bottom: 1.2rem;
            }

            .form-group label {
                font-size: 0.95rem;
                margin-bottom: 0.4rem;
            }

            .form-group input,
            .form-group textarea,
            .form-group select {
                padding: 0.8rem;
                font-size: 0.95rem;
            }

            .submit-button {
                padding: 0.8rem 1.5rem;
                font-size: 1rem;
            }

            .contacto-item div {
                font-size: 0.9rem;
            }

            .contacto-item strong {
                font-size: 0.95rem;
            }

            .footer-section {
                max-width: 300px;
            }

            .footer-section h3 {
                font-size: 1.1rem;
                margin-bottom: 0.8rem;
            }

            .footer-section p,
            .footer-section li {
                font-size: 0.9rem;
                line-height: 1.6;
            }

            .modal-content {
                margin: 20% auto;
                padding: 1.5rem;
                width: 95%;
                max-width: 350px;
            }

            .modal-icon {
                width: 60px;
                height: 60px;
                font-size: 2rem;
                margin-bottom: 0.8rem;
            }

            .modal h3 {
                font-size: 1.3rem;
                margin-bottom: 0.8rem;
            }

            .modal p {
                font-size: 0.9rem;
                margin-bottom: 1.5rem;
                line-height: 1.6;
            }

            .modal-button {
                padding: 0.6rem 1.5rem;
                font-size: 0.95rem;
            }
        }

        @media (max-width: 320px) {
            .container {
                padding: 0 0.6rem;
            }

            .hero h1 {
                font-size: 1.6rem;
                padding: 0 0.3rem;
            }

            .hero p {
                font-size: 0.9rem;
                padding: 0 0.6rem;
            }

            .section-title {
                font-size: 1.4rem;
                padding: 0 0.3rem;
            }

            .servicio-card,
            .testimonio {
                padding: 1.5rem 1rem;
            }

            .contacto-form {
                padding: 1.2rem 0.8rem;
            }
        }

        /* Animaciones */
        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(30px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        .fade-in-up {
            animation: fadeInUp 0.6s ease-out;
        }

        /* Smooth scrolling */
        html {
            scroll-behavior: smooth;
        }

        /* Loading states */
        .loading {
            opacity: 0.6;
            pointer-events: none;
        }

        /* WhatsApp button */
        .whatsapp-button {
            position: fixed;
            bottom: 20px;
            right: 20px;
            background: #25D366;
            color: white;
            width: 60px;
            height: 60px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.5rem;
            text-decoration: none;
            box-shadow: 0 4px 15px rgba(37, 211, 102, 0.3);
            transition: all 0.3s ease;
            z-index: 1000;
        }

        .whatsapp-button:hover {
            transform: scale(1.1);
            box-shadow: 0 6px 20px rgba(37, 211, 102, 0.4);
        }
        
        /* === ancho completo para la sección del landing === */
        .landing-full.et_pb_section{ padding:0 !important; }
        .landing-full .et_pb_row{ max-width:100% !important; width:100% !important; padding:0 !important; margin:0 !important; }
        .landing-full .et_pb_code, .landing-full .et_pb_code_inner{ padding:0 !important; margin:0 !important; }
        
        /* === header + menú móvil (básico) === */
        .header{ position:sticky; top:0; z-index:9999; }
        .mobile-menu-toggle{ display:none; }
        @media (max-width:768px){
          .mobile-menu-toggle{ display:block; }
          .header nav{ display:none; }
          .header nav.open{
            display:block !important;
            position:absolute; right:1rem; top:100%;
            background:#0A1A3C; width:calc(100% - 2rem); padding:1rem;
            border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,.25); z-index:10000;
          }
          .header nav.open ul{ display:flex; flex-direction:column; gap:1rem; list-style:none; margin:0; padding:0; }
        }
        @media (min-width:769px){
          .header nav{ display:flex !important; align-items:center; gap:2rem; }
        }
        
        /* === hero: asegurar que el overlay queda detrás y el texto arriba === */
        .hero{ position:relative; }
        .hero::before{ z-index:0 !important; pointer-events:none; }
        .hero .container, .hero .tagline, .hero h1, .hero p, .hero .cta-button{
          position:relative; z-index:1;
        }
        /* colores del héroe */
        .hero h1{ color:#fff !important; }
        .hero p { color:#f2f4f7 !important; }
        .hero .tagline{ color:#c6e400 !important; }
        
        /* que las anclas no queden tapadas */
        :target{ scroll-margin-top:90px; }

/* Quitar espacio que mete Divi en la primera sección */
.et_pb_section_first,
.et-l--body .et_pb_section:first-child,
.landing-full.et_pb_section,
.landing-full .et_pb_section:first-child{
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* Asegurar que el hero arranca pegado al header */
.header{ margin-bottom: 0 !important; }
.landing-full .hero{ margin-top: 0 !important; padding-top: 0 !important; }

/* Si el admin bar está visible, que no empuje contenido raro */
body.admin-bar .header{ top: 32px; }      /* opcional, solo cuando estás logueado */
:target{ scroll-margin-top: 90px; }       /* compensa altura del header en anclas */


    