/* Global Styles */

.footer__link, .footer__social-link, .footer__address-block, .footer__item a {
  text-decoration: none;
  color: var(--text-color-light);
  transition: opacity var(--transition-duration-default) var(--transition-easing-smooth),
              color var(--transition-duration-default) var(--transition-easing-smooth);
}

/* Footer Base */
.footer {
  background-color: var(--color-secondary); /* #1E1E1E, 10% accent, replaced --color-black */
  padding: var(--spacing-large);
  box-shadow: var(--shadow-md);
}

/* Footer Top Container */
.footer__top {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--spacing-large);
  margin: 0 var(--spacing-large) var(--spacing-large);
}

/* Footer Columns */
.footer__column {
  flex: 1 1 200px;
  min-width: 200px;
}

.footer__column--logo {
  display: flex;
  justify-content: center;
}

.footer__column--narrow {
  flex: 0.5 1 100px;
  min-width: 100px;
  text-align: center;
}

/* Footer Logo */
.footer__logo {
  display: block;
  width: 97%;
  max-width: 200px;
  height: auto;
  object-fit: contain;
  margin-bottom: var(--spacing-medium);
  opacity: 0.8;
  transform: translateY(0);
  transition: all var(--transition-duration-default) var(--transition-easing-smooth);
}

.footer__logo:hover {
  width: 100%;
  opacity: 1;
  transform: translateX(-5px);
  box-shadow: var(--shadow-xs);
}

/* Footer Titles */
.footer__title {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-medium);
  text-transform: uppercase;
  color: var(--text-color-light);
}

/* Footer Items and Links */
.footer__item, .footer__link, .footer__social-link, .footer__address-block {
  font-family: var(--font-family-primary);
  margin-bottom: var(--spacing-small);
  opacity: 0.8;
  color: var(--text-color-light);

}

.footer__item:hover, .footer__link:hover, .footer__social-link:hover, .footer__address-block:hover {
  opacity: 1;
  transition: all var(--transition-duration-default) var(--transition-easing-smooth);
  text-decoration: underline;
}

.footer__item i.fab {
  color: var(--color-success); /* #6AA84F, replaced --whatsapp-color */
}

.footer__map-icon, .footer__mail-icon {
  color: var(--color-info); /* #5BC0DE, replaced --info-color */
}

/* Address Block */
.footer__address {
  font-style: normal;
}

.footer__address-block {
  align-items: center;
  gap: 8px; /* Espacio entre icono y texto */
  text-decoration: none;
}

.footer__mail-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
}
.footer__mail-link:hover {
  text-decoration: underline;
}

/* Navigation and Social Lists */
.footer__list, .footer__socials {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer__list li {
  padding: var(--spacing-xx-small) 0;
}

.footer__socials {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-small);
}

/* Footer Bottom (Credit Section) */
.footer__bottom {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 55px;
  margin-top: auto;
  background: var(--wf-bg); /* #151C25 */
  border-top: 3px solid var(--wf-border); /* #799C9B */
  overflow: hidden;
}

.footer__bottom::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background-color: var(--wf-strip); /* #4C6160 */
  transition: left 1.2s ease-in-out;
  z-index: 1;
}

.footer__bottom:hover::before {
  left: 0;
}

/* Credit Text */
.footer__bottom p {
  position: relative;
  z-index: 2;
  color: var(--wf-text); /* #B2CFCD */
  font-size: var(--font-size-sm); /* 0.875rem */
  line-height: 55px;
  margin: 0;
  text-align: center;
  transition: color 1.2s ease-in-out;
}

.footer__bottom:hover p {
  color: var(--wf-bg); /* #151C25 */
  font-weight: var(--font-weight-semibold); /* 600 */
}

.credit-text {
  width: 100%;
}

/* Designer Link */
.wf {
  font-weight: var(--font-weight-semibold); /* 600 */
  color: var(--wf-text); /* #B2CFCD */
  padding-left: 3px;
  text-decoration: underline;
}

.wf:hover {
  font-size: 1.2em;
  color: var(--accent-color); /* #B59E5B, 30% primary */
  transition: all var(--transition-duration-default) var(--transition-easing-smooth);
}

/* Font Awesome Icons */
.svg-inline--fa {
  padding-left: 3px;
}

/* Media Queries */
@media (max-width: 1024px) {
  .footer {
    padding: var(--spacing-medium);
  }
  .footer__top {
    gap: var(--spacing-medium);
  }
}

@media (max-width: 768px) {
  .footer__top {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .footer__column {
    flex: 1 1 auto;
    width: 100%;
    max-width: 400px;
  }
  .footer__socials {
    flex-direction: row;
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .footer {
    padding: var(--spacing-small);
  }
  .footer__title {
    font-size: var(--font-size-lg); /* 1.25rem, replaced --font-size-h5 */
  }
}