Respect browser's prefered color scheme now

- Use gruvbox highlight theme when dark
This commit is contained in:
leafee98 2023-03-15 16:24:06 +08:00
parent 10441a59a8
commit 0547c3d73d
2 changed files with 281 additions and 113 deletions

View file

@ -1,3 +1,75 @@
/* defines light color */
:root {
--color-light-bg-page: #EBEBEB;
--color-light-bg-content: #F4F4F4;
--color-light-bg-block: #EBEBEB;
--color-light-bg-shadow: #E0E0E0;
--color-light-fg-font-normal: #4E403E;
--color-light-fg-font-hover: #555555;
--color-light-fg-font-block: #53504D;
--color-light-fg-font-quote: #57606A;
--color-light-fg-tiny-line: #e0e0e0;
--color-light-fg-marker-quote: #BFBFBF;
--color-light-fg-hyperlink: #FF5F61;
--color-light-fg-hyperlink-hover: #FC3134;
--color-light-bg-pager: #000000;
--color-light-fg-pager: #000000;
}
/* defines dark color */
:root {
--color-dark-bg-page: #2F2F2F;
--color-dark-bg-content: #453B3B;
--color-dark-bg-block: #4E403E;
--color-dark-bg-shadow: #505050;
--color-dark-fg-font-normal: #E8E8E8;
--color-dark-fg-font-hover: #CECECD;
--color-dark-fg-font-block: #E8E8E8;
--color-dark-fg-font-quote: #8B8680;
--color-dark-fg-tiny-line: #585858;
--color-dark-fg-marker-quote: #6F6B66;
--color-dark-fg-hyperlink: #FF5F61;
--color-dark-fg-hyperlink-hover: #FC3134;
--color-dark-bg-pager: #000000;
--color-dark-fg-pager: #000000;
}
:root {
--color-bg-page: var(--color-light-bg-page);
--color-bg-content: var(--color-light-bg-content);
--color-bg-block: var(--color-light-bg-block);
--color-bg-shadow: var(--color-light-bg-shadow);
--color-fg-font-normal: var(--color-light-fg-font-normal);
--color-fg-font-hover: var(--color-light-fg-font-hover);
--color-fg-font-block: var(--color-light-fg-font-block);
--color-fg-font-quote: var(--color-light-fg-font-quote);
--color-fg-tiny-line: var(--color-light-fg-tiny-line);
--color-fg-marker-quote: var(--color-light-fg-marker-quote);
--color-fg-hyperlink: var(--color-light-fg-hyperlink);
--color-fg-hyperlink-hover: var(--color-light-fg-hyperlink-hover);
--color-bg-pager: var(--color-light-bg-pager);
--color-fg-pager: var(--color-light-fg-pager);
}
@media (prefers-color-scheme: dark) {
:root {
--color-bg-page: var(--color-dark-bg-page);
--color-bg-content: var(--color-dark-bg-content);
--color-bg-block: var(--color-dark-bg-block);
--color-bg-shadow: var(--color-dark-bg-shadow);
--color-fg-font-normal: var(--color-dark-fg-font-normal);
--color-fg-font-hover: var(--color-dark-fg-font-hover);
--color-fg-font-block: var(--color-dark-fg-font-block);
--color-fg-font-quote: var(--color-dark-fg-font-quote);
--color-fg-tiny-line: var(--color-dark-fg-tiny-line);
--color-fg-marker-quote: var(--color-dark-fg-marker-quote);
--color-fg-hyperlink: var(--color-dark-fg-hyperlink);
--color-fg-hyperlink-hover: var(--color-dark-fg-hyperlink-hover);
--color-bg-pager: var(--color-dark-bg-pager);
--color-fg-pager: var(--color-dark-fg-pager);
}
}
:root { :root {
--fonts-sans-en: "Noto Sans", "Droid Sans", "Calibri", "Arial"; --fonts-sans-en: "Noto Sans", "Droid Sans", "Calibri", "Arial";
--fonts-sans-zh: "WenQuanYi Zen Hei", "WenQuanYi Micro Hei", --fonts-sans-zh: "WenQuanYi Zen Hei", "WenQuanYi Micro Hei",
@ -46,6 +118,7 @@
--font-size-6: 2.000rem; --font-size-6: 2.000rem;
} }
*, ::before, ::after { *, ::before, ::after {
font-family: inherit; font-family: inherit;
box-sizing: border-box; box-sizing: border-box;
@ -54,7 +127,7 @@
html { html {
font-family: var(--fonts-sans); font-family: var(--fonts-sans);
font-size: 16px; font-size: 16px;
color: var(--color-black-3); color: var(--color-fg-font-normal);
} }
/**************************************************************/ /**************************************************************/
@ -70,7 +143,7 @@ body {
align-items: center; align-items: center;
background-color: var(--color-light-4); background-color: var(--color-bg-page);
} }
/* set up padding and margin of some main elements */ /* set up padding and margin of some main elements */
@ -101,7 +174,9 @@ body {
.side-recent, .side-recent,
.side-categories, .side-categories,
.side-tags .side-tags
{ background-color: var(--color-light-5); } {
background-color: var(--color-bg-content);
}
/* place header in the center of header-wrapper */ /* place header in the center of header-wrapper */
.header-wrapper { .header-wrapper {
@ -164,7 +239,7 @@ body {
margin-top: var(--len-3); margin-top: var(--len-3);
padding-top: var(--len-3); padding-top: var(--len-3);
border-top: 1px solid var(--color-light-1); border-top: 1px solid var(--color-fg-tiny-line);
} }
} }
@ -206,9 +281,9 @@ body {
/* beautify sub menu style */ /* beautify sub menu style */
.header .sub-menu { .header .sub-menu {
background-color: var(--color-light-5); background-color: var(--color-bg-content);
padding: var(--len-2) var(--len-4); padding: var(--len-2) var(--len-4);
box-shadow: var(--color-light-1) 0px 0px 3px 1px; box-shadow: var(--color-bg-shadow) 0px 0px 3px 1px;
border-radius: 3px; border-radius: 3px;
} }
@ -219,8 +294,8 @@ body {
font-weight: bold; font-weight: bold;
} }
.header a { color: var(--color-black-3); text-decoration: none; } .header a { color: var(--color-fg-font-normal); text-decoration: none; }
.header a:hover { color: var(--color-fav-2); } .header a:hover { color: var(--color-fg-font-hover); }
/************************/ /************************/
/* set up footer layout */ /* set up footer layout */
@ -243,7 +318,7 @@ body {
.footer .footer-item:last-child { margin-right: 0; } .footer .footer-item:last-child { margin-right: 0; }
/* beautify hyper link style */ /* beautify hyper link style */
.footer { color: var(--color-black-1) } .footer { color: var(--color-fg-font-normal) }
.footer a { color: var(--color-fav-2); text-decoration: none; } .footer a { color: var(--color-fav-2); text-decoration: none; }
.footer a:hover { color: var(--color-fav-3); } .footer a:hover { color: var(--color-fav-3); }
@ -265,14 +340,14 @@ body {
align-items: flex-start; align-items: flex-start;
font-size: var(--font-size-1); font-size: var(--font-size-1);
color: var(--color-black-1); color: var(--color-fg-font-quote);
} }
.list-item .tips > * { margin-right: var(--len-3); } .list-item .tips > * { margin-right: var(--len-3); }
.list-item .tips > *:last-child { margin-right: 0; } .list-item .tips > *:last-child { margin-right: 0; }
.list-item .title a { text-decoration: none; color: var(--color-black-2); } .list-item .title a { text-decoration: none; color: var(--color-fg-font-normal); }
.list-item .title a:hover { color: var(--color-fav-2); } .list-item .title a:hover { color: var(--color-fg-font-hover); }
.list-item .tips a { text-decoration: none; color: var(--color-fav-2) } .list-item .tips a { text-decoration: none; color: var(--color-fav-2) }
.list-item .tips a:hover { color: var(--color-fav-3) } .list-item .tips a:hover { color: var(--color-fav-3) }
@ -286,7 +361,7 @@ body {
.list-item .title { margin: 0 0 var(--len-2) 0; } .list-item .title { margin: 0 0 var(--len-2) 0; }
.list-item .tips { margin: 0 0 var(--len-3) 0; } .list-item .tips { margin: 0 0 var(--len-3) 0; }
.list-item { border-bottom: 1px solid var(--color-light-2); } .list-item { border-bottom: 1px solid var(--color-fg-tiny-line); }
.list-item:last-child { border-bottom: 0; } .list-item:last-child { border-bottom: 0; }
.list-item:first-child { padding-top: 0;} .list-item:first-child { padding-top: 0;}
@ -307,7 +382,7 @@ body {
.side hr { .side hr {
border: none; border: none;
height: 1px; height: 1px;
background-color: var(--color-light-2); background-color: var(--color-bg-content);
margin: var(--len-2) 0; margin: var(--len-2) 0;
} }
@ -317,7 +392,7 @@ body {
.side > * { margin-bottom: var(--len-3); } .side > * { margin-bottom: var(--len-3); }
.side > *:last-child { margin-bottom: 0; } .side > *:last-child { margin-bottom: 0; }
.side a { color: var(--color-black-3); text-decoration: none; } .side a { color: var(--color-fg-font-normal); text-decoration: none; }
.side a:hover { color: var(--color-fav-2); } .side a:hover { color: var(--color-fav-2); }
/* horizontally place tags */ /* horizontally place tags */
@ -360,7 +435,7 @@ body {
.single .tip, .single .tip,
.single .taxonomies .single .taxonomies
{ color: var(--color-black-1)} { color: var(--color-fg-font-normal)}
.single .taxonomies > * { display: inline-block; } .single .taxonomies > * { display: inline-block; }
@ -382,10 +457,10 @@ body {
.content code { .content code {
font-family: var(--fonts-mono); font-family: var(--fonts-mono);
background-color: var(--color-light-4); background-color: var(--color-bg-block);
padding: 0 2px; padding: 0 2px;
border: 1px solid var(--color-light-1); border: 1px solid var(--color-fg-tiny-line);
border-radius: 2px; border-radius: 2px;
line-height: inherit; line-height: inherit;
word-wrap: break-word; word-wrap: break-word;
@ -400,6 +475,7 @@ body {
padding: var(--len-3); padding: var(--len-3);
border: none; border: none;
background-color: var(--color-bg-block);
border-radius: 3px; border-radius: 3px;
overflow: auto; overflow: auto;
@ -411,14 +487,14 @@ body {
margin-bottom: 5px; margin-bottom: 5px;
padding-left: 1em; padding-left: 1em;
margin-left: 0px; margin-left: 0px;
border-left: 3px solid #eee; border-left: 3px solid var(--color-fg-marker-quote);
color: var(--color-black-1); color: var(--color-fg-font-quote);
} }
.content hr { .content hr {
border: none; border: none;
height: 2px; height: 2px;
background-color: var(--color-light-4); background-color: var(--color-fg-tiny-line);
width: 80%; width: 80%;
margin: var(--len-2) auto; margin: var(--len-2) auto;
@ -526,11 +602,11 @@ body {
#archive .group .value .date { display: inline-block; width: 60px; } #archive .group .value .date { display: inline-block; width: 60px; }
#archive .group .value .title { display: inline; } #archive .group .value .title { display: inline; }
#archive .group .value .date { color: var(--color-black-0); } #archive .group .value .date { color: var(--color-fg-font-normal); }
#archive .group .value a { text-decoration: none; } #archive .group .value a { text-decoration: none; }
#archive .group .value a { color: var(--color-black-3); } #archive .group .value a { color: var(--color-fg-font-normal); }
#archive .group .value a:hover { color: var(--color-fav-2); } #archive .group .value a:hover { color: var(--color-fav-2); }
#archive .group .value .tags { #archive .group .value .tags {
@ -538,7 +614,7 @@ body {
margin-left: 7px; margin-left: 7px;
} }
#archive .group .value .tags { #archive .group .value .tags {
background: var(--color-light-4); background: var(--color-bg-block);
border-radius: 2px; border-radius: 2px;
padding: 4px 7px; padding: 4px 7px;
font-size: var(--font-size-1); font-size: var(--font-size-1);
@ -607,8 +683,8 @@ body {
text-decoration: none; text-decoration: none;
color: var(--color-black-2); color: var(--color-fg-font-normal);
background-color: var(--color-light-3); background-color: var(--color-fg-hyperlink-hover);
transition: background-color 0.25s; transition: background-color 0.25s;
} }
@ -620,7 +696,7 @@ body {
.pagination a.current { .pagination a.current {
background-color: var(--color-fav-1); background-color: var(--color-fav-1);
pointer-events: none; pointer-events: none;
color: var(--color-black-1); color: var(--color-fg-font-normal);
cursor: default; cursor: default;
} }
@ -635,7 +711,7 @@ body {
/* keep content style from being affected by remark42 style */ /* keep content style from being affected by remark42 style */
.content pre { .content pre {
background-color: transparent; background-color: transparent;
color: var(--color-black-3) color: var(--color-fg-font-normal)
} }
/**********/ /**********/

View file

@ -1,3 +1,4 @@
@media (prefers-color-scheme: light) {
/* Background */ .bg { color: #272822; } /* Background */ .bg { color: #272822; }
/* PreWrapper */ .chroma { color: #272822; } /* PreWrapper */ .chroma { color: #272822; }
/* Other */ .chroma .x { } /* Other */ .chroma .x { }
@ -83,3 +84,94 @@
/* GenericTraceback */ .chroma .gt { } /* GenericTraceback */ .chroma .gt { }
/* GenericUnderline */ .chroma .gl { } /* GenericUnderline */ .chroma .gl { }
/* TextWhitespace */ .chroma .w { } /* TextWhitespace */ .chroma .w { }
}
/* use monokai highlight theme in dark */
@media (prefers-color-scheme: dark) {
/* Background */ .bg { color: #f8f8f2; background-color: #272822; }
/* PreWrapper */ .chroma { color: #f8f8f2; background-color: #272822; }
/* Other */ .chroma .x { }
/* Error */ .chroma .err { color: #960050; background-color: #1e0010 }
/* CodeLine */ .chroma .cl { }
/* LineLink */ .chroma .lnlinks { outline: none; text-decoration: none; color: inherit }
/* LineTableTD */ .chroma .lntd { vertical-align: top; padding: 0; margin: 0; border: 0; }
/* LineTable */ .chroma .lntable { border-spacing: 0; padding: 0; margin: 0; border: 0; }
/* LineHighlight */ .chroma .hl { background-color: #ffffcc }
/* LineNumbersTable */ .chroma .lnt { white-space: pre; user-select: none; margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f }
/* LineNumbers */ .chroma .ln { white-space: pre; user-select: none; margin-right: 0.4em; padding: 0 0.4em 0 0.4em;color: #7f7f7f }
/* Line */ .chroma .line { display: flex; }
/* Keyword */ .chroma .k { color: #66d9ef }
/* KeywordConstant */ .chroma .kc { color: #66d9ef }
/* KeywordDeclaration */ .chroma .kd { color: #66d9ef }
/* KeywordNamespace */ .chroma .kn { color: #f92672 }
/* KeywordPseudo */ .chroma .kp { color: #66d9ef }
/* KeywordReserved */ .chroma .kr { color: #66d9ef }
/* KeywordType */ .chroma .kt { color: #66d9ef }
/* Name */ .chroma .n { }
/* NameAttribute */ .chroma .na { color: #a6e22e }
/* NameBuiltin */ .chroma .nb { }
/* NameBuiltinPseudo */ .chroma .bp { }
/* NameClass */ .chroma .nc { color: #a6e22e }
/* NameConstant */ .chroma .no { color: #66d9ef }
/* NameDecorator */ .chroma .nd { color: #a6e22e }
/* NameEntity */ .chroma .ni { }
/* NameException */ .chroma .ne { color: #a6e22e }
/* NameFunction */ .chroma .nf { color: #a6e22e }
/* NameFunctionMagic */ .chroma .fm { }
/* NameLabel */ .chroma .nl { }
/* NameNamespace */ .chroma .nn { }
/* NameOther */ .chroma .nx { color: #a6e22e }
/* NameProperty */ .chroma .py { }
/* NameTag */ .chroma .nt { color: #f92672 }
/* NameVariable */ .chroma .nv { }
/* NameVariableClass */ .chroma .vc { }
/* NameVariableGlobal */ .chroma .vg { }
/* NameVariableInstance */ .chroma .vi { }
/* NameVariableMagic */ .chroma .vm { }
/* Literal */ .chroma .l { color: #ae81ff }
/* LiteralDate */ .chroma .ld { color: #e6db74 }
/* LiteralString */ .chroma .s { color: #e6db74 }
/* LiteralStringAffix */ .chroma .sa { color: #e6db74 }
/* LiteralStringBacktick */ .chroma .sb { color: #e6db74 }
/* LiteralStringChar */ .chroma .sc { color: #e6db74 }
/* LiteralStringDelimiter */ .chroma .dl { color: #e6db74 }
/* LiteralStringDoc */ .chroma .sd { color: #e6db74 }
/* LiteralStringDouble */ .chroma .s2 { color: #e6db74 }
/* LiteralStringEscape */ .chroma .se { color: #ae81ff }
/* LiteralStringHeredoc */ .chroma .sh { color: #e6db74 }
/* LiteralStringInterpol */ .chroma .si { color: #e6db74 }
/* LiteralStringOther */ .chroma .sx { color: #e6db74 }
/* LiteralStringRegex */ .chroma .sr { color: #e6db74 }
/* LiteralStringSingle */ .chroma .s1 { color: #e6db74 }
/* LiteralStringSymbol */ .chroma .ss { color: #e6db74 }
/* LiteralNumber */ .chroma .m { color: #ae81ff }
/* LiteralNumberBin */ .chroma .mb { color: #ae81ff }
/* LiteralNumberFloat */ .chroma .mf { color: #ae81ff }
/* LiteralNumberHex */ .chroma .mh { color: #ae81ff }
/* LiteralNumberInteger */ .chroma .mi { color: #ae81ff }
/* LiteralNumberIntegerLong */ .chroma .il { color: #ae81ff }
/* LiteralNumberOct */ .chroma .mo { color: #ae81ff }
/* Operator */ .chroma .o { color: #f92672 }
/* OperatorWord */ .chroma .ow { color: #f92672 }
/* Punctuation */ .chroma .p { }
/* Comment */ .chroma .c { color: #75715e }
/* CommentHashbang */ .chroma .ch { color: #75715e }
/* CommentMultiline */ .chroma .cm { color: #75715e }
/* CommentSingle */ .chroma .c1 { color: #75715e }
/* CommentSpecial */ .chroma .cs { color: #75715e }
/* CommentPreproc */ .chroma .cp { color: #75715e }
/* CommentPreprocFile */ .chroma .cpf { color: #75715e }
/* Generic */ .chroma .g { }
/* GenericDeleted */ .chroma .gd { color: #f92672 }
/* GenericEmph */ .chroma .ge { font-style: italic }
/* GenericError */ .chroma .gr { }
/* GenericHeading */ .chroma .gh { }
/* GenericInserted */ .chroma .gi { color: #a6e22e }
/* GenericOutput */ .chroma .go { }
/* GenericPrompt */ .chroma .gp { }
/* GenericStrong */ .chroma .gs { font-weight: bold }
/* GenericSubheading */ .chroma .gu { color: #75715e }
/* GenericTraceback */ .chroma .gt { }
/* GenericUnderline */ .chroma .gl { }
/* TextWhitespace */ .chroma .w { }
}