/* ════════════════════════════════════════════════════════════════════
   lm-contact.css - custom /contact page (Contact phase, 2026-05-22).
   Loaded only on $page == 'contact'. Everything is namespaced `lmct-` with
   self-contained --ct-* tokens so it never collides with the global .lm-input
   / .lm-card / .lm-field rules (e.g. the auth design) or leaks into chrome.
   Rendered inside the normal site chrome, full-width content column. The form
   posts through the engine's js_ajax-forms → core/contact.php flow; the
   .alert-success / .alert-danger slots core.js fills are soft-styled below.
   ════════════════════════════════════════════════════════════════════ */
.lmct-page {
  --ct-primary: #0f6f4f;
  --ct-primary-strong: #0a5439;
  --ct-primary-soft: #f3f8f5;
  --ct-primary-soft-2: #dcebe2;
  --ct-bg: #ffffff;
  --ct-surface: #f8fafc;
  --ct-surface-2: #f1f5f9;
  --ct-text: #0f172a;
  --ct-muted: #475569;
  --ct-muted-2: #64748b;
  --ct-border: #e2e8f0;
  --ct-border-2: #eef2f6;
  --ct-elite-bg: #0F172A;
  --ct-danger: #b3261e;
  --ct-danger-soft: #fdf1f0;
  --ct-r-card: 12px;
  --ct-r-btn: 8px;
  --ct-r-input: 8px;
  --ct-font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --ct-font-serif: "Instrument Serif", "Iowan Old Style", Palatino, serif;
  font-family: var(--ct-font-sans);
  font-size: 15px;
  line-height: 1.7;
  color: var(--ct-text);
}
.lmct-page, .lmct-page *, .lmct-page *::before, .lmct-page *::after { box-sizing: border-box; }
.lmct-page a { color: var(--ct-primary); text-decoration: none; }
.lmct-page a:hover { text-decoration: underline; }

.lmct-wide { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 767px) { .lmct-wide { padding: 0 20px; } }

/* ---------- Page header ---------- */
.lmct-page-head {
  padding: 40px 0 36px;
  border-bottom: 1px solid var(--ct-border-2);
}
.lmct-page-head .eyebrow {
  font: 600 11px/1 var(--ct-font-sans);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ct-primary);
}
.lmct-page-head h1 {
  font: 500 56px/1.05 var(--ct-font-sans);
  letter-spacing: -0.025em;
  margin: 16px 0 18px;
  max-width: 760px;
  text-wrap: balance;
}
.lmct-page-head h1 em {
  font-family: var(--ct-font-serif);
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.015em;
}
.lmct-page-head .lead {
  font: 400 18px/1.6 var(--ct-font-sans);
  color: var(--ct-muted);
  margin: 0;
  max-width: 620px;
  text-wrap: pretty;
}
@media (max-width: 700px) {
  .lmct-page-head { padding: 48px 0 28px; }
  .lmct-page-head h1 { font-size: 36px; }
  .lmct-page-head .lead { font-size: 16px; }
}

/* ---------- Main grid ---------- */
.lmct-contact { padding: 56px 0 96px; }
.lmct-contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 56px;
  align-items: start;
}
@media (max-width: 900px) {
  .lmct-contact { padding: 40px 0 64px; }
  .lmct-contact-grid { grid-template-columns: 1fr; gap: 32px; }
}

/* ---------- Form ---------- */
.lmct-form-card {
  background: #fff;
  border: 1px solid var(--ct-border);
  border-radius: var(--ct-r-card);
  padding: 32px;
}
@media (max-width: 600px) { .lmct-form-card { padding: 22px; border-radius: 10px; } }

.lmct-form-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--ct-border-2);
}
.lmct-form-head h2 {
  font: 600 18px/1.3 var(--ct-font-sans);
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--ct-text);
}
.lmct-form-head .hint {
  font: 400 13px/1.4 var(--ct-font-sans);
  color: var(--ct-muted-2);
}

.lmct-form { display: flex; flex-direction: column; gap: 18px; }
.lmct-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 600px) {
  .lmct-row { grid-template-columns: 1fr; gap: 18px; }
}

.lmct-field { display: flex; flex-direction: column; gap: 6px; }
.lmct-label {
  font: 500 13px/1.3 var(--ct-font-sans);
  color: var(--ct-text);
  display: inline-flex; align-items: center; gap: 4px;
}
.lmct-label .req {
  color: var(--ct-muted-2);
  font-weight: 400;
  font-size: 13px;
  margin-left: 2px;
}

.lmct-input,
.lmct-textarea {
  font: 400 15px/1.5 var(--ct-font-sans);
  color: var(--ct-text);
  background: var(--ct-primary-soft);
  border: 1px solid var(--ct-border);
  border-radius: var(--ct-r-input);
  padding: 12px 14px;
  width: 100%;
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  -webkit-appearance: none; appearance: none;
}
.lmct-input::placeholder,
.lmct-textarea::placeholder {
  color: var(--ct-muted-2);
  opacity: 1;
}
.lmct-input:hover,
.lmct-textarea:hover { border-color: #c9d3df; }
.lmct-input:focus,
.lmct-textarea:focus {
  background: #fff;
  border-color: var(--ct-primary);
  box-shadow: 0 0 0 4px rgba(15, 111, 79, 0.12);
}
.lmct-textarea {
  min-height: 180px;
  resize: vertical;
  font-family: var(--ct-font-sans);
}

/* Helper / error */
.lmct-help {
  font: 400 12.5px/1.4 var(--ct-font-sans);
  color: var(--ct-muted-2);
  display: flex; align-items: center; gap: 6px;
  min-height: 16px;
}
.lmct-help .icon { width: 12px; height: 12px; flex: none; display: none; }

.lmct-field.is-invalid .lmct-input,
.lmct-field.is-invalid .lmct-textarea {
  border-color: #e5b5b0;
  background: var(--ct-danger-soft);
}
.lmct-field.is-invalid .lmct-input:focus,
.lmct-field.is-invalid .lmct-textarea:focus {
  border-color: var(--ct-danger);
  box-shadow: 0 0 0 4px rgba(179, 38, 30, 0.10);
}
.lmct-field.is-invalid .lmct-help {
  color: var(--ct-danger);
}
.lmct-field.is-invalid .lmct-help .icon { display: inline-block; }

/* Footer of form */
.lmct-form-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.lmct-form-foot .small {
  font: 400 12.5px/1.5 var(--ct-font-sans);
  color: var(--ct-muted-2);
  max-width: 360px;
}
.lmct-form-foot .small a { color: var(--ct-primary-strong); }

.lmct-btn-send {
  font: 600 14px/1 var(--ct-font-sans);
  color: #fff;
  background: var(--ct-primary);
  border: none;
  border-radius: var(--ct-r-btn);
  padding: 0 22px;
  height: 44px;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 10px;
  transition: background 0.15s ease, transform 0.06s ease;
}
.lmct-btn-send:hover { background: var(--ct-primary-strong); }
.lmct-btn-send:active { transform: translateY(1px); }
.lmct-btn-send svg { transition: transform 0.15s ease; }
.lmct-btn-send:hover svg { transform: translateX(2px); }

@media (max-width: 600px) {
  .lmct-form-foot { flex-direction: column-reverse; align-items: stretch; }
  .lmct-btn-send { width: 100%; justify-content: center; }
}

/* Success state */
.lmct-form.is-sent .lmct-form-grid { display: none; }
.lmct-sent {
  display: none;
  padding: 14px 16px;
  background: var(--ct-primary-soft);
  border: 1px solid var(--ct-primary-soft-2);
  border-left: 3px solid var(--ct-primary);
  border-radius: var(--ct-r-btn);
  font: 400 14px/1.5 var(--ct-font-sans);
  color: var(--ct-primary-strong);
  margin-top: 8px;
}
.lmct-form.is-sent .lmct-sent { display: block; }

/* ---------- Side info ---------- */
.lmct-info { display: flex; flex-direction: column; gap: 16px; }

.lmct-info-card {
  background: #fff;
  border: 1px solid var(--ct-border);
  border-radius: var(--ct-r-card);
  padding: 22px 24px;
}
.lmct-info-card.is-emerald {
  background: var(--ct-primary-soft);
  border-color: var(--ct-primary-soft-2);
}
.lmct-info-card h3 {
  font: 600 13px/1 var(--ct-font-sans);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ct-muted);
  margin: 0 0 14px;
}
.lmct-info-card.is-emerald h3 { color: var(--ct-primary-strong); opacity: 0.85; }

.lmct-info-row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 0;
  border-top: 1px solid var(--ct-border-2);
}
.lmct-info-card.is-emerald .lmct-info-row { border-top-color: var(--ct-primary-soft-2); }
.lmct-info-row:first-of-type { border-top: none; padding-top: 0; }
.lmct-info-row:last-of-type { padding-bottom: 0; }

.lmct-info-icon {
  width: 32px; height: 32px;
  flex: none;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--ct-border);
  color: var(--ct-primary);
  display: inline-flex; align-items: center; justify-content: center;
}
.lmct-info-card.is-emerald .lmct-info-icon { border-color: var(--ct-primary-soft-2); }

.lmct-info-body { min-width: 0; }
.lmct-info-body .k {
  font: 500 12px/1.2 var(--ct-font-sans);
  color: var(--ct-muted-2);
  margin-bottom: 4px;
  letter-spacing: 0.02em;
}
.lmct-info-body .v {
  font: 500 14px/1.45 var(--ct-font-sans);
  color: var(--ct-text);
  word-break: break-word;
}
.lmct-info-body .v a { color: var(--ct-text); }
.lmct-info-body .v a:hover { color: var(--ct-primary-strong); text-decoration: none; }
.lmct-info-body .sub {
  font: 400 12.5px/1.5 var(--ct-font-sans);
  color: var(--ct-muted-2);
  margin-top: 3px;
}

.lmct-status-pill {
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 12px/1 var(--ct-font-sans);
  color: var(--ct-primary-strong);
  background: #fff;
  border: 1px solid var(--ct-primary-soft-2);
  border-radius: 999px;
  padding: 6px 10px;
  margin-bottom: 14px;
}
.lmct-status-pill .dot {
  width: 7px; height: 7px; border-radius: 999px;
  background: var(--ct-primary);
  box-shadow: 0 0 0 3px rgba(15, 111, 79, 0.18);
}

/* ── Native (no-JS) soft validation - ports the design's .is-invalid look to
   the browser's :user-invalid so empty/invalid fields glow soft red. ─────── */
.lmct-page .lmct-input:user-invalid,
.lmct-page .lmct-textarea:user-invalid {
  border-color: #e5b5b0;
  background: var(--ct-danger-soft);
}
.lmct-page .lmct-input:user-invalid:focus,
.lmct-page .lmct-textarea:user-invalid:focus {
  border-color: var(--ct-danger);
  box-shadow: 0 0 0 4px rgba(179, 38, 30, 0.10);
}

/* ── Engine response slots (core.js fills/toggles .alert-success / .alert-danger).
   Soft, no harsh bootstrap box - matches the design's .lmct-sent confirmation. ── */
.lmct-page .alert-success,
.lmct-page .alert-danger {
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: var(--ct-r-btn);
  border: 1px solid;
  border-left-width: 3px;
  font: 400 14px/1.5 var(--ct-font-sans);
}
.lmct-page .alert-success {
  background: var(--ct-primary-soft);
  border-color: var(--ct-primary-soft-2);
  border-left-color: var(--ct-primary);
  color: var(--ct-primary-strong);
}
.lmct-page .alert-danger {
  background: var(--ct-danger-soft);
  border-color: #f3d4d1;
  border-left-color: var(--ct-danger);
  color: var(--ct-danger);
}

/* ════════════ DARK THEME ════════════ */
html[data-lm-theme="dark"] .lmct-page {
  --ct-primary: #2ea16f;
  --ct-primary-strong: #6ee7a8;
  --ct-primary-soft: rgba(46, 161, 111, 0.14);
  --ct-primary-soft-2: rgba(46, 161, 111, 0.34);
  --ct-bg: #0d1117;
  --ct-surface: #161b22;
  --ct-surface-2: #1c2230;
  --ct-text: #e6edf3;
  --ct-muted: #b9c2cc;
  --ct-muted-2: #8b95a1;
  --ct-border: #2b323c;
  --ct-border-2: #232932;
  --ct-elite-bg: #0d1117;
  --ct-danger: #f8b4ae;
  --ct-danger-soft: rgba(179, 38, 30, 0.18);
}
/* surfaces hard-coded #fff in the design → dark */
html[data-lm-theme="dark"] .lmct-page .lmct-form-card,
html[data-lm-theme="dark"] .lmct-page .lmct-info-card,
html[data-lm-theme="dark"] .lmct-page .lmct-info-icon,
html[data-lm-theme="dark"] .lmct-page .lmct-status-pill {
  background: #161b22;
  border-color: var(--ct-border);
}
html[data-lm-theme="dark"] .lmct-page .lmct-info-card.is-emerald {
  background: rgba(46, 161, 111, 0.10);
  border-color: var(--ct-primary-soft-2);
}
html[data-lm-theme="dark"] .lmct-page .lmct-input,
html[data-lm-theme="dark"] .lmct-page .lmct-textarea { background: var(--ct-surface-2); }
html[data-lm-theme="dark"] .lmct-page .lmct-input:focus,
html[data-lm-theme="dark"] .lmct-page .lmct-textarea:focus { background: #0d1117; }
