@font-face {
  font-family: "ArizonaFlare";
  src: url("../fonts/arizona_flare_300_normal_headings_h1-h6.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Helveesti";
  src: url("../fonts/helveesti_400_normal_body_ui.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "HelveestiBold";
  src: url("../fonts/helveesti_700_normal_body_labels.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

.contact {
  --contact-bg: #000;
  --contact-text: #fff;
  --contact-subtle: #6e6e6e;
  --contact-border: #ff;
  --contact-accent: #fff;
  --contact-gap-lg: 56px;
  --contact-gap-md: 28px;
  --contact-gap-sm: 12px;
}

.contact {
  padding: 72px 48px 80px;
  background: var(--contact-bg);
  color: var(--contact-text);
  font-family: "Helveesti", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.contact__title {
  font-family: "ArizonaFlare", serif;
  font-weight: 300;
  font-size: 50px;
  line-height: 1.3;
  letter-spacing: 0;
  margin: 0 0 16px 0;
}

.contact__subtitle {
  max-width: 520px;
  font-size: 14px;
  line-height: 1.3;
  color: var(--contact-subtle);
  margin: 0 0 var(--contact-gap-lg) 0;
}

.contact__info {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--contact-gap-md);
  margin-bottom: var(--contact-gap-lg);
}

.contact__block { min-height: 1px; }
.contact__label {
  font-family: "HelveestiBold", sans-serif;
  font-size: 14px;
  letter-spacing: 0.04em;
  margin: 0 0 10px;
}
.contact__details {
  font-size: 14px;
  line-height: 1.3;
  color: var(--contact-text);
  margin: 0;
}
.contact__link {
  color: var(--contact-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.contact__faq { margin-top: 12px; }
.contact__faq-title {
  font-family: "HelveestiBold", sans-serif;
  font-size: 18px;
  margin: 0 0 18px;
  letter-spacing: 0.02em;
}

.contact__faq-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.contact__faq-item + .contact__faq-item { margin-top: 10px; }

.contact__faq-question {
  appearance: none;
  width: 100%;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border: 0;
  border-bottom: 1px solid var(--contact-border);
  background: transparent;
  padding: 14px 0;
  font-size: 16px;
  line-height: 1.4;
  color: var(--contact-text);
  cursor: pointer;
}
.contact__faq-question:focus-visible {
  outline: 2px solid var(--contact-accent);
  outline-offset: 2px;
}

.contact__faq-icon {
  position: relative;
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
}
.contact__faq-icon::before,
.contact__faq-icon::after {
  content: "";
  position: absolute;
  inset: 50% auto auto 0;
  width: 100%;
  height: 1px;
  background: var(--contact-text);
  transform: translateY(-50%);
}
.contact__faq-icon::after {
  transform: translateY(-50%) rotate(90deg);
}
.contact__faq-question[aria-expanded="true"] .contact__faq-icon::after {
  opacity: 0; 
}

.contact__faq-answer {
  border-bottom: 1px solid var(--contact-border);
  padding: 12px 0 16px;
  color: var(--contact-subtle);
  font-size: 15px;
  line-height: 1.7;
}
.contact__faq-answer p { margin: 0; font-size: 16px; line-height: 1.3;}

@media (max-width: 880px) {
  .contact { padding: 56px 24px 64px; }
  .contact__info { grid-template-columns: 1fr; gap: 20px; }
  .contact__title { font-size: 30px; }
}
