/* =============================================================
   CURA CAPITAL — Contact Page Styles (contact.css)
   Sections: split-screen (form left, offices right)
   ============================================================= */

/* ─── CONTACT INTRO ───────────────────────────────────────── */

.contact-intro {
  text-align: center;
  max-width: 580px;
  margin-inline: auto;
  padding-bottom: var(--space-lg);
}

.contact-intro__direct {
  display: flex;
  justify-content: center;
  gap: var(--space-lg);
  flex-wrap: wrap;
  margin-top: var(--space-md);
}

.contact-intro__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  transition: color var(--transition-fast);
}

.contact-intro__link:hover { color: var(--color-accent); }

.contact-intro__link svg { flex-shrink: 0; }

/* ─── SPLIT LAYOUT ────────────────────────────────────────── */

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

@media (max-width: 1023px) {
  .contact-split { grid-template-columns: 1fr; }
}

/* ─── CONTACT FORM ────────────────────────────────────────── */

.contact-form-wrap {
  background-color: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-card);
  padding: var(--space-xl);
}

.contact-form-wrap h2 {
  margin-bottom: var(--space-lg);
}

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

/* ─── FORM GROUPS ─────────────────────────────────────────── */

.form-group { display: flex; flex-direction: column; gap: var(--space-xs); }

.form-group label {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--text-body);
}

.form-group label span[aria-hidden] {
  color: #e53e3e;
  margin-left: 2px;
}

.form-group input,
.form-group textarea,
.form-group select {
  padding: 11px 14px;
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-input);
  background-color: var(--bg-base);
  color: var(--text-body);
  font-size: 0.95rem;
  font-family: var(--font-primary);
  outline: none;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(61, 155, 233, 0.15);
}

.form-group input:focus-visible,
.form-group textarea:focus-visible,
.form-group select:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(61, 155, 233, 0.25);
}

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

/* Validation states */
.form-group.has-error input,
.form-group.has-error textarea,
.form-group.has-error select {
  border-color: #e53e3e;
}

.form-group.has-error input:focus,
.form-group.has-error textarea:focus {
  box-shadow: 0 0 0 3px rgba(229, 62, 62, 0.15);
}

.field-error {
  font-size: 0.8rem;
  color: #e53e3e;
  display: none;
}

.field--invalid + .field-error,
.form-group.has-error .field-error { display: block; }

.field--invalid {
  border-color: #e53e3e !important;
  outline-color: #e53e3e;
}

/* Success message */
.form-success {
  padding: var(--space-lg);
  background-color: #ecfdf5;
  border: 1px solid #6ee7b7;
  border-radius: var(--border-radius-card);
  color: #065f46;
  text-align: center;
  font-weight: 600;
}

[data-theme="dark"] .form-success {
  background-color: rgba(6, 95, 70, 0.20);
  border-color: #065f46;
  color: #6ee7b7;
}

/* Error message */
.form-error {
  padding: var(--space-md);
  background-color: #fff5f5;
  border: 1px solid #fc8181;
  border-radius: var(--border-radius-card);
  color: #c53030;
  text-align: center;
  font-size: 0.9rem;
}

.form-error a { color: inherit; font-weight: 600; }

[data-theme="dark"] .form-error {
  background-color: rgba(197, 48, 48, 0.15);
  border-color: #c53030;
  color: #fc8181;
}

/* ─── OFFICES PANEL ───────────────────────────────────────── */

.offices-panel { }

.offices-panel > h2 { margin-bottom: var(--space-lg); }

.offices-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.office-card {
  font-style: normal;
  background-color: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius-card);
  padding: var(--space-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.office-card:hover {
  border-color: var(--color-accent);
  box-shadow: var(--shadow-card);
}

.office-card h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: var(--space-xs);
}

[data-theme="dark"] .office-card h3 { color: var(--color-accent); }

.office-card p {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: 0;
}

.offices-contact {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.offices-contact a {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-body);
  transition: color var(--transition-fast);
}

.offices-contact a:hover { color: var(--color-accent); }

.offices-book-demo { width: 100%; }

@media (max-width: 599px) {
  .contact-form-wrap { padding: var(--space-lg); }
}

@media (max-width: 479px) {
  .offices-grid { grid-template-columns: 1fr; }
  .contact-form-wrap { padding: var(--space-md); }
}

/* ─── RECAPTCHA ────────────────────────────────────────────── */

/* Hide the floating badge — disclosure text is shown in form footer instead */
.grecaptcha-badge { visibility: hidden !important; }

.recaptcha-notice {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: var(--space-sm);
  text-align: justify; /* class selector — must be explicit here to override the p type-selector */
}

.recaptcha-notice a { color: var(--text-muted); text-decoration: underline; }
