/* =============================================================================
   BM Vertical Menu - Main Styles
   Module: bm_verticalmenu | Author: Bullmade
   ============================================================================= */

:root {
    --bm-vmenu-width: 220px;
    --bm-vmenu-bg: #f9f9f9;
    --bm-vmenu-text: #333333;
    --bm-vmenu-text-light: #666666;
    --bm-vmenu-border: #e8e8e8;
    --bm-vmenu-hover-bg: #f7f7f7;
    --bm-vmenu-link-color: #333333;
    --bm-vmenu-font-size: 13px;
    --bm-vmenu-padding: 16px;
    --bm-vmenu-transition: 0.3s ease;
    --bm-vmenu-page-bg: #f9f9f9;
    --bm-vmenu-page-padding: 16px;
}

/* =============================================================================
   Page background and padding
   ============================================================================= */

body.bm-vmenu-active {
    background: var(--bm-vmenu-page-bg);
    padding-top: var(--bm-vmenu-page-padding);
    padding-right: var(--bm-vmenu-page-padding);
    padding-bottom: var(--bm-vmenu-page-padding);
}

body.bm-vmenu-active #header {
    background: #ffffff;
    border-radius: 8px 8px 0 0;
}

body.bm-vmenu-active #header.bm-vmenu-scrolled {
    border-radius: 0;
}

body.bm-vmenu-active #wrapper {
    background: #ffffff;
    overflow: hidden;
}

body.bm-vmenu-active #wrapper.bm-vmenu-scrolled {
    border-radius: 0;
}

body.bm-vmenu-active #footer {
    background: #ffffff;
    border-radius: 0 0 8px 8px;
    overflow: hidden;
}

/* =============================================================================
   Sidebar container
   ============================================================================= */

.bm-vmenu {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: var(--bm-vmenu-width);
    background: var(--bm-vmenu-bg);
    z-index: 2;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    font-size: var(--bm-vmenu-font-size);
    color: var(--bm-vmenu-text);
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
}

.bm-vmenu *,
.bm-vmenu *::before,
.bm-vmenu *::after {
    box-sizing: border-box;
}

/* Push page content to the right */
body.bm-vmenu-active {
    padding-left: var(--bm-vmenu-width) !important;
}

/* Same layout applied on first paint via :has() — the .bm-vmenu-active class
   is only added by JS at the bottom of the page, so without this the page
   renders full-width for a moment and then snaps into place.
   Breakpoint MUST match where the sidebar is actually shown (it collapses
   off-canvas at max-width:992px). At 769–992px the menu is hidden, so this
   :has() rule (specificity 1,0,1) used to beat the mobile reset and leave a
   dead 220px gap with cramped content. Gate it to >=993px. */
@media (min-width: 993px) {
    body:has(#bm-vertical-menu) {
        padding-left: var(--bm-vmenu-width) !important;
    }

    body:has(#bm-vertical-menu) #wrapper {
        background: #ffffff;
        overflow: hidden;
    }

    body:has(#bm-vertical-menu) #footer {
        background: #ffffff;
        border-radius: 0 0 8px 8px;
        overflow: hidden;
    }
}

/* Close button (mobile only) */
.bm-vmenu__close {
    display: none;
    position: absolute;
    top: 10px;
    right: 10px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--bm-vmenu-text);
    padding: 4px;
    line-height: 1;
    z-index: 1;
}

.bm-vmenu__close:hover {
    opacity: 0.7;
}

/* =============================================================================
   Welcome section
   ============================================================================= */

.bm-vmenu__welcome {
    padding: var(--bm-vmenu-padding);
    padding-bottom: 12px;
}

.bm-vmenu__welcome-label {
    display: block;
    font-size: 12px;
    color: var(--bm-vmenu-text-light);
    margin-bottom: 2px;
}

.bm-vmenu__welcome-name {
    display: block;
    font-weight: 700;
    font-size: 15px;
    line-height: 1.3;
    color: var(--bm-vmenu-text);
}

.bm-vmenu__welcome-company {
    display: block;
    font-size: 12px;
    color: var(--bm-vmenu-text-light);
    margin-top: 1px;
}

.bm-vmenu__login-link {
    display: inline-block;
    font-weight: 600;
    color: var(--bm-vmenu-link-color);
    text-decoration: none;
    font-size: 14px;
}

.bm-vmenu__login-link:hover {
    text-decoration: underline;
}

/* =============================================================================
   Account dropdown (customer name -> collapsible account menu)
   ============================================================================= */

.bm-vmenu__account-dropdown {
    position: relative;
}

.bm-vmenu__account-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 0;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    color: var(--bm-vmenu-text);
    font-family: inherit;
    font-size: var(--bm-vmenu-font-size);
}

.bm-vmenu__account-identity {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

/* Keep a long name on one line inside the toggle */
.bm-vmenu__account-toggle .bm-vmenu__welcome-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.bm-vmenu__account-chevron {
    flex-shrink: 0;
    color: var(--bm-vmenu-text-light);
    transition: transform var(--bm-vmenu-transition);
}

.bm-vmenu__account-toggle--open .bm-vmenu__account-chevron {
    transform: rotate(180deg);
}

.bm-vmenu__account-menu {
    display: none;
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
}

.bm-vmenu__account-menu--open {
    display: block;
}

/* Separate "Sign out" from the rest of the menu */
.bm-vmenu__nav-item--logout {
    margin-top: 4px;
    padding-top: 4px;
    border-top: 1px solid var(--bm-vmenu-border);
}

/* =============================================================================
   Account navigation
   ============================================================================= */

.bm-vmenu__account {
    padding: 0 0 8px;
}

.bm-vmenu__nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.bm-vmenu__nav-item {
    margin: 0;
}

.bm-vmenu__nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px var(--bm-vmenu-padding);
    color: var(--bm-vmenu-link-color);
    text-decoration: none;
    transition: background-color var(--bm-vmenu-transition);
    font-size: 13px;
    line-height: 1.4;
}

.bm-vmenu__nav-link:hover {
    background-color: var(--bm-vmenu-hover-bg);
    text-decoration: none;
    color: var(--bm-vmenu-link-color);
}

/* =============================================================================
   Navigation icons (inline SVG via CSS backgrounds)
   ============================================================================= */

.bm-vmenu__nav-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.bm-vmenu__nav-icon::before {
    content: '';
    display: block;
    width: 18px;
    height: 18px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    opacity: 0.7;
}

.bm-vmenu__nav-icon--home::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-4 0a1 1 0 01-1-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 01-1 1h-2z'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--list::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='8' y1='6' x2='21' y2='6'/%3E%3Cline x1='8' y1='12' x2='21' y2='12'/%3E%3Cline x1='8' y1='18' x2='21' y2='18'/%3E%3Cline x1='3' y1='6' x2='3.01' y2='6'/%3E%3Cline x1='3' y1='12' x2='3.01' y2='12'/%3E%3Cline x1='3' y1='18' x2='3.01' y2='18'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--person::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 00-4-4H8a4 4 0 00-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--support::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 5a2 2 0 012-2h3.28a1 1 0 01.948.684l1.498 4.493a1 1 0 01-.502 1.21l-2.257 1.13a11.042 11.042 0 005.516 5.516l1.13-2.257a1 1 0 011.21-.502l4.493 1.498a1 1 0 01.684.949V19a2 2 0 01-2 2h-1C9.716 21 3 14.284 3 6V5z'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--address::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0118 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--slip::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3Cline x1='16' y1='13' x2='8' y2='13'/%3E%3Cline x1='16' y1='17' x2='8' y2='17'/%3E%3Cline x1='10' y1='9' x2='8' y2='9'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--voucher::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.59 13.41l-7.17 7.17a2 2 0 01-2.83 0L2 12V2h10l8.59 8.59a2 2 0 010 2.82z'/%3E%3Cline x1='7' y1='7' x2='7.01' y2='7'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--return::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 14 4 9 9 4'/%3E%3Cpath d='M20 20v-7a4 4 0 00-4-4H4'/%3E%3C/svg%3E");
}

.bm-vmenu__nav-icon--logout::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 01-2-2V5a2 2 0 012-2h4'/%3E%3Cpolyline points='16 17 21 12 16 7'/%3E%3Cline x1='21' y1='12' x2='9' y2='12'/%3E%3C/svg%3E");
}

/* =============================================================================
   Spacer (pushes bottom content down)
   ============================================================================= */

.bm-vmenu__spacer {
    flex: 1;
    min-height: 20px;
}

/* =============================================================================
   Language / Currency selector
   ============================================================================= */

.bm-vmenu__language {
    position: relative;
    padding: 8px var(--bm-vmenu-padding);
}

.bm-vmenu__language-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px 0;
    color: var(--bm-vmenu-text);
    font-size: var(--bm-vmenu-font-size);
    font-family: inherit;
}

.bm-vmenu__language-toggle:hover {
    opacity: 0.8;
}

.bm-vmenu__flag {
    border-radius: 2px;
    vertical-align: middle;
}

.bm-vmenu__currency {
    font-size: 12px;
    color: var(--bm-vmenu-text-light);
}

.bm-vmenu__language-dropdown {
    display: none;
    list-style: none;
    margin: 4px 0 0;
    padding: 4px 0;
    background: var(--bm-vmenu-bg);
    border: 1px solid var(--bm-vmenu-border);
    border-radius: 4px;
}

.bm-vmenu__language-dropdown--open {
    display: block;
}

.bm-vmenu__language-dropdown li {
    margin: 0;
    padding: 0;
}

.bm-vmenu__language-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    color: var(--bm-vmenu-link-color);
    text-decoration: none;
    font-size: 12px;
    transition: background-color var(--bm-vmenu-transition);
}

.bm-vmenu__language-option:hover {
    background-color: var(--bm-vmenu-hover-bg);
    text-decoration: none;
    color: var(--bm-vmenu-link-color);
}

.bm-vmenu__language-option--active {
    font-weight: 600;
}

/* =============================================================================
   Custom links
   ============================================================================= */

.bm-vmenu__links {
    padding: 4px 0 8px;
}

.bm-vmenu__links-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.bm-vmenu__links-item {
    margin: 0;
}

.bm-vmenu__links-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px var(--bm-vmenu-padding);
    color: var(--bm-vmenu-link-color);
    text-decoration: none;
    font-size: 13px;
    transition: background-color var(--bm-vmenu-transition);
}

.bm-vmenu__links-link:hover {
    background-color: var(--bm-vmenu-hover-bg);
    text-decoration: none;
    color: var(--bm-vmenu-link-color);
}

/* =============================================================================
   Logout
   ============================================================================= */

.bm-vmenu__logout {
    padding: 4px var(--bm-vmenu-padding) var(--bm-vmenu-padding);
}

.bm-vmenu__logout-link {
    color: var(--bm-vmenu-link-color);
    text-decoration: none;
    font-size: 13px;
}

.bm-vmenu__logout-link:hover {
    text-decoration: underline;
}

/* =============================================================================
   Debug info
   ============================================================================= */

.bm-vmenu__debug {
    padding: 4px var(--bm-vmenu-padding);
    font-size: 10px;
    color: #999;
    border-top: 1px dashed #ddd;
}

/* =============================================================================
   Mobile toggle button
   ============================================================================= */

.bm-vmenu-toggle {
    display: none;
    position: fixed;
    bottom: 16px;
    right: 16px;
    z-index: 1001;
    width: 44px;
    height: 44px;
    background: var(--bm-vmenu-bg);
    border: 1px solid var(--bm-vmenu-border);
    border-radius: 50%;
    cursor: pointer;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
    padding: 0;
}

.bm-vmenu-toggle__bar {
    display: block;
    width: 20px;
    height: 2px;
    background: var(--bm-vmenu-text);
    border-radius: 1px;
    transition: transform var(--bm-vmenu-transition), opacity var(--bm-vmenu-transition);
}

/* Hamburger to X animation when open */
.bm-vmenu-toggle[aria-expanded="true"] .bm-vmenu-toggle__bar:nth-child(1) {
    transform: rotate(45deg) translate(4px, 4px);
}

.bm-vmenu-toggle[aria-expanded="true"] .bm-vmenu-toggle__bar:nth-child(2) {
    opacity: 0;
}

.bm-vmenu-toggle[aria-expanded="true"] .bm-vmenu-toggle__bar:nth-child(3) {
    transform: rotate(-45deg) translate(4px, -4px);
}

/* =============================================================================
   Mobile overlay
   ============================================================================= */

.bm-vmenu-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 999;
}

.bm-vmenu-overlay--visible {
    display: block;
}

/* =============================================================================
   Responsive
   ============================================================================= */

@media (max-width: 992px) {
    .bm-vmenu {
        transform: translateX(-100%);
        transition: transform var(--bm-vmenu-transition);
        z-index: 1002;
    }

    .bm-vmenu--open {
        transform: translateX(0);
    }

    /* Don't push content on mobile */
    body.bm-vmenu-active {
        padding: 0 !important;
    }

    .bm-vmenu-toggle {
        display: flex;
    }

    .bm-vmenu__close {
        display: block;
    }
}

/* =============================================================================
   Print: hide sidebar
   ============================================================================= */

@media print {
    .bm-vmenu,
    .bm-vmenu-toggle,
    .bm-vmenu-overlay {
        display: none !important;
    }

    body.bm-vmenu-active {
        padding-left: 0 !important;
    }
}
