.contact-hero {
  padding-top: var(--space-40);
  padding-bottom: var(--space-32);
}

.contact-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-24);
  align-items: center;
}

.contact-hero__lead {
  max-width: 40rem;
}

.contact-hero__actions {
  margin-top: var(--space-16);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}

.contact-hero__badges {
  margin-top: var(--space-16);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}

.contact-hero__card {
  margin-left: auto;
  max-width: 28rem;
}

.small-text {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.contact-form-grid {
  align-items: flex-start;
}

.contact-form {
  display: flex;
  flex-direction: column;
}

.contact-form__grid {
  gap: var(--space-12);
}

.contact-form__label {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}

.contact-form__checkboxes {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-6);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.contact-checkbox input[type="checkbox"] {
  margin-top: 2px;
}

.contact-form__submit-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  margin-top: var(--space-8);
}

.contact-form__note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.contact-aside {
  max-height: 100%;
  overflow: hidden auto;
}

.contact-aside__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
  margin-top: var(--space-12);
}

.contact-aside__list h4 {
  font-size: var(--font-size-md);
  margin-top: 0;
}

.location-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: var(--space-24);
  align-items: flex-start;
}

.section__heading--left {
  text-align: left;
}

.location-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}

.location-map__card h3 {
  margin-bottom: var(--space-8);
}

.location-map__frame {
  position: relative;
  margin-top: var(--space-8);
  border-radius: var(--radius-xl);
  overflow: hidden;
  min-height: 260px;
  background: radial-gradient(circle at 10% 0, rgba(255, 63, 183, 0.4) 0, transparent 45%),
              radial-gradient(circle at 90% 100%, rgba(24, 212, 255, 0.45) 0, transparent 50%),
              linear-gradient(135deg, #050611, #111322);
}

.location-map__gradient {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(#1a1c35 1px, transparent 1px),
                    linear-gradient(90deg, #1a1c35 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: 0.6;
}

.location-map__pin {
  position: absolute;
  top: 46%;
  left: 56%;
  width: 18px;
  height: 18px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  background: radial-gradient(circle at 30% 30%, #fff 0, #ff3fb7 40%, #a30067 100%);
  box-shadow: var(--shadow-glow-accent);
}

.location-map__label {
  position: absolute;
  top: 46%;
  left: 60%;
  transform: translateY(-50%);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  background: rgba(5, 6, 17, 0.9);
  border: 1px solid rgba(245, 201, 106, 0.7);
  font-size: var(--font-size-xs);
}

.location-map__hint {
  margin-top: var(--space-12);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.newsletter-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-24);
  align-items: center;
}

.newsletter-form {
  display: flex;
  flex-direction: column;
}

.newsletter-form__submit-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.newsletter-form__note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

@media (max-width: 1024px) {
  .contact-hero__inner {
    grid-template-columns: minmax(0, 1fr);
  }

  .contact-hero__card {
    max-width: 100%;
  }

  .location-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .newsletter-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 768px) {
  .contact-hero {
    padding-top: var(--space-32);
  }

  .location-map__frame {
    min-height: 220px;
  }
}
