/* ============================================================
   forms.css — Form & Input Styles
   ============================================================ */

.booking-form-card {
  background: var(--bg-white);
  border-radius: var(--radius-lg);
  padding: 40px 36px;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
}
.booking-form-card h3 { font-size: 1.4rem; margin-bottom: 28px; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { margin-bottom: 18px; }
.form-group label { display: block; font-size: 0.84rem; font-weight: 600; color: var(--text-dark); margin-bottom: 7px; }

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font-family: var(--font-body);
  font-size: 0.93rem;
  color: var(--text-dark);
  background: var(--bg-white);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
  -webkit-appearance: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(43,127,212,0.12);
}
.form-group textarea { resize: vertical; min-height: 110px; }
.form-submit { width: 100%; padding: 15px; font-size: 1rem; border-radius: 8px; margin-top: 6px; }

/* Success State */
.form-success { display: none; text-align: center; padding: 32px; }
.form-success.active { display: block; }
.success-icon { width: 60px; height: 60px; background: #D1FAE5; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.success-icon svg { width: 28px; height: 28px; fill: #059669; }
.form-success h4 { font-size: 1.3rem; margin-bottom: 8px; color: var(--text-dark); }
.form-success p { color: var(--text-light); font-size: 0.95rem; }

@media (max-width: 768px) {
  .form-row { grid-template-columns: 1fr; }
  .booking-form-card { padding: 28px 20px; }
}
