/* Autocomplete dropdown */
.autocomplete-wrapper {
  position: relative;
}

.autocomplete-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  z-index: 50;
  max-height: 200px;
  overflow-y: auto;
  display: none;
}

.autocomplete-item {
  padding: var(--spacing-sm) var(--spacing-md);
  cursor: pointer;
  font-size: var(--text-sm);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
}

.autocomplete-item:last-child {
  border-bottom: none;
}

.autocomplete-item:hover,
.autocomplete-item.active {
  background: var(--color-primary-light);
  color: var(--color-primary);
}

/* Search error */
.search-error {
  margin-top: var(--spacing-md);
  color: var(--color-error, #d32f2f);
  background: var(--color-error-bg, #fce4ec);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}

/* Results section */
.results-header {
  margin-bottom: var(--spacing-lg);
}

/* Loading spinner */
.spinner-lg {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Itinerary cards */
.itinerary-card {
  background: var(--color-card);
  padding: var(--spacing-lg);
  border: 1px solid var(--color-border);
}

.itinerary-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-sm);
}

.itinerary-duration {
  font-weight: bold;
  font-size: var(--text-lg);
  color: var(--color-primary);
}

.itinerary-times {
  display: flex;
  gap: var(--spacing-sm);
  align-items: center;
}

/* Step styles */
.step {
  display: flex;
  align-items: baseline;
  gap: var(--spacing-sm);
  padding: var(--spacing-xs) 0;
  border-left: 2px solid var(--color-border);
  margin-left: var(--spacing-md);
  padding-left: var(--spacing-md);
}

.step:last-child {
  border-left-color: transparent;
}

.step-icon {
  font-size: var(--text-lg);
  min-width: 24px;
}

.step-text {
  font-size: var(--text-sm);
  line-height: 1.4;
}

/* Badge auto */
.badge-car {
  background: var(--color-secondary);
  color: white;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
}