/* === ARCHIVE LAYOUT (BEM: .archive-layout) === */
/* Renamed from .archive to prevent conflict with body.archive */
.archive-layout {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 120px 20px 80px;
    /* Anti-FOUC: hidden until .is-ready */
    opacity: 0;
    transform: translateY(10px);
    transition: opacity var(--duration-reveal) ease-out, transform var(--duration-reveal) ease-out;
    position: relative;
    min-height: 60vh;
    z-index: var(--z-level-1);
}

/* Reveal state: triggered by router.js adding .is-ready */
.archive-layout.is-ready {
    opacity: 1;
    transform: translateY(0);
}

/* === HEADER === */
/* Pattern: Aligned with .poems-index */
.archive-layout__header {
    text-align: center;
    margin-bottom: 60px;
    padding: 0;
    background: transparent;
    border: none;
    backdrop-filter: none;
}

.archive-layout__title {
    font-family: var(--font-main);
    font-size: clamp(1.25rem, 2.5vw, 2rem);
    color: var(--c-text);
    margin-bottom: 20px;
    margin-top: 20px;
    text-shadow: 0 0 30px var(--c-accent-30);
    text-transform: none;
    letter-spacing: normal;
}

.archive-layout__description {
    max-width: 700px;
    margin: 0 auto;
    color: var(--c-text-dim);
    font-size: 1.1rem;
    line-height: 1.8;
    font-style: normal;
    opacity: 1;
}

/* === GRID / LIST === */
.archive-layout__grid {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

/* === ARCHIVE ITEM (Card in BEM) === */
.archive-layout__grid .card {
    position: relative;
    padding: 25px 30px;
    transition: transform var(--trans-fast), background var(--trans-fast);
    /* Glass Effect */
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-md);
    /* Center the card within the wide layout to match Backup look */
    max-width: 800px;
    margin: 0 auto;
    width: 100%;
}

.archive-layout__grid .card:hover {
    transform: translateY(-5px);
    background: var(--c-white-05);
    border-color: var(--c-accent-30);
}

/* Entry Header */
.archive-layout__grid .card__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--c-white-10);
    padding: 0 0 15px 0;
    margin-bottom: 15px;
    flex-wrap: wrap;
    gap: 15px;
}

.archive-layout__grid .card__title {
    margin: 0;
    font-size: 1.6rem;
    font-family: var(--font-main);
    letter-spacing: 1px;
    line-height: 1.2;
    color: var(--c-text);
}

.archive-layout__grid .card__title a {
    text-decoration: none;
    color: var(--c-text);
    transition: color var(--trans-fast), text-shadow var(--trans-fast);
}

.archive-layout__grid .card__title a:hover,
.archive-layout__grid .card__title a:focus-visible {
    color: var(--c-text);
    text-shadow: 0 0 10px var(--c-white-60);
}

/* Date & Link */
.archive-layout__grid .card__date {
    font-size: 0.95rem;
    opacity: 0.6;
    font-family: var(--font-sans);
    color: var(--c-text-muted);
    font-style: italic;
}

.archive-layout__grid .card__date a {
    color: inherit;
    text-decoration: none;
    transition: color var(--trans-fast);
}

.archive-layout__grid .card__date a:hover {
    color: var(--c-text);
    opacity: 1;
    text-decoration: none;
    text-shadow: 0 0 8px var(--c-white-60);
}

/* Summary / Content */
.archive-layout__grid .card__content {
    font-style: italic;
    opacity: 0.9;
    margin-bottom: 20px;
    line-height: 1.6;
    color: var(--c-text-dim);
    font-size: 1.05rem;
    padding: 0;
    max-height: none;
    overflow: visible;
    max-width: 800px;
    margin: 0 auto 20px;
}

/* Footer & Button */
.archive-layout__grid .card__footer {
    text-align: right;
    margin-top: 10px;
    padding: 0;
}

.archive-layout__grid .action-btn {
    display: inline-block;
    padding: 8px 25px;
    border: 1px solid var(--c-white-20);
    border-radius: var(--radius-full);
    color: var(--c-text);
    text-decoration: none;
    font-size: 0.9rem;
    font-family: var(--font-sans);
    transition: background-color var(--trans-fast), border-color var(--trans-fast), transform var(--trans-fast);
    background: transparent;
}

.archive-layout__grid .action-btn:hover,
.archive-layout__grid .action-btn:focus-visible {
    background: var(--c-white-10);
    border-color: var(--c-white-40);
    transform: translateX(5px);
}

/* Pagination */
.pagination-wrapper {
    display: flex;
    justify-content: center;
    margin-top: 50px;
    margin-bottom: 40px;
}

.pagination {
    display: flex;
    gap: 10px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.pagination a,
.pagination span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid var(--c-white-20);
    border-radius: 50%;
    color: var(--c-text);
    text-decoration: none;
    transition: color var(--trans-fast), border-color var(--trans-fast), background-color var(--trans-fast);
    background: var(--glass-bg);
}

.pagination a:hover,
.pagination a:focus-visible,
.pagination span.current {
    background: var(--c-accent);
    border-color: var(--c-accent);
    color: var(--c-text);
    box-shadow: 0 0 15px var(--c-accent-60);
}

/* Responsive */
@media (max-width: 768px) {
    .archive-layout {
        width: 95%;
        padding: 100px 10px 60px;
        margin: 0 auto;
    }

    .archive-layout__header {
        margin-bottom: 30px;
    }

    .archive-layout__grid {
        gap: 20px;
        margin-top: 20px;
    }

    .archive-layout__grid .card {
        padding: 20px;
    }

    .archive-layout__grid .card__header {
        flex-direction: column;
        align-items: flex-start;
        gap: 5px;
    }

    .archive-layout__grid .card__date {
        font-size: 0.8rem;
    }


}