@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url("files/inter-cyrillic-ext-400-normal.b22d15f2947e.woff2") format("woff2"),url("files/inter-cyrillic-ext-400-normal.f25e0870e9dc.woff") format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url("files/inter-cyrillic-400-normal.74a70a8b71d0.woff2") format("woff2"),url("files/inter-cyrillic-400-normal.1b14d388d51c.woff") format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url("files/inter-greek-ext-400-normal.605d00085ebd.woff2") format("woff2"),url("files/inter-greek-ext-400-normal.d4440b2a5070.woff") format("woff");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url("files/inter-greek-400-normal.e4998c9e328a.woff2") format("woff2"),url("files/inter-greek-400-normal.957bee6bad76.woff") format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url("files/inter-vietnamese-400-normal.f31e0b32e489.woff2") format("woff2"),url("files/inter-vietnamese-400-normal.af21a511aaff.woff") format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url("files/inter-latin-ext-400-normal.0a6ff1a7c1e4.woff2") format("woff2"),url("files/inter-latin-ext-400-normal.247942b57580.woff") format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url("files/inter-latin-400-normal.da03732a27e1.woff2") format("woff2"),url("files/inter-latin-400-normal.35827309b4b3.woff") format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url("files/inter-cyrillic-ext-500-normal.6264462a26cb.woff2") format("woff2"),url("files/inter-cyrillic-ext-500-normal.f472ddcaca78.woff") format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url("files/inter-cyrillic-500-normal.0f5211cce140.woff2") format("woff2"),url("files/inter-cyrillic-500-normal.9c41d17b6705.woff") format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url("files/inter-greek-ext-500-normal.7cc37d788c54.woff2") format("woff2"),url("files/inter-greek-ext-500-normal.e01c2507975a.woff") format("woff");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url("files/inter-greek-500-normal.b0154f8ec2fa.woff2") format("woff2"),url("files/inter-greek-500-normal.a4953b10c178.woff") format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url("files/inter-vietnamese-500-normal.054ab7c8eaec.woff2") format("woff2"),url("files/inter-vietnamese-500-normal.38750c53794c.woff") format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url("files/inter-latin-ext-500-normal.90ff4f7e8bcb.woff2") format("woff2"),url("files/inter-latin-ext-500-normal.a49647f02032.woff") format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url("files/inter-latin-500-normal.51205681a1ba.woff2") format("woff2"),url("files/inter-latin-500-normal.d2c2ce4256b8.woff") format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url("files/inter-cyrillic-ext-600-normal.f7378cd72263.woff2") format("woff2"),url("files/inter-cyrillic-ext-600-normal.112c08a64824.woff") format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url("files/inter-cyrillic-600-normal.40727edfba55.woff2") format("woff2"),url("files/inter-cyrillic-600-normal.6a75d7a9a2df.woff") format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url("files/inter-greek-ext-600-normal.18223a441990.woff2") format("woff2"),url("files/inter-greek-ext-600-normal.16b62130fb99.woff") format("woff");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url("files/inter-greek-600-normal.c3a34dcac111.woff2") format("woff2"),url("files/inter-greek-600-normal.f67a21c64bd7.woff") format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url("files/inter-vietnamese-600-normal.72cc22e3e0e6.woff2") format("woff2"),url("files/inter-vietnamese-600-normal.be0d19f19f4f.woff") format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url("files/inter-latin-ext-600-normal.65aed4e1ef63.woff2") format("woff2"),url("files/inter-latin-ext-600-normal.bff95d0a0c3c.woff") format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url("files/inter-latin-600-normal.2ede57db1a3a.woff2") format("woff2"),url("files/inter-latin-600-normal.d5ec4ca8c281.woff") format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url("files/inter-cyrillic-ext-700-normal.f6f8f6127a4c.woff2") format("woff2"),url("files/inter-cyrillic-ext-700-normal.059dd6ce809c.woff") format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url("files/inter-cyrillic-700-normal.fc4bfa8e4204.woff2") format("woff2"),url("files/inter-cyrillic-700-normal.e8f535c437db.woff") format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url("files/inter-greek-ext-700-normal.7be4c2c21083.woff2") format("woff2"),url("files/inter-greek-ext-700-normal.47620c23d3a3.woff") format("woff");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url("files/inter-greek-700-normal.be8feba98af2.woff2") format("woff2"),url("files/inter-greek-700-normal.cf0e564772e5.woff") format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url("files/inter-vietnamese-700-normal.f7cdc3c0c4df.woff2") format("woff2"),url("files/inter-vietnamese-700-normal.32d38cd24297.woff") format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url("files/inter-latin-ext-700-normal.aa4c26661f64.woff2") format("woff2"),url("files/inter-latin-ext-700-normal.1022b5d15a19.woff") format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url("files/inter-latin-700-normal.8ca0a5155296.woff2") format("woff2"),url("files/inter-latin-700-normal.4025e89765a4.woff") format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url("files/jetbrains-mono-cyrillic-ext-400-normal.22e9c937e344.woff2") format("woff2"),url("files/jetbrains-mono-cyrillic-ext-400-normal.e61cd1409f31.woff") format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url("files/jetbrains-mono-cyrillic-400-normal.82462194ebb6.woff2") format("woff2"),url("files/jetbrains-mono-cyrillic-400-normal.1e73bf34a887.woff") format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url("files/jetbrains-mono-greek-400-normal.a5c8278c5258.woff2") format("woff2"),url("files/jetbrains-mono-greek-400-normal.5f855aa59cdc.woff") format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url("files/jetbrains-mono-vietnamese-400-normal.789a43b6ed9a.woff2") format("woff2"),url("files/jetbrains-mono-vietnamese-400-normal.64a5c21c5fd1.woff") format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url("files/jetbrains-mono-latin-ext-400-normal.443d1c3be5b2.woff2") format("woff2"),url("files/jetbrains-mono-latin-ext-400-normal.31f61f0b3ca9.woff") format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url("files/jetbrains-mono-latin-400-normal.caf0dfde4e44.woff2") format("woff2"),url("files/jetbrains-mono-latin-400-normal.595a3ec29485.woff") format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:500;src:url("files/jetbrains-mono-cyrillic-ext-500-normal.24fc306f6175.woff2") format("woff2"),url("files/jetbrains-mono-cyrillic-ext-500-normal.244cd69ca92d.woff") format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:500;src:url("files/jetbrains-mono-cyrillic-500-normal.af752ba91433.woff2") format("woff2"),url("files/jetbrains-mono-cyrillic-500-normal.5592236042ae.woff") format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:500;src:url("files/jetbrains-mono-greek-500-normal.eed865ab0191.woff2") format("woff2"),url("files/jetbrains-mono-greek-500-normal.6102424bf7ef.woff") format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:500;src:url("files/jetbrains-mono-vietnamese-500-normal.a026792141f5.woff2") format("woff2"),url("files/jetbrains-mono-vietnamese-500-normal.583bff253ad1.woff") format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:500;src:url("files/jetbrains-mono-latin-ext-500-normal.311b1217e9b0.woff2") format("woff2"),url("files/jetbrains-mono-latin-ext-500-normal.d4e8db2a1b8e.woff") format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:500;src:url("files/jetbrains-mono-latin-500-normal.a21e038a03f7.woff2") format("woff2"),url("files/jetbrains-mono-latin-500-normal.ffe0849f41e0.woff") format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}*,: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.19 | 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:Inter,system-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,pre,samp{font-family:JetBrains Mono,ui-monospace,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}html{scroll-behavior:smooth}body{min-height:100vh;--tw-bg-opacity:1;background-color:rgb(15 17 23/var(--tw-bg-opacity,1));font-family:Inter,system-ui,sans-serif;font-size:1rem;line-height:1.5rem;line-height:1.625;--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:rgb(99 102 241/var(--tw-text-opacity,1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}a,a:hover{--tw-text-opacity:1}a:hover{color:rgb(129 140 248/var(--tw-text-opacity,1))}img{display:block;max-width:100%}.sticky{position:sticky}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.min-h-screen{min-height:100vh}.transform{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))}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.bg-bg{--tw-bg-opacity:1;background-color:rgb(15 17 23/var(--tw-bg-opacity,1))}.font-sans{font-family:Inter,system-ui,sans-serif}.text-base{font-size:1rem;line-height:1.5rem}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.text-primary{--tw-text-opacity:1;color:rgb(99 102 241/var(--tw-text-opacity,1))}.text-slate-200{--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:solid}.blur{--tw-blur:blur(8px);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-filter{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,backdrop-filter;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}/**
 * HitReader component styles (plain CSS).
 * Appended to static/css/main.css at build time via npm run build:css.
 */

.post-card {
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid #2e3250;
  background: #1a1d27;
  transition: border-color 0.18s ease, transform 0.18s ease;
}

.post-card:hover {
  border-color: #6366f1;
  transform: translateY(-2px);
}

.post-card-media-link {
  display: block;
}

.post-card-image {
  width: 100%;
  height: 11rem;
  object-fit: cover;
}

@media (min-width: 640px) {
  .post-card-image {
    height: 13rem;
  }
}

.post-card-body {
  padding: 1rem;
}

@media (min-width: 640px) {
  .post-card-body {
    padding: 1.75rem;
  }
}

.post-card-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  font-size: 0.75rem;
  color: #94a3b8;
}

.post-card-title {
  margin-bottom: 0.5rem;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.375;
}

@media (min-width: 640px) {
  .post-card-title {
    font-size: 1.25rem;
  }
}

.post-card-title-link {
  color: #f1f5f9;
}

.post-card-title-link:hover {
  color: #818cf8;
}

.post-card-excerpt {
  margin-bottom: 1rem;
  font-size: 0.875rem;
  color: #94a3b8;
}

@media (min-width: 640px) {
  .post-card-excerpt {
    font-size: 1rem;
  }
}

.post-card-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.post-card-author {
  font-size: 0.875rem;
  font-weight: 500;
  color: #94a3b8;
}

.layout-grid {
  margin-left: auto;
  margin-right: auto;
  display: grid;
  max-width: 72rem;
  grid-template-columns: 1fr;
  gap: 2rem;
  padding: 2rem 1rem;
}

@media (min-width: 1024px) {
  .layout-grid {
    grid-template-columns: 1fr 280px;
    gap: 3rem;
    padding: 3rem 1.5rem;
  }
}

.layout-main,
.layout-sidebar {
  min-width: 0;
}

@media (min-width: 1024px) {
  .layout-sidebar {
    position: sticky;
    top: 5rem;
    align-self: start;
  }
}

.sidebar-panel {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.sidebar-card {
  border-radius: 14px;
  border: 1px solid #2e3250;
  background: #1a1d27;
  padding: 1.25rem;
}

.sidebar-heading {
  margin-bottom: 0.75rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #64748b;
}

.sidebar-link {
  font-size: 0.875rem;
  color: #94a3b8;
}

.sidebar-link:hover,
.sidebar-link-active {
  color: #818cf8;
}

.sidebar-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.text-muted-sm {
  font-size: 0.875rem;
  color: #64748b;
}

.page-header {
  margin-bottom: 2rem;
}

.page-heading {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.25;
}

@media (min-width: 640px) {
  .page-heading {
    font-size: 1.875rem;
  }
}

.page-heading-accent {
  color: #818cf8;
}

.page-subtext {
  margin-top: 0.5rem;
  color: #94a3b8;
}

.search-row {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 1.25rem;
}

@media (min-width: 640px) {
  .search-row {
    flex-direction: row;
  }
}

.search-input {
  flex: 1;
  border-radius: 8px;
  border: 1px solid #2e3250;
  background: #1a1d27;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  color: #e2e8f0;
  outline: none;
}

.search-input:focus {
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

.post-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.tag-row,
.tag-row-spaced {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.tag-row-spaced {
  margin-top: 1rem;
}

.empty-block {
  padding: 4rem 0;
  text-align: center;
  color: #94a3b8;
}

.empty-block-icon {
  margin-bottom: 1rem;
  font-size: 3rem;
}

.navbar {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid #2e3250;
  background: rgba(26, 29, 39, 0.95);
  backdrop-filter: blur(8px);
}

.navbar-inner {
  margin: 0 auto;
  display: flex;
  max-width: 72rem;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 1rem;
}

@media (min-width: 640px) {
  .navbar-inner {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

.navbar-brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.125rem;
  font-weight: 700;
  color: #f1f5f9;
}

.navbar-brand:hover {
  color: #818cf8;
}

.navbar-brand-icon {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  color: #6366f1;
}

.navbar-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  font-size: 0.875rem;
  font-weight: 500;
}

@media (min-width: 640px) {
  .navbar-links {
    gap: 1.25rem;
  }
}

.navbar-link {
  color: #94a3b8;
}

.navbar-link:hover {
  color: #f1f5f9;
}

.messages-wrap {
  margin: 0 auto;
  display: flex;
  max-width: 72rem;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1rem 1rem 0;
}

.site-body {
  display: flex;
  min-height: 100vh;
  flex-direction: column;
}

.site-main {
  flex: 1;
}

.site-footer {
  margin-top: auto;
  border-top: 1px solid #2e3250;
  background: #1a1d27;
  padding: 1.5rem 1rem;
}

.site-footer-inner {
  margin: 0 auto;
  max-width: 72rem;
  text-align: center;
  font-size: 0.875rem;
  color: #64748b;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  border-radius: 8px;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  transition: all 0.18s ease;
  text-decoration: none;
  cursor: pointer;
}

.btn-primary {
  border: none;
  background: #6366f1;
  color: #fff;
}

.btn-primary:hover {
  background: #818cf8;
  color: #fff;
}

.btn-outline {
  border: 1px solid #2e3250;
  background: transparent;
  color: #94a3b8;
}

.btn-outline:hover {
  border-color: #6366f1;
  color: #6366f1;
}

.btn-sm {
  padding: 0.375rem 0.875rem;
  font-size: 0.75rem;
}

.btn-full {
  width: 100%;
}

.btn-link {
  border: 0;
  background: transparent;
  padding: 0;
  font-size: 0.875rem;
  font-weight: 500;
  color: #94a3b8;
  cursor: pointer;
}

.btn-link:hover {
  color: #f87171;
}

.badge-category {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(99, 102, 241, 0.25);
  background: rgba(99, 102, 241, 0.15);
  padding: 0.125rem 0.625rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #818cf8;
}

.badge-tag {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid rgba(34, 211, 238, 0.2);
  background: rgba(34, 211, 238, 0.1);
  padding: 0.125rem 0.625rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #22d3ee;
}

.badge-tag:hover {
  background: rgba(34, 211, 238, 0.2);
  color: #22d3ee;
}

.article-header {
  margin-bottom: 2.5rem;
}

.article-title {
  margin-top: 0.75rem;
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1.25;
}

@media (min-width: 640px) {
  .article-title {
    font-size: 2.25rem;
  }
}

.article-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1rem;
  font-size: 0.875rem;
  color: #94a3b8;
}

.article-meta-sep {
  color: #2e3250;
}

.article-meta-strong {
  color: #e2e8f0;
}

.edit-link {
  font-weight: 600;
  color: #6366f1;
}

.edit-link:hover {
  color: #818cf8;
}

.avatar-sm {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 999px;
  object-fit: cover;
}

.article-hero-image {
  margin-bottom: 2.25rem;
  width: 100%;
  max-height: 460px;
  border-radius: 14px;
  object-fit: cover;
}

.article-prose {
  max-width: none;
  color: #e2e8f0;
  line-height: 1.8;
  font-size: 1.05rem;
}

.article-prose h1,
.article-prose h2,
.article-prose h3,
.article-prose h4 {
  margin: 2em 0 0.6em;
  font-weight: 700;
  line-height: 1.3;
  color: #f1f5f9;
}

.article-prose h2 {
  border-bottom: 1px solid #2e3250;
  padding-bottom: 0.5rem;
  font-size: 1.5rem;
}

.article-prose h3 {
  font-size: 1.25rem;
}

.article-prose p {
  margin: 1em 0;
}

.article-prose a {
  color: #818cf8;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.article-prose code {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.87em;
  background: #22263a;
  padding: 0.125rem 0.4375rem;
  border-radius: 4px;
  color: #22d3ee;
}

.article-prose pre {
  overflow-x: auto;
  margin: 1.5em 0;
  border: 1px solid #2e3250;
  border-radius: 8px;
  background: #22263a;
  padding: 1.25rem;
}

.article-prose pre code {
  background: none;
  padding: 0;
  color: #e2e8f0;
}

.article-prose ul,
.article-prose ol {
  margin: 1em 0 1em 1.5em;
}

.author-box {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
  margin-top: 3rem;
  border-radius: 14px;
  border: 1px solid #2e3250;
  background: #1a1d27;
  padding: 1.5rem;
}

@media (min-width: 640px) {
  .author-box {
    flex-direction: row;
  }
}

.author-box-avatar {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 999px;
  object-fit: cover;
}

.author-box-name {
  font-weight: 700;
  color: #f1f5f9;
}

.author-box-bio {
  margin-top: 0.25rem;
  font-size: 0.875rem;
  color: #94a3b8;
}

.comments-section {
  margin-top: 3rem;
}

.comments-heading {
  margin-bottom: 1.5rem;
  font-size: 1.25rem;
  font-weight: 700;
}

.comments-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 2.5rem;
}

.comment-card {
  border-radius: 8px;
  border: 1px solid #2e3250;
  background: #1a1d27;
  padding: 1rem;
}

.comment-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
}

.comment-author {
  color: #e2e8f0;
}

.comment-date {
  color: #64748b;
}

.comment-body {
  font-size: 0.875rem;
  color: #94a3b8;
}

.comment-empty {
  margin-bottom: 2rem;
  font-size: 0.875rem;
  font-style: italic;
  color: #64748b;
}

.comment-form-section {
  margin-top: 2rem;
}

.comment-form-title {
  font-size: 1.125rem;
  font-weight: 700;
}

.comment-form-note {
  margin-bottom: 1.25rem;
  font-size: 0.875rem;
  color: #64748b;
}

.form-stack > * + * {
  margin-top: 1rem;
}

.form-stack-lg > * + * {
  margin-top: 1.25rem;
}

.form-label {
  display: block;
  margin-bottom: 0.375rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #94a3b8;
}

.form-hint {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.75rem;
  color: #64748b;
}

.form-label-note {
  font-weight: 400;
  color: #64748b;
}

.form-error {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.75rem;
  font-weight: 500;
  color: #f87171;
}

.form-row-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 640px) {
  .form-row-2 {
    grid-template-columns: 1fr 1fr;
  }
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  padding-top: 0.5rem;
}

.site-main form input:not([type="submit"]):not([type="checkbox"]):not([type="file"]),
.site-main form textarea,
.site-main form select {
  width: 100%;
  border-radius: 8px;
  border: 1px solid #2e3250;
  background-color: #1a1d27;
  padding: 0.625rem 0.875rem;
  font-size: 0.875rem;
  color: #e2e8f0;
  outline: none;
  transition: border-color 0.18s ease;
}

.site-main form input::placeholder,
.site-main form textarea::placeholder {
  color: #64748b;
}

.site-main form input:focus,
.site-main form textarea:focus,
.site-main form select:focus {
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

.site-main form textarea.markdown-editor {
  min-height: 420px;
  resize: vertical;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.875rem;
}

.auth-shell {
  display: flex;
  justify-content: center;
  padding: 4rem 1rem;
}

.auth-card {
  width: 100%;
  max-width: 28rem;
  border-radius: 14px;
  border: 1px solid #2e3250;
  background: #1a1d27;
  padding: 2rem;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
}

@media (min-width: 640px) {
  .auth-card {
    padding: 2.5rem;
  }
}

.auth-card-header {
  margin-bottom: 1.75rem;
}

.auth-card-title {
  font-size: 1.5rem;
  font-weight: 800;
}

.auth-card-subtitle {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: #94a3b8;
}

.auth-card-footer {
  margin-top: 1.5rem;
  text-align: center;
  font-size: 0.875rem;
  color: #64748b;
}

.editor-page {
  margin: 0 auto;
  max-width: 56rem;
  padding: 2.5rem 1rem 3rem;
}

@media (min-width: 640px) {
  .editor-page {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

.editor-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 2rem;
}

.profile-page {
  margin: 0 auto;
  max-width: 48rem;
  padding: 2.5rem 1rem 3rem;
}

.profile-header {
  margin-bottom: 2rem;
}

.seo-details {
  border-radius: 8px;
  border: 1px solid #2e3250;
  background: #22263a;
}

.seo-summary {
  cursor: pointer;
  padding: 0.875rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  list-style: none;
}

.seo-summary::-webkit-details-marker {
  display: none;
}

.seo-body > * + * {
  margin-top: 1rem;
}

.seo-body {
  border-top: 1px solid #2e3250;
  padding: 1rem;
}

.preview-wrap {
  margin-bottom: 0.75rem;
}

.image-preview {
  width: 100%;
  max-height: 12rem;
  border-radius: 8px;
  border: 1px solid #2e3250;
  object-fit: cover;
}

.seo-counter-over {
  color: #f87171;
}

.not-found-page {
  margin: 0 auto;
  max-width: 72rem;
  padding: 5rem 1rem;
  text-align: center;
}

.not-found-code {
  margin-bottom: 1rem;
  font-size: 3rem;
  font-weight: 700;
  color: #64748b;
}

.not-found-subtext {
  margin: 0.75rem auto 0;
  max-width: 28rem;
  color: #94a3b8;
}

.not-found-actions {
  display: inline-flex;
  margin-top: 2rem;
}

.message {
  border-radius: 8px;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
}

.message-success {
  border: 1px solid rgba(74, 222, 128, 0.3);
  background: rgba(74, 222, 128, 0.1);
  color: #4ade80;
}

.message-error {
  border: 1px solid rgba(248, 113, 113, 0.3);
  background: rgba(248, 113, 113, 0.1);
  color: #f87171;
}

.message-info {
  border: 1px solid rgba(99, 102, 241, 0.3);
  background: rgba(99, 102, 241, 0.1);
  color: #818cf8;
}

.message-warning {
  border: 1px solid rgba(251, 191, 36, 0.3);
  background: rgba(251, 191, 36, 0.1);
  color: #fbbf24;
}

.highlight pre {
  margin: 0;
  background: transparent;
  padding: 0;
}

.pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid #2e3250;
}

.pagination-link {
  display: inline-flex;
  align-items: center;
  border-radius: 8px;
  border: 1px solid #2e3250;
  background: #1a1d27;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #e2e8f0;
  text-decoration: none;
  transition: border-color 0.18s ease, color 0.18s ease;
}

.pagination-link:hover {
  border-color: #6366f1;
  color: #818cf8;
}

.pagination-link-disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.pagination-status {
  font-size: 0.875rem;
  color: #94a3b8;
}
