:root{--pad: clamp(16px, 2.2vw, 32px);--gap: clamp(12px, 1.8vw, 22px);--bg: #ffffff;--fg: #000000;--muted: rgba(10, 10, 10, .62);--line: rgba(0, 0, 0, .14);--line-strong: rgba(0, 0, 0, .22);--panel: #ffffff;--soft: rgba(0, 0, 0, .04);--focus: #000;--invert-bg: #000;--invert-fg: #fff;--radius: 0px;--shadow: none;--font-sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}:root[data-theme=dark]{--bg: #000000;--fg: #ffffff;--muted: rgba(255, 255, 255, .62);--line: rgba(255, 255, 255, .16);--line-strong: rgba(255, 255, 255, .24);--panel: #000000;--soft: rgba(255, 255, 255, .06);--focus: #fff;--invert-bg: #fff;--invert-fg: #000}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}img,iframe{display:block;max-width:100%}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline;text-underline-offset:3px}:focus-visible{outline:2px solid var(--focus);outline-offset:3px}body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-kerning:normal;text-rendering:geometricPrecision;min-height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}main{flex:1;width:100%;padding:var(--pad);overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--pad) + var(--footerH, 96px) + env(safe-area-inset-bottom))}footer{width:100%}h1,h2,h3{margin:0;letter-spacing:-.03em}h1{font-size:clamp(30px,4.8vw,64px);line-height:.98}h2{font-size:16px;letter-spacing:.12em;text-transform:uppercase}p{margin:0;color:var(--muted)}.toTopArrow{position:fixed;right:var(--pad);bottom:calc(var(--footerH, 64px) + var(--pad) + env(safe-area-inset-bottom));z-index:99999;width:44px;height:44px;border-radius:999px;border:0;background:linear-gradient(#eaf7ff,#d6eeff);color:#0a0a0a;box-shadow:0 8px 24px #00000024;display:grid;place-items:center;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(6px);transition:opacity .14s linear,transform .14s linear,background .14s linear,color .14s linear}html[data-theme=dark] .toTopArrow{background:linear-gradient(#33204c,#21172f);color:#fffffff2;box-shadow:0 10px 28px #00000059}.toTopArrow.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.toTopArrow:hover{filter:contrast(1.08)}.toTopArrow.is-visible:hover{transform:translateY(-1px)}header{position:relative;top:0;z-index:30;width:100%;background:var(--bg);border-bottom:1px solid var(--line)}header nav{width:100%;padding:calc(var(--pad) * .65) var(--pad);display:grid;grid-template-columns:1fr auto;align-items:center;gap:var(--gap)}header nav>a{font-weight:700;letter-spacing:-.02em;font-size:16px;line-height:1}.themeToggle{appearance:none;border:1px solid var(--line);background:transparent;cursor:pointer;padding:0;border-radius:999px}.themeToggleTrack{width:52px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(#eaf7ff,#d6eeff)}.themeToggleThumb{width:24px;height:24px;border-radius:999px;background:var(--bg);border:1px solid var(--line);display:grid;place-items:center;position:relative;transform:translate(-10px);transition:transform .14s linear}.themeIcon{width:14px;height:14px;position:absolute}.themeIcon--sun{opacity:1;fill:#f6c945}.themeIcon--moon{opacity:0;fill:#f3e6a4}:root[data-theme=dark] .themeToggleTrack{background:linear-gradient(#33204c,#21172f)}:root[data-theme=dark] .themeToggleThumb{transform:translate(10px)}:root[data-theme=dark] .themeIcon--sun{opacity:0}:root[data-theme=dark] .themeIcon--moon{opacity:1}.themeToggle:hover .themeToggleTrack{filter:contrast(1.08)}body.home main{padding:0}body.home .homeSplit{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - var(--headerH, 64px) - var(--footerH, 64px))}body.home .homeHalf{position:relative;overflow:hidden;display:grid;align-content:end;padding:var(--pad);border-top:0}body.home .homeHalf--pro{border-right:1px solid var(--line)}body.home .homeHalfInner{max-width:56ch;position:relative;z-index:2}body.home .homeHalf h2{font-size:clamp(36px,6vw,84px);line-height:.96;letter-spacing:-.05em;text-transform:none;margin-bottom:10px;color:var(--fg)}body.home .homeHalf p{font-size:16px;line-height:1.35}body.home .homeHalf>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .12s linear;z-index:0}body.home .homeHalf:before{content:"";position:absolute;inset:0;background:transparent;transition:background .12s linear;z-index:1}body.home .homeHalf:hover>img,body.home .homeHalf:focus-visible>img{opacity:1}body.home .homeHalf:hover:before,body.home .homeHalf:focus-visible:before{background:#0009}body.home .homeHalf:hover h2,body.home .homeHalf:hover p,body.home .homeHalf:focus-visible h2,body.home .homeHalf:focus-visible p{color:#ffffffeb}body.home .homeHalf[data-armed=true]:before{background:#000000b3}body.home .homeHalf:hover h2,body.home .homeHalf:focus-visible h2{text-decoration:underline;text-decoration-color:currentColor;text-underline-offset:3px}body.home .homeHalf:hover,body.home .homeHalf:focus-visible{text-decoration:none}@media(max-width:900px){body.home .homeSplit{grid-template-columns:1fr}body.home .homeHalf--pro{border-right:0;border-bottom:1px solid var(--line)}}section[aria-label$="project grid"]>div{display:grid;gap:var(--gap);grid-template-columns:repeat(12,minmax(0,1fr));margin-top:var(--gap)}section[aria-label$="project grid"]>div>article{grid-column:span 4}@media(max-width:1100px){section[aria-label$="project grid"]>div>article{grid-column:span 6}}@media(max-width:650px){section[aria-label$="project grid"]>div>article{grid-column:span 12}}article{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--panel)}article:hover{border-color:var(--line-strong)}article>a{display:grid}article [data-hover-cycle]{aspect-ratio:4 / 3;background:var(--soft);border-bottom:1px solid var(--line)}article [data-hover-cycle] img{width:100%;height:100%;object-fit:cover}article>a>div:last-child{padding:14px 14px 16px;display:grid;gap:8px}article h3{font-size:16px;line-height:1.15;letter-spacing:-.02em;color:var(--fg)}article p{font-size:13px;color:var(--muted)}article p.summary{color:var(--muted);font-size:13.5px;line-height:1.35;display:-webkit-box;-webkit-box-orient:vertical;line-clamp:2;-webkit-line-clamp:2;overflow:hidden}article>a:hover{text-decoration:none}article>a:hover h3{text-decoration:underline;text-underline-offset:3px}main>article{width:100%;max-width:1100px;margin:0 auto}nav[aria-label="Project navigation"],section[aria-label="Project media"],main>article{border:0!important}nav[aria-label="Project navigation"]{padding:0;margin:0 0 18px;display:flex;gap:10px;flex-wrap:wrap}nav[aria-label="Project navigation"] a{border:1px solid var(--line);background:var(--bg);color:var(--fg);padding:10px 12px}nav[aria-label="Project navigation"] a:hover{background:var(--invert-bg);color:var(--invert-fg);border-color:var(--invert-bg);text-decoration:none}main>article>header{padding:18px 0;display:grid;gap:2px;border-top:1px solid var(--line)}main>article>header h1{margin:0;font-size:clamp(26px,3.4vw,46px);line-height:1.02;letter-spacing:-.03em}main>article>header p{margin:0;color:var(--muted);line-height:1.35}.projBlock{padding:18px 0;border-top:1px solid var(--line)}.mdGroup{padding:12px 0}.mdGroup+.mdGroup{border-top:1px solid var(--line)}.mdGroup>h2{margin:0 0 10px}.mdGroup>p{margin:0}.mdGroup>p+ul,.mdGroup>p+ol{margin-top:10px}.mdGroup>ul,.mdGroup>ol{margin:0}main>article{font-size:15px}main>article h2{text-transform:none;letter-spacing:-.02em;font-size:18px;line-height:1.15;margin:0;color:var(--fg)}main>article p,main>article li{font-size:1em;line-height:1.55;max-width:none}main>article p{margin:0}main>article p+p{margin-top:12px}main>article ul,main>article ol{margin:0;padding-left:1.5em}main>article li+li{margin-top:6px}section[aria-label="Project media"]{background:var(--bg)}.embed{width:100%;background:var(--bg)}.embed iframe{width:100%;height:auto;border:0;aspect-ratio:16 / 9;display:block}.mediaGrid img{width:100%;height:auto;border:0;display:block}.links{list-style:none;padding:0;margin:12px 0 0;display:flex;gap:10px;flex-wrap:nowrap;align-items:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch}.links li{margin:0;padding:0;flex:0 0 auto;display:flex;align-items:stretch}.links a{display:flex;align-items:center;height:40px;padding:0 12px;box-sizing:border-box;border:1px solid var(--line);background:var(--bg);color:var(--fg);line-height:1;white-space:nowrap}.links a{display:inline-flex;align-items:center;border:1px solid var(--line);background:var(--bg);color:var(--fg);padding:10px 12px;white-space:nowrap}.links a:hover{background:var(--invert-bg);color:var(--invert-fg);border-color:var(--invert-bg);text-decoration:none}.credits{display:grid;grid-template-columns:1fr 2fr;gap:8px 16px}.credits dt{font-weight:700;color:var(--fg)}.credits dd{margin:0;color:var(--muted)}.mediaGrid{display:grid;gap:var(--gap);grid-template-columns:repeat(12,minmax(0,1fr))}.mediaGrid figure{margin:0;grid-column:span 6}@media(max-width:900px){.mediaGrid figure{grid-column:span 12}}.mediaGrid img{width:100%;height:auto;border:1px solid var(--line);background:var(--panel)}footer{border-top:1px solid var(--line);background:var(--bg);position:fixed;left:0;right:0;bottom:0;z-index:50;padding:calc(var(--pad) * .75) var(--pad);padding-bottom:calc((var(--pad) * .75) + env(safe-area-inset-bottom))}footer nav[aria-label=Footer]{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.footerAbout{display:inline-block;padding:10px 0;font-weight:700;white-space:nowrap}.footerSocial{list-style:none;padding:0;margin:0;display:flex;align-items:center;gap:10px;flex-wrap:nowrap;justify-content:flex-end;max-width:65vw;overflow-x:auto;-webkit-overflow-scrolling:touch}.footerSocial li{flex:0 0 auto}.iconBtn{--brand1: var(--fg);--brand2: var(--fg);display:grid;place-items:center;width:40px;height:40px;border:0;background:transparent;border-radius:999px;color:color-mix(in oklab,var(--brand1) 80%,var(--fg));transition:background .14s linear,color .14s linear,filter .14s linear}.iconBtn svg{width:18px;height:18px;fill:currentColor}.iconBtn:hover{background:linear-gradient(var(--brand1),var(--brand2));color:var(--invert-fg);text-decoration:none}.iconBtn--instagram{--brand2: #f58529;--brand1: #dd2a7b}.iconBtn--linkedin{--brand1: #2097ff;--brand2: #256195}.iconBtn--email{--brand1: var(--fg);--brand2: var(--muted)}.footerBackToTop{margin:12px auto 0;display:block;border:0;background:transparent;color:var(--fg);font:inherit;font-weight:700;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.footerBackToTop:hover{color:var(--muted)}.aboutArticle .projectBody{max-width:none;width:100%}.projectBody .mdGroup h3{letter-spacing:0;text-transform:none;margin:0;font-weight:700}.projectBody .mdGroup:first-child{border-top:0}.projectBody .mdGroup h2{letter-spacing:0;text-transform:none;margin:0}.projectBody .mdGroup p{margin-top:10px}.projectBody .mdGroup ul{margin:10px 0 0;padding-left:18px}.projectBody .mdGroup li{margin:6px 0}
