/* ===== FINANCIAL PROJECTION PAGE ===== */
/* Ported from SvelteKit: underwritewise-fe/src/routes/workflow/[slug]/financial-projection/ */

.financial-projection {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding: var(--space-4);
}

/* ===== VALUATION TABLE ===== */
.valuation-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.valuation-table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-weight: var(--font-weight-semibold);
  color: var(--color-gray-700);
  background: var(--color-gray-50);
  border-bottom: 2px solid var(--color-gray-200);
  white-space: nowrap;
}

.valuation-table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-gray-800);
  border-bottom: 1px solid var(--color-gray-100);
}

.valuation-table tbody tr:hover {
  background: var(--color-gray-50);
}

/* Metric label column */
.valuation-table .metric-label {
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-700);
}

/* Monospace values */
.valuation-table .metric-value {
  font-family: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Menlo, monospace;
  font-weight: var(--font-weight-semibold);
  text-align: right;
}

/* Negative amounts (vacancy, expenses) */
.valuation-table .negative {
  color: var(--color-red-600, #dc2626);
}

/* Subtotal row (EGI) */
.valuation-table .total-row td {
  background: var(--color-gray-100);
  font-weight: var(--font-weight-bold);
  color: var(--color-gray-900);
}

/* NOI highlight row */
.valuation-table .noi-row td {
  background: var(--color-primary-50);
  border-top: 2px solid var(--color-primary-600);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-800, var(--color-primary-700));
}

/* Header content with tooltip */
.valuation-table__header-content {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Metric label with description */
.metric-description {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  color: var(--color-gray-500);
  margin-left: var(--space-2);
}

/* ===== STRESS TEST TABLE ===== */
.stress-test-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.stress-test-table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-weight: var(--font-weight-semibold);
  color: var(--color-gray-700);
  background: var(--color-gray-50);
  border-bottom: 2px solid var(--color-gray-200);
  white-space: nowrap;
}

.stress-test-table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-gray-800);
  border-bottom: 1px solid var(--color-gray-100);
  font-family: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Menlo, monospace;
}

.stress-test-table tbody tr:hover {
  background: var(--color-gray-50);
}

.stress-test-table .scenario-label {
  font-family: inherit;
  font-weight: var(--font-weight-medium);
  color: var(--color-gray-700);
}

/* Highlight the base case row (0% variation) */
.stress-test-table .base-case td {
  background: var(--color-primary-50);
  font-weight: var(--font-weight-semibold);
}

/* ===== PART NOTES ===== */
.valuation-note {
  font-size: var(--font-size-xs);
  color: var(--color-gray-500);
  margin-top: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-gray-300);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .financial-projection {
    padding: var(--space-3);
    gap: var(--space-4);
  }

  .valuation-table th,
  .valuation-table td,
  .stress-test-table th,
  .stress-test-table td {
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-xs);
  }
}
