@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap");:root{--bg:#050810;--bg-2:#0a0e1a;--bg-card:rgba(255,255,255,0.03);--accent:#5eead4;--accent-2:#14b8a6;--accent-glow:#67e8f9;--accent-light:rgba(94,234,212,0.15);--text:#eae5ec;--text-muted:rgba(234,229,236,0.80);--border:rgba(255,255,255,0.08);--border-accent:rgba(94,234,212,0.3);--radius:12px;--radius-sm:8px;--font:"Montserrat",system-ui,-apple-system,sans-serif;--code-font:"JetBrains Mono","Fira Code","Cascadia Code","Consolas",monospace;--transition:0.3s cubic-bezier(0.4,0,0.2,1);--syn-keyword:#c084fc;--syn-string:#4ade80;--syn-variable:#60a5fa;--syn-function:#fb923c;--syn-comment:rgba(234,229,236,0.32);--syn-property:#5eead4;--syn-number:#f97316;--syn-punct:rgba(234,229,236,0.6)}html[data-theme=light]{--bg:#f0f1f5;--bg-2:#e4e6f0;--bg-card:rgba(255,255,255,0.7);--accent:#0d9488;--accent-2:#0f766e;--accent-glow:#0d9488;--accent-light:rgba(13,148,136,0.12);--text:#0c0e1a;--text-muted:rgba(12,14,26,0.65);--border:rgba(0,0,0,0.11);--border-accent:rgba(13,148,136,0.35);--syn-keyword:#7c3aed;--syn-string:#15803d;--syn-variable:#1d4ed8;--syn-function:#c2410c;--syn-comment:rgba(13,15,26,0.38);--syn-property:#0d9488;--syn-number:#ea580c;--syn-punct:rgba(13,15,26,0.5)}html[data-theme=light] .nav{background:rgba(240,241,245,.88)}html[data-theme=light] .nav-mobile-overlay{background:rgba(240,241,245,.98)}html[data-theme=light] .page-hero{background-image:radial-gradient(rgba(13,148,136,.14) 1px,transparent 0)}html[data-theme=light] .tech-stack-canvas-wrap{background:radial-gradient(ellipse at 50% 55%,rgba(13,148,136,.07) 0,rgba(240,241,245,.97) 70%)}html[data-theme=light] .setup-badge{background:rgba(240,241,245,.92)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:var(--accent);color:var(--bg)}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-glow)}img,video{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{color:var(--text);line-height:1.2;letter-spacing:-.02em}h1{font-size:clamp(2.8rem,7vw,6rem);font-weight:700}h2{font-size:clamp(1.8rem,4vw,3rem)}h2,h3{font-weight:600}h3{font-size:1.25rem}p{color:var(--text-muted);line-height:1.8}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--accent-2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 40px;display:flex;align-items:center;justify-content:space-between;background:rgba(5,8,16,.7);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:padding var(--transition),background var(--transition)}.nav-brand{font-size:1.4rem;font-weight:700;color:var(--text)!important;letter-spacing:-.02em}.nav-brand span{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:8px;list-style:none}.nav-links a{color:var(--text-muted)!important;font-size:.875rem;font-weight:500;letter-spacing:.04em;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid transparent;transition:all var(--transition)}.nav-links a.active,.nav-links a:hover{color:var(--accent)!important;border-color:var(--border-accent);background:var(--accent-light)}.nav-scrolled{box-shadow:0 4px 24px rgba(0,0,0,.5)}.nav-theme-toggle{background:transparent;border:1px solid var(--border);color:var(--text-muted);width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);font-size:.95rem;flex-shrink:0}.nav-theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}.nav-hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:all var(--transition)}.nav-mobile-overlay{display:none;position:fixed;inset:0;background:rgba(5,8,16,.97);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:99;align-items:center;justify-content:center;flex-direction:column;gap:24px}.nav-mobile-overlay.open{display:flex}.nav-mobile-overlay a{font-size:1.5rem;font-weight:600;color:var(--text-muted)!important;padding:12px 32px;border-radius:var(--radius);border:1px solid transparent;transition:all var(--transition)}.nav-mobile-overlay a:hover{color:var(--accent)!important;border-color:var(--border-accent);background:var(--accent-light)}.page-wrapper{min-height:100vh}.section{padding:100px 0}.container{max-width:1200px;margin:0 auto;padding:0 40px}.section-label{font-family:var(--code-font);font-size:.78rem;font-weight:500;letter-spacing:.04em;text-transform:none;color:var(--syn-comment);margin-bottom:16px;display:block}.section-label:before{content:"// ";color:var(--syn-comment)}.section-title{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;color:var(--text);margin-bottom:16px}.section-subtitle{font-size:1rem;color:var(--text-muted);max-width:520px;line-height:1.8}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background-image:radial-gradient(rgba(94,234,212,.07) 1px,transparent 0);background-size:36px 36px}.hero:after{content:"";inset:0;background:repeating-linear-gradient(0deg,rgba(0,0,0,.018),rgba(0,0,0,.018) 1px,transparent 0,transparent 3px)}.hero-circle,.hero:after{position:absolute;pointer-events:none;z-index:0}.hero-circle{border-radius:50%;animation:circleRotate 8s linear infinite}.hero-circle-1{width:600px;height:600px;background:radial-gradient(circle,rgba(94,234,212,.12) 0,rgba(20,184,166,.06) 40%,transparent 70%);top:-150px;right:-100px;filter:blur(40px);animation-duration:10s}.hero-circle-2{width:500px;height:500px;background:radial-gradient(circle,rgba(103,232,249,.1) 0,rgba(94,234,212,.04) 40%,transparent 70%);bottom:-100px;left:-80px;filter:blur(60px);animation-duration:14s;animation-direction:reverse}@keyframes circleRotate{0%{transform:rotate(0deg) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(1turn) scale(1)}}.hero-content{position:relative;z-index:1;text-align:center;padding:0 40px}.hero-greeting{font-size:1rem;font-weight:500;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:20px;display:block}.hero-name{font-size:clamp(3.5rem,8vw,7.5rem);font-weight:800;color:var(--text);line-height:1;letter-spacing:-.04em;margin-bottom:24px}.hero-name .accent{color:var(--accent)}.hero-subtitle{font-size:clamp(1rem,2vw,1.4rem);color:var(--text-muted);margin-bottom:48px;min-height:2em}.hero-subtitle .typed-cursor{color:var(--accent)}.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:all var(--transition);border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-glow);border-color:var(--accent-glow);color:var(--bg);transform:translateY(-2px);box-shadow:0 8px 24px rgba(94,234,212,.3)}.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light);transform:translateY(-2px)}.scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;animation:scrollBounce 2s ease-in-out infinite}.scroll-indicator:before{content:"";display:block;width:1px;height:48px;background:linear-gradient(to bottom,var(--accent),transparent)}@keyframes scrollBounce{0%,to{transform:translateX(-50%) translateY(0);opacity:1}50%{transform:translateX(-50%) translateY(8px);opacity:.6}}.about-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:80px;gap:80px;align-items:center}.about-image-wrap{position:relative}.about-image-wrap:before{content:"";position:absolute;inset:-2px;border-radius:20px;background:linear-gradient(135deg,var(--accent),transparent);z-index:-1;opacity:.4}.about-image-inner{border-radius:18px;overflow:hidden;background:var(--bg-2)}.about-image-inner img{width:100%;height:100%;object-fit:cover}.about-placeholder{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;color:var(--bg)}.about-bio{font-size:1rem;color:var(--text-muted);line-height:1.9;margin-bottom:32px}.about-meta{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px;margin-bottom:40px}.about-meta-label{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:4px}.about-meta-value{font-size:.95rem;color:var(--text);font-weight:500}.about-terminal{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:24px 0 28px;font-family:var(--code-font);font-size:.8rem}.about-terminal-bar{background:var(--bg-2);border-bottom:1px solid var(--border);padding:8px 14px;display:flex;align-items:center;gap:6px}.about-terminal-title{margin-left:8px;font-size:.7rem;color:var(--text-muted);font-family:var(--code-font)}.about-terminal-body{padding:14px 18px;display:flex;flex-direction:column;gap:3px}.about-terminal-line{display:flex;align-items:baseline;line-height:1.7;flex-wrap:wrap}.about-terminal-prompt{color:var(--accent);margin-right:6px;flex-shrink:0}.about-terminal-cmd{color:var(--text)}.about-terminal-key{color:var(--syn-property);white-space:pre}.about-terminal-sep{color:var(--text-muted)}.about-terminal-val{color:var(--syn-string)}.about-terminal-green{color:#28c840!important}.about-terminal-comment{color:var(--syn-comment);font-style:italic;opacity:.75}.about-terminal-link{color:var(--syn-string);text-decoration:none}.about-terminal-link:hover{text-decoration:underline}.about-terminal-cursor-line{display:flex;align-items:center;margin-top:6px}.about-terminal-cursor{display:inline-block;width:8px;height:14px;background:var(--accent);margin-left:4px;animation:codeBlink 1.2s step-end infinite}.tech-marquee-section{padding:40px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}.tech-marquee-item{display:inline-flex;align-items:center;gap:10px;padding:0 28px;font-size:.85rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap;transition:color var(--transition)}.tech-marquee-item:hover{color:var(--accent)}.tech-marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}.tech-stack-section{padding:100px 0;text-align:center}.tech-stack-canvas-wrap{width:100%;height:520px;border-radius:24px;overflow:hidden;background:radial-gradient(ellipse at 50% 55%,rgba(94,234,212,.05) 0,rgba(5,8,16,.97) 70%);border:1px solid rgba(94,234,212,.1);box-shadow:0 0 80px rgba(94,234,212,.03),inset 0 1px 0 rgba(94,234,212,.06);position:relative;margin-top:48px}.tech-stack-canvas-wrap:before{content:"";position:absolute;inset:0;border-radius:24px;background:radial-gradient(ellipse at 20% 80%,rgba(129,140,248,.06) 0,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(94,234,212,.07) 0,transparent 50%);pointer-events:none;z-index:1}.tech-grid-mobile{display:none;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:48px}.tech-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;font-size:.8rem;font-weight:600;color:var(--text-muted);transition:all var(--transition)}.tech-pill:hover{border-color:var(--border-accent);color:var(--accent);background:var(--accent-light)}.tech-pill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.timeline-section{padding:100px 0}.timeline{position:relative;padding-left:40px;margin-top:56px}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--accent-2),transparent)}.timeline-item{position:relative;padding-bottom:56px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-47px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 0 4px rgba(94,234,212,.2),0 0 16px rgba(94,234,212,.4);animation:dotPulse 2s ease-in-out infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 0 4px rgba(94,234,212,.2),0 0 16px rgba(94,234,212,.4)}50%{box-shadow:0 0 0 8px rgba(94,234,212,.08),0 0 24px rgba(94,234,212,.5)}}.timeline-item:not(:first-child) .timeline-dot{animation:none;background:var(--bg-2);border-color:var(--accent-2);box-shadow:0 0 0 3px rgba(20,184,166,.15)}.timeline-date{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.timeline-role{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:4px}.timeline-company{font-weight:500;margin-bottom:12px}.timeline-company,.timeline-desc{font-size:.9rem;color:var(--text-muted)}.timeline-desc{line-height:1.7;max-width:600px;text-align:justify}.portfolio-section{padding:100px 0}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:24px;gap:24px;margin-top:56px}.portfolio-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:all var(--transition);cursor:pointer}.portfolio-card:hover{border-color:var(--border-accent);transform:translateY(-4px);box-shadow:0 20px 48px rgba(0,0,0,.5),0 0 0 1px rgba(94,234,212,.1)}.portfolio-card-thumb{aspect-ratio:16/9;background:var(--bg-2);overflow:hidden;position:relative}.portfolio-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.portfolio-card:hover .portfolio-card-thumb img{transform:scale(1.05)}.portfolio-card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-2) 0,rgba(94,234,212,.05) 100%)}.portfolio-card-body{padding:24px}.portfolio-card-cat{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}.portfolio-card-title{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:10px;transition:color var(--transition)}.portfolio-card:hover .portfolio-card-title{color:var(--accent)}.portfolio-card-desc{font-size:.85rem;color:var(--text-muted);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.portfolio-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}.related-card:hover{border-color:var(--accent)!important}.portfolio-tag{font-size:.7rem;font-weight:600;padding:4px 10px;border-radius:100px;background:var(--accent-light);color:var(--accent);border:1px solid var(--border-accent)}.portfolio-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px}.portfolio-filter-btn{padding:8px 18px;border-radius:100px;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;cursor:pointer;transition:all var(--transition);background:transparent;border:1px solid var(--border);color:var(--text-muted)}.portfolio-filter-btn.active,.portfolio-filter-btn:hover{background:var(--accent-light);border-color:var(--border-accent);color:var(--accent)}.skills-section{padding:60px 0}.skills-groups{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:40px;gap:40px;margin-top:48px}.skills-group-title{font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:20px}.skill-item{margin-bottom:18px}.skill-header{display:flex;justify-content:space-between;margin-bottom:8px}.skill-name{font-size:.875rem;font-weight:500;color:var(--text)}.skill-pct{font-size:.75rem;font-weight:600;color:var(--accent)}.skill-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.skill-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-2),var(--accent));border-radius:2px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.contact-section{padding:100px 0;text-align:center;position:relative;overflow:hidden}.contact-section:before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(94,234,212,.06) 0,transparent 70%);pointer-events:none}.contact-email{font-size:clamp(1.2rem,3vw,2rem);font-weight:700;color:var(--text);text-decoration:none;border-bottom:2px solid var(--accent);padding-bottom:4px;transition:all var(--transition);display:inline-block;margin:32px 0}.contact-email:hover{color:var(--accent);border-color:var(--accent-glow)}.contact-socials{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:32px}.contact-social-link{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-muted)!important;font-size:.875rem;font-weight:600;transition:all var(--transition)}.contact-social-link:hover{border-color:var(--border-accent);color:var(--accent)!important;background:var(--accent-light);transform:translateY(-2px)}.footer{padding:32px 40px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.footer-copy{font-size:.8rem;color:var(--text-muted)}.footer-socials{display:flex;gap:16px}.footer-social-link{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted)!important;font-size:1rem;transition:all var(--transition)}.footer-social-link:hover{border-color:var(--border-accent);color:var(--accent)!important;background:var(--accent-light)}.page-hero{padding:140px 0 60px;text-align:center;position:relative;background-image:radial-gradient(rgba(94,234,212,.07) 1px,transparent 0);background-size:36px 36px}.page-hero:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-2),transparent)}.page-hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;color:var(--text);letter-spacing:-.03em}.page-hero-sub{font-size:1rem;color:var(--text-muted);margin-top:12px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:32px;transition:all var(--transition)}.card:hover{border-color:var(--border-accent);box-shadow:0 8px 32px rgba(0,0,0,.4)}.preloader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}.preloader.hidden{opacity:0;visibility:hidden}.preloader-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);margin:0 5px;animation:preloaderBounce .8s ease-in-out infinite}.preloader-dot:nth-child(2){animation-delay:.15s}.preloader-dot:nth-child(3){animation-delay:.3s}@keyframes preloaderBounce{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(-12px);opacity:1}}.custom-cursor{width:12px;height:12px;background:var(--accent);z-index:9999;transition:width .3s,height .3s,background .3s,transform .15s;mix-blend-mode:screen}.custom-cursor,.custom-cursor-ring{position:fixed;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%)}.custom-cursor-ring{width:40px;height:40px;border:1px solid rgba(94,234,212,.5);z-index:9998;transition:width .3s,height .3s,border-color .3s}.cursor-expanded .custom-cursor{width:40px;height:40px;background:rgba(94,234,212,.15);border:1px solid var(--accent)}.cursor-expanded .custom-cursor-ring{width:60px;height:60px}.resume-about{display:grid;grid-template-columns:auto 1fr;grid-gap:40px;gap:40px;align-items:start;padding:48px 0;border-bottom:1px solid var(--border);margin-bottom:48px}.resume-avatar{width:120px;height:120px;border-radius:50%;overflow:hidden;border:2px solid var(--border-accent);flex-shrink:0}.resume-avatar img{width:100%;height:100%;object-fit:cover}.resume-name{font-size:2rem;font-weight:700;color:var(--text);margin-bottom:4px}.resume-desig{font-size:1rem;color:var(--accent);font-weight:500;letter-spacing:.04em;margin-bottom:16px}.resume-bio{font-size:.95rem;color:var(--text-muted);line-height:1.8;max-width:700px;text-align:justify}.resume-email{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-size:.875rem;color:var(--accent)!important;font-weight:500}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:60px 0}.post-content{font-size:1.05rem;line-height:1.9;color:var(--text-muted);font-weight:400;-webkit-font-smoothing:antialiased}.post-content p:empty,.post-content p:has(>br:only-child){display:none}.post-content>*+*{margin-top:1em}.post-content h1,.post-content h2,.post-content h3,.post-content h4{letter-spacing:-.01em}.post-content h2{font-size:1.25rem;font-weight:700;color:var(--text);line-height:1.3;margin-top:2.4rem;margin-bottom:.5rem;padding-left:14px;border-left:2px solid var(--accent)}.post-content h3{font-size:.82rem;font-weight:500;color:var(--accent);font-family:var(--code-font);letter-spacing:.06em;text-transform:uppercase;margin-top:1.8rem;margin-bottom:.3rem}.post-content h3:before{content:"// ";opacity:.55}.post-content p{margin:0;color:var(--text-muted);line-height:1.9}.post-content p+p,.post-content section>*+*{margin-top:1em}.post-content section+section{margin-top:.75rem}.post-content b,.post-content strong{color:var(--text);font-weight:600}.post-content em,.post-content i{font-style:italic;color:var(--text)}.post-content a{color:var(--accent);text-decoration:underline;-webkit-text-decoration-color:rgba(94,234,212,.3);text-decoration-color:rgba(94,234,212,.3);text-underline-offset:3px;transition:color var(--transition),-webkit-text-decoration-color var(--transition);transition:color var(--transition),text-decoration-color var(--transition);transition:color var(--transition),text-decoration-color var(--transition),-webkit-text-decoration-color var(--transition)}.post-content a:hover{color:var(--accent-glow);-webkit-text-decoration-color:var(--accent-glow);text-decoration-color:var(--accent-glow)}.post-content hr{border:none;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:3rem 0}.post-content blockquote{border-left:2px solid var(--accent);margin:2rem 0;padding:14px 20px;background:rgba(94,234,212,.04);border-radius:0 8px 8px 0}.post-content blockquote p{color:var(--text);font-style:italic;margin:0}.post-content code{font-family:var(--code-font);font-size:.84em;background:rgba(94,234,212,.07);color:var(--accent);padding:2px 7px;border-radius:4px;border:1px solid rgba(94,234,212,.15)}.post-content pre{background:var(--bg-2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:20px 24px;overflow-x:auto;margin:2rem 0}.post-content pre code{background:none;border:none;padding:0;font-size:.875rem;color:var(--text)}.post-content ol,.post-content ul{padding-left:0;list-style:none;margin:.5rem 0}.post-content ol li,.post-content ul li{padding-left:1.6rem;position:relative;margin-bottom:.45rem;color:var(--text-muted);line-height:1.75}.post-content ul li:before{content:"→";position:absolute;left:0;color:var(--accent);font-size:.8em;top:.18em}.post-content ol{counter-reset:post-ol}.post-content ol li{counter-increment:post-ol}.post-content ol li:before{content:counter(post-ol,decimal-leading-zero) ".";position:absolute;left:0;color:var(--accent);font-family:var(--code-font);font-size:.72em;top:.22em;letter-spacing:.02em}.post-content img{display:block;width:100%;max-width:100%;border-radius:12px;margin:2rem 0;border:1px solid var(--border);cursor:zoom-in;transition:border-color var(--transition),box-shadow var(--transition)}.post-content img:hover{border-color:var(--border-accent);box-shadow:0 8px 32px rgba(0,0,0,.4),0 0 0 1px rgba(94,234,212,.1)}.post-lightbox{position:fixed;inset:0;z-index:9999;background:rgba(5,8,16,.92);display:flex;align-items:center;justify-content:center;padding:24px;cursor:zoom-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:lightboxIn .2s ease}@keyframes lightboxIn{0%{opacity:0}to{opacity:1}}@keyframes lightboxImgIn{0%{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}.post-lightbox img{max-width:min(1200px,100%);max-height:90vh;width:auto;height:auto;border-radius:12px;border:1px solid var(--border-accent);box-shadow:0 32px 80px rgba(0,0,0,.8);cursor:zoom-out;object-fit:contain;animation:lightboxImgIn .25s cubic-bezier(.34,1.56,.64,1)}.post-lightbox-close{position:absolute;top:20px;right:24px;background:none;border:1px solid var(--border);color:var(--text-muted);font-size:1.2rem;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.post-lightbox-close:hover{border-color:var(--accent);color:var(--accent)}@media (max-width:900px){.container{padding:0 24px}.nav{padding:16px 24px}.nav-links{display:none}.nav-hamburger{display:flex}.section{padding:72px 0}.hero-content{padding:0 24px}.hero-name{font-size:clamp(2.8rem,10vw,5rem)}.about-grid{grid-template-columns:1fr;gap:48px}.about-image-wrap{max-width:280px;margin:0 auto}.resume-about{grid-template-columns:1fr}.footer{padding:24px}}@media (max-width:600px){.hero-cta{flex-direction:column;align-items:center}.tech-stack-canvas-wrap{display:none}.tech-grid-mobile{display:flex}.about-meta,.portfolio-grid,.skills-groups{grid-template-columns:1fr}.scroll-indicator{display:none}}.fade-up{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}.fade-up.visible{opacity:1;transform:translateY(0)}.fade-up-delay-1{transition-delay:.1s}.fade-up-delay-2{transition-delay:.2s}.fade-up-delay-3{transition-delay:.3s}.fade-up-delay-4{transition-delay:.4s}.hero-split{display:grid;grid-template-columns:1fr 1fr;grid-gap:64px;gap:64px;align-items:center;max-width:1200px;width:100%;padding:0 40px;position:relative;z-index:1}.hero-left,.hero-left .hero-greeting{text-align:left}.hero-left .hero-cta{justify-content:flex-start}.code-window{background:#0c0f1a;border:1px solid rgba(255,255,255,.09);border-radius:14px;overflow:hidden;box-shadow:0 0 0 1px rgba(94,234,212,.06),0 24px 64px rgba(0,0,0,.7),0 0 40px rgba(94,234,212,.04);position:relative}.code-window:before{content:"";position:absolute;inset:-1px;border-radius:15px;background:linear-gradient(135deg,rgba(94,234,212,.12),transparent 60%);pointer-events:none;z-index:0}.code-window-bar{padding:12px 18px;background:rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:8px;position:relative;z-index:1}.code-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.code-dot-red{background:#ff5f57}.code-dot-yellow{background:#febc2e}.code-dot-green{background:#28c840}.code-window-filename{flex:1 1;text-align:center;font-family:var(--code-font);font-size:.7rem;color:rgba(234,229,236,.35);letter-spacing:.02em}.code-window-body{padding:22px 24px 24px;font-family:var(--code-font);font-size:.82rem;line-height:1.8;position:relative;z-index:1;min-height:280px}.code-line{display:flex;min-height:1.8em}.line-num{min-width:28px;color:rgba(234,229,236,.18);font-size:.72rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;text-align:right;padding-right:18px;flex-shrink:0;padding-top:1px}.line-content{flex:1 1;white-space:pre}.kw{color:var(--syn-keyword)}.str{color:var(--syn-string)}.var{color:var(--syn-variable)}.fn{color:var(--syn-function)}.cm{color:var(--syn-comment)}.prop{color:var(--syn-property)}.num{color:var(--syn-number)}.pun{color:var(--syn-punct)}.code-cursor{display:inline-block;width:2px;height:1.1em;background:var(--accent);vertical-align:text-bottom;margin-left:1px;border-radius:1px;animation:codeBlink 1s step-end infinite}@keyframes codeBlink{0%,to{opacity:1}50%{opacity:0}}.portfolio-tag{font-family:var(--code-font);font-size:.68rem;font-weight:500;padding:3px 8px;border-radius:4px;background:rgba(94,234,212,.07);color:var(--syn-property);border:1px solid rgba(94,234,212,.18);letter-spacing:.02em}.tech-marquee-item{font-family:var(--code-font);font-size:.78rem}.tech-pill{font-family:var(--code-font);font-size:.72rem;color:var(--syn-keyword);background:rgba(192,132,252,.07);border-color:rgba(192,132,252,.2)}.tech-pill:before{content:"<"}.tech-pill:after{content:"/>"}.nav-brand{font-family:var(--code-font)!important;font-size:1rem!important;letter-spacing:-.01em}.about-meta-label{font-family:var(--code-font);font-size:.68rem;color:var(--syn-property);text-transform:none;letter-spacing:.01em}.about-meta-label:after{content:":"}.about-meta-value{font-family:var(--code-font);font-size:.82rem;color:var(--syn-string)}.timeline-date{color:var(--syn-comment);letter-spacing:.02em}.skill-pct,.timeline-date{font-family:var(--code-font);font-size:.72rem}.btn-primary:hover{box-shadow:0 0 0 2px var(--accent),0 8px 32px rgba(94,234,212,.35),0 0 60px rgba(94,234,212,.1)}.post-cat-badge{display:inline-block;width:-moz-fit-content;width:fit-content;font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(94,234,212,.3);padding:3px 10px;border-radius:100px;margin-bottom:12px}.post-cat-badge,.post-meta{font-family:var(--code-font)}.post-meta{display:flex;gap:16px;font-size:.75rem;color:var(--text-muted);margin-top:14px;opacity:.7}.post-card-featured{display:grid;grid-template-columns:1fr 1fr;grid-gap:0;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;overflow:hidden;margin-top:40px;margin-bottom:48px;transition:all var(--transition);text-decoration:none;color:inherit}.post-card-featured:hover{border-color:var(--border-accent);transform:translateY(-3px);box-shadow:0 24px 56px rgba(0,0,0,.5),0 0 0 1px rgba(94,234,212,.1)}.post-card-featured-thumb{position:relative;aspect-ratio:4/3;background:var(--bg-2);overflow:hidden;min-height:280px}.post-card-featured-thumb img{transition:transform .6s ease}.post-card-featured:hover .post-card-featured-thumb img{transform:scale(1.04)}.post-card-featured-body{padding:36px 36px 32px;display:flex;flex-direction:column;justify-content:center}.post-card-featured-title{font-size:1.45rem;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:12px;transition:color var(--transition)}.post-card-featured:hover .post-card-featured-title{color:var(--accent)}.post-card-featured-excerpt{font-size:.9rem;color:var(--text-muted);line-height:1.75;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:24px;gap:24px}.post-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:all var(--transition);text-decoration:none;color:inherit;display:flex;flex-direction:column}.post-card:hover{border-color:var(--border-accent);transform:translateY(-4px);box-shadow:0 20px 48px rgba(0,0,0,.5),0 0 0 1px rgba(94,234,212,.1)}.post-card-thumb{aspect-ratio:16/9;background:var(--bg-2);overflow:hidden;position:relative}.post-card-thumb img{transition:transform .6s ease}.post-card:hover .post-card-thumb img{transform:scale(1.05)}.post-card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-2) 0,rgba(94,234,212,.04) 100%)}.post-card-thumb-icon{font-family:var(--code-font);font-size:1.6rem;color:var(--border-accent);letter-spacing:-.04em}.post-card-body{padding:22px 24px 24px;flex:1 1;display:flex;flex-direction:column}.post-card-title{font-size:1.05rem;font-weight:700;color:var(--text);line-height:1.4;margin-bottom:8px;transition:color var(--transition)}.post-card:hover .post-card-title{color:var(--accent)}.post-card-excerpt{font-size:.84rem;color:var(--text-muted);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1 1}.post-hero-meta{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;font-size:.78rem;color:var(--text-muted);font-family:var(--code-font);opacity:.8}.post-hero-meta-item{display:flex;align-items:center;gap:6px}.post-breadcrumb{display:flex;gap:8px;justify-content:center;font-size:.8rem;color:var(--text-muted);margin-bottom:20px;flex-wrap:wrap}.post-breadcrumb a{color:var(--text-muted);text-decoration:none;transition:color var(--transition)}.post-breadcrumb a:hover{color:var(--accent)}.post-cover-image{border-radius:16px;overflow:hidden;position:relative;aspect-ratio:16/9;margin-bottom:40px;margin-top:24px}.post-article{max-width:100%}.post-article+.divider,.post-article~.divider{margin:40px 0}.post-share-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.post-share-label{font-family:var(--code-font);font-size:.75rem;color:var(--syn-comment)}.post-share-btns{display:flex;gap:10px}.post-share-btn{display:flex;align-items:center;gap:7px;font-size:.82rem;padding:8px 16px}@media (max-width:768px){.post-card-featured{grid-template-columns:1fr}.post-card-featured-thumb{min-height:200px;aspect-ratio:16/9}.post-card-featured-body{padding:24px}.post-card-featured-title{font-size:1.2rem}.post-grid{grid-template-columns:1fr}}@media (max-width:900px){.hero-split{grid-template-columns:1fr;gap:40px;padding:0 24px}.hero-left,.hero-split{text-align:center}.hero-left .hero-cta{justify-content:center}}@media (max-width:600px){.hero-right{display:none}}.page-hero-path{display:block;font-family:var(--code-font);font-size:.72rem;color:var(--syn-comment);margin-bottom:16px;letter-spacing:.02em}.skills-code-window{background:#0c0f1a;border:1px solid rgba(255,255,255,.09);border-radius:14px;overflow:hidden;box-shadow:0 0 0 1px rgba(94,234,212,.06),0 16px 40px rgba(0,0,0,.6)}.skills-code-body{padding:16px 20px 20px;font-family:var(--code-font);font-size:.78rem}.skill-code-header{margin-bottom:12px}.skill-code-row{display:grid;grid-template-columns:120px 1fr 36px;align-items:center;grid-gap:10px;gap:10px;margin-bottom:10px;padding-left:16px}.skill-code-name{color:var(--syn-property)}.skill-code-bar{height:5px;background:rgba(255,255,255,.06);overflow:hidden}.skill-code-bar,.skill-code-fill{border-radius:3px;position:relative}.skill-code-fill{height:100%;background:linear-gradient(90deg,var(--accent-2),var(--accent));transition:width 1.4s cubic-bezier(.4,0,.2,1)}.skill-code-fill:after{content:"";position:absolute;right:-1px;top:-2px;bottom:-2px;width:3px;background:white;border-radius:2px;opacity:.7;box-shadow:0 0 6px var(--accent)}.skill-code-pct{color:var(--accent);font-size:.65rem;text-align:right}.skill-code-footer{margin-top:4px}.contact-terminal-wrap{max-width:560px;margin:0 auto 40px;text-align:left}.contact-terminal-wrap .code-window-body{min-height:auto}.setup-section{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.setup-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:0;gap:0;align-items:stretch;margin-top:48px;border-radius:20px;overflow:hidden;border:1px solid var(--border)}.setup-photo{position:relative;min-height:420px;background:var(--bg)}.setup-photo-fade{position:absolute;right:0;top:0;bottom:0;width:100px;background:linear-gradient(to right,transparent,var(--bg-2));pointer-events:none}.setup-spec-window{border-radius:0!important;border:none!important;box-shadow:none!important;border-left:1px solid var(--border)!important}.setup-spec-window:before{display:none}.setup-badge{position:absolute;bottom:16px;left:16px;background:rgba(5,8,16,.85);border:1px solid var(--border-accent);border-radius:100px;padding:6px 14px;font-family:var(--code-font);font-size:.7rem;color:var(--accent);display:flex;align-items:center;gap:8px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.setup-badge-dot{width:7px;height:7px;border-radius:50%;background:#28c840;box-shadow:0 0 6px #28c840;animation:dotPulse 2s ease-in-out infinite}@media (max-width:900px){.setup-grid{grid-template-columns:1fr}.setup-photo{min-height:260px}.setup-photo-fade{display:none}.setup-spec-window{border-left:none!important;border-top:1px solid var(--border)!important}}html{-webkit-text-size-adjust:100%}body{overflow-x:hidden}.typed-cursor{color:var(--accent);font-weight:300;opacity:1;animation:typedBlink .7s infinite}@keyframes typedBlink{0%,to{opacity:1}50%{opacity:0}}