@charset "UTF-8";:root{--font-base:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;--font-display:"SF Pro Display",SF Pro Icons,Helvetica Neue,Helvetica,Arial,sans-serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-2xl:1.25rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-lg:2.25rem;--text-xl:3.25rem;--text-xxl:4.5rem;--text-xs--line-height:calc(1 / 0.75);--text-sm--line-height:calc(1.25 / 0.875);--text-base--line-height:calc(1.5 / 1);--text-lg--line-height:calc(1.75 / 1.125);--text-2xl--line-height:calc(2 / 1.5);--text-3xl--line-height:calc(2.25 / 1.875);--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-tight:1.1;--leading-snug:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--tracking-sm:0.01em;--tracking-base:0.005em;--tracking-md:-0.005em;--tracking-md-lg:-0.0125em;--tracking-lg:-0.02em;--tracking-xl:-0.025em;--tracking-2xl:-0.03em;--body-bg:#fafafa;--text:#333333;--text-emph:#6e6e73;--border:#f5f5f7;--img-bg:#ffffff;--callout-bg:#fff7e5;--callout-text:#513e10;--callout-icon:#ffa000;--link-color:#0000ee;--visited-color:#551a8b;--hover-color:#3333ee;--active-color:#ff0000;--brand-fsqcityguide:#f94877;--brand-fsqcityguide-light:#ffe6ec;--brand-fsqswarm:#ffa633;--brand-fsqswarm-light:#fff3dd;--brand-fsqlabs:#1791ff;--brand-fsqlabs-light:#e3f1ff;--box-shadow:0 1px 3px 0 rgba(15, 60, 14, 0.06),0 10px 14px rgba(15, 60, 14, 0.08);--audio-blur:12px;--audio-sat:1.35;--audio-bright:1.05;--audio-fill:color-mix(in oklab, canvas 24%, transparent);--audio-milk:color-mix(in oklab, canvas 16%, transparent);--audio-stroke:color-mix(in oklab, canvasText 22%, transparent);--darken:4%;--spacing-unit:8px;--g:calc(10rem / 16);--spacing-g1:calc(var(--g) * 1)}@media (prefers-color-scheme:dark){:root{--body-bg:#2b2d32;--text:#ffffff;--text-emph:#abb0bb;--border:#3e4045;--img-bg:#24262a;--callout-bg:#3a3424;--callout-text:#e8d9b0;--callout-icon:#ffb703;--link-color:#66b2ff;--visited-color:#b48fd6;--hover-color:#99ccff;--active-color:#ff6666;--darken:16%;--sat:120%;--bright:95%;--audio-fill:color-mix(in oklab, canvasText 14%, transparent);--audio-milk:color-mix(in oklab, canvasText 10%, transparent);--audio-stroke:color-mix(in oklab, canvasText 40%, transparent)}p{word-spacing:.05em}}*,::after,::before{box-sizing:border-box}html{font-size:100%;overflow-y:scroll;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}blockquote,body,dd,dl,figcaption,figure,h1,h2,h3,h4,li,ol[class],p,ul[class]{margin:0}a{text-decoration:none}a:not([class]){text-decoration-skip-ink:auto}a:link{color:var(--link-color);text-decoration:underline}a:visited{color:var(--visited-color)}a:focus,a:hover{color:var(--hover-color);text-decoration:underline}a:active{color:var(--active-color)}button,input,select,textarea{font:inherit}strong{font-weight:var(--font-weight-medium)}small{font-size:75%}abbr{text-decoration:none}.num{font-family:var(--font-mono);font-weight:var(--font-weight-medium)}iframe,img,video{display:block;margin:0;width:100%;max-width:100%}img{height:auto;vertical-align:middle;font-style:italic;background-repeat:no-repeat;background-size:cover;shape-margin:.75rem}mark{margin:0 -.4em;padding:.1em .4em;border-radius:.4em .3em;background:0 0;background-image:linear-gradient(to right,rgba(255,225,0,.1),rgba(255,225,0,.7) 4%,rgba(255,225,0,.3));-webkit-box-decoration-break:clone;box-decoration-break:clone}code,pre{background:var(--border);border-radius:calc(.25 * var(--spacing-unit));color:var(--text);-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none;letter-spacing:-.025em;line-height:inherit;tab-size:2;text-align:left;vertical-align:baseline}pre{box-sizing:content-box;overflow:auto;padding:calc(3 * var(--spacing-unit));white-space:pre-wrap;word-wrap:break-word}pre code{font-family:inherit;box-shadow:none;background-color:transparent}code{font-family:var(--font-mono);font-size:var(--text-base);line-height:var(--text-base--line-height);padding:calc(.5 * var(--spacing-unit)) calc(1 * var(--spacing-unit));border-radius:calc(.5 * var(--spacing-unit))}body{background:var(--border);color:var(--text);font-family:var(--font-base);font-size:var(--text-base);font-weight:var(--font-weight-normal);letter-spacing:.005em;line-height:var(--text-base--line-height);scroll-behavior:smooth;text-rendering:optimizeSpeed;text-wrap:pretty}body,button,input,select,textarea{font-synthesis:none;font-feature-settings:"kern";-moz-font-feature-settings:"kern";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;direction:ltr;text-align:left}.wrapper{margin:0 auto;max-width:1320px;width:90%}.breakout{overflow-x:auto}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-normal)}h1{font-size:var(--text-4xl);line-height:var(--text-4xl--line-height);letter-spacing:var(--tracking-base)}h2{font-size:var(--text-3xl);line-height:var(--text-4xl--line-height);letter-spacing:var(--tracking-base);margin-bottom:calc(3 * var(--spacing-unit))}h3{font-size:var(--text-2xl);font-weight:500;line-height:var(--text-4xl--line-height);letter-spacing:var(--tracking-base);margin-bottom:calc(1 * var(--spacing-unit))}.post-meta,h5,time{color:var(--text-emph);font-size:var(--text-sm);line-height:var(--leading-normal);letter-spacing:var(--tracking-sm);margin:0}p{margin-bottom:calc(3 * var(--spacing-unit))}blockquote{border-left:calc(.5 * var(--spacing-unit)) solid var(--border);margin-left:calc(-2.5 * var(--spacing-unit));padding-left:calc(2 * var(--spacing-unit))}figcaption{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);line-height:var(--leading-normal);letter-spacing:.01em;padding:calc(1 * var(--spacing-unit)) 0 0 0;text-align:center}figcaption span{color:var(--text-emph);display:block;font-weight:var(--font-weight-normal)}.skip-link,.visually-hidden{font-size:inherit;position:absolute;z-index:99993;top:0;left:50%;text-align:center;text-decoration:underline;transition:transform 166ms;transform:translate(-50%,-110%);opacity:0;pointer-events:none}.skip-link:focus{transform:translate(-50%);opacity:1}.grid.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}header[role=banner]{background:var(--img-bg);color:var(--text-emph);padding:calc(5 * var(--spacing-unit)) 0 calc(20 * var(--spacing-unit))}footer[role=contentinfo]{background:var(--border);color:var(--text-emph);padding:calc(10 * var(--spacing-unit)) 0}footer[role=contentinfo] .copyright{margin-top:calc(5 * var(--spacing-unit))}footer[role=contentinfo] .copyright p{font-size:var(--text-sm);line-height:var(--leading-normal);letter-spacing:var(--tracking-sm);margin-bottom:0;grid-column:7/-1}nav[role=navigation] ul{list-style:none;margin:0;padding:0}nav[role=navigation] ul a .active,nav[role=navigation] ul a.active,nav[role=navigation] ul a.active:has(span.active):hover,nav[role=navigation] ul a:hover{color:var(--text)}nav[role=navigation] ul a:hover .active{color:var(--text-emph)}nav[role=navigation] ul a.active:has(span.active){color:var(--text-emph)}nav[role=navigation] ul a.active{font-weight:var(--font-weight-medium)}nav[role=navigation] ul ul{padding:0}nav[role=navigation] ul.grid li:nth-child(2){grid-column:7/19}nav[role=navigation] ul.grid li.last{grid-column:21/-1}footer[role=contentinfo] li a,nav[role=navigation] li a{color:var(--text-emph);display:inline-flex;align-items:center;gap:calc(.5 * var(--spacing-unit));text-decoration:none;margin-bottom:calc(1 * var(--spacing-unit))}footer[role=contentinfo] a:hover svg path,nav[role=navigation] a:hover svg path{stroke:var(--text)}footer[role=contentinfo]{background:var(--border);color:var(--text-emph);padding:calc(10 * var(--spacing-unit)) 0}.footer-col:nth-child(1){grid-column:1/span 3}.footer-col:nth-child(2){grid-column:7/span 3}.footer-col:nth-child(3){grid-column:11/span 3}.footer-top{grid-column:21/-1}.footer-col ul.footer-links{list-style:none;margin:0 0 calc(3 * var(--spacing-unit)) 0;padding:0}footer[role=contentinfo] a{color:var(--text-emph);display:inline-flex;align-items:center;gap:calc(.5 * var(--spacing-unit));text-decoration:none;margin-bottom:calc(1 * var(--spacing-unit))}footer[role=contentinfo] a:hover{color:var(--text)}footer[role=contentinfo] a:hover svg path{stroke:var(--text)}footer[role=contentinfo] a.active{color:var(--text);font-weight:var(--font-weight-medium)}footer[role=contentinfo] .copyright{margin-top:calc(5 * var(--spacing-unit))}footer[role=contentinfo] .copyright p{font-size:var(--text-sm);line-height:var(--leading-normal);letter-spacing:var(--tracking-sm);margin-bottom:0;grid-column:7/-1}main[role=main]{background:var(--img-bg);outline:0;padding-bottom:calc(10 * var(--spacing-unit));border-bottom-left-radius:0;border-bottom-right-radius:0;min-height:99vh;transform:scale(1);transform-origin:50% 100%;will-change:transform,border-radius}main[role=main] header{margin-bottom:calc(5 * var(--spacing-unit))}main[role=main] header p{color:var(--text-emph);margin:calc(3 * var(--spacing-unit)) 0 0}.callout{display:flex;align-items:center;gap:calc(1 * var(--spacing-unit));background:var(--callout-bg);color:var(--callout-text);border-radius:calc(var(--spacing-unit));font-size:var(--text-sm);padding:calc(1.25 * var(--spacing-unit));margin-bottom:calc(5 * var(--spacing-unit));opacity:.8}.callout a{color:inherit;text-decoration:underline;text-underline-offset:2px}.callout svg{align-self:flex-start;flex-shrink:0;color:var(--callout-icon)}.callout .callout__text{display:block}.callout .callout__text p{margin-bottom:0}.content .main{overflow-wrap:break-word}.content .meta{grid-column:1/7;margin-top:calc(5 * var(--spacing-unit))}.content .meta>div{margin-bottom:calc(2 * var(--spacing-unit))}.content .meta>div h5{margin:0 0 calc(.5 * var(--spacing-unit))!important}.content .meta div ol,.content .meta div ul{list-style:none;list-style-position:inside;margin:0;padding:0}.content .meta .acc{border-top:1px solid var(--border)}.content .meta .acc:last-of-type{border-bottom:none}.content .meta .acc__summary{align-items:center;color:var(--text-emph);cursor:pointer;display:flex;justify-content:space-between;gap:1rem;list-style:none;font-size:var(--text-sm);line-height:var(--leading-normal);letter-spacing:var(--tracking-sm);padding:calc(3 * var(--spacing-unit)) 0}.content .meta .acc__summary::-webkit-details-marker{display:none}.content .meta .acc__chev{width:1rem;height:1rem;transition:transform .2s ease;transform:rotate(180deg)}.content .meta .acc[open] .acc__chev{transform:rotate(0)}.content .meta .acc__panel{padding:0 0 calc(3 * var(--spacing-unit))}.content .meta .acc__panel p,.content .meta .acc__panel ul{margin:0;padding:0}body#reading [role=main] ul,body#tickets [role=main] ul{list-style:none;margin:0;padding:0}body#reading [role=main] ul li,body#tickets [role=main] ul li{transition:opacity .3s ease}.post-meta{display:flex;align-items:baseline;gap:var(--spacing-unit);flex-wrap:wrap}#footnotes{color:var(--text-emph)}ul#footnotes{list-style-type:none;padding:0;margin-top:calc(5 * var(--spacing-unit))}#footnotes li{margin-bottom:calc(2 * var(--spacing-unit))}#footnotes li::marker{font-family:var(--font-mono)}body#error{position:relative}body#error #error-strip{position:fixed;left:0;right:0;top:0;z-index:4}body#error #error-strip .grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:0;height:8px;padding-inline:0}@media screen and (min-width:540px){.row-start-1,.row-start-7{grid-column-start:1}.row-end-19{grid-column-end:13}.work-section{grid-template-columns:repeat(2,minmax(0,1fr))}}@media screen and (min-width:768px){.footer-nav .footer-grid{grid-template-columns:1fr}.footer-top{text-align:right}.work-section{grid-template-columns:repeat(3,minmax(0,1fr))}.work-section .item:nth-child(2){grid-column:span 2/span 2;grid-row:span 2/span 2}}@media screen and (min-width:1140px){.grid{display:grid;gap:var(--spacing-g1);grid-template-columns:repeat(24,1fr);max-width:100%}.row-start-1{grid-column-start:1}.row-start-7{grid-column-start:7}.row-end-19{grid-column-end:19}.grid.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}h1{font-size:var(--text-xl);line-height:var(--text-lg--line-height);letter-spacing:var(--tracking-xl)}body#blog-post h1,body#home h1{line-height:var(--text-4xl--line-height)}.work-section .item:nth-child(2){grid-column-start:3;grid-row-start:1}#case-study .content .main .quotes li{margin-bottom:0}.breakout{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);transform:translate(calc(50vw - 50%));max-width:1320px;width:100vw}h5,time{margin:0 0 calc(-2 * var(--spacing-unit)) 0}nav[role=navigation] ul.grid li.last{text-align:right}}@media (prefers-reduced-motion:reduce){*{-webkit-animation-duration:0s!important;animation-duration:0s!important;-webkit-animation-iteration-count:1!important;animation-iteration-count:1!important;transition-duration:0s!important;scroll-behavior:auto!important}}