:root {
    --color-theme: #007aff;
    --color-theme-light: #007aff;
    --color-theme-9: #1f8bff;
    --color-theme-9-light: #1f8bff;
    --color-theme-8: #3d9bff;
    --color-theme-8-light: #3d9bff;
    --color-theme-7: #59a9ff;
    --color-theme-7-light: #59a9ff;
    --color-theme-6: #74b7ff;
    --color-theme-6-light: #74b7ff;
    --color-theme-5: #92c7ff;
    --color-theme-5-light: #92c7ff;
    --color-theme-4: #b9ddff;
    --color-theme-4-light: #b9ddff;
    --color-theme-3: #cee7ff;
    --color-theme-3-light: #cee7ff;
    --color-theme-2: #dff0ff;
    --color-theme-2-light: #dff0ff;
    --color-theme-1: #eef7ff;
    --color-theme-1-light: #eef7ff;
    --color-theme-0: #f6fbff;
    --color-theme-0-light: #f6fbff;

    --color-text: #444444;
    --color-text-light: #444444;
    --color-text-9: #666666;
    --color-text-9-light: #666666;
    --color-text-8: #888888;
    --color-text-8-light: #888888;
    --color-text-7: #aaaaaa;
    --color-text-7-light: #aaaaaa;
    --color-text-6: #9b9b9b;
    --color-text-6-light: #9b9b9b;
    --color-text-5: #acacac;
    --color-text-5-light: #acacac;
    --color-text-4: #bebebe;
    --color-text-4-light: #bebebe;
    --color-text-3: #cfcfcf;
    --color-text-3-light: #cfcfcf;
    --color-text-2: #dbdbdb;
    --color-text-2-light: #dbdbdb;
    --color-text-1: #ebebeb;
    --color-text-1-light: #ebebeb;
    --color-text-0: #f5f5f5;
    --color-text-0-light: #f5f5f5;
    --color-white: #ffffff;
    --color-white-light: #ffffff;

    --size-radius: 8px;
    --size-texts: 14px;
    --size-aside: 280px;
    --height-logo: 30px;
    --ratio-image: 56%;

    --shadow-minify: 0 2px 2px rgba(150, 150, 150, .1);
    --shadow-box: 0 0 5px rgba(150, 150, 150, .2);
}

html.dark {
    --color-theme-light: #166dc9;
    --color-theme-0-light: #222222;
    --color-theme-1-light: #444444;
    --color-theme-2-light: #555555;
    --color-theme-3-light: #666666;

    --color-text-9-light: #555555;
    --color-text-8-light: #555555;
    --color-text-7-light: #555555;
    --color-text-6-light: #555555;
    --color-text-5-light: #555555;
    --color-text-4-light: #444444;
    --color-text-3-light: #444444;
    --color-text-2-light: #444444;
    --color-text-1-light: #444444;
    --color-text-0-light: #444444;

    --color-white-light: #333333;

    --color-text-light: #999999;

    --shadow-minify: 0 .125em .25em rgba(0, 0, 0, .25);
    --shadow-box: 0 0 .5em rgba(0, 0, 0, .5);
}

/*
** 滚动条
*/
::-webkit-scrollbar-track {
    box-shadow: inset 1px 1px 2px rgba(0, 0, 0, 0.1);
    background-color: #f5f5f5;
    border-radius: 0;
}

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-thumb {
    background-color: #a6b3c2;
    border-radius: 5px;
}

/*
** 公用
*/
body {
    font-size: var(--size-texts);
    background-color: var(--color-theme-0-light);
    padding-top: calc(var(--height-logo) + 1em * 2);
}

body,
a {
    color: var(--color-text-light);
}

.color-theme,
.color-theme a,
a:hover {
    color: var(--color-theme-light);
}

img {
    border-radius: 5px;
    transition: all .4s;
}

kbd {
    padding: .25em .5em !important;
}

.icon-simply {
    font-size: 1em;
}

.container {
    max-width: 1220px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1em;
    padding-right: 1em;
}

.frame-container {
    margin-top: 1em;
}

.frame-main {
    flex: 1;
    margin-right: 1em;
    width: calc(100% - var(--size-aside) - 1em);
}

.frame-aside {
    margin-top: 1em;
    width: var(--size-aside);
}

.box {
    overflow: hidden;
    margin-top: 1em;
    padding: 1em;
    background-color: var(--color-white-light);
    border-radius: var(--size-radius);
    box-shadow: var(--shadow-box);
}

.disabled {
    opacity: .5;
    cursor: no-drop;
}

.badge,
a.badge,
.dashed,
a.dashed,
kbd {
    line-height: 1;
    padding: 3px 4px;
    border-radius: 3px;
}

.badge,
a.badge,
kbd {
    background-color: var(--color-theme-light);
    color: var(--color-white);
}

.dashed,
a.dashed {
    border: 1px solid var(--color-theme-light);
    color: var(--color-theme-light);
}

.fieldset {
    padding: 0;
    border: 1px solid var(--color-text-1-light);
    border-radius: 3px;
}

.fieldset > legend {
    margin-left: 20px;
    padding: 0 10px;
    letter-spacing: 2px;
}

.fieldset > .content {
    margin: 1em;
    margin-top: 0;
    overflow: hidden;
}

/*
** author
*/
.user-info {
    line-height: 1.2;
}

.user-info > .user-meta {
    flex: 1;
}

.user-info .avatar + .user-meta {
    margin-left: .5em;
}

.user-info .user-meta .other {
    margin-top: 5px;
    opacity: .7;
}

.avatar {
    display: inline-block;
    width: 36px;
    height: 36px;
    border-radius: 100%;
    border: 2px solid var(--color-theme-3)
}

.avatar > img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0;
}

.divider-vertical {
    margin-left: 1em;
    margin-right: 1em;
    padding-left: 1em;
    padding-right: 1em;
    height: 22px;
    line-height: 22px;
    border-left: 1px solid var(--color-text-1-light);
    border-right: 1px solid var(--color-text-1-light);
}

.divider-vertical + .divider-vertical {
    margin-left: 0;
    padding-left: 0;
    border-left: 0;
}

.divider-vertical + .divider-vertical:last-child {
    margin-right: 0;
    padding-right: 0;
    border-right: 0;
}

.tags .tag:not(:first-child) {
    margin-left: 10px;
}

.empty-box {
    min-height: 100px;
    max-height: 200px;
    font-size: 1.5em;
    opacity: .5;
}

kbd,
.badge,
.ago,
.article-list .infomation .meta,
.aside-new-list > .item .value,
.aside-hot-list .item .percent-image .infos,
.comment-item > .item-right .info,
footer {
    font-size: .875em;
}

.overflow-hidden,
.avatar,
.swiper {
    overflow: hidden;
}

.clipboard {
    cursor: pointer;
}

/*
** 内边距
*/
.pl-auto, .px-auto, .p-auto {
    padding-left: auto !important;
}

.pr-auto, .px-auto, .p-auto {
    padding-right: auto !important;
}

.pl-0, .px-0, .p-0 {
    padding-left: 0 !important;
}

.pr-0, .px-0, .p-0 {
    padding-right: 0 !important;
}

.pt-0, .py-0, .p-0 {
    padding-top: 0 !important;
}

.pb-0, .py-0, .p-0 {
    padding-bottom: 0 !important;
}

.pl-1, .px-1, .p-1 {
    padding-left: 1px !important;
}

.pr-1, .px-1, .p-1 {
    padding-right: 1px !important;
}

.pt-1, .py-1, .p-1 {
    padding-top: 1px !important;
}

.pb-1, .py-1, .p-1 {
    padding-bottom: 1px !important;
}

.pl-2, .px-2, .p-2 {
    padding-left: 2px !important;
}

.pr-2, .px-2, .p-2 {
    padding-right: 2px !important;
}

.pt-2, .py-2, .p-2 {
    padding-top: 2px !important;
}

.pb-2, .py-2, .p-2 {
    padding-bottom: 2px !important;
}

.pl-3, .px-3, .p-3 {
    padding-left: 3px !important;
}

.pr-3, .px-3, .p-3 {
    padding-right: 3px !important;
}

.pt-3, .py-3, .p-3 {
    padding-top: 3px !important;
}

.pb-3, .py-3, .p-3 {
    padding-bottom: 3px !important;
}

.pl-4, .px-4, .p-4 {
    padding-left: 4px !important;
}

.pr-4, .px-4, .p-4 {
    padding-right: 4px !important;
}

.pt-4, .py-4, .p-4 {
    padding-top: 4px !important;
}

.pb-4, .py-4, .p-4 {
    padding-bottom: 4px !important;
}

.pl-5, .px-5, .p-5 {
    padding-left: 5px !important;
}

.pr-5, .px-5, .p-5 {
    padding-right: 5px !important;
}

.pt-5, .py-5, .p-5 {
    padding-top: 5px !important;
}

.pb-5, .py-5, .p-5 {
    padding-bottom: 5px !important;
}

.pl-10, .px-10, .p-10 {
    padding-left: 10px !important;
}

.pr-10, .px-10, .p-10 {
    padding-right: 10px !important;
}

.pt-10, .py-10, .p-10 {
    padding-top: 10px !important;
}

.pb-10, .py-10, .p-10 {
    padding-bottom: 10px !important;
}

.pl-1em, .px-1em, .p-1em {
    padding-left: 1em !important;
}

.pr-1em, .px-1em, .p-1em {
    padding-right: 1em !important;
}

.pt-1em, .py-1em, .p-1em {
    padding-top: 1em !important;
}

.pb-1em, .py-1em, .p-1em {
    padding-bottom: 1em !important;
}

.pl-2em, .px-2em, .p-2em {
    padding-left: 2em !important;
}

.pr-2em, .px-2em, .p-2em {
    padding-right: 2em !important;
}

.pt-2em, .py-2em, .p-2em {
    padding-top: 2em !important;
}

.pb-2em, .py-2em, .p-2em {
    padding-bottom: 2em !important;
}

/*
** 外边距
*/
.ml-auto, .mx-auto, .m-auto {
    margin-left: auto !important;
}

.mr-auto, .mx-auto, .m-auto {
    margin-right: auto !important;
}

.ml-0, .mx-0, .m-0 {
    margin-left: 0 !important;
}

.mr-0, .mx-0, .m-0 {
    margin-right: 0 !important;
}

.mt-0, .my-0, .m-0 {
    margin-top: 0 !important;
}

.mb-0, .my-0, .m-0 {
    margin-bottom: 0 !important;
}

.ml-1, .mx-1, .m-1 {
    margin-left: 1px !important;
}

.mr-1, .mx-1, .m-1 {
    margin-right: 1px !important;
}

.mt-1, .my-1, .m-1 {
    margin-top: 1px !important;
}

.mb-1, .my-1, .m-1 {
    margin-bottom: 1px !important;
}

.ml-2, .mx-2, .m-2 {
    margin-left: 2px !important;
}

.mr-2, .mx-2, .m-2 {
    margin-right: 2px !important;
}

.mt-2, .my-2, .m-2 {
    margin-top: 2px !important;
}

.mb-2, .my-2, .m-2 {
    margin-bottom: 2px !important;
}

.ml-3, .mx-3, .m-3 {
    margin-left: 3px !important;
}

.mr-3, .mx-3, .m-3 {
    margin-right: 3px !important;
}

.mt-3, .my-3, .m-3 {
    margin-top: 3px !important;
}

.mb-3, .my-3, .m-3 {
    margin-bottom: 3px !important;
}

.ml-4, .mx-4, .m-4 {
    margin-left: 4px !important;
}

.mr-4, .mx-4, .m-4 {
    margin-right: 4px !important;
}

.mt-4, .my-4, .m-4 {
    margin-top: 4px !important;
}

.mb-4, .my-4, .m-4 {
    margin-bottom: 4px !important;
}

.ml-5, .mx-5, .m-5 {
    margin-left: 5px !important;
}

.mr-5, .mx-5, .m-5 {
    margin-right: 5px !important;
}

.mt-5, .my-5, .m-5 {
    margin-top: 5px !important;
}

.mb-5, .my-5, .m-5 {
    margin-bottom: 5px !important;
}

.ml-10, .mx-10, .m-10 {
    margin-left: 10px !important;
}

.mr-10, .mx-10, .m-10 {
    margin-right: 10px !important;
}

.mt-10, .my-10, .m-10 {
    margin-top: 10px !important;
}

.mb-10, .my-10, .m-10 {
    margin-bottom: 10px !important;
}

.ml-1em, .mx-1em, .m-1em {
    margin-left: 1em !important;
}

.mr-1em, .mx-1em, .m-1em {
    margin-right: 1em !important;
}

.mt-1em, .my-1em, .m-1em {
    margin-top: 1em !important;
}

.mb-1em, .my-1em, .m-1em {
    margin-bottom: 1em !important;
}

.ml-2em, .mx-2em, .m-2em {
    margin-left: 2em !important;
}

.mr-2em, .mx-2em, .m-2em {
    margin-right: 2em !important;
}

.mt-2em, .my-2em, .m-2em {
    margin-top: 2em !important;
}

.mb-2em, .my-2em, .m-2em {
    margin-bottom: 2em !important;
}

/*
** switch
*/
.button-switch {
    width: 40px;
    height: 22px;
    justify-content: flex-start;
    align-items: flex-start;
    background-color: var(--color-text-1);
    border: 1px solid var(--color-text-2);
    border-radius: 22px;
}

.button-switch .icon-box {
    background-color: var(--color-white);
    margin-left: 1px;
    margin-top: 1px;
    border-radius: 18px;
    transition: all .25s;
}

.button-switch .icon-box,
.button-switch .icon-box > .icon-simply {
    width: 18px;
    height: 18px;
    line-height: 18px;
    font-size: 12px;
    color: var(--color-text);
}

.dark #dark-mode .icon-box > .icon-during,
.button-switch > .icon-box > .icon-simply {
    display: none;
    font-style: normal;
    text-align: center;
}

.dark #dark-mode .icon-box > .icon-night,
.button-switch:not(.on) .icon-box > .icon-during,
.button-switch.on .icon-box > .icon-night {
    display: block;
}

.dark #dark-mode,
.button-switch.on {
    border-color: var(--color-text-9);
    background-color: var(--color-text-8);
}

.dark #dark-mode .icon-box,
.button-switch.on .icon-box {
    transform: translate(18px);
    background-color: var(--color-text-7);
}

.dark #dark-mode .icon-box,
.dark #dark-mode .icon-box > .icon-simply,
.button-switch.on .icon-box,
.button-switch.on .icon-box > .icon-simply {
    color: var(--color-text-0);
}

/*
** timelife progress
*/
@-webkit-keyframes progress {
    0% {
        background-position: 0 0;
    }
    100% {
        background-position: 30px 0;
    }
}

@keyframes progress {
    0% {
        background-position: 0 0;
    }
    100% {
        background-position: 30px 0;
    }
}

.timelife:not(:first-child) {
    margin-top: 1em;
}

.timelife .title-bar {
    margin-bottom: .5em;
}

.timelife .progress-percentage {
    color: var(--color-text-6);
}

.timelife .progress {
    align-items: center;
}

.timelife .progress-bar {
    height: .75em;
    background: var(--color-text-0-light);
    width: 0;
    min-width: 0;
    flex: 1;
    margin-right: .5em;
    border-radius: var(--size-radius);
}

.timelife .progress-bar-inner {
    width: 0;
    height: 100%;
    animation: progress 750ms linear infinite;
    transition: width 0.35s;
    border-radius: var(--size-radius);
}

.timelife-0 .progress-bar-inner {
    background-color: #bde6ff;
    background-image: linear-gradient(135deg, #50bfff 25%, transparent 25%, transparent 50%, #50bfff 50%, #50bfff 75%, transparent 75%, transparent 100%);
    background-size: 30px 30px;
}

.timelife-1 .progress-bar-inner {
    background-color: #ffd980;
    background-image: linear-gradient(135deg, #f7ba2a 25%, transparent 25%, transparent 50%, #f7ba2a 50%, #f7ba2a 75%, transparent 75%, transparent 100%);
    background-size: 30px 30px;
}

.timelife-2 .progress-bar-inner {
    background-color: #ffa9a9;
    background-image: linear-gradient(135deg, #ff4949 25%, transparent 25%, transparent 50%, #ff4949 50%, #ff4949 75%, transparent 75%, transparent 100%);
    background-size: 30px 30px;
}

.timelife-3 .progress-bar-inner {
    background-color: #67c23a;
    background-image: linear-gradient(135deg, #4f9e28 25%, transparent 25%, transparent 50%, #4f9e28 50%, #4f9e28 75%, transparent 75%, transparent 100%);
    background-size: 30px 30px;
}


/*
** display
*/
.display-flex,
.flex-column,
.flex-row,
.flex-center,
.flex-h-center,
.flex-v-center,
.flex-v-between,
.flex-start-center,
.flex-end-center,
.text-v-center,
.frame-container,
.button-switch,
nav .nav-items,
nav .nav-items > .item > a,
.virtual-select > .action,
.swiper-filmstrip .swiper-slide,
.simply-button-prev,
.simply-button-next,
.recommend-image,
.percent-image .figure > .figcaption,
.modularity > .modul-head,
.modularity > .modul-info,
.flex-list,
.article-list > .item,
.article-list .infomation,
.article-list .infomation .meta,
.timelife .progress,
.user-info,
.sidebar > .item,
.aside-message-list > .item,
.aside-search form,
.aside-new-list > .item > a,
.aside-calendar .calendartop tbody tr:first-child,
.aside-calendar .calendartop tbody tr:first-child td,
.aside-tag-list,
.aside-tag-list > .item a,
.aside-category-list,
.aside-category-list > .item a,
.pagination {
    display: flex;
}

.display-inline {
    display: inline;
}

.display-block {
    display: block;
}

.display-none {
    display: none;
}

.display-unset {
    display: unset !important;
}

/* 垂直居中 */
.align-items-center,
.flex-center,
.flex-start-center,
.flex-end-center,
.flex-v-center,
.flex-v-between,
.nav-items > .item > a,
.simply-button-prev,
.simply-button-next,
.percent-image .figure > .figcaption,
.virtual-select > .action,
.modularity > .modul-head,
.modularity > .modul-info,
.article-list .infomation .meta,
.user-info,
.sidebar > .item,
.aside-message-list > .item,
.aside-calendar .calendartop tbody tr:first-child,
.aside-calendar .calendartop tbody tr:first-child td,
.aside-tag-list,
.aside-tag-list > .item a,
.aside-category-list,
.aside-category-list > .item a,
.pagination {
    align-items: center;
}

.align-items-start {
    align-items: flex-start;
}

.align-items-end {
    align-items: flex-end;
}

.align-items-baseline {
    align-items: baseline;
}

.align-items-stretch {
    align-items: stretch;
}

/* 水平居中 */
.justify-content-center,
.flex-center,
.flex-h-center,
.virtual-select > .action,
.simply-button-prev,
.simply-button-next,
.sidebar > .item,
.aside-tag-list > .item,
.aside-category-list > .item,
footer .flex-list,
.pagination {
    justify-content: center;
}

.justify-content-start,
.flex-start-center {
    justify-content: flex-start;
}

.justify-content-end,
.flex-end-center {
    justify-content: flex-end;
}

.justify-content-between,
.flex-v-between,
.virtual-select > .action,
.modularity > .modul-head,
.modularity > .modul-info,
.blogger-platform,
.blogger-statistic,
.aside-message-list > .item,
.aside-calendar .calendartop tbody tr:first-child,
.aside-calendar .calendartop tbody tr:first-child td,
.aside-tag-list > .item a,
.aside-category-list > .item a {
    justify-content: space-between;
}

.justify-content-around {
    justify-content: space-around;
}

/*
** 文字对齐
*/
.text-v-center {
    align-content: center;
}

/* FLEX换行 */
.flex-warp,
.text-v-center,
.button-switch,
.blogger-platform,
.aside-message-list > .item,
.aside-tag-list,
.aside-category-list,
footer .flex-list,
.pagination {
    flex-wrap: wrap;
}

.flex-nowrap {
    flex-wrap: nowrap;
}

.flex-wrap-reverse {
    flex-wrap: wrap-reverse;
}

/* FLEX不换行 */
.flex-nowarp,
.user-info,
.virtual-select > .action,
.modularity > .modul-head,
.modularity > .modul-info,
.article-list > .item,
.percent-image .figure > .figcaption,
.aside-tag-list > .item a
.aside-category-list > .item a {
    flex-wrap: nowrap;
}

/* FLEX横排 */
.flex-row,
.user-info,
.virtual-select > .action,
.modularity > .modul-head,
.modularity > .modul-info,
.article-list > .item,
.aside-tag-list,
.aside-tag-list > .item a
.aside-category-list,
.aside-category-list > .item a,
.pagination {
    flex-direction: row;
}

.flex-row-reverse {
    flex-direction: row-reverse;
}

/* FLEX竖排 */
.flex-column,
.recommend-image,
.article-list .infomation,
.button-switch {
    flex-direction: column;
}

.flex-column-reverse {
    flex-direction: column-reverse;
}

/*
** 文字截断
*/
.word-warp {
    word-break: break-all;
}

.word-nowarp,
.flex-list > .item,
.aside-new-list > .item .value {
    word-break: keep-all;
    white-space: nowrap;
}

.word-nowarp-ellipsis,
.virtual-select > .action .value,
.percent-image .figure > .figcaption > .title,
.aside-new-list > .item .title,
.aside-tag-list > .item .title,
.aside-category-list > .item .title {
    overflow: hidden;
    word-break: keep-all;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.word-warp-ellipsis-2,
.article-list .infomation .title,
.article-list .infomation .description {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    text-overflow: ellipsis;
}

/*
** swiper
*/
.film-box {
    margin-bottom: 1em;
    align-items: stretch;
}

.recommend-image {
    width: calc(50% + 1em);
    margin-left: 1em;
}

.recommend-image > .item {
    flex: 1;
}

.recommend-image > .item:not(:first-child) {
    margin-top: 1em;
}

.swiper {
    width: 100%;
    max-height: 100%;
    border-radius: 5px;
}

.simply-button-prev,
.simply-button-next {
    position: absolute;
    bottom: 0;
    top: 50%;
    margin-top: -2em;
    width: 4em;
    height: 4em;
    z-index: 1;
    color: var(--color-text-5);
    transition: all .3s;
}

.simply-button-prev {
    left: 0;
    transform: translate(-4em, 0);
}

.simply-button-next {
    right: 0;
    transform: translate(4em, 0);
}

.swiper:hover .simply-button-prev {
    transform: translate(0, 0);
}

.swiper:hover .simply-button-next {
    transform: translate(0, 0);
}

.simply-button-prev .icon-simply {
    margin-right: 2em;
}

.simply-button-next .icon-simply {
    margin-left: 2em;
}

.simply-button-prev::before,
.simply-button-next::before {
    position: absolute;
    bottom: 0;
    z-index: -1;
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
}

.simply-button-prev::before {
    left: -2em;
    border-top-right-radius: 1em;
    transform: rotate(45deg);
}

.simply-button-next::before {
    right: -2em;
    border-top-left-radius: 1em;
    transform: rotate(-45deg);
}

.swiper-button-disabled {
    opacity: .3;
}

.simply-pagination {
    position: absolute;
    right: 0;
    bottom: 1.5em;
    left: 0;
    z-index: 1;
    text-align: center;
}

.swiper-filmstrip .simply-pagination {
    top: .5em !important;
    right: 0 !important;
    bottom: auto !important;
    left: auto !important;
    padding-right: .75em !important;
    text-align: right !important;
    transform: translate3d(0px, 0, 0);
}

.simply-pagination .swiper-pagination-bullet {
    width: .5em;
    height: .5em;
    margin: 0 3px;
    background-color: #fff;
    opacity: .4;
    border-radius: 1em;
    transition: 0.3s;
}

.simply-pagination .swiper-pagination-bullet-active {
    opacity: .9;
}

.simply-pagination.swiper-pagination-horizontal .swiper-pagination-bullet-active {
    width: 1em;
}

.simply-pagination.swiper-pagination-vertical .swiper-pagination-bullet-active {
    height: 1em;
}

/*
** 虚拟下拉
*/
.virtual-select {
    width: auto;
    position: relative;
    z-index: 10;
}

.virtual-select > .action {
    border: 1px solid var(--color-text-1-light);
    border-radius: 3px;
    padding: 10px;
    cursor: pointer;
}

.virtual-select.active > .action,
.virtual-select > .action:hover {
    border-color: var(--color-text-5-light);
}

.virtual-select > .action .value {
    color: var(--color-text-9-light);
}

.virtual-select > .action .icon-simply {
    margin-left: auto;
    transition: all 0.35s;
}

.virtual-select.active > .action .icon-simply {
    transform: rotate(180deg);
}

.virtual-select > .select {
    position: absolute;
    top: auto;
    right: 0;
    left: 0;
    z-index: 1;
    display: none;
    width: 100%;
    padding: 10px 0;
    background-color: var(--color-text-0-light);
    border-radius: 3px;
    box-shadow: var(--shadow-box);
}

.virtual-select.active > .select {
    display: block;
}

.virtual-select > .select > .option {
    cursor: pointer;
    line-height: 1.2;
    padding: 8px 10px;
    word-break: break-all;
}

.virtual-select > .select > .option,
.virtual-select > .select > .option a {
    color: var(--color-text-light)
}

.virtual-select > .select > .option a {
    display: block;
}

.virtual-select > .select > .option:hover {
    background-color: var(--color-text-1-light);
}

/*
** 图片比例
*/
.percent-image > a,
a.percent-image {
    width: 100%;
    min-height: fit-content;
    display: block;
    overflow: hidden;
    border-radius: 5px;
}

.swiper-slide.percent-image,
.swiper-slide .percent-image {
    border-radius: 0;
}

.percent-image .figure {
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
    padding-bottom: var(--ratio-image);
}

.percent-image .figure > img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    transition: all 0.4s;
    transform: scale(1.05);
}

.percent-image:hover:not(.avatar) .figure > img,
.percent-image:not(.avatar) a:hover .figure > img,
.swiper:hover .percent-image .figure > img {
    transform: scale(1.15);
    opacity: .8;
}

.percent-image .figure > .figcaption {
    position: absolute;
    top: auto;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 2;
    padding: 10px;
    line-height: 1.25;
    background: #000;
    background: rgba(0, 0, 0, 0.8);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0.56) 64%, rgba(0, 0, 0, 0.8) 100%);
    color: var(--color-text-0);
    text-decoration: none;
}

.percent-image .figure > .figcaption > .title {
    flex: 1;
}

/*
** modularity
*/
.modularity > .modul-head {
    padding-bottom: 1em;
    border-bottom: 1px solid var(--color-text-0-light);
}

.modularity > .modul-head .flex-list:first-child {
    margin-right: 1em;
}

.modularity .flex-list > .item.active,
.modularity .flex-list > .item.active a {
    color: var(--color-theme-light);
}

.modularity .flex-list > .item.active::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: calc(-1em - 1px);
    height: 1px;
    background: var(--color-theme-light);
}

.modularity > .modul-body {
    padding-top: 1em;
}

.colorful-dot,
article .content pre::before {
    width: 10px;
    height: 10px;
    border-radius: 10px;
    background-color: #35cd4b;
    box-shadow: -30px 0 #fdbc40, -15px 0 #fc625d;
}

/*
** 列表
*/
.modul-head .flex-list > .item {
    position: relative;
}

.modul-head .flex-list > .item:not(:first-child),
.article-list .flex-list > .item:not(:first-child) {
    margin-left: 1em;
}

.article-list > .item:not(:first-child) {
    margin-top: 1em;
    border-top: 1px solid var(--color-text-1-light);
    padding-top: 1em
}

.article-list .thumbnail {
    width: 15em;
    border-radius: 5px;
}

.article-list .infomation {
    flex: 1;
    margin-left: 1em;
    line-height: 1.4;
}

.article-list .infomation .title {
    font-weight: normal;
}

.article-list .infomation .description,
.article-list .infomation .meta {
    opacity: .65;
}

.article-list .infomation .description {
    margin-top: 1em;
    margin-bottom: 1em;
}

.article-list .infomation .meta {
    margin-top: auto;
}

.article-list .infomation .meta .tags {
    margin-left: auto;
}

/*
** 边栏
*/
.frame-aside > .box:first-child {
    margin-top: 0;
}

.aside-blogger {
    overflow: hidden;
    padding: 0;
}

.aside-blogger .avatar {
    width: 60px;
    height: 60px;
}

.blogger-image > img {
    border-radius: 0;
    width: 100%;
    max-height: 160px;
    object-fit: cover;
}

.aside-blogger > .user-info,
.aside-blogger > .blogger-statistic {
    padding: 1em 1em 0 1em;
}

.aside-blogger > *:last-child {
    padding-bottom: 1em;
}

.blogger-platform {
    margin: 1em 1em .25em;
}

.blogger-platform > .item {
    margin: .25em !important;
}

.blogger-platform > .item a {
    display: block;
    background-color: var(--color-theme-2);
    color: var(--color-white) !important;
    padding: .5em;
    font-size: 1.25em;
    border-radius: var(--size-radius);
    opacity: .75;
    transition: all .3s;
}

.blogger-platform > .item a .icon-simply {
    margin: 0 !important;
}

.blogger-platform > .item a:hover {
    opacity: 1;
}

.platform-wechat {
    background-color: #04c15f;
}

.platform-weibo {
    background-color: #ea5d5f;
}

.platform-qq {
    background-color: #308de9;
}

.platform-github {
    background-color: #1f2328;
}

.platform-twitter {
    background-color: #55acee;
}

.platform-rss {
    background-color: #90ad33;
}

.platform-linkedin {
    background-color: #0966c3;
}

.platform-juejin {
    background-color: #1e80ff;
}

.platform-zhihu {
    background-color: #008ffc;
}

.platform-google {
    background-color: #fcd402;
}

.platform-oschina {
    background-color: #0b7d3f;
}

.platform-facebook {
    background-color: #1877f2;
}

.platform-qzone {
    background-color: #fdcd00;
}

.platform-baidu {
    background-color: #3245df;
}

.platform-apple {
    background-color: #5f5f65;
}

.platform-alipay {
    background-color: #1976ff;
}

.platform-qrcode {
    background-color: #5d5d5d;
}

.blogger-statistic {
    text-align: center;
}

.blogger-statistic > .item .name {
    opacity: .65;
    margin-bottom: 1em;
}

.blogger-statistic > .item .value {
    font-size: 1.5em;
    font-family: Georgia;
}

.aside-message-list > .item:not(:first-child) {
    border-top: 1px solid var(--color-text-1-light);
    padding-top: 1em;
    margin-top: 1em;
}

.aside-message-list .ago {
    color: var(--color-theme-6-light);
}

.aside-interlinkage-list {
    line-height: 1.4;
}

.aside-interlinkage-list > .item {
    margin: .5em 1em .5em 0;
}

.aside-search form [name="keyword"] {
    min-width: 0;
    padding: .75em;
    border: 1px solid var(--color-text-1-light);
    border-right: 0;
    background-color: var(--color-text-0-light);
    color: var(--color-text-8);
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    flex: 1;
}

.aside-search form [name="keyword"]:focus {
    border-color: var(--color-theme);
}

.aside-search form [type="submit"] {
    padding: .75em;
    border: 0;
    background-color: var(--color-theme-light);
    color: var(--color-white);
    border-radius: 0;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
}

.aside-new-list > .item:not(:first-child) {
    margin-top: .75em;
}

.aside-new-list > .item .value {
    opacity: .5;
    margin-left: auto;
}

.aside-hot-list .item:not(:first-child) {
    margin-top: 1em;
}

.aside-hot-list .item .percent-image .number {
    position: absolute;
    top: 5px;
    right: -20px;
    z-index: 2;
    width: 65px;
    line-height: 1.4;
    text-align: center;
    transform: rotate(45deg);
    color: var(--color-white);
}

.aside-hot-list .item:nth-child(1) .percent-image .number {
    background-color: #eb1b1b;
}

.aside-hot-list .item:nth-child(2) .percent-image .number {
    background-color: #e95f21;
}

.aside-hot-list .item:nth-child(3) .percent-image .number {
    background-color: #f39a00;
}

.aside-hot-list .item:nth-child(4) .percent-image .number {
    background-color: #bccf02;
}

.aside-hot-list .item .percent-image .infos {
    opacity: .7;
}

.aside-calendar .calendartop,
.aside-calendar .calendar {
    width: 100%;
    text-align: center;
}

.aside-calendar .calendartop {
    line-height: 1.6;
}

.aside-calendar .calendar {
    line-height: 2;
}

.aside-calendar .calendartop tbody tr:first-child td a {
    padding: .25em .65em;
}

.aside-calendar .calendar tbody tr:first-child td {
    background-color: var(--color-text-1-light);
}

.aside-calendar .calendar tbody tr:first-child td:first-child {
    border-top-left-radius: 3px;
    border-bottom-left-radius: 3px;
}

.aside-calendar .calendar tbody tr:first-child td:last-child {
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
}

.aside-calendar .calendar .day,
.aside-calendar .calendar td a {
    position: relative;
    color: var(--color-theme-light);
}

.aside-calendar .calendar td a {
    text-decoration: underline;
}

.aside-calendar .calendar .day::after,
.aside-calendar .calendar td a:hover::after {
    content: '';
    display: block;
    width: 24px;
    height: 24px;
    position: absolute;
    left: calc(50% - 12px);
    top: calc(50% - 12px);
    border: 1px solid var(--color-theme-light);
    border-radius: 100%;
}

.aside-tag-list > .item,
.aside-category-list > .item {
    width: calc(50% - 2.5px);
    margin-top: 5px;
}

.aside-tag-list > .item:nth-child(1),
.aside-tag-list > .item:nth-child(2),
.aside-category-list > .item:nth-child(1),
.aside-category-list > .item:nth-child(2) {
    margin-top: 0;
}

.aside-tag-list > .item:nth-child(odd),
.aside-category-list > .item:nth-child(odd) {
    margin-right: 2.5px;
}

.aside-tag-list > .item:nth-child(even),
.aside-category-list > .item:nth-child(even) {
    margin-left: 2.5px;
}

.aside-tag-list > .item a,
.aside-category-list > .item a {
    border: 1px solid var(--color-text-1-light);
    border-radius: 3px;
    padding: 8px;
}

.aside-tag-list > .item a:hover,
.aside-category-list > .item a:hover {
    border-color: var(--color-theme-light);
}

.aside-tag-list > .item .badge,
.aside-category-list > .item .badge {
    font-size: 12px;
    background-color: var(--color-text-1-light);
    color: var(--color-text-light);
}

.aside-archive {
    overflow: visible;
}

/*
** 分页
*/
.pagination {
    margin-top: 1em;
}

.pagination > * {
    display: block;
    padding: 10px;
    margin-left: -1px;
    line-height: 1;
    border: 1px solid var(--color-theme-light);
}

.pagination > *:first-child {
    border-top-left-radius: 3px;
    border-bottom-left-radius: 3px;
}

.pagination > *:last-child {
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
}

.pagination > a,
.pagination > em {
    color: var(--color-theme-light);
}

.pagination > em {
    cursor: no-drop;
}

.pagination > span,
.pagination > a:hover {
    background-color: var(--color-theme-light);
    color: var(--color-white);
}

/*
** web
*/
.container-list .modularity-list > .modul-body {
    padding-top: 0;
}

.container-path {
    padding-top: 1em;
    line-height: 2;
}

.web-path > .path:not(:last-child)::after {
    content: '>';
    margin: 0 5px;
}

/*
** 文章
*/
.container-list,
.container-article {
    margin-top: 0;
}

.container-article .frame-main .box {
    padding: 1.5em;
}

.container-article .frame-main .modularity {
    line-height: 2;
}

.container-article .modularity .modul-info {
    padding-bottom: 1.5em;
    border-bottom: 1px solid var(--color-text-1-light)
}

.container-article .modularity .modul-info .avatar {
    width: 40px;
    height: 40px;
}

.container-article .modularity .modul-info .info > .item {
    margin-top: .25em;
    margin-bottom: .25em;
}

.container-article .modularity .modul-info .info > .item:not(:last-child) {
    margin-right: .5em;
}

.container-article .modularity .modul-info .info > .item:not(.comt),
.container-article .modularity .modul-info .info > .item.comt a {
    display: block;
    border-radius: 40px;
    background-color: var(--color-text-0-light);
    padding: .25em 1em;
}

.container-article .modularity .modul-info .info > .item.comt a:hover {
    background-color: var(--color-theme-light);
    color: var(--color-white);
}

article > .feed,
article > .fieldset,
article > .content,
article > .content h1,
article > .content h2,
article > .content h3,
article > .content h4,
article > .content h5,
article > .content h6,
article > .content > p,
article > .content > blockquote,
article > .content img,
article > .content svg,
article > .content video,
article > .content table {
    margin-top: var(--size-texts);
    margin-bottom: var(--size-texts);
}

article > .content h1,
article > .content h2,
article > .content h3,
article > .content h4,
article > .content h5,
article > .content h6 {
    position: relative;
    padding-left: var(--size-texts);
    margin-top: calc(var(--size-texts) * 1.5);
}

article > .content h1::before,
article > .content h2::before,
article > .content h3::before,
article > .content h4::before,
article > .content h5::before,
article > .content h6::before {
    content: '';
    position: absolute;
    top: .15em;
    bottom: .15em;
    left: 0;
    width: 4px;
    background: var(--color-theme);
    border-radius: 3px;
}

article .title {
    text-align: center;
    padding: 1em 0;
}

article .title,
h1, h2, h3, h4, h5, h6 {
    line-height: 1.4;
}

article .feed {
    background-color: var(--color-theme-1-light);
    border: 1px solid var(--color-theme-3-light);
    padding: 1em;
    border-radius: 5px;
}

article .feed span,
article .feed a {
    color: var(--color-theme);
}

article .fieldset > .content {
    font-style: italic;
    color: var(--color-text-8);
}

article .content {
    overflow: hidden;
}

article .content img,
article .content svg,
article .content table,
article .content audio,
article .content video {
    max-width: 100%;
    border-radius: 5px;
}

article .content blockquote {
    padding: 1em;
    background-color: var(--color-text-1-light);
    border-left: 5px solid var(--color-text-5-light);
    border-radius: 3px;
}

article .content a {
    color: var(--color-theme-light);
    text-decoration: underline;
}

article .content ul {
    list-style-type: revert;
    padding: revert;
}

article .content ol {
    list-style-type: revert;
    padding: revert;
}

article .content ul li{
    list-style:circle;
}
article .content ol li {
    list-style:decimal ;
}

article .content pre {
    position: relative;
    background-color: var(--color-text);
    color: var(--color-text-3);
    padding: calc(2em + 5px) 1.5em 1em .5em;
    border-radius: 5px;
}

article .content pre::-webkit-scrollbar-track {
    box-shadow: none;
    background-color: var(--color-text);
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
}

article .content pre::-webkit-scrollbar-thumb {
    background-color: var(--color-text-6);
}

article .content pre::before {
    position: absolute;
    top: 1em;
    left: calc(35px + .5em);
    content: '';
}

article .content table {
    width: 100%;
    border-color: var(--color-text-1-light);
}

article .content table tr th,
article .content table tr td {
    padding: .5em 1em;
    border: 1px solid var(--color-text-1-light);
}

article .content table tr th {
    white-space: nowrap;
    word-break: keep-all;
}

article .content table thead tr {
    background-color: var(--color-theme-0-light);
}

article .tags {
    margin-bottom: 2em;
}

.container-article .modularity .copyright-plugin {
    word-break: break-all;
    background-color: var(--color-theme-1-light);
    border-left: 5px solid var(--color-theme-3-light);
    padding: 1em;
    border-radius: 5px;
}

.neighbor-items > .item a {
    display: block;
    padding: .75em 1em;
    background-color: var(--color-theme-light);
    color: var(--color-white);
    border-radius: 3px;
}

/*
** comment
*/
.message {
    position: relative;
    display: block;
    width: 100%;
    margin-top: 10px;
    padding: .75em;
    background-color: var(--color-theme-1-light);
    border-radius: 5px;
    color: var(--color-text-light) !important;
    line-height: 1.2;
}

.message::before {
    content: '';
    position: absolute;
    top: -6px;
    left: 18px;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 7px solid var(--color-theme-1-light);
}

a.message:hover {
    background-color: var(--color-theme-2-light);
}

a.message:hover::before {
    border-bottom: 7px solid var(--color-theme-2-light);
}

.comment-title {
    padding-top: 0.5em;
    text-align: center;
    font-size: 1.5em;
}

.comment-user .avatar {
    width: 40px;
    height: 40px;
}

.comment-items .comment-item:not(:first-child) {
    border-top: 1px solid var(--color-text-1-light);
    padding-top: 1.5em;
    margin-top: 1.5em;
}

.comment-items .comment-item .comment-post {
    margin-top: 1em;
}

.comment-item > .item-right {
    flex: 1;
    margin-left: auto;
}

.comment-item > .item-right .info,
.comment-item .comment-time {
    opacity: .65;
}

.comment-item .comment-item .comment-item .item-right .info {
    display: none;
}

.user-level {
    color: #ff8f17;
}

.comment-form .head,
.comment-form .body,
.comment-form .foot {
    width: 100%;
    padding: 1em;
    background-color: var(--color-theme-0-light);
    border: 1px solid var(--color-text-1-light);
}

.comment-form .head {
    padding: 0;
    border-bottom: 0;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
}

.comment-item .comment-item .comment-item .comment-form .head {
    flex-direction: column;
}

.comment-item .comment-item .comment-item .comment-form .head .comment-control:not(:first-child) {
    border-left: 0;
    border-top: 1px solid var(--color-text-1-light);
}

.comment-form .head .comment-control {
    flex: 1;
    color: var(--color-text-light);
    width: 100%;
}

.comment-form .head .comment-control:not(:first-child) {
    border-left: 1px solid var(--color-text-1-light);
}

.comment-form .body {
    border-bottom: 0;
}

.comment-form .body textarea {
    width: 100%;
    line-height: 1;
    border: 0;
    resize: none;
    background: transparent;
    color: var(--color-text-light);
}

.layui-form-danger:focus {
    border-color: transparent !important;
}

.comment-form .body textarea::-webkit-scrollbar-track {
    box-shadow: none;
    background-color: transparent;
}

.comment-form .foot {
    border-top: 0;
    padding-top: 0;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
}

.comment-control {
    padding: 1em;
    background: transparent;
    border: 0;
}

.comment-form .foot #captcha,
.comment-form .foot .input-code {
    border: 1px solid var(--color-text-5-light);
    border-radius: 3px;
}

.comment-form .foot #captcha {
    cursor: pointer;
}

.comment-form .foot .input-code {
    padding: 5px;
    max-width: 5em;
    background-color: var(--color-white-light);
    color: var(--color-text-light);
}

.comment-form .foot > *:nth-child(2) {
    margin-left: auto;
}

a.button {
    display: inline-block;
}

.button {
    cursor: pointer;
    line-height: 1;
    padding: 10px;
    border: 0;
    background-color: var(--color-theme-light);
    color: var(--color-white) !important;
    border-radius: 5px;
}

.comment-closed,
.comment-login {
    border: 2px dashed var(--color-theme-3-light);
    padding: 2em;
    text-align: center;
    border-radius: 5px;
}

/*
** 头部
*/
header {
    background-color: var(--color-white-light);
    box-shadow: var(--shadow-minify);
    padding: 1em 0;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 99;
}

header .logo {
    font-size: 1.5em;
}

header > .container,
header .logo > .image {
    height: var(--height-logo);
}

header .logo > .text + .image,
header .logo > .image + .text {
    margin-left: .5em;
}

.nav-items > .item {
    position: relative;
}

.nav-items > .item:not(:first-child) {
    margin-left: 1.5em;
}

.nav-items > .item > a .icon-simply {
    transition: all 0.35s;
}

.xs-nav-layer {
    display: none;
}

.xs-nav-button {
    width: 30px;
    height: 30px;
    position: relative;
    cursor: pointer;
}

.nav-burger,
.nav-burger::before,
.nav-burger::after {
    width: 26px;
    height: 3px;
    background-color: var(--color-text-9);
    border-radius: 2px;
    transition: all 0.2s ease-in-out;
}

.nav-burger::before,
.nav-burger::after {
    position: absolute;
    content: '';
}

.nav-burger::before {
    transform: translateY(9px);
}

.nav-burger::after {
    transform: translateY(-9px);
}

.nav-open .nav-burger {
    background: transparent;
}

.nav-open .nav-burger::before {
    transform: rotate(-45deg) translateY(0);
}

.nav-open .nav-burger::after {
    transform: rotate(45deg) translateY(0);
}

/*
** footer
*/
footer {
    padding: 1em;
    line-height: 1.8;
    text-align: center;
}

footer .flex-list > .item {
    margin-left: .5em;
    margin-right: .5em;
}

/*
** sidebar
*/
.sidebar {
    position: fixed;
    right: 2em;
    bottom: 4em;
}

.sidebar > .item {
    cursor: pointer;
    width: 40px;
    height: 40px;
    border-radius: 40px;
    margin-top: 1em;
    font-size: 1.25em;
    background-color: var(--color-white-light);
    color: var(--color-theme-8);
    box-shadow: var(--shadow-box);
}

.sidebar > .item.sidebar-totop {
    opacity: 0;
    transition: all .55s;
}

.sidebar > .item.sidebar-totop.active {
    opacity: 1;
}

/*
** 适配
*/
@media screen and (max-width: 1280px) {
    .container {
        max-width: 992px;
    }

    .article-list > .item .meta > .item {
        display: none;
    }

    .article-list > .item .meta > .item.time,
    .article-list > .item .meta > .item.view,
    .article-list > .item .meta > .item.tags {
        display: block;
    }

    .article-list > .item .meta > .item.time {
        margin-left: 0;
    }
}

@media screen and (min-width: 992px) {
    header .xs-nav-button {
        display: none;
    }

    .nav-items > .item .nav-child-box {
        width: 8em;
        position: absolute;
        top: 1em;
        left: calc(50% - 4.5em);
        z-index: 9;
        opacity: 0;
        visibility: hidden;
        transform-origin: top;
        transition: all 0.35s;
        transform: translateX(0) perspective(600px) rotateX(-45deg);
    }

    .nav-items > .item.active .nav-child-box {
        opacity: 1;
        visibility: visible;
        transform: translateX(0) perspective(600px) rotateX(0);
    }

    .nav-items > .item.active > a .icon-simply {
        transform: rotate(180deg);
    }

    .nav-child-box .nav-child-items {
        position: relative;
        margin-top: 1em;
        padding: 10px;
        background-color: var(--color-white-light);
        box-shadow: var(--shadow-box);
        border-bottom-left-radius: 5px;
        border-bottom-right-radius: 5px;
        border-top: 3px solid var(--color-theme);
    }

    .nav-child-box .nav-child-items::before {
        content: '';
        position: absolute;
        top: -7px;
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 7px solid transparent;
        border-right: 7px solid transparent;
        border-bottom: 7px solid var(--color-theme);
    }

    .nav-child-items > .item:not(:first-child) {
        margin-top: 5px;
    }

    .nav-child-items > .item a {
        display: block;
        text-align: center;
        padding: 8px 5px;
        border-radius: 3px;
        overflow: hidden;
        background-color: var(--color-text-0-light);
        border: 1px solid var(--color-text-1-light);
    }

    .nav-child-items > .item a:hover {
        background-color: var(--color-theme);
        border-color: var(--color-theme);
        color: var(--color-white);
    }
}

@media screen and (max-width: 992px) {
    .container {
        max-width: 768px;
    }

    .xs-hidden,
    header .container > .right,
    header .container > .right > *:not(nav),
    .frame-aside {
        display: none !important;
    }

    .nav-open,
    .nav-open body {
        overflow: hidden;
    }

    .frame-main,
    .frame-aside {
        width: 100%;
    }

    .frame-container {
        flex-direction: column;
    }

    header .xs-nav-button {
        display: flex;
    }

    header .xs-nav-layer,
    header .container > .right {
        position: fixed;
        bottom: 0;
        left: 0;
        transform: translate3d(-100%, 0, 0);
    }

    header .xs-nav-layer {
        top: 0;
        right: 0;
        z-index: -1;
        width: 100vh;
        content: '';
        background-color: var(--color-white-light);
        backdrop-filter: blur(5px);
        opacity: .5;
    }

    header .container > .right {
        top: calc(var(--height-logo) + 1em * 2);
        right: auto;
        z-index: 99;
        display: flex !important;
        background-color: var(--color-white-light);
        align-items: flex-start;
        min-width: 200px;
        max-width: 70%;
        width: 70%;
        overflow-x: hidden;
        overflow-y: auto;
    }

    header .container nav {
        width: 100%;
        padding-left: 1em;
        padding-right: 1em;
        line-height: 3;
    }

    header .container nav .nav-items {
        flex-direction: column;
    }

    header .container nav .nav-items > .item:not(:first-child) {
        border-top: 1px solid var(--color-text-1-light);
    }

    header .container nav .nav-items .item {
        margin-left: 0;
    }

    header .container nav .nav-items .item .icon-simply {
        margin-left: auto !important;
        transform: rotate(-90deg);
    }

    header .container nav .nav-items .item .nav-child-box {
        display: none;
        margin-top: -.5em;
        padding-left: 1em;
        line-height: 2;
    }

    .nav-open header .xs-nav-layer {
        display: block;
    }

    .nav-open header .xs-nav-layer,
    .nav-open header .container > .right {
        transition: all .3s;
        transform: translate3d(0, 0, 0);
    }

    header .container nav .nav-items .item.show-child .icon-simply {
        transform: rotate(0);
    }

    .aside-hot.modularity > .modul-body {
        padding-top: 0;
    }

    .aside-hot-list {
        display: flex;
        flex-wrap: wrap;
    }

    .aside-hot-list > .item {
        width: calc(50% - .5em);
        margin-top: 1em;
    }

    .aside-hot-list > .item:nth-child(odd) {
        margin-right: 1em;
    }

    .comment-item > .item-right .info {
        display: none;
    }

    .comment-form .head {
        flex-direction: column;
    }

    .comment-form .head .comment-control:not(:first-child) {
        border-left: 0;
        border-top: 1px solid var(--color-text-1-light);
    }
}

@media screen and (max-width: 768px) and (min-width: 640px) {
    .frame-aside {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .frame-aside > * {
        width: calc(50% - .5em);
    }

    .frame-aside > *:nth-of-type(even) {
        margin-left: 1em;
    }

    .frame-aside > *:nth-child(2) {
        margin-top: 0;
    }
}

@media screen and (max-width: 768px) {
    .container {
        max-width: 100%;
    }

    .article-list .infomation .description,
    .simply-button-prev,
    .simply-button-next {
        display: none;
    }
}

@media screen and (max-width: 640px) {
    .article-list .thumbnail {
        width: 12em;
    }

    .article-list .infomation .title {
        font-size: 1em;
    }

    .container-article .frame-main .box {
        padding: 1em;
    }

    .container-article .modularity .modul-info {
        flex-direction: column;
        align-items: flex-start;
        padding-bottom: .75em;
    }

    .container-article .modularity .modul-info .info {
        margin-top: .5em;
        flex-wrap: wrap;
    }
}

@media screen and (max-width: 576px) {
    .film-box {
        flex-direction: column;
    }

    .recommend-image {
        width: 100%;
        margin-left: 0;
        margin-top: 1em;
        flex-direction: row;
    }

    .recommend-image > .item:not(:first-child) {
        margin-top: 0;
        margin-left: 1em;
    }

    .article-list .thumbnail {
        width: 120px;
    }

    .article-list > .item .meta > .item.tags,
    .aside-hot-list .item .percent-image .infos {
        display: none;
    }
}

@media screen and (max-width: 375px) {
    .article-list > .item .meta > .item.view {
        display: none;
    }
}

/**
 * markdown 输出样式
 */

 .markdown {
    overflow-wrap: break-word;
    text-align: justify
}

.markdown h1 {
    font-size: 1.8rem !important;
    margin-top: 1em;
    margin-bottom: 16px;
    font-weight: bold;
    padding-bottom: 5px;
    border-bottom: 1px solid #eee;
    letter-spacing: 1px
}

.markdown h2 {
    font-size: 1.5rem !important;
    margin-top: 1em;
    margin-bottom: 16px;
    font-weight: bold;
    padding-bottom: 5px;
    border-bottom: 1px solid #eee;
    letter-spacing: 1px
}

.markdown h3 {
    font-size: 1.3rem !important;
    line-height: 1.43;
    font-weight: bold
}

.markdown h4 {
    font-size: 1.2em !important;
    margin-bottom: 16px;
    font-weight: bold;
    line-height: 1.4;
    letter-spacing: 0.5px
}

.markdown h5 {
    font-size: 1rem !important;
    margin-top: 1em;
    margin-bottom: 16px;
    font-weight: bold;
    line-height: 1.4
}

.markdown h6 {
    font-size: 1rem !important;
    color: #777;
    margin-top: 1em;
    font-weight: bold;
    line-height: 1.4;
    margin-bottom: 16px
}

.markdown strong {
    font-weight: bold;
    font-size: 1rem !important
}

.markdown del {
    text-decoration: line-through
}

.markdown a {
    text-decoration: underline;
}

.markdown blockquote {
    color: #666;
    border-left: 4px solid #ddd;
    padding-left: 20px;
    margin-left: 0;
    font-size: 14px;
    font-style: italic
}

.markdown ul {
    padding-left: 2em;
    margin-bottom: 16px
}

.markdown ol {
    padding-left: 2em;
    margin-bottom: 16px
}

.markdown li {
    font-size: 15px !important;
    line-height: 2
}

.markdown hr {
    height: 1px;
    border: none;
    border-top: 1px solid #ddd;
    background: none
}

.markdown pre.prettyprint {
    padding: 10px;
    border: 1px solid #ddd;
    white-space: pre-wrap;
    word-wrap: break-word;
    line-height: 1.6
}

.markdown table {
    display: block;
    width: 100%;
    max-width: 100%;
    overflow: auto;
    word-break: keep-all;
    border-collapse: collapse;
    margin-bottom: 16px;
    table-layout: auto;
}

.markdown thead tr {
    background-color: #f5f5f6
}

.markdown td {
    padding: 6px 13px;
    border: 1px solid #00000019
}

.markdown th {
    padding: 6px 13px;
    border: 1px solid #00000019
}

.markdown table tr:nth-child(even) {
    background: #f5f5f6
}

/* 选择不在 <pre> 标签中的 <code> 元素 */
.markdown code:not(pre > code) {
    border-radius: 3px;
    font-size: 14px;
    margin-right: 4px;
    color: #f6607d;
    background: #00000019;
    padding: 2px 4px;
}

.markdown pre {
    padding: 10px;
    border-radius: 5px;
    border: 1px solid #00000019;
    background: #00000019;
    overflow: auto
}

.markdown img {
    display: block;
    margin: auto;
    box-sizing: border-box;
    border: 0
}

.markdown hr {
    margin: 7px 0 7px 0
}

