/* Modal Overlay */
.contact-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(17, 24, 39, 0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  padding: 1.5rem;
}

.contact-modal-overlay.open {
  opacity: 1;
  visibility: visible;
}

.contact-modal-container {
  position: relative;
  width: 100%;
  max-width: 720px;
  max-height: 90vh;
  overflow-y: auto;
  transform: translateY(20px) scale(0.98);
  transition: transform 0.3s ease;
  border-radius: 20px;
  background: #fff;
  /* Scrollbar hiding for cleaner look */
  scrollbar-width: none;
}
.contact-modal-container::-webkit-scrollbar {
  display: none;
}

.contact-modal-overlay.open .contact-modal-container {
  transform: translateY(0) scale(1);
}

.contact-modal-close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  width: 32px;
  height: 32px;
  background: #f3f4f6;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #4b5563;
  transition: background 0.2s, color 0.2s;
  z-index: 10;
  font-size: 1.2rem;
  line-height: 1;
}
.contact-modal-close:hover {
  background: #e5e7eb;
  color: #111827;
}

/* Form Styles */
.contact-modal-container .form-wrap { background: #fff; border: none; box-shadow: 0 24px 48px rgba(0,0,0,0.1); border-radius: 20px; padding: 3rem; margin: 0; width: 100%; }
.contact-modal-container .form-title { font-family: 'Syne', sans-serif; font-size: 1.5rem; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 0.5rem; color: var(--text, #111827); padding-right: 2rem; }
.contact-modal-container .form-sub { font-size: 0.9rem; color: var(--text2, #4B5563); margin-bottom: 2.5rem; }
.contact-modal-container .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.contact-modal-container .fg { display: flex; flex-direction: column; position: relative; gap: 0.4rem; }
.contact-modal-container .fg.full { grid-column: 1 / -1; }
.contact-modal-container .fg label { font-family: 'Inter', sans-serif; font-size: 0.8rem; color: var(--text2, #4B5563); font-weight: 500; }
.contact-modal-container .fg input, 
.contact-modal-container .fg select, 
.contact-modal-container .fg textarea { background: #fff; border: 1px solid rgba(0,0,0,0.1); box-shadow: 0 2px 4px rgba(0,0,0,0.02); border-radius: 10px; padding: 0.875rem 1rem; color: var(--text, #111827); font-size: 0.95rem; font-family: 'Inter', sans-serif; outline: none; transition: all 0.2s; resize: none; }
.contact-modal-container .fg input:hover, 
.contact-modal-container .fg select:hover, 
.contact-modal-container .fg textarea:hover { border-color: rgba(0,0,0,0.15); }
.contact-modal-container .fg input:focus, 
.contact-modal-container .fg select:focus, 
.contact-modal-container .fg textarea:focus { border-color: var(--accent, #E8503F); box-shadow: 0 0 0 4px rgba(232, 80, 63, 0.15); }
.contact-modal-container .fg input::placeholder, 
.contact-modal-container .fg textarea::placeholder { color: #9CA3AF; font-weight: 400; }
.contact-modal-container .fg select { appearance: none; cursor: pointer; padding-right: 2.5rem; background: url('data:image/svg+xml;utf8,<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="%236B7280" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"></polyline></svg>') no-repeat right 1rem center #fff; }
.contact-modal-container .fg select option { background: #fff; }
.contact-modal-container .phone-row { display: flex; gap: 0.75rem; }
.contact-modal-container .phone-code { background: #fff; border: 1px solid rgba(0,0,0,0.1); box-shadow: 0 2px 4px rgba(0,0,0,0.02); border-radius: 10px; padding: 0.875rem 1rem; color: var(--text, #111827); font-size: 0.95rem; font-family: 'Inter', sans-serif; outline: none; width: 100px; flex-shrink: 0; transition: all 0.2s; cursor: pointer; appearance: none; }
.contact-modal-container .phone-code:hover { border-color: rgba(0,0,0,0.15); }
.contact-modal-container .phone-code:focus { border-color: var(--accent, #E8503F); box-shadow: 0 0 0 4px rgba(232, 80, 63, 0.15); }
.contact-modal-container .phone-input { flex: 1; }
.contact-modal-container .form-submit { width: 100%; background: var(--text, #111827); color: #fff; font-family: 'Inter', sans-serif; font-size: 1rem; font-weight: 600; padding: 1rem; border: none; border-radius: 10px; cursor: pointer; transition: all 0.2s; margin-top: 1.5rem; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.contact-modal-container .form-submit:hover { background: #000; box-shadow: 0 6px 16px rgba(0,0,0,0.15); transform: translateY(-1px); }
.contact-modal-container .form-legal { font-size: 0.75rem; color: var(--text3, #9CA3AF); margin-top: 1rem; line-height: 1.6; text-align: center; }
.contact-modal-container .form-legal a { color: var(--text2, #4B5563); text-decoration: underline; }

@media (max-width: 900px) {
  .contact-modal-container .form-grid { grid-template-columns: 1fr; }
  .contact-modal-container .form-wrap { padding: 2rem 1.5rem; }
}

/* Mobile Menu Overrides */
.mobile-menu {
  justify-content: flex-start !important;
  padding-top: 6rem !important;
}


.mobile-menu {
  z-index: 101 !important;
}

