/* ========================================
   Main Stylesheet - Yoga Tours Landing
   Imports all component styles
   ======================================== */

/* Core styles */
@import url('variables.css');
@import url('base.css');

/* Components */
@import url('components/buttons.css');
@import url('components/header.css');
@import url('components/hero.css');
@import url('components/tabs.css');
@import url('components/tour-card.css');
@import url('components/gallery.css');
@import url('components/gallery-preview.css');
@import url('components/contact.css');
@import url('components/footer.css');

/* ========================================
   Additional Global Styles
   ======================================== */

/* Smooth reveal animations */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.reveal--visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal--delay-1 { transition-delay: 0.1s; }
.reveal--delay-2 { transition-delay: 0.2s; }
.reveal--delay-3 { transition-delay: 0.3s; }
.reveal--delay-4 { transition-delay: 0.4s; }

/* Section styling */
.section {
  padding: var(--space-4xl) 0;
}

.section--alt {
  background-color: var(--color-sand);
}

.section__header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto var(--space-3xl);
}

.section__label {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: var(--text-xl);
  color: var(--color-sage);
  margin-bottom: var(--space-sm);
}

.section__title {
  font-size: var(--text-2xl);
  color: var(--color-charcoal);
  margin-bottom: var(--space-md);
}

.section__subtitle {
  font-size: var(--text-base);
  color: var(--color-charcoal);
  line-height: 1.6;
}

/* Loading state */
.loading {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-cream);
  transition: opacity 0.5s ease, visibility 0.5s ease;
}

.loading--hidden {
  opacity: 0;
  visibility: hidden;
}

.loading__spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--color-sand);
  border-top-color: var(--color-sage);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Scroll to top button */
.scroll-top {
  position: fixed;
  bottom: var(--space-xl);
  right: var(--space-xl);
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-sage);
  color: var(--color-white);
  border-radius: 50%;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all var(--transition-base);
  z-index: var(--z-sticky);
}

.scroll-top--visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.scroll-top:hover {
  background-color: var(--color-sage-dark);
  color: var(--color-white);
  transform: translateY(-4px);
}

/* Responsive utilities */
@media (max-width: 768px) {
  .hide-mobile {
    display: none !important;
  }
}

@media (min-width: 769px) {
  .hide-desktop {
    display: none !important;
  }
}
