
@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes wiggle{10%{transform:rotate(2deg)}20%{transform:rotate(-2deg)}30%{transform:rotate(4deg) scale(1.03)}40%,80%{transform:rotate(-4deg) scale(1.06)}50%{transform:rotate(6deg) scale(1.09)}60%{transform:rotate(-6deg) scale(1.12)}70%{transform:rotate(4deg) scale(1.09)}90%{transform:rotate(2deg) scale(1.03)}to{transform:rotate(0deg)}}@keyframes bounce-left{33%{translate:-33.3%}}@keyframes bounce-right{33%{translate:33.3%}}@keyframes bounce-up{33%{translate:0-25%}}@keyframes bounce-down{33%{translate:0 25%}}@keyframes wobble{50%{border-radius:750px 550px 350px 750px/350px 750px 550px 450px}to{border-radius:750px 250px 750px 250px/250px 750px 250px 750px}}:root{--layout-max:1440px;--content-max:calc(1100px + 3rem);--text-max:70ch;--footer-max:320px;--section-padding:1rem;--flow-space:1.5rem;--color:#111;--color-bg:#fff;--color-gallery-bg:#000;--hr-height:3px;--font-heading:'Port Lligat Slab', Helvetica, serif;--font-copy:'PT Sans Narrow', sans-serif;--font-mono:Fira Code, Courier New, monospace;interpolate-size:allow-keywords}*,::after,::before{box-sizing:border-box}blockquote,body,dd,dl,figure,h1,h2,h3,h4,p{margin:0}ul[role=list]{list-style-type:none}ul[role=list],ul[role=list] li{margin:0;padding:0}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5}a:not([class]){text-decoration-skip-ink:auto}img,picture,video{max-width:100%;height:auto;display:block}button,input,select,textarea{font:inherit}@media (prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,::after,::before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.hidden{display:none}.visually-hidden{position:absolute!important;clip:rect(1px,1px,1px,1px);overflow:hidden;height:1px;width:1px;word-wrap:normal}.visually-hidden.focusable:active,.visually-hidden.focusable:focus{position:static!important;overflow:visible;clip:auto;width:auto;height:auto}.invisible{visibility:hidden}.clearfix::after{clear:both;content:"";display:table}.stack>*+*{margin-block-start:var(--flow-space)}.balance{text-wrap:balance}.layout,body,html{height:100%}.layout{max-width:var(--layout-max);display:flex;flex-flow:column nowrap;gap:0}.site-footer,main{padding:var(--flow-space)}@media (min-width:1200px){.layout{flex-flow:row nowrap;align-items:stretch}main{flex:1 1 100%}.site-footer{order:-1;flex:0 0 var(--footer-max)}.site-footer a{position:relative;z-index:1}}body{color:var(--color);background:var(--color-bg);font-family:var(--font-copy);font-size:1.5rem;font-size:clamp(1.25rem,2.5vw,1.6875rem)}p{line-height:1.4;max-width:var(--text-max)}strong{font-weight:900}em{font-style:italic}.h-entry .layout a:focus-visible,.h-entry .layout button:focus-visible{background:var(--color);color:var(--color-bg);border-color:var(--color-bg);outline:2px solid var(--color);outline-offset:0;text-shadow:none}sup{vertical-align:top}abbr[title]{border-bottom:1px dotted;cursor:help;text-decoration:none}abbr[lang],blockquote,main h4{font-style:italic}blockquote{opacity:.8;margin-inline:1em;padding-block:.1em;padding-inline:1em;border-inline-start:1em solid #ddd}blockquote p+p{margin-block-start:.5em}hr{--flow-space:3rem;max-width:calc(var(--text-max) - 20ch);height:var(--hr-height);margin-block:var(--flow-space);margin-inline:10ch;color:#888;border:1px solid currentColor;border-width:1px 0;position:relative;overflow:visible}hr::after{content:"§";background:#fff;padding:0 .4em;position:absolute;left:50%;transform:translateX(-50%) translateY(calc(-50% + (var(--hr-height)/2)))}main{font-weight:300}main h1,main h2,main h3{font-family:var(--font-heading)}main h1{font-size:1.75em}main h2{font-size:1.25em}main h4{font-weight:200;border-radius:1em/4em;border-left:1.5rem solid rgba(#f82,.8);padding-left:.5rem}label[for=uid],main h5{font-size:1em}main h6{font-size:.9em}ol:not([class],[role]) li,ul:not([class],[role]) li{line-height:1.2;font-size:95%;margin-right:5%;margin-bottom:1.5%}main ins.update{font-size:.9em;font-style:italic;color:#444;text-decoration:none}main ins.update::before{content:"Update "attr(datetime)": ";font-weight:500;color:#000}del+.oops,main del{display:inline-block;text-decoration:none}main del{opacity:.5;transition:opacity .2s ease-in-out;position:relative}main del::after{content:" ";position:absolute;bottom:.55em;left:0;right:0;border-bottom:1px solid #000;transition:transform .2s ease-in-out}del+.oops{opacity:.8;margin-right:-.2em;transition:.2s ease-in-out;transition-property:color,opacity,transform;perspective:600px;transform-style:preserve-3d;transform:translateX(-.2em) translateY(-.06em) rotateZ(-4deg);color:#111}main :not(pre)>code{display:inline-block;padding:0 .2em;border-radius:.2em;background:#ddd;font-family:var(--font-mono);font-size:.8em;font-weight:400}main aside.note{font-size:.8em;margin:0 1em;font-style:italic;opacity:.9}@media (min-width:1147px){main aside.note{margin:0 3em}}main aside.info{font-style:italic;font-weight:200;padding:.2em 5%;background-color:rgba(#79f,.4);border-radius:7px}@media (min-width:1147px){main aside.info{width:110%;margin-left:-5%}}main aside.warning{font-style:italic;font-weight:200;padding:.2em 5%;background-color:rgba(#fd0,.4);border-radius:7px}@media (min-width:1147px){main aside.warning{width:110%;margin-left:-5%}main aside.warning>p::before{content:"⚠ "}}.site-footer{font-size:18px;position:relative;text-align:right}.site-footer .wrapper{max-width:var(--footer-max);margin-inline-start:auto;margin-inline-end:0}.site-footer a{color:inherit}.site-footer .p-note{--flow-space:.5rem}.h-entry .layout .site-footer .face-link:focus-visible{background:0 0;outline:0;filter:drop-shadow(0 0 1px #000) drop-shadow(0 0 1px #000) drop-shadow(0 0 1px #000)}.site-footer .face-link img{display:initial;position:relative;z-index:1;border-radius:250px 750px 250px 750px/750px 250px 750px 250px;animation:wobble 25s ease-in-out alternate infinite;transition:transform .5s ease-in}.site-footer .site-nav{justify-content:flex-end}.site-footer .social-links{display:flex;flex-flow:row nowrap;justify-content:flex-end;align-items:center;gap:.25rem}.site-footer .social-link{display:block;flex:0 0 36px}.site-footer .social-link--mastodon{position:relative;top:2px}.site-footer .social-link--drupal{margin-inline-start:.1rem}.site-footer .social-link--pixelfed{flex-basis:44px}.site-footer .social-link--rss svg{border-radius:3px}.site-footer .social-link a{display:block;border:3px solid transparent;border-radius:3px;line-height:0}.fullscreen #photosphere .fullscreen,.listing.is-offline .teaser--title.is-cached,.site-footer .social-link a svg{display:block}.site-footer .social-link a:focus-visible{border-color:#000}.site-footer .social-link--pixelfed a:focus-visible #icon--pf-bg{fill:#000}@media (min-width:1200px){.site-footer .wrapper{position:fixed;top:0;left:0;padding:var(--flow-space);max-width:var(--footer-max)}.site-footer .wrapper::after{content:"";border-inline-end:1px solid currentColor;position:absolute;inset:1.5rem 0 1.5rem auto;opacity:.1}}#status{position:fixed;bottom:0;left:0;right:0;z-index:100;transform:translateY(300%);transition:transform .25s ease-in-out;background:#000d;backdrop-filter:blur(6px);color:#fff;text-shadow:1px 1px 1px #000;display:flex;flex-flow:row nowrap;gap:1rem;padding:1rem}#status.is--displayed,.photo[data-comment].photo--caption:after,.photo[data-comment]:hover:after{transform:translateY(0)}#message{flex:1 0 auto;margin:0}.site-nav ul{display:flex;flex-flow:row wrap;justify-content:flex-end;font-size:18px;gap:.5rem}.site-nav a{display:block;padding:.5rem;background:#0001;text-decoration:none;border-bottom:4px solid transparent}.site-nav a.active{border-color:#0003}.entry--main{padding-block-end:var(--flow-space)}.subtitle{margin-block-start:0;font-family:var(--font-mono);font-size:.8em;letter-spacing:-1px;opacity:.8}.intro{margin-block:1.5rem;max-width:40ch;opacity:.666;font-family:var(--font-heading);font-size:1.2em;line-height:1.2}.the-end{margin:1.25em 0;padding:0;font-size:1.32em;text-align:center}.entry-meta{margin-block:var(--flow-space);padding:var(--section-padding);font-family:var(--font-mono);font-size:18px;background:#0001}.contact label,.meta .u-url,.meta__url-label{cursor:pointer}.meta .u-url{max-width:100%}.syndication{display:flex;flex-flow:row nowrap;align-items:center;gap:1rem}.syndication__list{display:flex;flex-flow:row wrap;justify-content:flex-start;gap:1rem}.syndication__list li{flex:0 0 auto}#uid{width:calc(100% - 4em);font-size:calc(1em/27*24);letter-spacing:-.75px;border:1px solid #fff}#uid:focus{outline:2px solid #000;border-color:#000;color:#111}.media{margin:1em 0;padding:4%;background:var(--color-gallery-bg)}#photosphere,.gallery,.media{max-width:var(--content-max);width:100%;margin-block:2.5rem;padding:1.5rem;background:#000;border-radius:4px}.media{max-width:100%;width:attr(data-width)}#photosphere .caption{display:block}#photosphere .caption,#photosphere .fullscreen,.gallery .caption,.gallery figcaption,.media .caption{clear:both;padding-top:1em;opacity:.6;color:#ddd;font-size:90%;font-style:italic;text-align:center}.gallery .caption,.gallery figcaption,.media .caption{display:block}@media (min-width:1100px){#photosphere .caption,#photosphere .fullscreen,.gallery .caption,.gallery figcaption{margin:0 20%}}#photosphere .caption em,#photosphere .fullscreen em,.gallery .caption em,.gallery figcaption em,.media .caption em{white-space:nowrap}#photosphere .caption a,#photosphere .fullscreen a,.gallery .caption a,.gallery figcaption a,.media .caption a{color:inherit}.gallery figcaption{flex-basis:100%}.photo{display:block;overflow:hidden;position:relative;z-index:1;transition:transform .25s ease-in-out}.photo img,.photo img:before{position:absolute;width:100%;height:100%;min-height:5em}.photo img{object-fit:cover;color:transparent;line-height:1.5;background:#fff}.photo img:before{content:"";display:block;border:1px solid #bbb;border-radius:3px;background:linear-gradient(to top left,#fff,#ddd)}.photo img:after{content:"Image: "attr(alt);display:block;position:absolute;font-style:italic;color:#222;top:.5em;right:.5em;bottom:.5em;left:.5em}@media (min-width:500px){.photo img:after{font-size:.8em}}.photo[data-comment]:after{font-size:.9em;content:attr(data-comment);color:#fff;background:rgba(0,0,0,.66);display:block;position:absolute;bottom:0;left:0;right:0;padding:1em;transform:translateY(100%);transition:transform .33333s ease-in-out}@media (min-width:500px){.photo[data-comment]:after{font-size:.7em}}.grid-col-2 .photo,.grid-col-2-short .photo,.grid-col-3 .photo,.grid-float .photo,.grid-tall .photo{float:left;width:98%;padding-bottom:98%;margin-right:1%;margin-left:1%;margin-bottom:5%}@media (min-width:500px){.grid-col-2 .photo,.grid-col-2-short .photo,.grid-col-3 .photo,.grid-float .photo,.grid-tall .photo{margin-bottom:2%}}.grid-col-2 .photo.wide,.grid-col-2-short .photo.wide,.grid-col-3 .photo.wide,.grid-float .photo.wide,.grid-tall .photo.wide{float:none;clear:both;width:98%;padding-bottom:33.3333333333%}.grid-col-2 .tall,.grid-col-2-short .tall,.grid-col-3 .tall,.grid-float .tall,.grid-tall .tall{padding-bottom:160%}@media (min-width:500px){.grid-col-2 .photo.half,.grid-col-2-short .photo.half,.grid-col-3 .photo.half,.grid-float .photo.half,.grid-tall .photo.half{width:48%}.grid-col-2 .photo.one-third,.grid-col-2-short .photo.one-third,.grid-col-3 .photo.one-third,.grid-float .photo.one-third,.grid-tall .photo.one-third{width:31.3333333333%}.grid-col-2 .photo.two-third,.grid-col-2-short .photo.two-third,.grid-col-3 .photo.two-third,.grid-float .photo.two-third,.grid-tall .photo.two-third{width:64.6666666667%}.grid-col-2 .photo.tall,.grid-col-2-short .photo.tall,.grid-col-3 .photo.tall,.grid-float .photo.tall,.grid-tall .photo.tall{padding-bottom:103.9%}.grid-col-2 .photo.tall-half,.grid-col-2-short .photo.tall-half,.grid-col-3 .photo.tall-half,.grid-float .photo.tall-half,.grid-tall .photo.tall-half{padding-bottom:50.95%}.grid-col-2 .photo{width:48%;padding-bottom:51%}.grid-col-2-short .photo,.grid-col-3 .photo{width:48%;padding-bottom:33.3333333333%}.grid-col-3 .photo{width:31.3333333333%}.grid-col-3 .tall{width:64.6666666667%}.grid-tall .photo{width:48%;padding-bottom:33.3333333333%}}#photosphere{cursor:move}#photosphere .fullscreen{display:none;cursor:zoom-in;text-decoration:underline}code[class*=language-]{overflow:scroll}code[class*=language-],pre[class*=language-]{max-width:var(--content-max);color:#000;background:0 0;text-shadow:0 1px #fff;font-family:var(--font-mono);font-size:.92em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.25;letter-spacing:-.5px;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}code[class*=language-] ::-moz-selection,code[class*=language-]::-moz-selection,pre[class*=language-] ::-moz-selection,pre[class*=language-]::-moz-selection{text-shadow:none;background:#b3d4fc}code[class*=language-] ::selection,code[class*=language-]::selection,pre[class*=language-] ::selection,pre[class*=language-]::selection{text-shadow:none;background:#b3d4fc}@media print{code[class*=language-],pre[class*=language-]{text-shadow:none}}pre[class*=language-]{padding:1em;margin:2.5rem 0;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#f5f2f0}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.cdata,.token.comment,.token.doctype,.token.prolog{color:#708090}.token.punctuation{color:#999}.token.namespace{opacity:.7}.token.boolean,.token.constant,.token.deleted,.token.number,.token.property,.token.symbol,.token.tag{color:#905}.token.attr-name,.token.builtin,.token.char,.token.inserted,.token.selector,.token.string{color:#690}.language-css .token.string,.style .token.string,.token.entity,.token.operator,.token.url{color:#9a6e3a;background:rgba(255,255,255,.5)}.token.atrule,.token.attr-value,.token.keyword{color:#07a}.token.class-name,.token.function{color:#dd4a68}.token.important,.token.regex,.token.variable{color:#e90}.token.bold,.token.important{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.go{display:flex;flex-flow:row wrap;justify-content:center;gap:.5rem}.go .btn,.go button{border:0;background:#0001;border-block-end:4px solid #0003;padding-inline-start:1rem;color:#000;text-decoration:none;text-shadow:.5px .5px 1px #ffff;padding:.5rem 1rem;cursor:pointer}.go .btn::after,.go .btn::before{display:inline-block;position:relative}.go .btn--prev::before{content:"←";left:-5px}.go .btn--prev:hover::before{animation:bounce-left .333s ease-out}.go .btn--next{padding-inline-end:1em}.go .btn--next::after{content:"→";right:-5px}.go .btn--next:hover::after{animation:bounce-right .333s ease-out}.go .btn--back::before{content:"↑";left:-5px}.go .btn--back:hover::before{animation:bounce-up .333s ease-out}.go .btn--mail,.go .btn--offline{padding-inline-start:2rem}.go .btn--offline::before{content:"💾";left:-10px}.go .btn--mail:hover::before,.go .btn--offline:hover::before{animation:wiggle 1s ease-out}.go .btn--mail::before{content:"📨";left:-10px}.go .btn[disabled]{background-color:#0002}.webmentions{position:relative;background:#0001;padding:var(--section-padding) calc(var(--section-padding)*2);font-size:calc(1em*24/27)}.webmentions__list{padding-block-end:1.5rem}.webmentions__list ul{margin-block-start:1rem;margin-inline:0}.webmentions__list li+li{margin-block-start:1rem;padding:0}.webmentions__form{display:flex;flex-flow:row nowrap}.webmentions__url{min-width:100px;max-width:500px;flex:1 1 auto;border:3px solid #1116;border-inline-end:0;border-radius:5px 0 0 5px;font-family:var(--font-mono);font-size:90%;letter-spacing:-1px}.webmentions__submit{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:0 0 auto;border:3px solid #111;border-radius:0 5px 5px 0;padding:0 1rem;background:#111;color:#fff}.webmentions__url:focus{outline:0;border-color:#000}.contact button:focus,.webmentions__submit:focus{outline:0;text-decoration:underline}.p-comment{border-inline-start:var(--section-padding) solid #0001;padding-inline-start:var(--section-padding)}.p-comment .e-content{overflow-x:hidden}.p-comment .e-content a,.p-comment .e-content footer a{white-space:nowrap}.p-comment .e-content footer{font-family:var(--font-mono);font-size:.75em;letter-spacing:-1px}.tag-list a,a[rel=tag]{color:#333;white-space:nowrap}.tag-list{max-width:800px;clear:both;display:flex;flex-flow:row wrap;justify-content:center;align-items:baseline;list-style:none;gap:.75rem;margin:0;padding:0}.tag-list li{margin:0;order:calc(0 - var(--tag-weight))}.tag-list a{flex:1 0 10%;margin:0;padding:0;font-family:monospace;font-size:max(calc(var(--tag-weight)/10*.7em),.7em);color:inherit;word-spacing:-.6em}.tag-list a:last-child{flex-basis:50%}.map{width:100%;height:400px;margin-block:2.5rem;border-radius:5px}.map.mapboxgl-map{overflow:hidden;height:400px}@media (min-width:550px){.map.mapboxgl-map{height:calc(550px*1)}}@media (min-width:800px){.map.mapboxgl-map{height:calc(800px*.666)}}@media (min-width:1100px){.map.mapboxgl-map{height:calc(1100px*.666)}}.map.mapboxgl-control-container{font-size:.5em}.map.mapboxgl-popup-content{font-size:.8em;background:#fff;border-radius:3px;padding:.5em;display:flex;flex-flow:row wrap}.map.mapboxgl-popup-content .mapboxgl-popup-close-button{display:none}.map.mapboxgl-popup-content h3{flex:1 0 100%;margin:0;word-break:break-word}.map.mapboxgl-popup-content p{flex:1 0 100%;margin-bottom:0}:root{--cal-radius:0}.availability{display:flex;flex-flow:row wrap;justify-content:space-between;align-content:stretch;gap:1rem 0;max-width:1072px;margin:0;padding:0;border-radius:7px;transition:box-shadow .1666s linear}@media (min-width:640px){.availability{box-shadow:5px 5px 15px #0002;margin-bottom:2rem;flex-wrap:nowrap;gap:0;--cal-radius:7px}}.availability:hover{box-shadow:5px 5px 15px rgba(#000,.25)}.availability__date{display:inline-block}.intro:hover .availability__date{animation:wiggle 1s ease-in-out}.slot{display:block;flex:1 0 16.666%;width:100%;margin:0;padding:1em .333em;border:.5px solid #0005;border-top-width:1px;border-bottom-width:1px;text-align:center;font-size:.8em;transition:border-color .1666s linear}@media (min-width:640px){.slot{flex:0 1 auto}}.slot:hover{border-color:#0008}.slot:first-child{border-left-width:1px;border-radius:var(--cal-radius)0 0 var(--cal-radius)}.slot:last-child{border-right-width:1px;border-radius:0 var(--cal-radius) var(--cal-radius)0}.slot::after{content:attr(data-label)}.slot--past{color:#666;background:#ccc;cursor:not-allowed}.slot--full{background:#e64;cursor:not-allowed}.slot--half{background:#ec3;cursor:context-menu}.slot--open{background:#6c6;cursor:context-menu}.teaser--title .wrapper{display:flex;flex-flow:column nowrap}.teaser--title .title--main{margin-block-start:0;margin-block-end:.25em;font-weight:300;line-height:1.1}.teaser--title .where{font-size:.75em}.teaser--title .summary{order:99;font-size:.85em;opacity:.8}.teaser--title footer{color:rgba(#000,.5);font-family:var(--font-mono);font-size:calc(1em*18/27)}.work-cta{max-width:var(--text-max);border:5px solid #ddd;background:#eee;border-radius:11px;padding:1em;font-size:1.125em;text-align:center;position:relative}.work-cta .title--badge{text-align:end;background:#abf;border:2px solid #36f;border-radius:5px;padding-inline:1em;font-family:var(--font-copy);font-size:1.5rem;font-size:clamp(1.25rem,2.5vw,1.6875rem);position:absolute;top:-.8em;right:-1em;transform:rotate(8deg)}.work-cta .work-cta__intro{padding-inline:calc(var(--section-padding)*2);text-wrap:balance}.work-cta.contact form{background:0 0}.listing{display:flex;flex-flow:column nowrap;padding-block-end:var(--flow-space)}.listing .site-nav{order:-1;margin-block:0}.listing .site-nav ul{justify-content:flex-start;margin-block-end:var(--flow-space)}@media (min-width:1200px){.listing .site-nav ul{display:none}}.listing .site-nav a{color:inherit}.listing .search__input{max-width:50ch;width:100%}.listing .search__input:focus{border-color:transparent;outline:4px solid var(--color)}.listing .listing__list{--flow-space:2.5rem}.listing.is-offline .teaser--title{display:none}.contact form{background:#0001;padding:var(--section-padding) calc(var(--section-padding)*2)}.contact form>*{display:block}.contact input,.contact textarea{--flow-space:0;width:100%;max-width:600px;border:3px solid #1116;border-radius:3px;font-family:var(--font-mono)}.contact input:focus,.contact textarea:focus{outline:0;border-color:#111f}.contact .actions{display:flex;flex-flow:row nowrap;gap:0}.contact button{border:0;background:#111;color:#fff;padding:0 1.25rem;line-height:2;opacity:.7}.contact button[type=submit]{opacity:1}.contact .actions :first-child{border-radius:5px 0 0 5px}.contact .actions :last-child{border-radius:0 5px 5px 0}@media (min-width:600px){.contact{font-size:24px}}.clients[role=list]{max-width:var(--text-max);margin-block:2.5rem;display:flex;flex-flow:row wrap;animation:fade-in 1s ease-in-out}.client{flex:1 0 33.3333%;min-width:160px;min-height:160px;margin:0;padding:0;text-align:center;background-position:50% 50%;background-repeat:no-repeat;background-size:70%}.client--unocha{background-size:45%}.page--front .go,.page--work .go{justify-content:flex-start;margin-block:3.5rem}.page--front .hello.intro{margin-block-start:.5rem}.page--front .go{margin-block:2.5rem}.page--front .listing .listing--front{--flow-space:1rem}