/**
 * =================================================================
 * COMPONENT: Sidebar (Refactored Version)
 * File: component.sidebar.css
 * =================================================================
 */

/* =================================================================
   1. Main Sidebar Layout (Sticky Footer)
   ================================================================= */
#sidebar-scroll-area {
    display: flex !important;
    flex-direction: column;
    position: sticky;
    top: var(--sticky-top-offset); /* Controlled globally by style.css */
    height: calc(100vh - var(--sticky-top-offset)); /* Controlled globally by style.css */
    overflow: hidden;
    background-color: var(--color-white-soft);
}

.sidebar-scrollable-content {
    flex: 1;
    min-height: 0;
    padding: 0 1rem;
    overflow-y: scroll;
    scrollbar-color: var(--color-gray-dark) var(--color-white-warm);
    scrollbar-width: thin;
    background-color: var(--color-white-soft);
}

.sidebar-footer {
    padding: 1rem;
    flex-shrink: 0;
    text-align: center;
    border-top: 1px solid var(--color-white-warm);
    border-left: 9.5px solid var(--color-white-warm);
}

/* =================================================================
   2. Accordion & General Styles
   ================================================================= */
.filter {
    font-size: 0.875rem;
    font-weight: bold;
    color: var(--color-black-soft);
}

.border-side-menu {
    overflow: hidden;
    border-top: 0;
    border-radius: 0 0 4px 4px;
}

.custom-accordion {
    --bs-accordion-border-radius: 0;
}

.custom-accordion .accordion-item {
    border: none;
    border-top: 1px solid var(--color-white-warm);
    background-color: var(--color-white-soft);
}

.custom-accordion .accordion-button {
    padding-right: 0.75rem;
    font-family: 'IRANSans', sans-serif;
    font-size: 0.875rem;
    font-weight: bold;
    color: var(--color-black-soft);
    background-color: transparent;
    border-radius: 0 !important;
    box-shadow: none;
    transition: background-color 0.2s ease;
}

.custom-accordion .accordion-button:hover {
    color: var(--color-black-soft);
    /* background-color: var(--color-white-warm); */
}

.custom-accordion .accordion-button:not(.collapsed) {
    color: var(--color-black-soft);
    background-color: transparent;
    box-shadow: none;
}

.custom-accordion .accordion-button:focus {
    border-color: transparent;
    outline: 0;
    box-shadow: none;
}

/* =================================================================
   3. Checkbox & Form Styles
   ================================================================= */
.custom-accordion .form-check {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.75rem;
    padding: 7px 9px;
    font-size: 15px;
    /* font-weight: 500; */
    color: var(--color-black-soft);
    direction: rtl;
}

.custom-accordion .form-check .form-check-input {
    order: 1;
    width: 20px;
    height: 20px;
    margin: 0;
    border-color: var(--color-gray-mid);
    cursor: pointer;
    flex-shrink: 0;
}

.custom-accordion .form-check .form-check-label {
    order: 2;
    flex: 1;
    padding: 0;
    margin: 0;
    text-align: right;
    cursor: pointer;
}

.custom-accordion .form-check .form-check-input:checked {
    background-color: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
}

.custom-accordion .form-check .form-check-input:focus {
    box-shadow: none;
    outline: none;
}

.custom-accordion .form-control,
.custom-accordion .search-icon-inside {
    transition: all 0.2s ease-in-out;
}

.custom-accordion .search-icon-inside {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
}

.custom-accordion .form-control::placeholder {
    font-size: 12px;
}

/* Hover/Focus effect for search inputs */
.custom-accordion .search-input-wrapper:hover .form-control,
.custom-accordion .search-input-wrapper:focus-within .form-control {
    border-color: var(--color-primary-hover);
    box-shadow: 0 0 0 1px var(--color-primary-hover);
}

.custom-accordion .search-input-wrapper:hover .search-icon-inside,
.custom-accordion .search-input-wrapper:focus-within .search-icon-inside {
    color: var(--color-primary-hover);
}

/* =================================================================
   4. Checkbox Hover Effect
   ================================================================= */
.custom-accordion .form-check::before {
    content: '';
    position: absolute;
    top: 50%;
    right: 0px;
    transform: translateY(-50%);
    z-index: 0;
    width: 36px;
    height: 36px;
    background-color: rgba(235, 235, 235, 0.5);
    border-radius: 50%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.8s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.custom-accordion .form-check:hover::before {
    opacity: 1;
}

.custom-accordion .form-check:has(.form-check-input:checked):hover::before {
    background-color: rgba(80, 184, 176, 0.2);
}

/* Special positioning for the hover effect in the accordion header */
.custom-accordion .accordion-header .form-check {
    flex-grow: 1;
    padding: 0;
    background-color: transparent;
}

.custom-accordion .accordion-header .form-check::before {
    right: -9px;
}

/* =================================================================
   5. Custom Scrollbar
   ================================================================= */
.sidebar-scrollable-content::-webkit-scrollbar {
    width: 8px;
}

.sidebar-scrollable-content::-webkit-scrollbar-track {
    background-color: var(--color-white-warm);
}

.sidebar-scrollable-content::-webkit-scrollbar-thumb {
    background-color: var(--color-gray-dark);
    border-radius: 10px;
    border: 2px solid var(--color-white-warm);
}

.sidebar-scrollable-content::-webkit-scrollbar-thumb:hover {
    background-color: var(--color-black-soft);
}

/* فیلتر زمان مراسم: جلوگیری از تداخل ناحیه کلیک ردیف‌های مجاور */
#announcement-ceremony-filters .form-check {
    position: relative;
    z-index: 0;
}

#announcement-ceremony-filters .form-check-input {
    position: relative;
    z-index: 1;
}

/* =================================================================
   6. Mobile Fullscreen Filter Menu
   ================================================================= */
@media (max-width: 991.98px) {
    #sidebar-scroll-area {
        position: fixed;
        top: 0;
        right: 0;
        z-index: 1040;
        display: none; /* Initially hidden */
        width: 100vw;
        height: 100vh;
        background-color: var(--color-white-soft);
        border-right: none;
        flex-direction: column;
        transform-origin: top right;
        transform: scale(0);
        opacity: 0;
        pointer-events: none;
        transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0.3s ease;
    }

    #sidebar-scroll-area.open {
        display: flex !important;
        transform: scale(1);
        opacity: 1;
        pointer-events: auto;
        overflow-y: auto; /* Allow the main container to scroll */
    }

    body.sidebar-open {
        overflow: hidden;
    }

    .sidebar-mobile-header {
        position: -webkit-sticky;
        position: sticky;
        top: 0;
        z-index: 10;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 1rem 1.5rem;
        background-color: var(--color-white-soft);
        border-bottom: 1px solid var(--color-white-warm);
        flex-shrink: 0;
    }

    .sidebar-mobile-header .btn-close:focus {
        box-shadow: none;
        outline: none;
    }
    
    #sidebar-scroll-area.open .sidebar-scrollable-content {
        display: block !important;
        padding: 0;
        /* Let parent handle scroll */
        flex: initial;
        min-height: initial;
        overflow-y: visible;
    }

    #sidebar-scroll-area.open .border-side-menu,
    #sidebar-scroll-area.open .border-side-menu > div {
        display: block !important;
    }

    /* Make footer sticky inside the mobile view */
    #sidebar-scroll-area .sidebar-footer {
        position: -webkit-sticky;
        position: sticky;
        bottom: 0;
        z-index: 10;
        padding: 1rem 0;
        border-top: 1px solid var(--color-white-warm);
        border-left: none;
    }
}

/* =================================================================
   7. Namad Images (Trust Symbols)
   ================================================================= */
.namad-images {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    background-color: var(--color-white-soft);
}

.namad-images img {
    height: 65px;
    width: auto;
    object-fit: contain;
}

/* =================================================================
   8. Accordion Click Behavior Fix
   ================================================================= */

/* کل ناحیه فرم چک را نسبت به رویدادهای موس خنثی کن */
.custom-accordion .accordion-button .form-check {
    pointer-events: none;
}

/* فقط و فقط خود دایره رادیوباتن را دوباره قابل کلیک کن */
.custom-accordion .accordion-button .form-check-input {
    pointer-events: auto;
}

/* =================================================================
   9. Flexbox layout for Accordion Header (Final Fix)
   ================================================================= */

/* ۱. هدر آکاردئون را به یک کانتینر نسبی تبدیل می‌کنیم. */
.custom-accordion .accordion-header {
    position: relative;
}

/* ۲. دکمه رادیویی را به صورت مطلق در گوشه سمت راست قرار می‌دهیم. */
/* این کد مشابه بخش ۹ در فایل اولیه شماست */
.custom-accordion .accordion-header .custom-radio-wrapper {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
    z-index: 5; /* اطمینان از قرارگیری روی لایه‌های دیگر */
}

/* ۳. برای دکمه آکاردئون یک فضای خالی از راست ایجاد می‌کنیم تا متن زیر رادیو نرود. */
.custom-accordion .accordion-header .accordion-button {
    padding-right: 55px !important; 
}

.custom-accordion .accordion-header .custom-accordion-button-announcements,
.custom-accordion .accordion-header .custom-accordion-button-services,
.custom-accordion .accordion-header .custom-accordion-button-tombs {
    padding-right: 16px !important;
}

.custom-filter-side-badge {
    margin-right: 12px;
    width: 132px;
    text-align: right;
    padding: 8px 0px;
    font-size: 0.9rem;
    font-weight: 500;
    color: var( --color-black-soft);
    /* background-color: var(--color-white-aqua); */
    /* border: 1px solid var(--color-gray-dark); */
    border-radius: 5px; /* Overwrites default badge radius */
    vertical-align: middle;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
}

.custom-filter-side-badge:hover {
    color: var(--color-primary-hover);
    /* background-color: var(--color-primary-hover);
    border-color: var(--color-primary-hover); */
    /* transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.1); */
}

/* =================================================================
   11. اصلاح استایل آکاردئون داخلی
   ================================================================= */

/* ۱. حذف بوردر بالای آیتم‌های آکاردئون داخلی */
#inner-services-accordion .accordion-item {
    border-top: none;
}

/* ۲. کاهش فاصله عمودی (پدینگ) دکمه‌ها برای نزدیک‌تر شدن به هم */
#inner-services-accordion .accordion-button {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    padding-right: 4px !important;
    /* NEW: Add flex properties */
    display: flex;
    align-items: center;
    width: 100%;
}

/* NEW: Reset padding for the form-check inside inner accordion button */
#inner-services-accordion .accordion-button .form-check {
    padding: 0;
    /* We need to allow clicks on this checkbox now */
    pointer-events: auto; 
}

/* NEW: Ensure the badge takes up remaining space */
#inner-services-accordion .accordion-button .custom-filter-side-badge {
    flex-grow: 1;
    margin-right: 8px; /* Adjust spacing */
}

/* =================================================================
   12. تنظیمات پیکان‌های آکاردئون داخلی
   ================================================================= */

/* ۱. کوچک کردن اندازه پیکان‌ها در آکاردئون داخلی */
#inner-services-accordion .accordion-button::after {
    background-size: 1rem; /* اندازه پیش‌فرض معمولاً 1.25rem است */
    /* NEW: Ensure the arrow does not shrink */
    flex-shrink: 0;
}

/* =================================================================
   13. هم‌راستاسازی آکاردئون داخلی با مارجین منفی
   ================================================================= */

/* این کد آکاردئون داخلی را بدون تاثیر روی باکس جستجو، هم‌راستا می‌کند */
#inner-services-accordion {
    margin-right: -1.25rem;
    margin-left: -1.25rem;
}

/* =================================================================
   14. هم‌راستاسازی چک‌باکس‌های داخلی
   ================================================================= */

/* با مارجین منفی، چک‌باکس‌ها و محتوایشان را با رادیوباتن‌های اصلی هم‌راستا می‌کنیم.
  این کار دایره هاور را نیز به همراه خود به درستی جابجا می‌کند.
*/
#inner-services-accordion .service-checkbox-item {
    /* مقدار مارجین باید برابر با پدینگ پیش‌فرض .accordion-body باشد */
    margin-right: -0.6rem;
    margin-left: -0.6rem;
}

/* =================================================================
   15. تنظیم دقیق موقعیت پیکان‌های داخلی
   ================================================================= */

#inner-services-accordion .accordion-button::after {
    /* با افزودن مارجین از چپ، پیکان اندکی به سمت راست حرکت می‌کند */
    margin-left: 2px;
}
/* =============== */
#inner-services-accordion .accordion-button {
    display: flex;
    align-items: center;
    width: 100%;
}

/* =================================================================
   16. موقعیت‌دهی چک‌باکس‌های والد در آکاردئون داخلی
   ================================================================= */

/* ۱. کانتینر چک‌باکس را مانند رادیوباتن‌های منوی اصلی، به صورت شناور قرار می‌دهیم */
#inner-services-accordion .parent-checkbox-wrapper {
    position: absolute;
    top: 50%;
    right: 1.25rem; /* معادل 20px */
    transform: translateY(-50%);
    z-index: 5;
}

/* ۳. متن عنوان و پیکان را هم‌راستا می‌کنیم */
#inner-services-accordion .accordion-button .custom-filter-side-badge {
    margin-right: 0; /* مارجین قبلی را حذف می‌کنیم */
}

/* =================================================================
   17. اصلاح چیدمان افقی چک‌باکس و عنوان
   ================================================================= */

/* با تبدیل هدر به یک کانتینر فلکس، اجزای داخلی آن را هم‌راستا می‌کنیم */
#inner-services-accordion .accordion-header {
    display: flex;
    align-items: center;
    margin-right: 20px;
}

/* به دکمه می‌گوییم که تمام فضای افقی باقی‌مانده را اشغال کند */
#inner-services-accordion .accordion-button {
    flex-grow: 1;
}

/* پدینگ اضافی را از کانتینر چک‌باکس حذف می‌کنیم تا تداخلی ایجاد نکند */
#inner-services-accordion .parent-checkbox-wrapper {
    padding: 0;
}