*,:after,:before{--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:rgba(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:rgba(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: }/*
! tailwindcss v3.4.16 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;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,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{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}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.mb-\[-5px\]{margin-bottom:-5px}.ml-3{margin-left:.75rem}.mt-\[-8px\]{margin-top:-8px}.mt-auto{margin-top:auto}.\!inline{display:inline!important}.inline{display:inline}.flex{display:flex}.hidden{display:none}.h-\[32px\]{height:32px}.h-\[52px\]{height:52px}.min-h-\[44px\]{min-height:44px}.w-\[24px\]{width:24px}.w-\[52px\]{width:52px}.w-full{width:100%}.min-w-\[180px\]{min-width:180px}.max-w-\[60px\]{max-width:60px}.max-w-full{max-width:100%}.flex-1{flex:1 1 0%}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.\!gap-\[28px\]{gap:28px!important}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-\[16px\]{gap:16px}.gap-\[8px\]{gap:8px}.gap-\[var\(--b-shadow\)\]{gap:var(--b-shadow)}.gap-x-1{-moz-column-gap:.25rem;column-gap:.25rem}.gap-y-2{row-gap:.5rem}.self-start{align-self:flex-start}.self-center{align-self:center}.overflow-hidden{overflow:hidden}.text-ellipsis{text-overflow:ellipsis}.whitespace-pre{white-space:pre}.text-wrap{text-wrap:wrap}.text-nowrap{text-wrap:nowrap}.border-b-\[4px\]{border-bottom-width:4px}.border-t-2{border-top-width:2px}.border-foreground{border-color:var(--foreground)}.bg-atom{background-color:var(--atom)}.bg-background{background-color:var(--background)}.bg-github{background-color:var(--github)}.bg-habr{background-color:var(--habr)}.bg-instagram{background-color:var(--instagram)}.bg-linkedin{background-color:var(--linkedin)}.bg-npm{background-color:var(--npm)}.bg-rss{background-color:var(--rss)}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.p-2{padding:.5rem}.p-\[16px\]{padding:16px}.\!px-\[--l-gap\]{padding-left:var(--l-gap)!important;padding-right:var(--l-gap)!important}.\!py-\[--s-gap\]{padding-top:var(--s-gap)!important;padding-bottom:var(--s-gap)!important}.pr-\[18px\]{padding-right:18px}.text-center{text-align:center}.text-start{text-align:start}.text-\[17px\]{font-size:17px}.text-\[18px\]{font-size:18px}.text-\[19px\]{font-size:19px}.text-\[20px\]{font-size:20px}.text-\[24px\]{font-size:24px}.text-\[28px\]{font-size:28px}.font-bold{font-weight:700}.uppercase{text-transform:uppercase}.leading-\[1\],.leading-none{line-height:1}.text-\[--foreground\],.text-foreground{color:var(--foreground)}.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}.opacity-75{opacity:.75}:root{--background:#fff;--foreground:#000;--dot:#999;--focus:#93c5fd;--npm:#e82b00;--github:#fff;--instagram:#da63a6;--linkedin:#009bee;--email:#bbb;--habr:#a4cbdf;--rss:#f80;--atom:#00b7c3;--border-width:3px;--l-gap:40px;--m-gap:20px;--s-gap:16px;--b-shadow:10px;--s-shadow:4px}@media (prefers-color-scheme:dark){:root{--background:#161616;--foreground:#e8e8e8;--dot:#a7a7a7;--focus:#0b51a0;--npm:#b20;--github:#000;--instagram:#833a5c;--linkedin:#005582;--habr:#4a6a7a;--rss:#c60;--atom:#007a80;--border-width:2px}}@media (max-width:639px){:root{--l-gap:12px;--m-gap:12px;--s-gap:8px;--b-shadow:4px;--s-shadow:4px}}html{height:100%}body,html{background-color:var(--background)}body{min-height:100%;display:flex;flex-direction:column;color:var(--foreground);font-size:16px;font-family:var(--fira-sans);background-image:linear-gradient(45deg,var(--foreground) 1px,transparent 1px);background-size:15px 15px}h1,h2,h3,h4{font-family:var(--fira-code);font-weight:700}.content h1,h2{font-size:38px;line-height:1}h3{font-size:32px;line-height:1}h1 strong,h2 strong{color:#f44444}p code{font-family:var(--fira-code);background-color:#ebebeb;border-radius:4px;padding:1px 4px}li ul{margin-top:var(--s-gap)}p:has(>img){margin-right:var(--s-shadow)}.big-shadow{box-shadow:var(--b-shadow) var(--b-shadow) var(--foreground);margin-bottom:var(--b-shadow);margin-right:var(--b-shadow);display:flex;flex-direction:column;padding:var(--m-gap);gap:var(--m-gap);overflow:hidden}.big-shadow,.small-shadow{border-width:var(--border-width);border-color:var(--foreground)}.small-shadow{box-shadow:var(--s-shadow) var(--s-shadow) var(--foreground);margin-right:var(--s-shadow);margin-bottom:var(--s-shadow)}.big-button{font-family:var(--font-fixedsys);font-size:32px;line-height:1;padding:10px 20px 12px}.big-button:focus,.big-button:hover,.small-button:focus,.small-button:hover{background-color:var(--focus)}.big-button:active{color:var(--background);background-color:var(--foreground);margin:var(--b-shadow) 0 0 var(--b-shadow);box-shadow:none}.small-button{font-family:var(--font-fixedsys);font-size:24px;line-height:1;padding:8px 14px}.small-button:active{color:var(--background);background-color:var(--foreground);margin:var(--s-shadow) 0 0 var(--s-shadow);box-shadow:none}.content{width:100%;max-width:900px;margin:0 auto;display:flex;flex-direction:column;padding:var(--s-gap);row-gap:var(--s-gap)}@media (prefers-color-scheme:dark){h1 strong,h2 strong{color:#8c8c8c}p code{background-color:#262626}}@media (max-width:639px){.content h1,h2{font-size:24px;line-height:1.2}.big-button{font-size:24px;padding:8px 14px}}@media (hover:hover){.touchscreen-only{display:none}}.hover\:bg-focus:hover{background-color:var(--focus)}.active\:scale-90:active{--tw-scale-x:.9;--tw-scale-y:.9;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:400px){.xs\:inline{display:inline}.xs\:hidden{display:none}.xs\:text-\[26px\]{font-size:26px}}@media (min-width:640px){.sm\:inline{display:inline}.sm\:hidden{display:none}.sm\:h-\[40px\]{height:40px}.sm\:h-\[60px\]{height:60px}.sm\:w-\[30px\]{width:30px}.sm\:w-\[60px\]{width:60px}.sm\:gap-4{gap:1rem}.sm\:border-b-\[13px\]{border-bottom-width:13px}.sm\:p-4{padding:1rem}.sm\:text-end{text-align:end}.sm\:text-\[24px\]{font-size:24px}.sm\:text-\[38px\]{font-size:38px}}@media (min-width:1024px){.lg\:flex{display:flex}.lg\:text-\[48px\]{font-size:48px}}@media (prefers-color-scheme:dark){.dark\:border-b-\[2px\]{border-bottom-width:2px}.dark\:bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.dark\:opacity-100{opacity:1}.dark\:invert{--tw-invert:invert(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)}.dark\:hover\:bg-zinc-800:hover{--tw-bg-opacity:1;background-color:rgb(39 39 42/var(--tw-bg-opacity,1))}}