/**
 * Exploria - Cinematic Header Styles
 * Premium Travel Theme Enhancement
 * Version: 2.1.0
 *
 * HOW TO USE:
 *   Paste the FULL contents of this file into your theme's style.css,
 *   replacing the previous "Cinematic Header Styles" block entirely.
 *
 * CHANGES FROM 2.0.0:
 *   - FIX: Corrected header centering (was left:35%, now left:50% + translateX(-50%))
 *   - FIX: header-ready transform now chains translateX(-50%) correctly
 *   - NEW: .header--hidden / .header--visible for hide-on-scroll-down behaviour
 *   - NEW: Mobile overlay backdrop (#mobile-menu-overlay)
 *   - NEW: Accordion submenu styles for mobile
 *   - NEW: Submenu toggle button styles
 *   - IMPROVED: Perfect flex centering on header-inner for all breakpoints
 */

/* ============================================
   CSS CUSTOM PROPERTIES - Exploria DESIGN SYSTEM
   ============================================ */
:root {
  /* Primary Colors */
  --color-primary: #2563eb;
  --color-primary-rgb: 37, 99, 235;
  --color-primary-dark: #1d4ed8;
  --color-primary-light: #3b82f6;
  --color-accent: #f59e0b;
  --color-accent-light: #fbbf24;

  /* Glass Effect Colors */
  --glass-bg: rgba(255, 255, 255, 0.55);
  --glass-bg-scrolled: rgba(255, 255, 255, 0.88);
  --glass-border: rgba(255, 255, 255, 0.4);
  --glass-blur: 14px;
  --glass-blur-scrolled: 22px;
  --glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  --glass-shadow-scrolled: 0 12px 48px rgba(0, 0, 0, 0.15);

  /* Text Colors */
  --color-text-primary: #1e293b;
  --color-text-primary-rgb: 30, 41, 59;
  --color-text-secondary: #374151;
  --color-text-secondary-rgb: 55, 65, 81;
  --color-text-muted: #6b7280;
  --color-text-muted-rgb: 107, 114, 128;

  /* Header Dimensions */
  --header-height: 72px;
  --header-height-scrolled: 60px;
  --header-max-width: 1180px;
  --header-offset: 20px;
  --header-side-padding: 24px;
  --header-border-radius: 16px;

  /* Animation Timings */
  --transition-fast: 150ms;
  --transition-normal: 250ms;
  --transition-slow: 700ms;
  --transition-header: 480ms cubic-bezier(.22, .61, .36, 1);
  --ease-out-expo: cubic-bezier(.16, 1, .3, 1);
  --ease-spring: cubic-bezier(.34, 1.56, .64, 1);

  /* Z-Index Layers */
  --z-header: 1000;
  --z-mega-menu: 1001;
  --z-mobile-overlay: 998;
  --z-mobile-nav: 999;
  --z-overlay: 1100;
  --z-modal: 1200;
  --z-cursor: 9999;
}

/* Dark Mode Variables */
[data-theme="dark"],
.dark-mode {
  --glass-bg: rgba(15, 23, 42, 0.65);
  --glass-bg-scrolled: rgba(15, 23, 42, 0.92);
  --glass-border: rgba(255, 255, 255, 0.1);
  --glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  --glass-shadow-scrolled: 0 12px 48px rgba(0, 0, 0, 0.4);
  --color-text-primary: #f1f5f9;
  --color-text-secondary: #cbd5e1;
  --color-text-muted: #94a3b8;
}

/* ============================================
   BODY / PAGE BASE
   ============================================ */
body {
  overflow-x: hidden;
}

#page {
  overflow-x: hidden;
  position: relative;
}

/* ============================================
   FLOATING HEADER BASE
   === FIX: was left:35% — now properly centred ===
   ============================================ */
.site-header {
  position: fixed;
  /* === FIX: centre horizontally at all times === */
  left: 50%;
  top: var(--header-offset);
  width: calc(100% - 48px);       /* 24px breathing room each side */
  max-width: var(--header-max-width);
  z-index: var(--z-header);

  /* Initial state: invisible, slid up off-screen */
  opacity: 0;
  /* === FIX: translateX(-50%) keeps it centred; translateY(-120px) hides it above viewport === */
  transform: translateX(-50%) translateY(-120px);

  transition:
    opacity  var(--transition-header),
    transform var(--transition-header),
    top      var(--transition-slow) var(--ease-out-expo),
    box-shadow var(--transition-slow) var(--ease-out-expo);

  pointer-events: none;

  /* GPU acceleration */
  will-change: transform, opacity;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

/* === LOAD ANIMATION: header-ready fires 100ms after DOMContentLoaded === */
.site-header.header-ready {
  opacity: 1;
  /* === FIX: must keep translateX(-50%) or the header jumps right === */
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

/* === NEW: Hide on scroll DOWN === */
.site-header.header--hidden {
  opacity: 0;
  transform: translateX(-50%) translateY(-110%);
  pointer-events: none;
}

/* === NEW: Visible override (scroll UP after being hidden) === */
.site-header.header--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

/* ============================================
   Main Header Wrapper - Liquid Glass
   ============================================ */
.main-header-wrapper {
  position: relative;
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border);
  border-radius: var(--header-border-radius);
  box-shadow: var(--glass-shadow);
  overflow: visible;
  transition:
    background   var(--transition-slow) var(--ease-out-expo),
    box-shadow   var(--transition-slow) var(--ease-out-expo),
    border-radius var(--transition-slow) var(--ease-out-expo);
}

/* Top specular highlight */
.main-header-wrapper::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.6) 20%,
    rgba(255, 255, 255, 0.8) 50%,
    rgba(255, 255, 255, 0.6) 80%,
    transparent 100%
  );
  border-radius: var(--header-border-radius) var(--header-border-radius) 0 0;
  z-index: 1;
  pointer-events: none;
}

/* Inner glow */
.main-header-wrapper::after {
  content: '';
  position: absolute;
  top: 1px;
  left: 10%;
  right: 10%;
  height: 40%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, transparent 100%);
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
}

/* ============================================
   HEADER INNER — perfect three-column flex layout
   === IMPROVED: explicit grid-like flex for reliable centering ===
   ============================================ */
.header-inner {
  display: flex;
  align-items: center;
  height: var(--header-height);
  padding: 0 var(--header-side-padding);
  position: relative;
  z-index: 2;
  transition: height var(--transition-slow) var(--ease-out-expo);
  gap: 0;
}

/* Logo always left */
.site-branding {
  display: flex;
  align-items: center;
  flex: 0 0 auto;           /* never shrink/grow */
  z-index: 10;
}

/* === FIX: Navigation truly centred — takes remaining space, centres content === */
.main-navigation {
  display: flex;
  align-items: center;
  flex: 1 1 auto;
  justify-content: center;
  position: relative;
  z-index: 5;
  /* Prevent nav pushing actions off-screen on tighter viewports */
  overflow: visible;
}

/* === FIX: Actions always right, never pushed by nav === */
.header-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 0 0 auto;
  z-index: 10;
  margin-left: auto;         /* ensures right-alignment when nav is short */
}

/* ============================================
   SCROLLED STATE
   ============================================ */
.site-header.scrolled {
  top: 10px;
}

.site-header.scrolled .main-header-wrapper {
  background: var(--glass-bg-scrolled);
  backdrop-filter: blur(var(--glass-blur-scrolled));
  -webkit-backdrop-filter: blur(var(--glass-blur-scrolled));
  box-shadow: var(--glass-shadow-scrolled);
  border-radius: calc(var(--header-border-radius) * 0.875);
}

.site-header.scrolled .header-inner {
  height: var(--header-height-scrolled);
}

/* ============================================
   SITE BRANDING / LOGO
   ============================================ */
.site-logo-link {
  display: flex;
  align-items: center;
  text-decoration: none;
  transition: transform var(--transition-normal) var(--ease-out-expo);
}

.site-logo-link:hover {
  transform: scale(1.02);
}

.site-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap;
}

.site-branding img {
  max-height: 40px;
  width: auto;
  transition: max-height var(--transition-slow) var(--ease-out-expo),
              transform   var(--transition-normal) var(--ease-out-expo);
}

.site-header.scrolled .site-branding img {
  max-height: 32px;
}

/* ============================================
   MAIN NAVIGATION - PRIMARY MENU
   ============================================ */
.primary-menu {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.primary-menu > li {
  position: relative;
}

.primary-menu > li > a {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  position: relative;
  transition:
    color var(--transition-fast),
    transform var(--transition-normal) var(--ease-spring);
  border-radius: 8px;
  white-space: nowrap;
}

.primary-menu > li > a:hover {
  color: var(--color-primary);
}

/* Magnetic Hover Transform - Applied via JS */
.primary-menu > li > a.magnetic-hover {
  transform: translate(var(--magnet-x, 0), var(--magnet-y, 0)) scale(var(--magnet-scale, 1));
}

/* Animated Underline */
.primary-menu > li > a::after {
  content: '';
  position: absolute;
  bottom: 6px;
  left: 50%;
  width: calc(100% - 28px);
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
  border-radius: 2px;
  transform: translateX(-50%) scaleX(0);
  transform-origin: center;
  transition: transform var(--transition-normal) var(--ease-out-expo);
  pointer-events: none;
}

.primary-menu > li > a:hover::after,
.primary-menu > li.current-menu-item > a::after,
.primary-menu > li.current-menu-ancestor > a::after {
  transform: translateX(-50%) scaleX(1);
}

.primary-menu > li.current-menu-item > a,
.primary-menu > li.current-menu-ancestor > a {
  color: var(--color-primary);
}

/* Dropdown chevron */
.primary-menu > li.menu-item-has-children > a {
  padding-right: 30px;
}

.primary-menu > li.menu-item-has-children > a::before {
  content: '';
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-55%) rotate(0deg);
  width: 6px;
  height: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transition: transform var(--transition-fast);
}

.primary-menu > li.menu-item-has-children:hover > a::before,
.primary-menu > li.menu-item--open > a::before {
  transform: translateY(-35%) rotate(225deg);
}

/* ============================================
   3D MEGA MENU DROPDOWN
   ============================================ */
.primary-menu .sub-menu,
.primary-menu .mega-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(16px) perspective(1000px) rotateX(-6deg);
  min-width: 240px;
  padding: 10px 0;
  background: var(--glass-bg);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.15),
    0 0 0 1px rgba(255, 255, 255, 0.1) inset;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity   var(--transition-slow) var(--ease-out-expo),
    transform var(--transition-slow) var(--ease-out-expo),
    visibility var(--transition-slow);
  z-index: var(--z-mega-menu);
}

.primary-menu .sub-menu::before,
.primary-menu .mega-menu::before {
  content: '';
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 14px;
  height: 14px;
  background: var(--glass-bg);
  border-left: 1px solid var(--glass-border);
  border-top: 1px solid var(--glass-border);
  backdrop-filter: blur(22px);
  border-radius: 2px 0 0 0;
}

.primary-menu > li:hover > .sub-menu,
.primary-menu > li:hover > .mega-menu,
.primary-menu > li.menu-item--open > .sub-menu,
.primary-menu > li.menu-item--open > .mega-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0) perspective(1000px) rotateX(0);
}

.sub-menu li { list-style: none; }

.sub-menu li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 20px;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition:
    background var(--transition-fast),
    color     var(--transition-fast),
    transform var(--transition-fast);
}

.sub-menu li a:hover {
  background: rgba(var(--color-primary-rgb), 0.08);
  color: var(--color-primary);
  transform: translateX(4px);
}

/* ============================================
   FULL-WIDTH MEGA MENU
   ============================================ */
.mega-menu {
  min-width: 800px;
  max-width: calc(100vw - 80px);
  padding: 24px;
}

.mega-menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 24px;
}

.mega-menu-column {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mega-menu-heading {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  padding: 0 0 8px;
  border-bottom: 1px solid var(--glass-border);
  margin-bottom: 8px;
}

/* ============================================
   DESTINATION PREVIEW CARDS
   ============================================ */
.destination-preview-menu {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 24px;
  min-width: 700px;
}

.destinations-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.destination-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 16px;
  border-radius: 12px;
  cursor: pointer;
  transition:
    background var(--transition-fast),
    transform  var(--transition-fast);
}

.destination-item:hover,
.destination-item.active {
  background: rgba(var(--color-primary-rgb), 0.08);
  transform: translateX(4px);
}

.destination-icon {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  overflow: hidden;
  flex-shrink: 0;
  background: linear-gradient(135deg, #e0e7ff 0%, #c7d2fe 100%);
}

.destination-icon img { width: 100%; height: 100%; object-fit: cover; }

.destination-info h4 {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 4px;
}

.destination-info p {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  margin: 0;
}

.destination-preview-image {
  width: 280px;
  height: 200px;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  flex-shrink: 0;
}

.destination-preview-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow) var(--ease-out-expo);
}

.destination-item:hover .destination-preview-image img,
.destination-item.active .destination-preview-image img {
  transform: scale(1.05);
}

.preview-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 16px;
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.7));
  color: white;
}

.preview-overlay h5 { font-size: 1rem; font-weight: 600; margin: 0; }
.preview-overlay span { font-size: 0.75rem; opacity: 0.8; }

/* ============================================
   INTERACTIVE GLOBE IN MEGA MENU
   ============================================ */
.mega-menu-globe {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 24px;
  min-width: 750px;
}

.globe-container {
  width: 300px;
  height: 300px;
  position: relative;
  flex-shrink: 0;
}

.Exploria-globe {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: linear-gradient(135deg, #1e3a5f 0%, #0f172a 100%);
  position: relative;
  overflow: hidden;
  box-shadow:
    inset -25px -25px 40px rgba(0, 0, 0, 0.5),
    inset 10px 10px 20px rgba(255, 255, 255, 0.1),
    0 0 40px rgba(37, 99, 235, 0.3);
  animation: globe-rotate 30s linear infinite;
}

@keyframes globe-rotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.globe-lines {
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 18px, rgba(255,255,255,.03) 18px, rgba(255,255,255,.03) 19px),
    repeating-linear-gradient(90deg, transparent, transparent 18px, rgba(255,255,255,.03) 18px, rgba(255,255,255,.03) 19px);
  border-radius: 50%;
  animation: globe-lines-counter 30s linear infinite;
}

@keyframes globe-lines-counter {
  from { transform: rotate(0deg); }
  to   { transform: rotate(-360deg); }
}

.globe-marker {
  position: absolute;
  width: 12px;
  height: 12px;
  background: var(--color-accent);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 10px var(--color-accent);
  cursor: pointer;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  z-index: 5;
}

.globe-marker::before {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  border: 2px solid var(--color-accent);
  border-radius: 50%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0.5;
  animation: marker-pulse 2s ease-out infinite;
}

@keyframes marker-pulse {
  0%   { transform: translate(-50%, -50%) scale(1); opacity: 0.5; }
  100% { transform: translate(-50%, -50%) scale(2); opacity: 0; }
}

.globe-marker:hover {
  transform: translate(-50%, -50%) scale(1.5);
  box-shadow: 0 0 20px var(--color-accent);
}

.globe-marker-tooltip {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  padding: 8px 12px;
  background: rgba(15, 23, 42, 0.95);
  color: white;
  font-size: 0.75rem;
  font-weight: 500;
  white-space: nowrap;
  border-radius: 6px;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  pointer-events: none;
}

.globe-marker:hover .globe-marker-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.globe-destinations {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 280px;
  overflow-y: auto;
}

.globe-destination-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  cursor: pointer;
  transition: background var(--transition-fast), transform var(--transition-fast);
}

.globe-destination-item:hover {
  background: rgba(var(--color-primary-rgb), 0.08);
  transform: translateX(4px);
}

.globe-destination-item img { width: 36px; height: 36px; border-radius: 8px; object-fit: cover; }
.globe-destination-item span { font-size: 0.875rem; font-weight: 500; color: var(--color-text-primary); }

/* ============================================
   HEADER ACTION ICON BUTTONS
   ============================================ */
.header-icon-btn,
.header-search button,
.account-toggle,
.mobile-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  background: transparent;
  border-radius: 10px;
  cursor: pointer;
  position: relative;
  transition:
    background var(--transition-fast),
    transform  var(--transition-fast) var(--ease-spring),
    color      var(--transition-fast);
  color: var(--color-text-secondary);
  flex-shrink: 0;
}

.header-icon-btn:hover,
.header-search button:hover,
.account-toggle:hover {
  background: rgba(var(--color-primary-rgb), 0.1);
  color: var(--color-primary);
  transform: scale(1.08);
}

.header-icon-btn:active,
.header-search button:active {
  transform: scale(0.95);
}

.header-icon-btn svg,
.header-search svg,
.account-toggle svg {
  width: 20px;
  height: 20px;
  transition: transform var(--transition-fast) var(--ease-spring);
}

.header-icon-btn:hover svg,
.header-search button:hover svg,
.account-toggle:hover svg {
  transform: scale(1.1);
}

/* ============================================
   CART WITH COUNT BADGE
   ============================================ */
.header-cart {
  position: relative;
}

.header-cart__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  color: var(--color-text-secondary);
  transition:
    background var(--transition-fast),
    transform  var(--transition-fast) var(--ease-spring),
    color      var(--transition-fast);
}

.header-cart__link:hover {
  background: rgba(var(--color-primary-rgb), 0.1);
  color: var(--color-primary);
  transform: scale(1.08);
}

.header-cart__icon { width: 20px; height: 20px; }

.header-cart__count {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 17px;
  height: 17px;
  padding: 0 4px;
  font-size: 0.6rem;
  font-weight: 700;
  color: white;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: badge-pop var(--transition-normal) var(--ease-spring);
}

@keyframes badge-pop {
  0%   { transform: scale(0); }
  60%  { transform: scale(1.25); }
  100% { transform: scale(1); }
}

/* ============================================
   CINEMATIC MINI CART
   ============================================ */
.mini-cart {
  position: absolute;
  top: calc(100% + 14px);
  right: 0;
  width: 360px;
  max-height: 560px;
  background: var(--glass-bg);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.2),
    0 0 0 1px rgba(255, 255, 255, 0.1) inset;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px) scale(0.96);
  transition:
    opacity    var(--transition-slow) var(--ease-out-expo),
    transform  var(--transition-slow) var(--ease-out-expo),
    visibility var(--transition-slow);
  z-index: var(--z-mega-menu);
  overflow: hidden;
}

.header-cart:hover .mini-cart,
.header-cart.open .mini-cart {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.mini-cart__inner { padding: 20px; }

.mini-cart .woocommerce-mini-cart {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  max-height: 300px;
  overflow-y: auto;
}

.mini-cart .woocommerce-mini-cart-item {
  position: relative;
  display: grid;
  grid-template-columns: 64px 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 14px;
  row-gap: 4px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--glass-border);
}

.mini-cart .woocommerce-mini-cart-item:last-child {
  border-bottom: none;
}

.mini-cart .woocommerce-mini-cart-item img { grid-row: span 2; border-radius: 8px; }

.mini-cart .woocommerce-mini-cart-item > a:not(.remove) {
  grid-column: 2;
  grid-row: 1;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.mini-cart .woocommerce-mini-cart-item .quantity {
  grid-column: 2;
  grid-row: 2;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}

.mini-cart .woocommerce-mini-cart-item .remove {
  grid-column: 3;
  grid-row: 1;
  font-size: 1.125rem;
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.mini-cart .woocommerce-mini-cart-item .remove:hover { color: #ef4444; }

.mini-cart-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0;
  margin-top: 8px;
  border-top: 1px solid var(--glass-border);
}

.mini-cart-total strong { font-size: 0.9375rem; color: var(--color-text-primary); }
.mini-cart-total .amount { font-size: 1.125rem; font-weight: 700; color: var(--color-primary); }

.mini-cart-buttons { display: flex; gap: 10px; }

.mini-cart-buttons a {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 11px 14px;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: 10px;
  text-decoration: none;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.mini-cart-buttons .cart-link {
  background: rgba(var(--color-primary-rgb), 0.12);
  color: var(--color-primary);
}

.mini-cart-buttons .checkout-link {
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
  color: #fff;
}

.mini-cart-buttons a:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
}

/* ============================================
   ACCOUNT DROPDOWN
   ============================================ */
.header-account-dropdown { position: relative; }

.account-menu {
  position: absolute;
  top: calc(100% + 14px);
  right: 0;
  min-width: 200px;
  padding: 14px;
  background: var(--glass-bg);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--glass-border);
  border-radius: 14px;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.15),
    0 0 0 1px rgba(255, 255, 255, 0.1) inset;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px) scale(0.96);
  transition:
    opacity    var(--transition-slow) var(--ease-out-expo),
    transform  var(--transition-slow) var(--ease-out-expo),
    visibility var(--transition-slow);
  z-index: var(--z-mega-menu);
}

.header-account-dropdown:hover .account-menu,
.header-account-dropdown.open .account-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.account-menu .menu-welcome {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--glass-border);
}

.account-menu a {
  display: block;
  padding: 9px 12px;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: 8px;
  transition:
    background var(--transition-fast),
    color     var(--transition-fast),
    transform var(--transition-fast);
}

.account-menu a:hover {
  background: rgba(var(--color-primary-rgb), 0.08);
  color: var(--color-primary);
  transform: translateX(4px);
}

.account-menu .btn-link-accent {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: white;
  text-align: center;
  margin-top: 8px;
}

.account-menu .btn-link-accent:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(var(--color-primary-rgb), 0.4);
}

/* ============================================
   THEME TOGGLE
   ============================================ */
.theme-toggle-wrapper {
  display: flex;
  align-items: center;
}

.theme-toggle {
  position: relative;
  display: inline-flex;
  cursor: pointer;
}

.theme-toggle input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.theme-toggle-slider {
  position: relative;
  width: 50px;
  height: 26px;
  background: rgba(var(--color-text-muted-rgb), 0.2);
  border-radius: 13px;
  transition: background var(--transition-normal);
}

.theme-toggle input:checked + .theme-toggle-slider {
  background: var(--color-primary);
}

.slider-icon {
  position: absolute;
  top: 3px;
  width: 20px;
  height: 20px;
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    opacity   var(--transition-fast),
    transform var(--transition-fast) var(--ease-spring);
}

.slider-icon.sun  { left: 3px;  opacity: 1;   transform: scale(1); }
.slider-icon.moon { right: 3px; opacity: 0.4; transform: scale(0.8); }

.theme-toggle input:checked ~ .theme-toggle-slider .sun  { opacity: 0.4; transform: scale(0.8); }
.theme-toggle input:checked ~ .theme-toggle-slider .moon { opacity: 1;   transform: scale(1); }

/* ============================================
   CINEMATIC SEARCH OVERLAY
   ============================================ */
.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: var(--z-overlay);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 20vh;
  opacity: 0;
  visibility: hidden;
  transition:
    opacity    var(--transition-slow) var(--ease-out-expo),
    visibility var(--transition-slow);
}

.search-overlay.active {
  opacity: 1;
  visibility: visible;
}

.search-close {
  position: absolute;
  top: 32px;
  right: 32px;
  width: 46px;
  height: 46px;
  border: none;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  color: white;
  font-size: 1.5rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    background var(--transition-fast),
    transform  var(--transition-fast);
}

.search-close:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: rotate(90deg);
}

.search-form-wrapper {
  width: 100%;
  max-width: 680px;
  padding: 0 24px;
  transform: translateY(28px);
  transition: transform var(--transition-slow) var(--ease-out-expo);
}

.search-overlay.active .search-form-wrapper { transform: translateY(0); }

.search-form-wrapper form { display: flex; gap: 14px; }

.search-form-wrapper input[type="search"] {
  flex: 1;
  padding: 18px 24px;
  font-size: 1.2rem;
  background: rgba(255, 255, 255, 0.1);
  border: 2px solid rgba(255, 255, 255, 0.2);
  border-radius: 14px;
  color: white;
  outline: none;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}

.search-form-wrapper input[type="search"]::placeholder { color: rgba(255, 255, 255, 0.45); }

.search-form-wrapper input[type="search"]:focus {
  border-color: var(--color-primary);
  background: rgba(255, 255, 255, 0.14);
}

.search-form-wrapper button[type="submit"] {
  padding: 18px 28px;
  font-size: 0.9375rem;
  font-weight: 600;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  color: white;
  border: none;
  border-radius: 14px;
  cursor: pointer;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  white-space: nowrap;
}

.search-form-wrapper button[type="submit"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(var(--color-primary-rgb), 0.4);
}

/* ============================================
   MOBILE MENU TOGGLE (hamburger)
   ============================================ */
.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: 10px;
  transition: background var(--transition-fast);
}

.mobile-menu-toggle:hover {
  background: rgba(var(--color-primary-rgb), 0.1);
}

.hamburger-line {
  width: 20px;
  height: 1.5px;
  background: var(--color-text-secondary);
  border-radius: 2px;
  transition:
    transform var(--transition-normal) var(--ease-out-expo),
    opacity   var(--transition-normal),
    background var(--transition-fast);
  transform-origin: center;
  display: block;
}

/* Hamburger → X animation */
.mobile-menu-toggle.active .hamburger-line:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.mobile-menu-toggle.active .hamburger-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.mobile-menu-toggle.active .hamburger-line:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}

/* ============================================
   === NEW: MOBILE MENU OVERLAY BACKDROP ===
   ============================================ */
.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: var(--z-mobile-overlay);
  opacity: 0;
  visibility: hidden;
  transition:
    opacity    var(--transition-slow) var(--ease-out-expo),
    visibility var(--transition-slow);
  /* allow clicks through to close menu */
  cursor: pointer;
}

.mobile-menu-overlay.visible {
  opacity: 1;
  visibility: visible;
}

/* ============================================
   MOBILE NAVIGATION — enhanced slide-down
   ============================================ */
.mobile-navigation {
  position: fixed;
  /* Sit just below the header (accounting for offset + height) */
  top: calc(var(--header-height) + var(--header-offset) + 12px);
  left: 50%;
  width: calc(100% - 32px);
  max-width: calc(var(--header-max-width) - 32px);
  max-height: calc(100dvh - 140px);
  background: var(--glass-bg-scrolled);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  box-shadow: var(--glass-shadow-scrolled);
  z-index: var(--z-mobile-nav);

  /* Hidden state */
  opacity: 0;
  visibility: hidden;
  /* === IMPROVED: translate from header downward rather than upward === */
  transform: translateX(-50%) translateY(-24px);

  transition:
    opacity    400ms var(--ease-out-expo),
    transform  400ms var(--ease-out-expo),
    visibility 400ms;

  overflow: hidden;
}

.mobile-navigation.open {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.mobile-menu-inner {
  padding: 16px 20px 24px;
  max-height: calc(100dvh - 180px);
  overflow-y: auto;
  overscroll-behavior: contain;
}

/* ============================================
   MOBILE PRIMARY MENU ITEMS
   ============================================ */
.mobile-primary-menu {
  list-style: none;
  padding: 0;
  margin: 0;
}

.mobile-primary-menu > li {
  border-bottom: 1px solid var(--glass-border);
}

.mobile-primary-menu > li:last-child {
  border-bottom: none;
}

/* === IMPROVED: Each top-level item is flex row for toggle button === */
.mobile-primary-menu > li > .mobile-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mobile-primary-menu a {
  display: flex;
  align-items: center;
  flex: 1;
  padding: 13px 0;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  /* Staggered fade-in handled by JS adding .item-visible */
  opacity: 0;
  transform: translateY(8px);
  transition:
    color     var(--transition-fast),
    opacity   350ms var(--ease-out-expo),
    transform 350ms var(--ease-out-expo);
}

.mobile-navigation.open .mobile-primary-menu a {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger delays */
.mobile-navigation.open .mobile-primary-menu > li:nth-child(1) > .mobile-item-header > a { transition-delay:  20ms; }
.mobile-navigation.open .mobile-primary-menu > li:nth-child(2) > .mobile-item-header > a { transition-delay:  60ms; }
.mobile-navigation.open .mobile-primary-menu > li:nth-child(3) > .mobile-item-header > a { transition-delay: 100ms; }
.mobile-navigation.open .mobile-primary-menu > li:nth-child(4) > .mobile-item-header > a { transition-delay: 140ms; }
.mobile-navigation.open .mobile-primary-menu > li:nth-child(5) > .mobile-item-header > a { transition-delay: 180ms; }
.mobile-navigation.open .mobile-primary-menu > li:nth-child(6) > .mobile-item-header > a { transition-delay: 220ms; }
.mobile-navigation.open .mobile-primary-menu > li:nth-child(7) > .mobile-item-header > a { transition-delay: 260ms; }
.mobile-navigation.open .mobile-primary-menu > li:nth-child(8) > .mobile-item-header > a { transition-delay: 300ms; }

.mobile-primary-menu a:hover { color: var(--color-primary); }

/* === NEW: Submenu toggle button === */
.mobile-submenu-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border: none;
  background: rgba(var(--color-primary-rgb), 0.08);
  border-radius: 8px;
  color: var(--color-text-muted);
  cursor: pointer;
  transition:
    background  var(--transition-fast),
    color       var(--transition-fast),
    transform   var(--transition-normal) var(--ease-out-expo);
}

.mobile-submenu-toggle:hover {
  background: rgba(var(--color-primary-rgb), 0.16);
  color: var(--color-primary);
}

/* Chevron rotates when submenu is open */
.mobile-submenu-toggle[aria-expanded="true"] {
  background: rgba(var(--color-primary-rgb), 0.14);
  color: var(--color-primary);
  transform: rotate(180deg);
}

/* === NEW: Mobile sub-menu accordion === */
.mobile-primary-menu .sub-menu {
  list-style: none;
  padding: 0;
  margin: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height 380ms var(--ease-out-expo), opacity 300ms;
  opacity: 0;
}

.mobile-primary-menu .sub-menu.is-open {
  max-height: 800px;  /* generous upper bound */
  opacity: 1;
}

.mobile-primary-menu .sub-menu li {
  border-top: 1px solid var(--glass-border);
}

.mobile-primary-menu .sub-menu a {
  padding: 10px 0 10px 14px;
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--color-text-muted);
  /* Override the stagger-fade from parent — always visible when parent open */
  opacity: 1 !important;
  transform: none !important;
  transition: color var(--transition-fast) !important;
}

.mobile-primary-menu .sub-menu a:hover { color: var(--color-primary); }

/* ============================================
   AIRPLANE CURSOR EFFECT
   ============================================ */
.airplane-cursor {
  position: fixed;
  width: 30px;
  height: 30px;
  pointer-events: none;
  z-index: var(--z-cursor);
  opacity: 0;
  transform: translate(-50%, -50%) rotate(0deg);
  transition: opacity var(--transition-fast);
}

.airplane-cursor.visible { opacity: 1; }

.airplane-cursor svg {
  width: 100%;
  height: 100%;
  fill: var(--color-primary);
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
}

.airplane-trail {
  position: fixed;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary);
  pointer-events: none;
  z-index: calc(var(--z-cursor) - 1);
  opacity: 0;
}

.airplane-trail.visible {
  animation: trail-fade 300ms ease-out forwards;
}

@keyframes trail-fade {
  0%   { opacity: 0.4; transform: translate(-50%, -50%) scale(1); }
  100% { opacity: 0;   transform: translate(-50%, -50%) scale(0); }
}

/* ============================================
   SCROLL FLIGHT PATH
   ============================================ */
.flight-path-container {
  position: fixed;
  right: 28px;
  top: 50%;
  transform: translateY(-50%);
  width: 60px;
  height: 300px;
  z-index: calc(var(--z-header) - 1);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--transition-slow);
}

.flight-path-container.visible { opacity: 1; }

.flight-path {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 100%;
  background: repeating-linear-gradient(
    to bottom,
    transparent,
    transparent 4px,
    var(--glass-border) 4px,
    var(--glass-border) 8px
  );
  border-radius: 1px;
}

.flight-path-airplane {
  position: absolute;
  left: 50%;
  width: 26px;
  height: 26px;
  transform: translateX(-50%) translateY(0);
  transition: transform 50ms linear;
}

.flight-path-airplane svg {
  width: 100%;
  height: 100%;
  fill: var(--color-primary);
  filter: drop-shadow(0 2px 6px rgba(var(--color-primary-rgb), 0.4));
}

.flight-marker {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-accent);
  border: 2px solid var(--glass-bg);
  cursor: pointer;
  pointer-events: auto;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.flight-marker:hover {
  transform: translateX(-50%) scale(1.4);
  box-shadow: 0 0 12px var(--color-accent);
}

.flight-marker.passed { background: var(--color-primary); }

/* ============================================
   KEYBOARD NAVIGATION FOCUS STYLES
   ============================================ */
.keyboard-nav .site-header a:focus,
.keyboard-nav .site-header button:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* ============================================
   RESPONSIVE STYLES
   ============================================ */
@media (max-width: 1024px) {
  :root {
    --header-offset: 14px;
  }

  .site-header {
    width: calc(100% - 32px);
  }

  .main-navigation {
    display: none;
  }

  .mobile-menu-toggle {
    display: flex;
  }

  .flight-path-container {
    display: none;
  }
}

@media (max-width: 768px) {
  :root {
    --header-height: 64px;
    --header-height-scrolled: 56px;
    --header-offset: 10px;
    --header-border-radius: 14px;
    --header-side-padding: 16px;
  }

  .site-header {
    width: calc(100% - 24px);
  }

  .site-branding img {
    max-height: 30px;
  }

  .header-icon-btn,
  .header-search button,
  .account-toggle,
  .mobile-menu-toggle {
    width: 38px;
    height: 38px;
  }

  .mini-cart {
    width: calc(100vw - 40px);
    right: -4px;
  }

  .account-menu {
    width: calc(100vw - 40px);
    right: -4px;
  }

  .theme-toggle-slider {
    width: 44px;
    height: 24px;
  }

  .slider-icon {
    width: 18px;
    height: 18px;
    font-size: 0.75rem;
  }
}

@media (max-width: 480px) {
  :root {
    --header-offset: 8px;
    --header-border-radius: 12px;
  }

  .header-actions { gap: 2px; }

  .theme-toggle-wrapper { display: none; }

  .search-overlay { padding-top: 12vh; }

  .search-form-wrapper form { flex-direction: column; }

  .search-form-wrapper button[type="submit"] { width: 100%; }
}

/* ============================================
   PRINT STYLES
   ============================================ */
@media print {
  .site-header,
  .mobile-navigation,
  .mobile-menu-overlay,
  .search-overlay,
  .flight-path-container,
  .airplane-cursor { display: none !important; }
}

/* ============================================
   REDUCED MOTION
   ============================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .Exploria-globe,
  .globe-lines { animation: none; }

  /* Still allow header to be visible but skip the animation */
  .site-header.header-ready {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
  }
}