/* ============================================================
   HOTEVI — Navigation Styles
   Component: Two-tier nav (utility bar + main nav)
   ============================================================ */

/* ── Utility bar ──────────────────────────────────────────── */
.nav-utility {
  background: var(--color-navy);
  color: rgba(255,255,255,0.7);
  font-size: var(--text-sm);
  padding: 0.4rem 0;
}

.nav-utility__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
}

.nav-utility__left {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}

.nav-utility__item {
  display: flex;
  align-items: center;
  gap: 6px;
}

.nav-utility__right {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.nav-utility__btn {
  background: none;
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.85);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: border-color var(--transition-fast);
  font-family: var(--font-body);
}

.nav-utility__btn:hover { border-color: rgba(255,255,255,0.5); }

/* ── Main site header ─────────────────────────────────────── */
.site-header {
  background: var(--color-navy, #0D1B2A);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.site-header.scrolled {
  box-shadow: var(--shadow-md);
}

/* Ensure nav links stay visible when header scrolls to solid navy background */
.site-header.scrolled .nav-link {
  color: rgba(255,255,255,0.85);
}

.site-header.scrolled .nav-link:hover,
.site-header.scrolled .nav-link--active {
  color: var(--color-primary-light, #F5E0B0);
  border-bottom-color: var(--color-primary-light, #F5E0B0);
}

.site-header.scrolled .btn--outline {
  color: rgba(255,255,255,0.9);
  border-color: rgba(255,255,255,0.3);
}

.site-header.scrolled .btn--outline:hover {
  border-color: var(--color-primary-light, #F5E0B0);
  color: var(--color-primary-light, #F5E0B0);
}

.site-header.scrolled .nav-hamburger span {
  background: rgba(255,255,255,0.9);
}

/* Transparent variant (homepage hero) */
.site-header.nav-transparent {
  background: transparent;
  border-bottom-color: transparent;
}

.site-header.nav-transparent .nav-link {
  color: rgba(255,255,255,0.85);
  border-bottom-color: transparent;
}

.site-header.nav-transparent .nav-link:hover,
.site-header.nav-transparent .nav-link--active {
  color: var(--color-primary-light);
  border-bottom-color: var(--color-primary-light);
}

.site-header.nav-transparent .nav-hamburger span {
  background: rgba(255,255,255,0.9);
}

.site-header.nav-transparent .btn--outline {
  color: rgba(255,255,255,0.9);
  border-color: rgba(255,255,255,0.4);
}

.site-header.nav-transparent .btn--outline:hover {
  border-color: var(--color-primary-light);
  color: var(--color-primary-light);
}

.site-header.nav-transparent.scrolled {
  background: var(--color-navy, #0D1B2A);
  border-bottom-color: transparent;
}

.site-header.nav-transparent.scrolled .nav-link {
  color: rgba(255,255,255,0.85);
}

.site-header.nav-transparent.scrolled .nav-link:hover,
.site-header.nav-transparent.scrolled .nav-link--active {
  color: var(--color-primary-light, #F5E0B0);
  border-bottom-color: var(--color-primary-light, #F5E0B0);
}

.site-header.nav-transparent.scrolled .nav-hamburger span {
  background: rgba(255,255,255,0.9);
}

.site-header.nav-transparent.scrolled .btn--outline {
  color: rgba(255,255,255,0.9);
  border-color: rgba(255,255,255,0.3);
}

.site-header.nav-transparent.scrolled .btn--outline:hover {
  border-color: var(--color-primary-light, #F5E0B0);
  color: var(--color-primary-light, #F5E0B0);
}

/* ── Header inner ─────────────────────────────────────────── */
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  width: 100%;
}

/* ── Logo ─────────────────────────────────────────────────── */
.nav-logo {
  text-decoration: none;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.nav-logo img { display: block; max-width: 120px; height: auto; }

.nav-logo-text {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
}

.nav-logo-text span { color: var(--gold, #F59E0B); }

/* ── Nav actions (right side — always visible) ────────────── */
.nav-actions {
  display: flex !important;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ── Language switcher ────────────────────────────────────── */
.lang-switcher,
.lang-flags {
  display: flex !important;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.lang-flag {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  font-size: 22px;
  line-height: 1;
  text-decoration: none;
  border-radius: 6px;
  opacity: 0.75;
  transition: opacity 0.15s, background 0.15s;
}

.lang-flag:hover,
.lang-flag--active {
  opacity: 1;
  background: rgba(255, 255, 255, 0.12);
}

/* ── 320px: compact flags to prevent header overflow ─────── */
@media (max-width: 380px) {
  .lang-flags { gap: 0; }
  .lang-flag { min-width: 34px; min-height: 44px; font-size: 18px; border-radius: 4px; }
}

/* ── My Bookings button ───────────────────────────────────── */
.nav-bookings-btn {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--color-primary, #C8922A);
  color: #fff;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.15s;
}

.nav-bookings-btn:hover {
  background: var(--color-primary-dark, #A87520);
}

/* ── Narrow mobile (≤480px): hide button label, icon only ── */
@media (max-width: 480px) {
  .header-inner { padding: 10px 16px; }
  .nav-bookings-label { display: none; }
  .nav-bookings-btn { padding: 0; min-width: 44px; min-height: 44px; }
  .nav-bookings-btn svg { width: 18px; height: 18px; }
  .lang-switcher { gap: 2px; }
}

/* ── Button system ────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-weight: 600;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  white-space: nowrap;
  border: 2px solid transparent;
}

.btn--primary {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.btn--primary:hover {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn--outline {
  background: transparent;
  color: var(--color-navy);
  border-color: var(--color-gray-200);
}

.btn--outline:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.btn--sm  { padding: 0.4rem 0.875rem;  font-size: var(--text-sm);  }
.btn--md  { padding: 0.65rem 1.25rem;  font-size: var(--text-base); }
.btn--lg  { padding: 0.875rem 1.75rem; font-size: var(--text-lg);  }
.btn--xl  { padding: 1rem 2rem;        font-size: var(--text-xl);  height: 52px; }

/* ── Hamburger ────────────────────────────────────────────── */
.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  margin-left: auto;
}

.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-navy);
  transition: all var(--transition-fast);
}

/* ── Mobile: logo size ────────────────────────────────────── */
@media (max-width: 768px) {
  .nav-logo img { max-width: 90px; }
}

/* ── SITE FOOTER ──────────────────────────────────────────── */
.site-footer { background: var(--color-navy); color: rgba(255,255,255,0.75); }
.footer-main { padding: var(--space-16) 0 var(--space-12); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-12); }
.footer-logo { opacity: 0.92; margin-bottom: var(--space-4); display: block; }
.footer-tagline { font-size: var(--text-sm); line-height: 1.7; max-width: 260px; }
.footer-socials { display: flex; gap: var(--space-3); margin-top: var(--space-5); }
.footer-social {
  width: 38px; height: 38px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  font-size: var(--text-xs); font-weight: 700;
  transition: all var(--transition-fast);
}
.footer-social:hover { border-color: var(--color-primary); color: var(--color-primary); }
.footer-col__title {
  font-size: var(--text-sm); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-white); margin-bottom: var(--space-5);
}
.footer-links { list-style: none; display: flex; flex-direction: column; gap: var(--space-3); }
.footer-links a { color: rgba(255,255,255,0.65); text-decoration: none; font-size: var(--text-sm); transition: color var(--transition-fast); }
.footer-links a:hover { color: var(--color-primary); }
.footer-payment-icons { margin-top: var(--space-5); display: flex; gap: var(--space-2); flex-wrap: wrap; }
.payment-icon {
  padding: 3px 10px;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs); font-weight: 700;
  color: rgba(255,255,255,0.7);
}
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding: var(--space-5) 0; }
.footer-bottom__inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-4); }
.footer-copyright, .footer-powered { font-size: var(--text-sm); color: rgba(255,255,255,0.4); }

@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .footer-grid { grid-template-columns: 1fr; } }

/* ── Image protection — prevent right-click save / long-press ────── */
img {
  -webkit-touch-callout: none;
  pointer-events: none;
}
.view-rooms-btn, a img, .hotel-card-result a, .gallery-cell {
  pointer-events: auto;
}
