/* ==========================================================================
   CONTACT PAGE STYLES — Happy Hive
   Design system: DESIGN.md "The Energetic Atelier"
   ========================================================================== */

/* ══════════════════════════════════════════════════════════════════════════
   CONTACT SECTION (info + form two-column)
   ══════════════════════════════════════════════════════════════════════════ */
.contact-section {
  padding-block: var(--sp-20);
  background: var(--background);
}

.contact-section__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-12);
  align-items: start;
}

@media (min-width: 900px) {
  .contact-section__inner {
    grid-template-columns: 1fr 1.35fr;
    gap: var(--sp-16);
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   CONTACT INFO (left column)
   ══════════════════════════════════════════════════════════════════════════ */
.contact-info {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

.contact-info__heading {
  font-size: var(--text-headline-lg);
  font-weight: 800;
  color: var(--on-surface);
  letter-spacing: var(--tracking-tight);
}

/* Info blocks */
.contact-info__block {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.contact-info__label {
  font-size: var(--text-label-md);
  font-weight: 700;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--tertiary-container);
}

/* Individual info row */
.contact-info-row {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-start;
}

.contact-info-row__icon {
  font-size: 1.125rem;
  line-height: 1.5;
  flex-shrink: 0;
  width: 1.5rem;
  text-align: center;
}

.contact-info-row__text {
  font-size: var(--text-body-md);
  color: var(--on-surface-variant);
  line-height: var(--leading-relaxed);
}

.contact-info-row__link {
  font-size: var(--text-body-md);
  color: var(--primary);
  font-weight: 600;
  transition: color var(--ease-fast);
  line-height: var(--leading-relaxed);
}

.contact-info-row__link:hover { color: var(--primary-container); }

/* Contact person rows */
.contact-person {
  background: var(--surface);
  border-radius: var(--radius-lg);
  padding: var(--sp-4) var(--sp-5);
  box-shadow: var(--shadow-ambient);
  align-items: center;
}

.contact-person__name {
  font-size: var(--text-body-md);
  font-weight: 700;
  color: var(--on-surface);
}

.contact-person__role {
  font-size: var(--text-body-sm);
  color: var(--on-surface-variant);
  margin-bottom: var(--sp-2);
}

.contact-person__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}

.contact-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.75rem;
  border-radius: var(--radius-full);
  background: var(--surface-container-lowest);
  color: var(--primary);
  font-size: var(--text-body-sm);
  font-weight: 600;
  transition: background var(--ease-fast), color var(--ease-fast);
}

.contact-chip:hover {
  background: var(--primary-fixed);
}

.contact-chip--wa {
  background: #e8f5e9;
  color: #1b5e20;
}

.contact-chip--wa:hover {
  background: #c8e6c9;
}

/* ══════════════════════════════════════════════════════════════════════════
   ENROLLMENT FORM (right column)
   ══════════════════════════════════════════════════════════════════════════ */
.enrollment-form-wrap {
  /* sticks to top on large screens */
}

.enrollment-form-card {
  background: var(--surface);
  border-radius: var(--radius-xl);
  padding: var(--sp-8) var(--sp-8);
  box-shadow: var(--shadow-ambient);
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

@media (max-width: 599px) {
  .enrollment-form-card {
    padding: var(--sp-6);
  }
}

.enrollment-form__heading {
  font-size: var(--text-headline-lg);
  font-weight: 800;
  color: var(--on-surface);
  letter-spacing: var(--tracking-tight);
}

.enrollment-form__subtitle {
  font-size: var(--text-body-sm);
  color: var(--on-surface-variant);
  margin-top: calc(var(--sp-1) * -1);
}

/* ── Form layout ─────────────────────────────────────────────────────────── */
.enrollment-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}

@media (min-width: 520px) {
  .form-row { grid-template-columns: 1fr 1fr; }
}

/* ── Field component ─────────────────────────────────────────────────────── */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.field__label {
  font-size: var(--text-body-sm);
  font-weight: 700;
  color: var(--on-surface);
}

.field__required {
  color: var(--error);
  margin-left: 2px;
}

.field__input {
  width: 100%;
  padding: 0.6875rem var(--sp-4);
  background: var(--surface-container-lowest);
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-family);
  font-size: var(--text-body-md);
  color: var(--on-surface);
  outline: 2px solid transparent;
  outline-offset: 0;
  transition: outline-color var(--ease-fast), background var(--ease-fast);
  appearance: none;
  -webkit-appearance: none;
}

.field__input::placeholder { color: var(--on-surface-variant); opacity: 0.55; }

.field__input:focus {
  outline-color: var(--primary);
  background: var(--surface);
}

.field__select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%233a5060' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-4) center;
  padding-right: calc(var(--sp-4) + 1.5rem);
}

.field__textarea {
  resize: vertical;
  min-height: 90px;
}

/* Error state */
.field.has-error .field__input {
  outline-color: var(--error);
  background: #fff8f8;
}

.field__error {
  font-size: var(--text-label-md);
  color: var(--error);
  font-weight: 600;
  display: none;
}

.field.has-error .field__error { display: block; }

/* ── Checkbox field ──────────────────────────────────────────────────────── */
.field--checkbox {
  gap: var(--sp-2);
}

.field__checkbox-label {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-start;
  cursor: pointer;
}

.field__checkbox {
  flex-shrink: 0;
  width: 1.125rem;
  height: 1.125rem;
  margin-top: 2px;
  accent-color: var(--primary);
  cursor: pointer;
}

.field__checkbox-text {
  font-size: var(--text-body-sm);
  color: var(--on-surface-variant);
  line-height: var(--leading-relaxed);
}

.field__checkbox-text strong {
  color: var(--on-surface);
}

/* ── Submit button ───────────────────────────────────────────────────────── */
.enrollment-form__submit {
  width: 100%;
  margin-top: var(--sp-2);
  justify-content: center;
  font-size: var(--text-body-md);
  padding-block: 0.9375rem;
}

/* ══════════════════════════════════════════════════════════════════════════
   CTA BAND
   ══════════════════════════════════════════════════════════════════════════ */
.contact-cta {
  padding-block: var(--sp-20);
  background: var(--primary);
  text-align: center;
}

.contact-cta .section-tag {
  display: block;
  margin-bottom: var(--sp-3);
}

.contact-cta .section-title {
  color: #5a2800;
  margin-bottom: var(--sp-4);
}

.contact-cta__subtitle {
  font-size: var(--text-body-lg);
  line-height: var(--leading-relaxed);
  color: rgba(90, 40, 0, 0.80);
  max-width: 52ch;
  margin-inline: auto;
  margin-bottom: var(--sp-8);
}
