@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--ink:#0a1726;--ink-2:#0f2336;--paper:#f4f7f9;--white:#fff;--slate:#5b6c7b;--slate-2:#8a99a6;--line:#0a17261f;--line-soft:#0a172612;--signal:#00b8c4;--signal-deep:#06808a;--on-dark-line:#ffffff1f;--on-dark-dim:#ffffff8c;--font-display:"Space Grotesk", sans-serif;--font-body:"IBM Plex Sans", system-ui, sans-serif;--font-mono:"IBM Plex Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:hidden}button{cursor:pointer;font-family:inherit}img{max-width:100%;display:block}.wrap{max-width:1120px;margin:0 auto;padding:0 28px}.mono{font-family:var(--font-mono)}.display{font-family:var(--font-display)}.app-shell{min-height:100vh;position:relative}.app-content{z-index:1;position:relative}.page{animation:.45s cubic-bezier(.2,.7,.2,1) both rise}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.page{animation:none}*{transition:none!important}}.nav{z-index:50;-webkit-backdrop-filter:saturate(140%)blur(12px);backdrop-filter:saturate(140%)blur(12px);border-bottom:1px solid var(--line);background:#f4f7f9d9;position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;height:62px;display:flex}.mark{background:0 0;border:none;align-items:center;gap:11px;display:flex}.mark-glyph{border:1.5px solid var(--ink);border-radius:3px;place-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:grid;position:relative}.mark-glyph:after{content:"";background:var(--signal);width:6px;height:6px;position:absolute;top:-1.5px;right:-1.5px}.mark-text{text-align:left}.mark-name{letter-spacing:-.01em;color:var(--ink);font-size:15px;font-weight:600;display:block}.mark-role{color:var(--slate);letter-spacing:.08em;text-transform:uppercase;font-size:10px}.navlinks{gap:4px;display:flex}.navlink{letter-spacing:.06em;text-transform:uppercase;color:var(--slate);background:0 0;border:none;border-radius:4px;padding:8px 13px;font-size:12px;transition:color .18s,background .18s}.navlink:hover{color:var(--ink);background:#0a17260a}.navlink.active{color:var(--ink)}.navlink.active:before{content:"";background:var(--signal);vertical-align:middle;width:5px;height:5px;margin-right:7px;display:inline-block}@media (width<=600px){.mark-role{display:none}.navlink{padding:8px 9px}}.dot-field{z-index:0;pointer-events:none;position:fixed;inset:0}.dot-field--scoped{z-index:0;width:100%;height:100%;position:absolute;inset:0}.wip-banner{background:linear-gradient(90deg,#fef3c7 0%,#fffbeb 45%,#fef3c7 100%);border-bottom:1px solid #d9770659;position:relative;overflow:hidden}.wip-banner:before{content:"";pointer-events:none;background:linear-gradient(105deg,#0000 38%,#ffffff8c 50%,#0000 62%) 0 0/200% 100%;animation:4.5s ease-in-out infinite wip-shimmer;position:absolute;inset:0}@keyframes wip-shimmer{0%,to{background-position:100% 0}50%{background-position:-100% 0}}.wip-banner-inner{z-index:1;flex-wrap:wrap;align-items:center;gap:16px;padding:12px 28px;display:flex;position:relative}.wip-badge{letter-spacing:.12em;text-transform:uppercase;color:#92400e;background:#f59e0b38;border:1px solid #d9770673;border-radius:3px;flex-shrink:0;padding:5px 9px;font-size:10px;font-weight:500}.wip-copy{color:#78350f;font-size:13px;line-height:1.45}@media (prefers-reduced-motion:reduce){.wip-banner:before{animation:none}}.hero{background:var(--ink);color:#fff;border-bottom:1px solid var(--ink);position:relative;overflow:hidden}.hero-grid{background-image:linear-gradient(var(--on-dark-line) 1px, transparent 1px), linear-gradient(90deg, var(--on-dark-line) 1px, transparent 1px);opacity:.5;background-size:46px 46px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 70% at 70% 30%,#000 30%,#0000 75%);mask-image:radial-gradient(80% 70% at 70% 30%,#000 30%,#0000 75%)}.hero-inner{z-index:1;padding:74px 28px 0;position:relative}.eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--signal);align-items:center;gap:11px;margin-bottom:26px;font-size:11.5px;display:flex}.eyebrow:before{content:"";background:var(--signal);width:34px;height:1px}.h1{letter-spacing:-.03em;margin-bottom:24px;font-size:clamp(52px,9vw,108px);font-weight:700;line-height:.92}.h1 em{color:var(--signal);font-style:normal}.lede{color:#ffffffc7;max-width:560px;margin-bottom:54px;font-size:18px;line-height:1.62}.lede strong{color:#fff;font-weight:500}.readout{border-top:1px solid var(--on-dark-line);grid-template-columns:repeat(4,1fr);display:grid}.cell{border-right:1px solid var(--on-dark-line);padding:22px 18px 30px 0}.cell:last-child{border-right:none}.cell-label{letter-spacing:.12em;text-transform:uppercase;color:var(--on-dark-dim);align-items:center;gap:6px;margin-bottom:12px;font-size:10px;display:flex}.cell-label:before{content:"";background:var(--signal);border-radius:50%;width:4px;height:4px}.cell-num{letter-spacing:-.02em;color:#fff;font-size:34px;font-weight:500;line-height:1}.cell-unit{color:var(--on-dark-dim);margin-left:3px;font-size:14px}.cell-sub{color:var(--on-dark-dim);margin-top:8px;font-size:11px}.sec{padding:78px 0}.sec-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:20px;margin-bottom:38px;display:flex}.kicker{letter-spacing:.14em;text-transform:uppercase;color:var(--slate);align-items:center;gap:10px;margin-bottom:12px;font-size:11px;display:flex}.kicker b{color:var(--signal-deep);font-weight:500}.h2{letter-spacing:-.02em;font-size:clamp(28px,4vw,40px);font-weight:600;line-height:1.05}.sec-note{color:var(--slate);text-align:right;max-width:300px;font-size:14px}.proj-list{background:var(--line-soft);border:1px solid var(--line);border-radius:8px;flex-direction:column;gap:2px;display:flex;overflow:hidden}.proj-row{background:var(--white);text-align:left;width:100%;color:var(--ink);border:none;grid-template-columns:54px 1.4fr 1fr auto;align-items:center;gap:24px;padding:26px 28px;transition:background .18s;display:grid}.proj-row:hover{background:#fbfdfe}.proj-idx{color:var(--slate-2);font-size:13px}.proj-title{letter-spacing:-.01em;margin-bottom:5px;font-size:20px;font-weight:600;display:block}.proj-desc{color:var(--slate);font-size:14px;line-height:1.45}.proj-tags{flex-wrap:wrap;gap:6px;display:flex}.arrow{color:var(--slate-2);font-size:18px;transition:transform .18s,color .18s}.proj-row:hover .arrow{color:var(--signal-deep);transform:translate(4px)}.caps-grid{background:var(--line);border:1px solid var(--line);border-radius:8px;grid-template-columns:repeat(3,1fr);gap:1px;margin-bottom:40px;display:grid;overflow:hidden}.cap{background:var(--white);padding:30px 26px}.cap-n{color:var(--signal-deep);letter-spacing:.08em;margin-bottom:16px;font-size:11px}.cap-t{letter-spacing:-.01em;margin-bottom:9px;font-size:18px;font-weight:600}.cap-d{color:var(--slate);font-size:14px;line-height:1.55}.band{background:var(--ink);color:#fff;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:30px;padding:54px 48px;display:flex}.band h3{letter-spacing:-.02em;max-width:480px;font-size:clamp(24px,3.5vw,34px);font-weight:600;line-height:1.1}.btn{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;background:var(--signal);color:var(--ink);border:none;border-radius:5px;align-items:center;gap:10px;padding:15px 26px;font-size:13px;font-weight:500;transition:transform .15s,background .15s;display:inline-flex}.btn:hover{background:#fff;transform:translateY(-1px)}.btn.ghost{color:#fff;border:1px solid var(--on-dark-line);background:0 0}.btn.ghost:hover{color:#fff;background:#ffffff0f}@media (width<=820px){.readout{grid-template-columns:repeat(2,1fr)}.cell:nth-child(2){border-right:none}.caps-grid{grid-template-columns:1fr}.proj-row{grid-template-columns:30px 1fr auto}.proj-tags,.sec-note{display:none}.band{padding:36px 28px}}.work-sec{padding:64px 0 80px}.work-kicker{letter-spacing:.14em;text-transform:uppercase;color:var(--slate);align-items:center;gap:10px;margin-bottom:14px;font-size:11px;display:flex}.work-kicker b{color:var(--signal-deep)}.work-h{letter-spacing:-.02em;margin-bottom:10px;font-size:clamp(28px,4vw,40px);font-weight:600}.work-sub{color:var(--slate);max-width:520px;margin-bottom:48px;font-size:16px}.work-grid{background:var(--line);border:1px solid var(--line);border-radius:8px;grid-template-columns:repeat(2,1fr);gap:2px;display:grid;overflow:hidden}.work-card{background:var(--white);text-align:left;color:var(--ink);border:none;flex-direction:column;transition:background .18s;display:flex}.work-card:hover{background:#f9fcfd}.card-img-wrap{aspect-ratio:16/9;background:var(--ink);width:100%;overflow:hidden}.card-img{object-fit:cover;width:100%;height:100%}.card-img-placeholder{background:var(--ink);width:100%;height:100%;color:var(--on-dark-dim);letter-spacing:-.02em;place-items:center;font-size:32px;display:grid}.card-body{flex:1;padding:24px 24px 16px}.card-meta{gap:6px;margin-bottom:14px;display:flex}.card-title{letter-spacing:-.01em;margin-bottom:8px;font-size:22px;font-weight:600}.card-desc{color:var(--slate);margin-bottom:16px;font-size:14px;line-height:1.5}.card-tags{flex-wrap:wrap;gap:6px;display:flex}.card-footer{border-top:1px solid var(--line-soft);letter-spacing:.06em;text-transform:uppercase;color:var(--slate);align-items:center;gap:8px;padding:14px 24px;font-size:12px;transition:color .18s;display:flex}.work-card:hover .card-footer{color:var(--signal-deep)}.card-arrow{transition:transform .18s}.work-card:hover .card-arrow{transform:translate(4px)}@media (width<=700px){.work-grid{grid-template-columns:1fr}}.about-sec{padding:64px 0 80px}.about-kicker{letter-spacing:.14em;text-transform:uppercase;color:var(--slate);align-items:center;gap:10px;margin-bottom:32px;font-size:11px;display:flex}.about-kicker b{color:var(--signal-deep)}.about-grid{grid-template-columns:1.5fr 1fr;align-items:start;gap:60px;margin-bottom:54px;display:grid}.bio p{color:var(--slate);margin-bottom:20px;font-size:17px;line-height:1.7}.bio p:first-child{color:var(--ink)}.side-block{margin-bottom:32px}.side-label{letter-spacing:.12em;text-transform:uppercase;color:var(--slate);border-bottom:1px solid var(--line);margin-bottom:14px;padding-bottom:10px;font-size:11px}.side-row{border-bottom:1px solid var(--line-soft);justify-content:space-between;gap:14px;padding:7px 0;font-size:14px;display:flex}.side-row span:last-child{color:var(--slate);font-size:12px}.pills{flex-wrap:wrap;gap:7px;display:flex}.tag{letter-spacing:.04em;text-transform:uppercase;color:var(--slate);border:1px solid var(--line);border-radius:3px;padding:4px 8px;font-size:10.5px}.about-band{background:var(--ink);color:#fff;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:30px;padding:54px 48px;display:flex}.about-band h3{letter-spacing:-.02em;max-width:480px;font-size:clamp(24px,3.5vw,34px);font-weight:600;line-height:1.1}.about-btn{letter-spacing:.06em;text-transform:uppercase;background:var(--signal);color:var(--ink);border:none;border-radius:5px;padding:15px 26px;font-size:13px;font-weight:500;transition:transform .15s,background .15s}.about-btn:hover{background:#fff;transform:translateY(-1px)}@media (width<=820px){.about-grid{grid-template-columns:1fr;gap:40px}.about-band{padding:36px 28px}}.contact-sec{min-height:65vh;padding:90px 0}.contact-kicker{letter-spacing:.14em;text-transform:uppercase;color:var(--slate);align-items:center;gap:10px;margin-bottom:28px;font-size:11px;display:flex}.contact-kicker b{color:var(--signal-deep)}.contact-h{letter-spacing:-.03em;margin-bottom:22px;font-size:clamp(40px,7vw,78px);font-weight:700;line-height:.96}.contact-h em{color:var(--signal-deep);font-style:normal}.contact-sub{color:var(--slate);max-width:480px;margin-bottom:52px;font-size:18px}.contact-links{border-top:1px solid var(--line);flex-direction:column;display:flex}.clink{color:var(--ink);border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:22px 4px;text-decoration:none;transition:padding .2s,background .2s;display:flex}.clink:hover{background:var(--white);padding-left:16px}.clink--soon{cursor:default;color:var(--slate)}.clink--soon .clink-value{color:var(--slate-2);font-size:16px;font-weight:400}.clink-label{letter-spacing:.1em;text-transform:uppercase;color:var(--slate);font-size:11px}.clink-value{font-size:19px;font-weight:500}.detail-hero{background:var(--ink);color:#fff;padding:66px 0 58px}.back{color:var(--on-dark-dim);letter-spacing:.06em;text-transform:uppercase;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:30px;font-size:12px;transition:color .16s;display:inline-flex}.back:hover{color:#fff}.detail-h{letter-spacing:-.025em;margin-bottom:18px;font-size:clamp(34px,6vw,60px);font-weight:700;line-height:1}.detail-lede{color:#ffffffc7;max-width:600px;font-size:18px;line-height:1.6}.detail-meta{flex-wrap:wrap;gap:42px;margin-top:40px;display:flex}.meta-k{letter-spacing:.1em;text-transform:uppercase;color:var(--on-dark-dim);margin-bottom:7px;font-size:10px}.meta-v{color:#fff;font-size:15px}.detail-cover{border:1px solid var(--line);border-radius:10px;margin:42px 0;overflow:hidden}.detail-cover img{width:100%;display:block}.detail-body{grid-template-columns:1fr 1fr;gap:38px;padding-bottom:30px;display:grid}.detail-block h4{margin-bottom:11px;font-size:16px;font-weight:600}.detail-block p{color:var(--slate);font-size:15px;line-height:1.65}.detail-band{background:var(--ink);color:#fff;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:30px;padding:54px 48px;display:flex}.detail-band h3{letter-spacing:-.02em;max-width:480px;font-size:clamp(24px,3.5vw,34px);font-weight:600;line-height:1.1}.detail-btn{letter-spacing:.06em;text-transform:uppercase;background:var(--signal);color:var(--ink);border:none;border-radius:5px;padding:15px 26px;font-size:13px;font-weight:500;transition:transform .15s,background .15s}.detail-btn:hover{background:#fff;transform:translateY(-1px)}.detail-btn.ghost{color:#fff;border:1px solid var(--on-dark-line);background:0 0}.detail-btn.ghost:hover{color:#fff;background:#ffffff0f}@media (width<=820px){.detail-body{grid-template-columns:1fr}.detail-band{padding:36px 28px}}
