@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=Outfit:wght@400;500;700;800&display=swap";:root{--bg:#eef7ff;--panel:#fffaf3bd;--text:#172033;--text-muted:#51627d;--accent:#ff8a00;--accent-warm:#ff4d6d;--heading:"Outfit", "Trebuchet MS", sans-serif;--body:"Space Grotesk", "Segoe UI", sans-serif;font-family:var(--body);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);min-width:320px;margin:0}body,button,a,input,textarea{font-family:var(--body)}a{color:inherit}#root{min-height:100vh}h1,h2,h3,p,ul{margin-top:0}h1,h2,h3{font-family:var(--heading);color:var(--text);line-height:.98}h1{letter-spacing:-.06em;max-width:11ch;margin-bottom:0;font-size:clamp(3.4rem,9vw,6.8rem)}h2{margin-bottom:.8rem;font-size:clamp(1.8rem,4vw,2.8rem)}h3{font-size:1.35rem}p,li,a{font-size:1rem;line-height:1.65}::selection{color:#172033;background:#ff4d6d3d}.app-shell{min-height:100vh;position:relative;overflow:hidden}.city-backdrop{background:radial-gradient(circle at top,#ffb74d66,#0000 26%),radial-gradient(circle at 18% 24%,#22c55e38,#0000 24%),radial-gradient(circle at 82% 30%,#60a5fa33,#0000 26%),linear-gradient(#f7fbff 0%,#dff0ff 54%,#d9f6e7 100%);position:fixed;inset:0;overflow:hidden}.city-grid{opacity:.92;background:linear-gradient(#ffffff73 2px,#0000 2px) 0 0/160px 160px,linear-gradient(90deg,#ffffff73 2px,#0000 2px) 0 0/160px 160px,linear-gradient(#6884b033 58px,#0000 58px) 0 0/320px 320px,linear-gradient(90deg,#6884b033 58px,#0000 58px) 0 0/320px 320px;position:absolute;inset:0}.city-glow{filter:blur(24px);opacity:.28;border-radius:50%;width:34rem;height:34rem;position:absolute}.city-glow-left{background:#fb7185;top:5%;left:-8rem}.city-glow-right{background:#38bdf8;bottom:8%;right:-10rem}.city-block{background:linear-gradient(135deg,#ffffffa6,#ffffff26),#f4f8ffd6;border:1px solid #788eb52e;border-radius:2rem;position:absolute;box-shadow:inset 0 0 0 1px #fff3}.city-block-a{width:16rem;height:10rem;top:14%;left:12%}.city-block-b{width:18rem;height:12rem;top:18%;right:14%}.city-block-c{width:20rem;height:13rem;bottom:12%;left:9%}.city-block-d{width:14rem;height:10rem;bottom:16%;right:18%}.city-marker{color:#355070;letter-spacing:.12em;text-transform:uppercase;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff9e;border:1px solid #ffffffa6;border-radius:999px;padding:.55rem .9rem;font-size:.75rem;position:absolute}.marker-1{top:12%;right:22%}.marker-2{top:48%;left:8%}.marker-3{bottom:18%;right:10%}.boost-pad{background:#ffffffa6;border:1px solid #ff880047;border-radius:999px;justify-content:center;align-items:center;gap:.18rem;display:flex;position:fixed;transform:translate(-50%,-50%);box-shadow:0 0 0 .28rem #ff4d6d14,0 0 18px #ff88002e}.boost-pad-horizontal{width:4.8rem;height:1.5rem}.boost-pad-vertical{flex-direction:column;width:1.5rem;height:4.8rem}.boost-chevron{border-top:3px solid #ff4d6db8;border-right:3px solid #ff4d6db8;width:.75rem;height:.75rem;transform:rotate(45deg)}.boost-pad-vertical .boost-chevron{transform:rotate(135deg)}.trail-dot{pointer-events:none;background:radial-gradient(circle,#60a5fa 0%,#ff4d6d 70%,#0000 72%);border-radius:50%;width:.7rem;height:.7rem;margin-top:-.35rem;margin-left:-.35rem;position:fixed;box-shadow:0 0 16px #ff4d6d57}.cursor-car{pointer-events:none;z-index:4;background:linear-gradient(#ff9f1c 0%,#ff4d6d 62%,#845ef7 100%);border-radius:1.3rem;width:3.8rem;height:6rem;margin-top:-3rem;margin-left:-1.9rem;transition:box-shadow .12s,filter .12s;position:fixed;box-shadow:0 18px 34px #405b7e3d,inset 0 0 0 2px #fffaeb5c}.cursor-car-boosted{filter:saturate(1.15);box-shadow:0 18px 34px #405b7e3d,0 0 30px #38bdf859,inset 0 0 0 2px #fff1cb4d}.cursor-car:before,.cursor-car:after{content:"";background:#fff5d773;border-radius:999px;height:.45rem;position:absolute;left:.65rem;right:.65rem}.cursor-car:before{top:.85rem}.cursor-car:after{bottom:.9rem}.car-window{background:linear-gradient(#fff4d6d1,#fed7aa3d),#0f172a;border-radius:1rem;position:absolute;inset:1.55rem .75rem 1.45rem}.wheel{background:#111827;border-radius:999px;width:.72rem;height:1.25rem;position:absolute}.wheel-front-left,.wheel-back-left{left:-.25rem}.wheel-front-right,.wheel-back-right{right:-.25rem}.wheel-front-left,.wheel-front-right{top:1.15rem}.wheel-back-left,.wheel-back-right{bottom:1.15rem}.content{z-index:2;width:min(1120px,100% - 2rem);margin:0 auto;padding:3rem 0 5rem;position:relative}.content>*+*{margin-top:1.2rem}.panel{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fff9;border:1px solid #ffffff94;box-shadow:0 24px 80px #3b577824}.hero-panel{border-radius:2.5rem;flex-direction:column;justify-content:center;gap:1.5rem;min-height:86vh;padding:3rem;display:flex}.eyebrow{flex-wrap:wrap;gap:.75rem;display:flex}.eyebrow-chip,.loadout-chip{color:var(--text-muted);letter-spacing:.04em;background:#ffffff94;border:1px solid #ffffffb8;border-radius:999px;align-items:center;gap:.5rem;padding:.7rem 1rem;display:inline-flex}.hero-copy{grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);align-items:center;gap:1.5rem;display:grid}.hero-copy-text{gap:1rem;display:grid}.hero-portrait{background:linear-gradient(135deg,#ffffffd1,#fff6),#ffffff73;border:1px solid #ffffffb8;border-radius:2rem;width:min(100%,21rem);margin-left:auto;padding:.8rem;box-shadow:0 24px 60px #3b577829,inset 0 0 0 1px #fff6}.hero-portrait img{aspect-ratio:4/5;object-fit:cover;object-position:center top;border-radius:1.4rem;width:100%;display:block}.kicker,.section-tag,.stat-label,.timeline-range,.project-stack{color:var(--accent);text-transform:uppercase;letter-spacing:.18em;font-size:.8rem}.hero-actions{flex-wrap:wrap;gap:1rem;display:flex}.primary-button,.secondary-button{border-radius:999px;justify-content:center;align-items:center;gap:.55rem;min-height:3.25rem;padding:0 1.3rem;text-decoration:none;transition:transform .18s,border-color .18s,background .18s;display:inline-flex}.primary-button{color:#fff9f4;background:linear-gradient(135deg,#ff8a00,#ff4d6d);font-weight:700}.secondary-button{color:var(--text);background:#ffffff9e;border:1px solid #fffc}.primary-button:hover,.secondary-button:hover{transform:translateY(-2px)}.hero-note{max-width:34rem;color:var(--text-muted);background:#ffffff80;border-left:3px solid #ff4d6d99;border-radius:1rem;padding:1rem 1.15rem}.stats-grid,.projects-grid,.content-grid,.stacks-grid{gap:1.2rem;display:grid}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.stat-card,.mission-panel,.contact-panel,.stacks-panel,.timeline-panel,.interest-card,.project-card,.final-panel{border-radius:2rem}.stat-card{padding:1.4rem}.content-grid{grid-template-columns:1.2fr .8fr}.mission-panel,.contact-panel,.stacks-panel,.timeline-panel,.interest-card,.project-card,.final-panel{padding:2rem}.loadout-grid{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.contact-panel .link-list{gap:1rem;margin:1.25rem 0 0;padding:0;list-style:none;display:grid}.contact-panel li{color:var(--text-muted);align-items:center;gap:.85rem;display:flex}.contact-panel a{color:var(--text)}.stacks-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.stack-card{text-align:center;background:#ffffff80;border:1px solid #ffffffb8;border-radius:1.5rem;padding:1.4rem 1rem}.stack-card h3{margin:0 0 .35rem;font-size:1.1rem}.stack-card p{color:var(--text-muted);margin:0}.stack-logo{background:#fffc;border-radius:1.2rem;place-items:center;width:4rem;height:4rem;margin:0 auto 1rem;font-size:1.85rem;display:grid;box-shadow:inset 0 0 0 1px #ffffff80}.stack-card-react .stack-logo{color:#0ea5e9}.stack-card-node .stack-logo{color:#22c55e}.stack-card-express .stack-logo{color:#1f2937}.stack-card-javascript .stack-logo{color:#f59e0b}.stack-card-python .stack-logo{color:#2563eb}.stack-card-vue .stack-logo{color:#10b981}.stack-card-mongodb .stack-logo{color:#16a34a}.stack-card-mysql .stack-logo{color:#0284c7}.stack-card-aws .stack-logo{color:#f97316}.stack-card-github .stack-logo{color:#7c3aed}.interests-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.2rem;margin-top:1.2rem;display:grid}.interest-card{min-height:16rem}.interest-icon{width:3rem;height:3rem;color:var(--accent-warm);background:linear-gradient(135deg,#60a5fa24,#ff4d6d24);border-radius:1rem;place-items:center;margin-bottom:1.2rem;font-size:1.3rem;display:grid}.section-header{justify-content:space-between;gap:2rem;margin-bottom:1.8rem;display:flex}.section-header p:last-child{max-width:32rem;color:var(--text-muted)}.timeline{gap:1.4rem;display:grid}.timeline-item{grid-template-columns:auto 1fr;align-items:start;gap:1rem;display:grid}.timeline-pin{background:linear-gradient(135deg,#f97316,#facc15);border-radius:50%;width:.95rem;height:.95rem;margin-top:.45rem;box-shadow:0 0 0 .35rem #f9731629}.timeline h3{margin:.3rem 0 .7rem}.timeline h3 span{color:var(--text-muted);font-weight:500}.timeline ul{color:var(--text-muted);margin:0;padding-left:1.1rem}.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-card{align-content:start;gap:.85rem;min-height:17rem;display:grid}.project-card h2,.project-card p{margin:0}.project-link{justify-self:start;margin-top:auto}.final-panel{grid-template-columns:1fr auto;align-items:end;gap:1.5rem;margin-top:1.2rem;display:grid}.final-contact{justify-items:end;gap:.85rem;display:grid}.contact-email{color:var(--text-muted);font-weight:500;text-decoration:none}.contact-email:hover{color:var(--accent-warm)}@media (width<=980px){.content{width:min(100% - 1rem,1120px);padding:.75rem 0 4rem}.hero-panel{min-height:auto;padding:5.5rem 1.25rem 1.5rem}.hero-copy,.content-grid,.stacks-grid,.section-header,.final-panel,.stats-grid,.interests-grid,.projects-grid{grid-template-columns:1fr}.hero-copy-text{gap:.8rem}.hero-portrait{width:min(100%,18rem);margin:0}.section-header{gap:.75rem}.final-contact{justify-items:start}.cursor-car{width:3.2rem;height:5.2rem;margin-top:-2.6rem;margin-left:-1.6rem}.city-marker{font-size:.68rem}}@media (width<=640px){.marker-1,.marker-2,.marker-3,.city-block-c,.city-block-d{display:none}.hero-note,.section-header p:last-child{max-width:none}}
