:root{--page: #f7f3ea;--surface: #fbfaf4;--surface-soft: #f1f4ea;--surface-hover: #fffdf7;--text: #34382f;--muted: #7d8375;--subtle: #a4aa99;--line: #e3e0d4;--accent: #7f9371;--accent-dark: #637458;--shadow: 0 12px 32px rgba(83, 78, 61, .055);--radius: 8px;--content: 42rem;--font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-serif: Georgia, "Times New Roman", "Songti SC", serif}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:linear-gradient(180deg,rgb(255 255 255 / .36),transparent 280px),var(--page);color:var(--text);font-family:var(--font-sans);font-size:1rem;line-height:1.7;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:3px}button,input{font:inherit}.site-shell{width:min(100% - 2rem,var(--content));margin:0 auto;padding-bottom:4rem;min-width:0}.site-main{min-width:0}.site-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.75rem 0 1.25rem;border-bottom:1px solid rgb(145 151 126 / .12)}.brand{color:var(--text);font-family:var(--font-serif);font-size:clamp(1.35rem,2.4vw,1.7rem);font-weight:600;text-wrap:balance}.site-nav{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(.75rem,3vw,1.5rem);color:var(--muted);font-size:.9rem}.site-nav a{position:relative;padding:.25rem 0}.site-nav a:after{position:absolute;inset-inline:0;bottom:0;height:1px;background:var(--accent);content:"";opacity:0;transform:scaleX(.35);transition:opacity .18s ease,transform .18s ease}.site-nav a:hover,.site-nav a.is-active{color:var(--accent-dark)}.site-nav a:hover:after,.site-nav a.is-active:after{opacity:1;transform:scaleX(1)}.site-main{padding-top:.5rem}.site-footer{margin-top:3rem;padding-top:1.25rem;border-top:1px solid rgb(145 151 126 / .14);color:var(--subtle);font-size:.78rem;text-align:center}.intro{margin:.5rem 0 1.75rem}.intro h1,.page-title{margin:0;color:var(--text);font-family:var(--font-serif);font-size:clamp(1.05rem,2vw,1.28rem);font-weight:500;line-height:1.35;text-wrap:balance}.page-copy{max-width:36rem;margin:1rem 0 0;color:var(--muted);font-size:clamp(.95rem,2vw,1.05rem)}.post-list{display:grid;gap:.875rem}.post-card{display:block;padding:clamp(1.1rem,2.4vw,1.5rem);border:1px solid rgb(145 151 126 / .18);border-radius:var(--radius);background:color-mix(in srgb,var(--surface) 88%,var(--surface-soft));box-shadow:var(--shadow);transition:transform .16s ease,border-color .16s ease,background .16s ease}.post-card:hover{border-color:#7f93715c;background:var(--surface-hover);transform:translateY(-2px)}.post-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.5rem;color:var(--accent-dark);font-size:.78rem}.post-meta span+span:before{margin-inline-end:.5rem;color:var(--subtle);content:"/"}.post-title{margin:0;font-size:clamp(1rem,1.65vw,1.12rem);font-weight:650;line-height:1.35;text-wrap:pretty}.post-excerpt{display:-webkit-box;margin:.75rem 0 0;overflow:hidden;color:var(--muted);font-size:.88rem;line-height:1.65;-webkit-box-orient:vertical;-webkit-line-clamp:3}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(10rem,1fr));gap:1rem;margin-top:1.5rem}.category-card{display:block;padding:1.35rem 1rem;border:1px solid rgb(145 151 126 / .2);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);text-align:center;transition:transform .16s ease,border-color .16s ease,background .16s ease}.category-card:hover{border-color:#7f937161;background:var(--surface-hover);transform:translateY(-2px)}.category-card h2{margin:0 0 .35rem;font-size:1.1rem}.category-card p{margin:0;color:var(--muted);font-size:.85rem}.clear-button{margin-top:1rem;padding:0;border:0;background:transparent;color:var(--accent-dark);cursor:pointer;font-size:.88rem}.clear-button:hover{text-decoration:underline;text-underline-offset:3px}.archive-list{display:grid;gap:1.75rem}.archive-group h2{margin:0 0 .75rem;color:var(--accent-dark);font-size:1rem;font-weight:650}.archive-items{display:grid;gap:.35rem}.archive-item{display:grid;grid-template-columns:3.25rem minmax(0,1fr);gap:.875rem;align-items:baseline;padding:.35rem 0;border-bottom:1px solid rgb(145 151 126 / .14);font-size:.88rem}.archive-item:last-child{border-bottom:0}.archive-item time{color:var(--subtle);font-size:.78rem;font-variant-numeric:tabular-nums}.archive-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.archive-item:hover span{color:var(--accent-dark);text-decoration:underline;text-underline-offset:4px}.search-box{margin:1.5rem 0 1.25rem}.search-box input{width:100%;padding:.9rem 1rem;border:1px solid rgb(145 151 126 / .34);border-radius:var(--radius);background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.search-box input::placeholder{color:var(--subtle)}.search-hint{margin:0 0 1rem;color:var(--subtle);font-size:.8rem}.empty-state{padding:1.75rem;border:1px dashed rgb(145 151 126 / .38);border-radius:var(--radius);color:var(--muted);text-align:center;font-size:.9rem}.article-page{padding-top:.75rem;min-width:0}.back-link{display:inline-flex;align-items:center;gap:.25rem;margin-bottom:1.5rem;color:var(--accent-dark);font-size:.88rem}.back-link:hover{text-decoration:underline;text-underline-offset:4px}.article-header{margin-bottom:1.75rem}.article-title{margin:0;font-family:var(--font-serif);font-size:clamp(1.15rem,2.2vw,1.45rem);font-weight:500;line-height:1.25;text-wrap:balance}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tag{padding:.2rem .55rem;border-radius:999px;background:var(--surface-soft);color:var(--accent-dark);font-size:.75rem}.article-body{padding:clamp(1.25rem,3.5vw,2rem);border:1px solid rgb(145 151 126 / .18);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);min-width:0}.article-body p{margin:0 0 1.2em;color:#4a4f43;font-size:.94rem;line-height:1.8}.article-body p:last-child{margin-bottom:0}.article-body h2{margin:2em 0 .75em;font-size:1.05rem;line-height:1.35}.article-body h3{margin:1.6em 0 .6em;font-size:.98rem}.article-body a{color:var(--accent-dark);text-decoration:underline;text-underline-offset:3px}.article-body blockquote{margin:1.4em 0;padding:.35em 0 .35em 1.1em;border-inline-start:3px solid var(--accent);color:var(--accent-dark)}.article-body :not(pre)>code,.article-body p code,.article-body li code{padding:.15em .35em;border-radius:4px;background:#ecebdd;color:#4f5b46;font-size:.9em}.article-body .code-block{margin:1.25em 0;max-width:100%;min-width:0}.article-body .code-panel{max-width:100%;min-width:0;border:1px solid rgb(60 64 72 / .55);border-radius:var(--radius);box-shadow:var(--shadow);background:#24292e;overflow:hidden}.article-body .code-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.35rem .5rem .35rem .65rem;background:#1c2128;border-bottom:1px solid rgb(255 255 255 / .06)}.article-body .code-lang{color:#ffffff6b;font-size:.7rem;letter-spacing:.04em;text-transform:lowercase;user-select:none}.article-body .code-copy{display:inline-flex;align-items:center;gap:.35rem;flex-shrink:0;margin:0;padding:.28rem .5rem;border:1px solid rgb(255 255 255 / .14);border-radius:6px;background:#242930;color:#ffffffe6;font-family:inherit;font-size:.72rem;line-height:1;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .12s ease}.article-body .code-copy:hover{border-color:#ffffff47;background:#343a42;color:#fff}.article-body .code-copy:active{transform:scale(.97)}.article-body .code-copy.is-copied{border-color:#7f93718c;background:#374430;color:#e8f0e4}.article-body .code-copy-icons{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px}.article-body .code-copy-icon{display:block}.article-body .code-copy-icon--check,.article-body .code-copy.is-copied .code-copy-icon--copy{display:none}.article-body .code-copy.is-copied .code-copy-icon--check{display:block}.article-body .code-scroll{max-width:100%;min-width:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;background:#24292e}.article-body .code-scroll pre.shiki{display:block;margin:0;padding:.4rem .5rem .4rem 0;overflow:visible;width:max-content;min-width:100%;max-width:none;border-radius:0;background:#24292e!important;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Courier New,monospace;tab-size:2;font-variant-ligatures:none;box-sizing:border-box}.article-body .code-scroll pre.shiki code{display:block;padding:0;background:transparent!important;color:inherit;font-family:inherit;line-height:0;font-size:0}.article-body .code-scroll--ln pre.shiki code{counter-reset:code-ln}.article-body .code-scroll--ln .line{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;margin:0;padding:0;font-size:.8125rem;line-height:1.4;min-height:1.4em;white-space:pre}.article-body .code-scroll--ln .line>span{line-height:1.4}.article-body .code-scroll--ln .line:before{counter-increment:code-ln;content:counter(code-ln);flex:0 0 2.5em;padding:0 .5em 0 .35rem;margin-right:.5rem;border-right:1px solid rgb(255 255 255 / .08);color:#ffffff52;font-size:.7rem;line-height:1.4;text-align:right;font-variant-numeric:tabular-nums;user-select:none}.article-body .code-scroll--ln .line:empty{min-height:1.4em}.article-body .code-scroll:not(.code-scroll--ln) .line,.article-body .code-scroll pre.shiki:not(:has(.line)) code{display:block;white-space:pre;padding:0;margin:0;font-size:.8125rem;line-height:1.4}.article-body pre:not(.shiki){overflow-x:auto;margin:1.25em 0;padding:1rem 1.1rem;border-radius:var(--radius);background:#34382f;color:#f5f0e5;line-height:1.55;font-size:.85rem}.article-body pre:not(.shiki) code{padding:0;background:transparent;color:inherit}.article-body ul,.article-body ol{margin:0 0 1.2em;padding-inline-start:1.35em;color:#4a4f43;font-size:.94rem}.article-body li{margin-bottom:.35em}.article-body table{width:100%;border-collapse:collapse;margin:1.25em 0;font-size:.86rem}.article-body th,.article-body td{padding:.5rem .65rem;border-bottom:1px solid var(--line);text-align:start}.article-body hr{border:0;border-top:1px solid var(--line);margin:1.5em 0}.article-body img{display:block;max-width:100%;height:auto;margin:1.25em auto;border-radius:var(--radius)}@media(max-width:720px){.site-shell{width:min(100% - 1.5rem,var(--content))}.site-header{flex-direction:column;align-items:flex-start;gap:.75rem}.post-excerpt{-webkit-line-clamp:2}.archive-item{grid-template-columns:2.75rem minmax(0,1fr)}.article-body{padding:1.15rem}}
