:root{--bg:#ffffff;--text:#0b0b0b;--muted:rgba(0,0,0,.55);--hairline:rgba(0,0,0,.10);--soft:rgba(0,0,0,.04);--accent:#4A90D9;--accent-soft:rgba(74,144,217,.08);--accent-mid:rgba(74,144,217,.15);--max:900px}*{margin:0;padding:0;box-sizing:border-box}body,html{height:100%}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;line-height:1.6;opacity:0;transition:opacity .3s ease-in-out;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body.loaded{opacity:1}.container{max-width:var(--max);margin:0 auto;padding:0 24px}h1{font-family:'Playfair Display',serif;font-size:clamp(36px, 6vw, 48px);font-weight:700;margin-bottom:12px;letter-spacing:-.02em;line-height:1.15}h2{font-family:'Playfair Display',serif;font-size:clamp(24px, 4vw, 32px);font-weight:700;margin-bottom:24px;letter-spacing:-.01em;line-height:1.2}h3{font-size:clamp(20px, 3vw, 22px);font-weight:600;margin-bottom:16px;line-height:1.25}p{font-size:16px;margin-bottom:16px}header{padding:56px 0 32px;text-align:center}.intro{font-size:clamp(16px, 2.5vw, 18px);color:var(--muted);line-height:1.6;max-width:480px;margin:0 auto}[data-include]{opacity:0;transition:opacity .4s ease-in-out;will-change:opacity}[data-include=blog-nav],[data-include=nav]{min-height:80px}[data-include=header]{min-height:140px}[data-include=footer]{min-height:60px}[data-include].loaded{opacity:1}nav{padding:28px 0;border-bottom:1px solid var(--hairline);margin-bottom:40px}.nav-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.logo{font-size:20px;font-weight:700;color:var(--text);text-decoration:none;transition:color .2s ease}.logo:hover{color:var(--muted)}.nav-links{display:flex;gap:36px;flex-wrap:wrap}.nav-link{color:var(--muted);text-decoration:none;font-size:15px;font-weight:500;transition:color .2s ease;position:relative;padding-bottom:4px}.nav-link:hover{color:var(--text)}.nav-link.active{color:var(--text)}.nav-link.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--accent);border-radius:1px}.back-link{color:var(--muted);text-decoration:none;font-size:15px;font-weight:500;transition:color .25s ease}.back-link:hover{color:var(--accent)}section{margin-bottom:40px}.section-title{font-family:'Playfair Display',serif;font-size:clamp(24px, 4vw, 32px);font-weight:700;margin-bottom:36px;letter-spacing:-.01em;line-height:1.2}.post-list{list-style:none;display:flex;flex-direction:column;gap:8px}.post-item{padding:24px;border-radius:12px;border:1px solid transparent;transition:background .25s ease,border-color .25s ease}.post-item:hover{background:var(--soft);border-color:var(--hairline)}.post-link{text-decoration:none;color:var(--text);display:block}.post-date{font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:500;letter-spacing:.02em;text-transform:uppercase}.post-title{font-family:'Playfair Display',serif;font-size:clamp(20px, 3vw, 24px);font-weight:700;line-height:1.3;margin-bottom:8px;letter-spacing:-.01em;transition:color .25s ease}.post-item:hover .post-title{color:var(--accent)}.post-excerpt{font-size:15px;color:var(--muted);line-height:1.6}article{margin-bottom:80px}.article-header{margin-bottom:48px}.article-meta{display:flex;gap:12px;align-items:center;margin-bottom:20px;font-size:14px;flex-wrap:wrap}.article-date{color:var(--muted);font-weight:500}.article-tag{padding:4px 12px;background:var(--accent-soft);color:var(--accent);border-radius:999px;font-size:13px;font-weight:600}.article-reading-time{color:var(--muted);font-size:13px}.article-meta-sep{color:var(--hairline);font-size:13px;user-select:none}.article-intro{font-size:clamp(18px, 3vw, 20px);line-height:1.7;color:var(--muted)}.article-content{font-size:17px;line-height:1.85;max-width:680px}.article-content h2{font-family:'Playfair Display',serif;font-size:clamp(24px, 4vw, 28px);font-weight:700;margin-top:52px;margin-bottom:20px;letter-spacing:-.01em;line-height:1.2}.article-content h3{font-size:clamp(20px, 3vw, 22px);font-weight:600;margin-top:40px;margin-bottom:16px;line-height:1.25}.article-content p{margin-bottom:24px;color:var(--text)}.article-content ol,.article-content ul{margin-bottom:24px;margin-left:24px}.article-content li{margin-bottom:12px}.article-content blockquote{margin:36px 0;padding:24px 28px;background:var(--accent-soft);border-left:3px solid var(--accent);font-style:italic;color:var(--text);border-radius:0 8px 8px 0}.article-content blockquote p:last-child{margin-bottom:0}.article-content code{background:var(--accent-soft);padding:3px 8px;border-radius:4px;font-family:Monaco,'Courier New',monospace;font-size:15px;color:var(--text)}.article-content pre{background:#1a1a1a;color:#e0e0e0;padding:24px;border-radius:8px;overflow-x:auto;margin:36px 0;line-height:1.55;border:1px solid rgba(74,144,217,.2);max-width:none}.article-content pre{position:relative}.article-content pre code{background:0 0;padding:0;color:#e0e0e0;font-size:14px}.article-content a{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:3px;transition:color .2s ease,text-decoration-color .2s ease}.article-content a:hover{color:#3a73b0;text-decoration-color:#3a73b0}.article-content img{width:100%;border-radius:8px;margin:36px 0}.highlight{background:var(--accent-soft);padding:24px;border-left:3px solid var(--accent);border-radius:0 8px 8px 0;margin:36px 0}.highlight p{margin-bottom:0;font-weight:500}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:24px;margin:40px 0}.stat{padding:24px;background:var(--bg);border:1px solid var(--hairline);border-radius:8px;text-align:center;transition:border-color .25s ease,transform .25s ease}.stat:hover{border-color:var(--accent);transform:translateY(-2px)}.stat-number{font-family:'Playfair Display',serif;font-size:36px;font-weight:700;color:var(--text);margin-bottom:8px}.stat-label{font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.resume-header{margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--hairline)}.title{font-size:clamp(18px, 3vw, 20px);color:var(--muted);font-weight:600;margin-bottom:24px}.contact-info{display:flex;gap:16px;flex-wrap:wrap;font-size:15px}.contact-info a{color:var(--muted);text-decoration:none;transition:color .2s ease}.contact-info a:hover{color:var(--accent)}.item{margin-bottom:24px;padding:20px;background:var(--bg);border:1px solid var(--hairline);border-radius:8px;transition:border-color .25s ease,transform .25s ease}.item:hover{border-color:var(--accent);transform:translateY(-2px)}.item:last-child{margin-bottom:0}.item-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:6px;flex-wrap:wrap;gap:6px}.item h3{font-size:20px;font-weight:600;color:var(--text);margin-bottom:4px}.item .company{font-size:16px;color:var(--muted);font-weight:500}.item .date{font-size:14px;color:var(--muted);white-space:nowrap}.item ul{margin-left:16px;margin-top:8px}.item li{font-size:15px;color:var(--text);margin-bottom:8px;line-height:1.5}.item p{font-size:15px;color:var(--text);line-height:1.7}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.skill-category{padding:20px;background:var(--bg);border:1px solid var(--hairline);border-radius:8px;transition:border-color .25s ease,transform .25s ease}.skill-category:hover{border-color:var(--accent);transform:translateY(-2px)}.skill-category h3{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text)}.skill-category p{font-size:14px;color:var(--muted);line-height:1.5}.download-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--text);color:var(--bg);text-decoration:none;border-radius:8px;font-weight:600;font-size:15px;transition:background .25s ease,transform .25s ease;margin-top:16px}.download-btn:hover{background:var(--muted);transform:translateY(-2px)}.connect{text-align:center;padding:48px 0 16px}.connect h2{margin-bottom:12px}.connect p{color:var(--muted);margin-bottom:28px}.social-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}.social-link{color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;padding:6px 16px;border:1px solid var(--hairline);border-radius:999px;transition:color .25s ease,border-color .25s ease,background .25s ease}.social-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}footer{margin-top:64px;padding:28px 0;border-top:1px solid var(--hairline)}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}footer .social-links{margin-bottom:0;gap:8px}footer .social-link{padding:4px 12px;font-size:13px}footer p{font-size:13px;color:var(--muted)}footer:not(:has(.footer-content)){text-align:center}@media (max-width:768px){.container{padding:0 20px}header{padding:48px 0 28px}nav{padding:24px 0;margin-bottom:32px}.nav-content{flex-direction:column;align-items:flex-start;gap:16px}.nav-links{gap:24px;width:100%}.nav-link{font-size:14px}h1{font-size:clamp(32px, 8vw, 48px)}h2{font-size:clamp(22px, 6vw, 32px)}.section-title{font-size:clamp(22px, 6vw, 32px);margin-bottom:28px}.post-item{padding:20px 16px}.article-content{font-size:16px;max-width:100%}.article-content h2{font-size:clamp(22px, 6vw, 28px);margin-top:40px}.article-content h3{font-size:clamp(18px, 5vw, 22px)}.article-content pre{margin-left:-20px;margin-right:-20px;border-radius:0;padding:20px}.stats{grid-template-columns:repeat(2,1fr);gap:16px}.stat{padding:20px}.connect{padding:32px 0 16px}.item{padding:20px}.item-header{flex-direction:column;gap:8px}.skills-grid{grid-template-columns:1fr}.contact-info{flex-direction:column;gap:12px}.post-list{gap:4px}.footer-content{flex-direction:column;text-align:center;gap:12px}footer{margin-top:48px;padding:24px 0}}@media (max-width:480px){.container{padding:0 16px}header{padding:36px 0 24px}nav{padding:20px 0;margin-bottom:28px}.intro{font-size:clamp(15px, 4vw, 18px)}section{margin-bottom:36px}.post-item{padding:16px 12px}.stats{grid-template-columns:1fr}.connect{padding:24px 0 16px}.item{padding:16px}.skill-category{padding:16px}.article-content pre{margin-left:-16px;margin-right:-16px;padding:16px;font-size:12px}.article-content pre code{font-size:12px}.social-link{padding:6px 14px;font-size:13px}}@media print{.back-link,.download-btn,footer,nav{display:none}body{background:#fff;opacity:1}.item,.skill-category{border:1px solid var(--hairline);box-shadow:none;page-break-inside:avoid}.post-item{background:0 0;border:none}.article-content{max-width:100%}}@media (prefers-reduced-motion:reduce){*{transition:none!important}}