/* MT Lead Marketplace - Shared Form Styling
   Covers: lead form, dealer registration, preferences, dashboard
*/

:root {
  --mtlm-bg: #f6f7fb;
  --mtlm-card: #ffffff;
  --mtlm-text: #111111;
  --mtlm-muted: #666666;
  --mtlm-border: rgba(0, 0, 0, 0.12);
  --mtlm-radius: 16px;
  --mtlm-radius-sm: 12px;

  --mtlm-primary: #0084FF;
  --mtlm-primary-hover: #0070dd;

  --mtlm-error: #b00020;
  --mtlm-success: #0a7a2f;
}

/* =============================================
   SHARED BASE STYLES
   ============================================= */

.mtlm-lead-form-wrap,
.mtlm-dealer-reg-form,
.mtlm-dealer-pref,
.mtlm-dealer-dash {
  max-width: 640px;
  margin: 0 auto;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}

/* Headings */
.mtlm-dealer-pref h2,
.mtlm-dealer-pref h3,
.mtlm-dealer-dash h2,
.mtlm-dealer-dash h3 {
  color: var(--mtlm-text);
  margin-top: 0;
}

.mtlm-dealer-pref h2,
.mtlm-dealer-dash h2 {
  font-size: 24px;
  font-weight: 800;
  margin-bottom: 8px;
}

.mtlm-dealer-pref h3,
.mtlm-dealer-dash h3 {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 10px;
  margin-top: 20px;
}

/* =============================================
   FORM INPUTS (SHARED)
   ============================================= */

.mtlm-lead-form input[type="text"],
.mtlm-lead-form input[type="email"],
.mtlm-lead-form input[type="tel"],
.mtlm-lead-form input[type="number"],
.mtlm-lead-form select,
.mtlm-lead-form textarea,
.mtlm-dealer-reg-form input[type="text"],
.mtlm-dealer-reg-form input[type="email"],
.mtlm-dealer-reg-form input[type="tel"],
.mtlm-dealer-reg-form input[type="number"],
.mtlm-dealer-reg-form select,
.mtlm-dealer-reg-form textarea,
.mtlm-dealer-pref input[type="text"],
.mtlm-dealer-pref input[type="email"],
.mtlm-dealer-pref input[type="tel"],
.mtlm-dealer-pref input[type="number"],
.mtlm-dealer-pref select,
.mtlm-dealer-pref textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #ddd;
  border-radius: var(--mtlm-radius-sm);
  padding: 12px 14px;
  font-size: 15px;
  line-height: 1.4;
  background: #fff;
  color: var(--mtlm-text);
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  font-family: inherit;
}

.mtlm-lead-form input:focus,
.mtlm-lead-form select:focus,
.mtlm-lead-form textarea:focus,
.mtlm-dealer-reg-form input:focus,
.mtlm-dealer-reg-form select:focus,
.mtlm-dealer-reg-form textarea:focus,
.mtlm-dealer-pref input:focus,
.mtlm-dealer-pref select:focus,
.mtlm-dealer-pref textarea:focus {
  border-color: var(--mtlm-primary);
  box-shadow: 0 0 0 3px rgba(0, 132, 255, 0.12);
}

.mtlm-lead-form input::placeholder,
.mtlm-lead-form textarea::placeholder,
.mtlm-dealer-reg-form input::placeholder,
.mtlm-dealer-reg-form textarea::placeholder,
.mtlm-dealer-pref input::placeholder,
.mtlm-dealer-pref textarea::placeholder {
  color: #999;
}

/* Select dropdown arrow */
.mtlm-lead-form select,
.mtlm-dealer-reg-form select,
.mtlm-dealer-pref select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
  cursor: pointer;
}

/* =============================================
   FORM LABELS
   ============================================= */

.mtlm-lead-form .mtlm-row > label,
.mtlm-dealer-reg-form p > label,
.mtlm-dealer-pref p > label,
.mtlm-dealer-pref h3 {
  display: block;
  font-weight: 600;
  font-size: 16px;
  color: var(--mtlm-text);
  margin-bottom: 8px;
}

.mtlm-lead-form .mtlm-row > label .required,
.mtlm-dealer-reg-form label .required {
  color: var(--mtlm-error);
  font-weight: 400;
}

/* =============================================
   FORM PARAGRAPHS (DEALER REG)
   ============================================= */

.mtlm-dealer-reg-form p {
  margin: 0 0 16px 0;
}

.mtlm-dealer-reg-form p > label {
  margin-bottom: 6px;
}

/* =============================================
   BUTTONS
   ============================================= */

.mtlm-lead-form button[type="submit"],
.mtlm-submit-btn,
.mtlm-dealer-reg-form button[type="submit"],
.mtlm-dealer-pref button[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 28px;
  border: none;
  border-radius: var(--mtlm-radius-sm);
  background: var(--mtlm-primary);
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.05s ease;
  font-family: inherit;
}

.mtlm-lead-form button[type="submit"]:hover,
.mtlm-submit-btn:hover,
.mtlm-dealer-reg-form button[type="submit"]:hover,
.mtlm-dealer-pref button[type="submit"]:hover {
  background: var(--mtlm-primary-hover);
}

.mtlm-lead-form button[type="submit"]:active,
.mtlm-submit-btn:active,
.mtlm-dealer-reg-form button[type="submit"]:active,
.mtlm-dealer-pref button[type="submit"]:active {
  transform: translateY(1px);
}

/* Secondary button style */
.mtlm-dealer-dash a.button,
.mtlm-dealer-dash .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  border: none;
  border-radius: var(--mtlm-radius-sm);
  background: var(--mtlm-primary);
  color: #fff !important;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s ease;
}

.mtlm-dealer-dash a.button:hover,
.mtlm-dealer-dash .button:hover {
  background: var(--mtlm-primary-hover);
  text-decoration: none;
}

/* =============================================
   LEAD FORM SPECIFICS
   ============================================= */

.mtlm-lead-form {
  margin: 0;
  padding: 0;
}

/* Lead form wrap card styling */
.mtlm-lead-form-wrap {
  background: #0084FF08;
  border: 1px solid var(--mtlm-border);
  border-radius: var(--mtlm-radius);
  padding: 24px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.mtlm-lead-form .mtlm-row {
  margin: 0 0 18px 0;
}

/* Models grid */
.mtlm-models {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.mtlm-model-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid #e0e0e0;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 400 !important;
  font-size: 16px;
  transition: border-color 0.15s ease, background 0.15s ease;
  margin: 0 !important;
}

.mtlm-model-option:hover {
  border-color: var(--mtlm-primary);
  background: rgba(0, 132, 255, 0.03);
}

.mtlm-model-option input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  flex-shrink: 0;
  accent-color: var(--mtlm-primary);
}

.mtlm-model-option input[type="checkbox"]:checked + span {
  color: var(--mtlm-primary);
  font-weight: 600;
}

/* Budget grid */
.mtlm-budget-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.mtlm-budget-grid > div {
  display: flex;
  flex-direction: column;
}

.mtlm-field-hint {
  display: block;
  font-size: 14px;
  color: var(--mtlm-muted);
  margin-bottom: 6px;
  font-weight: 500;
}

/* Checkboxes */
.mtlm-checks {
  margin-top: 20px !important;
  padding-top: 16px;
  border-top: 1px solid #eee;
}

.mtlm-check-option {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 0 12px 0 !important;
  font-size: 14px;
  cursor: pointer;
  font-weight: 400 !important;
  line-height: 1.4;
}

.mtlm-check-option input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 2px 0 0 0;
  flex-shrink: 0;
  accent-color: var(--mtlm-primary);
}

/* Submit row */
.mtlm-submit-row {
  margin-top: 24px !important;
  padding-top: 16px;
  border-top: 1px solid #eee;
}

/* Messages */
.mtlm-msg {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 16px;
  line-height: 1.4;
}

.mtlm-msg:empty {
  display: none;
}

.mtlm-msg.error {
  background: rgba(176, 0, 32, 0.08);
  border: 1px solid rgba(176, 0, 32, 0.2);
  color: var(--mtlm-error);
}

.mtlm-msg.success {
  background: rgba(10, 122, 47, 0.08);
  border: 1px solid rgba(10, 122, 47, 0.2);
  color: var(--mtlm-success);
}

/* Honeypot (hidden) */
.mtlm-hp {
  position: absolute;
  left: -9999px;
  visibility: hidden;
  opacity: 0;
  height: 0;
  overflow: hidden;
}

/* =============================================
   DEALER REGISTRATION FORM
   ============================================= */

.mtlm-dealer-reg-form {
  background: #0084FF08;
  border: 1px solid var(--mtlm-border);
  border-radius: var(--mtlm-radius);
  padding: 24px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.mtlm-dealer-reg-form p:last-child {
  margin-bottom: 0;
}

/* Checkbox styling in dealer reg */
.mtlm-dealer-reg-form label input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-right: 8px;
  vertical-align: middle;
  accent-color: var(--mtlm-primary);
}

/* =============================================
   DEALER PREFERENCES
   ============================================= */

.mtlm-dealer-pref {
  background: var(--mtlm-card);
  border: 1px solid var(--mtlm-border);
  border-radius: var(--mtlm-radius);
  padding: 24px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.mtlm-dealer-pref form {
  margin: 0;
}

/* Checkbox grid in preferences */
.mtlm-dealer-pref div[style*="grid"] label {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  cursor: pointer;
  font-size: 16px;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.mtlm-dealer-pref div[style*="grid"] label:hover {
  border-color: var(--mtlm-primary);
  background: rgba(0, 132, 255, 0.03);
}

.mtlm-dealer-pref div[style*="grid"] input[type="checkbox"] {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--mtlm-primary);
}

/* Back link */
.mtlm-dealer-pref p a {
  color: var(--mtlm-primary);
  text-decoration: none;
  font-weight: 600;
}

.mtlm-dealer-pref p a:hover {
  text-decoration: underline;
}

/* =============================================
   DEALER DASHBOARD
   ============================================= */

.mtlm-dealer-dash {
  background: var(--mtlm-card);
  border: 1px solid var(--mtlm-border);
  border-radius: var(--mtlm-radius);
  padding: 24px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.mtlm-dealer-dash hr {
  border: none;
  border-top: 1px solid #eee;
  margin: 20px 0;
}

.mtlm-dealer-dash p a {
  color: var(--mtlm-primary);
  text-decoration: none;
  font-weight: 600;
}

.mtlm-dealer-dash p a:hover {
  text-decoration: underline;
}

/* Lead cards in dashboard */
.mtlm-dealer-dash > div[style*="border"] {
  background: #fafafa;
  border: 1px solid #e0e0e0 !important;
  border-radius: var(--mtlm-radius-sm) !important;
  padding: 16px !important;
  margin: 12px 0 !important;
}

/* Unlocked badge */
.mtlm-dealer-dash span[style*="0a7a2f"] {
  background: rgba(10, 122, 47, 0.08) !important;
  border-color: var(--mtlm-success) !important;
  padding: 6px 12px !important;
  font-size: 14px;
}

/* =============================================
   MOBILE RESPONSIVENESS
   ============================================= */

@media (max-width: 560px) {
  .mtlm-lead-form-wrap,
  .mtlm-dealer-reg-form,
  .mtlm-dealer-pref,
  .mtlm-dealer-dash {
    padding: 16px;
    border-radius: 14px;
  }

  .mtlm-models {
    grid-template-columns: 1fr;
  }

  .mtlm-budget-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .mtlm-lead-form input[type="text"],
  .mtlm-lead-form input[type="email"],
  .mtlm-lead-form input[type="tel"],
  .mtlm-lead-form input[type="number"],
  .mtlm-lead-form select,
  .mtlm-lead-form textarea,
  .mtlm-dealer-reg-form input,
  .mtlm-dealer-reg-form select,
  .mtlm-dealer-reg-form textarea,
  .mtlm-dealer-pref input,
  .mtlm-dealer-pref select {
    font-size: 16px; /* Prevents iOS zoom */
  }

  .mtlm-dealer-pref div[style*="grid"] {
    grid-template-columns: 1fr !important;
  }
}

/* =============================================
   LEGACY COMPAT
   ============================================= */

.mtlm-lead-form .mtlm-checks label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 0 12px 0;
  font-size: 14px;
  cursor: pointer;
}

.mtlm-lead-form .mtlm-checks input[type="checkbox"] {
  margin-top: 2px;
}
