/* ============================================================
   FONITEX — HEADER (3-level structure)
   topbar · masthead · mainnav
   Uses own media queries (NOT BS d-md-* which don't exist in classic CSS).
   ============================================================ */

/* Mobile-first defaults */
.fx-mobile-only { display: block; }
.fx-desktop-only { display: none; }

@media (min-width: 768px) {
  .fx-mobile-only { display: none; }
  .fx-desktop-only { display: block; }
}

#header {
  background: #fff;
  box-shadow: var(--fx-shadow-sm);
  border-bottom: 1px solid var(--fx-border);
  margin-bottom: 0;
  padding-bottom: 0;
}

/* Reset some classic styles that interfere */
#header .header-top {
  padding: 0;
}
#header .top-menu {
  margin: 0;
}

/* ============================================================
   1) TOPBAR — slim green bar (DESKTOP ONLY)
   ============================================================ */
.fx-topbar {
  display: none;  /* hidden by default (mobile) */
  background: var(--fx-primary);
  color: #fff;
  font-size: var(--fx-fs-sm);
  border-bottom: 1px solid var(--fx-primary-dark);
}

@media (min-width: 768px) {
  .fx-topbar { display: block; }
}

.fx-topbar-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 36px;
  padding: 4px 0;
  flex-wrap: wrap;
  gap: 12px;
}

.fx-topbar-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.fx-topbar-nav li {
  display: inline-flex;
  align-items: center;
  margin: 0;
}

.fx-topbar-nav a {
  color: #fff;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: var(--fx-transition);
}

.fx-topbar-nav a:hover,
.fx-topbar-nav a:focus {
  color: var(--fx-accent-light);
  text-decoration: none;
}

.fx-topbar-nav .material-icons {
  font-size: 14px;
  vertical-align: middle;
}

.fx-topbar-right { font-weight: var(--fx-fw-medium); }

/* ============================================================
   2) MASTHEAD — logo + search + tools
   ============================================================ */
.fx-masthead {
  background: #fff;
  padding: 12px 0;
}

/* Mobile masthead row */
.fx-masthead-mobile {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  margin-bottom: 12px;
}

.fx-mobile-menu-toggle {
  background: transparent;
  border: 0;
  font-size: 0;
  color: var(--fx-text);
  padding: 6px 8px;
  cursor: pointer;
  border-radius: var(--fx-radius);
  transition: var(--fx-transition);
}
.fx-mobile-menu-toggle .material-icons { font-size: 28px; }
.fx-mobile-menu-toggle:hover,
.fx-mobile-menu-toggle:focus {
  background: var(--fx-bg-alt);
}

.fx-mobile-logo {
  flex: 1 1 auto;
  text-align: center;
  max-width: 160px;
  margin: 0 auto;
}
.fx-mobile-logo img {
  max-width: 100%;
  max-height: 44px;
  height: auto;
  width: auto;
  display: inline-block;
}

.fx-mobile-tools {
  display: flex;
  align-items: center;
  gap: 8px;
}
.fx-mobile-tools a {
  color: var(--fx-text);
  display: inline-flex;
  align-items: center;
  padding: 6px;
  text-decoration: none;
}
.fx-mobile-tools .material-icons { font-size: 26px; }
.fx-mobile-tools .blockcart,
.fx-mobile-tools #_mobile_cart {
  display: inline-flex;
  align-items: center;
}

/* Desktop masthead row */
.fx-masthead-inner {
  display: none;  /* hidden on mobile */
  align-items: center;
  gap: 24px;
}

@media (min-width: 768px) {
  .fx-masthead-mobile { display: none; }
  .fx-masthead-inner { display: flex; }
  .fx-masthead { padding: 18px 0; }
}

.fx-masthead-logo {
  flex: 0 0 auto;
  max-width: 220px;
}
.fx-masthead-logo img,
.fx-logo-h1 img {
  max-width: 100%;
  max-height: 60px;
  height: auto;
  width: auto;
  display: block;
}
.fx-logo-h1 {
  margin: 0;
  font-size: 0;
  line-height: 0;
}

.fx-masthead-search {
  flex: 1 1 auto;
  max-width: 720px;
  width: 100%;
}

/* === SEARCH BAR — strong overrides on ps_searchbar === */
.fx-masthead-search #search_widget,
.fx-mobile-search #search_widget {
  margin: 0 !important;
  overflow: visible !important;
  width: 100%;
}

.fx-masthead-search #search_widget form,
.fx-mobile-search #search_widget form {
  position: relative;
  width: 100%;
}

.fx-masthead-search #search_widget form input[type="text"],
.fx-mobile-search #search_widget form input[type="text"],
#header .fx-masthead-search input[name="s"],
#header .fx-mobile-search input[name="s"] {
  width: 100% !important;
  height: 44px !important;
  padding: 0 56px 0 44px !important;
  border: 2px solid var(--fx-primary) !important;
  border-radius: var(--fx-radius-pill) !important;
  background: #fff !important;
  outline: none !important;
  font-size: 14px !important;
  color: var(--fx-text) !important;
  -webkit-appearance: none !important;
}

.fx-masthead-search #search_widget form input[type="text"]:focus,
.fx-mobile-search #search_widget form input[type="text"]:focus {
  border-color: var(--fx-primary-dark) !important;
  box-shadow: 0 0 0 3px rgba(0,136,114,.15) !important;
}

.fx-masthead-search #search_widget form i.search,
.fx-mobile-search #search_widget form i.search {
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  padding: 0 !important;
  color: var(--fx-primary) !important;
  font-size: 22px !important;
  pointer-events: none;
}

.fx-masthead-search #search_widget form i.clear,
.fx-mobile-search #search_widget form i.clear {
  position: absolute !important;
  right: 14px !important;
  left: auto !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  padding: 0 !important;
  color: var(--fx-text-muted) !important;
}

/* === TOOLS (desktop right area) === */
.fx-masthead-tools {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 18px;
}

.fx-masthead-tools > div {
  display: flex;
  align-items: center;
}

.fx-masthead-tools a {
  color: var(--fx-text);
  font-size: var(--fx-fs-sm);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  transition: var(--fx-transition);
}

.fx-masthead-tools a:hover,
.fx-masthead-tools a:focus { color: var(--fx-primary); }

.fx-masthead-tools .material-icons { font-size: 22px; }

.fx-masthead-tools .blockcart {
  background: var(--fx-bg-alt);
  padding: 8px 14px;
  border-radius: var(--fx-radius-pill);
  font-weight: var(--fx-fw-medium);
}
.fx-masthead-tools .blockcart.active { background: var(--fx-accent); color: #fff; }
.fx-masthead-tools .blockcart.active a,
.fx-masthead-tools .blockcart.active .cart-products-count { color: #fff; }
.fx-masthead-tools .cart-products-count {
  background: var(--fx-accent);
  color: #fff;
  border-radius: var(--fx-radius-pill);
  padding: 2px 8px;
  font-size: 11px;
  font-weight: var(--fx-fw-bold);
  margin-left: 4px;
}

.fx-masthead-tools .dropdown-toggle::after { margin-left: 4px; }

/* ============================================================
   3) MAINNAV — horizontal menu (DESKTOP ONLY)
   ============================================================ */
.fx-mainnav {
  display: none;
  background: var(--fx-bg-alt);
  border-top: 1px solid var(--fx-border);
  border-bottom: 1px solid var(--fx-border);
}

@media (min-width: 768px) {
  .fx-mainnav { display: block; }
}

.fx-mainnav-inner {
  display: flex;
  align-items: center;
  min-height: 48px;
}

/* Style ps_mainmenu output */
.fx-mainnav .top-menu,
.fx-mainnav ul.top-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: 100%;
}

.fx-mainnav .top-menu > li {
  position: relative;
  display: inline-block;
  margin: 0;
}

.fx-mainnav .top-menu > li > a {
  display: inline-flex;
  align-items: center;
  padding: 14px 18px;
  color: var(--fx-text);
  font-weight: var(--fx-fw-medium);
  font-size: 14px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .3px;
  transition: var(--fx-transition);
  border-bottom: 3px solid transparent;
}

.fx-mainnav .top-menu > li:hover > a,
.fx-mainnav .top-menu > li.current > a,
.fx-mainnav .top-menu > li.sfHoverForce > a {
  color: var(--fx-primary);
  border-bottom-color: var(--fx-primary);
  background: transparent;
}

.fx-mainnav .top-menu .sub-menu,
.fx-mainnav .top-menu ul.sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  list-style: none;
  margin: 0;
  padding: 8px 0;
  min-width: 240px;
  border: 1px solid var(--fx-border);
  border-top: 3px solid var(--fx-primary);
  box-shadow: var(--fx-shadow);
  z-index: 999;
  display: none;
}

.fx-mainnav .top-menu > li:hover > .sub-menu,
.fx-mainnav .top-menu > li:hover > ul.sub-menu { display: block; }

.fx-mainnav .top-menu .sub-menu li a {
  display: block;
  padding: 8px 18px;
  color: var(--fx-text);
  font-size: 13px;
  text-decoration: none;
  transition: var(--fx-transition);
}

.fx-mainnav .top-menu .sub-menu li a:hover,
.fx-mainnav .top-menu .sub-menu li a:focus {
  background: var(--fx-bg-alt);
  color: var(--fx-primary);
  padding-left: 22px;
}

/* Mobile menu drawer (when hamburger toggled) */
#mobile_top_menu_wrapper.fx-mobile-menu-wrapper {
  background: #fff;
  border-top: 1px solid var(--fx-border);
  padding: 12px 0;
}
#mobile_top_menu_wrapper .top-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
#mobile_top_menu_wrapper .top-menu li a {
  display: block;
  padding: 12px 16px;
  color: var(--fx-text);
  text-decoration: none;
  border-bottom: 1px solid var(--fx-border-light);
}
#mobile_top_menu_wrapper .top-menu li a:hover { color: var(--fx-primary); }

/* ============================================================
   Mobile cart wrapping (the blockcart inside #_mobile_cart)
   ============================================================ */
#_mobile_cart .blockcart,
.fx-mobile-cart-wrap .blockcart {
  background: var(--fx-bg-alt);
  padding: 6px 10px;
  border-radius: var(--fx-radius-pill);
  display: inline-flex;
  align-items: center;
  font-weight: var(--fx-fw-medium);
}
#_mobile_cart .blockcart.active,
.fx-mobile-cart-wrap .blockcart.active {
  background: var(--fx-accent);
  color: #fff;
}
#_mobile_cart .cart-products-count,
.fx-mobile-cart-wrap .cart-products-count {
  background: var(--fx-accent);
  color: #fff;
  border-radius: var(--fx-radius-pill);
  padding: 2px 8px;
  font-size: 11px;
  font-weight: var(--fx-fw-bold);
  margin-left: 4px;
}
