@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&family=Manrope:wght@400;600;700;800&display=swap");:root{--bg-0:#07050f;--bg-1:#130a24;--bg-2:#251043;--text-main:#f4f2f2;--text-soft:#b2b4d0;--violet-main:#a855f7;--violet-soft:#c084fc;--violet-deep:#6d28d9;--line:rgba(255,255,255,0.09)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{min-height:100vh;background:radial-gradient(circle at 18% 28%,rgba(168,85,247,.2),transparent 40%),radial-gradient(circle at 72% 60%,rgba(192,132,252,.14),transparent 42%),linear-gradient(140deg,var(--bg-0),var(--bg-1) 48%,var(--bg-2));color:var(--text-main);font-family:Manrope,sans-serif}a{color:inherit;text-decoration:none}.hero-page{min-height:100vh;position:relative;overflow:hidden;padding-top:6.2rem;padding-bottom:4.6rem}.ambient{position:absolute;border-radius:999px;filter:blur(80px);pointer-events:none}.ambient-left{width:360px;height:360px;left:-120px;top:170px;background:rgba(168,85,247,.25);animation:drift 10s ease-in-out infinite}.ambient-right{width:420px;height:420px;right:-140px;bottom:30px;background:rgba(192,132,252,.16);animation:drift 13s ease-in-out infinite reverse}.topbar{width:min(1320px,94vw);margin:0;padding:.85rem 1rem;display:flex;justify-content:space-between;align-items:center;position:fixed;top:1rem;left:50%;transform:translateX(-50%);z-index:50;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:rgba(14,9,27,.55);border:1px solid rgba(255,255,255,.11);border-radius:16px;box-shadow:0 10px 24px rgba(4,2,12,.4)}.logo{width:42px;height:42px;border:1px solid var(--line);border-radius:10px;display:grid;place-items:center;font-weight:800;letter-spacing:.03em}.topbar nav{display:flex;gap:.55rem}.topbar nav a{position:relative;display:inline-block;padding:.52rem .72rem;border-radius:10px;font-size:.97rem;color:rgba(244,242,242,.86);transition:color .22s ease,transform .22s ease,background .22s ease}.topbar nav a:after{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.32rem;height:1.5px;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(216,180,254,.95),transparent);transform:scaleX(0);transform-origin:center;transition:transform .22s ease}.topbar nav a:hover{color:#ffffff;transform:translateY(-2px);background:rgba(168,85,247,.12)}.topbar nav a.is-active{color:#ffffff;background:rgba(168,85,247,.14);box-shadow:inset 0 0 0 1px rgba(216,180,254,.06)}.topbar nav a.is-active:after,.topbar nav a:hover:after{transform:scaleX(1)}.hero{width:min(1220px,94vw);margin:0 auto;min-height:calc(100vh - 104px);display:grid;grid-template-columns:1fr .95fr;grid-gap:4rem;gap:4rem;align-items:center;position:relative;z-index:2;padding:1.6rem 0 4rem}.hero-left{display:flex;flex-direction:column;gap:1.25rem;padding-right:1.2rem}.welcome-pill{margin:0 0 .25rem;display:inline-block;padding:.52rem 1.1rem;border-radius:999px;border:1px solid rgba(168,85,247,.45);font-size:.79rem;letter-spacing:.34em;color:#d8b4fe;max-width:-moz-fit-content;max-width:fit-content}.hero-title{margin:0;line-height:1.04;font-size:clamp(2rem,5.1vw,4.35rem);font-weight:800;letter-spacing:-.01em}.hero-title span{display:block}.hero-title span:last-child{color:var(--violet-main)}.lead{margin-top:0;max-width:660px;font-size:clamp(1.07rem,1.5vw,1.45rem);line-height:1.48;color:var(--text-soft)}.lead strong{color:#ffffff}.lead em,.swap-word{color:#d8b4fe;font-style:normal;font-weight:700}.swap-word{min-width:19ch}.caret,.swap-word{display:inline-block}.caret{width:1px;height:1.1em;margin-left:.32rem;margin-bottom:-.08rem;background:rgba(216,180,254,.9);animation:blink 1s step-end infinite}.swap-line{display:block;margin-top:.5rem;min-height:2.95em;color:rgba(178,180,208,.95)}.socials{margin-top:.15rem;display:flex;gap:.75rem}.socials a{width:50px;height:50px;border-radius:12px;display:grid;place-items:center;border:1px solid var(--line);background:rgba(255,255,255,.03);color:rgba(244,242,242,.85);transition:transform .22s ease,border-color .22s ease,background .22s ease,color .22s ease}.socials a:hover{transform:translateY(-3px);border-color:rgba(168,85,247,.6);background:rgba(168,85,247,.16);color:#ffffff}.socials a svg{width:21px;height:21px;fill:currentColor}.actions{margin-top:.45rem;display:flex;gap:.85rem;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;min-width:200px;padding:1.03rem 1.4rem;border-radius:16px;font-size:.94rem;font-weight:700;letter-spacing:.06em;transition:transform .22s ease,box-shadow .22s ease,background .22s ease,border-color .22s ease}.btn-primary{background:linear-gradient(130deg,var(--violet-main),var(--violet-deep));color:#fff;box-shadow:0 12px 26px rgba(168,85,247,.28)}.btn-secondary{border:1px solid var(--line);background:rgba(255,255,255,.04);color:#f1f1f1}.btn:hover{transform:translateY(-2px)}.btn-primary:hover{box-shadow:0 16px 28px rgba(168,85,247,.42)}.btn-secondary:hover{border-color:rgba(168,85,247,.44);background:rgba(168,85,247,.12)}.code-card{--rx:0deg;--ry:0deg;--sx:0px;--sy:0px;--mx:50%;--my:50%;--hovered:0;transform-style:preserve-3d;background:rgba(8,6,16,.78);border:1px solid rgba(255,255,255,.09);border-radius:24px;overflow:hidden;box-shadow:0 16px 36px rgba(0,0,0,.5),inset 0 0 0 1px rgba(168,85,247,.12);transform:perspective(1300px) translateX(var(--sx)) translateY(calc(var(--sy) + (-12px * var(--hovered)))) rotateX(var(--rx)) rotateY(var(--ry));transition:transform .28s cubic-bezier(.22,1,.36,1),box-shadow .28s ease,border-color .28s ease;will-change:transform}.code-card:hover{border-color:rgba(192,132,252,.42);box-shadow:0 26px 40px rgba(6,2,18,.7),0 16px 28px rgba(168,85,247,.24),inset 0 0 0 1px rgba(168,85,247,.32)}.code-card:after,.code-card:before{content:"";position:absolute;inset:0;pointer-events:none;transition:opacity .28s ease}.code-card:before{opacity:calc(.2 + (.5 * var(--hovered)));background:radial-gradient(circle at var(--mx) var(--my),rgba(216,180,254,.24) 0,rgba(168,85,247,.08) 24%,transparent 55%);mix-blend-mode:screen}.code-card:after{opacity:calc(.12 + (.35 * var(--hovered)));background:linear-gradient(130deg,rgba(255,255,255,.22),transparent 24%,transparent 66%,rgba(192,132,252,.2))}.about-section{width:min(1360px,96vw);min-height:72vh;display:grid;grid-template-columns:1.2fr .78fr;grid-gap:5rem;gap:5rem;align-items:stretch;margin:clamp(8rem,16vh,13rem) auto clamp(6rem,12vh,10rem);padding:2.4rem 0 2.2rem;scroll-margin-top:8.5rem;opacity:0;transform:perspective(1200px) translateY(120px) rotateX(8deg) scale(.94);filter:blur(10px);transition:opacity .76s cubic-bezier(.22,1,.36,1),transform .92s cubic-bezier(.22,1,.36,1),filter .76s ease}.about-section.is-visible{opacity:1;transform:perspective(1200px) translateY(0) rotateX(0deg) scale(1);filter:blur(0)}.about-left{padding:1.7rem 1.8rem 1.8rem;border:1px solid var(--line);border-radius:22px;background:radial-gradient(circle at 15% 10%,rgba(168,85,247,.2),transparent 45%),rgba(12,7,22,.74);display:flex;flex-direction:column;gap:1.5rem;opacity:0;transform:translateX(-56px);transition:opacity .65s ease,transform .75s cubic-bezier(.22,1,.36,1)}.about-kicker{margin:0;display:inline-flex;align-items:center;gap:.65rem;color:#d8b4fe;font-size:.8rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase}.kicker-icon{width:24px;height:24px;border-radius:8px;border:1px solid rgba(168,85,247,.5);background:rgba(168,85,247,.12);display:grid;place-items:center}.kicker-icon svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.about-left h2{margin:0;font-size:clamp(1.7rem,3.2vw,2.9rem);line-height:1.06;letter-spacing:-.01em}.about-left h2 span{color:var(--violet-main)}.about-card{border:1px solid rgba(255,255,255,.1);border-radius:22px;background:rgba(8,6,16,.56);padding:1.5rem 1.6rem;position:relative;display:grid;grid-gap:1.1rem;gap:1.1rem;transition:transform .26s cubic-bezier(.22,1,.36,1),border-color .26s ease,box-shadow .26s ease,background .26s ease}.about-card:after{content:"";position:absolute;inset:0;border-radius:22px;pointer-events:none;opacity:0;background:radial-gradient(circle at 82% 18%,rgba(216,180,254,.14),transparent 46%);transition:opacity .26s ease}.about-card:before{content:"";position:absolute;left:0;top:12%;bottom:12%;width:3px;border-radius:999px;background:linear-gradient(180deg,var(--violet-soft),transparent)}.about-card:hover{transform:translateY(-6px);border-color:rgba(192,132,252,.42);background:rgba(12,8,24,.76);box-shadow:0 22px 34px rgba(6,2,18,.58),0 10px 22px rgba(168,85,247,.2),inset 0 0 0 1px rgba(168,85,247,.22)}.about-card:hover:before{background:linear-gradient(180deg,#e9d5ff,rgba(192,132,252,.22),transparent)}.about-card:hover:after{opacity:1}.about-card p{margin:0;color:rgba(230,230,245,.86);font-size:clamp(.98rem,1.12vw,1.2rem);line-height:1.68;font-style:italic}.about-metrics{margin-top:auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));border-top:1px solid rgba(255,255,255,.09);padding-top:1.05rem}.about-metrics div{display:flex;flex-direction:column;gap:.28rem;padding-right:.9rem}.about-metrics div+div{border-left:1px solid rgba(255,255,255,.08);padding-left:1.2rem}.about-metrics strong{font-size:clamp(1.4rem,2.1vw,1.9rem);color:#ffffff}.about-metrics span{color:rgba(178,180,208,.86);font-size:.82rem;text-transform:uppercase;letter-spacing:.11em}.about-photo-shell{margin:0;min-height:520px;width:min(520px,100%);justify-self:end;opacity:0;transform:translateX(56px) scale(.97);transition:opacity .65s ease,transform .85s cubic-bezier(.22,1,.36,1)}.about-photo{--rx:0deg;--ry:0deg;--sx:0px;--sy:0px;--mx:50%;--my:50%;--hovered:0;margin:0;width:100%;height:100%;border:1px solid rgba(255,255,255,.08);border-radius:22px;overflow:hidden;position:relative;background:rgba(5,4,8,.7);transform:perspective(1300px) translateX(var(--sx)) translateY(calc(var(--sy) + (-12px * var(--hovered)))) rotateX(var(--rx)) rotateY(var(--ry));transform-style:preserve-3d;transition:transform .28s cubic-bezier(.22,1,.36,1),box-shadow .3s ease,border-color .3s ease;box-shadow:0 18px 34px rgba(4,2,12,.52),inset 0 0 0 1px rgba(168,85,247,.1);will-change:transform}.about-photo:after,.about-photo:before{content:"";position:absolute;inset:0;pointer-events:none;transition:opacity .3s ease}.about-photo:before{opacity:calc(.08 + (.45 * var(--hovered)));background:radial-gradient(circle at var(--mx) var(--my),rgba(216,180,254,.32) 0,rgba(168,85,247,.12) 28%,transparent 56%);mix-blend-mode:screen}.about-photo:after{opacity:calc(.06 + (.3 * var(--hovered)));background:linear-gradient(135deg,rgba(255,255,255,.2),transparent 25%,transparent 68%,rgba(192,132,252,.22))}.about-section.is-visible .about-left{opacity:1;transform:translateX(0);transition-delay:.18s}.about-section.is-visible .about-photo-shell{opacity:1;transform:translateX(0) scale(1);transition-delay:.28s}.about-photo:hover{border-color:rgba(192,132,252,.45);box-shadow:0 28px 42px rgba(6,2,18,.68),0 12px 24px rgba(168,85,247,.2),inset 0 0 0 1px rgba(168,85,247,.22)}.about-photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%) contrast(105%);transform:translate3d(calc(var(--sx) * -.2),calc(var(--sy) * -.2),42px);transition:transform .26s ease}.about-photo:hover img{transform:translate3d(calc(var(--sx) * -.3),calc(var(--sy) * -.3),48px)}.about-atmosphere-video{width:100%;height:100%;object-fit:cover;filter:brightness(.46) saturate(.72) contrast(1.02);transform:translate3d(calc(var(--sx) * -.18),calc(var(--sy) * -.18),42px) scale(1.02);transition:transform .26s ease,filter .26s ease}.about-photo:hover .about-atmosphere-video{transform:translate3d(calc(var(--sx) * -.28),calc(var(--sy) * -.28),48px) scale(1.05);filter:brightness(.54) saturate(.82) contrast(1.04)}.about-photo-copy{position:absolute;left:1.4rem;right:1.4rem;bottom:1.35rem;z-index:2;display:grid;grid-gap:.35rem;gap:.35rem;transform:translateZ(52px)}.about-photo-copy span{color:rgba(216,180,254,.84);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.about-photo-copy strong{max-width:280px;color:#f8f8ff;font-size:clamp(1.15rem,1.8vw,1.55rem);line-height:1.15;letter-spacing:-.03em;text-shadow:0 10px 28px rgba(0,0,0,.5)}.experience-section{width:min(1200px,calc(100vw - 100px));margin:0 auto;padding:9.5rem 0 7rem;opacity:0;transform:translateY(80px);filter:blur(6px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1),filter .7s ease}.experience-section.is-visible{opacity:1;transform:translateY(0);filter:blur(0)}.experience-title-wrap{display:flex;align-items:center;justify-content:center;margin-bottom:6.4rem}.experience-title-wrap:after,.experience-title-wrap:before{content:"";flex:1 1;height:1px;background:linear-gradient(90deg,transparent,rgba(168,85,247,.7),transparent)}.experience-title-pill{margin:0 1rem;padding:.72rem 1.7rem;border-radius:999px;background:rgba(6,4,10,.86);border:1px solid rgba(168,85,247,.35);color:#f8f8ff;font-weight:800;font-size:clamp(.92rem,1.35vw,1.18rem);box-shadow:0 10px 18px rgba(0,0,0,.35)}.experience-timeline{position:relative;display:grid;grid-gap:2.2rem;gap:2.2rem}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:1px;transform:translateX(-50%);background:linear-gradient(180deg,rgba(168,85,247,.68),rgba(168,85,247,.1))}.timeline-item{display:grid;grid-template-columns:1fr 64px 1fr;align-items:center;position:relative;min-height:100%}.experience-date{grid-column:1;align-self:center;justify-self:end;display:inline-flex;align-items:center;gap:.55rem;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);color:rgba(222,224,245,.62);border-radius:999px;padding:.55rem .78rem;min-width:160px;transition:transform .3s ease,border-color .3s ease,background .3s ease,color .3s ease,box-shadow .3s ease;margin-top:0}.experience-date span{width:15px;height:15px;color:rgba(216,180,254,.48)}.experience-date svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.experience-date p{margin:0;font-size:.82rem}.experience-card{align-self:center;border:1px solid rgba(255,255,255,.1);border-radius:24px;background:radial-gradient(circle at 18% 8%,rgba(168,85,247,.08),transparent 42%),rgba(10,6,18,.42);padding:1.2rem 1.3rem;width:min(520px,100%);box-shadow:0 16px 30px rgba(4,2,12,.34),inset 0 0 0 1px rgba(168,85,247,.08);filter:saturate(.8) brightness(.88);transition:transform .32s cubic-bezier(.22,1,.36,1),border-color .32s ease,background .32s ease,box-shadow .32s ease,filter .32s ease}.experience-card,.timeline-item.is-left .experience-date{grid-column:3;justify-self:start}.timeline-item.is-left .experience-card{grid-column:1;justify-self:end}.experience-card h3{margin:0;font-size:clamp(1.25rem,1.9vw,1.6rem);color:rgba(255,255,255,.56)}.experience-card h3,.experience-company{transition:color .32s ease,text-shadow .32s ease}.experience-company{margin-top:.45rem;color:rgba(216,180,254,.5);font-weight:600;font-size:clamp(.8rem,.9vw,.88rem)}.experience-card ul{margin:.9rem 0 0;padding:0;list-style:none;display:grid;grid-gap:.6rem;gap:.6rem}.experience-card li{position:relative;padding-left:1.25rem;color:rgba(219,220,239,.45);font-size:clamp(.78rem,.88vw,.88rem);line-height:1.52;transition:color .32s ease,text-shadow .32s ease}.experience-card li:before{content:">";position:absolute;left:.2rem;top:.02rem;color:rgba(168,85,247,.42);font-size:1.05em;transition:color .32s ease,text-shadow .32s ease,transform .32s ease}.timeline-item:hover .experience-date{color:rgba(244,242,242,.94);border-color:rgba(192,132,252,.36);background:rgba(168,85,247,.1);box-shadow:0 10px 22px rgba(18,8,34,.3)}.timeline-item:hover .experience-date span{color:#d8b4fe}.timeline-item:hover .experience-card{transform:translateY(-8px);border-color:rgba(192,132,252,.38);background:radial-gradient(circle at 18% 8%,rgba(168,85,247,.22),transparent 44%),rgba(10,6,18,.78);box-shadow:0 24px 40px rgba(4,2,12,.58),0 10px 24px rgba(168,85,247,.16),inset 0 0 0 1px rgba(168,85,247,.18);filter:saturate(1) brightness(1)}.timeline-item:hover .experience-card h3{color:#ffffff;text-shadow:0 0 18px rgba(216,180,254,.12)}.timeline-item:hover .experience-company{color:#d8b4fe;text-shadow:0 0 16px rgba(168,85,247,.16)}.timeline-item:hover .experience-card li{color:rgba(232,234,248,.92);text-shadow:0 0 14px rgba(168,85,247,.08)}.timeline-item:hover .experience-card li:before{color:#c084fc;text-shadow:0 0 12px rgba(192,132,252,.28);transform:translateX(2px)}.stack-section{width:min(1320px,calc(100vw - 72px));margin:0 auto;padding:8.5rem 0 5.5rem;scroll-margin-top:8.5rem;opacity:0;transform:translateY(90px);filter:blur(8px);transition:opacity .76s cubic-bezier(.22,1,.36,1),transform .86s cubic-bezier(.22,1,.36,1),filter .76s ease}.stack-section.is-visible{opacity:1;transform:translateY(0);filter:blur(0)}.stack-heading{display:grid;grid-gap:.7rem;gap:.7rem;justify-items:center;text-align:center;margin-bottom:3.8rem}.stack-kicker{margin:0;position:relative;padding:0 1.2rem;color:#d8b4fe;font-size:.8rem;font-weight:700;letter-spacing:.34em;text-transform:uppercase}.stack-kicker:after,.stack-kicker:before{content:"";position:absolute;top:50%;width:42px;height:1px;background:linear-gradient(90deg,transparent,rgba(216,180,254,.72))}.stack-kicker:before{right:100%}.stack-kicker:after{left:100%;transform:scaleX(-1)}.stack-heading h2{margin:0;font-size:clamp(2rem,4.5vw,4rem);line-height:.98;letter-spacing:-.03em}.stack-heading h2 span{color:var(--violet-main)}.stack-marquees{display:grid;grid-gap:1.4rem;gap:1.4rem}.marquee-row{--marquee-gap:1rem;position:relative;overflow:hidden;padding:.45rem 0}.marquee-track{display:flex;width:max-content;gap:var(--marquee-gap);animation:marquee-left 30s linear infinite;will-change:transform}.marquee-row-bottom .marquee-track{animation-name:marquee-right;animation-duration:33s}.marquee-row:hover .marquee-track{animation-play-state:paused}.stack-card{min-width:268px;flex:0 0 auto;display:flex;align-items:center;gap:1.1rem;padding:1.2rem 1.3rem;border-radius:24px;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at 14% 18%,rgba(168,85,247,.07),transparent 40%),rgba(12,8,22,.46);box-shadow:0 16px 28px rgba(4,2,12,.28),inset 0 0 0 1px rgba(168,85,247,.05);filter:saturate(.78) brightness(.82);transition:transform .26s cubic-bezier(.22,1,.36,1),border-color .26s ease,background .26s ease,box-shadow .26s ease,filter .26s ease}.stack-card:hover{transform:translateY(-7px) scale(1.02);border-color:rgba(216,180,254,.35);background:radial-gradient(circle at 14% 18%,rgba(168,85,247,.24),transparent 42%),rgba(15,10,28,.84);box-shadow:0 24px 38px rgba(5,2,14,.5),0 10px 22px rgba(168,85,247,.16),inset 0 0 0 1px rgba(168,85,247,.14);filter:saturate(1) brightness(1)}.stack-icon{width:60px;height:60px;border-radius:18px;flex:0 0 auto;display:grid;place-items:center;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:rgba(168,85,247,.62);transition:color .26s ease,border-color .26s ease,background .26s ease,box-shadow .26s ease,transform .26s ease}.stack-card:hover .stack-icon{color:#d8b4fe;border-color:rgba(216,180,254,.26);background:rgba(168,85,247,.14);box-shadow:0 0 22px rgba(168,85,247,.12),inset 0 0 0 1px rgba(216,180,254,.1);transform:translateY(-1px)}.stack-icon svg{width:30px;height:30px;display:block;overflow:visible}.stack-copy{display:grid;grid-gap:.2rem;gap:.2rem}.stack-copy strong{font-size:1.02rem;color:rgba(255,255,255,.72);transition:color .26s ease,text-shadow .26s ease}.stack-copy span{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(178,180,208,.42);transition:color .26s ease}.stack-card:hover .stack-copy strong{color:#ffffff;text-shadow:0 0 18px rgba(216,180,254,.12)}.stack-card:hover .stack-copy span{color:rgba(216,180,254,.72)}.projects-section{width:min(1320px,calc(100vw - 72px));margin:0 auto;padding:8.6rem 0 7.2rem;scroll-margin-top:8.5rem;opacity:0;transform:translateY(92px);filter:blur(8px);transition:opacity .76s cubic-bezier(.22,1,.36,1),transform .86s cubic-bezier(.22,1,.36,1),filter .76s ease}.projects-section.is-visible{opacity:1;transform:translateY(0);filter:blur(0)}.projects-title-wrap{display:flex;align-items:center;justify-content:center;margin-bottom:5.2rem}.projects-title-wrap:after,.projects-title-wrap:before{content:"";flex:1 1;height:1px;background:linear-gradient(90deg,transparent,rgba(168,85,247,.7),transparent)}.projects-title-pill{margin:0 1rem;padding:.72rem 1.7rem;border-radius:999px;background:rgba(6,4,10,.86);border:1px solid rgba(168,85,247,.35);color:#f8f8ff;font-weight:800;font-size:clamp(.92rem,1.35vw,1.18rem);box-shadow:0 10px 18px rgba(0,0,0,.35)}.projects-heading{display:grid;grid-gap:.9rem;gap:.9rem;justify-items:center;text-align:center;margin-bottom:3.6rem}.projects-kicker{margin:0;color:#d8b4fe;font-size:.84rem;font-weight:700;letter-spacing:.4em;text-transform:uppercase}.projects-heading h2{margin:0;font-size:clamp(2.2rem,5vw,4.4rem);line-height:.98;letter-spacing:-.04em}.projects-heading h2 span{color:var(--violet-main)}.projects-heading p{margin:0;max-width:760px;color:rgba(186,188,216,.9);font-size:clamp(1rem,1.35vw,1.35rem);line-height:1.6}.projects-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:1.35rem;gap:1.35rem;align-items:start}.project-card{height:-moz-fit-content;height:fit-content;align-self:start;border-radius:28px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at 16% 0,rgba(168,85,247,.08),transparent 36%),rgba(10,6,18,.56);box-shadow:0 18px 34px rgba(4,2,12,.34),inset 0 0 0 1px rgba(168,85,247,.04);transition:transform .32s cubic-bezier(.22,1,.36,1),border-color .32s ease,box-shadow .32s ease,background .32s ease}.project-card:hover{transform:translateY(-10px);border-color:rgba(216,180,254,.26);background:radial-gradient(circle at 16% 0,rgba(168,85,247,.16),transparent 42%),rgba(12,8,22,.78);box-shadow:0 28px 48px rgba(4,2,12,.5),0 12px 22px rgba(168,85,247,.12),inset 0 0 0 1px rgba(168,85,247,.08)}.project-preview{height:246px;position:relative;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.08)}.project-preview>*{transform:scale(1);transform-origin:center;transition:transform .52s cubic-bezier(.22,1,.36,1)}.project-card:hover .project-preview>*{transform:scale(1.045)}.project-preview:after{content:"";position:absolute;inset:auto 0 0;height:44%;background:linear-gradient(180deg,rgba(9,6,16,0),rgba(9,6,16,.88))}.preview-docs{background:linear-gradient(180deg,rgba(247,247,249,.98),rgba(218,218,225,.88)),linear-gradient(135deg,rgba(168,85,247,.2),transparent)}.preview-topbar{height:34px;display:flex;align-items:center;gap:.38rem;padding:0 .9rem}.preview-topbar span{width:8px;height:8px;border-radius:999px;background:rgba(120,120,140,.42)}.preview-docs-body{padding:1rem 1.2rem 0;display:grid;grid-gap:.8rem;gap:.8rem;color:#0c0c12}.preview-pill{width:-moz-fit-content;width:fit-content;padding:.28rem .5rem;border-radius:999px;background:rgba(255,255,255,.84);border:1px solid rgba(12,12,18,.08);font-size:.56rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.preview-docs-body strong{display:grid;grid-gap:.1rem;gap:.1rem;font-size:2rem;line-height:1;letter-spacing:-.04em}.preview-docs-body strong span:last-child{color:#8d34eb}.preview-docs-body p{margin:0;max-width:270px;color:rgba(12,12,18,.66);font-size:.76rem;line-height:1.45}.preview-docs-panel{margin-top:.4rem;height:82px;border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.62),rgba(235,235,242,.8));border:1px solid rgba(12,12,18,.06);box-shadow:0 16px 24px rgba(22,18,40,.08)}.preview-tracker{display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,rgba(216,180,254,.12),transparent 26%),linear-gradient(140deg,rgba(120,18,214,.9),rgba(24,8,44,1))}.preview-tracker-board{width:86%;height:76%;display:grid;grid-template-columns:.32fr 1fr;transform:rotate(-10deg) translateY(-4px);border-radius:18px;overflow:hidden;background:rgba(255,250,252,.96);box-shadow:0 18px 36px rgba(0,0,0,.3)}.tracker-sidebar{display:grid;grid-gap:.48rem;gap:.48rem;align-content:start;padding:1rem .8rem;background:rgba(250,226,240,.74)}.tracker-heading,.tracker-lines span,.tracker-sidebar span{border-radius:999px;background:rgba(88,18,140,.18)}.tracker-sidebar span{height:8px}.tracker-main{display:grid;align-content:start;grid-gap:.75rem;gap:.75rem;padding:.95rem}.tracker-heading{height:12px;width:54%}.tracker-chart{height:86px;display:flex;align-items:flex-end;gap:.7rem}.tracker-chart span{width:24px;border-radius:10px 10px 0 0;background:linear-gradient(180deg,rgba(236,72,153,.95),rgba(168,85,247,.7))}.tracker-chart span:first-child{height:54px}.tracker-chart span:nth-child(2){height:74px}.tracker-chart span:nth-child(3){height:44px}.tracker-lines{display:grid;grid-gap:.5rem;gap:.5rem}.tracker-lines span:first-child{width:82%;height:10px}.tracker-lines span:nth-child(2){width:64%;height:10px}.tracker-lines span:nth-child(3){width:72%;height:10px}.preview-video{background:radial-gradient(circle at 78% 18%,rgba(96,165,250,.18),transparent 34%),linear-gradient(140deg,rgba(6,10,20,1),rgba(16,23,38,1))}.preview-video video{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.02) brightness(.92)}.project-card-body{padding:1.35rem 1.35rem 1.4rem;display:grid;grid-gap:1.2rem;gap:1.2rem}.project-copy{display:grid;grid-gap:.72rem;gap:.72rem}.project-copy h3{margin:0;font-size:2rem;line-height:1;letter-spacing:-.04em}.project-copy p{margin:0;color:rgba(198,200,226,.86);font-size:1rem;line-height:1.7}.project-tags{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center}.project-tags span{padding:.48rem .78rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:rgba(206,210,236,.84);font-size:.8rem;font-weight:600}.project-tags-toggle{padding:.48rem .78rem;display:inline-flex;align-items:center;gap:.36rem;border-radius:999px;border:1px solid rgba(244,114,182,.22);background:rgba(244,114,182,.08);color:#f472b6;font-size:.8rem;font-weight:700;letter-spacing:.03em;cursor:pointer;transition:transform .22s ease,border-color .22s ease,background .22s ease,color .22s ease,box-shadow .22s ease}.project-tags-toggle:hover{transform:translateY(-1px);border-color:rgba(244,114,182,.34);background:rgba(244,114,182,.14);box-shadow:0 8px 16px rgba(50,10,34,.2)}.project-tags-toggle.is-open{border-color:rgba(216,180,254,.28);background:rgba(168,85,247,.12);color:#d8b4fe}.project-tags-toggle svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.project-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.9rem;gap:.9rem}.project-btn{min-height:52px;display:inline-flex;align-items:center;justify-content:center;gap:.58rem;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:#f8f8ff;font-size:.88rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:transform .24s ease,border-color .24s ease,background .24s ease,box-shadow .24s ease}.project-btn:hover{transform:translateY(-2px);border-color:rgba(216,180,254,.28);background:rgba(168,85,247,.12);box-shadow:0 10px 18px rgba(18,8,34,.26)}.project-btn-secondary{background:rgba(255,255,255,.015)}.project-btn-disabled{opacity:.42;cursor:not-allowed;pointer-events:none;border-color:rgba(255,255,255,.06);background:rgba(255,255,255,.02);box-shadow:none}.project-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.projects-footer{margin-top:2.5rem;display:flex;justify-content:center}.projects-more-btn{min-width:240px;padding:1rem 1.3rem;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(216,180,254,.18);background:rgba(255,255,255,.03);color:#f8f8ff;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:transform .24s ease,background .24s ease,border-color .24s ease,box-shadow .24s ease}.projects-more-btn:hover{transform:translateY(-2px);background:rgba(168,85,247,.12);border-color:rgba(216,180,254,.3);box-shadow:0 14px 26px rgba(18,8,34,.26)}.projects-vault-page{padding-bottom:6.5rem}.vault-topbar{width:min(1320px,calc(100vw - 72px));margin:0 auto;display:flex;justify-content:flex-start}.vault-back{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1rem;border-radius:999px;border:1px solid rgba(216,180,254,.16);background:rgba(255,255,255,.03);color:rgba(248,248,255,.92);font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:transform .22s ease,border-color .22s ease,background .22s ease,box-shadow .22s ease}.vault-back:hover{transform:translateY(-2px);border-color:rgba(216,180,254,.28);background:rgba(168,85,247,.12);box-shadow:0 12px 20px rgba(18,8,34,.22)}.vault-back svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.projects-vault-hero{width:min(1100px,calc(100vw - 72px));margin:4.8rem auto 4rem;display:grid;grid-gap:1.1rem;gap:1.1rem;justify-items:center;text-align:center}.projects-vault-hero h1{margin:0;font-size:clamp(2.9rem,6vw,5.6rem);line-height:.95;letter-spacing:-.05em}.projects-vault-hero h1 span{color:var(--violet-main)}.projects-vault-hero p:last-child{margin:0;max-width:860px;color:rgba(188,191,219,.92);font-size:clamp(1.05rem,1.55vw,1.5rem);line-height:1.6}.contact-section,.projects-vault-grid{width:min(1320px,calc(100vw - 72px));margin:0 auto}.contact-section{padding:8.8rem 0 3.5rem;scroll-margin-top:8.5rem;opacity:0;transform:translateY(92px);filter:blur(8px);transition:opacity .76s cubic-bezier(.22,1,.36,1),transform .86s cubic-bezier(.22,1,.36,1),filter .76s ease}.contact-section.is-visible{opacity:1;transform:translateY(0);filter:blur(0)}.contact-heading{display:grid;grid-gap:.95rem;gap:.95rem;justify-items:center;text-align:center;margin-bottom:3.6rem}.contact-kicker{margin:0;display:inline-flex;align-items:center;gap:.7rem;color:#d8b4fe;font-size:.82rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase}.contact-kicker-icon{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;border:1px solid rgba(216,180,254,.18);background:rgba(168,85,247,.1)}.contact-kicker-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.contact-heading h2{margin:0;font-size:clamp(2.4rem,5vw,4.6rem);line-height:.96;letter-spacing:-.05em}.contact-heading h2 span{color:var(--violet-main)}.contact-heading p{margin:0;max-width:760px;color:rgba(186,188,216,.9);font-size:clamp(1rem,1.35vw,1.28rem);line-height:1.65}.contact-layout{display:grid;grid-template-columns:1.25fr .78fr;grid-gap:1.4rem;gap:1.4rem;align-items:start}.contact-direct,.contact-form-card,.contact-social{border-radius:28px;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at 14% 0,rgba(168,85,247,.1),transparent 34%),rgba(10,6,18,.58);box-shadow:0 18px 34px rgba(4,2,12,.32),inset 0 0 0 1px rgba(168,85,247,.04)}.contact-form-card{padding:1.7rem;display:grid;grid-gap:1.2rem;gap:1.2rem}.contact-form-head{display:grid;grid-gap:.45rem;gap:.45rem;padding-bottom:.25rem}.contact-direct h3,.contact-form-head h3,.contact-social h3{margin:0;font-size:1.85rem;letter-spacing:-.03em}.contact-form-head p{margin:0;color:rgba(186,188,216,.78);line-height:1.55}.contact-field{display:grid;grid-gap:.6rem;gap:.6rem}.contact-field span{color:rgba(216,180,254,.82);font-size:.8rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.contact-field input,.contact-field textarea{width:100%;border:1px solid rgba(255,255,255,.08);outline:none;border-radius:18px;background:rgba(255,255,255,.03);color:#f8f8ff;font:inherit;padding:1rem 1rem 1rem 1.05rem;transition:border-color .22s ease,background .22s ease,box-shadow .22s ease,transform .22s ease}.contact-field textarea{min-height:170px;resize:vertical}.contact-field input::placeholder,.contact-field textarea::placeholder{color:rgba(164,168,198,.48)}.contact-field input:focus,.contact-field textarea:focus{border-color:rgba(216,180,254,.3);background:rgba(168,85,247,.08);box-shadow:0 0 0 4px rgba(168,85,247,.08)}.contact-submit-btn{min-height:58px;margin-top:.25rem;display:inline-flex;align-items:center;justify-content:center;gap:.65rem;border:1px solid rgba(216,180,254,.2);border-radius:18px;background:rgba(255,255,255,.02);color:#ffffff;font-size:.9rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:transform .24s ease,border-color .24s ease,background .24s ease,box-shadow .24s ease}.contact-submit-btn:hover{transform:translateY(-2px);border-color:rgba(216,180,254,.32);background:rgba(168,85,247,.12);box-shadow:0 14px 24px rgba(18,8,34,.24)}.contact-submit-btn svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.contact-side{display:grid;grid-gap:1.2rem;gap:1.2rem}.contact-direct,.contact-social{padding:1.45rem}.contact-direct{display:grid;grid-gap:.9rem;gap:.9rem}.contact-info-card{display:grid;grid-template-columns:54px 1fr;grid-gap:1rem;gap:1rem;align-items:center;padding:.95rem;border-radius:22px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);transition:transform .24s ease,border-color .24s ease,background .24s ease,box-shadow .24s ease}.contact-info-card:hover{transform:translateY(-3px);border-color:rgba(216,180,254,.26);background:rgba(168,85,247,.1);box-shadow:0 14px 24px rgba(18,8,34,.2)}.contact-info-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;color:#d8b4fe;border:1px solid rgba(216,180,254,.14);background:rgba(168,85,247,.1)}.contact-info-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.contact-info-card strong{display:block;margin-bottom:.2rem;color:rgba(216,180,254,.84);font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.contact-info-card span{color:rgba(244,242,242,.92);font-size:1rem;line-height:1.45;word-break:break-word}.contact-social{display:grid;grid-gap:1rem;gap:1rem}.contact-social-links{display:flex;gap:.8rem;flex-wrap:wrap}.contact-social-links a{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);color:rgba(216,180,254,.84);transition:transform .22s ease,border-color .22s ease,background .22s ease,box-shadow .22s ease,color .22s ease}.contact-social-links a:hover{transform:translateY(-3px);border-color:rgba(216,180,254,.28);background:rgba(168,85,247,.12);color:#ffffff;box-shadow:0 12px 22px rgba(18,8,34,.22)}.contact-social-links svg{width:24px;height:24px;fill:currentColor;stroke:none}.card-head{height:50px;background:rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.08);padding:0 1rem;display:flex;align-items:center;justify-content:space-between;transform:translateZ(28px);position:relative;z-index:2}.dots{display:flex;gap:.45rem}.dots span{width:12px;height:12px;border-radius:999px;background:rgba(216,180,254,.24)}.dots span:first-child{background:#c084fc}.file{font-size:.82rem;color:#7f90a8}.file,pre{font-family:JetBrains Mono,monospace}pre{margin:0;padding:1.35rem 1.15rem 1.45rem;font-size:1rem;line-height:1.55;color:#e3e6eb;transform:translateZ(42px);position:relative;z-index:1}.line{display:block;white-space:pre-wrap}.line.blank{height:1rem}.n{color:#60718b;margin-right:.55rem}.k{color:#a855f7}.s{color:#d8b4fe}.fn{color:#a855f7}@keyframes drift{0%,to{transform:translate(0)}50%{transform:translate(22px,16px)}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes marquee-left{0%{transform:translateX(0)}to{transform:translateX(calc(-50% - (var(--marquee-gap) / 2)))}}@keyframes marquee-right{0%{transform:translateX(calc(-50% - (var(--marquee-gap) / 2)))}to{transform:translateX(0)}}@media (max-width:1024px){.hero{grid-template-columns:1fr;gap:2.3rem;padding:2.6rem 0 3.3rem;min-height:auto}.hero-left{padding-right:0}.code-card{transform:perspective(1300px) translateX(0) translateY(0) rotateX(0deg) rotateY(0deg)!important}.topbar nav{gap:1.2rem}.about-section{grid-template-columns:1fr;min-height:auto;gap:1.5rem;margin-top:clamp(5rem,11vh,7.5rem);margin-bottom:clamp(3.5rem,9vh,5rem);padding-top:1.4rem;padding-bottom:2.2rem;transform:none;filter:none}.about-left{padding:1.6rem 1.2rem}.about-photo{width:100%;height:100%}.about-photo-shell{min-height:380px;width:100%;justify-self:stretch;transform:none;opacity:1}.about-photo{transform:perspective(1300px) translateX(0) translateY(0) rotateX(0deg) rotateY(0deg)!important}.experience-section{width:min(760px,calc(100vw - 60px));padding-top:5rem;padding-bottom:4rem}.stack-section{width:min(920px,calc(100vw - 40px));padding-top:6rem;padding-bottom:4rem}.projects-section{padding-top:6.2rem;padding-bottom:4.8rem}.contact-section,.projects-section{width:min(980px,calc(100vw - 40px))}.contact-section{padding-top:6rem}.projects-vault-grid,.vault-topbar{width:min(980px,calc(100vw - 40px))}.projects-vault-hero{width:min(900px,calc(100vw - 40px));margin-top:4rem}.contact-layout,.projects-grid{grid-template-columns:1fr}.project-preview{height:260px}.stack-card{min-width:230px}.experience-timeline{gap:1rem}.timeline-line{display:none}.timeline-item{grid-template-columns:1fr;gap:.8rem}.experience-date,.timeline-item.is-left .experience-date{grid-column:1;justify-self:start;align-self:start;margin-top:0}.experience-card,.timeline-item.is-left .experience-card{grid-column:1;justify-self:stretch;width:100%;padding:1.3rem 1.2rem}}@media (max-width:720px){.experience-section{width:calc(100vw - 32px)}.stack-section{width:calc(100vw - 20px);padding-top:4.8rem}.projects-section{width:calc(100vw - 20px);padding-top:5rem}.contact-section{padding-top:4.8rem}.contact-section,.projects-vault-grid,.projects-vault-hero,.vault-topbar{width:calc(100vw - 20px)}.projects-vault-hero{margin-top:3rem;margin-bottom:2.8rem}.projects-vault-hero p:last-child{font-size:1rem}.topbar nav{display:none}.topbar{top:.7rem;padding:.72rem .8rem}.actions .btn{min-width:100%}.socials a{width:46px;height:46px}pre{font-size:.88rem}.about-metrics{grid-template-columns:1fr;gap:.8rem}.about-metrics div+div{border-left:none;padding-left:0}.experience-title-pill{padding:.66rem 1.2rem;font-size:.86rem}.experience-title-wrap:after,.experience-title-wrap:before{opacity:.4}.experience-card h3{font-size:1.18rem}.experience-card li{font-size:.82rem}.stack-heading{margin-bottom:2.6rem}.stack-heading h2{font-size:2.35rem}.marquee-row{--marquee-gap:0.75rem}.marquee-track{animation-duration:24s}.marquee-row-bottom .marquee-track{animation-duration:26s}.stack-card{min-width:206px;padding:1rem 1.05rem;gap:.9rem;border-radius:20px}.stack-icon{width:50px;height:50px;border-radius:14px}.stack-icon svg{width:26px;height:26px}.stack-copy strong{font-size:.95rem}.stack-copy span{font-size:.68rem}.projects-title-wrap{margin-bottom:3.6rem}.projects-title-pill{padding:.66rem 1.2rem;font-size:.86rem}.projects-heading{margin-bottom:2.6rem}.projects-heading p{font-size:1rem}.project-preview{height:210px}.preview-docs-body strong{font-size:1.55rem}.project-card-body{padding:1.1rem 1rem 1.15rem}.project-copy h3{font-size:1.6rem}.project-copy p{font-size:.95rem}.project-actions{grid-template-columns:1fr}.project-btn{min-height:50px;font-size:.82rem}.projects-more-btn{min-width:100%}.contact-heading{margin-bottom:2.6rem}.contact-heading p{font-size:1rem}.contact-direct,.contact-form-card,.contact-social{padding:1.1rem;border-radius:24px}.contact-direct h3,.contact-form-head h3,.contact-social h3{font-size:1.45rem}.contact-info-card{grid-template-columns:48px 1fr;gap:.8rem;padding:.85rem}.contact-info-icon{width:48px;height:48px;border-radius:16px}.contact-info-card span{font-size:.92rem}.contact-social-links a{width:54px;height:54px}.contact-submit-btn{min-height:54px;font-size:.82rem;letter-spacing:.14em}}