.fade-in {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}
.fade-in.visible { opacity: 1; transform: none; }

/* ── Layout ─────────────────────────────────────────── */
.contact-section {
  min-height: calc(100vh - var(--nav-h));
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
  min-height: calc(100vh - var(--nav-h));
}

/* ── Left: dark panel ───────────────────────────────── */
.contact-left {
  background: #f0ede8;
  padding: 5rem 4rem;
  display: flex;
  flex-direction: column;
}

.contact-left-text { flex: 1; }

.contact-left h1 {
  font-size: clamp(2.5rem, 4vw, 3.8rem);
  color: var(--black);
  margin-top: 0.5rem;
}

.contact-details { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-detail p { margin-top: 0.2rem; }
.contact-detail a {
  color: var(--black);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--warm-mid);
  transition: text-decoration-color 0.2s;
}
.contact-detail a:hover { text-decoration-color: var(--black); }

.contact-intro {
  color: var(--warm-muted);
  margin-top: 0.75rem;
  margin-bottom: 2.5rem;
  max-width: 380px;
  line-height: 1.8;
}

.contact-feature-img {
  margin-top: 4rem;
}
.contact-feature-img img {
  width: 100%;
  aspect-ratio: 3/2;
  object-fit: cover;
  object-position: center 30%;
  display: block;
}

/* ── Right: form ────────────────────────────────────── */
.contact-right {
  padding: 5rem 4rem;
  background: var(--off-white);
}

.contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: 0.4rem; }
.form-group label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--warm-muted);
}
.form-group label span { color: var(--accent); }
.form-group input,
.form-group select,
.form-group textarea {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 300;
  color: var(--black);
  background: transparent;
  border: none;
  border-bottom: 0.5px solid var(--warm-mid);
  padding: 10px 0;
  outline: none;
  transition: border-color 0.2s;
  width: 100%;
  -webkit-appearance: none;
  border-radius: 0;
}
.form-group select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239a968f' stroke-width='1' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 4px center;
  padding-right: 24px;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--warm-mid); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-bottom-color: var(--black); }
.form-group textarea { resize: vertical; min-height: 120px; line-height: 1.6; }
.form-footer { display: flex; align-items: center; gap: 1.5rem; margin-top: 0.5rem; }
.btn-submit { cursor: pointer; }
.btn-submit:disabled { opacity: 0.5; cursor: not-allowed; }
.form-note { font-size: 12px; color: var(--warm-muted); }
.form-success {
  padding: 1.25rem;
  border: 0.5px solid var(--warm-mid);
  font-family: var(--serif);
  font-size: 1.1rem;
  color: var(--black);
}

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; min-height: auto; }
  .contact-left { padding: 4rem 1.5rem; }
  .contact-feature-img { display: none; }
  .contact-right { padding: 3rem 1.5rem; }
}
@media (max-width: 500px) {
  .form-row { grid-template-columns: 1fr; }
}
