/* ===========================================================
   Contact + Request-demo form pages
   =========================================================== */

.form-section {
  min-height: 100vh;
  padding-block: calc(var(--nav-h) + var(--space-16)) var(--space-16);
  display: flex;
  align-items: center;
  background:
    radial-gradient(900px 500px at 0% 0%, rgba(127,216,199,.18), transparent 60%),
    radial-gradient(700px 500px at 100% 100%, rgba(14,140,140,.16), transparent 60%),
    var(--color-cream);
  position: relative;
  overflow: hidden;
}
.form-section .container { width: 100%; }
.form-grid {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: var(--space-16);
  align-items: stretch;
}
@media (max-width: 960px) { .form-grid { grid-template-columns: 1fr; gap: var(--space-10); } }

.form-aside {
  padding: var(--space-10);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(80% 120% at 0% 0%, rgba(127,216,199,.35), transparent 60%),
    linear-gradient(160deg, var(--color-teal-700), var(--color-ink));
  color: var(--color-white);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 480px;
}
.form-aside::after {
  content: '';
  position: absolute;
  inset-block-end: -120px; inset-inline-end: -100px;
  width: 320px; height: 320px;
  background: radial-gradient(closest-side, rgba(127,216,199,.45), transparent 70%);
  filter: blur(20px);
}
.form-aside .eyebrow {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.95);
}
.form-aside h2 { color: var(--color-white); margin-block: var(--space-5) var(--space-4); font-size: clamp(1.75rem, 3vw, 2.25rem); }
.form-aside p { color: rgba(255,255,255,.8); margin: 0; }
.aside-contact {
  margin-block-start: var(--space-8);
  display: flex; flex-direction: column; gap: var(--space-4);
  position: relative;
  z-index: 1;
}
.aside-contact a {
  display: inline-flex; align-items: center; gap: var(--space-3);
  color: rgba(255,255,255,.92);
  font-size: .95rem;
}
.aside-contact a:hover { color: var(--color-mint); }
.aside-contact i {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.1);
  border-radius: var(--radius-full);
  color: var(--color-mint);
}

.form-card {
  padding: var(--space-10);
  background: var(--color-white);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
}
.form-card .form-title {
  display: flex; align-items: center; gap: var(--space-4);
  margin-bottom: var(--space-3);
}
.form-card .form-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius);
  background: var(--color-teal-50);
  color: var(--color-teal-600);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.25rem;
}
.form-card h3 { font-size: 1.5rem; margin: 0; }
.form-card .form-sub { color: var(--color-slate); margin-block-end: var(--space-8); }

/* Inputs */
.form-group { margin-bottom: var(--space-4); position: relative; }
.form-label {
  display: block;
  font-size: .82rem;
  font-weight: 500;
  color: var(--color-slate);
  margin-bottom: var(--space-2);
}
.form-control,
textarea.form-control {
  width: 100%;
  padding: 14px 16px;
  font: inherit;
  font-size: .95rem;
  color: var(--color-ink);
  background: var(--color-cream-2);
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  transition: border-color var(--dur), background var(--dur), box-shadow var(--dur);
  outline: 0;
  font-family: var(--font-body);
}
[dir="rtl"] .form-control { font-family: 'Tajawal', var(--font-body); }
.form-control::placeholder { color: var(--color-muted); }
.form-control:focus {
  border-color: var(--color-teal-400);
  background: var(--color-white);
  box-shadow: 0 0 0 4px rgba(14,140,140,.12);
}
textarea.form-control { min-height: 130px; resize: vertical; }

.form-control.is-invalid {
  border-color: #DC3545;
  background: #FFF6F7;
}
.form-control.is-invalid:focus {
  box-shadow: 0 0 0 4px rgba(220,53,69,.12);
}
.invalid-feedback {
  display: none;
  margin-top: 6px;
  font-size: .82rem;
  color: #DC3545;
}
.is-invalid + .invalid-feedback { display: block; }

/* intl-tel-input integration */
.iti { width: 100%; direction: ltr; }
.iti__flag-container { z-index: 5; }
[dir="rtl"] .iti { direction: ltr; }
[dir="rtl"] .iti input.form-control {
  padding-left: 52px !important;
  padding-right: 16px !important;
  text-align: left;
  direction: ltr;
}

.form-submit {
  width: 100%;
  margin-block-start: var(--space-3);
}
.form-submit:disabled {
  opacity: .55;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: var(--shadow-teal) !important;
}

/* Alerts */
.alert {
  margin-block-start: var(--space-5);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius);
  font-size: .92rem;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.alert.d-none { display: none; }
.alert i { font-size: 1.1rem; }
.alert-success {
  background: #E8F8EF;
  color: #1F7A3A;
  border: 1px solid #BFEACB;
}
.alert-danger {
  background: #FFEBEE;
  color: #B71C1C;
  border: 1px solid #FAC2C8;
}
