@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Syne:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400&display=swap";:root{--bg:#0a0a0c;--bg-2:#0e0e12;--bg-3:#14141a;--surface:#ffffff04;--surface-2:#ffffff09;--surface-3:#ffffff0f;--border:#ffffff0d;--border-2:#ffffff1a;--border-glow:#ffffff26;--accent:#8b5cf6;--accent-2:#a78bfa;--accent-dim:#8b5cf61f;--accent-glow:#8b5cf640;--teal:#2dd4bf;--violet:#8b5cf6;--sapphire:#1e3a8a;--rose:#9f1239;--sage:#4ade80;--fg:#f9f8f6;--fg-2:#a1a1aa;--fg-3:#52525b;--fg-inv:#0a0a0c;--font-display:"Syne", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--text-2xs:clamp(.6rem, .8vw, .66rem);--text-xs:clamp(.68rem, .9vw, .74rem);--text-sm:clamp(.82rem, 1vw, .9rem);--text-base:clamp(.96rem, 1.1vw, 1.06rem);--text-lg:clamp(1.12rem, 1.5vw, 1.28rem);--text-xl:clamp(1.42rem, 2.5vw, 1.96rem);--text-2xl:clamp(2.1rem, 4vw, 3.1rem);--text-3xl:clamp(2.7rem, 5.5vw, 4.4rem);--text-hero:clamp(4.2rem, 10vw, 8.4rem);--s-1:8px;--s-2:16px;--s-3:24px;--s-4:32px;--s-5:40px;--s-6:48px;--s-8:64px;--s-10:80px;--s-12:96px;--s-16:128px;--s-section:clamp(80px, 12vw, 152px);--r-sm:6px;--r-md:12px;--r-lg:20px;--r-xl:32px;--r-full:9999px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-inout:cubic-bezier(.76, 0, .24, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 8px 32px #00000073;--shadow-lg:0 24px 64px #0000008c;--shadow-accent:0 16px 40px var(--accent-glow);--shadow-inset:inset 0 1px 0 #ffffff0e;--nav-h:76px}[data-theme=light]{--bg:#fafafa;--bg-2:#f4f4f5;--bg-3:#edede8;--surface:#ffffffa6;--surface-2:#fffc;--surface-3:#fff;--border:#0000000f;--border-2:#0000001f;--border-glow:#0000002e;--accent:#7c3aed;--accent-2:#6d28d9;--accent-dim:#7c3aed14;--accent-glow:#7c3aed26;--fg:#0a0a0c;--fg-2:#52525b;--fg-3:#71717a;--fg-inv:#fafafa;--shadow-inset:inset 0 1px 0 #fff}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;tab-size:2}body{background:var(--bg);color:var(--fg-2);font-family:var(--font-body);font-size:var(--text-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.75;overflow-x:hidden}body:after{content:"";pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' 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)'/%3E%3C/svg%3E");background-size:180px;position:fixed;inset:0}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}svg{display:block}ul,ol{list-style:none}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:var(--r-full)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--r-sm)}.section{width:100%;padding-block:var(--s-section);padding-inline:clamp(var(--s-4), 5vw, var(--s-10));isolation:isolate;position:relative}.container{max-width:1280px;margin-inline:auto;position:relative}.section-label{align-items:center;gap:var(--s-2);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--s-3);display:inline-flex}.section-label:before{content:"";background:var(--accent);flex-shrink:0;width:28px;height:1px}.section-title{font-family:var(--font-display);font-size:var(--text-3xl);letter-spacing:-.028em;color:var(--fg);font-weight:700;line-height:1.04}.section-title em{color:var(--accent);font-style:normal}.btn{justify-content:center;align-items:center;gap:var(--s-2);font-family:var(--font-body);font-size:var(--text-sm);letter-spacing:.02em;border-radius:var(--r-sm);transition:all .38s var(--ease-out);white-space:nowrap;isolation:isolate;padding:13px 28px;font-weight:500;display:inline-flex;position:relative;overflow:hidden}.btn svg{transition:transform .38s var(--ease-out);flex-shrink:0}.btn:hover svg{transform:translate(2px,-2px)}.btn-primary{background:var(--fg);color:var(--fg-inv);border:1px solid #0000}.btn-primary:after{content:"";background:var(--accent);z-index:-1;transition:transform .38s var(--ease-inout);position:absolute;inset:0;transform:translateY(105%)}.btn-primary:hover{color:#fff;box-shadow:var(--shadow-accent);transform:translateY(-3px)}.btn-primary:hover:after{transform:translateY(0)}.btn-ghost{color:var(--fg);border:1px solid var(--border-2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:0 0}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-2px)}.glow-orb{pointer-events:none;mix-blend-mode:screen;border-radius:50%;position:absolute}@keyframes mesh-float{0%,to{transform:translateY(0)scale(1)rotate(0)}50%{transform:translateY(-40px)scale(1.05)rotate(5deg)}}.tag{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.04em;color:var(--fg-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);align-items:center;padding:5px 11px;transition:border-color .2s,color .2s;display:inline-flex}[data-reveal]{opacity:0;transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);transform:translateY(28px)}[data-reveal].visible{opacity:1;transform:none}.nav{z-index:1000;height:var(--nav-h);padding-inline:clamp(var(--s-4), 5vw, var(--s-10));transition:height .38s var(--ease-out), background .38s, border-color .38s;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.nav.scrolled{-webkit-backdrop-filter:blur(24px)saturate(180%);border-bottom-color:var(--border);background:#060608c7;height:60px}[data-theme=light] .nav.scrolled{background:#f4f3f0d1}.nav-logo{font-family:var(--font-display);color:var(--fg);letter-spacing:-.035em;z-index:1;font-size:1.18rem;font-weight:800;transition:opacity .2s}.nav-logo:hover{opacity:.6}.nav-logo em{color:var(--accent);font-style:normal}.nav-links{align-items:center;gap:var(--s-8);display:flex}.nav-link{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.15em;text-transform:uppercase;color:var(--fg-2);padding-block:4px;transition:color .2s;position:relative}.nav-link:after{content:"";background:var(--accent);transform-origin:100%;height:1px;transition:transform .36s var(--ease-inout);position:absolute;bottom:-2px;left:0;right:0;transform:scaleX(0)}.nav-link:hover,.nav-link.active{color:var(--fg)}.nav-link:hover:after,.nav-link.active:after{transform-origin:0;transform:scaleX(1)}.nav-actions{align-items:center;gap:var(--s-2);z-index:1;display:flex}.nav-theme-btn{border-radius:var(--r-sm);width:36px;height:36px;color:var(--fg-2);border:1px solid var(--border);transition:all .2s var(--ease-out);justify-content:center;align-items:center;display:flex}.nav-theme-btn:hover{color:var(--fg);border-color:var(--border-2);background:var(--surface-2)}.nav-cta{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--fg);border:1px solid var(--border-2);border-radius:var(--r-sm);transition:all .22s var(--ease-out);padding:9px 18px}.nav-cta:hover{background:var(--fg);color:var(--fg-inv);border-color:var(--fg)}.nav-hamburger{border-radius:var(--r-sm);border:1px solid var(--border);z-index:1002;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;transition:all .2s;display:none;position:relative}.nav-hamburger:hover{border-color:var(--border-2);background:var(--surface)}.nav-hamburger span{background:var(--fg);width:18px;height:1.5px;transition:transform .3s var(--ease-out), opacity .2s;transform-origin:50%;border-radius:2px;display:block}.nav-hamburger.open span:first-child{transform:translateY(6.5px)rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-hamburger.open span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.nav-drawer{z-index:999;background:var(--bg);justify-content:center;align-items:center;gap:var(--s-3);transition:transform .42s var(--ease-inout);pointer-events:none;flex-direction:column;display:flex;position:fixed;inset:0;transform:translate(100%)}.nav-drawer.open{pointer-events:all;transform:translate(0)}.nav-drawer-link{font-family:var(--font-display);color:var(--fg-3);letter-spacing:-.025em;padding-block:var(--s-1);font-size:clamp(2.2rem,6vw,3rem);font-weight:700;transition:color .2s,transform .2s}.nav-drawer-link:hover{color:var(--fg);transform:translate(8px)}.nav-drawer-cta{margin-top:var(--s-4);font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:var(--r-sm);padding:12px 28px;transition:background .2s,color .2s}.nav-drawer-cta:hover{background:var(--accent);color:#fff}#hero{min-height:100svh;padding-top:clamp(130px,18vh,200px);padding-bottom:clamp(80px,14vh,160px);padding-inline:clamp(var(--s-4), 5vw, var(--s-10));isolation:isolate;align-items:center;display:grid;position:relative;overflow:hidden}#hero:before{display:none}.hero-glow-1{filter:blur(120px);background:radial-gradient(circle,#8b5cf659 0%,#0000 60%);width:900px;height:900px;animation:22s ease-in-out infinite mesh-float;top:-15%;right:-5%}.hero-glow-2{filter:blur(130px);background:radial-gradient(circle,#1e3a8a66 0%,#0000 60%);width:1000px;height:1000px;animation:28s ease-in-out infinite reverse mesh-float;bottom:0%;left:-10%}.hero-glow-3{filter:blur(100px);background:radial-gradient(circle,#9f123940 0%,#0000 60%);width:700px;height:700px;animation:35s ease-in-out 5s infinite mesh-float;top:30%;left:20%}.hero-inner{z-index:1;width:100%;max-width:1280px;margin-inline:auto;position:relative}.hero-badge{align-items:center;gap:var(--s-2);background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-full);margin-bottom:var(--s-5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 18px;display:inline-flex}.hero-badge-dot{background:var(--sage);border-radius:50%;flex-shrink:0;width:7px;height:7px;position:relative}.hero-badge-dot:after{content:"";background:var(--sage);opacity:.25;border-radius:50%;animation:2.8s cubic-bezier(.4,0,.6,1) infinite pulse-dot;position:absolute;inset:-4px}@keyframes pulse-dot{0%,to{opacity:.25;transform:scale(1)}50%{opacity:0;transform:scale(2.4)}}.hero-badge-text{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-2)}.hero-h1{font-family:var(--font-display);font-size:var(--text-hero);letter-spacing:-.048em;margin-bottom:var(--s-5);font-weight:800;line-height:.87}.hero-h1-word{color:var(--fg);margin-right:.1em;display:inline-block}.hero-h1-word--accent{color:var(--accent)}.hero-h1-word--outline{color:#0000;-webkit-text-stroke:1.5px var(--border-glow);font-weight:700}.hero-h1-word--small{color:var(--fg-2);letter-spacing:0;vertical-align:middle;margin-left:.05em;font-size:.4em;font-weight:400;transform:translateY(-.35em)}.hero-sub{max-width:520px;font-size:var(--text-lg);color:var(--fg-2);margin-bottom:var(--s-5);padding-left:var(--s-3);border-left:2px solid var(--border-glow);font-weight:300;line-height:1.72}.hero-sub strong{color:var(--fg);font-weight:500}.hero-actions{gap:var(--s-2);margin-bottom:var(--s-10);flex-wrap:wrap;display:flex}.hero-stats{gap:clamp(var(--s-6), 8vw, var(--s-16));padding-top:var(--s-6);border-top:1px solid var(--border-2);flex-wrap:wrap;display:flex}.hero-stat-num{font-family:var(--font-display);color:var(--fg);letter-spacing:-.035em;font-size:clamp(2.4rem,4.5vw,3.2rem);font-weight:700;line-height:1}.hero-stat-num em{color:var(--accent);vertical-align:super;font-size:.6em;font-style:normal}.hero-stat-label{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin-top:7px}.hero-marquee-wrap{border-top:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:absolute;bottom:0;left:0;right:0;overflow:hidden}.hero-marquee-track{width:max-content;padding-block:14px;animation:38s linear infinite marquee-run;display:flex}.hero-marquee-track:hover{animation-play-state:paused}@keyframes marquee-run{0%{transform:translate(0)}to{transform:translate(-50%)}}.hero-marquee-item{align-items:center;gap:var(--s-2);padding-inline:var(--s-4);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3);white-space:nowrap;transition:color .2s;display:inline-flex}.hero-marquee-item:hover{color:var(--fg-2)}.marquee-sep{background:var(--accent);opacity:.5;border-radius:50%;width:3px;height:3px}#about{background:var(--bg);border-block:1px solid var(--border)}.about-grid{gap:clamp(var(--s-8), 8vw, var(--s-16));grid-template-columns:1fr 340px;align-items:start;display:grid}.about-lead{font-size:var(--text-xl);color:var(--fg);margin-bottom:var(--s-4);font-weight:400;line-height:1.52}.about-lead em{color:var(--accent);font-style:normal;font-weight:600}.about-body{font-size:var(--text-base);color:var(--fg-2);margin-bottom:var(--s-4);font-weight:300;line-height:1.88}.about-cards{gap:var(--s-2);margin-top:var(--s-5);grid-template-columns:1fr 1fr;display:grid}.about-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-3) var(--s-2);transition:border-color .36s var(--ease-out), background .36s, transform .36s var(--ease-out);box-shadow:var(--shadow-inset)}.about-card:hover{border-color:var(--border-glow);background:var(--surface-2);transform:translateY(-3px)}.about-card-icon{margin-bottom:var(--s-1);font-size:1.25rem;line-height:1}.about-card-label{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3);margin-bottom:4px}.about-card-value{font-size:var(--text-sm);color:var(--fg);font-weight:500}.about-photo-col{position:sticky;top:100px}.about-photo-wrap{border-radius:var(--r-lg);aspect-ratio:3/4;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.about-photo-wrap:after{content:"";border-radius:var(--r-lg);border:1px solid var(--border-glow);pointer-events:none;position:absolute;inset:0}.about-photo-wrap img{object-fit:cover;filter:grayscale(70%)contrast(1.06);width:100%;height:100%;transition:filter 1.1s var(--ease-inout), transform 1.1s var(--ease-inout);transform:scale(1.04)}.about-photo-wrap:hover img{filter:grayscale(0%)contrast(1.02);transform:scale(1)}#projects{background:var(--bg-2)}.project-grid{gap:var(--s-5);grid-template-columns:repeat(auto-fit,minmax(min(100%,360px),1fr));padding:0;list-style:none;display:grid}.project-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-xl);padding:var(--s-5);-webkit-backdrop-filter:blur(40px)saturate(150%);will-change:transform, border-color;color:inherit;height:100%;transition:border-color .4s;display:block;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff26,0 12px 40px #00000080}.project-card:hover{border-color:#ffffff40}[data-theme=light] .project-card:hover{border-color:#00000040}.project-card-glow{border-radius:inherit;opacity:0;pointer-events:none;z-index:0;transition:opacity .5s;position:absolute;inset:0}.project-card:hover .project-card-glow{opacity:1}.project-card-content{z-index:1;flex-direction:column;height:100%;display:flex;position:relative}.project-card-header{margin-bottom:var(--s-4)}.project-media{aspect-ratio:16/9;border-radius:var(--r-lg);width:100%;margin-bottom:var(--s-4);background:var(--surface-2);border:1px solid var(--border);isolation:isolate;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.project-media video,.project-media img{object-fit:cover;width:100%;height:100%;transition:transform .7s var(--ease-out), filter .7s;filter:grayscale(60%)sepia(20%)hue-rotate(220deg)brightness(.65)}.project-card:hover .project-media video,.project-card:hover .project-media img{filter:grayscale(0%)sepia(0%)brightness();transform:scale(1.05)}.project-meta{align-items:center;gap:var(--s-3);margin-bottom:var(--s-3);display:flex}.project-num{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--fg-3);letter-spacing:.12em}.project-badge{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:var(--r-full);background:var(--accent-dim);padding:4px 12px;font-size:.65rem}.project-title{font-family:var(--font-display);font-size:var(--text-2xl);letter-spacing:-.025em;color:var(--fg);font-weight:700;line-height:1.1}.project-metrics{row-gap:var(--s-2);column-gap:var(--s-3);margin-bottom:var(--s-6);flex-grow:1;grid-template-columns:auto 1fr;align-items:baseline;display:grid}.project-metrics dt{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);font-size:.72rem}.project-metrics dd{font-size:var(--text-sm);color:var(--fg-2);margin:0;font-weight:300;line-height:1.6}.highlight-result{color:var(--accent)!important;font-weight:500!important}.project-card-footer{gap:var(--s-4);padding-top:var(--s-4);border-top:1px solid var(--border);flex-direction:column;margin-top:auto;display:flex}.project-tags{flex-wrap:wrap;gap:8px;display:flex}.project-tag{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--fg-3);background:var(--surface-2);border-radius:var(--r-sm);border:1px solid #0000;padding:4px 10px;transition:border-color .2s,color .2s}.project-link{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--fg);padding:var(--s-2) 0;justify-content:space-between;align-items:center;transition:color .2s;display:inline-flex}.project-link-icon{transition:transform .38s var(--ease-out);margin-right:5px}.project-card:hover .project-link{color:var(--accent)}.project-card:hover .project-link-icon{transform:translate(4px,-4px)}.projects-cta{text-align:center;margin-top:var(--s-16)}#skills{background:var(--bg)}.skills-grid{gap:var(--s-4);grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));display:grid}.skill-card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-xl);padding:var(--s-5);transition:border-color .36s var(--ease-out), box-shadow .36s;-webkit-backdrop-filter:blur(40px)saturate(150%);cursor:default;flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff26,0 12px 40px #00000080}.skill-card:hover{border-color:#ffffff40}[data-theme=light] .skill-card:hover{border-color:#00000040}.skill-card-glow{opacity:0;pointer-events:none;z-index:0;transition:opacity .4s;position:absolute;inset:0}.skill-card:hover .skill-card-glow{opacity:.15}.skill-card-content{z-index:1;flex-direction:column;flex-grow:1;display:flex;position:relative}.skill-card-header{align-items:center;gap:var(--s-3);margin-bottom:var(--s-5);padding-bottom:var(--s-4);border-bottom:1px solid var(--border);display:flex}.skill-card-icon{font-size:1.4rem;line-height:1;display:flex}.skill-card-title{font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:.15em;text-transform:uppercase;color:var(--fg);margin:0;font-weight:500}.skill-pills{flex-wrap:wrap;gap:8px;margin-top:auto;display:flex}.skill-pill{font-family:var(--font-mono);letter-spacing:.05em;color:var(--fg-2);background:var(--surface-2);border-radius:var(--r-full);border:1px solid #0000;align-items:center;gap:8px;padding:8px 14px;font-size:.75rem;transition:border-color .2s,color .2s,background .2s,transform .2s;display:inline-flex}.skill-pill:hover{border-color:var(--card-accent);color:var(--fg);background:var(--surface-3);transform:translateY(-3px)}.skill-bars{gap:var(--s-3);flex-direction:column;margin-top:auto;display:flex}.skill-bar-row{flex-direction:column;gap:8px;display:flex}.skill-bar-label{font-family:var(--font-mono);color:var(--fg);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;align-items:center;font-size:.7rem;display:flex}.skill-bar-pct{color:var(--card-accent);opacity:.9;font-weight:500}.skill-bar-track{border-radius:var(--r-full);background:#ffffff14;width:100%;height:4px;position:relative;overflow:hidden}[data-theme=light] .skill-bar-track{background:#00000014}.skill-bar-fill{border-radius:inherit;height:100%;box-shadow:0 0 10px var(--card-accent)}#contact{background:var(--bg-2)}.contact-grid{gap:clamp(var(--s-8), 8vw, var(--s-16));grid-template-columns:1fr 1fr;align-items:start;display:grid}.contact-headline{font-family:var(--font-display);font-size:var(--text-3xl);letter-spacing:-.028em;color:var(--fg);margin-bottom:var(--s-3);font-weight:700;line-height:1.04}.contact-headline em{color:var(--accent);font-style:normal}.contact-desc{font-size:var(--text-base);color:var(--fg-2);max-width:400px;font-weight:300;line-height:1.82}.contact-socials{margin-top:var(--s-5);border-top:1px solid var(--border)}.contact-social-link{padding:var(--s-3) 0;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-2);transition:color .2s, padding-left .36s var(--ease-out);justify-content:space-between;align-items:center;display:flex}.contact-social-link:hover{color:var(--accent);padding-left:var(--s-2)}.contact-social-link svg{transition:transform .36s var(--ease-out)}.contact-social-link:hover svg{transform:translate(3px,-3px)}.contact-form{gap:var(--s-5);flex-direction:column;display:flex}.form-row{gap:var(--s-4);grid-template-columns:1fr 1fr;display:grid}.form-group{flex-direction:column;gap:9px;display:flex;position:relative}.form-label{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.15em;text-transform:uppercase;color:var(--fg-3);transition:color .2s}.form-group:focus-within .form-label{color:var(--accent)}.form-input,.form-textarea{border:none;border-bottom:1px solid var(--border-2);color:var(--fg);font-family:var(--font-body);font-size:var(--text-base);transition:border-color .36s var(--ease-out);resize:vertical;background:0 0;outline:none;width:100%;padding:13px 0;font-weight:300}.form-input::placeholder,.form-textarea::placeholder{color:var(--fg-3);font-weight:300}.form-input:focus,.form-textarea:focus{border-bottom-color:var(--accent)}.form-textarea{min-height:120px;line-height:1.72}.contact-submit{width:100%;margin-top:var(--s-1);justify-content:center;padding:15px}.footer{background:var(--bg);border-top:1px solid var(--border);padding:var(--s-10) clamp(var(--s-4), 5vw, var(--s-10)) var(--s-6)}.footer-inner{gap:var(--s-8);flex-direction:column;max-width:1280px;margin-inline:auto;display:flex}.footer-main{justify-content:space-between;align-items:flex-start;gap:var(--s-6);display:flex}.footer-logo{font-family:var(--font-display);color:var(--fg);letter-spacing:-.035em;margin-bottom:var(--s-2);font-size:1.18rem;font-weight:800;transition:opacity .2s;display:block}.footer-logo:hover{opacity:.65}.footer-logo em{color:var(--accent);font-style:normal}.footer-tagline{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--fg-3);letter-spacing:.07em;max-width:250px;line-height:1.72}.footer-nav{gap:var(--s-5);flex-wrap:wrap;align-items:center;display:flex}.footer-nav-link{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);transition:color .2s}.footer-nav-link:hover{color:var(--fg)}.footer-divider{background:var(--border);height:1px}.footer-bottom{justify-content:space-between;align-items:center;gap:var(--s-4);flex-wrap:wrap;display:flex}.footer-copy{font-family:var(--font-mono);font-size:var(--text-2xs);color:var(--fg-3);letter-spacing:.02em;text-transform:uppercase}.footer-copy span{color:var(--accent);text-transform:lowercase;letter-spacing:0;font-weight:600}.footer-socials{gap:var(--s-2);display:flex}.footer-social{border-radius:var(--r-sm);border:1px solid var(--border);width:38px;height:38px;color:var(--fg-3);transition:all .2s var(--ease-out);justify-content:center;align-items:center;display:flex}.footer-social:hover{color:var(--fg);border-color:var(--border-2);background:var(--surface-2)}.cursor-dot{background:var(--fg);pointer-events:none;z-index:99999;mix-blend-mode:difference;will-change:left, top;border-radius:50%;width:5px;height:5px;position:fixed;transform:translate(-50%,-50%)}.cursor-ring{pointer-events:none;z-index:99998;width:32px;height:32px;transition:width .28s var(--ease-out), height .28s var(--ease-out), border-color .28s, background .28s;will-change:left, top;border:1px solid #fff3;border-radius:50%;position:fixed;transform:translate(-50%,-50%)}.cursor-ring.hovering{background:#f0510f0d;border-color:#f0510f61;width:50px;height:50px}@media (hover:none),(width<=900px){.cursor-dot,.cursor-ring{display:none!important}.project-card,.skill-card,.about-photo-wrap{transform:none!important}.project-card-glow,.skill-card-glow,.about-photo-glow{display:none!important}}@media (width<=1100px){.skills-grid{grid-template-columns:1fr 1fr}}@media (width<=1024px){.about-grid{grid-template-columns:1fr}.about-photo-col{position:static}.about-photo-wrap{aspect-ratio:4/5;width:100%;max-width:400px;margin-inline:auto}.contact-grid{grid-template-columns:1fr}}@media (width<=860px){.nav-links,.nav-cta{display:none}.nav-hamburger{display:flex}}@media (width<=768px){.nav{height:62px}.hero-h1{word-break:break-word;font-size:clamp(1.8rem,11vw,3.6rem);line-height:1.1}.hero-h1-word{margin-right:.15em;display:inline}.hero-h1-word--small{font-size:.45em;display:inline-block}.project-title,.contact-headline{font-size:clamp(2.1rem,8vw,3rem)}.section-title{font-size:clamp(2.1rem,7vw,3rem)}.hero-marquee-wrap{display:none}.form-row{grid-template-columns:1fr}.footer{padding-top:var(--s-6);padding-bottom:var(--s-4)}.footer-inner{gap:var(--s-4)}.footer-main{text-align:center;align-items:center;gap:var(--s-4);flex-direction:column}.footer-bottom{text-align:center;align-items:center;gap:var(--s-4);margin-top:-var(--s-2);flex-direction:column-reverse}.skills-grid{grid-template-columns:1fr}}@media (width<=480px){.hero-actions{flex-direction:column;width:100%}.magnetic-wrap{width:100%;display:block!important}.btn{justify-content:center;width:100%}.hero-stat-num{font-size:2.2rem}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
