@charset "UTF-8";
/* =============================================================================
   Contact Page Modern Design - Professional & Clean
   ============================================================================= */

/* Page Header - Hero Style */
.page-header {
  background: linear-gradient(135deg, #7cc576 0%, #5ba656 100%) !important;
  padding: 80px 0 !important;
  margin-bottom: 60px !important;
  position: relative !important;
  overflow: hidden !important;
}

.page-header::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100" viewBox="0 0 100 100"><rect width="100" height="100" fill="none"/><circle cx="50" cy="50" r="40" fill="white" opacity="0.03"/></svg>') !important;
  background-size: 100px 100px !important;
}

.page-header__content {
  position: relative !important;
  z-index: 1 !important;
  text-align: center !important;
}

.page-header__title {
  margin: 0 0 20px !important;
}

.page-header__title-main {
  display: block !important;
  font-size: 36px !important;
  font-weight: 700 !important;
  color: white !important;
  margin-bottom: 8px !important;
  letter-spacing: 0.05em !important;
}

.page-header__title-sub {
  display: block !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: rgba(255, 255, 255, 0.8) !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
}

.page-header__description {
  font-size: 16px !important;
  color: rgba(255, 255, 255, 0.95) !important;
  line-height: 1.8 !important;
  max-width: 600px !important;
  margin: 0 auto !important;
}

/* Contact Methods Grid - Card Style */
.contact-methods {
  padding: 60px 0 !important;
  background: #f8f8f8 !important;
}

.contact-methods__grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 30px !important;
  margin-top: 40px !important;
}

.contact-method {
  background: white !important;
  border-radius: 12px !important;
  padding: 40px 30px !important;
  text-align: center !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08) !important;
  transition: all 0.3s ease !important;
  border: 2px solid transparent !important;
}

.contact-method:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12) !important;
  border-color: #7cc576 !important;
}

.contact-method__icon {
  width: 80px !important;
  height: 80px !important;
  margin: 0 auto 24px !important;
  background: linear-gradient(135deg, #7cc576, #5ba656) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 36px !important;
  color: white !important;
}

.contact-method__icon::before {
  content: '☎' !important;
}

.contact-method:nth-child(2) .contact-method__icon::before {
  content: '💬' !important;
}

.contact-method:nth-child(3) .contact-method__icon::before {
  content: '✉' !important;
}

.contact-method__title {
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #333 !important;
  margin-bottom: 12px !important;
}

.contact-method__text {
  font-size: 14px !important;
  color: #666 !important;
  line-height: 1.6 !important;
  margin-bottom: 20px !important;
}

.contact-method__number {
  margin: 20px 0 !important;
}

.contact-method__link {
  font-size: 28px !important;
  font-weight: 700 !important;
  color: #3b82f6 !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.contact-method__link:hover {
  color: #1d4ed8 !important;
}

.contact-method__hours,
.contact-method__note {
  font-size: 13px !important;
  color: #999 !important;
  margin-top: 12px !important;
}

.contact-method__action {
  margin-top: 20px !important;
}

/* Modern Form Design */
.contact-form-section {
  padding: 80px 0 !important;
  background: white !important;
}

.contact-form {
  max-width: 720px !important;
  margin: 0 auto !important;
  background: white !important;
  border-radius: 16px !important;
  padding: 40px !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08) !important;
}

.form-group {
  margin-bottom: 28px !important;
}

.form-label {
  display: block !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #333 !important;
  margin-bottom: 8px !important;
}

.form-label--required::after {
  content: ' *' !important;
  color: #ef4444 !important;
}

.form-control,
.form-control-file {
  width: 100% !important;
  padding: 12px 16px !important;
  font-size: 15px !important;
  border: 2px solid #e5e5e5 !important;
  border-radius: 8px !important;
  background: white !important;
  transition: all 0.3s ease !important;
}

.form-control:focus {
  border-color: #7cc576 !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(173, 165, 139, 0.1) !important;
}

select.form-control {
  cursor: pointer !important;
  appearance: none !important;
  background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8"><path fill="%23666" d="M6 8L0 0h12z"/></svg>') !important;
  background-repeat: no-repeat !important;
  background-position: right 16px center !important;
  padding-right: 40px !important;
}

textarea.form-control {
  resize: vertical !important;
  min-height: 120px !important;
  line-height: 1.6 !important;
}

.form-help {
  display: block !important;
  font-size: 13px !important;
  color: #999 !important;
  margin-top: 6px !important;
}

.form-radio-group {
  display: flex !important;
  gap: 24px !important;
  flex-wrap: wrap !important;
}

.form-radio {
  display: flex !important;
  align-items: center !important;
  cursor: pointer !important;
  padding: 8px 12px !important;
  border: 2px solid #e5e5e5 !important;
  border-radius: 8px !important;
  transition: all 0.3s ease !important;
}

.form-radio:hover {
  border-color: #7cc576 !important;
  background: rgba(173, 165, 139, 0.05) !important;
}

.form-radio input[type="radio"] {
  margin-right: 8px !important;
}

.form-radio input[type="radio"]:checked + span {
  font-weight: 600 !important;
  color: #7cc576 !important;
}

.form-checkbox {
  display: flex !important;
  align-items: flex-start !important;
  cursor: pointer !important;
}

.form-checkbox input[type="checkbox"] {
  margin-right: 8px !important;
  margin-top: 2px !important;
  width: 18px !important;
  height: 18px !important;
  cursor: pointer !important;
}

.form-control-file {
  border-style: dashed !important;
  background: #fafafa !important;
  cursor: pointer !important;
  padding: 20px !important;
  text-align: center !important;
}

.form-control-file:hover {
  border-color: #7cc576 !important;
  background: rgba(173, 165, 139, 0.05) !important;
}

/* Form Submit Button */
.form-actions {
  text-align: center !important;
  margin-top: 40px !important;
  padding-top: 32px !important;
  border-top: 1px solid #e5e5e5 !important;
}

.btn--lg {
  padding: 16px 48px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  border-radius: 50px !important;
  min-width: 200px !important;
}

/* FAQ Section */
.contact-faq {
  padding: 60px 0 !important;
  background: #f8f8f8 !important;
}

.faq-list {
  max-width: 800px !important;
  margin: 40px auto 0 !important;
}

.faq-item {
  background: white !important;
  border-radius: 12px !important;
  padding: 24px 30px !important;
  margin-bottom: 16px !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
}

.faq-item__question {
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #333 !important;
  margin: 0 0 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.faq-item__question::before {
  content: 'Q' !important;
  width: 32px !important;
  height: 32px !important;
  background: #7cc576 !important;
  color: white !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
  flex-shrink: 0 !important;
}

.faq-item__answer {
  padding-left: 44px !important;
}

.faq-item__answer p {
  color: #666 !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}

/* Responsive Design */
@media (max-width: 768px) {
  .page-header {
    padding: 60px 0 !important;
  }
  
  .page-header__title-main {
    font-size: 28px !important;
  }
  
  .contact-methods__grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  
  .contact-method {
    padding: 30px 20px !important;
  }
  
  .contact-form {
    padding: 30px 20px !important;
    border-radius: 12px !important;
  }
  
  .form-row {
    grid-template-columns: 1fr !important;
  }
  
  .form-radio-group {
    flex-direction: column !important;
    gap: 12px !important;
  }
  
  .form-radio {
    width: 100% !important;
  }
  
  .btn--lg {
    width: 100% !important;
    padding: 14px 32px !important;
  }
  
  .faq-item {
    padding: 20px !important;
  }
  
  .faq-item__question {
    font-size: 16px !important;
  }
}

@media (max-width: 480px) {
  .page-header__title-main {
    font-size: 24px !important;
  }
  
  .page-header__description {
    font-size: 14px !important;
  }
  
  .contact-method__link {
    font-size: 24px !important;
  }
  
  .contact-form {
    box-shadow: none !important;
    padding: 20px !important;
  }
}

/* Success and Error Messages */
.alert {
  padding: 20px 24px !important;
  border-radius: 12px !important;
  margin-bottom: 32px !important;
  border: none !important;
  position: relative !important;
}

.alert--success {
  background: linear-gradient(135deg, #d4edda, #c3e6cb) !important;
  color: #155724 !important;
}

.alert--danger {
  background: linear-gradient(135deg, #f8d7da, #f5c6cb) !important;
  color: #721c24 !important;
}

.alert h3 {
  margin: 0 0 12px !important;
  font-size: 18px !important;
  font-weight: 600 !important;
}

.alert p,
.alert li {
  line-height: 1.6 !important;
}

.alert ul {
  margin: 0 !important;
  padding-left: 20px !important;
}

/* Section Title Enhancement */
.section-title {
  font-size: 32px !important;
  font-weight: 700 !important;
  text-align: center !important;
  margin-bottom: 16px !important;
  color: #333 !important;
  position: relative !important;
}

.section-title::after {
  content: '' !important;
  display: block !important;
  width: 60px !important;
  height: 3px !important;
  background: #7cc576 !important;
  margin: 20px auto 0 !important;
  border-radius: 2px !important;
}