/* Estilos responsive centralizados */

/* Media queries generales */
@media (max-width: 1200px) {
    .container {
        max-width: 960px;
    }
}

@media (max-width: 992px) {
    .container {
        max-width: 720px;
    }
}

@media (max-width: 768px) {
    .container {
        max-width: 540px;
    }
}

@media (max-width: 576px) {
    .container {
        max-width: 100%;
        padding-left: 16px;
        padding-right: 16px;
        box-sizing: border-box;
    }
}

/* Header responsive */
@media (max-width: 992px) {
    .header-container {
        flex-direction: column;
        height: auto;
        padding: 10px 0;
    }

    .nav-menu {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: #fff;
        padding: 1rem;
        box-shadow: 0 4px 12px rgba(0,0,0,0.1);
        flex-direction: column;
        gap: 0;
    }

    .nav-menu.toggled {
        display: flex;
    }

    .nav-menu li {
        width: 100%;
    }

    .nav-menu a {
        padding: 1rem 0;
        border-bottom: 1px solid #eee;
        font-size: 1.1rem;
    }

    .nav-menu .sub-menu {
        position: static;
        box-shadow: none;
        padding-left: 1.5rem;
        display: none;
    }

    .nav-menu .sub-menu.toggled {
        display: block;
    }

    .nav-menu .sub-menu a {
        padding: 0.75rem 0;
        border-bottom: none;
    }

    .menu-toggle {
        display: block;
    }
}

/* Grid responsive */
@media (max-width: 992px) {
    .post-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 576px) {
    .post-grid {
        grid-template-columns: 1fr;
        padding: 1rem;
    }

    .product-text h2 {
        font-size: 1.125rem;
    }
}

/* Footer responsive */
@media (max-width: 768px) {
    .footer-widget {
        flex-direction: column;
        gap: 1.2rem;
        align-items: center;
    }

    .footer-menu {
        flex-direction: column;
        gap: 0.7rem;
        align-items: center;
    }

    .social-menu {
        gap: 0.7rem;
    }
}

/* Slider responsive */
@media (max-width: 992px) {
    .slider-content h2 {
        font-size: 1.5rem;
    }
}

@media (max-width: 576px) {
    .featured-slider {
        padding: 3rem 0 1.5rem;
    }
    
    .slider-content h2 {
        font-size: 1.25rem;
    }
}

/* Botones responsive */
@media (max-width: 576px) {
    .btn {
        width: 100%;
        margin-bottom: 10px;
    }
}

/* Ajustes adicionales para mobile */
@media (max-width: 576px) {
    body {
        font-size: 14px;
    }
    h1 {
        font-size: 24px;
    }
    h2 {
        font-size: 20px;
    }
    h3 {
        font-size: 18px;
    }
}

/* Breadcrumbs responsive */
@media (max-width: 576px) {
    .breadcrumbs {
        font-size: 0.875rem;
    }
}

/* Ajustes específicos para móviles pequeños */
@media only screen and (max-width: 375px) {
    .product-banner {
        margin-bottom: 0px;
    }
    .product-container .product-content {
        margin-bottom: 20px;
    }
    .antevenio {
        margin-top: 32%;
    }
    #wrap {
        margin: 9% auto;
    }
    .cd-main-content {
        margin-top: 22%;
    }
    .product-banner {
        margin-top: -7%;
    }
    .nav-is-fixed .cd-main-header {
        margin-bottom: 3%;
    }
    .owl-prev, .owl-next {
        top: 33%;
    }
    
    .owl-carousel .owl-item .item .lazy {
        width: 100%;
        height: 320px;
    }
    .antevenio {
        margin-top: 2%;
    }
    #detail-pictures {
        margin-bottom: -5%;
    }

    .cd-form div + .enviar {
        bottom: 0%;
    }
    .container {
        margin-top: 22%;
    }
}

/* Responsive Adjustments */
@media (max-width: 768px) {
    .articles-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: 1rem;
    }
} 


/* Responsive */
@media (max-width: 768px) {
    .nav-menu {
        display: none;
    }
    
    .mobile-menu-toggle {
        display: block;
    }
    
    .articles-grid {
        grid-template-columns: 1fr;
    }
}


/* Padding lateral para header en mobile */
@media (max-width: 576px) {
    .header-container {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding-left: 16px;
        padding-right: 16px;
        height: 60px;
    }
    .site-branding {
        order: 1;
        flex: 1 1 auto;
        display: flex;
        align-items: center;
        justify-content: flex-start;
    }
    .menu-toggle {
        order: 2;
        display: block;
        background: none;
        border: none;
        font-size: 2rem;
        cursor: pointer;
        margin-left: auto;
        position: absolute;
        top: 12px;
        right: 18px;
        z-index: 10001;
    }
    .main-navigation {
        order: 3;
    }
}

/* Padding lateral para el grid de artículos en mobile */
@media (max-width: 576px) {
    .articles-grid,
    .post-grid {
        padding-left: 16px;
        padding-right: 16px;
    }
    .article-card,
    .product-box {
        margin-left: 0;
        margin-right: 0;
    }
}

/* --- MENÚ MOBILE BONITO Y LIMPIO --- */
@media (max-width: 576px) {
    .nav-menu,
    .nav-menu ul,
    .nav-menu li,
    .nav-menu a {
        background: none !important;
        box-shadow: none !important;
        height: auto !important;
        min-height: unset !important;
        max-height: unset !important;       
        align-items: unset !important;
        justify-content: unset !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    .nav-menu {
        padding: 0.5rem 0 0.5rem 0;
        border-radius: 0 0 16px 16px;
        z-index: 9999;
        flex-direction: column;
        gap: 0;
        display: none;
        animation: fadeInDown 0.3s;
        width: 100vw;
        left: 0;
        right: 0;
        top: 60px;
        position: fixed;
        box-shadow: 0 8px 24px rgba(0,0,0,0.08);
        background: #fff !important;
    }
    .nav-menu.toggled {
        display: block;
    }
    .nav-menu li {
        border-bottom: 1px solid #ececec;
    }
    .nav-menu li:last-child {
        border-bottom: none;
    }
    .nav-menu a {
        padding: 0.85rem 20px !important;
        font-size: 1.08rem;
        font-weight: 500;
        color: #222 !important;
        border-radius: 0;
        line-height: 1.2;
        transition: background 0.18s, color 0.18s;
        text-align: left;
        width: 100%;
    }
    .nav-menu a:hover,
    .nav-menu .current-menu-item > a {
        background: #e0f7fa !important;
        color: #00bcd4 !important;
    }
}

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

@media (max-width: 576px) {
    /* Box-sizing global para respetar paddings */
    *, *::before, *::after {
        box-sizing: border-box !important;
    }
    /* Cards y slider: ancho y padding simétrico */
    .product-box,
    .article-card,
    .slider-container,
    .slider-item {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        padding-left: 16px;
        padding-right: 16px;
        margin-left: 0 !important;
        margin-right: 0 !important;
        border: 1px solid #e9ecef;
        border-radius: 16px;
        box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    }
    /* Imágenes internas siempre adaptables */
    .product-box img,
    .article-card img,
    .slider-container img,
    .slider-item img {
        max-width: 100% !important;
        height: auto !important;
        display: block;
        margin: 0 auto;
    }
	.product {
		width: 100%;
	}
    
    /* Cards y product-box: sin anchos fijos heredados */
    .product-box,
    .product-img,
    .product {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
} 