
/* Footer Template 1 styling (Zuricom) */
.zuri-subscribe { position: relative; background-size: cover; background-position:center; padding: 48px 0; color:#fff; }
.zuri-subscribe:before { content:""; position:absolute; inset:0; background: rgba(0,0,0,.35); }
.zuri-subscribe__inner { position:relative; display:flex; align-items:center; gap: 18px; justify-content: space-between; flex-wrap:wrap; }
.zuri-subscribe__title { font-size: 36px; font-weight: 800; margin: 0 0 6px; }
.zuri-subscribe__text { margin:0; opacity: .9; }
.zuri-subscribe__action .btn { padding: 12px 22px; border-radius: 0; }

.zuri-footer .zuri-footer__widgets {
  background: var(--color-footer-bg);
  color: var(--color-footer-text);
  padding: 56px 0;
}

.zuri-footer .footer-widget h4,
.zuri-footer .widget-title {
  color: var(--color-footer-text);
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 14px;
}

.zuri-footer .footer-widget,
.zuri-footer .footer-widget p,
.zuri-footer .footer-widget li,
.zuri-footer .footer-widget span,
.zuri-footer .footer-widget div {
  color: var(--color-footer-text);
}

.zuri-footer .footer-widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.zuri-footer .footer-widget ul li {
  margin: 10px 0;
}

.zuri-footer .footer-widget a {
  color: var(--color-footer-link);
  text-decoration: none;
}

.zuri-footer .footer-widget a:hover {
  color: var(--color-footer-link-hover);
}

.zuri-footer .footer-widget--brand p {
  margin-top: 10px;
  opacity: 1;
}

.zuri-footer .zuri-footer__social {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}

.zuri-footer .zuri-footer__social a {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid currentColor;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-footer-link);
}

.zuri-footer .zuri-footer__social a:hover {
  color: var(--color-footer-link-hover);
  border-color: currentColor;
}

.zuri-footer .zuri-footer__bottom {
  background: var(--color-footer-bg);
  color: var(--color-footer-text);
  padding: 20px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}

.zuri-footer .zuri-footer__bottom,
.zuri-footer .zuri-footer__bottom * {
  color: var(--color-footer-text);
}

.zuri-footer .zuri-footer__bottom a {
  color: var(--color-footer-link);
}

.zuri-footer .zuri-footer__bottom a:hover {
  color: var(--color-footer-link-hover);
}

.zuri-footer .zuri-footer__bottom-inner {
  display: flex;
  align-items: center;
  gap: 18px;
  justify-content: space-between;
  flex-wrap: wrap;
}

.zuri-footer .zuri-footer__payments {
  opacity: .9;
  font-size: 13px;
}

.zuri-footer .zuri-footer__copy {
  font-size: 13px;
}

@media (max-width: 991px) {
  .zuri-subscribe__title { font-size: 30px; }
}

/* Better mobile stacking for Footer Template 1 */
@media (max-width: 767px) {
  .zuri-subscribe { padding: 36px 0; }

  .zuri-subscribe__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  .zuri-subscribe__title { font-size: 24px; }
  .zuri-subscribe__action { width: 100%; }
  .zuri-subscribe__action .btn {
    width: 100%;
    justify-content: center;
  }

  /* If widgets aren't already in a grid, this guarantees stacking */
  .zuri-footer .footer-widget {
    width: 100%;
    margin-bottom: 22px;
  }

  .zuri-footer .zuri-footer__bottom-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}

/* Footer Template 1 layout grid */
/* .zuri-footer .zuri-footer__widgets .container */
.zuri-footer .zuri-footer__widgets .row.zuricom-flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 30px;
}

/* Desktop: 4 columns */
@media (min-width: 992px) {
  .zuri-footer .footer-widget {
    flex: 1 1 calc(25% - 30px);
    max-width: calc(25% - 23px);
    min-width: 220px;
  }
}

/* Tablet: 2 columns */
@media (min-width: 576px) and (max-width: 991px) {
  .zuri-footer .footer-widget {
    flex: 1 1 calc(50% - 30px);
  }
}

/* Mobile: single column, centered */
@media (max-width: 575px) {
  .zuri-footer .zuri-footer__widgets {
    padding: 40px 0;
  }

  .zuri-footer .footer-widget {
    flex: 1 1 100%;
    text-align: center;
  }

  .zuri-footer .footer-widget ul {
    display: inline-block;
    text-align: left;
  }

  .zuri-footer .zuri-footer__social {
    justify-content: center;
  }
}
