/* finance/finance.css — imported by all finance tools in addition to shared.css */

.biz-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; min-width: 0; }
.biz-muted { color: var(--color-muted); font-size: 12px; }
.biz-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.biz-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
@media (max-width: 560px) { .biz-grid-2, .biz-grid-3 { grid-template-columns: 1fr; } }

.biz-big-num { font-family: var(--font-mono); font-size: 32px; font-weight: 700; color: var(--color-accent); letter-spacing: -0.02em; }
.biz-big-sub { font-size: 12px; color: var(--color-muted); margin-top: 2px; }

/* Simple horizontal bar chart, pure divs (no chart library) */
.biz-bars { display: flex; flex-direction: column; gap: 10px; }
.biz-bar-row { display: grid; grid-template-columns: 110px 1fr 70px; gap: 10px; align-items: center; }
.biz-bar-label { font-size: 12px; color: var(--color-text); text-align: right; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.biz-bar-track { height: 20px; background: var(--color-bg-soft); border: 0.5px solid var(--color-border); border-radius: 999px; overflow: hidden; }
.biz-bar-fill { height: 100%; background: linear-gradient(90deg, var(--grad-a), var(--grad-b)); border-radius: 999px; transition: width 0.4s ease; }
.biz-bar-val { font-family: var(--font-mono); font-size: 12px; color: var(--color-muted); }

/* SVG line chart wrapper */
.biz-chart { width: 100%; height: 200px; }
.biz-chart-line { fill: none; stroke: var(--color-accent); stroke-width: 2; }
.biz-chart-area { fill: url(#areaGrad); opacity: 0.5; }
.biz-chart-axis { stroke: var(--color-border); stroke-width: 1; }
.biz-chart-dot { fill: var(--color-accent); }

/* Donut chart (budget) */
.biz-donut-wrap { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.biz-donut-legend { display: flex; flex-direction: column; gap: 8px; }
.biz-legend-item { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.biz-legend-swatch { width: 12px; height: 12px; border-radius: 3px; flex-shrink: 0; }

.biz-item-card { background: var(--color-surface); border: 0.5px solid var(--color-border); border-radius: var(--radius-lg); padding: 16px; margin-bottom: 12px; }


/* Interactive chart hover */
.biz-chart-cursor { stroke: var(--color-muted); stroke-width: 1; stroke-dasharray: 3 3; }
.biz-chart-focus { fill: var(--color-surface); stroke: var(--color-accent); stroke-width: 2.5; }
.biz-chart-tip {
  position: absolute; transform: translate(-50%, -100%); pointer-events: none; z-index: 5;
  background: var(--color-surface); border: 0.5px solid var(--color-border); border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md); padding: 5px 10px; font-family: var(--font-mono); font-size: 12px;
  color: var(--color-text); white-space: nowrap;
}
.biz-chart-tip b { color: var(--color-muted); font-weight: 500; margin-right: 6px; }
.biz-chart-tip-extra { color: var(--color-muted); margin-left: 8px; }
.biz-chart-tip-extra::before { content: '· '; }
