/* ============================================================
   EDANTRA OS — CONTACT.CSS
   ============================================================ */

/* ─── MAIN TWO-COLUMN LAYOUT ─── */
.contact-main {
  padding-top: var(--nav-h);
  min-height: calc(100vh - var(--nav-h));
  background: var(--off-white);
}
.contact-outer {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: calc(100vh - var(--nav-h));
}

.contact-header {
  padding: 80px 0 72px;
}
.contact-header-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--page-px);
}

/* ─── LEFT PANEL ─── */
.contact-left {
  border-right: 1px solid var(--border);
  position: sticky;
  top: var(--nav-h);
  height: calc(100vh - var(--nav-h));
  overflow-y: auto;
  background: var(--warm-white);
}
.contact-left-inner {
  padding: 80px 64px 64px var(--page-px);
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.contact-h1 {
  font-family: var(--display);
  font-size: clamp(64px, 8vw, 120px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 0.90;
  color: var(--black);
  margin-bottom: 28px;
}
.contact-h1 em {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(54px, 6.8vw, 102px);
  text-transform: none;
  display: block;
}

.contact-intro {
  font-size: 16px;
  font-weight: 400;
  color: var(--mid);
  line-height: 1.75;
  max-width: 400px;
  margin-bottom: 48px;
}

/* What happens next */
.what-next {
  margin-bottom: 40px;
}
.what-next-label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.next-step {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 20px 0;
  border-bottom: 1px solid var(--border);
}
.next-step:last-child { border-bottom: none; }
.next-step-num {
  font-family: var(--display);
  font-size: 32px;
  font-weight: 400;
  color: var(--border-strong);
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}
.next-step-body {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.next-step-body strong {
  font-size: 15px;
  font-weight: 700;
  color: var(--black);
  letter-spacing: 0.01em;
  line-height: 1.3;
}
.next-step-body span {
  font-size: 14px;
  font-weight: 400;
  color: var(--mid);
  line-height: 1.65;
}

/* Live summary */
.contact-summary {
  border: 1px solid var(--border);
  margin-bottom: 32px;
}
.contact-summary.hidden { display: none; }
.summary-intro {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mid);
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}
.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--border);
}
.summary-row:last-child { border-bottom: none; }
.summary-row.hidden { display: none; }
.summary-key {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--mid);
  flex-shrink: 0;
}
.summary-val {
  font-size: 13px;
  font-weight: 500;
  color: var(--black);
  text-align: right;
  line-height: 1.5;
}

/* Contact details footer of left panel */
.contact-details {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: auto;
  padding-top: 32px;
  border-top: 1px solid var(--border);
}
.contact-detail-link {
  font-size: 13px;
  font-weight: 500;
  color: var(--black);
  text-decoration: none;
  transition: color 0.2s;
  letter-spacing: 0.02em;
}
.contact-detail-link:hover { color: var(--mid); }
.contact-detail-addr {
  font-size: 13px;
  font-weight: 400;
  color: var(--mid);
}

/* ─── RIGHT PANEL ─── */
.contact-right {
  padding: 80px var(--page-px) 80px 64px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* ─── STEP INDICATOR (shared styles with home, redeclared here) ─── */
.form-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 52px;
}
.fstep {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--warm-white);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--mid);
  transition: all 0.3s;
  flex-shrink: 0;
}
.fstep.active { background: var(--black); border-color: var(--black); color: var(--off-white); }
.fstep.done   { background: var(--black); border-color: var(--black); color: var(--accent); }
.fstep-line   { flex: 1; height: 1px; background: var(--border); }

/* ─── FORM STEPS ─── */
.form-step { display: flex; flex-direction: column; }
.form-step.hidden { display: none; }

.form-step-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 16px;
}
.form-step-q {
  font-family: var(--sans);
  font-size: clamp(20px, 2.5vw, 28px);
  font-weight: 700;
  color: var(--black);
  line-height: 1.25;
  margin-bottom: 28px;
}
.form-step-hint {
  font-size: 14px;
  font-weight: 400;
  color: var(--mid);
  margin-top: -16px;
  margin-bottom: 24px;
}

/* Business type grid */
.type-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.type-btn {
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 500;
  color: var(--mid);
  background: var(--warm-white);
  border: 1px solid var(--border);
  padding: 16px 18px;
  text-align: left;
  cursor: pointer;
  transition: all 0.18s;
  line-height: 1.3;
  min-height: 56px;
}
.type-btn:hover   { border-color: var(--black); color: var(--black); background: var(--off-white); }
.type-btn.selected { background: var(--black); border-color: var(--black); color: var(--off-white); }

/* Pain checkboxes */
.pain-checks {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 28px;
}
.pain-check-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 15px 18px;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--warm-white);
  transition: border-color 0.18s, background 0.18s;
}
.pain-check-item:hover { border-color: var(--border-strong); }
.pain-check-item input[type="checkbox"] {
  accent-color: var(--black);
  width: 17px;
  height: 17px;
  cursor: pointer;
  flex-shrink: 0;
}
.pain-check-item span { font-size: 15px; font-weight: 500; color: var(--black); }
.pain-check-item:has(input:checked) { background: var(--off-white); border-color: var(--black); }
.pain-check-item:has(input:checked) span { font-weight: 700; }

/* Next button */
.form-next-btn {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--off-white);
  background: var(--black);
  border: 1px solid var(--black);
  padding: 15px 32px;
  cursor: pointer;
  align-self: flex-start;
  transition: background 0.2s, color 0.2s;
}
.form-next-btn:hover { background: transparent; color: var(--black); }

/* Contact fields */
.field-group {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 28px;
}
.field-wrap { display: flex; flex-direction: column; gap: 7px; }
.field-label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--black);
}
.field-optional {
  font-weight: 400;
  color: var(--mid);
  text-transform: none;
  letter-spacing: 0;
  font-size: 12px;
}
.field-input {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 400;
  color: var(--black);
  background: var(--warm-white);
  border: 1px solid var(--border);
  padding: 14px 18px;
  outline: none;
  transition: border-color 0.2s;
  width: 100%;
  resize: none;
}
.field-input:focus { border-color: var(--black); }
.field-input::placeholder { color: var(--mid); }
.field-input.error { border-color: #b03020; }
.field-textarea { min-height: 88px; line-height: 1.6; }

.form-submit-btn {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--off-white);
  background: var(--black);
  border: none;
  padding: 18px 36px;
  cursor: pointer;
  width: 100%;
  transition: background 0.2s;
}
.form-submit-btn:hover    { background: #2a2a2a; }
.form-submit-btn:disabled { opacity: 0.5; cursor: default; }

.form-privacy {
  font-size: 13px;
  font-weight: 400;
  color: var(--mid);
  line-height: 1.6;
  margin-top: 14px;
}

/* ─── SUCCESS STATE ─── */
.form-success {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
}
.success-mark {
  width: 52px;
  height: 52px;
  background: #27873a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: #fff;
  font-weight: 700;
}
.form-sub {
  font-size: 17px;
  font-weight: 400;
  color: var(--mid);
  line-height: 1.75;
  max-width: 400px;
}
.success-next-steps {
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.success-next-label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 4px;
}

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .contact-outer { grid-template-columns: 1fr; }
  .contact-left  { position: static; height: auto; }
  .contact-left-inner {
    padding: 64px var(--page-px) 48px;
    border-bottom: 1px solid var(--border);
  }
  .contact-right { padding: 56px var(--page-px) 80px; }
}

@media (max-width: 600px) {
  .type-grid { grid-template-columns: 1fr; }
  .contact-h1 { font-size: clamp(52px, 16vw, 90px); }
}
