/* Filename: style/archive.css
   Description: Styling khusus halaman Archive (List Artikel)
   Dependencies: style.css (Root)
*/

/* ==========================================================================
   1. HERO SECTION (Dark & Bold)
   ========================================================================== */
.archive-hero {
    background-color: var(--surau-dark-bg);
    color: var(--surau-white);
    padding: 120px 0 80px;
    margin-top: -80px; /* Tarik ke atas di belakang header transparan */
    position: relative;
    overflow: hidden;
    text-align: center;
}

.archive-hero-inner {
    position: relative; z-index: 2; max-width: 800px; margin: 0 auto;
}

.hero-bg-pattern {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background-image: radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
    background-size: 30px 30px; opacity: 0.6; pointer-events: none;
}

.archive-subtitle {
    display: block; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 1px;
    margin-bottom: 10px; color: var(--surau-yellow); font-weight: 600;
}

.archive-title {
    font-size: 2.8rem; font-weight: 800; color: var(--surau-white); margin-bottom: 15px;
}

/* Hapus prefix "Category: " bawaan WP jika ada */
.archive-title span { display: none; } 

.archive-description {
    font-size: 1.1rem; color: #94A3B8; max-width: 600px; margin: 0 auto;
}

/* ==========================================================================
   2. LAYOUT GRID (Main + Sidebar)
   ========================================================================== */
.archive-layout-grid {
    display: grid;
    grid-template-columns: 1fr 320px; /* Kiri Lebar, Kanan Fixed */
    gap: 50px;
    margin-top: -60px; /* Overlap Hero */
    position: relative; z-index: 5;
    padding-bottom: 80px;
}

/* ==========================================================================
   3. POSTS GRID (2 Kolom Kartu)
   ========================================================================== */
.surau-posts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 Kolom Artikel */
    gap: 30px;
}

/* CARD DESIGN */
.blog-card-item {
    background: var(--surau-white);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
    overflow: hidden;
    transition: all 0.3s ease;
    border: 1px solid var(--surau-gray-border);
    display: flex; flex-direction: column;
}

.blog-card-item:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-hover);
    border-color: rgba(230,0,2,0.2);
}

/* Thumbnail */
.blog-card-thumb {
    position: relative; display: block; overflow: hidden;
    padding-top: 60%; /* Aspect Ratio Image */
}

.blog-card-thumb img {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    object-fit: cover; transition: transform 0.5s;
}

.blog-card-item:hover .blog-card-thumb img { transform: scale(1.1); }

/* Date Badge */
.blog-date {
    position: absolute; top: 15px; left: 15px;
    background: var(--surau-white);
    padding: 6px 12px; border-radius: 8px;
    text-align: center; line-height: 1;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}
.blog-date .day { display: block; font-size: 1.2rem; font-weight: 800; color: var(--surau-black); }
.blog-date .month { display: block; font-size: 0.75rem; text-transform: uppercase; color: var(--surau-red); font-weight: 600; }

/* Body */
.blog-card-body { padding: 25px; display: flex; flex-direction: column; flex-grow: 1; }

.blog-cat {
    font-size: 0.75rem; text-transform: uppercase; color: #888;
    margin-bottom: 10px; font-weight: 600; letter-spacing: 0.5px;
}

.blog-title {
    font-size: 1.25rem; margin-bottom: 12px; line-height: 1.4;
}
.blog-title a:hover { color: var(--surau-red); }

.blog-excerpt {
    font-size: 0.95rem; color: var(--surau-text-gray);
    margin-bottom: 20px; line-height: 1.6;
}

.read-more-link {
    margin-top: auto; /* Push to bottom */
    font-size: 0.9rem; font-weight: 700; color: var(--surau-red);
    display: flex; align-items: center; gap: 8px;
}
.read-more-link:hover { gap: 12px; }

/* ==========================================================================
   4. PAGINATION
   ========================================================================== */
.surau-pagination { margin-top: 50px; text-align: center; }
.surau-pagination .nav-links { display: flex; justify-content: center; gap: 10px; }

.surau-pagination .page-numbers {
    display: flex; align-items: center; justify-content: center;
    width: 45px; height: 45px;
    border-radius: 50%;
    background: var(--surau-white);
    border: 1px solid var(--surau-gray-border);
    color: var(--surau-black);
    font-weight: 600; transition: 0.2s;
}

.surau-pagination .page-numbers.current,
.surau-pagination .page-numbers:hover {
    background: var(--surau-red);
    color: white; border-color: var(--surau-red);
}

/* ==========================================================================
   5. SIDEBAR (Widget Styles)
   ========================================================================== */
.archive-sidebar { padding-top: 0; }
.sticky-sidebar { position: sticky; top: 100px; }

.widget {
    background: var(--surau-white); padding: 30px;
    border-radius: var(--radius-md); box-shadow: var(--shadow-soft);
    margin-bottom: 30px; border: 1px solid var(--surau-gray-border);
}

.widget-title {
    font-size: 1.1rem; border-bottom: 2px solid var(--surau-gray-light);
    padding-bottom: 10px; margin-bottom: 20px;
}

/* Search Widget */
.widget-search .search-form { position: relative; display: flex; }
.widget-search .search-field {
    width: 100%; padding: 12px 40px 12px 15px;
    border: 1px solid #ddd; border-radius: 50px;
}
.widget-search .search-submit {
    position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
    background: none; border: none; color: #999; cursor: pointer;
}

/* Categories List */
.widget-categories ul li {
    padding: 10px 0; border-bottom: 1px dashed #eee;
    display: flex; justify-content: space-between; font-size: 0.95rem;
}
.widget-categories ul li:last-child { border: none; }
.widget-categories a:hover { color: var(--surau-red); padding-left: 5px; }

/* Banner Widget */
.widget-cta-banner {
    background: var(--surau-dark-bg); color: white; text-align: center;
    position: relative; overflow: hidden; border: none;
}
.widget-cta-banner::before {
    content: ''; position: absolute; top:0; left:0; width:100%; height:100%;
    background: linear-gradient(135deg, rgba(255,255,255,0.1), transparent);
}
.cta-content { position: relative; z-index: 2; }
.cta-content h4 { color: var(--surau-yellow); margin-bottom: 10px; }
.cta-content p { color: #ccc; margin-bottom: 20px; font-size: 0.9rem; }

/* ==========================================================================
   6. RESPONSIVE
   ========================================================================== */
@media (max-width: 992px) {
    .archive-layout-grid { grid-template-columns: 1fr; gap: 40px; } /* Stack */
    .surau-posts-grid { grid-template-columns: 1fr; } /* 1 Kolom di Tablet kecil */
}

@media (max-width: 600px) {
    .archive-title { font-size: 2rem; }
}