﻿/* Build version: 2026.05.05-r4 */
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/d656aa54-d2c3-4faa-a971-cc7306f15594.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/4da80fde-3485-4de0-9450-f1204ec9dfed.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/4b42f5db-72ff-4b27-9b35-354a5297d4c2.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/f5e6e5a2-6e89-44e8-a4f4-76401bd4c430.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/e10e96a0-37a8-4acf-a25d-6aac879fc35e.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("assets/c2cb3aec-2510-4f7a-9b3d-07d446c7cd08.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/d656aa54-d2c3-4faa-a971-cc7306f15594.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/4da80fde-3485-4de0-9450-f1204ec9dfed.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/4b42f5db-72ff-4b27-9b35-354a5297d4c2.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/f5e6e5a2-6e89-44e8-a4f4-76401bd4c430.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/e10e96a0-37a8-4acf-a25d-6aac879fc35e.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/c2cb3aec-2510-4f7a-9b3d-07d446c7cd08.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/d656aa54-d2c3-4faa-a971-cc7306f15594.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/4da80fde-3485-4de0-9450-f1204ec9dfed.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/4b42f5db-72ff-4b27-9b35-354a5297d4c2.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/f5e6e5a2-6e89-44e8-a4f4-76401bd4c430.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/e10e96a0-37a8-4acf-a25d-6aac879fc35e.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/c2cb3aec-2510-4f7a-9b3d-07d446c7cd08.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/d656aa54-d2c3-4faa-a971-cc7306f15594.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/4da80fde-3485-4de0-9450-f1204ec9dfed.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/4b42f5db-72ff-4b27-9b35-354a5297d4c2.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/f5e6e5a2-6e89-44e8-a4f4-76401bd4c430.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/e10e96a0-37a8-4acf-a25d-6aac879fc35e.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/c2cb3aec-2510-4f7a-9b3d-07d446c7cd08.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/0e6a48f4-59c5-4870-b830-19dd67245675.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/206eb751-3646-4900-a3f4-948a917887cb.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8eb6543a-66af-4b5b-a48d-68796ad96efb.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/b911e1a1-416f-47e6-ad01-a507caa1c931.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/2af77612-1211-4097-a09a-51fe1deaae7d.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/93dc281a-3284-433f-862e-0e0722123d69.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/81210bb5-9d23-4a07-9282-6a16acbf4da5.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/aaf58d24-98e8-4ac7-afef-8a2e3a83d8df.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/ecb54427-fdd1-4e7c-8c4a-2a154c61137d.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8e048884-aca9-443c-bddb-38a75abd8ee7.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/0e6a48f4-59c5-4870-b830-19dd67245675.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/206eb751-3646-4900-a3f4-948a917887cb.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8eb6543a-66af-4b5b-a48d-68796ad96efb.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/b911e1a1-416f-47e6-ad01-a507caa1c931.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/2af77612-1211-4097-a09a-51fe1deaae7d.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/93dc281a-3284-433f-862e-0e0722123d69.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/81210bb5-9d23-4a07-9282-6a16acbf4da5.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/aaf58d24-98e8-4ac7-afef-8a2e3a83d8df.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/ecb54427-fdd1-4e7c-8c4a-2a154c61137d.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8e048884-aca9-443c-bddb-38a75abd8ee7.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/0e6a48f4-59c5-4870-b830-19dd67245675.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/206eb751-3646-4900-a3f4-948a917887cb.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8eb6543a-66af-4b5b-a48d-68796ad96efb.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/b911e1a1-416f-47e6-ad01-a507caa1c931.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/2af77612-1211-4097-a09a-51fe1deaae7d.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/93dc281a-3284-433f-862e-0e0722123d69.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/81210bb5-9d23-4a07-9282-6a16acbf4da5.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/aaf58d24-98e8-4ac7-afef-8a2e3a83d8df.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/ecb54427-fdd1-4e7c-8c4a-2a154c61137d.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8e048884-aca9-443c-bddb-38a75abd8ee7.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/0e6a48f4-59c5-4870-b830-19dd67245675.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/206eb751-3646-4900-a3f4-948a917887cb.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8eb6543a-66af-4b5b-a48d-68796ad96efb.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/b911e1a1-416f-47e6-ad01-a507caa1c931.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/2af77612-1211-4097-a09a-51fe1deaae7d.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/93dc281a-3284-433f-862e-0e0722123d69.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/81210bb5-9d23-4a07-9282-6a16acbf4da5.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/aaf58d24-98e8-4ac7-afef-8a2e3a83d8df.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/ecb54427-fdd1-4e7c-8c4a-2a154c61137d.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8e048884-aca9-443c-bddb-38a75abd8ee7.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/0e6a48f4-59c5-4870-b830-19dd67245675.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/206eb751-3646-4900-a3f4-948a917887cb.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8eb6543a-66af-4b5b-a48d-68796ad96efb.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/b911e1a1-416f-47e6-ad01-a507caa1c931.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* hebrew */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/2af77612-1211-4097-a09a-51fe1deaae7d.woff2") format('woff2');
  unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}
/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/93dc281a-3284-433f-862e-0e0722123d69.woff2") format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/81210bb5-9d23-4a07-9282-6a16acbf4da5.woff2") format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* vietnamese */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/aaf58d24-98e8-4ac7-afef-8a2e3a83d8df.woff2") format('woff2');
  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;
}
/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/ecb54427-fdd1-4e7c-8c4a-2a154c61137d.woff2") format('woff2');
  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;
}
/* latin */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 800;
  font-stretch: 100%;
  font-display: swap;
  src: url("assets/8e048884-aca9-443c-bddb-38a75abd8ee7.woff2") format('woff2');
  unicode-range: U+0000-00FF, 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;
}

/* MetroDev â€” Chat IA Landing â€” alineado a Manual de Marca */
:root {
  /* Brand oficial â€” Manual de Marca MetroDev */
  --md-brand:       #28285B;   /* color principal */
  --md-brand-ink:   #222222;   /* color secundario */
  --md-brand-deep:  #1A1A40;   /* tinte mÃ¡s profundo para gradientes */
  --md-brand-soft:  #3A3A78;   /* tinte medio */

  --md-blue-900: #15153A;
  --md-blue-800: #28285B;      /* = brand */
  --md-blue-700: #3A3A78;
  --md-blue-600: #4F4FA0;
  --md-blue-500: #6E6EC2;
  --md-blue-400: #9B9BDA;
  --md-blue-100: #E4E4F4;
  --md-blue-50:  #F2F2F9;

  --md-green-600: #00B377;
  --md-green-500: #00CC88;
  --md-green-400: #34E0A1;
  --md-green-100: #DCFBEC;

  --md-ink-900: #1A1A2E;
  --md-ink-700: #2A2A3D;
  --md-ink-500: #5A5A70;
  --md-ink-300: #A6A6BA;
  --md-ink-100: #E8E8F0;

  --md-bg: #FFFFFF;
  --md-bg-soft: #F7F7FB;

  --grad-primary: linear-gradient(135deg, #28285B 0%, #4F4FA0 55%, #00CC88 100%);
  --grad-primary-soft: linear-gradient(135deg, rgba(40,40,91,0.06), rgba(0,204,136,0.06));
  --grad-blue: linear-gradient(135deg, #28285B 0%, #4F4FA0 100%);
  --grad-green: linear-gradient(135deg, #00B377 0%, #34E0A1 100%);
  --grad-deep: linear-gradient(160deg, #15153A 0%, #28285B 50%, #3A3A78 100%);

  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 24px;
  --r-2xl: 32px;

  --shadow-sm: 0 1px 2px rgba(11,18,32,0.06), 0 1px 3px rgba(11,18,32,0.04);
  --shadow-md: 0 4px 12px rgba(11,18,32,0.06), 0 2px 4px rgba(11,18,32,0.04);
  --shadow-lg: 0 18px 40px rgba(0,61,153,0.12), 0 4px 12px rgba(11,18,32,0.06);
  --shadow-glow-blue: 0 0 0 1px rgba(0,102,204,0.15), 0 12px 40px rgba(0,102,204,0.25);
  --shadow-glow-green: 0 0 0 1px rgba(0,204,136,0.20), 0 12px 40px rgba(0,204,136,0.25);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Open Sans', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--md-ink-700);
  background: var(--md-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
  font-family: 'Open Sans', system-ui, sans-serif;
  font-weight: 800;
  color: var(--md-ink-900);
  letter-spacing: -0.02em;
  line-height: 1.08;
  margin: 0;
  text-wrap: balance;
}

p { text-wrap: pretty; margin: 0; }

a { color: inherit; text-decoration: none; }

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 28px;
}

section { padding: 120px 0; position: relative; }
section.tight { padding: 88px 0; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'JetBrains Mono', 'IBM Plex Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-blue-700);
  padding: 6px 12px;
  background: var(--md-blue-50);
  border: 1px solid var(--md-blue-100);
  border-radius: 999px;
}
.eyebrow::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--md-green-500);
  box-shadow: 0 0 0 4px rgba(0,204,136,0.2);
  animation: pulseDot 1.6s ease-in-out infinite;
}

@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(0,204,136,0.5); }
  50%      { box-shadow: 0 0 0 6px rgba(0,204,136,0); }
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: 'Open Sans', sans-serif;
  font-weight: 600;
  font-size: 16px;
  border: none;
  cursor: pointer;
  border-radius: var(--r-md);
  padding: 16px 28px;
  transition: transform .2s ease, box-shadow .25s ease, filter .2s ease;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary {
  background: var(--grad-primary);
  color: white;
  box-shadow: var(--shadow-glow-blue);
  position: relative;
  overflow: hidden;
}
.btn-primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.25) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .8s ease;
}
.btn-primary:hover::after { transform: translateX(100%); }
.btn-primary:hover { box-shadow: 0 0 0 1px rgba(0,102,204,0.2), 0 16px 50px rgba(0,102,204,0.35); }

.btn-green {
  background: var(--grad-green);
  color: white;
  box-shadow: var(--shadow-glow-green);
}
.btn-ghost {
  background: transparent;
  color: white;
  border: 1.5px solid rgba(255,255,255,0.45);
}
.btn-ghost:hover { background: rgba(255,255,255,0.08); }

.btn-lg { font-size: 18px; padding: 20px 36px; border-radius: var(--r-lg); }

/* Reveal on scroll */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* NAV */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.85);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid rgba(11,18,32,0.06);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 28px;
  max-width: 1200px;
  margin: 0 auto;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.brand-logo {
  height: 28px;
  width: auto;
  display: block;
}
.brand-logo-light { height: 32px; }
.brand-mark {
  width: 30px; height: 30px;
  border-radius: 8px;
  background: var(--grad-blue);
  display: grid; place-items: center;
  color: white;
  font-weight: 800;
  font-size: 14px;
  box-shadow: var(--shadow-sm);
}
.nav-links { display: flex; gap: 28px; align-items: center; }
.nav-links a {
  font-size: 14px;
  font-weight: 500;
  color: var(--md-ink-700);
  transition: color .2s ease;
}
.nav-links a:hover { color: var(--md-blue-700); }
.nav-cta {
  background: var(--md-ink-900);
  color: white !important;
  padding: 10px 18px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
}
@media (max-width: 760px) {
  .nav-links a:not(.nav-cta) { display: none; }
}

/* HERO */
.hero {
  position: relative;
  overflow: hidden;
  background: var(--grad-deep);
  color: white;
  padding: 100px 0 140px;
  isolation: isolate;
}
.hero::before {
  /* network grid */
  content: "";
  position: absolute; inset: 0;
  background-image:
    radial-gradient(rgba(255,255,255,0.12) 1px, transparent 1px),
    radial-gradient(rgba(0,204,136,0.08) 1px, transparent 1px);
  background-size: 40px 40px, 80px 80px;
  background-position: 0 0, 20px 20px;
  mask-image: radial-gradient(ellipse at 30% 30%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 30% 30%, black 30%, transparent 75%);
  z-index: 0;
}
.hero::after {
  content: "";
  position: absolute;
  right: -180px; top: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(0,204,136,0.30) 0%, transparent 60%);
  filter: blur(20px);
  z-index: 0;
}
.hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 60px;
  align-items: center;
}
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  margin-bottom: 28px;
  backdrop-filter: blur(10px);
}
.hero-badge .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--md-green-400);
  box-shadow: 0 0 12px var(--md-green-400);
  animation: pulseDot 1.6s ease-in-out infinite;
}

.hero h1 {
  color: white;
  font-size: clamp(34px, 5.4vw, 62px);
  font-weight: 800;
  margin-bottom: 24px;
}
.hero h1 .accent {
  background: linear-gradient(120deg, #34E0A1 0%, #5BA3F5 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-sub {
  font-size: clamp(17px, 1.6vw, 21px);
  color: rgba(255,255,255,0.78);
  max-width: 540px;
  margin-bottom: 40px;
}
.hero-ctas { display: flex; gap: 16px; flex-wrap: wrap; }

.hero-meta {
  display: flex;
  gap: 18px;
  margin-top: 44px;
  flex-wrap: nowrap;
  font-size: 13px;
  color: rgba(255,255,255,0.7);
}
.hero-meta .item { display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.hero-meta .check {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--md-green-500);
  color: white;
  display: grid; place-items: center;
  font-size: 11px;
  font-weight: 700;
}
@media (max-width: 760px) {
  .hero-meta {
    flex-wrap: wrap;
    gap: 12px 18px;
  }
}

/* FOOTER */
.footer {
  background: var(--md-ink-900);
  color: rgba(255,255,255,0.7);
  padding: 52px 0 26px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  max-width: 560px;
  margin: 0 auto 26px;
  align-items: center;
  text-align: center;
}
@media (max-width: 760px) {
  .footer { padding: 44px 0 24px; }
  .footer-grid { gap: 18px; margin-bottom: 20px; }
}
.footer .brand {
  justify-content: center;
}
.footer h4 {
  color: white;
  font-size: 13px;
  font-family: 'Open Sans', sans-serif;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.footer ul { list-style: none; padding: 0; margin: 0; }
.footer li { margin-bottom: 6px; font-size: 14px; }
.footer-bottom {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  text-align: center;
  font-size: 13px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.footer-bottom-logo {
  height: 22px;
  width: auto;
  opacity: 0.65;
}
.footer-link {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s;
}
.footer-link:hover {
  color: var(--md-green-500);
}
.footer-sede b {
  color: rgba(255,255,255,0.85);
}
.footer-sedes {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  justify-content: center;
}
.footer-sep {
  opacity: 0.4;
}
@media (max-width: 600px) {
  .footer-bottom { flex-direction: column; gap: 12px; }
  .footer li { font-size: 13px; }
  .footer-sedes {
    flex-direction: column;
    gap: 4px;
    align-items: center;
  }
  .footer-sep { display: none; }
}

/* utility */
.section-head { text-align: center; margin-bottom: 64px; }
.section-head h2 {
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 800;
  margin: 16px auto 16px;
  max-width: 780px;
}
.section-head h2 .accent {
  background: var(--grad-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.section-head p {
  font-size: 18px;
  color: var(--md-ink-500);
  max-width: 640px;
  margin: 0 auto;
}

/* HERO VISUAL */
.hero-visual {
  position: relative;
  height: 480px;
}
@media (max-width: 980px) { .hero-visual { height: 420px; } }

.legacy-box, .md-box, .chat-box {
  position: absolute;
  border-radius: var(--r-lg);
  backdrop-filter: blur(12px);
}
.legacy-box {
  top: 30px; left: 0;
  width: 200px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.18);
  padding: 18px;
}
.legacy-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.legacy-name {
  color: white;
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 12px;
}
.legacy-rows .row {
  display: flex;
  justify-content: space-between;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: rgba(255,255,255,0.6);
  padding: 6px 0;
  border-bottom: 1px dashed rgba(255,255,255,0.10);
}
.legacy-rows .row:last-child { border-bottom: none; }
.legacy-rows .row b { color: var(--md-blue-400); font-weight: 600; }

.md-box {
  top: 200px; left: 50%;
  transform: translateX(-50%);
  background: rgba(0,102,204,0.18);
  border: 1px solid rgba(91,163,245,0.45);
  padding: 14px 22px;
  display: flex; align-items: center; gap: 12px;
  box-shadow: 0 12px 40px rgba(0,102,204,0.45);
}
.md-box .core {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: var(--grad-primary);
  display: grid; place-items: center;
  color: white;
  font-weight: 800;
  font-size: 12px;
}
.md-box .label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: white;
  letter-spacing: 0.05em;
}

.chat-box {
  bottom: 0; right: 0;
  width: 280px;
  background: rgba(255,255,255,0.96);
  color: var(--md-ink-900);
  padding: 18px;
  box-shadow: 0 20px 60px rgba(0,30,77,0.35);
}
.chat-head {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px;
  color: var(--md-ink-500);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.chat-head .live {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--md-green-500);
  box-shadow: 0 0 8px var(--md-green-500);
  animation: pulseDot 1.6s ease-in-out infinite;
}
.chat-q {
  font-size: 13px;
  color: var(--md-ink-700);
  background: var(--md-blue-50);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 8px;
}
.chat-a {
  font-size: 13px;
  color: var(--md-ink-900);
  background: linear-gradient(135deg, rgba(0,204,136,0.12), rgba(0,102,204,0.10));
  border-left: 3px solid var(--md-green-500);
  border-radius: 10px;
  padding: 10px 12px;
  font-weight: 500;
}
.chat-a .num { color: var(--md-blue-700); font-weight: 700; }

@media (max-width: 640px) {
  .hero-visual {
    height: 540px;
  }

  .legacy-box {
    top: 18px;
    left: 10px;
    width: min(210px, calc(100% - 92px));
    padding: 16px;
  }

  .md-box {
    top: 258px;
    left: 50%;
    padding: 12px 16px;
    gap: 10px;
  }

  .md-box .label {
    font-size: 11px;
    letter-spacing: 0.04em;
  }

  .chat-box {
    right: 10px;
    bottom: 12px;
    width: min(260px, calc(100% - 28px));
    padding: 16px;
  }
}

/* FLOW DIAGRAM */
.flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 720px;
  margin: 0 auto;
}
.flow-node {
  border-radius: var(--r-xl);
  padding: 28px;
  display: flex;
  align-items: center;
  gap: 20px;
  position: relative;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.flow-node:hover { transform: translateY(-3px); }
.flow-node .num {
  width: 40px; height: 40px;
  border-radius: 12px;
  display: grid; place-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
}
.flow-node h4 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 4px;
}
.flow-node p {
  font-size: 14px;
  color: var(--md-ink-500);
}
.flow-node.legacy {
  background: var(--md-bg-soft);
  border: 1px solid var(--md-ink-100);
}
.flow-node.legacy .num { background: var(--md-ink-100); color: var(--md-ink-700); }
.flow-node.layer {
  background: var(--grad-blue);
  color: white;
  box-shadow: var(--shadow-lg);
}
.flow-node.layer h4, .flow-node.layer p { color: white; }
.flow-node.layer p { color: rgba(255,255,255,0.85); }
.flow-node.layer .num { background: rgba(255,255,255,0.18); color: white; }
.flow-node.chat {
  background: linear-gradient(135deg, #003D99 0%, #00CC88 100%);
  color: white;
  box-shadow: 0 18px 50px rgba(0,204,136,0.25);
}
.flow-node.chat h4, .flow-node.chat p { color: white; }
.flow-node.chat p { color: rgba(255,255,255,0.92); }
.flow-node.chat .num { background: rgba(255,255,255,0.22); color: white; }

.flow-arrow {
  width: 2px;
  height: 36px;
  margin: -8px 0;
  justify-self: center;
  background: linear-gradient(to bottom, transparent 0%, var(--md-blue-600) 30%, var(--md-green-500) 100%);
  position: relative;
}
.flow-arrow::after {
  content: "";
  position: absolute;
  bottom: -6px; left: 50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 8px solid var(--md-green-500);
}
.flow-arrow .pulse {
  position: absolute;
  width: 8px; height: 8px;
  background: var(--md-green-400);
  border-radius: 50%;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 0 12px var(--md-green-400);
  animation: flowDown 1.8s ease-in-out infinite;
}
@keyframes flowDown {
  0% { top: 0; opacity: 0; }
  20% { opacity: 1; }
  80% { opacity: 1; }
  100% { top: 100%; opacity: 0; }
}

.flow-tag {
  position: absolute;
  right: 20px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  opacity: 0.7;
}

.flow-caption {
  text-align: center;
  margin-top: 56px;
  font-size: 20px;
  color: var(--md-ink-700);
  font-weight: 500;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.flow-caption b { color: var(--md-blue-800); font-weight: 700; }

/* BENEFITS */
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) { .benefits-grid { grid-template-columns: 1fr; } }
.benefit-card {
  border-radius: var(--r-xl);
  padding: 36px 32px 32px;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--md-ink-100);
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  min-height: 380px;
  display: flex;
  flex-direction: column;
}
.benefit-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
}
.benefit-card .icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  display: grid; place-items: center;
  margin-bottom: 24px;
  position: relative;
  z-index: 1;
}
.benefit-card h3 {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 10px;
  position: relative; z-index: 1;
}
.benefit-card p {
  font-size: 15px;
  color: var(--md-ink-500);
  margin-bottom: 24px;
  position: relative; z-index: 1;
}
.benefit-card .demo {
  margin-top: auto;
  background: white;
  border: 1px solid var(--md-ink-100);
  border-radius: var(--r-md);
  padding: 14px;
  position: relative; z-index: 1;
}

.benefit-card.b1 { background: linear-gradient(155deg, var(--md-blue-50) 0%, white 70%); }
.benefit-card.b1 .icon { background: var(--grad-blue); color: white; }
.benefit-card.b2 { background: linear-gradient(155deg, var(--md-green-100) 0%, white 70%); }
.benefit-card.b2 .icon { background: var(--grad-green); color: white; }
.benefit-card.b3 { background: var(--grad-deep); color: white; border-color: transparent; }
.benefit-card.b3 h3, .benefit-card.b3 p { color: white; }
.benefit-card.b3 p { color: rgba(255,255,255,0.78); }
.benefit-card.b3 .icon { background: rgba(255,255,255,0.15); color: white; backdrop-filter: blur(8px); }
.benefit-card.b3 .demo { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.18); color: white; }

/* DEMO TYPEWRITER */
.demo-shell {
  max-width: 720px;
  margin: 0 auto;
  border-radius: var(--r-2xl);
  background: white;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--md-ink-100);
  overflow: hidden;
}
.demo-shell .topbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 20px;
  background: var(--md-bg-soft);
  border-bottom: 1px solid var(--md-ink-100);
}
.demo-shell .topbar .dot { width: 10px; height: 10px; border-radius: 50%; background: #DEE3EC; }
.demo-shell .topbar .title {
  margin-left: 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--md-ink-500);
  letter-spacing: 0.06em;
}
.demo-conv { padding: 28px; }
.bubble {
  border-radius: 14px;
  padding: 14px 18px;
  margin-bottom: 12px;
  max-width: 78%;
  line-height: 1.5;
  font-size: 15px;
}
.bubble-user {
  background: var(--md-ink-100);
  color: var(--md-ink-900);
  margin-left: auto;
  border-bottom-right-radius: 4px;
}
.bubble-ai {
  background: linear-gradient(135deg, rgba(0,61,153,0.06), rgba(0,204,136,0.10));
  border: 1px solid rgba(0,204,136,0.25);
  color: var(--md-ink-900);
  border-bottom-left-radius: 4px;
  font-family: 'Open Sans', sans-serif;
  white-space: pre-wrap;
  position: relative;
}
.bubble-ai .caret {
  display: inline-block;
  width: 8px; height: 18px;
  background: var(--md-green-600);
  vertical-align: -3px;
  margin-left: 2px;
  animation: blink 0.9s steps(2) infinite;
}
@keyframes blink { 50% { opacity: 0; } }
.bubble-ai .stat { color: var(--md-blue-700); font-weight: 700; }
.bubble-ai .alert { color: var(--md-green-600); font-weight: 700; }

.demo-foot {
  text-align: center;
  margin-top: 36px;
}

/* CASES */
.cases-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
@media (max-width: 800px) { .cases-grid { grid-template-columns: 1fr; } }
.case-card {
  border: 1px solid var(--md-ink-100);
  border-radius: var(--r-xl);
  padding: 36px;
  background: white;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease, border-color .35s ease;
  position: relative;
  overflow: hidden;
}
.case-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--grad-primary-soft);
  opacity: 0;
  transition: opacity .35s ease;
}
.case-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: transparent; }
.case-card:hover::before { opacity: 1; }
.case-card > * { position: relative; }

.case-tag {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--md-blue-700);
  background: var(--md-blue-50);
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 20px;
}
.case-card h3 { font-size: 26px; font-weight: 800; margin-bottom: 16px; }
.case-list { list-style: none; padding: 0; margin: 0 0 24px; }
.case-list li {
  display: flex;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--md-ink-100);
  font-size: 15px;
  color: var(--md-ink-700);
}
.case-list li:last-child { border-bottom: none; }
.case-list .arrow {
  color: var(--md-green-600);
  font-weight: 700;
  flex-shrink: 0;
}
.case-impact {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--md-ink-100);
}
.case-impact .num {
  font-family: 'Open Sans', sans-serif;
  font-size: 40px;
  font-weight: 800;
  background: var(--grad-primary);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
}
.case-impact .lbl {
  font-size: 13px;
  color: var(--md-ink-500);
}

/* TIMELINE */
.timeline {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  position: relative;
}
@media (max-width: 900px) { .timeline { grid-template-columns: 1fr; } }
.timeline::before {
  content: "";
  position: absolute;
  top: 36px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: repeating-linear-gradient(
    to right,
    var(--md-blue-600) 0 8px,
    transparent 8px 16px
  );
  z-index: 0;
}
@media (max-width: 900px) { .timeline::before { display: none; } }
.step {
  position: relative;
  z-index: 1;
  background: white;
  border: 1px solid var(--md-ink-100);
  border-radius: var(--r-xl);
  padding: 28px;
  text-align: center;
  transition: transform .3s ease, box-shadow .3s ease;
}
.step:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.step .circle {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--grad-blue);
  margin: 0 auto 16px;
  display: grid; place-items: center;
  color: white;
  font-family: 'Open Sans', sans-serif;
  font-weight: 800;
  font-size: 28px;
  box-shadow: 0 8px 24px rgba(0,102,204,0.35);
}
.step.s2 .circle { background: linear-gradient(135deg, #0066CC, #00CC88); box-shadow: 0 8px 24px rgba(0,180,140,0.35); }
.step.s3 .circle { background: var(--grad-green); box-shadow: 0 8px 24px rgba(0,204,136,0.4); }
.step .when {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--md-blue-700);
  margin-bottom: 8px;
}
.step h4 {
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 10px;
}
.step p {
  font-size: 14px;
  color: var(--md-ink-500);
}

/* FAQ */
.faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  max-width: 920px;
  margin: 0 auto;
}
@media (max-width: 760px) { .faq-grid { grid-template-columns: 1fr; } }
.faq-item {
  background: white;
  border: 1px solid var(--md-ink-100);
  border-radius: var(--r-lg);
  padding: 22px 24px;
  cursor: pointer;
  transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
.faq-item:hover { border-color: var(--md-blue-100); box-shadow: var(--shadow-md); }
.faq-item.open {
  border-color: var(--md-blue-100);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.faq-q {
  display: flex;
  align-items: center;
  font-weight: 600;
  color: var(--md-ink-900);
  font-size: 16px;
}
.faq-a {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  color: var(--md-ink-500);
  margin-top: 0;
  line-height: 1.55;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: max-height .35s ease, opacity .35s ease, margin-top .35s ease;
}
.faq-item.open .faq-a {
  max-height: 420px;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  margin-top: 14px;
}
.faq-a .check {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--md-green-500);
  color: white;
  display: grid; place-items: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}
.faq-toggle {
  margin-left: auto;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--md-blue-50);
  display: grid; place-items: center;
  color: var(--md-blue-700);
  font-weight: 700;
  transition: transform .3s ease, background-color .2s ease;
}
.faq-item.open .faq-toggle {
  transform: rotate(0deg);
  background: rgba(0, 204, 136, 0.16);
}

/* CTA FINAL */
.cta-final {
  background: var(--grad-deep);
  color: white;
  position: relative;
  overflow: hidden;
}
.cta-final::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(rgba(255,255,255,0.10) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
}
.cta-final::after {
  content: "";
  position: absolute;
  bottom: -200px; right: -200px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(0,204,136,0.4) 0%, transparent 70%);
  filter: blur(40px);
}
.cta-final .container { position: relative; z-index: 1; text-align: center; }
.cta-final h2 {
  color: white;
  font-size: clamp(36px, 5vw, 60px);
  font-weight: 800;
  margin-bottom: 20px;
}
.cta-final p {
  color: rgba(255,255,255,0.78);
  font-size: 19px;
  max-width: 580px;
  margin: 0 auto 40px;
}
.cta-buttons { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-bottom: 24px; }
.cta-fineprint {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.06em;
}

/* DEMO SECTION (dark) */
.demo-section {
  background: var(--grad-deep);
  color: white;
  position: relative;
  overflow: hidden;
}
.demo-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(91,163,245,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(91,163,245,0.06) 1px, transparent 1px);
  background-size: 48px 48px;
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
  z-index: 0;
}
.demo-section .container { position: relative; z-index: 1; }
.demo-section .section-head h2 { color: white; }
.demo-section .section-head h2 .accent {
  background: linear-gradient(120deg, #34E0A1 0%, #5BA3F5 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.demo-section .section-head p { color: rgba(255,255,255,0.72); }
.demo-section .eyebrow {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.18);
  color: rgba(255,255,255,0.85);
}

/* FORM */
.form-section { }
.form-card {
  max-width: 560px;
  margin: 0 auto;
  background: white;
  border-radius: var(--r-2xl);
  padding: 48px;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--md-ink-100);
}
@media (max-width: 600px) { .form-card { padding: 32px 24px; } }
.form-card h3 {
  font-size: 28px;
  font-weight: 800;
  margin-bottom: 8px;
  text-align: center;
}
.form-card .lead {
  text-align: center;
  color: var(--md-ink-500);
  margin-bottom: 32px;
}
.field { margin-bottom: 18px; }
.field label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--md-ink-700);
  margin-bottom: 6px;
  letter-spacing: 0.02em;
}
.field input, .field select {
  width: 100%;
  padding: 14px 16px;
  border: 1.5px solid var(--md-ink-100);
  border-radius: var(--r-md);
  font-family: inherit;
  font-size: 15px;
  color: var(--md-ink-900);
  background: white;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.field input:focus, .field select:focus {
  outline: none;
  border-color: var(--md-blue-600);
  box-shadow: 0 0 0 4px rgba(0,102,204,0.10);
}
.form-card .btn { width: 100%; margin-top: 8px; }
.form-success {
  text-align: center;
  padding: 32px 16px;
}
.form-success .check {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--grad-green);
  display: grid; place-items: center;
  color: white;
  font-size: 28px;
  font-weight: 800;
  margin: 0 auto 20px;
  box-shadow: 0 12px 32px rgba(0,204,136,0.35);
}
.form-success h3 { font-size: 24px; margin-bottom: 10px; }
.form-success p { color: var(--md-ink-500); }

.form-fineprint {
  text-align: center;
  font-size: 13px;
  color: var(--md-ink-500);
  margin-top: 20px;
}
.checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  margin-top: 8px;
}
.checkbox-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  color: var(--md-ink-700);
  cursor: pointer;
}
.checkbox-label input[type="checkbox"] {
  width: 17px;
  height: 17px;
  accent-color: var(--md-green-500);
  cursor: pointer;
  flex-shrink: 0;
}

/* PROBLEMA */
.problem-card {
  background: white;
  border: 1px solid var(--md-ink-100);
  border-radius: var(--r-xl);
  padding: 32px;
  transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease;
}
.problem-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--md-blue-100);
}
.problem-icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: var(--md-bg-soft);
  border: 1px solid var(--md-ink-100);
  color: var(--md-ink-500);
  display: grid; place-items: center;
  margin-bottom: 20px;
  transition: background .3s ease, color .3s ease, border-color .3s ease;
}
.problem-card:hover .problem-icon {
  background: var(--md-blue-50);
  color: var(--md-blue-700);
  border-color: var(--md-blue-100);
}
.problem-card h3 {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 10px;
}
.problem-card p {
  font-size: 15px;
  color: var(--md-ink-500);
}

/* BENTO */
.bento {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
@media (max-width: 800px) { .bento { grid-template-columns: 1fr; } }
.bento-card {
  background: white;
  border: 1px solid var(--md-ink-100);
  border-radius: var(--r-xl);
  padding: 32px;
  transition: transform .3s ease, box-shadow .3s ease;
  display: flex;
  flex-direction: column;
}
.bento-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.bento-card.big {
  grid-row: span 2;
  background: var(--grad-deep);
  color: white;
  border-color: transparent;
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}
.bento-card.big::before {
  content: "";
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse at top right, black 30%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at top right, black 30%, transparent 70%);
}
.bento-card.big > * { position: relative; z-index: 1; }
.bento-card.big h3, .bento-card.big p { color: white; }
.bento-card.big p { color: rgba(255,255,255,0.78); }
.bento-icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  background: var(--grad-blue);
  color: white;
  display: grid; place-items: center;
  margin-bottom: 20px;
}
.bento-icon.green { background: var(--grad-green); }
.bento-card.big .bento-icon { background: rgba(255,255,255,0.15); backdrop-filter: blur(8px); }
.bento-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--md-blue-700);
  margin-bottom: 8px;
}
.bento-card.big .bento-meta { color: rgba(255,255,255,0.6); }
.bento-card h3 { font-size: 22px; font-weight: 700; margin-bottom: 12px; }
.bento-card.big h3 { font-size: 28px; }
.bento-card p { font-size: 15px; color: var(--md-ink-500); }

.bento-track {
  margin-top: auto;
  padding-top: 32px;
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.08em;
}
.bento-track .m1 { text-align: center; }
.bento-track .m2 { text-align: right; color: var(--md-green-400); }
.bento-track-fill {
  position: absolute;
  left: 0; right: 0; top: 16px;
  height: 4px;
  background: rgba(255,255,255,0.10);
  border-radius: 2px;
  overflow: hidden;
}
.bento-track-fill::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 92%;
  background: linear-gradient(to right, var(--md-blue-400), var(--md-green-400));
  border-radius: 2px;
  animation: trackFill 2.4s ease-out forwards;
  transform-origin: left;
}
@keyframes trackFill {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

/* CASES 3-col responsive */
.cases-grid-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) {
  .cases-grid-3 { grid-template-columns: 1fr !important; }
}

  body.dense section { padding: 72px 0 !important; }
  body.dense section.tight { padding: 56px 0 !important; }
  body.dense .section-head { margin-bottom: 40px !important; }

  #app-loading-overlay {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: radial-gradient(circle at 50% 30%, rgba(79,79,160,0.3), rgba(21,21,58,0.98));
    z-index: 9999;
    opacity: 1;
    visibility: visible;
    transition: opacity 420ms ease, visibility 420ms ease;
  }

  #app-loading-overlay.is-hidden {
    opacity: 0;
    visibility: hidden;
  }

  #app-loading-logo {
    width: clamp(120px, 18vw, 210px);
    height: auto;
    filter: drop-shadow(0 14px 30px rgba(0, 0, 0, 0.35));
    animation: appLogoPulse 1.4s ease-in-out infinite;
  }

  @keyframes appLogoPulse {
    0% { transform: scale(0.98); opacity: 0.82; }
    50% { transform: scale(1); opacity: 1; }
    100% { transform: scale(0.98); opacity: 0.82; }
  }
