/* =========================================
   ONLINE SACRED YAGYAS STYLES
   ========================================= */

/* Hero Section Override (Placeholder Image) */
/* Hero Section Override (Placeholder Image) */
.yagya-page-hero {
    background: url('/wp-content/uploads/2025/12/yagyas.webp') no-repeat center center fixed !important;
    background-color: #1a1a1a;
    /* Fallback dark */
    background-size: cover !important;
}

.yagya-page-hero .sub-heading {
    display: inline-block;
    color: var(--gold-accent, #C9A24D);
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 2px;
    margin-bottom: 15px;
    text-transform: uppercase;
    background: rgba(0, 0, 0, 0.3);
    padding: 5px 15px;
    border-radius: 50px;
    border: 1px solid rgba(201, 162, 77, 0.3);
}

.sacred-yagyas-container {
    background-color: transparent;
    /* Inherit site background (cream/pattern) */
    padding-bottom: 80px;
}

/* =========================================
   YAJNA SERVICES SLIDER
   ========================================= */
.yajna-services-section {
    padding: 60px 0;
    /* Ensure no white background here */
    background: transparent;
}

.yajna-services-slider {
    padding: 20px 10px 60px !important;
    /* Bottom padding for pagination */
}

.yajna-service-card {
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
    overflow: hidden;
    transition: transform 0.3s ease;
    height: 100%;
    border: 1px solid rgba(0, 0, 0, 0.02);
}

.yajna-service-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08);
}

.yajna-image-placeholder {
    width: 100%;
    aspect-ratio: 4/3;
    background-color: #f0f0f0;
}

.yajna-card-content {
    padding: 25px;
    text-align: center;
}

.yajna-card-content h3 {
    font-family: var(--font-heading, "Cinzel", serif);
    color: var(--primary-green, #1B4D3E);
    font-size: 1.3rem;
    margin-bottom: 10px;
    font-weight: 700;
}

.yajna-desc {
    font-size: 0.95rem;
    color: #666;
    margin-bottom: 20px;
}

.yajna-btn {
    display: inline-block;
    background: var(--primary-green, #1B4D3E);
    color: #fff;
    padding: 10px 25px;
    border-radius: 50px;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 600;
    transition: all 0.3s ease;
    text-transform: uppercase;
}

.yajna-btn:hover {
    background: var(--gold-accent, #C9A24D);
    color: var(--primary-green, #1B4D3E);
    box-shadow: 0 5px 15px rgba(201, 162, 77, 0.3);
}

/* Swiper Controls */
.swiper-button-next,
.swiper-button-prev {
    color: var(--primary-green, #1B4D3E) !important;
    background: #fff;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50%;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.swiper-button-next:after,
.swiper-button-prev:after {
    font-size: 1.2rem !important;
}

.swiper-pagination-bullet-active {
    background: var(--primary-green, #1B4D3E) !important;
}

/* =========================================
   UPCOMING YAGYAS & HOMAS
   ========================================= */
.upcoming-yagyas-section {
    padding: 60px 0;
}

.upcoming-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
    flex-wrap: wrap;
    gap: 20px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    padding-bottom: 20px;
}

.upcoming-toggle-col {
    background: #fff;
    padding: 5px;
    border-radius: 50px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.toggle-btn {
    background: transparent;
    border: none;
    padding: 10px 25px;
    border-radius: 50px;
    font-size: 0.95rem;
    font-weight: 600;
    color: #777;
    cursor: pointer;
    transition: all 0.3s ease;
}

.toggle-btn.active {
    background: var(--primary-green, #1B4D3E);
    color: #fff;
    box-shadow: 0 4px 10px rgba(27, 77, 62, 0.2);
}

.month-title {
    font-family: var(--font-heading, "Cinzel", serif);
    font-size: 1.8rem;
    color: var(--primary-green, #1B4D3E);
    margin-bottom: 30px;
    border-left: 4px solid var(--gold-accent, #C9A24D);
    padding-left: 15px;
    display: flex;
    flex-direction: column;
}

.month-subtitle {
    font-family: var(--font-body, "Outfit", sans-serif);
    font-size: 1rem;
    color: #777;
    margin-top: 5px;
    font-weight: 400;
}

.yagya-events-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
}

.yagya-event-card {
    background: linear-gradient(135deg, #1B4D3E 0%, #0F3D2E 100%);
    border-radius: 20px;
    padding: 30px;
    color: #fff;
    position: relative;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(27, 77, 62, 0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    cursor: pointer;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.yagya-event-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px rgba(27, 77, 62, 0.25);
}

.event-badge {
    position: absolute;
    top: 20px;
    right: 20px;
    background: var(--gold-accent, #C9A24D);
    color: var(--primary-green, #1B4D3E);
    font-size: 0.75rem;
    font-weight: 700;
    padding: 5px 12px;
    border-radius: 50px;
    text-transform: uppercase;
}

.yagya-event-card h3 {
    font-family: var(--font-heading, "Cinzel", serif);
    font-size: 1.6rem;
    margin-bottom: 15px;
    margin-top: 20px;
    color: #fff;
}

.event-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.95rem;
    opacity: 0.9;
    margin-bottom: 25px;
    font-weight: 500;
}

.event-meta i {
    color: var(--gold-accent, #C9A24D);
}

.event-btn {
    display: inline-block;
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #fff;
    padding: 8px 20px;
    border-radius: 50px;
    font-size: 0.85rem;
    text-decoration: none;
    transition: all 0.3s ease;
}

.yagya-event-card:hover .event-btn {
    background: #fff;
    color: var(--primary-green, #1B4D3E);
    border-color: #fff;
}

/* Responsive */
@media (max-width: 992px) {
    .yagya-events-grid {
        grid-template-columns: 1fr;
    }

    .yajna-services-slider {
        padding: 0 20px 50px !important;
    }
}

@media (max-width: 768px) {
    .upcoming-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .upcoming-toggle-col {
        width: 100%;
        display: flex;
        justify-content: space-between;
    }

    .toggle-btn {
        flex: 1;
        text-align: center;
    }
}

/* =========================================
   DESKTOP REFINEMENTS (>= 1024px)
   ========================================= */
@media (min-width: 1024px) {

    /* 1. Vertical Spacing: Extra top spacing for section */
    .yajna-services-section {
        padding-top: 90px;
    }

    /* 2. Heading Block Positioning & Rhythm */
    .yajna-services-section .text-center {
        margin-top: 30px;
        /* Move block downward */
        margin-bottom: 70px !important;
        /* Move cards away from heading */
        max-width: 800px;
        margin-left: auto;
        margin-right: auto;
    }

    /* 3. Heading Spacing */
    .yajna-services-section .section-title {
        margin-bottom: 25px !important;
    }

    /* 4. Divider Spacing */
    .yajna-services-section .section-divider-center {
        margin-top: 0;
        margin-bottom: 25px !important;
    }

    /* 5. Description Styling */
    .yajna-services-section .section-subtitle {
        line-height: 1.8;
        font-size: 1.1rem;
    }
}