/* =============================================================================
   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: 1000;
    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;
}

/* 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 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");
}

/* =============================================================================
   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;
    left: 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: 768px) {
    .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-left: 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;
    }
}
