/* ==========================================================
   CONTACT.CSS — Contact & Quote Form (Theme-Aware)
   ========================================================== */
#contact {
  background: var(--bg-alt);
  position: relative;
  overflow: hidden;
}
#contact::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-magenta), transparent);
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-2xl);
  align-items: start;
}

/* ── Left: Info ── */
.contact-info-title {
  font-size: clamp(2rem, 4vw, 2.8rem);
  margin-bottom: var(--space-sm);
}
.contact-info-desc {
  color: var(--text-muted);
  margin-bottom: var(--space-xl);
  line-height: 1.75;
}

.contact-details { display: flex; flex-direction: column; gap: var(--space-lg); }

.contact-item { display: flex; align-items: flex-start; gap: var(--space-md); }
.contact-item-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  background: var(--bg-glass);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background var(--transition-smooth), border-color var(--transition-smooth);
}
/* Override any inline SVG stroke/fill — use theme-aware color */
.contact-item-icon svg {
  stroke: var(--text-primary);
  transition: stroke var(--transition-smooth);
}
.contact-item:hover .contact-item-icon {
  background: var(--item-accent, var(--color-cyan));
  border-color: var(--item-accent, var(--color-cyan));
}
.contact-item:hover .contact-item-icon svg { stroke: #000; }

.contact-item[data-accent="yellow"] { --item-accent: var(--color-yellow); }
.contact-item[data-accent="cyan"]   { --item-accent: var(--color-cyan); }
.contact-item[data-accent="white"]  { --item-accent: var(--text-primary); }

.contact-item-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  display: block;
  margin-bottom: 4px;
}
.contact-item-value {
  font-size: 0.95rem;
  color: var(--text-primary);
  line-height: 1.6;
}
.contact-item-value a:hover { color: var(--color-cyan); }

/* Pulsing 24/7 badge */
.contact-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(0,168,232,0.08);
  border: 1px solid rgba(0,168,232,0.25);
  border-radius: var(--radius-full);
  padding: 0.5rem 1rem;
  margin-top: var(--space-xl);
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-cyan);
}
.contact-badge-dot {
  width: 8px; height: 8px;
  background: var(--color-cyan);
  border-radius: 50%;
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(1.4); }
}

.contact-wa-btn {
  display: inline-flex;
  margin-top: var(--space-md);
  color: #25D366;
  border-color: rgba(37, 211, 102, 0.3);
  gap: 0.5rem;
}
.contact-wa-btn:hover {
  background: rgba(37, 211, 102, 0.1);
  border-color: #25D366;
  color: #25D366;
}

/* ── Right: Form ── */
.quote-form-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-top: 3px solid var(--color-cyan);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  box-shadow: var(--shadow-card);
}
.quote-form-title {
  font-size: 1.5rem;
  color: var(--text-primary);
  margin-bottom: 0.25rem;
}
.quote-form-subtitle {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: var(--space-lg);
}

.form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}

.form-group { display: flex; flex-direction: column; gap: 0.4rem; }

.form-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
}
.form-label-opt {
  text-transform: none;
  font-weight: 400;
  letter-spacing: normal;
  color: var(--text-faint);
}

.form-input,
.form-select,
.form-textarea {
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--radius-sm);
  padding: 0.8rem 1rem;
  color: var(--input-text);
  font-size: 0.9rem;
  width: 100%;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--input-ph); }
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-cyan);
  box-shadow: 0 0 0 3px rgba(0,168,232,0.15);
}

.form-select {
  appearance: none;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
}
.form-select option { background: var(--bg-card); color: var(--input-text); }

.form-textarea { resize: vertical; min-height: 110px; }

/* File Upload */
.form-upload {
  border: 1px dashed var(--border-hv);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  text-align: center;
  cursor: pointer;
  position: relative;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}
.form-upload:hover, .form-upload.drag-over {
  border-color: var(--color-cyan);
  background: rgba(0,168,232,0.04);
}
.form-upload input[type="file"] {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  opacity: 0; cursor: pointer;
}
.form-upload-icon { color: var(--color-cyan); margin-bottom: 0.5rem; }
.form-upload-text { font-size: 0.85rem; color: var(--text-muted); }
.form-upload-hint { font-size: 0.7rem; color: var(--text-faint); margin-top: 0.25rem; }

.form-submit { width: 100%; padding: 1rem; margin-top: var(--space-sm); font-size: 0.85rem; position: relative; }

/* Form Messages & Feedback */
.form-message {
  margin-top: 1rem;
  padding: 0.8rem 1rem;
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  line-height: 1.5;
  animation: fade-in 0.3s ease;
}
.form-message--success {
  background: rgba(34, 197, 94, 0.1);
  color: #22c55e;
  border: 1px solid rgba(34, 197, 94, 0.2);
}
.form-message--error {
  background: rgba(239, 68, 68, 0.1);
  color: #ef4444;
  border: 1px solid rgba(239, 68, 68, 0.2);
}

.btn-spinner {
  display: inline-block;
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,0.3);
  border-radius: 50%;
  border-top-color: #fff;
  animation: spin 1s linear infinite;
  margin-right: 8px;
  vertical-align: middle;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes fade-in { from { opacity: 0; transform: translateY(-5px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 768px) {
  .contact-grid    { grid-template-columns: 1fr; }
  .form-grid-2     { grid-template-columns: 1fr; }
  .quote-form-card { padding: var(--space-lg); }
}
