/* main.css */
@import url('base/variables.css');
@import url('base/reset.css');
@import url('base/typography.css');
@import url('base/theme.css');

@import url('layout/header.css');
@import url('layout/footer.css');
@import url('layout/grid.css');
@import url('layout/cookie-consent.css');

@import url('components/buttons.css');
@import url('components/cards.css');
@import url('components/forms.css');
@import url('components/tables.css');
@import url('components/modals.css');
@import url('components/admin-table-filters.css');
@import url('components/simple-table-filter.css');

@import url('pages/auth.css');
@import url('pages/admin.css');
@import url('pages/tasks.css');
@import url('pages/curators.css');
@import url('pages/notifications.css');

@import url('utilities/responsive.css');
@import url('utilities/animations.css');
@import url('utilities/helpers.css');

/* Оптимизированные основные стили layout */
.main-content {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - var(--header-height));
}

.footer {
  margin-top: auto;
}

/* Глобальный индикатор загрузки */
.global-loader {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 9999;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  padding: 10px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

/* Состояние загрузки для body */
body.loading {
  cursor: wait;
}

body.loading * {
  cursor: wait !important;
}

.toast-container {
  z-index: 9999;
}

.global-loading-bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--primary-color), #3b82f6, #06b6d4);
  z-index: 9999;
  transition: width 0.4s ease;
  background-size: 200% 100%;
}

.global-loading-bar.active {
  width: 100%;
  animation: loadingProgress 2s ease-in-out infinite;
  will-change: width;
}

@keyframes loadingProgress {
  0% {
    background-position: 200% 0;
  }

  100% {
    background-position: -200% 0;
  }
}

.main-content.loading {
  position: relative;
}

.main-content.loading::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.8);
  z-index: 1000;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

[data-bs-theme="dark"] .main-content.loading::after {
  background: rgba(15, 20, 25, 0.8);
}

#content {
  transition: opacity 0.3s ease, transform 0.3s ease;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.main-content {
  flex: 1;
}

.spa-container {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.3s ease, transform 0.3s ease;
  will-change: opacity, transform;
}

.spa-container.loading {
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
}

[data-spa-content] {
  visibility: hidden;
}

[data-spa-content].loaded {
  visibility: visible;
  animation: fadeInUp 0.4s ease;
}