html.darkmode, html.darkmode body {
  background-color: #222226 !important;
  color: #e6e6e6 !important; }

  html {
    font-size: 62.5%;
    background-color: #ffffff;
    height: 100%;
    scrollbar-width: none; }
    html::-webkit-scrollbar {
      display: none; }

* {
  box-sizing: border-box; }

  body {
    margin: 0;
    padding: 0;
    min-height: 100%;
    font-size: 1.6rem;
    line-height: 1.6;
    font-family: Cambria, 'Microsoft Yahei', sans-serif;
    font-weight: 300;
    color: #222222;
    background-color: #ffffff;
    overflow-x: hidden;
    transition: background-color 0.2s ease; }

    .container {
      display: flex;
      flex-direction: column;
      min-height: 100vh;
      max-width: 640px;
      margin: 0 auto;
      padding: 0 20px; }

      main {
        flex: 1 0 auto; }

        a:not(.back_to_top):not(.site-title a):not([class*="back_to_top"] a) {
          color: inherit;
          text-decoration: underline;
          text-decoration-color: #0FA0CE;
          text-underline-offset: 3px;
          position: relative;
          z-index: 1;
          transition: color 0.2s ease; }
          a:not(.back_to_top):not(.site-title a):not([class*="back_to_top"] a):after {
            content: '';
            position: absolute;
            left: 0;
            right: 0;
            bottom: 0;
            height: 0;
            background: #0FA0CE;
            z-index: -1;
            transition: height 0.2s ease; }
            a:not(.back_to_top):not(.site-title a):not([class*="back_to_top"] a):hover {
              color: #fff !important;
              text-decoration-color: transparent !important; }
              a:not(.back_to_top):not(.site-title a):not([class*="back_to_top"] a):hover:after {
                height: 100% !important; }

.site-title a, a.back_to_top, .back_to_top {
  text-decoration: none !important;
  transition: color 0.2s ease; }
  .site-title a:after, a.back_to_top:after, .back_to_top:after {
    display: none !important;
    content: none !important; }
    .site-title a:hover, a.back_to_top:hover, .back_to_top:hover {
      color: #0FA0CE !important;
      background: transparent !important;
      text-decoration: none !important; }
      .site-title a:hover:after, a.back_to_top:hover:after, .back_to_top:hover:after {
        display: none !important;
        height: 0 !important; }

header {
  padding: 3rem 0 0; }

  .header-top {
    display: flex;
    align-items: center;
    margin-bottom: 0; }

    .mode {
      cursor: pointer;
      margin-right: 15px;
      user-select: none;
      display: flex; }
      .mode .mode-icon {
        width: 3.2rem;
        height: 3.2rem;
        transition: transform 0.3s; }
        .mode .mode-icon:hover {
          transform: scale(1.1); }
      .mode .light-icon {
        display: block; }
        .mode .dark-icon {
          display: none; }

body.darkmode .mode .light-icon {
  display: none; }
  body.darkmode .mode .dark-icon {
    display: block; }

.site-title {
  font-size: 3.4rem;
  font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
  margin: 0; }
  .site-title a {
    color: inherit !important;
    font-weight: bold !important;
    text-decoration: none !important;
    position: relative;
    z-index: 1; }
    .site-title a:after {
      display: none !important;
      content: none !important;
      height: 0 !important; }
      .site-title a:hover {
        background: transparent !important;
        color: inherit !important;
        text-decoration: none !important; }
        .site-title a:hover:after {
          display: none !important;
          content: none !important;
          height: 0 !important; }

nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 3rem 0 2.6rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #E1E1E1;
  transition: border-bottom-color 0.2s; }
  nav .nav-links {
    display: flex; }
    nav .nav-links ul {
      display: flex;
      list-style: none;
      margin: 0;
      padding: 0; }
      nav .nav-links a {
        margin-right: 1.8rem;
        font-weight: 300; }
  nav .nav-search form {
    display: flex; }
    nav .nav-search input {
      width: 150px;
      height: 28px;
      padding: 0 10px;
      font-size: 1.2rem;
      color: inherit;
      font-weight: 300;
      border: 1px solid #E1E1E1;
      border-radius: 4px;
      background-color: transparent !important;
      outline: none;
      transition: width 0.3s ease, border-color 0.2s; }
      nav .nav-search input:focus {
        border-color: #0FA0CE;
        width: 220px; }
        nav .nav-search input::placeholder {
          color: #999999; }

main .column p {
  font-size: 1.6rem;
  line-height: 2;
  margin-bottom: 2.2rem;
  font-weight: 300; }
  main .column ruby rt {
    font-size: 0.6em;
    color: #999999;
    transform: translateY(-2px); }

h3 {
  font-size: 1.8rem;
  margin-top: 3rem;
  margin-bottom: 1.5rem;
  font-weight: bold !important; }

  h4 {
    font-size: 1.5rem;
    margin-top: 2.5rem;
    margin-bottom: 0.5rem; }
    h4 a {
      font-weight: bold !important; }

.post-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important; }
  .post-list .post-item {
    margin-bottom: 0.8rem; }
    .post-list .post-item .post-link {
      display: flex !important;
      justify-content: space-between;
      align-items: center;
      padding: 8px 12px;
      color: inherit;
      text-decoration: none !important; }
      .post-list .post-item .post-link .post-date {
        font-size: 1.6rem;
        color: #999999;
        flex-shrink: 0;
        font-weight: 300;
        margin-right: 1.5rem; }
        .post-list .post-item .post-link .post-date::before {
          content: '+ '; }
      .post-list .post-item .post-link .post-title {
        flex-grow: 1;
        text-align: left;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        font-weight: 300; }
        .post-list .post-item .post-link .post-visits {
          font-size: 1.6rem;
          color: #999999;
          flex-shrink: 0;
          font-weight: 300;
          margin-left: 10px; }
          .post-list .post-item .post-link:after {
            content: '';
            position: absolute;
            left: 0;
            right: 0;
            bottom: 0;
            height: 0;
            background: #0FA0CE;
            z-index: -1;
            transition: height 0.2s ease; }
            .post-list .post-item .post-link:hover {
              color: #fff !important; }
              .post-list .post-item .post-link:hover .post-date,
              .post-list .post-item .post-link:hover .post-visits {
                color: #fff !important; }
                .post-list .post-item .post-link:hover:after {
                  height: 100% !important; }

footer {
  flex-shrink: 0;
  color: #999999;
  font-size: 1.2rem;
  padding: 1.5rem 0 1.5rem;
  border-top: none;
  line-height: 1.4;
  font-weight: 300; }
  footer #siteinfo, footer #poweredby {
    margin-bottom: 2px; }
    footer span, footer a {
      margin-right: 8px;
      white-space: nowrap; }

body.darkmode nav {
  border-bottom-color: #444444 !important; }
  body.darkmode .nav-search input {
    border-color: #444444 !important; }
    body.darkmode .nav-search input::placeholder {
      color: #888888; }
body.darkmode main .column p ruby rt, body.darkmode footer,
body.darkmode footer span, body.darkmode footer a {
  color: #888888 !important; }
  body.darkmode .post-list .post-link .post-date,
  body.darkmode .post-list .post-link .post-visits {
    color: #888888 !important;
    transition: color 0.2s; }
    body.darkmode .post-list .post-link:hover .post-date,
    body.darkmode .post-list .post-link:hover .post-visits {
      color: #fff !important; }

.archive-page-container #cat-tag #cats {
  margin-top: 0; }
  .archive-page-container #cat-tag #cats .title {
    display: flex;
    align-items: baseline;
    border-bottom: 1px solid #E1E1E1;
    margin-bottom: 2rem;
    padding-bottom: 8px;
    transition: border-bottom-color 0.3s ease; }
    .archive-page-container #cat-tag #cats .title h1 {
      font-size: 2.4rem;
      margin: 0 1.5rem 0 0 !important;
      font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
      font-weight: bold; }
      .archive-page-container #cat-tag #cats .title span {
        font-size: 1.4rem;
        color: #999999; }
.archive-page-container #cat-tag #tags {
  margin-top: 1rem; }
  .archive-page-container #cat-tag #tags .title {
    display: flex;
    align-items: baseline;
    border-bottom: 1px solid #E1E1E1;
    margin-bottom: 2rem;
    padding-bottom: 8px;
    transition: border-bottom-color 0.3s ease; }
    .archive-page-container #cat-tag #tags .title h1 {
      font-size: 2.4rem;
      margin: 0 1.5rem 0 0 !important;
      font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
      font-weight: bold; }
      .archive-page-container #cat-tag #tags .title span {
        font-size: 1.4rem;
        color: #999999; }
.archive-page-container #cat-tag .item-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 1rem 1.5rem; }
  .archive-page-container #cat-tag .item-list li a {
    display: inline-flex;
    align-items: baseline;
    text-decoration: none !important;
    color: inherit;
    font-size: 1.6rem;
    position: relative;
    z-index: 1; }
    .archive-page-container #cat-tag .item-list li a .sep {
      margin: 0 4px;
      font-size: 1.2rem;
      color: #999999; }
      .archive-page-container #cat-tag .item-list li a span {
        font-size: 1.3rem;
        color: #999999; }
        .archive-page-container #cat-tag .item-list li a:after {
          content: '';
          position: absolute;
          left: -4px;
          right: -4px;
          bottom: 0;
          height: 0;
          background: #0FA0CE;
          z-index: -1;
          transition: height 0.2s ease-in-out; }
          .archive-page-container #cat-tag .item-list li a:hover {
            color: #fff !important; }
            .archive-page-container #cat-tag .item-list li a:hover span,
            .archive-page-container #cat-tag .item-list li a:hover .sep {
              color: #fff !important; }
              .archive-page-container #cat-tag .item-list li a:hover:after {
                height: 100% !important; }
.archive-page-container #archive {
  margin-top: 1rem; }
  .archive-page-container #archive .title {
    display: flex;
    align-items: baseline;
    margin-bottom: 3rem;
    border-bottom: 1px solid #E1E1E1;
    padding-bottom: 8px;
    transition: border-bottom-color 0.3s ease; }
    .archive-page-container #archive .title h1 {
      font-size: 2.6rem;
      margin: 0 1.5rem 0 0 !important;
      font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
      font-weight: bold; }
      .archive-page-container #archive .title span {
        font-size: 1.4rem;
        color: #999999; }
  .archive-page-container #archive .sub-title {
    display: flex;
    align-items: center;
    margin: 4rem 0 1.5rem; }
    .archive-page-container #archive .sub-title h2 {
      font-size: 2rem;
      margin: 0;
      font-weight: bold;
      color: inherit; }
      .archive-page-container #archive .sub-title .sep {
        margin: 0 8px;
        color: #999999; }
        .archive-page-container #archive .sub-title span:last-child {
          font-size: 1.5rem;
          color: #999999; }
  .archive-page-container #archive .post-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important; }
    .archive-page-container #archive .post-list li {
      margin-bottom: 0.8rem; }
      .archive-page-container #archive .post-list li a {
        display: flex !important;
        justify-content: space-between;
        align-items: center;
        padding: 8px 12px;
        color: inherit;
        text-decoration: none !important;
        position: relative;
        z-index: 1;
        background-color: transparent !important; }
        .archive-page-container #archive .post-list li a time {
          font-size: 1.6rem;
          color: #999999;
          flex-shrink: 0;
          margin-right: 1.5rem;
          font-weight: 300; }
          .archive-page-container #archive .post-list li a time::before {
            content: '+ '; }
        .archive-page-container #archive .post-list li a h4 {
          flex-grow: 1;
          text-align: left;
          margin: 0;
          font-size: 1.6rem;
          font-weight: 300;
          white-space: nowrap;
          overflow: hidden;
          text-overflow: ellipsis;
          font-family: inherit; }
          .archive-page-container #archive .post-list li a span:last-child {
            font-size: 1.6rem;
            color: #999999;
            margin-left: 10px;
            flex-shrink: 0;
            font-weight: 300; }
            .archive-page-container #archive .post-list li a:after {
              content: '';
              position: absolute;
              left: 0;
              right: 0;
              bottom: 0;
              height: 0;
              background: #0FA0CE;
              z-index: -1;
              transition: height 0.2s ease; }
              .archive-page-container #archive .post-list li a:hover {
                color: #fff !important; }
                .archive-page-container #archive .post-list li a:hover time,
                .archive-page-container #archive .post-list li a:hover h4,
                .archive-page-container #archive .post-list li a:hover span:last-child {
                  color: #fff !important; }
                  .archive-page-container #archive .post-list li a:hover:after {
                    height: 100% !important; }
.archive-page-container #pager {
  margin-top: 5rem;
  padding: 2rem 0;
  text-align: center; }
  .archive-page-container #pager .paginator {
    font-size: 1.4rem; }
    .archive-page-container #pager .paginator a,
    .archive-page-container #pager .paginator span {
      margin: 0 5px;
      text-decoration: none !important; }
      .archive-page-container #pager .paginator .current {
        color: #0FA0CE;
        font-weight: bold; }

body.darkmode .archive-page-container #cat-tag .title,
body.darkmode .archive-page-container #archive .title {
  border-bottom-color: #444444 !important; }
  body.darkmode .archive-page-container #cat-tag .item-list li a span,
  body.darkmode .archive-page-container #cat-tag .item-list li a .sep {
    color: #888888 !important; }
    body.darkmode .archive-page-container #cat-tag .item-list li a:hover span,
    body.darkmode .archive-page-container #cat-tag .item-list li a:hover .sep {
      color: #fff !important; }
body.darkmode .archive-page-container #archive .sub-title .sep,
body.darkmode .archive-page-container #archive .sub-title span:last-child {
  color: #888888 !important; }
  body.darkmode .archive-page-container .post-list li a time,
  body.darkmode .archive-page-container .post-list li a h4,
  body.darkmode .archive-page-container .post-list li a span:last-child {
    color: #888888 !important; }
    body.darkmode .archive-page-container .post-list li a:hover time,
    body.darkmode .archive-page-container .post-list li a:hover h4,
    body.darkmode .archive-page-container .post-list li a:hover span:last-child {
      color: #fff !important; }

.tag-items.section-group {
  margin-top: 0;
  margin-bottom: 4rem; }
  .tag-items.section-group .title-row {
    display: flex;
    align-items: baseline;
    margin-bottom: 3.5rem;
    border-bottom: 1px solid #E1E1E1;
    padding-bottom: 8px;
    transition: border-bottom-color 0.3s ease; }
    .tag-items.section-group .title-row .tag-title {
      margin: 0 1.5rem 0 0 !important;
      font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
      font-size: 2.6rem;
      font-weight: bold; }
      .tag-items.section-group .title-row .tag-title .label {
        color: inherit; }
        .tag-items.section-group .title-row .tag-title .name {
          color: inherit; }
    .tag-items.section-group .title-row .count {
      font-size: 1.4rem;
      color: #999999; }
  .tag-items.section-group .post-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important; }
    .tag-items.section-group .post-list .post-item {
      margin-bottom: 0.8rem; }
      .tag-items.section-group .post-list .post-item .post-link {
        display: flex !important;
        justify-content: space-between;
        align-items: center;
        padding: 8px 12px;
        color: inherit;
        text-decoration: none !important;
        position: relative;
        z-index: 1; }
        .tag-items.section-group .post-list .post-item .post-link .post-date {
          font-size: 1.6rem;
          color: #999999;
          flex-shrink: 0;
          margin-right: 1.5rem;
          font-weight: 300; }
          .tag-items.section-group .post-list .post-item .post-link .post-title {
            flex-grow: 1;
            text-align: left;
            margin: 0;
            font-size: 1.6rem;
            font-weight: 300;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis; }
            .tag-items.section-group .post-list .post-item .post-link .post-visits {
              font-size: 1.6rem;
              color: #999999;
              margin-left: 10px;
              flex-shrink: 0; }
              .tag-items.section-group .post-list .post-item .post-link:after {
                content: '';
                position: absolute;
                left: 0;
                right: 0;
                bottom: 0;
                height: 0;
                background: #0FA0CE;
                z-index: -1;
                transition: height 0.2s ease; }
                .tag-items.section-group .post-list .post-item .post-link:hover {
                  color: #fff !important; }
                  .tag-items.section-group .post-list .post-item .post-link:hover .post-date,
                  .tag-items.section-group .post-list .post-item .post-link:hover .post-title,
                  .tag-items.section-group .post-list .post-item .post-link:hover .post-visits {
                    color: #fff !important; }
                    .tag-items.section-group .post-list .post-item .post-link:hover:after {
                      height: 100% !important; }
  .tag-items.section-group #pager {
    margin-top: 5rem;
    padding: 2rem 0;
    text-align: center; }
    .tag-items.section-group #pager .paginator {
      font-size: 1.4rem; }
      .tag-items.section-group #pager .paginator a,
      .tag-items.section-group #pager .paginator span {
        margin: 0 5px;
        text-decoration: none !important; }
        .tag-items.section-group #pager .paginator a:after,
        .tag-items.section-group #pager .paginator span:after {
          display: none !important; }
      .tag-items.section-group #pager .paginator .current {
        color: #0FA0CE;
        font-weight: bold; }

body.darkmode .tag-items.section-group .title-row {
  border-bottom-color: #444444 !important; }
  body.darkmode .tag-items.section-group .title-row .count {
    color: #888888 !important; }
body.darkmode .tag-items.section-group .post-list .post-item .post-link .post-date,
body.darkmode .tag-items.section-group .post-list .post-item .post-link .post-visits {
  color: #888888 !important; }
  body.darkmode .tag-items.section-group .post-list .post-item .post-link:hover .post-date,
  body.darkmode .tag-items.section-group .post-list .post-item .post-link:hover .post-visits {
    color: #fff !important; }

#cat-tag-items.section-group {
  margin-top: 0;
  margin-bottom: 4rem; }
  #cat-tag-items.section-group .title-row {
    display: flex;
    align-items: baseline;
    margin-bottom: 3.5rem;
    border-bottom: 1px solid #E1E1E1;
    padding-bottom: 8px;
    transition: border-bottom-color 0.3s ease; }
    #cat-tag-items.section-group .title-row .category-title {
      margin: 0 1.5rem 0 0 !important;
      font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
      font-size: 2.6rem;
      font-weight: bold; }
      #cat-tag-items.section-group .title-row .category-title .label {
        color: inherit; }
        #cat-tag-items.section-group .title-row .category-title .name {
          color: inherit; }
    #cat-tag-items.section-group .title-row .count {
      font-size: 1.4rem;
      color: #999999; }
  #cat-tag-items.section-group .post-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important; }
    #cat-tag-items.section-group .post-list .post-item {
      margin-bottom: 0.8rem; }
      #cat-tag-items.section-group .post-list .post-item .post-link {
        display: flex !important;
        justify-content: space-between;
        align-items: center;
        padding: 8px 12px;
        color: inherit;
        text-decoration: none !important;
        position: relative;
        z-index: 1; }
        #cat-tag-items.section-group .post-list .post-item .post-link .post-date {
          font-size: 1.6rem;
          color: #999999;
          flex-shrink: 0;
          margin-right: 1.5rem;
          font-weight: 300; }
          #cat-tag-items.section-group .post-list .post-item .post-link .post-title {
            flex-grow: 1;
            text-align: left;
            margin: 0;
            font-size: 1.6rem;
            font-weight: 300;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis; }
            #cat-tag-items.section-group .post-list .post-item .post-link .post-visits {
              font-size: 1.6rem;
              color: #999999;
              margin-left: 10px;
              flex-shrink: 0;
              font-weight: 300; }
              #cat-tag-items.section-group .post-list .post-item .post-link:after {
                content: '';
                position: absolute;
                left: 0;
                right: 0;
                bottom: 0;
                height: 0;
                background: #0FA0CE;
                z-index: -1;
                transition: height 0.2s ease; }
                #cat-tag-items.section-group .post-list .post-item .post-link:hover {
                  color: #fff !important; }
                  #cat-tag-items.section-group .post-list .post-item .post-link:hover .post-date,
                  #cat-tag-items.section-group .post-list .post-item .post-link:hover .post-title,
                  #cat-tag-items.section-group .post-list .post-item .post-link:hover .post-visits {
                    color: #fff !important; }
                    #cat-tag-items.section-group .post-list .post-item .post-link:hover:after {
                      height: 100% !important; }
  #cat-tag-items.section-group #pager {
    margin-top: 5rem;
    padding: 2rem 0;
    text-align: center; }
    #cat-tag-items.section-group #pager .paginator {
      font-size: 1.4rem; }
      #cat-tag-items.section-group #pager .paginator a,
      #cat-tag-items.section-group #pager .paginator span {
        margin: 0 5px;
        padding: 4px 8px;
        text-decoration: none !important;
        color: inherit;
        position: relative;
        z-index: 1;
        transition: color 0.2s; }
        #cat-tag-items.section-group #pager .paginator a:after,
        #cat-tag-items.section-group #pager .paginator span:after {
          content: '';
          position: absolute;
          left: 0;
          right: 0;
          bottom: 0;
          height: 0;
          background: #0FA0CE;
          z-index: -1;
          transition: height 0.2s ease; }
          #cat-tag-items.section-group #pager .paginator a:hover,
          #cat-tag-items.section-group #pager .paginator span:hover {
            color: #fff !important; }
            #cat-tag-items.section-group #pager .paginator a:hover:after,
            #cat-tag-items.section-group #pager .paginator span:hover:after {
              height: 100% !important; }
      #cat-tag-items.section-group #pager .paginator .current {
        color: #0FA0CE;
        font-weight: bold; }

body.darkmode #cat-tag-items.section-group .title-row {
  border-bottom-color: #444444 !important; }
  body.darkmode #cat-tag-items.section-group .title-row .count {
    color: #888888 !important; }
body.darkmode #cat-tag-items.section-group .post-list .post-item .post-link .post-date,
body.darkmode #cat-tag-items.section-group .post-list .post-item .post-link .post-visits {
  color: #888888 !important; }
  body.darkmode #cat-tag-items.section-group .post-list .post-item .post-link:hover .post-date,
  body.darkmode #cat-tag-items.section-group .post-list .post-item .post-link:hover .post-visits {
    color: #fff !important; }
body.darkmode #cat-tag-items.section-group #pager .paginator a,
body.darkmode #cat-tag-items.section-group #pager .paginator span {
  color: #888888; }
  body.darkmode #cat-tag-items.section-group #pager .paginator a:hover,
  body.darkmode #cat-tag-items.section-group #pager .paginator span:hover {
    color: #fff !important; }
body.darkmode #cat-tag-items.section-group #pager .paginator .current {
  color: #0FA0CE; }

.search-page-container {
  margin-top: 0;
  margin-bottom: 4rem; }
  .search-page-container .title-row {
    display: flex;
    align-items: baseline;
    margin-bottom: 3.5rem;
    border-bottom: 1px solid #E1E1E1;
    padding-bottom: 8px; }
    .search-page-container .title-row .search-title {
      margin: 0 1.5rem 0 0 !important;
      font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
      font-size: 2.6rem;
      font-weight: bold;
      color: inherit; }
      .search-page-container .title-row .count {
        font-size: 1.4rem;
        color: #999999; }
  .search-page-container .post-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important; }
    .search-page-container .post-list .post-item {
      margin-bottom: 0.8rem; }
      .search-page-container .post-list .post-item .post-link {
        display: flex !important;
        justify-content: space-between;
        align-items: center;
        padding: 8px 12px;
        color: inherit;
        text-decoration: none !important;
        position: relative;
        z-index: 1; }
        .search-page-container .post-list .post-item .post-link .post-date {
          font-size: 1.6rem;
          color: #999999;
          flex-shrink: 0;
          font-weight: 300;
          margin-right: 1.5rem;
          display: inline-flex;
          align-items: center; }
          .search-page-container .post-list .post-item .post-link .post-date::before {
            content: '+';
            margin-right: 4px;
            display: inline-block; }
        .search-page-container .post-list .post-item .post-link .post-title {
          flex-grow: 1;
          text-align: left;
          margin: 0;
          font-size: 1.6rem;
          font-weight: 300;
          white-space: nowrap;
          overflow: hidden;
          text-overflow: ellipsis; }
          .search-page-container .post-list .post-item .post-link .post-visits {
            font-size: 1.6rem;
            color: #999999;
            margin-left: 10px;
            flex-shrink: 0; }
            .search-page-container .post-list .post-item .post-link:after {
              content: '';
              position: absolute;
              left: 0;
              right: 0;
              bottom: 0;
              height: 0;
              background: #0FA0CE;
              z-index: -1;
              transition: height 0.2s ease; }
              .search-page-container .post-list .post-item .post-link:hover {
                color: #fff !important; }
                .search-page-container .post-list .post-item .post-link:hover .post-date,
                .search-page-container .post-list .post-item .post-link:hover .post-title,
                .search-page-container .post-list .post-item .post-link:hover .post-visits {
                  color: #fff !important; }
                  .search-page-container .post-list .post-item .post-link:hover:after {
                    height: 100% !important; }
  .search-page-container #pager {
    margin-top: 5rem;
    padding: 2rem 0;
    text-align: center; }
    .search-page-container #pager .paginator {
      font-size: 1.4rem; }
      .search-page-container #pager .paginator a,
      .search-page-container #pager .paginator span {
        margin: 0 5px;
        padding: 4px 8px;
        text-decoration: none !important;
        position: relative;
        z-index: 1; }
        .search-page-container #pager .paginator a:after,
        .search-page-container #pager .paginator span:after {
          content: '';
          position: absolute;
          left: 0;
          right: 0;
          bottom: 0;
          height: 0;
          background: #0FA0CE;
          z-index: -1;
          transition: height 0.2s ease; }
          .search-page-container #pager .paginator a:hover,
          .search-page-container #pager .paginator span:hover {
            color: #fff !important; }
            .search-page-container #pager .paginator a:hover:after,
            .search-page-container #pager .paginator span:hover:after {
              height: 100% !important; }
      .search-page-container #pager .paginator .current {
        color: #0FA0CE;
        font-weight: bold; }

body.darkmode .search-page-container .title-row {
  border-bottom-color: #444444 !important; }
  body.darkmode .search-page-container .post-list .post-item .post-link .post-date,
  body.darkmode .search-page-container .post-list .post-item .post-link .post-visits {
    color: #888888 !important; }
    body.darkmode .search-page-container .post-list .post-item .post-link:hover .post-date,
    body.darkmode .search-page-container .post-list .post-item .post-link:hover .post-visits {
      color: #fff !important; }

article#post {
  margin-top: 0;
  margin-bottom: 8rem;
  position: relative; }
  article#post header#post-header {
    margin-bottom: 4rem;
    border-bottom: 1px solid #E1E1E1;
    padding-bottom: 2rem;
    transition: none; }
    article#post header#post-header h1 {
      font-size: 3.4rem;
      font-family: 'Noto Serif CJK SC', 'Source Han Serif SC', serif;
      margin: 0 0 2.5rem 0;
      line-height: 1.3;
      color: inherit; }
      article#post header#post-header .header-meta-row {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        font-size: 1.3rem;
        color: #999999;
        flex-wrap: wrap;
        gap: 1.5rem; }
        article#post header#post-header .header-meta-row #info {
          display: flex;
          flex-wrap: wrap;
          gap: 1.2rem; }
          article#post header#post-header .header-meta-row #info span,
          article#post header#post-header .header-meta-row #info time {
            white-space: nowrap; }
        article#post header#post-header .header-meta-row .post-metadata {
          display: flex;
          flex-wrap: wrap;
          gap: 0.8rem;
          justify-content: flex-start; }
          article#post header#post-header .header-meta-row .post-metadata span a {
            text-decoration: none !important;
            color: #999999;
            border: 1px solid #E1E1E1 !important;
            padding: 2px 8px;
            border-radius: 3px;
            font-size: 1.2rem;
            display: inline-block;
            transition: none; }
            article#post header#post-header .header-meta-row .post-metadata span a::before {
              content: '+ '; }
              article#post header#post-header .header-meta-row .post-metadata span a:after {
                display: none !important; }
                article#post header#post-header .header-meta-row .post-metadata span a:hover {
                  color: #fff !important;
                  background: #0FA0CE !important;
                  border-color: #0FA0CE !important; }
  article#post .toc {
    float: right;
    margin-left: 3rem;
    margin-bottom: 2rem;
    padding: 2.2rem;
    width: fit-content;
    font-family: Cambria, 'Microsoft Yahei', sans-serif;
    font-size: 1.6rem;
    line-height: 1.6;
    border-radius: 8px;
    background-color: rgba(15, 160, 206, 0.05);
    border-left: none !important; }
    article#post .toc ul {
      list-style: none;
      padding: 0;
      margin: 0; }
      article#post .toc ul li {
        margin: 8px 0; }
        article#post .toc ul li a {
          text-decoration: none !important;
          color: inherit;
          display: inline-flex;
          align-items: baseline; }
          article#post .toc ul li a::before {
            content: '+ ';
            margin-right: 8px;
            color: #999999;
            font-weight: 300; }
            article#post .toc ul li a:after {
              display: none !important; }
              article#post .toc ul li a:hover {
                color: #0FA0CE !important; }
        article#post .toc ul li ul {
          margin-top: 5px;
          padding-left: 1.5rem; }
    @media (max-width: 768px) {
      article#post .toc {
        float: none;
        width: 100%;
        margin-left: 0;
        margin-bottom: 3rem;   }
}
  article#post #post-content {
    font-size: 1.6rem;
    line-height: 2;
    color: inherit;
    border-bottom: 1px solid #E1E1E1;
    padding-bottom: 4rem;
    margin-bottom: 0; }
    article#post #post-content blockquote {
      margin: 2.5rem 0;
      padding: 0.5rem 2rem;
      border-left: 4px solid #0FA0CE;
      background-color: rgba(15, 160, 206, 0.05);
      font-style: italic; }
      article#post #post-content pre {
        background: #f8f8f8;
        padding: 1.5rem;
        border-radius: 6px;
        overflow-x: auto;
        margin: 2.5rem 0; }
        article#post #post-content pre code {
          font-size: 1.4rem;
          background: none;
          color: inherit;
          padding: 0; }
    article#post #post-content img {
      max-width: 100%;
      border-radius: 8px !important;
      margin: 2.5rem auto;
      display: block; }
  article#post h4.post-all-posts {
    text-align: center;
    margin: 5rem 0;
    border: none !important; }
    article#post h4.post-all-posts a {
      display: inline-block;
      background-color: #0FA0CE !important;
      color: #ffffff !important;
      padding: 12px 34px;
      font-size: 1.5rem;
      font-weight: bold;
      border-radius: 4px;
      text-decoration: none !important;
      line-height: 1;
      transition: opacity 0.2s ease; }
      article#post h4.post-all-posts a:after {
        display: none !important;
        content: none !important; }
        article#post h4.post-all-posts a::before {
          content: none !important; }
          article#post h4.post-all-posts a:hover {
            opacity: 0.85;
            background-color: #0FA0CE !important;
            color: #ffffff !important; }

#post-content center {
  margin: 0; }
  #post-content center code {
    display: inline-block;
    padding: 6px 30px;
    background: #f8f8f8;
    color: #0FA0CE;
    border-radius: 50px;
    font-weight: bold;
    font-size: 1.5rem;
    border: 1px solid #E1E1E1;
    margin: 0; }

#post-content :not(pre) > code {
  display: inline-block;
  vertical-align: middle;
  margin: 0 4px;
  padding: 0px 12px;
  font-size: 0.9em;
  font-family: Cambria, 'Microsoft Yahei', sans-serif;
  font-weight: 500;
  background-color: #f1f1f1;
  color: #0FA0CE;
  border-radius: 15px;
  border: 1px solid #E1E1E1; }
  body.darkmode #post-content :not(pre) > code {
    background-color: #2a2a2e;
    color: #39c4f1;
    border-color: #444444; }

body.darkmode article#post header#post-header {
  border-bottom-color: #444444 !important; }
  body.darkmode article#post header#post-header .post-metadata span a {
    border-color: #444444 !important;
    color: #888888 !important;
    background-color: transparent !important; }
    body.darkmode article#post header#post-header .post-metadata span a:hover {
      background-color: #0FA0CE !important;
      border-color: #0FA0CE !important;
      color: #fff !important; }
body.darkmode article#post .toc, body.darkmode article#post blockquote {
  background-color: rgba(15, 160, 206, 0.1) !important; }
  body.darkmode article#post #post-content {
    border-bottom-color: #444444 !important; }
    body.darkmode article#post #post-content pre {
      background-color: #121212 !important;
      border: 1px solid #444444 !important; }
      body.darkmode article#post #post-content pre code {
        color: #e0e0e0 !important; }
    body.darkmode article#post #post-content center code {
      background-color: #121212 !important;
      border: 1px solid #444444 !important;
      color: #e0e0e0 !important;
      border-radius: 50px;
      padding: 6px 30px;
      display: inline-block; }
body.darkmode article#post h4.post-all-posts a {
  background-color: #0FA0CE !important;
  color: #ffffff !important; }

.doc_comments {
  padding: 0 !important;
  margin: 4rem 0 0 !important;
  width: 100% !important; }
  .doc_comments .comments_block_title {
    display: none; }
    .doc_comments ul ul {
      padding: 0 !important; }
      .doc_comments #new_comment_form {
        border: 1px dashed #E1E1E1 !important;
        border-radius: 4px;
        background: transparent !important;
        margin-top: 1.6rem !important;
        margin-bottom: 1.6rem !important;
        transition: border-color 0.2s ease; }
        .doc_comments #new_comment_form .comment_trigger {
          padding-left: 1.6rem !important;
          padding-right: 1.6rem !important; }
          .doc_comments #new_comment_form .comment_trigger img {
            display: none; }
            .doc_comments #new_comment_form .comment_trigger .trigger_title {
              color: #999999 !important;
              line-height: 40px !important;
              margin-left: 0 !important;
              transition: color 0.2s ease; }
        .doc_comments #new_comment_form:hover {
          cursor: pointer; }
          .doc_comments #new_comment_form:hover .trigger_title {
            color: #0FA0CE !important; }
        .doc_comments #new_comment_form textarea {
          padding: 0 1.6rem 0 1.6rem !important;
          font-family: inherit;
          font-weight: inherit; }
          .doc_comments #new_comment_form textarea:hover {
            cursor: pointer; }
        .doc_comments #new_comment_form .input_body {
          padding-left: 1.6rem !important;
          padding-right: 1.6rem !important;
          background: #f9f9f9 !important;
          border-radius: 4px;
          height: 48px !important; }
          .doc_comments #new_comment_form .input_body ul {
            overflow: 0;
            line-height: normal !important; }
            .doc_comments #new_comment_form .input_body ul li input {
              padding-left: 0 !important;
              padding-right: 10px !important; }
              .doc_comments #new_comment_form .input_body ul li input::-webkit-input-placeholder {
                color: #999999; }
                .doc_comments #new_comment_form .input_body ul li input:focus::-webkit-input-placeholder {
                  color: #ccc; }
          .doc_comments #new_comment_form .input_body li.verification_code {
            display: block !important;
            width: 130px !important;
            margin-right: -10% !important; }
            .doc_comments #new_comment_form .input_body li.verification_code img {
              display: inline-block !important;
              margin: auto !important;
              min-width: 35% !important; }
              .doc_comments #new_comment_form .input_body li.verification_code input {
                display: inline-block !important;
                min-width: 30% !important;
                margin-left: 0 !important; }
          .doc_comments #new_comment_form .input_body li.li_author {
            width: 15% !important; }
            .doc_comments #new_comment_form .input_body li.li_email {
              width: 28% !important;
              margin-left: 0; }
              .doc_comments #new_comment_form .input_body li.li_site {
                width: 40% !important;
                margin-right: 0; }
                .doc_comments #new_comment_form .input_body .comment_submit_button {
                  color: #fff !important;
                  background: #0FA0CE !important;
                  margin-right: 1.6rem;
                  border-radius: 4px;
                  transition: opacity 0.2s ease;
                  margin: 0;
                  padding: 0;
                  height: 48px;
                  width: 18%; }
                  .doc_comments #new_comment_form .input_body .comment_submit_button:hover {
                    cursor: pointer;
                    background: #0FA0CE !important;
                    color: #fff !important;
                    opacity: 0.85; }
          .doc_comments #new_comment_form .input_body input {
            font-family: inherit;
            font-weight: inherit;
            -webkit-appearance: none;
            -moz-appearance: none; }
  .doc_comments .comments .comment {
    background: transparent !important;
    margin: 0 !important;
    border: 0 !important;
    border-top: 1px dashed #E1E1E1 !important;
    border-radius: 0 !important;
    padding: 1em 0 0 !important;
    word-break: inherit !important;
    border-width: 1px !important; }
    .doc_comments .comments .comment .author {
      padding-bottom: 0 !important; }
      .doc_comments .comments .comment .author b {
        background: transparent !important;
        color: inherit !important; }
        .doc_comments .comments .comment .author img {
          border: 1px dashed #ccc;
          border-radius: 100% !important;
          padding: 1px;
          box-sizing: border-box; }
          .doc_comments .comments .comment .author a {
            text-decoration: none !important; }
            .doc_comments .comments .comment .author a:after {
              display: none !important;
              content: none !important; }
              .doc_comments .comments .comment .author a:hover {
                background: transparent !important;
                color: #0FA0CE !important; }
      .doc_comments .comments .comment .author .reply {
        color: #999999 !important; }
        .doc_comments .comments .comment .author .author-date {
          font-size: 0.9em;
          color: #999999; }
    .doc_comments .comments .comment .sub_comments {
      margin: 0 0 0 48px !important; }
      .doc_comments .comments .comment .sub_comments .sub_comments .sub_comments {
        margin-left: 0 !important; }
        .doc_comments .comments .comment .p_part {
          padding-left: 48px !important; }
          .doc_comments .comments .comment #new_comment_form {
            margin-left: 48px; }
  .doc_comments .comments > .comment {
    border-top: 1px dashed #E1E1E1 !important;
    border-radius: 0 !important;
    padding: 1.6rem 0 0 !important; }

body.darkmode .doc_comments #new_comment_form {
  border-color: #444444 !important; }
  body.darkmode .doc_comments #new_comment_form textarea {
    background: transparent !important;
    color: #eeeeee !important;
    caret-color: #eeeeee !important;
    -webkit-text-fill-color: #eeeeee !important; }
    body.darkmode .doc_comments #new_comment_form .input_body {
      background: #202024 !important; }
      body.darkmode .doc_comments #new_comment_form .input_body ul li input {
        background: #2a2a2e !important;
        color: #eeeeee !important;
        caret-color: #eeeeee !important;
        border-color: #444444;
        -webkit-text-fill-color: #eeeeee !important; }
        body.darkmode .doc_comments #new_comment_form .input_body ul li input::-webkit-input-placeholder {
          color: #666 !important; }
body.darkmode .doc_comments .comments .comment {
  border-top-color: #444444 !important; }
  body.darkmode .doc_comments .comments .comment .p_part {
    color: #eeeeee !important; }
    body.darkmode .doc_comments .comments .comment .author img {
      border-color: #444444; }
      body.darkmode .doc_comments .comments .comment .author .author-date {
        color: #888888; }

@media screen and (max-width: 1024px) {
  nav a, .nav a, #nav a, .menu a, header a {
    text-decoration: none !important;
    transition: none !important;
    position: relative;   }
    nav a::after, .nav a::after, #nav a::after, .menu a::after, header a::after {
      display: none !important;
      content: none !important;
      height: 0 !important;
      transition: none !important;   }
      nav a:hover, nav a:active, nav a:focus, .nav a:hover, .nav a:active, .nav a:focus,
      #nav a:hover, #nav a:active, #nav a:focus, .menu a:hover, .menu a:active,
      .menu a:focus, header a:hover, header a:active, header a:focus {
        color: inherit !important;
        background: transparent !important;   }
        nav a:hover::after, nav a:active::after, nav a:focus::after, .nav a:hover::after,
        .nav a:active::after, .nav a:focus::after, #nav a:hover::after,
        #nav a:active::after, #nav a:focus::after, .menu a:hover::after,
        .menu a:active::after, .menu a:focus::after, header a:hover::after,
        header a:active::after, header a:focus::after {
          display: none !important;
          height: 0 !important;   }
}

@media screen and (max-width: 768px) {
  #comments {
    float: none;
    width: 100%;   }
    .doc_comments #new_comment_form .comment_triggered {
      height: 150px !important;   }
      .doc_comments #new_comment_form .input_body {
        padding-bottom: 135px !important;
        padding-right: 18% !important;   }
        .doc_comments #new_comment_form .input_body li {
          width: 15% !important;
          padding: 5px 0 !important;   }
          .doc_comments #new_comment_form .input_body li input {
            border: 1px dashed #ccc;   }
        .doc_comments #new_comment_form .input_body .comment_submit_button {
          width: 100% !important;
          height: auto;
          bottom: 0px;
          top: auto;   }
          .doc_comments #new_comment_form .input_body li.li_author {
            width: 70% !important;   }
            .doc_comments #new_comment_form .input_body li.li_email {
              width: 70% !important;   }
              .doc_comments #new_comment_form .input_body li.li_site {
                width: 70% !important;   }
                .doc_comments #new_comment_form .input_body li.verification_code {
                  padding-left: 75% !important;
                  padding-top: 6px !important;   }
                  .doc_comments #new_comment_form .input_body li.verification_code img {
                    width: 80px !important;
                    height: 24px;   }
                    .doc_comments #new_comment_form .input_body li.verification_code input {
                      width: 80px !important;
                      top: 10px;
                      height: 24px;   }
    .doc_comments .comments .comment .sub_comments .sub_comments {
      margin-left: 0 !important;   }
}

} @media screen and (max-width: 768px) body.darkmode .doc_comments #new_comment_form {
  border-color: #444444 !important; }
  } @media screen and (max-width: 768px) body.darkmode .doc_comments #new_comment_form .input_body {
    background: #202024 !important; }
    } @media screen and (max-width: 768px) body.darkmode .doc_comments #new_comment_form .input_body li input {
      border: 1px dashed #444444 !important;
      background: #2a2a2e !important;
      color: #eee !important; }
      } @media screen and (max-width: 768px) body.darkmode .doc_comments #new_comment_form .input_body li input::-webkit-input-placeholder {
        color: #666; }
    } @media screen and (max-width: 768px) body.darkmode .doc_comments #new_comment_form .input_body li.verification_code img {
      filter: brightness(0.8);
      background: #eee;
      border-radius: 2px; }
  } @media screen and (max-width: 768px) body.darkmode .doc_comments #new_comment_form .comment_submit_button {
    background: #0FA0CE !important;
    border: none !important;
    color: #fff !important; }
} @media screen and (max-width: 768px) body.darkmode .doc_comments .comments .comment {
  border-top-color: #444444 !important; }
  } @media screen and (max-width: 768px) body.darkmode .doc_comments .comments .comment .author img {
    border-color: #444444 !important; }
    } @media screen and (max-width: 768px) body.darkmode .doc_comments .comments .comment .sub_comments {
      border-left: 1px solid #333; }

#img-zoom-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  z-index: 9998;
  cursor: zoom-out;
  backdrop-filter: blur(5px); }

  .zoomed-image {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 90vw;
    max-height: 90vh;
    z-index: 9999;
    cursor: zoom-out;
    border-radius: 4px;
    box-shadow: 0 10px 50px rgba(0, 0, 0, 0.5);
    animation: zoomInAnim 0.3s ease-out; }

    @keyframes zoomInAnim {
      from {
        opacity: 0;
        transform: translate(-50%, -50%) scale(0.9);   }
        to {
          opacity: 1;
          transform: translate(-50%, -50%) scale(1);   }
}

body.darkmode #img-zoom-overlay {
  background: rgba(0, 0, 0, 0.92); }
