/* Flag language switcher styles for orbit/centered flags */
.language-switcher {
  position: absolute;
  right: 1.5rem;
  top: 50%;
  transform: translateY(-50%);
  width: 6.5rem;
  height: 6.5rem;
}

.language-switcher__orbit {
  position: relative;
  width: 100%;
  height: 100%;
}

.language-switcher__flag {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.41rem;
  height: 1.41rem;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 2px solid rgba(255, 255, 255, 0.85);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  text-decoration: none;
}

.language-switcher__flag--active {
  cursor: default;
  width: calc(1.41rem * 1.5);
  height: calc(1.41rem * 1.5);
  border-width: 3px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.language-switcher__flag--orbit {
  --radius: 2.4rem;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(var(--angle)) translateX(var(--radius)) rotate(calc(var(--angle) * -1));
}

.language-switcher__flag--orbit:hover,
.language-switcher__flag--orbit:focus-visible {
  transform: translate(-50%, -50%) rotate(var(--angle)) translateX(calc(var(--radius) + 0.18rem)) rotate(calc(var(--angle) * -1));
  width: 1.53rem;
  height: 1.53rem;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35);
}

.language-switcher__flag:focus-visible {
  outline: 3px solid #ffffff;
  outline-offset: 4px;
}

.language-switcher__label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 700px) {
  .language-switcher {
    right: 1.3rem;
    width: 3.36rem;
    height: 3.36rem;
  }

  .language-switcher__flag {
    width: 1.23rem;
    height: 1.23rem;
  }

  .language-switcher__flag--active {
    width: calc(1.23rem * 1.5);
    height: calc(1.23rem * 1.5);
  }

  .language-switcher__flag--orbit {
    --radius: 2rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .language-switcher__flag {
    transition: none;
  }
}
