/* ══════════════════════════════════════════════════════════════
   COMPONENTS
   
   Reusable component styles: cards, forms, alerts, loading states,
   empty states. Design tokens from vorasense-design-system.css
   
   Related files:
   - design-system.css (design tokens)
   - vorasense-pages.css (base styles)
   - responsive.css (responsive behavior)
   ══════════════════════════════════════════════════════════════ */

/* Enhanced Card Variants */
.vs-card--hoverable {
  cursor: pointer;
  transition: all var(--vs-transition);
}

.vs-card--hoverable:hover {
  transform: translateY(-3px);
  box-shadow: var(--vs-shadow-xl);
  border-color: rgba(212, 165, 116, 0.2);
}

.vs-card--highlight {
  border: 1px solid rgba(230, 154, 71, 0.3);
  background:
    linear-gradient(160deg,
      rgba(230, 154, 71, 0.05) 0%,
      rgba(45, 41, 38, 0.7) 100%);
}

/* Form Layouts */
.vs-form-grid {
  display: grid;
  gap: var(--vs-space-lg);
}

.vs-form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--vs-space-md);
}

.vs-form-actions {
  display: flex;
  gap: var(--vs-space-md);
  justify-content: flex-end;
  margin-top: var(--vs-space-xl);
  padding-top: var(--vs-space-xl);
  border-top: 1px solid rgba(245, 240, 232, 0.06);
}

/* Alerts & Notifications */
.vs-alert {
  padding: var(--vs-space-md) var(--vs-space-lg);
  border-radius: var(--vs-radius-md);
  border-left: 3px solid;
  font-size: var(--vs-text-sm);
  margin-bottom: var(--vs-space-md);
}

.vs-alert--info {
  background: rgba(126, 184, 138, 0.08);
  border-color: var(--vs-safe);
  color: var(--vs-safe);
}

.vs-alert--warning {
  background: rgba(212, 165, 116, 0.08);
  border-color: var(--vs-caution);
  color: var(--vs-caution);
}

.vs-alert--error {
  background: rgba(196, 92, 92, 0.08);
  border-color: var(--vs-danger);
  color: #f2b8a8;
}

.vs-alert--success {
  background: rgba(126, 184, 138, 0.08);
  border-color: var(--vs-safe);
  color: var(--vs-safe);
}

/* Loading States */
.vs-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--vs-space-md);
  padding: var(--vs-space-2xl);
  color: var(--vs-text-muted);
}

.vs-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid rgba(245, 240, 232, 0.1);
  border-top-color: var(--vs-accent);
  border-radius: 50%;
  animation: vs-spin 0.8s linear infinite;
}

@keyframes vs-spin {
  to {
    transform: rotate(360deg);
  }
}

/* Empty States */
.vs-empty {
  text-align: center;
  padding: var(--vs-space-3xl) var(--vs-space-xl);
  color: var(--vs-text-muted);
}

.vs-empty__icon {
  font-size: 48px;
  margin-bottom: var(--vs-space-lg);
  opacity: 0.3;
}

.vs-empty__title {
  font-size: var(--vs-text-xl);
  color: var(--vs-text-secondary);
  margin-bottom: var(--vs-space-sm);
}

.vs-empty__description {
  color: var(--vs-text-muted);
}

/* Card Variants */
.vs-card-success {
  background: var(--vs-safe-bg);
  border-color: var(--vs-safe-border);
  color: var(--vs-safe);
}

.vs-card-error {
  background: var(--vs-danger-bg);
  border-color: var(--vs-danger-border);
  color: var(--vs-danger);
}

.vs-error-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--vs-space-sm);
}

.vs-error-list li {
  padding: var(--vs-space-sm) var(--vs-space-md);
  border-left: 3px solid var(--vs-danger);
  color: inherit;
}
