/*** ESSENTIAL STYLES ***/
.sf-contener {
  clear: both;
  float: left;
  width: 100%;
}
.sf-menu,
.sf-menu * {
  margin: 0;
  padding: 0;
  list-style: none;
}
.sf-menu {
  position: relative;
  padding: 0;
  width: 100%;
  border-bottom: 3px solid #e9e9e9;
    /* background: #f6f6f6; */
    background-color: #ffffff;
}
@media (max-width: 767px) {
  .sf-menu {
    display: none;
  }
}
.sf-menu ul {
  position: absolute;
  top: -999em;
    /* background: #f6f6f6; */
    background-color: #ffffff;
   padding: 10px 0; 
}
@media (max-width: 767px) {
  .sf-menu ul {
    top: 0;
    position: relative;
  }
}

.sf-menu > li > a {
  /* font: 600 18px/22px "Open Sans", sans-serif;
    text-transform: uppercase;
    color: #484848;
    display: block;
    padding: 17px 20px;
  font-weight: 500; */
  display: block;
  padding: 0.5rem;
}
.sf-menu .sf-sub-indicator {
  display: none;
}
.sf-menu ul li {
  width: 100%;
}
.sf-menu li:hover {
  visibility: inherit;
  /* fixes IE7 'sticky bug' */
}
.sf-menu > li {
  float: left;
  position: relative;
  /* border-right: 1px solid #eadbdb; */
}

@media (min-width: 768px) {
  .sf-menu > li {
    margin-right: 12px;
}
}

.sf-menu a {
  display: block;
  position: relative;
  color: #000;
}
.sf-menu li:hover ul,
.sf-menu li.sfHover ul {
  left: 0;

  top: 100%;
 /*  match top ul list item height */
  z-index: 99;
  width: auto;
}
ul.sf-menu li:hover li ul,
ul.sf-menu li.sfHover li ul {
  top: -999em;
}
ul.sf-menu li li:hover li ul,
ul.sf-menu li li.sfHover li ul {
  top: -999em;
}

ul.sf-menu li li:hover ul,
ul.sf-menu li li.sfHover ul {
 left: 300px;
 /*   match ul width */
  top: 0;
}
 ul.sf-menu li li li:hover ul,
ul.sf-menu li li li.sfHover ul {
   left: 300px;
 /* match ul width */
  top: 0;
}
/*** DEMO SKIN ***/
.sf-menu {
  float: left;
  margin-bottom: 1em;

}
.sf-menu a {
  display: block;
  /* padding: 5px 22px 5px 20px;
  line-height: 34px; */
  padding: 6px 22px 6px 20px;
  font-size: 16px;
  border: 0;
  text-decoration: none;
}
.sf-menu a,
.sf-menu a:visited {
  color: rgba(0, 0, 0, 0.65);
  white-space: nowrap;
  /*text-shadow: 1px 1px 0px #fff; */
}
.sf-menu li {
  font-weight: 600;
}
.sf-menu li li {
  /* background: rgba(246, 246, 246, 0.9); */
  background-color: #ffffff;
  padding: 0 4px;
  font-weight: 500;
}

.sf-menu li li li {
  /* background: rgba(246, 246, 246, 0.9); */
  background-color: #ffffff;
}
.sf-menu a:focus,
.sf-menu a:hover,
.sf-menu a:active {
  background: rgba(255, 255, 255, 0.98);
}
.sf-menu ul li:hover,
.sf-menu ul li.sfHover,
.sf-menu ul li a:focus,
.sf-menu ul li a:hover,
.sf-menu ul li a:active {
  background: rgba(255, 255, 255, 0.98);
  outline: 0;
}
/*** arrows **/
.sf-sub-indicator {
  position: absolute;
  display: block;
  right: 10px;
  top: 1.05em;
  /* IE6 only */
  width: 10px;
  height: 10px;
  text-indent: -999em;
  overflow: hidden;
}
 .sf-sub-indicator:after {
  content: "▼";
  text-indent: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 10px;
  height: 10px;
  font-size: 10px;
  line-height: 10px;
  color: #333;
} 
a > .sf-sub-indicator {
  /* give all except IE6 the correct values */
  top: 11px;
  background-position: 0 -100px;
  /* use translucent arrow for modern browsers*/
}
/* apply hovers to modern browsers */
a:focus > .sf-sub-indicator,
a:hover > .sf-sub-indicator,
a:active > .sf-sub-indicator,
li:hover > a > .sf-sub-indicator,
li.sfHover > a > .sf-sub-indicator {
  background-position: -10px -100px;
  /* arrow hovers for modern browsers*/
}
/* point right for anchors in subs */
.sf-menu ul .sf-sub-indicator:after {
  content: "▶";
}
.sf-menu ul a > .sf-sub-indicator:after {
  content: "▶";
}
/* apply hovers to modern browsers */
.sf-menu ul a:focus > .sf-sub-indicator,
.sf-menu ul a:hover > .sf-sub-indicator,
.sf-menu ul a:active > .sf-sub-indicator,
.sf-menu ul li:hover > a > .sf-sub-indicator,
.sf-menu ul li.sfHover > a > .sf-sub-indicator {
  background-position: -10px 0;
  /* arrow hovers for modern browsers*/
}
/*** shadows for all but IE6 ***/
.sf-shadow ul {
  /* background: url('../img/shadow.png') no-repeat bottom right;
     */
  /* padding: 0 8px 9px 0;
     */
  -moz-border-bottom-left-radius: 17px;
  -moz-border-top-right-radius: 17px;
  -webkit-border-top-right-radius: 17px;
  -webkit-border-bottom-left-radius: 17px;
}
.sf-shadow ul.sf-shadow-off {
  background: transparent;
}
li.sf-search {
  background: inherit;
  float: right;
  line-height: 25px;
}

li.sf-search input {
  border-radius: 5px;
  padding: 8px 0;
  padding-left: 10px;
  font-size: 16px;
  margin: 6px 6px 0 0;
  background: #ffffff;
  border: 1px solid #eadbdb;
}

/* hack IE7 
.sf-menu a, .sf-menu a:visited {
    height:34px ;
}
.sf-menu li li {
    width:300px;
    background:#726f72 ;
}
.sf-menu .category-thumbnail img {
    max-width:100%;
    height:auto;
}
*/

/* MOBILE STYLES - MAJOR FIX FOR 4TH LEVEL ISSUE */
@media (max-width: 767px) {
  .sf-menu .sf-search {
    display: none !important;
  }
  
  /* FIRST LEVEL TOGGLE ARROWS - Fixed positioning */
  .sf-menu > li span.menu-mobile-grover {
    position: absolute;
    right: 15px;
    top: 26px;
    transform: translateY(-50%);
    width: 25px;
    height: 25px;
    z-index: 2;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #eaeaea;
    border-radius: 50%;
  }
  
  .sf-menu > li span.menu-mobile-grover:before {
    content: "▼";
    font-size: 12px;
    /* color: #333; */
    color: #555555;
    display: block;
    transition: transform 0.3s ease;
    transform-origin: center center;
  }
  
  .sf-menu > li span.menu-mobile-grover.active:before {
    transform: rotate(180deg);
  }
  
  /* SECOND+ LEVEL TOGGLE ARROWS - Fixed positioning */
  .menu-mobile-grover-second {
    position: absolute;
    right: 15px;
    top: 23px;
    transform: translateY(-50%);
    width: 25px;
    height: 25px;
    cursor: pointer;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #eaeaea;
    border-radius: 50%;
  }

  .menu-mobile-grover-second:before {
    content: "▼";
    font-size: 10px;
    color: #333;
    display: block;
    transition: transform 0.3s ease;
    transform-origin: center center;
  }

  .menu-mobile-grover-second.active:before {
    transform: rotate(180deg);
  }
  
  /* Rest of your mobile styles... */


  
  .sf-menu li,
  .sf-menu li ul {
    width: 100% !important;
  }
  
  /* CRITICAL FIX - This fixes the 4th level shifting issue */
  /* Override ALL desktop positioning rules for mobile */
  .sf-menu li:hover ul,
  .sf-menu li.sfHover ul {
    left: 0 !important;
    top: 0 !important;
    position: static !important;
  }
  
  ul.sf-menu li li:hover ul,
  ul.sf-menu li li.sfHover ul {
    left: 0 !important;
    top: 0 !important;
    position: static !important;
  }
  
  ul.sf-menu li li li:hover ul,
  ul.sf-menu li li li.sfHover ul {
    left: 0 !important;
    top: 0 !important;
    position: static !important;
  }
  
  ul.sf-menu li li li li:hover ul,
  ul.sf-menu li li li li.sfHover ul {
    left: 0 !important;
    top: 0 !important;
    position: static !important;
  }
  
  /* Reset all submenu positioning */
  .sf-menu ul {
    position: static !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
  }
  
  .menu-mobile {
    display: none;
  }
  ul.sf-menu li:hover li ul,
  ul.sf-menu li.sfHover li ul {
    top: 0 !important;
    position: static !important;
  }
  
  /* Visual hierarchy with indentation */
  ul.sf-menu li ul li {
    /* padding-left: 25px;
    padding-left: 10px; */
    position: relative;
  }
  
  ul.sf-menu li ul li ul li {
    /* padding-left: 45px; */
  }
  
  ul.sf-menu li ul li ul li ul li {
    padding-left: 65px;
  }
  
  ul.sf-menu li ul li ul li ul li ul li {
    padding-left: 85px;
  }
  
  ul.sf-menu li ul li ul li:before {
    width: 1px;
    height: 44px;
    display: inline-block;
    float: left;
    position: absolute;
    left: 20px;
    background: #ece7e7;
    content: " ";
  }
  
  /* Make sure relative positioning for toggle buttons */
  .menu-mobile li {
    position: relative;
  }

  /* Hide third level by default in mobile */
  .menu-mobile li ul {
    display: none;
  }
  
  /* Better touch targets */
  .sf-menu a {
    min-height: 44px;
    display: flex;
    align-items: center;
    /* padding: 12px 50px 12px 20px; Extra right padding for arrows */
    padding: 0.8rem !important;
  }
  .sf-menu li ul li ul li a{
    padding: 1rem 0;
  }
  /* Visual separation */
  .sf-menu li {
    border-bottom: 1px solid #f0f0f0;
  }
}

.cat-title {
  display: none;
}
@media (max-width: 767px) {
  .cat-title {
    display: block;
    font: 600 18px/22px "Open Sans", sans-serif;
    text-transform: uppercase;
    color: #000545;
    display: block;
    padding: 17px 20px;
    /* border-bottom: 3px solid #e9e9e9;
    background: #f6f6f6; */
    background-color: #ffffff;
    position: relative;
    cursor: pointer;
  }
  .cat-title:hover {
    background: #ff8a00;
    color: #fff;
  }
  .cat-title:after {
    display: block;
    content: "▼";
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 16px;
    transition: transform 0.3s ease;
  }
  .cat-title.active:after {
    transform: translateY(-50%) rotate(180deg);
  }
}
.submenu-container {
  box-shadow: 1px 1px 5px 0px rgba(0, 0, 0, 0.2);
  /* display: grid;
  grid-template-columns: auto auto; */
}
/*  */

.sf-menu li:last-child {
  border: none !important;
}

#block_top_menu {
  padding: 0px;
}

.sf-menu li {
  position: relative !important;
}

@media (min-width: 576px) {
  .sf-menu {
    padding: 0.4rem 7rem 0.4rem 7rem;
  }
  .soso {
    box-shadow: 1px 1px 5px 0px rgba(0, 0, 0, 0.2);
    left: 100% !important;
  }
}

/* Desktop hover improvements */
@media (min-width: 768px) {
  /* Add hover tolerance to prevent menu disappearing */
  .sf-menu ul {
    border: 2px solid transparent;
    margin-left: -2px;
    margin-top: -2px;
  }
  
  .sf-menu li ul {
    margin-left: -1px;
  }
  
  .sf-menu li li ul {
    margin-left: -1px;
    margin-top: -1px;
  }
}

/* Performance optimization */
.sf-menu ul {
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* Z-index management */
.sf-menu {
  z-index: 1000;
}

.sf-menu ul {
  z-index: 1001;
}

.sf-menu ul ul {
  z-index: 1002;
}

.sf-menu ul ul ul {
  z-index: 1003;
}

.sf-menu ul ul ul ul {
  z-index: 1004;
}