/*
=================================================
spp-drawers.css
Mobile right-side drawer navigation
Site: pickleballstouffville.ca (staging)
=================================================
All tokens defined in spp-tokens.css
=================================================
*/

/* =====================================================
   DESKTOP — HIDE ALL MOBILE ELEMENTS
   ===================================================== */
@media (min-width: 981px) {
    #spp-mm-open,
    #spp-mm-bottom-sheet,
    #spp-mm-overlay {
        display: none !important;
    }
    .spp-mobile-menu-wrapper {
        display: none !important;
    }
    .spp-side-nav {
        display: block !important;
    }
}

/* =====================================================
   GLOBAL — HIDE MENU WRAPPERS OUTSIDE DRAWER
   ===================================================== */
.spp-mobile-menu-wrapper {
    display: none !important;
}

#spp-mm-bottom-sheet .spp-mm-sheet-body .spp-mobile-menu-wrapper {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.6rem;
}

/* =====================================================
   MOBILE ONLY
   ===================================================== */
@media (max-width: 980px) {

    /* Hide Divi top navigation */
    #et_mobile_nav_menu,
    .mobile_menu_bar,
    #et-top-navigation .et_mobile_menu,
    #et-top-navigation {
        display: none !important;
    }

    /* Hide desktop side nav on mobile */
    .spp-side-nav {
        display: none !important;
    }

    /* ---------------------------------------------------
       HAMBURGER BUTTON — fixed top right
       --------------------------------------------------- */
    #spp-mm-open {
        position: fixed !important;
        top: 12px !important;
        right: 12px !important;
        z-index: 9999999 !important;
        width: 44px !important;
        height: 44px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: rgba(0, 77, 64, 0.92) !important;
        border: 1px solid var(--spp-secondary) !important;
        border-radius: 8px !important;
        cursor: pointer !important;
        padding: 0 !important;
        pointer-events: auto !important;
    }

    .spp-mm-open-icon::before {
        content: "\61";
        font-family: "ETmodules";
        font-size: 22px;
        color: var(--spp-text-light);
    }

    body.spp-mm-open #spp-mm-open .spp-mm-open-icon::before {
        content: "\4d";
    }

    /* ---------------------------------------------------
       OVERLAY
       --------------------------------------------------- */
    #spp-mm-overlay {
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.55);
        z-index: 999998;
        display: none;
        pointer-events: auto;
    }

    body.spp-mm-open #spp-mm-overlay {
        display: block;
    }

    /* ---------------------------------------------------
       RIGHT-SIDE DRAWER
       --------------------------------------------------- */
    #spp-mm-bottom-sheet {
        position: fixed !important;
        top: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        left: auto !important;
        width: 80vw !important;
        max-width: 320px !important;
        height: 100% !important;
        max-height: 100% !important;
        overflow-y: auto !important;
        background: var(--spp-drawer-bg) !important;
        border-left: 2px solid var(--spp-primary) !important;
        transform: translateX(100%);
        transition: transform .25s ease-out;
        display: flex !important;
        flex-direction: column;
        z-index: 999999 !important;
    }

    body.spp-mm-open #spp-mm-bottom-sheet {
        transform: translateX(0) !important;
    }

    /* ---------------------------------------------------
       DRAWER HEADER
       --------------------------------------------------- */
    .spp-mm-sheet-header {
        padding: .7rem 1rem;
        border-bottom: 1px solid var(--spp-border-light);
        display: flex;
        justify-content: space-between;
        align-items: center;
        position: sticky;
        top: 0;
        background: var(--spp-primary);
        z-index: 1;
    }

    .spp-mm-sheet-title {
        font-weight: 600;
        color: var(--spp-text-light) !important;
    }

    #spp-mm-close {
        background: transparent;
        border: none;
        cursor: pointer;
        padding: 4px;
    }

    #spp-mm-close-icon::before {
        content: "\4d";
        font-family: "ETmodules";
        font-size: 22px;
        color: var(--spp-text-light) !important;
    }

    /* ---------------------------------------------------
       DRAWER BODY
       --------------------------------------------------- */
    .spp-mm-sheet-body {
        padding: var(--spp-space-sm);
        overflow-y: auto;
        flex: 1;
    }

    /* Footer bottom padding no longer needed */
    .et_pb_section_0_tb_footer {
        padding-bottom: 20px !important;
    }
}

/* =====================================================
   SHARED MENU ITEM STYLES
   (desktop side nav + mobile drawer)
   ===================================================== */

.spp-mm-section {
    margin-bottom: 0.8rem;
}

.spp-mm-heading {
    color: var(--spp-text-light) !important;
    background: var(--spp-primary);
    font-size: 0.75rem;
    font-weight: 700;
    margin-bottom: 0.3rem;
    padding: 6px 10px;
    border-radius: var(--spp-radius);
    letter-spacing: 0.03em;
    text-transform: uppercase;
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    user-select: none;
}

.spp-mm-heading a {
    color: var(--spp-text-light) !important;
    text-decoration: none;
    flex: 1;
}

.spp-mm-heading a:hover {
    color: var(--spp-text-light) !important;
    opacity: 0.85;
}

.spp-mm-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.spp-mm-item {
    margin-bottom: 3px;
}

.spp-mm-item a {
    display: block;
    padding: 8px 10px;
    color: var(--spp-dark) !important;
    background: var(--spp-item-bg) !important;
    text-decoration: none;
    font-size: 0.75rem;
    line-height: var(--spp-line-height);
    border-radius: var(--spp-radius);
    border-left: 3px solid transparent;
    transition: background 0.15s ease, color 0.15s ease, border-left-color 0.15s ease;
}

.spp-mm-item a:hover,
.spp-mm-item a:active {
    background: rgba(0, 137, 123, 0.15) !important;
    color: var(--spp-primary) !important;
    border-left-color: var(--spp-primary) !important;
}

.spp-mm-list ul.sub-menu {
    margin-left: 0.5rem;
    padding-left: 0.5rem;
    border-left: 2px solid var(--spp-secondary);
    margin-top: 3px;
    list-style: none;
}

.spp-mm-list ul.sub-menu .spp-mm-item a {
    font-size: 0.7rem;
    padding-left: 12px;
    background: var(--spp-item-bg-sub) !important;
}

.spp-mm-section--direct .spp-mm-list {
    display: block !important;
}

/* =====================================================
   COLLAPSIBLE ACCORDION
   ===================================================== */

/* All sections closed by default */
.spp-side-nav--collapsible .spp-mm-section .spp-mm-list {
    display: none;
}

/* Show when open */
.spp-side-nav--collapsible .spp-mm-section.spp-open .spp-mm-list {
    display: block;
}

/* Arrow handled by JS toggle button */
.spp-side-nav--collapsible .spp-mm-heading::after {
    content: none;
}

/* Direct link sections always visible */
.spp-side-nav--collapsible .spp-mm-section--direct .spp-mm-list {
    display: block !important;
}

/* Mobile drawer collapsible */
#spp-mm-bottom-sheet .spp-side-nav--collapsible .spp-mm-section .spp-mm-list {
    display: none;
}

#spp-mm-bottom-sheet .spp-side-nav--collapsible .spp-mm-section.spp-open .spp-mm-list {
    display: block !important;
}

/* Accordion toggle button */
.spp-accordion-toggle {
    background: transparent;
    border: none;
    color: var(--spp-text-light);
    cursor: pointer;
    padding: 0 0 0 8px;
    font-size: 0.85rem;
    line-height: 1;
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.spp-mm-section.spp-open .spp-accordion-toggle {
    transform: rotate(90deg);
}

/* Desktop side nav font size */
@media (min-width: 981px) {
    .spp-side-nav .spp-mm-heading,
    .spp-side-nav .spp-mm-item a {
        font-size: 0.75rem;
    }
}
