/* CONTACT LAYOUT */

.contact-layout {
  display: grid;

  grid-template-columns:
    minmax(320px, 0.9fr)
    minmax(420px, 1fr);

  gap: 5rem;

  align-items: start;
}

/* CONTACT INFO */

.contact-info h2 {
  margin-bottom: 1.8rem;

  font-size: clamp(2.4rem, 4vw, 4.4rem);

  line-height: 1.05;
}

.contact-info p {
  max-width: 520px;

  font-size: 1.08rem;

  line-height: 1.8;
}

/* CONTACT DETAILS */

.contact-details {
  display: flex;
  flex-direction: column;

  gap: 1.4rem;

  margin-top: 3rem;
}

.contact-details a {
  width: fit-content;

  color: var(--text);

  font-size: 1.15rem;
  font-weight: 600;

  transition: var(--transition);
}

.contact-details a:hover {
  color: var(--primary);

  transform: translateX(2px);
}

/* CONTACT FORM WRAPPER */

.contact-form-wrapper {
  padding: 3rem;

  border-radius: 2.4rem;

  background: var(--white);

  border: 1px solid var(--border-light);

  box-shadow:
    0 20px 60px rgba(0,0,0,0.05);
}

/* CONTACT FORM */

.contact-form {
  display: flex;
  flex-direction: column;

  gap: 1.8rem;
}

/* FORM GROUP */

.form-group {
  display: flex;
  flex-direction: column;

  gap: 0.9rem;
}

/* LABELS */

.form-group label {
  color: var(--text);

  font-size: 0.95rem;
  font-weight: 600;
}

/* PLACEHOLDERS */

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: var(--text-muted);
}

/* INPUTS */

.contact-form input,
.contact-form textarea,
.contact-form select {
  width: 100%;

  padding: 1.1rem 1.3rem;

  border: 1px solid var(--border-light);

  border-radius: 1.4rem;

  background: var(--input-bg);

  color: var(--text);

  font-family: "Satoshi", sans-serif;

  font-size: 1rem;

  outline: none;

  transition: var(--transition);
}

/* TEXTAREA */

.contact-form textarea {
  resize: vertical;

  min-height: 180px;
}

/* SELECT*/

.contact-form select {
  cursor: pointer;

  appearance: none;
}

/* FOCUS STATES */

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
  border-color:
    rgba(72,99,56,0.35);

  background: var(--white);

  box-shadow:
    0 0 0 4px rgba(72,99,56,0.08);
}

/* SUBMIT BUTTON */

.contact-form .btn-primary {
  margin-top: 0.5rem;
}

.contact-form select option:first-child {
  color: var(--text-light);
}

.contact-detail-item {
  display: flex;

  align-items: center;

  gap: 1rem;

  padding: 1rem 1.25rem;

  border-radius: 1.25rem;

  background: var(--surface);

  border: 1px solid var(--border);

  text-decoration: none;

  color: inherit;

  transition:
    transform .35s ease,
    border-color .35s ease,
    box-shadow .35s ease;
}

.contact-detail-item:hover {
  transform: translateY(-3px);

  border-color: var(--primary);

  box-shadow:
    0 10px 30px rgba(0,0,0,.06);
}

.contact-detail-item span {
  display: block;

  margin-bottom: 0.25rem;

  font-size: 0.8rem;

  color: var(--text-muted);

  text-transform: uppercase;

  letter-spacing: .08em;
}

.contact-detail-item strong {
  font-size: 1rem;

  color: var(--text);
}

.contact-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.contact-detail-icon {
  width: 54px;
  height: 54px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;

  background: var(--primary-soft);

  border: 1px solid var(--primary-border);

  flex-shrink: 0;

  transition:
    transform .3s ease,
    background .3s ease,
    border-color .3s ease;
}

.contact-detail-icon img {
  width: 24px;
  height: 24px;

  display: block;

  object-fit: contain;
}

.contact-detail-item:hover .contact-detail-icon {
  transform: translateY(-2px);

  background: var(--primary-soft-hover);

  border-color: var(--primary);
}
