/* Variables CSS optimizadas */
:root {
  --primary-color: #28a745; /* Verde corporativo */
  --secondary-color: #0068d6; /* Azul corporativo */
  --color-marron: rgb(107, 82, 28); /* Gris oscuro para texto */
  --background-color: #f8f9fa; /* Gris claro para fondos */
  --text-color: #333333; /* Gris oscuro para texto */
  --heading-font: 'Poppins', sans-serif; /* Fuente moderna para títulos */
  --body-font: 'Roboto', sans-serif; /* Fuente clara para texto general */
  --border-radius: 10px;
  --transition-time: 0.3s;
  --accent-color: #e2f7e1; /* Verde claro para detalles */

  --font-size-title: 24px;
  --font-size-link: 16px;
  --link-spacing: 20px;
  --scroll-behavior: smooth; /* Control del comportamiento del scroll */
}

/* Reset y base */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: var(--body-font);
}

body {
  background-color: var(--background-color);
  color: var(--text-color);
  line-height: 1.6;
  font-size: 16px;
}

html,
body {
  margin: 0;
  padding: 0;
  overflow-x: hidden; /* Evita el desplazamiento horizontal */
  scroll-behavior: var(--scroll-behavior);
}

footer {
  padding: 10px 10vw;
}

/* Encabezado */
.header-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.title {
  font-size: var(--font-size-title);
  font-weight: bold;
  font-family: var(--heading-font);
}

.title img {
  height: 40px;
}

.links {
  display: flex;
}

.link {
  color: var(--background-color);
  text-decoration: none;
  margin-left: var(--link-spacing);
  font-size: var(--font-size-link);
}

.link:hover {
  text-decoration: underline;
}

/* Animaciones */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px); /* Efecto de movimiento suave hacia arriba */
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.appear {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity var(--transition-time) ease, transform var(--transition-time) ease;
}

.appear-visible {
  animation: fadeIn 0.8s ease forwards; /* forwards asegura que se mantenga el estado final */
}

.logo {
  max-width: 80px;
}

/* Gradientes */
.bg-gradient-primary {
  background: linear-gradient(45deg, var(--secondary-color), #6610f2);
}

.bg-gradient-success {
  background: linear-gradient(45deg, var(--primary-color), #218838);
}

.bg-gradient-warning {
  background: linear-gradient(45deg, #ffc107, #fd7e14);
}

.bg-gradient-danger {
  background: linear-gradient(45deg, #dc3545, #c82333);
}

.bg-gradient-info {
  background: linear-gradient(45deg, #17a2b8, #138496);
}

/* Cartas */
.card {
  position: relative;
  border-radius: var(--border-radius);
  overflow: hidden;
  height: 500px;
  width: 100%;
  transition: transform var(--transition-time) ease, box-shadow var(--transition-time) ease;
  cursor: pointer;
  color: var(--accent-color);
}

.card:hover {
  transform: scale(1.05);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}

.card-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  filter: brightness(0.8);
  transition: filter var(--transition-time) ease;
}

.card:hover .card-image {
  filter: brightness(0.5);
}

.card-header {
  position: absolute;
  bottom: 20px;
  right: 0px;
  color: var(--accent-color);
  z-index: 2;
  background-color: rgba(0, 0, 0, 0.6);
  padding: 10px 15px;
  border-radius: calc(var(--border-radius) / 2);
  font-size: 1.2rem;
  text-align: end;
  width: 80%;
  transition: opacity var(--transition-time) ease;
}

.card-body {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  color: var(--accent-color);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
  padding: 20px;
  opacity: 0;
  transition: opacity var(--transition-time) ease;
  z-index: 3;
}

.card:hover .card-body {
  opacity: 1;
}

.card:hover .card-header {
  opacity: 0;
}

/* Nuevo contenido */
p {
  font-size: 20px;
}

/* Estilo básico para las secciones */
section {
  padding: 50px 10vw;
  min-height: calc(50vh - 100px);
  width: 100vw;
}

section:nth-child(2n) {
  background-color: var(--background-color);
}

section:nth-child(2n - 1) {
  color: rgb(107, 82, 28);
}

h1 {
  font-size: clamp(3rem, 9vw, 5rem);
  font-weight: 700;
  margin-top: 50px;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: rgb(0, 143, 43);
}

h2 {
  font-size: 50px;
  font-size: clamp(1rem, 7vw, 3rem);

}

ul {
  list-style-type: disc; /* Utiliza viñetas por defecto */
  padding-left: 20px; /* Añade espacio a la izquierda para las viñetas */
}
