/* ── Card ── */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  overflow: hidden;
}

.card-top    { padding: 20px 20px 18px; }
.card-bottom {
  border-top: 1px solid var(--divider);
  padding: 18px 20px 20px;
}

/* ── Buttons ── */
.btn {
  display: block;
  width: 100%;
  height: var(--btn-h);
  background: var(--btn);
  color: var(--btn-text);
  border: none;
  border-radius: var(--r-md);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: -0.01em;
  transition: opacity 0.12s;
}
.btn:active { opacity: 0.75; }

.btn--secondary {
  background: transparent;
  color: var(--text);
  border: 1.5px solid var(--border);
}

.btn-note {
  text-align: center;
  font-size: 12px;
  color: var(--subtle);
  margin-top: 10px;
}

/* ── Bar (progress) ── */
.bar {
  height: 8px;
  background: var(--bar-bg);
  border-radius: var(--r-full);
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  background: var(--bar-fill);
  border-radius: var(--r-full);
  width: 0;
  transition: width 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Pill ── */
.pill {
  display: inline-flex;
  align-items: center;
  background: var(--text);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: var(--r-full);
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.pill--outline {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--border);
}

@media (prefers-reduced-motion: reduce) {
  .btn, .bar-fill { transition: none; }
}
