/* === RESPONSIVE DESIGN === */

/* Pantallas grandes (Desktop) */
@media (min-width: 1200px) {
    .container {
        padding: 0 var(--spacing-lg);
    }
    
    .hero h1 {
        font-size: 3.2rem;
    }
    
    .hero h2 {
        font-size: 1.8rem;
    }
}

/* Pantallas medianas (Desktop pequeño/Laptop) */
@media (min-width: 992px) and (max-width: 1199px) {
    .container {
        padding: 0 var(--spacing-md);
    }
    
    .hero h1 {
        font-size: 2.8rem;
    }
    
    .hero h2 {
        font-size: 1.6rem;
    }
    
    section {
        padding: var(--spacing-lg) 0;
    }
}

/* Pantallas medianas (Tablet) */
@media (min-width: 768px) and (max-width: 991px) {
    .container {
        padding: 0 var(--spacing-md);
    }
    
    .hero h1 {
        font-size: 2.5rem;
    }
    
    .hero h2 {
        font-size: 1.4rem;
    }
    
    section {
        padding: var(--spacing-md) 0;
    }
    
    .service-card {
        min-width: 250px;
    }
    
    .service-card p {
        min-height: 120px;
    }
    
    .advantage-item, .benefit-item {
        padding: var(--spacing-sm);
    }
}

/* Pantallas pequeñas (Móvil) */
@media (max-width: 767px) {
    html {
        font-size: 15px;
    }
    
    .container {
        padding: 0 var(--spacing-sm);
    }
    
    section {
        padding: var(--spacing-md) 0;
    }
    
    .hero {
        padding: calc(60px + var(--spacing-lg)) 0 var(--spacing-lg);
    }
    
    .hero h1 {
        font-size: 2rem;
    }
    
    .hero h2 {
        font-size: 1.2rem;
        margin-bottom: var(--spacing-md);
    }
    
    /* Menú móvil */
    .menu-icon {
        display: block;
    }
    
    .menu {
        position: fixed;
        top: 60px;
        left: -100%;
        width: 80%;
        height: 100vh;
        background: var(--color-white);
        flex-direction: column;
        align-items: flex-start;
        padding: var(--spacing-md);
        box-shadow: var(--shadow-lg);
        transition: left var(--transition-speed) var(--transition-func);
        z-index: 999;
    }
    
    .menu-toggle:checked ~ .menu {
        left: 0;
    }
    
    .menu li {
        margin: var(--spacing-xs) 0;
        width: 100%;
    }
    
    .menu a {
        display: block;
        padding: var(--spacing-xs) 0;
    }
    
    .menu-toggle:checked ~ .menu-icon span:nth-child(1) {
        top: 8px;
        transform: rotate(135deg);
    }
    
    .menu-toggle:checked ~ .menu-icon span:nth-child(2) {
        opacity: 0;
        left: -60px;
    }
    
    .menu-toggle:checked ~ .menu-icon span:nth-child(3) {
        top: 8px;
        transform: rotate(-135deg);
    }
    
    /* Ajustes de layout */
    .advantages, .service-cards {
        flex-direction: column;
    }
    
    .advantage-item, .service-card {
        width: 100%;
        margin-bottom: var(--spacing-md);
    }
    
    .service-card p {
        min-height: auto;
    }
    
    .benefits-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
    }
    
    .benefit-item {
        margin-bottom: var(--spacing-sm);
    }
    
    /* Formulario */
    .form-group {
        margin-bottom: var(--spacing-sm);
    }
    
    /* Footer */
    .footer-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
        text-align: center;
    }
    
    /* Botones */
    .buttons {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .btn-large {
        padding: var(--spacing-sm) var(--spacing-md);
    }
    
    /* Cookie popup */
    .cookie-content {
        flex-direction: column;
        text-align: center;
    }
    
    .cookie-content p {
        margin-right: 0;
    }
}

/* Móvil pequeño */
@media (max-width: 375px) {
    html {
        font-size: 14px;
    }
    
    .hero h1 {
        font-size: 1.8rem;
    }
    
    .hero h2 {
        font-size: 1.1rem;
    }
    
    .policy-content {
        padding: var(--spacing-md);
    }
}
