/* Factor Fast MegaMenu - Mobile styles (scoped via body.ffmm-is-mobile or .ffmm-wrap.ffmm-mobile)
   This file contains mobile-first accordion/overlay behavior and common base styles.
*/

:root { --ffmm-accent: #f68a34; --ffmm-accent-600: #de7a29; --ffmm-accent-700: #c86d23; --ffmm-accent-50: #fff3e9; }

/* Base resets */
.mega-menu { box-sizing: border-box; font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica, Arial, sans-serif; color: #111827; }
.mega-menu ul { list-style: none; margin: 0; padding: 0; }
.mega-menu a { text-decoration: none; color: inherit; }

/* Utility and accessibility */
.ffmm-no-scroll { overflow: hidden !important; }
.ffmm-menu { overflow: hidden; }
.ffmm-menu > .mega-menu { flex: 1 1 auto; min-height: 0; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.ffmm-menu > .ffmm-megamenu-container { flex: 1 1 auto; min-height: 0; display: flex; }
.ffmm-menu > .ffmm-megamenu-container > .mega-menu { flex: 1 1 auto; min-height: 0; overflow-y: auto; -webkit-overflow-scrolling: touch; }

/* Toggle button */
.ffmm-toggle { display: inline-flex; align-items: center; gap: 8px; padding: 10px 14px; border-radius: 8px; border: 1px solid var(--ffmm-accent-700); background: var(--ffmm-accent); color: #ffffff; cursor: pointer; font-weight: 600; }
.ffmm-toggle:hover { background: var(--ffmm-accent-600); }
.ffmm-burger-icon { width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; }
.ffmm-burger-image { width: 18px; height: 18px; object-fit: contain; }
.ffmm-toggle-label { font-size: 14px; }

/* Remove button styling when no-button-style option is enabled */
.ffmm-toggle.ffmm-toggle-no-button-style {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
    color: inherit !important;
}
.ffmm-toggle.ffmm-toggle-no-button-style:hover {
    background: transparent !important;
}

/* Mobile overlay and header (active when body.ffmm-is-mobile or wrapper has ffmm-mobile) */
body.ffmm-is-mobile .ffmm-wrap.is-closed .ffmm-menu,
.ffmm-wrap.ffmm-mobile.is-closed .ffmm-menu { display: none; }
body.ffmm-is-mobile .ffmm-wrap.is-closed .ffmm-menu[hidden],
.ffmm-wrap.ffmm-mobile.is-closed .ffmm-menu[hidden] { display: none !important; }
body.ffmm-is-mobile .ffmm-wrap.is-closed .ffmm-menu:not([hidden]),
.ffmm-wrap.ffmm-mobile.is-closed .ffmm-menu:not([hidden]) {
  position: fixed; inset: 0; z-index: 200010; background: #ffffff; display: flex; flex-direction: column; max-width: 420px; width: 100%; left: 0; right: auto;
}

/* Fallback: show panel if toggle has aria-expanded=true even if [hidden] still present */
body.ffmm-is-mobile .ffmm-wrap .ffmm-toggle[aria-expanded="true"] + .ffmm-menu,
.ffmm-wrap.ffmm-mobile .ffmm-toggle[aria-expanded="true"] + .ffmm-menu {
  position: fixed; inset: 0; z-index: 200010; background: #ffffff; display: flex !important; flex-direction: column; max-width: 420px; width: 100%; left: 0; right: auto; visibility: visible; pointer-events: auto;
}

/* Mobile header */
.ffmm-mobile-header { display: none; align-items: center; justify-content: space-between; gap: 8px; padding: 12px 14px; border-bottom: 1px solid #e5e7eb; flex: 0 0 auto; }
.ffmm-mobile-title { font-size: 16px; font-weight: 600; color: #111827; }
.ffmm-mobile-close { appearance: none; border: 0; background: transparent; width: 36px; height: 36px; border-radius: 9999px; color: #6b7280; font-size: 20px; line-height: 1; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; }
.ffmm-mobile-close:hover { background: #f3f4f6; color: #374151; }

/* Show the header in mobile mode */
body.ffmm-is-mobile .ffmm-mobile-header, .ffmm-wrap.ffmm-mobile .ffmm-mobile-header { display: flex; }
body.ffmm-is-mobile .ffmm-secondary, .ffmm-wrap.ffmm-mobile .ffmm-secondary { display: none; }
body.ffmm-is-mobile .ffmm-primary, .ffmm-wrap.ffmm-mobile .ffmm-primary { display: block; }

/* Hide two-pane on mobile; use ffmm-mobile-only */
body.ffmm-is-mobile .ffmm-two-pane,
.ffmm-wrap.ffmm-mobile .ffmm-two-pane { display: none !important; }

/* Mobile-only nav hidden by default; shown only in mobile mode */
.ffmm-mobile-only { display: none; }
body.ffmm-is-mobile .ffmm-mobile-only, .ffmm-wrap.ffmm-mobile .ffmm-mobile-only { display: block; }
/* Hide desktop-only containers only in mobile mode */
body.ffmm-is-mobile .ffmm-desktop-only, .ffmm-wrap.ffmm-mobile .ffmm-desktop-only { display: none !important; }

/* One column accordion (mobile) */
.mega-menu.ffmm-one-column { display: block; }
.mega-menu.ffmm-one-column > .mega-level.level-1 { display: block; }

/* Items */
.mega-menu .mega-item { border-bottom: 1px solid #dcdfe3; }
.mega-menu .mega-item:last-child { border-bottom: 0; }
.mega-menu .mega-link { display: flex; align-items: center; width: 100%; padding: 12px 16px; transition: background-color .15s ease, color .15s ease; }
.mega-menu .mega-link:hover { background: #f9fafb; }
.mega-menu .mega-link:focus-visible { outline: 2px solid var(--ffmm-accent); outline-offset: 2px; }
.mega-menu .mega-link .mega-label { font-size: 14px; font-weight: 500; color: #111827; }
.mega-menu .mega-thumb, .mega-menu .mega-icon { margin-right: 10px; display: inline-flex; align-items: center; justify-content: center; }
.mega-menu .mega-thumb img { width: 20px; height: 20px; object-fit: contain; }
.mega-menu .mega-icon { width: 20px; height: 20px; color: #6b7280; }

/* Hide media for deeper levels if requested */
.ffmm-icon-only-top .mega-level.level-2 .mega-thumb,
.ffmm-icon-only-top .mega-level.level-2 .mega-icon,
.ffmm-icon-only-top .mega-level.level-3 .mega-thumb,
.ffmm-icon-only-top .mega-level.level-3 .mega-icon { display: none !important; }

/* Right side arrow */
.ffmm-arrow { margin-left: 12px; color: #9ca3af; transition: transform .2s ease, color .2s ease; font-size: 16px; }
.mega-link[aria-expanded="true"] .ffmm-arrow { transform: rotate(90deg); color: var(--ffmm-accent); }

/* Accordion behavior: hide L2 under L1 by default on mobile */
body.ffmm-is-mobile .mega-menu.ffmm-one-column > .mega-level.level-1 > .mega-item > .mega-level.level-2,
.ffmm-wrap.ffmm-mobile .mega-menu.ffmm-one-column > .mega-level.level-1 > .mega-item > .mega-level.level-2 { display: none; background: #f9fafb; margin-left: 30px; }
body.ffmm-is-mobile .mega-menu.ffmm-one-column > .mega-level.level-1 > .mega-item > .mega-level.level-2 .mega-link,
.ffmm-wrap.ffmm-mobile .mega-menu.ffmm-one-column > .mega-level.level-1 > .mega-item > .mega-level.level-2 .mega-link { padding-left: 28px; }

/* Indent level-3 items for visibility */
.mega-menu .mega-level.level-3 .mega-link { padding-left: 36px; }

/* Hide lazy "show more" buttons on mobile */
body.ffmm-is-mobile .ffmm-expand, .ffmm-wrap.ffmm-mobile .ffmm-expand { display: none !important; }

/* Level backgrounds */
/* .mega-level.level-2 { background: #fafafa; } */
.mega-level.level-3 { background: #f5f5f5; margin-left: 30px; }

/* "All categories" link */
.mega-item.mega-all-link .mega-link { font-weight: 600; color: #1f2937; }
.mega-item.mega-all-link .mega-link:hover { color: #111827; background: var(--ffmm-accent-50); }

/* Level styling */
.mega-level.level-1 > .mega-item > .mega-link { background: #ffffff; font-size: 15px; font-weight: 600; border-left: 4px solid transparent; }
.mega-level.level-1 > .mega-item > .mega-link[aria-expanded="true"] { border-left-color: var(--ffmm-accent); background: var(--ffmm-accent-50); }
.mega-level.level-2 > .mega-item > .mega-link { background: #f9fafb; font-size: 14px; font-weight: 500; border-left: 4px solid var(--ffmm-accent); padding-left: 28px; }
.mega-level.level-2 > .mega-item > .mega-link[aria-expanded="true"] { border-left-color: var(--ffmm-accent-600); background: #fff7f0; }
.mega-level.level-3 > .mega-item > .mega-link { background: #f3f4f6; font-size: 13px; font-weight: 400; border-left: 4px solid var(--ffmm-accent); padding-left: 36px; color: #374151; }
.mega-level.level-3 > .mega-item > .mega-link:hover { background: #e5e7eb; color: #111827; }
.mega-level.level-1 > .mega-item > .mega-link .mega-label { font-size: 16px; font-weight: 600; color: #111827; }
.mega-level.level-2 > .mega-item > .mega-link .mega-label { font-size: 14px; font-weight: 500; color: #374151; }
.mega-level.level-3 > .mega-item > .mega-link .mega-label { font-size: 13px; font-weight: 400; color: #4b5563; }
@media (max-width: 768px) {
  .ffmm-toggle-label {
    display: none;
  }
}