.site-header__cta:hover {
  background: rgb(255 26 61);
}

.map-shell {
  position: relative;
  min-height: 340px;
  display: flex;
  flex-direction: column;
}

.map-frame,
.map-canvas {
  width: 100%;
  flex: 1;
  min-height: 340px;
  border: 0;
}

.map-open-link {
  display: block;
  padding: 0.75rem 1rem;
  text-align: center;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(242 242 244 / 0.55);
  background: rgb(10 10 12);
  border-top: 1px solid rgb(242 242 244 / 0.08);
  transition: color 0.2s ease;
}

.map-open-link:hover {
  color: rgb(228 2 43);
}

.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.lang-switch__select {
  appearance: none;
  border: 1px solid rgb(242 242 244 / 0.15);
  background: rgb(10 10 12 / 0.6)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23f2f2f4' d='M1 1l4 4 4-4'/%3E%3C/svg%3E")
    no-repeat right 0.45rem center / 10px 6px;
  color: rgb(242 242 244 / 0.75);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.42rem 1.35rem 0.42rem 0.55rem;
  border-radius: 0;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
}

.lang-switch__select:hover,
.lang-switch__select:focus-visible {
  color: rgb(242 242 244);
  border-color: rgb(228 2 43);
  background-color: rgb(228 2 43 / 0.1);
  outline: none;
}

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

.lang-switch button {
  border: 1px solid rgb(242 242 244 / 0.15);
  background: transparent;
  color: rgb(242 242 244 / 0.55);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.35rem 0.55rem;
  transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.lang-switch button.is-active,
.lang-switch button:hover {
  color: rgb(242 242 244);
  border-color: rgb(228 2 43);
  background: rgb(228 2 43 / 0.12);
}

@media (width < 1024px) {
  .site-header .lang-switch__select {
    padding: 0.38rem 1.25rem 0.38rem 0.5rem;
    font-size: 0.65rem;
  }

  .site-header .lang-switch button {
    padding: 0.38rem 0.52rem;
    font-size: 0.65rem;
  }
}

.google-reviews-logo {
  display: block;
  height: 1.35rem;
  width: auto;
  flex-shrink: 0;
}

.reviews-summary {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  color: rgb(242 242 244 / 0.5);
  font-size: 0.875rem;
  transition: color 0.2s ease;
}

.reviews-summary:hover {
  color: rgb(228 2 43);
}

.reviews-summary__text {
  line-height: 1.4;
}
