@charset "UTF-8";*,*:before,*:after{box-sizing:border-box}*{margin:0}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeLegibility;line-height:1.5}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}@media (prefers-reduced-motion: reduce){html:focus-within{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--bg: #ffffff;--fg: #111111;--muted: #6c6c6c;--maxw: 980px;--pad: clamp(16px, 2.5vw, 32px);--gap: clamp(12px, 1.8vw, 20px);--font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, "Segoe UI", Roboto, system-ui, sans-serif}html,body,#root{height:100%;background:var(--bg);color:var(--fg)}body{font-family:var(--font);letter-spacing:.02em}a{color:inherit;text-decoration:none}.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}header.site{position:relative;padding:var(--pad) 0;border-bottom:1px solid rgba(0,0,0,.08)}.header-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px}.brand-group{display:flex;flex-direction:column}.brand{font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:clamp(18px,2.2vw,22px)}.tagline{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:2px}.nav-area{margin-left:auto;display:flex;align-items:center;gap:18px}.site-nav{display:flex;gap:18px;flex-wrap:wrap}.site-nav a{text-transform:lowercase;padding:2px 0;border-bottom:2px solid transparent}.site-nav a.active{border-color:currentColor}.nav-toggle{display:none;align-items:center;justify-content:center;gap:8px;padding:8px 10px;border:1px solid rgba(0,0,0,.1);border-radius:10px;background:var(--bg);color:var(--fg)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}@media (max-width: 760px){.nav-toggle{display:inline-flex}header.site .site-nav{display:none}header.site .site-nav.open{display:grid!important;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);color:var(--fg);z-index:60;place-content:center;gap:24px;text-align:center;transition:opacity .2s ease,transform .2s ease;opacity:1;transform:none}header.site .site-nav.open a{font-size:22px;font-weight:700;text-transform:lowercase}}main{padding:28px 0 48px}footer.site{border-top:1px solid rgba(0,0,0,.08);margin-top:48px;padding:18px 0;color:var(--muted);font-size:14px}footer.site a{text-decoration:underline}.hero{margin:10vh 0 8vh}.hero h1{font-size:clamp(40px,8vw,88px);line-height:.9;letter-spacing:.04em;text-transform:uppercase}.hero h2{margin-top:8px;font-weight:600;letter-spacing:.3em;font-size:clamp(10px,1.2vw,12px);text-transform:uppercase;color:var(--muted)}.grid{--cols: 3;display:grid;gap:var(--gap);grid-template-columns:repeat(var(--cols),1fr)}@media (max-width: 900px){.grid{--cols: 2}}@media (max-width: 520px){.grid{--cols: 1}}.card{border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:16px;background:var(--bg)}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}.tab{border:1px solid rgba(0,0,0,.1);background:var(--bg);color:var(--fg);padding:6px 10px;border-radius:999px;font-size:14px;text-transform:lowercase}.tab.active{background:var(--fg);color:var(--bg)}.tab .tab-count{margin-left:6px;opacity:.6;font-size:12px}.photo-tile{position:relative;aspect-ratio:1/1;overflow:hidden;border-radius:10px;border:1px solid rgba(0,0,0,.08);cursor:zoom-in}.photo-tile img{width:100%;height:100%;object-fit:cover;transition:transform .18s ease}.photo-tile:hover img{transform:scale(1.03)}.filters{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 12px}.chip{border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:6px 10px;font-size:12px;background:var(--bg)}.chip.active{background:var(--fg);color:var(--bg)}.badge{position:absolute;top:8px;left:8px;padding:3px 8px;font-size:11px;border-radius:999px;background:#000c;color:#fff;letter-spacing:.08em}.lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e0;display:grid;place-items:center;z-index:50}.lightbox-img{max-height:90vh;width:auto;height:auto;box-shadow:0 10px 40px #00000080}.lightbox-btn,.lightbox-close{position:absolute;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:999px;padding:10px 14px;font-size:20px;line-height:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lightbox-btn:hover,.lightbox-close:hover{background:#ffffff2e}.lightbox-btn.left{left:18px;top:50%;transform:translateY(-50%)}.lightbox-btn.right{right:18px;top:50%;transform:translateY(-50%)}.lightbox-close{right:12px;top:12px;font-size:22px;padding:8px 12px}.lightbox-counter{position:absolute;bottom:12px;left:50%;transform:translate(-50%);color:#fff;font-size:13px;letter-spacing:.08em;opacity:.9}.landing{min-height:72vh;display:grid;align-content:center;gap:18px;padding-top:clamp(12px,6vh,64px);padding-bottom:clamp(20px,8vh,88px);transition:opacity .35s ease}.landing.leave-out{opacity:0}.landing-hint-wrap{height:24vh;position:relative}.landing-hint{position:relative;bottom:clamp(16px,6vh,48px);left:0;display:grid;place-items:center;text-align:center;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);opacity:.9;pointer-events:none;padding-top:10vh}.typing-block{display:grid;gap:clamp(4px,1.2vw,10px);-webkit-user-select:none;user-select:none;transition:opacity .5s ease}.typing-block.fade-out{opacity:0}.typing-line{font-weight:800;letter-spacing:.02em;line-height:.92;font-size:clamp(28px,9vw,110px);overflow-wrap:anywhere}.cursor{opacity:0;margin-left:.06em;display:inline-block;transform:translateY(.04em)}.cursor.on{animation:blink 1s steps(2,start) infinite;opacity:1}@keyframes blink{50%{opacity:0}}.design-card{display:grid;grid-template-columns:1fr;gap:16px}.design-card.clickable{cursor:pointer;transition:box-shadow .16s ease,transform .16s ease,border-color .16s ease}.design-card.clickable:hover{box-shadow:0 6px 24px #00000014;transform:translateY(-1px)}.design-meta{display:grid;gap:10px;align-content:start}.design-title{font-weight:700;font-size:18px}.design-title-row{display:flex;gap:10px;align-items:baseline;flex-wrap:wrap}.view-hint{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.design-summary{color:var(--muted)}.chips{display:flex;gap:6px;flex-wrap:wrap}.chip{border:1px solid rgba(0,0,0,.12);border-radius:999px;padding:4px 8px;font-size:12px}.design-cover{border:1px solid rgba(0,0,0,.08);border-radius:10px;overflow:hidden;padding:0;background:none}.design-cover img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}.cover-placeholder{display:grid;place-items:center;aspect-ratio:4/3;color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#000000e0;display:grid;place-items:center;padding:16px}.modal-panel{background:var(--bg);color:var(--fg);width:min(100%,980px);max-height:90vh;border-radius:16px;overflow:hidden;display:grid;grid-template-rows:auto 1fr;box-shadow:0 20px 60px #0006;position:relative}.modal-close{position:absolute;right:10px;top:10px;background:#0000000a;border:1px solid rgba(0,0,0,.1);border-radius:999px;padding:6px 10px;font-size:20px;line-height:1}.modal-close:hover{background:#00000014}.modal-head{position:sticky;top:0;background:var(--bg);border-bottom:1px solid rgba(0,0,0,.08);padding:14px 16px;display:grid;gap:8px}.modal-title{font-weight:800;font-size:clamp(22px,2.4vw,30px);line-height:1.05}.modal-links{display:flex;flex-wrap:wrap;gap:12px}.modal-links a{text-decoration:underline}.modal-body{overflow:auto;padding:16px;display:grid;gap:16px}.modal-description{color:var(--fg);opacity:.9}.modal-section{display:grid;gap:12px}.section-title{font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:12px;color:var(--muted)}.modal-figure{display:grid;gap:8px}.modal-figure img{width:100%;height:auto;border-radius:12px;border:1px solid rgba(0,0,0,.08)}.modal-figure figcaption{color:var(--muted);font-size:12px}.video-stack{display:grid;gap:var(--gap)}.video-card{display:grid;gap:12px}.video-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#000}.video-embed iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0}.video-meta{display:grid;gap:6px}.video-title{font-weight:700;font-size:18px}.video-desc{color:var(--muted)}.about-skills{display:grid;gap:12px}.about-skills h3{margin-top:8px;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.code-grid{display:block;column-count:2;column-gap:var(--gap)}@media (max-width: 820px){.code-grid{column-count:1}}.code-card{display:inline-block;width:100%;break-inside:avoid;margin:0 0 var(--gap)}.code-cover{display:block;border:1px solid rgba(0,0,0,.08);border-radius:12px;overflow:hidden;aspect-ratio:16/9;background:#0a0a0a}.code-cover img,.code-cover iframe{width:100%;height:100%;object-fit:cover;display:block;border:0}.code-meta{display:grid;gap:8px}.code-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.code-title{font-weight:800;font-size:16px}.code-links{display:flex;gap:12px}.btn-link{text-decoration:underline;font-size:14px}.code-desc{color:var(--muted)}.code-stats{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
