/* =============================
   MASTER HEADER STYLES
   ============================= */

.header.fixed-top {
  font-family: var(--body);
  background: #ffffff !important;
  z-index: 1040 !important;
  transition: all 0.3s var(--ease);
  border-bottom: 1px solid #f0f0f0;
}

/* =============================
   GLOBAL ORANGE SCROLLBAR
   (applies to every page that loads header.css)
   ============================= */

/* Chrome, Edge, Safari */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 10px;
}

::-webkit-scrollbar-thumb {
  background: #fe7021;
  border-radius: 10px;
  border: 2px solid #f1f1f1;
}

::-webkit-scrollbar-thumb:hover {
  background: #e65a1b;
}

::-webkit-scrollbar-corner {
  background: #f1f1f1;
}

/* Firefox */
html {
  scrollbar-width: thin;
  scrollbar-color: #fe7021 #f1f1f1;
}

/* =============================
   FULL ZOOM-OUT SAFETY
   Ensures images & content don't overflow
   or break at very wide / zoomed-out viewports
   ============================= */

/* Prevent any element from causing horizontal overflow */
body {
  overflow-x: hidden;
}

/* All images — always contain themselves */
img {
  max-width: 100% !important;
  height: auto;
}

/* Images that use absolute positioning (hero, card, banner)
   must stay within their parent at any viewport width */
.hero-bg,
.hero-bg-left img,
.hero-collage img,
.hc-card img,
.fbanner img,
.dotd-img img,
.ocard-img img,
.season-wrap img,
.cc-img,
.fb-lg img,
.fb-sm img {
  max-width: none !important;  /* absolute-positioned images fill container */
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Container fluid — prevent runaway width on 4K / zoom-out */
.header .container-fluid {
  max-width: 1400px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 48px !important; /* Match content .wrap padding */
  padding-right: 48px !important;
}

/* Very large screens (4K / extreme zoom-out):
   extra horizontal padding so content doesn't look
   wall-to-wall stretched */
@media (min-width: 1920px) {
  .header .container-fluid {
    max-width: 1600px !important;
  }
}

@media (min-width: 2560px) {
  .header .container-fluid {
    max-width: 1800px !important;
    padding-left: 60px !important;
    padding-right: 60px !important;
  }
}

/* =============================
   HERO SPACING (overlapping header)
   ============================= */
body {
  padding-top: 0 !important;
}

.hero, .page-hero, .hero-banner, .collections-hero, .offers-hero {
  padding-top: 82px !important;
}

@media (max-width: 1023px) {
  .header .container-fluid {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .logo { order: 1 !important; } /* Logo on the left */
  .header__action-items { order: 2 !important; } /* Toggler on the right */

  .header__main { 
    justify-content: space-between !important;
    height: 54px !important; /* Slightly more compact Zara/H&M style */
  }

  
  .mobile-menu-toggler {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    outline: none !important;
  }
  
  .mobile-menu-toggler .navbar-toggler-icon i {
    color: #132742 !important; /* Brand Navy as per image */
    font-size: 24px !important;
  }
}

/* Logo — shrinks a little if needed, never wraps */
.logo {
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
}

.logo__img {
  display: block !important;
  height: 35px !important;
  width: auto !important;
  max-width: 180px !important;
  object-fit: contain !important;
  transition: height 0.3s ease, max-width 0.3s ease !important;
}

/* Navbar fills ALL remaining space between logo and toggler */
/* (This logic is now handled by .navbar-collapse directly in the flat structure) */

/* navbar-collapse — also must shrink */
.navbar-collapse {
  min-width: 0 !important;
}

/* Action items (toggler) on the far right — never shrinks */
.header__action-items {
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
}

/* =============================
   TOGGLER BUTTON — visible only on screens < 1024px
   ============================= */
@media (min-width: 1024px) {
  .mobile-menu-toggler,
  .mobile-menu-close-btn,
  .mobile-menu-overlay {
    display: none !important;
  }
}

.mobile-menu-toggler {
  display: none; /* Inherit display flex via JS/Mobile Query */

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: none !important; /* Removed frame */
  border-radius: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  outline: none !important;
  box-shadow: none !important;
}

.mobile-menu-toggler:hover {
  border-color: #fe7021 !important;
  background: #fff3eb !important;
}

.mobile-menu-toggler .navbar-toggler-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.mobile-menu-toggler .navbar-toggler-icon i {
  font-size: 1.2rem !important;
  color: #333333 !important;
  line-height: 1 !important;
}

.mobile-menu-toggler:hover .navbar-toggler-icon i {
  color: #fe7021 !important;
}

/* =============================
   1024px LAPTOP + LARGE DESKTOP + 4K — show inline nav
   ============================= */
@media (min-width: 1024px) {

  /* Show nav inline, hide toggler. Fills space between logo and actions. */
  .navbar-collapse {
    display: flex !important;
    flex: 1 1 0% !important;   /* grow+shrink from zero basis */
    min-width: 0 !important;
    align-items: center !important;
    justify-content: flex-end !important;
    visibility: visible !important;
    position: static !important;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    overflow: visible !important;
    left: auto !important;
  }

  .nav-links-wrap {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
  }

  /* Hide toggler & overlay on 1024px+ */
  .mobile-menu-toggler,
  .mobile-menu-close-btn,
  .mobile-menu-overlay {
    display: none !important;
  }
}

/* =============================
   NAV LINKS — Base (desktop+)
   ============================= */
.header .nav-link {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 14.5px !important;
  font-weight: 400 !important;
  color: #333333 !important;
  padding: 0.2rem 0 !important;
  margin: 0 !important;
  transition: all 0.3s ease !important;
  white-space: nowrap !important;
  background: transparent !important;
  border: none !important;
}

.header .nav-link:hover,
.header .nav-link.active {
  color: #fe7021 !important;
  background: transparent !important;
}

/* Orange Underline Effect for Desktop Header Components */
@media (min-width: 1024px) {
  .header .nav-link {
    position: relative !important;
  }

  .header .nav-link::after {
    content: '' !important;
    position: absolute !important;
    bottom: -2px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: 2px !important;
    background-color: #fe7021 !important;
    transition: transform 0.3s ease-in-out !important;
    transform: scaleX(0) !important;
    transform-origin: center !important;
  }

  .header .nav-link:hover::after,
  .header .nav-link.active::after,
  .categories-dropdown:hover .nav-link::after {
    transform: scaleX(1) !important;
  }
}

/* Nav Item Spacing (Now part of nav-links-wrap) */
.nav-links-wrap > * {
  margin-right: 0;
}

.dropdown-item:hover {
  background-color: #f8f9fa !important;
  color: #fe7021 !important;
  transition: all 0.3s ease !important;
}

.categories-dropdown {
  position: relative !important;
}

.dropdown-menu {
  display: none;
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1050;
  transform: translateY(-10px);
  transform-origin: top left;
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease !important;
}

.dropdown-menu.show,
.categories-dropdown:hover .dropdown-menu {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) !important;
}

/* ══ Categories-specific positioning reference ══ */
.categories-dropdown .dropdown-menu {
  top: 84.8px !important;
  position: fixed !important;
  margin: 0 !important;
}

@media (max-width: 1023px) {
  .navbar-collapse .categories-dropdown {
    position: relative !important;
  }

  .navbar-collapse .dropdown-menu {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    z-index: 1060 !important;
  }
}

/* ── 1024px – 1159px: tightened Zara style to fit 7 items in one row ── */
@media (min-width: 1024px) and (max-width: 1159px) {
  .header .nav-link {
    font-size: 11.8px !important;
    letter-spacing: -0.01em !important;
    padding: 0.2rem 4px !important; /* Minimized side padding to avoid wrapping */
  }
  .nav-links-wrap > * {
    margin-right: 8px !important;
  }
  .logo__img {
    height: 34px !important;
    max-width: 140px !important;
  }
  .header__main {
    padding: 0 16px !important;
    height: 52px !important;
  }
}

/* ── 1160px – 1279px: comfortable ── */
@media (min-width: 1160px) and (max-width: 1279px) {
  .header .nav-link {
    font-size: 13px !important;
  }
  .nav-links-wrap > *:not(:last-child) {
    margin-right: 16px !important;
  }
  .logo__img {
    height: 42px !important;
    max-width: 150px !important;
  }
  .header__main {
    padding: 0 20px !important;
  }
}

/* ── 1280px+: full spacing ── */
@media (min-width: 1280px) {
  .header .nav-link {
    font-size: 15px !important;
  }
  .nav-links-wrap > *:not(:last-child) {
    margin-right: 20px !important;
  }
}

/* =============================
   CART ICON
   ============================= */
.cart-icon {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #333333 !important;
  font-size: 1.3rem !important;
  margin-right: 1.5rem !important;
  text-decoration: none !important;
  width: 40px !important;
  height: 40px !important;
}

.cart-icon:hover {
  color: #fe7021 !important;
}

.cart-badge {
  position: absolute !important;
  top: -5px !important;
  right: -5px !important;
  background-color: #fe7021 !important;
  color: #ffffff !important;
  border-radius: 50% !important;
  width: 20px !important;
  height: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.7rem !important;
  font-weight: bold !important;
}

/* =============================
   MOBILE / TABLET SIDEBAR
   (all screens < 1024px)
   ============================= */

/* Overlay backdrop — above header (1040), below sidebar panel (1045) */
.mobile-menu-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.45);
  z-index: 1041;
  backdrop-filter: blur(2px);
}

/* Sidebar panel — hidden off-screen to the LEFT by default */
@media (max-width: 1023px) {


  .mobile-menu-overlay {
    display: none; /* shown via JS */
  }

  .navbar-collapse {
    position: fixed !important;
    top: 0 !important;
    left: -320px !important;
    width: 300px !important;
    height: 100vh !important;
    background: #ffffff !important;
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.12) !important;
    transition: left 0.3s ease, visibility 0.3s ease !important;
    z-index: 1045 !important;
    overflow-y: auto !important;
    padding: 88px 24px 32px !important;
    visibility: hidden !important;
    display: block !important;
  }

  .navbar-collapse.show {
    left: 0 !important;
    visibility: visible !important;
  }

  /* Close button inside sidebar */
  .mobile-menu-close-btn {
    position: absolute !important;
    top: 18px !important;
    right: 18px !important;
    width: 38px !important;
    height: 38px !important;
    background: #f8f9fa !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    color: #333 !important;
    font-size: 1rem !important;
    transition: all 0.2s ease !important;
    z-index: 1046 !important;
  }

  .mobile-menu-close-btn:hover {
    background: #fe7021 !important;
    border-color: #fe7021 !important;
    color: #ffffff !important;
    transform: rotate(90deg) !important;
  }

  /* Sidebar brand logo area at the top */
  .sidebar-brand {
    display: block !important;
    margin-bottom: 24px !important;
  }

  /* Nav items in sidebar — stacked vertically */
  .nav-links-wrap {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    width: 100% !important;
    gap: 4px !important;
  }

  .nav-links-wrap > * {
    margin-right: 0 !important;
    margin-bottom: 0 !important;
    width: 100% !important;
  }

  .header .nav-link {
    font-size: 15px !important;
    font-weight: 400 !important;
    padding: 11px 16px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    border-radius: 10px !important;
    color: #333 !important;
    transition: background 0.2s ease, color 0.2s ease !important;
  }

  .header .nav-link:hover {
    background: #fff3eb !important;
    color: #fe7021 !important;
  }

  .header .nav-link.active {
    background: #fff3eb !important;
    color: #fe7021 !important;
    font-weight: 600 !important;
  }

  /* Divider between nav groups */
  .nav-links-wrap .nav-divider {
    width: 100% !important;
    height: 1px !important;
    background: #f0f0f0 !important;
    margin: 8px 0 !important;
  }
}

/* =============================
   SMALL MOBILE (< 480px)
   ============================= */
@media (max-width: 479px) {
  .header__main {
    padding: 0 10px !important; /* Minimized for corner placement */
    height: 48px !important;
  }

  .logo__img {
    height: 36px !important; /* Larger relative height for premium feel */
    max-width: 150px !important;
  }

  .mobile-menu-toggler {
    padding: 4px !important; /* Minimized for corner placement */
  }
}

/* =============================
   MEDIUM MOBILE (480px – 767px)
   ============================= */
@media (min-width: 480px) and (max-width: 767px) {
  .header__main {
    padding: 0 12px !important;
    height: 50px !important;
  }

  .logo__img {
    height: 40px !important;
  }
}

/* =============================
   LARGE MOBILE / TABLET (768px – 1023px)
   ============================= */
@media (min-width: 768px) and (max-width: 1023px) {
  .header__main {
    padding: 0 14px !important;
    height: 52px !important;
  }


  .logo__img {
    max-width: 220px !important;
  }
}


/* =============================
   1024px+ LAPTOP BASELINE
   Fine-tuned by sub-ranges above in NAV LINKS section
   ============================= */
@media (min-width: 1024px) {
  .header__main {
    height: 52px !important;
    overflow: visible !important;  /* allow dropdown to show */
  }

  /* navbar-collapse must not cause overflow */
  .navbar-collapse {
    overflow: visible !important;
    max-width: 100% !important;
  }

  /* nav-links-wrap row — compress instead of wrap */
  .nav-links-wrap {
    flex-wrap: nowrap !important;
    overflow: visible !important;
  }
}
