:root {
    /* 背景色 */
    --gt-body-bg: #f5f6f7;
    --gt-bg-rgb: 245, 246, 247;
    --gt-card-bg: #fff;
    --gt-bg-fa: #fafafa;
    --gt-bg-f5: #f5f5f5;
    --gt-white-color: #ffffff;
    --gt-header-bg: rgba(255, 255, 255, 0.95);
    --gt-footer-bg: rgba(255, 255, 255, 0.5);
    
    /* 文字色 */
    --gt-font-color: #34495e;
    --gt-font-rgb: 52, 73, 94;
    --gt-text-secondary: rgba(52, 73, 94, 0.66);
    --gt-text-muted: rgba(52, 73, 94, 0.56);
    
    /* 边框色 */
    --gt-border-color: rgba(50, 83, 180, 0.1);
    --gt-border-light: rgba(52, 73, 94, 0.16);
    
    /* 阴影 */
    --gt-box-shadow: 0 3px 8px 6px rgba(7, 17, 27, 0.05);
    --gt-header-shadow: 0 1px 12px rgba(0, 0, 0, 0.08);
    --gt-footer-shadow: 0 -2px 12px rgba(0, 0, 0, 0.08);
    
    /* 主题色 */
    --gt-main-color: #3253b4;
    --gt-main-rgb: 50, 83, 180;
    --gt-main-color-88: rgba(var(--gt-main-rgb), 0.88);
    --gt-main-color-66: rgba(var(--gt-main-rgb), 0.66);
    --gt-main-color-56: rgba(var(--gt-main-rgb), 0.56);
    --gt-main-color-28: rgba(var(--gt-main-rgb), 0.28);
    --gt-main-color-16: rgba(var(--gt-main-rgb), 0.16);
    --gt-main-color-10: rgba(var(--gt-main-rgb), 0.1);
    --gt-main-color-5: rgba(var(--gt-main-rgb), 0.05);
    --gt-main-color-6: rgba(var(--gt-main-rgb), 0.06);
    
    /* 字体透明度变体 */
    --gt-font-88: rgba(var(--gt-font-rgb), 0.88);
    --gt-font-66: rgba(var(--gt-font-rgb), 0.66);
    --gt-font-56: rgba(var(--gt-font-rgb), 0.56);
    --gt-font-28: rgba(var(--gt-font-rgb), 0.28);
    --gt-font-16: rgba(var(--gt-font-rgb), 0.16);
    --gt-font-6: rgba(var(--gt-font-rgb), 0.06);
    
    /* 布局 */
    --gt-main-radius: 0.5rem;
    --gt-aside-width: 318px;
    --gt-main-max-width: 1458px;
    --gt-header-height: 72px;
    
    /* 状态色 */
    --gt-info: #DE3C3D;
    --gt-info-hover: rgba(222, 60, 61, 0.09);
    --gt-success: #01C4B6;
    --gt-success-hover: rgba(1, 196, 182, 0.09);
    --gt-warning: #DD8636;
    --gt-warning-hover: rgba(221, 134, 54, 0.09);
    --gt-error: #DE3C3D;
    --gt-error-hover: rgba(222, 60, 61, 0.09);
    --gt-import: #FF69B4;
    --gt-import-hover: rgba(255, 105, 180, 0.09);
    
    /* 代码块 - 共享变量 */
    --gt-code-radius: var(--gt-main-radius);
    --gt-code-font: 'Cascadia Code', 'Source Code Pro', 'Fira Code', Consolas, monospace;
    --gt-code-font-size: 14px;
    --gt-code-line-height: 1.6;
    --gt-code-decoration-color: #ff5f56;
    --gt-code-decoration-shadow: 20px 0 0 #ffbd2e, 40px 0 0 #27c93f;
    --gt-code-lang-font: system-ui, -apple-system, sans-serif;
    
    /* 代码块 - 浅色模式 */
    --gt-code-bg: #ffffff;
    --gt-code-border: #e1e4e8;
    --gt-code-color: #24292e;
    --gt-code-lang-color: #6a737d;
    
    /* 语法高亮 - 浅色模式 */
    --gt-hl-keyword: #d73a49;
    --gt-hl-built-in: #005cc5;
    --gt-hl-string: #032f62;
    --gt-hl-number: #005cc5;
    --gt-hl-function: #6f42c1;
    --gt-hl-variable: #24292e;
    --gt-hl-comment: #6a737d;
    --gt-hl-tag: #22863a;
    --gt-hl-addition-bg: #f0fff4;
    --gt-hl-deletion-bg: #ffeef0;
    
    /* 层级 */
    --z-header: 500;
    --z-dropdown: 150;
    --z-overlay: 200;
    --z-modal: 300;
    --z-search-modal: 310;
    --z-mobile-sidebar: 900;
    --z-auth-modal: 999;
}

*,
*::before,
*::after {
    box-sizing: border-box
}

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
    margin: 0
}

ul,
ol {
    list-style: none;
    margin: 0;
    padding: 0
}

del {
    text-decoration: line-through
}

html:focus-within {
    scroll-behavior: smooth
}

a:not([class]) {
    text-decoration-skip-ink: auto
}

input,
button,
textarea,
select {
    font: inherit
}

* {
    -webkit-tap-highlight-color: transparent;
    text-decoration: none;
    outline: none
}

::selection,
::-webkit-selection {
    color: #fff;
    background: var(--gt-main-color-88)
}

html {
    word-wrap: break-word;
    overflow-wrap: break-word;
    font-size: 16px;
    font-weight: 400
}

body {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100vw;
    min-height: 100vh;
    color: var(--gt-font-color);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 400;
    background: var(--gt-body-bg);
    overflow-x: hidden
}

a {
    color: var(--gt-font-color);
    text-decoration: none;
    transition: color 0.18s ease-in-out
}

a:hover {
    color: var(--gt-main-color)
}

img {
    max-width: 100%;
    user-select: none;
    -webkit-user-drag: none
}

img[data-src]:not(.lazyloaded),
img.lazyload:not(.lazyloaded) {
    filter: blur(0.88rem) brightness(1);
    transition: filter 0.18s ease-in
}

img.lazyloaded {
    filter: none
}

.gt-hover:hover {
    color: var(--gt-main-color)
}

.gt-ellipsis {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    word-break: break-all
}

.gt-ellipsis:not([class*="line-"]) {
    white-space: nowrap;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
}

.gt-ellipsis.line-2 {
    -webkit-line-clamp: 2;
    line-clamp: 2;
    white-space: normal
}

.gt-ellipsis.line-3 {
    -webkit-line-clamp: 3;
    line-clamp: 3;
    white-space: normal
}

header.gt-header {
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: var(--gt-header-height);
    background-color: var(--gt-header-bg);
    box-shadow: var(--gt-header-shadow);
    transition: transform 0.3s ease-in-out, background-color 0.18s ease-in-out;
    z-index: var(--z-header);
    transform: translateY(0)
}

body.header-hidden header.gt-header {
    transform: translateY(-100%)
}

header.gt-header>section {
    margin: 0 auto;
    padding: 0 0.88rem 0 0;
    display: flex;
    align-items: center;
    width: 100%;
    height: 100%;
    max-width: var(--gt-main-max-width)
}

header.gt-header .home,
header.gt-header .site-logo {
    flex-shrink: 0;
    padding: 0.266rem 0.188rem;
    display: flex;
    align-items: center;
    gap: 0.618rem;
    color: var(--gt-font-color)
}

header.gt-header .home a,
header.gt-header .site-logo a {
    display: flex;
    align-items: center;
}

header.gt-header .home img,
header.gt-header .site-logo img,
header.gt-header .home span,
header.gt-header .site-logo span {
    display: block;
}

header.gt-header .home img,
header.gt-header .site-logo img {
    height: 2.5rem;
}

header.gt-header .home span,
header.gt-header .site-logo span {
    font-size: 1.5rem;
    font-weight: 700;
}

header.gt-header .nav-center {
    flex: 1;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.18rem;
    height: 100%;
    margin: 0 1rem
}

header.gt-header .nav-link {
    padding: 0.288rem 0.36rem;
    display: flex;
    align-items: center;
    gap: 0.28rem;
    font-size: 0.98rem;
    font-weight: 600;
    color: var(--gt-font-color);
    user-select: none;
    cursor: pointer;
    transition: all 0.18s;
    border: none;
    background: none
}

header.gt-header .nav-link:hover {
    color: var(--gt-main-color)
}

header.gt-header .nav-center .nav-link {
    white-space: nowrap
}

header.gt-header .nav-center .nav-link i {
    font-size: 1rem;
    transition: transform 0.18s
}

header.gt-header .nav-center .nav-dropdown:hover .nav-link i {
    transform: rotate(180deg)
}

header.gt-header .nav-right {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 0.88rem;
    margin-left: auto
}

header.gt-header .nav-right .nav-link i {
    font-size: 1.28rem
}

header.gt-header .menu-btn {
    display: none
}

header.gt-header .menu-btn svg {
    width: 1.5rem;
    height: 1.5rem
}

header.gt-header .menu-btn.active .menu-icon {
    display: none
}

header.gt-header .menu-btn.active .close-icon {
    display: block !important
}

main.main {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    min-height: calc(100vh - 200px);
    overflow: visible
}

main.main>.main-inner {
    flex-shrink: 0;
    position: relative;
    box-sizing: border-box;
    padding-top: calc(var(--gt-header-height) + 0.5rem);
    display: flex;
    flex-direction: row-reverse;
    width: 100%;
    max-width: var(--gt-main-max-width);
    min-height: calc(100vh - 200px);
    z-index: 1
}

main.main>.main-inner.aside-right {
    flex-direction: row
}

main.main>.main-inner.aside-left {
    flex-direction: row-reverse
}

main.main>.main-inner>.main-inner-content {
    flex: 1 1 0%;
    box-sizing: border-box;
    padding: 0.5rem 0.66rem 0.88rem;
    width: 100%;
    min-width: 0;
    height: max-content;
    overflow: hidden
}

aside.gt-aside {
    flex-shrink: 0;
    position: relative;
    box-sizing: border-box;
    padding: 2rem 0.66rem 0.88rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: var(--gt-aside-width);
    height: auto
}

.main-inner.home-page aside.gt-aside {
    padding: 0.75rem 0.66rem 0.88rem;
}

aside.gt-aside>.sticky-aside {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
    flex-grow: 1;
}

aside.gt-aside>.sticky-aside>.gt-aside-item:last-child {
    position: -webkit-sticky;
    position: sticky;
    top: calc(var(--gt-header-height) + 1rem);
    z-index: 10;
}

.main-inner.home-page aside.gt-aside>.sticky-aside>.gt-aside-item:last-child {
    top: calc(var(--gt-header-height) + 0.75rem);
}

.gt-aside-item {
    position: relative;
    box-sizing: border-box;
    padding: 1.28rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    width: 100%;
    max-width: 100%;
    height: max-content;
    border-radius: var(--gt-main-radius);
    background: var(--gt-card-bg);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.05);
    overflow: hidden;
    isolation: isolate;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1)
}

.gt-aside-item::before {
    content: "";
    position: absolute;
    top: 12px;
    right: 12px;
    width: 12px;
    height: 12px;
    background: #ff5f56;
    border-radius: 50%;
    box-shadow: -22px 0 0 #ffbd2e, -44px 0 0 #27c93f;
    z-index: 2;
}

.gt-aside-item:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(0, 0, 0, 0.1);
    background: linear-gradient(180deg, rgba(var(--gt-bg-rgb), 0.22) 0%, rgba(var(--gt-bg-rgb), 0.02) 100%)
}

.gt-aside-item>h3 {
    width: 100%;
    font-size: 0.68rem;
    font-weight: 400;
    color: var(--gt-font-56)
}

.gt-aside-item.user {
    padding: 1.88rem 0;
    align-items: center
}

.gt-aside-item:not(.user) .sky-h3 {
    font-size: 1rem;
    margin: -0.5rem 0 0.5rem 0;
    line-height: 14px;
    color: var(--gt-font-24);
    font-weight: 600;
    padding: 0;
    position: relative;
    top: 0;
    display: inline-block;
    vertical-align: middle;
}

.gt-aside-item.user .gt-aside-avatar {
    position: relative;
    width: 6.36rem;
    height: 6.36rem;
    border-radius: 50%;
    object-fit: cover;
    overflow: hidden;
    border: 3px solid var(--gt-main-color);
    box-shadow: 0 0 0 3px rgba(1, 196, 182, 0.2);
    transition: all 0.3s ease
}

.gt-aside-item.user .gt-aside-avatar:hover {
    transform: scale(1.05);
    box-shadow: 0 0 0 4px rgba(1, 196, 182, 0.3)
}

.gt-aside-item.user .gt-aside-author {
    position: relative;
    font-size: 1.25rem;
    font-weight: 600
}

.gt-aside-item.user .gt-aside-author::after {
    content: '';
    position: absolute;
    display: block;
    bottom: -0.16rem;
    left: 50%;
    transform: translateX(-50%);
    width: 36%;
    height: 0.26rem;
    border-radius: 3px;
    background-color: var(--gt-main-color-88)
}

.gt-aside-item.user .gt-aside-bio {
    font-size: 0.875rem;
    color: var(--gt-font-66);
    text-align: center;
    padding: 0 1rem;
    margin-top: 0.5rem;
    line-height: 1.5
}

.gt-aside-item.user .gt-aside-links {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem
}

.gt-aside-item.user .gt-aside-links-item {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.88rem;
    height: 1.88rem;
    border: solid 1px var(--gt-font-28);
    background-color: var(--gt-card-bg);
    border-radius: 0.38rem;
    overflow: hidden;
    z-index: 1;
    transition: all 0.18s ease-in-out
}

.gt-aside-item.user .gt-aside-links-item:hover {
    color: var(--gt-white-color);
    border-color: var(--gt-white-color)
}

.gt-aside-item.user .gt-aside-links-item::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 0;
    background-color: var(--gt-main-color-88);
    transition: height 0.18s ease-in-out;
    z-index: -1
}

.gt-aside-item.user .gt-aside-links-item:hover::after {
    height: 100%
}

.gt-aside-item.user .gt-aside-links-item i {
    font-size: 1.18rem
}

.gt-aside-item.tags .gt-aside-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.68rem 1rem;
    width: 100%;
    height: max-content;
    max-height: 18.88rem;
    overflow-x: hidden;
    overflow-y: auto
}

.gt-aside-item.tags .gt-aside-tags a {
    display: flex;
    align-items: center;
    gap: 0.18rem;
    width: max-content;
    height: max-content
}

.gt-aside-item.tags .gt-aside-tags a:hover span {
    color: var(--gt-main-color)
}

.gt-aside-item.tags .gt-aside-tags a span {
    box-sizing: border-box;
    width: max-content;
    font-size: 0.8rem;
    line-height: 1.5;
    transition: color 0.18s ease-in-out;
    overflow: hidden
}

.gt-aside-item.tags .gt-aside-tags a em {
    color: var(--gt-font-28);
    font-size: 0.688rem;
    font-style: normal
}

.gt-aside-item.articles .gt-aside-articles {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    width: 100%;
    height: max-content;
    overflow: hidden
}

/* 侧边栏最新评论 */
.gt-aside-item.recent-comments .gt-aside-comments {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
    height: max-content;
    overflow: hidden
}

.gt-aside-item.recent-comments .gt-aside-comment-item {
    display: flex;
    gap: 0.75rem;
    padding: 0.5rem;
    border-radius: var(--gt-main-radius);
    transition: background-color 0.18s ease-in-out;
    text-decoration: none
}

.gt-aside-item.recent-comments .gt-aside-comment-item:hover {
    background-color: var(--gt-font-6)
}

.gt-aside-item.recent-comments .gt-aside-comment-avatar {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    object-fit: cover
}

.gt-aside-item.recent-comments .gt-aside-comment-avatar-placeholder {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background-color: var(--gt-font-16);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gt-font-56)
}

.gt-aside-item.recent-comments .gt-aside-comment-content {
    flex: 1;
    min-width: 0
}

.gt-aside-item.recent-comments .gt-aside-comment-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.15rem;
    font-size: 0.75rem
}

.gt-aside-item.recent-comments .gt-aside-comment-author {
    font-weight: 500;
    color: var(--gt-font-color)
}

.gt-aside-item.recent-comments .gt-aside-comment-time {
    color: var(--gt-font-56)
}

.gt-aside-item.recent-comments .gt-aside-comment-text {
    font-size: 0.8125rem;
    color: var(--gt-font-66);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.5
}

/* 带封面的侧边栏文章样式 */
.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-item {
    display: block;
    width: 100%;
    height: auto;
    margin-bottom: 0.12rem;
    overflow: hidden;
    border-radius: var(--gt-main-radius);
    background-color: transparent;
    transition: all 0.3s ease;
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-item:last-child {
    margin-bottom: 0;
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-cover {
    position: relative;
    width: 100%;
    height: 8.88rem;
    overflow: hidden;
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-item:hover .gt-aside-article-img {
    transform: scale(1.05);
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1rem;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
    color: var(--gt-white-color);
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-title {
    margin: 0 0 0.36rem;
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1.4;
    color: var(--gt-white-color);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.gt-aside-item.articles .gt-aside-articles.gt-aside-articles-cover .gt-aside-article-meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 0.688rem;
    color: rgba(255, 255, 255, 0.8);
}

/* 侧边栏文章元信息 */
.gt-aside-article-views,
.gt-aside-article-time {
    display: inline-flex;
    align-items: center;
    gap: 0.1rem;
    vertical-align: middle;
    line-height: 1;
}

.gt-aside-article-views i,
.gt-aside-article-time i {
    font-size: 0.688rem;
}

/* 纯文字侧边栏文章样式 */
.gt-aside-articles-text {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.gt-aside-article-text-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0.75rem;
    border-radius: var(--gt-main-radius);
    background: var(--gt-card-bg);
    border: 1px solid rgba(var(--gt-main-rgb), 0.08);
    transition: all 0.3s ease;
}

.gt-aside-article-text-item:hover {
    background: rgba(var(--gt-main-rgb), 0.05);
    border-color: rgba(var(--gt-main-rgb), 0.15);
    transform: translateX(4px);
}

.gt-aside-article-rank {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 1.5rem;
    height: 1.5rem;
    border-radius: 0.375rem;
    background: linear-gradient(135deg, var(--gt-main-color, #6c5ce7), var(--gt-main-color-light, #a29bfe));
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    flex-shrink: 0;
}

/* 序号颜色循环 - 12色循环支持任意数量的文章 */
/* 第1个：主题色 */
.gt-aside-article-text-item:nth-child(12n+1) .gt-aside-article-rank {
    background: linear-gradient(135deg, var(--gt-main-color, #6c5ce7), var(--gt-main-color-light, #a29bfe));
}

/* 第2个：红色 */
.gt-aside-article-text-item:nth-child(12n+2) .gt-aside-article-rank {
    background: linear-gradient(135deg, #ff6b6b, #ee5a5a);
}

/* 第3个：橙色 */
.gt-aside-article-text-item:nth-child(12n+3) .gt-aside-article-rank {
    background: linear-gradient(135deg, #feca57, #ff9f43);
}

/* 第4个：黄色 */
.gt-aside-article-text-item:nth-child(12n+4) .gt-aside-article-rank {
    background: linear-gradient(135deg, #fdcb6e, #f39c12);
}

/* 第5个：绿色 */
.gt-aside-article-text-item:nth-child(12n+5) .gt-aside-article-rank {
    background: linear-gradient(135deg, #1dd1a1, #10ac84);
}

/* 第6个：青色 */
.gt-aside-article-text-item:nth-child(12n+6) .gt-aside-article-rank {
    background: linear-gradient(135deg, #00cec9, #01a3a4);
}

/* 第7个：蓝色 */
.gt-aside-article-text-item:nth-child(12n+7) .gt-aside-article-rank {
    background: linear-gradient(135deg, #48dbfb, #0abde3);
}

/* 第8个：靛蓝 */
.gt-aside-article-text-item:nth-child(12n+8) .gt-aside-article-rank {
    background: linear-gradient(135deg, #74b9ff, #0984e3);
}

/* 第9个：紫色 */
.gt-aside-article-text-item:nth-child(12n+9) .gt-aside-article-rank {
    background: linear-gradient(135deg, #a29bfe, #6c5ce7);
}

/* 第10个：粉色 */
.gt-aside-article-text-item:nth-child(12n+10) .gt-aside-article-rank {
    background: linear-gradient(135deg, #fd79a8, #e84393);
}

/* 第11个：玫红 */
.gt-aside-article-text-item:nth-child(12n+11) .gt-aside-article-rank {
    background: linear-gradient(135deg, #e17055, #d63031);
}

/* 第12个：薄荷绿 */
.gt-aside-article-text-item:nth-child(12n+12) .gt-aside-article-rank {
    background: linear-gradient(135deg, #55efc4, #00b894);
}

.gt-aside-article-text-title {
    flex: 1;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--gt-font-color);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    box-orient: vertical;
}

.gt-aside-article-text-item:hover .gt-aside-article-text-title {
    color: var(--gt-main-color);
}

.article-list-main {
    position: relative;
    box-sizing: border-box;
    padding-bottom: 1rem;
    width: 100%;
    max-width: var(--gt-main-max-width);
    margin: 0 auto 0;
    height: max-content;
}

.article-list-main>section.article-list {
    position: relative;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.75rem;
    width: 100%;
    min-width: 0;
    height: max-content;
}
/* 根据data-grid属性显示不同列数 */
.article-list-main>section.article-list[data-grid="3"] {
    grid-template-columns: repeat(3, 1fr);
}

.gt-article-item {
    position: relative;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: initial;
    min-height: max-content;
    border: solid 1px rgba(var(--gt-main-rgb), 0.1);
    border-radius: var(--gt-main-radius);
    background: var(--gt-card-bg);
    overflow: hidden;
    transition: all 0.3s ease;
    isolation: isolate;
    cursor: pointer
}

.gt-article-item:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
}

.gt-article-item:hover .gt-article-banner img {
    transform: scale(1.05)
}

/* 置顶标识基础样式 */
.gt-article-item.active::before,
.gt-recommend-top-badge {
    position: absolute;
    top: 0.8rem;
    left: -0.3rem;
    box-sizing: border-box;
    padding: 0.18rem 1rem;
    width: max-content;
    height: max-content;
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    border-radius: 0.66rem;
    transform: rotate(-45deg);
    background: rgba(255, 0, 0, 0.8);
    box-shadow: 0 2rem 1rem rgba(0, 0, 0, 0.1);
    z-index: 10;
}

.gt-article-item.active::before {
    content: "置顶";
}

.gt-recommend-top-badge {
    transition: all 0.3s ease;
}

.gt-article-item.active .gt-article-banner::before,
.gt-recommend-card.active .gt-recommend-thumb::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.06);
    z-index: 1;
    pointer-events: none
}

.gt-article-item .gt-article-banner {
    flex-shrink: 0;
    position: relative;
    box-sizing: border-box;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden
}

.gt-article-item .gt-article-banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease
}

.gt-article-item .gt-article-banner .banner-cat {
    position: absolute;
    bottom: 0.5rem;
    right: 0.5rem;
    z-index: 2;
    padding: 0.1rem 0.3rem;
    background-color: #3253b4;
    color: var(--gt-white-color);
    margin-right: 0;
    flex-shrink: 1;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: 0.5px solid #3253b4;
}



.gt-article-item > header {
    box-sizing: border-box;
    padding: 0.5rem 0.5rem 0.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    width: 100%;
    height: max-content
}

.gt-article-item>header>div:first-child {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    width: 100%;
    height: max-content;
    margin: 0;
    font-weight: normal
}

.gt-article-item .gt-article-cat {
    box-sizing: border-box;
    width: max-content;
    background-color: #3253b4;
    color: var(--gt-white-color);
    padding: 0.05rem 0.2rem;
    margin-right: 0.1rem;
    border: 0.5px solid #3253b4;
    border-radius: 0.15rem;
    font-size: 0.688rem;
    line-height: 1.2;
    display: inline-block;
    vertical-align: middle;
}

.gt-article-item .gt-article-taglist .gt-article-cat {
    margin-right: 0.28rem;
}

.gt-article-item>header>div:first-child time {
    box-sizing: border-box;
    font-weight: 400;
    color: var(--gt-font-56);
    width: max-content;
    margin-left: auto
}

.gt-article-item>header .title {
    box-sizing: border-box;
    width: 100%;
    height: max-content;
    overflow: hidden;
    margin: 0;
    font-size: 0.81rem;
    font-weight: 600
}

.gt-article-item>header .title a {
    font-weight: 600;
    font-size: 0.81rem;
    transition: color 0.18s;
    display: -webkit-box;
    display: box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    line-height: 1.4
}

.gt-article-item>header .title a:hover {
    color: var(--gt-main-color)
}

.gt-article-item .gt-article-excerpt {
    box-sizing: border-box;
    padding: 0 0.5rem;
    width: 100%;
    height: max-content;
    color: var(--gt-font-66);
    font-size: 0.788rem;
    font-weight: 400;
    letter-spacing: 0.88px;
    line-height: 0.9rem;
    margin: 0;
    display: -webkit-box;
    display: box;
    -webkit-line-clamp: 1;
    line-clamp: 1;
    -webkit-box-orient: vertical;
    box-orient: vertical;
    overflow: hidden;
    max-height: calc(0.9rem * 1);
}

.gt-article-item .gt-article-tags,
.gt-article-item .gt-article-taglist {
    box-sizing: border-box;
    padding: 0.1rem 0.5rem;
    width: 100%;
    height: max-content;
    font-weight: normal;
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    overflow: hidden;
    margin-top: auto;
    padding-bottom: 0.5rem;
}

/* 标签基础样式（网格布局） */
.gt-article-item .gt-article-tag {
    position: relative;
    box-sizing: border-box;
    margin-right: 0.2rem;
    padding: 0 0.3125rem;
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    flex-shrink: 0;
    max-width: 100%;
    height: 1rem;
    color: var(--gt-main-color);
    border-radius: 0.28rem;
    font-size: 0.7rem;
    font-weight: 400;
    line-height: 1.2;
    transition: color 0.288s ease-in-out;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    z-index: 1;
    vertical-align: middle;
}

/* 单列布局标签字体大小 */
.article-list.single-column .gt-article-tag {
    font-size: 0.78rem;
}

.gt-article-item .gt-article-tag::before,
.gt-article-item .gt-article-tag::after,
article.gt-article-main>.article-content-container .tag-list a::before,
article.gt-article-main>.article-content-container .tag-list a::after {
    content: '';
    position: absolute;
    left: auto;
    right: 0;
    top: 0;
    width: 0;
    height: 100%;
    z-index: -1;
    transition: width 0.288s ease-in-out;
    background-color: var(--gt-main-color-16);
}

.gt-article-item .gt-article-tag::after,
article.gt-article-main>.article-content-container .tag-list a::after {
    width: 100%;
    left: 0;
    right: auto;
}

/* 标签颜色 - 6种不同颜色循环 */
.gt-article-item .gt-article-tag.tag-1,
article.gt-article-main>.article-content-container .tag-list a.tag-1 { color: var(--gt-main-color); }
.gt-article-item .gt-article-tag.tag-1::after,
article.gt-article-main>.article-content-container .tag-list a.tag-1::after { background-color: var(--gt-main-color-10); }
.gt-article-item .gt-article-tag.tag-1:hover::before,
article.gt-article-main>.article-content-container .tag-list a.tag-1:hover::before { background-color: var(--gt-main-color-10); }

.gt-article-item .gt-article-tag.tag-2,
article.gt-article-main>.article-content-container .tag-list a.tag-2 { color: var(--gt-info); }
.gt-article-item .gt-article-tag.tag-2::after,
article.gt-article-main>.article-content-container .tag-list a.tag-2::after { background-color: var(--gt-info-hover); }
.gt-article-item .gt-article-tag.tag-2:hover::before,
article.gt-article-main>.article-content-container .tag-list a.tag-2:hover::before { background-color: var(--gt-info-hover); }

.gt-article-item .gt-article-tag.tag-3,
article.gt-article-main>.article-content-container .tag-list a.tag-3 { color: var(--gt-success); }
.gt-article-item .gt-article-tag.tag-3::after,
article.gt-article-main>.article-content-container .tag-list a.tag-3::after { background-color: var(--gt-success-hover); }
.gt-article-item .gt-article-tag.tag-3:hover::before,
article.gt-article-main>.article-content-container .tag-list a.tag-3:hover::before { background-color: var(--gt-success-hover); }

.gt-article-item .gt-article-tag.tag-4,
article.gt-article-main>.article-content-container .tag-list a.tag-4 { color: var(--gt-warning); }
.gt-article-item .gt-article-tag.tag-4::after,
article.gt-article-main>.article-content-container .tag-list a.tag-4::after { background-color: var(--gt-warning-hover); }
.gt-article-item .gt-article-tag.tag-4:hover::before,
article.gt-article-main>.article-content-container .tag-list a.tag-4:hover::before { background-color: var(--gt-warning-hover); }

.gt-article-item .gt-article-tag.tag-5,
article.gt-article-main>.article-content-container .tag-list a.tag-5 { color: var(--gt-error); }
.gt-article-item .gt-article-tag.tag-5::after,
article.gt-article-main>.article-content-container .tag-list a.tag-5::after { background-color: var(--gt-error-hover); }
.gt-article-item .gt-article-tag.tag-5:hover::before,
article.gt-article-main>.article-content-container .tag-list a.tag-5:hover::before { background-color: var(--gt-error-hover); }

.gt-article-item .gt-article-tag.tag-6,
article.gt-article-main>.article-content-container .tag-list a.tag-6 { color: var(--gt-import); }
.gt-article-item .gt-article-tag.tag-6::after,
article.gt-article-main>.article-content-container .tag-list a.tag-6::after { background-color: var(--gt-import-hover); }
.gt-article-item .gt-article-tag.tag-6:hover::before,
article.gt-article-main>.article-content-container .tag-list a.tag-6:hover::before { background-color: var(--gt-import-hover); }

.gt-article-item .gt-article-tag:hover,
article.gt-article-main>.article-content-container .tag-list a:hover {
    color: var(--gt-main-color);
}

.gt-article-item .gt-article-tag:hover::before,
article.gt-article-main>.article-content-container .tag-list a:hover::before {
    width: 100%;
    left: 0;
    right: auto;
}

.gt-article-item .gt-article-tag:hover::after,
article.gt-article-main>.article-content-container .tag-list a:hover::after {
    width: 0;
    right: 0;
    left: auto;
}

/* 文章卡片元信息 */
.gt-article-item .gt-article-taglist > time.sky-h6,
.gt-article-item .gt-article-taglist > span.sky-h6 {
    box-sizing: border-box;
    margin-right: 0.28rem;
    color: var(--gt-font-66);
    font-size: 0.75rem;
    font-weight: 400;
    line-height: 1 !important;
    display: inline-flex;
    align-items: center;
    gap: 0.1rem;
    vertical-align: middle;
    transition: color 0.18s;
    white-space: nowrap;
}

.gt-article-item .gt-article-taglist > time.sky-h6:last-child,
.gt-article-item .gt-article-taglist > span.sky-h6:last-child {
    margin-right: 0;
}

/* 单列布局电脑端元信息间距 */
.article-list.single-column .gt-article-taglist > time.sky-h6,
.article-list.single-column .gt-article-taglist > span.sky-h6 {
    margin-right: 0.8rem;
}

.article-list.single-column .gt-article-taglist > time.sky-h6:last-child,
.article-list.single-column .gt-article-taglist > span.sky-h6:last-child {
    margin-right: 0;
}

/* 单列布局手机端元信息间距 */
@media screen and (max-width: 768px) {
    .article-list.single-column .gt-article-taglist > time.sky-h6,
    .article-list.single-column .gt-article-taglist > span.sky-h6 {
        margin-right: 0.28rem;
    }
}

/* 文章详情页阅读量 */
article.gt-article-main>header .gt-article-views {
    display: inline-flex;
    align-items: center;
    gap: 0.1rem;
    vertical-align: middle;
    line-height: 1;
    color: var(--gt-font-66);
    font-size: 0.875rem;
}

article.gt-article-main>header .gt-article-views i {
    font-size: 0.875rem;
    color: var(--gt-font-56);
}

.gt-author-mini-avatar {
    border-radius: 50%;
    object-fit: cover;
    background-color: var(--gt-bg-f5);
    flex-shrink: 0;
    width: 1.2rem;
    height: 1.2rem;
}

.article-meta-item .gt-author-mini-avatar {
    width: 1.4rem;
    height: 1.4rem;
    vertical-align: middle;
}

.gt-article-item .gt-article-views i {
    font-size: 0.75rem;
    color: var(--gt-font-56);
}

.gt-article-item .gt-article-tag:last-of-type {
    margin-right: 0
}

section.gt-art-page {
    position: relative;
    box-sizing: border-box;
    padding: 1.5rem 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    width: 100%;
    height: max-content;
    overflow: hidden;
    margin-top: 1rem;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
}

article.gt-article-main {
    position: relative;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: max-content
}

article.gt-article-main>header {
    box-sizing: border-box;
    padding: 2rem 1rem 1rem;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: max-content;
    background-color: var(--gt-card-bg);
    border-top-left-radius: var(--gt-main-radius);
    border-top-right-radius: var(--gt-main-radius);
    box-shadow: var(--gt-box-shadow);
    overflow: hidden
}

article.gt-article-main>header h1 {
    width: 100%;
    font-weight: 700;
    font-size: 1.5rem;
    margin: 0
}

article.gt-article-main>header .article-meta {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    width: 100%;
    height: auto;
    overflow: visible;
    margin-top: 1rem;
    flex-wrap: wrap
}

article.gt-article-main>header .article-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.1rem;
    height: 1.2em;
    line-height: 1.2
}

article.gt-article-main>header .article-meta-item svg,
article.gt-article-main>header .article-meta-item i {
    flex-shrink: 0;
    height: 1em;
    width: 1em;
    object-fit: contain;
    vertical-align: middle;
}

article.gt-article-main>header .article-meta-item time,
article.gt-article-main>header .article-meta-item span {
    display: inline-flex;
    align-items: center;
    vertical-align: middle;
    line-height: 1.2
}

article.gt-article-main>header .article-meta-item span.time {
    color: #E9B740
}

article.gt-article-main>.article-content-container {
    box-sizing: border-box;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: max-content;
    background-color: var(--gt-card-bg);
    border-bottom-left-radius: var(--gt-main-radius);
    border-bottom-right-radius: var(--gt-main-radius);
    box-shadow: 0 12px 8px 6px rgba(7, 17, 27, 0.05);
    overflow: hidden
}

article.gt-article-main>.article-content-container .tag-list {
    margin-top: 2rem;
    position: relative;
    box-sizing: border-box;
    padding: 1rem 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.58rem;
    width: 100%
}

article.gt-article-main>.article-content-container .tag-list a {
    position: relative;
    box-sizing: border-box;
    padding: 0 0.3125rem;
    display: flex;
    align-items: center;
    gap: 0.28rem;
    width: max-content;
    height: 1.5rem;
    color: var(--gt-main-color);
    border-radius: 0.28rem;
    font-size: 0.76rem;
    transition: color 0.288s ease-in-out;
    overflow: hidden;
    z-index: 1
}





article.gt-article-main>.article-content-container .tag-list a i {
    height: 0.8rem;
    width: auto;
    object-fit: contain
}

.main-inner-content h1,
.main-inner-content h2,
.main-inner-content h3,
.main-inner-content h4,
.main-inner-content h5,
.main-inner-content h6 {
    display: inline-block;
    box-sizing: border-box;
    margin: 1.666rem 0 0.36rem;
    font-size: 1rem;
    width: 100%;
    max-width: 100%;
    word-break: break-all;
    color: var(--gt-font-color)
}

.main-inner-content h1:hover::before,
.main-inner-content h2:hover::before,
.main-inner-content h3:hover::before,
.main-inner-content h4:hover::before {
    color: var(--gt-main-color-88)
}

.main-inner-content h1 {
    margin: 0;
    padding-bottom: 1rem;
    font-size: 1.58rem
}

.main-inner-content h1::before {
    display: none
}

.article-content h2 {
    font-size: 1.5rem;
    position: relative;
    padding-left: 1.25rem;
    color: var(--gt-font-color)
}

.article-content h2::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 1em;
    width: 4px;
    background-color: #3b82f6;
    border-radius: 2px
}

.article-content h3 {
    font-size: 1.25rem;
    position: relative;
    display: inline-block;
    width: auto;
    padding-bottom: 0.25rem;
    margin-bottom: 0.5rem;
    color: var(--gt-font-color)
}

.article-content h3::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 35%;
    height: 3px;
    background-color: #f43f5e;
    border-radius: 1.5px
}

.main-inner-content h3 {
    font-size: 1.25rem
}

.main-inner-content h4 {
    font-size: 1.125rem
}

.main-inner-content p,
.main-inner-content ul:not(.gt-comment ul),
.main-inner-content ol:not(.gt-comment ol) {
    padding: 0.618rem 0;
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--gt-font-color)
}

.main-inner-content ul:not(.gt-comment ul) li,
.main-inner-content ol:not(.gt-comment ol) li {
    color: var(--gt-font-66);
    font-size: 0.875rem;
    line-height: 1.6
}

.main-inner-content p a,
.main-inner-content li a {
    color: var(--gt-main-color);
    text-decoration: none;
    transition: color 0.2s ease-in-out
}

.main-inner-content p a:hover,
.main-inner-content li a:hover {
    color: var(--gt-main-color-88)
}

.main-inner-content ul:not(.gt-comment ul),
.main-inner-content ol:not(.gt-comment ol) {
    box-sizing: border-box;
    padding-left: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    list-style: disc
}

.main-inner-content ol:not(.gt-comment ol) {
    list-style: decimal
}

.main-inner-content blockquote {
    margin: 1rem 0 1.618rem;
    padding: 0 0.88rem;
    border-left: 0.288rem solid #49b1f5;
    background-color: rgba(73, 177, 245, 0.1);
    border-radius: 0.618rem
}

.main-inner-content blockquote p {
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.58rem;
    color: var(--gt-font-color)
}

.main-inner-content table {
    box-sizing: border-box;
    margin: 1rem 0;
    width: 100%;
    border-spacing: 0;
    font-size: 0.9rem;
    background-color: var(--gt-card-bg);
    border: 1px solid var(--gt-font-16);
    border-radius: 0.38rem;
    overflow: hidden
}

.main-inner-content table a {
    color: #49B1F5;
    transition: all 0.18s
}

.main-inner-content table a:hover {
    color: #1b99ee
}

.main-inner-content table th {
    background-color: var(--gt-font-6);
    padding: 0.75rem;
    border-bottom: solid 1px var(--gt-font-16);
    border-right: solid 1px var(--gt-font-16);
    color: var(--gt-font-color)
}

.main-inner-content table th:last-of-type {
    border-right: none
}

.main-inner-content table td {
    padding: 0.618rem 0.75rem;
    vertical-align: top;
    border-bottom: solid 1px var(--gt-font-16);
    border-right: solid 1px var(--gt-font-16);
    color: var(--gt-font-color)
}

.main-inner-content table td:last-of-type {
    border-right: none
}

.main-inner-content table tr:last-of-type td {
    border-bottom: none
}

.main-inner-content table tr:hover {
    background-color: rgba(242, 242, 242, 0.4)
}

.main-inner-content img {
    display: block;
    margin: 0 auto
}

.main-inner-content img.gt-article-img {
    box-sizing: border-box;
    padding: 0.36rem;
    width: max-content;
    max-width: 100%;
    max-height: 36rem;
    border: solid 1px var(--gt-font-16);
    border-radius: 5px;
    cursor: zoom-in
}

.main-inner-content img.gt-article-img:not(.loaded) {
    width: 100%
}

.article-excerpt {
    margin: 0.618rem 0;
    padding: 0.75rem;
    border: 1px dashed #dd8636;
    border-radius: var(--gt-main-radius);
    background-color: var(--gt-bg-fa);
    color: var(--gt-font-color);
    font-size: 0.955rem;
    line-height: 1.6
}

pre,
code {
    font-family: var(--gt-code-font);
    font-size: inherit
}

.main-inner-content code {
    background-color: var(--gt-font-16);
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem
}

pre.gt-code-block {
    position: relative;
    background: var(--gt-code-bg);
    border: 1px solid var(--gt-code-border);
    border-radius: var(--gt-code-radius);
    margin: 1.25rem 0;
    padding: 2.5rem 1rem 1rem;
    font-family: var(--gt-code-font);
    font-size: var(--gt-code-font-size);
    line-height: var(--gt-code-line-height);
    color: var(--gt-code-color);
    overflow: auto;
    max-height: 500px
}

pre.gt-code-block::before {
    content: "";
    position: absolute;
    top: 0.875rem;
    left: 0.875rem;
    width: 0.75rem;
    height: 0.75rem;
    background: var(--gt-code-decoration-color);
    border-radius: 50%;
    box-shadow: var(--gt-code-decoration-shadow);
}

pre.gt-code-block .gt-code-lang,
pre.gt-code-block .gt-code-copy {
    position: absolute;
    top: 0.5rem;
    font-size: 0.75rem;
    font-family: var(--gt-code-lang-font);
    border-radius: 0.375rem
}

pre.gt-code-block .gt-code-lang {
    left: 4.5rem;
    color: var(--gt-code-lang-color);
    font-weight: 500;
    text-transform: uppercase
}

pre.gt-code-block .gt-code-copy {
    right: 0.75rem;
    padding: 0.25rem 0.625rem;
    background: var(--gt-card-bg);
    color: var(--gt-font-color);
    border: 1px solid var(--gt-border-light);
    cursor: pointer;
    z-index: 10;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    opacity: 0.8
}

pre.gt-code-block .gt-code-copy:hover {
    opacity: 1;
    background: var(--gt-main-color-16)
}

pre.gt-code-block .gt-code-copy.copy-success {
    background: var(--gt-success, #27c93f);
    color: #fff;
    border-color: var(--gt-success, #27c93f)
}

pre.gt-code-block .hljs {
    background: transparent;
    color: inherit;
    padding: 0
}

pre.gt-code-block :is(.hljs-keyword, .hljs-selector-tag) { color: var(--gt-hl-keyword) }
pre.gt-code-block .hljs-built_in { color: var(--gt-hl-built-in) }
pre.gt-code-block .hljs-tag { color: var(--gt-hl-tag) }
pre.gt-code-block :is(.hljs-string, .hljs-attr) { color: var(--gt-hl-string) }
pre.gt-code-block .hljs-number { color: var(--gt-hl-number) }
pre.gt-code-block :is(.hljs-function, .hljs-title, .hljs-class) { color: var(--gt-hl-function) }
pre.gt-code-block :is(.hljs-variable, .hljs-template-variable) { color: var(--gt-hl-variable) }
pre.gt-code-block :is(.hljs-comment, .hljs-quote) { color: var(--gt-hl-comment) }
pre.gt-code-block .hljs-addition { background-color: var(--gt-hl-addition-bg) }
pre.gt-code-block .hljs-deletion { background-color: var(--gt-hl-deletion-bg) }

.gt-footer {
    margin-top: 1rem;
    box-sizing: border-box;
    padding: 1.5rem 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: max-content;
    background-color: var(--gt-footer-bg);
    box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.08)
}

.gt-footer main {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 0.618rem;
    width: 100%;
    max-width: var(--gt-main-max-width);
    height: max-content;
    padding: 0 1rem
}

.gt-footer-grid {
    display: grid;
    grid-template-columns: 1.2fr 1.6fr 1fr;
    gap: 1.68rem;
    align-items: center;
    width: 100%
}

.gt-footer-brand {
    display: flex;
    flex-direction: column;
    gap: 0.75rem
}

.gt-footer-logo {
    display: inline-flex;
    align-items: center;
    width: max-content;
    height: max-content;
    color: var(--gt-font-color)
}

.gt-footer-logo-img {
    display: block;
    width: 120px;
    height: 40px;
    object-fit: contain
}

.gt-footer-logo-text {
    font-size: 1.08rem;
    font-weight: 700
}

.gt-footer-desc {
    font-size: 0.78rem;
    line-height: 1.6;
    color: var(--gt-font-66);
    font-weight: normal
}

.gt-footer-custom {
    font-size: 0.9rem;
    color: var(--gt-font-color);
    line-height: 1.8
}

.gt-footer-custom a {
    color: var(--gt-main-color);
    transition: color 0.18s
}

.gt-footer-custom a:hover {
    color: var(--gt-main-color)
}

.gt-footer-qrcodes {
    display: flex;
    justify-content: flex-end;
    gap: 1rem
}

.gt-footer-qrcode {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem
}

.gt-footer-qrcode-img {
    display: block;
    background: var(--gt-white-color);
    border-radius: 0.5rem;
    box-shadow: var(--gt-box-shadow);
    object-fit: cover
}

.gt-footer-qrcode-text {
    font-size: 0.86rem;
    color: var(--gt-font-66);
    line-height: 1.2
}

.gt-footer-bottom {
    box-sizing: border-box;
    margin-top: 0.8rem;
    padding-top: 0;
    border-top: none
}

.gt-footer-bottom p {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.618rem;
    line-height: 1.5;
    font-size: 0.875rem;
    color: var(--gt-font-color)
}

.gt-footer-bottom p a {
    color: var(--gt-main-color);
    transition: color 0.18s
}

.gt-footer-bottom p a:hover {
    color: var(--gt-main-color)
}

.gt-footer-bottom p span {
    box-sizing: border-box;
    padding-left: 0.28rem;
    display: flex;
    align-items: center;
    width: max-content;
    height: 1.25rem;
    background-color: transparent;
    font-size: 0.875rem;
    border-radius: 0.18rem;
    overflow: hidden
}

.gt-footer-bottom p span cite,
.gt-footer-bottom p span em {
    box-sizing: border-box;
    padding: 0 0.618rem;
    width: max-content;
    height: 100%;
    line-height: 1.25rem;
    color: var(--gt-font-color);
    font-style: normal
}

.gt-footer-bottom p span cite {
    padding-left: 0.28rem
}

.gt-footer-bottom p span em {
    background-color: transparent
}

.gt-footer-bottom p span svg {
    width: 0.88rem;
    height: 0.88rem;
    fill: var(--gt-font-color)
}

@media (max-width: 992px) {
    .gt-footer-grid {
        grid-template-columns: 1fr;
        gap: 1.18rem
    }
    .gt-footer-qrcodes {
        justify-content: center
    }
    .gt-footer-brand {
        display: none
    }
    .gt-footer-custom {
        text-align: center
    }
}

.gt-back-top {
    position: fixed;
    right: 1rem;
    bottom: 2rem;
    z-index: 998
}

/* 友链页面返回顶部按钮位置调整 - 与申请友链按钮对齐 */
body.page-template-links .gt-back-top {
    right: 1rem;
    bottom: 2rem;
}

.gt-back-top button {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--gt-card-bg);
    border: none;
    box-shadow: var(--gt-box-shadow);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.18s;
    color: var(--gt-font-color)
}

.gt-back-top button:hover {
    background: var(--gt-main-color);
    color: #fff;
    transform: translateY(-3px)
}

.gt-back-top button i {
    font-size: 1.2rem
}

.gt-search-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    display: none;
    align-items: flex-start;
    justify-content: center;
    padding-top: 15vh;
    z-index: var(--z-search-modal)
}

.gt-search-modal.active {
    display: flex
}

.gt-search-box {
    box-sizing: border-box;
    padding: 1rem;
    width: 100%;
    max-width: 500px;
    background: var(--gt-card-bg);
    border-radius: var(--gt-main-radius);
    box-shadow: var(--gt-box-shadow)
}



.gt-search-form {
    display: flex;
    gap: 0.5rem
}

.gt-search-form input {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 1px solid var(--gt-font-16);
    border-radius: var(--gt-main-radius);
    font-size: 0.95rem;
    outline: none;
    transition: all 0.18s
}

.gt-search-form input:focus {
    border-color: var(--gt-main-color);
    box-shadow: 0 0 0 3px var(--gt-main-color-16)
}

.gt-search-form button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.8rem;
    height: 2.8rem;
    background: var(--gt-main-color);
    border: none;
    border-radius: var(--gt-main-radius);
    color: #fff;
    cursor: pointer;
    transition: all 0.18s
}

.gt-search-form button:hover {
    background: var(--gt-main-color-88);
    transform: translateX(3px)
}

.gt-search-form button i {
    font-size: 1.2rem
}

.gt-animation.gt-animation-init {
    opacity: 0;
    animation: 300ms gt-init-show;
    animation-fill-mode: forwards;
    transition: opacity 0.18s ease-in-out, transform 0.18s ease-in-out
}

@keyframes gt-init-show {
    0% {
        transform: translateY(2rem);
        opacity: 0
    }

    100% {
        transform: translateY(0);
        opacity: 1
    }
}

.gt-article-item:nth-child(1) {
    animation-delay: 0.05s
}

.gt-article-item:nth-child(2) {
    animation-delay: 0.1s
}

.gt-article-item:nth-child(3) {
    animation-delay: 0.15s
}

.gt-article-item:nth-child(4) {
    animation-delay: 0.2s
}

.gt-article-item:nth-child(5) {
    animation-delay: 0.25s
}

.gt-article-item:nth-child(6) {
    animation-delay: 0.3s
}

.gt-article-item:nth-child(7) {
    animation-delay: 0.35s
}

.gt-article-item:nth-child(8) {
    animation-delay: 0.4s
}

.gt-article-item:nth-child(9) {
    animation-delay: 0.45s
}

.gt-space-loading {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    grid-column: span 3;
    width: 100%;
    height: 8.88rem;
    overflow: hidden
}

.gt-space-loading span {
    background-color: #000;
    position: relative;
    width: 5px;
    height: 5px;
    margin: 3px;
    border-radius: 5px
}

.gt-space-loading span:nth-of-type(1) {
    animation: gt-loading-animation 0.8s ease infinite
}

.gt-space-loading span:nth-of-type(2) {
    animation: gt-loading-animation 0.8s ease 0.2s infinite
}

.gt-space-loading span:nth-of-type(3) {
    animation: gt-loading-animation 0.8s ease 0.4s infinite
}

@keyframes gt-loading-animation {
    50% {
        height: 25px
    }

    0% {
        height: 5px
    }
}

@media screen and (max-width:1150px) {
    .article-list-main>section.article-list,
    .article-list-main>section.article-list[data-grid="4"] {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media screen and (max-width:888px) {
    main.main>.main-inner {
        flex-direction: column;
        padding-top: calc(var(--gt-header-height) + 0rem);
    }

    main.main>.main-inner>aside.gt-aside {
        display: none;
    }

    header.gt-header .nav-center {
        display: none
    }

    header.gt-header .nav-right {
        gap: 0.35rem
    }

    header.gt-header .nav-right .nav-link {
        padding: 0.2rem 0.3rem
    }

    header.gt-header .nav-right .nav-link i {
        font-size: 1.1rem
    }
}

@media screen and (max-width:768px) {
    :root {
        --gt-header-height: 56px
    }

    body {
        user-select: none;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none
    }

    header.gt-header>section {
        position: relative;
        justify-content: flex-end;
        padding: 0 0.88rem
    }

    header.gt-header .home,
    header.gt-header .site-logo {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        padding: 0
    }

    header.gt-header .home img,
    header.gt-header .site-logo img {
        height: 2rem;
    }

    header.gt-header .home span,
    header.gt-header .site-logo span {
        font-size: 1.2rem;
        line-height: 1;
    }

    article.gt-article-main>header h1 {
        font-size: 1.36rem
    }

    article.gt-article-main>header .article-meta {
        gap: 0.5rem 0.75rem
    }

    article.gt-article-main>header .article-meta-item {
        font-size: 0.8rem
    }

    article.gt-article-main>header .article-meta-item svg,
    article.gt-article-main>header .article-meta-item i {
        font-size: 0.85rem
    }

    .main-inner-content h1 {
        font-size: 1.36rem
    }

    .main-inner-content h2 {
        font-size: 1.26rem
    }

    .main-inner-content h3 {
        font-size: 1.125rem
    }
    
    /* 手机端缩小置顶标识 */
    .gt-article-item.active::before,
    .gt-recommend-top-badge {
        top: 0.6rem;
        left: -0.4rem;
        padding: 0.1rem 0.6rem;
        font-size: 0.688rem;
        border-radius: 0.4rem;
    }
}

@media screen and (max-width:1024px) {
    .article-list-main>section.article-list[data-grid="3"] {
        grid-template-columns: 1fr;
    }
}

@media screen and (max-width:768px) {
    .article-list-main>section.article-list[data-grid="4"] {
        grid-template-columns: repeat(2, 1fr);
    }
}

[data-theme="dark"] {
    /* 背景色 - 深色模式 */
    --gt-body-bg: #232323;
    --gt-bg-rgb: 35, 35, 35;
    --gt-card-bg: #303030;
    --gt-bg-fa: #2a2a2a;
    --gt-bg-f5: #333333;
    --gt-white-color: #f0f0f0;
    --gt-header-bg: rgba(30, 32, 33, 0.98);
    --gt-footer-bg: rgba(30, 32, 33, 0.5);
    
    /* 文字色 - 深色模式 */
    --gt-font-color: #e8e6e3;
    --gt-font-rgb: 232, 230, 227;
    --gt-text-secondary: rgba(232, 230, 227, 0.72);
    --gt-text-muted: rgba(232, 230, 227, 0.62);
    
    /* 边框色 - 深色模式 */
    --gt-border-color: #3a3d40;
    --gt-border-light: rgba(232, 230, 227, 0.16);
    
    /* 阴影 - 深色模式 */
    --gt-box-shadow: 0 3px 8px 6px rgba(0, 0, 0, 0.15);
    --gt-header-shadow: 0 1px 12px rgba(0, 0, 0, 0.25);
    --gt-footer-shadow: 0 -2px 12px rgba(0, 0, 0, 0.3);
    
    /* 状态色 - 深色模式 */
    --gt-info: #A8D08D;
    --gt-info-hover: rgba(168, 208, 141, 0.12);
    --gt-success: #FFD666;
    --gt-success-hover: rgba(255, 214, 102, 0.12);
    --gt-warning: #FF9999;
    --gt-warning-hover: rgba(255, 153, 153, 0.12);
    --gt-error: #B794F4;
    --gt-error-hover: rgba(183, 148, 244, 0.12);
    --gt-import: #F687B3;
    --gt-import-hover: rgba(246, 135, 179, 0.12);
    
    /* 代码块 - 深色模式 */
    --gt-code-bg: #1e1e1e;
    --gt-code-border: #3a3d40;
    --gt-code-color: #d4d4d4;
    --gt-code-lang-color: #858585;
    
    /* 语法高亮 - 深色模式 */
    --gt-hl-keyword: #569cd6;
    --gt-hl-built-in: #4ec9b0;
    --gt-hl-string: #ce9178;
    --gt-hl-number: #b5cea8;
    --gt-hl-function: #dcdcaa;
    --gt-hl-variable: #9cdcfe;
    --gt-hl-comment: #6a9955;
    --gt-hl-tag: #569cd6;
    --gt-hl-addition-bg: #203522;
    --gt-hl-deletion-bg: #4b1818;
}

[data-theme="dark"] .reward-close-btn {
    background: rgba(255, 255, 255, 0.15);
}

[data-theme="dark"] .reward-close-btn:hover {
    background: rgba(255, 255, 255, 0.25);
}

[data-theme="dark"] .gt-aside-item.user .gt-aside-links-item:hover {
    border-color: var(--gt-main-color);
}

.gt-pw-form {
    box-sizing: border-box;
    padding: 2rem 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%
}

.gt-pw-form-content {
    box-sizing: border-box;
    display: flex;
    gap: 0.5rem;
    width: 100%;
    max-width: 400px
}

.gt-pw-input {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 1px solid var(--gt-font-16);
    border-radius: var(--gt-main-radius);
    font-size: 0.95rem;
    outline: none;
    transition: all 0.18s;
    background-color: var(--gt-white-color);
    color: var(--gt-font-color)
}

.gt-pw-input:focus {
    border-color: var(--gt-main-color);
    box-shadow: 0 0 0 3px var(--gt-main-color-16)
}

.gt-pw-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    padding: 0 1.25rem;
    background: var(--gt-main-color);
    border: none;
    border-radius: var(--gt-main-radius);
    color: #fff;
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.18s
}

.gt-pw-btn:hover {
    background: var(--gt-main-color-88);
    transform: translateX(2px)
}

.gt-pw-btn i {
    font-size: 1rem
}

.gt-comment {
    margin-top: 2rem;
    box-sizing: border-box;
    width: 100%;
    height: max-content;
    border-radius: 0.5rem;
    background-color: var(--gt-card-bg);
    box-shadow: var(--gt-box-shadow);
    overflow: hidden
}

.gt-comment-header {
    box-sizing: border-box;
    padding: 1rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: var(--gt-font-6);
    border-bottom: 1px solid var(--gt-font-6)
}

.gt-comment-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--gt-font-color)
}

.gt-comment-title i {
    font-size: 1.25rem;
    color: var(--gt-main-color)
}

.gt-comment-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.5rem;
    height: 1.5rem;
    padding: 0 0.5rem;
    font-size: 0.75rem;
    font-style: normal;
    font-weight: 600;
    color: var(--gt-white-color);
    background-color: var(--gt-main-color);
    border-radius: 1rem
}

.gt-comment-form-wrap {
    box-sizing: border-box;
    padding: 1.5rem
}

.gt-comment-closed {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 2rem;
    color: var(--gt-font-56);
    text-align: center
}

.gt-comment-closed i {
    font-size: 2.5rem;
    color: var(--gt-font-28)
}

.gt-comment-form {
    display: flex;
    flex-direction: column;
    gap: 1rem
}

.gt-comment-textarea-wrap {
    position: relative;
    border: 1px solid var(--gt-font-16);
    border-radius: 0.5rem;
    overflow: hidden;
    transition: all 0.18s ease-in-out
}

.gt-comment-textarea-wrap:focus-within {
    border-color: var(--gt-main-color);
    box-shadow: 0 0 0 3px var(--gt-main-color-16)
}

.gt-comment-textarea-wrap textarea {
    width: 100%;
    min-height: 140px;
    padding: 1rem;
    border: none;
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--gt-font-color);
    background-color: transparent;
    resize: vertical;
    outline: none
}

.gt-comment-textarea-wrap textarea::placeholder {
    color: var(--gt-font-28)
}

.gt-comment-textarea-footer {
    padding: 0.5rem 1rem;
    background-color: var(--gt-font-6);
    border-top: 1px solid var(--gt-font-6)
}

.gt-comment-fields {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem
}

.gt-comment-field {
    position: relative;
    display: flex;
    align-items: center;
    border: 1px solid var(--gt-font-16);
    border-radius: 0.5rem;
    overflow: hidden;
    transition: all 0.18s ease-in-out
}

.gt-comment-field:focus-within {
    border-color: var(--gt-main-color);
    box-shadow: 0 0 0 3px var(--gt-main-color-16)
}

.gt-comment-field i {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
    color: var(--gt-font-56);
    background-color: var(--gt-font-6)
}

.gt-comment-field input {
    flex: 1;
    padding: 0.625rem 0.75rem;
    border: none;
    font-size: 0.875rem;
    color: var(--gt-font-color);
    background-color: transparent;
    outline: none
}

.gt-comment-field input::placeholder {
    color: var(--gt-font-28)
}

.gt-comment-submit-wrap {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.5rem
}

.gt-comment-submit-wrap button,
.gt-comment-submit-wrap .cancel-comment-reply a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    padding: 0.375rem 0.875rem;
    font-size: 0.8125rem;
    line-height: 1.5;
    min-height: 2rem;
    box-sizing: border-box;
    font-weight: 500;
    color: var(--gt-white-color);
    border-radius: 0.375rem;
    cursor: pointer;
    transition: all 0.2s
}

.gt-comment-submit-wrap button {
    background: var(--gt-main-color);
    border: none
}

.gt-comment-submit-wrap .cancel-comment-reply a {
    background-color: var(--gt-font-28)
}

.gt-comment-submit-wrap button:hover {
    background: var(--gt-main-color-dark, var(--gt-main-color));
    transform: translateY(-1px)
}

.gt-comment-submit-wrap .cancel-comment-reply a:hover {
    background-color: var(--gt-font-56)
}

.gt-comment-list {
    box-sizing: border-box;
    padding: 0 1.5rem 1.5rem
}

/* 修复：嵌套的评论列表不要左右 padding，避免递归累加 */
.gt-comment-replies .gt-comment-list {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.gt-comment-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 3rem 1rem;
    color: var(--gt-font-56)
}

.gt-comment-empty i {
    font-size: 3rem;
    color: var(--gt-font-16)
}

.gt-comment-item {
    display: flex;
    border-bottom: 1px dashed var(--gt-font-16);
    flex-wrap: wrap;
}

.gt-comment-item > .respond {
    width: 100%;
    flex-basis: 100%;
}

.gt-comment-item:last-child {
    border-bottom: none
}

.gt-comment-avatar {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08)
}

.gt-comment-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.gt-comment-master>.gt-comment-avatar {
    position: relative;
    overflow: visible;
    box-shadow: 0 0 16px rgba(153, 153, 255, 0.3)
}

.gt-comment-master>.gt-comment-avatar img {
    border-radius: 50%
}

.gt-comment-master>.gt-comment-avatar::after {
    content: "";
    position: absolute;
    right: -0.35rem;
    bottom: -0.35rem;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    background: var(--gt-white-color) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239999ff'%3E%3Cpath d='M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm-2 16l-4-4 1.41-1.41L10 14.17l6.59-6.59L18 9l-8 8z'/%3E%3C/svg%3E") no-repeat center center;
    background-size: 70%;
    box-shadow: 0 2px 6px rgba(153, 153, 255, 0.4)
}

.gt-comment-main {
    flex: 1;
    min-width: 0
}

.gt-comment-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    flex-wrap: wrap
}

.gt-comment-meta-wrapper {
    display: flex;
    flex-direction: column
}

.gt-comment-meta-info {
    margin-top: 0.125rem;
    font-size: 0.8rem
}

.gt-comment-footer {
    display: flex;
    align-items: center
}

.gt-comment-footer .gt-comment-actions {
    margin-left: 0.5rem
}

.gt-comment-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap
}

.gt-comment-nick {
    position: relative;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--gt-font-color);
    text-decoration: none;
    transition: color 0.18s ease-in-out
}

.gt-comment-nick::after {
    content: "";
    position: absolute;
    left: auto;
    right: 0;
    bottom: -1px;
    width: 0;
    height: 1px;
    background-color: var(--gt-main-color);
    transition: all 0.28s ease-in-out
}

a.gt-comment-nick:hover {
    color: var(--gt-main-color)
}

a.gt-comment-nick:hover::after {
    left: 0;
    right: auto;
    width: 100%
}

.gt-comment-master .gt-comment-nick {
    color: #9999ff;
    font-weight: 700
}

.gt-comment-badge {
    display: inline-flex;
    align-items: center;
    padding: 0 0.4rem;
    font-size: 0.75rem;
    font-weight: 500;
    color: #9999ff;
    border: 1px solid #9999ff;
    border-radius: 4px;
    line-height: 1.4
}

.gt-comment-badge i {
    display: none
}

.gt-comment-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
    padding: 0.1rem 0.4rem;
    font-size: 0.68rem;
    color: var(--gt-font-56);
    background-color: var(--gt-font-6);
    border-radius: 0.25rem;
    white-space: nowrap;
    line-height: 1
}

.gt-comment-tag i {
    font-size: 0.68rem;
    display: inline-flex;
    align-items: center
}

.gt-comment-time {
    flex-shrink: 0;
    font-size: 0.75rem;
    color: var(--gt-font-66);
    white-space: nowrap
}

.gt-comment-content {
    margin-bottom: 0.5rem;
    font-size: 0.88rem;
    line-height: 1.75;
    color: var(--gt-font-66);
    word-break: break-word
}

.gt-comment-content p {
    margin: 0;
    padding: 0.18rem 0
}

.gt-comment-content a {
    color: var(--gt-main-color);
    box-shadow: inset 0 -0.12rem var(--gt-main-color);
    transition: box-shadow 0.2s ease-in-out
}

.gt-comment-content a:hover {
    box-shadow: inset 0 -1.5rem var(--gt-main-color-16)
}

.gt-comment-actions {
    display: flex;
    gap: 1rem
}

/* Typecho 生成的回复链接样式 */
.gt-comment-actions a {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0;
    font-size: 0.75rem;
    color: var(--gt-font-66);
    text-decoration: none;
    background: transparent;
    border: none;
    cursor: pointer;
    transition: color 0.18s ease-in-out
}

.gt-comment-actions a:hover {
    color: var(--gt-main-color)
}

@media screen and (max-width:768px) {
    .gt-comment-fields {
        grid-template-columns: 1fr
    }

    .gt-comment-avatar {
        width: 36px;
        height: 36px
    }



    .gt-comment-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem
    }
}

.gt-breadcrumb {
    box-sizing: border-box;
    margin: 0 0 0.5rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--gt-font-66)
}

.gt-breadcrumb a {
    color: var(--gt-main-color);
    transition: color 0.18s
}

.gt-breadcrumb a:hover {
    color: var(--gt-main-color-88)
}

.gt-breadcrumb span {
    color: var(--gt-font-28)
}

.gt-breadcrumb .current {
    color: var(--gt-main-color)
}

/* 面包屑样式优化 - 仅针对移动端 */
@media (max-width: 768px) {
    .gt-breadcrumb {
        flex-wrap: nowrap;
        overflow: hidden;
        white-space: nowrap;
        font-size: 13px;
    }
    
    .gt-breadcrumb span:not(.current) {
        font-size: 12px;
    }
    
    .gt-breadcrumb span.current {
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 150px;
    }
}

.gt-empty {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    background: var(--gt-card-bg);
    border-radius: var(--gt-main-radius);
    box-shadow: var(--gt-box-shadow);
    text-align: center
}

.gt-empty img {
    max-width: 200px;
    margin-bottom: 1rem
}

.gt-empty p {
    color: var(--gt-font-66);
    font-size: 0.9rem
}

.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

section.gt-art-page a,
section.gt-art-page span,
.pagination a,
.pagination span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    height: 2rem;
    padding: 0 0.5rem;
    border-radius: var(--gt-main-radius);
    background-color: var(--gt-card-bg);
    box-shadow: var(--gt-box-shadow);
    font-size: 0.875rem;
    color: #99a9bf;
    user-select: none;
    transition: all 0.18s ease-in-out;
    text-decoration: none
}

section.gt-art-page a:hover,
.pagination a:hover {
    color: var(--gt-white-color);
    background-color: rgba(129, 146, 174, 0.36)
}

section.gt-art-page span.active,
section.gt-art-page a.active,
.pagination span.active,
.pagination a.active {
    background-color: #8192AE;
    color: var(--gt-white-color);
    cursor: default;
    pointer-events: none
}

section.gt-art-page span:not(.active),
.pagination span:not(.active) {
    background-color: transparent;
    box-shadow: none;
    color: var(--gt-font-28)
}

section.gt-art-page em,
.pagination em {
    color: var(--gt-font-28);
    font-style: normal;
    padding: 0 0.25rem
}

header.gt-header .nav-center .nav-dropdown {
    position: relative;
    height: 100%;
    display: flex;
    align-items: center
}

header.gt-header .nav-center .nav-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    min-width: 150px;
    padding: 0.5rem 0;
    background: var(--gt-card-bg);
    border-radius: var(--gt-main-radius);
    box-shadow: var(--gt-box-shadow);
    opacity: 0;
    visibility: hidden;
    transition: all 0.18s ease-in-out;
    z-index: 100
}

header.gt-header .nav-center .nav-dropdown:hover .nav-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0)
}

header.gt-header .nav-center .nav-dropdown-item {
    display: block;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--gt-font-color);
    transition: all 0.18s;
    white-space: nowrap
}

header.gt-header .nav-center .nav-dropdown-item:hover {
    background: var(--gt-main-color-16);
    color: var(--gt-main-color)
}

.d-flex {
    display: flex !important
}

.text-truncate {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important
}

.visually-hidden,
.visually-hidden-focusable:not(:focus):not(:focus-within) {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important
}

@media (min-width:768px) {
    .d-md-block {
        display: block !important
    }

    .d-md-flex {
        display: flex !important
    }

    .d-md-none {
        display: none !important
    }
}

@media (max-width:767px) {
    .d-md-block {
        display: none !important
    }

    .d-md-flex {
        display: none !important
    }

    .d-md-none {
        display: block !important
    }
}

/* ==================== 评论样式 ==================== */
.gt-comment-item {
    gap: 12px;
    padding: 12px 0 0
}

.gt-comment-item:last-child {
    padding-bottom: 0
}

.gt-comment-at {
    display: inline;
    margin-right: 4px;
    color: var(--gt-main-color);
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    box-shadow: none !important
}

.gt-comment-at:hover {
    text-decoration: underline;
    box-shadow: none !important
}

.gt-comment-replies {
    width: 100%;
    margin-top: 8px;
    padding-left: 42px
}

.gt-comment-replies .gt-comment-replies {
    padding-left: 0
}

/* 4. 博主标识 */
.gt-comment-master>.gt-comment-avatar {
    box-shadow: 0 0 0 2px #9999ff
}

.gt-comment-master>.gt-comment-avatar::after {
    right: -2px;
    bottom: -2px;
    width: 14px;
    height: 14px;
    border: 2px solid #fff
}

/* 5. 头像占位符 */
.gt-comment-avatar-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gt-font-6);
    color: var(--gt-font-56);
    font-size: 1.25rem
}

/* 6. 评论渲染错误提示 */
.gt-comment-error {
    color: #de3c3d;
    padding: 12px 16px;
    border: 1px solid rgba(222, 60, 61, 0.3);
    border-radius: 8px;
    margin: 12px 0;
    background: rgba(222, 60, 61, 0.05);
    font-size: 0.875rem
}

.form-control,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
textarea,
select {
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--gt-font-color);
    background-color: var(--gt-white-color);
    border: 1px solid var(--gt-font-16);
    border-radius: var(--gt-main-radius);
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    outline: none
}

.form-control:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
    border-color: var(--gt-main-color);
    box-shadow: 0 0 0 3px var(--gt-main-color-16)
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1rem;
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    border: 1px solid transparent;
    border-radius: var(--gt-main-radius);
    transition: all 0.15s ease-in-out
}

.btn-primary {
    color: #fff;
    background-color: var(--gt-main-color);
    border-color: var(--gt-main-color)
}

.btn-primary:hover {
    background-color: var(--gt-main-color-88);
    border-color: var(--gt-main-color-88)
}

.btn-outline-secondary {
    color: var(--gt-font-color);
    border-color: var(--gt-font-16);
    background-color: transparent
}

.btn-outline-secondary:hover {
    color: var(--gt-main-color);
    border-color: var(--gt-main-color);
    background-color: var(--gt-main-color-16)
}

.ticket {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    border-radius: 0.25rem;
    color: #fff
}

.ticket-primary {
    background: var(--gt-main-color)
}

.ticket-success {
    background: var(--gt-success)
}

.ticket-warning {
    background: var(--gt-warning)
}

.ticket-danger {
    background: var(--gt-error)
}

.ticket-rainbow {
    background: #667eea
}

.gt-mobile-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    z-index: var(--z-overlay);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease;
    will-change: opacity;
}

.gt-mobile-overlay.active {
    opacity: 1;
    visibility: visible;
}

.gt-mobile-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 280px;
    height: 100vh;
    background: var(--gt-card-bg);
    z-index: var(--z-mobile-sidebar);
    transform: translateX(-280px);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    box-shadow: 2px 0 15px rgba(0,0,0,0.1);
    border-radius: 0 20px 20px 0;
    overflow: hidden;
    padding-top: var(--gt-header-height);
}

.gt-mobile-sidebar.active {
    transform: translateX(0);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

/* Body */
.gt-mobile-sidebar-body {
    flex: 1;
    padding: 5px 20px 10px;
}

.gt-mobile-sidebar-body .gt-aside-item {
    margin-bottom: 1rem;
}

/* Header */
.gt-mobile-sidebar-header {
    padding: 15px 20px;
    background: var(--gt-card-bg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
}

.gt-mobile-sidebar-header .header-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    color: var(--gt-font-color);
    text-decoration: none;
    font-size: 12px;
    transition: all 0.2s;
    cursor: pointer;
}

.gt-mobile-sidebar-header .header-item .item-icon {
    width: 40px;
    height: 40px;
    background: var(--gt-main-color-6);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    transition: all 0.2s;
    color: var(--gt-font-color);
}

.gt-mobile-sidebar-header .header-item:hover .item-icon {
    background: var(--gt-main-color);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px var(--gt-main-color-28);
}



.gt-mobile-nav-list {
    display: flex;
    flex-direction: column;
    padding: 0 0 10px;
    margin: 0;
}

/* 一级菜单项 */
.gt-mobile-nav-item {
    position: relative;
}

.gt-mobile-nav-item.has-children {
    display: flex;
    flex-direction: column;
}

.gt-mobile-nav-link {
    display: flex;
    align-items: center;
    padding: 12px 10px 12px 0.75rem;
    font-size: 14px;
    color: var(--gt-font-color);
    text-decoration: none;
    font-weight: 500;
    border-radius: 8px;
    margin-bottom: 2px;
    margin-left: -10px;
    margin-right: -10px;
    transition: all 0.2s;
    position: relative;
}

.gt-mobile-nav-link::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 16px;
    background-color: var(--gt-main-color);
    border-radius: 2px;
}

/* 第一个一级菜单项减少上边距 */
.gt-mobile-nav-item:first-child .gt-mobile-nav-link {
    padding-top: 5px;
    padding-left: 0.75rem;
}

.gt-mobile-nav-link:hover,
.gt-mobile-nav-link.active {
    color: var(--gt-main-color);
}

.gt-mobile-nav-item.has-children .gt-mobile-nav-link {
    padding-bottom: 8px;
    padding-left: 0.75rem;
}

/* 二级菜单（网格布局） */
.gt-mobile-submenu {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    padding: 0.5rem;
    background: var(--gt-bg-fa);
    border-radius: 8px;
    margin-top: -10px;
}

.gt-mobile-submenu-item {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 0.4rem 0.5rem;
    color: var(--gt-main-color);
    text-decoration: none;
    border-radius: 4px;
    font-size: 0.75rem;
    text-align: left;
    transition: all 0.2s ease;
    border: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    background: var(--gt-main-color-5);
}

.gt-mobile-submenu-item:hover {
    color: var(--gt-main-color);
    background: var(--gt-main-color-10);
}

.gt-recommend-section {
    box-sizing: border-box;
    width: 100%;
    max-width: var(--gt-main-max-width);
    margin: 0.25rem auto 1rem;
    overflow: hidden;
}

@media screen and (max-width: 888px) {
    .gt-recommend-section {
        margin-top: 0.25rem;
    }
}

.gt-recommend-top {
    display: grid;
    grid-template-columns: calc(70% - 0.375rem) calc(30% - 0.375rem);
    gap: 0.75rem;
    margin-bottom: 0.75rem;
    height: 390px
}

.gt-recommend-top:has(.gt-recommend-right:only-child) {
    grid-template-columns: 1fr
}

.gt-recommend-top:has(.gt-recommend-main:only-child) {
    grid-template-columns: 1fr
}

/* 电脑端只有小图时，改为水平排列，只针对大屏幕 */
@media screen and (min-width:1025px) {
    .gt-recommend-top:has(.gt-recommend-right:only-child) .gt-recommend-right {
        grid-template-rows: 1fr;
        grid-template-columns: 1fr 1fr;
        height: 390px;
    }
    /* 当只有一个小图时，宽度改为100% */
    .gt-recommend-top:has(.gt-recommend-right:only-child) .gt-recommend-right:has(.gt-recommend-item:only-child) {
        grid-template-columns: 1fr;
    }
}

/* 中等屏幕电脑端只有小图时（769px-1024px），不影响手机端 */
@media screen and (min-width:769px) and (max-width:1024px) {
    .gt-recommend-top:has(.gt-recommend-right:only-child) .gt-recommend-right {
        grid-template-rows: 1fr;
        grid-template-columns: 1fr 1fr;
        height: 280px;
    }
    /* 当只有一个小图时，宽度改为100% */
    .gt-recommend-top:has(.gt-recommend-right:only-child) .gt-recommend-right:has(.gt-recommend-item:only-child) {
        grid-template-columns: 1fr;
    }
}

.gt-recommend-main {
    position: relative;
    display: block;
    height: 100%;
    border-radius: var(--gt-main-radius);
    overflow: hidden;
    box-shadow: var(--gt-box-shadow);
    transition: all 0.3s ease
}

.gt-recommend-main:hover,
.gt-recommend-item:hover,
.gt-recommend-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15)
}

.gt-recommend-main:hover img,
.gt-recommend-item:hover img,
.gt-recommend-card:hover img {
    transform: scale(1.05)
}

.gt-recommend-main picture,
.gt-recommend-main img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease
}

.gt-recommend-main .gt-recommend-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1rem 1.25rem;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
    color: #fff
}

.gt-recommend-main .gt-recommend-tag {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    font-size: 0.75rem;
    font-weight: 600;
    background: var(--gt-main-color);
    border-radius: 0.25rem;
    margin-bottom: 0.4rem
}

.gt-recommend-main h2 {
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.4;
    margin: 0;
    color: #fff;
    box-sizing: border-box !important
}

.gt-recommend-right {
    display: grid;
    grid-template-rows: 1fr 1fr;
    gap: 0.75rem;
    height: 100%
}

.gt-recommend-right:has(.gt-recommend-item:only-child) {
    grid-template-rows: 1fr
}

.gt-recommend-item {
    position: relative;
    display: block;
    border-radius: var(--gt-main-radius);
    overflow: hidden;
    box-shadow: var(--gt-box-shadow);
    transition: all 0.3s ease
}

.gt-recommend-item picture,
.gt-recommend-item img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease
}

.gt-recommend-item .gt-recommend-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 0.75rem 1rem;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
    color: #fff
}

.gt-recommend-item .gt-recommend-tag {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    font-size: 0.7rem;
    font-weight: 600;
    background: var(--gt-main-color);
    border-radius: 0.2rem;
    margin-bottom: 0.25rem
}

.gt-recommend-item h2 {
    font-size: 1.05rem;
    font-weight: 600;
    line-height: 1.4;
    margin: 0;
    color: #fff;
    box-sizing: border-box !important
}

.gt-recommend-bottom {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.75rem;
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}

.gt-recommend-card {
    position: relative;
    display: flex;
    flex-direction: column;
    border-radius: var(--gt-main-radius);
    overflow: hidden;
    background: var(--gt-card-bg);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease
}

.gt-recommend-card .gt-recommend-thumb {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
    aspect-ratio: 16 / 7;
    flex-shrink: 0
}

.gt-recommend-card .gt-recommend-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease
}

.gt-recommend-card .gt-recommend-views {
    position: absolute;
    top: 0.4rem;
    right: 0.4rem;
    padding: 0.15rem 0.5rem;
    font-size: 0.7rem;
    color: #fff;
    background: rgba(0, 0, 0, 0.55);
    border-radius: 0.25rem;
    backdrop-filter: blur(4px)
}

.gt-recommend-card h2 {
    font-size: 0.75rem;
    padding: 0.2rem 0.4rem;
    font-weight: 500;
    line-height: 1.2;
    margin: 0;
    color: var(--gt-font-color);
    transition: color 0.18s;
    height: max-content
}

.gt-recommend-card:hover h2 {
    color: var(--gt-main-color)
}

@media screen and (max-width:1024px) {
    .gt-recommend-top {
        height: 280px
    }

    .gt-recommend-bottom {
        grid-template-columns: repeat(2, 1fr)
    }

    .gt-recommend-card .gt-recommend-thumb {
        height: 100px
    }
}

@media screen and (max-width:768px) {
    .gt-recommend-section {
        margin-top: 0.5rem
    }

    .gt-recommend-top {
        grid-template-columns: 1fr;
        height: auto
    }

    .gt-recommend-main {
        height: 210px
    }

    .gt-recommend-main h2 {
        font-size: 1.1rem;
    }

    .gt-recommend-right {
        grid-template-rows: 1fr 1fr;
        height: auto; /* 移除固定高度，改为自适应 */
        gap: 0.75rem; /* 保持间距 */
    }

    .gt-recommend-right .gt-recommend-item {
        height: 130px; /* 设置单个小卡片固定高度 */
    }

    .gt-recommend-item h2 {
        font-size: 0.9rem;
    }

    /* 当只有一个推荐项时，高度与左侧大图匹配 */
    .gt-recommend-right:has(.gt-recommend-item:only-child) {
        grid-template-rows: 1fr;
    }

    /* 单卡片时高度设置 */
    .gt-recommend-right:has(.gt-recommend-item:only-child) .gt-recommend-item {
        height: 210px; /* 单卡片时与左侧大图高度一致 */
    }

    /* 当大图未填写，只填写右侧小图两个id时，两个卡片均为210px */
    .gt-recommend-top:not(:has(.gt-recommend-main)) .gt-recommend-right:not(:has(.gt-recommend-item:only-child)) .gt-recommend-item {
        height: 210px;
    }

    .gt-recommend-bottom {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.6rem
    }

    .gt-recommend-card .gt-recommend-thumb {
        height: 90px
    }

    .gt-recommend-card h2 {
        font-size: 0.8rem;
        padding: 0.5rem 0.6rem
    }
}

@media screen and (max-width:480px) {
    .gt-recommend-section {
        margin-top: 0.3rem
    }

    .gt-recommend-main {
        height: 170px
    }

    .gt-recommend-main h2 {
        font-size: 1rem;
    }

    .gt-recommend-right .gt-recommend-item {
        height: 110px; /* 小屏幕下单个小卡片高度 */
    }

    .gt-recommend-item h2 {
        font-size: 0.8rem;
    }

    /* 小屏幕下单卡片时与左侧大图高度一致 */
    .gt-recommend-right:has(.gt-recommend-item:only-child) .gt-recommend-item {
        height: 170px;
    }

    /* 当大图未填写，只填写右侧小图两个id时，两个卡片均为170px */
    .gt-recommend-top:not(:has(.gt-recommend-main)) .gt-recommend-right:not(:has(.gt-recommend-item:only-child)) .gt-recommend-item {
        height: 170px;
    }

    .gt-recommend-card .gt-recommend-thumb {
        height: 75px
    }

    .gt-recommend-card h2 {
        font-size: 0.65rem;
        padding: 0.4rem 0.5rem
    }
}

.article-actions {
    margin-top: 2rem;
    padding: 1.5rem;
    background: var(--gt-font-6);
    border-radius: var(--gt-main-radius);
    text-align: center
}

.article-actions .actions-title {
    margin: 0 0 1rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--gt-font-color)
}

.article-actions .actions-buttons {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap
}

.article-actions .action-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    border: none;
    border-radius: 2rem;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    background-color: var(--gt-card-bg);
    color: var(--gt-font-color);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08)
}

.article-actions .action-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15)
}

.article-actions .action-btn i {
    font-size: 1.125rem
}

.article-actions .reward-btn {
    background: #ff6b6b;
    color: #fff
}

.article-actions .reward-btn:hover {
    background: #ff5252
}

.article-actions .like-btn.liked {
    background: #ff6b6b;
    color: #fff
}

.article-actions .like-btn.liked i {
    animation: likeAnimation 0.5s ease
}

@keyframes likeAnimation {

    0%,
    100% {
        transform: scale(1)
    }

    50% {
        transform: scale(1.3)
    }
}

.article-actions .share-btn:hover {
    background: #3b82f6;
    color: #fff
}

.article-actions .collect-btn.collected {
    background: #f59e0b;
    color: #fff
}

.article-actions .collect-btn.collected i {
    animation: collectAnimation 0.5s ease
}

@keyframes collectAnimation {

    0%,
    100% {
        transform: scale(1) rotate(0deg)
    }

    50% {
        transform: scale(1.2) rotate(15deg)
    }
}

.reward-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.6);
    z-index: var(--z-auth-modal);
    justify-content: center;
    align-items: center;
    animation: fadeIn 0.3s ease
}

.reward-modal.active {
    display: flex
}

@keyframes fadeIn {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.reward-modal-content {
    position: relative;
    width: 90%;
    max-width: 360px;
    background: var(--gt-card-bg);
    border-radius: 1rem;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    overflow: hidden;
    animation: slideUp 0.3s ease
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(20px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.reward-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.25rem;
    background: #ff6b6b;
    color: #fff
}

.reward-modal-header h3 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5rem
}

.reward-modal-header h3 i {
    font-size: 1.25rem
}

.reward-close-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
    cursor: pointer;
    transition: all 0.2s ease
}

.reward-close-btn:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: rotate(90deg)
}

.reward-close-btn i {
    font-size: 1.25rem
}

.reward-modal-body {
    padding: 1.5rem
}

.reward-tabs {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 1.25rem
}

.reward-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    border: 2px solid var(--gt-font-16);
    border-radius: 2rem;
    background: transparent;
    color: var(--gt-font-66);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease
}

.reward-tab:hover {
    border-color: var(--gt-main-color);
    color: var(--gt-main-color)
}

.reward-tab.active {
    background: var(--gt-main-color);
    border-color: var(--gt-main-color);
    color: #fff
}

.reward-tab[data-tab="wechat"].active {
    background: #07c160;
    border-color: #07c160
}

.reward-tab[data-tab="alipay"].active {
    background: #1677ff;
    border-color: #1677ff
}

.reward-tab i {
    font-size: 1.125rem
}

.reward-qrcodes {
    display: flex;
    justify-content: center;
    margin-bottom: 1rem
}

.reward-qrcode {
    display: none;
    width: 200px;
    height: 200px;
    padding: 0.5rem;
    background: #f8f9fa;
    border-radius: 0.75rem;
    overflow: hidden
}

.reward-qrcode.active {
    display: block;
    animation: fadeIn 0.3s ease
}

.reward-qrcode img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 0.5rem
}

.reward-tip {
    margin: 0;
    text-align: center;
    font-size: 0.8125rem;
    color: var(--gt-font-56)
}

@media (max-width:768px) {
    .article-actions .actions-buttons {
        gap: 0.375rem;
        flex-wrap: nowrap;
        width: 100%
    }

    .article-actions .action-btn {
        padding: 0.4375rem 0.5rem;
        font-size: 0.75rem;
        gap: 0.25rem;
        flex: 1;
        min-width: 0;
        justify-content: center
    }

    .article-actions .action-btn i {
        font-size: 0.875rem
    }

    .article-actions {
        padding: 1rem 0.75rem
    }

    .reward-modal-content {
        max-width: 320px
    }

    .reward-qrcode {
        width: 180px;
        height: 180px
    }
}

.article-copyright {
    margin-top: 2rem;
    background: var(--gt-card-bg);
    border: 1px solid var(--gt-font-16);
    border-radius: var(--gt-main-radius);
    overflow: hidden;
    box-shadow: var(--gt-box-shadow)
}

.article-copyright .copyright-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 1.25rem;
    background: var(--gt-font-6);
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--gt-main-color);
    margin: 0;
    line-height: 1
}

.sky-h1 {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2
}

.sky-h2 {
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.3
}

.sky-h3 {
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.4
}

.sky-h4 {
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.5
}

.sky-h5 {
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.6
}

.sky-h6 {
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1.7
}

.text-truncate-2 {
    display: -webkit-box !important;
    display: box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important
}

.text-truncate-3 {
    display: -webkit-box !important;
    display: box !important;
    -webkit-line-clamp: 3 !important;
    line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important
}

@media screen and (max-width:1024px) {

    .sky-h1,
    .sky-h2 {
        font-size: calc(1rem + 2vw)
    }

    .sky-h3,
    .sky-h4 {
        font-size: calc(0.875rem + 1vw)
    }

    .sky-h5,
    .sky-h6 {
        font-size: 0.875rem
    }
}

@media screen and (max-width:768px) {
    .sky-h1 {
        font-size: 1.5rem
    }

    .sky-h2 {
        font-size: 1.25rem
    }

    .sky-h3 {
        font-size: 1.125rem
    }

    .sky-h4 {
        font-size: 1rem
    }
}

.article-copyright .copyright-header i {
    color: var(--gt-main-color);
    font-size: 1.125rem
}

.article-copyright .copyright-content {
    padding: 1rem 1.25rem;
    font-size: 0.875rem;
    line-height: 1.8;
    color: var(--gt-font-color)
}

.article-copyright .copyright-content p {
    margin: 0;
    padding: 0.25rem 0
}

.article-copyright .copyright-content a {
    color: var(--gt-main-color);
    text-decoration: none;
    word-break: break-all;
    transition: color 0.2s ease
}

.article-copyright .copyright-content a:hover {
    color: var(--gt-main-color-88)
}

.article-copyright .copyright-content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--gt-main-radius);
    margin: 0.5rem 0;
    border: 1px solid var(--gt-font-16)
}

.article-copyright .copyright-content strong {
    color: var(--gt-font-88)
}

@media (max-width:768px) {
    .article-copyright .copyright-content {
        font-size: 0.8125rem
    }
}

.gt-related-posts {
    margin-top: 2rem;
    background: var(--gt-card-bg);
    border: 1px solid var(--gt-font-16);
    border-radius: var(--gt-main-radius);
    overflow: hidden;
    box-shadow: var(--gt-box-shadow)
}

.gt-related-posts .gt-related-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 1.25rem;
    background: var(--gt-font-6);
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--gt-main-color);
    margin: 0;
    line-height: 1
}

.gt-related-posts .gt-related-header i {
    color: var(--gt-main-color);
    font-size: 1.125rem
}

.gt-related-posts .gt-related-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 200px;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}

.gt-related-posts .gt-related-card {
    display: flex;
    flex-direction: column;
    width: 200px;
    border-radius: var(--gt-main-radius);
    overflow: hidden;
    background: var(--gt-card-bg);
    box-shadow: var(--gt-box-shadow);
    transition: all 0.25s ease
}

.gt-related-posts .gt-related-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12)
}

.gt-related-posts .gt-related-card:hover img {
    transform: scale(1.05)
}

.gt-related-posts .gt-related-thumb {
    width: 100%;
    height: 110px;
    overflow: hidden
}

.gt-related-posts .gt-related-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease
}

.gt-related-posts .gt-related-title {
    padding: 0.6rem 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.4;
    color: var(--gt-font-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color 0.18s;
    box-sizing: border-box !important
}

.gt-related-posts .gt-related-card:hover .gt-related-title {
    color: var(--gt-main-color)
}

@media screen and (max-width:1024px) {
    .gt-related-posts .gt-related-grid {
        grid-auto-columns: 180px;
        padding: 0.875rem 1rem
    }

    .gt-related-posts .gt-related-card {
        width: 180px
    }

    .gt-related-posts .gt-related-thumb {
        height: 100px
    }
}

@media screen and (max-width:768px) {
    .gt-related-posts .gt-related-grid {
        grid-auto-columns: 160px;
        gap: 0.6rem;
        padding: 0.75rem
    }

    .gt-related-posts .gt-related-card {
        width: 160px
    }

    .gt-related-posts .gt-related-thumb {
        height: 90px
    }

    .gt-related-posts .gt-related-title {
        font-size: 0.875rem;
        padding: 0.5rem 0.6rem
    }
}

@media screen and (max-width:480px) {
    .gt-related-posts .gt-related-grid {
        grid-auto-columns: 140px
    }

    .gt-related-posts .gt-related-card {
        width: 140px
    }

    .gt-related-posts .gt-related-thumb {
        height: 75px
    }
}
/* Single Column Layout - Compact */
.article-list.single-column {
    display: flex !important;
    flex-direction: column;
    gap: 0.75rem;
}

.article-list.single-column .gt-article-item {
    display: grid !important;
    grid-template-columns: 260px 1fr;
    gap: 0.35rem 0.9rem;
    padding: 0.75rem;
    align-items: start;
    min-height: auto;
    height: auto;
}

.article-list.single-column .gt-article-content {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    justify-content: space-between;
}

.article-list.single-column .gt-article-banner {
    height: 160px;
    aspect-ratio: 16/10 !important;
    padding: 0;
    border-radius: var(--gt-main-radius);
    overflow: hidden;
}

.article-list.single-column .gt-article-banner img {
    object-position: center;
    transition: transform 0.6s ease;
    border-radius: 0;
}

.article-list.single-column .gt-article-content header {
    padding: 0;
    margin-top: 0.5rem;
    gap: 0.1rem;
    width: 100%;
    align-self: start;
}

.article-list.single-column .gt-article-content header .title {
    font-size: 1.05rem;
    line-height: 1.3;
    -webkit-line-clamp: 1;
    line-clamp: 1;
    margin: 0;
}

.article-list.single-column .gt-article-excerpt {
    padding: 0;
    margin: 0.6rem 0 0;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    height: auto;
    max-height: 100%;
    font-size: 0.8125rem;
    line-height: 1.45;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    word-break: break-word;
    align-self: start;
}

.article-list.single-column .gt-article-tags {
    margin-top: 0.5rem;
    padding: 0;
    gap: 0.1rem;
    margin-bottom: 0.25rem;
}

.article-list.single-column .gt-article-taglist {
    padding: 0;
    margin-top: 0.25rem;
    align-self: end;
}

/* 大屏幕下单列布局样式优化 */
.article-list.single-column .gt-article-item.active::before {
    left: 0;
    top: 0;
    transform: none;
    border-radius: 0 0 0.5rem 0;
    font-size: 0.8rem;
    padding: 0.2rem 0.8rem;
    box-shadow: 2px 2px 5px rgba(0,0,0,0.1);
}

.article-list.single-column .gt-article-item.active .gt-article-banner::before {
    display: none;
}

/* Mobile Responsive for Single Column */
@media screen and (max-width: 768px) {
    .article-list.single-column .gt-article-item {
        grid-template-columns: 140px 1fr;
        grid-template-rows: auto;
        height: 118px;
        gap: 0.4rem 0.75rem;
        padding: 0.6rem;
    }
    
    .article-list.single-column .gt-article-content header {
        padding: 0.1rem 0 0;
        margin-top: 0;
    }

    /* 手机端：单列布局只显示评论量，非单列布局隐藏点赞和评论数 */
    .article-list-main > section.article-list .gt-article-likes,
    .article-list-main > section.article-list:not(.single-column) .gt-article-comments {
        display: none !important;
    }
    
    .article-list.single-column .gt-article-content header .title {
        font-size: 0.88rem;
        margin: 0;
    }
    
    .article-list.single-column .gt-article-content header .title a {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        overflow: hidden;
        word-break: break-word;
        white-space: normal;
    }
    
    .article-list.single-column .gt-article-banner {
        height: 100%;
        aspect-ratio: unset !important;
    }

    .article-list.single-column .gt-article-excerpt {
        display: none;
    }

    .article-list.single-column .gt-article-taglist > time.sky-h6 {
        display: inline;
    }
}

@media screen and (max-width: 480px) {
    .article-list.single-column .gt-article-item {
        grid-template-columns: 120px 1fr;
        height: 108px;
        gap: 0.35rem 0.65rem;
        padding: 0.55rem;
    }
}

.gt-cms-section {
    margin-top: 1.5rem;
    width: 100%;
}

.gt-cms-title-h3 {
    font-size: 1.15rem !important;
    font-weight: 600;
    color: var(--gt-font-color);
    margin: 0 0 1rem !important;
    padding-left: 0.75rem;
    position: relative;
    display: inline-block;
}

.gt-cms-title-h3::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 1em;
    background-color: var(--gt-main-color);
    border-radius: 2px;
}

.gt-cms-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.gt-cms-card {
    background: var(--gt-card-bg);
    border-radius: var(--gt-main-radius);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    transition: all 0.3s ease;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.gt-cms-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
}

.gt-cms-header {
    display: flex;
    padding: 0.75rem;
    gap: 0.75rem;
}

.gt-cms-cover {
    position: relative;
    width: 140px;
    height: 100px;
    flex-shrink: 0;
    border-radius: var(--gt-main-radius);
    overflow: hidden;
}

.gt-cms-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.gt-cms-card:hover .gt-cms-cover img {
    transform: scale(1.05);
}

.gt-cms-views {
    position: absolute;
    top: 0.5rem;
    left: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.1rem;
    padding: 0.15rem 0.5rem;
    background: #ff6b6b;
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 1rem;
    box-shadow: 0 2px 6px rgba(238, 90, 36, 0.4);
}

.gt-cms-views i {
    font-size: 0.7rem;
}

.gt-cms-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.gt-cms-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.5rem;
}

.gt-cms-name {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--gt-font-color);
    transition: color 0.2s;
}

.gt-cms-name:hover {
    color: var(--gt-main-color);
}

.gt-cms-more {
    font-size: 0.85rem;
    color: var(--gt-main-color);
    transition: all 0.2s;
    white-space: nowrap;
}

.gt-cms-more:hover {
    color: var(--gt-main-color-88);
}

.gt-cms-desc {
    font-size: 0.85rem;
    color: var(--gt-font-66);
    margin: 0 0 0.5rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.gt-cms-count {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.75rem;
    color: var(--gt-font-56);
    line-height: 1;
}

.gt-cms-count i {
    font-size: 0.75rem;
    display: flex;
    align-items: center;
}

.gt-cms-body {
    padding: 0 0.75rem 0.75rem;
}

.gt-cms-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.gt-cms-list li {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0.5rem 0 !important;
    border-bottom: 1px dashed var(--gt-font-16);
    font-size: 0.875rem;
    transition: all 0.2s;
}

.gt-cms-list li:last-child {
    border-bottom: none;
}

.gt-cms-list li::before {
    content: '•';
    color: var(--gt-main-color);
    margin-right: 0.5rem;
    font-size: 0.8rem;
    flex-shrink: 0;
}

.gt-cms-list li a {
    flex: 1;
    color: var(--gt-font-color);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: color 0.2s;
}

.gt-cms-list li:hover a {
    color: var(--gt-main-color);
}

.gt-cms-date {
    font-size: 0.75rem;
    color: var(--gt-font-56);
    margin-left: 0.75rem;
    flex-shrink: 0;
    white-space: nowrap;
}

.gt-cms-empty {
    text-align: center;
    padding: 1.5rem;
    color: var(--gt-font-56);
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

/* 分类推荐文章列表阅读量 */
.gt-cms-post-views {
    display: inline-flex;
    align-items: center;
    gap: 0.1rem;
    vertical-align: middle;
    line-height: 1;
    font-size: 0.75rem;
    color: var(--gt-font-56);
}

.gt-cms-post-views i {
    font-size: 0.7rem;
}

/* Responsive - Tablet */
@media (max-width: 992px) {
    .gt-cms-grid {
        gap: 0.75rem;
    }
    .gt-cms-cover {
        width: 120px;
        height: 85px;
    }
    .gt-cms-name {
        font-size: 1rem;
    }
}

/* Responsive - Mobile */
@media (max-width: 768px) {
    .gt-cms-grid {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }
    .gt-cms-header {
        padding: 0.625rem;
    }
    .gt-cms-cover {
        width: 110px;
        height: 80px;
    }
    .gt-cms-name {
        font-size: 0.95rem;
    }
    .gt-cms-desc {
        font-size: 0.8rem;
    }
    .gt-cms-list li {
        font-size: 0.825rem;
        padding: 0.4rem 0 !important;
    }
}

/* Responsive - Small Mobile */
@media (max-width: 480px) {
    .gt-cms-section {
        margin-top: 1rem;
    }
    .gt-cms-title-h3 {
        font-size: 1rem !important;
        margin-bottom: 0.75rem !important;
    }
    .gt-cms-header {
        flex-direction: column;
        gap: 0.5rem;
    }
    .gt-cms-cover {
        width: 100%;
        height: 120px;
    }
    .gt-cms-views {
        top: 0.4rem;
        left: 0.4rem;
        padding: 0.1rem 0.4rem;
        font-size: 0.7rem;
    }
    .gt-cms-info {
        width: 100%;
    }
    .gt-cms-meta {
        margin-bottom: 0.35rem;
    }
    .gt-cms-body {
        padding: 0 0.625rem 0.625rem;
    }
    .gt-cms-list li {
        font-size: 0.8rem;
        padding: 0.35rem 0 !important;
    }
    .gt-cms-date {
        font-size: 0.7rem;
    }
}
/* Share Modal Styles */
#mirai-share-modal{display:none;position:fixed;inset:0;z-index:9999}
#mirai-share-modal.show{display:block}
#mirai-share-modal .share-mask{position:absolute;inset:0;background:rgba(0,0,0,.5)}
#mirai-share-modal .share-container{position:absolute;bottom:0;left:0;width:100%;background:var(--gt-card-bg);border-radius:16px 16px 0 0;padding:20px;transform:translateY(100%);transition:transform .3s ease;color:var(--gt-font-color)}
#mirai-share-modal.show .share-container{transform:translateY(0)}
#mirai-share-modal .share-title{text-align:center;margin-bottom:20px;font-weight:bold;font-size:16px;color:var(--gt-font-color)}
#mirai-share-modal .share-options{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;text-align:center}
#mirai-share-modal .share-item{cursor:pointer;font-size:12px;color:var(--gt-font-66);transition:opacity .2s}
#mirai-share-modal .share-item:hover{opacity:.8}
#mirai-share-modal .share-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;font-size:24px}
#mirai-share-modal .icon-qq{background:rgba(24,144,255,.15);color:#1890FF}
#mirai-share-modal .icon-wechat{background:rgba(7,193,96,.15);color:#07C160}
#mirai-share-modal .icon-weibo{background:rgba(224,47,41,.15);color:#E02F29}
#mirai-share-modal .icon-qzone{background:rgba(250,140,22,.15);color:#FA8C16}
#mirai-share-modal .icon-poster{background:rgba(114,46,209,.15);color:#722ED1}
#mirai-share-modal .icon-link{background:var(--gt-font-16);color:var(--gt-font-66)}
.share-close-btn{margin-top:20px;padding:10px;text-align:center;border-top:1px solid var(--gt-border-color);cursor:pointer;color:var(--gt-font-66);transition:color .2s}
.share-close-btn:hover{color:var(--gt-main-color)}

/* Poster Modal */
#mirai-poster-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .3s}
#mirai-poster-modal.show{pointer-events:auto;opacity:1}
#mirai-poster-modal .poster-mask{position:absolute;inset:0;background:rgba(0,0,0,.8);pointer-events:auto}
#mirai-poster-modal .poster-content{position:relative;z-index:1;max-width:90%;max-height:90%;pointer-events:auto;display:flex;flex-direction:column;align-items:center}
#mirai-generated-poster{max-width:100%;max-height:80vh;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.3)}
#mirai-poster-modal .poster-tip{text-align:center;margin-top:10px;color:#fff;background:rgba(0,0,0,.5);padding:5px 15px;border-radius:20px;font-size:12px}
#mirai-poster-modal .poster-close{color:#fff;cursor:pointer;padding:10px;margin-top:15px;opacity:.8;transition:opacity .2s;display:flex;align-items:center;justify-content:center}
#mirai-poster-modal .poster-close:hover{opacity:1}

/* WeChat Modal */
#mirai-wechat-modal{display:none;position:fixed;inset:0;z-index:10000;align-items:center;justify-content:center}
#mirai-wechat-modal.show{display:flex}
#mirai-wechat-modal .wechat-mask{position:absolute;inset:0;background:rgba(0,0,0,.8)}
#mirai-wechat-modal .wechat-content{position:relative;background:var(--gt-card-bg);padding:30px;border-radius:12px;text-align:center;max-width:300px;box-shadow:var(--gt-box-shadow)}
#mirai-wechat-modal .wechat-title{font-size:16px;font-weight:bold;margin-bottom:20px;color:var(--gt-font-color)}
#mirai-wechat-modal .wechat-qr{width:200px;height:200px;margin:0 auto;background:var(--gt-white-color);padding:10px;border-radius:4px}
#mirai-wechat-modal .wechat-desc{margin-top:15px;color:var(--gt-font-66);font-size:12px;line-height:1.5}
#mirai-wechat-modal .wechat-close{position:absolute;top:10px;right:10px;cursor:pointer;color:var(--gt-font-66);transition:color .2s}
#mirai-wechat-modal .wechat-close:hover{color:var(--gt-main-color)}

/* 验证码输入框及发送按钮样式 */
.gt-auth-code {
    display: flex !important;
    gap: 0.75rem;
    align-items: stretch;
}

.gt-auth-code input {
    flex: 1;
    width: 0 !important; /* 覆盖 width: 100% 以便 flex 生效 */
    min-width: 0;
}

.gt-btn-send {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 1rem;
    border: none;
    background: var(--gt-main-color);
    color: #fff;
    border-radius: 0.5rem;
    cursor: pointer;
    font-size: 0.875rem;
    white-space: nowrap;
    transition: all 0.2s;
    flex-shrink: 0;
}

.gt-btn-send:hover {
    background: var(--gt-main-color-88);
}

.gt-btn-send:disabled {
    background: var(--gt-font-16);
    color: var(--gt-font-56);
    cursor: not-allowed;
    opacity: 0.8;
}

.gt-post-navigation {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 2rem;
}

.gt-post-navigation a {
    display: flex;
    flex-direction: column;
    padding: 1rem 1.25rem;
    background: var(--gt-card-bg);
    border: 1px solid var(--gt-font-16);
    border-radius: var(--gt-main-radius);
    text-decoration: none;
    box-shadow: var(--gt-box-shadow);
    transition: all 0.25s ease;
}

.gt-post-navigation a:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
    border-color: var(--gt-main-color-28);
}

.gt-post-navigation .gt-nav-label {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.8125rem;
    color: var(--gt-font-56);
    margin-bottom: 0.375rem;
}

.gt-post-navigation a:hover .gt-nav-label {
    color: var(--gt-main-color);
}

.gt-post-navigation .gt-nav-title {
    font-size: 0.9375rem;
    font-weight: 500;
    line-height: 1.4;
    color: var(--gt-font-color);
    transition: color 0.18s;
}

.gt-post-navigation a:hover .gt-nav-title {
    color: var(--gt-main-color);
}

.gt-nav-prev {
    align-items: flex-start;
}

.gt-nav-next {
    align-items: flex-end;
    text-align: right;
}

.gt-nav-empty {
    visibility: hidden;
}

@media screen and (max-width: 768px) {
    .gt-post-navigation {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }
}

/* 移动端底部导航 */
.gt-mobile-bottom-tab {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: var(--gt-card-bg);
    box-shadow: var(--gt-footer-shadow);
    border-top: 1px solid var(--gt-border-color);
    padding-bottom: env(safe-area-inset-bottom, 0);
    transition: transform 0.3s ease-in-out;
    transform: translateY(0)
}

body.header-hidden .gt-mobile-bottom-tab {
    transform: translateY(100%)
}

.gt-mobile-bottom-tab-inner {
    display: flex;
    justify-content: space-around;
    align-items: center;
    height: 64px;
    max-width: 600px;
    margin: 0 auto;
}

.gt-mobile-bottom-tab-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    height: 100%;
    color: var(--gt-font-color);
}

.gt-mobile-bottom-tab-item i {
    font-size: 1.5rem;
    margin-bottom: 4px;
}

.gt-mobile-bottom-tab-item span {
    font-size: 0.8rem;
    font-weight: 600;
}

.gt-mobile-bottom-tab-item.active,
.gt-mobile-bottom-tab-item:hover {
    color: var(--gt-main-color);
}

.gt-mobile-bottom-tab-item.active i {
    transform: translateY(-2px);
}

@media screen and (max-width: 768px) {
    .gt-mobile-bottom-tab {
        display: block;
    }

    .gt-back-top {
        bottom: 80px;
    }

    /* 友链页面移动端返回顶部按钮样式 - 与申请友链按钮完全对齐 */
    body.page-template-links .gt-back-top {
        right: 0.75rem;
        bottom: 3.5rem;
    }

    body.page-template-links .gt-back-top button {
        width: 36px;
        height: 36px;
    }

    body {
        padding-bottom: 64px;
    }

    .gt-footer {
        margin-bottom: 64px;
    }
}

@media screen and (max-width: 480px) {
    .gt-mobile-bottom-tab-inner {
        height: 58px;
    }

    .gt-mobile-bottom-tab-item i {
        font-size: 1.4rem;
    }

    .gt-mobile-bottom-tab-item span {
        font-size: 0.75rem;
    }

    body {
        padding-bottom: 58px;
    }

    .gt-footer {
        margin-bottom: 58px;
    }

    .gt-back-top {
        bottom: 74px;
    }
}

@supports (padding-bottom: env(safe-area-inset-bottom)) {
    @media screen and (max-width: 768px) {
        .gt-mobile-bottom-tab {
            padding-bottom: env(safe-area-inset-bottom);
        }

        body {
            padding-bottom: calc(64px + env(safe-area-inset-bottom));
        }

        .gt-back-top {
            bottom: calc(80px + env(safe-area-inset-bottom));
        }
    }

    @media screen and (max-width: 480px) {
        body {
            padding-bottom: calc(58px + env(safe-area-inset-bottom));
        }

        .gt-back-top {
            bottom: calc(74px + env(safe-area-inset-bottom));
        }
    }
}

.gt-home-links-section{margin-top:1.5rem;width:100%}
.gt-home-links-wrapper{background:var(--gt-card-bg);border-radius:var(--gt-main-radius);box-shadow:var(--gt-box-shadow);padding:1.25rem 1.5rem}
.gt-home-links-list{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;align-items:center}
.gt-home-link-item{display:inline-flex;align-items:center;padding:.375rem 0;color:var(--gt-font-color);text-decoration:none;font-size:.9375rem;transition:color .2s;position:relative}
.gt-home-link-item:hover{color:var(--gt-main-color)}
.gt-home-link-item:not(:last-child)::after{content:'';position:absolute;right:-.625rem;top:50%;transform:translateY(-50%);width:1px;height:.875rem;background:var(--gt-font-16)}
.gt-home-link-more{color:var(--gt-main-color);font-weight:500}
.gt-home-link-more:hover{color:var(--gt-main-color-88)}
@media(max-width:768px){.gt-home-links-section{margin-top:1rem}.gt-home-links-wrapper{padding:1rem 1.25rem}.gt-home-links-list{gap:.375rem 1rem}.gt-home-link-item{font-size:.875rem}}
@media(max-width:480px){.gt-home-links-wrapper{padding:.875rem 1rem}.gt-home-links-list{gap:.25rem .875rem}.gt-home-link-item{font-size:.85rem;padding:.25rem 0}.gt-home-link-item:not(:last-child)::after{right:-.4375rem;height:.75rem}}
