:root {
  --jbp-bg:            #F9F7F4;
  --jbp-surface:       #FFFFFF;
  --jbp-surface-hover: #F1ECE3;
  --jbp-blue:          #3778DC;
  --jbp-blue-hover:    #4D8AE8;
  --jbp-gold:          #D4A843;
  --jbp-text:          #1C1A18;
  --jbp-text-muted:    #6B6560;
  --jbp-border:        #DFD8CB;
  --jbp-success:       #2D9F5F;
  --jbp-danger:        #D44949;
}

/* Hide elements with x-cloak until Alpine.js initialises.
   Without this the modal overlay (position:fixed;inset:0) is visible on load
   and blocks all clicks on the page. */
[x-cloak] { display: none !important; }

*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Barlow', sans-serif;
  color: var(--jbp-text);
  background: var(--jbp-bg);
  margin: 0;
}

.font-display { font-family: 'Barlow Condensed', sans-serif; }

/* Card */
.jbp-card {
  background: var(--jbp-surface);
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  border: 1px solid var(--jbp-border);
}

/* Label */
.jbp-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--jbp-text-muted);
}

/* Buttons */
.jbp-btn-primary {
  background: var(--jbp-blue);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: background 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.jbp-btn-primary:hover { background: var(--jbp-blue-hover); }

.jbp-btn-ghost {
  background: transparent;
  color: var(--jbp-text-muted);
  border: 1px solid var(--jbp-border);
  border-radius: 8px;
  padding: 8px 16px;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 600;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: background 0.15s;
}
.jbp-btn-ghost:hover { background: var(--jbp-surface-hover); }

/* Input */
.jbp-input {
  width: 100%;
  background: var(--jbp-bg);
  border: 1px solid var(--jbp-border);
  border-radius: 8px;
  padding: 8px 12px;
  font-family: 'Barlow', sans-serif;
  font-size: 14px;
  color: var(--jbp-text);
  transition: border-color 0.15s;
}
.jbp-input:focus { outline: none; border-color: var(--jbp-blue); }
select.jbp-input { appearance: auto; }
textarea.jbp-input { resize: vertical; }

/* Table */
.jbp-table { width: 100%; border-collapse: collapse; }
.jbp-table thead tr { border-bottom: 1px solid var(--jbp-border); }
.jbp-table th {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--jbp-text-muted);
  padding: 10px 16px;
  text-align: left;
  user-select: none;
}
.jbp-table td {
  padding: 12px 16px;
  font-size: 14px;
  border-bottom: 1px solid var(--jbp-border);
}
.jbp-table tbody tr:last-child td { border-bottom: none; }
.jbp-table tbody tr:hover { background: var(--jbp-surface-hover); }

/* Progress */
.jbp-progress-track {
  width: 100%;
  height: 8px;
  border-radius: 9999px;
  background: var(--jbp-surface-hover);
  overflow: hidden;
}
.jbp-progress-fill {
  height: 100%;
  border-radius: 9999px;
  background: var(--jbp-blue);
  transition: width 0.6s ease;
}

/* Badge */
.jbp-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 9999px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.badge-backbone         { background: rgba(55,120,220,0.12); color: #3778DC; }
.badge-startraxs        { background: rgba(212,168,67,0.16); color: #9C7A20; }
.badge-qwila            { background: rgba(45,159,95,0.14);  color: #1F7A47; }
.badge-mpi              { background: rgba(45,159,95,0.14);  color: #1F7A47; }
.badge-other            { background: rgba(107,101,96,0.14); color: #6B6560; }
.badge-anthropic        { background: rgba(212,73,73,0.12);  color: #B23A3A; }
.badge-openai           { background: rgba(45,159,95,0.14);  color: #1F7A47; }
.badge-apify            { background: rgba(55,120,220,0.12); color: #3778DC; }
.badge-income-protection     { background: rgba(55,120,220,0.12);  color: #3778DC; }
.badge-production-capability { background: rgba(138,79,191,0.14); color: #7339A8; }
.badge-asset-building        { background: rgba(45,159,95,0.14);  color: #1F7A47; }
.badge-deferred              { background: rgba(107,101,96,0.14); color: #6B6560; }

/* Status badges for wealth plan */
.status-not-started { background: rgba(107,101,96,0.16); color: #6B6560; }
.status-in-progress { background: rgba(212,168,67,0.18); color: #9C7A20; }
.status-complete    { background: rgba(45,159,95,0.16);  color: #1F7A47; }
.status-locked      { background: rgba(107,101,96,0.12); color: #6B6560; }

/* Modal */
.jbp-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(0,0,0,0.4);
}

/* Toast */
.jbp-toast {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 8px;
  background: var(--jbp-success);
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* Sidebar nav button */
.nav-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 20px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: transparent;
  border: none;
  border-left: 3px solid transparent;
  cursor: pointer;
  transition: background 0.1s, color 0.1s;
  text-align: left;
}

/* Toggle button group */
.jbp-toggle-group {
  display: inline-flex;
  border-radius: 8px;
  border: 1px solid var(--jbp-border);
  overflow: hidden;
}
.jbp-toggle-btn {
  padding: 6px 16px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: transparent;
  color: var(--jbp-text-muted);
  border: none;
  cursor: pointer;
  transition: background 0.1s, color 0.1s;
}

/* Icon button */
.jbp-icon-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--jbp-text-muted);
  padding: 4px;
  border-radius: 4px;
  transition: color 0.1s;
  display: inline-flex;
  align-items: center;
}
.jbp-icon-btn:hover { color: var(--jbp-blue); }
.jbp-icon-btn.danger:hover { color: var(--jbp-danger); }

/* HTMX loading indicator */
.htmx-indicator { opacity: 0; transition: opacity 0.2s; }
.htmx-request .htmx-indicator { opacity: 1; }

/* Empty state */
.jbp-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 16px;
  color: var(--jbp-text-muted);
  gap: 8px;
}
