:root{--bg:#f8f9fc;--bg1:#f0f3f8;--bg2:#e8ecf3;--bg3:#dfe5f0;--cyan:#0891b2;--purple:#7c3aed;--pink:#db2777;--amber:#b45309;--white:#1a1f2e;--muted:#6b7280;--dimmer:#e5e7eb;--card:rgba(255,255,255,0.9);--border:rgba(8,145,178,0.2);--glow-c:rgba(8,145,178,0.15);--glow-p:rgba(124,58,237,0.15);}*{margin:0;padding:0;box-sizing:border-box}img{max-width:100%;height:auto;display:block}html{scroll-behavior:smooth}body{font-family:'Syne',sans-serif;background:var(--bg);color:var(--white);overflow-x:hidden;cursor:none}#cur{position:fixed;width:10px;height:10px;background:var(--cyan);border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s,width .2s,height .2s,background .2s;mix-blend-mode:screen}#cur-r{position:fixed;width:38px;height:38px;border:1px solid var(--cyan);border-radius:50%;pointer-events:none;z-index:9998;opacity:.45;transition:all .1s linear}body:has(a:hover) #cur,body:has(button:hover) #cur{width:18px;height:18px;background:var(--pink);transform:translate(-4px,-4px)}body:has(a:hover) #cur-r,body:has(button:hover) #cur-r{width:52px;height:52px;border-color:var(--pink);opacity:.25}#bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.4;pointer-events:none;z-index:1}nav{position:fixed;top:0;left:0;right:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 5%;backdrop-filter:blur(24px);background:rgba(248,249,252,.85);border-bottom:1px solid var(--border);transition:all .4s}.logo{font-family:'Clash Display',sans-serif;font-size:1.35rem;font-weight:700;background:linear-gradient(90deg,var(--cyan),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.5px}.nav-ul{display:flex;list-style:none;gap:2.5rem}.nav-ul a{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--muted);text-decoration:none;letter-spacing:2px;text-transform:uppercase;position:relative;transition:color .3s}.nav-ul a::after{content:'';position:absolute;bottom:-5px;left:0;width:0;height:1px;background:var(--cyan);transition:width .3s}.nav-ul a:hover{color:var(--cyan)}.nav-ul a:hover::after{width:100%}.hire-btn{font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;padding:.7rem 1.8rem;background:transparent;border:1px solid var(--cyan);color:var(--cyan);border-radius:3px;cursor:pointer;transition:all .3s;position:relative;overflow:hidden;text-decoration:none}.hire-btn::before{content:'';position:absolute;inset:0;background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .3s}.hire-btn:hover::before{transform:scaleX(1)}.hire-btn:hover{color:var(--bg)}.hire-btn span{position:relative;z-index:1}#hero{height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:2rem 5%}.hero-wrap{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;max-width:1200px;width:100%;z-index:2}.hero-eyebrow{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--cyan);letter-spacing:4px;text-transform:uppercase;margin-bottom:1.5rem;display:flex;align-items:center;gap:.8rem;opacity:0;animation:fadeUp .8s .3s forwards}.hero-eyebrow::before{content:'';display:block;width:30px;height:1px;background:var(--cyan)}.hero-h1{font-family:'Clash Display',sans-serif;font-size:clamp(3rem,6vw,3.2rem);font-weight:700;line-height:1.05;margin-bottom:1.5rem;opacity:0;animation:titleSlideUp .8s .5s forwards}.hero-h1 .line1{display:block;color:var(--white)}.hero-h1 .line2{display:block;background:linear-gradient(135deg,var(--cyan) 0%,var(--purple) 60%,var(--pink) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;background-size:200%;animation:gradShift 5s ease infinite}.hero-sub{font-size:1.05rem;color:var(--muted);line-height:1.8;margin-bottom:2.5rem;max-width:480px;font-weight:400;opacity:0;animation:fadeUp .8s .7s forwards}.hero-sub em{color:var(--white);font-style:normal}.hero-btns{display:flex;gap:1rem;opacity:0;animation:fadeUp .8s .9s forwards}.btn-filled{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;padding:.9rem 2.2rem;background:linear-gradient(135deg,var(--cyan),var(--purple));color:var(--bg);border:none;border-radius:3px;cursor:pointer;text-decoration:none;transition:transform .2s,box-shadow .2s;font-weight:700;display:inline-block}.btn-filled:hover{transform:translateY(-3px);box-shadow:0 12px 40px var(--glow-c)}.btn-ghost{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;padding:.9rem 2.2rem;background:transparent;color:var(--white);border:1px solid var(--dimmer);border-radius:3px;cursor:pointer;text-decoration:none;transition:all .2s;display:inline-block}.btn-ghost:hover{border-color:var(--purple);color:var(--purple)}.hero-right{display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeIn 1.2s .6s forwards;position:relative}.avatar-scene{position:relative;width:400px;height:400px}.avatar-ring-outer{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(0,245,212,.15);animation:spinSlow 25s linear infinite}.avatar-ring-outer::before{content:'';position:absolute;top:-6px;left:50%;width:12px;height:12px;background:var(--cyan);border-radius:50%;box-shadow:0 0 20px var(--cyan),0 0 40px var(--glow-c);transform:translateX(-50%)}.avatar-ring-mid{position:absolute;inset:30px;border-radius:50%;border:1px dashed rgba(139,92,246,.2);animation:spinSlow 18s linear infinite reverse}.avatar-ring-mid::before{content:'';position:absolute;bottom:-5px;left:50%;width:10px;height:10px;background:var(--purple);border-radius:50%;box-shadow:0 0 15px var(--purple);transform:translateX(-50%)}.avatar-card{position:absolute;inset:60px;border-radius:50%;background:linear-gradient(135deg,var(--bg2),var(--bg3));border:2px solid rgba(124,58,237,.3);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 0 80px rgba(124,58,237,.15),inset 0 0 60px rgba(8,145,178,.05)}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;filter:saturate(1.1)}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8ecf3,#dfe5f0);border-radius:50%;flex-direction:column;gap:.5rem}.avatar-placeholder img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.avatar-placeholder-icon{font-size:5rem;filter:grayscale(.2)}.avatar-placeholder-text{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--muted);letter-spacing:2px}.avatar-badge{position:absolute;bottom:30px;right:-10px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:.7rem 1rem;backdrop-filter:blur(20px);display:flex;align-items:center;gap:.6rem;font-size:.8rem;font-weight:500;white-space:nowrap}.badge-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite;box-shadow:0 0 10px #22c55e}.avatar-stat{position:absolute;top:40px;left:-20px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:.7rem 1rem;backdrop-filter:blur(20px);text-align:center}.stat-val{font-family:'Clash Display',sans-serif;font-size:1.6rem;font-weight:700;background:linear-gradient(135deg,var(--cyan),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.stat-label{font-size:.68rem;color:var(--muted);letter-spacing:1px;font-family:'JetBrains Mono',monospace}.scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.7rem;z-index:2;opacity:0;animation:fadeUp .8s 1.5s forwards}.scroll-hint span{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--muted);letter-spacing:3px;text-transform:uppercase}.scroll-chevrons{display:flex;flex-direction:column;align-items:center;gap:4px}.scroll-chevrons i{display:block;width:10px;height:10px;border-right:1px solid var(--cyan);border-bottom:1px solid var(--cyan);transform:rotate(45deg);animation:bounceDown .8s infinite alternate}.scroll-chevrons i:nth-child(2){animation-delay:.15s;opacity:.6}.scroll-chevrons i:nth-child(3){animation-delay:.3s;opacity:.3}section{position:relative;z-index:2}.section-wrap{max-width:1200px;margin:0 auto;padding:8rem 5%}.s-label{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--cyan);letter-spacing:4px;text-transform:uppercase;margin-bottom:1rem;display:flex;align-items:center;gap:.8rem}.s-label::before{content:'';display:block;width:24px;height:1px;background:var(--cyan)}.s-h2{font-family:'Clash Display',sans-serif;font-size:clamp(2rem,4.5vw,1.5rem);font-weight:700;line-height:1.15;margin-bottom:.8rem;opacity:0;animation:titleSlideUp .8s .3s forwards}.s-rule{width:48px;height:2px;background:linear-gradient(90deg,var(--cyan),var(--purple));margin-bottom:3.5rem;border-radius:1px}#about{background:linear-gradient(180deg,var(--bg) 0%,var(--bg1) 100%)}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}.about-img-wrap{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/5}.about-img-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--bg2),var(--bg3));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;border:1px solid var(--border)}.about-img-placeholder img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}.about-img-placeholder-icon{font-size:7rem;opacity:.7}.about-img-label{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--muted);letter-spacing:3px}.about-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,31,46,.6) 0%,transparent 60%);opacity:0;pointer-events:none}.about-chips{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;display:flex;flex-wrap:wrap;gap:.4rem}.chip{font-family:'JetBrains Mono',monospace;font-size:.62rem;padding:.3rem .7rem;border-radius:4px;border:1px solid var(--border);color:var(--cyan);background:rgba(8,145,178,.08);letter-spacing:1px}.about-text .s-h2{margin-bottom:1rem}.about-text p{font-size:.98rem;color:var(--muted);line-height:1.9;margin-bottom:1.2rem;font-weight:400}.about-text strong{color:var(--white);font-weight:500}.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2.5rem}.kpi{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.2rem;text-align:center;transition:transform .3s,border-color .3s}.kpi:hover{transform:translateY(-4px);border-color:rgba(0,245,212,.3)}.kpi-n{font-family:'Clash Display',sans-serif;font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--cyan),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.kpi-l{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:.2rem}#skills{background:var(--bg1)}.skills-tabs{display:flex;gap:.5rem;margin-bottom:2.5rem;flex-wrap:wrap}.tab-btn{font-family:'JetBrains Mono',monospace;font-size:.68rem;padding:.6rem 1.4rem;border-radius:4px;border:1px solid var(--dimmer);background:transparent;color:var(--muted);cursor:pointer;letter-spacing:2px;text-transform:uppercase;transition:all .25s}.tab-btn.active,.tab-btn:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(0,245,212,.05)}.skills-panel{display:none}.skills-panel.active{display:block}.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.tech-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.3rem 1.5rem;display:flex;align-items:center;gap:1rem;cursor:default;transition:all .35s;position:relative;overflow:hidden}.tech-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--cyan),var(--purple));transform:scaleY(0);transition:transform .3s}.tech-card:hover{transform:translateX(6px);border-color:rgba(0,245,212,.25)}.tech-card:hover::before{transform:scaleY(1)}.tech-icon{font-size:2rem;flex-shrink:0;line-height:1}.tech-info .tech-name{font-size:.92rem;font-weight:500;margin-bottom:.3rem}.tech-info .tech-level{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--muted);letter-spacing:1px}.tech-bar-mini{height:2px;background:rgba(255,255,255,.07);border-radius:1px;margin-top:.5rem;overflow:hidden}.tech-bar-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--purple));border-radius:1px;width:0;transition:width 1s cubic-bezier(.4,0,.2,1)}#experience{background:var(--bg)}.exp-grid{display:grid;grid-template-columns:1fr 2fr;gap:4rem;align-items:start}.exp-nav{position:sticky;top:7rem}.exp-nav-item{padding:1rem 1.4rem;border-left:2px solid var(--dimmer);cursor:pointer;transition:all .25s;font-size:.9rem;color:var(--muted)}.exp-nav-item.active,.exp-nav-item:hover{border-color:var(--cyan);color:var(--white);background:rgba(0,245,212,.03)}.exp-company{font-family:'Clash Display',sans-serif;font-size:1rem;font-weight:600;display:block;margin-bottom:.2rem}.exp-period{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--cyan);letter-spacing:2px}.exp-detail{display:none;animation:fadeUp .4s ease}.exp-detail.active{display:block}.exp-role{font-family:'Clash Display',sans-serif;font-size:1.9rem;font-weight:700;margin-bottom:.3rem}.exp-meta{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--purple);letter-spacing:2px;margin-bottom:1.5rem}.exp-desc{color:var(--muted);line-height:1.85;font-size:.97rem;margin-bottom:2rem}.exp-achievements{list-style:none;display:flex;flex-direction:column;gap:.8rem}.exp-achievements li{display:flex;gap:.8rem;align-items:flex-start;font-size:.93rem;color:var(--muted);line-height:1.6}.exp-achievements li::before{content:'▹';color:var(--cyan);flex-shrink:0;margin-top:2px}.exp-achievements strong{color:var(--white);font-weight:500}.exp-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem}#projects{background:var(--bg1)}.proj-filter{display:flex;gap:.5rem;margin-bottom:2.5rem;flex-wrap:wrap}.filter-btn{font-family:'JetBrains Mono',monospace;font-size:.65rem;padding:.5rem 1.1rem;border-radius:100px;border:1px solid var(--dimmer);background:transparent;color:var(--muted);cursor:pointer;letter-spacing:2px;text-transform:uppercase;transition:all .25s}.filter-btn.active,.filter-btn:hover{border-color:var(--purple);color:var(--purple);background:rgba(139,92,246,.07)}.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.proj-card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:all .4s;position:relative;box-shadow:0 4px 20px rgba(0,0,0,.1)}.proj-card:hover{transform:translateY(-8px);border-color:rgba(139,92,246,.4);box-shadow:0 20px 60px rgba(0,0,0,.15),0 0 40px var(--glow-p),inset 0 0 20px rgba(139,92,246,.1)}.proj-img{height:180px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.proj-img-bg{position:absolute;inset:0;transition:transform .5s}.proj-card:hover .proj-img-bg{transform:scale(1.06)}.proj-emoji{position:relative;z-index:1;font-size:4rem;filter:drop-shadow(0 4px 24px rgba(0,0,0,.5))}.proj-img-thumb{position:relative;z-index:1;width:100%;height:100%;object-fit:cover}.proj-overlay{position:absolute;inset:0;background:rgba(248,249,252,.3);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;gap:.8rem;opacity:0;transition:opacity .3s;z-index:2;flex-wrap:wrap;padding:1rem}.proj-card:hover .proj-overlay{opacity:1}.proj-link{font-family:'JetBrains Mono',monospace;font-size:.68rem;padding:.6rem 1.2rem;border-radius:4px;text-decoration:none;transition:transform .2s,box-shadow .2s;letter-spacing:1px;display:inline-flex;align-items:center;gap:.4rem}.proj-link.demo{background:var(--cyan);color:var(--bg);font-weight:700;box-shadow:0 4px 15px rgba(8,145,178,.3)}.proj-link.demo:hover{transform:scale(1.08);box-shadow:0 8px 25px rgba(8,145,178,.5)}.proj-link.code{border:1px solid var(--dimmer);color:var(--white);background:rgba(255,255,255,.05);box-shadow:0 2px 10px rgba(0,0,0,.1)}.proj-link.code:hover{transform:scale(1.08);border-color:var(--cyan);background:rgba(8,145,178,.1);box-shadow:0 4px 15px rgba(8,145,178,.3)}.proj-link:hover{transform:scale(1.05)}.proj-body{padding:1.7rem}.proj-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.ptag{font-family:'JetBrains Mono',monospace;font-size:.58rem;padding:.22rem .6rem;border-radius:3px;background:rgba(139,92,246,.12);border:1px solid rgba(139,92,246,.25);color:#a78bfa;letter-spacing:1px}.proj-name{font-family:'Clash Display',sans-serif;font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.proj-desc{color:var(--muted);font-size:.88rem;line-height:1.65}.proj-stats{display:flex;gap:1.5rem;margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid var(--dimmer)}.proj-stat{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--muted);display:flex;align-items:center;gap:.4rem}.proj-stat-dot{width:6px;height:6px;border-radius:50%}#contact{background:var(--bg)}.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:6rem;align-items:start}.contact-social{display:flex;flex-direction:column;gap:.8rem;margin-top:2rem}.s-link{display:flex;align-items:center;gap:1rem;padding:.9rem 1.2rem;border:1px solid var(--border);border-radius:8px;color:var(--muted);text-decoration:none;font-size:.9rem;transition:all .3s;backdrop-filter:blur(10px)}.s-link:hover{border-color:rgba(0,245,212,.3);color:var(--cyan);background:rgba(0,245,212,.03)}.s-link-icon{font-size:1.4rem;flex-shrink:0}.s-link-text .s-link-label{font-size:.68rem;color:var(--muted);font-family:'JetBrains Mono',monospace;letter-spacing:1px;margin-bottom:.1rem}.s-link-text .s-link-val{font-size:.9rem;color:var(--white);font-weight:500}.contact-form-wrap{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2.5rem;backdrop-filter:blur(20px)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.fgroup{display:flex;flex-direction:column;gap:.5rem}.fgroup.full{margin-bottom:1rem}.flabel{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--muted);letter-spacing:2px;text-transform:uppercase}.finput,.ftextarea{background:rgba(255,255,255,.8);border:1px solid var(--dimmer);border-radius:6px;padding:.85rem 1.1rem;color:var(--white);font-family:'Syne',sans-serif;font-size:.92rem;outline:none;transition:all .3s;width:100%;resize:none}.finput:focus,.ftextarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(0,245,212,.08)}.ftextarea{min-height:130px}.finput::placeholder,.ftextarea::placeholder{color:var(--muted)}.submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,var(--cyan),var(--purple));color:var(--bg);border:none;border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:.75rem;letter-spacing:3px;text-transform:uppercase;font-weight:700;cursor:pointer;transition:all .3s;margin-top:.5rem}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 10px 40px var(--glow-c)}footer{text-align:center;padding:2rem;border-top:1px solid var(--border);font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--muted);letter-spacing:2px;position:relative;z-index:2}footer .heart{color:var(--pink)}#loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;transition:opacity .7s,visibility .7s}#loader.out{opacity:0;visibility:hidden;pointer-events:none}.loader-logo{font-family:'Clash Display',sans-serif;font-size:1.2rem;font-weight:700;background:linear-gradient(90deg,var(--cyan),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:2px}.loader-track{width:200px;height:1px;background:rgba(255,255,255,.06);border-radius:1px;overflow:hidden}.loader-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--purple));border-radius:1px;width:0;transition:width .05s linear}.loader-num{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--cyan);letter-spacing:2px}.rv{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}.rv.in{opacity:1;transform:translateY(0)}.s-h2{transition:opacity .6s ease,transform .6s ease}.proj-card{transition:all .5s cubic-bezier(.34,.1,.68,1)}.tech-card{transition:all .4s ease}.exp-role,.kpi,.proj-name{transition:opacity .6s ease,transform .6s ease}[data-parallax]{will-change:transform}@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes titleSlideUp{from{opacity:0;transform:translateY(40px);letter-spacing:-.02em}to{opacity:1;transform:translateY(0);letter-spacing:normal}}@keyframes fadeInScale{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{from{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{from{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes spinSlow{from{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes gradShift{0%,100%{background-position:0%}50%{background-position:100%}}@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}}@keyframes bounceDown{from{transform:rotate(45deg) translateY(-3px)}to{transform:rotate(45deg) translateY(3px)}}@keyframes float{0%,100%{transform:translateY(0) rotateX(2deg) rotateY(-2deg)}50%{transform:translateY(-12px) rotateX(-2deg) rotateY(2deg)}}@keyframes slideUpOnScroll{from{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInOnScroll{0%{opacity:0;transform:translateX(-40px)}100%{opacity:1;transform:translateX(0)}}@keyframes scaleUpOnScroll{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes revealText{from{opacity:0;clip-path:inset(0 100% 0 0)}to{opacity:1;clip-path:inset(0 0 0 0)}}@keyframes staggerFade{0%{opacity:0;transform:translateY(20px)}100%{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.section-wrap{padding:6rem 4%}.hero-wrap{gap:3rem}.about-grid,.contact-grid{gap:4rem}.exp-grid{gap:3rem}.tech-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.proj-grid{grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:1.2rem}}@media(max-width:768px){:root{--bg:#f8f9fc;--bg1:#f0f3f8}html{scroll-behavior:auto}body{cursor:auto}#cur,#cur-r{display:none}nav{padding:.8rem 4%;border-bottom:1px solid var(--border)}.logo{font-size:1rem}.nav-ul,.hire-btn{display:none}#hero{height:auto;min-height:100vh;padding:2rem 4%}.hero-wrap{grid-template-columns:1fr;gap:2rem;padding-top:5rem}.hero-right{display:none}.hero-eyebrow{font-size:.65rem;gap:.5rem}.hero-eyebrow::before{width:20px}.hero-h1{font-size:clamp(2rem,5vw,3.5rem);line-height:1.1}.hero-sub{font-size:.95rem;line-height:1.7;max-width:100%}.hero-btns{flex-direction:column;gap:.7rem}.btn-filled,.btn-ghost{width:100%;text-align:center;font-size:.65rem;padding:.8rem 1.5rem}.section-wrap{padding:5rem 4%;max-width:100%}.s-h2{font-size:clamp(1.5rem,4vw,2rem)}.s-label{font-size:.6rem}#about{padding:0}.about-grid{grid-template-columns:1fr;gap:3rem}.about-img-wrap{aspect-ratio:auto;height:250px;border-radius:12px}.about-img-placeholder{border-radius:12px}.about-text .s-h2{margin-bottom:.8rem}.about-text p{font-size:.9rem;margin-bottom:1rem}.kpi-row{grid-template-columns:repeat(2,1fr);gap:.8rem;margin-top:2rem}.kpi{padding:.8rem;border-radius:8px}.kpi-n{font-size:1.5rem}.kpi-l{font-size:.55rem}#skills{padding:0}.skills-tabs{gap:.4rem;margin-bottom:2rem}.tab-btn{font-size:.6rem;padding:.5rem 1rem;border-radius:3px}.tech-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.8rem}.tech-card{padding:1rem 1.2rem;gap:.8rem;border-radius:8px}.tech-icon{font-size:1.6rem}.tech-info .tech-name{font-size:.85rem}.tech-info .tech-level{font-size:.6rem}#experience{padding:0}.exp-grid{grid-template-columns:1fr;gap:2rem;align-items:start}.exp-nav{position:relative;top:auto;display:flex;gap:.5rem;overflow-x:auto;margin-bottom:2rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);border-left:none}.exp-nav-item{padding:.7rem 1rem;font-size:.8rem;border-left:none;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0}.exp-nav-item.active{border-bottom-color:var(--cyan);border-left:none}.exp-role{font-size:1.3rem;margin-bottom:.2rem}.exp-meta{font-size:.65rem}.exp-desc{font-size:.9rem;margin-bottom:1.5rem}.exp-achievements{gap:.6rem}.exp-achievements li{font-size:.88rem}#projects{padding:0}.proj-filter{gap:.4rem;margin-bottom:2rem}.filter-btn{font-size:.6rem;padding:.4rem .9rem}.proj-grid{grid-template-columns:1fr;gap:1.2rem}.proj-card{border-radius:12px}.proj-img{height:180px;border-radius:12px 12px 0 0}.proj-emoji{font-size:3rem}.proj-overlay{gap:.6rem;border-radius:12px 12px 0 0}.proj-link{font-size:.62rem;padding:.5rem 1rem}.proj-body{padding:1.2rem}.proj-name{font-size:.95rem}.proj-desc{font-size:.85rem}.proj-stats{gap:1rem;font-size:.6rem}#contact{padding:0}.contact-grid{grid-template-columns:1fr;gap:3rem;align-items:start}.contact-social{gap:.6rem;margin-top:1.5rem}.s-link{padding:.8rem 1rem;font-size:.85rem;border-radius:8px}.s-link-icon{font-size:1.2rem}.contact-form-wrap{padding:1.8rem;border-radius:12px}.form-row{grid-template-columns:1fr;gap:.8rem;margin-bottom:.8rem}.fgroup{gap:.4rem}.flabel{font-size:.6rem}.finput,.ftextarea{padding:.75rem;font-size:.88rem;border-radius:5px}.ftextarea{min-height:110px}.submit-btn{padding:.85rem;font-size:.68rem;margin-top:.4rem;border-radius:5px}footer{padding:1.5rem 4%;font-size:.6rem}.scroll-hint{display:none}.avatar-badge,.avatar-stat{display:none}}@media(max-width:480px){:root{--bg:#f8f9fc}nav{padding:.6rem 3%}.logo{font-size:.9rem;letter-spacing:.2px}#hero{min-height:calc(100vh - 4rem)}.hero-wrap{gap:1.5rem;padding-top:4rem}.hero-eyebrow{font-size:.6rem;margin-bottom:1rem}.hero-h1{font-size:clamp(1.8rem,5vw,2.5rem);line-height:1.05;margin-bottom:1rem}.hero-sub{font-size:.88rem;line-height:1.6;margin-bottom:1.5rem}.hero-btns{gap:.6rem}.btn-filled,.btn-ghost{font-size:.6rem;padding:.7rem 1.2rem}.section-wrap{padding:4rem 3%}.s-label{font-size:.55rem;margin-bottom:.8rem;gap:.6rem}.s-label::before{width:16px}.s-h2{font-size:clamp(1.3rem,4vw,1.8rem);margin-bottom:.6rem}.s-rule{width:36px;margin-bottom:2.5rem}.about-img-wrap{height:200px;border-radius:10px}.about-text .s-h2{margin-bottom:.6rem}.about-text p{font-size:.85rem;margin-bottom:.8rem;line-height:1.6}.about-chips{bottom:1rem;left:1rem;right:1rem;gap:.3rem}.chip{font-size:.55rem;padding:.25rem .5rem}.kpi-row{grid-template-columns:1fr;gap:.6rem;margin-top:1.5rem}.kpi{padding:.7rem;border-radius:6px}.kpi-n{font-size:1.3rem}.kpi-l{font-size:.5rem}.skills-tabs{gap:.3rem;margin-bottom:1.5rem}.tab-btn{font-size:.55rem;padding:.4rem .8rem;border-radius:3px}.tech-grid{grid-template-columns:1fr;gap:.6rem}.tech-card{padding:.8rem 1rem;gap:.7rem;border-radius:6px}.tech-icon{font-size:1.4rem}.tech-info .tech-name{font-size:.8rem;margin-bottom:.2rem}.tech-info .tech-level{font-size:.55rem}.exp-nav{gap:.3rem;margin-bottom:1.5rem;padding-bottom:.4rem}.exp-nav-item{padding:.6rem .8rem;font-size:.75rem}.exp-company{font-size:.85rem;margin-bottom:.1rem}.exp-period{font-size:.55rem}.exp-role{font-size:1.1rem;margin-bottom:.2rem}.exp-meta{font-size:.6rem;margin-bottom:1.2rem}.exp-desc{font-size:.85rem;margin-bottom:1.2rem;line-height:1.6}.exp-achievements{gap:.5rem}.exp-achievements li{font-size:.8rem}.exp-tags{gap:.3rem;margin-top:1.2rem}.proj-filter{gap:.3rem;margin-bottom:1.5rem}.filter-btn{font-size:.55rem;padding:.35rem .8rem}.proj-grid{gap:.8rem}.proj-img{height:150px}.proj-emoji{font-size:2.5rem}.proj-link{font-size:.58rem;padding:.4rem .8rem}.proj-body{padding:1rem}.proj-name{font-size:.9rem;margin-bottom:.4rem}.proj-desc{font-size:.8rem;line-height:1.5}.proj-stats{gap:1rem;margin-top:.8rem;padding-top:.8rem;font-size:.55rem}.contact-grid{gap:2rem}.contact-social{gap:.5rem}.s-link{padding:.7rem .9rem;font-size:.8rem;border-radius:6px}.s-link-icon{font-size:1rem}.s-link-text .s-link-label{font-size:.6rem}.s-link-text .s-link-val{font-size:.8rem}.contact-form-wrap{padding:1.5rem;border-radius:10px}.form-row{gap:.6rem}.fgroup{gap:.3rem}.flabel{font-size:.55rem}.finput,.ftextarea{padding:.65rem;font-size:.85rem;border-radius:4px}.ftextarea{min-height:100px}.submit-btn{padding:.75rem;font-size:.6rem;border-radius:4px}footer{padding:1.2rem 3%;font-size:.55rem}}.features-modal{position:fixed;inset:0;background:rgba(26,31,46,.7);backdrop-filter:blur(8px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s ease}.features-modal.active{opacity:1;pointer-events:auto}.modal-content{background:var(--card);border:1px solid var(--border);border-radius:16px;max-width:600px;width:100%;max-height:85vh;overflow-y:auto;padding:2rem;box-shadow:0 20px 80px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.1);animation:modalSlideUp .3s ease}.modal-close{position:absolute;top:1.5rem;right:1.5rem;background:transparent;border:none;font-size:1.5rem;color:var(--muted);cursor:pointer;padding:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;z-index:1}.modal-close:hover{background:rgba(124,58,237,.15);color:var(--cyan)}.modal-header{margin-bottom:2rem}.modal-header h2{font-family:'Clash Display',sans-serif;font-size:1.8rem;font-weight:700;margin-bottom:.8rem;background:linear-gradient(135deg,var(--cyan),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.modal-desc{color:var(--muted);line-height:1.8;font-size:.95rem}.modal-features{margin-bottom:2rem}.modal-features h3,.modal-tech h3{font-family:'Clash Display',sans-serif;font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--white)}.modal-features ul{list-style:none;display:flex;flex-direction:column;gap:.8rem}.modal-features li{display:flex;gap:.8rem;align-items:flex-start;color:var(--muted);line-height:1.6;font-size:.92rem}.modal-features li::before{content:'✓';color:var(--cyan);font-weight:bold;flex-shrink:0}.modal-tech{margin-bottom:1rem}.tech-list{display:flex;flex-wrap:wrap;gap:.6rem}.tech-chip{font-family:'JetBrains Mono',monospace;font-size:.7rem;padding:.4rem .8rem;border-radius:4px;background:rgba(139,92,246,.12);border:1px solid rgba(139,92,246,.25);color:#a78bfa;letter-spacing:.5px}@keyframes modalSlideUp{from{opacity:0;transform:translateY(20px);filter:blur(4px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}