*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,Menlo,Monaco,Consolas,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*{border-color:var(--tn-border)}body{background-color:var(--tn-bg-primary);color:var(--tn-fg-primary);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}::selection{background-color:var(--tn-selection);color:var(--tn-fg-primary)}::-moz-selection{background-color:var(--tn-selection);color:var(--tn-fg-primary)}:root{--tn-text-primary: var(--tn-fg-primary);--tn-text-secondary: var(--tn-fg-secondary);--tn-text-muted: var(--tn-fg-muted);--tn-accent-blue: var(--tn-blue);--tn-accent-green: var(--tn-green);--tn-accent-red: var(--tn-red)}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.container{margin-left:auto;margin-right:auto;max-width:80rem;padding-left:1rem;padding-right:1rem}@media (min-width: 640px){.container{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.container{padding-left:2rem;padding-right:2rem}}.btn-secondary{background-color:var(--tn-bg-tertiary);color:var(--tn-fg-primary)}.btn-secondary:hover{background-color:var(--tn-bg-hover)}.btn-secondary{border-radius:.5rem;padding:.75rem 1.5rem;font-weight:500;border-width:1px;border-color:var(--tn-border)}.btn-secondary:hover{border-color:var(--tn-fg-muted)}.btn-secondary{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.card{border-radius:.75rem;background-color:var(--tn-bg-secondary);padding:1.5rem;border-width:1px;border-color:var(--tn-border)}.card:hover{border-color:var(--tn-comment)}.card{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.card:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.link{color:var(--tn-blue)}.link:hover{color:var(--tn-cyan)}.link{text-underline-offset:2px}.link:hover{text-decoration-line:underline}.link{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.tag{border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;background-color:var(--tn-bg-tertiary);color:var(--tn-cyan);border-width:1px;border-color:var(--tn-border)}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-y-0{top:0;bottom:0}.left-4{left:1rem}.left-\[-29px\]{left:-29px}.right-0{right:0}.top-0{top:0}.z-10{z-index:10}.z-50{z-index:50}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:1rem;margin-bottom:1rem}.my-6{margin-top:1.5rem;margin-bottom:1.5rem}.-mr-2{margin-right:-.5rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-10{margin-left:2.5rem}.ml-12{margin-left:3rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.ml-6{margin-left:1.5rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.size-40{width:10rem;height:10rem}.size-5{width:1.25rem;height:1.25rem}.size-6{width:1.5rem;height:1.5rem}.size-full{width:100%;height:100%}.h-0\.5{height:.125rem}.h-16{height:4rem}.h-6{height:1.5rem}.h-auto{height:auto}.h-full{height:100%}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.w-0\.5{width:.125rem}.w-1\.5{width:.375rem}.w-6{width:1.5rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-full{min-width:100%}.max-w-4xl{max-width:56rem}.max-w-7xl{max-width:80rem}.max-w-full{max-width:100%}.max-w-none{max-width:none}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.border-separate{border-collapse:separate}.border-spacing-0{--tw-border-spacing-x: 0px;--tw-border-spacing-y: 0px;border-spacing:var(--tw-border-spacing-x) var(--tw-border-spacing-y)}.-translate-y-1{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-1{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-rotate-45{--tw-rotate: -45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-45{--tw-rotate: 45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in{animation:fadeIn .5s ease-in-out}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-bl{border-bottom-left-radius:.25rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-tn-blue{border-color:var(--tn-blue)}.border-tn-border{border-color:var(--tn-border)}.border-tn-comment{border-color:var(--tn-comment)}.border-tn-green{border-color:var(--tn-green)}.border-tn-red{border-color:var(--tn-red)}.border-tn-yellow{border-color:var(--tn-yellow)}.border-transparent{border-color:transparent}.bg-tn-accent-blue{background-color:var(--tn-accent-blue)}.bg-tn-bg-primary{background-color:var(--tn-bg-primary)}.bg-tn-bg-secondary{background-color:var(--tn-bg-secondary)}.bg-tn-bg-tertiary{background-color:var(--tn-bg-tertiary)}.bg-tn-blue{background-color:var(--tn-blue)}.bg-tn-comment{background-color:var(--tn-comment)}.bg-tn-fg-primary{background-color:var(--tn-fg-primary)}.bg-tn-green{background-color:var(--tn-green)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-3{padding-bottom:.75rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pt-40{padding-top:10rem}.text-left{text-align:left}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.text-tn-accent-blue{color:var(--tn-accent-blue)}.text-tn-blue{color:var(--tn-blue)}.text-tn-cyan{color:var(--tn-cyan)}.text-tn-fg-muted{color:var(--tn-fg-muted)}.text-tn-fg-primary{color:var(--tn-fg-primary)}.text-tn-fg-secondary{color:var(--tn-fg-secondary)}.text-tn-green{color:var(--tn-green)}.text-tn-magenta{color:var(--tn-magenta)}.text-tn-red{color:var(--tn-red)}.text-tn-text-muted{color:var(--tn-text-muted)}.text-tn-text-primary{color:var(--tn-text-primary)}.text-tn-text-secondary{color:var(--tn-text-secondary)}.text-tn-yellow{color:var(--tn-yellow)}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.accent-tn-accent-green{accent-color:var(--tn-accent-green)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.ring-4{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.grayscale{--tw-grayscale: grayscale(100%);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)}.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)}.backdrop-blur-lg{--tw-backdrop-blur: blur(16px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.hljs{background:#16161e!important;color:#a9b1d6!important}.markdown-content pre{background:#16161e!important;margin:1.5rem 0!important;box-sizing:border-box;border-radius:.5rem}.markdown-content code:not(pre code){background:#24283b!important;color:#9ece6a!important;padding:.125rem .375rem;border-radius:.25rem;font-size:.875rem;font-family:JetBrains Mono,monospace}.markdown-content pre code{background:transparent!important}.markdown-content div:has(pre){margin:0!important}.markdown-content input[type=checkbox]{margin-right:.5rem;accent-color:var(--tn-green)}.markdown-content li:has(input[type=checkbox]:checked){color:var(--tn-text-muted);text-decoration:line-through;opacity:.7}.markdown-content li:has(input[type=checkbox]:not(:checked)){color:var(--tn-text-secondary)}.markdown-content img{max-width:100%;height:auto;border-radius:8px;margin:1.5rem 0;box-shadow:0 4px 6px -1px #0000001a}.markdown-content table{border-collapse:separate;border-spacing:0}.markdown-content tbody tr:last-child td:first-child{border-bottom-left-radius:8px}.markdown-content tbody tr:last-child td:last-child{border-bottom-right-radius:8px}.markdown-content tbody tr:last-child td{border-bottom:none}.markdown-content .mermaid{display:flex;justify-content:center;margin:1.5rem 0!important;padding:1rem;background:#16161e!important;border-radius:.5rem;box-sizing:border-box}.markdown-content .mermaid svg{max-width:100%;height:auto}.alert-note{background-color:#7aa2f71a!important;border-color:#7aa2f7!important}.alert-tip{background-color:#9ece6a1a!important;border-color:#9ece6a!important}.alert-warning{background-color:#e0af681a!important;border-color:#e0af68!important}.alert-danger{background-color:#f7768e1a!important;border-color:#f7768e!important}:root{--tn-bg-primary: #1a1b26;--tn-bg-secondary: #16161e;--tn-bg-tertiary: #1e202e;--tn-bg-hover: #14141b;--tn-fg-primary: #a9b1d6;--tn-fg-secondary: #787c99;--tn-fg-muted: #515670;--tn-border: #101014;--tn-selection: #7aa2f740;--tn-highlight: #3d59a1;--tn-comment: #515c7e;--tn-blue: #7aa2f7;--tn-cyan: #7dcfff;--tn-green: #9ece6a;--tn-yellow: #e0af68;--tn-magenta: #bb9af7;--tn-red: #f7768e;--tn-orange: #ff9e64}.light{--tn-bg-primary: #e6e7ed;--tn-bg-secondary: #d6d8df;--tn-bg-tertiary: #dcdee3;--tn-bg-hover: #dadce3;--tn-fg-primary: #343b59;--tn-fg-secondary: #363c4d;--tn-fg-muted: #707280;--tn-border: #c1c2c7;--tn-selection: #2959aa30;--tn-highlight: #2959aa;--tn-comment: #888b94;--tn-blue: #2959aa;--tn-cyan: #0f4b6e;--tn-green: #385f0d;--tn-yellow: #8f5e15;--tn-magenta: #65359d;--tn-red: #8c4351;--tn-orange: #965027}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.first\:rounded-tl-lg:first-child{border-top-left-radius:.5rem}.last\:rounded-tr-lg:last-child{border-top-right-radius:.5rem}.last\:border-r-0:last-child{border-right-width:0px}.hover\:scale-110:hover{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-tn-comment:hover{border-color:var(--tn-comment)}.hover\:bg-tn-bg-hover:hover{background-color:var(--tn-bg-hover)}.hover\:bg-tn-bg-tertiary:hover{background-color:var(--tn-bg-tertiary)}.hover\:text-tn-accent-blue:hover{color:var(--tn-accent-blue)}.hover\:text-tn-blue:hover{color:var(--tn-blue)}.hover\:text-tn-fg-primary:hover{color:var(--tn-fg-primary)}.hover\:text-tn-magenta:hover{color:var(--tn-magenta)}.hover\:text-tn-text-muted:hover{color:var(--tn-text-muted)}.hover\:text-tn-text-primary:hover{color:var(--tn-text-primary)}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-lg:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-sm:hover{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.group:hover .group-hover\:text-tn-accent-blue{color:var(--tn-accent-blue)}.group:hover .group-hover\:text-tn-blue{color:var(--tn-blue)}@media (min-width: 640px){.sm\:mb-12{margin-bottom:3rem}.sm\:mb-16{margin-bottom:4rem}.sm\:mb-4{margin-bottom:1rem}.sm\:mb-6{margin-bottom:1.5rem}.sm\:mb-8{margin-bottom:2rem}.sm\:mt-10{margin-top:2.5rem}.sm\:mt-12{margin-top:3rem}.sm\:w-auto{width:auto}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-10{gap:2.5rem}.sm\:gap-2{gap:.5rem}.sm\:gap-4{gap:1rem}.sm\:gap-6{gap:1.5rem}.sm\:space-y-10>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2.5rem * var(--tw-space-y-reverse))}.sm\:space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.sm\:p-6{padding:1.5rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-8{padding-top:2rem;padding-bottom:2rem}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width: 768px){.md\:flex{display:flex}.md\:hidden{display:none}.md\:size-48{width:12rem;height:12rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}}@media (min-width: 1024px){.lg\:col-span-1{grid-column:span 1 / span 1}.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:mt-12{margin-top:3rem}.lg\:w-80{width:20rem}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:flex-row{flex-direction:row}.lg\:gap-12{gap:3rem}.lg\:gap-6{gap:1.5rem}.lg\:gap-8{gap:2rem}.lg\:space-y-12>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(3rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(3rem * var(--tw-space-y-reverse))}.lg\:space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:py-12{padding-top:3rem;padding-bottom:3rem}.lg\:text-5xl{font-size:3rem;line-height:1}.lg\:text-base{font-size:1rem;line-height:1.5rem}}.znc{color:var(--tn-text-secondary);line-height:1.8}.znc h1,.znc h2,.znc h3,.znc h4,.znc h5,.znc h6{color:var(--tn-text-primary);font-weight:600;margin-top:2rem;margin-bottom:1rem}.znc h1{font-size:2rem;padding-bottom:.75rem;border-bottom:1px solid var(--tn-border)}.znc h2{font-size:1.5rem}.znc h3{font-size:1.25rem}.znc a{color:var(--tn-blue);text-decoration:none}.znc a:hover{text-decoration:underline}.znc pre{background-color:#16161e;border-radius:.5rem;padding:1rem;overflow-x:auto}.znc code{font-family:Consolas,Monaco,Courier New,monospace}.znc :not(pre)>code{background-color:var(--tn-bg-tertiary);color:var(--tn-magenta);padding:.2rem .4rem;border-radius:.25rem;font-size:.875em}.znc table{border-collapse:collapse;width:100%;margin:1.5rem 0}.znc th,.znc td{border:1px solid var(--tn-border);padding:.75rem;text-align:left}.znc th{background-color:var(--tn-bg-tertiary);color:var(--tn-text-primary);font-weight:600}.znc blockquote{border-left:4px solid var(--tn-comment);background-color:var(--tn-bg-tertiary);padding:1rem;margin:1.5rem 0;border-radius:.5rem}.znc ul,.znc ol{margin:1rem 0;padding-left:2rem}.znc li{margin:.5rem 0}.znc hr{border:none;border-top:1px solid var(--tn-border);margin:2rem 0}.znc img{max-width:100%;height:auto;border-radius:.5rem;margin:1.5rem 0}.znc .msg{padding:1rem;margin:1.5rem 0;border-radius:.5rem;border-left:4px solid}.znc .msg.msg-info{background-color:#7dcfff1a;border-left-color:var(--tn-blue)}.znc .msg.msg-alert{background-color:#f7768e1a;border-left-color:var(--tn-red)}.znc .msg.msg-warn{background-color:#e0af681a;border-left-color:var(--tn-yellow)}.znc details{margin:1.5rem 0;padding:1rem;border:1px solid var(--tn-border);border-radius:.5rem;background-color:var(--tn-bg-secondary)}.znc details summary{cursor:pointer;font-weight:600;color:var(--tn-text-primary);-webkit-user-select:none;-moz-user-select:none;user-select:none}.znc details summary:hover{opacity:.8}.znc details[open] summary{margin-bottom:1rem}.znc input[type=checkbox]{margin-right:.5rem;accent-color:var(--tn-green)}.znc p{margin:1rem 0}.znc .code-block-filename-container{background-color:var(--tn-bg-tertiary);border-top-left-radius:.5rem;border-top-right-radius:.5rem;padding:.5rem 1rem;font-size:.875rem;color:var(--tn-text-muted);border-bottom:1px solid var(--tn-border)}.znc .code-block-filename{font-family:Consolas,Monaco,Courier New,monospace}.znc .code-block-container pre{border-top-left-radius:0;border-top-right-radius:0;margin-top:0}.znc .footnotes{margin-top:3rem;padding-top:1rem;border-top:1px solid var(--tn-border)}.znc .footnotes-title{font-weight:600;font-size:1.1rem;color:var(--tn-text-primary);margin-bottom:.5rem;display:block}.znc .footnotes-list{font-size:.9rem;color:var(--tn-text-secondary)}.znc .footnote-ref a{color:var(--tn-blue);text-decoration:none}.znc .footnote-backref{color:var(--tn-blue);text-decoration:none;margin-left:.25rem}.znc .embed-block{display:block;margin:1.5rem 0}.znc .embed-block iframe{width:100%;border:1px solid var(--tn-border);border-radius:.5rem}.znc .embed-youtube iframe{aspect-ratio:16 / 9;min-height:400px}.znc .embed-codepen iframe{height:500px}.znc .zenn-embedded iframe{min-height:200px}.znc .zenn-link-card{display:flex;text-decoration:none;margin:0;border-radius:.5rem;border:1px solid var(--tn-border);overflow:hidden;transition:all .2s ease;height:128px}.znc .zenn-link-card:hover{border-color:var(--tn-blue);box-shadow:0 10px 15px -3px #0000001a}.znc p:has(.zenn-link-card){margin:1.5rem 0;padding:0;line-height:0}.znc .zenn-link-card>div:first-child{flex:1;padding:.75rem 1rem;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.375rem}.znc .zenn-link-card>div:last-child{width:256px;height:128px;flex-shrink:0;align-self:stretch}.znc .zenn-link-card>div:last-child img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;display:block;margin:0!important;border-radius:0!important}.znc .ogp-card-title{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;font-weight:500;color:var(--tn-text-primary);line-height:1.4}.znc .ogp-card-description{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;font-size:.875rem;color:var(--tn-text-secondary);line-height:1.4}.znc .ogp-card-domain{font-size:.75rem;color:var(--tn-text-muted);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (prefers-color-scheme: dark){.znc{color:var(--tn-text-secondary)}}
