@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;1,400&family=Inter:wght@300;400;500&display=swap";html{scroll-behavior:smooth}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f4f0;--text:#111;--muted:#888;--border:#1111111f;--border-strong:#111;background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.6}body{margin:0}#root{min-height:100svh}a{color:inherit;text-decoration:none}h1,h2,h3{color:var(--text);font-family:Playfair Display,Georgia,serif;font-weight:400;line-height:1.05}:root{--ease-out-quart:cubic-bezier(.25, 1, .5, 1);--ease-out-expo:cubic-bezier(.16, 1, .3, 1)}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes heroFadeIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.hero-enter{opacity:0;animation-duration:.7s;animation-fill-mode:both;animation-timing-function:var(--ease-out-expo);animation-name:heroFadeUp}.hero-enter--1{animation-delay:50ms}.hero-enter--2{animation-duration:.8s;animation-delay:.2s}.hero-enter--3{animation-delay:.38s}.hero-enter--4{animation-delay:.52s}.hero-enter--5{animation-name:heroFadeIn;animation-duration:.9s;animation-delay:.28s}.reveal{opacity:0;transition:opacity .65s var(--ease-out-quart), transform .65s var(--ease-out-quart);transform:translateY(20px)}.reveal--visible{opacity:1;transform:translateY(0)}.header{z-index:100;background:var(--bg);border-bottom:1px solid var(--border);position:fixed;top:0;left:0;right:0}.header-inner{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:0 56px;display:flex}.logo{letter-spacing:.18em;text-transform:uppercase;font-family:Inter,sans-serif;font-size:12px;font-weight:500}.nav{gap:40px;display:flex}.nav a{letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:400;transition:color .2s;position:relative}.nav a:after{content:"";background:var(--text);transform-origin:100%;width:100%;height:1px;transition:transform .25s var(--ease-out-quart);position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.nav a:hover{color:var(--text)}.nav a:hover:after{transform-origin:0;transform:scaleX(1)}.hero{grid-template-columns:1fr 1fr;align-items:center;gap:48px;max-width:1200px;min-height:100svh;margin:0 auto;padding:64px 56px 0;display:grid}.hero-content{padding:72px 0}.hero-label{letter-spacing:.2em;text-transform:uppercase;color:var(--muted);align-items:center;gap:14px;margin-bottom:28px;font-size:11px;font-weight:400;display:flex}.hero-label:before{content:"";background:var(--muted);flex-shrink:0;width:28px;height:1px;display:block}.cursor{color:var(--muted);margin-left:1px;font-weight:300;animation:.9s step-start infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-name{letter-spacing:-.02em;margin-bottom:28px;font-size:clamp(52px,5.5vw,80px)}.hero-bio{color:var(--muted);max-width:400px;margin-bottom:44px;font-size:15px;line-height:1.75}.hero-ctas{align-items:center;gap:14px;display:flex}.btn-primary{background:var(--text);color:var(--bg);letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--text);cursor:pointer;align-items:center;padding:13px 30px;font-family:Inter,sans-serif;font-size:11px;font-weight:500;transition:background .22s,color .22s;display:inline-flex}.btn-primary:hover{color:var(--text);background:0 0}.btn-primary:active{transition-duration:.1s;transform:scale(.97)}.btn-secondary{color:var(--text);letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--border-strong);cursor:pointer;background:0 0;align-items:center;padding:13px 30px;font-family:Inter,sans-serif;font-size:11px;font-weight:500;transition:background .22s,color .22s;display:inline-flex}.btn-secondary:hover{background:var(--text);color:var(--bg)}.btn-secondary:active{transition-duration:.1s;transform:scale(.97)}.hero-visual{justify-content:center;align-items:center;display:flex}.headshot-frame{position:relative}.headshot-frame:after{content:"";border:1px solid var(--border-strong);z-index:0;pointer-events:none;position:absolute;inset:14px -14px -14px 14px}.headshot{z-index:1;aspect-ratio:4/5;object-fit:cover;object-position:center top;filter:grayscale();width:100%;max-width:360px;display:block;position:relative}.about{border-top:1px solid var(--border)}.section-inner{max-width:1200px;margin:0 auto;padding:80px 56px}.section-header{border-bottom:1px solid var(--border);align-items:baseline;gap:20px;margin-bottom:64px;padding-bottom:24px;display:flex}.section-num{letter-spacing:.18em;color:var(--muted);font-size:11px;font-weight:400}.section-title{letter-spacing:-.01em;color:var(--text);margin:0;font-family:Playfair Display,serif;font-size:28px;font-weight:400}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.about-lead{color:var(--text);margin-bottom:24px;font-size:18px;font-weight:300;line-height:1.7}.about-body{color:var(--muted);margin-bottom:48px;font-size:15px;line-height:1.8}.about-edu{border-top:1px solid var(--border);flex-direction:column;gap:4px;padding-top:28px;display:flex}.about-edu-label{letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:10px;font-weight:500}.about-edu-value{color:var(--text);font-family:Playfair Display,serif;font-size:20px;font-weight:400}.about-edu-deg{color:var(--muted);letter-spacing:.02em;font-size:13px}.about-skills{flex-direction:column;gap:0;display:flex}.skill-group{border-bottom:1px solid var(--border);padding:20px 0}.skill-group:first-child{border-top:1px solid var(--border)}.skill-category{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;font-size:10px;font-weight:500;display:block}.skill-items{flex-wrap:wrap;gap:8px;display:flex}.skill-tag{letter-spacing:.04em;color:var(--text);border:1px solid var(--border);white-space:nowrap;will-change:clip-path;clip-path:inset(0 101% 0 0);background:0 0;padding:4px 12px;font-size:12px;font-weight:400;transition:clip-path .4s cubic-bezier(.4,0,.2,1)}.skill-tag--visible{clip-path:inset(0 0% 0 0)}.contact{border-top:1px solid var(--border)}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.contact-lead{color:var(--muted);margin-bottom:40px;font-size:16px;line-height:1.75}.contact-links{flex-direction:column;gap:0;display:flex}.contact-link{border-bottom:1px solid var(--border);flex-direction:column;gap:3px;padding:20px 0;transition:opacity .2s;display:flex}.contact-link:first-child{border-top:1px solid var(--border)}.contact-link:hover{opacity:.6}.contact-link-label{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:500}.contact-link-value{color:var(--text);letter-spacing:.01em;font-size:14px}.contact-form{flex-direction:column;gap:28px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-field{flex-direction:column;gap:8px;display:flex;position:relative}.form-field:after{content:"";background:var(--text);transform-origin:0;width:100%;height:1px;transition:transform .3s var(--ease-out-quart);pointer-events:none;position:absolute;bottom:0;left:0;transform:scaleX(0)}.form-field:focus-within:after{transform:scaleX(1)}.form-label{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:500}.form-input{border:none;border-bottom:1px solid var(--border);color:var(--text);-webkit-appearance:none;background:0 0;border-radius:0;outline:none;width:100%;padding:10px 0;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s}.form-input:focus{border-bottom-color:#0000}.form-input::placeholder{color:#0000}.form-textarea{resize:none;line-height:1.6}.form-footer{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.form-footer .btn-primary:disabled{opacity:.5;cursor:not-allowed}.form-footer .btn-primary:disabled:hover{background:var(--text);color:var(--bg)}.form-status{letter-spacing:.04em;font-size:12px}.form-status--success{color:var(--text)}.form-status--error{color:var(--text);text-underline-offset:3px;text-decoration:underline}.projects{border-top:1px solid var(--border)}.projects-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:48px;display:flex}.tab-btn{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;margin-right:36px;padding:12px 0;font-family:Inter,sans-serif;font-size:11px;font-weight:500;transition:color .2s,border-color .2s}.tab-btn:hover{color:var(--text)}.tab-btn--active{color:var(--text);border-bottom-color:var(--text)}.projects-grid{background:var(--border);border:1px solid var(--border);grid-template-columns:repeat(2,1fr);gap:1px;animation:.3s forwards fadeUp;display:grid}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.project-card{background:var(--bg);flex-direction:column;gap:16px;padding:36px;transition:background .2s;display:flex}.project-card:hover{background:#efefeb}.project-card-meta{justify-content:space-between;align-items:center;display:flex}.project-company{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:500}.project-year{letter-spacing:.1em;color:var(--muted);font-size:10px}.project-title{letter-spacing:-.01em;color:var(--text);margin:0;font-family:Playfair Display,serif;font-size:20px;font-weight:400;line-height:1.2}.project-desc{color:var(--muted);flex:1;font-size:13px;line-height:1.75}.project-tags{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.project-tag{letter-spacing:.04em;color:var(--text);border:1px solid var(--border);white-space:nowrap;background:0 0;padding:3px 10px;font-size:11px}@media (width<=900px){.hero{grid-template-columns:1fr;gap:32px;padding:64px 28px 0}.hero-visual{order:-1;padding-top:32px}.hero-content{padding:0 0 56px}.section-inner{padding:56px 28px}.about-grid{grid-template-columns:1fr;gap:48px}.projects-grid{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr;gap:48px}.form-row{grid-template-columns:1fr}}@media (width<=560px){.header-inner{padding:0 20px}.logo{font-size:0}.logo:after{content:"AS";letter-spacing:.18em;font-size:12px}.nav{gap:18px}.nav a{font-size:10px}.hero{gap:24px;padding:64px 20px 0}.hero-name{font-size:clamp(40px,11vw,52px)}.headshot{max-width:200px}.headshot-frame:after{display:none}.section-inner{padding:44px 20px}.section-header{margin-bottom:40px}.about-lead{font-size:16px}.project-card{padding:24px 20px}.hero-ctas{flex-direction:column;align-items:flex-start}.btn-primary,.btn-secondary{justify-content:center;width:100%}}.footer{border-top:1px solid var(--border);margin-top:auto}.footer-inner{grid-template-columns:1fr auto auto;align-items:center;gap:48px;max-width:1200px;margin:0 auto;padding:40px 56px;display:grid}.footer-name{letter-spacing:.18em;text-transform:uppercase;color:var(--text);font-size:12px;font-weight:500}.footer-nav{gap:32px;display:flex}.footer-nav a,.footer-links a{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:400;transition:color .2s;position:relative}.footer-nav a:after,.footer-links a:after{content:"";background:var(--text);transform-origin:100%;width:100%;height:1px;transition:transform .25s var(--ease-out-quart);position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.footer-nav a:hover,.footer-links a:hover{color:var(--text)}.footer-nav a:hover:after,.footer-links a:hover:after{transform-origin:0;transform:scaleX(1)}.footer-links{gap:32px;display:flex}.footer-bottom{border-top:1px solid var(--border);justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:16px 56px 32px;display:flex}.footer-bottom span{color:var(--muted);letter-spacing:.08em;font-size:11px}.back-to-top{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0;font-family:Inter,sans-serif;font-size:11px;transition:color .2s}.back-to-top:hover{color:var(--text)}@media (width<=900px){.footer-inner{grid-template-columns:1fr;gap:24px;padding:36px 28px}.footer-bottom{padding:16px 28px 28px}}@media (width<=560px){.footer-inner{padding:32px 20px}.footer-nav,.footer-links{gap:20px}.footer-bottom{padding:16px 20px 24px}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.hero-enter,.reveal,.skill-tag,.projects-grid,.nav a:after,.form-field:after{opacity:1!important;clip-path:none!important;transition:none!important;animation:none!important;transform:none!important}}
