/**
 * Blog Archive - Layout específico
 * 
 * Las cards están en: design-system/_cards.css
 * Los badges están en: design-system/_badges.css
 * 
 * @package Xacobeos
 * @version 2.0.0
 */

/*--------------------------------------------------------------
# Main Container
--------------------------------------------------------------*/
.blog-archive-main {
    background: var(--xacobeos-white);
    min-height: 60vh;
}

.blog-archive-main .container {
    max-width: 1300px;
    padding: var(--xacobeos-space-8) var(--xacobeos-space-6);
}

/*--------------------------------------------------------------
# Header Hero
--------------------------------------------------------------*/
.blog-archive-header {
    text-align: center;
    padding: var(--xacobeos-space-12) 0 var(--xacobeos-space-16) 0;
    max-width: 800px;
    margin: 0 auto;
}

.archive-category-badge {
    display: inline-block;
    background: var(--xacobeos-blue-100);
    color: var(--xacobeos-blue-700);
    padding: var(--xacobeos-space-2) var(--xacobeos-space-4);
    border-radius: var(--xacobeos-radius-full);
    font-size: var(--xacobeos-text-sm);
    font-weight: var(--xacobeos-font-bold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--xacobeos-space-6);
}

.archive-title {
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: var(--xacobeos-font-extrabold);
    color: var(--xacobeos-gray-900);
    margin: 0 0 var(--xacobeos-space-4) 0;
    line-height: var(--line-height-tight);
}

.archive-description {
    font-size: var(--xacobeos-text-lg);
    color: var(--xacobeos-gray-600);
    line-height: var(--xacobeos-leading-relaxed);
    max-width: 600px;
    margin: 0 auto;
}

/*--------------------------------------------------------------
# Pagination
--------------------------------------------------------------*/
.blog-pagination {
    margin: var(--xacobeos-space-16) 0 var(--xacobeos-space-8) 0;
    display: flex;
    justify-content: center;
}

.blog-pagination ul {
    display: flex;
    align-items: center;
    gap: var(--xacobeos-space-2);
    list-style: none;
    padding: 0;
    margin: 0;
}

.blog-pagination li {
    margin: 0;
}

.blog-pagination a,
.blog-pagination span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 var(--xacobeos-space-4);
    border: 2px solid var(--xacobeos-gray-200);
    border-radius: var(--xacobeos-radius-md);
    background: var(--xacobeos-white);
    color: var(--xacobeos-gray-700);
    font-weight: var(--xacobeos-font-semibold);
    transition: all var(--xacobeos-transition-base) var(--xacobeos-ease-out);
    text-decoration: none !important;
}

.blog-pagination a:hover {
    border-color: var(--xacobeos-blue-600);
    color: var(--xacobeos-blue-600);
    background: var(--xacobeos-blue-50);
}

.blog-pagination .current {
    background: var(--xacobeos-blue-600);
    color: var(--xacobeos-white);
    border-color: var(--xacobeos-blue-600);
}

/* Ocultar los puntos (dots) */
.blog-pagination .dots {
    display: none !important;
}

.blog-pagination .prev,
.blog-pagination .next {
    gap: var(--xacobeos-space-2);
}

.blog-pagination svg {
    width: 16px;
    height: 16px;
}

/*--------------------------------------------------------------
# Empty State
--------------------------------------------------------------*/
.no-posts {
    text-align: center;
    padding: var(--xacobeos-space-20) var(--xacobeos-space-8);
    background: var(--xacobeos-gray-50);
    border-radius: var(--xacobeos-radius-2xl);
    border: 2px dashed var(--xacobeos-gray-300);
}

.no-posts svg {
    color: var(--xacobeos-gray-400);
    margin-bottom: var(--xacobeos-space-6);
}

.no-posts h2 {
    font-size: var(--xacobeos-text-2xl);
    font-weight: var(--xacobeos-font-bold);
    color: var(--xacobeos-gray-900);
    margin: 0 0 var(--xacobeos-space-3) 0;
}

.no-posts p {
    font-size: var(--xacobeos-text-base);
    color: var(--xacobeos-gray-600);
    max-width: 500px;
    margin: 0 auto;
}

/*--------------------------------------------------------------
# Responsive
--------------------------------------------------------------*/
@media (max-width: 768px) {
    .blog-archive-header {
        padding: var(--xacobeos-space-8) 0 var(--xacobeos-space-12) 0;
    }
    
    .archive-title {
        font-size: 2rem;
    }
    
    .archive-description {
        font-size: var(--xacobeos-text-base);
    }
}

@media (max-width: 480px) {
    .blog-pagination ul {
        flex-wrap: wrap;
    }
    
    .blog-pagination a,
    .blog-pagination span {
        min-width: 40px;
        height: 40px;
        padding: 0 var(--xacobeos-space-3);
        font-size: var(--xacobeos-text-sm);
    }
}

/* 
 * NOTA: Estilos de .post-card y .blog-card-modern están en:
 * /css/design-system/_cards.css
 */
