/**
 * Main Stylesheet - Rowzen
 * Arquitectura CSS moderna y modular
 *
 * Estructura:
 * 1. Core - Variables, reset, base
 * 2. Layout - Header, footer, grid
 * 3. Components - Buttons, forms, cards, alerts, modals
 * 4. Pages - Estilos específicos de páginas
 * 5. Utilities - Clases de utilidad
 */

/* === CORE === */
@import url('core/variables.css');
@import url('core/reset.css');
@import url('core/base.css');

/* === LAYOUT === */
@import url('layout/header.css');
@import url('layout/footer.css');
@import url('layout/grid.css');

/* === COMPONENTS === */
@import url('components/buttons.css');
@import url('components/forms.css');
@import url('components/cards.css');
@import url('components/alerts.css');
@import url('components/modals.css');

/* === PAGES === */
@import url('pages/home.css');
@import url('pages/autorespuestas.css');
@import url('pages/plantillas.css');
@import url('pages/create.css');

/* === UTILITIES === */

/* Spacing Utilities */
.m-0 { margin: 0 !important; }
.m-1 { margin: var(--spacing-1) !important; }
.m-2 { margin: var(--spacing-2) !important; }
.m-3 { margin: var(--spacing-3) !important; }
.m-4 { margin: var(--spacing-4) !important; }
.m-5 { margin: var(--spacing-5) !important; }
.m-6 { margin: var(--spacing-6) !important; }

.mt-1 { margin-top: var(--spacing-1) !important; }
.mt-2 { margin-top: var(--spacing-2) !important; }
.mt-3 { margin-top: var(--spacing-3) !important; }
.mt-4 { margin-top: var(--spacing-4) !important; }
.mt-5 { margin-top: var(--spacing-5) !important; }
.mt-6 { margin-top: var(--spacing-6) !important; }

.mb-1 { margin-bottom: var(--spacing-1) !important; }
.mb-2 { margin-bottom: var(--spacing-2) !important; }
.mb-3 { margin-bottom: var(--spacing-3) !important; }
.mb-4 { margin-bottom: var(--spacing-4) !important; }
.mb-5 { margin-bottom: var(--spacing-5) !important; }
.mb-6 { margin-bottom: var(--spacing-6) !important; }

.p-0 { padding: 0 !important; }
.p-1 { padding: var(--spacing-1) !important; }
.p-2 { padding: var(--spacing-2) !important; }
.p-3 { padding: var(--spacing-3) !important; }
.p-4 { padding: var(--spacing-4) !important; }
.p-5 { padding: var(--spacing-5) !important; }
.p-6 { padding: var(--spacing-6) !important; }

/* Text Utilities */
.text-left { text-align: left !important; }
.text-center { text-align: center !important; }
.text-right { text-align: right !important; }

.text-primary { color: var(--color-primary) !important; }
.text-secondary { color: var(--color-secondary) !important; }
.text-success { color: var(--color-success) !important; }
.text-error { color: var(--color-error) !important; }
.text-warning { color: var(--color-warning) !important; }
.text-info { color: var(--color-info) !important; }
.text-gray { color: var(--color-gray-600) !important; }

.text-bold { font-weight: var(--font-weight-bold) !important; }
.text-semibold { font-weight: var(--font-weight-semibold) !important; }
.text-normal { font-weight: var(--font-weight-normal) !important; }

.text-xs { font-size: var(--font-size-xs) !important; }
.text-sm { font-size: var(--font-size-sm) !important; }
.text-base { font-size: var(--font-size-base) !important; }
.text-lg { font-size: var(--font-size-lg) !important; }
.text-xl { font-size: var(--font-size-xl) !important; }

/* Background Utilities */
.bg-white { background-color: var(--color-white) !important; }
.bg-gray { background-color: var(--color-gray-100) !important; }
.bg-primary { background-color: var(--color-primary) !important; }
.bg-secondary { background-color: var(--color-secondary) !important; }

/* Border Utilities */
.rounded { border-radius: var(--border-radius-base) !important; }
.rounded-sm { border-radius: var(--border-radius-sm) !important; }
.rounded-lg { border-radius: var(--border-radius-lg) !important; }
.rounded-full { border-radius: var(--border-radius-full) !important; }

/* Shadow Utilities */
.shadow-none { box-shadow: none !important; }
.shadow-sm { box-shadow: var(--shadow-sm) !important; }
.shadow { box-shadow: var(--shadow-base) !important; }
.shadow-md { box-shadow: var(--shadow-md) !important; }
.shadow-lg { box-shadow: var(--shadow-lg) !important; }

/* Display Utilities */
.d-none { display: none !important; }
.d-block { display: block !important; }
.d-inline { display: inline !important; }
.d-inline-block { display: inline-block !important; }
.d-flex { display: flex !important; }

/* Width Utilities */
.w-25 { width: 25% !important; }
.w-50 { width: 50% !important; }
.w-75 { width: 75% !important; }
.w-100 { width: 100% !important; }
.w-auto { width: auto !important; }

/* Misc Utilities */
.orange { color: var(--color-primary) !important; }

.fw-normal { font-weight: var(--font-weight-normal) !important; }
.fw-bold { font-weight: var(--font-weight-bold) !important; }

.is-hidden { display: none !important; }

.variables-help-note {
  margin-top: var(--spacing-2);
  display: block;
}

/* Backward compatibility classes */
.third {
  width: 360px;
  margin: var(--spacing-5);
}

.row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}

/* Responsive visibility */
@media (max-width: 768px) {
  .hide-mobile {
    display: none !important;
  }
}

@media (min-width: 769px) {
  .hide-desktop {
    display: none !important;
  }
}

/* Animation Utilities */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fade-in {
  animation: fadeIn var(--transition-base);
}

.slide-up {
  animation: slideUp var(--transition-base);
}

/* Smooth scrolling */
html {
  scroll-behavior: smooth;
}

/* Selection color */
::selection {
  background-color: var(--color-primary);
  color: var(--color-white);
}

::-moz-selection {
  background-color: var(--color-primary);
  color: var(--color-white);
}

/* Scrollbar styling (WebKit browsers) */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background-color: var(--color-gray-100);
}

::-webkit-scrollbar-thumb {
  background-color: var(--color-gray-400);
  border-radius: var(--border-radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background-color: var(--color-primary);
}

/* Page loader and theme toggle */
.page-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-light) 50%, var(--color-primary) 100%);
  background-size: 200% 100%;
  animation: loading 1.5s infinite;
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.2s;
}

.page-loader.active { opacity: 1; }

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

.content { animation: fadeIn 0.2s ease-in; }

.theme-toggle {
  background: var(--color-bg-tertiary);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-full);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
  margin-left: var(--spacing-2);
}

.theme-toggle:hover {
  background: var(--color-bg-hover);
  transform: scale(1.05);
}

.theme-toggle .theme-icon-dark,
.theme-toggle .theme-icon-light {
  font-size: 1rem;
  position: absolute;
  transition: opacity var(--transition-base), transform var(--transition-base);
}

.theme-toggle .theme-icon-dark {
  opacity: 1;
  transform: rotate(0deg);
}

.theme-toggle .theme-icon-light {
  opacity: 0;
  transform: rotate(-90deg);
}

:root[data-theme="light"] .theme-toggle .theme-icon-dark {
  opacity: 0;
  transform: rotate(90deg);
}

:root[data-theme="light"] .theme-toggle .theme-icon-light {
  opacity: 1;
  transform: rotate(0deg);
}
