.elementor-location-footer {
  display: none !important;
}

.koe-footer {
  position: relative;
  overflow: hidden;
  background: #050505;
  color: #fff;
  font-family: "Roboto Mono", "Courier New", monospace;
}

.koe-footer a {
  color: inherit;
  text-decoration: none;
}

.koe-footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: clamp(24px, 3.2vw, 44px) clamp(28px, 5vw, 72px);
  align-items: start;
  padding: clamp(56px, 7vw, 96px) clamp(24px, 6vw, 110px) clamp(42px, 5vw, 70px);
}

.koe-footer-nav {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(24px, 5vw, 78px);
  align-items: center;
  justify-content: center;
  justify-self: center;
  color: #fff;
  font-size: clamp(15px, 1.28vw, 21px);
  font-weight: 800;
  letter-spacing: 0.12em;
  line-height: 1;
  text-transform: uppercase;
}

.koe-footer-nav a,
.koe-footer-office a,
.koe-footer-instagram {
  transition: opacity 180ms ease, transform 180ms ease;
}

.koe-footer-nav a:hover,
.koe-footer-office a:hover,
.koe-footer-instagram:hover {
  opacity: 0.62;
}

.koe-footer-instagram {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  justify-self: end;
}

.koe-footer-instagram svg {
  display: block;
  width: 25px;
  height: 25px;
  fill: currentColor;
}

.koe-footer-offices {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: minmax(210px, 300px) minmax(210px, 300px);
  gap: clamp(92px, 16vw, 220px);
  justify-content: center;
  padding-top: clamp(8px, 1.5vw, 18px);
}

.koe-footer-office {
  display: grid;
  gap: 9px;
  color: rgba(255, 255, 255, 0.72);
  font-size: clamp(13px, 1.02vw, 16px);
  line-height: 1.45;
  letter-spacing: 0.04em;
}

.koe-footer-office:first-child {
  transform: translateX(clamp(18px, 3vw, 44px));
}

.koe-footer-office p {
  margin: 0;
}

.koe-footer-label {
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.koe-footer-marquee {
  border-block: 1px solid rgba(255, 255, 255, 0.16);
  overflow: hidden;
  white-space: nowrap;
}

.koe-footer-marquee-track {
  display: flex;
  width: max-content;
  animation: koe-footer-marquee 32s linear infinite;
}

.koe-footer-marquee span {
  display: block;
  padding: clamp(18px, 2.5vw, 38px) clamp(18px, 2.8vw, 42px);
  color: #fff;
  font-size: clamp(92px, 14.5vw, 260px);
  font-weight: 950;
  line-height: 0.78;
  letter-spacing: -0.055em;
}

.koe-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 22px clamp(24px, 6vw, 110px);
  color: rgba(255, 255, 255, 0.52);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.koe-footer-bottom p {
  margin: 0;
}

@keyframes koe-footer-marquee {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50%, 0, 0);
  }
}

@media (max-width: 760px) {
  .koe-footer-grid {
    grid-template-columns: 1fr auto;
    gap: 28px 18px;
    padding: 44px 22px 34px;
  }

  .koe-footer-nav {
    align-content: start;
    display: grid;
    gap: 14px;
    justify-content: start;
    justify-self: start;
    text-align: left;
    font-size: 15px;
    letter-spacing: 0.1em;
  }

  .koe-footer-instagram {
    width: 38px;
    height: 38px;
  }

  .koe-footer-instagram svg {
    width: 24px;
    height: 24px;
  }

  .koe-footer-offices {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-top: 8px;
  }

  .koe-footer-office {
    font-size: 13px;
  }

  .koe-footer-office:first-child {
    transform: none;
  }

  .koe-footer-marquee span {
    padding: 16px 18px;
    font-size: clamp(68px, 24vw, 118px);
    line-height: 0.86;
  }

  .koe-footer-bottom {
    padding: 18px 22px 24px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .koe-footer-marquee-track {
    animation: none;
  }
}
