*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f9f8f7;--text:#111;--text-secondary:#6b6b6b;--accent:#4a6fa5;--card-bg:#fff;--card-border:#00000012;--font-display:"Space Grotesk", system-ui, sans-serif;--font-serif:"Cormorant Garamond", Georgia, serif;--font-body:"Inter", system-ui, sans-serif}html{scroll-behavior:smooth}body{background-color:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}#root{min-height:100svh}.orbs{pointer-events:none;z-index:-1;position:fixed;inset:0;overflow:hidden}.orb{pointer-events:none;border-radius:50%;position:absolute}.orb-1{filter:blur(80px);background:radial-gradient(circle,#4a6fa52e 0%,#0000 70%);width:700px;height:700px;animation:22s ease-in-out infinite alternate orbDrift1;top:-250px;left:-250px}.orb-2{filter:blur(80px);background:radial-gradient(circle,#648cbe1f 0%,#0000 70%);width:600px;height:600px;animation:28s ease-in-out infinite alternate orbDrift2;bottom:-200px;right:-200px}.orb-3{filter:blur(60px);background:radial-gradient(circle,#4a6fa514 0%,#0000 70%);width:450px;height:450px;animation:18s ease-in-out infinite alternate orbDrift3;top:50%;left:60%}@keyframes orbDrift1{0%{transform:translate(0)}to{transform:translate(100px,70px)}}@keyframes orbDrift2{0%{transform:translate(0)}to{transform:translate(-90px,-60px)}}@keyframes orbDrift3{0%{transform:translate(0)scale(1)}to{transform:translate(-50px,40px)scale(1.15)}}.bento{box-sizing:border-box;grid-template-rows:1fr auto;grid-template-columns:1fr 1fr 1fr;gap:.625rem;height:100svh;padding:.875rem;display:grid;position:relative}.gap-tracer{pointer-events:none;z-index:20;position:absolute;inset:0}@media (width<=768px){.gap-tracer{display:none}}.bento-cell{background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;padding:2.25rem;overflow:hidden}.cell-hero{flex-direction:column;grid-area:1/1/auto/3;justify-content:center;display:flex}.cell-project{flex-direction:column;grid-area:1/3/3;display:flex}.cell-skills{grid-area:2/1}.cell-contact{grid-area:2/2}.hero-name{font-family:var(--font-display);letter-spacing:-.025em;color:var(--text);margin-bottom:1rem;font-size:clamp(3rem,8vw,7.5rem);font-weight:500;line-height:1}.hero-title{font-family:var(--font-body);letter-spacing:.22em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.875rem;font-size:.75rem;font-weight:400}.hero-tagline{font-family:var(--font-serif);color:var(--text-secondary);font-size:clamp(1.125rem,1.8vw,1.4rem);font-style:italic;font-weight:400}.section-label{letter-spacing:.22em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:1rem;font-size:.625rem;font-weight:500}.skills-list{color:var(--text-secondary);font-size:.9375rem;line-height:1.8}.project-content{flex-direction:column;flex:1;display:flex}.project-logo{object-fit:contain;align-self:flex-start;width:auto;height:clamp(2rem,4vw,3rem);margin:1.25rem 0 .875rem}.project-desc{color:var(--text-secondary);flex:1;font-size:.9375rem;line-height:1.55}.project-link{color:var(--accent);letter-spacing:.02em;margin-top:1.5rem;font-size:.875rem;font-weight:500}.project-more{color:#00000038;letter-spacing:.1em;text-transform:uppercase;margin-top:.75rem;font-size:.6875rem}.badge{letter-spacing:.08em;text-transform:uppercase;border-radius:999px;align-self:flex-start;align-items:center;padding:.2em .7em;font-size:.625rem;font-weight:500;display:inline-flex}.badge-live{color:var(--accent);background:#4a6fa51a}.badge-in-progress{color:#9b7a3a;background:#b48c501a}.badge-open-source{color:#2d7a56;background:#3c8c641a}.contact-email{color:var(--text);width:fit-content;margin-bottom:1.5rem;font-size:clamp(.8125rem,1.1vw,1rem);transition:color .3s;display:block;position:relative}.contact-email:after{content:"";background:var(--accent);width:0;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.contact-email:hover{color:var(--accent)}.contact-email:hover:after{width:100%}.social-links{align-items:center;gap:1.25rem;display:flex}.social-link{color:var(--text-secondary);align-items:center;gap:.45rem;font-size:.8125rem;transition:color .2s;display:inline-flex}.social-link:hover{color:var(--text)}@media (width<=768px){.bento{flex-direction:column;gap:.75rem;height:auto;min-height:100svh;padding:1rem;display:flex}.bento-cell{border-radius:16px;padding:2rem}.cell-hero{min-height:60svh}.cell-project{min-height:280px}}
