/* ===== ACCESSIBILITY ===== */

/* Focus visible — keyboard-only focus ring */
*:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}

*:focus:not(:focus-visible) {
  outline: none;
}

/* Specific focus styles */
.slider-btn:focus-visible {
  outline: 3px solid var(--white-color);
  outline-offset: 2px;
  box-shadow: 0 0 0 5px var(--primary-color);
}

.button:focus-visible,
.yc-btn:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(0, 78, 203, 0.3);
}

.toggle:focus-visible,
.toggle-static:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

/* Screen-reader-only utility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Skip link */
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  background: var(--primary-color);
  color: white;
  padding: 0.5rem 1rem;
  z-index: 10000;
  font-weight: 600;
}

.skip-link:focus {
  top: 0;
}

/* Fieldset reset */
fieldset.city-filters {
  border: none;
  margin: 0;
  padding: 0;
}

/* Focus trap backdrop — visible when modal/lightbox is open */
.modal-backdrop-active {
  overflow: hidden;
}

/* ── prefers-reduced-motion ── */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .slide {
    transition: none !important;
  }

  .slider-container {
    transition: none !important;
  }

  .lightbox {
    transition: none !important;
  }

  .modal-content {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }

  .toggle:hover {
    transform: none;
  }

  .card:hover,
  .room-card:hover,
  .yc-cart__item:hover {
    transform: none;
  }

  .button:hover,
  .yc-btn:hover,
  .apply-filters-btn:hover {
    transform: none;
  }

  .slider-btn:hover {
    transform: translateY(-50%);
  }

  .user-dropdown-menu {
    transition: none !important;
  }

  .header-lang__menu {
    transition: none !important;
  }

  .price-details-content {
    transition: none !important;
  }

  #filter-options {
    transition: none !important;
  }
}
