@layer components {
  .btn {
    --btn-background: var(--color-canvas);
    --btn-border-color: var(--color-ink-lighter);
    --btn-color: var(--color-ink);
    --btn-font-weight: 500;
    --btn-padding: 0.5em 1em;
    --btn-gap: 0.5ch;
    --btn-border-radius: var(--radius);
    --btn-hover-brightness: 0.92;
    --icon-size: 1.2em;

    align-items: center;
    background: var(--btn-background);
    border: 1px solid var(--btn-border-color);
    border-radius: var(--btn-border-radius);
    color: var(--btn-color);
    cursor: pointer;
    display: inline-flex;
    font-size: inherit;
    font-weight: var(--btn-font-weight);
    gap: var(--btn-gap);
    justify-content: center;
    line-height: 1.5;
    padding: var(--btn-padding);
    text-decoration: none;
    transition: background-color 100ms, border-color 100ms, color 100ms, opacity 100ms;
    white-space: nowrap;

    &:hover {
      filter: brightness(var(--btn-hover-brightness));
    }

    &:disabled, &.disabled {
      opacity: 0.4;
      pointer-events: none;
    }

    i { font-size: var(--icon-size); }
  }

  /* ── Sizes ── */
  .btn--small {
    --btn-padding: 0.25em 0.6em;
    font-size: var(--text-small);
  }

  /* ── Filled variants ── */
  .btn--primary {
    --btn-background: var(--color-link);
    --btn-border-color: var(--color-link);
    --btn-color: var(--color-white);
  }

  .btn--negative {
    --btn-background: var(--color-negative);
    --btn-border-color: var(--color-negative);
    --btn-color: var(--color-white);
  }

  .btn--positive {
    --btn-background: var(--color-positive);
    --btn-border-color: var(--color-positive);
    --btn-color: var(--color-white);
  }

  .btn--warning {
    --btn-background: var(--color-warning);
    --btn-border-color: var(--color-warning);
    --btn-color: var(--color-ink);
  }

  /* ── Outline variants ── */
  .btn--outline {
    --btn-background: transparent;
    --btn-color: var(--color-ink);
    --btn-border-color: var(--color-ink-lighter);
  }

  .btn--outline-primary {
    --btn-background: transparent;
    --btn-color: var(--color-link);
    --btn-border-color: var(--color-link);
  }

  .btn--outline-negative {
    --btn-background: transparent;
    --btn-color: var(--color-negative);
    --btn-border-color: var(--color-negative);
  }

  .btn--outline-warning {
    --btn-background: transparent;
    --btn-color: oklch(var(--lch-yellow-dark));
    --btn-border-color: oklch(var(--lch-yellow-dark));
  }

  .btn--outline-positive {
    --btn-background: transparent;
    --btn-color: var(--color-positive);
    --btn-border-color: var(--color-positive);
  }

  /* ── Plain (no border, no background) ── */
  .btn--plain {
    --btn-background: transparent;
    --btn-border-color: transparent;
    --btn-color: inherit;
    --btn-padding: 0;
  }

  /* ── Icon button (square) ── */
  .btn--icon {
    --btn-padding: 0.5em;
    aspect-ratio: 1;
  }
}
