.contact-main {
  padding: var(--section-pad);
  background: linear-gradient(180deg, var(--paper-warm) 0%, var(--paper) 35%);
}
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.contact-info h2 { margin-bottom: 28px; }

.fit-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 48px;
}
.fit-item {
  padding: 22px 26px;
  font-size: 1.08rem;
  color: #4a4458;
  line-height: 1.72;
  background: #fff;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border);
  border-left: 4px solid var(--econ-light);
}
.fit-item p { font-size: inherit; color: inherit; line-height: inherit; }
.fit-item strong { color: var(--ink); }

.contact-details {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.contact-detail {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.detail-label {
  font-size: 0.8125rem;
  color: #8b8399;
}
.contact-detail span {
  font-size: 1.0625rem;
  color: #6b6280;
}
.contact-email {
  font-size: 1.125rem;
  color: var(--socio);
  text-decoration: underline;
  text-decoration-color: rgba(106, 48, 210, 0.35);
  text-underline-offset: 4px;
  display: inline-block;
}
.contact-email:hover {
  text-decoration-color: var(--socio);
}

/* ── Form ── */
.contact-form-wrap {
  border: 1px solid var(--border);
  padding: 40px;
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.form-group label {
  font-size: 0.9rem;
  font-weight: 500;
  color: #6b6280;
}
.form-group .optional {
  color: #bbb;
  font-size: 0.8125rem;
  font-weight: 400;
}
.form-group input,
.form-group select,
.form-group textarea {
  font-family: var(--font-body);
  font-size: 1.0625rem;
  padding: 14px 16px;
  border: 1px solid var(--border);
  background: var(--paper);
  color: var(--ink);
  transition: border-color var(--ease), box-shadow var(--ease);
  border-radius: var(--radius-sm);
  -webkit-appearance: none;
  appearance: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--socio);
  box-shadow: 0 0 0 3px rgba(106, 48, 210, 0.12);
}
.form-group input::placeholder,
.form-group textarea::placeholder {
  color: #bbb;
}
.form-group select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238b8399' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
  cursor: pointer;
}
.form-group textarea {
  resize: vertical;
  min-height: 120px;
}

.form-submit { width: 100%; }

@media (max-width: 768px) {
  .contact-main { padding: var(--section-pad-mobile); }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .contact-form-wrap { padding: 28px; }
  .fit-item { padding: 18px 20px; }
}
