/* Quitar márgenes y asegurar que el body ocupa todo el alto */
html, body {
  margin: 0;
  padding: 0;
  height: 100%;
}

/* Fuente variable normal */
@font-face {
  font-family: 'Archivo';
  src: url('../fonts/Archivo-VariableFont_wdth,wght.ttf') format('truetype-variations');
  font-weight: 100 900;
  font-stretch: 75% 125%;
  font-style: normal;
}

/* Fuente variable en cursiva */
@font-face {
  font-family: 'Archivo';
  src: url('../fonts/Archivo-Italic-VariableFont_wdth,wght.ttf') format('truetype-variations');
  font-weight: 100 900;
  font-stretch: 75% 125%;
  font-style: italic;
}

/* --- Colores --- */
:root {
  --color-primary: #00CF78;   /* Verde esmeralda */
  --color-light:   #D6FAEB;   /* Verde menta claro */
  --color-dark:    #084A34;   /* Verde profundo */
}

/*--- body normal ---*/
body {
  font-family: 'Archivo', sans-serif;
  font-stretch: 100%;
  margin: 0;
  background: var(--color-light);
}

/* --- Hero --- */
.hero {
  width: 60%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: space-between; /* redes abajo */
  align-items: center;
  color: var(--color-dark);
  padding: 4rem 5rem;
  box-sizing: border-box;
}

.hero-content {
  flex: 1;
  display: flex;
  align-items: center;
  min-width: 90%;
}

.hero-header h1 {
  margin: 0 0 0 0;
  font-size: clamp(3rem, 5vw, 4rem);
  letter-spacing: -0.15rem;
  font-weight: 800;
}

.hero-header h2 {
  margin: 0 0 3rem 0;
  font-size: clamp(1.5rem, 3vw, 1.8rem);
  color: var(--color-primary);
}

.hero-header p {
  margin: 0.5rem 0;
  font-size: clamp(1.1rem, 2.5vw, 1.2rem);
  font-weight: 300;
}

.hero-header #descripcion {
  line-height: 2rem;
}

.hero p a {
  color: var(--color-dark);
  text-decoration: underline;
  margin: 0 1rem;
  transition: color 0.3s ease;
}

.hero p a:hover {
  color: var(--color-primary);
}

.hero strong {
  font-weight: 700;
}

/* --- Contenido posterior --- */
.content {
  min-height: 100vh;
  padding: 4rem 2rem;
  box-sizing: border-box;
  background: #f5f5f5;
}

.content:nth-child(even) {
  background: #e0e0e0;
}

/* --- Botones ---*/
/* CONTENEDOR para alinear los dos botones */
.buttons {
  display: flex;
  gap: 1rem;            /* espacio entre botones */
  margin-top: 2rem;
  margin-bottom: 2.5rem;
}

/* BOTÓN BASE: estilo común */
.btn {
  display: inline-flex; /* para alinear icono y texto en línea */
  align-items: center;
  gap: 0.5rem;          /* espacio entre icono y texto */
  padding: 0.75rem 1rem;
  font-family: 'Archivo', sans-serif;
  font-weight: 500;
  font-size: clamp(1rem, 2vw, 1.3rem);
  border-radius: 1rem;  /* bordes redondeados estilo “pill” */
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none; /* por si es <a> */
}

/* Variante 1: Botón sólido */
.btn-primary {
  background-color: var(--color-dark); /* verde principal */
  color: var(--color-light);
  border: 2px solid var(--color-dark);
}

.btn-primary a {
  color: var(--color-light);
  text-decoration: none;
}

.btn-primary:hover {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

/* Variante 2: Botón contorneado */
.btn-outline {
  background-color: transparent;
  color: var(--color-dark);
  border: 2px solid var(--color-dark);
}

.btn-outline:hover {
  background-color: var(--color-primary);
  color: var(--color-dark);
  border-color: var(--color-primary);
}

/* Opcional: estilo para iconos SVG o <img> */
.btn svg,
.btn img {
  width: 1.2rem;
  height: 1.2rem;
}


/* ---------- MEDIA QUERIES ---------- */

/* Tablets y pantallas medianas */
@media (max-width: 992px) {
  .hero {
    padding: 1.5rem;
  }
  .content {
    padding: 3rem 1.5rem;
  }
}

/* Móviles */
@media (max-width: 600px) {
  .hero {
    padding: 1rem;
  }
  .hero-social a {
    margin: 0 0.5rem;
    font-size: 0.9rem;
  }
  .content {
    padding: 2rem 1rem;
  }
}

/* Tablets: ancho casi completo y padding moderado */
@media (max-width: 992px) {
  .hero {
    width: 80%;
    padding: 3rem 2rem;
  }
}

/* Móviles: ancho completo y padding reducido */
@media (max-width: 600px) {
  .hero {
    width: 100%;
    padding: 2rem 1rem;
  }
}
