.theme-toggle{background:none;border:none;padding:.5rem;font-size:1.25rem;transition:transform .2s}.theme-toggle:hover{transform:rotate(15deg)}.theme-icon{display:block}.layout{min-height:100vh;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:100;background:var(--site-bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-content{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;gap:2rem}.logo{display:flex;align-items:center;gap:.5rem;color:var(--text-main);font-weight:700;font-size:1.25rem}.logo-img{height:28px;width:auto;vertical-align:middle}.nav{display:flex;gap:1.5rem;flex:1}.nav-link{color:var(--text-muted);font-size:.95rem;transition:color .2s;position:relative}.nav-link:hover,.nav-link.active{color:var(--text-main)}.nav-link.active:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--accent)}.header-actions{display:flex;align-items:center;gap:.75rem}.search-container{display:flex;align-items:center;gap:.5rem}.search-container.open .search-btn{opacity:1}.search-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--card-bg);border-radius:50%;cursor:pointer;transition:all .2s;color:var(--text-muted)}.search-btn:hover{background:var(--accent);color:var(--site-bg)}.search-btn svg{width:18px;height:18px}.search-form{overflow:hidden;animation:searchExpand .2s ease-out}@keyframes searchExpand{0%{width:0;opacity:0}to{width:200px;opacity:1}}.search-input{width:200px;padding:.5rem 1rem;border:1px solid var(--border);border-radius:20px;background:var(--card-bg);color:var(--text-main);font-size:.9rem;transition:all .2s}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}.search-input::placeholder{color:var(--text-muted)}.main{flex:1;padding:2rem 0}.footer{text-align:center;padding:2rem;color:var(--text-muted);font-size:.85rem;border-top:1px solid var(--border)}.mobile-menu-btn{display:none;background:none;border:none;padding:.5rem}.hamburger{display:block;width:20px;height:2px;background:var(--text-main);position:relative;transition:all .3s}.hamburger:before,.hamburger:after{content:"";position:absolute;width:100%;height:100%;background:var(--text-main);transition:all .3s}.hamburger:before{top:-6px}.hamburger:after{top:6px}.hamburger.open{background:transparent}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{top:0;transform:rotate(-45deg)}@media (max-width: 768px){.header-content{gap:1rem;padding:1rem}.mobile-menu-btn{display:block}.nav{position:fixed;top:60px;left:0;right:0;background:var(--site-bg);flex-direction:column;padding:1rem;gap:1rem;border-bottom:1px solid var(--border);transform:translateY(-100%);opacity:0;pointer-events:none;transition:all .3s}.nav.open{transform:translateY(0);opacity:1;pointer-events:all}.header-actions{margin-left:auto}.search-container.open .search-form{position:absolute;top:100%;left:0;right:60px;padding:1rem;background:var(--site-bg);border-bottom:1px solid var(--border);animation:none}.search-form,.search-input{width:100%}@keyframes searchExpand{0%{opacity:0}to{opacity:1}}}.article-card{padding:1.5rem 0;border-bottom:1px solid var(--border)}.article-card-link{color:inherit;display:block;margin-bottom:.75rem}.article-card-title{font-size:1.35rem;font-weight:700;margin-bottom:.5rem;color:var(--text-main);transition:color .2s}.article-card-link:hover .article-card-title{color:var(--accent)}.article-card-excerpt{color:var(--text-muted);line-height:1.6}.article-card-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-muted)}.article-card-date{opacity:.8}.article-card-category{display:inline-flex;align-items:center;gap:.3rem;background:var(--card-bg);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;color:var(--text-muted);transition:all .2s}.article-card-category:hover{background:var(--accent);color:var(--site-bg)}.article-card-tags{display:flex;gap:.5rem}.article-card-tag{display:inline-flex;align-items:center;gap:.3rem;background:var(--card-bg);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;color:var(--text-muted);transition:all .2s}.article-card-tag:hover{background:var(--accent);color:var(--site-bg)}.pagination{display:flex;justify-content:center;align-items:center;gap:1.5rem;padding:2rem 0;font-size:.95rem}.pagination-link{color:var(--accent)}.pagination-info{color:var(--text-muted)}.pagination-disabled{color:var(--text-muted);opacity:.5;pointer-events:none}.home{max-width:720px;margin:0 auto}.article-list{margin-bottom:2rem}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.article-detail{max-width:720px;margin:0 auto}.article-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.article-title{font-size:2rem;margin-bottom:1rem;color:var(--text-main)}.article-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-muted)}.meta-icon{width:14px;height:14px;flex-shrink:0}.article-date{opacity:.8}.article-category{display:inline-flex;align-items:center;gap:.3rem;background:var(--card-bg);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;color:var(--text-muted);transition:all .2s}.article-category:hover{background:var(--accent);color:var(--site-bg)}.article-tags{display:flex;gap:.5rem}.article-tag{display:inline-flex;align-items:center;gap:.3rem;background:var(--card-bg);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;color:var(--text-muted);transition:all .2s}.article-tag:hover{background:var(--accent);color:var(--site-bg)}.code-window{margin:1.5rem 0;border-radius:10px;overflow:hidden;box-shadow:0 4px 20px #00000026;border:1px solid var(--border)}.code-window-header{background:var(--terminal-header);padding:10px 14px;display:flex;gap:6px;align-items:center}.code-window-header .dot{width:10px;height:10px;border-radius:50%}.code-window-header .dot-red{background:#ff5f56}.code-window-header .dot-yellow{background:#ffbd2e}.code-window-header .dot-green{background:#27c93f}.code-lang{margin-left:auto;font-size:.75rem;color:var(--text-muted);font-family:JetBrains Mono,monospace}.code-wrapper{position:relative;background:#0d1117}.code-copy-btn{position:absolute;top:8px;right:8px;background:#ffffff1a;border:none;border-radius:4px;padding:6px 8px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.6;transition:all .2s;z-index:10}.code-copy-btn:hover{opacity:1;background:#fff3}.code-copy-btn svg{width:16px;height:16px;stroke:#64ffda}.code-window pre.code-block{margin:0;padding:2.5rem 1rem 1rem;border-radius:0;background:#0d1117}.loading,.not-found{text-align:center;color:var(--text-muted);padding:3rem 0}@media (max-width: 768px){.article-title{font-size:1.5rem}}.category-page{max-width:720px;margin:0 auto}.category-cloud{display:flex;flex-wrap:wrap;gap:1rem}.category-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--card-bg);border-radius:8px;color:var(--text-main);transition:all .2s}.category-item:hover{background:var(--accent);color:var(--site-bg)}.category-name{font-weight:500}.category-count{font-size:.8rem;opacity:.7}.tag-page{max-width:720px;margin:0 auto}.tag-list-page{max-width:720px;margin:0 auto}.tag-cloud{display:flex;flex-wrap:wrap;gap:1rem}.tag-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--card-bg);border-radius:8px;color:var(--text-main);transition:all .2s}.tag-item:hover{background:var(--accent);color:var(--site-bg)}.tag-name{font-weight:500}.tag-count{font-size:.8rem;opacity:.7}.loading,.empty{text-align:center;color:var(--text-muted);padding:3rem 0}.archive-page{max-width:900px;margin:0 auto}.archive-header{margin-bottom:2rem}.archive-back{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.9rem;margin-bottom:1rem;transition:color .2s}.archive-back:hover{color:var(--accent)}.archive-back svg{width:16px;height:16px}.archive-title{font-size:1.75rem;color:var(--text-main);margin-bottom:2rem}.archive-container{display:flex;flex-direction:column}.archive-year-row{display:flex;gap:2rem;padding:1.5rem 0;border-bottom:1px solid var(--border)}.archive-year{font-size:1.5rem;font-weight:700;color:var(--accent);min-width:80px}.archive-articles{flex:1;display:flex;flex-direction:column}.archive-article-row{display:flex;align-items:center;gap:1rem;padding:.5rem;border-radius:4px;transition:all .2s;color:inherit}.archive-article-row:hover{background:var(--card-bg)}.archive-mm-dd{font-size:.85rem;color:var(--text-muted);min-width:50px;font-family:JetBrains Mono,monospace}.archive-article-title{flex:1;color:var(--text-main)}.archive-article-row:hover .archive-article-title{color:var(--accent)}.archive-list{display:flex;flex-direction:column}.archive-item{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--border);color:inherit}.archive-item:hover .archive-title-text{color:var(--accent)}.archive-date{font-size:.85rem;color:var(--text-muted);min-width:50px;font-family:JetBrains Mono,monospace}.archive-title-text{color:var(--text-main)}@media (max-width: 768px){.archive-year-row{flex-direction:column;gap:.5rem}.archive-year{font-size:1.25rem}}.about-page{max-width:720px;margin:0 auto}.page-title{font-size:1.75rem;margin-bottom:2rem;color:var(--text-main)}.about-content{line-height:2}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:100%;max-width:400px;padding:2rem;background:var(--card-bg);border-radius:12px;border:1px solid var(--border)}.login-title{font-size:1.5rem;text-align:center;margin-bottom:2rem;color:var(--text-main)}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-error{padding:.75rem;background:#ff00001a;border:1px solid rgba(255,0,0,.3);border-radius:6px;color:#f44;font-size:.9rem}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:240px;background:var(--card-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.admin-sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border)}.admin-sidebar-header h2{font-size:1.1rem;color:var(--text-main)}.admin-nav{flex:1;padding:1rem 0}.admin-nav-link{display:block;padding:.85rem 1.5rem;color:var(--text-muted);transition:all .2s}.admin-nav-link:hover,.admin-nav-link.active{color:var(--text-main);background:var(--site-bg)}.admin-nav-link.active{border-left:3px solid var(--accent);padding-left:calc(1.5rem - 3px)}.admin-sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--border)}.admin-main{flex:1;padding:2rem;overflow-y:auto;max-width:calc(100% - 240px)}@media (max-width: 768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;flex-direction:row;height:auto;border-right:none;border-bottom:1px solid var(--border)}.admin-sidebar-header{padding:1rem;border-bottom:none;border-right:1px solid var(--border)}.admin-nav{display:flex;flex-wrap:wrap;padding:0}.admin-nav-link{padding:1rem}.admin-nav-link.active{border-left:none;border-bottom:3px solid var(--accent);padding-left:1rem}.admin-sidebar-footer{border-top:none;border-left:1px solid var(--border);padding:1rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--card-bg);border-radius:12px;width:90%;max-width:400px;max-height:80vh;overflow:hidden;animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1.1rem;font-weight:600;color:var(--text-main)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:var(--text-main)}.modal-body{padding:1.5rem;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.article-edit-page{max-width:800px;position:relative}.article-form{display:flex;flex-direction:column;gap:1.5rem}.form-label-row{display:flex;justify-content:space-between;align-items:center}.btn-link{background:none;border:none;color:var(--accent);font-size:.85rem;cursor:pointer}.btn-link:hover{text-decoration:underline}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tag-selector{display:flex;flex-wrap:wrap;gap:.5rem}.tag-btn{padding:.4rem 1rem;border:1px solid var(--border);border-radius:20px;background:var(--card-bg);color:var(--text-muted);font-size:.85rem;transition:all .2s}.tag-btn.selected{background:var(--accent);color:var(--site-bg);border-color:var(--accent)}.modal-form{display:flex;flex-direction:column;gap:1rem}.article-list-page{max-width:1000px;position:relative}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{font-size:1.5rem;color:var(--text-main)}.article-table{width:100%;border-collapse:collapse;background:var(--card-bg);border-radius:8px;overflow:hidden}.article-table th,.article-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.article-table th{background:var(--site-bg);font-weight:600;font-size:.85rem;color:var(--text-muted)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.8rem}.status-badge.published{background:#64ffda33;color:var(--accent)}.status-badge.draft{background:var(--card-bg);color:var(--text-muted)}.action-link{margin-right:1rem;color:var(--accent);font-size:.9rem}.action-link.danger{color:#f44;background:none;border:none}.pagination{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.category-manage-page{max-width:600px;position:relative}.category-manage-page h1{font-size:1.5rem;margin-bottom:2rem;color:var(--text-main)}.category-form{display:flex;gap:1rem;margin-bottom:2rem}.category-form .input{flex:1}.category-table{width:100%;border-collapse:collapse;background:var(--card-bg);border-radius:8px}.category-table th,.category-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.category-table th{background:var(--site-bg);font-weight:600;font-size:.85rem;color:var(--text-muted)}.tag-manage-page{max-width:600px;position:relative}.tag-manage-page h1{font-size:1.5rem;margin-bottom:2rem;color:var(--text-main)}.tag-form{display:flex;gap:1rem;margin-bottom:2rem}.tag-form .input{flex:1}.tag-table{width:100%;border-collapse:collapse;background:var(--card-bg);border-radius:8px}.tag-table th,.tag-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.tag-table th{background:var(--site-bg);font-weight:600;font-size:.85rem;color:var(--text-muted)}.action-link{margin-right:1rem;color:var(--accent);font-size:.9rem;background:none;border:none}.action-link.danger{color:#f44}.settings-page{max-width:800px;position:relative}.settings-page h1{font-size:1.5rem;margin-bottom:2rem;color:var(--text-main)}.settings-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:var(--text-main)}.textarea-about{min-height:200px;resize:vertical;font-family:JetBrains Mono,monospace;font-size:.9rem;line-height:1.6}.menu-toggles{display:flex;flex-wrap:wrap;gap:1.5rem}.toggle-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-main)}.toggle-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-actions{padding-top:1rem;border-top:1px solid var(--border)}.loading{text-align:center;color:var(--text-muted);padding:3rem 0}.toast{position:fixed;top:20px;right:20px;padding:1rem 1.5rem;border-radius:8px;font-size:.9rem;z-index:1000;animation:slideIn .3s ease}.toast-success{background:var(--accent);color:var(--site-bg)}.toast-error{background:#f44;color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.not-found-page{text-align:center;padding:4rem 0}.not-found-title{font-size:6rem;font-weight:700;color:var(--accent);margin-bottom:1rem}.not-found-text{color:var(--text-muted);margin-bottom:2rem}:root{--site-bg: #fdfdfd;--text-main: #1a1a1a;--text-muted: #666666;--accent: #2563eb;--border: rgba(0, 0, 0, .08);--card-bg: #f9f9f9;--terminal-header: #e5e7eb}[data-theme=dark]{--site-bg: #0a192f;--text-main: #e6f1ff;--text-muted: #8892b0;--accent: #64ffda;--border: rgba(255, 255, 255, .1);--card-bg: #112240;--terminal-header: #1d2d50}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Libre Baskerville,"Noto Serif SC",serif;background-color:var(--site-bg);color:var(--text-main);line-height:1.8;transition:background-color .3s ease,color .3s ease;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#80808033;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#80808066}::selection{background-color:var(--accent);color:var(--site-bg)}a{color:var(--accent);text-decoration:none;transition:opacity .2s}a:hover{opacity:.8}button{cursor:pointer;font-family:inherit}.terminal-container{margin:2rem 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 20px #0000001a;border:1px solid var(--border)}.terminal-header{background:var(--terminal-header);padding:8px 14px;display:flex;gap:6px;align-items:center}.dot{width:10px;height:10px;border-radius:50%}.dot-red{background:#ff5f56}.dot-yellow{background:#ffbd2e}.dot-green{background:#27c93f}.markdown-content h1{font-size:1.85rem;margin:2rem 0 1rem;font-weight:700}.markdown-content h2{font-size:1.45rem;margin:1.5rem 0 1rem;font-weight:700}.markdown-content h3{font-size:1.25rem;margin:1rem 0;font-weight:700}.markdown-content p{margin:1rem 0}.markdown-content ul,.markdown-content ol{margin:1rem 0;padding-left:1.5rem}.markdown-content li{margin:.5rem 0}.markdown-content blockquote{border-left:3px solid var(--accent);padding-left:1.5rem;color:var(--text-muted);font-style:italic;margin:1.5rem 0}.markdown-content pre{background:#0d1117;padding:1rem;border-radius:6px;overflow-x:auto;margin:1rem 0}.markdown-content code{font-family:JetBrains Mono,monospace;font-size:.9em}.markdown-content pre code{background:transparent;padding:0}.markdown-content :not(pre)>code{background:var(--card-bg);padding:.2rem .4rem;border-radius:4px}.markdown-content table{width:100%;border-collapse:collapse;margin:1.5rem 0}.markdown-content th,.markdown-content td{border:1px solid var(--border);padding:.75rem 1rem;text-align:left}.markdown-content th{background:var(--card-bg);font-weight:700}.markdown-content img{max-width:100%;border-radius:6px}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border-radius:6px;font-size:.95rem;font-weight:500;transition:all .2s;border:none}.btn-primary{background:var(--accent);color:var(--site-bg)}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-secondary{background:var(--card-bg);color:var(--text-main);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent)}.input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:6px;background:var(--site-bg);color:var(--text-main);font-family:inherit;font-size:.95rem;transition:border-color .2s}.input:focus{outline:none;border-color:var(--accent)}textarea.input{min-height:200px;resize:vertical;font-family:JetBrains Mono,monospace}@media (max-width: 768px){.container{padding:0 1rem}.markdown-content h1{font-size:1.5rem}.markdown-content h2{font-size:1.25rem}.markdown-content h3{font-size:1.1rem}}
