/* ═══════════════════════════════════════
   Budget widget — standalone progress card
   ═══════════════════════════════════════ */
.budget-widgets-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

@media (min-width: 769px) {
  .budget-widgets-row {
    grid-template-columns: 1fr 1fr;
  }
}

.budget-widget {
  background: var(--surface);
  background-image: var(--gradient-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
}

.budget-widget__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
}

.budget-widget__title {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--text-muted);
}

.budget-widget__percent {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-tighter);
  line-height: 1;
}

.budget-widget__percent--success { color: var(--success); }
.budget-widget__percent--warning { color: var(--warning); }
.budget-widget__percent--danger { color: var(--danger); }

.budget-widget .budget-bar {
  margin-bottom: 0;
}

.budget-widget__footer {
  display: flex;
  justify-content: space-between;
  margin-top: var(--space-sm);
  font-size: var(--text-sm);
}

.budget-widget__footer strong {
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

/* Budget progress bar */
.budget-bar {
  margin-bottom: var(--space-sm);
  height: 40px;
}

.budget-bar--md { height: 28px; }
.budget-bar--sm { height: 24px; }

/* Expand when 100% marker is shown below */
.budget-bar--overflow { height: 56px; }
.budget-bar--overflow.budget-bar--md { height: 42px; }
.budget-bar--overflow.budget-bar--sm { height: 38px; }

.budget-bar__canvas {
  display: block;
  width: 100%;
  height: 100%;
}

/* Dashboard card context */
.card__budget .budget-bar {
  margin-top: var(--space-sm);
  margin-bottom: 0;
}

.budget-bar__label {
  display: flex;
  justify-content: space-between;
  font-size: var(--text-xs);
  margin-top: var(--space-xs);
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
}

/* Filter bar */
.filters {
  margin-bottom: var(--space-lg);
  padding: var(--space-sm) var(--space-md);
  background: var(--surface);
  border-radius: var(--radius-lg);
}

.filters .form-group {
  margin-bottom: 0;
}

.filters .form-row {
  gap: var(--space-md);
}

.filters__form {
  display: flex;
  gap: var(--space-md);
  align-items: flex-end;
}

@media (min-width: 641px) {
  .filters .form-label {
    font-size: var(--text-2xs);
    margin-bottom: var(--space-xs);
    color: var(--text-faint);
  }
}

.filters__tabs {
  display: flex;
  gap: var(--space-xs);
}

@media (max-width: 640px) {
  .filters__form {
    flex-direction: column;
    align-items: stretch;
  }
}
