/* 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-quote: #57606a; --color-light-fg-tiny-line: #e0e0e0; --color-light-fg-marker-quote: #bfbfbf; --color-light-fg-font-hyper: #4e403e; --color-light-fg-font-hyper-hover: #469f71; --color-light-fg-hyperlink: #4ca878; --color-light-fg-hyperlink-hover: #2a9436; --color-light-bg-pager-normal: #d4d4d4; --color-light-bg-pager-current: #e4e4e4; --color-light-bg-pager-hover: #ececec; } /* defines dark color */ :root { --color-dark-bg-page: #202124; --color-dark-bg-content: #262628; --color-dark-bg-block: #2b2b2b; --color-dark-bg-shadow: #505050; --color-dark-fg-font-normal: #c2c2b6; --color-dark-fg-font-hover: #d2d2d3; --color-dark-fg-font-quote: #8b8680; --color-dark-fg-tiny-line: #3b3b3b; --color-dark-fg-marker-quote: #6f6b66; --color-dark-fg-font-hyper: #c2c2b6; --color-dark-fg-font-hyper-hover: #62de9e; --color-dark-fg-hyperlink: #62de9e; --color-dark-fg-hyperlink-hover: #3ecb50; --color-dark-bg-pager-normal: #303030; --color-dark-bg-pager-current: #3a3a3e; --color-dark-bg-pager-hover: #444446; } /* :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-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-font-hyper: var(--color-light-fg-font-hyper); --color-fg-font-hyper-hover: var(--color-light-fg-font-hyper-hover); --color-fg-hyperlink: var(--color-light-fg-hyperlink); --color-fg-hyperlink-hover: var(--color-light-fg-hyperlink-hover); --color-bg-pager-normal: var(--color-light-bg-pager-normal); --color-bg-pager-current: var(--color-light-bg-pager-current); --color-bg-pager-hover: var(--color-light-bg-pager-hover); } @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-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-font-hyper: var(--color-dark-fg-font-hyper); --color-fg-font-hyper-hover: var(--color-dark-fg-font-hyper-hover); --color-fg-hyperlink: var(--color-dark-fg-hyperlink); --color-fg-hyperlink-hover: var(--color-dark-fg-hyperlink-hover); --color-bg-pager-normal: var(--color-dark-bg-pager-normal); --color-bg-pager-current: var(--color-dark-bg-pager-current); --color-bg-pager-hover: var(--color-dark-bg-pager-hover); } /*}*/ :root { --fonts-sans-en: "Noto Sans", "Droid Sans", "Calibri", "Arial"; --fonts-sans-zh: "WenQuanYi Zen Hei", "WenQuanYi Micro Hei", "Noto Sans CJK", "Microsoft YaHei", "PingFang SC"; --fonts-sans: var(--fonts-sans-en), var(--fonts-sans-zh), Lato, sans-serif; --fonts-mono-en: "DejaVu Sans Mono", "Noto Sans Mono", "Consolas", "Courier"; --fonts-mono-zh: "Noto Sans Mono CJK", "WenQuanYi Zen Hei Mono", "WenQuanYi Micro Hei Mono"; --fonts-mono: var(--fonts-mono-en), var(--fonts-mono-zh), monospace; --len-0: 0rem; --len-1: 0.25rem; --len-2: 0.5rem; --len-3: 1rem; --len-4: 1.5rem; --len-5: 3rem; --font-size-0: 0.8125rem; --font-size-1: 0.875rem; --font-size-2: 1rem; --font-size-3: 1.125rem; --font-size-4: 1.25rem; --font-size-5: 1.5rem; --font-size-6: 2rem; } *, ::before, ::after { font-family: inherit; box-sizing: border-box; } html { font-family: var(--fonts-sans); font-size: 16px; color: var(--color-fg-font-normal); } /**************************************************************/ /* approximately set up the layout of header, footer and main */ /**************************************************************/ body { display: flex; flex-direction: column; min-height: 100vh; margin: 0; align-items: center; background-color: var(--color-bg-page); } /* set up padding and margin of some main elements */ .main-wrapper { margin-top: var(--len-5); margin-bottom: var(--len-5); } a.external:after { /*edd external icon to external link as :after with unicode symbol*/ /* content: "⮺";*/ } .main-wrapper { display: flex; flex-wrap: wrap; } .main-wrapper > * { height: fit-content; } .main { padding: var(--len-4); } .side { padding-left: var(--len-4); } .main { flex: 0 0 72%; width: 72%; } .side { flex: 0 0 28%; width: 28%; } /* mobile layout: place side to bottom */ @media (max-width: 991px) { .main { padding: var(--len-4); } .side { padding-left: 0; padding-top: var(--len-4); } .main { flex: 0 0 100%; width: 100%; } .side { flex: 0 0 100%; width: 100%; } } /* set light background */ /*.header-wrapper,*/ .footer, .main, .side-recent, .side-categories, .side-tags, .side-calendar, .side-door-status, .side-contact { background-color: var(--color-bg-content); } .side-contact .icon { margin-right: 1em; } /* place header in the center of header-wrapper */ .header-wrapper { display: flex; justify-content: center; } /* let footer stay at bottom of screen */ .footer { margin-top: auto; margin-bottom: 0; } #calendar.loading{ height: 100em; } #calendar .row { display: block; } #calendar .location{ margin-left: 0.25em; cursor: pointer; } #calendar .today{ color: var(--color-dark-fg-font-hyper-hover); } /********** set up break point **********/ .main-wrapper, .header { max-width: 1140px; } @media (max-width: 1199px) { .main-wrapper, .header { max-width: 960px; } } @media (max-width: 991px) { .main-wrapper, .header { max-width: 720px; } } @media (max-width: 767px) { .main-wrapper, .header { max-width: 540px; } } @media (max-width: 575px) { .main-wrapper, .header { max-width: none; } } /* size the element who has breakpoint limitation */ /* .header, .main-wrapper, .main { width: 100vw; } */ /* .header-wrapper, .footer { width: 100vw; } */ .header { /*background-image: url("/img/banner.png");*/ background-image: url("/img/banner/off.jpg"); background-size: cover; background-repeat: no-repeat; background-position-x: center ; background-position-y: top ; } .header-wrapper, .footer { width: 90vw; } .main-wrapper { width: calc(100vw - 2 * var(--len-3)); } /************************/ /* set up header layout */ /************************/ .header { padding: 0 var(--len-3); width: 100%; background-position: center; min-height: 240px; text-shadow: 0px 0px 6px #0d0d0d, 0px 0px 14px #0d0d0d, 0px 0px 14px #0d0d0d; } /* place title and menus horizonally */ .header { display: flex; flex-wrap: wrap; align-content: end; justify-content: space-between; } .header .menu { justify-content: center; align-items: center; } .header .site-title { text-align: center; } @media (max-width: 767px) { .header .site-title { padding-top: var(--len-4); flex: 0 0 100%; } .header .menu { flex-wrap: wrap; flex: 0 0 100%; margin-top: var(--len-3); padding-top: var(--len-3); border-top: 1px solid var(--color-fg-tiny-line); } } /* setup hyper link style */ .header .site-title { text-decoration: none; font-family: var(--fonts-sans); font-size: var(--font-size-3); font-weight: bold; } /********** set up menus layout **********/ /* menus and submenus, hover to display, and setup animation */ .header .menu-item .sub-menu { visibility: hidden; opacity: 0; transition: opacity 0.25s, visibility 0.25s; } .header .menu-item:hover .sub-menu { visibility: visible; opacity: 1; } .header .sub-menu { position: absolute; } /* menu direction */ .header .menu { display: flex; align-items: center; } .header .sub-menu { display: flex; flex-direction: column; align-items: flex-start; } /* set up spacing of menu items in menu and sub-menu */ .header .menu > * { margin-right: var(--len-3); } .header .menu > *:last-child { margin-right: 0; } .header .sub-menu > * { margin-bottom: var(--len-2); } .header .sub-menu > *:last-child { margin-bottom: 0; } /* beautify sub menu style */ .header .sub-menu { background-color: var(--color-bg-content); padding: var(--len-2) var(--len-4); box-shadow: var(--color-bg-shadow) 0px 0px 3px 1px; border-radius: 3px; } /* beautify menu item */ .header .menu-item { font-family: var(--fonts-sans); font-size: var(--font-size-3); font-weight: bold; } .header a { color: var(--color-dark-fg-font-normal); text-decoration: none; } /*always dark since backgroundimage is dark */ .header a:hover { color: var(--color-fg-font-hover); } /************************/ /* set up footer layout */ /************************/ .footer { padding: var(--len-4) 0; font-size: var(--font-size-1); } .footer > * { margin-top: var(--len-2); margin-bottom: var(--len-2); } /* credit, license and social layout */ .footer .footer-row { display: flex; justify-content: center; } .footer .footer-item { margin-right: var(--len-3); margin-left: var(--len-3); } .footer .footer-item:last-child { margin-right: 0; } /* beautify hyper link style */ .footer { color: var(--color-fg-font-normal); } .footer a { color: var(--color-fg-hyperlink); text-decoration: none; } .footer a:hover { color: var(--color-fg-hyperlink-hover); } /**********************************/ /* set up home page's list layout */ /**********************************/ .list-item .tips { display: flex; flex-wrap: wrap; justify-content: start; align-items: flex-start; font-size: var(--font-size-1); color: var(--color-fg-font-quote); } .list-item .tips > * { margin-right: var(--len-3); } .list-item .tips > *:last-child { margin-right: 0; } .list-item .title a { text-decoration: none; color: var(--color-fg-font-normal); } .list-item .title a:hover { color: var(--color-fg-font-hover); } .list-item .tips a { text-decoration: none; color: var(--color-fg-hyperlink); } .list-item .tips a:hover { color: var(--color-fg-hyperlink-hover); } .list-item .title { margin: var(--len-2) 0 var(--len-3) 0; } .list-item .tags > *, .list-item .categories > * { margin: 0 var(--len-1); } .list-item .summary > * { margin: 0; } .list-item .title { margin: 0 0 var(--len-2) 0; } .list-item .tips { margin: 0 0 var(--len-3) 0; } .list-item { border-bottom: 1px solid var(--color-fg-tiny-line); } .list-item:last-child { border-bottom: 0; } .list-item:first-child { padding-top: 0; } .list-item { padding: var(--len-3) 0; } .list-item:last-child { padding-bottom: 0; } /**********************/ /* set up side layout */ /**********************/ .side h2 { margin: 0; } .side ul { list-style: none; margin: 0; padding: 0; } .side li { margin-bottom: var(--len-3); } .side li:last-child { margin-bottom: 0; } .side hr { border: none; height: 1px; background-color: var(--color-bg-content); margin: var(--len-2) 0; } .side > * { padding: var(--len-4); } .side > * { margin-bottom: var(--len-3); } .side > *:last-child { margin-bottom: 0; } .side a { color: var(--color-dark-fg-font-hyper-hover); text-decoration: none; } .side a:hover { color: var(--color-fg-hyperlink); } /* horizontally place tags */ .side .side-tags li { margin: var(--len-1) var(--len-1); } /*****************************/ /* set up single post layout */ /*****************************/ .single { display: flex; flex-direction: column; align-items: center; } .single a { text-decoration: none; color: var(--color-fg-hyperlink); } .single a:hover { color: var(--color-fg-hyperlink-hover); } .single .title, .single .tip, .single .taxonomies, .single .content { width: 100%; } .single .taxonomies { margin-top: var(--len-1); } .single > hr { border: none; background-color: var(--color-fg-tiny-line); height: 1px; width: 90%; margin: var(--len-3) 0; } .single .title, .single .tip, .single .taxonomies { text-align: center; } .single .tip, .single .taxonomies { color: var(--color-fg-font-normal); } .single .taxonomies > * { display: inline-block; } .single .taxonomies > * { margin-right: var(--len-3); } .single .taxonomies > *:last-child { margin-right: 0; } .single .title { margin: var(--len-2) 0 var(--len-3) 0; font-size: var(--font-size-6); } /***** set up content style *****/ .content { line-height: 1.5; } .content code { font-family: var(--fonts-mono); background-color: var(--color-bg-block); padding: 0 2px; border: 1px solid var(--color-fg-tiny-line); border-radius: 2px; line-height: inherit; word-wrap: break-word; } /* keep in style with highlighting */ .content pre { padding: 7px; } .content pre code { display: block; padding: var(--len-3); border: none; background-color: var(--color-bg-block); border-radius: 3px; overflow: auto; width: 100%; } .content blockquote { margin-top: 5px; margin-bottom: 5px; padding-left: 1em; margin-left: 0px; border-left: 3px solid var(--color-fg-marker-quote); color: var(--color-fg-font-quote); } .content hr { border: none; height: 2px; background-color: var(--color-fg-tiny-line); width: 80%; margin: var(--len-2) auto; } .content table { width: 100%; margin: 40px 0; border-collapse: collapse; line-height: 1.5em; } .content th, .content td { text-align: left; padding-right: 20px; vertical-align: top; } .content table td, .content table td { border-spacing: none; border-style: solid; padding: 10px 15px; border-width: 1px 0 0 0; } .content thead th, .content thead th { text-align: left; padding: 10px 15px; height: 20px; font-weight: bold; color: #444; cursor: default; white-space: nowrap; border: 1px solid #dadadc; } .content tr > td { border: 1px solid #dadadc; } .content tr:nth-child(odd) > td { background: #fcfcfc; } .content h1, .content h2, .content h3 { font-weight: bold; } .content p, .content pre { word-break: normal; overflow-wrap: anywhere; } .content img { max-width: 92%; display: block; margin-left: auto; margin-right: auto; } .content .anchor { visibility: hidden; } .content h1:hover a, .content h2:hover a, .content h3:hover a, .content h4:hover a { visibility: visible; } .highlight pre { padding: 7px; overflow-x: auto; } .highlight { max-width: 100%; overflow-x: auto; } /**************************/ /* setup list page layout */ /**************************/ #archive { padding-left: var(--len-3); display: none; } #archive .group { margin: var(--len-4) auto; } #archive .group .key { font-size: var(--font-size-4); margin-bottom: var(--len-2); } #archive .group .value { display: block; font-size: var(--font-size-2); margin-bottom: 12px; } #archive .group .value { text-indent: -60px; padding-left: 60px; } #archive .group .value * { text-indent: 0; } #archive .group .value .date { display: inline-block; width: 60px; } #archive .group .value .title { display: inline; } #archive .group .value .date { color: var(--color-fg-font-normal); } #archive .group .value a { text-decoration: none; } #archive .group .value a { color: var(--color-fg-font-hyper); } #archive .group .value a:hover { color: var(--color-fg-font-hyper-hover); } #archive .group .value .tags { display: inline-block; margin-left: 7px; } #archive .group .value .tags { background: var(--color-bg-block); border-radius: 2px; padding: 4px 7px; font-size: var(--font-size-1); margin-right: 3px; } /**********************/ /* setup terms layout */ /**********************/ #tags { max-width: 700px; margin: 48px auto 0 auto; padding: 0 12px; text-align: center; } #tags .tag { display: inline-block; margin: 7px 7px; } @media (max-width: 700px) { #tags { margin: 0 auto 0 auto; } #tags .tag { display: inline-block; margin: 4px 5px; } } #tags .tag a { background: #f2f2f2; padding: 4px 7px; color: #757575; color: #404040; font-size: 14px; margin-right: 3px; } #tags .tag a:hover { color: #0366d6; } /***************************/ /* setup pagination layout */ /***************************/ .pagination { width: 100%; text-align: center; padding-top: var(--len-5); } .pagination a { display: inline-block; font-size: var(--font-size-2); border-radius: var(--len-5); width: var(--len-5); height: var(--len-5); line-height: var(--len-5); text-align: center; vertical-align: middle; text-decoration: none; color: var(--color-fg-font-normal); background-color: var(--color-bg-pager-normal); transition: background-color 0.25s; } .pagination a:hover { background-color: var(--color-bg-pager-hover); } .pagination a.current { background-color: var(--color-bg-pager-current); pointer-events: none; color: var(--color-fg-font-normal); cursor: default; } /***************************/ /* setup commenting layout */ /***************************/ .commenting { width: 85%; } /* keep content style from being affected by remark42 style */ .content pre { background-color: transparent; color: var(--color-fg-font-normal); } /**********/ /** misc **/ /**********/ .archive-hint { padding-left: var(--len-4); color: var(--color-fg-font-quote); } .max-wrapper { width: 100%; height: 100%; padding: 0; margin: 0; } #ds-img { /* make image fit in div */ width: 50%; } .content p img[src$="#left"] { float: left; margin: 0 var(--len-3) var(--len-3) 0; } .content p img[src$="#right"] { float: right; margin: 0 var(--len-3) var(--len-3) 0; } .content p img[src$="#right_sa"] { margin: 0 0 0 auto ; } .content p img[src$="#left_sa"] { margin: 0 auto 0 0 ; }