*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#dfe8f7;--bg2:#d4e0f4;--glass:hsla(0,0%,100%,.45);--glass-b:hsla(0,0%,100%,.62);--border:hsla(0,0%,100%,.7);--border-hi:hsla(0,0%,100%,.85);--blue:#2271d1;--blue-dim:#a8c4e8;--cyan:#0aa3bf;--purple:#7c4fcf;--text:#1a2540;--text-dim:#3d5480;--text-muted:#7a93b8;--glow:rgba(74,120,200,.18);--glow-s:rgba(74,120,200,.08)}html{scroll-behavior:smooth}body{background:linear-gradient(135deg,#ccd9f0,#dce8f8 35%,#e8d8f5 65%,#cfe8f4);background-attachment:fixed;color:var(--text);font-family:DM Sans,sans-serif;min-height:100vh;overflow-x:hidden}.aurora{inset:0;overflow:hidden;pointer-events:none;position:fixed;z-index:0}.aurora:before{animation:drift1 18s ease-in-out infinite alternate;background:radial-gradient(ellipse,rgba(99,142,255,.55) 0,rgba(120,80,255,.28) 40%,transparent 70%);content:"";height:600px;left:-200px;position:absolute;top:-200px;width:900px}.aurora:after{animation:drift2 22s ease-in-out infinite alternate;background:radial-gradient(ellipse,rgba(220,100,255,.45) 0,rgba(100,180,255,.22) 45%,transparent 70%);bottom:-100px;content:"";height:500px;position:absolute;right:-100px;width:700px}.aurora-mid{animation:drift3 15s ease-in-out infinite alternate;background:radial-gradient(ellipse,rgba(30,200,230,.38) 0,rgba(80,140,255,.2) 50%,transparent 70%);height:400px;left:30%;position:absolute;top:40%;width:600px}.aurora-extra1{animation:drift1 20s ease-in-out 3s infinite alternate;background:radial-gradient(ellipse,rgba(255,140,100,.22) 0,rgba(255,80,160,.14) 50%,transparent 70%);height:350px;left:5%;position:absolute;top:60%;width:500px}.aurora-extra2{animation:drift2 17s ease-in-out 5s infinite alternate;background:radial-gradient(ellipse,rgba(60,220,180,.28) 0,rgba(40,160,255,.15) 50%,transparent 70%);height:320px;position:absolute;right:10%;top:10%;width:450px}@keyframes drift1{0%{transform:translate(0) scale(1)}to{transform:translate(120px,80px) scale(1.15)}}@keyframes drift2{0%{transform:translate(0) scale(1)}to{transform:translate(-80px,-60px) scale(1.2)}}@keyframes drift3{0%{transform:translate(0)}to{transform:translate(-60px,40px)}}.grid-overlay{background-image:linear-gradient(hsla(0,0%,100%,.12) 1px,transparent 0),linear-gradient(90deg,hsla(0,0%,100%,.12) 1px,transparent 0);background-size:60px 60px}#particles,.grid-overlay{inset:0;pointer-events:none;position:fixed;z-index:0}.glass{backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:#ffffff6b;border:1px solid hsla(0,0%,100%,.68);border-radius:20px;box-shadow:0 8px 32px #506ec81a,inset 0 1px #fffc}.glass,.glass-hi{overflow:hidden;position:relative}.glass-hi{backdrop-filter:blur(36px) saturate(200%);-webkit-backdrop-filter:blur(36px) saturate(200%);background:#ffffff94;border:1px solid hsla(0,0%,100%,.8);border-radius:20px;box-shadow:0 4px 6px #506ec80f,0 12px 40px #506ec824,0 0 0 1px #fff6,inset 0 1px #fffffff2,inset 0 -1px #506ec80f}.glass-hi:after,.glass:after{animation:shimmer 6s ease-in-out infinite;background:linear-gradient(105deg,transparent 30%,hsla(0,0%,100%,.18) 50%,transparent 70%);background-size:200% 100%;border-radius:inherit;content:"";inset:0;pointer-events:none;position:absolute}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.site-nav{align-items:center;display:flex;height:54px;left:50%;max-width:1140px;padding:0 6px 0 16px;position:fixed;top:14px;transform:translate(-50%);width:calc(100% - 56px);z-index:100}.nav-logo{background:linear-gradient(90deg,var(--blue),var(--cyan));-webkit-background-clip:text;font-family:Syne,sans-serif;font-size:1.05rem;font-weight:800;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.01em;margin-right:auto;padding-left:8px;text-decoration:none}.nav-links{align-items:center;display:flex;gap:8px}.nav-link{border-radius:10px;color:var(--text-dim);font-family:Syne,sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.09em;padding:7px 14px;text-decoration:none;text-transform:uppercase;transition:all .2s;white-space:nowrap}.nav-link:not(.nav-cta):hover{background:var(--bg2);color:var(--text)}.nav-link:not(.nav-cta).active{background:var(--blue-dim);box-shadow:0 2px 10px #506ec81f,inset 0 1px #ffffffe6;color:var(--blue)}@media(prefers-color-scheme:dark){.nav-link:not(.nav-cta).active{color:#fff}.nav-link:not(.nav-cta):hover{background:var(--blue-dim)}}.nav-dot{animation:blink 2.5s ease-in-out infinite;background:var(--cyan);border-radius:50%;box-shadow:0 0 6px var(--cyan);flex-shrink:0;height:5px;margin-left:10px;width:5px}@keyframes blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.nav-cta{align-items:center;animation:ctaGlow 3s ease-in-out infinite;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:10px;box-shadow:0 4px 14px #2271d166;color:#fff;display:inline-flex;flex-shrink:0;font-family:Syne,sans-serif;font-size:.74rem;font-weight:700;gap:7px;letter-spacing:.09em;margin-left:6px;overflow:hidden;padding:8px 18px;position:relative;text-decoration:none;text-transform:uppercase;transition:transform .2s,box-shadow .2s;white-space:nowrap}.nav-cta:before{animation:ctaShimmer 3.5s ease-in-out .8s infinite;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.3),transparent);content:"";height:100%;left:-100%;pointer-events:none;position:absolute;top:0;width:60%}.nav-cta-dot{animation:ctaDotBlink 2s ease-in-out infinite;background:#ffffffe6;border-radius:50%;box-shadow:0 0 5px #fffc;flex-shrink:0;height:6px;width:6px}.nav-cta:hover{animation-play-state:paused;box-shadow:0 6px 28px #2271d199,0 0 0 3px #2271d126;transform:translateY(-1px) scale(1.03)}.nav-cta:active{transform:scale(1.01) translateY(0)}.nav-cta.active{animation-play-state:paused;box-shadow:0 4px 14px #2271d180,0 0 0 2px #ffffff73}@keyframes ctaGlow{0%,to{box-shadow:0 4px 14px #2271d166}50%{box-shadow:0 4px 26px #2271d1ad,0 0 0 4px #2271d121}}@keyframes ctaShimmer{0%{left:-60%}to{left:160%}}@keyframes ctaDotBlink{0%,to{opacity:.9;transform:scale(1)}50%{opacity:.45;transform:scale(.65)}}@media(prefers-color-scheme:dark){.nav-cta{box-shadow:0 4px 18px #4a9eff59}@keyframes ctaGlow{0%,to{box-shadow:0 4px 18px #4a9eff59}50%{box-shadow:0 4px 30px #4a9eff99,0 0 0 4px #4a9eff1f}}.nav-cta:hover{box-shadow:0 6px 32px #4a9eff8c,0 0 0 3px #4a9eff2e}}.panel-title{align-items:center;color:var(--blue);display:flex;font-family:Syne,sans-serif;font-size:.68rem;font-weight:700;gap:10px;letter-spacing:.18em;margin-bottom:18px;text-transform:uppercase}.panel-title:after{background:linear-gradient(90deg,rgba(74,120,200,.5),transparent);content:"";flex:1;height:1px}.page{display:grid;gap:24px;grid-template-columns:320px 1fr;grid-template-rows:auto 1fr}.page,.page-single{margin:0 auto;max-width:1140px;padding:92px 28px 80px;position:relative;z-index:1}.page-hero{animation:fadeDown .6s ease both;margin-bottom:44px}.page-hero-label{color:var(--cyan);font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:300;letter-spacing:.2em;margin-bottom:10px;text-transform:uppercase}.page-hero-title{background:linear-gradient(90deg,#1a2540 0,var(--blue) 55%,var(--cyan) 100%);-webkit-background-clip:text;font-family:Syne,sans-serif;font-size:2.8rem;font-weight:800;letter-spacing:-.03em;line-height:1;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:14px}.page-hero-sub{color:var(--text-dim);font-size:.95rem;font-weight:300;line-height:1.7;max-width:560px}.header{align-items:center;animation:fadeDown .7s ease both;display:flex;gap:40px;grid-column:1/-1;overflow:hidden;padding:36px 44px;position:relative}.header:before{background:linear-gradient(105deg,rgba(120,160,255,.12),rgba(180,100,255,.08) 60%,transparent);border-radius:inherit;content:"";inset:0;position:absolute}.header-avatar{align-items:center;background:linear-gradient(135deg,var(--blue),var(--purple));border-radius:50%;box-shadow:0 0 0 3px #ffffffb3,0 8px 28px #506ec847;color:#fff;display:flex;flex-shrink:0;font-family:Syne,sans-serif;font-size:2.2rem;font-weight:800;height:90px;justify-content:center;position:relative;width:90px;z-index:1}.header-text{flex:1;position:relative;z-index:1}.header-name{background:linear-gradient(90deg,#1a2540 0,var(--cyan) 60%,var(--blue) 100%);-webkit-background-clip:text;font-family:Syne,sans-serif;font-size:2.6rem;font-weight:800;letter-spacing:-.02em;line-height:1;-webkit-text-fill-color:transparent;background-clip:text}.header-role{color:var(--blue);font-family:JetBrains Mono,monospace;font-size:1rem;font-weight:300;letter-spacing:.12em;margin-top:8px;text-transform:uppercase}.header-tagline{color:var(--text-dim);font-size:.9rem;font-weight:300;line-height:1.6;margin-top:10px;max-width:520px}.header-contacts{display:flex;flex-direction:column;gap:8px;margin-left:auto;position:relative;z-index:1}.contact-item{align-items:center;color:var(--text-dim);display:flex;font-family:JetBrains Mono,monospace;font-size:.82rem;font-weight:300;gap:10px}.contact-item .icon{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff8c;border:1px solid hsla(0,0%,100%,.8);border-radius:8px;box-shadow:0 2px 8px #506ec81a;display:flex;flex-shrink:0;font-size:.75rem;height:28px;justify-content:center;width:28px}.sidebar{animation:fadeLeft .7s ease .15s both;display:flex;flex-direction:column;gap:20px}.panel{animation:fadeUp .6s ease both;padding:24px 26px}.skill-item{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.skill-name{color:var(--text);font-size:.85rem;font-weight:400}.skill-tag>span{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffff80;border:1px solid hsla(0,0%,100%,.75);border-radius:4px;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.68rem;margin-top:1px;padding:1px 6px}.skill-bar-wrap{background:#ffffff73;border:1px solid hsla(0,0%,100%,.65);border-radius:3px;flex-shrink:0;height:5px;overflow:hidden;width:80px}.skill-bar-fill{animation:barGrow 1.2s cubic-bezier(.4,0,.2,1) both;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:3px;box-shadow:0 0 8px #4a78c859;height:100%;transform-origin:left}@keyframes barGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.lang-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.lang-name{font-size:.88rem}.lang-dots{display:flex;gap:5px}.dot{border-radius:50%;height:9px;width:9px}.dot.on{background:var(--blue);box-shadow:0 0 6px #4a78c880,inset 0 1px #fff6}.dot.off{background:#ffffff73;border:1px solid hsla(0,0%,100%,.72);box-shadow:inset 0 1px 2px #506ec81a}#constellation{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffff47;border:1px solid hsla(0,0%,100%,.65);border-radius:12px;height:120px;width:100%}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffff7a;border:1px solid hsla(0,0%,100%,.75);border-radius:20px;box-shadow:0 2px 8px #506ec814,inset 0 1px #ffffffe6;color:var(--blue);cursor:default;font-size:.75rem;font-weight:500;letter-spacing:.03em;padding:5px 12px;transition:all .2s}.chip:hover{background:#ffffffad;border-color:#ffffffeb;box-shadow:0 4px 16px #506ec826,inset 0 1px #fff;transform:translateY(-1px)}.main{display:flex;flex-direction:column;gap:20px}.exp-card{animation:fadeUp .6s ease both;overflow:hidden;padding:22px 26px;position:relative;transition:border-color .3s,box-shadow .3s}.exp-card:hover{border-color:#ffffffe6;box-shadow:0 8px 32px #506ec829,0 0 0 1px #ffffff80,inset 0 1px #fffffff2}.exp-card:before{background:linear-gradient(180deg,var(--blue),var(--cyan));border-radius:20px 0 0 20px;bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;transition:opacity .3s;width:3px}.exp-card:hover:before{opacity:1}.exp-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:8px}.exp-title{color:#1a2540;font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700}.exp-company{color:var(--blue);font-size:.83rem;font-weight:400;margin-top:3px}.exp-badge{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff7a;border:1px solid hsla(0,0%,100%,.72);border-radius:8px;color:var(--text-muted);flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.7rem;padding:4px 10px;white-space:nowrap}.exp-badge.current{background:#ffffff8c;border-color:#1ed2f066;box-shadow:0 0 14px #1ec8e62e,inset 0 1px #ffffffe6;color:#0a7a90}.exp-list{display:flex;flex-direction:column;gap:6px;list-style:none;margin-top:12px}.exp-list li{align-items:flex-start;color:var(--text-dim);display:flex;font-size:.85rem;font-weight:300;gap:10px;line-height:1.55}.exp-list li:before{color:var(--blue);content:"›";flex-shrink:0;font-size:1rem;font-weight:700;margin-top:-1px}.exp-list li span.hl{color:var(--text);font-weight:400}.edu-card{gap:20px;padding:20px 26px}.edu-card,.edu-icon{align-items:center;display:flex}.edu-icon{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffff85;border:1px solid hsla(0,0%,100%,.78);border-radius:14px;box-shadow:0 4px 12px #506ec81a,inset 0 1px #ffffffe6;flex-shrink:0;font-size:1.4rem;height:48px;justify-content:center;width:48px}.edu-degree{font-family:Syne,sans-serif;font-size:1rem;font-weight:700}.edu-school{color:var(--blue);font-size:.83rem;margin-top:3px}.edu-year{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.72rem;margin-top:4px}.filter-bar{animation:fadeUp .5s ease .1s both;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}.filter-btn{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#ffffff6b;border:1px solid hsla(0,0%,100%,.68);border-radius:10px;box-shadow:0 2px 8px #506ec80f,inset 0 1px #ffffffd9;color:var(--text-dim);cursor:pointer;font-family:Syne,sans-serif;font-size:.73rem;font-weight:700;letter-spacing:.1em;padding:7px 18px;text-transform:uppercase;transition:all .2s}.filter-btn:hover{background:#fff9;color:var(--text)}.filter-btn.active{background:#ffffffa6;border-color:#ffffffe0;box-shadow:0 4px 14px #506ec824,inset 0 1px #fff;color:var(--blue)}.portfolio-grid{display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.portfolio-card{animation:fadeUp .6s ease both;display:flex;flex-direction:column;overflow:hidden;padding:26px;position:relative;transition:border-color .3s,box-shadow .3s,transform .3s}.portfolio-card:hover{border-color:#ffffffe6;box-shadow:0 16px 48px #506ec82e,0 0 0 1px #ffffff80,inset 0 1px #fffffff2;transform:translateY(-4px)}.portfolio-card:before{content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.portfolio-card[data-cat~=web]:before{background:linear-gradient(90deg,var(--cyan),#42b883)}.portfolio-card[data-cat~=enterprise]:before{background:linear-gradient(90deg,var(--blue),var(--purple))}.portfolio-card[data-cat~=data]:before{background:linear-gradient(90deg,var(--purple),var(--blue))}.portfolio-card:hover:before{opacity:1}.card-featured{background:#0aa3bf1a;border:1px solid rgba(10,163,191,.3);border-radius:6px;color:var(--cyan);font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:400;letter-spacing:.12em;padding:2px 8px;position:absolute;right:16px;text-transform:uppercase;top:16px}.card-icon{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffff85;border:1px solid hsla(0,0%,100%,.75);border-radius:14px;box-shadow:0 4px 12px #506ec814,inset 0 1px #ffffffe6;display:flex;flex-shrink:0;font-size:1.5rem;height:50px;justify-content:center;margin-bottom:16px;width:50px}.card-client{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:300;letter-spacing:.08em;margin-bottom:6px}.card-title{color:var(--text);font-family:Syne,sans-serif;font-size:1.08rem;font-weight:700;line-height:1.3;margin-bottom:10px}.card-desc{color:var(--text-dim);flex:1;font-size:.84rem;font-weight:300;line-height:1.65;margin-bottom:20px}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.card-tag{background:#ffffff73;border:1px solid hsla(0,0%,100%,.68);border-radius:5px;color:var(--text-dim);font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:400;letter-spacing:.05em;padding:2px 8px}.card-footer{align-items:center;border-top:1px solid hsla(0,0%,100%,.55);display:flex;justify-content:space-between;padding-top:14px}.card-year{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.68rem}.card-cat-badge{border-radius:6px;font-family:Syne,sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.1em;padding:3px 9px;text-transform:uppercase}.badge-web{background:#0aa3bf1a;border:1px solid rgba(10,163,191,.25);color:#0aa3bf}.badge-enterprise{background:#2271d11a;border:1px solid rgba(34,113,209,.25);color:var(--blue)}.badge-data{background:#7c4fcf1a;border:1px solid rgba(124,79,207,.25);color:var(--purple)}.about-grid{align-items:start;display:grid;gap:24px;grid-template-columns:1fr 340px}.about-main,.about-sidebar{display:flex;flex-direction:column;gap:20px}.about-bio-card{animation:fadeUp .6s ease .1s both;padding:36px 38px}.about-bio-card p{color:var(--text-dim);font-size:.95rem;font-weight:300;line-height:1.8;margin-bottom:18px}.about-bio-card p:last-child{margin-bottom:0}.about-bio-card p strong{color:var(--text);font-weight:500}.about-approach-grid{animation:fadeUp .6s ease .2s both;display:grid;gap:16px;grid-template-columns:1fr 1fr}.approach-card{padding:22px 24px;transition:transform .2s,box-shadow .2s}.approach-card:hover{box-shadow:0 12px 36px #506ec829;transform:translateY(-3px)}.approach-icon{display:block;font-size:1.6rem;margin-bottom:12px}.approach-title{color:var(--text);font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;margin-bottom:8px}.approach-text{color:var(--text-dim);font-size:.82rem;font-weight:300;line-height:1.6}.currently-card{animation:fadeUp .6s ease .15s both;padding:26px 28px}.currently-row{align-items:flex-start;border-bottom:1px solid hsla(0,0%,100%,.45);display:flex;gap:12px;padding:10px 0}.currently-row:last-child{border-bottom:none;padding-bottom:0}.currently-dot{border-radius:50%;flex-shrink:0;height:8px;margin-top:5px;width:8px}.dot-blue{background:var(--blue);box-shadow:0 0 6px #2271d180}.dot-cyan{background:var(--cyan);box-shadow:0 0 6px #0aa3bf80}.dot-purple{background:var(--purple);box-shadow:0 0 6px #7c4fcf80}.currently-text{color:var(--text-dim);font-size:.84rem;font-weight:300;line-height:1.5}.currently-text strong{color:var(--text);font-weight:500}.interests-card{animation:fadeUp .6s ease .25s both;padding:26px 28px}.interests-list{display:flex;flex-direction:column;gap:8px;list-style:none}.interests-list li{align-items:center;color:var(--text-dim);display:flex;font-size:.84rem;font-weight:300;gap:10px;line-height:1.5}.interests-list li:before{color:var(--cyan);content:"→";flex-shrink:0;font-size:.9rem}.availability-card{animation:fadeUp .6s ease .3s both;padding:24px 26px}.avail-status{align-items:center;display:flex;gap:10px;margin-bottom:12px}.avail-dot{animation:blink 2s ease infinite;background:#22c55e;border-radius:50%;box-shadow:0 0 8px #22c55e99;height:10px;width:10px}.avail-label{color:#16a34a;font-family:Syne,sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.avail-text{color:var(--text-dim);font-size:.82rem;font-weight:300;line-height:1.55}.contact-grid{align-items:start;display:grid;gap:24px;grid-template-columns:1fr 360px}.contact-form-card{animation:fadeUp .6s ease .1s both;padding:36px 38px}.form-group{margin-bottom:20px}.form-label{color:var(--blue);display:block;font-family:Syne,sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.14em;margin-bottom:8px;text-transform:uppercase}.form-input,.form-textarea{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffff73;border:1px solid hsla(0,0%,100%,.68);border-radius:12px;box-shadow:inset 0 1px 3px #506ec812;color:var(--text);font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:300;outline:none;padding:12px 16px;resize:none;transition:border-color .2s,box-shadow .2s;width:100%}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-textarea:focus{background:#fff9;border-color:#2271d173;box-shadow:0 0 0 3px #2271d11a,inset 0 1px 3px #506ec812}.form-textarea{height:140px}.form-row{display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-btn{background:linear-gradient(90deg,var(--blue),var(--cyan));border:none;border-radius:12px;box-shadow:0 4px 18px #2271d159;color:#fff;cursor:pointer;font-family:Syne,sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.12em;padding:14px;text-transform:uppercase;transition:box-shadow .2s,transform .2s;width:100%}.form-btn:hover{box-shadow:0 6px 24px #2271d180;transform:translateY(-1px)}.form-btn:active{transform:translateY(0)}.form-success{padding:40px 20px;text-align:center}.form-success-icon{font-size:2.8rem;margin-bottom:16px}.form-success-title{color:var(--text);font-family:Syne,sans-serif;font-size:1.2rem;font-weight:700;margin-bottom:10px}.form-success-text{color:var(--text-dim);font-size:.88rem;font-weight:300;line-height:1.6}.contact-sidebar{display:flex;flex-direction:column;gap:20px}.contact-info-card{animation:fadeUp .6s ease .15s both;padding:28px 30px}.contact-info-row{align-items:center;border-bottom:1px solid hsla(0,0%,100%,.45);display:flex;gap:14px;padding:12px 0;transition:transform .2s}.contact-info-row:first-child{padding-top:0}.contact-info-row:last-child{border-bottom:none;padding-bottom:0}.contact-info-row:hover{transform:translate(4px)}.ci-icon{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffff85;border:1px solid hsla(0,0%,100%,.78);border-radius:10px;box-shadow:0 2px 8px #506ec814,inset 0 1px #ffffffe6;display:flex;flex-shrink:0;font-size:1rem;height:38px;justify-content:center;width:38px}.ci-label{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:300;letter-spacing:.08em;margin-bottom:2px;text-transform:uppercase}.ci-value{color:var(--text-dim);font-size:.84rem;font-weight:400}.ci-value a{color:var(--blue);text-decoration:none}.ci-value a:hover{text-decoration:underline}.social-card{animation:fadeUp .6s ease .22s both;padding:24px 28px}.social-links{display:flex;flex-direction:column;gap:10px}.social-link{align-items:center;background:#ffffff61;border:1px solid hsla(0,0%,100%,.62);border-radius:12px;color:var(--text-dim);display:flex;font-size:.85rem;font-weight:400;gap:12px;padding:10px 14px;text-decoration:none;transition:all .2s}.social-link:hover{background:#fff9;border-color:#ffffffd9;color:var(--blue);transform:translate(4px)}.social-link-icon{flex-shrink:0;font-size:1.1rem}.social-link-handle{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.72rem;margin-left:auto}@keyframes fadeDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:none}}@keyframes fadeLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:none}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}.delay-4{animation-delay:.4s}.delay-5{animation-delay:.5s}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#fff3}::-webkit-scrollbar-thumb{background:#ffffff8c;border:1px solid hsla(0,0%,100%,.8);border-radius:3px}.nav-mobile-controls{align-items:center;display:none;gap:8px}.nav-cta-mobile{font-size:.68rem!important;gap:5px!important;margin-left:0!important;padding:7px 13px!important}.mobile-menu-btn{align-items:center;background:#ffffff61;border:1px solid hsla(0,0%,100%,.68);border-radius:50%;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;gap:6px;height:38px;justify-content:center;padding:8px;transition:background .2s,border-color .2s,box-shadow .2s;width:38px}.mobile-menu-btn span{background:var(--text-dim);border-radius:2px;display:block;height:2px;transform-origin:center;transition:transform .32s cubic-bezier(.34,1.2,.64,1),opacity .18s ease,width .2s ease;width:22px}.mobile-menu-btn span:first-child,.mobile-menu-btn span:nth-child(3){align-self:center;width:14px}.mobile-menu-btn:hover{background:#ffffff94;box-shadow:0 0 0 4px #506ec81a}.mobile-menu-btn.is-open span:first-child{transform:translateY(6.5px) rotate(45deg);width:16px}.mobile-menu-btn.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}.mobile-menu-btn.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);width:16px}.mobile-menu-overlay{backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%);background:#040812b8;inset:0;opacity:0;overflow:hidden;pointer-events:none;position:fixed;transition:opacity .35s ease;z-index:300}.mobile-menu-overlay:before{animation:drift1 18s ease-in-out infinite alternate;background:radial-gradient(ellipse,rgba(0,200,170,.28) 0,rgba(20,160,200,.14) 45%,transparent 70%);content:"";height:260px;left:-60px;pointer-events:none;position:absolute;top:-60px;width:360px}.mobile-menu-overlay:after{animation:drift2 22s ease-in-out infinite alternate;background:radial-gradient(ellipse,rgba(120,60,220,.18) 0,rgba(60,120,255,.1) 50%,transparent 70%);bottom:80px;content:"";height:200px;pointer-events:none;position:absolute;right:-40px;width:280px}.mobile-menu-overlay.is-open{opacity:1;pointer-events:all}.mobile-menu-card{backdrop-filter:blur(52px) saturate(180%);-webkit-backdrop-filter:blur(52px) saturate(180%);background:#050814f0;border:1px solid hsla(0,0%,100%,.09);border-radius:28px;bottom:108px;box-shadow:inset 0 -2px #ffffff0f,0 8px 80px #000000b8,0 0 0 1px #ffffff08;left:18px;overflow:hidden;padding:6px 24px 10px;position:absolute;right:18px;transform:translateY(calc(100% + 130px));transition:transform .48s cubic-bezier(.34,1.1,.64,1)}.mobile-menu-overlay.is-open .mobile-menu-card{transform:translateY(0)}.mmcard-aurora{background:radial-gradient(ellipse,rgba(0,205,175,.42) 0,rgba(0,175,215,.2) 38%,transparent 66%);border-radius:50%;filter:blur(14px);height:200px;pointer-events:none;position:absolute;right:-50px;top:-70px;width:260px}.mobile-menu-section-label{color:#ffffff47;font-family:Syne,sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.2em;padding:16px 2px 10px;position:relative;text-align:left;text-transform:uppercase;z-index:1}.mobile-menu-item{align-items:center;border-bottom:1px solid hsla(0,0%,100%,.07);cursor:pointer;display:flex;gap:16px;justify-content:space-between;opacity:0;padding:13px 2px;position:relative;text-decoration:none;transform:translate(-10px);transition:border-color .18s;z-index:1}.mobile-menu-item:last-child{border-bottom:none;padding-bottom:10px}.mobile-menu-item:hover{border-color:#ffffff1f}.mobile-menu-overlay.is-open .mobile-menu-item{animation:mobileItemIn .38s ease forwards}.mobile-menu-overlay.is-open .mobile-menu-item:nth-child(3){animation-delay:.14s}.mobile-menu-overlay.is-open .mobile-menu-item:nth-child(4){animation-delay:.2s}.mobile-menu-overlay.is-open .mobile-menu-item:nth-child(5){animation-delay:.26s}.mobile-menu-overlay.is-open .mobile-menu-item:nth-child(6){animation-delay:.32s}@keyframes mobileItemIn{to{opacity:1;transform:translate(0)}}.mobile-item-label{color:#ffffffd1;font-family:Syne,sans-serif;font-size:1.15rem;font-weight:700;letter-spacing:-.01em;transition:color .18s;white-space:nowrap}.mobile-menu-item:hover .mobile-item-label{color:var(--text-dim)}.mobile-menu-item.active .mobile-item-label{color:var(--cyan)}.mobile-item-btn{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#1e263cb3;border:1px solid hsla(0,0%,100%,.12);border-radius:50%;box-shadow:0 4px 24px #00000059,inset 0 1px #ffffff1a;color:#ffffffbf;display:flex;flex-shrink:0;height:56px;justify-content:center;transition:background .2s,border-color .2s,box-shadow .2s,transform .2s;width:56px}.mobile-menu-item:hover .mobile-item-btn{background:#323e5fd9;border-color:#ffffff38;box-shadow:0 6px 28px #00000073,inset 0 1px #ffffff2e;color:#fff;transform:scale(1.06)}.mobile-menu-item.active .mobile-item-btn{background:#0aa3bf2e;border-color:#38d9f573;box-shadow:0 0 0 1px #38d9f533,0 4px 24px #0aa3bf40,inset 0 1px #ffffff1f;color:var(--cyan)}.mobile-item-btn.cta-btn{animation:ctaBtnGlow 3s ease-in-out infinite;background:linear-gradient(135deg,var(--blue) 0,var(--cyan) 100%);border:none;box-shadow:0 4px 28px #0aa3bf8c,0 0 0 1px #38d9f54d,inset 0 1px #ffffff40;color:#fff}.mobile-menu-item:hover .mobile-item-btn.cta-btn{background:linear-gradient(135deg,#3390ff,#0dd5f0);box-shadow:0 6px 40px #0aa3bfbf,0 0 0 3px #38d9f540,inset 0 1px #ffffff4d}.mobile-item-label.cta-label{color:#fff}.mobile-menu-item:hover .mobile-item-label.cta-label{color:var(--cyan)}@keyframes ctaBtnGlow{0%,to{box-shadow:0 4px 28px #0aa3bf8c,0 0 0 1px #38d9f54d,inset 0 1px #ffffff40}50%{box-shadow:0 4px 40px #0aa3bfcc,0 0 0 3px #38d9f533,inset 0 1px #ffffff40}}.mobile-menu-close-wrap{bottom:36px;left:50%;opacity:0;position:absolute;transform:translate(-50%) translateY(12px) scale(.88)}.mobile-menu-overlay.is-open .mobile-menu-close-wrap{animation:mobileCloseIn .4s cubic-bezier(.34,1.25,.64,1) .1s forwards}@keyframes mobileCloseIn{to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.mobile-menu-close-btn{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#141826cc;border:1px solid hsla(0,0%,100%,.13);border-radius:50%;box-shadow:0 4px 24px #00000059,inset 0 1px #ffffff14;color:#ffffff8c;cursor:pointer;display:flex;height:56px;justify-content:center;transition:background .2s,color .2s,transform .2s;width:56px}.mobile-menu-close-btn:hover{background:#323855e6;color:#ffffffe6;transform:scale(1.08)}.mobile-item-btn svg,.mobile-menu-close-btn svg{flex-shrink:0;height:22px;stroke-width:1.6;width:22px}body.menu-open{overflow:hidden}@media(max-width:960px){.portfolio-grid{grid-template-columns:1fr 1fr}.about-grid,.contact-grid{grid-template-columns:1fr}}@media(max-width:860px){.page{grid-template-columns:1fr}.header{flex-wrap:wrap}.header-contacts{flex-direction:row;flex-wrap:wrap;margin-left:0}.about-approach-grid{grid-template-columns:1fr}}@media(max-width:640px){.portfolio-grid{grid-template-columns:1fr}.site-nav{width:calc(100% - 28px)}.nav-links{display:none}.nav-mobile-controls{display:flex}.page-hero-title{font-size:2.1rem}}@media(prefers-color-scheme:dark){:root{--bg:#04050f;--bg2:#070c1a;--border:hsla(0,0%,100%,.1);--border-hi:rgba(120,180,255,.35);--blue:#4a9eff;--blue-dim:#1e4a80;--cyan:#38d9f5;--purple:#9b6dff;--text:#dce6f8;--text-dim:#7a92b8;--text-muted:#3d5580;--glow:rgba(74,158,255,.18);--glow-s:rgba(74,158,255,.08)}body{background:#04050f}.aurora:before{background:radial-gradient(ellipse,rgba(74,158,255,.12) 0,transparent 70%)}.aurora:after{background:radial-gradient(ellipse,rgba(155,109,255,.1) 0,transparent 70%)}.aurora-mid{background:radial-gradient(ellipse,rgba(56,217,245,.07) 0,transparent 70%)}.aurora-extra1{background:radial-gradient(ellipse,rgba(74,158,255,.06) 0,transparent 70%)}.aurora-extra2{background:radial-gradient(ellipse,rgba(155,109,255,.05) 0,transparent 70%)}.grid-overlay{background-image:linear-gradient(rgba(74,158,255,.025) 1px,transparent 0),linear-gradient(90deg,rgba(74,158,255,.025) 1px,transparent 0)}.glass{background:#ffffff0a;border:1px solid hsla(0,0%,100%,.1);box-shadow:none}.glass-hi{background:#ffffff0e;border:1px solid rgba(120,180,255,.35);box-shadow:0 0 0 1px #4a9eff14,0 8px 40px #00000080,inset 0 1px #ffffff1a}.glass-hi:after,.glass:after{background:linear-gradient(105deg,transparent 30%,hsla(0,0%,100%,.04) 50%,transparent 70%)}.header:before{background:linear-gradient(105deg,rgba(74,158,255,.08),rgba(155,109,255,.06) 60%,transparent)}.header-avatar{box-shadow:0 0 0 3px #4a9eff4d,0 0 30px #4a9eff40}.header-name{background:linear-gradient(90deg,#fff 0,var(--cyan) 60%,var(--blue) 100%);-webkit-background-clip:text;background-clip:text}.page-hero-title{background:linear-gradient(90deg,#fff 0,var(--blue) 55%,var(--cyan) 100%);-webkit-background-clip:text;background-clip:text}.contact-item .icon{-webkit-backdrop-filter:none;backdrop-filter:none;background:#4a9eff1a;border:1px solid rgba(74,158,255,.2);box-shadow:none}.skill-tag>span{-webkit-backdrop-filter:none;backdrop-filter:none;background:#ffffff0a;border:1px solid hsla(0,0%,100%,.07)}.skill-bar-wrap{background:#ffffff12;border:none}.skill-bar-fill{box-shadow:0 0 8px #4a9eff99}.dot.on{background:var(--blue);box-shadow:0 0 6px #4a9effb3}.dot.off{background:#ffffff1a;border:1px solid hsla(0,0%,100%,.15);box-shadow:none}#constellation{-webkit-backdrop-filter:none;backdrop-filter:none;background:#4a9eff08;border:1px solid rgba(74,158,255,.12)}.chip{-webkit-backdrop-filter:none;backdrop-filter:none;background:#4a9eff14;border:1px solid rgba(74,158,255,.2);box-shadow:none}.chip:hover{background:#4a9eff2e;border-color:#4a9eff73;box-shadow:0 0 12px #4a9eff33}.exp-card:hover{border-color:#4a9eff4d;box-shadow:0 0 0 1px #4a9eff14,0 12px 40px #00000080}.exp-title{color:#fff}.exp-badge{-webkit-backdrop-filter:none;backdrop-filter:none;background:#ffffff0a;border:1px solid hsla(0,0%,100%,.08)}.exp-badge.current{background:#38d9f512;border-color:#38d9f540;box-shadow:0 0 10px #38d9f51a;color:var(--cyan)}.edu-icon{-webkit-backdrop-filter:none;backdrop-filter:none;background:linear-gradient(135deg,#4a9eff26,#9b6dff26);border:1px solid rgba(74,158,255,.2);box-shadow:none}.nav-link:hover{background:#ffffff12}.nav-link.active{background:#4a9eff1f;border-color:#4a9eff40;box-shadow:none;color:var(--blue)}.filter-btn{background:#ffffff0a;border:1px solid hsla(0,0%,100%,.09)}.filter-btn:hover{background:#ffffff14}.filter-btn.active{background:#4a9eff1f;border-color:#4a9eff47;box-shadow:none;color:var(--blue)}.portfolio-card:hover{border-color:#4a9eff4d;box-shadow:0 16px 48px #00000080}.card-icon{-webkit-backdrop-filter:none;backdrop-filter:none;background:#4a9eff14;border:1px solid rgba(74,158,255,.15);box-shadow:none}.card-tag{background:#ffffff0a;border-color:#ffffff14}.card-title{color:#dce6f8}.card-footer{border-top-color:#ffffff14}.form-input,.form-textarea{background:#ffffff0d;border-color:#ffffff1a;color:var(--text)}.form-input:focus,.form-textarea:focus{background:#4a9eff14;border-color:#4a9eff59;box-shadow:0 0 0 3px #4a9eff14}.ci-icon{-webkit-backdrop-filter:none;backdrop-filter:none;background:#4a9eff14;border:1px solid rgba(74,158,255,.15);box-shadow:none}.contact-info-row{border-bottom-color:#ffffff12}.social-link{background:#ffffff08;border-color:#ffffff12}.social-link:hover{background:#4a9eff1a;border-color:#4a9eff40}.currently-row{border-bottom-color:#ffffff12}.avail-label{color:#4ade80}.mobile-menu-btn{background:#ffffff0d;border-color:#ffffff1f}.mobile-menu-btn span{background:var(--text)}.mobile-menu-btn:hover{background:#ffffff1a}.mobile-menu-overlay{background:#02040cd9}.mobile-menu-overlay:before{background:radial-gradient(ellipse,rgba(0,200,170,.22) 0,rgba(20,160,200,.1) 45%,transparent 70%)}.mobile-menu-overlay:after{background:radial-gradient(ellipse,rgba(100,40,200,.14) 0,rgba(60,100,255,.08) 50%,transparent 70%)}::-webkit-scrollbar-track{background:#04050f}::-webkit-scrollbar-thumb{background:#1e4a80;border:none}}
