@import"https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--ink: #111312;--ink-soft: #303631;--paper: #f6f7f3;--paper-deep: #e4e9e0;--surface: #fffefa;--surface-muted: #eef2eb;--line: rgba(17, 19, 18, .14);--line-strong: rgba(17, 19, 18, .28);--muted: #626a63;--accent: #1f6f64;--accent-dark: #124f49;--accent-warm: #a85636;--accent-blue: #275d9c;--accent-violet: #635278;--shadow: 0 24px 70px rgba(17, 19, 18, .14);--shadow-soft: 0 14px 44px rgba(17, 19, 18, .09);--sans: Archivo, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--display: "Space Grotesk", Archivo, ui-sans-serif, system-ui, sans-serif;color:var(--ink);background:var(--paper);font-family:var(--sans);letter-spacing:0}*,*:before,*:after{box-sizing:border-box}html{background:var(--paper);scroll-behavior:smooth}section[id]{scroll-margin-top:108px}body{margin:0;min-width:320px;overflow-x:hidden;background:linear-gradient(90deg,rgba(17,19,18,.035) 1px,transparent 1px),linear-gradient(180deg,#f6f7f3 0%,#edf1ea 45%,#f6f7f3 100%);background-size:72px 100%,100% 100%;color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.65;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body:before{position:fixed;inset:0;z-index:-1;pointer-events:none;content:"";background-image:linear-gradient(rgba(17,19,18,.04) 1px,transparent 1px);background-size:100% 8px;opacity:.45}a{color:inherit;text-decoration-thickness:1px;text-underline-offset:.2em}h1,h2,h3,p,a,dd{overflow-wrap:break-word}img{display:block;max-width:100%}button,input,textarea,select{font:inherit}button{cursor:pointer}:focus-visible{outline:3px solid rgba(31,111,100,.42);outline-offset:4px}.skip-link{position:fixed;top:1rem;left:1rem;z-index:100;padding:.72rem 1rem;color:#fffefa;background:var(--ink);border-radius:6px;transform:translateY(-180%);transition:transform .18s ease-out}.skip-link:focus{transform:translateY(0)}.site-header{position:sticky;top:0;z-index:50;background:rgba(246,247,243,.88);border-bottom:1px solid var(--line);backdrop-filter:blur(18px)}.nav-shell{display:flex;align-items:center;justify-content:space-between;width:min(1180px,calc(100% - 40px));min-height:76px;margin:0 auto;gap:1.5rem}.brand,.footer-brand{font-family:var(--display);font-weight:700;line-height:1;text-decoration:none}.brand{display:inline-flex;align-items:baseline;gap:.32rem;color:var(--ink);font-size:1.04rem}.brand span:last-child{color:var(--accent-dark)}.nav-links{display:flex;align-items:center;justify-content:flex-end;gap:.2rem}.nav-links a{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:.58rem .72rem;color:var(--muted);font-size:.94rem;font-weight:700;text-decoration:none;border-radius:6px;transition:color .17s ease-out,background-color .17s ease-out,border-color .17s ease-out}.nav-links a:hover,.nav-links a:focus-visible,.nav-links a[aria-current=page]{color:var(--ink);background:rgba(17,19,18,.06)}.nav-links .nav-cta{margin-left:.2rem;color:#fffefa;background:var(--ink)}.nav-links .nav-cta:hover,.nav-links .nav-cta:focus-visible,.nav-links .nav-cta[aria-current=page]{color:#fffefa;background:var(--accent-dark)}.nav-toggle{display:none;align-items:center;gap:.44rem;min-height:44px;padding:.56rem .7rem;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:6px}.nav-toggle-line{display:block;width:18px;height:1px;background:currentColor}.nav-toggle-label{font-size:.9rem;font-weight:700}.site-main{min-height:70vh}.hero{--hero-x: 0px;--hero-y: 0px;--hero-tilt: 0deg;position:relative;min-height:calc(100svh - 156px);padding:5rem max(20px,calc((100vw - 1180px)/2)) 3.8rem;overflow:hidden;isolation:isolate;color:#fffefa;background:linear-gradient(115deg,rgba(17,19,18,.98) 0%,rgba(20,30,29,.98) 54%,rgba(75,63,49,.95) 100%),var(--ink)}.hero-surface{position:absolute;inset:0;z-index:-1;pointer-events:none;background:linear-gradient(90deg,rgba(255,254,250,.08) 1px,transparent 1px),linear-gradient(180deg,transparent 0%,rgba(0,0,0,.28) 100%);background-position:calc(50% + var(--hero-x)) 0,0 0;background-size:90px 100%,100% 100%}.hero-surface:after{position:absolute;right:-10%;bottom:0;width:52%;height:100%;content:"";background:linear-gradient(135deg,transparent 0 34%,rgba(168,86,54,.18) 34% 58%,transparent 58%)}.hero-grid{display:grid;grid-template-columns:minmax(0,1.12fr) minmax(320px,.72fr);width:min(1180px,calc(100% - 40px));margin:0 auto;gap:3.2rem;align-items:center}.hero-copy{max-width:760px;min-width:0}.eyebrow{margin:0 0 .85rem;color:var(--accent-dark);font-size:.78rem;font-weight:800;line-height:1.2;text-transform:uppercase;letter-spacing:0}.hero .eyebrow{color:#a5d5cc}.hero h1,.page-hero h1{margin:0;font-family:var(--display);font-size:5.25rem;font-weight:700;line-height:.96;letter-spacing:0}.hero-line{max-width:760px;margin:1.28rem 0 0;color:#fffefa;font-family:var(--display);font-size:1.72rem;font-weight:500;line-height:1.22}.hero-intro{max-width:650px;margin:1.1rem 0 0;color:#fffefac7;font-size:1.04rem}.hero-actions,.button-row,.page-hero-actions{display:flex;flex-wrap:wrap;gap:.72rem;margin-top:2rem}.button{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:.78rem 1.02rem;border:1px solid transparent;border-radius:6px;font-weight:800;line-height:1.2;text-decoration:none;transition:background-color .18s ease-out,border-color .18s ease-out,color .18s ease-out,transform .18s ease-out,box-shadow .18s ease-out}.button:hover{transform:translateY(-2px)}.button-light{color:var(--ink);background:#fffefa;box-shadow:0 18px 42px #0003}.button-ghost-light{color:#fffefa;border-color:#fffefa47;background:rgba(255,254,250,.08)}.button-ghost-light:hover{background:rgba(255,254,250,.15)}.button-dark{color:#fffefa;background:var(--ink);box-shadow:var(--shadow-soft)}.button-dark:hover{background:var(--accent-dark)}.button-ghost{color:var(--ink);border-color:var(--line-strong);background:rgba(255,254,250,.58)}.button-ghost:hover{background:var(--surface)}.hero-portrait{position:relative;display:grid;gap:1rem;align-self:stretch;min-width:0;transform:translate3d(var(--hero-x),var(--hero-y),0) rotate(var(--hero-tilt));transition:transform .24s cubic-bezier(.2,.7,.2,1)}.portrait-frame{position:relative;display:grid;align-items:end;height:460px;min-height:460px;margin:0;overflow:hidden;border:1px solid rgba(255,254,250,.2);border-radius:8px;background:linear-gradient(90deg,rgba(255,254,250,.06) 1px,transparent 1px),linear-gradient(145deg,rgba(31,111,100,.2),rgba(168,86,54,.12));background-size:28px 100%,100% 100%;box-shadow:0 30px 80px #00000052}.portrait-frame:before{position:absolute;inset:1rem;content:"";border:1px solid rgba(255,254,250,.18);border-radius:6px}.portrait-frame img{position:relative;z-index:1;width:100%;height:100%;max-height:none;object-fit:cover;object-position:top center;filter:contrast(1.03) saturate(.95)}.hero-focus{display:grid;gap:.72rem;padding:1rem;color:#fffefac7;border:1px solid rgba(255,254,250,.18);border-radius:8px;background:rgba(255,254,250,.08)}.hero-focus p{margin:0;color:#fffefa;font-family:var(--display);font-size:1.1rem;font-weight:700}.hero-focus ul,.contact-list{display:grid;gap:.45rem;padding:0;margin:0;list-style:none}.hero-focus li,.contact-list li{position:relative;padding-left:1.1rem}.hero-focus li:before,.contact-list li:before{position:absolute;top:.72em;left:0;width:.42rem;height:.42rem;content:"";background:currentColor;border-radius:50%}.content-section,.page-hero,.section-jump,.site-footer{width:min(1180px,calc(100% - 40px));margin:0 auto}.content-section{padding:6.2rem 0}.featured-section{padding-top:5.4rem}.section-heading{max-width:780px;margin-bottom:2.5rem}.section-heading.compact{margin-bottom:1.45rem}.section-heading h2,.contact-band h2{margin:0;font-family:var(--display);font-size:3.05rem;font-weight:700;line-height:1.05}.section-heading p:not(.eyebrow),.page-hero p:not(.eyebrow),.contact-band p:not(.eyebrow){margin:.9rem 0 0;color:var(--muted);font-size:1.05rem}.browser-section{padding-bottom:3.2rem}.work-browser{display:grid;grid-template-columns:minmax(280px,.88fr) minmax(0,1.12fr);gap:1rem;align-items:stretch}.track-controls,.track-preview,.contact-panel{border:1px solid var(--line);border-radius:8px;background:rgba(255,254,250,.78);box-shadow:var(--shadow-soft)}.track-controls{display:grid;gap:.5rem;padding:.6rem}.track-button{display:grid;grid-template-columns:2.4rem minmax(0,1fr);gap:.8rem;width:100%;min-height:82px;padding:.82rem;color:var(--muted);text-align:left;background:transparent;border:1px solid transparent;border-radius:6px;transition:background-color .18s ease-out,border-color .18s ease-out,color .18s ease-out}.track-button:hover,.track-button.is-active{color:var(--ink);background:var(--surface-muted);border-color:var(--line)}.track-button strong,.track-button small{display:block}.track-button strong{font-family:var(--display);font-size:1.04rem;line-height:1.2}.track-button small{margin-top:.25rem;font-size:.86rem;line-height:1.35}.track-index{display:inline-flex;align-items:center;justify-content:center;width:2.2rem;height:2.2rem;color:var(--accent-dark);font-size:.76rem;font-weight:800;border:1px solid currentColor;border-radius:50%}.track-preview{position:relative;min-height:420px;padding:1.5rem;overflow:hidden}.track-preview:before{position:absolute;inset:0 0 auto;height:7px;content:"";background:linear-gradient(90deg,var(--accent),var(--accent-warm),var(--accent-blue))}.track-preview h3{max-width:760px;margin:0;font-family:var(--display);font-size:2.35rem;line-height:1.05}.track-preview>p:not(.eyebrow){max-width:720px;margin:.95rem 0 0;color:var(--ink-soft);font-size:1.1rem}.track-details,.card-meta{display:grid;gap:.75rem;margin:1.5rem 0 0}.track-details{grid-template-columns:repeat(3,minmax(0,1fr))}.track-details div,.card-meta div{padding-top:.85rem;border-top:1px solid var(--line)}.track-details dt,.card-meta dt{color:var(--muted);font-size:.74rem;font-weight:800;text-transform:uppercase}.track-details dd,.card-meta dd{margin:.22rem 0 0;color:var(--ink);font-weight:700;line-height:1.35}.track-preview .button{margin-top:1.5rem}.track-web:before{background:linear-gradient(90deg,var(--accent-blue),var(--accent),var(--ink))}.track-games:before{background:linear-gradient(90deg,var(--accent-warm),var(--accent-violet),var(--ink))}.track-animation:before{background:linear-gradient(90deg,var(--accent-violet),var(--accent-warm),var(--accent))}.featured-grid,.discipline-grid,.portfolio-grid{display:grid;gap:1rem}.hero-grid>*,.work-browser>*,.featured-grid>*,.discipline-grid>*,.portfolio-grid>*,.about-layout>*,.contact-layout>*,.about-index>*{min-width:0}.featured-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.discipline-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.portfolio-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.portfolio-grid.is-single{grid-template-columns:minmax(0,760px)}.feature-card,.discipline-card,.portfolio-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:rgba(255,254,250,.82);box-shadow:0 12px 36px #1113120f;transition:border-color .19s ease-out,box-shadow .19s ease-out,transform .19s ease-out,background-color .19s ease-out}.feature-card:before,.discipline-card:before,.portfolio-card:before{position:absolute;inset:0 0 auto;height:4px;content:"";background:var(--ink);transform:scaleX(.18);transform-origin:left;transition:transform .22s ease-out}.feature-card:hover,.discipline-card:hover,.portfolio-card:hover,.portfolio-card:focus-within{border-color:#1f6f645c;background:var(--surface);box-shadow:var(--shadow);transform:translateY(-4px)}.feature-card:hover:before,.discipline-card:hover:before,.portfolio-card:hover:before,.portfolio-card:focus-within:before{transform:scaleX(1)}.feature-card{display:flex;flex-direction:column;min-height:310px;padding:1.45rem}.discipline-card{min-height:250px;padding:1.35rem}.portfolio-card{min-height:300px;padding:1.35rem}.feature-card h3,.discipline-card h3,.portfolio-card h3{margin:0;color:var(--ink);font-family:var(--display);font-size:1.48rem;font-weight:700;line-height:1.15}.writing-card h3{font-size:1.62rem}.feature-card p:not(.eyebrow),.discipline-card p,.portfolio-card p{color:var(--muted)}.feature-card p:not(.eyebrow){margin:1rem 0 1.5rem}.discipline-card p,.portfolio-card p{margin:.88rem 0 0}.feature-card a{width:fit-content;margin-top:auto;color:var(--accent-dark);font-weight:800}.project-card a{display:block;height:100%;color:inherit;text-decoration:none}.card-kicker{margin:0 0 1.2rem;color:var(--accent-dark);font-size:.78rem;font-weight:800;line-height:1.3;text-transform:uppercase;letter-spacing:0}.card-meta{margin-top:1.3rem}.page-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,auto);gap:2rem;align-items:end;padding:6rem 0 3.2rem;border-bottom:1px solid var(--line)}.page-hero h1{max-width:900px;color:var(--ink);font-size:4.35rem}.page-hero p{max-width:780px;font-size:1.14rem}.page-hero-actions{justify-content:flex-end;margin-top:0}.section-jump{position:sticky;top:76px;z-index:20;display:flex;gap:.45rem;padding:.7rem 0;overflow-x:auto;background:rgba(246,247,243,.9);border-bottom:1px solid var(--line);backdrop-filter:blur(14px);scrollbar-width:none}.section-jump::-webkit-scrollbar{display:none}.section-jump a{flex:0 0 auto;min-height:40px;padding:.5rem .72rem;color:var(--muted);font-size:.9rem;font-weight:800;text-decoration:none;border:1px solid var(--line);border-radius:999px;background:rgba(255,254,250,.7);transition:color .17s ease-out,border-color .17s ease-out,background-color .17s ease-out}.section-jump a:hover,.section-jump a:focus-visible{color:var(--ink);border-color:var(--line-strong);background:var(--surface)}.portfolio-section{padding-top:3rem;padding-bottom:4.8rem}.about-section,.contact-section{padding-top:4rem}.about-layout,.contact-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.82fr);gap:4rem;align-items:center}.contact-layout{align-items:start}.about-copy{max-width:760px}.lead{margin-top:0;color:var(--ink);font-family:var(--display);font-size:1.76rem;font-weight:600;line-height:1.32}.about-copy p:not(.lead),.contact-layout p:not(.lead){color:var(--muted)}.about-portrait{position:relative;display:grid;align-content:end;justify-self:end;width:100%;max-width:430px;margin:0;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:linear-gradient(90deg,rgba(17,19,18,.06) 1px,transparent 1px),linear-gradient(145deg,rgba(31,111,100,.14),rgba(168,86,54,.1)),var(--surface-muted);background-size:30px 100%,100% 100%,100% 100%;box-shadow:var(--shadow)}.about-portrait img{width:100%;max-height:460px;padding:1rem 1rem 0;object-fit:contain;object-position:bottom center}.about-portrait figcaption{margin:0;padding:1rem 1.2rem 1.1rem;color:#fffefa;background:var(--ink);border-top:1px solid var(--line);font-family:var(--display);font-size:1.25rem;font-weight:700;line-height:1.2}.about-portrait figcaption span{display:block;margin-top:.35rem;color:#fffefaad;font-family:var(--sans);font-size:.9rem}.about-index-section{padding-top:0}.about-index{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--line)}.about-index div{min-height:210px;padding:1.35rem;background:rgba(255,254,250,.82)}.about-index span{display:block;color:var(--accent-dark);font-size:.76rem;font-weight:800}.about-index strong{display:block;margin-top:1rem;font-family:var(--display);font-size:1.45rem}.about-index p{margin:.72rem 0 0;color:var(--muted)}.contact-list{margin-top:1.4rem;color:var(--ink-soft);font-weight:700}.contact-panel{display:grid;gap:1.25rem;padding:1.35rem}.contact-panel span{display:block;margin-bottom:.35rem;color:var(--muted);font-size:.8rem;font-weight:800;text-transform:uppercase}.contact-panel a:not(.button){color:var(--accent-dark);font-weight:800;overflow-wrap:anywhere}.social-links{display:flex;flex-wrap:wrap;gap:.8rem}.contact-band{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-top:1rem;padding-top:3.2rem;padding-bottom:3.2rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.contact-band h2{max-width:760px;font-size:2.7rem}.site-footer{display:flex;align-items:flex-start;justify-content:space-between;padding:2.8rem 0 3.2rem;gap:2rem;color:var(--muted);border-top:1px solid var(--line)}.footer-brand{display:inline-block;color:var(--ink);font-size:1.05rem}.site-footer p{max-width:460px;margin:.55rem 0 0}.footer-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.9rem}.footer-links a{color:var(--ink-soft);font-weight:800}.reveal{opacity:0;clip-path:inset(0 0 12% 0);transform:translateY(18px);transition:opacity .52s ease-out,clip-path .52s ease-out,transform .52s cubic-bezier(.2,.7,.2,1)}.reveal.is-visible{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0)}@media (max-width: 1080px){.hero{min-height:auto;padding-top:4.4rem}.hero-grid{grid-template-columns:minmax(0,1fr)}.hero-copy{max-width:860px}.hero-portrait{max-width:620px}.portrait-frame{height:430px;min-height:430px}.hero h1,.page-hero h1{font-size:4.05rem}.featured-grid,.discipline-grid,.portfolio-grid,.track-details{grid-template-columns:repeat(2,minmax(0,1fr))}.work-browser,.page-hero,.about-layout,.contact-layout{grid-template-columns:1fr}.page-hero-actions{justify-content:flex-start}.about-portrait{justify-self:start}}@media (max-width: 760px){body{font-size:16px}.nav-shell,.content-section,.page-hero,.section-jump,.site-footer{width:min(1180px,calc(100% - 32px))}.nav-shell{width:100%;min-height:68px;padding:0 16px}.brand{display:inline-grid;gap:.08rem}.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;flex:0 0 52px;margin-left:auto;width:52px;padding:.55rem}.nav-toggle-label{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;white-space:nowrap;clip:rect(0,0,0,0)}.nav-links{position:absolute;top:calc(100% + 1px);right:16px;left:16px;display:grid;justify-content:stretch;gap:.25rem;padding:.65rem;background:rgba(246,247,243,.98);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .18s ease-out,transform .18s ease-out}.nav-links.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-links a{width:100%;justify-content:flex-start}.nav-links .nav-cta{margin-left:0}.hero{padding:3.4rem 16px}.hero-grid{width:calc(100vw - 32px);max-width:calc(100vw - 32px);gap:2rem}.hero-copy,.hero-portrait{width:100%;max-width:calc(100vw - 32px);padding-right:16px}.hero h1,.page-hero h1{font-size:3rem;line-height:1}.hero h1{max-width:8.5ch}.hero-line{font-size:1.35rem}.hero-intro{font-size:1rem}.hero-actions,.page-hero-actions{align-items:stretch}.button{width:100%}.portrait-frame{height:340px;min-height:300px;max-height:340px}.portrait-frame img{height:100%;max-height:340px}.hero-focus{display:none}.content-section{padding:4.4rem 0}.page-hero{padding:4.2rem 0 2.8rem}.section-heading h2,.contact-band h2{font-size:2.3rem}.featured-grid,.discipline-grid,.portfolio-grid,.track-details,.about-index{grid-template-columns:1fr}.feature-card,.discipline-card,.portfolio-card,.track-preview,.about-index div{min-height:auto}.track-button{min-height:74px}.section-jump{top:68px;width:100%;padding-right:16px;padding-left:16px}.lead{font-size:1.42rem}.contact-band,.site-footer{display:grid}.footer-links{justify-content:flex-start}}@media (max-width: 600px){.nav-shell,.content-section,.page-hero,.section-jump,.site-footer{width:342px;max-width:342px;margin-right:auto;margin-left:16px}.nav-shell{padding-right:0;padding-left:0}.hero-grid,.hero-copy,.hero-portrait{width:342px;max-width:342px;margin-right:auto;margin-left:0}.hero h1,.page-hero h1{font-size:2.45rem}.hero-line{font-size:1.22rem}.track-button{grid-template-columns:2rem minmax(0,1fr)}.track-index{width:1.9rem;height:1.9rem}}@media (max-width: 360px){.nav-shell,.content-section,.page-hero,.section-jump,.site-footer,.hero-grid,.hero-copy,.hero-portrait{width:288px;max-width:288px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.hero-portrait,.reveal{opacity:1;clip-path:none;transform:none}}
