/* GLOBAL */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
body {
  color: #33373a;
  background-color: #ffffff;
}
/*titulos*/
.titulo-home {
  font-size: 3rem !important;
  color: #255946;
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-bottom: 10px;
}
.text-green {
  color: #69b517;
}
.lema {
  font-size: 1.5rem;
  color: #fe131e;
  font-style: italic;
  font-weight: 500;
}

/* NAVBAR */
:root {
  --fondo-navbar: #ffffff;
  --text-navbar: #2e7d32;
  --text-active-navbar: #191a19;
  --fondo-btn-navbar: transparent;
  --text-btn-navbar: #09490c;
  --border-btn-navbar: var(--text-navbar);
}
.navbar {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  padding: 0.5rem 0;
  background-color: var(--fondo-navbar) !important;
}

.navbar-nav .nav-link {
  color: var(--text-navbar);
  font-weight: 500;
  letter-spacing: 0.5px;
  transition: color 0.2s, background 0.2s;

  padding: 0.5rem 1rem;
}

.navbar-nav .nav-link.active {
  color: var(--text-active-navbar);
  background-color: --;
  transition: color 0.2s, border-bottom-color 0.2s;
}
.navbar-nav .nav-link:hover {
  color: var(--text-active-navbar);
  border-bottom: 2px solid #09490c;
  transition: color 0.2s, border-bottom-color 0.2s;
}
.btn-outline-light {
  border-width: 2px;
  font-weight: 500;
  transition: background 0.2s, color 0.2s;
}

.btn-outline-light {
  background: var(--fondo-btn-navbar);
  color: var(--text-btn-navbar);
  border-color: var(--border-btn-navbar);
}
.navbar-toggler {
  border-color: var(--text-navbar);
}
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgb(46,125,50)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}
.navbar-brand img {
  transition: transform 0.2s;
}

.navbar-nav .nav-link {
  color: var(--text-navbar);
  font-weight: 500;
  letter-spacing: 0.5px;
  transition: color 0.2s, background 0.2s;

  padding: 0.5rem 1rem;
}

.navbar-nav .nav-link.active {
  color: var(--text-active-navbar);
  background-color: --;
  transition: color 0.2s, border-bottom-color 0.2s;
}
.navbar-nav .nav-link:hover {
  color: var(--text-active-navbar);
  border-bottom: 2px solid #09490c;
  transition: color 0.2s, border-bottom-color 0.2s;
}
.btn-outline-light {
  border-width: 2px;
  font-weight: 500;
  transition: background 0.2s, color 0.2s;
}

.btn-outline-light {
  background: var(--fondo-btn-navbar);
  color: var(--text-btn-navbar);
  border-color: var(--border-btn-navbar);
}
.navbar-toggler {
  border-color: var(--text-navbar);
}
.navbar-toggler-icon {
  color: var(--text-navbar);
}

@media (max-width: 991.98px) {
  .navbar-nav .nav-link {
    margin-bottom: 0.5rem;
    padding: 0.5rem 0.75rem;
  }
  .btn-outline-light {
    width: 100%;
    margin-top: 0.5rem;
  }
  .custom-caption {
    max-width: 100%;
    min-height: 100%;
    padding: 0.75rem;
  }

  .custom-caption .btn-outline-light {
    width: 100%;
    margin-top: 0.5rem;
  }
}
/* Ajustes especiales para pantallas >= 1920px */
@media (min-width: 1920px) {
  .navbar {
    padding: 1rem 2rem;
  }

  .navbar-brand img {
    height: 110px; /* Logo más grande */
  }

  .navbar-nav .nav-link {
    font-size: 1.3rem;
    padding: 0.75rem 1.25rem;
  }

  .btn-outline-light {
    font-size: 1.1rem;
    padding: 0.6rem 1.2rem;
  }
}

/* Ultra pantallas (4K, >= 2560px) */
@media (min-width: 2560px) {
  .navbar-brand img {
    height: 130px;
  }

  .navbar-nav .nav-link {
    font-size: 1.5rem;
  }

  .btn-outline-light {
    font-size: 1.25rem;
    padding: 0.75rem 1.5rem;
  }
}

/* FOOTERS */
.footer {
  background-color: #69b517;
  color: #f1f1f1;
  padding: 50px 20px 20px;
}

.footer-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 30px;
  max-width: 1200px;
  margin: auto;
}

.footer h3 {
  margin-bottom: 15px;
  font-size: 20px;
  font-weight: bold;
}

.footer p,
.footer a {
  font-size: 15px;
  color: #dcdcdc;
  line-height: 1.6;
  text-decoration: none;
}

.footer a:hover {
  color: #ffffff;
}

.social-links a {
  display: inline-block;
  margin-right: 12px;
  font-size: 22px;
  color: #dcdcdc;
  transition: transform 0.3s, color 0.3s;
}

.social-links a:hover {
  color: #ffffff;
  transform: scale(1.2);
}

.footer-col i {
  margin-right: 8px;
  font-size: 18px;
}

.footer-bottom {
  text-align: center;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  margin-top: 30px;
  padding-top: 15px;
  font-size: 14px;
  color: #ccc;
}

/* Para pantallas Full HD (1920px en adelante) */
@media (min-width: 1920px) {
  body {
    font-size: 1.2rem; /* aumenta un poco la fuente */
  }

  .container,
  .container-fluid {
    max-width: 1800px; /* controla que no quede demasiado al centro */
  }

  h1,
  h2,
  h3 {
    font-size: 1.5em; /* ajusta títulos */
  }

  .navbar {
    padding: 1.2rem 4rem; /* más espacio en la barra */
  }
}

/* Para pantallas aún más grandes (2K, 4K) */
@media (min-width: 2560px) {
  body {
    font-size: 1.5rem;
  }

  .container,
  .container-fluid {
    max-width: 2200px;
  }

  h1,
  h2,
  h3 {
    font-size: 2em;
  }
}
.slide-in-top {
  -webkit-animation: slide-in-top 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
  animation: slide-in-top 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
}

@-webkit-keyframes slide-in-top {
  0% {
    -webkit-transform: translateY(-1000px);
    transform: translateY(-1000px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes slide-in-top {
  0% {
    -webkit-transform: translateY(-1000px);
    transform: translateY(-1000px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
  }
}
