/* ==================== SISTEMA DE UBICACIÓN DINÁMICO ==================== */

/* Selects de ubicación */
.bf-location-select {
  position: relative;
}

.bf-location-select:disabled {
  background-color: var(--neutral-100);
  color: var(--neutral-500);
  cursor: not-allowed;
  opacity: 0.7;
}

.bf-location-select:disabled option {
  color: var(--neutral-500);
}

/* Estados de loading */
.bf-location-loading {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--bg-soft);
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text-muted);
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 8px;
}

.bf-location-loading .spinner {
  animation: rotate 1s linear infinite;
}

.bf-location-loading.bf-hidden {
  display: none;
}

/* Indicadores de estado */
.bf-location-status {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
}

.bf-location-status.loading {
  color: var(--primary);
}

.bf-location-status.success {
  color: var(--success);
}

.bf-location-status.error {
  color: var(--danger);
}

/* Cascada visual */
.bf-location-group {
  position: relative;
}

.bf-location-group::after {
  content: '';
  position: absolute;
  right: -10px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%2362257e' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m4 6 4 4 4-4'/%3e%3c/svg%3e");
  opacity: 0.5;
}

/* Estados de dependencia */
.bf-location-dependent {
  position: relative;
}

.bf-location-dependent::before {
  content: '';
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  background: var(--neutral-300);
  border-radius: 50%;
}

.bf-location-dependent.ready::before {
  background: var(--success);
}

/* Animaciones */
@keyframes locationSlideIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
    max-height: 0;
  }
  to {
    opacity: 1;
    transform: translateY(0);
    max-height: 200px;
  }
}

.bf-location-select:not(:disabled) {
  animation: locationSlideIn 0.3s ease-out;
}

/* Responsive */
@media (max-width: 768px) {
  .bf-location-group::after,
  .bf-location-dependent::before {
    display: none;
  }
  
  .bf-location-loading {
    padding: 10px 12px;
    font-size: 13px;
  }
}

/* Estados de validación mejorados */
.was-validated .bf-location-select:valid:not(:disabled) {
  border-color: var(--success);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%2310b981' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m4 6 4 4 4-4'/%3e%3c/svg%3e");
}

.was-validated .bf-location-select:invalid:not(:disabled) {
  border-color: var(--danger);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23ef4444' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m4 6 4 4 4-4'/%3e%3c/svg%3e");
}

/* Agregar al location-select.css */
.bf-location-disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.bf-location-disabled option {
  color: var(--text-muted);
}