/* Pioneers Partners — Website UI Kit styles */
/* ==========================================================================
   PIONEERS PARTNERS — Colors & Type
   Base tokens + semantic CSS variables for typography and color.
   Load this first; everything else in the design system depends on it.
   ========================================================================== */

/* Fonts — pulled from Google Fonts (Brand Guideline page 05).
   If you ship offline, drop the .woff2 files into ./fonts/ and replace this
   @import with @font-face rules. */
/* vietnamese */
@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/2570f14f-83b2-4792-9770-601ed3ebeba3.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/3df7e38b-3769-4cc3-8466-f55e7281d99d.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("fonts/64012c82-6512-4f9e-b347-5eb110d0993f.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;
}
/* vietnamese */
@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/2570f14f-83b2-4792-9770-601ed3ebeba3.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/3df7e38b-3769-4cc3-8466-f55e7281d99d.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("fonts/64012c82-6512-4f9e-b347-5eb110d0993f.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;
}
/* vietnamese */
@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/2570f14f-83b2-4792-9770-601ed3ebeba3.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/3df7e38b-3769-4cc3-8466-f55e7281d99d.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("fonts/64012c82-6512-4f9e-b347-5eb110d0993f.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;
}
/* vietnamese */
@font-face {
  font-family: 'Josefin Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/2570f14f-83b2-4792-9770-601ed3ebeba3.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/3df7e38b-3769-4cc3-8466-f55e7281d99d.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: 'Josefin Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("fonts/64012c82-6512-4f9e-b347-5eb110d0993f.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/1ffcbe27-6d8a-40f0-8fa6-0281d4126bd6.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/8a01f2ff-8d0e-4e70-a10e-24aa504f0371.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/831d430a-2dda-4ee3-bc35-6f0222ee8519.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/ddf7c840-47be-432e-836b-291696b44313.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/98cfc322-461a-429c-b0d6-0358e7712d12.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/379fe69b-dc79-40f3-a049-c197ee5daa9a.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/8193a9de-5f61-42a4-bd75-efb7819ed6b0.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/6db1cf69-6b9b-4bca-bc8b-45b4b6766132.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/0f179cd6-8a71-4c3d-af28-e69a1fa7f854.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: italic;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/b19313ac-d9d2-44a4-8aba-d483081081d5.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/1ffcbe27-6d8a-40f0-8fa6-0281d4126bd6.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/8a01f2ff-8d0e-4e70-a10e-24aa504f0371.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/831d430a-2dda-4ee3-bc35-6f0222ee8519.woff2") format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/ddf7c840-47be-432e-836b-291696b44313.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/98cfc322-461a-429c-b0d6-0358e7712d12.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/379fe69b-dc79-40f3-a049-c197ee5daa9a.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/8193a9de-5f61-42a4-bd75-efb7819ed6b0.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/6db1cf69-6b9b-4bca-bc8b-45b4b6766132.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/0f179cd6-8a71-4c3d-af28-e69a1fa7f854.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: italic;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("fonts/b19313ac-d9d2-44a4-8aba-d483081081d5.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("fonts/348f8e96-b5e5-4bcd-ae57-2122453efeb7.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("fonts/aa1fb6a7-016d-44b7-87d9-4cb8e84eafd0.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("fonts/95d7fbee-d47c-4307-aa6a-f1532b376139.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("fonts/bc2eba4c-47c4-497e-86f2-1491d9bb2e5e.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("fonts/67b8f6df-3082-47ad-9d54-5f97710309d2.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("fonts/d66b83f3-a2b6-4317-9a77-9c34dd0df264.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("fonts/99fcc0ed-f05b-47a6-ba1d-74a48f5ddc33.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("fonts/7f210970-8cb8-4cfd-82f4-56d478485da1.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("fonts/cdbc2310-82a8-45e0-8e64-d169772eb8ac.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("fonts/d4cfdccd-6d4d-4ebf-9996-2d38f650184b.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("fonts/348f8e96-b5e5-4bcd-ae57-2122453efeb7.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("fonts/aa1fb6a7-016d-44b7-87d9-4cb8e84eafd0.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("fonts/95d7fbee-d47c-4307-aa6a-f1532b376139.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("fonts/bc2eba4c-47c4-497e-86f2-1491d9bb2e5e.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("fonts/67b8f6df-3082-47ad-9d54-5f97710309d2.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("fonts/d66b83f3-a2b6-4317-9a77-9c34dd0df264.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("fonts/99fcc0ed-f05b-47a6-ba1d-74a48f5ddc33.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("fonts/7f210970-8cb8-4cfd-82f4-56d478485da1.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("fonts/cdbc2310-82a8-45e0-8e64-d169772eb8ac.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("fonts/d4cfdccd-6d4d-4ebf-9996-2d38f650184b.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("fonts/348f8e96-b5e5-4bcd-ae57-2122453efeb7.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("fonts/aa1fb6a7-016d-44b7-87d9-4cb8e84eafd0.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("fonts/95d7fbee-d47c-4307-aa6a-f1532b376139.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("fonts/bc2eba4c-47c4-497e-86f2-1491d9bb2e5e.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("fonts/67b8f6df-3082-47ad-9d54-5f97710309d2.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("fonts/d66b83f3-a2b6-4317-9a77-9c34dd0df264.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("fonts/99fcc0ed-f05b-47a6-ba1d-74a48f5ddc33.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("fonts/7f210970-8cb8-4cfd-82f4-56d478485da1.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("fonts/cdbc2310-82a8-45e0-8e64-d169772eb8ac.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("fonts/d4cfdccd-6d4d-4ebf-9996-2d38f650184b.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("fonts/348f8e96-b5e5-4bcd-ae57-2122453efeb7.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("fonts/aa1fb6a7-016d-44b7-87d9-4cb8e84eafd0.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("fonts/95d7fbee-d47c-4307-aa6a-f1532b376139.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("fonts/bc2eba4c-47c4-497e-86f2-1491d9bb2e5e.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("fonts/67b8f6df-3082-47ad-9d54-5f97710309d2.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("fonts/d66b83f3-a2b6-4317-9a77-9c34dd0df264.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("fonts/99fcc0ed-f05b-47a6-ba1d-74a48f5ddc33.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("fonts/7f210970-8cb8-4cfd-82f4-56d478485da1.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("fonts/cdbc2310-82a8-45e0-8e64-d169772eb8ac.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("fonts/d4cfdccd-6d4d-4ebf-9996-2d38f650184b.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;
}


:root {
  /* ── BRAND COLORS ───────────────────────────────────────────────── */
  --pp-blue:          #0069B4;   /* Primary — from logo SVG */
  --pp-blue-950:      #00243D;   /* Midnight — hero/footer (CI 1.0) */
  --pp-blue-900:      #003A63;   /* Headlines on light, dark sections */
  --pp-blue-700:      #00528F;   /* Hover / pressed */
  --pp-blue-500:      #0069B4;   /* = --pp-blue */
  --pp-blue-300:      #4B9BD4;   /* Illustration, chart mid */
  --pp-blue-100:      #D6E8F4;   /* Subtle fills, badges */
  --pp-blue-050:      #EEF5FB;   /* Page tint, card base */

  /* Neutrals — warm-cool slate */
  --pp-ink:           #0E1726;
  --pp-ink-700:       #243247;
  --pp-ink-500:       #5A6B82;
  --pp-ink-300:       #98A6BA;
  --pp-stone:         #BEC3C5;   /* Warm neutral grey (CI 1.0) */
  --pp-line:          #DCE3EC;
  --pp-surface:       #F5F7FA;
  --pp-surface-alt:   #FFFFFF;
  --pp-white:         #FFFFFF;

  /* Accents — used as signal, never as decoration */
  --pp-orange:        #E25822;   /* Persimmon — CI 1.0 candidate */
  --pp-orange-500:    #E25822;
  --pp-orange-100:    #FBE2D5;
  --pp-amber:         #FBBA00;   /* CI 1.0 — highlight signal */
  --pp-amber-100:     #FFF2D8;
  --pp-gold:          #FBBA00;   /* alias — prefer --pp-amber */
  --pp-signal:        #D64545;   /* errors / critical only */
  --pp-success:       #1F8A5C;

  /* Optional — humanistic + sector tags (CI 1.0) */
  --pp-sage:          #7AC6B6;
  --pp-sage-100:      #A8D7CE;
  --pp-forest:        #024537;

  /* ── SEMANTIC FOREGROUND / BACKGROUND ───────────────────────────── */
  --fg-1: var(--pp-ink);          /* Body text */
  --fg-2: var(--pp-ink-700);      /* Secondary text */
  --fg-3: var(--pp-ink-500);      /* Meta, caption */
  --fg-4: var(--pp-ink-300);      /* Disabled */
  --fg-accent: var(--pp-blue);    /* Links, accents */
  --fg-on-dark: var(--pp-white);

  --bg-1: var(--pp-surface);      /* Canvas */
  --bg-2: var(--pp-white);        /* Card */
  --bg-3: var(--pp-blue-050);     /* Soft tint */
  --bg-inverse: var(--pp-blue-950);

  --border: var(--pp-line);
  --border-strong: var(--pp-ink-300);

  /* ── TYPOGRAPHY ─────────────────────────────────────────────────── */
  --pp-font-display:  "Josefin Sans", "Futura", "Helvetica Neue", Arial, sans-serif;
  --pp-font-sans:     "Open Sans", -apple-system, BlinkMacSystemFont,
                      "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --pp-font-mono:     "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;

  --serif-display: var(--pp-font-display);   /* historical alias — semantic */
  --sans:          var(--pp-font-sans);
  --mono:          var(--pp-font-mono);

  /* Type scale — 1.250 Major Third */
  --pp-fs-xs:   12px;
  --pp-fs-sm:   14px;
  --pp-fs-base: 16px;
  --pp-fs-md:   18px;
  --pp-fs-lg:   22px;
  --pp-fs-xl:   28px;
  --pp-fs-2xl:  36px;
  --pp-fs-3xl:  46px;
  --pp-fs-4xl:  60px;
  --pp-fs-5xl:  78px;

  --pp-lh-tight: 1.1;
  --pp-lh-snug:  1.25;
  --pp-lh-base:  1.55;
  --pp-lh-loose: 1.7;

  --pp-tracking-tight:  -0.02em;
  --pp-tracking-normal: 0;
  --pp-tracking-wide:    0.08em;
  --pp-tracking-caps:    0.14em;

  /* ── SPACING (4pt base) ─────────────────────────────────────────── */
  --pp-space-1:   4px;
  --pp-space-2:   8px;
  --pp-space-3:  12px;
  --pp-space-4:  16px;
  --pp-space-5:  24px;
  --pp-space-6:  32px;
  --pp-space-7:  48px;
  --pp-space-8:  64px;
  --pp-space-9:  96px;
  --pp-space-10:128px;

  /* ── RADII ──────────────────────────────────────────────────────── */
  --pp-radius-sm:   4px;
  --pp-radius-md:   8px;
  --pp-radius-lg:  14px;
  --pp-radius-xl:  22px;
  --pp-radius-pill: 999px;

  /* ── SHADOWS / ELEVATION ────────────────────────────────────────── */
  --pp-shadow-1: 0 1px 2px rgba(14, 23, 38, 0.06), 0 1px 1px rgba(14, 23, 38, 0.04);
  --pp-shadow-2: 0 6px 16px -4px rgba(14, 23, 38, 0.10), 0 2px 4px rgba(14, 23, 38, 0.04);
  --pp-shadow-3: 0 18px 40px -12px rgba(0, 105, 180, 0.22), 0 4px 10px rgba(14, 23, 38, 0.06);
  --pp-shadow-focus: 0 0 0 3px rgba(0, 105, 180, 0.28);

  /* ── MOTION ─────────────────────────────────────────────────────── */
  --pp-ease-out:    cubic-bezier(0.2, 0.7, 0.2, 1);
  --pp-ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --pp-dur-fast: 140ms;
  --pp-dur-med:  240ms;
  --pp-dur-slow: 420ms;

  /* ── LAYOUT ─────────────────────────────────────────────────────── */
  --pp-container:      1200px;
  --pp-container-wide: 1440px;
  --pp-gutter: clamp(20px, 4vw, 56px);
}

/* ===========================================================================
   Semantic typography classes — apply directly to elements or use as a guide
   when wiring component-specific styles.
   =========================================================================== */

.pp-body {
  font-family: var(--pp-font-sans);
  font-size: var(--pp-fs-base);
  line-height: var(--pp-lh-base);
  color: var(--fg-1);
  background: var(--bg-1);
  -webkit-font-smoothing: antialiased;
}

/* Display & headings — Josefin Sans, weight 600/700, tight tracking */
.pp-h1, h1.pp {
  font-family: var(--pp-font-display);
  font-weight: 600;
  font-size: clamp(44px, 6vw, var(--pp-fs-5xl));
  line-height: var(--pp-lh-tight);
  letter-spacing: -0.03em;
  color: var(--fg-1);
  margin: 0;
  text-wrap: balance;
}
.pp-h2, h2.pp {
  font-family: var(--pp-font-display);
  font-weight: 600;
  font-size: clamp(32px, 4vw, var(--pp-fs-3xl));
  line-height: var(--pp-lh-tight);
  letter-spacing: var(--pp-tracking-tight);
  color: var(--fg-1);
  margin: 0;
  text-wrap: balance;
}
.pp-h3, h3.pp {
  font-family: var(--pp-font-display);
  font-weight: 600;
  font-size: var(--pp-fs-xl);
  line-height: var(--pp-lh-snug);
  letter-spacing: -0.01em;
  color: var(--fg-1);
  margin: 0;
}
.pp-h4, h4.pp {
  font-family: var(--pp-font-display);
  font-weight: 600;
  font-size: var(--pp-fs-md);
  line-height: var(--pp-lh-snug);
  color: var(--fg-1);
  margin: 0;
}

/* Lead — Open Sans 22/1.45 */
.pp-lead {
  font-family: var(--pp-font-sans);
  font-size: var(--pp-fs-lg);
  font-weight: 400;
  line-height: 1.45;
  color: var(--fg-2);
  text-wrap: pretty;
}

/* Body — Open Sans 16/1.55 */
.pp-p, p.pp {
  font-family: var(--pp-font-sans);
  font-size: var(--pp-fs-base);
  line-height: var(--pp-lh-base);
  color: var(--fg-2);
  margin: 0;
  text-wrap: pretty;
}

.pp-small {
  font-family: var(--pp-font-sans);
  font-size: var(--pp-fs-sm);
  line-height: 1.55;
  color: var(--fg-3);
}

/* Eyebrow / label / tag — Open Sans 12, 600, ALL CAPS, tracked +0.14em */
.pp-eyebrow {
  font-family: var(--pp-font-sans);
  font-size: var(--pp-fs-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--pp-tracking-caps);
  color: var(--pp-blue);
}

/* Code / monospaced values (HEX, tokens) */
.pp-mono, code.pp {
  font-family: var(--pp-font-mono);
  font-size: 0.9em;
  letter-spacing: 0.02em;
  color: var(--fg-2);
}

/* Emphasis — italic in body; blue-300 highlight inside display headlines */
.pp em, em.pp { font-style: italic; color: inherit; }
.pp-display em { font-style: normal; color: var(--pp-blue-300); }


* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--pp-font-sans);
  color: var(--fg-1);
  background: var(--bg-1);
  -webkit-font-smoothing: antialiased;
  line-height: var(--pp-lh-base);
}
a { color: inherit; text-decoration: none; }

/* ── Topbar ─────────────────────────────────────────── */
.pp-topbar {
  position: sticky; top: 0; z-index: 100;
  background: var(--pp-white);
  border-bottom: 1px solid var(--pp-line);
  padding: 14px clamp(20px, 4vw, 40px);
  display: flex; align-items: center; gap: 24px;
}
.pp-topbar__mark img { height: 28px; width: auto; display: block; }
.pp-topbar__nav { margin-left: auto; display: flex; gap: 4px; font-size: 13px; }
.pp-topbar__nav a {
  padding: 8px 14px; border-radius: var(--pp-radius-sm);
  color: var(--pp-ink-700);
  transition: background var(--pp-dur-fast) var(--pp-ease-out), color var(--pp-dur-fast);
  cursor: pointer;
}
.pp-topbar__nav a:hover, .pp-topbar__nav a.is-active { background: var(--pp-blue-050); color: var(--pp-blue); }
.pp-topbar__cta { padding: 8px 16px !important; font-size: 13px !important; }

/* ── Buttons ────────────────────────────────────────── */
.pp-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--pp-font-sans);
  font-size: 14px; font-weight: 600;
  padding: 12px 22px;
  border-radius: var(--pp-radius-pill);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: all var(--pp-dur-fast) var(--pp-ease-out);
  letter-spacing: 0.01em;
  background: transparent;
  color: inherit;
  text-decoration: none;
}
.pp-btn--lg { padding: 16px 28px; font-size: 15px; }
.pp-btn svg { width: 16px; height: 16px; }
.pp-btn--primary { background: var(--pp-blue); color: #fff; }
.pp-btn--primary:hover { background: var(--pp-blue-700); box-shadow: var(--pp-shadow-3); transform: translateY(-1px); }
.pp-btn--accent { background: var(--pp-orange); color: #fff; }
.pp-btn--accent:hover { background: #C24817; box-shadow: 0 18px 40px -12px rgba(226,88,34,0.50), 0 4px 10px rgba(14,23,38,0.08); transform: translateY(-1px); }
.pp-btn--secondary { color: var(--pp-blue); border-color: var(--pp-blue); }
.pp-btn--secondary:hover { background: var(--pp-blue); color: #fff; }
.pp-btn--ghost { color: var(--pp-ink); }
.pp-btn--ghost:hover { background: var(--pp-blue-050); color: var(--pp-blue); }
.pp-btn--ghost-on-dark { color: #fff; border-color: rgba(255,255,255,0.3); }
.pp-btn--ghost-on-dark:hover { background: rgba(255,255,255,0.08); border-color: #fff; }

.pp-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: var(--pp-radius-pill);
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
}
.pp-badge--blue { background: var(--pp-blue-100); color: var(--pp-blue-900); }

/* ── Section chrome ─────────────────────────────────── */
.pp-section { padding: clamp(56px, 8vw, 112px) clamp(20px, 4vw, 56px); }
.pp-wrap { max-width: var(--pp-container-wide); margin: 0 auto; }
.pp-section-head { margin-bottom: 56px; max-width: 760px; }
.pp-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: var(--pp-tracking-caps);
  color: var(--pp-blue);
  margin-bottom: 16px;
}
.pp-eyebrow::before { content: ""; width: 28px; height: 1px; background: currentColor; }
.pp-eyebrow--on-dark { color: var(--pp-blue-300); }

.pp-h2 { font-family: var(--pp-font-display); font-weight: 600; font-size: clamp(32px, 4vw, 52px); line-height: var(--pp-lh-tight); letter-spacing: var(--pp-tracking-tight); margin: 0 0 16px; color: var(--pp-ink); text-wrap: balance; }
.pp-h2--on-dark { color: #fff; }
.pp-h3 { font-family: var(--pp-font-display); font-weight: 600; font-size: 28px; letter-spacing: -0.01em; margin: 0; }
.pp-lead { font-size: 20px; color: var(--pp-ink-700); margin: 0; line-height: 1.5; text-wrap: pretty; }

.pp-p { font-family: var(--pp-font-sans); font-size: 16px; line-height: 1.55; color: var(--pp-ink); margin: 0; }

/* ── Hero ───────────────────────────────────────────── */
.pp-hero {
  background: #003E6B;
  background-image:
    radial-gradient(ellipse at 80% 0%, rgba(0,105,180,0.55) 0%, transparent 55%),
    radial-gradient(ellipse at 0% 100%, rgba(0,36,61,0.30) 0%, transparent 55%);
  color: #fff;
  padding: clamp(72px, 12vw, 160px) clamp(20px, 4vw, 56px) clamp(56px, 9vw, 110px);
  overflow: hidden;
}
.pp-hero__grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 56px; align-items: end; max-width: var(--pp-container-wide); margin: 0 auto; }
.pp-hero__eyebrow { display: inline-flex; align-items: center; gap: 12px; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: var(--pp-tracking-caps); color: var(--pp-blue-300); margin-bottom: 28px; }
.pp-hero__eyebrow::before { content: ""; width: 40px; height: 1px; background: var(--pp-blue-300); }
.pp-hero__h1 { font-family: var(--pp-font-display); font-size: clamp(44px, 6.5vw, 88px); font-weight: 600; line-height: 1.02; letter-spacing: -0.03em; margin: 0 0 26px; text-wrap: balance; }
.pp-hero__h1 em { font-style: normal; color: var(--pp-blue-300); }
.pp-hero__lead { font-size: clamp(16px, 1.4vw, 20px); line-height: 1.55; color: rgba(255,255,255,0.82); max-width: 58ch; margin: 0 0 32px; }
.pp-hero__cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px; }
.pp-hero__meta { display: flex; gap: 32px; flex-wrap: wrap; font-size: 13px; color: rgba(255,255,255,0.6); padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.12); }
.pp-hero__meta b { color: #fff; font-weight: 500; display: block; margin-bottom: 2px; }
.pp-hero__mark { display: flex; align-items: center; justify-content: center; padding: 44px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--pp-radius-lg); aspect-ratio: 1/1; backdrop-filter: blur(4px); }
.pp-hero__mark img { width: 100%; max-width: 200px; filter: drop-shadow(0 10px 32px rgba(0,0,0,0.25)); }

/* Hero · Variante A1 — Pioneers Blue, kursiv weiß */
.pp-hero--a1 { background: var(--pp-blue); background-image:
  radial-gradient(ellipse at 80% 0%, rgba(75,155,212,0.55) 0%, transparent 55%),
  radial-gradient(ellipse at 0% 100%, rgba(0,36,61,0.40) 0%, transparent 55%); }
.pp-hero--a1 .pp-hero__grid { grid-template-columns: 1fr; }
.pp-hero--a1 .pp-hero__h1 em { font-style: italic; font-weight: 500; color: #fff; }
.pp-hero--a1 .pp-hero__eyebrow { color: rgba(255,255,255,0.82); }
.pp-hero--a1 .pp-hero__eyebrow::before { background: rgba(255,255,255,0.55); }

/* Hero · Variante B3 — Weiß, Persimmon-Punkt vor Veränderung */
.pp-hero--b3 { background: #fff; color: var(--pp-ink); border-bottom: 1px solid var(--pp-line); }
.pp-hero--b3 .pp-hero__grid { grid-template-columns: 1fr; }
.pp-hero--b3 .pp-hero__eyebrow { color: var(--pp-ink); }
.pp-hero--b3 .pp-hero__eyebrow::before { background: var(--pp-orange); width: 32px; height: 3px; border-radius: 2px; }
.pp-hero--b3 .pp-hero__h1 { color: var(--pp-ink); }
.pp-hero--b3 .pp-hero__h1 em { font-style: normal; color: var(--pp-ink); }
.pp-hero--b3 .pp-hero__h1 em::before { content: ""; display: inline-block; width: 12px; height: 12px; background: var(--pp-orange); border-radius: 50%; margin-right: 14px; vertical-align: 0.12em; }
.pp-hero--b3 .pp-hero__lead { color: var(--pp-ink-700); }
.pp-hero--b3 .pp-hero__meta { color: var(--pp-ink-500); border-top-color: var(--pp-line); }
.pp-hero--b3 .pp-hero__meta b { color: var(--pp-ink); }
.pp-hero--b3 .pp-btn--ghost-on-dark { color: var(--pp-ink); border-color: var(--pp-ink-300); }

/* ── Principles ─────────────────────────────────────── */
.pp-principles { background: #fff; border-top: 1px solid var(--pp-line); border-bottom: 1px solid var(--pp-line); }
.pp-principles__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--pp-line); margin-top: 40px; }
.pp-principles__cell { background: #fff; padding: 40px 36px 48px; }
.pp-principles__num { font-family: var(--pp-font-display); font-size: 54px; font-weight: 600; color: var(--pp-blue); line-height: 1; margin-bottom: 20px; letter-spacing: -0.04em; }
.pp-principles__title { font-family: var(--pp-font-display); font-size: 28px; font-weight: 600; margin: 0 0 12px; letter-spacing: -0.01em; }
.pp-principles__body { color: var(--pp-ink-700); font-size: 16px; margin: 0; line-height: 1.55; }
.pp-principles__body strong { color: var(--pp-ink); font-weight: 600; }

/* ── Cases ──────────────────────────────────────────── */
.pp-cases { background: var(--pp-orange-100); }
.pp-cases__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.pp-case { background: #fff; border-radius: var(--pp-radius-lg); padding: 32px 30px; box-shadow: var(--pp-shadow-1); display: flex; flex-direction: column; gap: 18px; min-height: 380px; }
.pp-case__head { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.pp-case__sector { font-size: 12px; color: var(--pp-ink-500); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.pp-case__title { font-family: var(--pp-font-display); font-size: 24px; font-weight: 600; line-height: 1.2; letter-spacing: -0.01em; margin: 0; position: relative; padding-bottom: 8px; }
.pp-case__title::after { content: ""; position: absolute; left: 0; bottom: 0; width: 32px; height: 3px; background: var(--pp-amber); border-radius: 2px; }
.pp-case__body { font-size: 15px; color: var(--pp-ink-700); margin: 0; line-height: 1.55; flex: 1; }
.pp-case__kpi { display: flex; align-items: baseline; gap: 12px; padding-top: 20px; border-top: 1px solid var(--pp-line); }
.pp-case__delta { font-family: var(--pp-font-display); font-size: 48px; font-weight: 600; letter-spacing: -0.03em; color: var(--pp-blue); line-height: 1; }
.pp-case__delta-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--pp-ink-500); font-weight: 600; }

/* ── Voice ──────────────────────────────────────────── */
.pp-voice {
  background: #003E6B;
  background-image: radial-gradient(ellipse at 90% 10%, rgba(75,155,212,0.16) 0%, transparent 55%);
  color: #fff;
}
.pp-section-head--on-dark .pp-eyebrow { color: var(--pp-blue-300); }
.pp-section-head--on-dark .pp-eyebrow::before { background: var(--pp-blue-300); }
.pp-voice__pairs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.pp-voice__pair { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--pp-radius-lg); padding: 32px 28px; font-family: var(--pp-font-display); font-weight: 600; font-size: 28px; line-height: 1.2; letter-spacing: -0.01em; }
.pp-voice__pair b { display: block; color: var(--pp-blue-300); font-weight: 600; margin-bottom: 12px; font-size: 11px; text-transform: uppercase; letter-spacing: var(--pp-tracking-caps); font-family: var(--pp-font-sans); }
.pp-voice__pair em { font-style: normal; color: var(--pp-blue-300); }

/* ── Modal / Form ───────────────────────────────────── */
.pp-modal__scrim {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(14, 23, 38, 0.55);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: pp-fade var(--pp-dur-med) var(--pp-ease-out);
}
.pp-modal {
  background: #fff;
  border-radius: var(--pp-radius-lg);
  padding: 40px 44px;
  width: min(560px, 100%);
  max-height: 90vh; overflow-y: auto;
  position: relative;
  box-shadow: var(--pp-shadow-3);
  animation: pp-rise var(--pp-dur-med) var(--pp-ease-out);
}
.pp-modal__close {
  position: absolute; top: 16px; right: 18px;
  background: transparent; border: none; cursor: pointer;
  width: 36px; height: 36px; border-radius: 50%;
  font-size: 24px; color: var(--pp-ink-500);
  display: flex; align-items: center; justify-content: center;
  transition: background var(--pp-dur-fast);
}
.pp-modal__close:hover { background: var(--pp-blue-050); color: var(--pp-blue); }
.pp-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.pp-field { display: flex; flex-direction: column; gap: 6px; }
.pp-field--full { grid-column: 1 / -1; }
.pp-field label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: var(--pp-tracking-caps); color: var(--pp-ink-700); }
.pp-field input, .pp-field textarea {
  padding: 12px 14px; border: 1.5px solid var(--pp-line);
  border-radius: var(--pp-radius-sm);
  font-family: var(--pp-font-sans); font-size: 15px;
  background: #fff; color: var(--pp-ink); resize: vertical;
  transition: border var(--pp-dur-fast), box-shadow var(--pp-dur-fast);
}
.pp-field input:focus, .pp-field textarea:focus { outline: none; border-color: var(--pp-blue); box-shadow: var(--pp-shadow-focus); }
.pp-form__actions { grid-column: 1 / -1; display: flex; justify-content: flex-end; gap: 12px; margin-top: 8px; }
.pp-modal__success { text-align: center; padding: 16px 0; }
.pp-modal__check { width: 56px; height: 56px; margin: 0 auto 20px; border-radius: 50%; background: #DCF2E8; color: var(--pp-success); display: flex; align-items: center; justify-content: center; font-size: 28px; font-weight: 700; }

@keyframes pp-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes pp-rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* ── Footer ─────────────────────────────────────────── */
.pp-footer { background: var(--pp-blue-050); color: var(--pp-ink-700); padding: 64px clamp(20px, 4vw, 56px) 40px; border-top: 1px solid var(--pp-line); }
.pp-footer__wrap { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 48px; max-width: var(--pp-container-wide); margin: 0 auto; }
.pp-footer img { height: 32px; width: auto; margin-bottom: 18px; display: block; }
.pp-footer__addr { font-size: 13px; line-height: 1.6; margin: 0; color: var(--pp-ink-700); }
.pp-footer h4 { font-family: var(--pp-font-display); color: var(--pp-ink); margin: 0 0 16px; font-size: 14px; font-weight: 600; }
.pp-footer ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; font-size: 13px; }
.pp-footer li { color: var(--pp-ink-700); transition: color var(--pp-dur-fast); cursor: pointer; }
.pp-footer li:hover { color: var(--pp-blue); }
.pp-footer__bottom { grid-column: 1 / -1; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--pp-line); display: flex; justify-content: space-between; font-size: 12px; color: var(--pp-ink-500); }

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 960px) {
  .pp-hero__grid, .pp-principles__grid, .pp-cases__grid, .pp-voice__pairs, .pp-footer__wrap { grid-template-columns: 1fr; }
  .pp-form { grid-template-columns: 1fr; }
  .pp-topbar__nav { display: none; }
}
