/* Estilos exclusivos para la página de contacto */

/* Mejoras para el formulario de contacto */
.formulario-contenedor {
  max-width: 700px;
}

/* Estilos para el select */
.campo-form select {
  width: 100%;
  padding: 14px 18px;
  border-radius: var(--radio-boton);
  border: 1px solid var(--borde-sutil);
  background: var(--bg-tarjeta);
  color: var(--texto-oscuro);
  font-size: 16px;
  font-family: inherit;
  transition: all 0.3s ease;
  cursor: pointer;
}

.campo-form select:focus {
  outline: none;
  border-color: var(--acento-principal);
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

/* Estilos para la información de contacto */
.contacto-info {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.contacto-info-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.contacto-info-icono {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.12), rgba(118, 75, 162, 0.08));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--acento-principal);
  flex-shrink: 0;
}

.contacto-info-texto {
  flex: 1;
}

.contacto-info-titulo {
  font-weight: 600;
  color: var(--texto-oscuro);
  margin-bottom: 4px;
  font-size: 15px;
}

.contacto-info-dato {
  color: var(--texto-medio);
  font-size: 14px;
}

/* Responsivo para la página de contacto */

@media screen and (max-width: 1024px) {
  .formulario-contenedor {
    max-width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .campo-form select {
    padding: 12px 16px;
    font-size: 15px;
  }
  
  .contacto-info-item {
    gap: 10px;
  }
  
  .contacto-info-icono {
    width: 36px;
    height: 36px;
  }
}

@media screen and (max-width: 640px) {
  .campo-form select {
    padding: 12px 14px;
    font-size: 14px;
  }
}

@media screen and (max-width: 480px) {
  .campo-form select {
    padding: 10px 12px;
  }
}

@media screen and (max-width: 360px) {
  .campo-form select {
    padding: 10px;
  }
}

/* Media queries para pantallas grandes */
@media screen and (min-width: 1440px) {
  .formulario-contenedor {
    max-width: 800px;
  }
}

@media screen and (min-width: 1920px) {
  .formulario-contenedor {
    max-width: 900px;
  }
}

/* Soporte para modo de alto contraste */
@media (prefers-contrast: high) {
  .campo-form select {
    border-width: 2px;
  }
}

/* Soporte para reducción de movimiento */
@media (prefers-reduced-motion: reduce) {
  .campo-form select {
    transition: none;
  }
}

/* Estilos adicionales */
.contacto-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--borde-sutil), transparent);
  margin: 24px 0;
}

.contacto-mapa-placeholder {
  width: 100%;
  height: 200px;
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.12), rgba(118, 75, 162, 0.08));
  border-radius: 16px;
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--texto-medio);
  border: 1px dashed rgba(102, 126, 234, 0.15);
}

.contacto-horario {
  background: linear-gradient(135deg, rgba(102, 126, 234, 0.06), rgba(118, 75, 162, 0.04));
  padding: 16px;
  border-radius: 12px;
  border: 1px solid rgba(102, 126, 234, 0.1);
}

.contacto-horario-dia {
  font-weight: 600;
  color: var(--texto-oscuro);
}

.contacto-horario-hora {
  color: var(--texto-medio);
}
