/*
* domain.com - Estilos responsivos
* 
* Estilos responsivos para el sitio web de auditoría financiera domain.com
* Utilizando un enfoque mobile-first
*/

/* Dispositivos pequeños (teléfonos móviles, menos de 768px) */
/* Los estilos base ya están definidos en style.css */

/* Ocultar menú principal y mostrar menú móvil en dispositivos pequeños */
@media (max-width: 767px) {
    .main-nav {
        display: none;
    }
    
    .mobile-menu-container {
        display: block;
    }
    
    h1 {
        font-size: 2rem;
    }
    
    h2 {
        font-size: 1.8rem;
    }
    
    h3 {
        font-size: 1.3rem;
    }
    
    section {
        padding: 60px 0;
    }
    
    /* Grid layouts para móvil */
    .benefits-grid,
    .services-grid,
    .portfolio-grid,
    .testimonials-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .footer-content {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    
    .hero-section {
        padding: 80px 0;
    }
    
    .hero-section h1 {
        font-size: 2.2rem;
    }
    
    /* Ajustes adicionales para móvil */
    .benefit-item,
    .service-item,
    .portfolio-item,
    .testimonial-item {
        padding: 20px;
    }
    
    .form-container {
        padding: 25px;
    }
    
    .map-placeholder {
        height: 300px;
    }
    
    .cookie-popup {
        flex-direction: column;
    }
    
    .cookie-popup p {
        margin: 0 0 15px 0;
    }
}

/* Dispositivos medianos (tablets, 768px y superior) */
@media (min-width: 768px) and (max-width: 1023px) {
    .main-nav {
        display: none;
    }
    
    .mobile-menu-container {
        display: block;
    }
    
    h1 {
        font-size: 2.2rem;
    }
    
    h2 {
        font-size: 1.9rem;
    }
    
    /* Grid layouts para tablet */
    .benefits-grid,
    .services-grid,
    .portfolio-grid,
    .testimonials-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 25px;
    }
    
    .footer-content {
        grid-template-columns: repeat(2, 1fr);
        gap: 30px;
    }
    
    .footer-column:nth-child(1) {
        grid-column: span 2;
    }
}

/* Dispositivos grandes (escritorios, 1024px y superior) */
@media (min-width: 1024px) {
    .mobile-menu-container {
        display: none;
    }
    
    .main-nav {
        display: block;
    }
    
    /* Aquí los layouts ya están bien definidos en el CSS base */
}

/* Dispositivos extra grandes (escritorios grandes, 1440px y superior) */
@media (min-width: 1440px) {
    .container {
        max-width: 1320px;
    }
    
    h1 {
        font-size: 3.2rem;
    }
    
    h2 {
        font-size: 2.5rem;
    }
    
    h3 {
        font-size: 1.8rem;
    }
    
    .hero-section {
        padding: 120px 0;
    }
}

/* Específicos para impresión */
@media print {
    .site-header,
    .cookie-popup,
    .form-container,
    .map-container,
    .site-footer {
        display: none;
    }
    
    body {
        color: #000;
        background: #fff;
        font-size: 12pt;
    }
    
    a {
        color: #000;
        text-decoration: underline;
    }
    
    h1 {
        font-size: 18pt;
    }
    
    h2 {
        font-size: 16pt;
    }
    
    h3 {
        font-size: 14pt;
    }
    
    .container {
        width: 100%;
        max-width: none;
        padding: 0;
    }
}

/* Soportes para alto contraste y otras características de accesibilidad */
@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }
    
    .fade-in {
        opacity: 1;
        transform: none;
        transition: none;
    }
    
    /* Deshabilitar todas las animaciones */
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

@media (prefers-color-scheme: dark) {
    /* Soporte para modo oscuro si el navegador lo prefiere */
    /* Esto es opcional y se incluye como mejora de accesibilidad */
    body {
        background-color: #121212;
        color: #f5f5f5;
    }
    
    .benefit-item, 
    .testimonial-item, 
    .portfolio-item, 
    .form-container, 
    .policy-content, 
    .policy-box {
        background-color: #222;
    }
    
    .service-item, 
    .map-placeholder, 
    .address-info {
        background-color: #333;
    }
}
