:root{--bg: #ececec;--bg-soft: #f3f3f3;--text: #060606;--muted: #4e4e4e;--line: #d6d6d6;--surface: #ffffff;--shadow: 0 28px 70px rgba(0, 0, 0, .12)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}html{scroll-behavior:smooth}body{font-family:Space Grotesk,sans-serif;color:var(--text);background:var(--bg)}img{display:block;max-width:100%}.img-fallback{background:repeating-linear-gradient(135deg,#e5e5e5 0,#e5e5e5 14px,#ececec 14px,#ececec 28px);border:1px dashed #c8c8c8}.site{min-height:100vh}main{padding-top:42px}.top-nav{position:fixed;top:0;right:0;left:0;z-index:100;background:#050505;border-bottom:1px solid #111111}.top-nav-inner{width:min(1240px,calc(100% - 2rem));margin:0 auto;min-height:72px;display:flex;align-items:center;justify-content:space-between}.brand-button{border:0;background:transparent;color:#f3f3f3;font:inherit;font-size:clamp(1.05rem,1.4vw,1.85rem);letter-spacing:.01em;cursor:pointer;padding:0}.top-links{display:flex;gap:1.05rem}.top-links button{border:0;color:#d6d6d6;background:transparent;font:inherit;font-size:1.03rem;cursor:pointer;padding:.35rem .2rem;transition:color .18s ease,transform .18s ease}.top-links button:hover{color:#fff;transform:translateY(-1px)}.hero{min-height:calc(100vh - 72px);min-height:750px;background:radial-gradient(circle at 50% 20%,#f2f2f2 0%,transparent 55%),var(--bg);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}.hero-object{position:absolute;left:0;top:0;z-index:2;max-width:none;transform-origin:center;pointer-events:none;-webkit-user-select:none;user-select:none;will-change:transform;animation:float 8s ease-in-out infinite;transition:width .24s ease;filter:drop-shadow(0 16px 26px rgba(0,0,0,.08))}.hero .img-fallback.hero-object{border-radius:18px;opacity:.46}.hero-ring-item{position:absolute;z-index:5;pointer-events:none;animation:hero-circle-drift var(--drift-duration, 10s) ease-in-out infinite;animation-delay:var(--drift-delay, 0s);transition:left .26s ease,top .26s ease}.hero-title-wrap{position:absolute;z-index:9;left:50%;top:53%;transform:translate(-50%,-50%);width:min(1040px,calc(100% - 3rem));display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.15rem}.hero-title-wrap h1{margin:0;text-align:center;font-family:Syne,sans-serif;line-height:.89;font-size:clamp(3.95rem,10.2vw,8.8rem);letter-spacing:-.05em}.hero-title-wrap h1 span{display:block}.hero-left-lines,.hero-right-lines{margin:0;font-family:IBM Plex Mono,Space Mono,monospace;text-transform:uppercase;line-height:1.12;letter-spacing:.035em;font-size:clamp(.75rem,.95vw,1.02rem)}.hero-left-lines{text-align:right}.hero-right-lines{text-align:left}.brand-strip{position:absolute;right:0;bottom:0;left:0;z-index:7;min-height:98px;padding:1.05rem 0 .85rem;overflow:hidden;background:linear-gradient(to bottom,#ececec00,#ecececfa 35%)}.brand-track{width:max-content;display:flex;align-items:end;gap:clamp(1.2rem,3vw,3rem);animation:brand-marquee 22s linear infinite}.brand-track span{flex:0 0 auto;min-width:clamp(125px,12vw,210px);text-align:center;color:#636363;font-size:clamp(1.05rem,2.1vw,3rem);line-height:1;font-weight:700;letter-spacing:-.02em}.work-section,.about-section,.case-page,.resume-page{width:min(1140px,calc(100% - 2.2rem));margin:0 auto;padding:5.2rem 0}.section-top p{margin:0;text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;color:#7d7d7d}.section-top h2{margin:.5rem 0 0;font-family:Syne,sans-serif;letter-spacing:-.03em;font-size:clamp(2rem,4.8vw,4.2rem)}.filter-row{margin-top:1.35rem;display:flex;gap:.75rem;flex-wrap:wrap}.filter-row button{border:1px solid #c6c6c6;border-radius:999px;background:#f8f8f8;padding:.6rem 1.05rem;color:#1f1f1f;font:inherit;font-size:.9rem;cursor:pointer;transition:background .2s ease,color .2s ease,transform .2s ease}.filter-row button:hover{transform:translateY(-1px)}.filter-row .is-active{background:#121212;color:#f8f8f8;border-color:#121212}.project-grid{margin-top:1.4rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.project-card{border-radius:0;overflow:hidden;text-decoration:none;color:#f5f5f5;border:1px solid #d0d0d0;background:#101010;box-shadow:0 10px 26px #0000000d;transition:box-shadow .25s ease,border-color .25s ease;will-change:transform}.project-card:hover{border-color:#bcbcbc;box-shadow:var(--shadow)}.project-image-wrap{position:relative;aspect-ratio:16 / 10;overflow:hidden;background:#151515}.project-image-wrap img,.project-image-wrap .img-fallback{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;border:0}.project-card:hover .project-image-wrap img,.project-card:hover .project-image-wrap .img-fallback{transform:scale(1.035)}.project-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:space-between;padding:1.08rem;background:linear-gradient(to bottom,#0003,#00000024 32%,#000000ad);pointer-events:none}.project-tags{display:flex;flex-wrap:wrap;gap:.52rem}.project-tag{display:inline-flex;align-items:center;border-radius:999px;padding:.45rem .85rem;font-size:.8rem;line-height:1;letter-spacing:.02em;color:#101010;border:1px solid rgba(0,0,0,.16);background:#ffffffe6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.project-info{max-width:92%}.project-info h3{margin:0;color:#f7f7f7;letter-spacing:-.02em;line-height:1.14;font-size:clamp(1.45rem,2.45vw,2.2rem);text-wrap:balance}.project-cta{margin-top:.7rem;display:inline-flex;align-items:center;gap:.35rem;width:max-content;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#fff;padding:.44rem .8rem;border-radius:999px;border:1px solid rgba(255,255,255,.72);background:#000000b8}.project-card:hover .project-cta{color:#fff;background:#ffffff29;border-color:#fffc}.about-grid{margin-top:1.4rem;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:1.2rem}.about-grid img{width:100%;height:100%;min-height:380px;object-fit:cover;border-radius:24px;border:1px solid #cfcfcf}.about-grid .img-fallback{width:100%;min-height:380px;border-radius:24px}.about-grid p{margin:0;font-size:clamp(1rem,1.35vw,1.25rem);line-height:1.55}.about-grid p+p{margin-top:1rem}.about-actions{margin-top:1.55rem;display:flex;gap:.75rem;flex-wrap:wrap}.about-actions a{text-decoration:none;color:#f3f3f3;background:#111;padding:.7rem 1rem;border-radius:999px}.about-actions .secondary-action{color:#111;background:#f9f9f9;border:1px solid #c8c8c8}.contact-section{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);margin-top:1.8rem}.contact-ticker{background:#ff4e14;color:#fff6ef;overflow:hidden;border-top:1px solid #f13f04;border-bottom:1px solid #f13f04}.contact-ticker-track{width:max-content;display:flex;gap:2.2rem;padding:.52rem 0;animation:contact-marquee 20s linear infinite}.contact-ticker-track span{text-transform:uppercase;letter-spacing:.06em;font-size:clamp(.86rem,1vw,1.08rem);font-weight:700;white-space:nowrap}.contact-panel{background:#060606;color:#f3f3f3;padding:clamp(1.8rem,5vw,3.3rem) min(8vw,7rem) 1rem}.contact-kicker{margin:0;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:#a8a8a8}.contact-panel h2{margin:.55rem 0 0;font-family:Syne,sans-serif;font-size:clamp(2rem,6vw,4.5rem);line-height:1.02;letter-spacing:-.03em;max-width:16ch}.contact-copy{margin:1rem 0 0;max-width:58ch;color:#ccc;line-height:1.55}.contact-actions{margin-top:1.25rem;display:flex;gap:.72rem;flex-wrap:wrap}.contact-actions a{text-decoration:none;border-radius:999px;padding:.7rem 1rem;border:1px solid #f0f0f0;color:#f6f6f6}.contact-actions a:first-child{background:#f7f7f7;color:#121212}.contact-ball-field{margin-top:clamp(2rem,5vw,3.3rem);width:min(100%,820px);margin-inline:auto;display:flex;justify-content:center}.contact-spline{width:100%;height:clamp(170px,24vw,260px);display:grid;place-items:center;border-radius:22px;border:1px solid #2a2a2a;overflow:hidden;background:radial-gradient(circle at 50% 0,rgba(255,255,255,.06),transparent 60%),#0e0e0e}.contact-spline>div{width:100%;height:100%}.contact-spline canvas{width:100%!important;height:100%!important;display:block;object-fit:cover;object-position:center center;touch-action:none;pointer-events:auto}.contact-ball-canvas{width:100%;height:clamp(160px,22vw,248px);display:block;border-radius:22px;border:1px solid #2a2a2a;background:radial-gradient(circle at 50% 0,rgba(255,255,255,.06),transparent 60%),#0e0e0e;cursor:grab;touch-action:none}.contact-ball-canvas.is-dragging{cursor:grabbing}.contact-ball-hint{margin:.62rem 0 0;color:#9f9f9f;font-size:.83rem;letter-spacing:.04em;text-transform:uppercase}.site-footer{border-top:1px solid var(--line);padding:1rem 1.2rem;display:flex;align-items:center;justify-content:space-between;color:#6a6a6a;font-size:.84rem}.site-footer p{margin:0}.site-footer a{color:#181818;text-decoration:none;font-weight:600}.case-page h1,.resume-page h1{margin:0;font-family:Syne,sans-serif;letter-spacing:-.03em;line-height:1.06;font-size:clamp(2.15rem,5.2vw,5.1rem)}.back-pill{border:1px solid #c8c8c8;border-radius:999px;background:#f6f6f6;color:#141414;padding:.55rem 1rem;font:inherit;cursor:pointer}.case-meta{margin:1.15rem 0 .25rem;color:#6d6d6d;text-transform:uppercase;letter-spacing:.09em;font-size:.78rem}.case-summary{margin:1.15rem 0 0;max-width:75ch;line-height:1.5;font-size:clamp(1rem,1.4vw,1.25rem)}.unlock-form{margin-top:1.4rem;max-width:560px;border:1px solid #d0d0d0;border-radius:18px;padding:1rem;background:#f8f8f8;color:#171717}.unlock-form label{display:block;margin-bottom:.6rem;font-size:.84rem;text-transform:uppercase;letter-spacing:.08em;color:#5a5a5a}.unlock-row{display:flex;gap:.6rem}.unlock-row input{flex:1;min-width:0;border:1px solid #c5c5c5;border-radius:12px;padding:.7rem .8rem;font:inherit;color:#101010;background:#fff}.unlock-row input::placeholder{color:gray}.unlock-row input:focus{outline:2px solid #161616;outline-offset:1px}.unlock-row button{border:1px solid #101010;border-radius:12px;background:#101010;color:#f4f4f4;font:inherit;padding:.7rem 1rem;cursor:pointer}.unlock-error{margin:.7rem 0 0;color:#b02424;font-size:.88rem}.case-main-image{margin-top:1.8rem;border-radius:28px;overflow:hidden;border:1px solid #cfcfcf;box-shadow:var(--shadow)}.case-main-image img{width:100%;object-fit:cover}.case-main-image .img-fallback{width:100%;aspect-ratio:16 / 9;border:0}.case-columns{margin-top:2.1rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.case-columns section{border:1px solid #d2d2d2;border-radius:20px;padding:1rem;background:#f9f9f9}.case-columns h2,.impact-section h2,.resume-grid h2{margin:0;font-size:1.05rem}.case-columns p{margin:.65rem 0 0;line-height:1.5}.impact-section{margin-top:1.9rem}.impact-grid{margin-top:.75rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem}.impact-grid article{background:#131313;color:#f3f3f3;border-radius:15px;padding:.9rem;font-size:.95rem}.gallery-grid{margin-top:1.7rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.gallery-grid img{width:100%;border-radius:16px;border:1px solid #cccccc}.gallery-grid .img-fallback{width:100%;aspect-ratio:16 / 10;border-radius:16px}.next-case-link{margin-top:1.7rem;display:inline-flex;text-decoration:none;color:#f3f3f3;background:#111;border-radius:999px;padding:.7rem 1rem}.resume-kicker{margin:0;color:#676767;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem}.resume-summary{margin:1rem 0 0;max-width:68ch;line-height:1.5;font-size:clamp(1rem,1.2vw,1.25rem)}.resume-grid{margin-top:1.6rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem}.resume-grid article{background:#f8f8f8;border:1px solid #d0d0d0;border-radius:16px;padding:1rem}.resume-grid ul{margin:.8rem 0 0;padding-left:1.1rem;line-height:1.5}.resume-actions{margin-top:1.6rem;display:flex;gap:.7rem;flex-wrap:wrap}.resume-actions a{text-decoration:none;border-radius:999px;padding:.7rem 1rem;border:1px solid #cbcbcb;color:#101010}.resume-actions a:first-child{background:#101010;color:#f3f3f3;border-color:#101010}@keyframes hero-circle-drift{0%{transform:translate(var(--drift-size))}25%{transform:translateY(var(--drift-size))}50%{transform:translate(calc(var(--drift-size) * -1))}75%{transform:translateY(calc(var(--drift-size) * -1))}to{transform:translate(var(--drift-size))}}@keyframes float{0%,to{margin-top:0}50%{margin-top:-9px}}@keyframes brand-marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes contact-marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (prefers-reduced-motion: reduce){.hero-object,.hero-ring-item{transition:none}}@media (max-width: 920px){.hero{min-height:calc(100svh - 72px);min-height:680px}.hero-title-wrap{grid-template-columns:1fr;top:50%;text-align:center}.hero-left-lines,.hero-right-lines{text-align:center}.project-grid,.about-grid,.case-columns,.impact-grid,.resume-grid,.gallery-grid{grid-template-columns:1fr}.unlock-row{flex-direction:column}}@media (max-width: 700px){.top-nav-inner{width:calc(100% - 1.1rem);min-height:64px}.brand-button{font-size:.95rem;max-width:46%;text-align:left}.top-links{gap:.6rem}.top-links button{font-size:.89rem}main{padding-top:64px}.hero{min-height:max(700px,calc(100svh - 64px))}.hero-title-wrap{width:min(430px,calc(100% - 1.4rem));top:54%}.hero-title-wrap h1{font-size:clamp(3rem,16vw,5rem)}.hero-left-lines,.hero-right-lines{position:absolute;font-size:clamp(.62rem,2.3vw,.74rem);line-height:1.24;letter-spacing:.08em}.hero-right-lines{left:50%;top:-66px;transform:translate(-50%);text-align:center}.hero-left-lines{right:6%;bottom:-48px;text-align:left}.brand-strip{display:none}.brand-track{animation-duration:17s}.work-section,.about-section,.case-page,.resume-page{width:calc(100% - 1.2rem);padding:3.6rem 0}.project-image-wrap{aspect-ratio:4 / 3}.project-overlay{padding:.82rem}.project-tag{font-size:.72rem;padding:.38rem .66rem}.project-info{max-width:96%}.project-info h3{font-size:clamp(1.28rem,7.2vw,1.85rem)}.project-cta{margin-top:.58rem;font-size:.72rem;padding:.38rem .68rem}.contact-panel{padding:1.35rem .8rem .8rem}.contact-ball-canvas{height:164px}.contact-ball-field{width:100%}.contact-spline{height:clamp(150px,52vw,220px)}.contact-ball-hint{text-align:center}.site-footer{padding:.9rem .7rem}}
