/**
 * Header Component - Desktop Navigation
 *
 * @package Annecy_Unik_Lodges
 */

/* ========================================
   HEADER PRINCIPAL
   ======================================== */

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 1rem 0;
  background-color: transparent;
  transition: background-color var(--transition-base),
    box-shadow var(--transition-base);
}

/* Header scrolled - fond semi-transparent avec blur */
.site-header.is-scrolled {
  background-color: rgba(54, 94, 88, 0.5);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Container flex : logo gauche, nav droite */
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ========================================
   LOGO
   ======================================== */

.site-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.site-logo img {
  height: 50px;
  width: auto;
}

.site-title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-white);
  text-decoration: none;
}

.site-title:hover {
  color: var(--color-secondary);
}

/* ========================================
   NAVIGATION DESKTOP
   ======================================== */

.site-navigation {
  display: flex;
  align-items: center;
}

/* Menu principal (ul) */
.site-navigation .nav-menu {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Items de premier niveau */
.site-navigation .nav-menu > li {
  position: relative;
}

/* Liens de premier niveau */
.site-navigation .nav-menu > li > a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0.75rem 1rem;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-white);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: color var(--transition-fast);
  white-space: nowrap;
}

/* Chevron icon for menu items with sub-menus */
.site-navigation .nav-menu > li > a .menu-chevron {
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}

.site-navigation .nav-menu > li:hover > a .menu-chevron {
  transform: rotate(180deg);
}

.site-navigation .nav-menu > li.current-menu-item > a,
.site-navigation .nav-menu > li.current-menu-ancestor > a {
  color: var(--color-white);
}

/* Hover avec background pour tous les liens */
.site-navigation .nav-menu > li > a:hover {
  background-color: rgba(54, 94, 88, 0.5);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--color-white);
}

/* ========================================
   SOUS-MENUS (DROPDOWNS)
   ======================================== */

.site-navigation .nav-menu .sub-menu {
  position: absolute;
  top: calc(100% + 20px);
  left: 0;
  min-width: 240px;
  background-color: rgba(54, 94, 88, 0.5);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  list-style: none;
  margin: 0;
  padding: 0.5rem 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all var(--transition-fast);
  pointer-events: none;
}

/* Zone invisible pour maintenir le hover */
.site-navigation .nav-menu .sub-menu::before {
  content: '';
  position: absolute;
  top: -20px;
  left: 0;
  right: 0;
  height: 20px;
}

/* Garder le background sur le lien parent quand on hover le sous-menu */
.site-navigation .nav-menu > li:hover > a {
  background-color: rgba(54, 94, 88, 0.5);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--color-white);
}

/* Affichage au hover */
.site-navigation .nav-menu > li:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* Liens des sous-menus */
.site-navigation .nav-menu .sub-menu li {
  margin: 0;
}

.site-navigation .nav-menu .sub-menu li a {
  display: block;
  padding: 0.6rem 1.25rem;
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--color-white);
  text-decoration: none;
  text-transform: none;
  transition: all var(--transition-fast);
}

.site-navigation .nav-menu .sub-menu li a:hover {
  color: var(--color-secondary);
}

.site-navigation .nav-menu .sub-menu li.current-menu-item a {
  color: var(--color-secondary);
  font-weight: 500;
}

/* ========================================
   HEADER ACTIONS (Boutons à droite)
   ======================================== */

.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: 1.5rem;
}

.header-action__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  background-color: var(--color-primary);
  border: none;
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-decoration: none;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.header-action__btn:hover {
  background-color: var(--color-primary-dark, #2a4a45);
  color: var(--color-white);
}

/* Phone Button */
.header-phone {
  padding: 10px;
  background-color: rgba(54, 94, 88, 0.5);
}

.header-phone:hover {
  background-color: rgba(54, 94, 88, 0.7);
}

.header-phone svg {
  width: 18px;
  height: 18px;
}

/* Language Switcher */
.header-lang {
  padding: 10px 12px;
  background-color: rgba(54, 94, 88, 0.5);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.header-lang:hover {
  background-color: rgba(54, 94, 88, 0.7);
}

/* Réserver Button & Dropdown */
.header-reserve-wrapper {
  position: relative;
}

.header-reserve {
  padding: 10px 20px;
}

/* Lodges Dropdown */
.lodges-dropdown {
  position: absolute;
  top: calc(100% + 20px);
  right: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all var(--transition-fast);
  pointer-events: none;
  z-index: 100;
}

.lodges-dropdown::before {
  content: '';
  position: absolute;
  top: -20px;
  left: 0;
  right: 0;
  height: 20px;
}

.lodges-dropdown-inner {
  background: var(--color-primary);
  padding: 20px;
  width: 486px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.header-reserve-wrapper:hover .lodges-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* Lodge Item */
.lodge-item {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 10px;
  cursor: pointer;
  transition: background 0.2s ease;
  text-decoration: none;
}

.lodge-item:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* Lodge Image */
.lodge-item-image {
  width: 150px;
  height: 85px;
  flex-shrink: 0;
  overflow: hidden;
}

.lodge-item-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.lodge-item:hover .lodge-item-image img {
  transform: scale(1.05);
}

/* Lodge Content */
.lodge-item-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}

.lodge-item-title {
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: 400;
  color: var(--color-secondary);
  line-height: normal;
  margin: 0;
}

.lodge-item-desc {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  color: var(--color-white);
  line-height: normal;
  margin: 0;
}

/* ========================================
   MENU TOGGLE (BURGER) - Mobile uniquement
   ======================================== */

.menu-toggle {
  display: none;
}

/* ========================================
   MOBILE ACTIONS - Caché en desktop
   ======================================== */

.header-actions-mobile {
  display: none;
}

/* ========================================
   RESPONSIVE
   ======================================== */

@media (max-width: 1024px) {
  /* Pas de blur sur le header en mobile */
  .site-header.is-scrolled {
    background-color: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  /* Cacher le logo en mobile */
  .site-logo,
  .site-title {
    display: none;
  }

  /* Cacher la navigation desktop */
  .site-navigation {
    display: none;
  }

  /* Afficher les actions mobile */
  .header-actions-mobile {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .header-phone-mobile {
    padding: 10px;
    background-color: var(--color-primary);
  }

  .header-phone-mobile svg {
    width: 18px;
    height: 18px;
  }

  .header-reserve-mobile {
    padding: 10px 20px;
    background-color: var(--color-primary);
  }

  /* Afficher le bouton burger avec background primary */
  .menu-toggle {
    display: flex;
    background-color: var(--color-primary);
  }
}

/* ========================================
   MODAL RÉSERVATION MOBILE
   ======================================== */

.reserve-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}

.reserve-modal.is-open {
  opacity: 1;
  visibility: visible;
}

/* Overlay */
.reserve-modal__overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
}

/* Content */
.reserve-modal__content {
  position: absolute;
  inset: 0;
  background-color: var(--color-primary);
  display: flex;
  flex-direction: column;
  padding: 20px;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.reserve-modal.is-open .reserve-modal__content {
  transform: translateY(0);
}

/* Close Button */
.reserve-modal__close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--color-white);
  cursor: pointer;
  transition: opacity 0.2s ease;
  z-index: 10;
}

.reserve-modal__close svg {
  width: 32px;
  height: 32px;
}

.reserve-modal__close:hover {
  opacity: 0.7;
}

/* Title */
.reserve-modal__title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-secondary);
  text-align: center;
  margin: 60px 0 30px;
}

/* Lodges List */
.reserve-modal__lodges {
  display: flex;
  flex-direction: column;
  gap: 15px;
  flex: 1;
}

/* Lodge Item */
.reserve-modal__lodge {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
  background: rgba(255, 255, 255, 0.05);
  text-decoration: none;
  transition: background 0.2s ease;
}

.reserve-modal__lodge:hover,
.reserve-modal__lodge:active {
  background: rgba(255, 255, 255, 0.1);
}

/* Lodge Image */
.reserve-modal__lodge-image {
  width: 120px;
  height: 80px;
  flex-shrink: 0;
  overflow: hidden;
}

.reserve-modal__lodge-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Lodge Content */
.reserve-modal__lodge-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}

.reserve-modal__lodge-title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 400;
  color: var(--color-secondary);
  line-height: 1.3;
  margin: 0;
}

.reserve-modal__lodge-desc {
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 400;
  color: var(--color-white);
  line-height: 1.4;
  margin: 0;
  opacity: 0.8;
}

/* Body lock when modal is open */
body.reserve-modal-open {
  overflow: hidden;
}
