/* ================================================
   11. アーカイブページ専用スタイル
   ================================================ */

/* ========== アーカイブページのページネーション ========== */
.archive-grid-wrapper + .container .pagination .pagination-dots {
    padding: var(--spacing-8) var(--spacing-4);
    color: var(--color-secondary);
    font-size: var(--font-size-s);
    align-self: center;
}

.archive-grid-wrapper + .container .pagination .current {
    pointer-events: none;
}


/* ========== 月別アーカイブ選択 ========== */
.month-archive-selector {
    max-width: 300px;
    margin: 0 auto;
}

.month-dropdown {
    width: 100%;
    padding: var(--spacing-16);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius);
    background: var(--color-white);
    color: var(--color-black);
    font-size: var(--font-size-m);
    cursor: pointer;
    appearance: none;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="%23666" d="M6 8L2 4h8z"/></svg>');
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 12px;
    padding-right: 40px;
}

.month-dropdown:hover {
    border-color: var(--color-purple);
}

.month-dropdown:focus {
    outline: none;
    border-color: var(--color-purple);
    box-shadow: 0 0 0 2px rgba(56, 17, 91, 0.1);
}

/* ========== アーカイブページヒーロー ========== */
.archive-hero-section {
    background: var(--color-bg-section);
    padding: var(--spacing-32) 0;
    border-bottom: 1px solid var(--color-border);
}

.archive-hero-content {
    max-width: 800px;
    margin: 0 auto;
}

.archive-title {
    font-size: var(--font-size-title);
    font-weight: 600;
    color: var(--color-black);
    margin-bottom: var(--spacing-24);
    line-height: var(--line-height-limited);
}

/* ========== カテゴリフィルタートグル ========== */
.category-filter-toggle {
    display: flex;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
    margin: var(--spacing-24) auto;
    width: fit-content;
}

/* カテゴリフィルタボタンのスタイル（.btn拡張版） */
.filter-btn.active {
    background: var(--color-black);
    color: var(--color-white);
    border-color: var(--color-black);
    box-shadow: var(--elevation-2);
}

.filter-btn.active:hover {
    background: var(--color-black);
    color: var(--color-white);
    border-color: var(--color-black);
}

/* ========== アーカイブグリッド ========== */
.archive-content {
    padding-top: var(--spacing-48);
    padding-bottom: 0;
    margin: 0;
    width: 100%;
    box-sizing: border-box;
}

.jiji-archive .archive-grid-wrapper {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 var(--spacing-16);
    box-sizing: border-box;
}

.archive-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    margin: 0 0 var(--spacing-32) 0;
    width: 100%;
    box-sizing: border-box;
}

.archive-card-wrapper {
    border-right: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    box-sizing: border-box;
    min-width: 0;
    overflow: hidden;
}

.archive-card-wrapper:nth-child(3n) {
    border-right: none;
}

/* ========== アーカイブページレスポンシブ対応 ========== */
@media (max-width: 768px) {
    .archive-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .archive-card-wrapper:nth-child(3n) {
        border-right: 1px solid var(--color-border);
    }
    
    .archive-card-wrapper:nth-child(2n) {
        border-right: none;
    }
    
    .category-filter-toggle {
        gap: var(--spacing-4);
    }
    
    /* スマホ版アーカイブコンテンツパディング調整 */
    .archive-content {
        padding-top: var(--spacing-32);
        padding-bottom: 0;
    }
    
    .filter-btn {
        padding: 6px 10px;
        font-size: var(--font-size-ss);
    }
}

@media (max-width: 480px) {
    .archive-grid {
        grid-template-columns: 1fr;
    }
    
    .archive-card-wrapper {
        border-right: none !important;
        border-bottom: 1px solid var(--color-border);
    }
    
    .archive-card-wrapper:nth-child(2n),
    .archive-card-wrapper:nth-child(3n) {
        border-right: none !important;
    }
}