@layer base{html{scroll-behavior:smooth}body{font-feature-settings:"liga" 1,"kern" 1}}~45px h3{font-size:2rem}/*! tailwindcss v4.1.12 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-leading:initial;--tw-font-weight:initial;--tw-border-style:solid;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-duration:initial;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0}}}@layer theme{:root,:host{--font-sans:"Lato",sans-serif;--font-serif:ui-serif,Georgia,Cambria,"Times New Roman",Times,serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-100:oklch(93.6% .032 17.717);--color-red-400:oklch(70.4% .191 22.216);--color-red-700:oklch(50.5% .213 27.518);--color-yellow-100:oklch(97.3% .071 103.193);--color-yellow-400:oklch(85.2% .199 91.936);--color-yellow-700:oklch(55.4% .135 66.442);--color-green-200:oklch(92.5% .084 155.995);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-green-800:oklch(44.8% .119 151.328);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-800:oklch(42.4% .199 265.638);--color-pink-300:oklch(82.3% .12 346.018);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-3xl:48rem;--container-4xl:56rem;--container-6xl:72rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--text-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-black:900;--leading-tight:1.25;--leading-relaxed:1.625;--radius-md:.375rem;--radius-lg:.5rem;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-pink:#dd7896;--color-cyan:#569c9a;--color-light-yellow:#fee2a3;--color-gray-blue:#d0e1eb;--color-gray-cyan:#b8d0d2;--color-gray-purple:#d3bbdf;--color-gray-magenta:#a289a7;--font-script:"Annie Use Your Telescope",script}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}html{scroll-behavior:smooth}body{font-feature-settings:"liga" 1,"kern" 1}}@layer components{.btn-primary{border-radius:var(--radius-lg);padding-inline:calc(var(--spacing)*6);padding-block:calc(var(--spacing)*3);--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));color:#fff;background-color:#569c9a}.btn-primary:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y);box-shadow:var(--shadow-custom)}.project-card{margin-top:calc(var(--spacing)*2);position:relative}.project-title{font-family:var(--font-sans);font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height));-webkit-text-decoration-color:var(--color-gray-300);text-decoration-color:var(--color-gray-300);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.project-title:hover{-webkit-text-decoration-color:var(--color-gray-500);text-decoration-color:var(--color-gray-500)}}.tech-tag{padding-inline:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*1);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));color:var(--color-gray-700);background-color:var(--color-gray-blue);border-radius:.25rem;display:inline-block}.tech-tag-large{background-color:var(--color-blue-100);padding-inline:calc(var(--spacing)*3);padding-block:calc(var(--spacing)*1);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));color:var(--color-blue-800);border-radius:3.40282e38px;display:inline-block}.tool-tag{padding-inline:calc(var(--spacing)*3);padding-block:calc(var(--spacing)*1);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));background-color:var(--color-gray-blue);border-radius:3.40282e38px;display:inline-block}.project-links{margin-top:calc(var(--spacing)*1)}:where(.project-links>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*4)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-x-reverse)))}.project-links{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.project-link{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));text-decoration-line:underline}@media (hover:hover){.project-link:hover{color:var(--color-blue-800)}}.project-link{color:var(--color-cyan)}.project-link--live{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));text-decoration-line:underline}@media (hover:hover){.project-link--live:hover{color:var(--color-green-800)}}.project-link--live{color:var(--color-cyan)}.month-section{margin-bottom:calc(var(--spacing)*8)}.blog-post-item{margin-top:calc(var(--spacing)*2)}.blog-post-item:first-child{margin-top:calc(var(--spacing)*0)}.post-tag-inline{padding-inline:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*.5);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));color:var(--color-gray-600);border-radius:.25rem;flex-shrink:0;display:inline-block}.recent-posts-section{margin-top:calc(var(--spacing)*15);border-top-style:var(--tw-border-style);border-top-width:1px;border-color:var(--color-gray-200);padding-top:calc(var(--spacing)*8)}.recent-posts-grid{gap:calc(var(--spacing)*4);grid-template-columns:repeat(1,minmax(0,1fr));display:grid}@media (min-width:40rem){.recent-posts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:64rem){.recent-posts-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.recent-post-card-horizontal{border-radius:var(--radius-lg);border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-200);transition-property:box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.recent-post-card-horizontal:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.recent-post-card-horizontal{flex-direction:column;height:100%;display:flex}.recent-post-content{padding:calc(var(--spacing)*4);flex-direction:column;flex:1;display:flex}.recent-post-title{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height));color:var(--color-gray-900);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.recent-post-title:hover{color:var(--color-gray-600)}}.recent-post-title{-webkit-text-decoration-color:var(--color-gray-300);text-decoration-color:var(--color-gray-300)}@media (hover:hover){.recent-post-title:hover{-webkit-text-decoration-color:var(--color-gray-500);text-decoration-color:var(--color-gray-500)}}.recent-post-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.recent-post-date{margin-top:calc(var(--spacing)*2);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));color:var(--color-gray-400);display:block}.recent-post-excerpt{margin-top:calc(var(--spacing)*3);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed);color:var(--color-gray-500);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;display:-webkit-box;overflow:hidden}.recent-post-tags{margin-top:calc(var(--spacing)*3);gap:calc(var(--spacing)*1);flex-wrap:wrap;display:flex}.recent-post-card{border-radius:var(--radius-lg);border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-200);padding:calc(var(--spacing)*4);transition-property:box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (hover:hover){.recent-post-card:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.post-tag{background-color:var(--color-gray-100);padding-inline:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*1);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));color:var(--color-gray-600);border-radius:.25rem;display:inline-block}.tag-filter-container{margin-bottom:calc(var(--spacing)*8);padding:calc(var(--spacing)*4);background:0 0}.tag-filter-title{margin-bottom:calc(var(--spacing)*3);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.tag-filter-list{gap:calc(var(--spacing)*3);flex-wrap:wrap;display:flex}.tag-filter-item{cursor:pointer;padding-inline:calc(var(--spacing)*3);padding-block:calc(var(--spacing)*1);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-300);background-color:#fffc;border-radius:3.40282e38px}@supports (color:color-mix(in lab,red,red)){.tag-filter-item{background-color:color-mix(in oklab,var(--color-white)80%,transparent)}}.tag-filter-item{color:var(--color-gray-700);--tw-backdrop-blur:blur(var(--blur-sm));-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,)}@media (hover:hover){.tag-filter-item:hover{border-color:var(--color-gray-400)}}.tag-filter-item{box-shadow:0 1px 2px #0000000d}.tag-filter-item.active{border-color:var(--color-gray-100);color:var(--color-white);background-color:var(--color-cyan)}.tag-filter-item:hover{background-color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.tag-filter-item:hover{background-color:color-mix(in oklab,var(--color-white)90%,transparent)}}.tag-filter-item:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.tag-filter-clear{cursor:pointer;font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));color:var(--color-gray-500);text-decoration-line:underline}@media (hover:hover){.tag-filter-clear:hover{color:var(--color-gray-700)}}.portfolio-grid{column-count:1;column-fill:balance;column-gap:.5rem}@media (min-width:640px){.portfolio-grid{column-count:2;column-gap:.75rem}}@media (min-width:1024px){.portfolio-grid{column-count:3;column-gap:1rem}}.portfolio-card{margin-bottom:calc(var(--spacing)*3);border-radius:var(--radius-lg);border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-200);transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));--tw-duration:.3s;transition-duration:.3s;position:relative;overflow:hidden}@media (hover:hover){.portfolio-card:hover{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y);--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.portfolio-card{break-inside:avoid;width:100%;display:inline-block}.portfolio-image-natural{object-fit:cover;width:100%;transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));--tw-duration:.3s;height:auto;transition-duration:.3s;display:block}.portfolio-overlay{inset:calc(var(--spacing)*0);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));--tw-duration:.3s;background:0 0;align-items:flex-end;transition-duration:.3s;display:flex;position:absolute}.portfolio-card:hover .portfolio-overlay{background-color:var(--color-pink);opacity:.8}.portfolio-overlay-content{padding:calc(var(--spacing)*2);color:var(--color-white);opacity:0;transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));--tw-duration:.3s;transition-duration:.3s}@media (hover:hover){.portfolio-overlay-content:hover{opacity:1}}.portfolio-overlay-title{margin-bottom:calc(var(--spacing)*1);font-family:var(--font-serif);font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.portfolio-overlay-tags{gap:calc(var(--spacing)*1);flex-wrap:wrap;display:flex}.portfolio-overlay-tag{background-color:#fff3;border-radius:.25rem}@supports (color:color-mix(in lab,red,red)){.portfolio-overlay-tag{background-color:color-mix(in oklab,var(--color-white)20%,transparent)}}.portfolio-overlay-tag{padding-inline:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*1);font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.page-header{margin-bottom:calc(var(--spacing)*6);border-bottom-style:var(--tw-border-style);border-bottom-width:1px;border-color:var(--color-gray-200);padding-bottom:calc(var(--spacing)*6)}.page-title{margin-top:calc(var(--spacing)*2);margin-bottom:calc(var(--spacing)*3);font-family:var(--font-script);font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height));--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.page-meta{align-items:center;gap:calc(var(--spacing)*4);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));color:var(--color-gray-600);flex-wrap:wrap;display:flex}.category-tag{background-color:var(--color-gray-100);padding-inline:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*1);color:var(--color-gray-700);border-radius:.25rem}.btn-github{border-radius:var(--radius-lg);padding-inline:calc(var(--spacing)*4);padding-block:calc(var(--spacing)*2);color:var(--color-white);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));align-items:center;display:inline-flex}@media (hover:hover){.btn-github:hover{background-color:var(--color-gray-800)}}.btn-demo{border-radius:var(--radius-lg);background-color:var(--color-green-600);padding-inline:calc(var(--spacing)*4);padding-block:calc(var(--spacing)*2);color:var(--color-white);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));align-items:center;display:inline-flex}@media (hover:hover){.btn-demo:hover{background-color:var(--color-green-700)}}.btn-back{color:var(--color-gray-600);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));align-items:center;display:inline-flex}@media (hover:hover){.btn-back:hover{color:var(--color-gray-900)}}.featured-image-container{margin-bottom:calc(var(--spacing)*6);border-radius:var(--radius-lg);border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-200);overflow:hidden}.featured-image{background-color:var(--color-gray-50);object-fit:contain;width:100%;height:auto;max-height:70vh}.section-header{margin-top:calc(var(--spacing)*5);margin-bottom:calc(var(--spacing)*6);font-family:var(--font-sans);font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.month-header{margin-top:calc(var(--spacing)*6);margin-bottom:calc(var(--spacing)*-1);--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);color:var(--color-gray-400)}.month-header:first-of-type{margin-top:calc(var(--spacing)*2)}.tools-section{margin-top:calc(var(--spacing)*4)}.tools-label{margin-bottom:calc(var(--spacing)*2);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.tools-list{gap:calc(var(--spacing)*2);flex-wrap:wrap;display:flex}.nav-section{margin-top:calc(var(--spacing)*12);border-top-style:var(--tw-border-style);border-top-width:1px;border-color:var(--color-gray-200);padding-top:calc(var(--spacing)*6)}:where(.section-group>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*0)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*0)*calc(1 - var(--tw-space-y-reverse)))}.status-error{margin-bottom:calc(var(--spacing)*4);border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-red-400);background-color:var(--color-red-100);padding-inline:calc(var(--spacing)*4);padding-block:calc(var(--spacing)*3);color:var(--color-red-700);border-radius:.25rem}.status-warning{margin-bottom:calc(var(--spacing)*4);border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-yellow-400);background-color:var(--color-yellow-100);padding-inline:calc(var(--spacing)*4);padding-block:calc(var(--spacing)*3);color:var(--color-yellow-700);border-radius:.25rem}.status-list{margin-top:calc(var(--spacing)*2);list-style-type:disc;list-style-position:inside}}@layer utilities{.\@container{container-type:inline-size}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing)*0)}.-top-20{top:calc(var(--spacing)*-20)}.-top-30{top:calc(var(--spacing)*-30)}.top-0{top:calc(var(--spacing)*0)}.top-1\/2{top:50%}.top-1\/4{top:25%}.top-4{top:calc(var(--spacing)*4)}.top-10{top:calc(var(--spacing)*10)}.top-15{top:calc(var(--spacing)*15)}.top-20{top:calc(var(--spacing)*20)}.top-full{top:100%}.-right-10{right:calc(var(--spacing)*-10)}.-right-16{right:calc(var(--spacing)*-16)}.-right-20{right:calc(var(--spacing)*-20)}.-right-25{right:calc(var(--spacing)*-25)}.right-0{right:calc(var(--spacing)*0)}.right-4{right:calc(var(--spacing)*4)}.-bottom-10{bottom:calc(var(--spacing)*-10)}.-bottom-20{bottom:calc(var(--spacing)*-20)}.-bottom-40{bottom:calc(var(--spacing)*-40)}.bottom-10{bottom:calc(var(--spacing)*10)}.bottom-48{bottom:calc(var(--spacing)*48)}.bottom-60{bottom:calc(var(--spacing)*60)}.-left-2{left:calc(var(--spacing)*-2)}.-left-6{left:calc(var(--spacing)*-6)}.-left-10{left:calc(var(--spacing)*-10)}.-left-20{left:calc(var(--spacing)*-20)}.-left-25{left:calc(var(--spacing)*-25)}.-left-40{left:calc(var(--spacing)*-40)}.left-0{left:calc(var(--spacing)*0)}.z-0{z-index:0}.z-10{z-index:10}.z-50{z-index:50}.prose{font-family:var(--font-sans);font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height));--tw-leading:1.5;line-height:1.5}@container (min-width:24rem){.prose{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}.prose h2,.prose h3{font-family:var(--font-script);--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold);margin-top:calc(var(--spacing)*4)!important;margin-bottom:calc(var(--spacing)*6)!important}:is(.prose h2,.prose h3)+*{margin-top:calc(var(--spacing)*0)!important}.prose h2{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height));--tw-leading:1.2;line-height:1.2}.prose h3{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height));--tw-leading:1.5;line-height:1.5}.prose>p{margin-block:calc(var(--spacing)*5)}.prose>:not(p),.prose>p:has(>img),.prose p>img{margin-block:calc(var(--spacing)*8)}.prose :first-child{margin-top:calc(var(--spacing)*2)}.prose :last-child{margin-bottom:calc(var(--spacing)*0)}.prose ul{list-style-type:" ❥ "}.prose ol{list-style-type:decimal}.prose ul,.prose ol{margin-top:calc(var(--spacing)*0);padding-left:calc(var(--spacing)*5)}.prose li{margin-block:calc(var(--spacing)*1)}.prose li::marker{color:var(--color-gray-400)}.prose a{color:var(--color-pink);text-decoration-line:underline}.prose hr{margin-top:calc(var(--spacing)*16);margin-bottom:calc(var(--spacing)*13);--tw-border-style:none;border-style:none;height:auto}.prose hr:before{content:"✮  ✮  ✮";text-align:center;color:var(--color-gray-400);display:block}.prose img,.prose video{border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-200)}.prose pre{border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-200);padding-inline:calc(var(--spacing)*3);padding-block:calc(var(--spacing)*2);font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height));--tw-leading:1.5;line-height:1.5}.prose code:not(pre code){border-style:var(--tw-border-style);border-width:1px;border-color:var(--color-gray-200);background-color:var(--color-white);-webkit-box-decoration-break:clone;box-decoration-break:clone;padding-inline:calc(var(--spacing)*1);padding-block:calc(var(--spacing)*.5);font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height));overflow-wrap:break-word;color:var(--color-cyan)}.prose pre code{border-radius:var(--radius-lg);padding:calc(var(--spacing)*4);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));color:var(--color-green-200);display:block}.prose mark{padding-inline:calc(var(--spacing)*1);color:var(--color-gray-900);background-color:var(--color-light-yellow);border-radius:.25rem}.prose .text-pink{color:var(--color-pink)}.prose blockquote{border-left-style:var(--tw-border-style);padding-top:calc(var(--spacing)*2);padding-bottom:calc(var(--spacing)*2.5);padding-left:calc(var(--spacing)*4);background-color:var(--color-gray-blue);border-left-width:4px;font-style:italic}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-6{margin-top:calc(var(--spacing)*6)}.mt-7{margin-top:calc(var(--spacing)*7)}.mt-9{margin-top:calc(var(--spacing)*9)}.mt-auto{margin-top:auto}.mr-2{margin-right:calc(var(--spacing)*2)}.mb-1{margin-bottom:calc(var(--spacing)*1)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-7{margin-bottom:calc(var(--spacing)*7)}.mb-8{margin-bottom:calc(var(--spacing)*8)}.ml-0\.5{margin-left:calc(var(--spacing)*.5)}.ml-3{margin-left:calc(var(--spacing)*3)}.ml-4{margin-left:calc(var(--spacing)*4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.size-20{width:calc(var(--spacing)*20);height:calc(var(--spacing)*20)}.icon{height:calc(var(--spacing)*4);width:calc(var(--spacing)*4)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-50{height:calc(var(--spacing)*50)}.h-60{height:calc(var(--spacing)*60)}.h-70{height:calc(var(--spacing)*70)}.h-90{height:calc(var(--spacing)*90)}.max-h-\[90vh\]{max-height:90vh}.min-h-dvh{min-height:100dvh}.w-4{width:calc(var(--spacing)*4)}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.w-50{width:calc(var(--spacing)*50)}.w-60{width:calc(var(--spacing)*60)}.w-70{width:calc(var(--spacing)*70)}.w-90{width:calc(var(--spacing)*90)}.max-w-\[90vw\]{max-width:90vw}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.-rotate-100{rotate:-100deg}.-rotate-200{rotate:-200deg}.rotate-0{rotate:none}.rotate-20{rotate:20deg}.rotate-40{rotate:40deg}.rotate-60{rotate:60deg}.rotate-90{rotate:90deg}.rotate-170{rotate:170deg}.rotate-180{rotate:180deg}.rotate-200{rotate:200deg}.rotate-270{rotate:270deg}.rotate-290{rotate:290deg}.rotate-330{rotate:330deg}.cursor-pointer{cursor:pointer}.cursor-zoom-in{cursor:zoom-in}.resize{resize:both}.grid-rows-\[max-content_1fr\]{grid-template-rows:max-content 1fr}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-1\.5>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*1.5)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*1.5)*calc(1 - var(--tw-space-x-reverse)))}:where(.space-x-3>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*3)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-x-reverse)))}:where(.space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*4)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-x-reverse)))}.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-gray-200{border-color:var(--color-gray-200)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black)50%,transparent)}}.bg-black\/75{background-color:#000000bf}@supports (color:color-mix(in lab,red,red)){.bg-black\/75{background-color:color-mix(in oklab,var(--color-black)75%,transparent)}}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-50\/95{background-color:#f9fafbf2}@supports (color:color-mix(in lab,red,red)){.bg-gray-50\/95{background-color:color-mix(in oklab,var(--color-gray-50)95%,transparent)}}.bg-white\/20{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.bg-white\/20{background-color:color-mix(in oklab,var(--color-white)20%,transparent)}}.bg-white\/30{background-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.bg-white\/30{background-color:color-mix(in oklab,var(--color-white)30%,transparent)}}.p-2{padding:calc(var(--spacing)*2)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.py-1{padding-block:calc(var(--spacing)*1)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.pt-2{padding-top:calc(var(--spacing)*2)}.pt-8{padding-top:calc(var(--spacing)*8)}.pt-28{padding-top:calc(var(--spacing)*28)}.pr-1{padding-right:calc(var(--spacing)*1)}.pr-2{padding-right:calc(var(--spacing)*2)}.pr-6{padding-right:calc(var(--spacing)*6)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-6{padding-bottom:calc(var(--spacing)*6)}.pl-8{padding-left:calc(var(--spacing)*8)}.text-left{text-align:left}.text-right{text-align:right}.font-sans{font-family:var(--font-sans)}.font-script{font-family:var(--font-script)}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-black{--tw-font-weight:var(--font-weight-black);font-weight:var(--font-weight-black)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-pretty{text-wrap:pretty}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-800{color:var(--color-gray-800)}.text-gray-900{color:var(--color-gray-900)}.text-pink{color:var(--color-pink)}.text-white{color:var(--color-white)}.underline{text-decoration-line:underline}.decoration-pink-300{-webkit-text-decoration-color:var(--color-pink-300);text-decoration-color:var(--color-pink-300)}.decoration-dotted{text-decoration-style:dotted}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-10{opacity:.1}.opacity-15{opacity:.15}.opacity-20{opacity:.2}.opacity-25{opacity:.25}.opacity-30{opacity:.3}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-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-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.group-hover\:scale-105:is(:where(.group):hover *){--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.group-hover\:bg-black\/60:is(:where(.group):hover *){background-color:#0009}@supports (color:color-mix(in lab,red,red)){.group-hover\:bg-black\/60:is(:where(.group):hover *){background-color:color-mix(in oklab,var(--color-black)60%,transparent)}}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.hover\:bg-\[var\(--color-pink\)\]:hover{background-color:var(--color-pink)}.hover\:bg-black\/75:hover{background-color:#000000bf}@supports (color:color-mix(in lab,red,red)){.hover\:bg-black\/75:hover{background-color:color-mix(in oklab,var(--color-black)75%,transparent)}}.hover\:bg-gray-800:hover{background-color:var(--color-gray-800)}.hover\:bg-green-700:hover{background-color:var(--color-green-700)}.hover\:text-gray-700:hover{color:var(--color-gray-700)}.hover\:opacity-75:hover{opacity:.75}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-gray-200:focus{--tw-ring-color:var(--color-gray-200)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.active\:cursor-grabbing:active{cursor:grabbing}@media not all and (min-width:40rem){.max-sm\:mt-4{margin-top:calc(var(--spacing)*4)}.max-sm\:inline-block{display:inline-block}.max-sm\:min-h-\[calc\(100dvh-theme\(spacing\.16\)\)\]{min-height:calc(100dvh - 4rem)}.max-sm\:pl-4{padding-left:calc(var(--spacing)*4)}}@media (min-width:40rem){.sm\:sticky{position:sticky}.sm\:top-0{top:calc(var(--spacing)*0)}.sm\:mx-auto{margin-inline:auto}.sm\:mt-4{margin-top:calc(var(--spacing)*4)}.sm\:block{display:block}.sm\:hidden{display:none}.sm\:size-25{width:calc(var(--spacing)*25);height:calc(var(--spacing)*25)}.sm\:h-screen{height:100vh}.sm\:max-w-3xl{max-width:var(--container-3xl)}.sm\:max-w-4xl{max-width:var(--container-4xl)}.sm\:grid-cols-\[1fr_max-content\]{grid-template-columns:1fr max-content}.sm\:grid-rows-none{grid-template-rows:none}.sm\:items-end{align-items:flex-end}.sm\:gap-x-8{column-gap:calc(var(--spacing)*8)}:where(.sm\:space-x-0>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*0)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*0)*calc(1 - var(--tw-space-x-reverse)))}.sm\:overflow-y-auto{overflow-y:auto}.sm\:pt-14{padding-top:calc(var(--spacing)*14)}.sm\:pt-16{padding-top:calc(var(--spacing)*16)}.sm\:pl-6{padding-left:calc(var(--spacing)*6)}.sm\:text-right{text-align:right}}@media (min-width:48rem){.md\:-left-10{left:calc(var(--spacing)*-10)}.md\:h-80{height:calc(var(--spacing)*80)}.md\:h-90{height:calc(var(--spacing)*90)}.md\:h-100{height:calc(var(--spacing)*100)}.md\:h-110{height:calc(var(--spacing)*110)}.md\:w-80{width:calc(var(--spacing)*80)}.md\:w-90{width:calc(var(--spacing)*90)}.md\:w-100{width:calc(var(--spacing)*100)}.md\:w-110{width:calc(var(--spacing)*110)}}@media (min-width:64rem){.lg\:h-90{height:calc(var(--spacing)*90)}.lg\:h-100{height:calc(var(--spacing)*100)}.lg\:h-120{height:calc(var(--spacing)*120)}.lg\:w-90{width:calc(var(--spacing)*90)}.lg\:w-100{width:calc(var(--spacing)*100)}.lg\:w-120{width:calc(var(--spacing)*120)}}}.font-color-pink{color:var(--color-pink)}.font-color-cyan{color:var(--color-cyan)}.font-color-purple{color:var(--color-gray-purple)}.font-color-magenta{color:var(--color-gray-magenta)}.bg-theme-pink{background-color:var(--color-pink)}.bg-theme-yellow{background-color:var(--color-light-yellow)}.bg-theme-blue{background-color:var(--color-gray-blue)}.bg-theme-cyan{background-color:var(--color-cyan)}.bg-theme-gray-cyan{background-color:var(--color-gray-cyan)}.reenie-beanie-regular{font-family:Reenie Beanie,cursive;font-style:normal;font-weight:400}h2{font-size:3rem}h4{font-size:2.5rem}:where(.blog-toc-container>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}.blog-toc-item{display:block}.blog-toc-content{align-items:flex-start;gap:calc(var(--spacing)*1);padding-block:calc(var(--spacing)*1);min-height:2.5rem;display:flex}.blog-toc-left{flex:none;max-width:65%}.blog-toc-title{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height));--tw-leading:var(--leading-tight);line-height:var(--leading-tight);--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));text-decoration-style:dotted}@media (hover:hover){.blog-toc-title:hover{color:var(--color-gray-500)}}.blog-toc-title{-webkit-text-decoration-color:var(--color-gray-300);text-decoration-color:var(--color-gray-300)}@media (hover:hover){.blog-toc-title:hover{-webkit-text-decoration-color:var(--color-gray-200);text-decoration-color:var(--color-gray-200)}}.blog-toc-title{display:block}.blog-toc-tags{margin-top:calc(var(--spacing)*1);gap:calc(var(--spacing)*1);flex-wrap:wrap;display:flex}.blog-toc-dots{border-bottom:2px dotted #d1d5db;flex:1;min-width:2rem;height:1px;margin:.75rem .5rem 0;position:relative}.blog-toc-right{flex-shrink:0;align-items:center;margin-top:.1rem;display:flex}.blog-toc-reading-time{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);white-space:nowrap;color:var(--color-gray-600);padding-inline:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*1);background-color:var(--color-gray-cyan);border-radius:.25rem}@media (max-width:640px){.blog-toc-left{max-width:60%}.blog-toc-title{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.blog-toc-reading-time{padding-inline:calc(var(--spacing)*1.5);padding-block:calc(var(--spacing)*.5);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.blog-toc-dots{margin:.5rem .25rem 0}}.blog-toc-item:hover .blog-toc-dots{border-color:#9ca3af}.blog-toc-item:hover .blog-toc-reading-time{background-color:var(--color-cyan);color:#fff;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.blog-toc-dots-alt{flex:1;height:0;margin:.75rem .5rem 0;position:relative;overflow:hidden}.blog-toc-dots-alt:before{content:"························································································";letter-spacing:.1em;white-space:nowrap;font-size:.875rem;line-height:1;display:block;overflow:hidden}.flipbook-modal{inset:calc(var(--spacing)*0);z-index:50;visibility:hidden;opacity:0;z-index:9999;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed}.flipbook-modal.active{visibility:visible;opacity:1}.flipbook-backdrop{inset:calc(var(--spacing)*0);background-color:var(--color-black);opacity:.8;position:absolute}.flipbook-content{z-index:10;max-height:100vh;max-width:var(--container-6xl);padding:calc(var(--spacing)*4);flex-direction:column;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:relative}.book-display{margin-bottom:calc(var(--spacing)*4);border-radius:var(--radius-lg);background-color:var(--color-white);padding:calc(var(--spacing)*4)}@media (prefers-color-scheme:dark){.book-display{background-color:var(--color-gray-800)}}.book-display{justify-content:center;align-items:center;max-height:calc(100vh - 120px);display:flex;overflow:hidden;box-shadow:0 20px 40px #0000004d}.single-page{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.single-page .book-page{object-fit:contain;max-width:100%;max-height:100%;display:block}.double-spread{justify-content:center;align-items:center;gap:.5rem;width:100%;height:100%;display:flex}.left-page,.right-page{object-fit:contain;max-width:calc(50% - .25rem);max-height:100%;display:block}.control-bar{background-color:var(--color-white);padding-inline:calc(var(--spacing)*6);padding-block:calc(var(--spacing)*3);border-radius:3.40282e38px;align-items:center;display:flex}@media (prefers-color-scheme:dark){.control-bar{background-color:var(--color-gray-800)}}.control-bar{z-index:10;position:relative;box-shadow:0 8px 20px #0000004d}.control-btn{margin-inline:calc(var(--spacing)*2);cursor:pointer;border-radius:var(--radius-lg);--tw-border-style:none;padding-inline:calc(var(--spacing)*4);padding-block:calc(var(--spacing)*2);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium);transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));background-color:var(--color-gray-100);color:var(--color-gray-700);border-style:none}@media (hover:hover){.control-btn:hover{background-color:var(--color-gray-200)}}@media (prefers-color-scheme:dark){.control-btn{background-color:var(--color-gray-700);color:var(--color-gray-200)}@media (hover:hover){.control-btn:hover{background-color:var(--color-gray-600)}}}.control-btn:disabled{cursor:not-allowed;opacity:.5}.control-btn:disabled:hover{background-color:var(--color-gray-100)}@media (prefers-color-scheme:dark){.control-btn:disabled:hover{background-color:var(--color-gray-700)}}.close-btn{background-color:var(--color-gray-cyan);color:var(--color-white)}.open-flipbook-btn{cursor:pointer;border-radius:var(--radius-lg);--tw-border-style:none;padding-inline:calc(var(--spacing)*4);padding-block:calc(var(--spacing)*2);color:var(--color-white);transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));background-color:var(--color-cyan);border-style:none;align-items:center;display:inline-flex}.open-flipbook-btn:hover{opacity:.9;transform:translateY(-1px)}@media (max-width:768px){.flipbook-content{justify-content:space-between;height:100vh;padding:80px .5rem .5rem}.book-display{flex:1;justify-content:center;align-items:center;max-height:calc(100vh - 180px);margin:0;padding:.75rem;display:flex}.single-page{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.single-page .book-page{object-fit:contain;object-position:center;max-width:95%;max-height:95%}.double-spread{flex-direction:column;justify-content:center;align-items:center;gap:.5rem}.left-page,.right-page{object-fit:contain;max-width:95%;max-height:45%;margin:0}.control-bar{margin:0;margin-bottom:env(safe-area-inset-bottom,8px);flex-shrink:0;padding:.5rem 1rem}.control-btn{margin:0 .25rem;padding:.5rem .75rem;font-size:.75rem}.flipbook-modal.active .flipbook-content{transform:none}}.double-page-spread{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.book-page.double-page{object-fit:contain;max-width:90%;max-height:90%}.double-width-mobile .book-page{object-fit:contain;width:auto;max-width:none;height:80vh}.double-width-mobile{justify-content:center;display:flex;overflow-x:auto}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-duration{syntax:"*";inherits:false}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}
