/* ===============================================================
   ZONA IMAGINARIA - Contact Page
   =============================================================== */

.zi-contact {
  min-height: 80vh;
  background:
    radial-gradient(circle at top left, rgba(255, 193, 7, 0.08), transparent 28%),
    radial-gradient(circle at 90% 5%, rgba(34, 211, 238, 0.08), transparent 24%),
    var(--zi-bg-primary);
  color: var(--zi-text-primary);
}

.zi-contact__hero {
  padding: var(--zi-space-4xl) 0 var(--zi-space-2xl);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.zi-contact__hero-inner {
  max-width: 1400px;
}

.zi-contact__eyebrow {
  margin: 0 0 var(--zi-space-sm);
  color: var(--zi-gold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: var(--zi-text-xs);
  font-weight: 700;
}

.zi-contact__title {
  margin: 0;
  font-family: var(--zi-font-heading);
  font-size: clamp(2rem, 5vw, 3.2rem);
  line-height: 1.1;
}

.zi-contact__subtitle {
  margin: var(--zi-space-lg) 0 0;
  color: var(--zi-text-secondary);
  font-size: var(--zi-text-md);
  max-width: 70ch;
}

.zi-contact__content {
  padding: var(--zi-space-3xl) 0 var(--zi-space-4xl);
}

.zi-contact__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: var(--zi-space-xl);
  align-items: start;
}

.zi-contact__panel {
  background: var(--zi-bg-card);
  border: 1px solid var(--zi-border-light);
  border-radius: var(--zi-radius-xl);
  box-shadow: var(--zi-shadow-card);
  padding: var(--zi-space-xl);
}

.zi-contact__panel-title {
  margin: 0 0 var(--zi-space-lg);
  font-size: var(--zi-text-2xl);
}

.zi-contact__alert {
  margin-bottom: var(--zi-space-lg);
  border-radius: var(--zi-radius-md);
  padding: 0.85rem 1rem;
  font-size: var(--zi-text-sm);
  font-weight: 600;
}

.zi-contact__alert--success {
  background: rgba(34, 211, 238, 0.11);
  border: 1px solid rgba(34, 211, 238, 0.32);
  color: var(--zi-cyan-light);
}

.zi-contact__alert--error {
  background: rgba(255, 107, 26, 0.12);
  border: 1px solid rgba(255, 107, 26, 0.3);
  color: #ffd8c0;
}

.zi-contact-form {
  display: grid;
  gap: var(--zi-space-md);
}

.zi-contact-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--zi-space-md);
}

.zi-contact-form__field {
  display: grid;
  gap: 0.45rem;
}

.zi-contact-form__field label {
  font-size: var(--zi-text-sm);
  color: var(--zi-text-secondary);
  font-weight: 600;
}

.zi-contact-form input,
.zi-contact-form textarea {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--zi-radius-md);
  background: rgba(12, 20, 64, 0.45);
  color: var(--zi-text-primary);
  padding: 0.75rem 0.95rem;
  font-size: var(--zi-text-base);
  font-family: var(--zi-font-body);
  transition: border-color var(--zi-transition-fast), box-shadow var(--zi-transition-fast);
}

.zi-contact-form input::placeholder,
.zi-contact-form textarea::placeholder {
  color: var(--zi-text-muted);
}

.zi-contact-form input:focus,
.zi-contact-form textarea:focus {
  outline: none;
  border-color: rgba(255, 193, 7, 0.75);
  box-shadow: 0 0 0 3px rgba(255, 193, 7, 0.18);
}

.zi-contact-form textarea {
  resize: vertical;
  min-height: 160px;
}

.zi-contact-form .zi-btn {
  justify-self: start;
}

.zi-contact-form__honeypot {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
}

.zi-contact__aside {
  display: grid;
  gap: var(--zi-space-md);
}

.zi-contact__card {
  background: linear-gradient(160deg, rgba(29, 47, 122, 0.95) 0%, rgba(23, 37, 104, 0.95) 100%);
  border: 1px solid var(--zi-border-light);
  border-radius: var(--zi-radius-xl);
  padding: var(--zi-space-lg);
  box-shadow: var(--zi-shadow-card);
}

.zi-contact__card h3 {
  margin: 0 0 0.45rem;
  font-size: var(--zi-text-lg);
}

.zi-contact__card p {
  margin: 0;
  color: var(--zi-text-secondary);
  font-size: var(--zi-text-sm);
}

.zi-contact__card a {
  display: inline-block;
  margin-top: 0.7rem;
  color: var(--zi-gold-light);
  text-decoration: underline;
  text-underline-offset: 2px;
}

@media (max-width: 900px) {
  .zi-contact__grid {
    grid-template-columns: 1fr;
  }

  .zi-contact__aside {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .zi-contact__hero {
    padding: var(--zi-space-3xl) 0 var(--zi-space-xl);
  }

  .zi-contact__content {
    padding: var(--zi-space-2xl) 0 var(--zi-space-3xl);
  }

  .zi-contact__panel {
    padding: var(--zi-space-lg);
  }

  .zi-contact-form__row {
    grid-template-columns: 1fr;
  }

  .zi-contact-form .zi-btn {
    width: 100%;
    justify-content: center;
  }
}
