:root{--background:#080806;--foreground:#f4f0e8;--muted:#a9a597;--border:#2b3029;--accent:#d8a657;--accent-strong:#efc878;--accent-seal:#e0623d;--accent-cool:#78b7a4;--surface:#11130f;--surface-raised:#191c16;--surface-deep:#050505;--danger:#e07a64;--shadow:0 1px 2px #00000038, 0 18px 50px #0000004d;--radius:4px;--max-width:1180px;--motion-fast:.16s;--motion-standard:.26s;--motion-slow:.42s;--motion-ease:cubic-bezier(.2, .8, .2, 1);--glow:color-mix(in srgb, var(--accent) 6%, transparent);--grid-line:color-mix(in srgb, var(--foreground) 3%, transparent);--grain-opacity:.05;--glass-highlight:#ffffff14;--root-font-size:100%;--font-serif-stack:var(--font-serif-tc,"Noto Serif TC"), "Songti TC", "PMingLiU", serif;--font-mono-stack:var(--font-mono,"SFMono-Regular"), ui-monospace, Menlo, Consolas, monospace}:root[data-theme=light]{--background:#f6f2e8;--foreground:#1c1a13;--muted:#6c685b;--border:#d9d2bf;--accent:#9a6e1c;--accent-strong:#6f4d12;--accent-seal:#bc4326;--accent-cool:#2f7568;--surface:#efeadc;--surface-raised:#fffdf4;--surface-deep:#e8e2d1;--danger:#b84f3a;--shadow:0 1px 2px #3c372814, 0 16px 42px #26251f1f;--glow:color-mix(in srgb, var(--accent) 5%, transparent);--grid-line:color-mix(in srgb, var(--foreground) 4%, transparent);--grain-opacity:.035;--glass-highlight:#ffffff8c;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}html{background:var(--background);color:var(--foreground);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-size:var(--root-font-size);scroll-behavior:smooth}@supports (-webkit-app-region:drag){:root{--root-font-size:94%}}@supports (font:-apple-system-body){:root{--root-font-size:103%}}body{background:radial-gradient(1100px 540px at 84% -120px, var(--glow), transparent 65%), var(--background);color:var(--foreground);text-rendering:optimizelegibility;flex-direction:column;min-height:100vh;margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,PingFang TC,sans-serif;line-height:1.65;display:flex;overflow-x:clip}body:before{background-image:linear-gradient(to right, var(--grid-line) 1px, transparent 1px), linear-gradient(to bottom, var(--grid-line) 1px, transparent 1px);content:"";pointer-events:none;z-index:-1;background-size:72px 72px;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000d9,#0000004d 45%,#0000 85%);mask-image:linear-gradient(#000000d9,#0000004d 45%,#0000 85%)}body:after{content:"";opacity:var(--grain-opacity);pointer-events:none;z-index:-1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:160px 160px;position:fixed;inset:0}a{color:inherit;text-decoration:none}button,input{font:inherit}img{max-width:100%;display:block}main{flex:1 0 auto}main:focus{outline:none}.skip-link{background:var(--accent);border-radius:0 0 var(--radius) 0;color:var(--background);transition:transform var(--motion-fast) var(--motion-ease);z-index:60;padding:10px 16px;font-size:.9rem;font-weight:700;position:fixed;top:0;left:0;transform:translateY(-110%)}.skip-link:focus-visible{outline:2px solid var(--accent-strong);outline-offset:2px;transform:translateY(0)}::selection{background:var(--accent-seal);color:#fdf6ec}@keyframes fade-up-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes popover-in{0%{opacity:0;transform:translateY(-6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.site-header{background:color-mix(in srgb, var(--background) 86%, transparent);border-bottom:1px solid var(--border);z-index:20;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);grid-template-columns:auto minmax(280px,1fr) auto auto;grid-template-areas:"brand nav search theme";align-items:center;gap:16px;width:100%;margin:0;padding:15px clamp(18px,4vw,42px);display:grid;position:sticky;top:0;left:0;right:0}.brand-link{white-space:nowrap;grid-area:brand;align-items:baseline;gap:10px;display:inline-flex}.brand-link span:first-child{font-family:var(--font-serif-stack);letter-spacing:.01em;font-size:1.06rem;font-weight:600;line-height:1}.brand-link span:last-child{border:1px solid color-mix(in srgb, var(--accent-seal) 60%, transparent);color:var(--accent-seal);font-family:var(--font-serif-stack);transition:background-color var(--motion-fast) var(--motion-ease);border-radius:3px;padding:3px 4px 4px;font-size:.76rem;font-weight:600;line-height:1;transform:translateY(-2px)}.brand-link:hover span:last-child,.brand-link:focus-visible span:last-child{background:color-mix(in srgb, var(--accent-seal) 14%, transparent)}.nav-links{grid-area:nav;justify-content:center;align-items:center;gap:20px;display:flex}.header-search{grid-area:search;justify-self:end;min-width:0}.nav-links a,.text-link{color:var(--muted);transition:color var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);font-size:.9rem;position:relative}.nav-links a{font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;font-size:.72rem}.nav-links a:after,.text-link:after{background:var(--accent);content:"";transform-origin:0;height:1px;transition:transform var(--motion-fast) var(--motion-ease);width:100%;position:absolute;bottom:-4px;left:0;transform:scaleX(0)}.nav-links a:hover,.nav-links a:focus-visible,.text-link:hover,.text-link:focus-visible{color:var(--foreground)}.nav-links a:hover:after,.nav-links a:focus-visible:after,.text-link:hover:after,.text-link:focus-visible:after{transform:scaleX(1)}.nav-links a[aria-current=page]{color:var(--foreground)}.nav-links a[aria-current=page]:after{transform:scaleX(1)}.icon-button{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);cursor:pointer;height:38px;transition:border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);justify-content:center;align-items:center;width:38px;display:inline-flex}.theme-toggle{grid-area:theme}.icon-button:hover,.icon-button:focus-visible{border-color:var(--accent);color:var(--accent-strong);transform:translateY(-1px)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.page-shell{counter-reset:section;max-width:var(--max-width);margin:0 auto;padding:clamp(44px,7vw,92px) clamp(18px,4vw,42px)}.compact-page{max-width:780px}.hero{animation:fade-up-in var(--motion-slow) var(--motion-ease) both;grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);gap:40px;min-height:360px;display:grid;position:relative}.hero>div{z-index:1;position:relative}.hero>div:first-of-type{align-content:center}.hero-seal{background:var(--accent-seal);box-shadow:0 3px 14px color-mix(in srgb, var(--accent-seal) 35%, transparent);color:#fdf6ec;font-family:var(--font-serif-stack);height:48px;transition:transform var(--motion-fast) var(--motion-ease);-webkit-user-select:none;user-select:none;border-radius:3px;justify-content:center;align-items:center;width:48px;margin-top:28px;font-size:1.5rem;font-weight:700;display:inline-flex;transform:rotate(-2.5deg)}.hero-seal:hover{transform:rotate(-1deg)scale(.96)}.eyebrow{color:var(--accent-seal);font-family:var(--font-mono-stack);letter-spacing:.18em;text-transform:uppercase;align-items:center;gap:10px;margin:0 0 14px;font-size:.7rem;font-weight:400;display:flex}.eyebrow:before{background:color-mix(in srgb, var(--accent-seal) 65%, transparent);content:"";width:22px;height:1px}.section .eyebrow:before{color:color-mix(in srgb, var(--accent-seal) 70%, var(--foreground));content:counter(section, decimal-leading-zero);counter-increment:section;letter-spacing:.08em;background:0 0;width:auto;height:auto}h1,h2,h3,p{margin-top:0}h1{font-family:var(--font-serif-stack);letter-spacing:.01em;text-wrap:balance;margin-bottom:22px;font-size:clamp(2.45rem,5vw,3.45rem);font-weight:600;line-height:1.14}h2{font-family:var(--font-serif-stack);text-wrap:balance;margin-bottom:18px;font-size:1.55rem;font-weight:600;line-height:1.3}h3{font-family:var(--font-serif-stack);font-size:1.06rem;font-weight:600;line-height:1.45}.lead{color:var(--muted);text-wrap:pretty;max-width:650px;font-size:1.06rem}.section{animation:fade-up-in var(--motion-slow) var(--motion-ease) both;margin-top:64px;animation-delay:80ms}.page-shell>.section:nth-child(3){animation-delay:.16s}.page-shell>.section:nth-child(4){animation-delay:.24s}.section-header{border-top:1px solid var(--border);justify-content:space-between;align-items:baseline;gap:18px;margin-bottom:22px;padding-top:18px;display:flex}.section-header h2{margin-bottom:0}.section-header p{color:var(--muted);margin:0}.section-header .text-link{font-family:var(--font-mono-stack);letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;font-size:.7rem}.section-header .text-link:after{content:"→";height:auto;transition:transform var(--motion-fast) var(--motion-ease);background:0 0;width:auto;margin-left:8px;display:inline-block;position:static;transform:none}.section-header .text-link:hover:after,.section-header .text-link:focus-visible:after{transform:translate(4px)}.content-grid,.featured-grid{gap:14px;display:grid}.content-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.featured-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.entry-card,.content-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--motion-standard) var(--motion-ease), box-shadow var(--motion-standard) var(--motion-ease), transform var(--motion-standard) var(--motion-ease);overflow:hidden}.entry-card:hover,.entry-card:focus-visible,.content-card:hover,.content-card:focus-within{border-color:color-mix(in srgb, var(--accent) 72%, var(--border));box-shadow:var(--shadow);transform:translateY(-3px)}.entry-card{-webkit-backdrop-filter:blur(22px)saturate(1.5);background:color-mix(in srgb, var(--surface) 80%, transparent);box-shadow:inset 0 1px 0 var(--glass-highlight);grid-template-columns:auto minmax(0,1fr);align-content:center;gap:4px 16px;padding:15px 44px 15px 18px;display:grid;position:relative}.entry-card:hover,.entry-card:focus-visible{box-shadow:inset 0 1px 0 var(--glass-highlight), var(--shadow)}.entry-card:before{color:var(--accent-seal);content:counter(entry, decimal-leading-zero);counter-increment:entry;font-family:var(--font-mono-stack);letter-spacing:.08em;grid-area:1/1/span 2;padding-top:5px;font-size:.72rem}.entry-card:after{color:var(--muted);content:"↗";font-family:var(--font-mono-stack);transition:color var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);font-size:.9rem;position:absolute;top:13px;right:16px}.entry-card:hover:after,.entry-card:focus-visible:after{color:var(--accent-strong);transform:translate(2px,-2px)}.entry-card span{font-family:var(--font-serif-stack);grid-column:2;font-size:1.05rem;font-weight:600;line-height:1.35}.entry-card p{color:var(--muted);grid-column:2;margin:0;font-size:.88rem}.card-link{height:100%;display:grid}.card-media{aspect-ratio:16/10;background:linear-gradient(150deg, color-mix(in srgb, var(--accent) 22%, transparent), color-mix(in srgb, var(--accent-seal) 10%, transparent) 55%, transparent), var(--surface-raised);border-bottom:1px solid var(--border);position:relative;overflow:hidden}.card-media img,.media-fallback{filter:saturate(.95);object-fit:cover;height:100%;transition:filter var(--motion-slow) var(--motion-ease), transform var(--motion-slow) var(--motion-ease);width:100%}.content-card:hover .card-media img,.content-card:focus-within .card-media img{filter:saturate(1.04);transform:scale(1.035)}.media-fallback{display:block}.card-body{gap:10px;padding:16px;display:grid}.card-meta{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;flex-wrap:wrap;gap:12px;font-size:.68rem;display:flex}.content-card h3{margin:0}.content-card p{color:var(--muted);margin:0;font-size:.9rem}.project-card{background:var(--surface-deep)}.project-card .card-body{background:var(--surface)}.tag-list{flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.tag-list li{border:1px solid var(--border);color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.1em;text-transform:uppercase;border-radius:2px;padding:4px 6px;font-size:.64rem;line-height:1}.list-stack{border-top:1px solid var(--border)}.list-item{border-bottom:1px solid var(--border);transition:border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);flex-wrap:wrap;align-items:baseline;gap:4px 16px;padding:17px 0;display:flex}.list-item:hover,.list-item:focus-visible{border-color:var(--accent);color:var(--foreground);transform:translate(3px)}.list-item strong{font-family:var(--font-serif-stack);flex:auto;order:1;align-items:baseline;gap:14px;min-width:min(100%,260px);font-size:1.04rem;font-weight:600;display:flex}.list-item strong:after{border-bottom:1px dotted color-mix(in srgb, var(--muted) 40%, transparent);content:"";flex:36px;min-width:36px;transform:translateY(-4px)}.list-item time{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.1em;order:2;font-size:.74rem}.list-item span{color:var(--muted);order:3;width:100%;font-size:.9rem}.empty-state{border:1px dashed var(--border);border-radius:var(--radius);color:var(--muted);padding:22px;font-size:.92rem}.search-panel-compact{background:0 0;border:0;margin-top:0;padding:0;position:relative}.search-trigger{background:0 0}.search-panel-compact .search-popover{animation:popover-in var(--motion-standard) var(--motion-ease) both;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transform-origin:100% 0;z-index:35;width:min(420px,100vw - 36px);padding:12px;position:absolute;top:calc(100% + 10px);right:0}.search-panel-compact .empty-state{background:var(--surface);margin-top:14px;padding:14px}.search-panel-compact .search-field{gap:7px}.search-panel-compact .search-field span{white-space:nowrap;font-size:.68rem;font-weight:400;line-height:1}.search-panel-compact .search-field input{background:var(--surface);min-height:38px;padding:8px 10px}.search-panel-compact .search-results{max-height:min(360px,100vh - 132px);margin-top:8px;padding:0 12px;overflow:auto}.search-panel-compact .search-results li:first-child{border-top:0}.search-field{gap:8px;display:grid}.search-field span{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;font-size:.72rem}.search-field input{background:var(--background);border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground);outline:none;min-height:44px;padding:10px 12px}.search-field input:focus{border-color:var(--accent)}.search-field input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.search-results{gap:0;margin:18px 0 0;padding:0;list-style:none;display:grid}.search-results li{border-top:1px solid var(--border)}.search-results a{gap:5px;padding:14px 0;display:grid}.search-results span{color:var(--accent-seal);font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;font-size:.66rem;font-weight:400}.search-results p{color:var(--muted);margin:0;font-size:.9rem}.site-footer{border-top:1px solid var(--border);color:var(--muted);justify-content:space-between;align-items:center;gap:12px;padding:34px clamp(18px,4vw,42px);font-size:.84rem;display:flex}.footer-brand{gap:6px;display:grid}.footer-brand span:first-child{color:var(--foreground);font-family:var(--font-serif-stack);letter-spacing:.01em;font-size:1rem;font-weight:600}.footer-brand span:last-child{font-size:.82rem}.footer-links{font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;flex-wrap:wrap;align-items:center;gap:18px;font-size:.7rem;display:flex}.footer-links a{transition:color var(--motion-fast) var(--motion-ease)}.footer-links a:hover,.footer-links a:focus-visible{color:var(--foreground)}.prose{color:var(--foreground);max-width:720px;font-size:1.02rem;line-height:1.85}.prose p,.prose li{color:color-mix(in srgb, var(--foreground) 86%, var(--muted))}.prose p{text-wrap:pretty;margin:0 0 1.45em}.prose a{color:var(--accent-strong);text-decoration:underline;-webkit-text-decoration-color:color-mix(in srgb, var(--accent-strong) 45%, transparent);text-decoration-color:color-mix(in srgb, var(--accent-strong) 45%, transparent);text-underline-offset:4px;transition:text-decoration-color var(--motion-fast) var(--motion-ease)}.prose a:hover,.prose a:focus-visible{-webkit-text-decoration-color:var(--accent-strong);text-decoration-color:var(--accent-strong)}.prose h2,.prose h3{scroll-margin-top:96px}.prose h2{margin:2.4em 0 .9em;font-size:1.5rem}.prose h3{margin:2em 0 .8em;font-size:1.15rem}.prose blockquote{border-left:2px solid var(--accent-seal);color:color-mix(in srgb, var(--foreground) 78%, var(--muted));font-family:var(--font-serif-stack);margin:28px 0;padding:2px 0 2px 20px;font-size:1.04rem}.prose hr{background:var(--border);border:0;width:72px;height:1px;margin:40px auto}.prose table{border-collapse:collapse;width:100%;margin:24px 0;display:block;overflow-x:auto}.prose th{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.12em;text-align:left;text-transform:uppercase;font-size:.72rem;font-weight:400}.prose th,.prose td{border-bottom:1px solid var(--border);padding:10px 14px 10px 0}.prose pre,.prose figure[data-rehype-pretty-code-figure]{border:1px solid var(--border);border-radius:var(--radius);background:#0d0f0b;margin:24px 0;padding:16px;position:relative;overflow:auto}:root[data-theme=light] .prose pre,:root[data-theme=light] .prose figure[data-rehype-pretty-code-figure]{background:#f7f4ea}.prose code{font-family:var(--font-mono-stack);font-size:.88em}.prose :not(pre)>code{background:color-mix(in srgb, var(--surface-raised) 80%, transparent);border:1px solid var(--border);border-radius:3px;padding:2px 5px;font-size:.84em}.code-copy-button{background:var(--surface-raised);border:1px solid var(--border);color:var(--muted);cursor:pointer;font-family:var(--font-mono-stack);letter-spacing:.08em;border-radius:3px;padding:5px 8px;font-size:.7rem;position:absolute;top:10px;right:10px}.callout,.comparison,.pros-cons{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin:22px 0;padding:16px}.callout{border-left:3px solid var(--accent)}.callout[data-tone=warning]{border-left-color:var(--danger)}.callout[data-tone=success]{border-left-color:var(--accent-cool)}.steps{counter-reset:steps;padding-left:0;list-style:none}.steps li{border-left:1px solid var(--border);counter-increment:steps;margin-left:12px;padding:0 0 18px 22px;position:relative}.steps li:before{background:var(--accent);color:var(--background);content:counter(steps);font-family:var(--font-mono-stack);border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:700;display:inline-flex;position:absolute;top:0;left:-12px}.comparison,.pros-cons{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.reading-progress{background:color-mix(in srgb, var(--background) 70%, transparent);z-index:40;height:2px;position:fixed;top:0;left:0;right:0}.reading-progress span{background:linear-gradient(90deg, var(--accent-seal), var(--accent));transform-origin:0;height:100%;transition:none;display:block}.hero-entry-grid{counter-reset:entry;grid-template-rows:repeat(3,minmax(0,1fr));grid-template-columns:1fr;align-self:stretch;gap:10px;display:grid}.hero .lead{margin-bottom:0}.page-list-header{border-bottom:1px solid var(--border);border-top:0;align-items:baseline;margin-bottom:34px;padding-top:0;padding-bottom:22px}.page-list-header p:not(.eyebrow){color:var(--muted);margin:0}.page-list-count{font-family:var(--font-mono-stack);letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;font-size:.7rem}.page-list-count span{color:var(--accent-seal)}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.article-shell{--article-body-width:720px;--article-side-width:220px;--article-layout-gap:42px;max-width:1328px}.project-shell{max-width:1120px}.article-header{border-bottom:1px solid var(--border);max-width:var(--article-body-width);margin:0 auto 40px;padding-bottom:28px}.article-header h1{font-size:clamp(2rem,3.6vw,2.7rem);line-height:1.22}.article-meta{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.12em;text-transform:uppercase;flex-wrap:wrap;gap:14px;font-size:.74rem;display:flex}.article-layout{align-items:start;gap:var(--article-layout-gap);grid-template-areas:"toc prose spacer";grid-template-columns:minmax(0, 1fr) minmax(0, var(--article-body-width)) minmax(0, 1fr);justify-content:center;display:grid}.article-layout>.prose{grid-area:prose;width:100%}.toc-panel{border-left:1px solid var(--border);color:var(--muted);min-width:0;width:min(100%, var(--article-side-width));grid-area:toc;justify-self:end;padding-left:14px;font-size:.84rem;position:sticky;top:100px}.toc-details summary{color:var(--foreground);cursor:pointer;font-family:var(--font-serif-stack);align-items:center;gap:8px;margin-bottom:10px;font-size:.92rem;font-weight:600;list-style:none;display:flex}.toc-details summary::-webkit-details-marker{display:none}.toc-details summary:before{color:var(--accent-seal);content:"▸";font-family:var(--font-mono-stack);transition:transform var(--motion-fast) var(--motion-ease);font-size:.8rem}.toc-details[open] summary:before{transform:rotate(90deg)}.toc-panel ol{gap:8px;margin:0;padding:0;list-style:none;display:grid}.toc-panel li[data-depth="3"]{padding-left:12px}.toc-panel a{transition:color var(--motion-fast) var(--motion-ease)}.toc-panel a:hover{color:var(--accent-strong)}.toc-panel a[aria-current=location]{color:var(--accent-strong);font-weight:600}.project-hero{grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);align-items:end;gap:28px;margin-bottom:26px;display:grid}.project-cover{aspect-ratio:16/10;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);position:relative;overflow:hidden}.project-cover img{object-fit:cover}.project-meta-grid{border-bottom:1px solid var(--border);border-top:1px solid var(--border);grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin:0 0 32px;display:grid}.project-meta-grid div{border-right:1px solid var(--border);padding:14px}.project-meta-grid div:last-child{border-right:0}.project-meta-grid dt{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;font-size:.68rem}.project-meta-grid dd{margin:4px 0 0}.project-links{flex-wrap:wrap;gap:10px;margin-bottom:30px;display:flex}.project-links a{border:1px solid var(--border);border-radius:var(--radius);color:var(--accent-strong);font-family:var(--font-mono-stack);letter-spacing:.08em;transition:border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);padding:8px 10px;font-size:.78rem}.project-links a:hover,.project-links a:focus-visible{border-color:var(--accent);color:var(--foreground);transform:translate(3px)}.project-prose{margin:0 auto}.photo-gallery{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.photo-card{background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--motion-standard) var(--motion-ease), box-shadow var(--motion-standard) var(--motion-ease), transform var(--motion-standard) var(--motion-ease);display:block;overflow:hidden}.photo-card:hover,.photo-card:focus-visible{border-color:color-mix(in srgb, var(--accent) 72%, var(--border));box-shadow:var(--shadow);transform:translateY(-3px)}.photo-card-media{aspect-ratio:4/5;position:relative;overflow:hidden}.photo-card-media img{object-fit:cover;height:100%;transition:transform var(--motion-slow) var(--motion-ease);width:100%}.photo-card:hover .photo-card-media img,.photo-card:focus-visible .photo-card-media img{transform:scale(1.04)}.photo-card-overlay{color:#f4f0e8;opacity:0;transition:opacity var(--motion-standard) var(--motion-ease);background:linear-gradient(#08080600,#080806d1);gap:4px;padding:16px 14px 14px;display:grid;position:absolute;bottom:0;left:0;right:0}.photo-card:hover .photo-card-overlay,.photo-card:focus-visible .photo-card-overlay{opacity:1}.photo-card-overlay strong{font-family:var(--font-serif-stack);font-size:.98rem;font-weight:600}.photo-card-overlay span{color:#c8c5b8;font-family:var(--font-mono-stack);letter-spacing:.1em;font-size:.72rem}.photo-shell{max-width:960px}.photo-shell>.text-link{margin-bottom:20px;display:inline-block}.photo-detail-figure{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:28px;overflow:hidden}.photo-detail-figure img{width:100%;height:auto}.photo-detail-header{max-width:720px;margin:0 auto}.photo-meta{border-top:1px solid var(--border);flex-wrap:wrap;gap:28px;margin:22px 0 0;padding-top:18px;display:flex}.photo-meta dt{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;font-size:.68rem}.photo-meta dd{margin:4px 0 0}.photo-meta+.tag-list{margin-top:20px}.photo-prose{margin:28px auto 0}.post-pagination{max-width:var(--article-body-width);grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:48px auto 0;display:grid}.pagination-link{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--motion-standard) var(--motion-ease), box-shadow var(--motion-standard) var(--motion-ease), transform var(--motion-standard) var(--motion-ease);gap:6px;padding:16px;display:grid}.pagination-link:hover,.pagination-link:focus-visible{border-color:color-mix(in srgb, var(--accent) 72%, var(--border));box-shadow:var(--shadow);transform:translateY(-2px)}.pagination-link span{color:var(--muted);font-family:var(--font-mono-stack);letter-spacing:.14em;text-transform:uppercase;font-size:.68rem;font-weight:400}.pagination-link strong{font-family:var(--font-serif-stack);font-size:.98rem;font-weight:600;line-height:1.4}.pagination-link-next{text-align:right}.comments-section{border-top:1px solid var(--border);max-width:var(--article-body-width);margin:56px auto 0;padding-top:30px}.comments-section .section-header{border-top:0;margin-bottom:18px;padding-top:0}.comments-section .section-header p:not(.eyebrow){color:var(--muted);margin:4px 0 0}.giscus-host{min-height:180px}.giscus-host .giscus,.giscus-host .giscus-frame{width:100%}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;animation:none!important}.hero,.section{opacity:1;transform:none}.reading-progress span{transition:none}}@media (max-width:820px){.site-header{grid-template-columns:1fr auto auto;grid-template-areas:"brand search theme""nav nav nav";gap:12px 14px}.nav-links{scrollbar-width:none;justify-content:flex-start;padding-bottom:2px;overflow-x:auto}.nav-links::-webkit-scrollbar{display:none}.header-search{width:auto}.hero,.content-grid,.featured-grid,.project-grid,.article-layout,.project-hero,.project-meta-grid,.comparison,.pros-cons{grid-template-columns:1fr}.hero{min-height:auto}.hero-entry-grid{grid-template-rows:none}.article-layout{grid-template-areas:"toc""prose"}.toc-panel{justify-self:stretch;width:100%;position:static}.project-meta-grid div{border-bottom:1px solid var(--border);border-right:0}h1{font-size:2.35rem}.section-header,.site-footer{flex-direction:column;align-items:flex-start}.post-pagination{grid-template-columns:1fr}.pagination-link-next{text-align:left}.photo-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:520px){.site-header{grid-template-columns:minmax(0,1fr) auto auto}.search-panel-compact .search-popover{right:-52px}.photo-gallery{grid-template-columns:1fr}.list-item strong:after{display:none}}
