/**
 * Actions & Controls Module
 *
 * Contains all action button styles including:
 * - Action buttons container and layout
 * - Theme toggle with dark mode animations
 * - Language selector action button
 * - Responsive action button styles
 * - Icon and text elements
 */

/* ==========================================================================
   Actions & Controls
   ========================================================================== */

.navbar__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem; /* 12px gap between action buttons (globe, More, settings) - tighter than nav links */
  flex-shrink: 0;
  max-width: 100%; /* Prevent overflow */
  min-width: 0; /* Allow shrinking */
  margin-left: auto; /* Push actions and auth to the right side */
  margin-right: 1.5rem; /* 24px spacing to auth section */
}

/* ==========================================================================
   Progressive Responsive Breakpoints
   ========================================================================== */

/* Large screens 1920px+ - Minimal padding for maximum space utilization */
@media (min-width: 1920px) {
  .navbar__container {
    padding: 0 0.625rem 0 0.625rem; /* 10px horizontal padding - minimal for large screens */
    max-width: 1800px; /* More space for large screens */
  }

  .navbar__brand {
    margin-right: 2.5rem !important; /* 40px spacing to Book Now button - equal to Book Now to nav spacing */
  }

  .navbar__search-section {
    margin-right: 2.5rem; /* 40px spacing to nav section - equal spacing */
    max-width: 450px;
  }

  .navbar__nav--desktop {
    margin-right: 2.5rem; /* 40px spacing to Actions */
  }

  .navbar__actions {
    margin-right: 2rem; /* 32px spacing to Auth */
  }
}

/* Standard desktop spacing - 1400px and below */
@media (max-width: 1400px) {
  .navbar__container {
    padding: 0 0.5rem 0 0.5rem; /* 8px horizontal padding - minimal */
  }

  .navbar__brand {
    margin-right: 2rem !important; /* 32px spacing to Book Now button - equal to Book Now to nav spacing */
  }

  .navbar__search-section {
    margin-right: 2rem; /* 32px spacing to nav section - equal spacing */
    max-width: 350px;
  }

  .navbar__nav--desktop {
    margin-right: 2rem; /* 32px spacing to Actions */
  }

  .navbar__menu {
    gap: 0.375rem; /* 6px gap between nav links (tighter) */
  }

  .navbar__link {
    padding: 0.5rem 0.875rem; /* Slightly reduce link padding */
    font-size: 0.8125rem;
  }

  .navbar__actions {
    gap: 0.625rem; /* 10px gap between action buttons */
    margin-right: 1.25rem; /* 20px spacing to Auth */
  }

  .navbar__auth {
    gap: 0.875rem; /* 14px spacing between auth buttons */
  }

  .navbar__auth-button {
    padding: 9px 18px;
    font-size: 0.875rem;
  }

  .navbar__auth-link {
    padding: 9px 16px;
    font-size: 0.875rem;
  }

  .navbar__action-button {
    padding: 0.5rem;
  }
}

/* Compact at 1280px and below - Switch to mobile view */
@media (max-width: 1024px) {
  /* Mobile hamburger menu is active at this breakpoint */
  /* See responsive.css for mobile menu styles */
}

/* Desktop compact spacing at medium screens */
@media (max-width: 1400px) and (min-width: 1025px) {
  .navbar__container {
    padding: 0 0.5rem 0 0.5rem; /* 8px horizontal padding */
  }

  .navbar__brand {
    margin-right: 1.5rem !important; /* 24px spacing to Book Now button - equal to Book Now to nav spacing */
  }

  .navbar__search-section {
    margin-right: 1.5rem; /* 24px spacing to nav section - equal spacing */
    max-width: 300px;
  }

  .navbar__nav--desktop {
    margin-right: 1.25rem; /* 20px spacing to Actions */
  }

  .navbar__menu {
    gap: 0.25rem; /* 4px gap between nav links */
  }

  .navbar__link {
    padding: 0.45rem 0.75rem;
    font-size: 0.75rem;
  }

  .navbar__actions {
    gap: 0.5rem; /* 8px gap between action buttons */
    margin-right: 1rem; /* 16px spacing to Auth */
  }

  /* Hide action text labels, show only icons */
  .navbar__action-text,
  .navbar__action-button .navbar__action-text {
    display: none !important;
  }

  .navbar__action-button {
    padding: 0.5rem;
    min-width: 40px;
  }

  /* Keep chevron on language selector */
  .navbar__action-chevron {
    margin-left: 0 !important;
  }

  /* Make auth buttons more compact */
  .navbar__auth {
    gap: 0.75rem; /* 12px spacing between auth buttons */
  }

  .navbar__auth-link {
    padding: 0.5rem 0.75rem;
    font-size: 0.8125rem;
  }

  .navbar__auth-button {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
  }

  /* Hide "Sign In" text on smaller screens, keep only "Get Started" */
  .navbar__auth-link-text {
    display: none !important;
  }

  /* Show only icon for Sign In */
  .navbar__auth-link-icon {
    margin: 0 !important;
  }
}

/* Further compacting at 1100px - Minimal padding */
@media (max-width: 1100px) {
  .navbar__container {
    padding: 0 0.375rem 0 0.375rem; /* 6px horizontal padding */
  }

  .navbar__brand {
    margin-right: 1.25rem !important; /* 20px spacing to Book Now button - equal to Book Now to nav spacing */
  }

  .navbar__search-section {
    margin-right: 1.25rem; /* 20px spacing to nav section - equal spacing */
    max-width: 250px;
  }

  .navbar__nav--desktop {
    margin-right: 1rem; /* 16px spacing to Actions */
  }

  .navbar__menu {
    gap: 0.25rem;
  }

  .navbar__link {
    padding: 0.4rem 0.65rem;
    font-size: 0.6875rem;
  }

  .navbar__actions {
    gap: 0.25rem; /* Further reduce gap */
  }

  .navbar__action-button {
    padding: 0.4rem;
    min-width: 36px;
    font-size: 0.8125rem;
  }

  .navbar__actions {
    margin-right: 0.875rem; /* 14px spacing to Auth */
  }

  .navbar__auth {
    gap: 0.625rem; /* 10px spacing between auth buttons */
  }

  .navbar__auth-button {
    padding: 8px 14px;
    font-size: 0.8125rem;
  }

  .navbar__auth-link {
    padding: 8px 12px;
    font-size: 0.8125rem;
  }

  .navbar__auth-button-text {
    font-size: 0.75rem;
  }
}

/* Very compact at 1050px - Minimal padding */
@media (max-width: 1050px) {
  .navbar__container {
    padding: 0 0.375rem 0 0.375rem; /* 6px horizontal padding */
  }

  .navbar__brand {
    margin-right: 1rem !important; /* 16px spacing to Book Now button - equal to Book Now to nav spacing */
  }

  .navbar__search-section {
    margin-right: 1rem; /* 16px spacing to nav section - equal spacing */
    max-width: 200px;
  }

  .navbar__nav--desktop {
    margin-right: 0.875rem; /* 14px spacing to Actions */
  }

  .navbar__menu {
    gap: 0.2rem;
  }

  .navbar__link {
    padding: 0.35rem 0.55rem;
    font-size: 0.625rem;
  }

  .navbar__link-text {
    font-size: 0.625rem;
  }

  .navbar__actions {
    gap: 0.2rem;
  }

  .navbar__action-button {
    padding: 0.35rem;
    min-width: 32px;
  }

  .navbar__action-icon {
    font-size: 0.875rem;
  }

  .navbar__actions {
    margin-right: 0.75rem; /* 12px spacing to Auth */
  }

  .navbar__auth {
    gap: 0.5rem; /* 8px spacing between auth buttons */
  }

  .navbar__auth-button {
    padding: 7px 12px;
    font-size: 0.75rem;
  }

  .navbar__auth-link {
    padding: 7px 10px;
    font-size: 0.75rem;
  }

  .navbar__auth-button-text {
    font-size: 0.7rem;
    letter-spacing: 0;
  }
}

/* Logo responsive scaling - 1200px */
@media (max-width: 1200px) {
  .navbar__logo-wrapper {
    width: 44px;
    height: 44px;
  }

  .navbar__logo-text {
    font-size: 0.9rem;
  }

  .navbar__logo-text-main {
    font-size: 18px;
  }

  .navbar__logo-text-sub {
    font-size: 10px;
  }
}

/* Logo responsive scaling - 1100px */
@media (max-width: 1100px) {
  .navbar__logo-wrapper {
    width: 40px;
    height: 40px;
  }

  .navbar__logo-text {
    font-size: 0.85rem;
  }

  .navbar__logo-text-main {
    font-size: 16px;
  }

  .navbar__logo-text-sub {
    font-size: 9px;
  }
}

/* Logo responsive scaling - 1050px */
@media (max-width: 1050px) {
  .navbar__logo-wrapper {
    width: 36px;
    height: 36px;
  }

  .navbar__logo-text {
    font-size: 0.8rem;
  }

  .navbar__logo-text-main {
    font-size: 14px;
  }

  .navbar__logo-text-sub {
    font-size: 8px;
  }
}

/* Even more compact at 992px */
@media (max-width: 992px) {
  .navbar__auth-button-text {
    /* Shorten "Get Started" to just the icon arrow */
    font-size: 0;
    width: 0;
    padding: 0;
  }

  .navbar__auth-button-icon {
    margin: 0;
  }

  .navbar__auth-button {
    padding: 0.5rem;
    min-width: 40px;
  }
}

.navbar__action {
  position: relative;
  flex-shrink: 0; /* Prevent action buttons from overlapping */
  min-width: 0; /* Allow proper flex shrinking */
}

.navbar__action-button {
  display: flex;
  align-items: center;
  gap: var(--navbar-spacing-sm);
  padding: 0.3125rem 0.4375rem; /* Reduced padding: 5px vertical, 7px horizontal for compact navbar */
  border: none;
  background: transparent;
  color: var(--navbar-text-secondary);
  border-radius: var(--navbar-border-radius);
  cursor: pointer;
  transition: all var(--navbar-transition-base);
  font-size: 0.75rem; /* Reduced from 0.875rem for more compact navbar */
  font-weight: var(--navbar-font-weight-medium);
}

.navbar__action-button:hover {
  background: var(--navbar-hover);
  color: var(--navbar-text-primary);
}

/* Ensure theme toggle inherits navbar background properly */
.navbar__action-button--theme {
  background: rgba(75, 85, 99, 0.1);
  border: 1px solid rgba(75, 85, 99, 0.2);
}

.navbar__action-button--theme:hover {
  background: rgba(75, 85, 99, 0.2);
  border-color: rgba(75, 85, 99, 0.3);
}

/* Dark mode theme toggle */
[data-theme="dark"] .navbar__action-button--theme,
.dark-mode .navbar__action-button--theme {
  background: rgba(209, 213, 219, 0.1);
  border-color: rgba(209, 213, 219, 0.2);
}

[data-theme="dark"] .navbar__action-button--theme:hover,
.dark-mode .navbar__action-button--theme:hover {
  background: rgba(209, 213, 219, 0.2);
  border-color: rgba(209, 213, 219, 0.3);
}

.navbar__action-icon {
  font-size: 0.875rem; /* Reduced from 1rem for more compact navbar */
}

.navbar__action-text {
  font-size: 0.75rem;
  font-weight: var(--navbar-font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.navbar__action-chevron {
  font-size: 0.75rem;
  color: var(--navbar-text-muted);
  transition: transform var(--navbar-transition-base);
}

.navbar__action-button[aria-expanded="true"] .navbar__action-chevron {
  transform: rotate(180deg);
  color: var(--navbar-primary);
}

/* ==========================================================================
   Advanced Dark Mode Toggle
   ========================================================================== */

.navbar__action-button--theme {
  position: relative;
  width: 56px;
  height: 32px;
  padding: 4px;
  background: var(--navbar-hover);
  border-radius: 16px;
  overflow: hidden;
}

.navbar__action-button--theme:hover {
  background: var(--navbar-active);
}

.navbar__theme-icon {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.875rem;
  transition: all var(--navbar-transition-base);
  z-index: 2;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.navbar__theme-icon--light {
  left: 6px;
  opacity: 1;
  color: var(--navbar-warning);
}

.navbar__theme-icon--dark {
  right: 6px;
  opacity: 0;
  color: var(--navbar-primary);
}

[data-theme="dark"] .navbar__theme-icon--light,
.dark-mode .navbar__theme-icon--light {
  opacity: 0;
}

[data-theme="dark"] .navbar__theme-icon--dark,
.dark-mode .navbar__theme-icon--dark {
  opacity: 1;
}

.navbar__theme-slider {
  position: absolute;
  top: 4px;
  left: 4px;
  width: 24px;
  height: 24px;
  background: var(--navbar-text-primary);
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  transition: transform var(--navbar-transition-base);
  z-index: 1;
}

[data-theme="dark"] .navbar__theme-slider,
.dark-mode .navbar__theme-slider,
html.dark .navbar__theme-slider {
  transform: translateX(24px);
  background: var(--navbar-text-primary);
  box-shadow: 0 2px 8px rgba(255, 255, 255, 0.15);
}
