/**
 * Template: Archive
 *
 * Layout und Styling fuer die Archivseiten.
 *
 * @package DTVP
 * @since   1.3.0
 */

/* ==========================================================================
   Archive Container
   ========================================================================== */

.archive-page {
    background-color: var(--archive-bg, var(--color-archive-bg, #F3F1EC));
    min-height: 100vh;
}

/* Header auf Archivseiten: kompakter, Texte unten */
.archive-page .subpage-header {
    min-height: calc(24vh + var(--header-h, 110px));
    max-height: calc(24vh + var(--header-h, 110px));
}

.archive-page .subpage-header__inner {
    align-items: flex-end;
    padding-top: var(--space-8);
    padding-bottom: 3vh;
}

/* ==========================================================================
   Card Grid
   ========================================================================== */

.archive-grid {
    width: 100%;
    max-width: var(--container-max, 1280px);
    margin: 0 auto;
    padding: var(--space-16, 4rem) var(--container-padding, 1.5rem) var(--space-24, 6rem);
}

.archive-grid__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-8, 2rem);
    list-style: none;
    margin: 0;
    padding: 0;
}

.archive-grid__item {
    display: flex;
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.archive-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-2, 0.5rem);
    padding-top: var(--space-12, 3rem);
}

.archive-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--space-3, 0.75rem);
    font-family: var(--font-mono, monospace);
    font-size: var(--text-sm, 0.875rem);
    font-weight: 700;
    text-decoration: none;
    color: var(--color-dark, #0d0d0d);
    border-radius: var(--radius-md, 8px);
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.archive-pagination .page-numbers:hover {
    background-color: var(--color-neutral-200, #e5e5e5);
    color: var(--color-dark, #0d0d0d);
}

.archive-pagination .page-numbers.current {
    background-color: var(--color-magenta, #e4006f);
    color: var(--color-white, #ffffff);
}

.archive-pagination .page-numbers.dots {
    pointer-events: none;
    color: var(--color-neutral-300, #d4d4d4);
}

.archive-pagination .page-numbers.prev,
.archive-pagination .page-numbers.next {
    font-weight: 800;
}

/* ==========================================================================
   Empty State
   ========================================================================== */

.archive-empty {
    text-align: center;
    padding: var(--space-24, 6rem) var(--container-padding, 1.5rem);
}

.archive-empty__text {
    font-family: var(--font-body, sans-serif);
    font-size: var(--text-lg, 1.125rem);
    color: var(--color-neutral-700, #404040);
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1024px) {
    .archive-grid__list {
        grid-template-columns: 1fr;
        gap: var(--space-8, 2rem);
    }
}

@media (max-width: 768px) {
    .archive-grid {
        padding: var(--space-10, 2.5rem) var(--container-padding, 1.5rem) var(--space-16, 4rem);
    }

    .archive-grid__list {
        grid-template-columns: 1fr;
        gap: var(--space-8, 2rem);
    }

    .archive-pagination {
        padding-top: var(--space-8, 2rem);
    }
}
