/* ==========================================================================
   CONTACT PAGE - Specific Styles
   ========================================================================== */

/* --------------------------------------------------------------------------
   BREADCRUMB
   -------------------------------------------------------------------------- */
.breadcrumb-wrapper {
  padding-top: 100px;
  background-color: var(--color-white);
}

/* --------------------------------------------------------------------------
   CONTACT SECTION
   -------------------------------------------------------------------------- */
.contact-section {
  padding: var(--space-10) 0 var(--space-16);
}

.contact-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--space-12);
  align-items: start;
}

/* --------------------------------------------------------------------------
   CONTACT INFO
   -------------------------------------------------------------------------- */
.contact-info .tag {
  margin-bottom: var(--space-4);
}

.contact-info h1 {
  font-size: var(--text-4xl);
  margin-bottom: var(--space-6);
}

.contact-info .lead {
  margin-bottom: var(--space-10);
}

.contact-methods {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-bottom: var(--space-10);
}

.contact-method {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.contact-method-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background-color: var(--color-accent);
  border-radius: var(--radius-lg);
  color: var(--color-black);
  flex-shrink: 0;
}

.contact-method-content h4 {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-gray-500);
  margin-bottom: var(--space-1);
}

.contact-method-content a,
.contact-method-content span {
  font-size: var(--text-lg);
  font-weight: var(--font-medium);
  color: var(--color-black);
}

.contact-method-content a:hover {
  color: var(--color-accent);
}

/* Contact Promise */
.contact-promise {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  background-color: var(--color-gray-50);
  border-radius: var(--radius-xl);
}

.promise-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-gray-700);
}

/* --------------------------------------------------------------------------
   CONTACT FORM
   -------------------------------------------------------------------------- */
.contact-form-wrapper {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  padding: var(--space-8);
  box-shadow: var(--shadow-lg);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.form-group {
  display: flex;
  flex-direction: column;
}

.form-label {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-gray-700);
  margin-bottom: var(--space-1);
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-gray-900);
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  transition: all var(--transition-fast);
}

.form-input:hover,
.form-select:hover,
.form-textarea:hover {
  border-color: var(--color-gray-300);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 4px var(--color-accent-light);
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--color-gray-400);
}

.form-textarea {
  min-height: 100px;
  resize: vertical;
}

.form-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 20px;
  padding-right: 48px;
}

/* Checkbox */
.form-checkbox {
  flex-direction: row;
  align-items: flex-start;
  gap: var(--space-3);
}

.form-checkbox input {
  width: 20px;
  height: 20px;
  margin-top: 2px;
  accent-color: var(--color-accent);
  cursor: pointer;
  flex-shrink: 0;
}

.form-checkbox label {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
  cursor: pointer;
}

.form-checkbox a {
  color: var(--color-black);
  text-decoration: underline;
}

.form-checkbox a:hover {
  color: var(--color-accent);
}

/* Form States */
.form-input.error,
.form-select.error,
.form-textarea.error {
  border-color: #ef4444;
}

.form-error {
  display: none;
  font-size: var(--text-sm);
  color: #ef4444;
  margin-top: var(--space-1);
}

.form-success {
  padding: var(--space-8);
  text-align: center;
  background-color: var(--color-accent-light);
  border-radius: var(--radius-xl);
}

.form-success p {
  font-size: var(--text-lg);
  color: var(--color-black);
  font-weight: var(--font-medium);
}

/* --------------------------------------------------------------------------
   FAQ MINI
   -------------------------------------------------------------------------- */
.faq-mini-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

.faq-mini-header h2 {
  font-size: var(--text-2xl);
}

.faq-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

.faq-mini-item {
  padding: var(--space-6);
  background-color: var(--color-white);
  border-radius: var(--radius-xl);
}

.faq-mini-item h4 {
  font-size: var(--text-base);
  margin-bottom: var(--space-2);
}

.faq-mini-item p {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

/* --------------------------------------------------------------------------
   RESPONSIVE
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: var(--space-12);
  }

  .contact-info {
    text-align: center;
  }

  .contact-methods {
    max-width: 400px;
    margin-inline: auto;
  }

  .contact-method {
    text-align: left;
  }

  .contact-promise {
    max-width: 400px;
    margin-inline: auto;
  }
}

@media (max-width: 768px) {
  .contact-section {
    padding: var(--space-8) 0 var(--space-16);
  }

  .contact-info h1 {
    font-size: var(--text-3xl);
  }

  .contact-form-wrapper {
    padding: var(--space-6);
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .faq-mini-grid {
    grid-template-columns: 1fr;
  }
}
