:root{--bg: #f5f5f7;--bg-card: #ffffff;--bg-code: #f0f0f2;--text: #1d1d1f;--text-secondary: #6e6e73;--text-tertiary: #86868b;--accent: #0071e3;--accent-hover: #0077ed;--border: #d2d2d7;--shadow: rgba(0, 0, 0, .04);--header-bg: rgba(245, 245, 247, .72);--max-width: 1080px;--content-width: 720px;--radius: 12px;--radius-sm: 8px;--transition: .3s cubic-bezier(.25, .1, .25, 1)}[data-theme=dark]{--bg: #000000;--bg-card: #1d1d1f;--bg-code: #1d1d1f;--text: #f5f5f7;--text-secondary: #a1a1a6;--text-tertiary: #6e6e73;--accent: #2997ff;--accent-hover: #4dabff;--border: #38383d;--shadow: rgba(0, 0, 0, .2);--header-bg: rgba(0, 0, 0, .72)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:-apple-system,SF Pro Text,SF Pro Display,system-ui,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover)}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{color:var(--text);font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:2.5rem}h2{font-size:1.75rem}h3{font-size:1.375rem}h4{font-size:1.125rem}p{margin-bottom:1rem;color:var(--text-secondary)}blockquote{border-left:3px solid var(--accent);padding:.5rem 1rem;margin:1.5rem 0;background:var(--bg-card);border-radius:0 var(--radius-sm) var(--radius-sm) 0}blockquote p{margin-bottom:0}code{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.875em;background:var(--bg-code);padding:.15em .4em;border-radius:4px}pre{background:var(--bg-code)!important;border-radius:var(--radius-sm);padding:1.25rem;overflow-x:auto;margin:1.5rem 0;border:1px solid var(--border)}pre code{background:none;padding:0;font-size:.85rem;line-height:1.7}hr{border:none;border-top:1px solid var(--border);margin:2rem 0}table{width:100%;border-collapse:collapse;margin:1.5rem 0}th,td{padding:.75rem 1rem;border:1px solid var(--border);text-align:left}th{background:var(--bg-card);font-weight:600}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.content{max-width:var(--content-width);margin:0 auto}.site-header{position:sticky;top:0;z-index:100;background:var(--header-bg);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border)}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;height:52px;display:flex;align-items:center;justify-content:space-between}.site-logo{font-size:1.125rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.site-logo:hover{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:1.5rem;list-style:none}.nav-links a{color:var(--text-secondary);font-size:.875rem;font-weight:400;transition:color var(--transition)}.nav-links a:hover,.nav-links a.active{color:var(--text)}.nav-actions{display:flex;align-items:center;gap:.75rem}.site-footer{border-top:1px solid var(--border);padding:2rem 0;margin-top:4rem}.footer-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;display:flex;justify-content:space-between;align-items:center;color:var(--text-tertiary);font-size:.8125rem}.footer-links{display:flex;gap:1rem;list-style:none}.footer-links a{color:var(--text-tertiary)}.footer-links a:hover{color:var(--text)}.hero{padding:6rem 0 4rem;text-align:center}.hero h1{font-size:3.5rem;font-weight:700;letter-spacing:-.04em;margin-bottom:1rem;background:linear-gradient(135deg,var(--text) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero p{font-size:1.25rem;color:var(--text-secondary);max-width:540px;margin:0 auto;line-height:1.5}.post-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.post-card{background:var(--bg-card);padding:1.5rem 2rem;transition:background var(--transition)}.post-card:hover{background:var(--bg)}.post-card-title{font-size:1.25rem;font-weight:600;margin-bottom:.375rem;letter-spacing:-.01em}.post-card-title a{color:var(--text)}.post-card-title a:hover{color:var(--accent)}.post-card-meta{display:flex;align-items:center;gap:.75rem;font-size:.8125rem;color:var(--text-tertiary);margin-bottom:.5rem}.post-card-desc{color:var(--text-secondary);font-size:.9375rem;line-height:1.5;margin:0}.tag{display:inline-block;padding:.2em .6em;font-size:.75rem;color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);border-radius:4px;font-weight:500;transition:all var(--transition)}.tag:hover{color:#fff;background:var(--accent)}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem}.tag-cloud{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.tag-cloud-item{padding:.5rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:980px;font-size:.9375rem;color:var(--text-secondary);transition:all var(--transition)}.tag-cloud-item:hover{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--bg-card))}.tag-cloud-count{color:var(--text-tertiary);font-size:.8125rem;margin-left:.25rem}.archive-year{margin-bottom:3rem}.archive-year h2{font-size:2rem;font-weight:700;margin-bottom:1.5rem;color:var(--text)}.archive-list{list-style:none}.archive-item{display:flex;align-items:baseline;gap:1.5rem;padding:.75rem 0;border-bottom:1px solid var(--border)}.archive-date{font-size:.875rem;color:var(--text-tertiary);font-variant-numeric:tabular-nums;flex-shrink:0;width:5rem}.archive-title{font-size:1rem;font-weight:500}.archive-title a{color:var(--text)}.archive-title a:hover{color:var(--accent)}.post-header{text-align:center;padding:4rem 0 2rem}.post-header h1{font-size:2.75rem;max-width:800px;margin:0 auto 1rem}.post-meta{display:flex;justify-content:center;align-items:center;gap:1rem;color:var(--text-tertiary);font-size:.875rem}.post-body{font-size:1.0625rem;line-height:1.8}.post-body h2{margin-top:3rem;margin-bottom:1rem;padding-top:1rem;border-top:1px solid var(--border)}.post-body h3{margin-top:2rem;margin-bottom:.75rem}.post-body p{color:var(--text-secondary);margin-bottom:1.25rem}.post-body ul,.post-body ol{margin-bottom:1.25rem;padding-left:1.5rem;color:var(--text-secondary)}.post-body li{margin-bottom:.375rem}.post-body img{border-radius:var(--radius-sm);margin:1.5rem auto}.toc{position:sticky;top:80px}.toc-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:.75rem}.toc-list{list-style:none;border-left:1px solid var(--border);padding-left:1rem}.toc-list li{margin-bottom:.5rem}.toc-list a{font-size:.8125rem;color:var(--text-tertiary);transition:color var(--transition)}.toc-list a:hover,.toc-list a.active{color:var(--text)}.toc-list .depth-3{padding-left:1rem}.search-btn{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:980px;color:var(--text-tertiary);font-size:.8125rem;cursor:pointer;transition:all var(--transition)}.search-btn:hover{border-color:var(--text-tertiary);color:var(--text-secondary)}.search-btn kbd{font-family:inherit;font-size:.6875rem;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:.1em .4em}.search-overlay{display:none;position:fixed;inset:0;z-index:200;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);justify-content:center;padding-top:15vh}.search-overlay.open{display:flex}.search-dialog{width:100%;max-width:580px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:0 24px 80px #00000026;overflow:hidden;max-height:60vh;display:flex;flex-direction:column}.search-input-wrap{display:flex;align-items:center;padding:0 1rem;border-bottom:1px solid var(--border)}.search-icon{color:var(--text-tertiary);flex-shrink:0}.search-input{flex:1;border:none;outline:none;padding:1rem .75rem;font-size:1rem;background:transparent;color:var(--text);font-family:inherit}.search-input::placeholder{color:var(--text-tertiary)}.search-results{overflow-y:auto;padding:.5rem}.search-result-item{display:block;padding:.75rem 1rem;border-radius:var(--radius-sm);color:var(--text);transition:background var(--transition)}.search-result-item:hover{background:var(--bg)}.search-result-item .title{font-weight:500;font-size:.9375rem}.search-result-item .snippet{font-size:.8125rem;color:var(--text-tertiary);margin-top:.25rem}.search-empty{padding:2rem;text-align:center;color:var(--text-tertiary);font-size:.875rem}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:none;cursor:pointer;color:var(--text-secondary);border-radius:50%;transition:all var(--transition)}.theme-toggle:hover{color:var(--text);background:var(--bg)}.theme-toggle svg{width:18px;height:18px}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:3rem}.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .75rem;border-radius:980px;font-size:.875rem;transition:all var(--transition)}.pagination a{color:var(--text-secondary);border:1px solid var(--border)}.pagination a:hover{color:var(--text);border-color:var(--text)}.pagination .current{color:#fff;background:var(--accent);font-weight:500}.about-content{padding:4rem 0}.about-content h1{font-size:3rem;margin-bottom:2rem}.about-body{font-size:1.0625rem;line-height:1.8}.about-body p{color:var(--text-secondary);margin-bottom:1.25rem}.about-body h2{margin-top:2.5rem;margin-bottom:1rem}.about-body ul{padding-left:1.5rem;color:var(--text-secondary);margin-bottom:1.25rem}.menu-toggle{display:none}.menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:6px;z-index:110}.menu-btn span{display:block;width:100%;height:2px;background:var(--text);border-radius:2px;transition:all var(--transition);transform-origin:center}.menu-toggle:checked~.menu-btn span:nth-child(1){transform:translateY(7px) rotate(45deg)}.menu-toggle:checked~.menu-btn span:nth-child(2){opacity:0}.menu-toggle:checked~.menu-btn span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-overlay{display:none}.nav-wrapper{display:flex;align-items:center;gap:1.5rem}.nav-dropdown{position:relative}.nav-dropdown-toggle{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary);font-size:.875rem;font-weight:400;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:color var(--transition)}.nav-dropdown-toggle:hover{color:var(--text)}.nav-dropdown-toggle svg{width:12px;height:12px;transition:transform var(--transition)}.nav-dropdown:hover .nav-dropdown-toggle svg{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);min-width:140px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 8px 30px #00000014;padding:.375rem;opacity:0;visibility:hidden;transition:all var(--transition);z-index:110}.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible}.nav-dropdown-menu a{display:block;padding:.5rem .75rem;color:var(--text-secondary);font-size:.8125rem;border-radius:4px;transition:all var(--transition)}.nav-dropdown-menu a:hover{color:var(--text);background:var(--bg)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all var(--transition)}.project-card:hover{border-color:var(--text-tertiary);box-shadow:0 8px 30px var(--shadow);transform:translateY(-2px)}.project-card-cover{width:100%;aspect-ratio:16 / 10;object-fit:cover;background:var(--bg-code)}.project-card-body{padding:1.25rem 1.5rem}.project-card-title{font-size:1.125rem;font-weight:600;margin-bottom:.375rem}.project-card-title a{color:var(--text)}.project-card-title a:hover{color:var(--accent)}.project-card-desc{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin-bottom:.75rem}.project-card-links{display:flex;gap:.75rem;margin-top:.75rem}.project-card-links a{font-size:.8125rem;color:var(--accent);display:flex;align-items:center;gap:.375rem}.skill-cloud{display:flex;flex-wrap:wrap;gap:.625rem}.skill-tag{padding:.375rem .875rem;background:var(--bg-card);border:1px solid var(--border);border-radius:980px;font-size:.8125rem;color:var(--text-secondary);transition:all var(--transition)}.skill-tag:hover{color:var(--accent);border-color:var(--accent)}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:.5rem;bottom:.5rem;width:1px;background:var(--border)}.timeline-item{position:relative;padding-bottom:2rem}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";position:absolute;left:-2rem;top:.5rem;width:9px;height:9px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);transform:translate(-4px)}.timeline-date{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:.25rem}.timeline-title{font-size:1.0625rem;font-weight:600;margin-bottom:.25rem}.timeline-subtitle{font-size:.9375rem;color:var(--text-secondary);margin-bottom:.375rem}.timeline-desc{font-size:.875rem;color:var(--text-tertiary);line-height:1.6}.resume-section{margin-bottom:3rem}.resume-section h2{font-size:1.375rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.resume-header{text-align:center;margin-bottom:3rem}.resume-header h1{font-size:2.5rem;margin-bottom:.5rem}.resume-contact{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;color:var(--text-secondary);font-size:.875rem}.resume-contact a{color:var(--text-secondary)}.resume-contact a:hover{color:var(--accent)}.links-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.links-category-btn{padding:.375rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:980px;font-size:.8125rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:inherit}.links-category-btn:hover,.links-category-btn.active{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--bg-card))}.links-group{margin-bottom:2.5rem}.links-group h2{font-size:1.25rem;margin-bottom:1rem}.links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.link-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition)}.link-card:hover{border-color:var(--text-tertiary);box-shadow:0 2px 12px var(--shadow)}.link-card-icon{width:36px;height:36px;border-radius:8px;background:var(--bg-code);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.link-card-info{flex:1;min-width:0}.link-card-name{font-size:.875rem;font-weight:500;color:var(--text)}.link-card-desc{font-size:.75rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.now-section{margin-bottom:3rem}.now-section h2{font-size:1.375rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.now-section ul{list-style:none;padding:0}.now-section li{padding:.75rem 0;border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:.9375rem}.now-section li:last-child{border-bottom:none}.now-updated{font-size:.8125rem;color:var(--text-tertiary);margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border)}.resource-list{display:flex;flex-direction:column;gap:.75rem}.resource-card{padding:1.25rem 1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:all var(--transition)}.resource-card:hover{border-color:var(--text-tertiary)}.resource-card-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.375rem}.resource-card-title{font-size:1rem;font-weight:500}.resource-card-title a{color:var(--text)}.resource-card-title a:hover{color:var(--accent)}.resource-card-source{font-size:.75rem;color:var(--text-tertiary);flex-shrink:0}.resource-card-desc{font-size:.875rem;color:var(--text-secondary);line-height:1.5;margin:0}.resource-card-meta{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;font-size:.75rem;color:var(--text-tertiary)}.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin-top:3rem;border:1px solid var(--border)}.post-nav-item{background:var(--bg-card);padding:1.25rem 1.5rem;transition:background var(--transition)}.post-nav-item:hover{background:var(--bg)}.post-nav-label{font-size:.75rem;color:var(--text-tertiary);margin-bottom:.25rem}.post-nav-title{font-size:.9375rem;font-weight:500;color:var(--text)}.post-nav-item:hover .post-nav-title{color:var(--accent)}.post-nav-next{text-align:right}.reading-time{font-size:.8125rem;color:var(--text-tertiary)}.reading-time:before{content:"·";margin:0 .375rem}.filter-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.filter-tab{padding:.375rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:980px;font-size:.8125rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:inherit}.filter-tab:hover,.filter-tab.active{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--bg-card))}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}@media(max-width:768px){.hero h1{font-size:2.5rem}.hero{padding:4rem 0 2rem}.post-header h1{font-size:2rem}.post-header{padding:2rem 0 1.5rem}h1{font-size:2rem}.header-inner{padding:0 1rem}.menu-btn{display:flex}.nav-wrapper{position:fixed;top:0;right:0;width:280px;height:100vh;background:var(--bg-card);border-left:1px solid var(--border);flex-direction:column;align-items:flex-start;padding:80px 1.5rem 2rem;gap:0;transform:translate(100%);transition:transform var(--transition);z-index:105;overflow-y:auto}.menu-toggle:checked~.nav-wrapper{transform:translate(0)}.nav-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:104}.menu-toggle:checked~.nav-overlay{display:block}.nav-links{flex-direction:column;align-items:flex-start;gap:0;width:100%}.nav-links li{width:100%}.nav-links a,.nav-dropdown-toggle{display:block;padding:.75rem 0;font-size:1rem;width:100%}.nav-dropdown-menu{position:static;transform:none;box-shadow:none;border:none;padding:0 0 0 1rem;opacity:1;visibility:visible}.nav-dropdown-menu a{font-size:.875rem}.project-grid,.links-grid,.post-nav{grid-template-columns:1fr}.footer-inner{flex-direction:column;gap:.75rem;text-align:center}.archive-item{gap:1rem}.search-btn span{display:none}}@media(max-width:480px){.hero h1{font-size:2rem}.hero p{font-size:1.0625rem}.post-header h1{font-size:1.75rem}.post-card{padding:1.25rem 1rem}.resume-header h1{font-size:2rem}}
