*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Noto Sans SC",sans-serif;color:#333;background:#fff;line-height:1.75;min-height:100vh;display:flex;flex-direction:column}a{color:#2563eb;text-decoration:none}a:hover{color:#1d4ed8;text-decoration:underline}img{max-width:100%;height:auto}h1,h2,h3,h4,h5,h6{line-height:1.3;margin-top:1.5em;margin-bottom:0.5em;font-weight:600}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{margin-bottom:1em}code{font-family:"JetBrains Mono","Fira Code",Consolas,monospace;font-size:0.9em;background:#f3f4f6;padding:0.15em 0.4em;border-radius:3px}pre{background:#f3f4f6;padding:1.5rem;border-radius:6px;overflow-x:auto;margin-bottom:1.5em}pre code{background:none;padding:0}blockquote{border-left:3px solid #2563eb;padding-left:1.5rem;color:#666;margin-bottom:1.5em}ul,ol{padding-left:1.5em;margin-bottom:1em}hr{border:none;border-top:1px solid #e5e7eb;margin:2rem 0}table{width:100%;border-collapse:collapse;margin-bottom:1.5em}table th,table td{border:1px solid #e5e7eb;padding:0.5em 0.75em;text-align:left}table th{background:#f3f4f6;font-weight:600}.container{max-width:780px;margin:0 auto;padding:0 1.5rem}.site-header{border-bottom:1px solid #e5e7eb;padding:1rem 0}.site-header .container{display:flex;justify-content:space-between;align-items:center}.site-title{font-size:1.25rem;font-weight:700;color:#333}.site-title:hover{text-decoration:none;color:#2563eb}.site-nav a{margin-left:1.5rem;color:#666;font-size:0.95rem}.site-nav a:hover{color:#2563eb;text-decoration:none}main.container{flex:1;padding-top:2rem;padding-bottom:3rem}.site-footer{border-top:1px solid #e5e7eb;padding:1.5rem 0;text-align:center;color:#666;font-size:0.85rem}@media (max-width: 600px){.site-header .container{flex-direction:column;gap:0.5rem}.site-nav a{margin-left:0;margin-right:1rem}}.post-list{list-style:none;padding:0}.post-list li{padding:0.6rem 0;border-bottom:1px solid #e5e7eb;display:flex;align-items:baseline;gap:1rem}.post-list li:last-child{border-bottom:none}.post-date{font-size:0.85rem;color:#666;white-space:nowrap;font-family:"JetBrains Mono","Fira Code",Consolas,monospace}.post-header{margin-bottom:2rem}.post-title{margin-top:0;font-size:2rem}.post-meta{color:#666;font-size:0.9rem}.post-content h2{margin-top:2em}.post-content h3{margin-top:1.5em}.page-title{margin-top:0}.tag{display:inline-block;background:#f3f4f6;color:#666;font-size:0.8rem;padding:0.1em 0.5em;border-radius:3px;margin-right:0.3em}.hero{padding:3rem 0 1.5rem}.hero h1{font-size:2.8rem;margin-top:0;margin-bottom:0.3rem;letter-spacing:-0.02em}.hero .hero-role{font-size:1.2rem;color:#2563eb;font-weight:500;margin-bottom:0.5rem}.hero p{font-size:1.05rem;color:#666}.featured-projects,.post-list-section{margin-top:2.5rem}.featured-projects h2,.post-list-section h2{margin-top:0;margin-bottom:1rem;font-size:1.4rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1.25rem}.project-card{display:block;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;color:#333;transition:box-shadow 0.2s, transform 0.2s}.project-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.08);transform:translateY(-2px);text-decoration:none;color:#333}.project-cover{height:180px;background-size:cover;background-position:center;background-color:#f3f4f6}.project-card-body{padding:1rem 1.25rem}.project-card-body h3{margin:0 0 0.4rem;font-size:1.15rem}.project-card-body p{color:#666;font-size:0.9rem;margin-bottom:0.6rem}.project-tags{display:flex;flex-wrap:wrap;gap:0.3rem}.view-all{margin-top:1rem}.view-all a{font-weight:500}.project-detail .project-header{margin-bottom:2rem}.project-detail .project-desc{font-size:1.1rem;color:#666}.project-detail .project-meta{display:flex;align-items:center;gap:1rem;margin-top:1rem;flex-wrap:wrap}.project-hero-img{margin-bottom:2rem;border-radius:8px;overflow:hidden}.project-hero-img img{display:block;width:100%}.btn{display:inline-block;padding:0.4em 1em;border-radius:6px;font-size:0.9rem;font-weight:500;background:#2563eb;color:#fff}.btn:hover{background:#1d4ed8;text-decoration:none;color:#fff}.btn-outline{background:transparent;border:1px solid #2563eb;color:#2563eb}.btn-outline:hover{background:#2563eb;color:#fff}@media (max-width: 600px){.project-grid{grid-template-columns:1fr}.hero h1{font-size:2rem}}.highlight{margin-bottom:1.5em;border-radius:6px}.highlight pre{margin-bottom:0}.highlight .c,.highlight .cm,.highlight .c1,.highlight .cs{color:#6a737d}.highlight .k,.highlight .kd,.highlight .kn,.highlight .kp,.highlight .kr,.highlight .kt{color:#d73a49}.highlight .s,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .s2,.highlight .se,.highlight .sh,.highlight .si,.highlight .sx,.highlight .s1{color:#032f62}.highlight .na{color:#005cc5}.highlight .nb{color:#005cc5}.highlight .nc{color:#6f42c1}.highlight .no{color:#005cc5}.highlight .nf,.highlight .nx{color:#6f42c1}.highlight .nn{color:#005cc5}.highlight .mi,.highlight .mf,.highlight .mh,.highlight .mo{color:#005cc5}.highlight .o,.highlight .ow{color:#d73a49}
