body{font-variant-ligatures:common-ligatures;-moz-font-feature-settings:"liga","clig";-webkit-font-feature-settings:"liga","clig";font-feature-settings:"liga","clig"}::-moz-selection{background:rgba(23,47,51,.8)}::selection{background:rgba(23,47,51,.8)}.opacity-80{opacity:.8}.opacity-0{opacity:0}.block{display:block}.inline-block{display:inline-block}[class*=inline-block]{vertical-align:top}.absolute{position:absolute}.fixed{position:fixed}.t-0,.top-0{top:0}.l-0,.left-0{left:0}.r-0,.right-0{right:0}.b-0,.bottom-0{bottom:0}.inset-0{top:0;right:0;bottom:0;left:0}.m-0{margin:0}.m-2{margin:.59375rem}.mx-2{margin-left:.59375rem;margin-right:.59375rem}.-mx-2{margin-left:-.59375rem;margin-right:-.59375rem}.mx-4{margin-left:1.1875rem;margin-right:1.1875rem}.my-0{margin-top:0;margin-bottom:0}.-mt-1{margin-top:-.296875rem}.ml-0{margin-left:0}.ml-1{margin-left:.296875rem}.ml-2{margin-left:.59375rem}.ml-4{margin-left:1.1875rem}.mr-0{margin-right:0}.mr-1{margin-right:.296875rem}.mr-2{margin-right:.59375rem}.mr-4{margin-right:1.1875rem}.bg-white{background-color:#fff}.p-0{padding:0}.px-2{padding-left:.59375rem;padding-right:.59375rem}.py-0{padding-top:0;padding-bottom:0}.py-4{padding-top:1.1875rem;padding-bottom:1.1875rem}.py-8{padding-top:2.375rem;padding-bottom:2.375rem}.pl-0{padding-left:0}.pl-1{padding-left:.296875rem}.pl-2{padding-left:.59375rem}.pr-0{padding-right:0}.pr-1{padding-right:.296875rem}.pr-2{padding-right:.59375rem}.pr-4{padding-right:1.1875rem}.pt-1{padding-top:.296875rem}.pt-2{padding-top:.59375rem}.pt-4{padding-top:1.1875rem}.pt-8{padding-top:2.375rem}.pb-1{padding-bottom:.296875rem}.pb-2{padding-bottom:.59375rem}.pb-4{padding-bottom:1.1875rem}.pb-8{padding-bottom:2.375rem}.float-left{float:left}.float-right{float:right}.clear-both{clear:both}.clear-both[aria-hidden]{margin-top:2.375rem}@media(min-width:50.5rem){.md\:float-right{float:right}}@media(min-width:72rem){.lg\:float-right{float:right}}[class*=columns]{-webkit-column-gap:1.1875rem;-moz-column-gap:1.1875rem;column-gap:1.1875rem}.columns-2{-webkit-columns:2;-moz-columns:2;columns:2}@media(min-width:72rem){.lg\:columns-4{-webkit-columns:4;-moz-columns:4;columns:4}}.columns-2 ul,.columns-2 ol{margin:0!important}.w-fit{width:initial;width:fit-content}.w-full{width:100%}.w-1\/4{width:100%;max-width:25%}.w-3\/8{width:100%;max-width:37.5%}.w-1\/2{width:100%;max-width:50%}.w-5\/8{width:100%;max-width:62.5%}.min-w-100{min-width:100%}; .max-w-none{max-width:none}@media(min-width:30rem){.xs\:mb-0{margin-bottom:0}.xs\:pl-2{padding-left:.59375rem}.xs\:inline-block{display:inline-block}.xs\:w-1\/4{width:100%;max-width:25%}.xs\:w-3\/8{width:100%;max-width:37.5%}.xs\:w-1\/2{width:100%;max-width:50%}.xs\:w-5\/8{width:100%;max-width:62.5%}.xs\:w-full{width:100%;max-width:100%}}@media(min-width:40rem){.sm\:-mx-2{margin-left:-.59375rem;margin-right:-.59375rem}.sm\:px-2{padding-left:.59375rem;padding-right:.59375rem}.sm\:inline-block{display:inline-block}.sm\:w-1\/4{width:100%;max-width:25%}.sm\:w-3\/8{width:100%;max-width:37.5%}.sm\:w-1\/2{width:100%;max-width:50%}.sm\:w-5\/8{width:100%;max-width:62.5%}.sm\:w-full{width:100%;max-width:100%}}@media(min-width:50.5rem){.md\:-mx-2{margin-left:-.59375rem;margin-right:-.59375rem}.md\:px-2{padding-left:.59375rem;padding-right:.59375rem}.md\:pr-4{padding-right:1.1875rem}.md\:inline-block{display:inline-block}.md\:w-1\/4{width:100%;max-width:25%}.md\:w-3\/8{width:100%;max-width:37.5%}.md\:w-1\/2{width:100%;max-width:50%}.md\:w-5\/8{width:100%;max-width:62.5%}.md\:w-full{width:100%;max-width:100%}}@media(min-width:72rem){.lg\:pr-4{padding-right:1.1875rem}.lg\:w-1\/4{width:100%;max-width:25%}.lg\:w-1\/2{width:100%;max-width:50%}.lg\:w-full{width:100%;max-width:100%}}@media(min-width:80rem){.xl\:-mx-2{margin-left:-.59375rem;margin-right:-.59375rem}.xl\:px-2{padding-left:.59375rem;padding-right:.59375rem}.xl\:inline-block{display:inline-block}.xl\:w-1\/4{width:100%;max-width:25%}.xl\:w-3\/8{width:100%;max-width:37.5%}.xl\:w-1\/2{width:100%;max-width:50%}.xl\:w-5\/8{width:100%;max-width:62.5%}.xl\:w-full{width:100%;max-width:100%}}@media(hover:hover){a:hover{text-decoration:none}}.no-underline{text-decoration:none}a:focus,a:active{background:#ebe6e5!important;color:#14191a!important;outline:none}a.link-full::after{content:"";display:block;position:absolute;top:0;bottom:0;left:0;right:0;z-index:1}a.link-external[href^=http]:not([href^="https://timothee.goguely.com/"])::after{content:"↗";display:inline-block;font-family:nt bau mono,Menlo,monospace;color:rgba(235,230,229,.666);margin-left:.15em}h1,h2,h3,h4{font-weight:400;margin:0}h4{display:inline-block}h1,h2,h3,h4{max-width:33.68em}strong{font-weight:400;background:rgba(23,47,51,.8);border-radius:.125rem}cite{font-style:normal}.uppercase{text-transform:uppercase}.list-none{list-style:none}table{margin:3.5625rem -1.1875rem;padding:0 1.1875rem;width:calc(100% + 1.1875rem * 2);max-width:max(33.68em,100vw);border-collapse:collapse;overflow-x:auto;display:block;caption-side:bottom}.table-mono thead th{text-align:right}.table-mono td{font-family:nt bau mono,Menlo,monospace;text-align:right}.table-mono tbody td{opacity:.66}caption{text-align:left;font-size:.75rem;line-height:1.6;text-transform:none;opacity:.66;margin-top:1.9em}caption::before{content:"↑";margin-right:.5em}th{text-align:left;font-weight:400}tr>*{padding:.25em 1em .25em 0;border-bottom:1px solid rgba(235,230,229,.333)}table a{white-space:pre}.text-xs{font-size:.46875rem;line-height:1.6}[class*=text-xs]{letter-spacing:.1em}.text-lg{font-size:1.9rem;line-height:1.25}@media(min-width:30rem){.xs\:text-xs{font-size:.6rem;line-height:1.6}.xs\:text-sm{font-size:.75rem;line-height:1.6}}@media(min-width:40rem){.sm\:text-xs{font-size:.6rem;line-height:1.6}.sm\:text-sm{font-size:.75rem;line-height:1.6}.sm\:text-base{font-size:1.125rem;line-height:1.579}.sm\:text-lg{font-size:1.9rem;line-height:1.25}}@media(min-width:50.5rem){.md\:text-xs{font-size:.6rem;line-height:1.6}.md\:text-sm{font-size:.75rem;line-height:1.6}.md\:text-base{font-size:1.125rem;line-height:1.579}.md\:text-lg{font-size:1.9rem;line-height:1.25}}@media(min-width:72rem){.lg\:text-xs{font-size:.6rem;line-height:1.6}.lg\:text-sm{font-size:.75rem;line-height:1.6}.lg\:text-base{font-size:1.125rem;line-height:1.579}.lg\:text-lg{font-size:1.9rem;line-height:1.25}}@media(min-width:80rem){.xl\:text-xs{font-size:.6rem;line-height:1.6}.xl\:text-sm{font-size:.75rem;line-height:1.6}.xl\:text-base{font-size:1.125rem;line-height:1.579}.xl\:text-lg{font-size:1.9rem;line-height:1.25}}.mix-blend-multiply{mix-blend-mode:multiply}.mix-blend-screen{mix-blend-mode:screen}[data-ratio]:not([data-ratio=auto]){position:relative;height:0;width:100%}[data-ratio]:not([data-ratio=auto])>*{position:absolute;top:0;height:100%}[data-ratio="3/1"]{padding-top:33.33333333%}[data-ratio="21/9"]{padding-top:42.85714286%}[data-ratio="16/9"]{padding-top:56.25%}[data-ratio="5/3"]{padding-top:60%}[data-ratio="3/2"]{padding-top:66.66666666%}[data-ratio="7/5"]{padding-top:71.42857143%}[data-ratio="4/3"]{padding-top:75%}[data-ratio="10/8"]{padding-top:80%}[data-ratio="1/1"]{padding-top:100%}#header a{color:inherit;text-decoration:none}.btn:focus,.btn:active{outline:1px solid rgba(235,230,229,.666)}#back-to-top{background:rgba(20,25,26,.666);color:rgba(235,230,229,.666)!important;position:absolute;top:unset;bottom:1.1875rem;right:1.1875rem;display:block;border-radius:50%;text-decoration:none;text-align:center;padding:.75em;cursor:n-resize}#back-to-top:focus,#back-to-top:active{background:#14191a;outline-color:rgba(235,230,229,.666)}@media(hover:hover){.btn:hover{background:#172f33}#back-to-top:hover{background:#14191a}}.breadcrumb ol{list-style:none;display:inline-block;padding-left:0}.breadcrumb ol>li{display:inline}.tags.text-sm .tag,.tag.text-sm{font-size:.75rem}.tag a:focus{color:#172f33;background:#e8d0cc}.tag a:active{color:#172f33!important;background:#ebe6e5!important}@media(hover:hover){.tag a:hover{color:#e8d0cc;background:#172f33}}.content ul,.content ol{max-width:40em}.content ul{padding-left:0}.content ul>li:not(.tag):last-child{margin-bottom:0!important}.content .list-none,.content .tags,#design+ul,#code+ul{padding-left:0}.content ul:not(.list-none,.tags,#design+ul,#code+ul) li:not(.tag){position:relative;margin-bottom:1em;list-style:none;padding-left:1.1875rem}.content ul:not(.list-none,.tags,#design+ul,#code+ul) li:not(.tag)::before{content:"";display:inline-block;position:absolute;top:.875rem;left:0;background:currentColor;opacity:.333;width:.375rem;height:.375rem;border-radius:50%}.content .projet h4{display:inline-block;min-width:11.666em}@media(min-width:30rem){.content h2{font-size:1.1875rem;line-height:1.579}.content h3{font-size:1.9rem;line-height:1.25}}@media(min-width:72rem){h1+.content h2+*{margin-top:.55rem!important}}#footer{background:rgba(23,47,51,.8);clear:both;margin-top:2.375rem}#footer *::-moz-selection{background:rgba(20,25,26,.666)}#footer *::selection{background:rgba(20,25,26,.666)}#links li::before{content:"↗ ";font-family:nt bau mono,Menlo,monospace;color:rgba(235,230,229,.666)}#stats{color:rgba(235,230,229,.666);white-space:nowrap}#stats li:nth-child(3){margin-bottom:1.6em}.stat-name::after{content:" "attr(data-dots);display:inline;font-family:nt bau mono,Menlo,monospace}@media(min-width:30rem){#stats{-webkit-columns:2;-moz-columns:2;columns:2;-webkit-column-gap:1.1875rem;-moz-column-gap:1.1875rem;column-gap:1.1875rem}#stats li:nth-child(3){margin-bottom:0}}@media(min-width:72rem){.lg\:pt-0{padding-top:0}}.article{position:relative;margin-bottom:1em!important}@media(min-width:50.5rem){#code,#code+ul{position:absolute;left:50%;padding-left:.6rem}#code{top:5.5rem;margin-top:0}#code+ul{top:7.9rem;right:0}.content:after{content:"";display:block;clear:both}}@media(min-width:72rem){#code,#code+ul{left:70%;width:auto}#code{top:3.5625rem}#code+ul{top:5.9rem}#design+ul,#code+ul{padding-left:.446rem!important}}[data-type=blog][data-kind=section] .content>*{margin-left:0;padding-left:0}[data-type=blog][data-kind=page] main>header h1{font-size:inherit}[data-type=blog][data-kind=page] .content h2{font-family:nt bau,-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Helvetica,Arial,sans-serif,apple color emoji,segoe ui emoji,segoe ui symbol;font-size:1.9rem;line-height:1.25;letter-spacing:-.01em;text-transform:none}[data-type=blog][data-kind=page] .content h3{font-family:nt bau,-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Helvetica,Arial,sans-serif,apple color emoji,segoe ui emoji,segoe ui symbol;font-size:1.1875rem;line-height:1.333;text-transform:none;opacity:.66;margin-top:2.666em}[data-type=blog][data-kind=page] .content figure{margin:4.75rem 0}[data-type=blog][data-kind=page] .content figure:not(.w-full){max-width:769px}[data-type=blog][data-kind=page] .content picture{display:flex;mix-blend-mode:screen}[data-type=blog][data-kind=page] .content abbr::after{content:"";display:block;position:absolute;bottom:-2px;left:0;width:100%;height:1px;opacity:.666;background:repeating-linear-gradient(to right,#EBE6E5 1px,#EBE6E5 2px,transparent 2px,transparent 6px)}[data-type=blog][data-kind=page] article a[href^=http]:not([href^="https://timothee.goguely.com/"])::after{content:"↗";display:inline-block;font-family:nt bau mono,Menlo,monospace;font-size:.75rem;color:rgba(235,230,229,.666);margin-left:.15em}@media(hover:hover){.item:hover{border-color:rgba(235,230,229,.666)}}@media(prefers-color-scheme:dark){html{content:"dark"}}[data-theme=dark] .dark\:hidden{display:none}[data-theme=light] .light\:hidden{display:none}[data-theme=light] body{color:#14191a;background:rgba(235,230,229,.666)}[data-theme=light] *::-moz-selection{background:rgba(232,208,204,.8)}[data-theme=light] *::selection{background:rgba(232,208,204,.8)}[data-theme=light] #footer *::-moz-selection{background:rgba(235,230,229,.666)}[data-theme=light] #footer *::selection{background:rgba(235,230,229,.666)}[data-theme=light] .tag *,[data-theme=light] .tag-link,[data-theme=light] .btn{background:rgba(232,208,204,.8);color:rgba(20,25,26,.666)}[data-theme=light] a:focus{background:#172f33!important;color:#e8d0cc!important}[data-theme=light] .tag a:active{background:#172f33!important;color:#ebe6e5!important}[data-theme=light] .btn:focus,[data-theme=light] .btn:active{outline-color:currentColor}[data-theme=light] #back-to-top{background:rgba(235,230,229,.666);color:rgba(20,25,26,.666)!important}[data-theme=light] #back-to-top:focus,[data-theme=light] #back-to-top:active{background:#ebe6e5}[data-theme=light] #back-to-top:focus,[data-theme=light] #back-to-top:active{outline-color:rgba(20,25,26,.666)}[data-theme=light] hr,[data-theme=light] #stats::before{background:repeating-linear-gradient(to right,#14191a 0,#14191a 1px,transparent 1px,transparent 6px)}[data-theme=light] a{color:#172f33}[data-theme=light] a:focus,[data-theme=light] a:active{background:#14191a;color:#ebe6e5!important}[data-theme=light] strong,[data-theme=light] #footer{background:rgba(232,208,204,.8)}[data-theme=light] figcaption,[data-theme=light] #stats,[data-theme=light] #links li::before{color:rgba(20,25,26,.666)}[data-theme=light] .filter-text-current::after{background:rgba(20,25,26,.666);mix-blend-mode:screen}[data-theme=light] #hero picture,[data-theme=light] .item-cover picture,[data-theme=light] [data-type=blog][data-kind=page] .content picture{mix-blend-mode:multiply}[data-theme=light] .item{border-color:rgba(20,25,26,.333)}@media(hover:hover){[data-theme=light] .btn:hover{background:#e8d0cc}[data-theme=light] #back-to-top:hover{background:#ebe6e5}[data-theme=light] .item:hover{border-color:rgba(20,25,26,.666)}[data-theme=light] .tag a:hover{color:#172f33;background:#e8d0cc}}