/* Stysky's Blog 完美自定义样式 - 不强制覆盖主题背景设置 */

/* 基础样式优化 - 不设置强制背景 */
body {
    padding-top: 60px;
    /* 移除所有强制背景设置，让主题配置生效 */
}

/* 导航栏完全透明 - 强制覆盖所有可能的背景设置 */
#nav,
nav#nav,
#page-header #nav,
#page-header.nav-fixed #nav,
.nav-fixed #nav {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
}

/* 头像样式 */
.avatar-img {
    border-radius: 50%;
    border: 3px solid rgba(255, 255, 255, 0.8);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
}

.avatar-img:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

/* 页面标题区域完全透明 - 融入背景图 */
#page-header,
.page-header,
#page-header .page-title,
.page-header .page-title,
#page-header .page-title-wrap,
.page-header .page-title-wrap {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: none !important;
    border: none !important;
}

/* 确保页面标题文字可见 */
#page-header h1,
.page-header h1,
#page-header .page-title,
.page-header .page-title {
    color: white !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    background: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* 卡片样式 */
.card-widget {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%
}

body {
  margin: 0
}

main {
  display: block
}

h1 {
  font-size: 2em;
  margin: .67em 0
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible
}

pre {
  font-family: monospace, monospace;
  font-size: 1em
}

a {
  background-color: transparent
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em
}

small {
  font-size: 80%
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

img {
  border-style: none
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0
}

button,
input {
  overflow: visible
}

button,
select {
  text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted ButtonText
}

fieldset {
  padding: .35em .75em .625em
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

details {
  display: block
}

summary {
  display: list-item
}

template {
  display: none
}

[hidden] {
  display: none
}
.limit-one-line,
.container .flink .flink-item-name,
.container .flink .flink-item-desc,
#aside-content .card-archives ul.card-archive-list > .card-archive-list-item a span,
#aside-content .card-categories ul.card-category-list > .card-category-list-item a span,
.site-data > a .headline,
#nav #blog-info,
#sidebar #sidebar-menus .menus_items .site-page {
  overflow: hidden;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.limit-more-line,
.article-sort-item-title,
#recent-posts .recent-post-item >.recent-post-info > .article-title,
#recent-posts .recent-post-item >.recent-post-info > .content,
#aside-content .aside-list > .aside-list-item .content > .name,
#aside-content .aside-list > .aside-list-item .content > .title,
#aside-content .aside-list > .aside-list-item .content > .comment,
#post-info .post-title,
.pagination-related .info .info-1 .info-item-2,
.pagination-related .info .info-2 .info-item-1,
.container figure.gallery-group p,
.container figure.gallery-group .gallery-group-name {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
}
.fontawesomeIcon,
.custom-hr:before,
#post .post-copyright:before,
#post #post-outdate-notice:before,
.note:not(.no-icon)::before,
.search-dialog hr:before {
  display: inline-block;
  font-weight: 600;
  font-family: 'Font Awesome 7 Free', 'Font Awesome 6 Free';
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}
.cardHover,
.layout > div:first-child:not(.nc),
#recent-posts .recent-post-item,
#article-container .shuoshuo-item,
#aside-content .card-widget,
.layout .pagination > *:not(.space) {
  background: var(--card-bg);
  -webkit-box-shadow: var(--card-box-shadow);
  box-shadow: var(--card-box-shadow);
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
  border-radius: 8px;
}
.cardHover:hover,
.layout > div:first-child:not(.nc):hover,
#recent-posts .recent-post-item:hover,
#article-container .shuoshuo-item:hover,
#aside-content .card-widget:hover,
.layout .pagination > *:not(.space):hover {
  -webkit-box-shadow: var(--card-hover-box-shadow);
  box-shadow: var(--card-hover-box-shadow);
}
.imgHover,
.article-sort-item-img :first-child,
#recent-posts .recent-post-item .post_cover .post-bg,
#aside-content .aside-list > .aside-list-item .thumbnail :first-child {
  width: 100%;
  height: 100%;
  -webkit-transition: filter 375ms ease-in 0.2s, -webkit-transform 0.6s;
  -moz-transition: filter 375ms ease-in 0.2s, -moz-transform 0.6s;
  -o-transition: filter 375ms ease-in 0.2s, -o-transform 0.6s;
  -ms-transition: filter 375ms ease-in 0.2s, -ms-transform 0.6s;
  transition: filter 375ms ease-in 0.2s, transform 0.6s;
  object-fit: cover;
}
.imgHover:hover,
.article-sort-item-img :first-child:hover,
#recent-posts .recent-post-item .post_cover .post-bg:hover,
#aside-content .aside-list > .aside-list-item .thumbnail :first-child:hover {
  -webkit-transform: scale(1.1);
  -moz-transform: scale(1.1);
  -o-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
.postImgHover:hover .cover,
.pagination-related:hover .cover {
  opacity: 0.5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  filter: alpha(opacity=50);
  -webkit-transform: scale(1.1);
  -moz-transform: scale(1.1);
  -o-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
.postImgHover .cover,
.pagination-related .cover {
  width: 100%;
  height: 100%;
  opacity: 0.4;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
  filter: alpha(opacity=40);
  -webkit-transition: all 0.6s, filter 375ms ease-in 0.2s;
  -moz-transition: all 0.6s, filter 375ms ease-in 0.2s;
  -o-transition: all 0.6s, filter 375ms ease-in 0.2s;
  -ms-transition: all 0.6s, filter 375ms ease-in 0.2s;
  transition: all 0.6s, filter 375ms ease-in 0.2s;
  object-fit: cover;
}
.list-beauty,
.category-lists ul {
  list-style: none;
}
.list-beauty li,
.category-lists ul li {
  position: relative;
  padding: 0.12em 0.4em 0.12em 1.4em;
}
.list-beauty li:hover:before,
.category-lists ul li:hover:before {
  border-color: var(--pseudo-hover);
}
.list-beauty li:before,
.category-lists ul li:before {
  position: absolute;
  top: 0.67em;
  left: 0;
  width: 0.43em;
  height: 0.43em;
  border: 0.215em solid #49b1f5;
  border-radius: 0.43em;
  background: transparent;
  content: '';
  cursor: pointer;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  -o-transition: all 0.3s ease-out;
  -ms-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.custom-hr,
.search-dialog hr {
  position: relative;
  margin: 40px auto;
  border: 2px dashed var(--hr-border);
  width: calc(100% - 4px);
}
.custom-hr:hover:before,
.search-dialog hr:hover:before {
  left: calc(95% - 20px);
}
.custom-hr:before,
.search-dialog hr:before {
  position: absolute;
  top: -10px;
  left: 5%;
  z-index: 1;
  color: var(--hr-before-color);
  content: '\f0c4';
  font-size: 20px;
  line-height: 1;
  -webkit-transition: all 1s ease-in-out;
  -moz-transition: all 1s ease-in-out;
  -o-transition: all 1s ease-in-out;
  -ms-transition: all 1s ease-in-out;
  transition: all 1s ease-in-out;
}
.verticalCenter,
.pagination-related .info .info-1,
.pagination-related .info .info-2 {
  position: absolute;
  top: 50%;
  width: 100%;
  -webkit-transform: translate(0, -50%);
  -moz-transform: translate(0, -50%);
  -o-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
#content-inner,
#footer {
  -webkit-animation: bottom-top 1s;
  -moz-animation: bottom-top 1s;
  -o-animation: bottom-top 1s;
  -ms-animation: bottom-top 1s;
  animation: bottom-top 1s;
}
#page-header:not(.full_page),
#nav.show {
  -webkit-animation: header-effect 1s;
  -moz-animation: header-effect 1s;
  -o-animation: header-effect 1s;
  -ms-animation: header-effect 1s;
  animation: header-effect 1s;
}
#site-title,
#site-subtitle {
  -webkit-animation: titleScale 1s;
  -moz-animation: titleScale 1s;
  -o-animation: titleScale 1s;
  -ms-animation: titleScale 1s;
  animation: titleScale 1s;
}
canvas:not(#ribbon-canvas),
#web_bg {
  -webkit-animation: to_show 4s;
  -moz-animation: to_show 4s;
  -o-animation: to_show 4s;
  -ms-animation: to_show 4s;
  animation: to_show 4s;
}
#ribbon-canvas {
  -webkit-animation: ribbon_to_show 4s;
  -moz-animation: ribbon_to_show 4s;
  -o-animation: ribbon_to_show 4s;
  -ms-animation: ribbon_to_show 4s;
  animation: ribbon_to_show 4s;
}
#sidebar-menus.open > :nth-child(1) {
  -webkit-animation: sidebarItem 0.2s;
  -moz-animation: sidebarItem 0.2s;
  -o-animation: sidebarItem 0.2s;
  -ms-animation: sidebarItem 0.2s;
  animation: sidebarItem 0.2s;
}
#sidebar-menus.open > :nth-child(2) {
  -webkit-animation: sidebarItem 0.4s;
  -moz-animation: sidebarItem 0.4s;
  -o-animation: sidebarItem 0.4s;
  -ms-animation: sidebarItem 0.4s;
  animation: sidebarItem 0.4s;
}
#sidebar-menus.open > :nth-child(3) {
  -webkit-animation: sidebarItem 0.6s;
  -moz-animation: sidebarItem 0.6s;
  -o-animation: sidebarItem 0.6s;
  -ms-animation: sidebarItem 0.6s;
  animation: sidebarItem 0.6s;
}
#sidebar-menus.open > :nth-child(4) {
  -webkit-animation: sidebarItem 0.8s;
  -moz-animation: sidebarItem 0.8s;
  -o-animation: sidebarItem 0.8s;
  -ms-animation: sidebarItem 0.8s;
  animation: sidebarItem 0.8s;
}
.scroll-down-effects {
  -webkit-animation: scroll-down-effect 1.5s infinite;
  -moz-animation: scroll-down-effect 1.5s infinite;
  -o-animation: scroll-down-effect 1.5s infinite;
  -ms-animation: scroll-down-effect 1.5s infinite;
  animation: scroll-down-effect 1.5s infinite;
}
.avatar-img {
  -webkit-animation: avatar_turn_around 2s linear infinite;
  -moz-animation: avatar_turn_around 2s linear infinite;
  -o-animation: avatar_turn_around 2s linear infinite;
  -ms-animation: avatar_turn_around 2s linear infinite;
  animation: avatar_turn_around 2s linear infinite;
}
.reward-main {
  -webkit-animation: donate_effcet 0.3s 0.1s ease both;
  -moz-animation: donate_effcet 0.3s 0.1s ease both;
  -o-animation: donate_effcet 0.3s 0.1s ease both;
  -ms-animation: donate_effcet 0.3s 0.1s ease both;
  animation: donate_effcet 0.3s 0.1s ease both;
}
@-moz-keyframes scroll-down-effect {
  0% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translate(0, -16px);
    -moz-transform: translate(0, -16px);
    -o-transform: translate(0, -16px);
    -ms-transform: translate(0, -16px);
    transform: translate(0, -16px);
  }
  100% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}
@-webkit-keyframes scroll-down-effect {
  0% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translate(0, -16px);
    -moz-transform: translate(0, -16px);
    -o-transform: translate(0, -16px);
    -ms-transform: translate(0, -16px);
    transform: translate(0, -16px);
  }
  100% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}
@-o-keyframes scroll-down-effect {
  0% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translate(0, -16px);
    -moz-transform: translate(0, -16px);
    -o-transform: translate(0, -16px);
    -ms-transform: translate(0, -16px);
    transform: translate(0, -16px);
  }
  100% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}
@keyframes scroll-down-effect {
  0% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translate(0, -16px);
    -moz-transform: translate(0, -16px);
    -o-transform: translate(0, -16px);
    -ms-transform: translate(0, -16px);
    transform: translate(0, -16px);
  }
  100% {
    opacity: 0.4;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
    filter: alpha(opacity=40);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}
@-moz-keyframes header-effect {
  0% {
    -webkit-transform: translateY(-35px);
    -moz-transform: translateY(-35px);
    -o-transform: translateY(-35px);
    -ms-transform: translateY(-35px);
    transform: translateY(-35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-webkit-keyframes header-effect {
  0% {
    -webkit-transform: translateY(-35px);
    -moz-transform: translateY(-35px);
    -o-transform: translateY(-35px);
    -ms-transform: translateY(-35px);
    transform: translateY(-35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-o-keyframes header-effect {
  0% {
    -webkit-transform: translateY(-35px);
    -moz-transform: translateY(-35px);
    -o-transform: translateY(-35px);
    -ms-transform: translateY(-35px);
    transform: translateY(-35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes header-effect {
  0% {
    -webkit-transform: translateY(-35px);
    -moz-transform: translateY(-35px);
    -o-transform: translateY(-35px);
    -ms-transform: translateY(-35px);
    transform: translateY(-35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-moz-keyframes bottom-top {
  0% {
    -webkit-transform: translateY(35px);
    -moz-transform: translateY(35px);
    -o-transform: translateY(35px);
    -ms-transform: translateY(35px);
    transform: translateY(35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-webkit-keyframes bottom-top {
  0% {
    -webkit-transform: translateY(35px);
    -moz-transform: translateY(35px);
    -o-transform: translateY(35px);
    -ms-transform: translateY(35px);
    transform: translateY(35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-o-keyframes bottom-top {
  0% {
    -webkit-transform: translateY(35px);
    -moz-transform: translateY(35px);
    -o-transform: translateY(35px);
    -ms-transform: translateY(35px);
    transform: translateY(35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes bottom-top {
  0% {
    -webkit-transform: translateY(35px);
    -moz-transform: translateY(35px);
    -o-transform: translateY(35px);
    -ms-transform: translateY(35px);
    transform: translateY(35px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-moz-keyframes titleScale {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-webkit-keyframes titleScale {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-o-keyframes titleScale {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes titleScale {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-moz-keyframes search_close {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
@-webkit-keyframes search_close {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
@-o-keyframes search_close {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
@keyframes search_close {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
@-moz-keyframes to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
}
@-webkit-keyframes to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
}
@-o-keyframes to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
}
@keyframes to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
}
@-moz-keyframes to_hide {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
}
@-webkit-keyframes to_hide {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
}
@-o-keyframes to_hide {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
}
@keyframes to_hide {
  0% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
  100% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
}
@-moz-keyframes ribbon_to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 0.6;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)";
    filter: alpha(opacity=60);
  }
}
@-webkit-keyframes ribbon_to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 0.6;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)";
    filter: alpha(opacity=60);
  }
}
@-o-keyframes ribbon_to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 0.6;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)";
    filter: alpha(opacity=60);
  }
}
@keyframes ribbon_to_show {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
  100% {
    opacity: 0.6;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=60)";
    filter: alpha(opacity=60);
  }
}
@-moz-keyframes avatar_turn_around {
  from {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    -o-transform: rotate(0);
    -ms-transform: rotate(0);
    transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-webkit-keyframes avatar_turn_around {
  from {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    -o-transform: rotate(0);
    -ms-transform: rotate(0);
    transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-o-keyframes avatar_turn_around {
  from {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    -o-transform: rotate(0);
    -ms-transform: rotate(0);
    transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes avatar_turn_around {
  from {
    -webkit-transform: rotate(0);
    -moz-transform: rotate(0);
    -o-transform: rotate(0);
    -ms-transform: rotate(0);
    transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@-moz-keyframes sub_menus {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(10px);
    -moz-transform: translateY(10px);
    -o-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-webkit-keyframes sub_menus {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(10px);
    -moz-transform: translateY(10px);
    -o-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-o-keyframes sub_menus {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(10px);
    -moz-transform: translateY(10px);
    -o-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes sub_menus {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(10px);
    -moz-transform: translateY(10px);
    -o-transform: translateY(10px);
    -ms-transform: translateY(10px);
    transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-moz-keyframes donate_effcet {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(-20px);
    -moz-transform: translateY(-20px);
    -o-transform: translateY(-20px);
    -ms-transform: translateY(-20px);
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-webkit-keyframes donate_effcet {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(-20px);
    -moz-transform: translateY(-20px);
    -o-transform: translateY(-20px);
    -ms-transform: translateY(-20px);
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-o-keyframes donate_effcet {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(-20px);
    -moz-transform: translateY(-20px);
    -o-transform: translateY(-20px);
    -ms-transform: translateY(-20px);
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes donate_effcet {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
    -webkit-transform: translateY(-20px);
    -moz-transform: translateY(-20px);
    -o-transform: translateY(-20px);
    -ms-transform: translateY(-20px);
    transform: translateY(-20px);
  }
  100% {
    opacity: 1;
    -ms-filter: none;
    filter: none;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-moz-keyframes sidebarItem {
  0% {
    -webkit-transform: translateX(200px);
    -moz-transform: translateX(200px);
    -o-transform: translateX(200px);
    -ms-transform: translateX(200px);
    transform: translateX(200px);
  }
  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@-webkit-keyframes sidebarItem {
  0% {
    -webkit-transform: translateX(200px);
    -moz-transform: translateX(200px);
    -o-transform: translateX(200px);
    -ms-transform: translateX(200px);
    transform: translateX(200px);
  }
  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@-o-keyframes sidebarItem {
  0% {
    -webkit-transform: translateX(200px);
    -moz-transform: translateX(200px);
    -o-transform: translateX(200px);
    -ms-transform: translateX(200px);
    transform: translateX(200px);
  }
  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@keyframes sidebarItem {
  0% {
    -webkit-transform: translateX(200px);
    -moz-transform: translateX(200px);
    -o-transform: translateX(200px);
    -ms-transform: translateX(200px);
    transform: translateX(200px);
  }
  100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
:root {
  --global-font-size: 14px;
  --global-bg: #fff;
  --font-color: #4c4948;
  --hr-border: #a4d8fa;
  --hr-before-color: #80c8f8;
  --search-bg: #f6f8fa;
  --search-input-color: #4c4948;
  --search-a-color: #4c4948;
  --preloader-bg: #37474f;
  --preloader-color: #fff;
  --tab-border-color: #f0f0f0;
  --tab-button-bg: #f0f0f0;
  --tab-button-color: #1f2d3d;
  --tab-button-hover-bg: #dcdcdc;
  --tab-button-active-bg: #fff;
  --card-bg: #fff;
  --card-meta: #858585;
  --sidebar-bg: #f6f8fa;
  --sidebar-menu-bg: #fff;
  --btn-hover-color: #ff7242;
  --btn-color: #fff;
  --btn-bg: #49b1f5;
  --text-bg-hover: rgba(73,177,245,0.7);
  --light-grey: #eee;
  --dark-grey: #cacaca;
  --white: #fff;
  --text-highlight-color: #1f2d3d;
  --blockquote-color: #6a737d;
  --blockquote-bg: rgba(73,177,245,0.1);
  --reward-pop: #f5f5f5;
  --toc-link-color: #666261;
  --card-box-shadow: 0 3px 8px 6px rgba(7,17,27,0.05);
  --card-hover-box-shadow: 0 3px 8px 6px rgba(7,17,27,0.09);
  --pseudo-hover: #ff7242;
  --headline-presudo: #a0a0a0;
  --scrollbar-color: #49b1f5;
  --default-bg-color: #49b1f5;
  --zoom-bg: #fff;
  --mark-bg: rgba(0,0,0,0.3);
}
body {
  position: relative;
  overflow-y: scroll;
  min-height: 100%;
  background: var(--global-bg);
  color: var(--font-color);
  font-size: var(--global-font-size);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue', Lato, Roboto, 'PingFang SC', 'Microsoft YaHei', sans-serif;
  line-height: 2;
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  scroll-behavior: smooth;
}
@-moz-document url-prefix() {
  * {
    scrollbar-width: thin;
    scrollbar-color: var(--scrollbar-color) transparent;
  }
}
*::-webkit-scrollbar {
  width: 5px;
  height: 5px;
}
*::-webkit-scrollbar-thumb {
  background: var(--scrollbar-color);
}
*::-webkit-scrollbar-track {
  background-color: transparent;
}
input::placeholder {
  color: var(--font-color);
}
#web_bg {
  position: fixed;
  z-index: -999;
  width: 100%;
  height: 100%;
  background-attachment: local;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  position: relative;
  margin: 20px 0 14px;
  color: var(--text-highlight-color);
  font-weight: bold;
}
h1 code,
h2 code,
h3 code,
h4 code,
h5 code,
h6 code {
  font-size: inherit !important;
}
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.table-wrap {
  overflow-x: scroll;
  margin: 0 0 20px;
  border-radius: 5px;
}
.table-wrap table {
  border-radius: 5px;
}
.table-wrap table thead > tr:first-child th:first-child {
  border-top-left-radius: 5px;
}
.table-wrap table thead > tr:first-child th:last-child {
  border-top-right-radius: 5px;
}
.table-wrap table tbody > tr:last-child td:first-child {
  border-bottom-left-radius: 5px;
}
.table-wrap table tbody > tr:last-child td:last-child {
  border-bottom-right-radius: 5px;
}
table {
  display: table;
  width: 100%;
  border-spacing: 0;
  border-collapse: separate;
  border-top: 1px solid var(--light-grey);
  border-left: 1px solid var(--light-grey);
  empty-cells: show;
}
table thead {
  background: rgba(153,169,191,0.1);
}
table th,
table td {
  padding: 6px 12px;
  border: 1px solid var(--light-grey);
  border-top: none;
  border-left: none;
  vertical-align: middle;
}
*::selection {
  background: #00c4b6;
  color: #f7f7f7;
}
button {
  padding: 0;
  outline: 0;
  border: none;
  background: none;
  cursor: pointer;
  touch-action: manipulation;
}
a {
  color: #99a9bf;
  text-decoration: none;
  word-wrap: break-word;
  -webkit-transition: all 0.2s;
  -moz-transition: all 0.2s;
  -o-transition: all 0.2s;
  -ms-transition: all 0.2s;
  transition: all 0.2s;
  overflow-wrap: break-word;
}
a:hover {
  color: #49b1f5;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
img[src=''],
img:not([src]) {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
.img-alt {
  margin: -10px 0 10px;
  color: #858585;
}
.img-alt:hover {
  text-decoration: none !important;
}
blockquote {
  margin: 0 0 20px;
  padding: 7px 15px;
  border-left: 4px solid #49b1f5;
  background-color: var(--blockquote-bg);
  color: var(--blockquote-color);
  border-radius: 6px;
}
blockquote footer cite:before {
  padding: 0 5px;
  content: '—';
}
blockquote > :last-child {
  margin-bottom: 0 !important;
}
.fa-fw {
  width: 1.25em;
  text-align: center;
}
:root {
  --hl-color: #90a4ae;
  --hl-bg: #f6f8fa;
  --hltools-bg: #e6ebf1;
  --hltools-color: #90a4ae;
  --hlnumber-bg: #f6f8fa;
  --hlnumber-color: rgba(144,164,174,0.5);
  --hlscrollbar-bg: #dce4eb;
  --hlexpand-bg: linear-gradient(180deg, rgba(246,248,250,0.6), rgba(246,248,250,0.9));
}
[data-theme='dark'] {
  --hl-color: rgba(255,255,255,0.7);
  --hl-bg: #171717;
  --hltools-bg: #1a1a1a;
  --hltools-color: #90a4ae;
  --hlnumber-bg: #171717;
  --hlnumber-color: rgba(255,255,255,0.4);
  --hlscrollbar-bg: #1f1f1f;
  --hlexpand-bg: linear-gradient(180deg, rgba(23,23,23,0.6), rgba(23,23,23,0.9));
}
@-moz-document url-prefix() {
  scrollbar-color: var(--hlscrollbar-bg) transparent;
}
figure.highlight table::-webkit-scrollbar-thumb {
  background: var(--hlscrollbar-bg);
}
figure.highlight pre .deletion {
  color: #bf42bf;
}
figure.highlight pre .addition {
  color: #105ede;
}
figure.highlight pre .meta {
  color: #7c4dff;
}
figure.highlight pre .comment {
  color: rgba(149,165,166,0.8);
}
figure.highlight pre .variable,
figure.highlight pre .attribute,
figure.highlight pre .regexp,
figure.highlight pre .ruby .constant,
figure.highlight pre .xml .tag .title,
figure.highlight pre .xml .pi,
figure.highlight pre .xml .doctype,
figure.highlight pre .html .doctype,
figure.highlight pre .css .id,
figure.highlight pre .tag .name,
figure.highlight pre .css .class,
figure.highlight pre .css .pseudo {
  color: #e53935;
}
figure.highlight pre .tag {
  color: #39adb5;
}
figure.highlight pre .number,
figure.highlight pre .preprocessor,
figure.highlight pre .literal,
figure.highlight pre .params,
figure.highlight pre .constant,
figure.highlight pre .command {
  color: #f76d47;
}
figure.highlight pre .built_in {
  color: #ffb62c;
}
figure.highlight pre .ruby .class .title,
figure.highlight pre .css .rules .attribute,
figure.highlight pre .string,
figure.highlight pre .value,
figure.highlight pre .inheritance,
figure.highlight pre .header,
figure.highlight pre .ruby .symbol,
figure.highlight pre .xml .cdata,
figure.highlight pre .special,
figure.highlight pre .number,
figure.highlight pre .formula {
  color: #91b859;
}
figure.highlight pre .keyword,
figure.highlight pre .title,
figure.highlight pre .css .hexcolor {
  color: #39adb5;
}
figure.highlight pre .function,
figure.highlight pre .python .decorator,
figure.highlight pre .python .title,
figure.highlight pre .ruby .function .title,
figure.highlight pre .ruby .title .keyword,
figure.highlight pre .perl .sub,
figure.highlight pre .javascript .title,
figure.highlight pre .coffeescript .title {
  color: #6182b8;
}
figure.highlight pre .tag .attr,
figure.highlight pre .javascript .function {
  color: #7c4dff;
}
.container figure.highlight .line.marked {
  background-color: rgba(128,203,196,0.251);
}
.container figure.highlight table {
  display: block;
  overflow: auto;
  border: none;
}
.container figure.highlight table td {
  padding: 0;
  border: none;
}
.container figure.highlight .gutter pre {
  padding-right: 10px;
  padding-left: 10px;
  background-color: var(--hlnumber-bg);
  color: var(--hlnumber-color);
  text-align: right;
}
.container figure.highlight .code pre {
  padding-right: 10px;
  padding-left: 10px;
  width: 100%;
}
.container pre,
.container figure.highlight {
  overflow: auto;
  margin: 0 0 20px;
  padding: 0;
  background: var(--hl-bg);
  color: var(--hl-color);
  line-height: 1.6;
}
.container pre,
.container code {
  font-size: var(--global-font-size);
  font-family: consolas, Menlo, monospace, 'PingFang SC', 'Microsoft YaHei', sans-serif !important;
  border-radius: 6px;
}
.container code {
  padding: 2px 5px;
  background: rgba(27,31,35,0.05);
  color: #f47466;
}
.container pre {
  padding: 10px 20px;
}
.container pre code {
  padding: 0;
  background: none;
  color: var(--hl-color);
  text-shadow: none;
}
.container figure.highlight {
  position: relative;
  border-radius: 6px;
}
.container figure.highlight pre {
  margin: 0;
  padding: 8px 0;
  border: none;
}
.container figure.highlight figcaption,
.container figure.highlight .caption {
  padding: 6px 0 2px 14px;
  font-size: var(--global-font-size);
  line-height: 1em;
}
.container figure.highlight figcaption a,
.container figure.highlight .caption a {
  float: right;
  padding-right: 10px;
  color: var(--hl-color);
}
.container figure.highlight figcaption a:hover,
.container figure.highlight .caption a:hover {
  border-bottom-color: var(--hl-color);
}
.container figure.highlight.copy-true {
  -webkit-user-select: all;
  -moz-user-select: all;
  -ms-user-select: all;
  user-select: all;
  -webkit-user-select: all;
}
.container figure.highlight.copy-true > table,
.container figure.highlight.copy-true > pre {
  display: block !important;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
.container .highlight-tools {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  padding: 0 8px;
  min-height: 24px;
  height: 2.15em;
  background: var(--hltools-bg);
  color: var(--hltools-color);
  font-size: var(--global-font-size);
  overflow: hidden;
}
.container .highlight-tools > * {
  padding: 5px;
}
.container .highlight-tools i {
  cursor: pointer;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
.container .highlight-tools i:hover {
  color: #49b1f5;
}
.container .highlight-tools.closed ~ * {
  display: none;
}
.container .highlight-tools.closed .expand {
  -webkit-transform: rotate(-90deg);
  -moz-transform: rotate(-90deg);
  -o-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
.container .highlight-tools > .macStyle {
  padding: 0;
}
.container .highlight-tools .code-lang {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 1.15em;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-user-select: none;
  padding: 2px;
}
.container .highlight-tools .copy-notice {
  padding-right: 2px;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transition: opacity 0.4s;
  -moz-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  -ms-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
.container .highlight-tools .code-lang {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.container .gutter {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-user-select: none;
}
.container .gist table {
  width: auto;
}
.container .gist table td {
  border: none;
}
.article-sort {
  margin-left: 10px;
  padding-left: 20px;
  border-left: 2px solid #aadafa;
}
.article-sort-title {
  position: relative;
  margin-left: 10px;
  padding-bottom: 20px;
  padding-left: 20px;
  font-size: 1.72em;
}
.article-sort-title:hover:before {
  border-color: var(--pseudo-hover);
}
.article-sort-title:before {
  position: absolute;
  top: calc(((100% - 36px) / 2));
  left: -9px;
  z-index: 1;
  width: 10px;
  height: 10px;
  border: 5px solid #49b1f5;
  border-radius: 10px;
  background: var(--card-bg);
  content: '';
  line-height: 10px;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
.article-sort-title:after {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 0;
  width: 2px;
  height: 1.5em;
  background: #aadafa;
  content: '';
}
.article-sort-item {
  position: relative;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  margin: 0 0 20px 10px;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
.article-sort-item:hover:before {
  border-color: var(--pseudo-hover);
}
.article-sort-item:before {
  position: absolute;
  left: calc(-20px - 17px);
  width: 6px;
  height: 6px;
  border: 3px solid #49b1f5;
  border-radius: 6px;
  background: var(--card-bg);
  content: '';
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
.article-sort-item.no-article-cover {
  height: 80px;
}
.article-sort-item.no-article-cover .article-sort-item-info {
  padding: 0;
}
.article-sort-item.year {
  font-size: 1.43em;
  margin-bottom: 10px;
}
.article-sort-item.year:hover:before {
  border-color: #49b1f5;
}
.article-sort-item.year:before {
  border-color: var(--pseudo-hover);
}
.article-sort-item-time {
  color: var(--card-meta);
  font-size: 0.85em;
}
.article-sort-item-time time {
  padding-left: 6px;
  cursor: default;
}
.article-sort-item-title {
  color: var(--font-color);
  font-size: 1.05em;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-line-clamp: 2;
}
.article-sort-item-title:hover {
  color: #49b1f5;
  -webkit-transform: translateX(10px);
  -moz-transform: translateX(10px);
  -o-transform: translateX(10px);
  -ms-transform: translateX(10px);
  transform: translateX(10px);
}
.article-sort-item-img {
  overflow: hidden;
  width: 100px;
  height: 70px;
  border-radius: 6px;
}
@media screen and (max-width: 768px) {
  .article-sort-item-img {
    width: 70px;
    height: 70px;
  }
}
.article-sort-item-info {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: 0 16px;
}
.category-lists .category-title {
  font-size: 2.57em;
}
@media screen and (max-width: 768px) {
  .category-lists .category-title {
    font-size: 2em;
  }
}
.category-lists .category-list {
  margin-bottom: 0;
}
.category-lists .category-list a {
  color: var(--font-color);
}
.category-lists .category-list a:hover {
  color: #49b1f5;
}
.category-lists .category-list .category-list-count {
  margin-left: 8px;
  color: var(--card-meta);
}
.category-lists .category-list .category-list-count:before {
  content: '(';
}
.category-lists .category-list .category-list-count:after {
  content: ')';
}
.category-lists ul {
  padding: 0 0 0 20px;
}
.category-lists ul ul {
  padding-left: 4px;
}
.category-lists ul li {
  position: relative;
  margin: 6px 0;
  padding: 0.12em 0.4em 0.12em 1.4em;
}
#body-wrap {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-orient: vertical;
  -moz-box-orient: vertical;
  -o-box-orient: vertical;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  min-height: 100vh;
}
.layout {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1 auto;
  -ms-flex: 1 auto;
  flex: 1 auto;
  margin: 0 auto;
  padding: 40px 15px;
  max-width: 1200px;
  width: 100%;
}
@media screen and (max-width: 900px) {
  .layout {
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -o-box-orient: vertical;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
@media screen and (max-width: 768px) {
  .layout {
    padding: 20px 5px;
  }
}
@media screen and (min-width: 2000px) {
  .layout {
    max-width: 70%;
  }
}
.layout > div:first-child:not(.nc) {
  -webkit-align-self: flex-start;
  align-self: flex-start;
  -ms-flex-item-align: start;
  padding: 50px 40px;
}
@media screen and (max-width: 768px) {
  .layout > div:first-child:not(.nc) {
    padding: 36px 14px;
  }
}
.layout > div:first-child {
  width: 74%;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
@media screen and (max-width: 900px) {
  .layout > div:first-child {
    width: 100% !important;
  }
}
.layout.hide-aside {
  max-width: 1000px;
}
@media screen and (min-width: 2000px) {
  .layout.hide-aside {
    max-width: 1300px;
  }
}
.layout.hide-aside > div {
  width: 100% !important;
}
.apple #page-header.full_page {
  background-attachment: scroll !important;
}
.apple .recent-post-item,
.apple .avatar-img,
.apple .flink-item-icon {
  -webkit-transform: translateZ(0);
  -moz-transform: translateZ(0);
  -o-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
}
.container .flink {
  margin-bottom: 20px;
}
.container .flink .flink-list {
  overflow: auto;
  padding: 10px 10px 0;
  text-align: center;
}
.container .flink .flink-list > .flink-list-item {
  position: relative;
  float: left;
  overflow: hidden;
  margin: 15px 7px;
  width: calc(100% / 3 - 15px);
  height: 90px;
  line-height: 17px;
  -webkit-transform: translateZ(0);
  border-radius: 8px;
}
@media screen and (max-width: 1024px) {
  .container .flink .flink-list > .flink-list-item {
    width: calc(50% - 15px) !important;
  }
}
@media screen and (max-width: 600px) {
  .container .flink .flink-list > .flink-list-item {
    width: calc(100% - 15px) !important;
  }
}
.container .flink .flink-list > .flink-list-item:hover .flink-item-icon {
  margin-left: -10px;
  width: 0;
}
.container .flink .flink-list > .flink-list-item:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  background: var(--text-bg-hover);
  content: '';
  -webkit-transition: -webkit-transform 0.3s ease-out;
  -moz-transition: -moz-transform 0.3s ease-out;
  -o-transition: -o-transform 0.3s ease-out;
  -ms-transition: -ms-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  -webkit-transform: scale(0);
  -moz-transform: scale(0);
  -o-transform: scale(0);
  -ms-transform: scale(0);
  transform: scale(0);
}
.container .flink .flink-list > .flink-list-item:hover:before,
.container .flink .flink-list > .flink-list-item:focus:before,
.container .flink .flink-list > .flink-list-item:active:before {
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -o-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
}
.container .flink .flink-list > .flink-list-item a {
  color: var(--font-color);
  text-decoration: none;
}
.container .flink .flink-list > .flink-list-item a .flink-item-icon {
  float: left;
  overflow: hidden;
  margin: 15px 10px;
  width: 60px;
  height: 60px;
  border-radius: 7px;
  -webkit-transition: width 0.3s ease-out;
  -moz-transition: width 0.3s ease-out;
  -o-transition: width 0.3s ease-out;
  -ms-transition: width 0.3s ease-out;
  transition: width 0.3s ease-out;
}
.container .flink .flink-list > .flink-list-item a .flink-item-icon img {
  width: 100%;
  height: 100%;
  -webkit-transition: filter 375ms ease-in 0.2s, -webkit-transform 0.3s;
  -moz-transition: filter 375ms ease-in 0.2s, -moz-transform 0.3s;
  -o-transition: filter 375ms ease-in 0.2s, -o-transform 0.3s;
  -ms-transition: filter 375ms ease-in 0.2s, -ms-transform 0.3s;
  transition: filter 375ms ease-in 0.2s, transform 0.3s;
  object-fit: cover;
}
.container .flink .flink-list > .flink-list-item a .img-alt {
  display: none;
}
.container .flink .flink-item-name {
  padding: 16px 10px 0 0;
  height: 40px;
  font-weight: bold;
  font-size: 1.43em;
}
.container .flink .flink-item-desc {
  padding: 16px 10px 16px 0;
  height: 50px;
  font-size: 0.93em;
}
.container .flink .flink-name {
  margin-bottom: 5px;
  font-weight: bold;
  font-size: 1.5em;
}
#recent-posts .recent-post-item {
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-orient: horizontal;
  -moz-box-orient: horizontal;
  -o-box-orient: horizontal;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  height: 16.8em;
}
@media screen and (max-width: 768px) {
  #recent-posts .recent-post-item {
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -o-box-orient: vertical;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    height: auto;
  }
}
@media screen and (min-width: 2000px) {
  #recent-posts .recent-post-item {
    height: 18.8em;
  }
}
#recent-posts .recent-post-item:hover .post-bg {
  -webkit-transform: scale(1.1);
  -moz-transform: scale(1.1);
  -o-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
#recent-posts .recent-post-item.ads-wrap {
  display: block !important;
  height: auto !important;
}
#recent-posts .recent-post-item .post_cover {
  overflow: hidden;
  width: 42%;
  height: 100%;
}
@media screen and (max-width: 768px) {
  #recent-posts .recent-post-item .post_cover {
    width: 100%;
    height: 230px;
  }
}
#recent-posts .recent-post-item .post_cover.right {
  -webkit-box-ordinal-group: 1;
  -moz-box-ordinal-group: 1;
  -o-box-ordinal-group: 1;
  -ms-flex-order: 1;
  -webkit-order: 1;
  order: 1;
}
@media screen and (max-width: 768px) {
  #recent-posts .recent-post-item .post_cover.right {
    -webkit-box-ordinal-group: 0;
    -moz-box-ordinal-group: 0;
    -o-box-ordinal-group: 0;
    -ms-flex-order: 0;
    -webkit-order: 0;
    order: 0;
  }
}
#recent-posts .recent-post-item .post_cover .post-bg {
  z-index: -4;
}
#recent-posts .recent-post-item >.recent-post-info {
  padding: 0 40px;
  width: 58%;
}
@media screen and (max-width: 768px) {
  #recent-posts .recent-post-item >.recent-post-info {
    padding: 20px 20px 30px;
    width: 100%;
  }
}
#recent-posts .recent-post-item >.recent-post-info.no-cover {
  width: 100%;
}
@media screen and (max-width: 768px) {
  #recent-posts .recent-post-item >.recent-post-info.no-cover {
    padding: 30px 20px;
  }
}
#recent-posts .recent-post-item >.recent-post-info > .article-title {
  color: var(--text-highlight-color);
  font-size: 1.55em;
  line-height: 1.4;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  -webkit-line-clamp: 2;
}
#recent-posts .recent-post-item >.recent-post-info > .article-title .sticky {
  margin-right: 10px;
  color: #ff7242;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  #recent-posts .recent-post-item >.recent-post-info > .article-title {
    font-size: 1.43em;
  }
}
#recent-posts .recent-post-item >.recent-post-info > .article-title:hover {
  color: #49b1f5;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap {
  margin: 6px 0;
  color: var(--card-meta);
  font-size: 0.9em;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap > .post-meta-date {
  cursor: default;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap i {
  margin: 0 4px 0 0;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap .fa-spinner {
  margin: 0;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap .article-meta-label {
  padding-right: 4px;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap .article-meta-separator {
  margin: 0 6px;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap .article-meta-link {
  margin: 0 4px;
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap a {
  color: var(--card-meta);
}
#recent-posts .recent-post-item >.recent-post-info > .article-meta-wrap a:hover {
  color: #49b1f5;
  text-decoration: underline;
}
#recent-posts .recent-post-item >.recent-post-info > .content {
  -webkit-line-clamp: 2;
  word-break: break-word;
}
#article-container .shuoshuo-item {
  margin-bottom: 20px;
  padding: 35px 30px 30px;
}
@media screen and (max-width: 768px) {
  #article-container .shuoshuo-item {
    padding: 25px 20px 20px;
  }
}
#article-container .shuoshuo-item-header {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  cursor: default;
}
#article-container .shuoshuo-avatar {
  overflow: hidden;
  width: 40px;
  height: 40px;
  border-radius: 40px;
}
#article-container .shuoshuo-avatar img {
  margin: 0;
  width: 100%;
  height: 100%;
}
#article-container .shuoshuo-info {
  margin-left: 10px;
  line-height: 1.5;
}
#article-container .shuoshuo-date {
  color: #858585;
  font-size: 0.8em;
}
#article-container .shuoshuo-content {
  padding: 15px 0 10px;
}
#article-container .shuoshuo-content > *:last-child {
  margin-bottom: 0;
}
#article-container .shuoshuo-footer {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
#article-container .shuoshuo-footer.flex-between {
  -webkit-box-pack: justify;
  -moz-box-pack: justify;
  -o-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
#article-container .shuoshuo-footer.flex-end {
  -webkit-box-pack: end;
  -moz-box-pack: end;
  -o-box-pack: end;
  -ms-flex-pack: end;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}
#article-container .shuoshuo-footer .shuoshuo-tag {
  display: inline-block;
  margin-right: 8px;
  padding: 0 8px;
  width: fit-content;
  border: 1px solid #49b1f5;
  border-radius: 12px;
  color: #49b1f5;
  font-size: 0.85em;
  cursor: default;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
#article-container .shuoshuo-footer .shuoshuo-tag:hover {
  background: #49b1f5;
  color: var(--white);
}
#article-container .shuoshuo-footer .shuoshuo-comment-btn {
  padding: 2px;
  color: #90a4ae;
  cursor: pointer;
}
#article-container .shuoshuo-footer .shuoshuo-comment-btn:hover {
  color: #49b1f5;
}
#article-container .shuoshuo-comment {
  padding-top: 10px;
}
#article-container .shuoshuo-comment.no-comment {
  display: none;
}
.tag-cloud-list a {
  display: inline-block;
  margin: 2px;
  padding: 2px 7px;
  line-height: 1.7;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
  border-radius: 5px;
}
.tag-cloud-list a:hover {
  background: var(--btn-bg) !important;
  -webkit-box-shadow: 2px 2px 6px rgba(0,0,0,0.2);
  box-shadow: 2px 2px 6px rgba(0,0,0,0.2);
  color: var(--btn-color) !important;
}
@media screen and (max-width: 768px) {
  .tag-cloud-list a {
    zoom: 0.85;
  }
}
.tag-cloud-title {
  font-size: 2.57em;
}
@media screen and (max-width: 768px) {
  .tag-cloud-title {
    font-size: 2em;
  }
}
.page-title + .tag-cloud-list {
  text-align: left;
}
#aside-content {
  width: 26%;
}
@media screen and (min-width: 900px) {
  #aside-content {
    padding-left: 15px;
  }
}
@media screen and (max-width: 900px) {
  #aside-content {
    margin-top: 20px;
    width: 100%;
  }
}
#aside-content .card-widget {
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
  padding: 20px 24px;
}
#aside-content .card-info .author-info-name {
  font-weight: 500;
  font-size: 1.57em;
}
#aside-content .card-info .author-info-description {
  margin-top: -0.42em;
}
#aside-content .card-info .site-data {
  margin: 14px 0 4px;
}
#aside-content .card-info .card-info-social-icons {
  margin: 6px 0 -6px;
}
#aside-content .card-info .card-info-social-icons .social-icon {
  margin: 0 10px;
  color: var(--font-color);
  font-size: 1.4em;
}
#aside-content .card-info .card-info-social-icons i {
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
#aside-content .card-info .card-info-social-icons i:hover {
  -webkit-transform: rotate(360deg);
  -moz-transform: rotate(360deg);
  -o-transform: rotate(360deg);
  -ms-transform: rotate(360deg);
  transform: rotate(360deg);
}
#aside-content .card-info #card-info-btn {
  display: block;
  margin-top: 14px;
  background-color: var(--btn-bg);
  color: var(--btn-color);
  text-align: center;
  line-height: 2.4;
  border-radius: 7px;
}
#aside-content .card-info #card-info-btn:hover {
  background-color: var(--btn-hover-color);
}
#aside-content .card-info #card-info-btn span {
  padding-left: 10px;
}
#aside-content .item-headline {
  padding-bottom: 6px;
  font-size: 1.2em;
}
#aside-content .item-headline span {
  margin-left: 6px;
}
@media screen and (min-width: 900px) {
  #aside-content .sticky_layout {
    position: sticky;
    position: -webkit-sticky;
    top: 20px;
    -webkit-transition: top 0.3s;
    -moz-transition: top 0.3s;
    -o-transition: top 0.3s;
    -ms-transition: top 0.3s;
    transition: top 0.3s;
  }
}
#aside-content .card-tag-cloud a {
  display: inline-block;
  padding: 0 4px;
  line-height: 1.8;
}
#aside-content .card-tag-cloud a:hover {
  color: #49b1f5 !important;
}
#aside-content .aside-list > span {
  display: block;
  margin-bottom: 10px;
  text-align: center;
}
#aside-content .aside-list > .aside-list-item {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  padding: 6px 0;
}
#aside-content .aside-list > .aside-list-item:first-child {
  padding-top: 0;
}
#aside-content .aside-list > .aside-list-item:not(:last-child) {
  border-bottom: 1px dashed #f5f5f5;
}
#aside-content .aside-list > .aside-list-item:last-child {
  padding-bottom: 0;
}
#aside-content .aside-list > .aside-list-item .thumbnail {
  overflow: hidden;
  width: 4em;
  height: 4em;
  border-radius: 6px;
}
#aside-content .aside-list > .aside-list-item .content {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-left: 10px;
  word-break: break-all;
}
#aside-content .aside-list > .aside-list-item .content > .name {
  -webkit-line-clamp: 1;
}
#aside-content .aside-list > .aside-list-item .content > time,
#aside-content .aside-list > .aside-list-item .content > .name {
  display: block;
  color: var(--card-meta);
  font-size: 0.85em;
}
#aside-content .aside-list > .aside-list-item .content > .title,
#aside-content .aside-list > .aside-list-item .content > .comment {
  color: var(--font-color);
  line-height: 1.5;
  -webkit-line-clamp: 2;
}
#aside-content .aside-list > .aside-list-item .content > .title:hover,
#aside-content .aside-list > .aside-list-item .content > .comment:hover {
  color: #49b1f5;
}
#aside-content .aside-list > .aside-list-item.no-cover {
  min-height: 4.4em;
}
#aside-content .card-archives ul.card-archive-list,
#aside-content .card-categories ul.card-category-list {
  margin: 0;
  padding: 0;
  list-style: none;
}
#aside-content .card-archives ul.card-archive-list > .card-archive-list-item a,
#aside-content .card-categories ul.card-category-list > .card-category-list-item a {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-orient: horizontal;
  -moz-box-orient: horizontal;
  -o-box-orient: horizontal;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  margin: 2px 0;
  padding: 2px 8px;
  color: var(--font-color);
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
  border-radius: 6px;
}
#aside-content .card-archives ul.card-archive-list > .card-archive-list-item a:hover,
#aside-content .card-categories ul.card-category-list > .card-category-list-item a:hover {
  padding: 2px 12px;
  background-color: var(--text-bg-hover);
  color: var(--white);
}
#aside-content .card-archives ul.card-archive-list > .card-archive-list-item a span:first-child,
#aside-content .card-categories ul.card-category-list > .card-category-list-item a span:first-child {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
#aside-content .card-categories .card-category-list.child {
  padding: 0 0 0 16px;
}
#aside-content .card-categories .card-category-list > .parent > a.expand i {
  -webkit-transform: rotate(-90deg);
  -moz-transform: rotate(-90deg);
  -o-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
#aside-content .card-categories .card-category-list > .parent > a.expand + .child {
  display: block;
}
#aside-content .card-categories .card-category-list > .parent > a .card-category-list-name {
  width: 70% !important;
}
#aside-content .card-categories .card-category-list > .parent > a .card-category-list-count {
  width: calc(100% - 70% - 20px);
  text-align: right;
}
#aside-content .card-categories .card-category-list > .parent > a i {
  float: right;
  margin-right: -0.5em;
  padding: 0.5em;
  -webkit-transition: -webkit-transform 0.3s;
  -moz-transition: -moz-transform 0.3s;
  -o-transition: -o-transform 0.3s;
  -ms-transition: -ms-transform 0.3s;
  transition: transform 0.3s;
  -webkit-transform: rotate(0);
  -moz-transform: rotate(0);
  -o-transform: rotate(0);
  -ms-transform: rotate(0);
  transform: rotate(0);
}
#aside-content .card-webinfo .webinfo .webinfo-item {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  padding: 2px 10px 0;
}
#aside-content .card-webinfo .webinfo .webinfo-item div:first-child {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-right: 20px;
}
@media screen and (min-width: 901px) {
  #aside-content #card-toc {
    right: 0 !important;
  }
}
@media screen and (max-width: 900px) {
  #aside-content #card-toc {
    position: fixed;
    right: 55px;
    bottom: 30px;
    z-index: 100;
    max-width: 380px;
    max-height: calc(100% - 60px);
    width: calc(100% - 80px);
    -webkit-transition: none;
    -moz-transition: none;
    -o-transition: none;
    -ms-transition: none;
    transition: none;
    -webkit-transform: scale(0);
    -moz-transform: scale(0);
    -o-transform: scale(0);
    -ms-transform: scale(0);
    transform: scale(0);
    -webkit-transform-origin: right bottom;
    -moz-transform-origin: right bottom;
    -o-transform-origin: right bottom;
    -ms-transform-origin: right bottom;
    transform-origin: right bottom;
  }
  #aside-content #card-toc.open {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
#aside-content #card-toc .toc-percentage {
  float: right;
  margin-top: -9px;
  color: #a9a9a9;
  font-style: italic;
  font-size: 140%;
}
#aside-content #card-toc .toc-content {
  overflow-y: scroll;
  overflow-y: overlay;
  margin: 0 -24px;
  max-height: calc(100vh - 120px);
  width: calc(100% + 48px);
}
@media screen and (max-width: 900px) {
  #aside-content #card-toc .toc-content {
    max-height: calc(100vh - 140px);
  }
}
#aside-content #card-toc .toc-content > * {
  margin: 0 20px !important;
}
#aside-content #card-toc .toc-content > * > .toc-item > .toc-child {
  margin-left: 10px;
  padding-left: 10px;
  border-left: 1px solid var(--dark-grey);
}
#aside-content #card-toc .toc-content:not(.is-expand) .toc-child {
  display: none;
}
@media screen and (max-width: 900px) {
  #aside-content #card-toc .toc-content:not(.is-expand) .toc-child {
    display: block !important;
  }
}
#aside-content #card-toc .toc-content:not(.is-expand) .toc-item.active .toc-child {
  display: block;
}
#aside-content #card-toc .toc-content ol,
#aside-content #card-toc .toc-content li {
  list-style: none;
}
#aside-content #card-toc .toc-content > ol {
  padding: 0 !important;
}
#aside-content #card-toc .toc-content ol {
  margin: 0;
  padding-left: 18px;
}
#aside-content #card-toc .toc-content .toc-link {
  display: block;
  margin: 4px 0;
  padding: 1px 8px;
  color: var(--toc-link-color);
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  border-radius: 6px;
}
#aside-content #card-toc .toc-content .toc-link:hover {
  color: #49b1f5;
}
#aside-content #card-toc .toc-content .toc-link.active {
  background: #00c4b6;
  color: #fff;
}
#aside-content .sticky_layout:only-child > :first-child {
  margin-top: 0;
}
#aside-content .card-more-btn {
  float: right;
  color: inherit;
}
#aside-content .card-more-btn:hover {
  -webkit-animation: more-btn-move 1s infinite;
  -moz-animation: more-btn-move 1s infinite;
  -o-animation: more-btn-move 1s infinite;
  -ms-animation: more-btn-move 1s infinite;
  animation: more-btn-move 1s infinite;
}
#aside-content .card-announcement .item-headline i {
  color: #f00;
}
#aside-content .card-announcement .announcement_content {
  white-space: pre-line;
}
.avatar-img {
  overflow: hidden;
  margin: 0 auto;
  width: 110px;
  height: 110px;
  border-radius: 70px;
}
.avatar-img img {
  width: 100%;
  height: 100%;
  -webkit-transition: filter 375ms ease-in 0.2s, -webkit-transform 0.3s;
  -moz-transition: filter 375ms ease-in 0.2s, -moz-transform 0.3s;
  -o-transition: filter 375ms ease-in 0.2s, -o-transform 0.3s;
  -ms-transition: filter 375ms ease-in 0.2s, -ms-transform 0.3s;
  transition: filter 375ms ease-in 0.2s, transform 0.3s;
  object-fit: cover;
}
.avatar-img img:hover {
  -webkit-transform: rotate(360deg);
  -moz-transform: rotate(360deg);
  -o-transform: rotate(360deg);
  -ms-transform: rotate(360deg);
  transform: rotate(360deg);
}
.site-data {
  display: table;
  width: 100%;
  table-layout: fixed;
}
.site-data > a {
  display: table-cell;
}
.site-data > a div {
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
.site-data > a:hover div {
  color: #49b1f5 !important;
}
.site-data > a .headline {
  color: var(--font-color);
  font-size: 0.95em;
}
.site-data > a .length-num {
  margin-top: -0.45em;
  color: var(--text-highlight-color);
  font-size: 1.2em;
}
@media screen and (min-width: 900px) {
  html.hide-aside .layout {
    -webkit-box-pack: center;
    -moz-box-pack: center;
    -o-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
  }
  html.hide-aside .layout > .aside-content {
    display: none;
  }
  html.hide-aside .layout > div:first-child {
    width: 80%;
  }
}
.page .sticky_layout {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-orient: vertical;
  -moz-box-orient: vertical;
  -o-box-orient: vertical;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
}
@-moz-keyframes more-btn-move {
  0%, 100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(3px);
    -moz-transform: translateX(3px);
    -o-transform: translateX(3px);
    -ms-transform: translateX(3px);
    transform: translateX(3px);
  }
}
@-webkit-keyframes more-btn-move {
  0%, 100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(3px);
    -moz-transform: translateX(3px);
    -o-transform: translateX(3px);
    -ms-transform: translateX(3px);
    transform: translateX(3px);
  }
}
@-o-keyframes more-btn-move {
  0%, 100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(3px);
    -moz-transform: translateX(3px);
    -o-transform: translateX(3px);
    -ms-transform: translateX(3px);
    transform: translateX(3px);
  }
}
@keyframes more-btn-move {
  0%, 100% {
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
  50% {
    -webkit-transform: translateX(3px);
    -moz-transform: translateX(3px);
    -o-transform: translateX(3px);
    -ms-transform: translateX(3px);
    transform: translateX(3px);
  }
}
@-moz-keyframes toc-open {
  0% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-webkit-keyframes toc-open {
  0% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-o-keyframes toc-open {
  0% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes toc-open {
  0% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-moz-keyframes toc-close {
  0% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
@-webkit-keyframes toc-close {
  0% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
@-o-keyframes toc-close {
  0% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
@keyframes toc-close {
  0% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
  100% {
    -webkit-transform: scale(0.7);
    -moz-transform: scale(0.7);
    -o-transform: scale(0.7);
    -ms-transform: scale(0.7);
    transform: scale(0.7);
  }
}
#post-comment .comment-head {
  margin-bottom: 20px;
}
#post-comment .comment-head:after {
  display: block;
  clear: both;
  content: '';
}
#post-comment .comment-head .comment-headline {
  display: inline-block;
  vertical-align: middle;
  font-weight: 700;
  font-size: 1.43em;
}
#post-comment .comment-head .comment-switch {
  display: inline-block;
  float: right;
  margin: 2px auto 0;
  padding: 4px 16px;
  width: max-content;
  border-radius: 8px;
  background: #f6f8fa;
}
#post-comment .comment-head .comment-switch .first-comment {
  color: #49b1f5;
}
#post-comment .comment-head .comment-switch .second-comment {
  color: #ff7242;
}
#post-comment .comment-head .comment-switch #switch-btn {
  position: relative;
  display: inline-block;
  margin: -4px 8px 0;
  width: 42px;
  height: 22px;
  border-radius: 34px;
  background-color: #49b1f5;
  vertical-align: middle;
  cursor: pointer;
  -webkit-transition: 0.4s;
  -moz-transition: 0.4s;
  -o-transition: 0.4s;
  -ms-transition: 0.4s;
  transition: 0.4s;
}
#post-comment .comment-head .comment-switch #switch-btn:before {
  position: absolute;
  bottom: 4px;
  left: 4px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background-color: #fff;
  content: '';
  -webkit-transition: 0.4s;
  -moz-transition: 0.4s;
  -o-transition: 0.4s;
  -ms-transition: 0.4s;
  transition: 0.4s;
}
#post-comment .comment-wrap > div {
  -webkit-animation: tabshow 0.5s;
  -moz-animation: tabshow 0.5s;
  -o-animation: tabshow 0.5s;
  -ms-animation: tabshow 0.5s;
  animation: tabshow 0.5s;
}
#post-comment .comment-wrap > div:nth-child(2) {
  display: none;
}
#post-comment.move #switch-btn {
  background-color: #ff7242;
}
#post-comment.move #switch-btn:before {
  -webkit-transform: translateX(20px);
  -moz-transform: translateX(20px);
  -o-transform: translateX(20px);
  -ms-transform: translateX(20px);
  transform: translateX(20px);
}
#post-comment.move .comment-wrap > div:first-child {
  display: none;
}
#post-comment.move .comment-wrap > div:last-child {
  display: block;
}
#footer {
  position: relative;
  background-color: #49b1f5;
  background-attachment: scroll;
  background-position: bottom;
  background-size: cover;
}
#footer > * {
  position: relative;
  color: var(--light-grey);
}
#footer a {
  color: var(--light-grey);
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
#footer a:hover {
  color: #49b1f5;
}
#footer .footer-separator {
  margin: 0 4px;
}
#footer .icp-icon {
  padding: 0 4px;
  max-height: 1.4em;
  width: auto;
  vertical-align: text-bottom;
}
#footer .footer-flex {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-orient: horizontal;
  -moz-box-orient: horizontal;
  -o-box-orient: horizontal;
  -webkit-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -o-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -moz-box-pack: justify;
  -o-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin: 0 auto;
  padding: 40px 60px;
  max-width: 1200px;
  width: 100%;
  text-align: left;
  gap: 13px;
}
@media screen and (max-width: 768px) {
  #footer .footer-flex {
    padding: 30px;
    gap: 10px;
  }
}
#footer .footer-flex .footer-flex-items {
  -webkit-flex-shrink: 0;
  flex-shrink: 0;
  min-width: 100px;
  text-align: left;
  white-space: nowrap;
}
#footer .footer-flex .footer-flex-title {
  margin-bottom: 5px;
  white-space: nowrap;
  font-weight: 600;
  font-size: 1.4em;
}
#footer .footer-flex .footer-flex-item {
  margin: 10px 0;
  white-space: nowrap;
}
#footer .footer-flex a {
  display: block;
  white-space: nowrap;
}
#footer .footer-other {
  padding: 40px 20px;
  width: 100%;
  text-align: center;
}
#footer .footer-other .framework-info {
  display: block;
}
#page-header {
  position: relative;
  width: 100%;
  background-color: #49b1f5;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
}
#page-header.full_page {
  height: 100vh;
  background-attachment: fixed;
}
#page-header.full_page #site-info {
  position: absolute;
  top: 43%;
  padding: 0 10px;
  width: 100%;
}
#page-header #site-title,
#page-header #site-subtitle,
#page-header #scroll-down .scroll-down-effects {
  text-align: center;
  text-shadow: 2px 2px 4px rgba(0,0,0,0.15);
  line-height: 1.5;
}
#page-header #site-title {
  margin: 0;
  color: var(--white);
  font-size: 1.85em;
}
@media screen and (min-width: 768px) {
  #page-header #site-title {
    font-size: 2.85em;
  }
}
#page-header #site-subtitle {
  color: var(--light-grey);
  font-size: 1.15em;
}
@media screen and (min-width: 768px) {
  #page-header #site-subtitle {
    font-size: 1.72em;
  }
}
#page-header #site_social_icons {
  display: none;
  margin: 0 auto;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #page-header #site_social_icons {
    display: block;
  }
}
#page-header #site_social_icons .social-icon {
  margin: 0 10px;
  color: var(--light-grey);
  text-shadow: 2px 2px 4px rgba(0,0,0,0.15);
  font-size: 1.43em;
}
#page-header #scroll-down {
  position: absolute;
  bottom: 10px;
  width: 100%;
  cursor: pointer;
}
#page-header #scroll-down .scroll-down-effects {
  position: relative;
  width: 100%;
  color: var(--light-grey);
  font-size: 20px;
}
#page-header.not-home-page {
  height: 400px;
}
@media screen and (max-width: 768px) {
  #page-header.not-home-page {
    height: 280px;
  }
}
#page-header #page-site-info {
  position: absolute;
  top: 200px;
  padding: 0 10px;
  width: 100%;
}
@media screen and (max-width: 768px) {
  #page-header #page-site-info {
    top: 140px;
  }
}
#page-header.post-bg {
  height: 400px;
}
@media screen and (max-width: 768px) {
  #page-header.post-bg {
    height: 360px;
  }
}
#page-header #post-info {
  position: absolute;
  width: 100%;
  top: calc(50% + 30px);
  padding: 0 8%;
  text-align: center;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  #page-header #post-info {
    padding: 0 15px;
  }
}
#page-header.not-top-img {
  margin-bottom: 10px;
  height: 60px;
  background: 0;
}
#page-header.not-top-img .title-seo {
  display: none;
}
#page-header.not-top-img #nav {
  background: rgba(255,255,255,0.8);
  -webkit-box-shadow: 0 5px 6px -5px rgba(133,133,133,0.6);
  box-shadow: 0 5px 6px -5px rgba(133,133,133,0.6);
}
#page-header.not-top-img #nav a,
#page-header.not-top-img #nav span.site-page,
#page-header.not-top-img #nav .site-name {
  color: var(--font-color);
  text-shadow: none;
}
#page-header.nav-fixed #nav {
  position: fixed;
  top: 0;
  z-index: 91;
  background: rgba(255,255,255,0.7);
  -webkit-box-shadow: 0 5px 6px -5px rgba(133,133,133,0.6);
  box-shadow: 0 5px 6px -5px rgba(133,133,133,0.6);
  -webkit-transition: -webkit-transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  -moz-transition: -moz-transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  -o-transition: -o-transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  -ms-transition: -ms-transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  will-change: transform;
  backdrop-filter: none;
}
#page-header.nav-fixed #nav #blog-info {
  color: var(--font-color);
}
#page-header.nav-fixed #nav #blog-info:hover {
  color: #49b1f5;
}
#page-header.nav-fixed #nav #blog-info .site-name {
  text-shadow: none;
}
#page-header.nav-fixed #nav #blog-info > a:first-child {
  display: none;
}
#page-header.nav-fixed #nav #blog-info > a:last-child {
  display: inline;
}
#page-header.nav-fixed #nav a,
#page-header.nav-fixed #nav span.site-page,
#page-header.nav-fixed #nav #toggle-menu {
  color: var(--font-color);
  text-shadow: none;
}
#page-header.nav-fixed #nav a:hover,
#page-header.nav-fixed #nav span.site-page:hover,
#page-header.nav-fixed #nav #toggle-menu:hover {
  color: #49b1f5;
}
#page-header.fixed #nav {
  position: fixed;
  top: 0;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
}
#page-header.nav-visible:not(.fixed) #nav {
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
  -webkit-transform: translate3d(0, 100%, 0);
  -moz-transform: translate3d(0, 100%, 0);
  -o-transform: translate3d(0, 100%, 0);
  -ms-transform: translate3d(0, 100%, 0);
  transform: translate3d(0, 100%, 0);
}
#page-header.nav-visible:not(.fixed) + .layout > .aside-content > .sticky_layout {
  top: 70px;
  -webkit-transition: top 0.5s;
  -moz-transition: top 0.5s;
  -o-transition: top 0.5s;
  -ms-transition: top 0.5s;
  transition: top 0.5s;
}
#page-header.fixed #nav {
  position: fixed;
}
#page-header.fixed + .layout > .aside-content > .sticky_layout {
  top: 70px;
  -webkit-transition: top 0.5s;
  -moz-transition: top 0.5s;
  -o-transition: top 0.5s;
  -ms-transition: top 0.5s;
  transition: top 0.5s;
}
#page-header.fixed + .layout #card-toc .toc-content {
  max-height: calc(100vh - 170px);
}
#page .page-title {
  margin: 0 0 10px;
  font-weight: bold;
  font-size: 2em;
}
#post > #post-info {
  margin-bottom: 30px;
}
#post > #post-info .post-title {
  padding-bottom: 4px;
  border-bottom: 1px solid var(--light-grey);
  color: var(--text-highlight-color);
}
#post > #post-info .post-title .post-edit-link {
  float: right;
}
#post > #post-info #post-meta,
#post > #post-info #post-meta a {
  color: #78818a;
}
#post-info .post-title {
  margin-bottom: 8px;
  color: var(--white);
  font-weight: normal;
  font-size: 2.5em;
  line-height: 1.5;
  -webkit-line-clamp: 3;
}
@media screen and (max-width: 768px) {
  #post-info .post-title {
    font-size: 2.1em;
  }
}
#post-info .post-title .post-edit-link {
  padding-left: 10px;
}
#post-info #post-meta {
  color: var(--light-grey);
  font-size: 95%;
}
@media screen and (min-width: 768px) {
  #post-info #post-meta > .meta-secondline > span:first-child {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  #post-info #post-meta {
    font-size: 90%;
  }
  #post-info #post-meta > .meta-firstline,
  #post-info #post-meta > .meta-secondline {
    display: inline;
  }
}
#post-info #post-meta .post-meta-separator {
  margin: 0 5px;
}
#post-info #post-meta .post-meta-icon {
  margin-right: 4px;
}
#post-info #post-meta .post-meta-label {
  margin-right: 4px;
}
#post-info #post-meta a {
  color: var(--light-grey);
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  -o-transition: all 0.3s ease-out;
  -ms-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
#post-info #post-meta a:hover {
  color: #49b1f5;
  text-decoration: underline;
}
#nav {
  position: fixed;
  top: 0;
  z-index: 90;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  padding: 0 36px;
  width: 100%;
  height: 60px;
  font-size: 1.3em;
  opacity: 1;
  -ms-filter: none;
  filter: none;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
}
@media screen and (max-width: 768px) {
  #nav {
    padding: 0 16px;
  }
}
#nav.show {
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
#nav #blog-info {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  color: var(--light-grey);
}
#nav #blog-info .site-icon {
  margin-right: 6px;
  height: 36px;
  vertical-align: middle;
}
#nav #blog-info .nav-page-title {
  display: none;
}
#nav #toggle-menu {
  display: none;
  padding: 2px 0 0 6px;
  vertical-align: top;
}
#nav #toggle-menu:hover {
  color: var(--white);
}
#nav a,
#nav span.site-page {
  color: var(--light-grey);
}
#nav a:hover,
#nav span.site-page:hover {
  color: var(--white);
}
#nav .site-name {
  text-shadow: 2px 2px 4px rgba(0,0,0,0.15);
  font-weight: bold;
}
#nav .menus_items {
  display: inline;
}
#nav .menus_items .menus_item {
  position: relative;
  display: inline-block;
  padding: 0 0 0 14px;
}
#nav .menus_items .menus_item:hover .menus_item_child {
  display: block;
}
#nav .menus_items .menus_item:hover > span > i:last-child {
  -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  -o-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg);
}
#nav .menus_items .menus_item > span > i:last-child {
  padding: 4px;
  -webkit-transition: -webkit-transform 0.3s;
  -moz-transition: -moz-transform 0.3s;
  -o-transition: -o-transform 0.3s;
  -ms-transition: -ms-transform 0.3s;
  transition: transform 0.3s;
}
#nav .menus_items .menus_item .menus_item_child {
  position: absolute;
  right: 0;
  display: none;
  margin-top: 8px;
  padding: 0;
  width: max-content;
  background-color: var(--sidebar-bg);
  -webkit-box-shadow: 0 5px 20px -4px rgba(0,0,0,0.5);
  box-shadow: 0 5px 20px -4px rgba(0,0,0,0.5);
  -webkit-animation: sub_menus 0.3s 0.1s ease both;
  -moz-animation: sub_menus 0.3s 0.1s ease both;
  -o-animation: sub_menus 0.3s 0.1s ease both;
  -ms-animation: sub_menus 0.3s 0.1s ease both;
  animation: sub_menus 0.3s 0.1s ease both;
  border-radius: 5px;
}
#nav .menus_items .menus_item .menus_item_child:before {
  position: absolute;
  top: -8px;
  left: 0;
  width: 100%;
  height: 20px;
  content: '';
}
#nav .menus_items .menus_item .menus_item_child li {
  list-style: none;
}
#nav .menus_items .menus_item .menus_item_child li:hover {
  background: var(--text-bg-hover);
}
#nav .menus_items .menus_item .menus_item_child li:first-child {
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
}
#nav .menus_items .menus_item .menus_item_child li:last-child {
  border-bottom-right-radius: 5px;
  border-bottom-left-radius: 5px;
}
#nav .menus_items .menus_item .menus_item_child li a {
  display: inline-block;
}
#nav .menus_items .menus_item .submenu_title > .site-page {
  cursor: default;
  padding: 8px 16px;
  display: block;
  color: var(--font-color);
  opacity: 0.7;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=70)";
  filter: alpha(opacity=70);
}
#nav.hide-menu #toggle-menu {
  display: inline-block !important;
}
#nav.hide-menu #toggle-menu .site-page {
  font-size: inherit;
}
#nav.hide-menu .menus_items {
  display: none;
}
#nav.hide-menu #search-button span:not(.site-page) {
  display: none;
}
#nav #search-button {
  display: inline;
  padding: 0 0 0 14px;
}
#nav .site-page {
  position: relative;
  padding-bottom: 6px;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
  font-size: 0.78em;
  cursor: pointer;
}
#nav .site-page:not(.child):after {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  width: 0;
  height: 3px;
  background-color: #80c8f8;
  content: '';
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  border-radius: 6px;
}
#nav .site-page:not(.child):hover:after {
  width: 100%;
}
#nav .nav-page-title {
  position: relative;
  overflow: hidden;
}
#nav .nav-page-title > :first-child,
#nav .nav-page-title > :last-child {
  display: inline-block;
  -webkit-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
#nav .nav-page-title > :last-child {
  position: absolute;
  top: 50%;
  left: 0;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transform: translateY(-50%) translateY(-10px);
  -moz-transform: translateY(-50%) translateY(-10px);
  -o-transform: translateY(-50%) translateY(-10px);
  -ms-transform: translateY(-50%) translateY(-10px);
  transform: translateY(-50%) translateY(-10px);
}
#nav .nav-page-title:hover > :last-child {
  opacity: 1;
  -ms-filter: none;
  filter: none;
  -webkit-transform: translateY(-50%) translateY(0);
  -moz-transform: translateY(-50%) translateY(0);
  -o-transform: translateY(-50%) translateY(0);
  -ms-transform: translateY(-50%) translateY(0);
  transform: translateY(-50%) translateY(0);
}
#nav .nav-page-title:hover > :first-child {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transform: translateY(10px);
  -moz-transform: translateY(10px);
  -o-transform: translateY(10px);
  -ms-transform: translateY(10px);
  transform: translateY(10px);
}
#pagination .pagination {
  margin-top: 20px;
  text-align: center;
}
#pagination .page-number.current {
  background: #00c4b6;
  color: var(--white);
}
#pagination .full-width {
  width: 100% !important;
}
#pagination .pagination-related {
  height: 150px;
}
@media screen and (min-width: 768px) {
  #pagination .pagination-related {
    -webkit-box-flex: 1;
    -moz-box-flex: 1;
    -o-box-flex: 1;
    box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
  }
}
#pagination .pagination-related .info-1 .info-item-2 {
  -webkit-line-clamp: 1;
}
#pagination .pagination-related .info-2 .info-item-1 {
  -webkit-line-clamp: 2;
}
#pagination.pagination-post {
  overflow: hidden;
  margin-top: 40px;
  width: 100%;
  border-radius: 6px;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
}
@media screen and (max-width: 768px) {
  #pagination.pagination-post {
    -webkit-box-orient: vertical;
    -moz-box-orient: vertical;
    -o-box-orient: vertical;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.layout .pagination > * {
  display: inline-block;
  margin: 0 6px;
  width: 2.5em;
  height: 2.5em;
  line-height: 2.5em;
}
.layout .pagination > *:not(.space):hover {
  background: var(--btn-hover-color);
  color: var(--btn-color);
}
#archive .pagination {
  margin-top: 30px;
}
#archive .pagination > *:not(.space) {
  -webkit-box-shadow: none;
  box-shadow: none;
}
.pagination-related {
  position: relative;
  display: inline-block;
  overflow: hidden;
  background: #000;
  vertical-align: bottom;
}
.pagination-related.next-post .info {
  text-align: right;
}
.pagination-related .info .info-1,
.pagination-related .info .info-2 {
  padding: 20px 40px;
  color: var(--white);
  -webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
  -moz-transition: -moz-transform 0.3s, opacity 0.3s;
  -o-transition: -o-transform 0.3s, opacity 0.3s;
  -ms-transition: -ms-transform 0.3s, opacity 0.3s;
  transition: transform 0.3s, opacity 0.3s;
}
.pagination-related .info .info-1 .info-item-1 {
  color: var(--light-grey);
  text-transform: uppercase;
  font-size: 90%;
}
.pagination-related .info .info-1 .info-item-2 {
  color: var(--white);
  font-weight: 500;
}
.pagination-related .info .info-2 {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transform: translate(0, 0);
  -moz-transform: translate(0, 0);
  -o-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  transform: translate(0, 0);
}
.pagination-related:not(.no-desc):hover .info-1 {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transform: translate(0, -100%);
  -moz-transform: translate(0, -100%);
  -o-transform: translate(0, -100%);
  -ms-transform: translate(0, -100%);
  transform: translate(0, -100%);
}
.pagination-related:not(.no-desc):hover .info-2 {
  opacity: 1;
  -ms-filter: none;
  filter: none;
  -webkit-transform: translate(0, -50%);
  -moz-transform: translate(0, -50%);
  -o-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
.container {
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.container a {
  color: #49b1f5;
}
.container a:hover {
  text-decoration: underline;
}
.container img {
  display: block;
  margin: 0 auto 20px;
  max-width: 100%;
  -webkit-transition: filter 375ms ease-in 0.2s;
  -moz-transition: filter 375ms ease-in 0.2s;
  -o-transition: filter 375ms ease-in 0.2s;
  -ms-transition: filter 375ms ease-in 0.2s;
  transition: filter 375ms ease-in 0.2s;
  border-radius: 6px;
}
.container p {
  margin: 0 0 16px;
}
.container iframe {
  margin: 0 0 20px;
}
.container kbd {
  margin: 0 3px;
  padding: 3px 5px;
  border: 1px solid #b4b4b4;
  background-color: #f8f8f8;
  -webkit-box-shadow: 0 1px 3px rgba(0,0,0,0.25), 0 2px 1px 0 rgba(255,255,255,0.6) inset;
  box-shadow: 0 1px 3px rgba(0,0,0,0.25), 0 2px 1px 0 rgba(255,255,255,0.6) inset;
  color: #34495e;
  white-space: nowrap;
  font-weight: 600;
  font-size: 0.9em;
  font-family: Monaco, 'Ubuntu Mono', monospace;
  line-height: 1em;
  border-radius: 3px;
}
.container ol ol,
.container ul ol,
.container ol ul,
.container ul ul {
  padding-left: 20px;
}
.container ol li,
.container ul li {
  margin: 4px 0;
}
.container ol p,
.container ul p {
  margin: 0 0 8px;
}
.container > :last-child {
  margin-bottom: 0 !important;
}
.container hr {
  margin: 20px 0;
}
#post .tag_share:after {
  display: block;
  clear: both;
  content: '';
}
#post .tag_share .post-meta__tag-list {
  display: inline-block;
}
#post .tag_share .post-meta__tags {
  display: inline-block;
  margin: 8px 8px 8px 0;
  padding: 0 12px;
  width: fit-content;
  border: 1px solid #49b1f5;
  border-radius: 12px;
  color: #49b1f5;
  font-size: 0.85em;
  -webkit-transition: all 0.2s ease-in-out;
  -moz-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  -ms-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
#post .tag_share .post-meta__tags:hover {
  background: #49b1f5;
  color: var(--white);
}
#post .tag_share .post-share {
  display: inline-block;
  float: right;
  margin: 8px 0 0;
  width: fit-content;
}
#post .tag_share .post-share .social-share {
  font-size: 0.85em;
}
#post .tag_share .post-share .social-share .social-share-icon {
  margin: 0 4px;
  width: 1.85em;
  height: 1.85em;
  font-size: 1.2em;
  line-height: 1.85em;
}
#post .post-copyright {
  position: relative;
  margin: 40px 0 10px;
  padding: 10px 16px;
  border: 1px solid var(--light-grey);
  -webkit-transition: box-shadow 0.3s ease-in-out;
  -moz-transition: box-shadow 0.3s ease-in-out;
  -o-transition: box-shadow 0.3s ease-in-out;
  -ms-transition: box-shadow 0.3s ease-in-out;
  transition: box-shadow 0.3s ease-in-out;
  border-radius: 6px;
}
#post .post-copyright:before {
  position: absolute;
  top: 2px;
  right: 12px;
  color: #49b1f5;
  content: '\f1f9';
  font-size: 1.3em;
}
#post .post-copyright:hover {
  -webkit-box-shadow: 0 0 8px 0 rgba(232,237,250,0.6), 0 2px 4px 0 rgba(232,237,250,0.5);
  box-shadow: 0 0 8px 0 rgba(232,237,250,0.6), 0 2px 4px 0 rgba(232,237,250,0.5);
}
#post .post-copyright .post-copyright-meta {
  color: #49b1f5;
  font-weight: bold;
}
#post .post-copyright .post-copyright-meta i {
  margin-right: 3px;
}
#post .post-copyright .post-copyright-info {
  padding-left: 6px;
}
#post .post-copyright .post-copyright-info a {
  text-decoration: underline;
  word-break: break-word;
}
#post .post-copyright .post-copyright-info a:hover {
  text-decoration: none;
}
#post #post-outdate-notice {
  position: relative;
  margin: 0 0 20px;
  padding: 0.5em 1.2em;
  background-color: #ffe6e6;
  color: #f66;
  border-radius: 3px;
  padding: 0.5em 1em 0.5em 2.6em;
  border-left: 5px solid #ff8080;
}
#post #post-outdate-notice .num {
  padding: 0 4px;
}
#post #post-outdate-notice:before {
  position: absolute;
  top: 50%;
  left: 0.9em;
  color: #ff8080;
  content: '\f071';
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}
#post .ads-wrap {
  margin: 40px 0;
}
.relatedPosts {
  margin-top: 40px;
}
.relatedPosts > .headline {
  margin-bottom: 5px;
  font-weight: 700;
  font-size: 1.43em;
}
.relatedPosts > .relatedPosts-list > a {
  margin: 3px;
  width: calc(33.333% - 6px);
  height: 200px;
  border-radius: 6px;
}
@media screen and (max-width: 768px) {
  .relatedPosts > .relatedPosts-list > a {
    margin: 2px;
    width: calc(50% - 4px);
    height: 150px;
  }
}
@media screen and (max-width: 600px) {
  .relatedPosts > .relatedPosts-list > a {
    width: calc(100% - 4px);
  }
}
.relatedPosts > .relatedPosts-list .info .info-1 .info-item-2 {
  -webkit-line-clamp: 2;
}
.relatedPosts > .relatedPosts-list .info .info-2 .info-item-1 {
  -webkit-line-clamp: 3;
}
.post-reward {
  position: relative;
  margin-top: 80px;
  width: 100%;
  text-align: center;
  pointer-events: none;
}
.post-reward > * {
  pointer-events: auto;
}
.post-reward .reward-button {
  display: inline-block;
  padding: 4px 24px;
  background: var(--btn-bg);
  color: var(--btn-color);
  cursor: pointer;
  border-radius: 6px;
}
.post-reward .reward-button i {
  margin-right: 5px;
}
.post-reward:hover .reward-button {
  background: var(--btn-hover-color);
}
.post-reward:hover > .reward-main {
  display: block;
}
.post-reward .reward-main {
  position: absolute;
  bottom: 40px;
  left: 0;
  z-index: 100;
  display: none;
  padding: 0 0 15px;
  width: 100%;
  border-radius: 6px;
}
.post-reward .reward-main .reward-all {
  display: inline-block;
  margin: 0;
  padding: 20px 10px;
  background: var(--reward-pop);
}
.post-reward .reward-main .reward-all:before {
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 100%;
  height: 20px;
  content: '';
}
.post-reward .reward-main .reward-all:after {
  position: absolute;
  right: 0;
  bottom: 2px;
  left: 0;
  margin: 0 auto;
  width: 0;
  height: 0;
  border-top: 13px solid var(--reward-pop);
  border-right: 13px solid transparent;
  border-left: 13px solid transparent;
  content: '';
}
.post-reward .reward-main .reward-all .reward-item {
  display: inline-block;
  padding: 0 8px;
  list-style-type: none;
  vertical-align: top;
}
.post-reward .reward-main .reward-all .reward-item img {
  width: 130px;
  height: 130px;
}
.post-reward .reward-main .reward-all .reward-item .post-qr-code-desc {
  width: 130px;
  color: #858585;
}
#rightside {
  position: fixed;
  right: -48px;
  bottom: 40px;
  z-index: 100;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
}
#rightside.rightside-show {
  opacity: 0.8;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
  filter: alpha(opacity=80);
  -webkit-transform: translate(-58px, 0);
  -moz-transform: translate(-58px, 0);
  -o-transform: translate(-58px, 0);
  -ms-transform: translate(-58px, 0);
  transform: translate(-58px, 0);
}
#rightside #rightside-config-hide {
  height: 0;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transition: -webkit-transform 0.4s;
  -moz-transition: -moz-transform 0.4s;
  -o-transition: -o-transform 0.4s;
  -ms-transition: -ms-transform 0.4s;
  transition: transform 0.4s;
  -webkit-transform: translate(45px, 0);
  -moz-transform: translate(45px, 0);
  -o-transform: translate(45px, 0);
  -ms-transform: translate(45px, 0);
  transform: translate(45px, 0);
}
#rightside #rightside-config-hide.show {
  height: auto;
  opacity: 1;
  -ms-filter: none;
  filter: none;
  -webkit-transform: translate(0, 0);
  -moz-transform: translate(0, 0);
  -o-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  transform: translate(0, 0);
}
#rightside #rightside-config-hide.status {
  height: auto;
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
#rightside > div > button,
#rightside > div > a {
  display: block;
  margin-bottom: 5px;
  width: 35px;
  height: 35px;
  background-color: var(--btn-bg);
  color: var(--btn-color);
  text-align: center;
  font-size: 16px;
  line-height: 35px;
  border-radius: 5px;
}
#rightside > div > button:hover,
#rightside > div > a:hover {
  background-color: var(--btn-hover-color);
}
#rightside #mobile-toc-button {
  display: none;
}
@media screen and (max-width: 900px) {
  #rightside #mobile-toc-button {
    display: block;
  }
}
@media screen and (max-width: 900px) {
  #rightside #hide-aside-btn {
    display: none;
  }
}
#sidebar #menu-mask {
  position: fixed;
  z-index: 102;
  display: none;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.8);
}
#sidebar #sidebar-menus {
  position: fixed;
  top: 0;
  right: -330px;
  z-index: 103;
  overflow-x: hidden;
  overflow-y: scroll;
  padding-left: 5px;
  width: 330px;
  height: 100%;
  background: var(--sidebar-bg);
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
  -o-transition: all 0.5s;
  -ms-transition: all 0.5s;
  transition: all 0.5s;
}
#sidebar #sidebar-menus.open {
  -webkit-transform: translate3d(-100%, 0, 0);
  -moz-transform: translate3d(-100%, 0, 0);
  -o-transform: translate3d(-100%, 0, 0);
  -ms-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0);
}
#sidebar #sidebar-menus > .avatar-img {
  margin: 20px auto;
}
#sidebar #sidebar-menus .site-data {
  padding: 0 10px;
}
#sidebar #sidebar-menus hr {
  margin: 20px auto;
}
#sidebar #sidebar-menus .menus_items {
  margin: 20px;
  padding: 15px;
  background: var(--sidebar-menu-bg);
  -webkit-box-shadow: 0 0 1px 1px rgba(7,17,27,0.05);
  box-shadow: 0 0 1px 1px rgba(7,17,27,0.05);
  border-radius: 10px;
}
#sidebar #sidebar-menus .menus_items .site-page {
  position: relative;
  display: block;
  margin: 4px 0;
  padding: 2px 23px 2px 15px;
  color: var(--font-color);
  font-size: 1.15em;
  cursor: pointer;
  border-radius: 6px;
}
#sidebar #sidebar-menus .menus_items .site-page:hover {
  background: var(--text-bg-hover);
  color: var(--white);
}
#sidebar #sidebar-menus .menus_items .site-page i:first-child {
  width: 15%;
  text-align: left;
}
#sidebar #sidebar-menus .menus_items .site-page.group > i:last-child {
  position: absolute;
  top: 0.6em;
  right: 10px;
  -webkit-transition: -webkit-transform 0.3s;
  -moz-transition: -moz-transform 0.3s;
  -o-transition: -o-transform 0.3s;
  -ms-transition: -ms-transform 0.3s;
  transition: transform 0.3s;
}
#sidebar #sidebar-menus .menus_items .site-page.group.hide > i:last-child {
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -o-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
}
#sidebar #sidebar-menus .menus_items .site-page.group.hide + .menus_item_child {
  display: none;
}
#sidebar #sidebar-menus .menus_items .menus_item_child {
  margin: 0;
  padding-left: 25px;
  list-style: none;
}
#vcomment {
  font-size: 1.1em;
}
#vcomment .vbtn {
  border: none;
  background: var(--btn-bg);
  color: var(--btn-color);
}
#vcomment .vbtn:hover {
  background: var(--btn-hover-color);
}
#vcomment .vimg {
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
#vcomment .vimg:hover {
  -webkit-transform: rotate(360deg);
  -moz-transform: rotate(360deg);
  -o-transform: rotate(360deg);
  -ms-transform: rotate(360deg);
  transform: rotate(360deg);
}
#vcomment .vcards .vcard .vcontent.expand:before,
#vcomment .vcards .vcard .vcontent.expand:after {
  z-index: 22;
}
#waline-wrap {
  --waline-font-size: 1.1em;
  --waline-theme-color: #49b1f5;
  --waline-active-color: #ff7242;
}
#waline-wrap .wl-comment-actions > button:not(last-child) {
  padding-right: 4px;
}
.twikoo .tk-content p {
  margin: 3px 0;
}
.fireworks {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  pointer-events: none;
}
.medium-zoom-image--opened {
  z-index: 99999 !important;
  margin: 0 !important;
}
.medium-zoom-overlay {
  z-index: 99999 !important;
}
.utterances,
.fb-comments iframe {
  width: 100% !important;
}
#gitalk-container .gt-meta {
  margin: 0 0 0.8em;
  padding: 6px 0 16px;
}
.aplayer {
  color: #4c4948;
}
.container .aplayer {
  margin: 0 0 20px;
}
.snackbar-container.snackbar-css {
  border-radius: 5px;
  opacity: 0.85 !important;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=85)" !important;
  filter: alpha(opacity=85) !important;
}
.abc-music-sheet {
  margin: 0 0 20px;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transition: opacity 0.3s;
  -moz-transition: opacity 0.3s;
  -o-transition: opacity 0.3s;
  -ms-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.abc-music-sheet.abcjs-container {
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
@media screen and (max-width: 768px) {
  .fancybox__toolbar__column.is-middle {
    display: none;
  }
}
.container .btn-center {
  margin: 0 0 20px;
  text-align: center;
}
.container .btn-beautify {
  display: inline-block;
  margin: 0 4px 6px;
  padding: 0 15px;
  background-color: var(--btn-beautify-color, #777);
  color: #fff;
  line-height: 2;
  border-radius: 6px;
}
.container .btn-beautify.blue {
  --btn-beautify-color: #428bca;
}
.container .btn-beautify.pink {
  --btn-beautify-color: #ff69b4;
}
.container .btn-beautify.red {
  --btn-beautify-color: #f00;
}
.container .btn-beautify.purple {
  --btn-beautify-color: #6f42c1;
}
.container .btn-beautify.orange {
  --btn-beautify-color: #ff8c00;
}
.container .btn-beautify.green {
  --btn-beautify-color: #5cb85c;
}
.container .btn-beautify:hover {
  background-color: var(--btn-hover-color);
}
.container .btn-beautify i + span {
  margin-left: 6px;
}
.container .btn-beautify:not(.block) + .btn-beautify:not(.block) {
  margin: 0 4px 20px;
}
.container .btn-beautify.block {
  display: block;
  margin: 0 0 20px;
  width: fit-content;
  width: -moz-fit-content;
}
.container .btn-beautify.block.center {
  margin: 0 auto 20px;
}
.container .btn-beautify.block.right {
  margin: 0 0 20px auto;
}
.container .btn-beautify.larger {
  padding: 6px 15px;
}
.container .btn-beautify:hover {
  text-decoration: none;
}
.container .btn-beautify.outline {
  border: 1px solid transparent;
  border-color: var(--btn-beautify-color, #777);
  background-color: transparent;
  color: var(--btn-beautify-color, #777);
}
.container .btn-beautify.outline:hover {
  background-color: var(--btn-beautify-color, #777);
}
.container .btn-beautify.outline:hover {
  color: #fff !important;
}
.container figure.gallery-group {
  position: relative;
  float: left;
  overflow: hidden;
  margin: 6px 4px;
  width: calc(50% - 8px);
  height: 250px;
  border-radius: 10px;
  background: #000;
  -webkit-transform: translate3d(0, 0, 0);
}
@media screen and (max-width: 600px) {
  .container figure.gallery-group {
    width: calc(100% - 8px);
  }
}
@media screen and (min-width: 1024px) {
  .container figure.gallery-group {
    width: calc(100% / 3 - 8px);
  }
}
.container figure.gallery-group:hover img {
  opacity: 0.4;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=40)";
  filter: alpha(opacity=40);
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.container figure.gallery-group:hover .gallery-group-name::after {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.container figure.gallery-group:hover p {
  opacity: 1;
  -ms-filter: none;
  filter: none;
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.container figure.gallery-group img {
  position: relative;
  margin: 0;
  max-width: none;
  width: calc(100% + 20px);
  height: 250px;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  backface-visibility: hidden;
  opacity: 0.8;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
  filter: alpha(opacity=80);
  -webkit-transition: all 0.3s, filter 375ms ease-in 0.2s;
  -moz-transition: all 0.3s, filter 375ms ease-in 0.2s;
  -o-transition: all 0.3s, filter 375ms ease-in 0.2s;
  -ms-transition: all 0.3s, filter 375ms ease-in 0.2s;
  transition: all 0.3s, filter 375ms ease-in 0.2s;
  -webkit-transform: translate3d(-10px, 0, 0);
  -moz-transform: translate3d(-10px, 0, 0);
  -o-transform: translate3d(-10px, 0, 0);
  -ms-transform: translate3d(-10px, 0, 0);
  transform: translate3d(-10px, 0, 0);
  object-fit: cover;
}
.container figure.gallery-group figcaption {
  position: absolute;
  top: 0;
  left: 0;
  padding: 30px;
  width: 100%;
  height: 100%;
  color: #fff;
  text-transform: uppercase;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  backface-visibility: hidden;
}
.container figure.gallery-group figcaption > a {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1000;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
.container figure.gallery-group p {
  margin: 0;
  padding: 8px 0 0;
  letter-spacing: 1px;
  font-size: 1.1em;
  line-height: 1.5;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transition: opacity 0.35s, -webkit-transform 0.35s;
  -moz-transition: opacity 0.35s, -moz-transform 0.35s;
  -o-transition: opacity 0.35s, -o-transform 0.35s;
  -ms-transition: opacity 0.35s, -ms-transform 0.35s;
  transition: opacity 0.35s, transform 0.35s;
  -webkit-transform: translate3d(100%, 0, 0);
  -moz-transform: translate3d(100%, 0, 0);
  -o-transform: translate3d(100%, 0, 0);
  -ms-transform: translate3d(100%, 0, 0);
  transform: translate3d(100%, 0, 0);
  -webkit-line-clamp: 4;
}
.container figure.gallery-group .gallery-group-name {
  position: relative;
  margin: 0;
  padding: 8px 0;
  font-weight: bold;
  font-size: 1.65em;
  line-height: 1.5;
  -webkit-line-clamp: 2;
}
.container figure.gallery-group .gallery-group-name:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #fff;
  content: '';
  -webkit-transition: -webkit-transform 0.35s;
  -moz-transition: -moz-transform 0.35s;
  -o-transition: -o-transform 0.35s;
  -ms-transition: -ms-transform 0.35s;
  transition: transform 0.35s;
  -webkit-transform: translate3d(-100%, 0, 0);
  -moz-transform: translate3d(-100%, 0, 0);
  -o-transform: translate3d(-100%, 0, 0);
  -ms-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0);
}
.container .gallery-group-main {
  overflow: auto;
  padding: 0 0 16px;
}
.container .gallery-container {
  margin: 0 0 20px;
  text-align: center;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
.container .gallery-container.loaded {
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
.container .gallery-container img {
  display: initial;
  margin: 0;
  width: 100%;
  height: 100%;
}
.container .gallery-container .gallery-data {
  display: none;
}
.container .gallery-container button {
  margin-top: 25px;
  padding: 8px 14px;
  background: var(--btn-bg);
  color: var(--btn-color);
  font-weight: bold;
  font-size: 1.1em;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
  border-radius: 5px;
}
.container .gallery-container button:hover {
  background: var(--btn-hover-color);
}
.container .gallery-container button:hover i {
  margin-left: 8px;
}
.container .gallery-container button i {
  margin-left: 4px;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
}
.container .loading-container {
  display: inline-block;
  overflow: hidden;
  width: 154px;
  height: 154px;
}
.container .loading-container .loading-item {
  position: relative;
  width: 100%;
  height: 100%;
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform: translateZ(0) scale(1);
  -moz-transform: translateZ(0) scale(1);
  -o-transform: translateZ(0) scale(1);
  -ms-transform: translateZ(0) scale(1);
  transform: translateZ(0) scale(1);
  -webkit-transform-origin: 0 0;
  -moz-transform-origin: 0 0;
  -o-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  transform-origin: 0 0;
}
.container .loading-container .loading-item div {
  position: absolute;
  width: 30.8px;
  height: 30.8px;
  border-radius: 50%;
  background: #e15b64;
  -webkit-transform: translate(61.6px, 61.6px) scale(1);
  -moz-transform: translate(61.6px, 61.6px) scale(1);
  -o-transform: translate(61.6px, 61.6px) scale(1);
  -ms-transform: translate(61.6px, 61.6px) scale(1);
  transform: translate(61.6px, 61.6px) scale(1);
  -webkit-animation: loading-ball 1.92s infinite cubic-bezier(0, 0.5, 0.5, 1);
  -moz-animation: loading-ball 1.92s infinite cubic-bezier(0, 0.5, 0.5, 1);
  -o-animation: loading-ball 1.92s infinite cubic-bezier(0, 0.5, 0.5, 1);
  -ms-animation: loading-ball 1.92s infinite cubic-bezier(0, 0.5, 0.5, 1);
  animation: loading-ball 1.92s infinite cubic-bezier(0, 0.5, 0.5, 1);
}
.container .loading-container .loading-item div:nth-child(1) {
  background: #f47e60;
  -webkit-transform: translate(113.96px, 61.6px) scale(1);
  -moz-transform: translate(113.96px, 61.6px) scale(1);
  -o-transform: translate(113.96px, 61.6px) scale(1);
  -ms-transform: translate(113.96px, 61.6px) scale(1);
  transform: translate(113.96px, 61.6px) scale(1);
  -webkit-animation: loading-ball-r 0.48s infinite cubic-bezier(0, 0.5, 0.5, 1), loading-ball-c 1.92s infinite step-start;
  -moz-animation: loading-ball-r 0.48s infinite cubic-bezier(0, 0.5, 0.5, 1), loading-ball-c 1.92s infinite step-start;
  -o-animation: loading-ball-r 0.48s infinite cubic-bezier(0, 0.5, 0.5, 1), loading-ball-c 1.92s infinite step-start;
  -ms-animation: loading-ball-r 0.48s infinite cubic-bezier(0, 0.5, 0.5, 1), loading-ball-c 1.92s infinite step-start;
  animation: loading-ball-r 0.48s infinite cubic-bezier(0, 0.5, 0.5, 1), loading-ball-c 1.92s infinite step-start;
}
.container .loading-container .loading-item div:nth-child(2) {
  background: #e15b64;
  -webkit-animation-delay: -0.48s;
  -moz-animation-delay: -0.48s;
  -o-animation-delay: -0.48s;
  -ms-animation-delay: -0.48s;
  animation-delay: -0.48s;
}
.container .loading-container .loading-item div:nth-child(3) {
  background: #f47e60;
  -webkit-animation-delay: -0.96s;
  -moz-animation-delay: -0.96s;
  -o-animation-delay: -0.96s;
  -ms-animation-delay: -0.96s;
  animation-delay: -0.96s;
}
.container .loading-container .loading-item div:nth-child(4) {
  background: #f8b26a;
  -webkit-animation-delay: -1.44s;
  -moz-animation-delay: -1.44s;
  -o-animation-delay: -1.44s;
  -ms-animation-delay: -1.44s;
  animation-delay: -1.44s;
}
.container .loading-container .loading-item div:nth-child(5) {
  background: #abbd81;
  -webkit-animation-delay: -1.92s;
  -moz-animation-delay: -1.92s;
  -o-animation-delay: -1.92s;
  -ms-animation-delay: -1.92s;
  animation-delay: -1.92s;
}
@-moz-keyframes loading-ball {
  0% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  25% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  50% {
    -webkit-transform: translate(9.24px, 61.6px) scale(1);
    -moz-transform: translate(9.24px, 61.6px) scale(1);
    -o-transform: translate(9.24px, 61.6px) scale(1);
    -ms-transform: translate(9.24px, 61.6px) scale(1);
    transform: translate(9.24px, 61.6px) scale(1);
  }
  75% {
    -webkit-transform: translate(61.6px, 61.6px) scale(1);
    -moz-transform: translate(61.6px, 61.6px) scale(1);
    -o-transform: translate(61.6px, 61.6px) scale(1);
    -ms-transform: translate(61.6px, 61.6px) scale(1);
    transform: translate(61.6px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
}
@-webkit-keyframes loading-ball {
  0% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  25% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  50% {
    -webkit-transform: translate(9.24px, 61.6px) scale(1);
    -moz-transform: translate(9.24px, 61.6px) scale(1);
    -o-transform: translate(9.24px, 61.6px) scale(1);
    -ms-transform: translate(9.24px, 61.6px) scale(1);
    transform: translate(9.24px, 61.6px) scale(1);
  }
  75% {
    -webkit-transform: translate(61.6px, 61.6px) scale(1);
    -moz-transform: translate(61.6px, 61.6px) scale(1);
    -o-transform: translate(61.6px, 61.6px) scale(1);
    -ms-transform: translate(61.6px, 61.6px) scale(1);
    transform: translate(61.6px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
}
@-o-keyframes loading-ball {
  0% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  25% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  50% {
    -webkit-transform: translate(9.24px, 61.6px) scale(1);
    -moz-transform: translate(9.24px, 61.6px) scale(1);
    -o-transform: translate(9.24px, 61.6px) scale(1);
    -ms-transform: translate(9.24px, 61.6px) scale(1);
    transform: translate(9.24px, 61.6px) scale(1);
  }
  75% {
    -webkit-transform: translate(61.6px, 61.6px) scale(1);
    -moz-transform: translate(61.6px, 61.6px) scale(1);
    -o-transform: translate(61.6px, 61.6px) scale(1);
    -ms-transform: translate(61.6px, 61.6px) scale(1);
    transform: translate(61.6px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
}
@keyframes loading-ball {
  0% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  25% {
    -webkit-transform: translate(9.24px, 61.6px) scale(0);
    -moz-transform: translate(9.24px, 61.6px) scale(0);
    -o-transform: translate(9.24px, 61.6px) scale(0);
    -ms-transform: translate(9.24px, 61.6px) scale(0);
    transform: translate(9.24px, 61.6px) scale(0);
  }
  50% {
    -webkit-transform: translate(9.24px, 61.6px) scale(1);
    -moz-transform: translate(9.24px, 61.6px) scale(1);
    -o-transform: translate(9.24px, 61.6px) scale(1);
    -ms-transform: translate(9.24px, 61.6px) scale(1);
    transform: translate(9.24px, 61.6px) scale(1);
  }
  75% {
    -webkit-transform: translate(61.6px, 61.6px) scale(1);
    -moz-transform: translate(61.6px, 61.6px) scale(1);
    -o-transform: translate(61.6px, 61.6px) scale(1);
    -ms-transform: translate(61.6px, 61.6px) scale(1);
    transform: translate(61.6px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
}
@-moz-keyframes loading-ball-r {
  0% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(0);
    -moz-transform: translate(113.96px, 61.6px) scale(0);
    -o-transform: translate(113.96px, 61.6px) scale(0);
    -ms-transform: translate(113.96px, 61.6px) scale(0);
    transform: translate(113.96px, 61.6px) scale(0);
  }
}
@-webkit-keyframes loading-ball-r {
  0% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(0);
    -moz-transform: translate(113.96px, 61.6px) scale(0);
    -o-transform: translate(113.96px, 61.6px) scale(0);
    -ms-transform: translate(113.96px, 61.6px) scale(0);
    transform: translate(113.96px, 61.6px) scale(0);
  }
}
@-o-keyframes loading-ball-r {
  0% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(0);
    -moz-transform: translate(113.96px, 61.6px) scale(0);
    -o-transform: translate(113.96px, 61.6px) scale(0);
    -ms-transform: translate(113.96px, 61.6px) scale(0);
    transform: translate(113.96px, 61.6px) scale(0);
  }
}
@keyframes loading-ball-r {
  0% {
    -webkit-transform: translate(113.96px, 61.6px) scale(1);
    -moz-transform: translate(113.96px, 61.6px) scale(1);
    -o-transform: translate(113.96px, 61.6px) scale(1);
    -ms-transform: translate(113.96px, 61.6px) scale(1);
    transform: translate(113.96px, 61.6px) scale(1);
  }
  100% {
    -webkit-transform: translate(113.96px, 61.6px) scale(0);
    -moz-transform: translate(113.96px, 61.6px) scale(0);
    -o-transform: translate(113.96px, 61.6px) scale(0);
    -ms-transform: translate(113.96px, 61.6px) scale(0);
    transform: translate(113.96px, 61.6px) scale(0);
  }
}
@-moz-keyframes loading-ball-c {
  0% {
    background: #e15b64;
  }
  25% {
    background: #abbd81;
  }
  50% {
    background: #f8b26a;
  }
  75% {
    background: #f47e60;
  }
  100% {
    background: #e15b64;
  }
}
@-webkit-keyframes loading-ball-c {
  0% {
    background: #e15b64;
  }
  25% {
    background: #abbd81;
  }
  50% {
    background: #f8b26a;
  }
  75% {
    background: #f47e60;
  }
  100% {
    background: #e15b64;
  }
}
@-o-keyframes loading-ball-c {
  0% {
    background: #e15b64;
  }
  25% {
    background: #abbd81;
  }
  50% {
    background: #f8b26a;
  }
  75% {
    background: #f47e60;
  }
  100% {
    background: #e15b64;
  }
}
@keyframes loading-ball-c {
  0% {
    background: #e15b64;
  }
  25% {
    background: #abbd81;
  }
  50% {
    background: #f8b26a;
  }
  75% {
    background: #f47e60;
  }
  100% {
    background: #e15b64;
  }
}
blockquote.pullquote {
  position: relative;
  max-width: 45%;
  font-size: 110%;
}
blockquote.pullquote.left {
  float: left;
  margin: 1em 0.5em 0 0;
}
blockquote.pullquote.right {
  float: right;
  margin: 1em 0 0 0.5em;
}
.video-container {
  position: relative;
  overflow: hidden;
  margin-bottom: 16px;
  padding-top: 56.25%;
  height: 0;
}
.video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  margin-top: 0;
  width: 100%;
  height: 100%;
}
.hide-inline > .hide-button,
.hide-block > .hide-button {
  display: inline-block;
  padding: 5px 18px;
  background: #49b1f5;
  color: var(--white);
  border-radius: 6px;
}
.hide-inline > .hide-button:hover,
.hide-block > .hide-button:hover {
  background-color: var(--btn-hover-color);
}
.hide-inline > .hide-button.open,
.hide-block > .hide-button.open {
  display: none;
}
.hide-inline > .hide-button.open + div,
.hide-block > .hide-button.open + div {
  display: block;
}
.hide-inline > .hide-button.open + span,
.hide-block > .hide-button.open + span {
  display: inline;
}
.hide-inline > .hide-content,
.hide-block > .hide-content {
  display: none;
}
.hide-inline > .hide-button {
  margin: 0 6px;
}
.hide-inline > .hide-content {
  margin: 0 6px;
}
.hide-block {
  margin: 0 0 16px;
}
.toggle {
  margin-bottom: 20px;
  border: 1px solid #f0f0f0;
  border-radius: 5px;
  overflow: hidden;
}
.toggle > .toggle-button {
  padding: 6px 15px;
  background: #f0f0f0;
  color: #1f2d3d;
  cursor: pointer;
}
.toggle > .toggle-content {
  margin: 30px 24px;
}
.container .inline-img {
  display: inline;
  margin: 0 3px;
  height: 1.1em;
  vertical-align: text-bottom;
}
.hl-label {
  padding: 2px 4px;
  color: #fff;
  border-radius: 3px;
}
.hl-label.default {
  background-color: #777;
}
.hl-label.blue {
  background-color: #428bca;
}
.hl-label.pink {
  background-color: #ff69b4;
}
.hl-label.red {
  background-color: #f00;
}
.hl-label.purple {
  background-color: #6f42c1;
}
.hl-label.orange {
  background-color: #ff8c00;
}
.hl-label.green {
  background-color: #5cb85c;
}
.note {
  position: relative;
  margin: 0 0 20px;
  padding: 15px;
  border-radius: 3px;
}
.note.icon-padding {
  padding-left: 3em;
}
.note > .note-icon {
  position: absolute;
  top: calc(50% - 0.5em);
  left: 0.8em;
  font-size: larger;
}
.note.blue:not(.disabled) {
  border-left-color: #428bca !important;
}
.note.blue:not(.disabled).modern {
  border-left-color: transparent !important;
  color: #428bca;
}
.note.blue:not(.disabled):not(.simple) {
  background: #e3eef7 !important;
}
.note.blue > .note-icon {
  color: #428bca;
}
.note.pink:not(.disabled) {
  border-left-color: #ff69b4 !important;
}
.note.pink:not(.disabled).modern {
  border-left-color: transparent !important;
  color: #ff69b4;
}
.note.pink:not(.disabled):not(.simple) {
  background: #ffe9f4 !important;
}
.note.pink > .note-icon {
  color: #ff69b4;
}
.note.red:not(.disabled) {
  border-left-color: #f00 !important;
}
.note.red:not(.disabled).modern {
  border-left-color: transparent !important;
  color: #f00;
}
.note.red:not(.disabled):not(.simple) {
  background: #ffd9d9 !important;
}
.note.red > .note-icon {
  color: #f00;
}
.note.purple:not(.disabled) {
  border-left-color: #6f42c1 !important;
}
.note.purple:not(.disabled).modern {
  border-left-color: transparent !important;
  color: #6f42c1;
}
.note.purple:not(.disabled):not(.simple) {
  background: #e9e3f6 !important;
}
.note.purple > .note-icon {
  color: #6f42c1;
}
.note.orange:not(.disabled) {
  border-left-color: #ff8c00 !important;
}
.note.orange:not(.disabled).modern {
  border-left-color: transparent !important;
  color: #ff8c00;
}
.note.orange:not(.disabled):not(.simple) {
  background: #ffeed9 !important;
}
.note.orange > .note-icon {
  color: #ff8c00;
}
.note.green:not(.disabled) {
  border-left-color: #5cb85c !important;
}
.note.green:not(.disabled).modern {
  border-left-color: transparent !important;
  color: #5cb85c;
}
.note.green:not(.disabled):not(.simple) {
  background: #e7f4e7 !important;
}
.note.green > .note-icon {
  color: #5cb85c;
}
.note.simple {
  border: 1px solid #eee;
  border-left-width: 5px;
}
.note.modern {
  border: 1px solid transparent !important;
  background-color: #f5f5f5;
  color: #4c4948;
}
.note.flat {
  border: initial;
  border-left: 5px solid #eee;
  background-color: #f9f9f9;
  color: #4c4948;
}
.note h2,
.note h3,
.note h4,
.note h5,
.note h6 {
  margin-top: 3px;
  margin-bottom: 0;
  padding-top: 0 !important;
  border-bottom: initial;
}
.note p:first-child,
.note ul:first-child,
.note ol:first-child,
.note table:first-child,
.note pre:first-child,
.note blockquote:first-child,
.note img:first-child {
  margin-top: 0 !important;
}
.note p:last-child,
.note ul:last-child,
.note ol:last-child,
.note table:last-child,
.note pre:last-child,
.note blockquote:last-child,
.note img:last-child {
  margin-bottom: 0 !important;
}
.note .img-alt {
  margin: 5px 0 10px;
}
.note:not(.no-icon) {
  padding-left: 3em;
}
.note:not(.no-icon)::before {
  position: absolute;
  top: calc(50% - 0.95em);
  left: 0.8em;
  font-size: larger;
}
.note.default.flat {
  background: #f7f7f7;
}
.note.default.modern {
  border-color: #e1e1e1;
  background: #f3f3f3;
  color: #666;
}
.note.default.modern a:not(.btn) {
  color: #666;
}
.note.default.modern a:not(.btn):hover {
  color: #454545;
}
.note.default:not(.modern) {
  border-left-color: #777;
}
.note.default:not(.modern) h2,
.note.default:not(.modern) h3,
.note.default:not(.modern) h4,
.note.default:not(.modern) h5,
.note.default:not(.modern) h6 {
  color: #777;
}
.note.default:not(.no-icon)::before {
  content: '\f0a9';
}
.note.default:not(.no-icon):not(.modern)::before {
  color: #777;
}
.note.primary.flat {
  background: #f5f0fa;
}
.note.primary.modern {
  border-color: #e1c2ff;
  background: #f3daff;
  color: #6f42c1;
}
.note.primary.modern a:not(.btn) {
  color: #6f42c1;
}
.note.primary.modern a:not(.btn):hover {
  color: #453298;
}
.note.primary:not(.modern) {
  border-left-color: #6f42c1;
}
.note.primary:not(.modern) h2,
.note.primary:not(.modern) h3,
.note.primary:not(.modern) h4,
.note.primary:not(.modern) h5,
.note.primary:not(.modern) h6 {
  color: #6f42c1;
}
.note.primary:not(.no-icon)::before {
  content: '\f055';
}
.note.primary:not(.no-icon):not(.modern)::before {
  color: #6f42c1;
}
.note.info.flat {
  background: #eef7fa;
}
.note.info.modern {
  border-color: #b3e5ef;
  background: #d9edf7;
  color: #31708f;
}
.note.info.modern a:not(.btn) {
  color: #31708f;
}
.note.info.modern a:not(.btn):hover {
  color: #215761;
}
.note.info:not(.modern) {
  border-left-color: #428bca;
}
.note.info:not(.modern) h2,
.note.info:not(.modern) h3,
.note.info:not(.modern) h4,
.note.info:not(.modern) h5,
.note.info:not(.modern) h6 {
  color: #428bca;
}
.note.info:not(.no-icon)::before {
  content: '\f05a';
}
.note.info:not(.no-icon):not(.modern)::before {
  color: #428bca;
}
.note.success.flat {
  background: #eff8f0;
}
.note.success.modern {
  border-color: #d0e6be;
  background: #dff0d8;
  color: #3c763d;
}
.note.success.modern a:not(.btn) {
  color: #3c763d;
}
.note.success.modern a:not(.btn):hover {
  color: #32562c;
}
.note.success:not(.modern) {
  border-left-color: #5cb85c;
}
.note.success:not(.modern) h2,
.note.success:not(.modern) h3,
.note.success:not(.modern) h4,
.note.success:not(.modern) h5,
.note.success:not(.modern) h6 {
  color: #5cb85c;
}
.note.success:not(.no-icon)::before {
  content: '\f058';
}
.note.success:not(.no-icon):not(.modern)::before {
  color: #5cb85c;
}
.note.warning.flat {
  background: #fdf8ea;
}
.note.warning.modern {
  border-color: #fae4cd;
  background: #fcf4e3;
  color: #8a6d3b;
}
.note.warning.modern a:not(.btn) {
  color: #8a6d3b;
}
.note.warning.modern a:not(.btn):hover {
  color: #714f30;
}
.note.warning:not(.modern) {
  border-left-color: #f0ad4e;
}
.note.warning:not(.modern) h2,
.note.warning:not(.modern) h3,
.note.warning:not(.modern) h4,
.note.warning:not(.modern) h5,
.note.warning:not(.modern) h6 {
  color: #f0ad4e;
}
.note.warning:not(.no-icon)::before {
  content: '\f06a';
}
.note.warning:not(.no-icon):not(.modern)::before {
  color: #f0ad4e;
}
.note.danger.flat {
  background: #fcf1f2;
}
.note.danger.modern {
  border-color: #ebcdd2;
  background: #f2dfdf;
  color: #a94442;
}
.note.danger.modern a:not(.btn) {
  color: #a94442;
}
.note.danger.modern a:not(.btn):hover {
  color: #84333f;
}
.note.danger:not(.modern) {
  border-left-color: #d9534f;
}
.note.danger:not(.modern) h2,
.note.danger:not(.modern) h3,
.note.danger:not(.modern) h4,
.note.danger:not(.modern) h5,
.note.danger:not(.modern) h6 {
  color: #d9534f;
}
.note.danger:not(.no-icon)::before {
  content: '\f056';
}
.note.danger:not(.no-icon):not(.modern)::before {
  color: #d9534f;
}
.container .series-items a:hover {
  color: var(--pseudo-hover);
}
.container .tabs {
  position: relative;
  margin: 0 0 20px;
  border-right: 1px solid var(--tab-border-color);
  border-bottom: 1px solid var(--tab-border-color);
  border-left: 1px solid var(--tab-border-color);
  border-radius: 6px;
  overflow: hidden;
}
.container .tabs > .nav-tabs {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -o-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  background: var(--tab-button-bg);
}
.container .tabs > .nav-tabs > .tab {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  -ms-box-flex: 1;
  box-flex: 1;
  -webkit-flex-grow: 1;
  flex-grow: 1;
  padding: 8px 18px;
  border-top: 2px solid var(--tab-border-color);
  background: var(--tab-button-bg);
  color: var(--tab-button-color);
  line-height: 2;
  -webkit-transition: all 0.4s;
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -ms-transition: all 0.4s;
  transition: all 0.4s;
}
.container .tabs > .nav-tabs > .tab i {
  width: 1.5em;
}
.container .tabs > .nav-tabs > .tab.active {
  border-top: 2px solid #49b1f5;
  background: var(--tab-button-active-bg);
  cursor: default;
}
.container .tabs > .nav-tabs > .tab:not(.active):hover {
  border-top: 2px solid var(--tab-button-hover-bg);
  background: var(--tab-button-hover-bg);
}
.container .tabs > .nav-tabs.no-default ~ .tab-to-top {
  display: none;
}
.container .tabs > .tab-contents .tab-item-content {
  position: relative;
  display: none;
  padding: 36px 24px 10px;
}
@media screen and (max-width: 768px) {
  .container .tabs > .tab-contents .tab-item-content {
    padding: 24px 14px;
  }
}
.container .tabs > .tab-contents .tab-item-content.active {
  display: block;
  -webkit-animation: tabshow 0.5s;
  -moz-animation: tabshow 0.5s;
  -o-animation: tabshow 0.5s;
  -ms-animation: tabshow 0.5s;
  animation: tabshow 0.5s;
}
.container .tabs > .tab-contents .tab-item-content > :last-child {
  margin-bottom: 0;
}
.container .tabs > .tab-to-top {
  padding: 0 16px 10px 0;
  width: 100%;
  text-align: right;
}
.container .tabs > .tab-to-top button {
  color: #99a9bf;
}
.container .tabs > .tab-to-top button:hover {
  color: #49b1f5;
}
@-moz-keyframes tabshow {
  0% {
    -webkit-transform: translateY(15px);
    -moz-transform: translateY(15px);
    -o-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-webkit-keyframes tabshow {
  0% {
    -webkit-transform: translateY(15px);
    -moz-transform: translateY(15px);
    -o-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@-o-keyframes tabshow {
  0% {
    -webkit-transform: translateY(15px);
    -moz-transform: translateY(15px);
    -o-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes tabshow {
  0% {
    -webkit-transform: translateY(15px);
    -moz-transform: translateY(15px);
    -o-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
  100% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -o-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}
.container .timeline {
  margin: 0 10px 20px;
  padding: 14px 0 5px 20px;
  border-left: 2px solid var(--timeline-color, #49b1f5);
}
.container .timeline.blue {
  --timeline-color: #428bca;
  --timeline-bg: rgba(66,139,202, 0.2);
}
.container .timeline.pink {
  --timeline-color: #ff69b4;
  --timeline-bg: rgba(255,105,180, 0.2);
}
.container .timeline.red {
  --timeline-color: #f00;
  --timeline-bg: rgba(255,0,0, 0.2);
}
.container .timeline.purple {
  --timeline-color: #6f42c1;
  --timeline-bg: rgba(111,66,193, 0.2);
}
.container .timeline.orange {
  --timeline-color: #ff8c00;
  --timeline-bg: rgba(255,140,0, 0.2);
}
.container .timeline.green {
  --timeline-color: #5cb85c;
  --timeline-bg: rgba(92,184,92, 0.2);
}
.container .timeline .timeline-item {
  margin: 0 0 15px;
}
.container .timeline .timeline-item:hover .item-circle:before {
  border-color: var(--timeline-color, #49b1f5);
}
.container .timeline .timeline-item.headline .timeline-item-title .item-circle > p {
  font-weight: 600;
  font-size: 1.2em;
}
.container .timeline .timeline-item.headline .timeline-item-title .item-circle:before {
  left: -28px;
  border: 4px solid var(--timeline-color, #49b1f5);
}
.container .timeline .timeline-item.headline:hover .item-circle:before {
  border-color: var(--pseudo-hover);
}
.container .timeline .timeline-item .timeline-item-title {
  position: relative;
}
.container .timeline .timeline-item .item-circle:before {
  position: absolute;
  top: 50%;
  left: -27px;
  width: 6px;
  height: 6px;
  border: 3px solid var(--pseudo-hover);
  border-radius: 50%;
  background: var(--card-bg);
  content: '';
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  -ms-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform: translate(0, -50%);
  -moz-transform: translate(0, -50%);
  -o-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
.container .timeline .timeline-item .item-circle > p {
  margin: 0 0 8px;
  font-weight: 500;
}
.container .timeline .timeline-item .timeline-item-content {
  position: relative;
  padding: 12px 15px;
  border-radius: 8px;
  background: var(--timeline-bg, #e4f3fd);
  font-size: 0.93em;
}
.container .timeline .timeline-item .timeline-item-content > :last-child {
  margin-bottom: 0;
}
.container .timeline + .timeline {
  margin-top: -20px;
}
[data-theme='dark'] {
  --global-bg: #0d0d0d;
  --font-color: rgba(255,255,255,0.7);
  --hr-border: rgba(255,255,255,0.4);
  --hr-before-color: rgba(255,255,255,0.7);
  --search-bg: #121212;
  --search-input-color: rgba(255,255,255,0.7);
  --search-a-color: rgba(255,255,255,0.7);
  --preloader-bg: #0d0d0d;
  --preloader-color: rgba(255,255,255,0.7);
  --tab-border-color: #2c2c2c;
  --tab-button-bg: #2c2c2c;
  --tab-button-color: rgba(255,255,255,0.7);
  --tab-button-hover-bg: #383838;
  --tab-button-active-bg: #121212;
  --card-bg: #121212;
  --sidebar-bg: #121212;
  --sidebar-menu-bg: #1f1f1f;
  --btn-hover-color: #787878;
  --btn-color: rgba(255,255,255,0.7);
  --btn-bg: #1f1f1f;
  --text-bg-hover: #383838;
  --light-grey: rgba(255,255,255,0.7);
  --dark-grey: rgba(255,255,255,0.2);
  --white: rgba(255,255,255,0.9);
  --text-highlight-color: rgba(255,255,255,0.9);
  --blockquote-color: rgba(255,255,255,0.7);
  --blockquote-bg: #2c2c2c;
  --reward-pop: #2c2c2c;
  --toc-link-color: rgba(255,255,255,0.6);
  --scrollbar-color: #525252;
  --timeline-bg: #1f1f1f;
  --zoom-bg: #121212;
  --mark-bg: rgba(0,0,0,0.6);
}
[data-theme='dark'] #web_bg:before {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.7);
  content: '';
}
[data-theme='dark'] .container code {
  background: #2c2c2c;
}
[data-theme='dark'] .container pre > code {
  background: #171717;
}
[data-theme='dark'] .container figure.highlight {
  -webkit-box-shadow: none;
  box-shadow: none;
}
[data-theme='dark'] .container .note code {
  background: rgba(27,31,35,0.05);
}
[data-theme='dark'] .container .aplayer {
  filter: brightness(0.8);
}
[data-theme='dark'] .container kbd {
  border-color: #696969;
  background-color: #525252;
  color: #e2f1ff;
}
[data-theme='dark'] #page-header.nav-fixed > #nav,
[data-theme='dark'] #page-header.not-top-img > #nav {
  background: rgba(18,18,18,0.8);
  -webkit-box-shadow: 0 5px 6px -5px rgba(133,133,133,0);
  box-shadow: 0 5px 6px -5px rgba(133,133,133,0);
}
[data-theme='dark'] #post-comment .comment-switch {
  background: #2c2c2c !important;
}
[data-theme='dark'] #post-comment .comment-switch #switch-btn {
  filter: brightness(0.8);
}
[data-theme='dark'] .note {
  filter: brightness(0.8);
}
[data-theme='dark'] .hide-button,
[data-theme='dark'] .btn-beautify,
[data-theme='dark'] .hl-label,
[data-theme='dark'] #post-outdate-notice,
[data-theme='dark'] .error-img,
[data-theme='dark'] .container iframe,
[data-theme='dark'] .gist,
[data-theme='dark'] .ads-wrap {
  filter: brightness(0.8);
}
[data-theme='dark'] img {
  filter: brightness(0.8);
}
[data-theme='dark'] #aside-content .aside-list > .aside-list-item:not(:last-child) {
  border-bottom: 1px dashed rgba(255,255,255,0.1);
}
[data-theme='dark'] #gitalk-container {
  filter: brightness(0.8);
}
[data-theme='dark'] #gitalk-container svg {
  fill: rgba(255,255,255,0.9) !important;
}
[data-theme='dark'] #disqusjs #dsqjs:hover,
[data-theme='dark'] #disqusjs #dsqjs:focus,
[data-theme='dark'] #disqusjs #dsqjs .dsqjs-tab-active,
[data-theme='dark'] #disqusjs #dsqjs .dsqjs-no-comment {
  color: rgba(255,255,255,0.7);
}
[data-theme='dark'] #disqusjs #dsqjs .dsqjs-order-label {
  background-color: #1f1f1f;
}
[data-theme='dark'] #disqusjs #dsqjs .dsqjs-post-body {
  color: rgba(255,255,255,0.7);
}
[data-theme='dark'] #disqusjs #dsqjs .dsqjs-post-body code,
[data-theme='dark'] #disqusjs #dsqjs .dsqjs-post-body pre {
  background: #2c2c2c;
}
[data-theme='dark'] #disqusjs #dsqjs .dsqjs-post-body blockquote {
  color: rgba(255,255,255,0.7);
}
[data-theme='dark'] #artitalk_main #lazy {
  background: #121212;
}
[data-theme='dark'] #operare_artitalk .c2 {
  background: #121212;
}
@media screen and (max-width: 900px) {
  [data-theme='dark'] #card-toc {
    background: #1f1f1f;
  }
}
[data-theme='dark'] .artalk.atk-dark-mode,
[data-theme='dark'] .atk-layer-wrap.atk-dark-mode {
  --at-color-font: rgba(255,255,255,0.7);
  --at-color-meta: rgba(255,255,255,0.7);
  --at-color-grey: rgba(255,255,255,0.7);
}
[data-theme='dark'] .atk-send-btn,
[data-theme='dark'] .atk-badge {
  color: rgba(255,255,255,0.7) !important;
}
[data-theme='dark'] #waline-wrap {
  --waline-color: rgba(255,255,255,0.7);
  --waline-dark-grey: rgba(255,255,255,0.7);
  --waline-info-color: rgba(255,255,255,0.5);
}
.read-mode {
  --font-color: #4c4948;
  --readmode-light-color: #fff;
  --white: #4c4948;
  --light-grey: #4c4948;
  --gray: #d6dbdf;
  --hr-border: #d6dbdf;
  --hr-before-color: #b9c2c9;
  --highlight-bg: #f7f7f7;
  --exit-btn-bg: #c0c0c0;
  --exit-btn-color: #fff;
  --exit-btn-hover: #8d8d8d;
  --pseudo-hover: none;
}
[data-theme='dark'] .read-mode {
  --font-color: rgba(255,255,255,0.7);
  --readmode-light-color: #0d0d0d;
  --white: rgba(255,255,255,0.9);
  --light-grey: rgba(255,255,255,0.7);
  --gray: rgba(255,255,255,0.7);
  --hr-border: rgba(255,255,255,0.5);
  --hr-before-color: rgba(255,255,255,0.7);
  --highlight-bg: #171717;
  --exit-btn-bg: #1f1f1f;
  --exit-btn-color: rgba(255,255,255,0.9);
  --exit-btn-hover: #525252;
}
.read-mode {
  background: var(--readmode-light-color);
}
.read-mode .exit-readmode {
  position: fixed;
  top: 30px;
  right: 30px;
  z-index: 100;
  width: 40px;
  height: 40px;
  background: var(--exit-btn-bg);
  color: var(--exit-btn-color);
  font-size: 16px;
  -webkit-transition: background 0.3s;
  -moz-transition: background 0.3s;
  -o-transition: background 0.3s;
  -ms-transition: background 0.3s;
  transition: background 0.3s;
  border-radius: 8px;
}
@media screen and (max-width: 768px) {
  .read-mode .exit-readmode {
    top: initial;
    bottom: 30px;
  }
}
.read-mode .exit-readmode:hover {
  background: var(--exit-btn-hover);
}
.read-mode #aside-content {
  display: none;
}
.read-mode #page-header.post-bg {
  background: none !important;
}
.read-mode #page-header.post-bg:before {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
.read-mode #page-header.post-bg > #post-info {
  text-align: center;
}
.read-mode #post {
  margin: 0 auto;
  background: transparent;
  -webkit-box-shadow: none;
  box-shadow: none;
}
.read-mode #post:hover {
  -webkit-box-shadow: none;
  box-shadow: none;
}
.read-mode > canvas {
  display: none !important;
}
.read-mode .highlight-tools,
.read-mode #footer,
.read-mode #post > *:not(#post-info):not(.post-content),
.read-mode #nav,
.read-mode #post-outdate-notice,
.read-mode #web_bg,
.read-mode #rightside,
.read-mode .not-top-img {
  display: none !important;
}
.read-mode .container a {
  color: #99a9bf;
}
.read-mode .container pre,
.read-mode .container .highlight:not(.js-file-line-container) {
  background: var(--highlight-bg) !important;
}
.read-mode .container pre *,
.read-mode .container .highlight:not(.js-file-line-container) * {
  color: var(--font-color) !important;
}
.read-mode .container figure.highlight {
  border-radius: 0 !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
}
.read-mode .container figure.highlight > :not(.highlight-tools) {
  display: block !important;
}
.read-mode .container figure.highlight .line:before {
  color: var(--font-color) !important;
}
.read-mode .container figure.highlight .hljs {
  background: var(--highlight-bg) !important;
}
.read-mode .container h1,
.read-mode .container h2,
.read-mode .container h3,
.read-mode .container h4,
.read-mode .container h5,
.read-mode .container h6 {
  padding: 0;
}
.read-mode .container h1:before,
.read-mode .container h2:before,
.read-mode .container h3:before,
.read-mode .container h4:before,
.read-mode .container h5:before,
.read-mode .container h6:before {
  content: '';
}
.read-mode .container h1:hover,
.read-mode .container h2:hover,
.read-mode .container h3:hover,
.read-mode .container h4:hover,
.read-mode .container h5:hover,
.read-mode .container h6:hover {
  padding: 0;
}
.read-mode .container ul:hover:before,
.read-mode .container li:hover:before,
.read-mode .container ol:hover:before {
  -webkit-transform: none !important;
  -moz-transform: none !important;
  -o-transform: none !important;
  -ms-transform: none !important;
  transform: none !important;
}
.read-mode .container ol:before,
.read-mode .container li:before {
  background: transparent !important;
  color: var(--font-color) !important;
}
.read-mode .container ul >li:before {
  border-color: var(--gray) !important;
}
.read-mode .container .tabs {
  border: 2px solid var(--tab-border-color);
}
.read-mode .container .tabs > .nav-tabs {
  background: transparent;
}
.read-mode .container .tabs > .nav-tabs > .tab {
  border-top: none !important;
}
.read-mode .container .tabs > .tab-contents .tab-item-content.active {
  -webkit-animation: none;
  -moz-animation: none;
  -o-animation: none;
  -ms-animation: none;
  animation: none;
}
.read-mode .container code {
  color: var(--font-color);
}
.read-mode .container blockquote {
  border-color: var(--gray);
  background-color: var(--readmode-light-color);
}
.read-mode .container kbd {
  border: 1px solid var(--gray);
  background-color: transparent;
  -webkit-box-shadow: none;
  box-shadow: none;
  color: var(--font-color);
}
.read-mode .container .hide-toggle {
  border: 1px solid var(--gray) !important;
}
.read-mode .container .hide-button,
.read-mode .container .btn-beautify,
.read-mode .container .hl-label {
  border: 1px solid var(--gray) !important;
  background: var(--readmode-light-color) !important;
  color: var(--font-color) !important;
}
.read-mode .container .note {
  border: 2px solid var(--gray);
  border-left-color: var(--gray) !important;
  filter: none;
  background-color: var(--readmode-light-color) !important;
  color: var(--font-color);
}
.read-mode .container .note:before,
.read-mode .container .note .note-icon {
  color: var(--font-color);
}
.search-dialog {
  position: fixed;
  top: 10%;
  left: 50%;
  z-index: 1001;
  display: none;
  margin-left: -300px;
  padding: 20px;
  width: 600px;
  background: var(--search-bg);
  --search-height: 100vh;
  border-radius: 8px;
}
@media screen and (max-width: 768px) {
  .search-dialog {
    top: 0;
    left: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
  }
}
.search-dialog .search-nav {
  margin: 0 0 14px;
  color: #49b1f5;
  font-size: 1.4em;
  line-height: 1;
}
.search-dialog .search-nav .search-dialog-title {
  margin-right: 10px;
}
.search-dialog .search-nav .search-close-button {
  float: right;
  color: #858585;
  -webkit-transition: color 0.2s ease-in-out;
  -moz-transition: color 0.2s ease-in-out;
  -o-transition: color 0.2s ease-in-out;
  -ms-transition: color 0.2s ease-in-out;
  transition: color 0.2s ease-in-out;
}
.search-dialog .search-nav .search-close-button:hover {
  color: #49b1f5;
}
.search-dialog hr {
  margin: 15px auto;
}
#search-mask {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1000;
  display: none;
  background: rgba(0,0,0,0.6);
}

/* 全局背景设置 - 移除，让每篇文章使用专属背景 */
/* body {
    background: url(/static/background.jpg) center center/cover no-repeat fixed;
} */

/* 页面特定背景 */
.index-page { background: url(/static/background.jpg) center center/cover no-repeat fixed !important; }
.archive-page { background: url(/static/2.jpg) center center/cover no-repeat fixed !important; }
.tag-page { background: url(/static/3.jpg) center center/cover no-repeat fixed !important; }
.category-page { background: url(/static/4.jpg) center center/cover no-repeat fixed !important; }
.about-page { background: url(/static/5.jpg) center center/cover no-repeat fixed !important; }
.link-page { background: url(/static/6.jpg) center center/cover no-repeat fixed !important; }

/* 文章页面背景 - 使用 CSS 变量支持动态封面背景 */
.post-page {
    background-image: var(--post-bg, url(/static/background.jpg)) !important;
    background-size: cover !important;
    background-position: center !important;
    background-attachment: fixed !important;
    background-repeat: no-repeat !important;
}

/* 特定文章背景图 */
.post-page-hexo-guide {
    background: url(/static/Hexo.jpg) center center/cover no-repeat fixed !important;
}

/* 信息收集类文章背景图 */
.post-page-info-collection {
    background: url(/static/123.jpg) center center/cover no-repeat fixed !important;
}

/* Linux操作系统类文章背景图 */
.post-page-linux {
    background: url(/static/Linux.jpg) center center/cover no-repeat fixed !important;
}

/* 永恒之蓝渗透测试文章背景图 */
.post-page-eternal-blue {
    background: url(/static/EB.png) center center/cover no-repeat fixed !important;
}

/* Knowledge文章背景图 */
.post-page-knowledge {
    background: url(/static/zs/is.jpg) center center/cover no-repeat fixed !important;
}

/* 针对 ld.png 的文章背景（确保生成后也生效） */
.post-page-vulnerability {
    background: url(/static/ld/ld.png) center center/cover no-repeat fixed !important;
}

/* 根据页面 meta og:image 自动应用 ld.png 背景 */
html:has(head meta[property="og:image"][content*="/static/ld/ld.png"]) body,
html:has(head meta[name="og:image"][content*="/static/ld/ld.png"]) body {
    background: url(/static/ld/ld.png) center center/cover no-repeat fixed !important;
}

/* 同步 web 背景层 */
html:has(head meta[property="og:image"][content*="/static/ld/ld.png"]) #web_bg,
html:has(head meta[name="og:image"][content*="/static/ld/ld.png"]) #web_bg {
    background-image: url(/static/ld/ld.png) !important;
}


/* ============ 导航栏：置顶 + 去毛玻璃 ============ */
#nav,
.nav-fixed #nav,
#page-header.nav-fixed #nav {
    position: fixed !important;
    top: 0 !important;
    left: 0; right: 0;
    z-index: 10050 !important;
    opacity: 1 !important;
    background: transparent !important;
    background-color: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: none !important;
}

/* ============ 文章标题区：强制垂直居中（参考 fzero 风格） ============ */
#page-header.post-bg #post-info,
#page-header.not-home-page #post-info,
#page-header #post-info {
    position: absolute !important;
    top: 50% !important;
    bottom: auto !important;
    left: 0; right: 0;
    transform: translateY(-50%) !important;
    padding: 0 8% !important;
    width: 100% !important;
    text-align: center !important;
}

/* 标题与元信息样式 */
#post-info .post-title {
    text-align: center !important;
    font-size: 2.5rem !important;
    font-weight: bold !important;
    color: #fff !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    margin-bottom: 1rem !important;
    line-height: 1.3 !important;
    display: block !important;
    width: 100% !important;
}

#post-meta {
    text-align: center !important;
    color: #fff !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
}

#post-meta .meta-firstline,
#post-meta .meta-secondline {
    justify-content: center !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
    width: 100% !important;
    text-align: center !important;
}

#post-meta .post-meta-separator { color: rgba(255, 255, 255, 0.8) !important; }
#post-meta a { color: rgba(255, 255, 255, 0.9) !important; text-decoration: none !important; }
#post-meta a:hover { color: #fff !important; text-decoration: underline !important; }

/* 内容区域透明度 */
#main { background: rgba(255, 255, 255, 0.95); border-radius: 12px; margin: 20px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1); }

/* 文章卡片样式 */
.recent-post-item { background: rgba(255, 255, 255, 0.9) !important; border-radius: 12px !important; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1) !important; transition: all 0.3s ease; }
.recent-post-item:hover { transform: translateY(-5px); box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15) !important; }

/* 博主头像样式 */
.card-author .card-author-avatar img { border-radius: 50% !important; border: 3px solid rgba(255, 255, 255, 0.8); box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); }

/* 文章封面默认图片 */
.post-cover { background-image: url(/static/Hexo.jpg) !important; }

/* 文章页面特殊样式 */
#post { position: relative; }

/* 移动端优化 */
@media (max-width: 768px) {
    #post-info .post-title { font-size: 1.8rem !important; line-height: 1.2 !important; padding: 0 1rem !important; }
    #page-header #post-info { padding: 0 15px !important; }
    #main { margin: 10px !important; border-radius: 8px !important; }
    .container { padding: 0 10px !important; }
    aside { display: none !important; }
    #main { width: 100% !important; max-width: 100% !important; }
}

/* 超小屏幕 */
@media (max-width: 480px) {
    #post-info .post-title { font-size: 1.5rem !important; padding: 0 0.5rem !important; }
    #main { margin: 5px !important; border-radius: 6px !important; }
}

/* 平板端 */
@media (min-width: 769px) and (max-width: 1024px) {
    #post-info .post-title { font-size: 2.2rem !important; }
    #main { margin: 15px !important; }
}

/* ============ 手机端响应式设计 ============ */
@media (max-width: 768px) {
    /* 文章标题手机端适配 */
    #post-info .post-title {
        font-size: 1.8rem !important;
        line-height: 1.4 !important;
        padding: 0 1rem !important;
    }

    #post-meta {
        font-size: 0.9rem !important;
    }

    /* 手机端侧边栏优化 - 确保显示并优化布局 */
    #aside-content {
        position: relative !important;
        width: 100% !important;
        margin-top: 20px !important;
        float: none !important;
        display: block !important;
    }

    /* 确保侧边栏卡片在手机端显示 */
    #aside-content .card-widget {
        display: block !important;
        margin-bottom: 15px !important;
        border-radius: 8px !important;
    }

    /* 主内容区域手机端适配 */
    #content-inner {
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 0 1rem !important;
        width: 100% !important;
    }

    /* 文章内容手机端适配 */
    #post {
        margin: 0 !important;
        padding: 1rem !important;
        border-radius: 0 !important;
    }

    /* 导航栏手机端适配 */
    #nav {
        padding: 0 1rem !important;
    }

    #nav .menus_item {
        font-size: 0.9rem !important;
    }

    /* 作者卡片手机端优化 */
    .card-author {
        margin-bottom: 15px !important;
    }

    .card-author .card-content {
        padding: 15px !important;
    }

    /* 公告卡片手机端优化 */
    .card-announcement {
        margin-bottom: 15px !important;
    }

    /* 最新文章卡片手机端优化 */
    .card-recent-post {
        margin-bottom: 15px !important;
    }

    .card-recent-post .item {
        padding: 8px 0 !important;
    }

    .card-recent-post .item-title {
        font-size: 14px !important;
        line-height: 1.4 !important;
    }

    /* 分类卡片手机端优化 */
    .card-categories {
        margin-bottom: 15px !important;
    }

    /* 标签卡片手机端优化 */
    .card-tags {
        margin-bottom: 15px !important;
    }

    /* 归档卡片手机端优化 */
    .card-archives {
        margin-bottom: 15px !important;
    }

    /* 网站信息卡片手机端优化 */
    .card-webinfo {
        margin-bottom: 15px !important;
    }
}

@media (max-width: 480px) {
    /* 超小屏幕适配 */
    #post-info .post-title {
        font-size: 1.5rem !important;
        padding: 0 0.5rem !important;
    }

    #post-meta {
        font-size: 0.8rem !important;
    }

    #content-inner {
        padding: 0 0.5rem !important;
    }

    #post {
        padding: 0.5rem !important;
    }

    /* 超小屏幕侧边栏进一步优化 */
    #aside-content .card-widget {
        margin-bottom: 10px !important;
        padding: 15px !important;
    }

    .card-author .card-content {
        padding: 10px !important;
    }

    /* 作者卡片内容手机端优化 */
    .card-author .author-info__name {
        font-size: 18px !important;
    }

    .card-author .author-info__description {
        font-size: 12px !important;
        margin: 8px 0 !important;
    }

    .card-author .author-info__statistics {
        margin: 10px 0 !important;
    }

    .card-author .author-info__statistics .item {
        font-size: 12px !important;
    }

    .card-author .author-info__statistics .item .num {
        font-size: 16px !important;
    }
}

/* ============ IP位置显示样式 ============ */
.author-ip-location {
    margin-top: 12px !important;
    padding: 8px 12px !important;
    background: rgba(73, 177, 245, 0.1) !important;
    border: 1px solid rgba(73, 177, 245, 0.3) !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    color: #49b1f5 !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    word-break: break-word !important;
    line-height: 1.4 !important;
}

/* 深色模式下的IP位置显示 */
[data-theme="dark"] .author-ip-location {
    background: rgba(73, 177, 245, 0.2) !important;
    border: 1px solid rgba(73, 177, 245, 0.4) !important;
    color: #5dade2 !important;
}

/* 手机端IP位置显示优化 */
@media (max-width: 768px) {
    .author-ip-location {
        font-size: 11px !important;
        padding: 6px 10px !important;
        margin-top: 8px !important;
        flex-direction: column !important;
        gap: 4px !important;
    }

    .author-ip-location i {
        margin-right: 0 !important;
        margin-bottom: 2px !important;
    }
}

@media (max-width: 480px) {
    .author-ip-location {
        font-size: 10px !important;
        padding: 5px 8px !important;
        margin-top: 6px !important;
    }
}

/* 确保作者卡片有足够的空间 */
.card-author .card-content {
    padding-bottom: 20px !important;
}

/* 手机端作者卡片优化 */
@media (max-width: 768px) {
    .card-author .card-content {

/* ===== 新增：特定文章背景图（与历史文章风格一致） ===== */
.post-page-aiweb {
  background: url(/static/ai1.png) center center/cover no-repeat fixed !important;
}
.post-page-sqlmap {
  background: url(/static/sql.png) center center/cover no-repeat fixed !important;
}
.post-page-dirsearch {
  background: url(/static/dir.png) center center/cover no-repeat fixed !important;
}
.post-page-nmap {
  background: url(/static/nmap.jpg) center center/cover no-repeat fixed !important;
}

/* ===== 统一 bash 代码块样式（所有文章生效） ===== */
figure.highlight.bash,
pre[class*="language-bash"],
code[class*="language-bash"] {
  background: #0d1117 !important; /* 深色背景 */
  color: #c9d1d9 !important;      /* 代码前景 */
  border-radius: 10px !important;
  border: 1px solid rgba(240,246,252,0.1) !important;
  font-family: Consolas, Menlo, Monaco, 'Courier New', monospace !important;
}
figure.highlight.bash pre,
pre[class*="language-bash"] {
  background: transparent !important;
  margin: 0 !important;
  padding: 12px 14px !important;
  line-height: 1.6 !important;
}
figure.highlight.bash .gutter {
  background: rgba(240,246,252,0.03) !important;
  color: #8b949e !important;
}
figure.highlight.bash .code {
  background: transparent !important;
}
figure.highlight.bash .line,
pre[class*="language-bash"] .line {
  white-space: pre-wrap !important;
  word-break: break-word !important;
}

        padding-bottom: 15px !important;
    }
}


/* ===== 再次声明：特定文章背景（桌面优先，避免被上方 media 包裹） ===== */
.post-page-aiweb { background: url(/static/ai1.png) center center/cover no-repeat fixed !important; }
.post-page-sqlmap { background: url(/static/sql.png) center center/cover no-repeat fixed !important; }
.post-page-dirsearch { background: url(/static/dir.png) center center/cover no-repeat fixed !important; }
.post-page-nmap { background: url(/static/nmap.jpg) center center/cover no-repeat fixed !important; }

/* 保底：让文章页头部透明，显示我们设定的背景 */
#page-header,
.page-header { background: transparent !important; }

/* 如果通过 JS 设置了 --post-bg，则应用到页头（避免内联样式覆盖）*/
.post-page #page-header { background-image: var(--post-bg, none) !important; }

/* ===== 通用代码块风格（无论是否识别语言） ===== */
figure.highlight,
figure.highlight pre,
figure.highlight .code,
figure.highlight .gutter {
  background: #0d1117 !important;
}
figure.highlight {
  color: #c9d1d9 !important;
  border-radius: 10px !important;
  border: 1px solid rgba(240,246,252,0.1) !important;
}
figure.highlight .gutter { color: #8b949e !important; }
figure.highlight pre { padding: 12px 14px !important; line-height: 1.6 !important; }

.greeting-popup {
    position: fixed;
    top: 90px; /* 下移，避免遮挡右上角导航 */
    right: 20px;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 12px;
    padding: 20px 25px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    z-index: 9000; /* 导航z-index=10050，弹窗低于导航 */
    min-width: 280px;
    max-width: 350px;
    transform: translateX(400px);
    opacity: 0;
    transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

.greeting-popup.show {
    transform: translateX(0);
    opacity: 1;
}

.greeting-popup .greeting-header {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.greeting-popup .greeting-icon {
    font-size: 24px;
    margin-right: 12px;
    color: #4a90e2;
    animation: bounce 2s infinite;
}

.greeting-popup .greeting-title {
    font-size: 18px;
    font-weight: 600;
    color: #333;
}

.greeting-popup .close-btn {
    position: absolute;
    top: 12px;
    right: 15px;
    background: none;
    border: none;
    font-size: 18px;
    color: #999;
    cursor: pointer;
}

.greeting-popup .progress-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: linear-gradient(90deg, #4a90e2, #67b6ff);
    border-radius: 0 0 12px 12px;
    animation: progressBar 4s linear forwards;
}

@keyframes progressBar {
    from { width: 100%; }
    to { width: 0%; }
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40% { transform: translateY(-8px); }
    60% { transform: translateY(-4px); }
}

.performance-monitor {
    position: fixed;
    bottom: 20px;
    left: 20px;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(10px);
    color: #fff;
    padding: 12px 16px;
    border-radius: 12px;
    font-family: 'Monaco', 'Menlo', monospace;
    font-size: 12px;
    z-index: 9998;
    min-width: 200px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
    transition: all 0.3s ease;
    opacity: 0.9;
}

.performance-monitor:hover {
    opacity: 1;
    transform: translateY(-2px);
}

.performance-monitor .monitor-title {
    display: flex;
    align-items: center;
    margin-bottom: 8px;
    font-weight: 600;
}

.performance-monitor .metric-row {
    display: flex;
    justify-content: space-between;
    margin: 6px 0;
}

.performance-monitor .metric-value.critical { color: #F44336; }
.performance-monitor .metric-value.warning { color: #FF9800; }
.performance-monitor .fps-value { color: #4CAF50; }
.performance-monitor .ping-value { color: #2196F3; }
.performance-monitor .memory-value { color: #9C27B0; }

.performance-monitor .toggle-btn {
    position: absolute;
    top: -8px;
    right: -8px;
    width: 20px;
    height: 20px;
    background: rgba(255, 255, 255, 0.2);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
}

.performance-monitor.minimized {
    width: 60px;
    height: 40px;
    padding: 8px;
}

.performance-monitor.minimized .monitor-content {
    display: none;
}

/* 导航栏样式 - 参考 blog.fzero.me */
:root{
    --nav-text-color:#ffffff;
    --nav-hover-bg: rgba(255,255,255,0.16);
    --nav-hover-color:#ffffff;
}

/* 导航栏基础样式 - 完全透明背景 */
#nav {
    background: transparent !important;
    background-color: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
    transition: all 0.3s ease;
}

/* 导航栏固定时的样式 - 保持透明 */
#nav.nav-fixed,
.nav-fixed #nav,
#page-header.nav-fixed #nav {
    background: transparent !important;
    background-color: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: none !important;
}

/* 导航栏logo */
#nav .nav-logo {
    display: flex;
    align-items: center;
    font-size: 1.2em;
    font-weight: 600;
    color: var(--nav-text-color) !important;
    text-decoration: none;
}

#nav .nav-logo img {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    margin-right: 10px;
    object-fit: cover;
}

/* 导航菜单样式 */
#nav #menus {
    display: flex;
    align-items: center;
}

#nav #menus .menus_items {
    display: flex;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

#nav #menus .menus_items > .menus_item {
    position: relative;
    margin: 0 15px;
}

#nav #menus .menus_items > .menus_item > a {
    display: flex;
    align-items: center;
    padding: 10px 15px;
    color: var(--nav-text-color) !important;
    text-decoration: none;
    font-weight: 500;
    border-radius: 6px;
    transition: all 0.3s ease;
}

/* 分组菜单（如“文章”“关于”）的文字与图标也统一为白色 */
#nav #menus .menus_items > .menus_item > .group,
#nav #menus .menus_items > .menus_item > .group i{
    color: var(--nav-text-color) !important;
}

#nav #menus .menus_items > li > a:hover {
    background: var(--nav-hover-bg);
    color: var(--nav-hover-color) !important;
    transform: translateY(-1px);
}

#nav #menus .menus_items > .menus_item > a i {
    margin-right: 6px;
    font-size: 0.9em;
    color: var(--nav-text-color) !important;
}

/* 下拉菜单样式 */
#nav #menus .menus_items .menus_item_child {
    position: absolute;
    top: 100%;
    left: 0;
    background: rgba(0, 0, 0, 0.75);
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-radius: 8px;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
    min-width: 160px;
    z-index: 1000;
    border: 1px solid rgba(255, 255, 255, 0.12);
    max-width: calc(100vw - 24px);
}

#nav #menus .menus_items > .menus_item:hover .menus_item_child {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

#nav #menus .menus_item_child li {
    list-style: none;
}

#nav #menus .menus_item_child li a {
    display: block;
    padding: 12px 20px;
    color: #fff !important;
    text-decoration: none;
    font-weight: 400;
    transition: all 0.3s ease;
    border-radius: 6px;
    margin: 4px 8px;
}

#nav #menus .menus_item_child li a:hover {
    background: rgba(255, 255, 255, 0.14);
    color: #fff !important;
}

#nav #menus .menus_item_child li a i {
    margin-right: 8px;
    width: 16px;
    text-align: center;
    color: #fff !important;
}

/* 右侧“关于”等靠右的下拉，不超出可视区域 */
#nav #menus .menus_items > .menus_item:last-child .menus_item_child{
    right: 0;
    left: auto;
}

/* 顶部站点标题颜色与搜索、汉堡按钮颜色 */
#nav .site-name{ color: var(--nav-text-color) !important; text-shadow: 0 1px 2px rgba(0,0,0,0.15); }
#search-button .social-icon i, #search-button .social-icon, #toggle-menu i{ color: var(--nav-text-color) !important; }

/* 搜索按钮样式 */
#nav .search-button {
    padding: 8px 12px;
    background: rgba(74, 144, 226, 0.1);
    border: 1px solid rgba(74, 144, 226, 0.3);
    border-radius: 6px;
    color: #4a90e2;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-left: 15px;
}

#nav .search-button:hover {
    background: rgba(74, 144, 226, 0.2);
    transform: translateY(-1px);
}

/* 移动端适配 */
@media (max-width: 768px) {
    #nav #menus .menus_items {
        flex-direction: column;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: rgba(0, 0, 0, 0.8);
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
        border-radius: 0 0 12px 12px;
        padding: 20px 0;
        transform: translateY(-10px);
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease;
    }
    
    #nav #menus.show .menus_items {
        transform: translateY(0);
        opacity: 1;
        visibility: visible;
    }
    
    #nav #menus .menus_items > .menus_item {
        margin: 5px 20px;
        width: calc(100% - 40px);
    }
    
    #nav #menus .menus_items > .menus_item > a {
        width: 100%;
        justify-content: flex-start;
    }
    
    #nav #menus .menus_item_child {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        background: rgba(0, 0, 0, 0.05);
        margin-top: 10px;
        border-radius: 6px;
    }
}

/* 导航栏动画效果 */
#nav { animation: navSlideDown 0.6s ease-out; }
@keyframes navSlideDown { from { transform: translateY(-100%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

/* 导航栏hover效果增强 */
#nav #menus .menus_items > .menus_item::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 50%;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, rgba(255,255,255,0.6), rgba(255,255,255,0.9));
    transition: all 0.3s ease;
    transform: translateX(-50%);
}

#nav #menus .menus_items > .menus_item:hover::after {
    width: 80%;
}

/* 侧边栏菜单显示修复：确保子菜单在侧栏中默认可见 */
#sidebar-menus .menus_items .menus_item_child { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; background: transparent; border: 0; min-width: auto; }
#sidebar-menus .menus_items .menus_item { margin: 6px 0; }
#sidebar-menus .menus_items .menus_item > a,
#sidebar-menus .menus_items .menus_item > .group { display: flex; align-items: center; padding: 8px 12px; border-radius: 6px; }
#sidebar-menus .menus_items .menus_item_child li a { padding: 8px 28px; }

/* 右侧浮动按钮（返回顶部、设置等）在首页偶尔被遮挡：提升层级，确保始终可见 */
#rightside{ z-index: 10010; }
#sidebar{ z-index: 1005; }

/* 始终显示顶部的侧边栏切换按钮，避免偶发消失 */
#toggle-menu{ display:inline-block !important; cursor:pointer; }
#toggle-menu i{ color: var(--nav-text-color) !important; }

/* 确保导航层级高于问候等弹窗，避免遮挡 */
#nav{ z-index: 10050; position: relative; }

/* 自动隐藏导航：向下隐藏，向上显示 */
#nav.nav-hidden { transform: translateY(-100%); opacity: 0; transition: transform .25s ease, opacity .25s ease; }
#nav.nav-visible { transform: translateY(0); opacity: 1; transition: transform .25s ease, opacity .25s ease; }

/* 保证固定时也应用动画 */
.nav-fixed #nav.nav-hidden { transform: translateY(-100%); opacity: 0; }
.nav-fixed #nav.nav-visible { transform: translateY(0); opacity: 1; }

/* Markdown Guide 风格留言板样式 */
.markdown-guestbook {
    max-width: 900px;
    margin: 0 auto;
    padding: 20px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
    line-height: 1.6;
    color: #24292f;
}

/* GitHub 风格的头部 */
.guestbook-header {
    background: #0d1117;
    color: #f0f6fc;
    padding: 40px 30px;
    border-radius: 12px;
    margin-bottom: 30px;
    border: 1px solid #30363d;
}

.guestbook-header h1 {
    margin: 0 0 10px 0;
    font-size: 2.5rem;
    font-weight: 600;
    color: #f0f6fc;
}

.guestbook-header p {
    margin: 0;
    font-size: 1.1rem;
    color: #8b949e;
}

/* Markdown 文档风格的内容区域 */
.markdown-section {
    background: #ffffff;
    border: 1px solid #d0d7de;
    border-radius: 8px;
    padding: 30px;
    margin-bottom: 20px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.markdown-section h2 {
    margin: 0 0 20px 0;
    font-size: 1.5rem;
    font-weight: 600;
    color: #24292f;
    border-bottom: 1px solid #d0d7de;
    padding-bottom: 10px;
}

.markdown-section h3 {
    margin: 20px 0 15px 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: #24292f;
}

/* GitHub 风格的代码块样式 */
.feature-info {
    background: #f6f8fa;
    border: 1px solid #d0d7de;
    border-radius: 6px;
    padding: 16px;
    margin: 20px 0;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;
}

.feature-info .icon {
    color: #0969da;
    margin-right: 8px;
}

/* 表单样式 - GitHub 风格 */
.github-form {
    background: #f6f8fa;
    border: 1px solid #d0d7de;
    border-radius: 8px;
    padding: 20px;
    margin: 20px 0;
}

.form-group {
    margin-bottom: 16px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: #24292f;
    font-size: 14px;
}

.form-control {
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    line-height: 1.45;
    color: #24292f;
    background-color: #ffffff;
    border: 1px solid #d0d7de;
    border-radius: 6px;
    box-sizing: border-box;
    transition: border-color 0.2s ease-in-out;
}

.form-control:focus {
    outline: none;
    border-color: #0969da;
    box-shadow: 0 0 0 3px rgba(9, 105, 218, 0.1);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 16px;
}

/* Markdown 预览区域 */
.markdown-preview {
    background: #ffffff;
    border: 1px solid #d0d7de;
    border-radius: 6px;
    padding: 16px;
    margin-top: 10px;
    min-height: 100px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
}

.markdown-preview h1, .markdown-preview h2, .markdown-preview h3 {
    margin-top: 0;
    margin-bottom: 16px;
}

.markdown-preview code {
    background: #f6f8fa;
    padding: 2px 4px;
    border-radius: 3px;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;
    font-size: 85%;
}

.markdown-preview pre {
    background: #f6f8fa;
    padding: 16px;
    border-radius: 6px;
    overflow-x: auto;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;
}

.markdown-preview blockquote {
    margin: 0;
    padding: 0 16px;
    color: #656d76;
    border-left: 4px solid #d0d7de;
}

/* GitHub 风格按钮 */
.btn-github {
    background: #2da44e;
    color: #ffffff;
    border: 1px solid rgba(27, 31, 36, 0.15);
    border-radius: 6px;
    padding: 8px 16px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    display: inline-block;
}

.btn-github:hover {
    background: #2c974b;
    border-color: rgba(27, 31, 36, 0.15);
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0,0,0,0.12);
}

.btn-github:disabled {
    background: #94d3a2;
    cursor: not-allowed;
    transform: none;
}

/* 留言列表 - GitHub Issues 风格 */
.comments-list {
    margin-top: 20px;
}

.comment-item {
    background: #ffffff;
    border: 1px solid #d0d7de;
    border-radius: 8px;
    margin-bottom: 16px;
    overflow: hidden;
}

.comment-header {
    background: #f6f8fa;
    border-bottom: 1px solid #d0d7de;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.comment-author {
    font-weight: 600;
    color: #0969da;
    text-decoration: none;
}

.comment-time {
    color: #656d76;
    font-size: 12px;
}

.comment-body {
    padding: 16px;
}

.comment-content {
    color: #24292f;
    line-height: 1.6;
}

/* Markdown 工具栏 */
.markdown-toolbar {
    background: #f6f8fa;
    border: 1px solid #d0d7de;
    border-bottom: none;
    border-radius: 6px 6px 0 0;
    padding: 8px 12px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.toolbar-btn {
    background: none;
    border: 1px solid transparent;
    border-radius: 4px;
    padding: 4px 8px;
    font-size: 12px;
    color: #656d76;
    cursor: pointer;
    transition: all 0.2s ease;
}

.toolbar-btn:hover {
    background: #ffffff;
    border-color: #d0d7de;
    color: #24292f;
}

/* 字符计数器 */
.char-counter {
    text-align: right;
    font-size: 12px;
    color: #656d76;
    margin-top: 8px;
}

.char-counter.warning {
    color: #d1242f;
}

/* 响应式设计 */
@media (max-width: 768px) {
    .markdown-guestbook {
        padding: 15px;
    }
    
    .form-grid {
        grid-template-columns: 1fr;
    }
    
    .guestbook-header h1 {
        font-size: 2rem;
    }
    
    .markdown-toolbar {
        flex-direction: column;
        gap: 4px;
    }
    
    .comment-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
}

/* 深色模式适配 */
[data-theme="dark"] .markdown-section {
    background: #0d1117;
    border-color: #30363d;
    color: #f0f6fc;
}

[data-theme="dark"] .markdown-section h2,
[data-theme="dark"] .markdown-section h3 {
    color: #f0f6fc;
    border-color: #30363d;
}

[data-theme="dark"] .github-form {
    background: #161b22;
    border-color: #30363d;
}

[data-theme="dark"] .form-control {
    background: #0d1117;
    border-color: #30363d;
    color: #f0f6fc;
}

[data-theme="dark"] .markdown-preview {
    background: #0d1117;
    border-color: #30363d;
    color: #f0f6fc;
}

[data-theme="dark"] .comment-item {
    background: #0d1117;
    border-color: #30363d;
}

[data-theme="dark"] .comment-header {
    background: #161b22;
    border-color: #30363d;
}

[data-theme="dark"] .comment-content {
    color: #f0f6fc;
}

/* 头像预览与上传按钮布局修复 */
#gb-form .row { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
#gb-form .row.mood { grid-template-columns: auto 1fr; align-items: center; }
#gb-form .gb-avatar-preview { display: flex; align-items: center; justify-content: center; }
#gb-form #gb-avt-img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; box-shadow: 0 0 0 2px rgba(0,0,0,0.05); }

@media (max-width: 600px) {
  #gb-form .row { grid-template-columns: 1fr; }
  #gb-form .row.mood { grid-template-columns: auto 1fr; }
}

:root{--card-bg:#fff;--card-br:#e9edf2;--muted:#8a95a3;--text:#2b2f36}
#shuoshuo-app{max-width:860px;margin:0 auto;padding:0 12px}
.ss-tools{display:flex;align-items:center;gap:10px;margin:10px 0;flex-wrap:wrap}
.ss-tools button{border:1px solid var(--card-br);background:#fff;border-radius:999px;padding:8px 14px;cursor:pointer}
.ss-item{background:var(--card-bg);border:1px solid var(--card-br);border-radius:12px;padding:14px;margin:12px 0}
.ss-item .hd{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:14px;margin-bottom:6px;flex-wrap:wrap}
.ss-item .name{color:#2b2f36;font-weight:700}
.ss-item .content{color:var(--text);line-height:1.7}

/* 通用图库容器 */
.ss-gallery{display:grid;gap:10px;margin-top:10px}
.ss-gallery img{width:100%;height:auto;border-radius:10px;border:1px solid var(--card-br);object-fit:cover}

/* 单图：放大至容器宽度内，限制最大高度，保持不溢出 */
.ss-gallery.single{grid-template-columns:1fr}
.ss-gallery.single img{max-height:520px;width:100%;object-fit:contain;background:rgba(0,0,0,0.02)}

/* 两图：左右并排卡片，保持良好可读性 */
.ss-gallery.two{grid-template-columns:1fr 1fr}
.ss-gallery.two img{aspect-ratio: 16 / 10; object-fit:cover}

/* 多图：自适应网格，小卡片 */
.ss-gallery.multi{grid-template-columns:repeat(3, 1fr)}
.ss-gallery.multi img{aspect-ratio: 1 / 1; object-fit:cover}

.ss-empty{color:var(--muted);text-align:center;padding:20px 0}

@media(max-width:980px){
  .ss-gallery.single img{max-height:460px}
}
@media(max-width:768px){
  .ss-tools{gap:8px}
  .ss-tools button{width:100%;padding:10px 14px}
  .ss-item{padding:12px}
  .ss-item .hd{font-size:13px}
  .ss-gallery.two{grid-template-columns:1fr;}
  .ss-gallery.multi{grid-template-columns:repeat(2, 1fr)}
  .ss-gallery.single img{max-height:380px}
}
@media(max-width:480px){
  .ss-gallery.multi{grid-template-columns:repeat(2, 1fr)}
  .ss-gallery.single img{max-height:300px}
} 
:root{--card-bg:#fff;--card-br:#e9edf2;--text:#2b2f36;--muted:#8a95a3;--pri:#4a90e2;--shadow:0 10px 24px rgba(18,38,63,.08)}
#guestbook-app{max-width:980px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial;color:var(--text);padding:0 12px}
.gb-card{background:var(--card-bg);border:1px solid var(--card-br);border-radius:14px;box-shadow:var(--shadow);padding:18px;margin-bottom:18px}
.gb-hero{display:flex;gap:18px;align-items:center}
.gb-hero .img{width:120px;height:120px;border-radius:12px;overflow:hidden;flex:0 0 120px;border:1px solid var(--card-br)}
.gb-hero .img img{width:100%;height:100%;object-fit:cover}
.gb-hero .meta h2{margin:0 0 6px 0;font-size:22px}
.gb-hero .meta p{margin:4px 0;color:var(--muted)}
.gb-badges{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}
.gb-badge{background:#f3f6fa;border:1px solid #e6ebf1;padding:6px 10px;border-radius:999px;color:#445066;font-size:12px}
.gb-stats{display:flex;gap:14px;margin-top:6px;color:#55606e;font-size:13px}

.gb-rules h4{margin:0 0 10px 0}
.gb-form .row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:10px}
.gb-form input,.gb-form textarea,.gb-form select{width:100%;padding:10px 12px;border:1.8px solid #e5e8eb;border-radius:10px;background:#fff;color:var(--text);transition:border .2s,box-shadow .2s}
.gb-form input:focus,.gb-form textarea:focus,.gb-form select:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px rgba(74,144,226,.15)}
.gb-form .mood{grid-template-columns:80px 1fr;align-items:center;color:#55606e}
.gb-form button{background:linear-gradient(135deg,#4a90e2,#3d7ed1);color:#fff;border:none;padding:12px 18px;border-radius:20px;cursor:pointer;box-shadow:0 8px 16px rgba(74,144,226,.25)}
.gb-form button:hover{filter:brightness(1.03)}
.gb-avatar-preview{display:flex;align-items:center;gap:10px}
#gb-avt-img{width:44px;height:44px;border-radius:50%;border:1px solid var(--card-br);object-fit:cover}

.gb-item{border:1px solid var(--card-br);border-radius:12px;padding:14px;background:#fff;margin-bottom:12px}
.gb-item .hd{display:flex;gap:8px;align-items:center;margin-bottom:6px;flex-wrap:wrap}
.gb-item .hd .avt img{width:28px;height:28px;border-radius:50%;border:1px solid var(--card-br);object-fit:cover}
.gb-item .name{font-weight:700}
.gb-item .time{margin-left:auto;font-size:12px;color:var(--muted)}
.gb-item .content{color:#3a4250;line-height:1.7;word-break:break-word}

.gb-load{display:flex;justify-content:center;margin:10px 0}
.gb-load button{background:#fff;border:1.5px solid var(--card-br);padding:10px 16px;border-radius:999px;cursor:pointer}
.gb-load button:hover{border-color:var(--pri);color:var(--pri)}

.gb-extras{display:grid;grid-template-columns:2fr 1fr;gap:18px}
@media(max-width:900px){.gb-extras{grid-template-columns:1fr}}
.gb-note{font-size:14px;color:#54606e}
.gb-kv{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.gb-kv .kv{background:#f8fafc;border:1px solid #eef2f6;border-radius:10px;padding:10px}
.gb-kv .k{font-size:12px;color:#8892a0}
.gb-kv .v{font-weight:700;color:#2b2f36}

.gb-footer-wave{margin-top:18px;border-radius:14px;overflow:hidden;border:1px solid var(--card-br);box-shadow:var(--shadow)}
.gb-footer-wave svg{display:block;width:100%;height:140px}

/* 头像与列表布局增强 */
.gb-card{ background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:18px; margin:16px 0; }
#gb-list .gb-item{ padding:12px 8px; border-bottom:1px dashed #eee; }
#gb-list .gb-item:last-child{ border-bottom:none; }
#gb-list .gb-item .hd{ display:flex; align-items:center; gap:10px; font-size:14px; color:#6b7280; }
#gb-list .gb-item .hd .avt img{ width:38px; height:38px; border-radius:50%; object-fit:cover; box-shadow:0 0 0 2px rgba(0,0,0,.03); }
#gb-list .gb-item .name{ color:#111827; font-weight:600; }
#gb-list .gb-item .mood{ margin-left:auto; min-width:90px; text-align:right; color:#374151; }
#gb-list .gb-item .time{ margin-left:14px; white-space:nowrap; font-size:12px; color:#9ca3af; }
#gb-list .gb-item .content{ margin-top:8px; font-size:15px; color:#111827; line-height:1.7; }

/* 表单与预览行距 */
#gb-form{ margin-bottom:12px; }
#gb-form .row{ margin-bottom:10px; }
#gb-form .gb-avatar-preview{ min-height:56px; }

/* Mobile 优化 */
@media(max-width:680px){
  .gb-hero{flex-direction:column;align-items:flex-start}
  .gb-hero .img{width:100%;height:auto;flex:none}
  .gb-hero .img img{height:auto}
  .gb-form .row{grid-template-columns:1fr}
  .gb-form .mood{grid-template-columns:70px 1fr}
  .gb-form button{width:100%;padding:14px 18px;border-radius:14px}
  .gb-item .time{margin-left:0;order:3;width:100%}
  #gb-list .gb-item .mood{min-width:auto;margin-left:0;text-align:left}
  .gb-load button{width:100%}
  #gb-avt-img{width:40px;height:40px}
}

/* 通用小游戏样式 */
.lab-container{max-width:1100px;margin:0 auto;padding:1rem}
.lab-intro{background:var(--card);padding:1rem 1.2rem;border-radius:12px;margin-bottom:1rem}
.lab-intro h1{margin:0 0 .5rem}
/* 美化按钮 */
.lab-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:.5rem 1rem;margin:.3rem .4rem;cursor:pointer;font-weight:600;letter-spacing:.02em;box-shadow:0 6px 16px rgba(99,102,241,.25),inset 0 1px 0 rgba(255,255,255,.15);transition:transform .12s ease,box-shadow .2s ease,filter .2s ease}
.lab-btn:hover{filter:brightness(1.05);box-shadow:0 10px 22px rgba(99,102,241,.35)}
.lab-btn:active{transform:translateY(1px);box-shadow:0 6px 12px rgba(0,0,0,.25)}
.lab-btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(99,102,241,.25),0 8px 20px rgba(99,102,241,.35)}
.lab-btn:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.1)}
.lab-btn.alt{background:linear-gradient(135deg,#0ea5e9,#22d3ee);border-color:rgba(255,255,255,.18);box-shadow:0 6px 16px rgba(14,165,233,.25),inset 0 1px 0 rgba(255,255,255,.15)}
.lab-btn.alt:hover{box-shadow:0 10px 22px rgba(14,165,233,.35)}
.lab-stage{background:var(--card);border-radius:12px;padding:1rem}
.lab-controls{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-bottom:.6rem}
.lab-controls label{display:flex;align-items:center;gap:.4rem}
.lab-controls .lab-btn{min-height:36px;line-height:1.2}
.lab-editor{display:grid;grid-template-columns:minmax(280px,1fr) 340px;gap:.6rem}
.lab-editor textarea{height:140px;width:100%;padding:.6rem;border-radius:8px;border:1px solid var(--border)}
.lab-hints details{background:var(--card);border:1px dashed var(--border);border-radius:8px;padding:.3rem .6rem;margin:.2rem 0}
.lab-preview{margin-top:.8rem}
.lab-status{display:flex;gap:1rem;margin-bottom:.4rem;font-size:.95rem}
#xss-iframe{width:100%;height:280px;border:1px solid var(--border);border-radius:8px;background:#fff}
.lab-result{background:#0b1020;color:#c8e1ff;border-radius:8px;padding:.8rem;min-height:180px;white-space:pre-wrap}
/* 运行状态提示动画 */
#xss-status, #sqli-status{position:relative}
#xss-status.loading::after, #sqli-status.loading::after{content:' ···';animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:.4}}
@media (max-width:860px){.lab-editor{grid-template-columns:1fr}}

/* 美化下拉选择器 */
.lab-controls select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--card)!important;color:inherit;border:1px solid var(--border)!important;border-radius:10px;padding:.4rem 2rem .4rem .6rem;line-height:1.2;box-shadow:inset 0 1px 0 rgba(255,255,255,.15),0 1px 2px rgba(0,0,0,.04);transition:border-color .2s ease,box-shadow .2s ease,filter .2s ease}
.lab-controls select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;background-size:1rem}
.lab-controls select:hover{border-color:#8b5cf6!important;box-shadow:0 0 0 3px rgba(99,102,241,.18)!important}
.lab-controls select:focus{outline:none;border-color:#6366f1!important;box-shadow:0 0 0 3px rgba(99,102,241,.25)!important}
.lab-controls label{font-weight:500}

/* 语义色按钮 */
.lab-btn.success{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:rgba(255,255,255,.18);box-shadow:0 6px 16px rgba(34,197,94,.25),inset 0 1px 0 rgba(255,255,255,.15)}
.lab-btn.success:hover{box-shadow:0 10px 22px rgba(34,197,94,.35)}
.lab-btn.warning{background:linear-gradient(135deg,#f59e0b,#f97316);border-color:rgba(255,255,255,.18);box-shadow:0 6px 16px rgba(245,158,11,.25),inset 0 1px 0 rgba(255,255,255,.15)}
.lab-btn.warning:hover{box-shadow:0 10px 22px rgba(245,158,11,.35)}
.lab-btn.danger{background:linear-gradient(135deg,#ef4444,#f43f5e);border-color:rgba(255,255,255,.18);box-shadow:0 6px 16px rgba(239,68,68,.25),inset 0 1px 0 rgba(255,255,255,.15)}
.lab-btn.danger:hover{box-shadow:0 10px 22px rgba(239,68,68,.35)}
.lab-btn.info{background:linear-gradient(135deg,#0ea5e9,#22d3ee);border-color:rgba(255,255,255,.18);box-shadow:0 6px 16px rgba(14,165,233,.25),inset 0 1px 0 rgba(255,255,255,.15)}
.lab-btn.info:hover{box-shadow:0 10px 22px rgba(14,165,233,.35)}
.lab-btn.secondary{background:linear-gradient(135deg,#94a3b8,#64748b);border-color:rgba(255,255,255,.18);box-shadow:0 6px 16px rgba(100,116,139,.25),inset 0 1px 0 rgba(255,255,255,.15)}
.lab-btn.secondary:hover{box-shadow:0 10px 22px rgba(100,116,139,.35)}

/* 默认把“重置进度”做成警示色，“前/后”保持信息色 */
#xss-reset.lab-btn,#sqli-reset.lab-btn{background:linear-gradient(135deg,#f59e0b,#f97316);box-shadow:0 6px 16px rgba(245,158,11,.25)}
#xss-reset.lab-btn:hover,#sqli-reset.lab-btn:hover{box-shadow:0 10px 22px rgba(245,158,11,.35)}

/* 给各个选择器着色（强制生效） */
#xss-mode,#sqli-mode{background:linear-gradient(180deg,#eef2ff,#e0e7ff)!important;border-color:#c7d2fe!important;color:#111827!important}
#xss-level,#sqli-level{background:linear-gradient(180deg,#f5f3ff,#ede9fe)!important;border-color:#ddd6fe!important;color:#111827!important}
#xss-sink{background:linear-gradient(180deg,#fff1f2,#ffe4e6)!important;border-color:#fecdd3!important;color:#111827!important}
#xss-csp{background:linear-gradient(180deg,#ecfeff,#cffafe)!important;border-color:#bae6fd!important;color:#111827!important}
#sqli-dataset{background:linear-gradient(180deg,#ecfeff,#cffafe)!important;border-color:#bae6fd!important;color:#111827!important}
#sqli-guard{background:linear-gradient(180deg,#fef9c3,#fde68a)!important;border-color:#fde68a!important;color:#111827!important}

/* 选择器 hover/focus 高亮，与主题保持一致（强制） */
#xss-mode:hover,#sqli-mode:hover,#xss-level:hover,#sqli-level:hover,#xss-sink:hover,#xss-csp:hover,#sqli-dataset:hover,#sqli-guard:hover{box-shadow:0 0 0 3px rgba(99,102,241,.14)!important}
#xss-mode:focus,#sqli-mode:focus,#xss-level:focus,#sqli-level:focus,#xss-sink:focus,#xss-csp:focus,#sqli-dataset:focus,#sqli-guard:focus{outline:none;border-color:#6366f1!important;box-shadow:0 0 0 3px rgba(99,102,241,.22)!important}
