:root{--bg-primary:#fff;--bg-secondary:#fafafa;--bg-tertiary:#f5f5f5;--text-primary:#333;--text-secondary:#666;--text-tertiary:#999;--border-color:#e0e0e0;--border-hover:#d0d0d0;--shadow-light:rgba(0,0,0,.1);--shadow-medium:rgba(0,0,0,.15);--accent-color:#007acc;--accent-hover:#005a9e;--error-color:#dc3545;--success-color:#28a745;--warning-color:#ffc107;--code-bg:#f8f9fa;--code-border:#e9ecef;--link-color:#007acc;--link-hover:#005a9e;--code-comment:#6a737d;--code-punctuation:#24292e;--code-property:#005cc5;--code-string:#032f62;--code-operator:#24292e;--code-keyword:#d73a49;--code-function:#6f42c1;--code-variable:#e36209}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--bg-tertiary:#3a3a3a;--text-primary:#fff;--text-secondary:#ccc;--text-tertiary:#999;--border-color:#404040;--border-hover:#505050;--shadow-light:rgba(0,0,0,.3);--shadow-medium:rgba(0,0,0,.4);--accent-color:#4dabf7;--accent-hover:#74c0fc;--error-color:#ff6b6b;--success-color:#51cf66;--warning-color:#ffd43b;--code-bg:#2d2d2d;--code-border:#404040;--link-color:#4dabf7;--link-hover:#74c0fc;--code-comment:#57a64a;--code-punctuation:#fff;--code-property:#4ec9b0;--code-string:#d69d85;--code-operator:#fff;--code-keyword:#c586c0;--code-function:#dcdcaa;--code-variable:#4fc1ff}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.theme-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:all .2s ease;position:relative;z-index:1001;pointer-events:auto}.theme-toggle:hover{color:var(--text-primary);background:var(--bg-tertiary);transform:translateY(-1px)}.theme-toggle svg{width:18px;height:18px;transition:transform .3s ease}.theme-toggle:hover svg{transform:rotate(15deg)}.theme-dropdown{position:relative;display:inline-block;z-index:1000}.theme-dropdown-content{position:absolute;top:100%;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-medium);padding:8px 0;min-width:120px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease}.theme-dropdown.active .theme-dropdown-content{opacity:1;visibility:visible;transform:translateY(0)}.theme-option{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-size:.9rem}.theme-option.active,.theme-option:hover{background:var(--bg-tertiary);color:var(--text-primary)}.theme-option.active{font-weight:600}.theme-option svg{width:16px;height:16px}*{box-sizing:border-box;padding:0;margin:0;-webkit-tap-highlight-color:transparent;tap-highlight-color:transparent}#__next,body,html{max-width:100vw;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}a{color:inherit;text-decoration:none}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:1.1rem}.error-message{background:var(--error-color);color:var(--bg-primary);padding:12px;border-radius:6px;font-size:.9rem;text-align:center}@media (max-width:768px){body,html{font-size:14px}}.site-header{display:flex;flex-direction:column;align-items:center;padding:64px 0 32px;background:none;box-shadow:none}.site-title{font-size:2.8rem;font-weight:700;color:var(--text-primary);margin-bottom:18px;letter-spacing:.01em;font-family:Inter,Helvetica Neue,Arial,sans-serif}.site-subtitle{font-size:1.15rem;color:var(--text-secondary);margin-bottom:32px;font-weight:400;letter-spacing:.01em}.main-header{width:100%;padding:24px 0 0;background:none}.header-content{max-width:800px;margin:0 auto;padding:0 24px;justify-content:space-between}.avatar-section,.header-content{display:flex;align-items:center}.avatar-link{display:block;text-decoration:none;transition:transform .2s ease}.avatar-link:hover{transform:scale(1.05)}.avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid var(--border-color);transition:border-color .2s}.avatar:hover{border-color:var(--border-hover)}.avatar-image{width:100%;height:100%;object-fit:cover}.main-header nav{display:flex;gap:48px}.nav-link{color:var(--text-secondary);font-size:.95rem;font-weight:400;text-decoration:none;padding:8px 0;position:relative;transition:color .2s;letter-spacing:.02em}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--text-primary);transition:width .3s ease}.nav-link:hover{color:var(--text-primary)}.nav-link:hover:after{width:100%}.social-links{gap:16px}.social-link,.social-links{display:flex;align-items:center}.social-link{justify-content:center;width:32px;height:32px;color:var(--text-secondary);border-radius:6px;transition:all .2s ease;position:relative}.social-link:hover{color:var(--text-primary);background:var(--bg-tertiary);transform:translateY(-1px)}.social-link svg{width:18px;height:18px}@media (max-width:768px){.header-content{padding:0 16px}.main-header nav{gap:24px}.nav-link{font-size:1rem}.site-title{font-size:2.8rem}.site-subtitle{font-size:1.15rem}.social-links{gap:12px}.social-link{width:32px;height:32px}.social-link svg{width:18px;height:18px}}.home-hero{text-align:center;max-width:800px;margin:64px auto 48px;padding-left:0}.home-title{font-size:2.8rem;font-weight:700;color:var(--text-primary);margin-bottom:18px;letter-spacing:.01em;font-family:Inter,Helvetica Neue,Arial,sans-serif}.home-subtitle{font-size:1.15rem;color:var(--text-secondary);margin-bottom:0;font-weight:400;letter-spacing:.01em}.home-container{max-width:800px;margin:0 auto;padding:0 24px}.articles-list{margin-top:48px}.home-header{margin-bottom:48px}.article-item{background:var(--bg-primary);border-radius:12px;padding:32px;margin-bottom:24px;box-shadow:0 2px 8px var(--shadow-light);transition:all .3s ease;border:1px solid var(--border-color)}.article-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow-medium);border-color:var(--border-hover)}.article-item-title{font-size:1.6rem;font-weight:600;margin-bottom:12px;line-height:1.4;transition:color .2s}.article-item-title,.article-item:hover .article-item-title{color:var(--text-primary)}.article-item-excerpt{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:16px}.article-item-meta{display:flex;align-items:center;gap:16px;color:var(--text-tertiary);font-size:.85rem;margin-bottom:16px}.article-item-meta span{display:flex;align-items:center;gap:4px}.article-item-meta .icon{width:14px;height:14px;opacity:.6}.article-item-tags{margin-top:0}.article-item-tags .tag{display:inline-flex;align-items:center;font-size:.75rem;transition:all .3s ease;letter-spacing:.02em;position:relative;overflow:hidden;box-shadow:0 1px 3px var(--shadow-light)}.article-item-tags .tag:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.4),transparent);transition:left .5s ease}.article-item-tags .tag:hover{border-color:var(--border-hover);box-shadow:0 2px 6px var(--shadow-medium)}.article-item-tags .tag:hover:before{left:100%}@media (max-width:768px){.home-container{padding:20px 16px}.home-title{font-size:2.8rem}.home-subtitle{font-size:1.15rem}.article-item{padding:24px;margin-bottom:20px}.article-item-title{font-size:1.6rem;line-height:1.4;margin-bottom:12px}.article-item-excerpt{font-size:1rem;line-height:1.6;margin-bottom:16px}.article-item-meta{flex-direction:row;flex-wrap:wrap;gap:12px;font-size:.9rem}.article-item-tags{gap:8px;margin-top:16px}.article-item-tags .tag{padding:4px 12px;font-size:.8rem;border-radius:16px}}.article-container{max-width:800px;margin:0 auto;padding:0 24px}.article-title{font-size:2.2rem;font-weight:700;color:var(--text-primary);margin:48px 0 32px;line-height:1.3;letter-spacing:-.02em}.article-meta{display:flex;align-items:center;flex-wrap:wrap;gap:24px;margin-bottom:48px;padding-bottom:32px;color:var(--text-secondary);font-size:.9rem}.article-meta span{display:flex;align-items:center;gap:6px}.article-meta .icon{width:16px;height:16px;opacity:.7}.article-content{margin-bottom:64px;line-height:1.7;color:var(--text-primary)}.article-content h1,.article-content h2,.article-content h3,.article-content h4,.article-content h5,.article-content h6{margin:2.5rem 0 1rem;color:var(--text-primary);font-weight:600;line-height:1.4}.article-content h1{font-size:1.8rem}.article-content h2{font-size:1.6rem}.article-content h3{font-size:1.4rem}.article-content h4{font-size:1.2rem}.article-content h5{font-size:1.1rem}.article-content h6{font-size:1rem}.article-content p{margin:1.2rem 0;line-height:1.7}.article-content ol,.article-content ul{margin:1.2rem 0;padding-left:1.5rem}.article-content li{margin:.5rem 0;line-height:1.6}.article-content blockquote{margin:1.5rem 0!important;padding:1rem 1.5rem!important;border-left:4px solid var(--text-secondary)!important;background:var(--code-bg)!important;font-style:italic!important;color:var(--text-secondary)!important}.article-content blockquote p{margin:0}.article-content img{max-width:100%;height:auto;border-radius:8px;margin:1.5rem 0;box-shadow:0 2px 8px var(--shadow-light)}.article-content pre{background:var(--code-bg)!important;border:1px solid var(--code-border)!important;border-radius:8px!important;padding:20px!important;margin:2rem 0!important;overflow-x:auto!important;font-size:.9rem!important;line-height:1.6!important;box-shadow:0 4px 12px var(--shadow-medium)!important}.article-content code{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.85rem;line-height:1.5;color:var(--text-primary)!important}.article-content pre code{background:none;padding:0;border-radius:0}.table-wrapper{overflow-x:auto;margin:1.5rem 0;border-radius:8px;box-shadow:0 2px 8px var(--shadow-light);background:var(--bg-primary)}[data-theme=dark] .article-content table{background-color:#1a1a1a!important;border-color:#404040!important}[data-theme=dark] .article-content table td,[data-theme=dark] .article-content table th{border-color:#404040!important}[data-theme=dark] .article-content table th{background-color:#3a3a3a!important;color:#fff!important}[data-theme=dark] .article-content table td{color:#fff!important}[data-theme=dark] .article-content table tr:nth-child(2n){background-color:#2d2d2d!important}[data-theme=dark] .article-content table tr:nth-child(odd){background-color:#1a1a1a!important}[data-theme=dark] .article-content table tr:hover{background-color:#3a3a3a!important}.article-content table{width:100%;border-collapse:collapse;background:var(--bg-primary);font-size:.9rem;color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.article-content table td,.article-content table th{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color);color:var(--text-primary)!important}.article-content table th{background:var(--bg-tertiary)!important;font-weight:600;color:var(--text-primary)!important}.article-content table tr:nth-child(2n){background:var(--bg-secondary)!important}.article-content table tr:nth-child(odd){background:var(--bg-primary)!important}.article-content table tr:hover{background:var(--bg-tertiary)!important;transition:background-color .2s ease}.article-content table tr:last-child td{border-bottom:none}.article-content a{color:var(--text-primary);text-decoration:none!important;border-bottom:1px solid transparent;transition:border-color .2s}.article-content a:hover{border-bottom-color:var(--text-secondary)}.article-content a:active,.article-content a:hover,.article-content a:visited{text-decoration:none!important}.article-content strong{font-weight:600;color:var(--text-primary)}.article-content em{font-style:italic}.copyright{margin-top:80px;margin-bottom:10px;text-align:center}.copyright p{color:var(--text-tertiary);font-size:.85rem;font-weight:400;margin:0;letter-spacing:.02em}.table-of-contents{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:24px;margin:32px 0;position:relative}.toc-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.toc-list{list-style:none;padding:0;margin:0}.toc-item{cursor:pointer;transition:all .2s ease;border-radius:4px;padding:6px 0 6px 8px;margin-left:-8px;color:var(--text-secondary);font-size:.9rem;line-height:1.4}.toc-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.toc-level-1{font-weight:600;color:var(--text-primary)}.toc-level-2{padding-left:16px}.toc-level-3{padding-left:24px;font-size:.85rem}.toc-level-4{padding-left:32px;font-size:.85rem}.toc-level-5{padding-left:40px;font-size:.8rem}.toc-level-6{padding-left:48px;font-size:.8rem}.article-item-tags{display:flex;flex-wrap:wrap;gap:8px;margin:32px 0}.article-item-tags .tag{display:inline-block;padding:4px 12px;background:var(--code-bg);color:var(--text-secondary);text-decoration:none;border-radius:16px;font-size:.85rem;font-weight:500;transition:all .2s ease;border:1px solid var(--code-border)}.article-item-tags .tag:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 2px 4px var(--shadow-light)}.article-content .prism-code{background:var(--code-bg)!important;padding:20px!important;border-radius:8px!important;overflow-x:auto!important;margin:2rem 0!important;border:1px solid var(--code-border)!important;font-size:.9rem!important;line-height:1.6!important;box-shadow:0 4px 12px var(--shadow-medium)!important}code[class*=language-],pre[class*=language-]{font-size:.9rem!important;line-height:1.6!important;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace!important}.token.cdata,.token.comment,.token.doctype,.token.prolog{color:var(--code-comment)!important;font-style:italic!important}.token.punctuation{color:var(--code-punctuation)!important}.token.boolean,.token.constant,.token.deleted,.token.number,.token.property,.token.symbol,.token.tag{color:var(--code-property)!important}.token.attr-name,.token.builtin,.token.char,.token.inserted,.token.selector,.token.string{color:var(--code-string)!important}.language-css .token.string,.style .token.string,.token.entity,.token.operator,.token.url{color:var(--code-operator)!important}.token.atrule,.token.attr-value,.token.keyword{color:var(--code-keyword)!important}.token.class-name,.token.function{color:var(--code-function)!important}.token.important,.token.regex,.token.variable{color:var(--code-variable)!important}.token.bold,.token.important{font-weight:700!important}.token.italic{font-style:italic!important}.token.entity{cursor:help!important}.article-content code,.article-content p code{background:var(--code-bg)!important;color:var(--text-primary)!important;padding:3px 8px!important;border-radius:4px!important;font-size:.9em!important;font-weight:500!important;border:1px solid var(--code-border)!important}.code-block-header{background:var(--bg-tertiary);color:var(--text-secondary);padding:8px 20px;border-radius:8px 8px 0 0;font-size:.85rem;font-weight:500;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px}.code-block-header .language-label{background:var(--text-secondary);color:var(--bg-primary);padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.code-block-wrapper{margin:2rem 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px var(--shadow-medium)}.code-block-wrapper pre{margin:0!important;border-radius:0 0 8px 8px!important}.about-page{max-width:800px;margin:0 auto;padding:20px}.about-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:0;border-bottom:none}.about-header h1{font-size:2.5rem;color:var(--text-primary);margin:0}.back-btn{background:#6c757d;color:#fff;text-decoration:none;display:inline-block}.back-btn:hover{background:#545b62}.about-content{line-height:1.8;color:var(--text-primary);font-size:16px}.about-content h1,.about-content h2,.about-content h3,.about-content h4,.about-content h5,.about-content h6{margin:30px 0 15px;color:var(--text-primary);font-weight:600}.about-content h1{font-size:2rem;border-bottom:2px solid var(--border-color);padding-bottom:10px}.about-content h2{font-size:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:8px}.about-content h3{font-size:1.3rem}.about-content p{margin:0 0 20px}.about-content ol,.about-content ul{margin:0 0 20px 20px}.about-content li{margin:5px 0}.about-content blockquote{margin:20px 0;padding:15px 20px;background:var(--code-bg);border-left:4px solid var(--text-primary);font-style:italic;color:var(--text-secondary)}.about-content a{color:var(--text-primary);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}.about-content a:hover{border-bottom-color:var(--text-primary)}.about-content img{max-width:100%;height:auto;border-radius:8px;margin:20px 0}.about-content pre{background:var(--code-bg);padding:20px;border-radius:8px;overflow-x:auto;margin:20px 0;border:1px solid var(--code-border)}.about-content code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em;color:var(--text-primary)}.about-content pre code{background:none;padding:0;color:inherit;font-size:14px;line-height:1.5}.loading{text-align:center;padding:40px;color:var(--text-secondary);font-size:16px}@media (max-width:768px){.article-container{padding:0 24px;max-width:100%}.article-title{font-size:2.2rem;margin:32px 0 24px;line-height:1.3}.article-meta{gap:16px;font-size:.9rem;margin-bottom:32px;padding-bottom:24px}.article-content{font-size:16px;line-height:1.7;margin-bottom:48px}.article-content h1{font-size:1.8rem}.article-content h2{font-size:1.6rem}.article-content h3{font-size:1.4rem}.article-content h4{font-size:1.2rem}.article-content h5{font-size:1.1rem}.article-content h6{font-size:1rem}.article-content p{margin:1.2rem 0;line-height:1.7}.article-content ol,.article-content ul{margin:1.2rem 0;padding-left:1.5rem}.article-content li{margin:.5rem 0;line-height:1.6}.article-content blockquote{margin:1.5rem 0;padding:1rem 1.2rem;font-size:.95rem}.table-wrapper{margin:1.5rem 0}.article-content table{font-size:.9rem}.article-content td,.article-content th{padding:12px 16px;color:var(--text-primary)!important}[data-theme=dark] .article-content table{background-color:#1a1a1a!important;border-color:#404040!important}[data-theme=dark] .article-content table th{background-color:#3a3a3a!important;color:#fff!important}[data-theme=dark] .article-content table td{color:#fff!important}[data-theme=dark] .article-content table tr:nth-child(2n){background-color:#2d2d2d!important}[data-theme=dark] .article-content table tr:nth-child(odd){background-color:#1a1a1a!important}[data-theme=dark] .article-content table tr:hover{background-color:#3a3a3a!important}.table-of-contents{padding:24px;margin:32px 0}.toc-title{font-size:1.1rem;margin-bottom:16px}.toc-item{font-size:.9rem;line-height:1.4;padding:6px 0 6px 8px;margin-left:-8px}.toc-level-1{font-weight:600;color:var(--text-primary)}.toc-level-2{padding-left:16px}.toc-level-3{padding-left:24px;font-size:.85rem}.toc-level-4{padding-left:32px;font-size:.85rem}.toc-level-5{padding-left:40px;font-size:.8rem}.toc-level-6{padding-left:48px;font-size:.8rem}.toc-item{word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;max-width:100%}.toc-item,.toc-list{box-sizing:border-box}.toc-list{width:100%}.toc-list .toc-list{margin-left:0;padding-left:0}.table-of-contents{max-width:100%;box-sizing:border-box;overflow:hidden}.copyright{margin-top:60px;margin-bottom:20px}.copyright p{font-size:.85rem}.about-page{padding:15px}.about-header{flex-direction:column;gap:15px;align-items:stretch}.about-header h1{font-size:2rem}.back-btn{align-self:flex-start}.about-content{font-size:15px}.about-content h1{font-size:1.8rem}.about-content h2{font-size:1.4rem}.about-content h3{font-size:1.2rem}}.article-content li code,.article-content p code,.article-content td code,.article-content th code{background:var(--code-bg)!important;color:var(--text-primary)!important;padding:3px 8px!important;border-radius:4px!important;font-size:.9em!important;font-weight:500!important;border:1px solid var(--code-border)!important}.article-content pre code{background:none!important;color:var(--text-primary)!important;padding:0!important;border-radius:0!important;font-size:.9rem!important;font-weight:400!important;border:none!important}[data-theme=dark] .article-content :is(hr),[data-theme=dark] .article-content hr{border:none!important;border-top:1.5px solid #444!important;background:none!important;height:0!important;margin:2.5rem 0!important}[data-theme=dark] .article-content h1{border-bottom:2px solid #444!important}[data-theme=dark] .article-content h2{border-bottom:1px solid #444!important}.article-content pre::-webkit-scrollbar{height:8px;background:transparent}.article-content pre::-webkit-scrollbar-thumb{background:#d0d0d0;border-radius:4px}[data-theme=dark] .article-content pre::-webkit-scrollbar-thumb{background:#444}.article-content pre::-webkit-scrollbar-thumb:hover{background:#b0b0b0}[data-theme=dark] .article-content pre::-webkit-scrollbar-thumb:hover{background:#666}.tags-container{max-width:800px;margin:0 auto;padding:0 24px}.tags-title{font-size:2.2rem;font-weight:600;color:var(--text-primary);margin:48px 0 32px;text-align:center;letter-spacing:-.02em}.tags-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.tags-list .tag{display:inline-flex;align-items:center;padding:8px 16px;background:var(--code-bg);color:var(--text-secondary);font-size:.9rem;border-radius:20px;text-decoration:none;transition:all .3s ease;border:1px solid var(--code-border);font-weight:500;letter-spacing:.02em;position:relative;overflow:hidden;box-shadow:0 2px 6px var(--shadow-light)}.tags-list .tag:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.4),transparent);transition:left .5s ease}.tags-list .tag:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-medium)}.tags-list .tag:hover:before{left:100%}.tag-count{margin-left:6px;background:var(--shadow-light);color:var(--text-secondary);padding:2px 6px;border-radius:8px;font-size:.75rem;font-weight:600}.back-link{color:var(--text-tertiary);font-size:.9rem;text-decoration:none;transition:color .2s ease;font-weight:400;background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.back-link:hover{color:var(--text-secondary)}.tags-list-wrapper{max-width:700px;margin:0 auto;background:var(--bg-primary);border-radius:10px;box-shadow:0 2px 16px var(--shadow-light);padding:32px 24px;display:flex;flex-wrap:wrap;gap:16px;justify-content:flex-start}.loading-indicator{display:flex;justify-content:center;align-items:center;padding:40px 0;min-height:120px}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-secondary)}.spinner{width:32px;height:32px;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-top-color:var(--text-secondary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.no-more{display:flex;justify-content:center;align-items:center;padding:20px;color:var(--text-tertiary);font-size:.9rem;font-weight:300;font-style:italic}@media (max-width:768px){.tags-container{padding:0 16px}.tags-title{font-size:1.8rem;margin:32px 0 24px}.tags-list{gap:8px}.back-link,.tags-list .tag{padding:6px 12px;font-size:.85rem}}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}.login-container{background:var(--bg-secondary);padding:40px;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.1);width:100%;max-width:400px;border:1px solid #e0e0e0}.login-container h1{text-align:center;margin-bottom:30px;color:var(--text-primary);font-size:1.8rem}.login-form{gap:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#555;font-size:.9rem}.form-input{border-radius:8px;font-size:1rem}.form-input:focus{border-color:#333}.login-button{background:#333;color:#fff;border:none;padding:14px;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.login-button:hover:not(:disabled){background:#555}.login-button:disabled{opacity:.7;cursor:not-allowed}.admin-dashboard{max-width:1200px;margin:0 auto;padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.dashboard-header h1{font-size:2rem;color:var(--text-primary);margin:0}.header-actions{display:flex;gap:12px}.new-article-btn{color:#fff;padding:10px 20px;border-radius:6px;text-decoration:none;font-weight:500;transition:background-color .2s}.new-article-btn,.new-article-btn:hover{background:var(--success-color)}.config-btn{background:var(--accent-color);color:#fff;padding:10px 20px;border-radius:6px;text-decoration:none;font-weight:500;transition:background-color .2s}.config-btn:hover{background:var(--accent-hover)}.logout-btn{color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.logout-btn,.logout-btn:hover{background:var(--error-color)}.articles-table-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);min-width:1200px;-webkit-overflow-scrolling:touch}.articles-table{width:100%;border-collapse:collapse;background:var(--bg-secondary);font-size:15px;font-weight:400;line-height:1.4;table-layout:fixed;min-width:1200px;color:var(--text-primary)}.articles-table th{background:var(--bg-tertiary);padding:14px 10px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap;font-size:14px;overflow:hidden;text-overflow:ellipsis}.articles-table th.sortable{cursor:pointer;transition:background-color .2s}.articles-table th.sortable:hover{background:var(--bg-tertiary)}.articles-table td{padding:14px 10px;border-bottom:1px solid var(--border-color);vertical-align:top;word-wrap:break-word;font-weight:400;font-size:14px;overflow:hidden;text-overflow:ellipsis;background:var(--bg-secondary);color:var(--text-primary)}.articles-table tbody tr:hover{background:var(--bg-tertiary)}.resize-handle{position:absolute;right:0;top:0;bottom:0;width:4px;background:transparent;cursor:col-resize;transition:background-color .2s}.resize-handle:hover{background:#007bff}.title-cell{font-weight:500;color:var(--text-primary)}.title-cell,.url-cell{max-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.url-cell{font-family:Courier New,monospace;font-size:12px;color:#666}.top-cell{text-align:center}.top-status{padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.top-status.top{background:#fff3cd;color:#856404}.top-status.normal{background:var(--bg-tertiary);color:#6c757d}.visible-cell{text-align:center}.status{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.status.published{background:#d4edda;color:#155724}.status.draft{background:#f8d7da;color:#721c24}.views-cell,.words-cell{text-align:center}.created-at-cell,.updated-at-cell,.views-cell,.words-cell{font-family:Courier New,monospace;color:#666;font-weight:500}.created-at-cell,.updated-at-cell{font-size:12px;white-space:nowrap}.actions-cell{text-align:center;min-width:120px}.actions{display:flex;gap:6px;justify-content:center;flex-wrap:nowrap}.actions .delete-btn,.actions .edit-btn{padding:6px 10px;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s;white-space:nowrap;min-width:50px}.actions .edit-btn{background:#007bff;color:#fff}.actions .edit-btn:hover{background:#0056b3}.actions .delete-btn{background:#dc3545;color:#fff}.actions .delete-btn:hover{background:#c82333}.admin-article-form{max-width:800px;margin:0 auto;padding:20px}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.form-header h1{font-size:2rem;color:var(--text-primary);margin:0}.back-btn{background:var(--border-color);color:var(--text-primary);border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.back-btn:hover{background:var(--border-hover)}.article-form{background:var(--bg-secondary);padding:30px;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.1);border:1px solid #e0e0e0}.form-textarea{border-radius:8px;font-size:1rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.form-textarea:focus{border-color:#333}.checkbox-label{color:#555}.form-checkbox{width:18px;height:18px;cursor:pointer}.form-actions{padding-top:20px;border-top:1px solid #e9ecef}.submit-btn{color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.submit-btn,.submit-btn:hover:not(:disabled){background:var(--success-color)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.cancel-btn{background:var(--border-color);color:var(--text-primary);border:none;padding:12px 24px;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.cancel-btn:hover{background:var(--border-hover)}.pagination-container{margin-top:20px;padding:20px;background:var(--bg-secondary);border-radius:8px;box-shadow:0 2px 8px var(--shadow-light);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;color:var(--text-primary);border:1px solid var(--border-color)}.pagination-info{font-size:14px;color:#666;font-weight:500}.pagination-controls{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.page-size-selector{display:flex;align-items:center;gap:8px}.page-size-selector label{font-size:14px;color:#333;font-weight:500}.page-size-select{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff;cursor:pointer}.page-buttons{display:flex;align-items:center;gap:5px}.page-btn{padding:6px 12px;border:1px solid #ddd;background:#fff;color:#333;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s;min-width:40px}.page-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:#007bff;color:#007bff}.page-btn.active{background:var(--primary,#444);border-color:#007bff;color:#fff}.page-btn:disabled{background:var(--bg-tertiary);color:#ccc;cursor:not-allowed;border-color:#e9ecef}.page-jump{display:flex;align-items:center;gap:8px}.page-jump label{font-size:14px;color:#333;font-weight:500}.page-jump-input{width:60px;padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:14px;text-align:center}.page-jump-btn{padding:6px 12px;border:1px solid #007bff;background:#007bff;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.page-jump-btn:hover{background:#0056b3;border-color:#0056b3}@media (max-width:1200px){.articles-table-container{min-width:1000px}.articles-table td,.articles-table th{padding:8px 6px;font-size:12px}.actions{gap:4px}.actions .delete-btn,.actions .edit-btn{padding:4px 8px;font-size:11px;min-width:40px}}.admin-container{max-width:800px;margin:0 auto;padding:20px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.admin-header h1{font-size:2rem;color:var(--text-primary);margin:0}.admin-btn{padding:10px 20px;border-radius:6px;text-decoration:none;font-weight:500;border:none;cursor:pointer;transition:background-color .2s;font-size:14px}.admin-btn.primary{background:#007bff;color:#fff}.admin-btn.primary:hover:not(:disabled){background:#0056b3}.admin-btn.secondary{background:var(--border-color);color:var(--text-primary)}.admin-btn.secondary:hover{background:var(--border-hover)}.admin-btn.danger{color:#fff}.admin-btn.danger,.admin-btn.danger:hover:not(:disabled){background:var(--error-color)}.admin-btn:disabled{opacity:.7;cursor:not-allowed}.admin-form{background:var(--bg-secondary);padding:30px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.admin-form,.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.form-input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:6px;font-size:16px;transition:border-color .2s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#007bff}.form-textarea{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:6px;font-size:14px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;line-height:1.5;resize:vertical;transition:border-color .2s;box-sizing:border-box}.form-textarea:focus{outline:none;border-color:#007bff}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#333}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;gap:12px;margin-top:30px}.message{padding:12px 16px;border-radius:6px;margin-bottom:20px;font-weight:500}.message.success{background:var(--success-color);color:var(--text-primary);border:1px solid var(--success-color)}.message.error{background:var(--error-color);color:var(--text-primary);border:1px solid var(--error-color)}.about-info{background:var(--bg-tertiary);padding:20px;border-radius:6px;border-left:4px solid var(--accent-color)}.about-info h3{margin:0 0 15px;color:var(--text-primary);font-size:1.1rem}.about-info p{margin:8px 0;color:#666;font-size:14px}.about-info strong{color:#333}.config-section{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e9ecef}.config-section:last-child{border-bottom:none}.config-section h3{margin:0 0 20px;color:#333;font-size:1.2rem;font-weight:600}.config-info{background:var(--bg-secondary);padding:20px;border-radius:6px;border-left:4px solid var(--accent-color);margin-top:20px}.config-info h3{margin:0 0 15px;color:var(--text-primary);font-size:1.1rem}.config-info ul{margin:0;padding-left:20px}.config-info li{margin:8px 0;color:#666;font-size:14px;line-height:1.5}.config-info strong{color:#333}.likes-cell{text-align:center;font-family:Courier New,monospace;color:#666;font-weight:500}@media (prefers-color-scheme:dark){.admin-container,.admin-dashboard,body{background:var(--bg-primary,#18181a);color:var(--text-primary,#f5f5f5)}.about-info h3,.admin-header h1,.config-info h3,.config-section h3,.dashboard-header h1,.form-header h1{color:var(--text-primary,#f5f5f5)}.about-info p,.about-info strong,.config-info li,.config-info strong{color:var(--text-secondary,#aaa)}.admin-btn.danger,.admin-btn.primary,.admin-btn.secondary,.back-btn,.cancel-btn,.submit-btn{color:#fff}.back-link{color:var(--text-secondary,#aaa)!important}.back-link:hover{color:var(--text-primary,#f5f5f5)!important}.articles-table{background:var(--bg-secondary,#232326);color:var(--text-primary,#f5f5f5)}.articles-table th{background:var(--bg-tertiary,#232326);color:var(--text-primary,#f5f5f5);border-bottom:2px solid var(--border-color,#333)}.articles-table td{border-bottom:1px solid var(--border-color,#333);color:var(--text-primary,#f5f5f5)}.articles-table tbody tr:hover{background:var(--bg-hover,#23232a)}.admin-header,.dashboard-header{border-bottom:2px solid var(--border-color,#333)}.form-input,.form-textarea{background:var(--bg-secondary,#232326);color:var(--text-primary,#f5f5f5);border:2px solid var(--border-color,#333)}.form-input:focus,.form-textarea:focus{border-color:var(--primary,#888)}.admin-btn,.cancel-btn,.config-btn,.logout-btn,.new-article-btn,.submit-btn{color:#fff}.admin-article-form,.admin-form,.article-form,.pagination-container{background:var(--bg-secondary,#232326);color:var(--text-primary,#f5f5f5);border:1px solid var(--border-color,#333)}.pagination-container{box-shadow:0 2px 8px rgba(0,0,0,.3)}.pagination-info{color:var(--text-secondary,#aaa)}.page-size-selector label{color:var(--text-primary,#f5f5f5)}.page-btn,.page-size-select{background:var(--bg-secondary,#232326);color:var(--text-primary,#f5f5f5);border:1px solid var(--border-color,#333)}.page-btn.active{background:var(--primary,#444);color:#fff}.page-btn:disabled{color:var(--text-tertiary,#888);background:var(--bg-secondary,#232326);border-color:var(--border-color,#333)}.form-group label{color:var(--text-primary,#f5f5f5)}.message{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.message.success{background:var(--success-color);color:var(--text-primary);border-color:var(--success-color)}.message.error{background:var(--error-color);color:var(--text-primary);border-color:var(--error-color)}.likes-cell{color:var(--text-primary,#f5f5f5)}.page-jump label{color:var(--text-secondary,#aaa)}.page-jump-input{background:var(--bg-secondary,#232326);color:var(--text-primary,#f5f5f5)}.page-jump-btn,.page-jump-input{border:1px solid var(--border-color,#333)}.page-jump-btn{background:var(--primary,#444);color:#fff}.config-info{background:var(--bg-secondary,#232326);color:var(--text-secondary,#aaa);border:1px solid var(--border-color,#333)}.config-info h3{color:var(--text-primary,#f5f5f5)}.config-info li,.config-info strong{color:var(--text-secondary,#aaa)}}