@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/55c55f0601d81cf3-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/26a46d62cd723877-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/97e0cb1ae144a2a9-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/581909926a08bbc8-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/55c55f0601d81cf3-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/26a46d62cd723877-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/97e0cb1ae144a2a9-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/581909926a08bbc8-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/55c55f0601d81cf3-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/26a46d62cd723877-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/97e0cb1ae144a2a9-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/581909926a08bbc8-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter Fallback;src:local("Arial");ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.00%;size-adjust:107.12%}.__className_59aeca{font-family:Inter,Inter Fallback;font-style:normal}

/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden}.absolute,.sr-only{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.right-\[min\(12px\,_2vw\)\]{right:min(12px,2vw)}.bottom-\[min\(12px\,_2vw\)\]{bottom:min(12px,2vw)}.left-\[min\(12px\,_2vw\)\]{left:min(12px,2vw)}.isolate{isolation:isolate}.z-40{z-index:40}.z-50{z-index:50}.z-\[1\]{z-index:1}.container{width:100%}.mx-auto{margin-inline:auto}.box-border{box-sizing:border-box}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.size-full{width:100%;height:100%}.h-\[120px\]{height:120px}.h-\[calc\(100vh-8rem\)\]{height:calc(100vh - 8rem)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.max-h-\[95vh\]{max-height:95vh}.min-h-\[400px\]{min-height:400px}.min-h-\[500px\]{min-height:500px}.min-h-screen{min-height:100vh}.w-1\/2{width:50%}.w-\[calc\(100vw-2rem\)\]{width:calc(100vw - 2rem)}.w-full{width:100%}.max-w-\[40\%\]{max-width:40%}.max-w-\[80\%\]{max-width:80%}.max-w-\[644px\]{max-width:644px}.max-w-\[666px\]{max-width:666px}.max-w-\[685px\]{max-width:685px}.max-w-\[704px\]{max-width:704px}.max-w-none{max-width:none}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.content-stretch{align-content:stretch}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-\[10px\]{border-radius:10px}.rounded-\[20px\]{border-radius:20px}.rounded-\[min\(16px\,_3vw\)\]{border-radius:min(16px,3vw)}.rounded-\[min\(24px\,_3vw\)\]{border-radius:min(24px,3vw)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-none{--tw-border-style:none;border-style:none}.border-\[rgba\(0\,0\,0\,0\.07\)\]{border-color:#00000012}.bg-\[\#0A84FF\]{background-color:#0a84ff}.bg-\[\#1e1e1e\]{background-color:#1e1e1e}.bg-\[\#2d2d30\]{background-color:#2d2d30}.bg-\[\#FDFDFC\]{background-color:#fdfdfc}.bg-transparent{background-color:#0000}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-\[min\(16px\,_4vw\)\]{padding:min(16px,4vw)}.px-\[12px\]{padding-inline:12px}.px-\[16px\]{padding-inline:16px}.px-\[min\(12px\,_3vw\)\]{padding-inline:min(12px,3vw)}.px-\[min\(16px\,_4vw\)\]{padding-inline:min(16px,4vw)}.py-\[4px\]{padding-block:4px}.py-\[6px\]{padding-block:6px}.py-\[min\(10px\,_2\.5vw\)\]{padding-block:min(10px,2.5vw)}.pt-\[192px\]{padding-top:192px}.pr-\[16px\]{padding-right:16px}.pl-\[16px\]{padding-left:16px}.text-center{text-align:center}.text-left{text-align:left}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[15px\]{font-size:15px}.text-\[max\(16px\,_min\(15px\,_4vw\)\)\]{font-size:max(16px,min(15px,4vw))}.text-\[min\(13px\,_3\.5vw\)\]{font-size:min(13px,3.5vw)}.text-nowrap{text-wrap:nowrap}.break-words{overflow-wrap:break-word}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[\#82827C\]{color:#82827c}.text-\[rgb\(var\(--foreground\)\)\]{color:rgb(var(--foreground))}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.placeholder-\[\#979797\]::placeholder{color:#979797}.opacity-0{opacity:0}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.opacity-\[\.5\]{opacity:.5}.opacity-\[\.9\]{opacity:.9}.shadow-\[0px_10px_25px_-3px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:0px 10px 25px -3px var(--tw-shadow-color,#0000001a)}.ring,.shadow-\[0px_10px_25px_-3px_rgba\(0\,0\,0\,0\.1\)\]{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.outline-none{--tw-outline-style:none;outline-style:none}.placeholder\:text-\[\#979797\]::placeholder{color:#979797}.placeholder\:text-\[rgb\(var\(--foreground\)\)\]::placeholder{color:rgb(var(--foreground))}.placeholder\:opacity-50::placeholder{opacity:.5}.placeholder\:opacity-60::placeholder{opacity:.6}@media (hover:hover){.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:bg-\[rgb\(var\(--foreground\)\)\]:hover{background-color:rgb(var(--foreground))}.hover\:opacity-100:hover{opacity:1}}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}@media (prefers-color-scheme:dark){.dark\:bg-\[\#111110\]{background-color:#111110}.dark\:text-\[\#7C7B74\]{color:#7c7b74}}body,html{width:100%;height:100%;margin:0;padding:0;line-height:1.65}:root{--background:#fdfdfc;--foreground:33,32,28;--navbar-bg:#fffc;--navbar-border:#00000014;--hover-bg:#eeedeb;--project-title-color:#21201c;--project-desc-color:#63635e;--project-separator-date-color:#8f8f8f;--project-separator-border-color:#d4d4d4;--shadow-light:0 0 0 1px #00000014,0 2px 2px 0 #0000000a;--shadow-dark:0 0 0 1px #ffffff14,0 1px 2px 0 #00000014;--chat-title-bg:#eeedeb;--chat-border:#00000014;--chat-input-bg:#eeedeb;--chat-button-bg:#eeedeb;--chat-button-border:#00000014;--chat-button-text:#21201c;--chat-scanline:#0000000d}@media (prefers-color-scheme:dark){:root{--background:#111110;--foreground:238,238,236;--navbar-bg:#11111052;--navbar-border:#eeeeec14;--hover-bg:#ffffff14;--project-title-color:#eeeeec;--project-desc-color:#b5b3ad;--project-separator-date-color:#707070;--project-separator-border-color:#2e2e2e;--chat-title-bg:#1b1b1b;--chat-border:#ffffff1a;--chat-input-bg:#1e1e1e;--chat-button-bg:#000c;--chat-button-border:#fff3;--chat-button-text:white;--chat-scanline:#0009}}body{background-color:var(--background);line-height:1.65}body,h1,h2{color:rgb(var(--foreground));font-size:16px}h1,h2{font-weight:600;line-height:24px}h1{margin-top:0!important;margin-bottom:2rem!important}h2{margin-top:5rem!important;margin-bottom:1.25rem!important}.image-spacing{margin-bottom:0}.image-spacing,.prose+div[class*=mt-],section div[class*=mt-]{margin-top:2rem!important}.text-foreground{color:rgb(var(--foreground))}.bg-background{background-color:var(--background)}.text-highlight{color:rgb(var(--foreground));font-weight:500}.text-image-desc{font-size:12px;line-height:16px}.shadow-style{box-shadow:var(--shadow-light)}@media (prefers-color-scheme:dark){.shadow-style{box-shadow:var(--shadow-dark)}}.progressive-blur-gradient-top{background-image:linear-gradient(#fdfdfc,#0000)}.progressive-blur-gradient-bottom{background-image:linear-gradient(#0000,#fdfdfc)}@media (prefers-color-scheme:dark){.progressive-blur-gradient-top{background-image:linear-gradient(#111110,#0000)}.progressive-blur-gradient-bottom{background-image:linear-gradient(#0000,#111110)}}.prose p{color:rgb(var(--foreground));opacity:.9;margin-bottom:1.5rem;font-size:16px;line-height:1.75}.prose p:last-child{margin-bottom:0}.prose code{background-color:#0000000d;border-radius:.25rem;padding:.125rem .375rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875em;font-weight:500}@media (prefers-color-scheme:dark){.prose code{background-color:#ffffff1a}}.prose a{color:rgb(var(--foreground));text-decoration:underline;-webkit-text-decoration-color:rgba(var(--foreground),.3);text-decoration-color:rgba(var(--foreground),.3);text-underline-offset:.125rem;transition:text-decoration-color .15s}.prose a:hover{-webkit-text-decoration-color:rgba(var(--foreground),.7);text-decoration-color:rgba(var(--foreground),.7)}.prose strong{font-weight:600}.link-button,.prose strong{color:rgb(var(--foreground))}.link-button{align-items:center;gap:.5rem;margin-top:1.5rem;font-size:16px;font-weight:500;text-decoration:none;transition:opacity .15s;display:inline-flex}.link-button:hover{opacity:.7}.link-arrow{width:16px;height:16px;transition:transform .15s;display:inline-block}.link-button:hover .link-arrow{transform:translate(2px)}figure{margin:2.5rem 0}figure img{border-radius:12px;width:100%;height:auto;display:block}figure figcaption{text-align:center;color:rgb(var(--foreground));opacity:.6;margin-top:.75rem;font-size:14px;line-height:1.5}.sidebar-nav{z-index:100;position:fixed;top:130px;right:calc(50vw + 444px);margin-left:0!important;padding-left:0!important;padding-right:0!important}@media (max-width:1200px) and (min-width:981px){.sidebar-nav{top:130px;left:calc(50vw - 444px);right:unset;position:fixed}.anchor-list{display:none}}@media (max-width:980px){.sidebar-nav{max-width:644px;right:unset;top:unset;height:auto;min-height:0;display:block;position:static;margin-bottom:3rem!important;margin-left:auto!important;margin-right:auto!important;padding-left:0!important;padding-right:0!important}.sidebar-nav .back-button{margin-bottom:0}.anchor-list{display:none}}.back-button{color:rgb(var(--foreground));cursor:pointer;opacity:.7;white-space:nowrap;background:0 0;border:none;align-items:center;gap:.5rem;margin-bottom:2rem;padding:0;font-size:16px;font-weight:400;transition:opacity .25s cubic-bezier(.4,0,.2,1);display:inline-flex}.back-button:hover{opacity:1}@keyframes fillStroke{0%{stroke-dasharray:0 100}to{stroke-dasharray:100 0}}.back-arrow{stroke-dasharray:100 0;stroke-dashoffset:0;width:18px;height:18px;transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.back-button:hover .back-arrow{animation:fillStroke .25s cubic-bezier(.65,0,.35,1) forwards;transform:rotate(-15deg)}.anchor-list{flex-direction:column;align-items:flex-start;gap:.75rem;display:flex}.anchor-link{text-align:left;color:rgb(var(--foreground));cursor:pointer;opacity:.6;white-space:nowrap;background:0 0;border:none;padding:0;font-size:14px;font-weight:400;transition:opacity .25s cubic-bezier(.4,0,.2,1);position:relative}.anchor-link:hover{opacity:1}.project-page .content-width{max-width:520px;margin:0 auto}.project-page .sidebar-nav{right:calc(50vw + 382px)}.masonry-container{box-sizing:border-box;width:100%;max-width:100vw;padding:24px 24px 120px;overflow-x:hidden}.masonry-grid{column-count:3;box-sizing:border-box;column-gap:8px;width:100%;max-width:1400px;margin:0 auto}.masonry-item{break-inside:avoid;margin-bottom:8px}.masonry-content{border:1px solid var(--project-separator-border-color);background:var(--background);cursor:pointer;border-radius:8px;width:100%;transition:border-color .2s;position:relative;overflow:hidden}.masonry-content:is(:hover,:focus-visible){border-color:rgba(var(--foreground),.2)}.masonry-overlay{pointer-events:none;opacity:0;z-index:1;transition:opacity .2s;position:absolute;inset:0}.masonry-content:is(:hover,:focus-visible) .masonry-overlay{opacity:1}.bottom-blur{z-index:1;background:linear-gradient(#0000,#0000000d 40%,#0003 70%,#0006);position:absolute;inset:0}.masonry-info{z-index:2;justify-content:space-between;align-items:center;display:flex;position:absolute;bottom:0;left:16px;right:16px}.masonry-title{color:#fff;font-weight:600}.masonry-date,.masonry-title{font-size:14px;line-height:1.2}.masonry-date{color:#fffc}.masonry-content img,.masonry-content video{object-fit:cover;width:100%;height:100%;display:block}@media (max-width:1200px){.masonry-grid{column-count:3}.masonry-container{padding:20px}}@media (max-width:900px){.masonry-grid{column-count:2}.masonry-container{padding:16px}}@media (max-width:600px){.masonry-grid{column-count:1;max-width:100%;margin:80px 0 0}.masonry-container{padding:0 0 120px}.masonry-container,.masonry-container.mt-16{margin-top:32px!important}.masonry-title{font-size:16px}.masonry-date{font-size:13px}}.project-page .content-container{width:100%;max-width:644px;margin:0 auto;padding-left:1.25rem;padding-right:1.25rem}@media (min-width:640px){.project-page .content-container{padding-left:1.5rem;padding-right:1.5rem}}.mt-16{margin-top:80px!important}.navbar-scroll-container{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scroll-snap-type:none}.navbar-scroll-container::-webkit-scrollbar{display:none}@media (max-width:699px){.navbar-item-mobile:active{transform:scale(.98)}.navbar-item-mobile:active,.navbar-social-link:active{transition:all .1s;background-color:var(--hover-bg)!important}.navbar-social-link:active{transform:scale(.95)}.navbar-social-link:hover:not(:active){opacity:.7!important;background-color:#0000!important}.navbar-scroll-container{scroll-snap-type:none;-webkit-overflow-scrolling:touch}}.changelog-modal-reset h1,.changelog-modal-reset h2,.changelog-modal-reset h3,.changelog-modal-reset h4,.changelog-modal-reset h5,.changelog-modal-reset h6{margin:0!important;padding:0!important;line-height:1!important}.changelog-button,.changelog-button:after{border-radius:6px}.lab-navigation-container{background-color:var(--navbar-bg);border:1px solid var(--navbar-border)}.lab-navigation-button{color:rgb(var(--foreground))}.lab-navigation-separator{background-color:rgba(var(--foreground),.3)}.sandpack-preview-container .sp-button:has(svg[viewBox="0 0 24 24"]),.sandpack-preview-container .sp-button[aria-label*="Open in CodeSandbox"],.sandpack-preview-container .sp-button[aria-label*="Open in new tab"],.sandpack-preview-container .sp-button[title*="Open in CodeSandbox"],.sandpack-preview-container .sp-button[title*="Open in new tab"],.sandpack-preview-container .sp-preview-actions button,.sandpack-preview-container .sp-preview-container button[title]{display:none!important}:focus{outline:none}:focus-visible{outline-offset:2px;border-radius:2px;outline:2px solid orange}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}