@font-face {
  font-family: 'Ella Brutalist';
  src: url('../fonts/EllaBrutalist.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}

/* ===============================
   VARIABLES GLOBALES
   =============================== */
:root {
  /* ðŸŽ¨ Colores */
  --color-primario: #ffd900;   /* Amarillo vibrante */
  --color-secundario: #333333; /* Gris oscuro casi negro */
  --color-blanco: #ffffff;

  /* ðŸ–‹ï¸ TipografÃ­as */
  --fuente-principal: 'Ella Brutalist', sans-serif;
  --fuente-secundaria: 'Montserrat', sans-serif;

  /* ðŸ“ TamaÃ±os responsivos */
  --fs-h1: clamp(2rem, 5vw, 3.5rem);
  --fs-h2: clamp(1.5rem, 4vw, 2.5rem);
  --fs-h3: clamp(1.25rem, 3vw,  1.8rem);
  --fs-body: clamp(1rem, 2vw, 1.125rem);
}
/* ===============================
   ESTILOS BASE
   =============================== */
body {
  font-family: var(--fuente-secundaria);
  font-size: var(--fs-body);
  color: var(--color-secundario);
  background-color: var(--color-blanco);
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--fuente-principal);
  font-weight: 700;
  color: var(--color-secundario);
  line-height: 1.2;
}

p {
  font-family: var(--fuente-secundaria);
}

/* ===============================
   BOTONES GENERALES
   =============================== */
.btn {
  display: inline-block;
  padding: var(--spacing-xs) var(--spacing-md);
  font-family: var(--fuente-secundaria);
  font-weight: 600;
  font-size: 1rem;
  border-radius: var(--radius);
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition);
  border: none;
}

/* BotÃ³n amarillo principal */
.btn-primario {
  background: var(--color-primario);
  color: var(--color-secundario);
}
.btn-primario:hover {
  background: #e6c200;
  transform: translateY(-2px);
}

/* BotÃ³n secundario (oscuro) */
.btn-secundario {
  background: var(--color-secundario);
  color: var(--color-blanco);
}
.btn-secundario:hover {
  background: #333333;
  transform: translateY(-2px);
}

/* BotÃ³n con borde */
.btn-outline {
  background: transparent;
  border: 2px solid var(--color-secundario);
  color: var(--color-secundario);
}
.btn-outline:hover {
  background: var(--color-secundario);
  color: var(--color-blanco);
}

/* ===============================
   NAVBAR
=============================== */
.navbar {
    background-color: var(--color-primario);
    height: 8rem ;
}   
.navbar-brand {
    font-family: var(--fuente-principal);
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    text-decoration: none;
    font-weight: 500;
    padding-left: 6rem; 
}
.navbar-toggler {
    border: none; /* Quita el borde por defecto */
    font-size: 1.5rem; /* Tamaño del ícono o símbolo */
    color: var(--color-secundario); /* Color del ícono */
    background-color: transparent; /* Fondo transparente */
    padding: var(--spacing-xs); /* Espaciado */
    transition: var(--transition); /* Animación suave */
}
.collapse {
    justify-content: flex-end; /* Alinea los elementos a la derecha */
    padding-right: 6rem; 
}
.nav-item {
    font-size: 1.1rem;
    font-weight: 200;
    font-family: var(--fuente-principal);
    padding-right: 2rem;
    margin-right: 0;
}
.nav-link {
    position: relative;                   /* necesario para el ::after */
    font-family: var(--fuente-principal);
    font-size: 1rem;
    color: var(--color-secundario);
    text-decoration: none;
    padding: 0.5rem 1rem;
    transition: color 0.3s ease;
}

.nav-link::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0%;
    height: 2px;                          
    background-color: var(--color-secundario);
    transform-origin: center;
    transition: width 0.3s ease;
}

.nav-link:hover {
    color: var(--color-blanco);
}

.nav-link:hover::after {
    width: 100%;                        
}




/* ===============================
   ESTILOS ESPECÍFICOS AVISO LEGAL
   =============================== */

.aviso-legal {
  max-width: 900px;
  margin: 8rem auto 4rem auto; /* espacio con navbar fijo */
  padding: 2rem;
  background-color: #f9f9f9;
  border-radius: 1rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.aviso-legal h1 {
  font-size: var(--fs-h1);
  color: var(--color-secundario);
  margin-bottom: 1.5rem;
  text-align: center;
  border-bottom: 3px solid var(--color-primario);
  padding-bottom: 0.5rem;
}

.aviso-legal h2 {
  font-size: var(--fs-h2);
  color: var(--color-primario);
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-family: var(--fuente-principal);
}

.aviso-legal p {
  margin-bottom: 1rem;
  text-align: justify;
  font-family: var(--fuente-secundaria);
  line-height: 1.7;
}

.aviso-legal strong {
  color: var(--color-secundario);
}

.aviso-legal section {
  margin-bottom: 2rem;
}

/* ===============================
   RESPONSIVE
   =============================== */
@media (max-width: 768px) {
  .aviso-legal {
    padding: 1.5rem;
    margin: 6rem 1rem 2rem 1rem;
  }
  .aviso-legal h1 {
    font-size: 2rem;
  }
  .aviso-legal h2 {
    font-size: 1.5rem;
  }
}
