.btn {
  text-decoration: none;
  border: transparent;
  background: transparent;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--spacing-4);
  background: var(--color-surface-primary);
  color: var(--color-text-inverse-high);
  border-radius: var(--rad-action-md);
  font-weight: bold;
  font-size: var(--font-size-5);
  height: 48px;
  min-width: 80px;
  padding-inline: var(--spacing-6);
  white-space: nowrap;
  .icon {
    width: 24px;
    height: 24px;
    fill: var(--color-text-primary);
  }
  &.primary {
    background: var(--color-surface-primary);
    color: var(--color-text-inverse-high);
    .icon {
      fill: var(--color-text-inverse-high);
    }
    &.ghost {
      background: transparent;
      color: var(--color-text-primary);
      .icon {
        fill: var(--color-text-primary);
      }
    }
  }
  &.secondary {
    background: var(--color-surface-base-primary);
    border: 1px solid var(--color-surface-primary);
    color: var(--color-text-primary);
    .icon {
      fill: var(--color-text-primary);
    }
    &.ghost {
      background: transparent;
      border-color: transparent;
      color: var(--color-text-primary);
      .icon {
        fill: var(--color-text-primary);
      }
    }
  }
  &.tertiary {
    background: var(--color-surface-base-primary);
    border: 1px solid var(--color-border-base-middle);
    color: var(--color-text-base-middle);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    .icon {
      fill: var(--color-text-base-low);
    }
    &.ghost {
      background: transparent;
      border-color: transparent;
      color: var(--color-text-base-middle);
      .icon {
        fill: var(--color-text-base-middle);
      }
    }
  }
  &.danger {
    background: var(--color-surface-base-primary);
    border: 1px solid var(--color-border-base-middle);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    color: var(--color-text-danger);
    .icon {
      fill: var(--color-text-danger);
    }
    &.ghost {
      background: transparent;
      border-color: transparent;
      color: var(--color-text-danger);
      .icon {
        fill: var(--color-text-danger);
      }
    }
  }
  &.full {
    width: 100%;
  }
  &.sm {
    height: 36px;
    min-width: 64px;
    padding-inline: var(--spacing-6);
    font-size: var(--font-size-4);
    .icon {
      width: 20px;
      height: 20px;
    }
  }
  &.md {
    height: 48px;
    min-width: 80px;
    padding-inline: var(--spacing-8);
  }
  &.lg {
    height: 64px;
    min-width: 96px;
    padding-inline: var(--spacing-8);
  }
}
.text-btn {
  padding-inline: 0;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  white-space: nowrap;
  color: var(--color-text-primary);
  font-weight: 600;
  text-decoration: none;
  background: transparent;
  border: none;
  font-size: var(--font-size-4);
  .icon {
    width: 16px;
    height: 16px;
    fill: var(--color-text-primary);
  }
  &.inverse {
    color: var(--color-text-inverse-high);
    .icon {
      fill: var(--color-text-inverse-high);
    }
  }
}
.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  padding: var(--spacing-2);
  border-radius: var(--radius-round);
  aspect-ratio: 1/1;
  background: var(--color-surface-base-primary);
  border: 1px solid var(--color-border-base-middle);
  .icon {
    width: 20px;
    height: 20px;
    fill: var(--color-text-base-placeholder);
  }
  &.ghost {
    background: transparent;
    border: none;
  }
  &.fill {
    background: var(--color-surface-primary);
    border: 1px solid var(--color-border-primary);
    .icon {
      fill: var(--color-text-inverse-high);
    }
  }
  &.inverse {
    background: transparent;
    border: none;
    .icon {
      fill: var(--color-text-inverse-high);
    }
  }
  &.sm {
    width: 44px;
    height: 44px;
    .icon {
      width: 20px;
      height: 20px;
    }
  }
  &.md {
    width: 44px;
    height: 44px;
    .icon {
      width: 24px;
      height: 24px;
    }
  }
}
