*,:after,:before{box-sizing:border-box;margin:0;padding:0}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}a:focus-visible,button:focus-visible{outline:none}:root,[data-theme=dark]{--bg:#0a1a12;--bg-alt:#0f2017;--surface:#142a1e;--surface-hover:#1a3426;--text:#fff;--primary:#10b981;--primary-dark:#059669;--accent:#14b8a6;--accent2:#0ea5e9;--border:#1e3a2e;--glow:rgba(16,185,129,.12);--glow-accent:rgba(20,184,166,.08);--radius:16px;--radius-sm:10px;--shadow:0 4px 20px rgba(0,0,0,.35);--shadow-lg:0 20px 50px rgba(0,0,0,.45);--nav-bg:rgba(20,42,30,.75);--nav-border:hsla(0,0%,100%,.06);--btn-secondary-bg:hsla(0,0%,100%,.04);--code-bg:rgba(16,185,129,.12);--max-w:1100px;--font:"Inter",system-ui,-apple-system,sans-serif;--navbar-h:68px}[data-theme=light]{--bg:#ecfdf5;--bg-alt:#f0fdf4;--surface:#fff;--surface-hover:#f0fdf4;--text:#000;--primary:#059669;--primary-dark:#047857;--accent:#0d9488;--accent2:#0284c7;--border:#a7f3d0;--glow:rgba(5,150,105,.08);--glow-accent:rgba(13,148,136,.06);--radius:16px;--radius-sm:10px;--shadow:0 4px 20px rgba(0,0,0,.08);--shadow-lg:0 20px 50px rgba(0,0,0,.12);--nav-bg:hsla(0,0%,100%,.8);--nav-border:rgba(0,0,0,.06);--btn-secondary-bg:rgba(0,0,0,.03);--code-bg:rgba(5,150,105,.08);--max-w:1100px;--font:"Inter",system-ui,-apple-system,sans-serif;--navbar-h:68px}html{scroll-behavior:smooth;transition:background .3s}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.7;min-height:100vh;display:flex;flex-direction:column;transition:background .3s,color .3s;background-image:radial-gradient(ellipse at 20% 50%,var(--glow) 0,transparent 50%),radial-gradient(ellipse at 80% 20%,var(--glow-accent) 0,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(14,165,233,.03) 0,transparent 50%);background-attachment:fixed}a{color:var(--primary);text-decoration:none;transition:all .25s}a:hover{color:var(--accent)}img{max-width:100%;height:auto;border-radius:var(--radius)}.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}section{animation:fadeUp .5s ease-out both}h1,h2,h3,h4{font-weight:800;line-height:1.25;letter-spacing:-.02em}h1{font-size:3rem}h2{font-size:2rem}h3{font-size:1.3rem}h4{font-size:1.1rem}code{font-family:JetBrains Mono,Fira Code,monospace;background:var(--code-bg);padding:3px 8px;border-radius:6px;font-size:.88em;color:var(--primary)}::selection{background:var(--primary);color:#fff}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.navbar-wrapper{position:-webkit-sticky;position:sticky;top:12px;z-index:100;width:80%;margin:0 auto;transition:width .3s}.navbar{position:relative;border-radius:16px;background:var(--nav-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--nav-border);box-shadow:0 8px 32px rgba(0,0,0,.3);transition:background .3s,border .3s}.nav-inner{justify-content:space-between;height:var(--navbar-h);padding:0 20px}.logo,.nav-inner{display:flex;align-items:center}.logo{font-size:1.2rem;font-weight:800;color:var(--text);gap:8px;transition:all .25s}.logo:hover{color:var(--primary);transform:scale(1.02)}.nav-links{display:flex;gap:4px;list-style:none;align-items:center}.nav-links a{padding:8px 16px;border-radius:10px;font-weight:500;font-size:.9rem;color:var(--text);transition:all .25s;position:relative}.nav-links a:hover{color:var(--text);background:hsla(0,0%,100%,.05)}[data-theme=light] .nav-links a:hover{background:rgba(0,0,0,.04)}.nav-links a.active{color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent));box-shadow:0 4px 15px rgba(16,185,129,.3)}[data-theme=light] .nav-links a.active{box-shadow:0 4px 15px rgba(5,150,105,.25)}.navbar-btn{background:var(--btn-secondary-bg);color:var(--text);border:1px solid var(--border);padding:7px 13px;border-radius:10px;font-weight:700;font-size:.8rem;cursor:pointer;transition:all .25s;letter-spacing:.5px;display:flex;align-items:center;gap:4px;line-height:1}.navbar-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:scale(1.05);box-shadow:0 4px 15px rgba(16,185,129,.3)}.navbar-btn-group{display:flex;gap:6px;margin-left:8px}[data-theme=light] .navbar-btn:hover{box-shadow:0 4px 15px rgba(5,150,105,.25)}.theme-icon{font-size:1rem;line-height:1}.hamburger{display:none;background:var(--btn-secondary-bg);border:1px solid var(--border);border-radius:10px;font-size:1.5rem;cursor:pointer;color:var(--text);padding:6px 12px}@media (max-width:768px){.navbar-wrapper{width:90%;top:8px}.nav-links{display:none;position:absolute;top:calc(var(--navbar-h) + 8px);left:0;right:0;flex-direction:column;background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:12px;padding:8px;gap:4px;box-shadow:var(--shadow-lg)}.nav-links.open{display:flex}.nav-links a{padding:12px 16px;border-radius:8px;text-align:center}.nav-links li:last-child{border-top:1px solid var(--border);margin-top:4px;padding-top:8px}.navbar-btn{width:100%;justify-content:center;padding:10px}.navbar-btn-group{flex-direction:row;width:100%;margin-left:0;gap:6px}.navbar-btn-group .navbar-btn{flex:1 1}.hamburger{display:block}}.hero{padding:100px 0 80px;position:relative;overflow:hidden}.hero:before{top:-50%;left:-20%;width:600px;height:600px;background:radial-gradient(circle,var(--glow) 0,transparent 70%)}.hero:after,.hero:before{content:"";position:absolute;pointer-events:none}.hero:after{bottom:-30%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,var(--glow-accent) 0,transparent 70%)}.hero-inner{display:flex;align-items:center;gap:64px;position:relative;z-index:1}.hero-text{flex:1 1}.hero-text h1{margin-bottom:16px;font-size:3.5rem;line-height:1.1}.gradient-text{background:linear-gradient(135deg,var(--primary),var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% 200%;animation:gradientShift 4s ease infinite}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.hero-sub{font-size:1.1rem;color:var(--text);margin-bottom:36px;max-width:540px;line-height:1.8}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.hero-avatar{flex-shrink:0;position:relative}.avatar-box{width:200px;height:200px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;box-shadow:0 0 60px rgba(16,185,129,.25);position:relative;animation:float 6s ease-in-out infinite;transition:box-shadow .3s;overflow:hidden}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.avatar-box:after{content:"";position:absolute;inset:-4px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent),var(--accent2));z-index:-1;opacity:.3;filter:blur(20px)}@media (max-width:768px){h1{font-size:2.2rem}.hero{padding:60px 0 40px}.hero-text h1{font-size:2.5rem}.hero-inner{flex-direction:column-reverse;text-align:center;gap:32px}.hero-sub{max-width:100%}.hero-actions{justify-content:center}.avatar-box{width:150px;height:150px;font-size:4rem}}.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:12px;font-weight:600;font-size:.95rem;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;text-decoration:none;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff!important;box-shadow:0 4px 20px rgba(16,185,129,.35)}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(16,185,129,.45)}[data-theme=light] .btn-primary{box-shadow:0 4px 20px rgba(5,150,105,.25)}[data-theme=light] .btn-primary:hover{box-shadow:0 8px 30px rgba(5,150,105,.35)}.btn-secondary{background:var(--btn-secondary-bg);color:var(--text)!important;border:1.5px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-secondary:hover{border-color:var(--primary);background:var(--code-bg);color:var(--primary)!important;transform:translateY(-2px);box-shadow:0 8px 25px rgba(16,185,129,.15)}.section{padding:.5rem 0;transition:background .3s}.alt-bg{background:var(--bg-alt)}.section-title{font-size:1.75rem;margin-bottom:40px;display:flex;align-items:center;gap:10px;position:relative}.section-title:after{content:"";flex:1 1;height:1px;background:linear-gradient(90deg,var(--border),transparent);margin-left:16px}.section-footer{text-align:center;margin-top:48px}.page-header{padding:48px 0 32px;position:relative}.page-header:before{content:"";position:absolute;top:-20%;left:10%;width:300px;height:300px;background:radial-gradient(circle,var(--glow) 0,transparent 70%);pointer-events:none}.page-title{font-size:2.5rem;margin-bottom:8px}.page-desc{color:var(--text);font-size:1.1rem}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:24px;gap:24px}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:28px;transition:all .35s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:0;transition:opacity .35s}.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--primary);background:var(--surface-hover)}.card:hover:before{opacity:1}.card-title{font-size:1.2rem;margin-bottom:8px}.card-title a{color:var(--text)}.card-title a:hover{color:var(--primary)}.card-date{font-size:.82rem;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px}.card-excerpt{color:var(--te .card-image-wrap { margin:-28px -28px 16px -28px; border-radius:var(--radius) var(--radius) 0 0; overflow:hidden; width:calc(100% + 56px); } .card-img { width:100%; height:200px; object-fit:cover; display:block; transition:transform .35s; } .card:hover .card-img { transform:scale(1.05); } .card-body { } xt);font-size:.92rem;margin-bottom:14px;line-height:1.7}.card-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.75rem;font-weight:600;background:var(--code-bg);color:var(--primary);border:1px solid rgba(16,185,129,.15);letter-spacing:.3px;transition:all .25s;margin:0 .25rem}.tag:hover{background:rgba(16,185,129,.2);transform:translateY(-1px)}.filter-section{padding:0 0 32px}.filter-tags{display:flex;flex-wrap:wrap;gap:8px}.filter-btn{padding:8px 20px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .25s;color:var(--text)}.filter-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--code-bg)}.filter-btn.active{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent;box-shadow:0 4px 15px rgba(16,185,129,.25)}.blog-list{display:flex;flex-direction:column;gap:16px}.blog-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all .35s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow);position:relative;overflow:hidden}.blog-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--primary),var(--accent));opacity:0;transition:opacity .35s}.blog-item:hover{transform:translateX(8px);border-color:var(--primary);background:var(--surface-hover);box-shadow:var(--shadow-lg)}.blog-item:hover:before{opacity:1}.blog-item-title{font-size:1.2rem;margin-bottom:4px}.blog-item-title a{color:var(--text)}.blog-item-title a:hover{color:var(--primary)}.blog-item-meta{font-size:.82rem;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px;.blog-item-inner{display:flex;gap:20px;align-items:flex-start}.blog-item-image-wrap{flex-shrink:0;width:240px;border-radius:10px;overflow:hidden}.blog-item-img{width:100%;height:160px;object-fit:cover;display:block;transition:transform .35s}.blog-item:hover .blog-item-img{transform:scale(1.05)}.blog-item-content{flex:1 1;min-width:0}@media (max-width:640px){.blog-item-inner{flex-direction:column}.blog-item-image-wrap{width:100%}.blog-item-img{height:200px}}}.blog-item-excerpt{color:var(--text);font-size:.92rem;line-height:1.7}.blog-item-tags{margin-top:12px}.markdown-content{max-width:780px}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4{margin-top:2.5rem;margin-bottom:.75rem}.markdown-content h2{padding-bottom:10px;border-bottom:1px solid var(--border)}.markdown-content h2:first-of-type{margin-top:0}.markdown-content p{margin-bottom:1.3rem;color:var(--text);line-height:1.8}.markdown-content strong{color:var(--text)}.markdown-content ol,.markdown-content ul{margin:0 0 1.3rem 1.5rem;color:var(--text)}.markdown-content li{margin-bottom:6px}.markdown-content blockquote{border-left:3px solid var(--primary);background:var(--code-bg);padding:16px 24px;margin:1.5rem 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text);font-style:italic}.markdown-content pre{background:#0d1f17;border-radius:var(--radius-sm);padding:20px 24px;overflow-x:auto;margin:1.5rem 0;border:1px solid var(--border)}[data-theme=light] .markdown-content pre{background:#f0fdf4}[data-theme=light] .markdown-content pre code{color:#065f46}.markdown-content code:not(pre code){background:var(--code-bg);color:var(--primary);padding:2px 8px;border-radius:6px;font-size:.88em}.markdown-content pre code{background:transparent;color:#e2e8f0}.markdown-content img{border-radius:var(--radius);margin:1.5rem 0;box-shadow:var(--shadow-lg)}.markdown-content hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}.markdown-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;border-radius:var(--radius-sm);overflow:hidden}.markdown-content td,.markdown-content th{padding:12px 16px;border:1px solid var(--border);text-align:left}.markdown-content th{background:var(--code-bg);font-weight:600;color:var(--text)}.view-meta{margin-bottom:40px;padding-bottom:28px;border-bottom:1px solid var(--border)}.view-meta h1{margin-bottom:10px;font-size:2.2rem}.view-meta .meta-line{color:var(--text);font-size:.9rem;display:flex;gap:20px;flex-wrap:wrap;align-items:center}.back-link{display:inline-flex;align-items:center;gap:6px;margin-bottom:28px;font-weight:500;padding:8px 16px;border-radius:10px;background:var(--btn-secondary-bg);border:1px solid var(--border);transition:all .25s;.detail-image-wrap{margin-bottom:32px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.detail-img{width:100%;height:400px;object-fit:cover;display:block}@media (max-width:768px){.detail-img{height:250px}}}.back-link:hover{background:var(--code-bg);border-color:var(--primary);transform:translateX(-4px)}.about-content{display:grid;grid-template-columns:280px 1fr;grid-gap:56px;gap:56px}.about-sidebar{text-align:center}.avatar-large{width:130px;height:130px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 0 40px rgba(16,185,129,.2);position:relative;overflow:hidden}.avatar-large:after{content:"";position:absolute;inset:-3px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent),var(--accent2));z-index:-1;opacity:.25;filter:blur(15px)}.about-sidebar h2{font-size:1.3rem;margin-bottom:4px}.tagline{color:var(--text);font-size:.88rem;margin-bottom:24px}.about-meta{display:flex;flex-direction:column;gap:10px;font-size:.9rem;color:var(--text)}.skills-list{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 32px}.skill-tag{padding:6px 16px;border-radius:999px;background:var(--code-bg);border:1px solid rgba(16,185,129,.15);font-size:.85rem;font-weight:500;color:var(--primary);transition:all .25s}.skill-tag:hover{background:rgba(16,185,129,.18);transform:translateY(-2px)}@media (max-width:768px){.about-content{grid-template-columns:1fr;gap:32px}.about-sidebar{text-align:left;display:flex;flex-direction:column;align-items:center;gap:20px;flex-wrap:wrap}.avatar-large{margin:0}.cards-grid{grid-template-columns:1fr}}.footer{margin-top:auto;border-top:1px solid var(--border);padding:28px 0;background:var(--surface);transition:background .3s,border .3s}.footer-inner{display:flex;justify-content:space-between;align-items:center;font-size:.88rem;color:var(--text)}.footer-links{display:flex;gap:20px}.footer-links a{color:var(--text);font-weight:500;transition:all .25s}