*,*:before,*:after{box-sizing:border-box}*{margin:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#1f2937}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}@media (min-width: 640px){.container{padding:0 1.5rem}}@media (min-width: 1024px){.container{padding:0 2rem}}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.flex-grow{flex-grow:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-4>*+*{margin-left:1rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 768px){.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\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid{display:grid}.lg\:grid-cols-\[1fr_250px\]{grid-template-columns:1fr 250px}.lg\:gap-12{gap:3rem}.lg\:block{display:block}}.hidden{display:none}.block{display:block}.inline-flex{display:inline-flex}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:1rem;margin-bottom:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.ml-2{margin-left:.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-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}.pt-8{padding-top:2rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-full{width:100%}.h-4{height:1rem}.h-5{height:1.25rem}.h-16{height:4rem}.max-w-none{max-width:none}.max-w-4xl{max-width:56rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.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}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.leading-tight{line-height:1.25}.text-center{text-align:center}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-800{color:#1f2937}.text-gray-900{color:#111827}.text-blue-600{color:#2563eb}.text-blue-700{color:#1d4ed8}.text-white{color:#fff}.bg-white{background-color:#fff}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-blue-50{background-color:#eff6ff}.bg-blue-100{background-color:#dbeafe}.bg-blue-600{background-color:#2563eb}.border{border-width:1px}.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}.border-gray-100{border-color:#f3f4f6}.border-gray-200{border-color:#e5e7eb}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}.shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px -1px #0000001a}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.transition-colors{transition-property:color,background-color,border-color;transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-duration:.15s}.transition-transform{transition-property:transform;transition-duration:.15s}.sticky{position:sticky}.top-0{top:0}.top-24{top:6rem}.z-50{z-index:50}.overflow-hidden{overflow:hidden}.prose{color:#374151;max-width:65ch}.prose>*+*{margin-top:1.25em}.prose h1{font-size:2.25em;font-weight:800;margin-top:0;margin-bottom:.8em;line-height:1.1;color:#111827}.prose h2{font-size:1.5em;font-weight:700;margin-top:2em;margin-bottom:.5em;line-height:1.3;color:#111827;padding-bottom:.3em;border-bottom:1px solid #e5e7eb}.prose h3{font-size:1.25em;font-weight:600;margin-top:1.6em;margin-bottom:.4em;line-height:1.4;color:#111827}.prose h4{font-size:1em;font-weight:600;margin-top:1.5em;margin-bottom:.3em;color:#111827}.prose-headings\:scroll-mt-20 :is(h1,h2,h3,h4,h5,h6){scroll-margin-top:5rem}.prose p{margin-top:1.25em;margin-bottom:1.25em}.prose a{color:#2563eb;text-decoration:none;font-weight:500;border-bottom:1px solid #93c5fd;transition:all .15s ease}.prose a:hover{color:#1d4ed8;border-bottom-color:#2563eb;background-color:#eff6ff}.prose a code{color:#2563eb}.prose ul{list-style-type:disc;padding-left:1.625em;margin-top:1.25em;margin-bottom:1.25em}.prose ol{list-style-type:decimal;padding-left:1.625em;margin-top:1.25em;margin-bottom:1.25em}.prose li{margin-top:.5em;margin-bottom:.5em}.prose li::marker{color:#6b7280}.prose blockquote{font-style:italic;color:#4b5563;border-left:4px solid #3b82f6;margin:1.6em 0;background-color:#f9fafb;padding:1em;border-radius:0 .5rem .5rem 0}.prose code:not(pre code){background-color:#f3f4f6;color:#1f2937;padding:.2em .4em;border-radius:.375rem;font-size:.875em;font-family:JetBrains Mono,Fira Code,monospace;font-weight:500}.prose pre{background-color:#f6f8fa!important;border:1px solid #e1e4e8;border-radius:.5rem;padding:1rem;overflow-x:auto;font-size:.875em;line-height:1.7;margin:1.5em 0}.prose pre code{background-color:transparent!important;padding:0;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.9em;color:#24292e}.prose .code-block{position:relative}.prose table{width:100%;border-collapse:collapse;margin:2em 0;font-size:.875em}.prose thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.prose th{padding:.75em 1em;text-align:left;font-weight:600;color:#374151}.prose td{padding:.75em 1em;border-bottom:1px solid #e5e7eb}.prose tbody tr:hover{background-color:#f9fafb}.prose img{border-radius:.5rem;margin:2em auto;box-shadow:0 4px 6px -1px #0000001a}.prose figure{margin:2em 0}.prose figcaption{text-align:center;font-size:.875em;color:#6b7280;margin-top:.75em}.prose hr{border:none;border-top:1px solid #e5e7eb;margin:3em 0}.prose input[type=checkbox]{margin-right:.5em}.hover\:text-blue-600:hover{color:#2563eb}.hover\:text-blue-800:hover{color:#1e40af}.hover\:bg-gray-50:hover{background-color:#f9fafb}.hover\:bg-gray-100:hover{background-color:#f3f4f6}.hover\:bg-blue-200:hover{background-color:#bfdbfe}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.hover\:-translate-y-1:hover{transform:translateY(-.25rem)}.group:hover .group-hover\:text-blue-600{color:#2563eb}.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}.backdrop-blur-md{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.bg-white\/90{background-color:#ffffffe6}.post-card{background:#fff;border-radius:.75rem;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.post-card:hover{box-shadow:0 10px 25px -5px #0000001a;transform:translateY(-2px)}.post-card a{text-decoration:none;border-bottom:none}a{text-decoration:none}header a,footer a,nav a{text-decoration:none;border-bottom:none}.toc-link{display:block;color:#6b7280;font-size:.875rem;text-decoration:none;transition:color .15s;border-left:2px solid transparent;padding:.25rem 0 .25rem .75rem}.toc-link:hover{color:#2563eb}.toc-link.active{color:#2563eb;border-left-color:#2563eb}.toc-link.depth-3{padding-left:1.5rem;font-size:.8125rem}.prose pre::-webkit-scrollbar{height:8px}.prose pre::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.prose pre::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.prose pre::-webkit-scrollbar-thumb:hover{background:#a8a8a8}
