html {
    overflow-x: initial !important;
}

:root {
    --bg-color: #ffffff;
    --text-color: #333333;
    --select-text-bg-color: #B5D6FC;
    --select-text-font-color: auto;
    --monospace: "Lucida Console", Consolas, "Courier", monospace;
}

html {
    font-size: 14px;
    background-color: var(--bg-color);
    color: var(--text-color);
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}

body {
    margin: 0px;
    padding: 0px;
    height: auto;
    bottom: 0px;
    top: 0px;
    left: 0px;
    right: 0px;
    font-size: 1rem;
    line-height: 1.42857;
    overflow-x: hidden;
    background: inherit;
}

iframe {
    margin: auto;
}

a.url {
    word-break: break-all;
}

a:active, a:hover {
    outline: 0px;
}

.in-text-selection, ::selection {
    text-shadow: none;
    background: var(--select-text-bg-color);
    color: var(--select-text-font-color);
}

#write {
    margin: 0px auto;
    height: auto;
    width: inherit;
    word-break: normal;
    word-wrap: break-word;
    position: relative;
    white-space: normal;
    padding-bottom: 70px;
    overflow-x: visible;
}

.first-line-indent #write div, .first-line-indent #write li, .first-line-indent #write p {
    text-indent: 2em;
}

.first-line-indent #write div :not(p):not(div), .first-line-indent #write div.md-htmlblock-container, .first-line-indent #write p *, .first-line-indent pre {
    text-indent: 0px;
}

.for-image #write {
    padding-left: 8px;
    padding-right: 8px;
}

body.typora-export {
    padding-left: 30px;
    padding-right: 30px;
}

@media screen and (max-width: 500px) {
    body.typora-export {
        padding-left: 0px;
        padding-right: 0px;
    }
}

#write > blockquote:first-child, #write > div:first-child, #write > figure:first-child, #write > ol:first-child, #write > p:first-child, #write > pre:first-child, #write > ul:first-child {
    margin-top: 30px;
}

#write li > figure:first-child {
    margin-top: -20px;
}

#write ol, #write ul {
    position: relative;
}

img {
    max-width: 100%;
    vertical-align: middle;
}

button, input, select, textarea {
    color: inherit;
    font-style: inherit;
    font-variant: inherit;
    font-weight: inherit;
    font-stretch: inherit;
    font-size: inherit;
    line-height: inherit;
    font-family: inherit;
}

input[type="checkbox"], input[type="radio"] {
    line-height: normal;
    padding: 0px;
}

*, ::after, ::before {
    box-sizing: border-box;
}

#write h1, #write h2, #write h3, #write h4, #write h5, #write h6, #write p, #write pre {
    width: inherit;
}

#write h1, #write h2, #write h3, #write h4, #write h5, #write h6, #write p {
    position: relative;
}

h1, h2, h3, h4, h5, h6 {
    break-after: avoid-page;
    break-inside: avoid;
    orphans: 2;
}

p {
    orphans: 4;
}

h1 {
    font-size: 2rem;
}

h2 {
    font-size: 1.8rem;
}

h3 {
    font-size: 1.6rem;
}

h4 {
    font-size: 1.4rem;
}

h5 {
    font-size: 1.2rem;
}

h6 {
    font-size: 1rem;
}

.md-math-block, .md-rawblock, h1, h2, h3, h4, h5, h6, p {
    margin-top: 1rem;
    margin-bottom: 1rem;
}

.hidden {
    display: none;
}

.md-blockmeta {
    color: rgb(204, 204, 204);
    font-weight: 700;
    font-style: italic;
}

a {
    cursor: pointer;
}

sup.md-footnote {
    padding: 2px 4px;
    background-color: rgba(238, 238, 238, 0.7);
    color: rgb(85, 85, 85);
    border-radius: 4px;
    cursor: pointer;
}

sup.md-footnote a, sup.md-footnote a:hover {
    color: inherit;
    text-transform: inherit;
    text-decoration: inherit;
}

#write input[type="checkbox"] {
    cursor: pointer;
    width: inherit;
    height: inherit;
}

figure {
    overflow-x: auto;
    margin: 1.2em 0px;
    max-width: calc(100% + 16px);
    padding: 0px;
}

figure > table {
    margin: 0px !important;
}

tr {
    break-inside: avoid;
    break-after: auto;
}

thead {
    display: table-header-group;
}

table {
    border-collapse: collapse;
    border-spacing: 0px;
    width: 100%;
    overflow: auto;
    break-inside: auto;
    text-align: left;
}

table.md-table td {
    min-width: 80px;
}

#blogTitle h1 {
    font-size: 150%;
    font-weight: bold;
    line-height: 1.5;
    margin: 10px 20px;
    /* margin-top: 10px; */
    height: 30px;
    float: left;
}

#blogTitle h2 {
    margin-left: 4em;
    line-height: 1.5;
    width: 50%;
    float: left;
    height: 36px;
    padding: 0px;
    margin: 0px 100px;
    font-size: 16px;
}

div.hr:focus {
    cursor: none;
}

#write pre {
    white-space: pre-wrap;
}

#write.fences-no-line-wrapping pre {
    white-space: pre;
}

#write pre.ty-contain-cm {
    white-space: normal;
}

.md-fences {
    font-size: 0.9rem;
    display: block;
    break-inside: avoid;
    text-align: left;
    overflow: visible;
    white-space: pre;
    background: inherit;
    position: relative !important;
}

.md-diagram-panel {
    width: 100%;
    margin-top: 10px;
    text-align: center;
    padding-top: 0px;
    padding-bottom: 8px;
    overflow-x: auto;
}

#write .md-fences.mock-cm {
    white-space: pre-wrap;
}

.md-fences.md-fences-with-lineno {
    padding-left: 0px;
}

#write.fences-no-line-wrapping .md-fences.mock-cm {
    white-space: pre;
    overflow-x: auto;
}

.md-fences.mock-cm.md-fences-with-lineno {
    padding-left: 8px;
}

.footnotes {
    opacity: 0.8;
    font-size: 0.9rem;
    margin-top: 1em;
    margin-bottom: 1em;
}

.footnotes + .footnotes {
    margin-top: 0px;
}

.md-reset {
    margin: 0px;
    padding: 0px;
    border: 0px;
    outline: 0px;
    vertical-align: top;
    background: 0px 0px;
    text-decoration: none;
    text-shadow: none;
    float: none;
    position: static;
    width: auto;
    height: auto;
    white-space: nowrap;
    cursor: inherit;
    -webkit-tap-highlight-color: transparent;
    line-height: normal;
    font-weight: 400;
    text-align: left;
    box-sizing: content-box;
    direction: ltr;
}

li div {
    padding-top: 0px;
}

blockquote {
    margin: 1rem 0px;
}

li .mathjax-block, li p {
    margin: 0.5rem 0px;
}

li {
    margin: 0px;
    position: relative;
}

blockquote > :last-child {
    margin-bottom: 0px;
}

blockquote > :first-child, li > :first-child {
    margin-top: 0px;
}

.footnotes-area {
    color: rgb(136, 136, 136);
    margin-top: 0.714rem;
    padding-bottom: 0.143rem;
    white-space: normal;
}

#write .footnote-line {
    white-space: pre-wrap;
}

@media print {
    body, html {
        border: 1px solid transparent;
        height: 99%;
        break-after: avoid;
        break-before: avoid;
    }

    #write {
        margin-top: 0px;
        border-color: transparent !important;
    }

    html.blink-to-pdf {
        font-size: 13px;
    }

    @page {
        margin: 20mm 0px;
    }
}

.footnote-line {
    margin-top: 0.714em;
    font-size: 0.7em;
}

a img, img a {
    cursor: pointer;
}

pre.md-meta-block {
    font-size: 0.8rem;
    min-height: 0.8rem;
    white-space: pre-wrap;
    background: rgb(204, 204, 204);
    display: block;
    overflow-x: hidden;
}

p > img:only-child {
    display: block;
    margin: auto;
}

p > .md-image:only-child {
    display: inline-block;
    width: 100%;
    text-align: center;
}

#write .MathJax_Display {
    margin: 0.8em 0px 0px;
}

.md-math-block {
    width: 100%;
}

.md-math-block:not(:empty)::after {
    display: none;
}

[contenteditable="true"]:active, [contenteditable="true"]:focus {
    outline: 0px;
    box-shadow: none;
}

.md-task-list-item {
    position: relative;
    list-style-type: none;
}

.task-list-item.md-task-list-item {
    padding-left: 0px;
}

.md-task-list-item > input {
    position: absolute;
    top: 0px;
    left: 0px;
    margin-left: -1.2em;
    margin-top: calc(1em - 10px);
}

.math {
    font-size: 1rem;
}

.md-toc {
    min-height: 3.58rem;
    position: relative;
    font-size: 0.9rem;
    border-radius: 10px;
}

.md-toc-content {
    position: relative;
    margin-left: 0px;
}

.md-toc-content::after, .md-toc::after {
    display: none;
}

.md-toc-item {
    display: block;
    color: rgb(65, 131, 196);
}

.md-toc-item a {
    text-decoration: none;
}

.md-toc-inner:hover {
}

.md-toc-inner {
    display: inline-block;
    cursor: pointer;
}

.md-toc-h1 .md-toc-inner {
    margin-left: 0px;
    font-weight: 700;
}

.md-toc-h2 .md-toc-inner {
    margin-left: 2em;
}

.md-toc-h3 .md-toc-inner {
    margin-left: 4em;
}

.md-toc-h4 .md-toc-inner {
    margin-left: 6em;
}

.md-toc-h5 .md-toc-inner {
    margin-left: 8em;
}

.md-toc-h6 .md-toc-inner {
    margin-left: 10em;
}

@media screen and (max-width: 48em) {
    .md-toc-h3 .md-toc-inner {
        margin-left: 3.5em;
    }

    .md-toc-h4 .md-toc-inner {
        margin-left: 5em;
    }

    .md-toc-h5 .md-toc-inner {
        margin-left: 6.5em;
    }

    .md-toc-h6 .md-toc-inner {
        margin-left: 8em;
    }
}

a.md-toc-inner {
    font-size: inherit;
    font-style: inherit;
    font-weight: inherit;
    line-height: inherit;
}

.footnote-line a:not(.reversefootnote) {
    color: inherit;
}

.md-attr {
    display: none;
}

.md-fn-count::after {
    content: ".";
}

code, pre, samp, tt {
    font-family: var(--monospace);
}

kbd {
    margin: 0px 0.1em;
    padding: 0.1em 0.6em;
    font-size: 0.8em;
    color: rgb(36, 39, 41);
    background: rgb(255, 255, 255);
    border: 1px solid rgb(173, 179, 185);
    border-radius: 3px;
    box-shadow: rgba(12, 13, 14, 0.2) 0px 1px 0px, rgb(255, 255, 255) 0px 0px 0px 2px inset;
    white-space: nowrap;
    vertical-align: middle;
}

.md-comment {
    color: rgb(162, 127, 3);
    opacity: 0.8;
    font-family: var(--monospace);
}

code {
    text-align: left;
}

a.md-print-anchor {
    white-space: pre !important;
    border-width: initial !important;
    border-style: none !important;
    border-color: initial !important;
    display: inline-block !important;
    position: absolute !important;
    width: 1px !important;
    right: 0px !important;
    outline: 0px !important;
    background: 0px 0px !important;
    text-decoration: initial !important;
    text-shadow: initial !important;
}

.md-inline-math .MathJax_SVG .noError {
    display: none !important;
}

.md-math-block .MathJax_SVG_Display {
    text-align: center;
    margin: 0px;
    position: relative;
    text-indent: 0px;
    max-width: none;
    max-height: none;
    min-height: 0px;
    min-width: 100%;
    width: auto;
    overflow-y: hidden;
    display: block !important;
}

.MathJax_SVG_Display, .md-inline-math .MathJax_SVG_Display {
    width: auto;
    margin: inherit;
    display: inline-block !important;
}

.MathJax_SVG .MJX-monospace {
    font-family: var(--monospace);
}

.MathJax_SVG .MJX-sans-serif {
    font-family: sans-serif;
}

.MathJax_SVG {
    display: inline;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    zoom: 90%;
    text-indent: 0px;
    text-align: left;
    text-transform: none;
    letter-spacing: normal;
    word-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    float: none;
    direction: ltr;
    max-width: none;
    max-height: none;
    min-width: 0px;
    min-height: 0px;
    border: 0px;
    padding: 0px;
    margin: 0px;
}

.MathJax_SVG * {
    transition: none;
}

.os-windows.monocolor-emoji .md-emoji {
    font-family: "Segoe UI Symbol", sans-serif;
}

.md-diagram-panel > svg {
    max-width: 100%;
}

[lang="mermaid"] svg, [lang="flow"] svg {
    max-width: 100%;
}

[lang="mermaid"] .node text {
    font-size: 1rem;
}

table tr th {
    border-bottom: 0px;
}

video {
    max-width: 100%;
    display: block;
    margin: 0px auto;
}

iframe {
    max-width: 100%;
    width: 100%;
    border: none;
}

.highlight td, .highlight tr {
    border: 0px;
}

#navigator {
    background-color: #36648a;
    height: 60px;
    line-height: 60px;
    overflow: hidden;
    clear: both;
}

.catListEssay ul li a, .catListLink ul li a, .catListNoteBook ul li a, .catListTag ul li a, .catListPostCategory ul li a, .catListPostArchive ul li a, .catListImageCategory ul li a, .catListArticleArchive ul li a, .catListView ul li a, .catListFeedback ul li a, .catListComment ul li a, .catListBlogRank ul li a, .catList ul li a .catListArticleCategory ul li a {
    text-indent: 1em;
    font-size: 16px;
}

#navList a:link, #navList a:visited, #navList a:active {
    color: #fff;
}

.cm-negative {
    color: rgb(221, 68, 68);
}

.cm-positive {
    color: rgb(34, 153, 34);
}

.cm-header, .cm-strong {
    font-weight: 700;
}

.cm-del {
    text-decoration: line-through;
}

.cm-em {
    font-style: italic;
}

.cm-link {
    text-decoration: underline;
}

.cm-error {
    color: red;
}

.cm-invalidchar {
    color: red;
}

.cm-constant {
    color: rgb(38, 139, 210);
}

.cm-defined {
    color: rgb(181, 137, 0);
}

.cm-searching {
    background: rgba(255, 255, 0, 0.4);
}

@media print {
    .CodeMirror div.CodeMirror-cursor {
        visibility: hidden;
    }
}

@font-face {
    font-family: "Source Han Sans SC";
    font-weight: normal;
    src: local("Source Han Sans SC Regular"), url("catfish/SourceHanSansSC-Regular.otf");
}

@font-face {
    font-family: "Source Han Sans";
    font-weight: bold;
    src: local("Source Han Sans SC Bold"), url("catfish/SourceHanSansSC-Bold.otf");
}

@font-face {
    font-family: "Source Han Serif";
    font-weight: normal;
    src: local("Source Han Serif SC Regular"), url("catfish/SourceHanSerifSC-Regular.otf");
}

@font-face {
    font-family: "Source Han Serif";
    font-weight: bold;
    src: local("Source Han Serif SC Bold"), url("catfish/SourceHanSerifSC-Bold.otf");
}

@font-face {
    font-family: mononoki;
    font-style: normal;
    font-weight: normal;
    src: local("mononoki Regular"), url("catfish/mononoki-Regular.woff");
}

@font-face {
    font-family: mononoki;
    font-style: italic;
    font-weight: normal;
    src: local("mononoki Italic"), url("catfish/mononoki-Italic.woff");
}

@font-face {
    font-family: mononoki;
    font-style: normal;
    font-weight: bold;
    src: local("mononoki Bold"), url("catfish/mononoki-Bold.woff");
}

@font-face {
    font-family: mononoki;
    font-style: italic;
    font-weight: bold;
    src: local("mononoki Bold Italic"), url("catfish/mononoki-BoldItalic.woff");
}

@font-face {
    font-family: STXihei;
    font-style: normal;
    font-weight: normal;
    src: local("STXihei"), url("catfish/STXihei.otf");
}

html {
    font-size: 16px;
}

body {
    background: rgb(255, 255, 255);
    font-family: STXihei, "Source Han Sans SC", sans-serif;
    color: rgb(85, 85, 85);
}

#write {
    max-width: 60em;
}

h1, h2, h3, h4, h5, h6 {
    position: relative;
    margin-top: 1em;
    margin-bottom: 1em;
    font-weight: bold;
    line-height: 1.4em;
}

h1 {
    font-size: 2em;
    line-height: 1.2em;
}

h2 {
    font-size: 1.5em;
    line-height: 1.225em;
}

h3 {
    font-size: 1.3em;
    line-height: 1.43em;
}

h4 {
    font-size: 1.2em;
}

h5 {
    font-size: 1em;
}

h6 {
    font-size: 1em;
    color: rgb(153, 153, 153);
}

#cnblogs_post_body h1 {
    font-size: 23px;
    font-weight: bold;
    line-height: 1.5;
    margin: 10px 0
}

#cnblogs_post_body h2 {
    font-size: 22px;
    font-weight: bold;
    line-height: 1.5;
    margin: 10px 0
}

#cnblogs_post_body h3 {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.5;
    margin: 10px 0
}

#cnblogs_post_body h4 {
    font-size: 19px;
    font-weight: bold;
    margin: 10px 0
}

#cnblogs_post_body h5 {
    font-size: 18px;
    font-weight: bold;
    margin: 10px 0
}

#cnblogs_post_body h6 {
    font-size: 17px;
    font-weight: bold;
    margin: 10px 0
}
hr {
    border: 1px solid rgb(221, 221, 221);
}

a {
    text-decoration: none;
    color: rgb(37, 143, 184);
}

a:hover, a:active {
    text-decoration: underline;
}

ul, ol {
    padding-left: 2em;
}

.task-list {
    padding-left: 2em;
}

.task-list-item {
    padding-left: 1.6em;
}

.task-list-item input {
    top: 3px;
    left: 8px;
}

table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0px;
}

table th {
    font-weight: bold;
    border: 1px solid rgb(221, 221, 221);
    padding-bottom: 0.5em;
}

table td {
    border: 1px solid rgb(221, 221, 221);
    padding: 10px 0px;
}

blockquote {
    border-left: 5px solid rgb(221, 221, 221);
    padding-left: 0.5em;
    font-family: "Source Han Serif SC", serif;
    color: rgb(85, 85, 85);
}

blockquote blockquote {
    padding-right: 0px;
}

.md-fences, code, tt {
    margin: 0px 0.3em;
    padding: 0px 0.3em;
    background: rgb(238, 238, 238);
    font-family: "Courier New", monospace, Mononoki;
    /*text-shadow: rgb(255, 255, 255) 0px 1px;*/
    font-size: 16px;
}

.md-fences {
    margin: 15px auto;
    padding: 0.7em 1em;
    text-shadow: none;
}

.cm-s-inner {
    background-color: rgb(38, 50, 56);
    color: rgb(233, 237, 237);
}

.cnblogs-markdown .hljs, .cnblogs-post-body .hljs {
    display: block;
    overflow-x: auto;
    padding: .5em;
    background: #000000;
    color: rgba(255, 255, 255, 255)
}

.cnblogs-markdown code, .cnblogs-post-body code {
    background-color: #000000 !important;
    border: 1px solid #ccc !important;
    border-radius: 6px !important;
    vertical-align: middle;
    color: #ffffff
}

.cnblogs-markdown .hljs, .cnblogs-post-body .hljs {
    font-family: "Courier New", sans-serif !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
    padding: 5px !important;
}

#cnblogs_post_body img {
    max-width: 100%;
}

.md-fences, code, tt {
    margin: 0px 0.3em;
    padding: 0px 0.3em;
    background: rgb(238, 238, 238);
    font-family: "Courier New", monospace, Mononoki;
    /* text-shadow: rgb(255, 255, 255) 0px 1px; */
    font-size: 16px;
}

.md-fences {
    background-color: rgb(38, 50, 56);
    color: rgb(233, 237, 237);
    border: none;
}

.md-fences .code-tooltip {
    background-color: rgb(38, 50, 56);
}

.md-fences {
    background-color: rgb(38, 50, 56);
    color: rgb(233, 237, 237);
    border: none;
}

.md-fences .code-tooltip {
    background-color: rgb(38, 50, 56);
}

#write pre.md-meta-block {
    padding: 1em;
    background-color: rgb(255, 255, 255);
    border-bottom: 1px dashed rgb(221, 221, 221);
    color: rgb(128, 203, 196);
    margin-top: 0px !important;
}

.md-image > .md-meta {
    color: inherit;
}

header, .context-menu, .megamenu-content, footer {
    font-family: "Source Han Sans SC", sans-serif;
}

@media print {
    html {
        font-size: 13px;
    }

    table, pre {
        break-inside: avoid;
    }

    pre {
        word-wrap: break-word;
    }
}

header, .context-menu, .megamenu-content, footer {
    font-family: "Helvetica Neue", Helvetica, "Segoe UI", Arial, sans-serif;
}

.md-diagram-panel-preview {
    color: rgb(38, 50, 56);
}

.cm-s-inner {
    background-color: rgb(38, 50, 56);
    color: rgb(233, 237, 237);
}

.hljs-keyword, .hljs-selector-tag, .hljs-built_in, .hljs-name, .hljs-tag {
    color: #00fdff;
}

.hljs-string, .hljs-title, .hljs-section, .hljs-attribute, .hljs-literal, .hljs-template-tag, .hljs-template-variable, .hljs-type, .hljs-addition {
    color: #ffffff;
}

.hljs-keyword {
    color: rgb(0, 255, 255);
}

.hljs-operator {
    color: rgb(238, 130, 238);
}

.hljs-variable-2 {
    color: rgb(128, 203, 196);
}

.hljs-variable-3 {
    color: rgb(130, 177, 255);
}

.hljs-builtin {
    color: rgb(222, 203, 107);
}

.hljs-builtin {
    color: rgb(255, 0, 0);
}

.hljs-atom {
    color: rgb(247, 118, 105);
}

.hljs-number {
    color: rgb(255, 0, 255);
}

.hljs-def {
    color: rgb(255, 255, 255);
}

.hljs-string {
    color: rgb(255, 255, 0);
}

.hljs-string-2 {
    color: rgb(255, 255, 0);
}

.hljs-comment {
    color: rgb(62, 255, 0);
}

.hljs-variable {
    color: rgb(130, 177, 255);
}

.hljs-variable-3 {
    color: rgb(255, 255, 255);
}

.hljs-tag {
    color: rgb(128, 203, 196);
}

.hljs-meta {
    color: rgb(128, 203, 196);
}

.hljs-attribute {
    color: rgb(255, 255, 255);
}

.hljs-property {
    color: rgb(255, 255, 255);
}

.hljs-qualifier {
    color: rgb(255, 255, 255);
}

.hljs-tag {
    color: rgb(255, 255, 255);
}

.hljs-error {
    color: rgb(255, 255, 255);
    background-color: rgb(236, 95, 103);
}

.hljs-title {
    color: rgb(255, 255, 255);
}

.md-fences {
    background-color: rgb(38, 50, 56);
    color: rgb(233, 237, 237);
    border: none;
}

.md-fences .code-tooltip {
    background-color: rgb(38, 50, 56);
}

img {
    border: 1px dashed black;
}