/* Serenity Finance v3 — shared styles. Black + gold to match the v1 logo. */
:root {
  --black: #1A1A1A;
  --black-soft: #2A2A2A;
  --gold: #D4B675;
  --gold-soft: #F7EFD9;
  --bg: #F5F5F5;
  --text: #1A1A1A;
  --muted: #6B6B6B;
  --border: #DDDDE0;
  --success: #1E7A3C;
  --warn:   #B86600;
  --danger: #7A1F1F;
  /* legacy aliases used in older inline styles */
  --navy: var(--black);
  --tan: var(--gold);
  --tan-soft: var(--gold-soft);
  --red: var(--danger);
}
* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html { -webkit-text-size-adjust: 100%; }
html, body {
  margin: 0; padding: 0; background: var(--bg); color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  font-feature-settings: "kern", "liga", "ss01";
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
body { padding-bottom: env(safe-area-inset-bottom); }
.wrap   { max-width: 760px; margin: 0 auto; padding: 32px 20px; }
.wide   { max-width: 1200px; }

/* ---------- Header bar (small, used on dashboards) ---------- */
header.bar { background: var(--black); color: white; padding: 14px 20px; display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
header.bar a { color: white; text-decoration: none; opacity: 0.85; font-size: 14px; white-space: nowrap; }
header.bar a:hover { opacity: 1; }
header.bar img.logo { height: 32px; width: auto; display: block; }
header.bar .spacer { flex: 1; }

h1, h2, h3 { color: var(--black); }

/* ---------- Cards ---------- */
.card { background: white; border: 1px solid var(--border); border-radius: 10px; padding: 24px; margin-bottom: 18px; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }

/* ---------- Forms ---------- */
label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; color: var(--text); }
input, select, textarea {
  width: 100%; padding: 12px 14px; border: 1px solid var(--border); border-radius: 8px;
  font-size: 15px; background: white; font-family: inherit;
}
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--black);
  box-shadow: 0 0 0 3px rgba(212, 182, 117, 0.25);
}
.row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.row.three { grid-template-columns: 1fr 1fr 1fr; }
.field { margin-bottom: 14px; }

/* ---------- Buttons (black with gold accent) ---------- */
button {
  padding: 12px 22px; border: none; border-radius: 8px;
  background: var(--black); color: white;
  font-size: 15px; font-weight: 600; cursor: pointer; font-family: inherit;
  transition: opacity 0.12s, transform 0.04s;
}
button:hover { opacity: 0.92; }
button:active { transform: scale(0.98); }
button:disabled { opacity: 0.5; cursor: not-allowed; }
button.ghost { background: white; color: var(--black); border: 1.5px solid var(--black); }
button.danger { background: var(--danger); }
button.gold   { background: var(--gold); color: var(--black); }

/* ---------- Alerts ---------- */
.alert { padding: 12px 14px; border-radius: 8px; margin-bottom: 16px; font-size: 14px; }
.alert.err { background: #FBE5E5; color: var(--danger); border: 1px solid #E8C2C2; }
.alert.ok  { background: #E5F5EB; color: var(--success); border: 1px solid #C2E1CC; }

.muted { color: var(--muted); font-size: 13px; }

/* ---------- Tab nav ---------- */
.tabs { display: flex; gap: 4px; margin-bottom: 16px; border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.tab-btn {
  background: transparent; color: var(--muted); border: none; border-radius: 0;
  padding: 12px 18px; font-size: 14px; font-weight: 600;
  border-bottom: 3px solid transparent; min-height: auto;
  width: auto;
}
.tab-btn:hover { color: var(--black); background: transparent; opacity: 1; }
.tab-btn.active { color: var(--black); border-bottom-color: var(--gold); }

/* ---------- Segmented filter (US/CA/All) ---------- */
.seg-filter { display: inline-flex; gap: 0; background: white; border: 1px solid var(--border); border-radius: 10px; padding: 4px; margin-bottom: 18px; }
.seg-btn {
  background: transparent; color: var(--muted); border: none; border-radius: 7px;
  padding: 8px 16px; font-size: 13px; font-weight: 600; min-height: auto; width: auto;
}
.seg-btn:hover { background: transparent; opacity: 1; }
.seg-btn.active { background: var(--black); color: white; }

/* ---------- Step indicator ---------- */
.step-indicator { display: flex; gap: 8px; margin-bottom: 24px; }
.step-indicator div { flex: 1; height: 4px; background: var(--border); border-radius: 2px; }
.step-indicator div.active { background: var(--black); }
.step-indicator div.done   { background: var(--gold); }

/* ---------- Tables ---------- */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table { width: 100%; border-collapse: collapse; font-size: 14px; }
thead { background: var(--gold-soft); }
th, td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--border); }
th { font-weight: 600; color: var(--black); font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; }

/* ---------- Stat cards ---------- */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 16px; margin-bottom: 24px; }
.stat { background: white; border: 1px solid var(--border); border-radius: 8px; padding: 16px; }
.stat .label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; }
.stat .value { font-size: 24px; font-weight: 700; color: var(--black); margin-top: 4px; }

/* ---------- Badges ---------- */
.badge { display: inline-block; padding: 3px 9px; border-radius: 10px; font-size: 11px; font-weight: 600; }
.badge.active     { background: #E5F5EB; color: var(--success); }
.badge.past_due   { background: #FBE5E5; color: var(--danger); }
.badge.pending    { background: #FFF4D6; color: var(--warn); }
.badge.completed  { background: var(--gold-soft); color: var(--black); }
.retry-flag       { color: var(--warn); font-size: 12px; margin-left: 4px; cursor: help; vertical-align: middle; }

/* ---------- Trust badge (e.g. "No Fees, No Interest") ---------- */
.trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--gold-soft);
  color: var(--black);
  padding: 8px 14px;
  border: 1px solid var(--gold);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.2px;
  margin: 4px 0 16px;
}
/* Variant for use inside the black ".breakdown" box: keep the gold pill but
   center it under the highlighted row and pull the bottom margin in. */
.breakdown .trust-badge.trust-badge-on-dark {
  display: flex;
  width: max-content;
  margin: 14px auto 2px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.4);
}

/* ---------- Customer-form brand panel ---------- */
.brand-panel {
  background: linear-gradient(180deg, #0E0E0E 0%, #1A1A1A 100%);
  padding: 40px 24px 32px; display: flex; flex-direction: column;
  align-items: center; gap: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.15);
}
.brand-panel img { max-width: 960px; width: 96%; height: auto; display: block; }

/* ---------- Signature pad + Stripe ---------- */
.signature-pad { border: 1.5px dashed var(--border); border-radius: 8px; background: white; touch-action: none; cursor: crosshair; width: 100%; height: 180px; }
#stripe-card { padding: 14px; border: 1px solid var(--border); border-radius: 8px; background: white; }

/* ---------- Modal ---------- */
dialog { border: none; border-radius: 12px; padding: 0; max-width: 520px; width: 90vw; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
dialog::backdrop { background: rgba(0, 0, 0, 0.55); }
.modal-body { padding: 24px; }
.modal-body h3 { margin: 0 0 8px; color: var(--black); }
.pw-display { display: flex; gap: 8px; margin: 16px 0; flex-wrap: wrap; }
.pw-display code { flex: 1; min-width: 180px; padding: 12px 14px; background: var(--gold-soft); border: 2px solid var(--gold); border-radius: 8px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 17px; font-weight: 600; letter-spacing: 0.5px; color: var(--black); user-select: all; }
.modal-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 16px; flex-wrap: wrap; }

/* ============================================================ */
/* Mobile responsive                                            */
/* ============================================================ */
@media (max-width: 640px) {
  /* ----- Layout ----- */
  .wrap { padding: 20px 14px; }
  .card {
    padding: 18px 16px; border-radius: 14px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 4px 12px rgba(0,0,0,0.03);
  }

  /* ----- Typography ----- */
  h2 { font-size: 22px; letter-spacing: -0.01em; }
  h3 { font-size: 17px; }

  /* ----- Forms ----- */
  .row, .row.three { grid-template-columns: 1fr; gap: 10px; }
  .field { margin-bottom: 16px; }
  label { font-size: 13px; margin-bottom: 8px; color: var(--text); }
  input, select, textarea {
    font-size: 16px; padding: 14px 14px; border-radius: 10px;
    /* prevent iOS zoom on focus is handled by 16px font */
  }

  /* ----- Header (small bar, used on dashboards) ----- */
  header.bar {
    padding: calc(env(safe-area-inset-top, 0) + 12px) 16px 12px;
    gap: 14px;
    position: sticky; top: 0; z-index: 50;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  }
  header.bar img.logo { height: 26px; }
  header.bar a { font-size: 13px; }

  /* ----- Customer-form brand panel ----- */
  .brand-panel {
    padding: calc(env(safe-area-inset-top, 0) + 28px) 16px 24px;
    gap: 6px;
  }
  .brand-panel img { max-width: 640px; }

  /* ----- Buttons (tall, full-width, generous touch target) ----- */
  button {
    width: 100%; padding: 16px 22px; font-size: 16px;
    border-radius: 12px; min-height: 52px;
    transition: opacity 0.12s, transform 0.06s;
  }
  button + button { margin-top: 10px; }
  /* Action button rows in modals etc. should still be inline-ish */
  .modal-actions button { width: auto; min-width: 110px; }
  /* Tab + seg buttons should keep auto width on mobile too */
  .tab-btn, .seg-btn { width: auto; min-height: auto; padding: 10px 14px; margin-top: 0; }
  .tab-btn + .tab-btn { margin-top: 0; }
  .seg-btn + .seg-btn { margin-top: 0; }
  .seg-filter { width: 100%; justify-content: stretch; }
  .seg-filter .seg-btn { flex: 1; }

  /* ----- Stats grid (compact, 2 per row) ----- */
  .stats { grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 18px; }
  .stat { padding: 14px; border-radius: 12px; }
  .stat .label { font-size: 10px; }
  .stat .value { font-size: 22px; margin-top: 6px; }

  /* ----- Tables → stacked cards (refined hierarchy) ----- */
  .table-wrap { overflow: visible; }
  table, thead, tbody, tr, td { display: block; }
  thead { display: none; }
  table { font-size: 14px; }
  tr {
    background: white; border: 1px solid var(--border); border-radius: 14px;
    padding: 16px; margin-bottom: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 6px 16px rgba(0,0,0,0.03);
  }
  td {
    padding: 7px 0; border: none;
    display: grid; grid-template-columns: 110px 1fr; gap: 12px; align-items: baseline;
    line-height: 1.4; word-break: break-word;
  }
  td::before {
    content: attr(data-label);
    font-weight: 600; font-size: 11px; color: var(--muted);
    text-transform: uppercase; letter-spacing: 0.6px;
  }
  /* When a td has no value, hide the label too */
  td:empty { display: none; }
  /* Action-cell buttons should stay tap-friendly inside the card */
  td button { width: 100%; margin-top: 6px; min-height: 44px; padding: 10px 14px; }
  td button + button { margin-top: 8px; }
  /* Don't render the row separators since each tr is its own card */
  tr td:last-child { padding-bottom: 0; }

  /* ----- Step indicator: chunky bars ----- */
  .step-indicator { gap: 6px; margin-bottom: 18px; }
  .step-indicator div { height: 5px; border-radius: 3px; }

  /* ----- Signature pad ----- */
  .signature-pad { height: 140px; }

  /* ----- Modal: full-width-ish on phones ----- */
  dialog { max-width: 96vw; width: 96vw; border-radius: 14px; }
  .modal-body { padding: 20px 18px; }
  .pw-display code { font-size: 16px; padding: 14px; }
}

/* Very small screens (<360px) — extra-compact */
@media (max-width: 360px) {
  td { grid-template-columns: 90px 1fr; gap: 8px; }
  .stats { grid-template-columns: 1fr; }
  .brand-panel img { max-width: 480px; }
}
