/* ================================================================
   Billing Module — billing.css
   All classes prefixed bill-
   ================================================================ */

/* ── Period / config bar ─────────────────────────────────────── */
.bill-config-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  background: var(--surface-raised);
  border-bottom: 1px solid var(--border-subtle);
  flex-wrap: wrap;
}

.bill-config-label {
  font-family: var(--font-ui);
  font-size: var(--text-2xs);
  font-weight: 600;
  letter-spacing: 0.07em;
  color: var(--stone-light);
  text-transform: uppercase;
}

.bill-config-input {
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--cream);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 3px 8px;
  min-width: 80px;
}

.bill-config-input:focus {
  outline: none;
  border-color: var(--gold-muted);
}

/* ── KPI strip ───────────────────────────────────────────────── */
.bill-kpi-strip {
  display: flex;
  gap: var(--sp-4);
  padding: var(--sp-4);
  flex-wrap: wrap;
}

.bill-kpi {
  flex: 1;
  min-width: 160px;
  background: var(--surface-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-4);
}

.bill-kpi-label {
  font-family: var(--font-ui);
  font-size: var(--text-2xs);
  font-weight: 600;
  letter-spacing: 0.07em;
  color: var(--stone-light);
  text-transform: uppercase;
  margin-bottom: var(--sp-1);
}

.bill-kpi-value {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--gold);
  letter-spacing: -0.01em;
}

.bill-kpi-sub {
  font-family: var(--font-ui);
  font-size: var(--text-2xs);
  color: var(--stone-mid);
  margin-top: 2px;
}

/* ── Fund breakdown table ────────────────────────────────────── */
.bill-table-wrap {
  padding: 0 var(--sp-4) var(--sp-4);
}

.bill-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-ui);
  font-size: var(--text-sm);
}

.bill-table th {
  font-size: var(--text-2xs);
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--stone-light);
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--border);
  text-align: left;
  white-space: nowrap;
}

.bill-table th.num,
.bill-table td.num {
  text-align: right;
}

.bill-table td {
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--border-subtle);
  color: var(--cream-muted);
  white-space: nowrap;
}

.bill-table tr:last-child td {
  border-bottom: none;
}

.bill-table tfoot td {
  border-top: 1px solid var(--border);
  border-bottom: none;
  font-weight: 600;
  color: var(--cream);
  padding-top: var(--sp-3);
}

/* ── Phase badges ────────────────────────────────────────────── */
.bill-badge {
  display: inline-block;
  padding: 1px 8px;
  border-radius: var(--radius-sm);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.bill-badge-investing {
  background: rgba(90, 158, 112, 0.15);
  color: var(--green-muted, #5A9E70);
  border: 1px solid rgba(90, 158, 112, 0.3);
}

.bill-badge-harvesting {
  background: rgba(191, 163, 106, 0.15);
  color: var(--gold);
  border: 1px solid rgba(191, 163, 106, 0.3);
}

/* ── Footnotes ───────────────────────────────────────────────── */
.bill-footnotes {
  padding: var(--sp-2) var(--sp-4) var(--sp-4);
  font-family: var(--font-ui);
  font-size: var(--text-2xs);
  color: var(--stone-mid);
  line-height: 1.6;
}

/* ── Generate button ─────────────────────────────────────────── */
.bill-generate-btn {
  font-family: var(--font-ui);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 6px 18px;
  background: var(--gold-dim);
  border: 1px solid var(--gold-muted);
  border-radius: var(--radius-sm);
  color: var(--gold);
  cursor: pointer;
  transition: all var(--t-fast);
  margin-left: auto;
}

.bill-generate-btn:hover {
  background: rgba(191, 163, 106, 0.25);
  border-color: var(--gold);
}

.bill-generate-btn:disabled {
  opacity: 0.4;
  cursor: default;
}

/* ── No-client placeholder ───────────────────────────────────── */
.bill-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 240px;
  font-family: var(--font-ui);
  font-size: var(--text-sm);
  color: var(--stone-mid);
}
