@tailwind base;@tailwind components;@tailwind utilities;@font-face{font-family:Alibaba PuHuiTi;src:url(/assets/AlibabaPuHuiTi-3-55-Regular.CLF8OQnk.woff2) format("woff2");font-style:normal;font-weight:400;font-display:swap}@font-face{font-family:Alibaba PuHuiTi;src:url(/assets/AlibabaPuHuiTi-3-55-Regular.CLF8OQnk.woff2) format("woff2");font-style:normal;font-weight:500;font-display:swap}@font-face{font-family:Alibaba PuHuiTi;src:url(/assets/AlibabaPuHuiTi-3-85-Bold.xfjIV0-H.woff2) format("woff2");font-style:normal;font-weight:700;font-display:swap}:root{--bg: #0A0A08;--bg-2: #111110;--bg-3: #181816;--bg-hover: #1E1E1B;--text: #E0DCD3;--text-2: #666260;--text-3: #323130;--border: #1C1C1A;--border-2: #282825;--accent: #C8A96E;--accent-2: #DFC080;--accent-bg: rgba(200, 169, 110, .07);--tag-bg: #181816;--tag-text: #5A5855;--font-logo: "Syne", "PingFang SC", "Microsoft YaHei", sans-serif;--app-font-logo: var(--font-logo);--font-display: "Alibaba PuHuiTi", "PingFang SC", "Microsoft YaHei", sans-serif;--font-sans: "Alibaba PuHuiTi", "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono: "Alibaba PuHuiTi", "PingFang SC", "Microsoft YaHei", sans-serif;--max-w: 1100px;--content-w: 740px;--transition: .2s cubic-bezier(.22, 1, .36, 1);--radius: 4px}[data-theme=light]{--bg: #FAFAF8;--bg-2: #F3F2F0;--bg-3: #ECEAE7;--bg-hover: #E5E3DF;--text: #1A1A18;--text-2: #636059;--text-3: #A09D99;--border: #E0DDD8;--border-2: #D4D1CB;--accent: #8B6914;--accent-2: #9E7618;--accent-bg: rgba(139, 105, 20, .09);--tag-bg: #ECEAE7;--tag-text: #7A7773}[data-theme=light] .site-nav .container{background:#fafaf8eb}[data-theme=light] .hero{background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 23px,rgba(0,0,0,.022) 23px,rgba(0,0,0,.022) 24px)}[data-theme=light] .hero-project-backdrop:after{background:linear-gradient(to bottom,#fafaf880,#fafaf8e0)}[data-theme=light] .hero-project-image-layer{filter:saturate(.65) brightness(.9) contrast(.95)}[data-theme=light] .hero-project-code-flash{color:#1c1a1614;text-shadow:none}[data-theme=light] .hero-project-cut-flash{background:#fff}[data-theme=light] .hero-project-noise{background-image:radial-gradient(circle at 22% 18%,rgba(0,0,0,.14) 0 .8px,transparent 1.4px),radial-gradient(circle at 72% 68%,rgba(0,0,0,.1) 0 .9px,transparent 1.6px),radial-gradient(circle at 40% 82%,rgba(0,0,0,.09) 0 .7px,transparent 1.3px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}ul,ol{list-style:none}img{max-width:100%;display:block}body{background-color:var(--bg);color:var(--text);font-family:var(--font-sans);line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px 180px}@keyframes enterPage{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-body{animation:enterPage .5s cubic-bezier(.22,1,.36,1) both}a{color:inherit;text-decoration:none;transition:color var(--transition)}.container{max-width:var(--max-w);margin:0 auto;padding:0 40px}.container--narrow{max-width:var(--content-w);margin:0 auto;padding:0 40px}.site-nav{position:fixed;top:0;left:0;right:0;z-index:200}.site-nav .container{display:flex;align-items:center;justify-content:space-between;height:52px;border-bottom:1px solid var(--border);background:#0a0a08e0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.site-title{color:var(--text);transition:color var(--transition);line-height:1}.site-logo{position:relative;display:inline-block;line-height:1}.site-logo-text{font-family:var(--font-logo);font-weight:800;font-size:16px;letter-spacing:-.04em;color:var(--text);display:block;transition:color var(--transition)}.site-logo-sup{font-family:var(--font-logo);font-size:7px;font-style:normal;color:var(--accent);position:absolute;top:-3px;right:-12px;letter-spacing:.05em;line-height:1}.site-title:hover .site-logo-text{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:32px}.nav-links a{font-family:var(--app-font-logo);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);position:relative;transition:color var(--transition)}.nav-links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width var(--transition)}.nav-links a:hover,.nav-links a.active{color:var(--text)}.nav-links a.active:after,.nav-links a:hover:after{width:100%}.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}.nav-toggle span{display:block;width:20px;height:1px;background:var(--text-2);transition:all var(--transition)}.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg);background:var(--text)}.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);background:var(--text)}.theme-btn{background:none;border:none;cursor:pointer;padding:4px 6px;color:var(--text-2);display:flex;align-items:center;justify-content:center;transition:color var(--transition);flex-shrink:0}.theme-btn:hover{color:var(--text)}.theme-icon{width:14px;height:14px}.site-footer{margin-top:120px;border-top:1px solid var(--border)}.site-footer .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;height:56px}.footer-left{font-size:11px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase}.footer-links{display:flex;gap:24px}.footer-links a{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);transition:color var(--transition)}.footer-links a:hover{color:var(--accent)}.hero{padding-top:52px;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 23px,rgba(255,255,255,.012) 23px,rgba(255,255,255,.012) 24px)}.hero-project-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.95;transition:background .52s cubic-bezier(.22,1,.36,1);overflow:hidden}.hero-project-image-layer{position:absolute;top:-4%;right:-4%;bottom:-4%;left:-4%;z-index:0;background-position:center;background-size:cover;background-repeat:no-repeat;opacity:0;transform:scale(1.06) translateZ(0);transition:opacity .62s cubic-bezier(.22,1,.36,1),transform 1.8s cubic-bezier(.22,1,.36,1);filter:saturate(.9) brightness(.48) contrast(1.04)}.hero-project-image-layer.is-visible{opacity:1;transform:scale(1.01) translateZ(0)}.hero-project-image-layer.layer-a{animation:heroBgDriftA 12s ease-in-out infinite alternate}.hero-project-image-layer.layer-b{animation:heroBgDriftB 13s ease-in-out infinite alternate}@keyframes heroBgDriftA{0%{transform:scale(1.04) translate3d(-8px,-4px,0)}to{transform:scale(1.08) translate3d(10px,6px,0)}}@keyframes heroBgDriftB{0%{transform:scale(1.05) translate3d(9px,-6px,0)}to{transform:scale(1.09) translate3d(-7px,8px,0)}}.hero-project-backdrop:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:linear-gradient(to bottom,#0a0a089e,#0a0a08e0)}.hero-project-noise{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;opacity:.12;mix-blend-mode:soft-light;background-image:radial-gradient(circle at 22% 18%,rgba(255,255,255,.23) 0 .8px,transparent 1.4px),radial-gradient(circle at 72% 68%,rgba(255,255,255,.16) 0 .9px,transparent 1.6px),radial-gradient(circle at 40% 82%,rgba(255,255,255,.15) 0 .7px,transparent 1.3px);background-size:170px 170px,220px 220px,140px 140px;animation:heroNoiseMove 3.2s steps(8,end) infinite}.hero-project-cut-flash{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;background:#000;pointer-events:none;opacity:0;animation:heroCutFlash .12s steps(2,end) both}.hero-project-code-flash{position:absolute;right:32px;top:24%;z-index:4;font-family:var(--font-logo);font-size:clamp(60px,13vw,210px);font-weight:800;line-height:.9;letter-spacing:-.03em;text-transform:uppercase;color:#e0dcd342;text-shadow:0 0 42px rgba(224,220,211,.14);pointer-events:none;animation:heroProjectCodeFlash .76s cubic-bezier(.22,1,.36,1) both}.hero-project-desc{position:absolute;left:40px;right:40px;bottom:136px;z-index:5;max-width:min(820px,90%);font-family:var(--font-display);font-size:clamp(20px,4vw,52px);font-weight:700;line-height:1.14;letter-spacing:-.02em;color:#e0dcd32e;text-wrap:balance;animation:heroProjectFade .42s ease both}@keyframes heroProjectFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes heroProjectCodeFlash{0%{opacity:0;transform:translate3d(0,14px,0) scale(1.04);filter:blur(1.5px)}38%{opacity:.4;transform:translateZ(0) scale(1);filter:blur(0)}to{opacity:.12;transform:translate3d(0,-4px,0) scale(.995);filter:blur(0)}}@keyframes heroNoiseMove{0%{transform:translateZ(0)}25%{transform:translate3d(-1%,1%,0)}50%{transform:translate3d(.8%,-.8%,0)}75%{transform:translate3d(-.6%,.5%,0)}to{transform:translateZ(0)}}@keyframes heroCutFlash{0%{opacity:0}28%{opacity:.36}58%{opacity:.08}to{opacity:0}}.hero-corners{position:absolute;top:72px;left:0;right:0;padding:0 40px;display:flex;justify-content:space-between;align-items:flex-start}.hero-corner-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);line-height:1.8}.hero-corner-label span{display:block;color:var(--text-2)}.hero-display-wrap{padding:0 40px;position:relative;z-index:2}.hero-display{font-family:var(--font-logo);font-weight:800;font-size:clamp(72px,13vw,180px);line-height:.92;letter-spacing:-.04em;color:var(--text);-webkit-user-select:none;user-select:none;text-shadow:0 0 120px rgba(200,169,110,.08)}.hero-display-sub{font-family:var(--font-display);font-weight:400;font-size:clamp(14px,2vw,20px);letter-spacing:.01em;color:var(--text-2);margin-top:16px;max-width:440px;line-height:1.65}.hero-bottom{margin-top:48px;padding:24px 40px 48px;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;border-top:1px solid var(--border-2);position:relative;z-index:2}.hero-stats{display:flex;align-items:center;gap:32px}.hero-stat{display:flex;flex-direction:column;gap:3px}.hero-stat-val{font-family:var(--font-display);font-weight:700;font-size:24px;color:var(--text);letter-spacing:-.03em;line-height:1}.hero-stat-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}.hero-scroll{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);display:flex;align-items:center;gap:8px}.hero-scroll:before{content:"";display:block;width:32px;height:1px;background:var(--text-3)}.hero-projects{padding:0 40px;margin-top:52px;position:relative;z-index:2}.hero-project-entry{display:grid;grid-template-columns:56px 1fr 52px 76px;align-items:center;gap:0 16px;padding:10px 0;border-top:1px solid var(--border);text-decoration:none;transition:background var(--transition)}.hero-project-entry:last-child{border-bottom:1px solid var(--border)}.hpe-no{font-family:var(--font-logo);font-size:10px;font-weight:600;letter-spacing:.1em;color:var(--text-3)}.hpe-name{font-family:var(--font-logo);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-2);transition:color var(--transition)}.hero-project-entry:hover .hpe-name{color:var(--text)}.hpe-year{font-family:var(--font-logo);font-size:10px;font-weight:600;color:var(--text-3);text-align:right}.hpe-status{font-family:var(--font-logo);font-size:10px;font-weight:700;letter-spacing:.1em;text-align:right}.section-hd{display:flex;align-items:center;justify-content:space-between;padding:56px 0 0;margin-bottom:32px;border-top:1px solid var(--border)}.section-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-2)}.section-more{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);transition:color var(--transition);display:flex;align-items:center;gap:6px}.section-more:hover{color:var(--accent)}.section-more:after{content:"→"}.featured-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.featured-card{display:block;padding:22px 24px;border-right:1px solid var(--border);background:var(--bg-2);text-decoration:none;transition:background var(--transition);position:relative}.featured-card:last-child{border-right:none}.featured-card:hover{background:var(--bg-3)}.featured-card:after{content:"→";position:absolute;top:22px;right:24px;font-size:12px;color:var(--text-3);transition:color var(--transition),transform var(--transition)}.featured-card:hover:after{color:var(--accent);transform:translate(3px,-2px)}.featured-badge{display:inline-block;font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.fc-meta{font-size:11px;color:var(--text-3);letter-spacing:.04em;margin-bottom:8px;font-family:var(--font-mono)}.fc-title{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--text);line-height:1.45;margin-bottom:8px;transition:color var(--transition)}.featured-card:hover .fc-title{color:var(--accent)}.fc-excerpt{font-size:12px;color:var(--text-2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-item{border-bottom:1px solid var(--border)}.article-item:first-child{border-top:1px solid var(--border)}.article-item-link{display:block;padding:22px 0;text-decoration:none;color:inherit;transition:padding-left var(--transition);cursor:pointer}.article-item-link:hover{padding-left:8px}.article-list--indexed .article-item-link{display:grid;grid-template-columns:48px 1fr auto;gap:0 28px;align-items:center}.ai-num{font-family:var(--font-mono);font-size:11px;color:var(--text-3);letter-spacing:.06em;transition:color var(--transition);padding-top:3px;align-self:flex-start}.article-item-link:hover .ai-num{color:var(--accent)}.ai-main{min-width:0}.a-meta{display:flex;align-items:center;gap:8px;margin-bottom:5px}.a-date{font-family:var(--font-mono);font-size:11px;color:var(--text-3);letter-spacing:.04em}.a-sep{width:2px;height:2px;border-radius:50%;background:var(--text-3);flex-shrink:0}.a-cat{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);padding:2px 7px;border-radius:2px;font-family:var(--font-mono)}.a-title{font-family:var(--font-display);font-weight:700;font-size:clamp(16px,2.2vw,22px);color:var(--text);line-height:1.3;letter-spacing:-.02em;margin-bottom:5px;transition:color var(--transition)}.article-item-link:hover .a-title{color:var(--accent)}.a-excerpt{font-size:13px;color:var(--text-2);line-height:1.65;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.ai-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:100px;flex-shrink:0}.a-tags{display:flex;flex-wrap:wrap;gap:4px}.ai-right .a-tags{justify-content:flex-end}.a-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px}.tag-pill{font-family:var(--font-mono);font-size:10px;color:var(--tag-text);background:var(--tag-bg);border:1px solid var(--border-2);padding:2px 7px;border-radius:2px;letter-spacing:.02em;text-decoration:none;transition:border-color var(--transition),color var(--transition)}.tag-pill:hover{border-color:var(--accent);color:var(--accent)}.a-read-time{font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.04em;white-space:nowrap}.article-page{display:grid;grid-template-columns:1fr 200px;gap:80px;padding:80px 0 120px;align-items:start}.article-header{margin-bottom:48px;padding-bottom:40px;border-bottom:1px solid var(--border)}.article-header .a-cat{display:inline-block;margin-bottom:20px}.article-header h1{font-family:var(--font-display);font-weight:800;font-size:clamp(24px,4vw,42px);line-height:1.2;letter-spacing:-.03em;color:var(--text);margin-bottom:24px}.article-hd-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px 20px}.article-hd-meta span{font-family:var(--font-mono);font-size:11px;color:var(--text-3);letter-spacing:.04em;display:flex;align-items:center;gap:5px}.article-body{font-size:17px;line-height:1.88;color:var(--text)}.article-body h2{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.02em;margin-top:52px;margin-bottom:16px;padding-top:20px;border-top:1px solid var(--border);scroll-margin-top:72px;color:var(--text)}.article-body h3{font-family:var(--font-display);font-weight:600;font-size:17px;margin-top:32px;margin-bottom:12px;scroll-margin-top:72px;color:var(--text)}.article-body p{margin-bottom:20px}.article-body ul,.article-body ol{padding-left:22px;margin:16px 0 20px;list-style:revert}.article-body li{margin-bottom:6px}.article-body code{font-family:var(--font-mono);font-size:.83em;background:var(--bg-3);border:1px solid var(--border-2);padding:1px 6px;border-radius:3px;color:var(--accent)}.article-body pre{background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);padding:24px;overflow-x:auto;margin:24px 0}.article-body pre code{background:none;border:none;padding:0;font-size:13px;line-height:1.7;color:var(--text)}.article-body blockquote{border-left:2px solid var(--accent);padding:6px 20px;margin:24px 0;color:var(--text-2);font-style:italic}.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--border-2)}.article-body a:hover{text-decoration-color:var(--accent)}.article-body strong{font-weight:600;color:var(--text)}.article-body img{border-radius:var(--radius);margin:24px 0}.article-body table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px}.article-body th,.article-body td{padding:10px 14px;border:1px solid var(--border-2)}.article-body th{background:var(--bg-2);color:var(--text);font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.article-body td{color:var(--text-2)}.article-sidebar{position:sticky;top:72px}.toc-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:14px}.toc-list{border-left:1px solid var(--border)}.toc-link{display:block;font-family:var(--font-mono);font-size:11.5px;color:var(--text-3);padding:4px 0 4px 14px;margin-left:-1px;border-left:2px solid transparent;line-height:1.5;transition:color var(--transition),border-color var(--transition)}.toc-link:hover{color:var(--text-2)}.toc-link.active{color:var(--accent);border-left-color:var(--accent)}.toc-item--h3 .toc-link{padding-left:26px;font-size:11px}.reading-progress-wrap{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.reading-progress-bar-bg{height:2px;background:var(--border-2);border-radius:1px;overflow:hidden}.reading-progress-bar{height:100%;background:var(--accent);width:0%;transition:width .1s}.article-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:56px;padding-top:36px;border-top:1px solid var(--border)}.article-nav-btn{display:block;padding:18px 20px;border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;transition:border-color var(--transition),background var(--transition);background:var(--bg-2)}.article-nav-btn:hover{border-color:var(--accent);background:var(--accent-bg)}.article-nav-btn--next{text-align:right}.anb-dir{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px}.anb-title{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--text);line-height:1.4}.page-hd{padding:80px 0 36px;border-bottom:1px solid var(--border);margin-bottom:48px}.page-hd-eyebrow{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:14px;display:block}.page-hd-title{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,5vw,52px);letter-spacing:-.04em;line-height:1.05;color:var(--text);margin-bottom:12px}.page-hd-sub{font-size:14px;color:var(--text-2)}.cat-layout{display:grid;grid-template-columns:200px 1fr;gap:56px;align-items:start}.cat-sidebar{position:sticky;top:72px}.cat-sidebar-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:16px}.cat-tree-item{border-bottom:1px solid var(--border)}.cat-tree-link{display:flex;align-items:center;justify-content:space-between;padding:10px 0;font-size:13px;color:var(--text-2);cursor:pointer;transition:color var(--transition);text-decoration:none}.cat-tree-link:hover{color:var(--text)}.cat-tree-link.active{color:var(--accent)}.cat-count{font-family:var(--font-mono);font-size:11px;color:var(--text-3);background:var(--bg-2);padding:1px 7px;border-radius:2px}.cat-children{padding-left:14px}.cat-children .cat-tree-item{border-bottom:1px solid var(--border)}.cat-children .cat-tree-link{font-size:12px;padding:8px 0}.tag-cloud-wrap{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:52px}.tag-cloud-btn{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;border:1px solid var(--border-2);border-radius:var(--radius);background:var(--bg-2);font-family:var(--font-mono);font-size:12px;color:var(--text-2);cursor:pointer;transition:all var(--transition)}.tag-cloud-btn:hover,.tag-cloud-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.tag-cloud-btn .tc-count{font-size:10px;color:var(--text-3);transition:color var(--transition)}.tag-cloud-btn.active .tc-count{color:var(--accent)}.archive-section{margin-bottom:56px}.archive-year-hd{display:flex;align-items:baseline;gap:14px;margin-bottom:28px;padding-bottom:14px;border-bottom:1px solid var(--border)}.archive-year-num{font-family:var(--font-display);font-weight:800;font-size:32px;font-style:italic;color:var(--text);letter-spacing:-.04em}.archive-year-count{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}.archive-month-group{margin-bottom:24px}.archive-month-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px;display:flex;align-items:center;gap:10px}.archive-month-label:after{content:"";flex:1;height:1px;background:var(--border)}.archive-entry{display:flex;align-items:baseline;gap:14px;padding:7px 0;border-bottom:1px solid var(--border)}.archive-entry:last-child{border-bottom:none}.ae-day{font-family:var(--font-mono);font-size:11px;color:var(--text-3);min-width:28px}.ae-title{font-size:14px;color:var(--text);text-decoration:none;transition:color var(--transition);line-height:1.5}.ae-title:hover{color:var(--accent)}.ae-cat{margin-left:auto;font-family:var(--font-mono);font-size:10px;color:var(--text-3);white-space:nowrap}.series-grid{display:flex;flex-direction:column;gap:2px}.series-card{border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px;background:var(--bg-2);transition:border-color var(--transition),background var(--transition)}.series-card:hover{border-color:var(--border-2);background:var(--bg-3)}.series-card-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:8px}.series-name{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--text);line-height:1.35;letter-spacing:-.02em}.series-badge{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--text-3);background:var(--bg-3);border:1px solid var(--border-2);padding:3px 10px;border-radius:2px;white-space:nowrap;flex-shrink:0}.series-desc{font-size:13px;color:var(--text-2);line-height:1.65;margin-bottom:22px}.series-articles-list{border-left:1px solid var(--border-2);padding-left:20px}.series-article-row{display:flex;align-items:center;gap:12px;padding:6px 0}.sar-num{font-family:var(--font-mono);font-size:11px;color:var(--text-3);min-width:22px}.sar-title{font-size:13px;color:var(--text-2);text-decoration:none;transition:color var(--transition)}.sar-title:hover{color:var(--accent)}.sar-date{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--text-3);white-space:nowrap}.about-layout{display:grid;grid-template-columns:1fr 260px;gap:72px;padding-bottom:80px;align-items:start}.about-avatar-wrap{width:64px;height:64px;border-radius:50%;background:var(--bg-3);border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-style:italic;font-size:24px;color:var(--accent);margin-bottom:24px;transition:box-shadow var(--transition);overflow:hidden}.about-avatar-wrap:hover{box-shadow:0 0 0 3px var(--accent-bg)}.about-avatar-wrap img{width:100%;height:100%;object-fit:cover}.about-name{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,5vw,48px);letter-spacing:-.04em;line-height:1.05;color:var(--text);margin-bottom:14px}.about-tagline{font-size:15px;color:var(--text-2);line-height:1.75;max-width:420px;margin-bottom:44px}.about-section{margin-bottom:44px}.about-sec-title{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border)}.about-body{font-size:15px;color:var(--text-2);line-height:1.82}.about-body p{margin-bottom:16px}.about-body p:last-child{margin-bottom:0}.about-body strong{color:var(--text);font-weight:600}.skills-chips{display:flex;flex-wrap:wrap;gap:8px}.skill-chip{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;padding:5px 12px;background:var(--bg-3);border:1px solid var(--border-2);border-radius:2px;color:var(--text-2)}.about-fact-card{border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:12px;background:var(--bg-2)}.afc-title{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin-bottom:14px}.afc-rows{display:flex;flex-direction:column;gap:9px}.afc-row{display:flex;align-items:flex-start;gap:12px;font-size:12px}.afc-row-label{color:var(--text-3);min-width:42px;font-family:var(--font-mono);font-size:11px}.afc-row-val{color:var(--text-2);line-height:1.5}.afc-row-val a{color:var(--accent)}.afc-row-val a:hover{text-decoration:underline}.clock-wrap{position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);width:min(660px,84vmin);height:min(660px,84vmin);-webkit-user-select:none;user-select:none;overflow:visible;z-index:1;pointer-events:none}.clock-wrap .clock-center,.clock-wrap .clock-item{pointer-events:auto}.clock-orbit{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.clock-ring{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.clock-item{position:absolute;top:0;left:0;width:41px;height:55px;pointer-events:auto}.clock-card{width:100%;height:100%;background:var(--bg-3);border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;cursor:pointer;transition:border-color .3s,box-shadow .3s,transform .3s}.clock-card:hover{transform:scale(1.06);border-color:var(--border-2)}.cc-img{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.cc-bg-text{position:absolute;font-family:var(--font-display);font-size:18px;font-weight:800;letter-spacing:-.04em;line-height:1;pointer-events:none;transition:color .3s}.cc-id{font-family:var(--font-mono);font-size:5px;color:#fff3;letter-spacing:.08em;position:absolute;bottom:3px;right:3px}.cc-label{font-family:var(--font-mono);font-size:5.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);padding:3px 4px 2px;border-top:1px solid var(--border);background:var(--bg-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .3s,background .3s}.clock-item.active .clock-card{border-color:var(--accent);box-shadow:0 0 0 1px #c8a96e2e,0 6px 24px #c8a96e1a;transform:scale(1.12)}.clock-item.active .cc-label{color:var(--accent);background:var(--accent-bg)}.clock-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:87px;height:87px;border-radius:50%;border:1px solid var(--border-2);background:var(--bg-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:crosshair;z-index:10;transition:border-color .4s,background .4s,box-shadow .4s}.clock-center:hover{border-color:#c8a96e66;background:var(--bg-3);box-shadow:0 0 32px #c8a96e12}.clock-logo{position:relative;display:inline-block;line-height:1}.clock-logo-text{font-family:var(--font-logo);font-size:18px;font-weight:800;letter-spacing:-.04em;color:var(--text);display:block;transition:color .3s}.clock-center:hover .clock-logo-text{color:var(--accent)}.clock-logo-sup{font-family:var(--font-logo);font-size:6px;font-style:normal;color:var(--accent);position:absolute;top:-1px;right:-10px;letter-spacing:.05em;line-height:1}.project-info{margin-top:72px;min-height:100px}.project-showcase{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:28px;align-items:start}.project-spotlight{position:sticky;top:72px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-2);padding:22px 20px}.pi-inner{display:grid;grid-template-columns:1fr auto;gap:0 40px;align-items:start;border-top:1px solid var(--border);padding-top:24px}@keyframes pi-fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.pi-inner.pi-enter{animation:pi-fade-up .24s ease forwards}.pi-id{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--text-3);margin-bottom:6px}.pi-name{font-family:var(--font-display);font-size:clamp(16px,2vw,24px);font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1.1;margin-bottom:10px}.pi-desc{font-size:12px;color:var(--text-2);line-height:1.7;max-width:480px;margin:0}.pi-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;padding-top:2px}.pi-tech{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:5px}.pi-tag{font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;color:var(--text-2);background:var(--bg-3);border:1px solid var(--border-2);padding:2px 7px;border-radius:2px;white-space:nowrap}.pi-meta{display:flex;align-items:center;gap:8px}.pi-year{font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.06em}.pi-status{font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:2px;border:1px solid var(--border-2);color:var(--text-3)}.pi-detail-link{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--text-3);text-decoration:none;text-transform:uppercase;transition:color .2s}.pi-detail-link:hover{color:var(--accent)}.project-list-minimal{border-top:1px solid var(--border)}.project-row{display:grid;grid-template-columns:68px 1fr auto;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;transition:background var(--transition),padding-left var(--transition)}.project-row:hover{padding-left:8px;background:linear-gradient(90deg,rgba(255,255,255,.02),transparent 55%)}.project-row-year{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--text-3)}.project-row-name{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text);letter-spacing:-.01em;line-height:1.35}.project-row-status{font-family:var(--font-mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:2px;border:1px solid var(--border-2);color:var(--text-3);justify-self:end}.project-row-more .project-row-name{color:var(--accent)}.empty-state{text-align:center;padding:72px 0;color:var(--text-3);font-size:14px;font-family:var(--font-mono);letter-spacing:.04em}.empty-state-icon{font-size:28px;margin-bottom:12px;opacity:.5}.breadcrumb{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);display:flex;align-items:center;gap:8px;margin-bottom:32px}.breadcrumb a{color:var(--text-3);transition:color var(--transition)}.breadcrumb a:hover{color:var(--accent)}.breadcrumb-sep{color:var(--text-3)}@media (max-width: 960px){.article-page{grid-template-columns:1fr;gap:0}.article-sidebar{display:none}.about-layout{grid-template-columns:1fr;gap:40px}.featured-grid{grid-template-columns:repeat(2,1fr)}.featured-card:nth-child(2n){border-right:none}.featured-card:nth-child(n+3){border-top:1px solid var(--border)}}@media (max-width: 768px){.container,.container--narrow{padding:0 20px}.nav-links{display:none}.nav-toggle{display:flex}.nav-links.open{display:flex;flex-direction:column;align-items:flex-start;position:absolute;top:52px;left:0;right:0;background:var(--bg-2);border-bottom:1px solid var(--border);padding:16px 20px 20px;gap:16px;z-index:99}.hero-corners{padding:0 20px}.hero-project-code-flash{right:18px;top:20%;font-size:clamp(50px,20vw,120px)}.hero-project-desc{left:20px;right:20px;bottom:170px;font-size:clamp(18px,6vw,30px)}.hero-display-wrap{padding:0 20px}.hero-projects{padding:0 20px;margin-top:36px}.hero-project-entry{grid-template-columns:48px 1fr 52px;gap:0 12px}.hpe-year{display:none}.hero-bottom{padding:24px 20px 40px;flex-direction:column;align-items:flex-start;gap:20px}.section-hd{padding-top:36px;margin-bottom:20px}.cat-layout{grid-template-columns:1fr}.cat-sidebar{position:static}.article-nav{grid-template-columns:1fr}.article-nav-btn--next{text-align:left}.article-list--indexed .article-item-link{grid-template-columns:32px 1fr}.ai-right,.archive-entry .ae-cat{display:none}.site-footer .container{flex-direction:column;align-items:flex-start;height:auto;padding:20px 0}.pi-meta{flex-wrap:wrap}}@media (max-width: 640px){.clock-wrap{width:min(380px,88vmin);height:min(380px,88vmin)}.project-showcase{grid-template-columns:1fr;gap:16px}.project-spotlight{position:static}.project-row{grid-template-columns:56px 1fr auto}.pi-inner{grid-template-columns:1fr;gap:16px}.pi-right{align-items:flex-start}.pi-tech{justify-content:flex-start}.featured-grid{grid-template-columns:1fr}.featured-card{border-right:none}.featured-card+.featured-card{border-top:1px solid var(--border)}}@media (max-width: 480px){.hero-display{font-size:16vw}.a-title{font-size:16px}.hero-stats{flex-wrap:wrap;gap:20px}.hero-project-entry{grid-template-columns:1fr 52px;gap:0 8px}.hpe-no{display:none}}.hero[data-v-749107ff]{position:relative;overflow:hidden}.th-canvas[data-v-749107ff]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.home-section[data-v-749107ff]{margin-top:80px}@media (max-width: 768px){.home-section[data-v-749107ff]{margin-top:52px}.project-info[data-v-749107ff]{margin-top:40px}}@media (max-width: 480px){.home-section[data-v-749107ff]{margin-top:36px}}.pj-page[data-v-f287e24c]{--proj-accent: hsl(var(--proj-hue), 55%, 58%);--proj-glow-start: hsl(var(--proj-hue), 60%, 20%)}.pj-fullscreen[data-v-f287e24c]{min-height:100svh;display:flex;align-items:center;justify-content:center}.pj-hero[data-v-f287e24c]{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 23px,rgba(255,255,255,.012) 23px,rgba(255,255,255,.012) 24px)}[data-theme=light] .pj-hero[data-v-f287e24c]{background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 23px,rgba(0,0,0,.022) 23px,rgba(0,0,0,.022) 24px)}.pj-hero-glow[data-v-f287e24c]{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse 70% 55% at 60% 30%,var(--proj-glow-start) 0%,transparent 70%);opacity:.5}[data-theme=light] .pj-hero-glow[data-v-f287e24c]{background:radial-gradient(ellipse 70% 55% at 60% 30%,hsl(var(--proj-hue),60%,88%) 0%,transparent 70%);opacity:.6}.pj-ghost[data-v-f287e24c]{position:absolute;right:-2%;top:14%;font-family:var(--font-logo);font-size:clamp(80px,18vw,260px);font-weight:800;line-height:.88;letter-spacing:-.05em;text-transform:uppercase;color:var(--proj-accent);opacity:.07;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap}.pj-hero-top[data-v-f287e24c]{position:absolute;top:72px;left:0;right:0;padding:0 40px;display:flex;justify-content:space-between;align-items:center;z-index:2}.pj-back[data-v-f287e24c]{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--text-3);text-decoration:none;transition:color var(--transition)}.pj-back[data-v-f287e24c]:hover{color:var(--text)}.pj-hero-no[data-v-f287e24c]{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;color:var(--text-3);text-transform:uppercase}.pj-hero-body[data-v-f287e24c]{padding:0 40px;position:relative;z-index:2;margin-bottom:8px}.pj-name[data-v-f287e24c]{font-family:var(--font-logo);font-weight:800;font-size:clamp(40px,8vw,100px);letter-spacing:-.04em;line-height:.95;color:var(--text);margin-bottom:20px}.pj-desc[data-v-f287e24c]{font-size:16px;line-height:1.75;color:var(--text-2);max-width:560px;margin-bottom:28px}.pj-gh-link[data-v-f287e24c]{display:inline-block;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--proj-accent);text-decoration:none;padding:8px 16px;border:1px solid color-mix(in srgb,var(--proj-accent) 35%,transparent);transition:border-color var(--transition),background var(--transition)}.pj-gh-link[data-v-f287e24c]:hover{background:color-mix(in srgb,var(--proj-accent) 10%,transparent);border-color:var(--proj-accent)}.pj-hero-bottom[data-v-f287e24c]{padding:20px 40px 40px;border-top:1px solid var(--border-2);position:relative;z-index:2}.pj-meta-row[data-v-f287e24c]{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.pj-meta-item[data-v-f287e24c]{display:flex;align-items:baseline;gap:8px}.pj-meta-label[data-v-f287e24c]{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;color:var(--text-3)}.pj-meta-val[data-v-f287e24c]{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--text-2);font-weight:600}.pj-meta-sep[data-v-f287e24c]{color:var(--text-3);font-size:12px}.pj-stack-inline[data-v-f287e24c]{font-weight:500}.pj-stack-dot[data-v-f287e24c],.pj-stack-more[data-v-f287e24c]{color:var(--text-3)}.pj-body[data-v-f287e24c]{padding-top:72px;padding-bottom:96px}.pj-section[data-v-f287e24c]{margin-bottom:60px}.pj-section-hd[data-v-f287e24c]{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--border)}.pj-section-label[data-v-f287e24c]{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--text-2);font-weight:600}.pj-section-count[data-v-f287e24c]{font-family:var(--font-mono);font-size:10px;color:var(--text-3);background:var(--bg-3);padding:1px 7px;border-radius:2px}.pj-hl-list[data-v-f287e24c]{display:flex;flex-direction:column}.pj-hl-item[data-v-f287e24c]{display:grid;grid-template-columns:36px 1fr;gap:16px;align-items:baseline;padding:16px 0;border-bottom:1px solid var(--border)}.pj-hl-idx[data-v-f287e24c]{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--proj-accent);font-weight:700;opacity:.75}.pj-hl-text[data-v-f287e24c]{font-size:15px;line-height:1.7;color:var(--text-2)}.pj-tags[data-v-f287e24c]{display:flex;flex-wrap:wrap;gap:8px}.pj-tag[data-v-f287e24c]{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--tag-text);background:var(--tag-bg);padding:5px 12px;border-radius:2px;transition:background var(--transition),color var(--transition)}.pj-tag[data-v-f287e24c]:hover{background:color-mix(in srgb,var(--proj-accent) 12%,var(--tag-bg));color:var(--proj-accent)}@media (max-width: 768px){.pj-hero-top[data-v-f287e24c]{padding:0 20px;top:56px}.pj-hero-body[data-v-f287e24c]{padding:0 20px}.pj-hero-bottom[data-v-f287e24c]{padding:16px 20px 36px}.pj-body[data-v-f287e24c]{padding-top:48px;padding-bottom:64px}.pj-ghost[data-v-f287e24c]{font-size:clamp(64px,22vw,160px);top:10%;right:-4%}}@media (max-width: 480px){.pj-name[data-v-f287e24c]{font-size:clamp(32px,11vw,56px)}.pj-meta-row[data-v-f287e24c]{gap:10px}.pj-hl-item[data-v-f287e24c]{grid-template-columns:28px 1fr;gap:12px}}
