/* ================================================================
   FIFOZONE PREMIUM HEADER CSS v5.1
   Compact · Sticky · Premium Hover System · All Links Clickable
   ================================================================ */

/* ── DESIGN TOKENS ── */
:root {
  --fifo-orange:       #f07021;
  --fifo-orange-dark:  #d95f15;
  --fifo-orange-glow:  rgba(240,112,33,0.15);
  --fifo-dark:         #1b1c2e;
  --fifo-text:         #4b5563;
  --fifo-muted:        #9ca3af;
  --fifo-border:       #e5e7eb;
  --fifo-white:        #ffffff;
  --fifo-surface:      #f8fafc;
  --fifo-surface-soft: #f1f5f9;

  --fifo-r-sm:  8px;
  --fifo-r-md:  12px;
  --fifo-r-lg:  16px;

  --fifo-shadow-xs: 0 1px 4px rgba(0,0,0,0.06);
  --fifo-shadow-sm: 0 2px 10px rgba(0,0,0,0.08);
  --fifo-shadow-md: 0 6px 20px rgba(0,0,0,0.10);
  --fifo-shadow-lg: 0 16px 40px rgba(0,0,0,0.13);

  --fifo-ease:   cubic-bezier(0.4,0,0.2,1);
  --fifo-spring: cubic-bezier(0.34,1.56,0.64,1);
  --fifo-t-fast: 0.18s;
  --fifo-t-base: 0.24s;

  --fifo-c-dogs:     #f07021;
  --fifo-c-cats:     #8b5cf6;
  --fifo-c-food:     #10b981;
  --fifo-c-pharmacy: #3b82f6;
  --fifo-c-grooming: #0e8f98;
  --fifo-c-small:    #d5a62f;
  --fifo-c-large:    #7a5a33;

  --fifo-g-grooming: linear-gradient(135deg, #0e8f98 0%, #2fc7bd 100%);
  --fifo-g-small:    linear-gradient(135deg, #f6c95f 0%, #d39d1b 100%);
  --fifo-g-large:    linear-gradient(135deg, #7a5a33 0%, #b97843 100%);

  --fifo-topbar-h:  64px;
  --fifo-navbar-h:  44px;
}

/* ================================================================
   RESET
   ================================================================ */
#fifo-header *, #fifo-header *::before, #fifo-header *::after {
  box-sizing: border-box;
}

/* ================================================================
   HEADER SHELL
   ================================================================ */
#fifo-header {
  position: sticky;
  top: 0;
  z-index: 9999;
  width: 100%;
  background: var(--fifo-white);
  border-bottom: 1px solid rgba(148,163,184,0.15);
  box-shadow: var(--fifo-shadow-xs);
  transition: box-shadow var(--fifo-t-base) var(--fifo-ease),
              background var(--fifo-t-base) var(--fifo-ease);
  will-change: box-shadow;
}

#fifo-header.fifo-header--scrolled {
  box-shadow: 0 8px 28px rgba(15,23,42,0.11);
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

#fifo-header.fifo-header--scrolled .fifo-top-bar   { min-height: 52px; }
#fifo-header.fifo-header--scrolled .fifo-logo img  { height: 28px; }
#fifo-header.fifo-header--scrolled .fifo-nav-container { height: 36px; }

/* ================================================================
   TOP BAR
   ================================================================ */
.fifo-top-bar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  padding: 10px 20px;
  min-height: var(--fifo-topbar-h);
  transition: min-height var(--fifo-t-base) var(--fifo-ease),
              padding    var(--fifo-t-base) var(--fifo-ease);
}

/* ================================================================
   LOGO
   ================================================================ */
.fifo-logo { flex-shrink: 0; line-height: 0; }

.fifo-logo a {
  display: block;
  text-decoration: none;
  transition: opacity var(--fifo-t-fast) var(--fifo-ease),
              transform var(--fifo-t-fast) var(--fifo-spring);
}
.fifo-logo a:hover { opacity: 0.85; transform: scale(1.02); }

.fifo-logo img {
  height: 34px;
  width: auto;
  display: block;
  transition: height var(--fifo-t-base) var(--fifo-ease);
}

.fifo-logo-text {
  font-family: 'Poppins', sans-serif;
  font-size: 20px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--fifo-orange) 0%, #ff8c42 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.5px;
}

/* ================================================================
   SEARCH
   ================================================================ */
.fifo-search-wrapper {
  flex: 1;
  max-width: 500px;
  min-width: 160px;
}
.fifo-search-form { width: 100%; }

.fifo-search-input-group {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--fifo-surface);
  border: 1.5px solid var(--fifo-border);
  border-radius: var(--fifo-r-md);
  height: 40px;
  padding: 0 6px 0 12px;
  transition: border-color var(--fifo-t-fast) var(--fifo-ease),
              box-shadow   var(--fifo-t-fast) var(--fifo-ease),
              background   var(--fifo-t-fast) var(--fifo-ease),
              transform    var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-search-input-group:focus-within {
  border-color: var(--fifo-orange);
  box-shadow: 0 0 0 3px var(--fifo-orange-glow);
  background: var(--fifo-white);
  transform: translateY(-1px);
}

.fifo-search-icon-left {
  width: 16px; height: 16px;
  color: var(--fifo-muted);
  flex-shrink: 0;
  transition: color var(--fifo-t-fast) var(--fifo-ease);
  pointer-events: none;
}
.fifo-search-input-group:focus-within .fifo-search-icon-left { color: var(--fifo-orange); }

.fifo-search-input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 0;
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--fifo-dark);
  outline: none;
  min-width: 0;
}
.fifo-search-input::placeholder { color: var(--fifo-muted); }

.fifo-search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  border: none;
  background: var(--fifo-orange);
  color: white;
  border-radius: var(--fifo-r-sm);
  cursor: pointer;
  padding: 0;
  transition: background  var(--fifo-t-fast) var(--fifo-ease),
              transform   var(--fifo-t-fast) var(--fifo-spring),
              box-shadow  var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-search-btn:hover {
  background: var(--fifo-orange-dark);
  transform: scale(1.08);
  box-shadow: 0 4px 12px rgba(240,112,33,0.35);
}
.fifo-search-btn svg { width: 16px; height: 16px; pointer-events: none; }

.fifo-search-suggestions {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: #ffffff;
  border: 1px solid var(--fifo-border);
  border-radius: var(--fifo-r-md);
  box-shadow: var(--fifo-shadow-lg);
  overflow: hidden;
  z-index: 10020;
}

.search-suggest-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  text-decoration: none;
  color: var(--fifo-dark);
  border-bottom: 1px solid #f1f5f9;
}

.search-suggest-item:last-child {
  border-bottom: none;
}

.search-suggest-item:hover {
  background: #f8fafc;
}

.search-suggest-item img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  border-radius: 10px;
  background: #f8fafc;
}

.search-suggest-item span {
  flex: 1;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.35;
}

.search-suggest-item strong {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--fifo-orange);
  white-space: nowrap;
}

/* ================================================================
   DELIVERY BUTTON
   ================================================================ */
.fifo-delivery-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(125deg, #ffffff 0%, #f8fbff 65%, #f1f6ff 100%);
  border: 1.5px solid #d8e2ee;
  border-radius: 14px;
  min-width: 156px;
  padding: 7px 12px;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  flex-shrink: 0;
  transition: border-color var(--fifo-t-fast) var(--fifo-ease),
              box-shadow   var(--fifo-t-fast) var(--fifo-ease),
              transform    var(--fifo-t-fast) var(--fifo-spring),
              background   var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-delivery-btn:hover {
  border-color: #c9d8ea;
  box-shadow: 0 8px 24px rgba(30, 64, 175, 0.12);
  transform: translateY(-1px);
  background: var(--fifo-white);
}

.fifo-location-icon {
  width: 19px; height: 19px;
  color: #2563eb;
  flex-shrink: 0;
  pointer-events: none;
  transition: transform var(--fifo-t-fast) var(--fifo-spring);
}
.fifo-delivery-btn:hover .fifo-location-icon { transform: scale(1.15); }

.fifo-delivery-text { display: flex; flex-direction: column; gap: 1px; text-align: left; }
.fifo-delivery-label {
  font-size: 9px; font-weight: 700; color: #64748b;
  text-transform: uppercase; letter-spacing: 0.6px; line-height: 1;
}
.fifo-delivery-value {
  font-size: 13px; font-weight: 700; color: #0f172a; line-height: 1;
  transition: color var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-delivery-btn:hover .fifo-delivery-value { color: #1d4ed8; }

.fifo-delivery-chevron {
  width: 14px; height: 14px; color: var(--fifo-muted); pointer-events: none;
  transition: transform var(--fifo-t-fast) var(--fifo-ease),
              color     var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-delivery-btn[aria-expanded="true"] .fifo-delivery-chevron {
  transform: rotate(180deg); color: var(--fifo-orange);
}

/* ================================================================
   HEADER ICONS
   ================================================================ */
.fifo-header-icons { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }

.fifo-icon-link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px; height: 42px;
  background: var(--fifo-surface);
  border: 1.5px solid var(--fifo-border);
  border-radius: var(--fifo-r-md);
  color: var(--fifo-text);
  text-decoration: none;
  transition: background   var(--fifo-t-fast) var(--fifo-ease),
              border-color var(--fifo-t-fast) var(--fifo-ease),
              color        var(--fifo-t-fast) var(--fifo-ease),
              transform    var(--fifo-t-fast) var(--fifo-spring),
              box-shadow   var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-icon-link:hover {
  background: var(--fifo-orange-glow);
  border-color: rgba(240,112,33,0.3);
  color: var(--fifo-orange);
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 6px 18px var(--fifo-orange-glow);
}
.fifo-icon-svg { width: 21px; height: 21px; pointer-events: none; }

/* Tooltip */
.fifo-icon-tooltip {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--fifo-dark);
  color: white;
  font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 600;
  padding: 4px 8px;
  border-radius: 6px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--fifo-t-fast) var(--fifo-ease),
              transform var(--fifo-t-fast) var(--fifo-ease);
  z-index: 10;
}
.fifo-icon-tooltip::after {
  content: '';
  position: absolute;
  top: 100%; left: 50%; transform: translateX(-50%);
  border: 4px solid transparent;
  border-top-color: var(--fifo-dark);
}
.fifo-icon-link:hover .fifo-icon-tooltip {
  opacity: 1; transform: translateX(-50%) translateY(0);
}

/* Cart badge */
.fifo-cart-badge {
  position: absolute;
  top: -5px; right: -5px;
  background: var(--fifo-orange);
  color: white;
  font-family: 'Inter', sans-serif;
  font-size: 9px; font-weight: 700;
  min-width: 18px; height: 18px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 2px solid var(--fifo-white);
  padding: 0 3px;
  transition: transform var(--fifo-t-fast) var(--fifo-spring);
  pointer-events: none;
}
.fifo-cart-link:hover .fifo-cart-badge { transform: scale(1.15); }

/* ================================================================
   HAMBURGER
   ================================================================ */
.fifo-hamburger-btn {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: var(--fifo-surface);
  border: 1.5px solid var(--fifo-border);
  border-radius: var(--fifo-r-sm);
  padding: 9px;
  cursor: pointer;
  transition: border-color var(--fifo-t-fast) var(--fifo-ease),
              background   var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-hamburger-btn:hover { border-color: var(--fifo-orange); background: var(--fifo-orange-glow); }

.fifo-hamburger-line {
  width: 20px; height: 2px;
  background: var(--fifo-text);
  border-radius: 2px;
  display: block;
  transition: transform 0.28s var(--fifo-ease), opacity 0.2s ease, background 0.2s ease;
}
.fifo-hamburger-btn:hover .fifo-hamburger-line { background: var(--fifo-orange); }
.fifo-hamburger-btn[aria-expanded="true"] .fifo-hamburger-line:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.fifo-hamburger-btn[aria-expanded="true"] .fifo-hamburger-line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.fifo-hamburger-btn[aria-expanded="true"] .fifo-hamburger-line:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* ================================================================
   NAVIGATION BAR
   ================================================================ */
.fifo-navigation {
  background: var(--fifo-white);
  border-top: 1px solid rgba(148,163,184,0.12);
}

.fifo-nav-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--fifo-navbar-h);
  gap: 3px;
  transition: height var(--fifo-t-base) var(--fifo-ease);
}

/* ── Plain nav link (Home, Blog, About Us, Contact Us) ── */
.fifo-nav-link {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  padding: 0 10px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--fifo-text);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--fifo-t-fast) var(--fifo-ease);
  cursor: pointer;
  /* Ensure nothing blocks clicks */
  z-index: 2;
}
.fifo-nav-link::after {
  content: '';
  position: absolute;
  bottom: 0; left: 11px; right: 11px;
  height: 2px;
  background: var(--fifo-orange);
  border-radius: 2px 2px 0 0;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.26s var(--fifo-ease);
  pointer-events: none;
}
.fifo-nav-link:hover,
.fifo-nav-link.fifo-active { color: var(--fifo-orange); }
.fifo-nav-link:hover::after,
.fifo-nav-link.fifo-active::after { transform: scaleX(1); transform-origin: left; }

/* ── Dropdown wrapper ── */
.fifo-nav-dropdown {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  /* CRITICAL: do NOT set pointer-events:none here */
}

/* ── Category label link — MUST be fully clickable ── */
.fifo-nav-trigger-link {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  padding: 0 2px 0 10px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--fifo-text);
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  z-index: 3;                  /* sits above the mega-menu backdrop */
  transition: color var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-nav-trigger-link::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--fifo-orange);
  border-radius: 2px 2px 0 0;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.26s var(--fifo-ease);
  pointer-events: none;
}
.fifo-nav-dropdown:hover .fifo-nav-trigger-link,
.fifo-nav-dropdown.is-open .fifo-nav-trigger-link { color: var(--fifo-orange); }
.fifo-nav-dropdown:hover .fifo-nav-trigger-link::after,
.fifo-nav-dropdown.is-open .fifo-nav-trigger-link::after { transform: scaleX(1); transform-origin: left; }

/* Category colour overrides */
.fifo-nav-dropdown[data-section="dogs"]:hover     .fifo-nav-trigger-link,
.fifo-nav-dropdown[data-section="dogs"].is-open   .fifo-nav-trigger-link { color: var(--fifo-c-dogs); }
.fifo-nav-dropdown[data-section="dogs"] .fifo-nav-trigger-link::after    { background: var(--fifo-c-dogs); }

.fifo-nav-dropdown[data-section="cats"]:hover     .fifo-nav-trigger-link,
.fifo-nav-dropdown[data-section="cats"].is-open   .fifo-nav-trigger-link { color: var(--fifo-c-cats); }
.fifo-nav-dropdown[data-section="cats"] .fifo-nav-trigger-link::after    { background: var(--fifo-c-cats); }

.fifo-nav-dropdown[data-section="food"]:hover     .fifo-nav-trigger-link,
.fifo-nav-dropdown[data-section="food"].is-open   .fifo-nav-trigger-link { color: var(--fifo-c-food); }
.fifo-nav-dropdown[data-section="food"] .fifo-nav-trigger-link::after    { background: var(--fifo-c-food); }

.fifo-nav-dropdown[data-section="pharmacy"]:hover   .fifo-nav-trigger-link,
.fifo-nav-dropdown[data-section="pharmacy"].is-open .fifo-nav-trigger-link { color: var(--fifo-c-pharmacy); }
.fifo-nav-dropdown[data-section="pharmacy"] .fifo-nav-trigger-link::after  { background: var(--fifo-c-pharmacy); }

.fifo-nav-dropdown[data-section="grooming"]:hover   .fifo-nav-trigger-link,
.fifo-nav-dropdown[data-section="grooming"].is-open .fifo-nav-trigger-link { color: var(--fifo-c-grooming); }
.fifo-nav-dropdown[data-section="grooming"] .fifo-nav-trigger-link::after  { background: var(--fifo-c-grooming); }

.fifo-nav-dropdown[data-section="small-pets"]:hover   .fifo-nav-trigger-link,
.fifo-nav-dropdown[data-section="small-pets"].is-open .fifo-nav-trigger-link { color: var(--fifo-c-small); }
.fifo-nav-dropdown[data-section="small-pets"] .fifo-nav-trigger-link::after  { background: var(--fifo-c-small); }

.fifo-nav-dropdown[data-section="large-pets"]:hover   .fifo-nav-trigger-link,
.fifo-nav-dropdown[data-section="large-pets"].is-open .fifo-nav-trigger-link { color: var(--fifo-c-large); }
.fifo-nav-dropdown[data-section="large-pets"] .fifo-nav-trigger-link::after  { background: var(--fifo-c-large); }

/* ── Chevron button ── */
.fifo-nav-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  padding: 0 6px 0 1px;
  margin: 0;
  cursor: pointer;
  color: var(--fifo-muted);
  height: 100%;
  z-index: 3;
  transition: color var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-nav-trigger:hover { color: var(--fifo-orange); }

.fifo-dropdown-chevron {
  width: 12px; height: 12px;
  pointer-events: none;
  transition: transform var(--fifo-t-base) var(--fifo-ease);
}
.fifo-nav-trigger[aria-expanded="true"] .fifo-dropdown-chevron { transform: rotate(180deg); }

/* ================================================================
   MEGA MENU PANEL
   CRITICAL: pointer-events:none when hidden, auto when shown
   The panel must NOT sit on top of the trigger-link
   ================================================================ */
.fifo-mega-menu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 700px;
  max-width: 880px;
  background: var(--fifo-white);
  border: 1px solid rgba(148,163,184,0.18);
  border-top: none;
  border-radius: 0 var(--fifo-r-lg) var(--fifo-r-lg) var(--fifo-r-lg);
  box-shadow: var(--fifo-shadow-lg);
  z-index: 1001;             /* above everything except the header shell */

  /* Hidden state */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;     /* CRITICAL: hidden panel must not block nav links */
  transform: translateY(8px);

  max-height: calc(100vh - 140px);
  overflow-y: auto;
  transition: opacity    var(--fifo-t-base) var(--fifo-ease),
              transform  var(--fifo-t-base) var(--fifo-ease),
              visibility var(--fifo-t-base) var(--fifo-ease);
  will-change: opacity, transform;
}

/* Shown state — restore pointer-events */
.fifo-mega-menu.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;   /* CRITICAL: allow clicks on links inside */
  transform: translateY(0);
}

/* ── Mega menu header (clickable "Browse all X") ── */
.fifo-mega-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 22px 11px;
  border-bottom: 1px solid var(--fifo-border);
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
}

.fifo-mega-header-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: var(--fifo-dark);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: color var(--fifo-t-fast) var(--fifo-ease),
              gap   var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-mega-header-link:hover { color: var(--fifo-orange); gap: 12px; }

.fifo-mega-header-arrow {
  width: 16px; height: 16px;
  pointer-events: none;
  transition: transform var(--fifo-t-fast) var(--fifo-spring);
}
.fifo-mega-header-link:hover .fifo-mega-header-arrow { transform: translateX(3px); }

.fifo-mega-header-tagline {
  font-family: 'Inter', sans-serif;
  font-size: 11.5px;
  color: var(--fifo-muted);
  font-weight: 500;
}

/* Category accent stripe at top of dropdown */
.fifo-nav-dropdown[data-section="dogs"]      .fifo-mega-menu { border-top: 3px solid var(--fifo-c-dogs); }
.fifo-nav-dropdown[data-section="cats"]      .fifo-mega-menu { border-top: 3px solid var(--fifo-c-cats); }
.fifo-nav-dropdown[data-section="food"]      .fifo-mega-menu { border-top: 3px solid var(--fifo-c-food); }
.fifo-nav-dropdown[data-section="pharmacy"]  .fifo-mega-menu { border-top: 3px solid var(--fifo-c-pharmacy); }
.fifo-nav-dropdown[data-section="grooming"]  .fifo-mega-menu { border-top: 3px solid var(--fifo-c-grooming); }
.fifo-nav-dropdown[data-section="small-pets"] .fifo-mega-menu { border-top: 3px solid var(--fifo-c-small); }
.fifo-nav-dropdown[data-section="large-pets"] .fifo-mega-menu { border-top: 3px solid var(--fifo-c-large); }

.fifo-nav-dropdown[data-section="grooming"] .fifo-mega-header {
  background: linear-gradient(90deg, rgba(14,143,152,0.12) 0%, rgba(47,199,189,0.07) 100%);
}

.fifo-nav-dropdown[data-section="small-pets"] .fifo-mega-header {
  background: linear-gradient(90deg, rgba(246,201,95,0.2) 0%, rgba(211,157,27,0.08) 100%);
}

.fifo-nav-dropdown[data-section="large-pets"] .fifo-mega-header {
  background: linear-gradient(90deg, rgba(122,90,51,0.16) 0%, rgba(185,120,67,0.09) 100%);
}

/* Dogs override — border-top:none was set above, re-add with colour */
.fifo-nav-dropdown[data-section="dogs"] .fifo-mega-menu { border-top: 3px solid var(--fifo-c-dogs) !important; }

/* ── Sub-category grid ── */
.fifo-mega-menu-content {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 18px 22px 20px;
}

.fifo-mega-column {
  padding: 0 14px 0 0;
  border-right: 1px solid var(--fifo-border);
}
.fifo-mega-column:last-child { border-right: none; padding-right: 0; }
.fifo-mega-column + .fifo-mega-column { padding-left: 14px; }

.fifo-mega-column-title {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--fifo-dark);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: color var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-mega-column-title:hover { color: var(--fifo-orange); }

.fifo-mega-column ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 2px;
}

.fifo-mega-column li a {
  display: flex;
  align-items: center;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--fifo-text);
  text-decoration: none;
  padding: 6px 8px;
  border-radius: var(--fifo-r-sm);
  cursor: pointer;
  transition: color      var(--fifo-t-fast) var(--fifo-ease),
              background var(--fifo-t-fast) var(--fifo-ease),
              transform  var(--fifo-t-fast) var(--fifo-ease),
              box-shadow var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-mega-column li a:hover {
  color: var(--fifo-orange);
  background: rgba(240,112,33,0.08);
  transform: translateX(3px);
  box-shadow: inset 2px 0 0 var(--fifo-orange);
}

.fifo-nav-dropdown[data-section="grooming"] .fifo-mega-column li a:hover {
  color: #0f766e;
  background: rgba(14, 143, 152, 0.12);
  box-shadow: inset 2px 0 0 #0e8f98;
}

.fifo-nav-dropdown[data-section="small-pets"] .fifo-mega-column li a:hover {
  color: #9a6e06;
  background: rgba(233, 185, 65, 0.18);
  box-shadow: inset 2px 0 0 #d39d1b;
}

.fifo-nav-dropdown[data-section="large-pets"] .fifo-mega-column li a:hover {
  color: #5a3e22;
  background: rgba(160, 113, 74, 0.14);
  box-shadow: inset 2px 0 0 #8b5e34;
}

.fifo-mega-sublist {
  list-style: none;
  margin: 4px 0 0 10px;
  padding: 0 0 0 10px;
  border-left: 2px solid var(--fifo-surface-soft);
  display: flex; flex-direction: column; gap: 2px;
}
.fifo-mega-sublist a { font-size: 12px; color: #6b7280; }
.fifo-mega-sublist--flat { margin: 0; padding: 0; border-left: none; }

/* Scrollbar inside mega menu */
.fifo-mega-menu::-webkit-scrollbar { width: 5px; }
.fifo-mega-menu::-webkit-scrollbar-track { background: transparent; }
.fifo-mega-menu::-webkit-scrollbar-thumb { background: var(--fifo-border); border-radius: 3px; }

/* ================================================================
   BACKDROP (closes panels on click-outside)
   Must be BELOW the nav items but ABOVE page content
   ================================================================ */
.fifo-mega-menu-backdrop, .fifo-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,0.22);
  backdrop-filter: blur(2px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 9998;           /* below header (9999) but above page */
  transition: opacity    var(--fifo-t-base) var(--fifo-ease),
              visibility var(--fifo-t-base) var(--fifo-ease);
}
.fifo-mega-menu-backdrop.show, .fifo-backdrop.fifo-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* ================================================================
   MOBILE CLOSE (inside drawer)
   ================================================================ */
.fifo-mobile-close {
  display: none;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  padding: 16px 20px 12px;
  font-family: 'Inter', sans-serif;
  font-size: 14px; font-weight: 600;
  color: var(--fifo-text);
  cursor: pointer;
  width: 100%;
  border-bottom: 1px solid var(--fifo-border);
  margin-bottom: 4px;
  transition: color var(--fifo-t-fast);
}
.fifo-mobile-close:hover { color: var(--fifo-orange); }
.fifo-mobile-close svg { width: 20px; height: 20px; pointer-events: none; }

/* ================================================================
   DELIVERY MODAL
   ================================================================ */
.fifo-delivery-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.fifo-delivery-modal[hidden] { display: none !important; }

.fifo-delivery-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15,23,42,0.52);
  backdrop-filter: blur(4px);
  cursor: pointer;
}

.fifo-delivery-modal-box {
  position: relative;
  z-index: 1;
  background: var(--fifo-white);
  border-radius: var(--fifo-r-lg);
  padding: 32px 28px;
  width: 100%;
  max-width: 380px;
  box-shadow: var(--fifo-shadow-lg);
  text-align: center;
  animation: fifoModalIn 0.28s var(--fifo-spring) both;
}
@keyframes fifoModalIn {
  from { opacity: 0; transform: translateY(16px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.fifo-delivery-modal-close {
  position: absolute;
  top: 14px; right: 14px;
  background: var(--fifo-surface);
  border: none; border-radius: 50%;
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: var(--fifo-text);
  transition: background var(--fifo-t-fast), color var(--fifo-t-fast),
              transform  var(--fifo-t-fast) var(--fifo-spring);
}
.fifo-delivery-modal-close:hover {
  background: rgba(240,112,33,0.12);
  color: var(--fifo-orange);
  transform: rotate(90deg) scale(1.1);
}
.fifo-delivery-modal-close svg { width: 18px; height: 18px; pointer-events: none; }

.fifo-modal-icon-wrap {
  width: 56px; height: 56px;
  background: linear-gradient(135deg, #fff3ea, #ffe0c8);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px;
}
.fifo-modal-icon-wrap svg { width: 26px; height: 26px; color: var(--fifo-orange); pointer-events: none; }

.fifo-modal-title {
  font-family: 'Poppins', sans-serif;
  font-size: 20px; font-weight: 700; color: var(--fifo-dark);
  margin: 0 0 6px;
}
.fifo-modal-desc {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px; color: var(--fifo-muted);
  margin: 0 0 20px;
}

.fifo-pincode-row { display: flex; gap: 8px; }

.fifo-pincode-input {
  flex: 1;
  height: 44px;
  padding: 0 14px;
  border: 1.5px solid var(--fifo-border);
  border-radius: var(--fifo-r-md);
  font-family: 'Inter', sans-serif;
  font-size: 15px; font-weight: 600;
  color: var(--fifo-dark);
  background: var(--fifo-surface);
  outline: none;
  letter-spacing: 2px;
  text-align: center;
  transition: border-color var(--fifo-t-fast), box-shadow var(--fifo-t-fast);
}
.fifo-pincode-input:focus {
  border-color: var(--fifo-orange);
  box-shadow: 0 0 0 3px var(--fifo-orange-glow);
  background: var(--fifo-white);
}
.fifo-pincode-input::placeholder { letter-spacing: 0; font-size: 12.5px; font-weight: 400; }

.fifo-pincode-submit {
  height: 44px; padding: 0 20px;
  background: var(--fifo-orange); color: white;
  border: none; border-radius: var(--fifo-r-md);
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 700;
  cursor: pointer; white-space: nowrap;
  transition: background var(--fifo-t-fast) var(--fifo-ease),
              transform  var(--fifo-t-fast) var(--fifo-spring),
              box-shadow var(--fifo-t-fast) var(--fifo-ease);
}
.fifo-pincode-submit:hover {
  background: var(--fifo-orange-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(240,112,33,0.35);
}

.fifo-pincode-error {
  color: #ef4444;
  font-family: 'Inter', sans-serif;
  font-size: 12px; margin: 8px 0 0;
  text-align: left;
}

/* ================================================================
   RESPONSIVE — TABLET ≤ 1024px
   ================================================================ */
@media (max-width: 1024px) {
  .fifo-mega-menu         { min-width: 560px; }
  .fifo-mega-menu-content { grid-template-columns: repeat(2,1fr); padding: 14px 16px; }
  .fifo-nav-trigger-link  { font-size: 12.5px; padding-left: 7px; }
  .fifo-nav-link          { font-size: 12.5px; padding: 0 7px; }
  .fifo-search-wrapper    { max-width: 360px; }
  .fifo-delivery-btn      { min-width: 138px; padding: 7px 10px; }
}

/* ================================================================
   RESPONSIVE — MOBILE ≤ 768px
   Desktop nav is hidden. Mobile menu is in mobile-menu.css.
   ================================================================ */
@media (max-width: 768px) {
  .fifo-hamburger-btn  { display: flex; }
  .fifo-account-link   { display: none; }
  .fifo-delivery-label { display: none; }

  .fifo-top-bar { padding: 8px 14px; gap: 8px; min-height: auto; }
  .fifo-logo img { height: 28px; }
  .fifo-search-wrapper { max-width: none; flex: 1; min-width: 100px; }
  .fifo-search-input-group { height: 36px; }

  /* Hide the desktop navigation bar completely on mobile */
  .fifo-navigation {
    display: none !important;
  }

  /* Hide old close button (no longer used) */
  .fifo-mobile-close { display: none !important; }

  /* Keep backdrop for desktop mega menu fallback */
  .fifo-backdrop { z-index: 99998; background: rgba(15,23,42,0.5); }
}

/* ================================================================
   RESPONSIVE — SMALL MOBILE ≤ 480px
   ================================================================ */
@media (max-width: 480px) {
  .fifo-delivery-btn { display: none; }
  .fifo-header-icons { gap: 4px; }
  .fifo-icon-link    { width: 38px; height: 38px; }
  .fifo-icon-svg     { width: 19px; height: 19px; }
  .fifo-top-bar      { padding: 8px 12px; }
  .fifo-search-input { font-size: 12px; }
}

/* ================================================================
   FOCUS / ACCESSIBILITY
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

.fifo-nav-trigger:focus-visible,
.fifo-nav-link:focus-visible,
.fifo-nav-trigger-link:focus-visible,
.fifo-icon-link:focus-visible,
.fifo-search-btn:focus-visible,
.fifo-delivery-btn:focus-visible {
  outline: 2px solid var(--fifo-orange);
  outline-offset: 2px;
}

/* ================================================================
   GLOBAL HOVER & ANIMATION SYSTEM
   ================================================================ */

/* ── WooCommerce / Elementor buttons ── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .single_add_to_cart_button,
.woocommerce .checkout-button,
.elementor-button,
a.button {
  transition: background    0.22s ease,
              color         0.22s ease,
              transform     0.20s cubic-bezier(0.34,1.56,0.64,1),
              box-shadow    0.22s ease,
              border-color  0.22s ease !important;
  will-change: transform;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce .single_add_to_cart_button:hover,
.elementor-button:hover,
a.button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 22px rgba(240,112,33,0.28) !important;
}

/* ── Product cards ── */
.woocommerce ul.products li.product,
.product-card,
[class*="product-item"] {
  transition: transform 0.26s ease, box-shadow 0.26s ease !important;
  will-change: transform;
}
.woocommerce ul.products li.product:hover,
.product-card:hover,
[class*="product-item"]:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 16px 40px rgba(15,23,42,0.12) !important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__link img,
.product-card img {
  transition: transform 0.36s ease;
}
.woocommerce ul.products li.product:hover .woocommerce-loop-product__link img,
.product-card:hover img { transform: scale(1.06); }

/* ── Footer links ── */
.site-footer a, footer a, [class*="footer"] a {
  transition: color 0.18s ease, transform 0.18s cubic-bezier(0.34,1.56,0.64,1);
  display: inline-block;
}
.site-footer a:hover, footer a:hover, [class*="footer"] a:hover {
  color: var(--fifo-orange) !important;
  transform: translateX(3px);
}

/* ── Social icons ── */
[class*="social"] a, .elementor-social-icons-wrapper a {
  transition: color 0.18s ease, background 0.18s ease,
              transform 0.20s cubic-bezier(0.34,1.56,0.64,1),
              box-shadow 0.18s ease !important;
}
[class*="social"] a:hover, .elementor-social-icons-wrapper a:hover {
  transform: translateY(-3px) scale(1.12) !important;
  box-shadow: 0 8px 18px rgba(0,0,0,0.15) !important;
}

/* ── Form fields ── */
input[type="text"]:not(.fifo-search-input):not(.fifo-pincode-input),
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
select,
textarea {
  transition: border-color 0.18s ease, box-shadow 0.18s ease !important;
}
input[type="text"]:not(.fifo-search-input):focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
select:focus,
textarea:focus {
  border-color: var(--fifo-orange) !important;
  box-shadow: 0 0 0 3px rgba(240,112,33,0.12) !important;
  outline: none !important;
}

/* ================================================================
   SEARCH SUGGESTIONS - FIXED v4.2 (new structure support)
   ================================================================ */
.search-suggest-section-label {
  padding: 8px 14px 4px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #94a3b8;
  background: #f8fafc;
}

.search-suggest-divider {
  height: 1px;
  background: #f1f5f9;
  margin: 4px 0;
}

.search-suggest-info {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px;
  flex: 1;
}

.search-suggest-name {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #1e293b;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.search-suggest-cat-lbl {
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #94a3b8 !important;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.search-suggest-price {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  white-space: nowrap;
  flex-shrink: 0;
}

.search-suggest-price del {
  font-size: 11px;
  color: #94a3b8;
}

.search-suggest-price strong {
  font-size: 14px !important;
  font-weight: 800 !important;
  color: #7c3aed !important;
}

.search-suggest-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 6px;
  background: #fef3c7;
  color: #d97706;
}

.search-suggest-badge.search-suggest-oos {
  background: #fee2e2;
  color: #dc2626;
}

.search-suggest-cat {
  background: #fafafa;
}

.search-suggest-cat-icon {
  font-size: 18px;
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex !important;
  align-items: center;
  justify-content: center;
  background: #f1f5f9;
  border-radius: 10px;
}

.search-suggest-count {
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #94a3b8 !important;
}

.search-suggest-all {
  display: block;
  padding: 12px 14px;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: #7c3aed;
  background: #faf5ff;
  border-top: 1px solid #e9d5ff;
  text-decoration: none;
  transition: background .15s;
}

.search-suggest-all:hover {
  background: #f3e8ff;
  color: #5b21b6;
}

.search-suggest-empty {
  padding: 20px 14px;
  text-align: center;
  font-size: 13px;
  color: #94a3b8;
  font-style: italic;
}