/* Contact Us Page – DIYCraftWorks */

.contact-intro {
  margin-top: var(--space-12);
  margin-bottom: var(--space-8);
  background: linear-gradient(90deg, #ff889633 0%, #ffc94b33 100%);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-4);
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.contact-intro h1 {
  color: var(--color-primary);
  margin-bottom: var(--space-3);
}

.contact-main {
  margin-bottom: var(--space-12);
  align-items: flex-start;
}
@media (max-width: 900px) {
  .contact-main {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
  }
}

.contact-form-card {
  background: var(--color-neutral-100);
  min-width: 0;
  width: 100%;
  max-width: 520px;
}
.contact-form-card form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: var(--space-2);
}
.form-group label {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-neutral-800);
}
.form-group input,
.form-group select,
.form-group textarea {
  margin-top: 2px;
}
.form-note {
  font-size: var(--font-size-xs);
  color: var(--color-neutral-700);
  margin-top: var(--space-2);
}
#form-status, #event-signup-status {
  font-size: var(--font-size-sm);
  margin-top: var(--space-2);
  color: var(--color-success);
}
#form-status[aria-invalid="true"],
#event-signup-status[aria-invalid="true"] {
  color: var(--color-danger);
}

.contact-help-card {
  background: var(--color-neutral-200);
  min-width: 0;
  max-width: 390px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.help-links {
  display: flex;
  flex-direction: column;
  gap: 6px;
  list-style: none;
  font-size: var(--font-size-base);
}
.help-links a {
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: underline;
  transition: color var(--transition-fast);
}
.help-links a:hover { color: var(--color-text); }

.community-title {
  margin-top: var(--space-6);
  color: var(--color-primary);
  font-size: var(--font-size-md);
  font-weight: 700;
}

.social-links {
  list-style: none;
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-2);
}
.social-links li {
  display: inline;
}
.social-links a {
  display: block;
  border-radius: 50%;
  padding: 2px;
}
.social-links img {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--color-neutral-300);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition), border-color var(--transition);
}
.social-links a:hover img, .social-links a:focus-visible img {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
}

.collab-section {
  margin-top: var(--space-12);
  margin-bottom: var(--space-8);
  text-align: center;
  background: linear-gradient(90deg, #ffc94b22, #ff889622);
  border: 2px dotted var(--color-primary);
}
.collab-section h2 {
  margin-bottom: var(--space-2);
}
.collab-section .button {
  margin-top: var(--space-2);
}
.collab-section .small {
  color: var(--color-neutral-700);
}

.visit-section {
  margin-bottom: var(--space-8);
  background: var(--color-neutral-100);
}
.visit-section address {
  font-style: normal;
  font-family: var(--font-family-sans);
  margin-bottom: var(--space-2);
  font-size: var(--font-size-base);
}
.visit-details ul {
  font-size: var(--font-size-sm);
  color: var(--color-neutral-800);
  margin-bottom: var(--space-2);
  list-style: disc inside;
  padding-left: var(--space-2);
}
.event-signup-form {
  margin-top: var(--space-4);
  background: var(--color-neutral-200);
  padding: var(--space-4);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-xs);
  max-width: 430px;
}
.studio-map {
  margin-top: var(--space-4);
  width: 100%;
  min-height: 180px;
}

/* FAQ Accordion */
.faq-section {
  margin-bottom: var(--space-12);
}
.faq-accordion {
  background: var(--color-neutral-100);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
  margin-bottom: var(--space-4);
}
.faq-question {
  display: block;
  width: 100%;
  background: none;
  border: 0;
  padding: var(--space-4);
  text-align: left;
  font-size: var(--font-size-base);
  font-weight: 700;
  color: var(--color-primary);
  cursor: pointer;
  border-bottom: 1px solid var(--color-neutral-300);
  transition: background var(--transition-fast);
}
.faq-question[aria-expanded="true"] {
  background: var(--color-neutral-200);
  color: var(--color-text);
}
.faq-question:focus-visible {
  background: var(--color-warning);
  outline: 2px solid var(--color-warning);
  color: var(--color-text);
}
.faq-answer {
  padding: var(--space-4);
  font-size: var(--font-size-base);
  color: var(--color-text);
  background: var(--color-neutral-200);
}
.faq-bottom {
  text-align: center;
  margin-top: var(--space-4);
}

/* Responsive tweaks */
@media (max-width: 900px) {
  .faq-accordion, .collab-section, .visit-section, .contact-help-card, .contact-form-card {
    padding: var(--space-4) !important;
  }
  .studio-map { height: 160px; }
  .contact-intro { padding: var(--space-6) var(--space-1); }
}
@media (max-width:600px) {
  .contact-help-card, .contact-form-card, .event-signup-form {
    max-width: 100%;
  }
  .faq-question, .faq-answer {
    padding: var(--space-2);
    font-size: var(--font-size-sm);
  }
  .collab-section, .visit-section {
    margin-top: var(--space-6);
  }
}
