/* BorneHub Pro Portal – Dealer Space UI
   Accent: #ec900a ; Text: rgb(24,24,24)
   Reuses base variables and .swpp-box / .swpp-btn / .swpp-table from swpp-pro.css
   when both are loaded. This file adds dealer-specific components.
*/

/* ── Status color palette ────────────────────────────────────────────────── */
:root {
  --swpp-status-nouveau:          #3b82f6;
  --swpp-status-devis_envoye:     #f59e0b;
  --swpp-status-devis_accepte:    #22c55e;
  --swpp-status-non_comptabilise: #9ca3af;
  --swpp-status-devis_perdu:      #ef4444;
  --swpp-status-lead_paye:        #8b5cf6;
}

/* ── Page wrapper ────────────────────────────────────────────────────────── */
.swpp-dealer-page {
  width: 90%;
  max-width: 1060px;
  margin: 24px auto 100px;
  color: var(--swpp-text, rgb(24,24,24));
}

/* ── Toolbar ─────────────────────────────────────────────────────────────── */
.swpp-dealer-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: rgba(255,255,255,.88);
  border: 1px solid var(--swpp-border, rgba(0,0,0,.10));
  border-radius: 999px;
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 10px;
}

.swpp-dealer-toolbar__brand {
  font-weight: 700;
  font-size: 15px;
  color: var(--swpp-text, rgb(24,24,24));
  text-decoration: none;
  white-space: nowrap;
}

.swpp-dealer-toolbar__links {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.swpp-dealer-toolbar__links a {
  color: var(--swpp-text, rgb(24,24,24));
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  padding: 6px 10px;
  border-radius: 8px;
  transition: background .15s;
}
.swpp-dealer-toolbar__links a:hover { background: rgba(0,0,0,.05); }

.swpp-dealer-toolbar__cta {
  background: var(--swpp-accent, #ec900a) !important;
  color: #111 !important;
  border-radius: 999px !important;
  padding: 8px 16px !important;
  font-weight: 700 !important;
}
.swpp-dealer-toolbar__cta:hover { background: rgba(0,0,0,.05) !important; }

/* ── Dashboard content area ──────────────────────────────────────────────── */
.swpp-dealer-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ── Status sections ─────────────────────────────────────────────────────── */
.swpp-dealer-section {
  background: #fff;
  border: 1px solid var(--swpp-border, rgba(0,0,0,.10));
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 8px 24px rgba(17,24,39,.06);
}

.swpp-dealer-section__title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--swpp-muted, #6b7280);
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.swpp-dealer-section__count {
  background: var(--swpp-bg, #f6f7fb);
  border: 1px solid var(--swpp-border, rgba(0,0,0,.10));
  border-radius: 999px;
  padding: 1px 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--swpp-text, rgb(24,24,24));
}

/* Section accent strip (left border based on status) */
.swpp-dealer-section--nouveau          { border-left: 4px solid var(--swpp-status-nouveau); }
.swpp-dealer-section--devis_envoye     { border-left: 4px solid var(--swpp-status-devis_envoye); }
.swpp-dealer-section--devis_accepte    { border-left: 4px solid var(--swpp-status-devis_accepte); }
.swpp-dealer-section--non_comptabilise { border-left: 4px solid var(--swpp-status-non_comptabilise); }
.swpp-dealer-section--devis_perdu      { border-left: 4px solid var(--swpp-status-devis_perdu); }
.swpp-dealer-section--lead_paye        { border-left: 4px solid var(--swpp-status-lead_paye); }

/* ── Lead cards grid ─────────────────────────────────────────────────────── */
.swpp-dealer-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
}

.swpp-dealer-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--swpp-border, rgba(0,0,0,.10));
  background: var(--swpp-bg, #f6f7fb);
  cursor: pointer;
  text-align: left;
  transition: transform .15s ease, box-shadow .15s ease, border-color .2s;
  font-family: inherit;
}
.swpp-dealer-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(17,24,39,.10);
  border-color: rgba(0,0,0,.18);
}
.swpp-dealer-card:active { transform: translateY(0px) scale(.99); }

/* Status-colored top accent for cards */
.swpp-dealer-card--nouveau          { border-top: 3px solid var(--swpp-status-nouveau); }
.swpp-dealer-card--devis_envoye     { border-top: 3px solid var(--swpp-status-devis_envoye); }
.swpp-dealer-card--devis_accepte    { border-top: 3px solid var(--swpp-status-devis_accepte); }
.swpp-dealer-card--non_comptabilise { border-top: 3px solid var(--swpp-status-non_comptabilise); }
.swpp-dealer-card--devis_perdu      { border-top: 3px solid var(--swpp-status-devis_perdu); }
.swpp-dealer-card--lead_paye        { border-top: 3px solid var(--swpp-status-lead_paye); }

.swpp-card__name {
  font-weight: 700;
  font-size: 14px;
  color: var(--swpp-text, rgb(24,24,24));
}
.swpp-card__vehicle {
  font-size: 13px;
  color: var(--swpp-muted, #6b7280);
}
.swpp-card__location {
  font-size: 12px;
  color: var(--swpp-muted, #6b7280);
}
.swpp-card__date {
  font-size: 11px;
  color: var(--swpp-muted, #6b7280);
  margin-top: 2px;
}
.swpp-card__commission {
  margin-top: 4px;
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: #22c55e;
  background: rgba(34,197,94,.10);
  border-radius: 999px;
  padding: 1px 8px;
  align-self: flex-start;
}

/* ── Commission table ────────────────────────────────────────────────────── */
.swpp-dealer-commissions { margin-top: 4px; }
.swpp-dealer-commissions h3 { margin: 0 0 14px; font-size: 18px; }

.swpp-dealer-totals {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.swpp-dealer-total {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 14px 18px;
  border-radius: 14px;
  border: 1px solid var(--swpp-border, rgba(0,0,0,.10));
  background: var(--swpp-bg, #f6f7fb);
  min-width: 120px;
}
.swpp-dealer-total__label {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--swpp-muted, #6b7280);
}
.swpp-dealer-total__amount {
  font-size: 26px;
  font-weight: 700;
  color: var(--swpp-text, rgb(24,24,24));
}
.swpp-dealer-total--paid .swpp-dealer-total__amount { color: #22c55e; }
.swpp-dealer-total--pending .swpp-dealer-total__amount { color: #f59e0b; }

.swpp-dealer-commission-table { min-width: 540px; }

/* ── Badges ──────────────────────────────────────────────────────────────── */
.swpp-badge {
  display: inline-flex;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid rgba(0,0,0,.08);
}
.swpp-badge--paid    { background: rgba(34,197,94,.12); color: #166534; }
.swpp-badge--pending { background: rgba(245,158,11,.12); color: #92400e; }
.swpp-badge--status  { background: rgba(236,144,10,.12); color: #7a4b00; }

/* ── Lightbox ────────────────────────────────────────────────────────────── */
.swpp-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
}
.swpp-lightbox.is-open { display: block; }

.swpp-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17,24,39,.50);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.swpp-lightbox__panel {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  border-radius: 20px;
  padding: 28px;
  width: min(92vw, 640px);
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: 0 24px 60px rgba(17,24,39,.20);
}

.swpp-lightbox__close {
  position: absolute;
  top: 14px;
  right: 16px;
  background: rgba(0,0,0,.06);
  border: none;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
}
.swpp-lightbox__close:hover { background: rgba(0,0,0,.12); }

.swpp-lightbox-table { min-width: unset; width: 100%; }

/* ── Mobile FAB ──────────────────────────────────────────────────────────── */
.swpp-dealer-fab {
  display: none;
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--swpp-accent, #ec900a);
  color: #111;
  font-weight: 700;
  font-size: 15px;
  padding: 14px 28px;
  border-radius: 999px;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(236,144,10,.35);
  white-space: nowrap;
  z-index: 999;
  transition: transform .15s ease, box-shadow .15s ease;
}
.swpp-dealer-fab:hover {
  transform: translateX(-50%) translateY(-2px);
  box-shadow: 0 16px 36px rgba(236,144,10,.40);
}

@media (max-width: 780px) {
  .swpp-dealer-fab { display: flex; }
  .swpp-dealer-toolbar__cta { display: none; }
  .swpp-dealer-cards { grid-template-columns: 1fr; }
}

/* ── Dealer registration form ────────────────────────────────────────────── */
.swpp-dealer-form .swpp-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 600px) {
  .swpp-dealer-form .swpp-form-row { grid-template-columns: 1fr; }
}

.swpp-dealer-form label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--swpp-muted, #6b7280);
  margin-bottom: 4px;
}
.swpp-dealer-form input,
.swpp-dealer-form select {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--swpp-border, rgba(0,0,0,.10));
  border-radius: 10px;
  font-size: 14px;
  color: var(--swpp-text, rgb(24,24,24));
  background: #fff;
  box-sizing: border-box;
  transition: border-color .15s;
}
.swpp-dealer-form input:focus,
.swpp-dealer-form select:focus {
  outline: none;
  border-color: var(--swpp-accent, #ec900a);
  box-shadow: 0 0 0 3px rgba(236,144,10,.18);
}

/* ── Login page — unified form ───────────────────────────────────────────── */
.bh-login-wrap {
  max-width: 420px;
  margin: 60px auto;
  padding: 40px 36px 36px;
  background: var(--bh-surface, #1a1c1e);
  border: 1px solid var(--bh-border, rgba(255,255,255,.08));
  border-radius: 20px;
  box-shadow: 0 24px 64px rgba(0,0,0,.28);
}

/* Light theme override */
.bh-light .bh-login-wrap {
  background: #ffffff;
  border-color: #e5e7eb;
  box-shadow: 0 8px 32px rgba(0,0,0,.08);
}

/* Brand / logo row */
.bh-login-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px;
}
.bh-login-brand__name {
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--bh-text, #f3f4f6);
}
.bh-light .bh-login-brand__name { color: #111213; }

/* Titles */
.bh-login-title {
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin: 0 0 6px;
  color: var(--bh-text, #f3f4f6);
}
.bh-light .bh-login-title { color: #111213; }

.bh-login-sub {
  font-size: .875rem;
  color: var(--bh-text-muted, #9ca3af);
  margin: 0 0 28px;
}

/* Error banner */
.bh-login-error {
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.3);
  color: #fca5a5;
  border-radius: 10px;
  padding: 10px 14px;
  font-size: .85rem;
  margin-bottom: 18px;
}
.bh-light .bh-login-error {
  background: rgba(239,68,68,.06);
  color: #b91c1c;
}

/* Form fields — override WP default styles */
.bh-login-form #loginform {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  box-shadow: none;
}
.bh-login-form #loginform p { margin: 0 0 16px; }
.bh-login-form #loginform label {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--bh-text-muted, #9ca3af);
  margin-bottom: 6px;
}
.bh-light .bh-login-form #loginform label { color: #6b7280; }

.bh-login-form #loginform input[type="text"],
.bh-login-form #loginform input[type="password"] {
  width: 100%;
  box-sizing: border-box;
  background: var(--bh-surface-2, #0f1011);
  border: 1.5px solid var(--bh-border, rgba(255,255,255,.1));
  border-radius: 10px;
  padding: 11px 14px;
  font-size: .95rem;
  color: var(--bh-text, #f3f4f6);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none;
}
.bh-light .bh-login-form #loginform input[type="text"],
.bh-light .bh-login-form #loginform input[type="password"] {
  background: #f9fafb;
  border-color: #d1d5db;
  color: #111213;
}
.bh-login-form #loginform input[type="text"]:focus,
.bh-login-form #loginform input[type="password"]:focus {
  border-color: #3ecf4c;
  box-shadow: 0 0 0 3px rgba(62,207,76,.18);
}

/* Hide the "remember me" checkbox row */
.bh-login-form #loginform .forgetmenot { display: none; }

/* Submit button */
.bh-login-form #loginform .submit { margin: 8px 0 0; }
.bh-login-form #loginform input[type="submit"] {
  width: 100%;
  background: #3ecf4c;
  color: #0f1011;
  border: none;
  border-radius: 10px;
  padding: 13px 20px;
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s, transform .1s, box-shadow .15s;
  -webkit-appearance: none;
}
.bh-login-form #loginform input[type="submit"]:hover {
  opacity: .9;
  box-shadow: 0 8px 20px rgba(62,207,76,.3);
  transform: translateY(-1px);
}
.bh-login-form #loginform input[type="submit"]:active {
  transform: translateY(0);
  opacity: 1;
}

/* Forgot password link */
.bh-login-forgot {
  margin-top: 16px;
  text-align: center;
}
.bh-login-forgot a {
  font-size: .85rem;
  color: var(--bh-text-muted, #9ca3af);
  text-decoration: none;
  transition: color .15s;
}
.bh-login-forgot a:hover { color: #3ecf4c; }
.bh-light .bh-login-forgot a { color: #6b7280; }

/* ── Lost password form — styles spécifiques ─────────────────────────────── */
.bh-lp-hint {
  font-size: .875rem;
  color: var(--bh-text-muted, #9ca3af);
  margin: 0 0 24px;
  line-height: 1.6;
}
.bh-light .bh-lp-hint { color: #6b7280; }

.bh-lp-label {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--bh-text-muted, #9ca3af);
  margin-bottom: 6px;
}
.bh-light .bh-lp-label { color: #6b7280; }

.bh-lp-input {
  width: 100%;
  box-sizing: border-box;
  background: var(--bh-surface-2, #0f1011);
  border: 1.5px solid var(--bh-border, rgba(255,255,255,.1));
  border-radius: 10px;
  padding: 11px 14px;
  font-size: .95rem;
  color: var(--bh-text, #f3f4f6);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  -webkit-appearance: none;
}
.bh-light .bh-lp-input {
  background: #f9fafb;
  border-color: #d1d5db;
  color: #111213;
}
.bh-lp-input:focus {
  border-color: #3ecf4c;
  box-shadow: 0 0 0 3px rgba(62,207,76,.18);
}
.bh-lp-input::placeholder { color: var(--bh-text-muted, #6b7280); opacity: .6; }

.bh-lp-submit {
  width: 100%;
  background: #3ecf4c;
  color: #0f1011;
  border: none;
  border-radius: 10px;
  padding: 13px 20px;
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s, transform .1s, box-shadow .15s;
  -webkit-appearance: none;
  margin-top: 8px;
}
.bh-lp-submit:hover {
  opacity: .9;
  box-shadow: 0 8px 20px rgba(62,207,76,.3);
  transform: translateY(-1px);
}
.bh-lp-submit:active { transform: translateY(0); opacity: 1; }

/* Confirmation envoi */
.bh-lp-success {
  background: rgba(62,207,76,.08);
  border: 1px solid rgba(62,207,76,.25);
  border-radius: 12px;
  padding: 20px;
  margin: 20px 0 0;
}
.bh-lp-success p {
  margin: 0;
  font-size: .9rem;
  color: var(--bh-text-muted, #9ca3af);
  line-height: 1.65;
}
.bh-light .bh-lp-success { background: rgba(62,207,76,.05); }
.bh-light .bh-lp-success p { color: #4b5563; }

/* ── Lead comment history ─────────────────────────────────────────────────── */
.swpp-lead-comments {
  margin-top: 24px;
  border-top: 1px solid rgba(0,0,0,.08);
  padding-top: 16px;
}
.swpp-lead-comments h4 {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .05em;
  opacity: .55;
  margin: 0 0 12px;
}
.swpp-lead-comment {
  background: rgba(0,0,0,.04);
  border-radius: 8px;
  padding: 10px 14px;
  margin-bottom: 10px;
}
.swpp-lead-comment__meta {
  display: block;
  font-size: 11px;
  opacity: .5;
  margin-bottom: 4px;
}
.swpp-lead-comment__text {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  white-space: pre-wrap;
}
.swpp-lead-update-form h4 {
  font-size: 15px;
  margin: 0 0 var(--sp-3, 12px);
}

/* ── Button aliases (dash-modifier variants for installer/dealer pages) ─────── */
.swpp-btn-primary { background: var(--swpp-accent, #ec900a); color: #111; border-color: transparent; font-weight: 700; }
.swpp-btn-primary:hover { background: #d4810a; }
.swpp-btn-sm { padding: 6px 14px; font-size: .82rem; }
.swpp-btn-lg { padding: 14px 32px; font-size: 1rem; }
