:root{--surface:#090c10;--surface-2:#0d1318;--panel:#111920;--panel-strong:#17232b;--ink:#f3f7f4;--muted:#9aa9a9;--line:#cbf4eb21;--line-strong:#66ffe547;--teal:#58f2d5;--teal-soft:#0e2f31;--coral:#ff8a64;--lime:#c9f46a;--blue:#8ea7ff;--shadow-soft:0 24px 80px #0000006b;--shadow-neon:0 0 0 1px #58f2d533, 0 0 32px #58f2d51f;color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}html{background:var(--surface);scroll-behavior:smooth}body{background:linear-gradient(120deg, #58f2d514, transparent 24%), linear-gradient(280deg, #ff8a6414, transparent 26%), var(--surface);min-width:320px;margin:0}button,input,textarea,select{font:inherit}a{text-underline-offset:4px}img,svg{display:block}::selection{background:var(--lime);color:var(--ink)}#root{min-height:100svh}.portfolio-shell{background:linear-gradient(#ffffff09 1px, transparent 1px), linear-gradient(90deg, #ffffff08 1px, transparent 1px), linear-gradient(135deg, #58f2d514, transparent 28%), linear-gradient(315deg, #8ea7ff14, transparent 32%), var(--surface);background-size:46px 46px,46px 46px,auto,auto,auto;min-height:100svh;position:relative;overflow:hidden}.portfolio-shell:before{content:"";z-index:0;background:linear-gradient(90deg,#0000,#58f2d542,#0000);height:1px;position:absolute;top:64px;left:-20%;right:-20%}.site-header{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:color-mix(in srgb, var(--surface) 72%, transparent);border-bottom:1px solid var(--line);z-index:20;justify-content:space-between;align-items:center;height:64px;padding:0 clamp(18px,4vw,52px);display:flex;position:sticky;top:0;left:0;right:0;box-shadow:0 10px 42px #00000047}.brand,.site-header nav,.button,.text-link,.project-topline,.signal-row,.cred-strip strong{align-items:center;display:flex}.brand{color:var(--ink);gap:10px;font-weight:760;text-decoration:none}.brand-mark{background:linear-gradient(135deg, var(--teal), var(--blue));color:#061012;border-radius:8px;place-items:center;width:34px;height:34px;font-size:.82rem;display:grid;box-shadow:0 0 28px #58f2d547}.site-header nav{gap:clamp(16px,3vw,34px)}.site-header nav a,.text-link{color:var(--muted);font-size:.94rem;font-weight:680;text-decoration:none}.site-header nav a:hover,.text-link:hover{color:var(--teal)}.hero-section{z-index:1;grid-template-columns:minmax(0,1fr) minmax(320px,.88fr);align-items:center;gap:clamp(28px,4vw,56px);min-height:calc(100svh - 64px);padding:clamp(18px,4vw,40px) clamp(18px,4vw,52px);display:grid;position:relative}.hero-copy{align-self:center;max-width:700px}.eyebrow,.section-kicker{color:var(--teal);letter-spacing:0;text-transform:uppercase;align-items:center;gap:8px;margin:0 0 14px;font-size:.75rem;font-weight:800;display:inline-flex}.eyebrow,.section-badge{background:#58f2d514;border:1px solid #58f2d52e;border-radius:999px;padding:8px 11px}h1,h2,h3,p{margin:0}h1{color:var(--ink);letter-spacing:0;text-shadow:0 0 42px #58f2d517;max-width:780px;font-size:clamp(2.25rem,4.7vw,4.15rem);font-weight:850;line-height:1}h2{color:var(--ink);letter-spacing:0;font-size:clamp(1.8rem,3vw,3.2rem);font-weight:820;line-height:1}h3{color:var(--ink);letter-spacing:0;font-size:1.28rem;line-height:1.2}.hero-lede{color:var(--muted);max-width:620px;margin-top:14px;font-size:clamp(.98rem,1.15vw,1.1rem);line-height:1.5}.hero-actions,.contact-actions{flex-wrap:wrap;gap:12px;margin-top:20px;display:flex}.button{border:1px solid #0000;border-radius:8px;justify-content:center;gap:10px;min-height:44px;padding:0 16px;font-weight:760;text-decoration:none;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s}.button:hover{box-shadow:var(--shadow-neon);transform:translateY(-2px)}.button.primary{background:linear-gradient(135deg, var(--teal), var(--lime));color:#071113}.button.ghost{border-color:var(--line);color:var(--ink);background:#ffffff0a}.signal-row{color:var(--muted);flex-wrap:wrap;gap:10px;margin-top:14px}.signal-row span{border:1px solid var(--line);background:#ffffff0b;border-radius:999px;align-items:center;gap:8px;padding:8px 12px;display:inline-flex}.hero-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;max-width:620px;margin-top:12px;display:grid}.hero-metrics div{border:1px solid var(--line);background:linear-gradient(#ffffff13,#ffffff09);border-radius:8px;padding:9px 10px}.hero-metrics strong,.hero-metrics span{display:block}.hero-metrics strong{color:var(--ink);font-size:.9rem}.hero-metrics span{color:var(--muted);margin-top:2px;font-size:.74rem}.hero-visual{background:linear-gradient(135deg, #58f2d51f, transparent 40%), var(--panel);border:1px solid var(--line-strong);box-shadow:var(--shadow-soft), var(--shadow-neon);border-radius:8px;align-self:stretch;min-height:390px;position:relative;overflow:hidden}.hero-visual:before{content:"";pointer-events:none;z-index:1;background:linear-gradient(135deg,#ffffff2e,#0000 34%,#58f2d51f);position:absolute;inset:0}.hero-visual img{object-fit:cover;width:100%;height:100%}.visual-chip-row{z-index:2;flex-wrap:wrap;gap:8px;display:flex;position:absolute;top:16px;left:16px;right:16px}.visual-chip-row span,.visual-console{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);color:#fffc;background:#070e12ad;border:1px solid #ffffff24}.visual-chip-row span{border-radius:999px;padding:7px 10px;font-size:.78rem;font-weight:800}.visual-console{z-index:2;border-radius:8px;align-items:center;gap:9px;padding:10px 12px;display:flex;position:absolute;top:62px;right:16px}.visual-console span{background:var(--lime);border-radius:50%;width:9px;height:9px;box-shadow:0 0 18px #c9f46abd}.visual-console code{color:#ffffffd1;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.78rem}.hero-stats{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:#fff;z-index:2;background:#071014c7;border:1px solid #ffffff29;border-radius:8px;padding:14px 16px;position:absolute;bottom:16px;left:16px;right:16px}.hero-stats span,.cred-strip span{color:var(--muted);text-transform:uppercase;margin-bottom:6px;font-size:.82rem;font-weight:760;display:block}.hero-stats span{color:#ffffffa8}.hero-stats strong{font-size:clamp(1rem,1.4vw,1.3rem);display:block}.cred-strip{border-block:1px solid var(--line);z-index:1;grid-template-columns:repeat(3,1fr);display:grid;position:relative}.cred-strip>div{background:#ffffff09;padding:20px clamp(18px,4vw,52px)}.cred-strip>div+div{border-left:1px solid var(--line)}.cred-strip strong{color:var(--ink);gap:8px}.section{z-index:1;padding:clamp(56px,7vw,92px) clamp(18px,4vw,52px);position:relative}.intro-section,.stack-section{background:linear-gradient(#ffffff09,#ffffff04)}.intro-grid,.process-grid{grid-template-columns:minmax(0,.9fr) minmax(300px,1fr);gap:clamp(24px,5vw,72px);display:grid}.intro-copy,.process-list{color:var(--muted);gap:18px;font-size:1.08rem;line-height:1.72;display:grid}.section-heading{justify-content:space-between;align-items:end;gap:24px;margin-bottom:28px;display:flex}.section-badge{color:var(--teal);white-space:nowrap;align-items:center;gap:8px;font-size:.9rem;font-weight:800;display:flex}.text-link{white-space:nowrap;gap:8px}.projects-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.projects-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr))}.site-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.site-preview-card{border:1px solid var(--line);box-shadow:var(--shadow-soft);background:linear-gradient(#ffffff12,#ffffff09);border-radius:8px;transition:border-color .18s,box-shadow .18s,transform .18s;display:grid;overflow:hidden}.browser-frame{border-bottom:1px solid var(--line);background:linear-gradient(90deg,#58f2d524,#0000 42%,#ff8a641f),#101418;height:420px;position:relative;overflow:hidden}.browser-bar{background:#11191f;align-items:center;gap:7px;height:32px;padding:0 12px;display:flex}.browser-bar span{background:#53616a;border-radius:50%;width:9px;height:9px}.browser-bar span:first-child{background:var(--coral)}.browser-bar span:nth-child(2){background:var(--lime)}.browser-bar span:nth-child(3){background:var(--teal)}.browser-frame iframe{transform-origin:0 0;background:#fff;border:0;width:138.888%;height:539px;position:absolute;top:32px;left:0;transform:scale(.72)}.gesture-guide{opacity:0;pointer-events:none;z-index:3;background:#070e12ad;border:1px solid #58f2d547;border-radius:999px;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:absolute;bottom:18px;right:18px;box-shadow:0 0 24px #58f2d533}.gesture-guide:before{background:linear-gradient(180deg, var(--teal), var(--lime));content:"";border-radius:999px;width:12px;height:22px;position:absolute}.gesture-guide:after{content:"";opacity:0;border:1px solid #58f2d573;border-radius:999px;width:2px;height:80px;position:absolute;transform:translateY(-16px)}.gesture-guide span{background:#c9f46ab8;border-radius:50%;width:5px;height:5px;position:absolute;top:12px;box-shadow:0 0 18px #c9f46ad1}.site-preview-card.preview-animate .browser-frame iframe{animation:5.2s cubic-bezier(.76,0,.24,1) .45s both preview-scroll-demo}.site-preview-card.preview-animate .gesture-guide{animation:5.2s cubic-bezier(.76,0,.24,1) .45s both gesture-swipe-demo}.site-preview-card.preview-animate .gesture-guide:after{animation:5.2s .45s both gesture-trail-demo}.site-preview-copy{gap:16px;padding:22px;display:grid}.site-preview-copy p{color:var(--muted);line-height:1.62}.fallback-link{justify-self:start;margin-top:2px}.project-card,.skill-card{border:1px solid var(--line);background:linear-gradient(#fff1,#ffffff07);border-radius:8px;transition:border-color .18s,box-shadow .18s,transform .18s;box-shadow:0 18px 46px #00000038}.project-card:hover,.skill-card:hover,.site-preview-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-soft), var(--shadow-neon);transform:translateY(-3px)}.project-card{flex-direction:column;gap:18px;min-height:360px;padding:22px;display:flex;position:relative}.project-card:before{content:"";height:4px;display:block;position:absolute;inset:0 0 auto}.project-card.teal:before{background:var(--teal)}.project-card.coral:before{background:var(--coral)}.project-card.lime:before{background:var(--lime)}.project-card.blue:before{background:var(--blue)}.project-topline{justify-content:space-between}.project-topline span{color:var(--muted);text-transform:uppercase;font-size:.82rem;font-weight:800}.project-topline a{color:var(--ink)}.project-card p{color:var(--muted);line-height:1.62}.project-card strong{color:var(--ink);line-height:1.45;display:block}.tag-row{flex-wrap:wrap;gap:8px;margin-top:auto;display:flex}.tag-row span{border:1px solid var(--line);color:var(--muted);background:#ffffff0b;border-radius:999px;padding:7px 10px;font-size:.84rem;font-weight:700}.skills-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.skill-card{padding:24px}.skill-card svg{color:var(--coral);margin-bottom:22px}.skill-card ul{color:var(--muted);gap:10px;margin:18px 0 0;padding:0;list-style:none;display:grid}.skill-card li{border-top:1px solid var(--line);padding-top:10px}.process-section{color:var(--ink);background:linear-gradient(110deg,#58f2d529,#0000 36%),linear-gradient(260deg,#ff8a6421,#0000 34%),#071014}.process-section h2,.process-section .section-kicker{color:var(--ink)}.process-grid svg{color:var(--lime);margin-bottom:20px}.process-list{color:#f3f7f4c7}.process-list p{border-bottom:1px solid #ffffff29;padding-bottom:18px}@keyframes preview-scroll-demo{0%,18%,to{transform:scale(.72)translateY(0)}46%,68%{transform:scale(.72)translateY(-120px)}}@keyframes gesture-swipe-demo{0%,14%,78%,to{opacity:0;transform:translateY(0)}20%,70%{opacity:1}44%,62%{opacity:1;transform:translateY(-74px)}}@keyframes gesture-trail-demo{0%,18%,76%,to{opacity:0;transform:translateY(-16px)scaleY(.35)}32%,64%{opacity:1;transform:translateY(-38px)scaleY(1)}}@media (prefers-reduced-motion:reduce){.site-preview-card.preview-animate .browser-frame iframe,.site-preview-card.preview-animate .gesture-guide,.site-preview-card.preview-animate .gesture-guide:after{animation:none}}.contact-section{background:linear-gradient(120deg, #58f2d52e, transparent 34%), linear-gradient(280deg, #8ea7ff24, transparent 36%), var(--teal-soft);border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:32px;padding:clamp(48px,6vw,76px) clamp(18px,4vw,52px);display:flex}.contact-section h2{max-width:900px}.contact-actions{margin-top:0}@media (width<=1120px){.hero-section,.intro-grid,.process-grid{grid-template-columns:1fr}.hero-visual{min-height:360px}.projects-grid,.projects-grid.compact,.site-preview-grid,.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=760px){.site-header{height:auto;padding-block:14px}.site-header nav{gap:12px}.site-header nav a{font-size:.84rem}.brand span:last-child{display:none}.hero-section{gap:28px;min-height:auto;padding-top:34px}h1{font-size:clamp(2.2rem,11vw,3.6rem)}.hero-actions,.contact-actions{flex-direction:column}.button{width:100%}.hero-visual{min-height:300px}.cred-strip,.projects-grid,.projects-grid.compact,.site-preview-grid,.skills-grid{grid-template-columns:1fr}.browser-frame{height:330px}.browser-frame iframe{height:414px}.cred-strip>div+div{border-left:0;border-top:1px solid var(--line)}.section-heading,.contact-section{flex-direction:column;align-items:stretch}.project-card{min-height:0}}
