:root{color-scheme:dark;--homeBase:#2e3944;--homeFade:#60a5fa;--portfolioBase:#124e66;--portfolioFade:#60a5fa;--historyBase:#d3d9d4;--historyFade:#748d92;--contactBase:#748d92;--contactFade:#2e3944;--navBG:rgba(46, 57, 68, .8);--ink:#f7fbff;--muted:rgba(247,251,255,.68);--deep:#1f2b34;--blue:#62aaf7;--cyan:#82d9e8;--shadow:0 28px 70px rgba(0,0,0,.26);--portrait-shadow-x:0px;--portrait-shadow-y:0px;font-family:Montserrat,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;scroll-behavior:smooth}*{box-sizing:border-box}html{min-height:100%;background:var(--homeBase)}body{margin:0;min-height:100%;min-width:320px;background:transparent;color:var(--ink);position:relative}body:before{background:linear-gradient(to top left,var(--homeFade) 0%,var(--homeBase) 50%);content:"";inset:0;pointer-events:none;position:fixed;z-index:0}html[data-tone=portfolio] body:before{background:linear-gradient(to top left,var(--portfolioFade) 0%,var(--portfolioBase) 50%)}html[data-tone=history] body:before{background:linear-gradient(to top left,var(--historyFade) 0%,var(--historyBase) 50%)}html[data-tone=contact] body:before{background:linear-gradient(to top left,var(--contactFade) 0%,var(--contactBase) 50%)}body>*{position:relative;z-index:1}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}.site-header{align-items:center;display:flex;justify-content:space-between;left:0;padding:28px clamp(22px,5vw,58px);position:fixed;right:0;top:0;z-index:30}.brand-mark{align-items:center;border:1px solid color-mix(in srgb,currentColor 42%,transparent);color:var(--brand-contrast,#fff);display:inline-flex;font-weight:800;height:44px;justify-content:center;transition:border-color .18s ease,color .18s ease;width:44px;z-index:50}html.menu-open .brand-mark{color:#fff}.menu-button{align-items:center;background:transparent;border:0;cursor:pointer;display:block;height:44px;padding:0;position:relative;width:50px;z-index:31}.menu-button span{background:#fff;border-radius:999px;box-shadow:0 1px 10px #00000047;display:block;height:5px;left:50%;position:absolute;top:50%;transform-origin:center;transition:opacity .18s ease,transform .18s ease,width .18s ease;transform:translate(-50%,-50%);width:40px}.menu-button span:first-child{transform:translate(-50%,calc(-50% - 12px))}.menu-button span:last-child{transform:translate(-50%,calc(-50% + 12px))}.menu-button.open span:first-child{transform:translate(-50%,-50%) rotate(45deg)}.menu-button.open span:nth-child(2){opacity:0;width:0}.menu-button.open span:last-child{transform:translate(-50%,-50%) rotate(-45deg)}.menu-overlay{backdrop-filter:blur(5px);background:var(--navBG);height:100dvh;inset:0;opacity:0;pointer-events:none;position:fixed;transition:opacity .24s ease;width:100vw;z-index:20}.menu-overlay.open{opacity:1;pointer-events:auto}.menu-panel{display:grid;gap:10px;left:clamp(26px,6vw,120px);position:absolute;top:30vh}.menu-panel a{font-size:clamp(2rem,4vw,3.2rem);font-weight:800;line-height:1.08;transition:color .18s ease,transform .18s ease}.menu-panel a:hover,.menu-panel a.active{color:var(--cyan);transform:translate(10px)}.section-panel{min-height:100vh;padding:clamp(110px,13vh,150px) clamp(24px,6vw,120px) clamp(54px,8vh,96px);position:relative}.hero{align-items:stretch;display:grid;gap:clamp(30px,5vw,70px);grid-template-columns:minmax(290px,.86fr) minmax(360px,1.14fr);min-height:100vh;overflow:hidden;padding-bottom:0;padding-top:0}.hero-copy{align-self:stretch;display:flex;flex-direction:column;justify-content:center;justify-content:safe center;padding-top:clamp(96px,11vh,126px);z-index:5}.eyebrow{color:var(--blue)!important;font-size:clamp(1.55rem,3vw,2.7rem);font-weight:300!important;margin:0 0 10px}h1,h2,h3,p{margin-top:0;font-weight:500}h1{font-size:clamp(2.5rem,6vw,3rem);line-height:1.04;margin-bottom:12px;font-weight:700}p{font-weight:500}.hero-copy h2,.history-heading h2{color:#ffffffa6;font-size:clamp(2rem,4.2vw,2.8rem);line-height:1.08;margin-bottom:12px}.hero-copy p,.section-intro p,.contact-list,.timeline p,.project-description{color:var(--muted);font-size:clamp(1rem,1.45vw,1.42rem);line-height:1.34}.hero-copy p{max-width:700px}.button-row,.form-actions{display:flex;flex-wrap:wrap;gap:28px;margin-top:34px}.button{align-items:center;border:2px solid var(--blue);display:inline-flex;font-size:1.05rem;font-weight:800;justify-content:center;min-height:54px;min-width:170px;padding:0 26px;transition:background .18s ease,color .18s ease,transform .18s ease}.button:hover{transform:translateY(-2px)}.button-fill{background:var(--blue);color:#172536}.button-outline{background:#14202838}.hero-portrait{align-self:stretch;min-height:calc(100vh - clamp(110px,13vh,150px));position:relative;z-index:1}.diamond-art{bottom:-68px;height:min(100vh,1400px);max-width:none;object-fit:cover;position:absolute;right:-105px;width:min(78vw,1325px);overflow:visible;z-index:1}.robert-photo,.robert-shadow{bottom:0;max-height:min(80vh,830px);max-width:52vw;position:absolute;right:0;transform-origin:bottom center}.robert-photo{filter:drop-shadow(0 24px 34px rgba(0,0,0,.18));z-index:2}.robert-shadow{right:clamp(-50px,4vw,-75px);transform:translate(var(--portrait-shadow-x),var(--portrait-shadow-y));transition:transform .12s ease-out;z-index:1}.portfolio{display:block}.section-intro{max-width:100%;padding-bottom:clamp(42px,8vh,88px)}.project-grid{display:block}.project-card{display:grid;gap:clamp(36px,5vw,78px);grid-template-columns:minmax(280px,.34fr) minmax(420px,.66fr);min-height:60vh;padding:clamp(72px,10vh,120px) 0;position:relative}astro-island:not(:last-child) .project-card{border-bottom:1px solid var(--blue)}.project-card+.project-card{border-top:1px solid rgba(255,255,255,.24)}.project-card-copy{align-self:start;padding-top:clamp(8px,2vh,24px);position:sticky;top:clamp(112px,15vh,150px);z-index:2}.project-card-copy .eyebrow{font-size:clamp(1.55rem,3vw,1.8rem)}.project-card h2{font-size:clamp(2.4rem,4.4vw,2rem);line-height:1.04;margin-bottom:16px}.project-card .eyebrow{margin-bottom:14px}.project-meta{display:flex;flex-wrap:wrap;gap:12px 28px;margin-bottom:24px}.project-meta p{color:#ffffffc7;font-size:clamp(.95rem,1.2vw,1.1rem);font-weight:700;line-height:1.2;margin:0;text-transform:none}.project-meta span{color:var(--blue);display:block;font-size:.78rem;font-weight:800;letter-spacing:0;margin-bottom:4px;text-transform:uppercase}.project-description{color:var(--muted);display:block;font-size:clamp(1.05rem,1.45vw,1.3rem);line-height:1.34;max-width:640px}.project-description :first-child{margin-top:0}.project-description :last-child{margin-bottom:0}.project-description p{margin:0 0 1rem}.project-description strong,.project-description b{color:#fff;font-weight:800}.project-description em{color:#ffffffdb}.project-description a{color:var(--blue);font-weight:700;text-decoration:underline;text-underline-offset:3px}.project-description ul,.project-description ol{display:grid;gap:.48rem;margin:1rem 0;padding-left:1.25rem}.project-description li::marker{color:var(--blue)}.project-description h3,.project-description h4{color:#fff;font-size:clamp(1.2rem,2vw,1.6rem);font-weight:800;margin:1.3rem 0 .6rem}.project-card .button{margin-top:clamp(36px,10vh,20px)}.project-card-media{align-self:start;perspective:1200px;position:sticky;top:clamp(112px,15vh,150px)}.project-card-media a,.project-card-media img{display:block}.project-card-media img{box-shadow:18px 24px 34px #00000038;margin-left:auto;max-width:min(100%,980px);transform:perspective(1200px) rotateY(-5deg) rotateX(1.5deg);transition:transform .18s ease-out;width:100%}.history{color:#26323c;display:block;min-height:140vh;position:relative}.history .eyebrow,.history-heading h1,.history-heading h2{color:#fff}.history-heading{left:clamp(24px,6vw,120px);position:sticky;top:100px;width:min(28vw,420px);z-index:4}.history-section-nav{display:grid;gap:14px}.history-section-nav a{color:#ffffffa3;display:block;font-size:clamp(1rem,2vw,3rem);font-weight:500;line-height:1.05;transition:color .18s ease,transform .18s ease}.history-section-nav a.active,.history-section-nav a:hover{color:#fff;font-weight:800;transform:translate(10px)}.history-content{margin-left:clamp(340px,34vw,560px);max-width:920px;position:relative;top:-100px}.history-section{scroll-margin-top:clamp(96px,12vh,130px)}.history-section-education{border-top:4px solid #233242;margin-top:clamp(48px,8vh,88px);padding-top:clamp(48px,8vh,88px)}.timeline{position:relative}.timeline:before{background:#233242;bottom:0;content:"";left:220px;position:absolute;top:10px;width:4px}.timeline-item{display:grid;gap:54px;grid-template-columns:180px minmax(0,1fr);padding-bottom:64px;position:relative}.timeline-item:before{background:#233242;border-radius:999px;content:"";height:14px;left:215px;position:absolute;top:10px;width:14px}.timeline time{color:#5b6670;font-size:clamp(1.7rem,3.3vw,2rem);font-weight:700;line-height:1.08;text-align:right}.timeline h3{color:#56616b;font-size:clamp(2rem,3.6vw,3rem);line-height:1.05;margin-bottom:18px}.timeline h4{color:#56616b;font-size:clamp(1.1rem,1.8vw,1.6rem);margin:0 0 4px}.timeline p{color:#56616b;max-width:780px}.contact{align-items:start;display:grid;gap:56px;grid-template-columns:minmax(280px,.36fr) minmax(520px,.64fr);min-height:100vh;place-content:center}.contact .eyebrow{color:#22313d}.contact-copy{align-self:start}.contact h1:after{background:currentColor;content:"";display:inline-block;height:.72em;margin-left:.22em;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='m12 5 7 7-7 7'/%3E%3C/svg%3E") center/contain no-repeat;vertical-align:-.04em;width:.72em}.contact-list{display:grid;gap:6px;margin-top:32px}.contact-list p{margin:0}.contact-form{align-self:start;display:grid;gap:18px}.contact-form label{display:grid}.contact-form label span{height:0;overflow:hidden}.contact-form input,.contact-form textarea{background:#25333c33;border:2px solid rgba(33,46,56,.34);color:#fff;min-height:66px;outline:0;padding:16px 24px;resize:vertical}.contact-form input:focus,.contact-form textarea:focus{border-color:#fff}.hp{display:none!important}.form-actions{justify-content:flex-end}@media(max-width:980px){.hero,.portfolio,.history,.contact{grid-template-columns:1fr}.hero-copy{align-self:auto;display:block;padding-top:0}.hero-portrait{clip-path:inset(-100vh -100vw 0 -100vw);min-height:48vh;order:-1}.hero-portrait:after{background:#4c5f72;bottom:0;content:"";height:1px;left:50%;position:absolute;transform:translate(-50%);width:100vw;z-index:3}.diamond-art{width:min(116vw,1720px);bottom:-248px}.robert-photo,.robert-shadow{max-width:54%}.history{display:block;padding-left:0;padding-right:0}.history-heading{backdrop-filter:blur(5px);box-shadow:0 8px 6px -6px #0000;left:0;margin-bottom:10px;padding:18px 36px;position:sticky;right:0;top:80px;transition:box-shadow .22s ease;width:auto;z-index:5}html.has-scrolled .history-heading{box-shadow:0 8px 6px -6px #0006}.history-heading .eyebrow{margin-bottom:8px}.history-section-nav{display:flex;flex-wrap:wrap;gap:16px}.history-section-nav a{font-size:clamp(1rem,7vw,2rem)}.history-content{margin-left:0;max-width:none;padding:0 18px;position:relative;top:auto}.timeline:before,.timeline-item:before{left:0}.timeline-item{gap:26px;grid-template-columns:1fr;padding-left:32px;position:relative}.timeline-item:before{left:-5px}.timeline time{text-align:left}.section-panel.history{padding-top:74px}.site-header.blured{backdrop-filter:blur(5px);transition:box-shadow .22s ease}html[data-tone=portfolio] .site-header.blured,html[data-tone=contact] .site-header.blured{box-shadow:0 8px 6px -6px #0000}html.has-scrolled[data-tone=portfolio] .site-header.blured,html.has-scrolled[data-tone=contact] .site-header.blured{box-shadow:0 8px 6px -6px #0006}.project-card{gap:34px;grid-template-columns:1fr;min-height:auto;padding:58px 0}.project-card-copy,.project-card-media{position:relative;top:auto}.project-card .button{margin-top:28px}.project-card-media img{max-width:100%;transform:perspective(1200px) rotateY(-3deg) rotateX(1deg)}.contact h1:after{transform:rotate(90deg)}}@media(max-width:640px){.site-header{padding:18px}.brand-mark{height:38px;width:38px}.menu-button{height:44px;width:44px}.menu-button span{height:5px;width:30px}.section-panel{min-height:auto;padding:92px 18px 54px}.section-panel.history{padding-left:0;padding-right:0}.history-content{top:auto}.history-heading{padding:14px 36px;top:74px}.hero-copy{position:relative;z-index:3}.hero-portrait{clip-path:inset(-100vh -100vw 0 -100vw);min-height:320px}.diamond-art{bottom:-133px;right:-5vw;width:110vw;height:686px}.robert-photo,.robert-shadow{max-height:320px;max-width:70%}.robert-shadow{right:-30px}.button{min-width:140px;width:100%}.button-row,.form-actions{gap:14px}.section-intro{padding-bottom:28px}.project-card{padding:42px 0}}
