/**
 * Tool Rating Component Styles
 * Sistema de calificaciones de herramientas con estrellas interactivas
 * Integrado con design-system.css - Enterprise-grade
 */

/* ===== IMPORTAR DESIGN SYSTEM ===== */
@import url('../design-system.css');

/* === RATING WIDGET CONTAINER === */
.tool-rating-widget {
  padding: var(--space-4);
  background: var(--color-surface-variant);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-outline-variant);
  transition: box-shadow var(--duration-normal) var(--easing-standard);
  contain: layout style;
}

.tool-rating-widget:hover {
  box-shadow: var(--shadow-2);
}

/* === RATING DISPLAY === */
.rating-display {
  margin-bottom: var(--space-4);
}

.rating-stars-display {
  display: inline-flex;
  gap: var(--space-1);
}

.rating-stars-display i {
  font-size: var(--font-size-lg);
  color: var(--color-warning-500);
  transition: transform var(--duration-fast) var(--easing-standard);
}

.rating-average {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-on-surface);
}

.rating-count {
  font-size: var(--font-size-sm);
  color: var(--color-on-surface-variant);
}

/* === INTERACTIVE STARS INPUT === */
.rating-stars-input {
  display: inline-flex;
  gap: var(--space-2);
  cursor: pointer;
  user-select: none;
}

.rating-star {
  color: var(--color-outline);
  font-size: var(--font-size-3xl);
  transition: all var(--duration-fast) var(--easing-standard);
  cursor: pointer;
}

.rating-star:hover,
.rating-star.active {
  color: var(--color-warning-500);
  transform: scale(1.1);
}

.rating-star:focus {
  outline: 2px solid var(--color-primary-500);
  outline-offset: var(--space-1);
  border-radius: var(--radius-sm);
}

/* === RATING FORM === */
.rating-form {
  animation: fadeIn var(--duration-normal) var(--easing-standard);
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(calc(-1 * var(--space-2)));
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.rating-comment {
  resize: vertical;
  min-height: calc(var(--space-12) * 2);
  transition:
    border-color var(--duration-fast) var(--easing-standard),
    box-shadow var(--duration-fast) var(--easing-standard);
}

.rating-comment:focus {
  border-color: var(--color-primary-500);
  box-shadow: 0 0 0 0.25rem rgba(var(--color-primary-rgb), 0.25);
}

.rating-submit {
  min-width: 10rem;
  transition: all var(--duration-fast) var(--easing-standard);
}

.rating-submit:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-2);
}

.rating-submit:active {
  transform: translateY(0);
}

/* === ALERT STYLES === */
.tool-rating-widget .alert-sm {
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-sm);
}

/* === DARK MODE SUPPORT === */
/* NOTA: En este sitio, bg-light permanece CLARO en dark mode (Bootstrap 5 default) */
/* Por lo tanto, NO hacemos override de colores - el texto oscuro por defecto */
/* funciona perfectamente sobre el fondo claro de bg-light */
/* Solo ajustamos colores de advertencia que necesitan brillar más */
[data-bs-theme='dark'] .rating-star:hover,
[data-bs-theme='dark'] .rating-star.active {
  color: #ffd940; /* Amarillo más brillante para dark mode */
}

/* === RESPONSIVE DESIGN === */
@media (max-width: 768px) {
  .tool-rating-widget {
    padding: var(--space-3);
  }

  .rating-stars-input .rating-star {
    font-size: var(--font-size-4xl);
  }

  .rating-display {
    text-align: center;
  }

  .rating-submit {
    width: 100%;
  }
}

@media (max-width: 576px) {
  .rating-stars-input .rating-star {
    font-size: var(--font-size-5xl);
    gap: var(--space-3);
  }

  .rating-average {
    font-size: var(--font-size-3xl);
  }
}

/* === LOADING STATE === */
.tool-rating-widget.loading {
  opacity: 0.6;
  pointer-events: none;
}

.tool-rating-widget.loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: var(--space-8);
  height: var(--space-8);
  border: 3px solid var(--color-surface);
  border-top-color: var(--color-primary-500);
  border-radius: var(--radius-full);
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

/* === SUCCESS STATE === */
.tool-rating-widget.success {
  border-color: var(--color-success-500);
  background: rgba(var(--color-success-rgb), 0.05);
}

/* === ACCESSIBILITY === */
.rating-star:focus-visible {
  outline: 2px solid var(--color-primary-500);
  outline-offset: var(--space-1);
}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
  .rating-star,
  .rating-submit,
  .rating-form {
    transition: none;
    animation: none;
  }

  .tool-rating-widget.loading::after {
    animation: none;
  }
}
