/* ============================================================
   Contact — dark theme
   Two-column layout: info card on the left, inquiry form
   on the right. Dark surface, glow focus on inputs.
   ============================================================ */
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 40px;
  align-items: start;
}
.contact-info .overline {
  margin-bottom: 14px;
}
.contact-info h2 {
  margin-bottom: 18px;
  color: var(--color-text);
}
.contact-info > p {
  color: var(--color-text-secondary);
  font-size: 16px;
  line-height: 1.75;
  margin-bottom: 32px;
}
.contact-details {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.contact-detail {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px;
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  transition:
    border-color 220ms ease,
    transform 220ms ease,
    background 220ms ease;
}
.contact-detail:hover {
  border-color: var(--color-border-strong);
  transform: translateY(-2px);
  background: var(--color-surface-2);
}
.contact-detail-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: var(--color-accent-soft);
  color: var(--color-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.contact-detail-icon svg {
  width: 20px;
  height: 20px;
}
.contact-detail h5 {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 4px;
  letter-spacing: -0.01em;
}
.contact-detail span,
.contact-detail a {
  font-size: 14px;
  color: var(--color-text-secondary);
  line-height: 1.6;
  white-space: pre-line;
  transition: color 180ms ease;
}
.contact-detail a:hover {
  color: var(--color-accent);
}

html[dir="rtl"] .contact-info {
  direction: rtl;
  text-align: right;
}
html[dir="rtl"] .contact-info .overline {
  display: block;
}
html[dir="rtl"] .contact-detail {
  flex-direction: row;
}

.contact-form {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 36px;
  box-shadow: var(--shadow-md);
}
.contact-form .heading-4 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
  color: var(--color-text);
}
.contact-form-sub {
  color: var(--color-text-secondary);
  font-size: 14px;
  margin-bottom: 24px;
}
.form-group {
  margin-bottom: 18px;
}
.form-group label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 6px;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 12px 14px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 15px;
  transition:
    border-color 200ms ease,
    box-shadow 200ms ease,
    background 200ms ease;
  outline: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--color-text-placeholder);
}
.form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23b6bfd0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--color-accent);
  background: var(--color-surface);
  box-shadow: 0 0 0 4px rgba(255, 77, 6, 0.18);
}
.form-group input.success,
.form-group select.success,
.form-group textarea.success {
  border-color: var(--color-success);
  box-shadow: 0 0 0 4px rgba(88, 196, 122, 0.18);
}
.form-group input.error,
.form-group select.error,
.form-group textarea.error {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 4px rgba(255, 111, 90, 0.18);
}
.form-group textarea {
  min-height: 130px;
  resize: vertical;
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 1024px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}
@media (max-width: 640px) {
  .form-row {
    grid-template-columns: 1fr;
  }
  .contact-form {
    padding: 24px;
  }
}
