/* ============================================
   Flatsome Mobile Nav – fmn-style.css
   ============================================ */

:root {
    --fmn-accent:       #007c42;
    --fmn-text:         #222222;
    --fmn-border:       #e5e5e5;
    --fmn-bg:           #ffffff;
    --fmn-header-bg:    #f7f7f7;
    --fmn-overlay-bg:   rgba(0, 0, 0, 0.45);
    --fmn-width:        320px;
    --fmn-transition:   0.3s ease;
    --fmn-icon-size:    23px;
    --fmn-z-overlay:    120000;
    --fmn-z-nav:        120001;
}

/* ----- Trigger Button ----- */
.fmn-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
    color: var(--fmn-text);
    line-height: 1;
}

.fmn-trigger svg {
    width: var(--fmn-icon-size);
    height: var(--fmn-icon-size);
    fill: currentColor;
    display: block;
}

/* ----- Overlay ----- */
.fmn-overlay {
    position: fixed;
    inset: 0;
    background: var(--fmn-overlay-bg);
    z-index: var(--fmn-z-overlay);
    opacity: 0;
    transition: opacity var(--fmn-transition);
}

.fmn-overlay.fmn-overlay--visible {
    opacity: 1;
}

/* ----- Nav Drawer ----- */
.fmn-nav {
    position: fixed;
    top: 0;
    left: 0;
    width: var(--fmn-width);
    max-width: 90vw;
    height: 100%;
    background: var(--fmn-bg);
    z-index: var(--fmn-z-nav);
    overflow: hidden;
    transform: translateX(-100%);
    transition: transform var(--fmn-transition);
    box-shadow: 2px 0 16px rgba(0,0,0,0.15);
    display: flex;
    flex-direction: column;
}

/* ----- Body scroll lock ----- */
html.fmn-open,
body.fmn-open {
    overflow: hidden;
}

.fmn-nav.fmn-nav--open {
    transform: translateX(0);
}

/* ----- Panel ----- */
.fmn-panel {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--fmn-bg);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform var(--fmn-transition);
    overflow-y: auto;
    padding-bottom: 69px; /* clearance for sticky bar */
    box-sizing: border-box;
}

.fmn-panel--active {
    transform: translateX(0);
}



/* ----- Panel Header ----- */
.fmn-panel-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 16px;
    background: var(--fmn-header-bg);
    border-bottom: 1px solid var(--fmn-border);
    min-height: 52px;
    position: sticky;
    top: 0;
    z-index: 1;
    margin-bottom: 10px;
}

.fmn-panel-title {
    flex: 1;
    font-size: 16px;
    font-weight: 600;
    color: var(--fmn-text);
    letter-spacing: 0.01em;
    padding-left: 4px;
}

.fmn-back-btn,
.fmn-close-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    margin-right: 0px;
    color: var(--fmn-accent);
    flex-shrink: 0;
}

.fmn-back-btn svg,
.fmn-close-btn svg {
    width: 16px;
    height: 16px;
    fill: currentColor;
    display: block;
}

.fmn-close-btn {
    color: var(--fmn-text);
    margin-left: auto;
}

/* ----- Menu List ----- */
.fmn-menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

.fmn-item {
    display: flex;
    align-items: stretch;
    margin-bottom: 0;
}

.fmn-link {
    flex: 1;
    display: flex;
    align-items: center;
    padding: 12px 20px !important;
    color: var(--fmn-text);
    text-decoration: none;
    font-size: 14px !important;
    line-height: 1.4 !important;
    transition: color 400ms ease, background 400ms ease;
}

.fmn-link:active {
    color: var(--fmn-accent);

    transition: none;
}

.fmn-link--parent {
    width: 100%;
    text-align: left;
    justify-content: space-between;
    cursor: pointer;
    text-transform: none;
    letter-spacing: normal;
    font-family: inherit;
    font-weight: normal;
    margin-right: 0px;
}

.fmn-link--parent svg {
    width: 10px;
    height: 10px;
    fill: currentColor;
    flex-shrink: 0;
}

/* ----- "Ver Todos" highlight ----- */
.fmn-ver-todos .fmn-link {
    color: var(--fmn-accent);
    font-weight: 600;
}

.fmn-ver-todos .fmn-link:active {
    text-decoration: underline;
}

/* ----- Secondary Label ----- */
.fmn-secondary-label {
    padding: 30px 20px 4px;
    margin: 0;
    font-size: 0.75rem;
    font-weight: 400;
    color: var(--fmn-text);
    opacity: 0.5;
}

/* ----- Secondary Links ----- */
.fmn-secondary-links {
    padding: 4px 0;
}

.fmn-secondary-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 20px;
    color: var(--fmn-text);
    text-decoration: none;
    font-size: 14px;
    transition: color 400ms ease, background 400ms ease;
}

.fmn-secondary-link svg {
    flex-shrink: 0;
    fill: currentColor;
    opacity: 0.6;
}

.fmn-secondary-link:active {
    color: var(--fmn-accent);

    transition: none;
}

.fmn-secondary-link:active svg {
    opacity: 1;
}

/* ----- Sticky Bottom Bar ----- */
.fmn-sticky-bar {
    position: sticky;
    bottom: 0;
    padding: 12px 20px;
    background: var(--fmn-bg);
    margin-top: auto;
    z-index: 2;
    box-shadow: 0 -8px 16px rgba(255, 255, 255, 0.95);
}

.fmn-sticky-btn {
    display: block;
    width: 100%;
    padding: 13px 20px;
    background-color: #007d42;
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    transition: background-color 400ms ease;
}

.fmn-sticky-btn:active {
    background-color: #006235;
    color: #fff;
    transition: none;
}
