:root{--bg: #F5F5F0;--bg-alt: #EAEAE3;--ink: #0A0A0A;--ink-light: #2A2A2A;--ink-muted: #888888;--accent: #FF4D30;--accent-hover: #E03A1F;--border: rgba(10, 10, 10, .1);--border-dark: var(--ink);--font-serif: "Instrument Serif", "Georgia", serif;--font-display: "Instrument Serif", "Georgia", serif;--font-body: "IBM Plex Mono", "Courier New", monospace;--space-xs: .5rem;--space-sm: 1rem;--space-md: 2rem;--space-lg: 4rem;--space-xl: 6rem;--space-2xl: 10rem;--max-width: 1000px;--gutter: clamp(1.5rem, 5vw, 5rem);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);font-weight:300;color:var(--ink);background-color:var(--bg);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:400;line-height:.95;letter-spacing:-.01em}a{color:var(--ink);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent)}img{max-width:100%;display:block}::selection{background:var(--accent);color:var(--bg)}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:var(--space-2xl) var(--gutter) var(--space-lg);max-width:100%;margin:0 auto;position:relative;background:var(--bg)}.hero-inner{max-width:var(--max-width);margin:0 auto;width:100%;padding:0 var(--gutter)}.hero-statement{margin-bottom:var(--space-md)}.hero-statement p{font-family:var(--font-serif);font-size:clamp(2.5rem,5.5vw,5rem);font-weight:400;line-height:1.05;letter-spacing:-.01em;color:var(--ink)}.hero-statement em{font-style:italic;color:var(--ink);text-decoration:none;background-image:linear-gradient(var(--accent),var(--accent));background-size:0% 2px;background-position:0% 88%;background-repeat:no-repeat;transition:background-size .4s cubic-bezier(.16,1,.3,1);cursor:default}.hero-statement em:hover{background-size:100% 2px}.hero-bottom{margin-top:var(--space-xl)}.hero-cta{display:flex;gap:1rem}.btn{font-family:var(--font-body);font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;padding:1rem 2.5rem;transition:all .3s cubic-bezier(.16,1,.3,1);cursor:pointer;text-decoration:none;display:inline-block}.btn--primary{background:var(--ink);color:var(--bg);border:1px solid var(--ink)}.btn--primary:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--border)}.btn--ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero-scroll-line{width:1px;height:50px;background:var(--border);position:relative;overflow:hidden}.hero-scroll-line:after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--accent);animation:scroll-pulse 2s ease-in-out infinite}@keyframes scroll-pulse{0%{top:-100%}50%{top:0}to{top:100%}}@media(max-width:768px){.hero{padding:var(--space-xl) var(--gutter) var(--space-md)}.hero-inner{padding:0}.hero-bottom{margin-top:var(--space-md)}.hero-scroll{display:none}.hero-cta{width:fit-content}}.projects{border-bottom:1px solid var(--border)}.projects-heading{font-size:clamp(4rem,10vw,8rem);margin-bottom:var(--space-lg)}.projects-heading em{color:var(--accent)}.projects-list{display:flex;flex-direction:column}.project-row{display:grid;grid-template-columns:60px 1fr 200px;gap:var(--space-md);align-items:start;padding:var(--space-md) 0;border-top:1px solid var(--border);text-decoration:none;color:var(--ink);transition:all .3s ease}.project-row:last-child{padding-bottom:0}.project-row:hover{padding-left:1rem;color:var(--ink)}.project-row:hover .project-num{color:var(--accent)}.project-row:hover .project-arrow{color:var(--accent);transform:translate(5px)}.project-num{font-family:var(--font-body);font-size:.65rem;font-weight:500;letter-spacing:.15em;color:var(--ink-muted);transition:color .3s ease}.project-title{font-family:var(--font-serif);font-size:2rem;font-weight:400;margin-bottom:.15rem}.project-role{font-family:var(--font-serif);font-size:1rem;font-style:italic;color:var(--ink-light);display:block;margin-bottom:.5rem}.project-desc{font-size:.75rem;color:var(--ink-muted);line-height:1.7;max-width:480px}.project-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end}.project-tag{font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;padding:.3rem .6rem;border:1px solid var(--accent);color:var(--accent)}.project-year{font-family:var(--font-body);font-size:.6rem;letter-spacing:.15em;color:var(--ink-muted)}.project-arrow{color:var(--ink-muted);transition:all .3s ease}.project-card,.project-card-top,.project-card-image,.project-card-placeholder{display:none}@media(max-width:900px){.project-row{grid-template-columns:40px 1fr}.project-meta{display:none}}@media(max-width:480px){.project-row{grid-template-columns:1fr}.project-num{display:none}}.skills{border-bottom:1px solid var(--border)}.skills-heading{font-size:clamp(4rem,10vw,8rem);margin-bottom:var(--space-lg)}.skills-heading em{color:var(--accent)}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.skill-group{padding:var(--space-md);border-right:1px solid var(--border)}.skill-group:nth-child(4n){border-right:none}.skill-category{font-family:var(--font-body);font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem}.skill-items{list-style:none}.skill-item{font-size:.8rem;font-weight:400;color:var(--ink-light);padding:.4rem 0;border-bottom:1px solid rgba(0,0,0,.04);transition:all .2s ease;cursor:default}.skill-item:last-child{border-bottom:none}.skill-item:hover{color:var(--ink);padding-left:.5rem}.skills-education{margin-top:var(--space-md);padding-top:var(--space-md)}.education-items{display:flex;gap:var(--space-lg);margin-top:1rem}.education-item{display:flex;flex-direction:column;gap:.25rem}.education-school{font-family:var(--font-serif);font-size:1.1rem;font-style:italic;color:var(--ink)}.education-detail{font-size:.7rem;color:var(--ink-muted);letter-spacing:.05em}@media(max-width:480px){.education-items{flex-direction:column;gap:var(--space-sm)}}.skills-layout,.skills-intro,.skills-description,.skills-groups{display:none}@media(max-width:768px){.skills-grid{grid-template-columns:1fr 1fr}.skill-group{border-right:1px solid var(--border)}.skill-group:nth-child(2n){border-right:none}.skill-group:nth-child(n+3){border-top:1px solid var(--border)}}@media(max-width:480px){.skills-grid{grid-template-columns:1fr}.skill-group{border-right:none;border-bottom:1px solid var(--border);padding:var(--space-md) 0}.skill-group:last-child{border-bottom:none}}.contact-section{background:var(--accent);color:var(--ink);padding:var(--space-2xl) var(--gutter)}.contact-inner{max-width:var(--max-width);margin:0 auto;text-align:center}.contact-section .section-label{justify-content:center;color:#fff6}.contact-section .section-label:after{display:none}.contact-heading{font-family:var(--font-serif);font-size:clamp(5rem,15vw,12rem);line-height:1;color:var(--ink);margin-bottom:var(--space-md)}.contact-email{font-family:var(--font-body);font-size:clamp(1rem,2.5vw,1.5rem);font-weight:700;color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:4px;transition:all .3s ease;display:inline-block}.contact-email:hover{color:#fff;border-color:#fff}.contact-socials{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:var(--space-lg)}.contact-social-link{font-family:var(--font-body);font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#ffffff80;text-decoration:none;transition:color .3s ease}.contact-social-link:hover{color:#fff}.contact-sep{color:#ffffff4d;font-size:.75rem}.contact-layout,.contact-main,.contact-text,.contact-socials-label,.contact-socials-list{display:none}.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.5rem var(--gutter);transition:all .3s ease}.nav--scrolled{padding:1rem var(--gutter);background:#f5f5f0e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.nav-inner{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-family:var(--font-display);font-size:1.8rem;color:var(--ink);letter-spacing:.05em;text-decoration:none}.nav-logo-dot{color:var(--accent)}.nav-links{list-style:none;display:flex;gap:2.5rem}.nav-link{font-family:var(--font-body);font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-light);text-decoration:none;position:relative}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);transition:width .3s cubic-bezier(.16,1,.3,1)}.nav-link:hover{color:var(--ink)}.nav-link:hover:after{width:100%}@media(max-width:768px){.nav-links{gap:1.5rem}.nav-link{font-size:.6rem}}@media(max-width:480px){.nav-links{gap:1rem}}*,*:before,*:after{cursor:none!important}.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:10001;will-change:transform}.cursor-dot--hover{width:8px;height:8px}.cursor-ring{position:fixed;top:0;left:0;width:36px;height:36px;border:1.5px solid var(--ink);border-radius:50%;pointer-events:none;z-index:10000;will-change:transform;transition:width .3s ease,height .3s ease,border-color .2s ease}.cursor-ring--hover{width:56px;height:56px;border-color:var(--accent)}@media(hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none}*,*:before,*:after{cursor:auto!important}}.site{position:relative}.grain{display:none}.section{padding:var(--space-xl) var(--gutter);max-width:var(--max-width);margin:0 auto}.section-label{font-family:var(--font-body);font-size:.65rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:1.5rem}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.footer{padding:var(--space-lg) var(--gutter);max-width:var(--max-width);margin:0 auto;border-top:1px solid var(--border)}.footer-inner{display:flex;justify-content:space-between;align-items:center}.footer-line{display:none}.footer p{font-size:.7rem;letter-spacing:.15em;color:var(--ink-muted);text-transform:uppercase}@media(max-width:768px){:root{--gutter: 1rem}.section{padding:var(--space-md) var(--gutter)}}
