#theme-toggle {
  appearance: none;
  all: unset;
  background: var(--background-1);
  border: 2px solid var(--background-1);
  border-radius: 1.6rem;
  cursor: pointer;
  margin: 0 auto;
  padding: 2px 0;
  vertical-align: -1px;
  transition: outline .1s ease-in-out;

  &:focus {
    outline: 2px solid var(--orange-1);
  }

  .icon {
    width: 20px;
    height: 20px;
    border-radius: 100%;
    background: var(--foreground-3);
    color: var(--background-1);
    padding: 1px;
    margin: 0 2px;

    svg {
      margin-top: -2px;
    }
  }

  span {
    display: flex;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
  }

  .dark {
    display: none;
  }

  :root[data-theme='dark'] & {
    .dark {
      display: flex;
    }
    .light {
      display: none;
    }
  }
}
