@mixin light {
  --color-mode: 'light';
  --color-primary: #{$light-color-primary};
  --color-secondary: #{$light-color-secondary};
  --color-focus: #{$light-color-focus};
  --color-mute: #{$light-color-mute};
  --color-font: #{$light-color-font};
  --color-divider: #{$light-color-divider};
  --color-bg: #{$light-color-bg};
  --color-codebg: #{$light-color-codebg};
}

@mixin dark {
  --color-mode: 'dark';
  --color-primary: #{$dark-color-primary};
  --color-secondary: #{$dark-color-secondary};
  --color-focus: #{$dark-color-focus};
  --color-mute: #{$dark-color-mute};
  --color-font: #{$dark-color-font};
  --color-divider: #{$dark-color-divider};
  --color-bg: #{$dark-color-bg};
  --color-codebg: #{$dark-color-codebg};
}

body[data-theme='auto'] {
  @include light();

  @media (prefers-color-scheme: dark) {
    @include dark();
    @import '_dark-diff'; // things different from light
  }
}

body[data-theme='light'] {
  @include light();
}

body[data-theme='dark'] {
  @include dark();
  @import '_dark-diff'; // things different from light
}

@mixin link-1 {
  a {
    color: var(--color-primary);
  }

  a:hover {
    color: var(--color-secondary);
  }
}

@mixin link-2 {
  a {
    color: var(--color-secondary);
  }

  a:hover {
    color: var(--color-focus);
  }
}

$divider: 2px solid var(--color-divider);