/* Estilos para la funcionalidad de búsqueda */
.search-container {
  max-width: 800px;
  margin: 20px auto;
  padding: 0 20px;
}

.search-input-wrapper {
  display: flex;
  gap: 8px;
}

#search-input {
  flex: 1;
  padding: 12px 20px;
  font-size: 16px;
  border: 2px solid #ddd;
  border-radius: 25px;
  outline: none;
  transition: border-color 0.3s ease;
}

#search-input:focus {
  border-color: #007acc;
  box-shadow: 0 0 0 3px rgba(0, 122, 204, 0.1);
}

/* Botón de búsqueda eliminado en templates activos; mantenemos control por JS si hace falta.
  (Reglas de #search-button eliminadas) */

/* Indicador visual mostrado mientras el usuario escribe */
.searching-indicator {
  align-self: center;
  font-size: 14px;
  color: #666;
  margin-left: 8px;
}

.search-results {
  display: none;
  background: white;
  border: 1px solid #ddd;
  border-radius: 8px;
  margin-top: 10px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  max-height: 400px;
  overflow-y: auto;
}

.search-result { padding: 15px 20px; border-bottom: 1px solid #eee; }
.search-result:last-child { border-bottom: none; }
.search-result h3 { margin: 0 0 8px 0; font-size: 18px; }
.search-result h3 a { color: #007acc; text-decoration: none; }
.search-result h3 a:hover { text-decoration: underline; }
.search-date { color: #666; font-size: 14px; margin: 5px 0; }
.search-excerpt { color: #555; font-size: 14px; line-height: 1.4; margin: 8px 0 0 0; }
.search-excerpt mark { background-color: #fff3cd; padding: 2px 4px; border-radius: 3px; }
.no-results { padding: 20px; text-align: center; color: #666; font-style: italic; }

/* Responsive */
@media (max-width: 768px) {
  .search-container { padding: 0 15px; }
  #search-input { font-size: 16px; }
}
