/* Card & Button Components */

.card {
  background-color: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 10px;
  padding: 1.15rem;
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.card-visual {
  flex-shrink: 0;
}

.card-info {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.card h3 {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: 0;
}

.card-value {
  font-size: 1.45rem;
  font-weight: 600;
  color: var(--text-main);
  line-height: 1.3;
}

.card-subtext {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.card-subtext-positive {
  color: var(--accent-positive);
}

.card-subtext-positive i {
  font-size: 0.7rem;
  line-height: 1;
}

.card-chevron {
  position: absolute;
  top: 0.7rem;
  right: 0.7rem;
  color: var(--text-muted);
  transition: all 0.2s;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid var(--border-main);
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-chevron:hover {
  color: var(--text-main);
  border-color: var(--text-main);
}

.card-chevron i {
  font-size: 0.85rem;
  line-height: 1;
}

.task-progress-chart {
  position: relative;
  width: 56px;
  height: 56px;
}

.chart-center-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-main);
}

.total-expenses-chart {
  width: 70px;
  height: 50px;
}

.btn {
  padding: 0.375rem 0.75rem;
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 500;
  transition: background-color 0.2s, color 0.2s;
}

.btn-secondary {
  background-color: var(--accent-primary-light);
  color: var(--accent-primary);
}

.btn-secondary:hover {
  background-color: var(--sidebar-active-bg);
}

.btn-primary {
  background-color: var(--accent-primary);
  color: var(--text-on-accent);
}

.btn-primary:hover {
  opacity: 0.85;
}

.btn-small-pill {
  background-color: var(--accent-primary-light);
  color: var(--accent-primary);
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  transition: background-color 0.2s;
}

.btn-small-pill:hover {
  background-color: var(--sidebar-active-bg);
}
