@layer reset;@layer theme{:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;--max-width-container:42.5rem;--max-width-container-large:67.5rem;--nav-height:3.438rem;--border-radius-s:.375rem;--border-radius:.5rem;--border-radius-l:1rem;--line-height:1.5625;--line-height-s:1.4;--font-size-base:100%;--font-size-code:.9rem;--font-primary:"Inter", sans-serif;--font-secondary:"Victor Mono", sans-serif;--font-monospace:"Fira Code", monospace;--color-blue:#007ab7;--color-purple:#660087;--chroma-purple:.95;--color-red:#c06e59;--chroma-red:.95;--color-green:#37946e;--chroma-green:.95;--color-green-05:oklch(from var(--color-green) 18% calc(.08 * var(--chroma-green,c / .2)) h);--color-green-10:oklch(from var(--color-green) 23.5% calc(.1 * var(--chroma-green,c / .2)) h);--color-green-20:oklch(from var(--color-green) 32% calc(.135 * var(--chroma-green,c / .2)) h);--color-green-30:oklch(from var(--color-green) 47.5% calc(.16 * var(--chroma-green,c / .2)) h);--color-green-40:oklch(from var(--color-green) 44.5% calc(.185 * var(--chroma-green,c / .2)) h);--color-green-50:oklch(from var(--color-green) 56.5% calc(.2 * var(--chroma-green,c / .2)) h);--color-green-60:oklch(from var(--color-green) 66.5% calc(.175 * var(--chroma-green,c / .2)) h);--color-green-70:oklch(from var(--color-green) 74.5% calc(.13 * var(--chroma-green,c / .2)) h);--color-green-80:oklch(from var(--color-green) 83% calc(.085 * var(--chroma-green,c / .2)) h);--color-green-90:oklch(from var(--color-green) 91.5% calc(.04 * var(--chroma-green,c / .2)) h);--color-green-95:oklch(from var(--color-green) 95.5% calc(.02 * var(--chroma-green,c / .2)) h);--color-hover:oklch(from var(--color-green) 50% calc(.16 * var(--chroma-green,c / .2)) h);--color-link:var(--color-green-50);--color-link-visited:var(--color-purple);--color-border-muted:var(--lightningcss-light,oklch(92% 8.42937e-9 45))var(--lightningcss-dark,oklch(40% 3.37175e-8 45));--brand:var(--lightningcss-light,var(--color-green))var(--lightningcss-dark,var(--color-green-90));--link:var(--lightningcss-light,var(--color-link))var(--lightningcss-dark,oklch(from var(--color-link) 83.5% calc(.085 * var(--chroma-green,c / .2)) h));--link-hover:var(--lightningcss-light,oklch(from var(--color-link) 40% calc(.16 * var(--chroma-green,c / .2)) h))var(--lightningcss-dark,oklch(from var(--color-link) 87% calc(.04 * var(--chroma-green,c / .2)) h));--link-visited:var(--lightningcss-light,oklch(from var(--color-link-visited) 57% calc(.2 * var(--chroma-purple,c / .2)) h))var(--lightningcss-dark,oklch(from var(--color-link-visited) 83.5% calc(.085 * var(--chroma-purple,c / .2)) h));--link-visited-hover:var(--lightningcss-light,oklch(from var(--color-link-visited) 40% calc(.16 * var(--chroma-purple,c / .2)) h))var(--lightningcss-dark,oklch(from var(--color-link-visited) 92% calc(.04 * var(--chroma-purple,c / .2)) h));--text:var(--lightningcss-light,#111)var(--lightningcss-dark,#fefefe);--text-muted:var(--lightningcss-light,#6c757d)var(--lightningcss-dark,#adb5bd);--text-inverted:var(--lightningcss-light,#fff)var(--lightningcss-dark,#000);--text-code:var(--lightningcss-light,oklch(from var(--color-red) 45% calc(.15 * var(--chroma-red,c / .2)) h))var(--lightningcss-dark,oklch(from var(--color-red) 83.5% calc(.09 * var(--chroma-red,c / .2)) h));--surface-1:var(--lightningcss-light,#fff)var(--lightningcss-dark,#101c2e);--surface-2:var(--lightningcss-light,#e9ecef)var(--lightningcss-dark,#142337);--surface-3:var(--lightningcss-light,#eaeaeb)var(--lightningcss-dark,#16263b);--surface-4:var(--lightningcss-light,#dedfe0)var(--lightningcss-dark,#1b2d45);color:#000;background-color:#f8f9fa}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}html .shiki,html .shiki span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;-webkit-text-decoration:var(--shiki-dark-text-decoration)!important;text-decoration:var(--shiki-dark-text-decoration)!important}}}@layer base{*,:before,:after{box-sizing:border-box}html{font-size:var(--font-size-base)}body{background-color:var(--surface-1);font-family:var(--font-primary);min-height:100dvh;color:var(--text);line-height:var(--line-height);font-size:var(--font-size-base);flex-direction:column;margin:0;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-secondary);overflow-wrap:break-word}li{margin-block-end:.5rem}ol{padding-inline-start:20px}a{color:var(--link);-webkit-text-decoration-color:var(--link);text-decoration-color:var(--link);overflow-wrap:break-word}a:hover{color:var(--link-hover);text-decoration:underline;-webkit-text-decoration-color:var(--link-hover);text-decoration-color:var(--link-hover)}a:not(.nav-link,.link-not-visited):visited{color:var(--link-visited);-webkit-text-decoration-color:var(--link-visited);text-decoration-color:var(--link-visited)}a:not(.nav-link,.link-not-visited):visited:hover{color:var(--link-visited-hover);-webkit-text-decoration-color:var(--link-visited-hover);text-decoration-color:var(--link-visited-hover)}button{background-color:var(--color-green);text-align:center;vertical-align:middle;border-radius:var(--border-radius);border:1px solid var(--surface-3);cursor:pointer;gap:.5rem;padding:.5rem}button:hover{background-color:var(--color-hover)}code{color:var(--text-code);font-size:var(--font-size-code);font-family:var(--font-monospace);line-height:var(--line-height)}p{margin:0;margin-block-end:30px}}@layer typography{@font-face{font-family:Inter;src:url(/fonts/Inter-VariableFont_opsz,wght.woff2)format("woff2-variations");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/fonts/Inter-Italic-VariableFont_opsz,wght.woff2)format("woff2-variations");font-weight:100 900;font-style:italic;font-display:swap}@font-face{font-family:Victor Mono;src:url(/fonts/VictorMono-Regular.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Fira Code;src:url(/fonts/FiraCode-VF.woff2)format("woff2-variations");font-weight:100 900;font-style:normal;font-display:swap}.font-secondary{font-family:var(--font-secondary)}}@layer layout{.nav{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.nav a{color:var(--text);text-decoration:none}.nav ul{gap:.5rem;margin:0;padding:0;display:flex}.nav ul li{margin:0;list-style:none}.nav ul li a{border-radius:var(--border-radius);display:flex}.nav>ul li:has([aria-current=page]){-webkit-text-decoration:underline wavy;text-decoration:underline wavy;-webkit-text-decoration-color:var(--link);text-decoration-color:var(--link);text-underline-offset:5px}.list-no-style{padding-inline-start:0}.list-no-style li{list-style:none}.list-no-style li a{align-items:center;gap:1rem;display:flex}.main{flex-direction:column;flex:auto;display:flex}.content{width:100%;max-width:var(--max-width-container)}.container{width:min(var(--max-width-container), 100% - 1rem);min-width:0;margin-inline:auto;padding:1rem;overflow-x:hidden}.container-large{width:min(var(--max-width-container-large), 100% - 1rem);min-width:0;margin-inline:auto;padding:1rem;overflow-x:hidden}.app{flex-direction:column;flex:auto;margin-top:3rem;display:flex}.footer{flex-direction:column;padding:1rem;display:flex}.footer .footer__row{place-content:center space-between;display:flex}.footer .footer__row .footer__row__text{font-family:var(--font-secondary);font-optical-sizing:auto;color:var(--text-muted);font-size:.8rem;font-style:normal;font-weight:500}.footer .footer__row .footer__row__links{gap:1.5rem;display:flex}.footer .footer__row .footer__row__links .footer__row__links__icon{width:1.25rem;height:1.25rem;fill:var(--text-muted);transition:fill .2s}.footer .footer__row .footer__row__links .footer__row__links__icon:hover{fill:var(--brand)}#btn-scroll-top{border-radius:var(--border-radius);background-color:var(--surface-3);color:var(--text);cursor:pointer;opacity:.9;border:none;padding:.75rem 1rem;transition:opacity .3s;display:none;position:fixed;bottom:30px;right:16px;box-shadow:0 2px 6px #0000004d}#btn-scroll-top:hover{background-color:var(--surface-4)}@media (width>=648px){.container{width:min(var(--max-width-container), 100% - 1rem)}#btn-scroll-top{margin-left:336px;left:50%;right:auto}}}@layer utilities{.wavy-link{text-underline-offset:4px;transition:text-underline-offset .2s}.wavy-link:hover{text-underline-offset:5px;-webkit-text-decoration:underline wavy;text-decoration:underline wavy;-webkit-text-decoration-color:var(--color-green);text-decoration-color:var(--color-green)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.mb-3{margin-bottom:1rem}.gap{gap:.5rem}.gap-l{gap:1rem}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.flex-centered{justify-content:center;align-items:center}}@layer animations{@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.6s forwards fade-in-up}@media (prefers-reduced-motion:reduce){.fade-up{animation:none}}}@layer app{.icon{width:1.375rem;height:1.375rem;color:var(--text-muted)}.icon:hover{color:var(--brand)}.svg-icon{width:1.375rem;height:1.375rem;color:inherit}.form-group{flex-direction:column;display:flex}.form-control{color:var(--text);background-color:var(--surface-2);border-color:var(--surface-3);border-radius:var(--border-radius);padding:.5rem;font-size:1rem;transition:background-color .3s,border-color .3s}.form-control:focus{border-color:var(--brand);outline:none}.form-control::placeholder{color:var(--text-muted)}.form-control:-webkit-autofill{-webkit-text-fill-color:var(--text);-webkit-box-shadow:0 0 0 1000px var(--surface-2) inset;transition:background-color,border-color}.form-control:-webkit-autofill:hover{-webkit-text-fill-color:var(--text);-webkit-box-shadow:0 0 0 1000px var(--surface-2) inset;transition:background-color,border-color}.form-control:-webkit-autofill:focus{-webkit-text-fill-color:var(--text);-webkit-box-shadow:0 0 0 1000px var(--surface-2) inset;transition:background-color,border-color}.form-control:-webkit-autofill:active{-webkit-text-fill-color:var(--text);-webkit-box-shadow:0 0 0 1000px var(--surface-2) inset;transition:background-color,border-color}.alert{border:1px solid var(--color-border-muted);background-color:var(--surface-2);border-radius:var(--border-radius-l);padding:1rem}.alert>:last-child{margin-block-end:0}.card{border-radius:var(--border-radius-l);color:var(--text);background-color:var(--surface-2);flex-direction:column;flex:auto;width:100%;padding:2rem;display:flex;overflow:auto}.card h1{margin-top:0}.card h2{margin-bottom:.5rem}.card .form-control{background-color:var(--surface-1)}.article{border-radius:var(--border-radius-l)}.article hr{margin-bottom:2rem}.article .article__footer{gap:.5rem;margin-top:1rem;display:flex}}@layer shiki{.code-wrapper{border-radius:var(--border-radius-s);border:1px solid var(--surface-4);background-color:var(--surface-3);margin-block-end:2rem;position:relative;overflow:hidden}pre.shiki{margin:0;padding:1.25rem 1rem;overflow-x:auto;background-color:var(--surface-2)!important}pre.shiki code{width:max-content;min-width:100%;padding-right:3rem;display:block}.copy-icon{width:1rem;height:1rem;color:var(--text-muted);place-content:center;display:flex}.code-wrapper:hover .btn-copy{opacity:1}.btn-copy{cursor:pointer;color:var(--text-muted);opacity:0;background-color:#0000;border:none;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;transition:opacity .2s;position:absolute;top:.5rem;right:.5rem}.btn-copy:hover{background:var(--surface-3)}.btn-copy:focus-visible{opacity:1}.icon-check{color:var(--color-green);display:none}.btn-copy.copied .icon-copy{display:none}.btn-copy.copied .icon-check{display:block}}@layer pages{.hsl{flex-wrap:wrap;justify-content:space-between;gap:.5rem;margin-bottom:3rem;display:flex}.hsl .hsl__form-group{flex-direction:column;width:9.688rem;display:flex}.hex{flex-wrap:wrap;margin-bottom:2rem;display:flex}.hex .hex__form-group{flex-direction:column;width:9.375rem;display:flex}.color{flex-direction:column;justify-content:center;align-items:center;gap:1rem;margin-bottom:3rem;display:flex}.color .color__block{border:1px solid var(--surface-4);width:100%;height:6.25rem}.pixel-rem-calc{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:3rem;display:flex}.pixel-rem-calc .pixel-rem-calc__form{flex-direction:column;gap:1rem;width:100%;display:flex}.pixel-rem-calc .pixel-rem-calc__bidirect-icon{min-width:1.5rem;min-height:1.5rem;color:var(--text-muted);display:none;position:relative;top:1rem}@media (width>=768px){.pixel-rem-calc{flex-wrap:nowrap}.pixel-rem-calc .pixel-rem-calc__bidirect-icon{display:flex}}.em-pixel-converter{flex-direction:column;gap:1rem;max-width:15rem;display:flex}.metronome{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text);border-radius:18px;padding:1.5rem 2rem}.metronome .metronome__top{justify-content:space-between;align-items:baseline;margin-bottom:.95rem;display:flex}.metronome .metronome__top h1{margin:0 0 1rem}.metronome .metronome__top .metronome__top__status{opacity:.8;font-size:14px}.metronome .metronome__top .metronome__top__beat{justify-content:flex-end;align-items:center;gap:10px;display:flex}.metronome .metronome__top .metronome__top__beat .beat-dot{opacity:.7;background:#ffffff40;border:1px solid #ffffff2e;border-radius:999px;width:14px;height:14px;transform:scale(1)}.metronome .metronome__top .metronome__top__beat .beat-dot.on{opacity:1;animation:.12s ease-out pop}.metronome .metronome__top .metronome__top__beat .beat-dot.accent{box-shadow:0 0 0 6px #78b4ff26}.metronome .metronome__time-sig{grid-template-columns:1fr 1fr;gap:12px;margin-top:10px;margin-bottom:2rem;display:grid}@media (width<=440px){.metronome .metronome__time-sig{grid-template-columns:1fr}}.metronome .metronome__bpm-row{justify-content:center;align-items:baseline;margin-bottom:1rem;display:flex}.metronome .metronome__bpm-row .metronome__bpm-row__bpm-value{letter-spacing:-1px;font-size:56px;font-weight:800}.metronome .metronome__slider{width:100%;margin:8px 0 14px}.metronome .metronome__controls{grid-template-columns:1fr 2fr 1fr;gap:10px;margin-bottom:2rem;display:grid}.metronome .metronome__bottom{justify-content:center;align-items:center;margin-top:10px;display:flex}.metro-field{gap:6px;display:grid}.metro-field span{opacity:.82;font-size:13px}.metro-field select{height:40px;color:inherit;border:1px solid #ffffff1f;border-radius:12px;outline:none;padding:0 10px}.metro-btn{background:var(--surface-4);height:46px;color:var(--text);cursor:pointer;border:none;border-radius:14px;font-size:16px;transition:transform 80ms,background .12s,border-color .12s}.metro-btn:hover{background:var(--surface-1)}.metro-btn:active{transform:translateY(1px)scale(.99)}.metro-btn.primary{color:var(--text-inverted);background:var(--brand);font-weight:700}.metro-btn.ghost{font-size:20px;font-weight:700}@keyframes pop{0%{transform:scale(.85)}to{transform:scale(1.15)}}.search-controls{margin-bottom:2rem}.search-controls input{width:100%}.tag-filters{flex-wrap:wrap;gap:.5rem;margin-bottom:3rem;display:flex}.tag-filter{background-color:var(--surface-4);cursor:pointer;border-radius:var(--border-radius);border:1px solid #0000;padding:.5rem;font-size:1rem;display:inline-block}.tag-filter:hover{background-color:var(--surface-3)}.tag-filter.active{background-color:var(--color-red);color:#fff}.search-results{padding-inline-start:0}.post-link{flex-wrap:wrap-reverse;display:flex}.post-link .post-link__title{flex:1}.post-link .post-link__date{flex:0 auto;justify-content:flex-end;min-width:180px;padding:.25rem}.post-link .post-link__category{flex:0 auto;min-width:70px;padding:.25rem}.post-link .post-link__tag{border:1px solid var(--text-muted);padding:.25rem}}
