:root{--bg:#fafafa;--surface:#ffffff;--text:#2c2c2a;--text-sec:#666;--text-hint:#999;--border:#e5e5e5;--accent:#1D9E75;--accent-soft:#E1F5EE;--radius:12px;--maxw:820px;--maxw-wide:1080px;--shadow:0 1px 3px rgba(0,0,0,.06);--font:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",sans-serif}[data-theme=dark]{--bg:#141414;--surface:#1e1e1e;--text:#e8e8e8;--text-sec:#aaa;--text-hint:#777;--border:#333;--accent:#5DCAA5;--accent-soft:#1a2e28;--shadow:0 1px 3px rgba(0,0,0,.3)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none;transition:opacity .2s}a:hover{opacity:.75}img{max-width:100%;border-radius:var(--radius)}.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}.container-wide{max-width:var(--maxw-wide)}.site-header{border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10;backdrop-filter:saturate(180%)blur(8px)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:60px}.logo{font-weight:600;font-size:18px;color:var(--text)}.nav{display:flex;gap:28px}.nav a{color:var(--text-sec);font-size:15px;font-weight:500}.nav a.active,.nav a:hover{color:var(--accent);opacity:1}.theme-toggle{background:0 0;border:none;color:var(--text-sec);cursor:pointer;padding:6px;display:flex;align-items:center}.theme-toggle .icon-moon{display:none}[data-theme=dark] .theme-toggle .icon-sun{display:none}[data-theme=dark] .theme-toggle .icon-moon{display:block}.hero{padding:72px 0 48px;text-align:center}.hero h1{font-size:38px;font-weight:600;letter-spacing:-.5px}.hero-desc{color:var(--text-sec);font-size:18px;margin-top:12px}.section{padding:32px 0}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.section-head h2{font-size:22px;font-weight:600}.more{font-size:14px}.post-list{display:flex;flex-direction:column;gap:16px}.post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;transition:border-color .2s,box-shadow .2s}.post-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}.post-card a{color:var(--text);display:block}.post-date{font-size:13px;color:var(--text-hint);font-family:var(--font)}.post-card h3{font-size:18px;font-weight:600;margin:6px 0 8px}.post-card p{color:var(--text-sec);font-size:14px}.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.tag{font-size:12px;color:var(--accent);background:var(--accent-soft);padding:2px 10px;border-radius:20px}.tags-bottom{margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.portfolio-grid-full{margin-top:24px}.portfolio-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s}.portfolio-item:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.portfolio-cover{height:180px;background-size:cover;background-position:50%;background-color:var(--accent-soft)}.portfolio-info{padding:18px 20px}.portfolio-info h3{font-size:17px;font-weight:600;color:var(--text)}.portfolio-info p{color:var(--text-sec);font-size:14px;margin-top:6px}.article{padding:32px 0 64px}.page-head{padding:32px 0 24px}.page-head h1{font-size:30px;font-weight:600}.page-desc{color:var(--text-sec);margin-top:8px}.article-head{margin-bottom:32px}.article-head h1{font-size:30px;font-weight:600;letter-spacing:-.3px}.article-meta{display:flex;gap:16px;color:var(--text-hint);font-size:14px;margin-top:10px}.article-cover{width:100%;margin:20px 0}.btn{display:inline-block;margin-top:16px;padding:8px 20px;background:var(--accent);color:#fff;border-radius:8px;font-size:14px;font-weight:500}.btn:hover{opacity:.9}.article-content{font-size:16px;line-height:1.85}.article-content h2{font-size:22px;font-weight:600;margin:36px 0 16px}.article-content h3{font-size:18px;font-weight:600;margin:28px 0 12px}.article-content p{margin:16px 0}.article-content ul,.article-content ol{margin:16px 0;padding-left:24px}.article-content li{margin:6px 0}.article-content blockquote{border-left:3px solid var(--accent);padding:8px 20px;margin:20px 0;color:var(--text-sec);background:var(--accent-soft);border-radius:0 8px 8px 0}.article-content pre{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px;overflow-x:auto;margin:20px 0;color:var(--text)}.article-content code{font-family:sf mono,Consolas,monospace;font-size:14px}.article-content :not(pre)>code{background:var(--accent-soft);color:var(--accent);padding:2px 6px;border-radius:4px}.article-content img{margin:20px 0}.article-content table{width:100%;margin:20px 0;border-collapse:collapse;font-size:15px}.article-content th,.article-content td{border:1px solid var(--border);padding:10px 14px;text-align:left}.article-content th{background:var(--accent-soft);font-weight:600;color:var(--text)}.article-content tr:nth-child(even){background:var(--bg)}.article-nav{display:flex;justify-content:space-between;margin-top:48px;padding-top:24px;border-top:1px solid var(--border);gap:16px}.article-nav a{font-size:14px}.pagination{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:40px;color:var(--text-sec);font-size:14px}.site-footer{border-top:1px solid var(--border);padding:28px 0;margin-top:48px}.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.footer-inner p{color:var(--text-hint);font-size:14px}.social{display:flex;gap:20px}.social a{color:var(--text-sec);font-size:14px}@media(max-width:640px){.hero{padding:48px 0 32px}.hero h1{font-size:28px}.hero-desc{font-size:16px}.nav{gap:18px}.nav a{font-size:14px}.article-head h1,.page-head h1{font-size:24px}.portfolio-grid{grid-template-columns:1fr}.footer-inner{justify-content:center;text-align:center}}[data-theme=dark] .article-content pre,[data-theme=dark] .article-content pre *,[data-theme=dark] .article-content .highlight,[data-theme=dark] .article-content .highlight *{color:#e8e8e8 !important}[data-theme=dark] .article-content pre,[data-theme=dark] .article-content .highlight>pre,[data-theme=dark] .article-content .chroma{background-color:#1e1e1e !important;border-color:#333 !important}[data-theme=dark] .article-content .highlight .ln,[data-theme=dark] .article-content .lntd.ln{color:#777 !important;border-right-color:#333 !important}.redact{display:inline-block;vertical-align:baseline;cursor:pointer;border-radius:4px;line-height:1.4;transition:opacity .2s}.redact:hover{opacity:.85}.redact-canvas{display:inline-block;vertical-align:middle;border-radius:3px;background:#bbb;image-rendering:pixelated;image-rendering:crisp-edges;position:relative;top:-1px}.redact-revealed{display:inline-block;vertical-align:baseline;font-family:sf mono,Consolas,monospace;font-size:.92em;background:var(--accent-soft);color:var(--accent);padding:1px 6px;border-radius:4px;border:1px dashed var(--accent)}.redact-revealed[hidden]{display:none !important}.redact-dialog{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.45);z-index:1000;padding:20px}.redact-dialog-open{display:flex}.redact-dialog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;width:100%;max-width:340px;box-shadow:0 8px 32px rgba(0,0,0,.2)}.redact-dialog-card h3{font-size:17px;font-weight:600;margin-bottom:6px}.redact-dialog-hint{color:var(--text-sec);font-size:13px;margin-bottom:16px}.redact-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:15px;background:var(--bg);color:var(--text);font-family:var(--font)}.redact-input:focus{outline:none;border-color:var(--accent)}.redact-dialog-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.redact-btn{padding:8px 18px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:1px solid transparent;font-family:var(--font)}.redact-btn-primary{background:var(--accent);color:#fff}.redact-btn-primary:hover{opacity:.9}.redact-btn-ghost{background:0 0;color:var(--text-sec);border-color:var(--border)}.redact-btn-ghost:hover{opacity:.75}.redact-dialog-error{color:#d33;font-size:13px;margin-top:12px;min-height:18px}.comments{margin-top:48px;padding-top:28px;border-top:1px solid var(--border)}.comment-title{font-size:20px;font-weight:600;margin-bottom:20px}.comment-form{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}.comment-name-input,.comment-body-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:15px;background:var(--bg);color:var(--text);font-family:var(--font);resize:vertical}.comment-name-input:focus,.comment-body-input:focus{outline:none;border-color:var(--accent)}.comment-name-input{max-width:240px}.comment-website{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}.comment-form-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.comment-error{color:#d33;font-size:13px;flex:1}.comment-submit{cursor:pointer;border:none}.comment-list{display:flex;flex-direction:column;gap:0}.comment-item{padding:16px 0;border-bottom:1px solid var(--border)}.comment-item:last-child{border-bottom:none}.comment-head{display:flex;align-items:baseline;gap:12px;margin-bottom:6px}.comment-name{font-weight:600;color:var(--text);font-size:14px}.comment-time{color:var(--text-hint);font-size:12px}.comment-body{color:var(--text);font-size:15px;line-height:1.7;white-space:pre-wrap;word-break:break-word}.comment-empty{color:var(--text-hint);font-size:14px;padding:16px 0;text-align:center}