:root {
  --color-principal: #04518C;
  --color-secundario: #C8CF3E;
  --color-tercero: red;
  --color-felicitacion: #28a745;
  --color-queja: #dc3545;
  --color-sugerencia: #ffc107;

  --fondo-principal: #f8f9fa;
  --texto-principal: #212529;
  --texto-secundario: #495057;
  --overlay-blue: rgba(4, 81, 140, 0.85);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Poppins', sans-serif;
  background: white;
  overflow-x: hidden;
  line-height: 1.6;
}

a {
  color: var(--color-principal);
}

a:hover {
  color: var(--color-principal);
  text-decoration: underline;
}


/* CLASES DE UTILIDAD PARA BACKGROUNDS */
.bg-principal {
  background-color: var(--color-principal);
}

.bg-secundario {
  background-color: var(--color-secundario);
}

.bg-tercero {
  background-color: var(--color-tercero);
}

/* Opcional: Clases para fondos claros (tipo Light Mode) */

.bg-principal-claro {
  background-color: #e6f0f7;
}

.bg-secundario-claro {
  background-color: #f7f9e8;
}

/* Botones */

.button {
  color: white;
  padding: 15px 35px;
  border-radius: 5px;
  font-size: 16px;
  border: none;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}


.button:hover {
  color: white;
  transform: translateY(-2px);
}

.btn-primary {
  background-color: var(--color-principal);
  border-color: var(--color-principal);
}

.btn-secondary {
  background-color: var(--color-secundario);
  border-color: var(--color-secundario);
}

/* Tarjetas */
.card {
  background-color: var(--fondo-tarjeta);
  border-color: var(--borde-tarjeta);
}

/* Formularios */
.form-control:focus {
  border-color: var(--color-principal);
  box-shadow: 0 0 0 0.2rem rgba(var(--color-principal), 0.25);
}

/* Contenedor principal de la página */
.main-container {
  padding: 2rem 1rem;
}

/* Estilo para el pie de página */
.footer {
  padding: 2rem 1rem;
  margin-top: 3rem;
  background-color: var(--fondo-tarjeta);
  border-top: 1px solid var(--borde-tarjeta);
  color: var(--texto-secundario);
}