@import 'https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&family=JetBrains+Mono:wght@400;500;600;700&display=swap';:root{--bg:#0c0d10;--surface:#13151a;--surface-hover:#1a1d24;--border:#23272f;--border-subtle:#1c1f26;--text-primary:#e4e6ea;--text-secondary:#8b919d;--text-tertiary:#5c6370;--accent:#22c55e;--accent-hover:#16a34a;--accent-subtle:rgba(34, 197, 94, 0.12);--code-bg:#0f1115;--radius:12px;--radius-sm:6px;--radius-xs:4px;--transition:200ms ease-out}[data-theme=light]{--bg:#fafafa;--surface:#ffffff;--surface-hover:#f4f4f5;--border:#e4e4e7;--border-subtle:#eaeaea;--text-primary:#18181b;--text-secondary:#52525b;--text-tertiary:#71717a;--accent:#16a34a;--accent-hover:#15803d;--accent-subtle:rgba(22, 163, 74, 0.08);--code-bg:#f4f4f5}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;overflow-x:hidden}body{font-family:ibm plex sans,-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;line-height:1.7;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}h1,h2,h3,h4,h5,h6{font-family:jetbrains mono,monospace;font-weight:600;line-height:1.25;color:var(--text-primary)}h1{font-size:3rem;font-weight:700;letter-spacing:-.02em}h2{font-size:2rem;letter-spacing:-.01em}h3{font-size:1.5rem}h4{font-size:1.25rem}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 32px}.content-width{max-width:720px}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;background:var(--bg);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:all .3s ease}.nav.scrolled{border-bottom-color:var(--border)}[data-theme=light] .nav{background:var(--surface)}.nav-container{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 32px}.nav-logo{font-family:jetbrains mono,monospace;font-size:1rem;font-weight:600;color:var(--text-primary);text-decoration:none;letter-spacing:-.01em}.nav-logo:hover{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:40px;list-style:none}.nav-links a{font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:color var(--transition);position:relative}.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--accent);transition:width var(--transition)}.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}.nav-links a:hover::after,.nav-links a.active::after{width:100%}.nav-right{display:flex;align-items:center;gap:16px;position:relative;z-index:10}.theme-toggle{background:0 0;border:none;cursor:pointer;padding:8px;color:var(--text-secondary);transition:color var(--transition)}.theme-toggle:hover{color:var(--text-primary)}.theme-toggle svg{width:18px;height:18px;display:block}.theme-toggle .sun-icon{display:block}.theme-toggle .moon-icon{display:none}[data-theme=light] .theme-toggle .sun-icon{display:none !important}[data-theme=light] .theme-toggle .moon-icon{display:block !important}.mobile-menu-btn{display:none;background:0 0;border:none;cursor:pointer;padding:8px;color:var(--text-secondary)}.mobile-menu-btn svg{width:24px;height:24px;display:block}.mobile-nav{display:none;position:fixed;top:60px;left:0;right:0;bottom:0;background:var(--bg);padding:32px 24px;z-index:1001}.mobile-nav.open{display:block}.mobile-nav a{display:block;padding:16px 0;font-size:1.25rem;color:var(--text-primary);border-bottom:1px solid var(--border)}.hero{min-height:calc(100vh - 80px);display:flex;align-items:center;padding:120px 0 80px}.hero-grid{display:grid;grid-template-columns:280px 1fr;gap:64px;align-items:center;max-width:900px;margin:0 auto}.hero-image-wrapper{display:flex;justify-content:center}.hero-profile-image{width:240px;height:240px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:0 0 40px var(--accent-subtle)}.hero-content{display:flex;flex-direction:column;gap:20px}.hero-title{font-size:3.5rem;font-weight:700;letter-spacing:-.03em;line-height:1.1;margin:0}.hero-role{font-family:jetbrains mono,monospace;font-size:.9rem;color:var(--accent);font-weight:500;margin:0}.hero-tagline{font-size:1.125rem;color:var(--text-secondary);line-height:1.6;max-width:480px;margin:0}.hero-socials{display:flex;gap:12px;margin-top:8px}.hero-cta{display:inline-block;margin-top:8px;font-size:.9375rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color var(--transition)}.hero-cta:hover{color:var(--accent)}.social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);transition:all var(--transition)}.social-link:hover{color:var(--accent);border-color:var(--accent)}.social-link svg{width:20px;height:20px}.page-header{padding:120px 0 32px}.page-title{font-size:3rem;margin-bottom:16px}.page-description{font-size:1.125rem;color:var(--text-secondary);max-width:600px}.section{padding:96px 0}.section-title{font-size:1.75rem;margin-bottom:48px}.about-content{display:grid;gap:48px}.about-text p{margin-bottom:24px;color:var(--text-secondary)}.skills-grid{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.skill-tag{display:inline-flex;align-items:center;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-family:jetbrains mono,monospace;color:var(--text-secondary);transition:all var(--transition)}.skill-tag:hover{border-color:var(--accent);color:var(--accent)}.projects-hero{padding:160px 0 64px}.projects-title{font-size:4.5rem;font-weight:700;letter-spacing:-.04em;line-height:1;margin:0 0 16px}.projects-description{font-size:1.25rem;color:var(--text-secondary);max-width:520px;margin:0}.projects-section{padding:0 0 96px}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}.project-card{display:flex;flex-direction:column;padding:24px;background:0 0;border:1px solid transparent;border-radius:var(--radius);text-decoration:none;transition:all var(--transition)}.project-card:hover{border-color:var(--border);background:var(--surface)}.project-card:hover .project-card-title{color:var(--accent)}.project-card-header{margin-bottom:12px}.project-card-tags{display:flex;flex-wrap:wrap;gap:8px}.project-tag,.tag-chip{display:inline-block;font-size:.6875rem;font-family:jetbrains mono,monospace;font-weight:500;color:var(--text-tertiary);letter-spacing:-.02em;padding:4px 10px;background:var(--surface);border:1px solid var(--border);border-radius:999px;transition:all var(--transition)}.project-card:hover .project-tag,.project-card:hover .tag-chip{color:var(--text-secondary);border-color:var(--text-tertiary)}.project-card-title{font-size:1.25rem;font-weight:600;line-height:1.35;color:var(--text-primary);margin-bottom:12px;transition:color var(--transition)}.project-card-excerpt{font-size:.9375rem;color:var(--text-secondary);line-height:1.6}.project-description{font-size:.9rem;color:var(--text-secondary);margin-bottom:16px;line-height:1.6}.project-tags{display:flex;flex-wrap:wrap;gap:8px}.blog-hero{padding:160px 0 64px}.blog-hero-grid{display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:start}.blog-hero-content{display:flex;flex-direction:column;gap:16px}.blog-hero-title{font-size:4.5rem;font-weight:700;letter-spacing:-.04em;line-height:1;margin:0}.blog-hero-description{font-size:1.25rem;color:var(--text-secondary);max-width:520px;margin:0}.blog-rss-link{display:inline-flex;align-items:center;gap:8px;margin-top:8px;font-size:.875rem;font-family:jetbrains mono,monospace;color:var(--text-secondary);transition:color var(--transition)}.blog-rss-link:hover{color:var(--accent)}.blog-rss-link svg{width:16px;height:16px}.blog-tags-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.blog-tags-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:16px}.blog-tags-filter{display:flex;flex-wrap:wrap;gap:8px}.tag-filter{padding:6px 14px;font-size:.8125rem;font-family:jetbrains mono,monospace;font-weight:500;color:var(--text-secondary);background:0 0;border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:all var(--transition)}.tag-filter:hover{color:var(--text-primary);border-color:var(--text-tertiary)}.tag-filter.active{color:var(--bg);background:var(--accent);border-color:var(--accent)}.blog-search-section{padding:0 0 48px}.blog-search-wrapper{position:relative;width:100%;max-width:640px}.blog-search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-tertiary);pointer-events:none}.blog-search-input{width:100%;padding:18px 20px 18px 56px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:1rem;color:var(--text-primary);font-family:inherit;transition:all var(--transition)}.blog-search-input::placeholder{color:var(--text-tertiary)}.blog-search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.blog-section{padding:0 0 96px}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}.blog-card{display:flex;flex-direction:column;padding:24px;background:0 0;border:1px solid transparent;border-radius:var(--radius);text-decoration:none;transition:all var(--transition)}.blog-card:hover{border-color:var(--border);background:var(--surface)}.blog-card:hover .blog-card-title{color:var(--accent)}.blog-card-header{margin-bottom:12px}.blog-card-tags{display:flex;flex-wrap:wrap;gap:8px}.blog-tag,.blog-card .tag-chip{display:inline-block;font-size:.6875rem;font-family:jetbrains mono,monospace;font-weight:500;color:var(--text-tertiary);letter-spacing:-.02em;padding:4px 10px;background:var(--surface);border:1px solid var(--border);border-radius:999px;transition:all var(--transition)}.blog-card:hover .blog-tag,.blog-card:hover .tag-chip{color:var(--text-secondary);border-color:var(--text-tertiary)}.blog-card-title{font-size:1.25rem;font-weight:600;line-height:1.35;color:var(--text-primary);margin-bottom:12px;transition:color var(--transition)}.blog-card-excerpt{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:16px}.blog-card-meta{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-tertiary);margin-top:auto}.blog-card-meta-sep{opacity:.5}.no-results{display:none;text-align:center;padding:80px 0;color:var(--text-tertiary)}.no-results.visible{display:block}.post-header{padding:160px 0 48px}.post-title{font-size:2.5rem;font-weight:700;margin-bottom:24px;letter-spacing:-.02em}.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.875rem;color:var(--text-secondary)}.post-meta-sep{color:var(--text-tertiary);opacity:.5}.post-meta-tags{display:flex;flex-wrap:wrap;gap:6px}.post-meta-tags .tag-chip{font-size:.6875rem;padding:3px 8px}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:.875rem;margin-bottom:16px}.breadcrumb-item{color:var(--text-tertiary);text-decoration:none;transition:color var(--transition)}.breadcrumb-item:hover{color:var(--accent)}.breadcrumb-sep{color:var(--text-tertiary);opacity:.5}.breadcrumb-current{color:var(--text-secondary);font-weight:500}.post-content{max-width:720px;margin:0 auto;padding:0 0 64px}.post-content>*:first-child{margin-top:0}.post-content p{margin-bottom:24px;color:var(--text-secondary)}.post-content h1{font-size:2.5rem;margin-top:0;margin-bottom:32px;letter-spacing:-.02em}.post-content h2{margin-top:48px;margin-bottom:24px}.post-content h3{margin-top:32px;margin-bottom:16px}.post-content ul,.post-content ol{margin-bottom:24px;padding-left:24px;color:var(--text-secondary)}.post-content li{margin-bottom:8px}.highlight{position:relative;margin:24px 0;background:var(--code-bg);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.15)}.code-header{display:flex;align-items:center;justify-content:space-between;height:36px;padding:0 12px;background:var(--surface);border-bottom:1px solid var(--border)}.code-dots{display:flex;align-items:center;gap:6px}.code-dot{width:9px;height:9px;border-radius:50%}.code-dot.red{background:#ff5f56}.code-dot.yellow{background:#ffbd2e}.code-dot.green{background:#27c93f}.code-lang{display:none}.code-copy-btn{display:flex;align-items:center;gap:4px;padding:4px 6px;background:var(--surface);border:1px solid var(--border);border-radius:4px;font-family:jetbrains mono,monospace;font-size:.65rem;color:var(--text-muted);cursor:pointer;opacity:0;transition:all .2s ease}.highlight:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{background:var(--border);color:var(--text)}.code-copy-btn svg{width:12px;height:12px}.code-copy-btn.copied{color:var(--accent);border-color:var(--accent)}.highlight pre{margin:0;padding:16px 20px;border:none;border-radius:0;overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}.highlight pre.chroma,.highlight .chroma{background:0 0;color:#f8f8f2}.highlight pre code{font-family:jetbrains mono,monospace;font-size:.8125rem;line-height:1.7;background:0 0;color:inherit;display:block;min-width:max-content}:not(.highlight)>code{font-family:jetbrains mono,monospace;font-size:.875em;background:var(--code-bg);color:var(--text);padding:2px 6px;border-radius:var(--radius-sm)}.comments-section{max-width:720px;margin:0 auto;padding:48px 0;border-top:1px solid var(--border)}.comments-section .giscus-frame-wrapper{max-width:100%;overflow:hidden}@media(max-width:768px){.comments-section{padding:32px 0}}.contact-section{padding:96px 0;border-top:1px solid var(--border)}.contact-section-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:16px}.contact-section-intro{font-size:1.125rem;color:var(--text-secondary);text-align:center;margin-bottom:40px;max-width:500px;margin-left:auto;margin-right:auto}.contact-form-wrapper{max-width:520px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px}.contact-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-input{padding:14px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--text-primary);transition:all var(--transition)}.form-input::placeholder{color:var(--text-tertiary)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.form-input.error{border-color:#ef4444}.form-input.valid{border-color:var(--accent)}.form-textarea{resize:vertical;min-height:140px}.form-error{font-size:.8125rem;color:#ef4444;min-height:18px}.form-submit{padding:14px 24px;background:var(--accent);border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;color:var(--bg);cursor:pointer;transition:all var(--transition)}.form-submit:hover{background:var(--accent-hover)}.form-submit:active{transform:scale(.98)}.form-submit:disabled{opacity:.65;cursor:not-allowed;transform:none}.form-submit .spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--bg);border-top-color:transparent;border-radius:50%;animation:form-spin .6s linear infinite;vertical-align:middle;margin-right:6px}@keyframes form-spin{to{transform:rotate(360deg)}}.form-success{display:none;padding:16px;background:var(--accent-subtle);border:1px solid var(--accent);border-radius:var(--radius-sm);font-size:.9375rem;color:var(--accent);text-align:center}.form-success.visible{display:block}.contact-content{max-width:600px;margin:0 auto;text-align:center}.contact-intro{font-size:1.125rem;color:var(--text-secondary);margin-bottom:48px}.contact-links{display:flex;flex-direction:column;gap:24px;align-items:center}.contact-link{display:inline-flex;align-items:center;gap:12px;padding:16px 32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:1rem;transition:all var(--transition)}.contact-link:hover{border-color:var(--accent);color:var(--accent)}.contact-link svg{width:24px;height:24px;color:var(--accent)}.footer{padding:48px 0;border-top:1px solid var(--border)}.footer-content{display:flex;flex-direction:column;align-items:center;gap:16px}.footer-text{font-size:.875rem;color:var(--text-tertiary)}.footer-socials{display:flex;gap:24px}.footer-social{color:var(--text-tertiary);transition:color var(--transition)}.footer-social:hover{color:var(--accent)}.footer-social svg{width:20px;height:20px}@media(max-width:1024px){.hero-grid{grid-template-columns:240px 1fr;gap:48px}.blog-hero-grid{grid-template-columns:1fr;gap:40px}.projects-grid{grid-template-columns:1fr;gap:24px}.blog-tags-card{max-width:400px}.blog-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.contact-form-wrapper{max-width:900px;padding:48px 64px}.hero-profile-image{width:320px;height:320px}}@media(max-width:768px){.container,.nav-container{padding:0 20px}.nav-links{display:none}.mobile-menu-btn{display:block}.hero{padding-top:100px;padding-bottom:48px}.hero-grid{grid-template-columns:1fr;gap:32px;text-align:center}.hero-image-wrapper{order:-1}.hero-profile-image{width:180px;height:180px}.hero-content{align-items:center}.hero-tagline{max-width:100%}.hero-title{font-size:2.5rem}.hero-tagline{font-size:1rem}.contact-form-wrapper{padding:24px}.form-submit{width:100%}.blog-hero{padding:120px 0 48px}.blog-hero-title{font-size:3rem}.blog-hero-description{font-size:1.0625rem}.blog-tags-card{padding:20px}.blog-grid{grid-template-columns:1fr;gap:40px}.blog-card-title{font-size:1.125rem}.page-header{padding:100px 0 48px}.page-title{font-size:2rem}.section{padding:48px 0}.projects-grid{grid-template-columns:1fr;gap:24px}.projects-hero{padding:120px 0 48px}.projects-title{font-size:3rem}.projects-description{font-size:1.0625rem}.post-title{font-size:1.75rem}pre{padding:16px;font-size:.8125rem}pre code{font-size:.8125rem}h1{font-size:2rem}h2{font-size:1.5rem}}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hero-content>*{animation:fadeIn .5s ease-out forwards}.hero-content>*:nth-child(1){animation-delay:.1s}.hero-content>*:nth-child(2){animation-delay:.2s}.hero-content>*:nth-child(3){animation-delay:.3s}.hero-content>*:nth-child(4){animation-delay:.4s}.hero-content>*:nth-child(5){animation-delay:.5s}.hero-content>*:nth-child(6){animation-delay:.6s}.hero-content>*:nth-child(7){opacity:0}@media print{.nav,.footer,.theme-toggle{display:none}}