/* [next]/internal/font/google/open_sans_cabccca5.module.css [app-client] (css) */
@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/3ce154ad7d54dc86-s.f170796f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7cdbb9ca823c0a73-s.f2244ea0.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1e239d59b95c7889-s.4a36b7d0.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/a421df443b3f383b-s.90e10d49.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/c2873153dc73d9e3-s.6884c055.woff2") format("woff2");
  unicode-range: U+307-308, U+590-5FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/d38a53d0ba90b32d-s.3eaec13b.woff2") format("woff2");
  unicode-range: U+302-303, U+305, U+307-308, U+310, U+312, U+315, U+31A, U+326-327, U+32C, U+32F-330, U+332-333, U+338, U+33A, U+346, U+34D, U+391-3A1, U+3A3-3A9, U+3B1-3C9, U+3D1, U+3D5-3D6, U+3F0-3F1, U+3F4-3F5, 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+1EE??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/5b0229109f6656bb-s.6c710ca8.woff2") format("woff2");
  unicode-range: U+1-C, U+E-1F, U+7F-9F, 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+28??, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B??, 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+1F0??, 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+1F7??, 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+1FB??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/ca19bc83075b2625-s.195cce89.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/2aec202ebfcf461b-s.p.d55a2306.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/cf514f5d0007dafa-s.p.417aa1a2.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/3ce154ad7d54dc86-s.f170796f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7cdbb9ca823c0a73-s.f2244ea0.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1e239d59b95c7889-s.4a36b7d0.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/a421df443b3f383b-s.90e10d49.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/c2873153dc73d9e3-s.6884c055.woff2") format("woff2");
  unicode-range: U+307-308, U+590-5FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/d38a53d0ba90b32d-s.3eaec13b.woff2") format("woff2");
  unicode-range: U+302-303, U+305, U+307-308, U+310, U+312, U+315, U+31A, U+326-327, U+32C, U+32F-330, U+332-333, U+338, U+33A, U+346, U+34D, U+391-3A1, U+3A3-3A9, U+3B1-3C9, U+3D1, U+3D5-3D6, U+3F0-3F1, U+3F4-3F5, 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+1EE??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/5b0229109f6656bb-s.6c710ca8.woff2") format("woff2");
  unicode-range: U+1-C, U+E-1F, U+7F-9F, 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+28??, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B??, 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+1F0??, 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+1F7??, 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+1FB??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/ca19bc83075b2625-s.195cce89.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/2aec202ebfcf461b-s.p.d55a2306.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/cf514f5d0007dafa-s.p.417aa1a2.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/3ce154ad7d54dc86-s.f170796f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7cdbb9ca823c0a73-s.f2244ea0.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1e239d59b95c7889-s.4a36b7d0.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/a421df443b3f383b-s.90e10d49.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/c2873153dc73d9e3-s.6884c055.woff2") format("woff2");
  unicode-range: U+307-308, U+590-5FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/d38a53d0ba90b32d-s.3eaec13b.woff2") format("woff2");
  unicode-range: U+302-303, U+305, U+307-308, U+310, U+312, U+315, U+31A, U+326-327, U+32C, U+32F-330, U+332-333, U+338, U+33A, U+346, U+34D, U+391-3A1, U+3A3-3A9, U+3B1-3C9, U+3D1, U+3D5-3D6, U+3F0-3F1, U+3F4-3F5, 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+1EE??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/5b0229109f6656bb-s.6c710ca8.woff2") format("woff2");
  unicode-range: U+1-C, U+E-1F, U+7F-9F, 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+28??, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B??, 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+1F0??, 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+1F7??, 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+1FB??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/ca19bc83075b2625-s.195cce89.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/2aec202ebfcf461b-s.p.d55a2306.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/cf514f5d0007dafa-s.p.417aa1a2.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/3ce154ad7d54dc86-s.f170796f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7cdbb9ca823c0a73-s.f2244ea0.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1e239d59b95c7889-s.4a36b7d0.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/a421df443b3f383b-s.90e10d49.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/c2873153dc73d9e3-s.6884c055.woff2") format("woff2");
  unicode-range: U+307-308, U+590-5FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/d38a53d0ba90b32d-s.3eaec13b.woff2") format("woff2");
  unicode-range: U+302-303, U+305, U+307-308, U+310, U+312, U+315, U+31A, U+326-327, U+32C, U+32F-330, U+332-333, U+338, U+33A, U+346, U+34D, U+391-3A1, U+3A3-3A9, U+3B1-3C9, U+3D1, U+3D5-3D6, U+3F0-3F1, U+3F4-3F5, 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+1EE??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/5b0229109f6656bb-s.6c710ca8.woff2") format("woff2");
  unicode-range: U+1-C, U+E-1F, U+7F-9F, 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+28??, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B??, 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+1F0??, 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+1F7??, 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+1FB??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/ca19bc83075b2625-s.195cce89.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/2aec202ebfcf461b-s.p.d55a2306.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/cf514f5d0007dafa-s.p.417aa1a2.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/3ce154ad7d54dc86-s.f170796f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/7cdbb9ca823c0a73-s.f2244ea0.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/1e239d59b95c7889-s.4a36b7d0.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/a421df443b3f383b-s.90e10d49.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/c2873153dc73d9e3-s.6884c055.woff2") format("woff2");
  unicode-range: U+307-308, U+590-5FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/d38a53d0ba90b32d-s.3eaec13b.woff2") format("woff2");
  unicode-range: U+302-303, U+305, U+307-308, U+310, U+312, U+315, U+31A, U+326-327, U+32C, U+32F-330, U+332-333, U+338, U+33A, U+346, U+34D, U+391-3A1, U+3A3-3A9, U+3B1-3C9, U+3D1, U+3D5-3D6, U+3F0-3F1, U+3F4-3F5, 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+1EE??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/5b0229109f6656bb-s.6c710ca8.woff2") format("woff2");
  unicode-range: U+1-C, U+E-1F, U+7F-9F, 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+28??, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B??, 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+1F0??, 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+1F7??, 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+1FB??;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/ca19bc83075b2625-s.195cce89.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/2aec202ebfcf461b-s.p.d55a2306.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Open Sans;
  font-style: normal;
  font-weight: 700;
  font-stretch: 100%;
  font-display: swap;
  src: url("../media/cf514f5d0007dafa-s.p.417aa1a2.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Open Sans Fallback;
  src: local(Arial);
  ascent-override: 101.65%;
  descent-override: 27.86%;
  line-gap-override: 0.0%;
  size-adjust: 105.15%;
}

.open_sans_cabccca5-module__ehYlLG__className {
  font-family: Open Sans, Open Sans Fallback;
  font-style: normal;
}

.open_sans_cabccca5-module__ehYlLG__variable {
  --font-open-sans: "Open Sans", "Open Sans Fallback";
}

/* [next]/internal/font/google/source_serif_4_8d0ebd24.module.css [app-client] (css) */
@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("../media/62492e45f348cf87-s.8e6b601f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("../media/8f9704ed0c18c9e0-s.983c8ea4.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("../media/c73d4b34880585a8-s.12db1be5.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("../media/f00b8cc54454926d-s.142cae63.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("../media/741805f5bd1ef272-s.p.e72effc5.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url("../media/ea3421846039b7f3-s.p.093205c5.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../media/62492e45f348cf87-s.8e6b601f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../media/8f9704ed0c18c9e0-s.983c8ea4.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../media/c73d4b34880585a8-s.12db1be5.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../media/f00b8cc54454926d-s.142cae63.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../media/741805f5bd1ef272-s.p.e72effc5.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../media/ea3421846039b7f3-s.p.093205c5.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../media/62492e45f348cf87-s.8e6b601f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../media/8f9704ed0c18c9e0-s.983c8ea4.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../media/c73d4b34880585a8-s.12db1be5.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../media/f00b8cc54454926d-s.142cae63.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../media/741805f5bd1ef272-s.p.e72effc5.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../media/ea3421846039b7f3-s.p.093205c5.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../media/62492e45f348cf87-s.8e6b601f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../media/8f9704ed0c18c9e0-s.983c8ea4.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../media/c73d4b34880585a8-s.12db1be5.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../media/f00b8cc54454926d-s.142cae63.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../media/741805f5bd1ef272-s.p.e72effc5.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../media/ea3421846039b7f3-s.p.093205c5.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../media/62492e45f348cf87-s.8e6b601f.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../media/8f9704ed0c18c9e0-s.983c8ea4.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../media/c73d4b34880585a8-s.12db1be5.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../media/f00b8cc54454926d-s.142cae63.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../media/741805f5bd1ef272-s.p.e72effc5.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../media/ea3421846039b7f3-s.p.093205c5.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/20aee433927f7d4b-s.a2c089c6.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/256e1f7f180674ba-s.afa27594.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/be3bf58b83159894-s.7b13a9eb.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/753b6407f468151f-s.504826d2.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/292081311a6a8abc-s.p.2a17492d.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../media/68d403cf9f2c68c5-s.p.f9f15f61.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/20aee433927f7d4b-s.a2c089c6.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/256e1f7f180674ba-s.afa27594.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/be3bf58b83159894-s.7b13a9eb.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/753b6407f468151f-s.504826d2.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/292081311a6a8abc-s.p.2a17492d.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../media/68d403cf9f2c68c5-s.p.f9f15f61.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/20aee433927f7d4b-s.a2c089c6.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/256e1f7f180674ba-s.afa27594.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/be3bf58b83159894-s.7b13a9eb.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/753b6407f468151f-s.504826d2.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/292081311a6a8abc-s.p.2a17492d.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../media/68d403cf9f2c68c5-s.p.f9f15f61.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/20aee433927f7d4b-s.a2c089c6.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/256e1f7f180674ba-s.afa27594.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/be3bf58b83159894-s.7b13a9eb.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/753b6407f468151f-s.504826d2.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/292081311a6a8abc-s.p.2a17492d.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../media/68d403cf9f2c68c5-s.p.f9f15f61.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/20aee433927f7d4b-s.a2c089c6.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/256e1f7f180674ba-s.afa27594.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/be3bf58b83159894-s.7b13a9eb.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/753b6407f468151f-s.504826d2.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/292081311a6a8abc-s.p.2a17492d.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: "Source Serif 4";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../media/68d403cf9f2c68c5-s.p.f9f15f61.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Source Serif 4 Fallback";
  src: local(Times New Roman);
  ascent-override: 87.87%;
  descent-override: 28.41%;
  line-gap-override: 0.0%;
  size-adjust: 117.91%;
}

.source_serif_4_8d0ebd24-module__GCoosG__className {
  font-family: "Source Serif 4", "Source Serif 4 Fallback";
}

.source_serif_4_8d0ebd24-module__GCoosG__variable {
  --font-source-serif: "Source Serif 4", "Source Serif 4 Fallback";
}

/* [project]/frontend/src/app/globals.css [app-client] (css) */
html {
  scroll-behavior: smooth;
  font-size: 20px;
}

body {
  font-family: var(--font-open-sans), "Open Sans", sans-serif;
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}

:root {
  --bg: #f5f4f1;
  --bg-white: #fff;
  --text: #1a1a1a;
  --text-light: #4a4a4a;
  --muted: #6b6b6b;
  --border: #e2e0dc;
  --bg-footer: #d0e5e4;
  --red: #b51d28;
  --red-hover: #961820;
  --red-light: #b51d280f;
  --notfall: #c49298;
  --notfall-accent: #d03860;
  --intensiv: #8fb8c8;
  --intensiv-accent: #5b9bb5;
  --faerben: #7a9ab8;
  --faerben-accent: #2a5ab0;
  --transplant: #c4a88a;
  --transplant-accent: #d4956a;
  --herz: #a898c0;
  --herz-accent: #8b6baf;
  --diagnostik: #7ab8a0;
  --diagnostik-accent: #00b27a;
  --anticholium: #c4a0a8;
  --anticholium-accent: #d44070;
  --custodiol: #c4a87a;
  --custodiol-accent: #e08828;
  --sedalam: #7aacac;
  --sedalam-accent: #28aaaa;
  --maik: #c4d8be;
  --maik-accent: #4a6830;
  --text-xs: .59rem;
  --text-sm: .68rem;
  --text-base: .83rem;
  --text-md: .95rem;
  --text-lg: 1rem;
  --text-xl: 1.26rem;
  --text-2xl: 1.67rem;
  --text-3xl: 2rem;
  --text-4xl: 2.4rem;
  --text-5xl: 3rem;
  --text-6xl: 3.2rem;
  --text-7xl: 4rem;
  --space-xs: .45rem;
  --space-sm: .68rem;
  --space-md: .9rem;
  --space-lg: 1.35rem;
  --space-xl: 1.8rem;
  --space-2xl: 2.7rem;
  --space-3xl: 3.6rem;
  --space-4xl: 5.4rem;
  --radius-sm: .45rem;
  --radius-md: .79rem;
  --radius-lg: 1.13rem;
  --shadow-sm: 0 1px 3px #0000000f;
  --shadow-md: 0 4px 16px #00000014;
  --shadow-lg: 0 8px 32px #0000001a;
  --transition: .25s ease;
  --max-width: 69.75rem;
}

*, :before, :after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

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

.container {
  max-width: var(--max-width);
  padding: 0 var(--space-xl);
  margin: 0 auto;
}

.header {
  z-index: 100;
  border-bottom: 1px solid #0000;
  transition: background .4s, border-color .4s, box-shadow .4s;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: #fff !important;
}

.header.scrolled {
  background: var(--bg-white);
  border-bottom-color: var(--border);
  box-shadow: 0 1px 8px #0000000a;
}

.header-top {
  padding: var(--space-xs) 0;
  opacity: 1;
  border-bottom: 1px solid #0000000f;
  max-height: 2.5rem;
  transition: max-height .4s, opacity .3s, padding .4s;
  overflow: hidden;
  display: none !important;
}

.header.scrolled .header-top {
  opacity: 0;
  max-height: 0;
  padding: 0;
}

.header-top .container {
  justify-content: flex-end;
  align-items: center;
  gap: var(--space-lg);
  display: flex;
}

.header-top-link {
  font-size: var(--text-sm);
  color: var(--muted);
  transition: color var(--transition);
}

.header-top-link:hover {
  color: var(--text);
}

.fachkreise-btn {
  background: var(--red);
  color: #fff;
  padding: var(--space-xs) var(--space-lg);
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .0625rem;
  transition: background var(--transition);
  cursor: pointer;
  border-radius: .25rem;
  align-items: center;
  gap: .375rem;
  font-weight: 700;
  display: inline-flex;
}

.fachkreise-btn:hover {
  background: var(--red-hover);
}

.header-main {
  padding: var(--space-lg) 0;
  transition: padding .4s;
  position: relative;
  background: #fff !important;
  border-bottom: 1px solid #e2e0dc !important;
}

.header.scrolled .header-main {
  padding: var(--space-sm) 0;
}

.header-main .container {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.logo .logo-img {
  width: auto;
  height: 3.125rem;
  transition: height .4s;
  filter: none !important;
}

.header.scrolled .logo .logo-img {
  height: 1.75rem;
}

.nav {
  align-items: center;
  gap: 1.75rem;
  margin-left: auto;
  display: flex;
}

.nav-item {
  align-items: center;
  display: flex;
  position: relative;
}

.nav a {
  font-size: var(--text-base);
  letter-spacing: .0125rem;
  transition: all var(--transition);
  white-space: nowrap;
  border-bottom: 2px solid #0000;
  padding: .375rem 0;
  font-weight: 600;
  color: #4a4a4a !important;
}

.nav a:hover {
  border-bottom-color: var(--red);
  color: #b51d28 !important;
}

.nav a.active {
  color: #b51d28 !important;
}

.header.scrolled .nav a {
  font-size: var(--text-base);
}

.header.scrolled .nav {
  gap: 1.75rem;
}

.header-edge-actions {
  margin-left: var(--space-lg);
  align-items: center;
  display: flex;
}

.nav-fachkreise {
  color: var(--red);
  border: 1.5px solid var(--red);
  text-transform: uppercase;
  letter-spacing: .0625rem;
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--transition);
  background: #fff;
  border-radius: .25rem;
  align-items: center;
  gap: .375rem;
  padding: .375rem 1rem;
  font-size: .62rem;
  font-weight: 700;
  display: inline-flex;
}

.nav-fachkreise:hover, .nav-fachkreise.fk-active {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}

.fachkreise-mobile.fk-active {
  color: var(--red);
  border: 1.5px solid var(--red);
  background: #fff;
}

.lang-toggle-fixed {
  z-index: 1000;
  color: #fff;
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  padding: var(--space-xs) var(--space-md);
  text-transform: uppercase;
  letter-spacing: .08em;
  cursor: pointer;
  white-space: nowrap;
  writing-mode: vertical-lr;
  background: #4a4a4a;
  border: none;
  align-items: center;
  font-size: .62rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  position: fixed;
  top: 85.7%;
  right: 0;
}

.lang-toggle-fixed:hover {
  color: #fff;
  background: #1a1a1a;
}

.nav-item .dropdown {
  background: var(--bg-white);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-md);
  padding: var(--space-sm) 0;
  z-index: 200;
  min-width: 12rem;
  display: none;
  position: absolute;
  top: 100%;
  left: -1rem;
}

.nav-item:hover .dropdown {
  display: block;
}

.nav-item .dropdown a {
  padding: var(--space-xs) var(--space-lg);
  font-size: var(--text-sm);
  border-bottom: none;
  font-weight: 500;
  display: block;
}

.nav-item .dropdown a:hover {
  background: var(--red-light);
  color: var(--red);
  border-bottom: none;
}

.header-mobile-actions {
  align-items: center;
  gap: var(--space-sm);
  display: none;
}

.fachkreise-mobile {
  display: none;
}

.hamburger {
  cursor: pointer;
  width: 2.5rem;
  height: 2.5rem;
  padding: var(--space-xs);
  background: none;
  border: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: .3125rem;
  display: none;
}

.hamburger span {
  background: var(--text);
  border-radius: .125rem;
  width: 1.375rem;
  height: .125rem;
  transition: all .3s;
  display: block;
}

.hamburger.active span:first-child {
  transform: rotate(45deg)translate(.3125rem, .3125rem);
}

.hamburger.active span:nth-child(2) {
  opacity: 0;
}

.hamburger.active span:nth-child(3) {
  transform: rotate(-45deg)translate(.3125rem, -.3125rem);
}

.mobile-nav {
  background: var(--bg-white);
  z-index: 99;
  padding: 7.5rem var(--space-xl) 2.5rem;
  flex-direction: column;
  gap: 0;
  display: none;
  position: fixed;
  inset: 0;
}

.mobile-nav.open {
  display: flex;
}

.mobile-nav a {
  font-size: var(--text-lg);
  color: var(--text-light);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--border);
  transition: color var(--transition);
  font-weight: 600;
}

.mobile-nav a:hover {
  color: var(--red);
}

.mobile-nav .fachkreise-btn {
  margin-top: var(--space-lg);
  text-align: center;
  justify-content: center;
}

.btn {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-base);
  padding: .875rem var(--space-xl);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  cursor: pointer;
  letter-spacing: .0125rem;
  border: none;
  font-weight: 600;
  display: inline-flex;
}

.btn-primary {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-base);
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-sm);
  background: var(--red);
  color: #fff;
  transition: all var(--transition);
  cursor: pointer;
  border: none;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.btn-primary:hover {
  background: var(--red-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px #b51d284d;
}

.btn-secondary {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-base);
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-sm);
  color: var(--text-light);
  border: 1.5px solid var(--border);
  transition: all var(--transition);
  cursor: pointer;
  background: none;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.btn-secondary:hover {
  border-color: var(--red);
  color: var(--red);
}

.btn-outline {
  color: var(--red);
  border: 1.5px solid var(--red);
  background: none;
}

.btn-outline:hover {
  background: var(--red);
  color: #fff;
}

.hero {
  background: var(--bg);
  padding: 7.5rem 0 0;
  overflow: hidden;
}

.hero-content {
  padding-top: 2.5rem;
}

.hero-grid {
  gap: var(--space-3xl);
  height: 60svh;
  min-height: 26.25rem;
  max-height: 34.375rem;
  padding-top: 2.5rem;
  padding-bottom: var(--space-3xl);
  grid-template-columns: 1fr 1fr;
  align-items: center;
  display: grid;
}

.hero-eyebrow {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .1875rem;
  color: var(--red);
  margin-bottom: var(--space-md);
  font-weight: 700;
}

.hero-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-4xl);
  color: var(--text);
  letter-spacing: -.03125rem;
  margin-bottom: 1.25rem;
  font-weight: 300;
  line-height: 1.1;
}

.hero-title strong {
  font-weight: 300;
}

.hero-title span {
  color: var(--muted);
  font-size: var(--text-2xl);
  margin-top: .25rem;
  display: block;
}

.hero-desc {
  font-size: var(--text-lg);
  color: var(--text-light);
  max-width: 28.75rem;
  margin-bottom: 1.75rem;
  font-weight: 300;
  line-height: 1.7;
}

.hero-actions {
  gap: .875rem;
  display: flex;
}

.hero-text-fade {
  opacity: 1;
  transition: opacity .4s;
}

.hero-text-fade.fading {
  opacity: 0;
}

.hero-slider {
  border-radius: var(--radius-lg);
  height: 100%;
  position: relative;
  overflow: hidden;
}

.hero-slide {
  opacity: 0;
  transition: opacity .8s;
  position: absolute;
  inset: 0;
}

.hero-slide.active {
  opacity: 1;
}

.hero-slide img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.slider-indicators {
  bottom: var(--space-md);
  z-index: 5;
  gap: .375rem;
  display: flex;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.slider-dot {
  width: var(--space-xs);
  height: var(--space-xs);
  cursor: pointer;
  background: #ffffff4d;
  border: 1.5px solid #ffffff80;
  border-radius: 50%;
  transition: all .3s;
}

.slider-dot.active {
  background: #fff;
  border-color: #fff;
  transform: scale(1.15);
}

.slider-progress {
  z-index: 5;
  background: #fff9;
  border-radius: 0 .0625rem 0 0;
  height: .125rem;
  position: absolute;
  bottom: 0;
  left: 0;
}

.slider-controls {
  bottom: var(--space-md);
  right: var(--space-md);
  z-index: 5;
  align-items: center;
  gap: .25rem;
  display: flex;
  position: absolute;
}

.slider-btn {
  -webkit-backdrop-filter: blur(.375rem);
  backdrop-filter: blur(.375rem);
  color: #ffffffb3;
  width: 1.75rem;
  height: 1.75rem;
  font-size: var(--text-xs);
  cursor: pointer;
  background: #ffffff26;
  border: 1px solid #ffffff40;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  transition: all .2s;
  display: flex;
}

.slider-btn:hover {
  color: #fff;
  background: #ffffff4d;
  border-color: #ffffff80;
}

.section {
  padding: 5.5rem 0;
}

.section-eyebrow {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .1875rem;
  color: var(--red);
  margin-bottom: var(--space-md);
  font-weight: 700;
}

.section-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-3xl);
  margin-bottom: var(--space-md);
  letter-spacing: -.01875rem;
  font-weight: 300;
  line-height: 1.2;
}

.section-desc {
  font-size: var(--text-lg);
  color: var(--muted);
  max-width: 37.5rem;
  font-weight: 300;
  line-height: 1.75;
}

.section-header {
  margin-bottom: 3.5rem;
}

.section-therapy {
  background: var(--bg-white);
}

.therapy-grid {
  gap: var(--space-md);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.therapy-card {
  background: var(--bg-white);
  padding: 1.5rem var(--space-lg);
  transition: all var(--transition);
  cursor: pointer;
  border: 1px solid var(--border);
  border-radius: 14px;
  align-items: flex-start;
  gap: 1.125rem;
  display: flex;
}

.therapy-card:hover {
  border-color: #ccc;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px #0000000f;
}

.therapy-icon {
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 3.25rem;
  height: 3.25rem;
  display: flex;
}

.therapy-icon svg {
  width: 1.625rem;
  height: 1.625rem;
}

.therapy-info h3 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-lg);
  margin-bottom: .375rem;
  font-weight: 600;
}

.therapy-info p {
  font-size: var(--text-base);
  color: var(--muted);
  line-height: 1.55;
}

.therapy-info .therapy-link {
  font-size: var(--text-sm);
  color: var(--red);
  margin-top: .625rem;
  font-weight: 600;
  display: inline-block;
}

.therapy-card:hover .therapy-link {
  text-decoration: underline;
}

.section-highlights {
  background: var(--bg);
}

.highlight-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  display: grid;
}

.highlight-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition);
  cursor: pointer;
  border: 1px solid var(--border);
  flex-direction: column;
  display: flex;
  overflow: hidden;
}

.highlight-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: #ccc;
  transform: translateY(-4px);
}

.highlight-card-bar {
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  height: 30px;
}

.highlight-card-body {
  text-align: center;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 10rem;
  padding: 2rem 1.75rem 1.25rem;
  display: flex;
}

.highlight-card-body .highlight-icon {
  opacity: .15;
  width: auto;
  height: 5.5rem;
  margin-bottom: .75rem;
}

.highlight-name {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-2xl);
  font-weight: 400;
  line-height: 1.2;
}

.highlight-name sup {
  font-size: .6em;
}

.highlight-divider {
  margin-bottom: var(--space-sm);
  flex-direction: column;
  gap: 3px;
  padding: 0;
  display: flex;
}

.highlight-divider-thick {
  border-radius: 2px;
  width: 100%;
  height: 3px;
}

.highlight-divider-thin {
  opacity: .35;
  width: 100%;
  height: 1px;
}

.highlight-info {
  flex-direction: column;
  flex: 1;
  padding: 1rem 1.75rem 1.75rem;
  display: flex;
}

.highlight-info .highlight-tagline {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-md);
  margin-bottom: var(--space-xs);
  color: var(--text);
  font-weight: 500;
}

.highlight-info p {
  font-size: var(--text-base);
  color: var(--muted);
  flex: 1;
  margin-bottom: 1.125rem;
  line-height: 1.65;
}

.highlight-info .highlight-more {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .05rem;
  transition: gap var(--transition);
  align-items: center;
  gap: .375rem;
  font-weight: 700;
  display: inline-flex;
}

.highlight-card:hover .highlight-more {
  gap: .625rem;
}

.section-company {
  background: var(--bg-white);
}

.company-grid {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 3.5rem;
  display: grid;
}

.bw-image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
}

.bw-image img {
  object-fit: cover;
  filter: grayscale();
  width: 100%;
  height: 26.25rem;
  transition: filter .5s;
}

.bw-image:hover img {
  filter: grayscale(0%);
}

.bw-image .image-accent {
  background: var(--red);
  height: .25rem;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

.company-text .section-title {
  font-size: var(--text-3xl);
}

.company-text .company-desc {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: var(--space-xl);
  font-weight: 300;
  line-height: 1.8;
}

.company-facts {
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.fact {
  text-align: center;
  padding: 1.25rem var(--space-xs);
  background: var(--bg);
  border-radius: var(--radius-sm);
}

.fact .fact-num {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-2xl);
  color: var(--red);
  font-weight: 300;
  line-height: 1.1;
}

.fact .fact-label {
  font-size: var(--text-sm);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .03125rem;
  margin-top: .25rem;
  font-weight: 600;
}

.section-production {
  background: var(--red);
  padding: 5.5rem 0;
}

.production-grid {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 3.5rem;
  display: grid;
}

.production-text .section-eyebrow {
  color: #ffffff80;
}

.production-text .section-title {
  color: #fff;
  margin-bottom: var(--space-md);
  font-size: var(--text-3xl);
}

.production-text p {
  font-size: var(--text-lg);
  color: #ffffffbf;
  margin-bottom: var(--space-xl);
  font-weight: 300;
  line-height: 1.8;
}

.production-features {
  gap: var(--space-sm);
  grid-template-columns: 1fr 1fr;
  display: grid;
}

.prod-feat {
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) 1.125rem;
  border-radius: var(--radius-sm);
  background: #ffffff1a;
  border: 1px solid #ffffff1f;
  display: flex;
}

.prod-feat .feat-dot {
  width: var(--space-xs);
  height: var(--space-xs);
  background: #ffffff80;
  border-radius: 50%;
  flex-shrink: 0;
}

.prod-feat span {
  font-size: var(--text-base);
  color: #ffffffe6;
  font-weight: 600;
}

.production-image {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 8px 32px #0003;
}

.production-image img {
  object-fit: cover;
  width: 100%;
  height: 23.75rem;
}

.section-campus {
  background: var(--bg);
}

.campus-card {
  background: var(--bg-white);
  border-radius: var(--radius-lg);
  align-items: center;
  gap: var(--space-2xl);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  padding: 3.25rem;
  display: flex;
}

.campus-icon {
  background: var(--red-light);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 5.5rem;
  height: 5.5rem;
  display: flex;
}

.campus-icon svg {
  width: 2.5rem;
  height: 2.5rem;
  stroke: var(--red);
}

.campus-text h3 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-xl);
  margin-bottom: .625rem;
  font-weight: 400;
}

.campus-text p {
  font-size: var(--text-lg);
  color: var(--muted);
  max-width: 32.5rem;
  margin-bottom: 1.125rem;
  font-weight: 300;
  line-height: 1.7;
}

.campus-text .campus-link {
  font-size: var(--text-base);
  color: var(--red);
  text-transform: uppercase;
  letter-spacing: .03125rem;
  transition: gap var(--transition);
  align-items: center;
  gap: .375rem;
  font-weight: 700;
  display: inline-flex;
}

.campus-text .campus-link:hover {
  gap: .625rem;
}

.section-career {
  background: var(--bg-white);
}

.career-grid {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 3.5rem;
  display: grid;
}

.career-text .section-title {
  font-size: var(--text-3xl);
}

.career-text p {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: 1.75rem;
  font-weight: 300;
  line-height: 1.8;
}

.footer {
  padding-top: var(--space-4xl);
  border-top: none;
  background: var(--bg-footer) !important;
  color: var(--text-light) !important;
}

.footer a {
  transition: color var(--transition);
  color: var(--text-light) !important;
}

.footer a:hover {
  color: var(--red) !important;
}

.footer .footer-logo img {
  height: 5rem;
  margin-bottom: var(--space-lg);
  filter: none !important;
}

.footer .footer-brand {
  margin-top: -1.3rem;
}

.footer .footer-brand p {
  font-size: var(--text-base);
  color: var(--muted);
  line-height: 1.8;
}

.footer-main-grid {
  gap: var(--space-3xl);
  margin-bottom: var(--space-3xl);
  grid-template-columns: 1fr auto 1fr;
  align-items: start;
  display: grid;
}

.footer-nav-links {
  gap: var(--space-sm);
  flex-direction: column;
  padding-top: .15rem;
  display: flex;
}

.footer-nav-links h4 {
  font-size: var(--text-sm);
  letter-spacing: .09375rem;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--space-sm);
  font-weight: 700;
}

.footer-nav-links a {
  font-weight: 600;
  font-size: var(--text-base) !important;
  color: var(--text) !important;
}

.footer-nav-links a:hover {
  color: var(--red) !important;
}

.footer-nw-box {
  border-radius: var(--radius-sm);
  padding: var(--space-lg) var(--space-xl);
  background: #0000000a;
  border-left: 3px solid #0000001a;
}

.footer-nw-box p {
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--muted) !important;
}

.footer-nw-box a {
  text-decoration: underline;
  color: var(--muted) !important;
}

.footer-nw-box a:hover {
  color: var(--red) !important;
}

.footer-bottom {
  font-size: var(--text-sm);
  border-top: 1px solid #00000014;
  justify-content: space-between;
  padding: 1.75rem 0;
  display: flex;
}

.footer-bottom-links {
  gap: var(--space-lg);
  display: flex;
}

.footer-bottom-links a {
  font-size: var(--text-sm);
  color: var(--muted) !important;
}

.footer-bottom-links a:hover {
  color: var(--red) !important;
}

.copyright {
  color: var(--muted);
}

.color-stripe {
  opacity: .1;
  background: linear-gradient(to right, #7aacac 0% 6.25%, #c47a50 6.25% 12.5%, #7a9ab8 12.5% 18.75%, #d4cc6e 18.75% 25%, #6e6e56 25% 31.25%, #4a8c3f 31.25% 37.5%, #c4a0a8 37.5% 43.75%, #c49298 43.75% 50%, #c4a87a 50% 56.25%, #8b5fa0 56.25% 62.5%, #d47a92 62.5% 68.75%, #7ab8a0 68.75% 75%, #5c3d7a 75% 81.25%, #2fa5ab 81.25% 87.5%, #b8a84e 87.5% 93.75%, #b5b5b0 93.75% 100%);
  border: none;
  width: 100%;
  height: .1875rem;
  margin: 0;
}

.section-title-decorated {
  padding-bottom: var(--space-sm);
  position: relative;
}

.section-title-decorated:after {
  content: "";
  opacity: .1;
  background: linear-gradient(to right, #7aacac, #c47a50, #7a9ab8, #d4cc6e, #6e6e56, #4a8c3f, #c4a0a8, #c49298, #c4a87a, #8b5fa0, #d47a92, #7ab8a0, #5c3d7a, #2fa5ab, #b8a84e, #b5b5b0);
  border-radius: .125rem;
  width: 100%;
  height: .1875rem;
  position: absolute;
  bottom: 0;
  left: 0;
}

.wp-content h1, .wp-content h2, .wp-content h3, .wp-content h4, .wp-content h5, .wp-content h6 {
  margin-bottom: var(--space-lg);
  line-height: 1.2;
}

.wp-content h1 {
  font-size: var(--text-5xl);
  font-weight: 600;
}

.wp-content h2 {
  font-size: var(--text-3xl);
  font-weight: 600;
}

.wp-content h3 {
  font-size: var(--text-2xl);
  font-weight: 600;
}

.wp-content p {
  margin-bottom: var(--space-lg);
  font-size: var(--text-md);
  color: var(--text-light);
  line-height: 1.8;
}

.wp-content a {
  color: var(--red);
  text-decoration: underline;
}

.wp-content a:hover {
  color: var(--red-hover);
}

.wp-content img {
  border-radius: var(--radius-md);
  margin: var(--space-2xl) 0;
}

.wp-content ul, .wp-content ol {
  margin-bottom: var(--space-lg);
  padding-left: var(--space-xl);
}

.wp-content li {
  margin-bottom: var(--space-xs);
  font-size: var(--text-md);
  color: var(--text-light);
}

@media (max-width: 1024px) {
  .therapy-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .hero-title {
    font-size: var(--text-3xl);
  }

  .hero-title span {
    font-size: var(--text-2xl);
  }
}

@media (max-width: 989px) {
  .header-edge-actions {
    display: none;
  }

  .product-row {
    grid-template-columns: 200px 1fr auto;
  }
}

@media (max-width: 768px) {
  .header-top, .nav {
    display: none;
  }

  .hamburger, .header-mobile-actions {
    display: flex;
  }

  .fachkreise-mobile {
    background: var(--red);
    color: #fff;
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: .03125rem;
    white-space: nowrap;
    border-radius: .25rem;
    align-items: center;
    gap: .375rem;
    padding: .375rem .875rem;
    font-weight: 700;
    display: inline-flex;
  }

  .lang-toggle {
    font-size: var(--text-sm);
    color: var(--muted);
    align-items: center;
    gap: .25rem;
    font-weight: 600;
    display: inline-flex;
  }

  .hero {
    overflow: visible;
  }

  .hero-grid {
    grid-template-columns: 1fr;
    height: auto;
    max-height: none;
    padding-top: 6.25rem;
  }

  .hero-content {
    padding-top: var(--space-lg);
  }

  .hero-content h1, .hero-title {
    margin-top: var(--space-md);
  }

  .hero-slider {
    min-height: 17.5rem;
  }

  .hero-title {
    font-size: var(--text-2xl);
  }

  .hero-title span {
    font-size: var(--text-xl);
  }

  .section-title {
    font-size: var(--text-2xl);
  }

  .logo .logo-img {
    height: 2.25rem;
  }

  .header.scrolled .logo .logo-img {
    height: 1.5rem;
  }

  .therapy-grid, .highlight-grid, .company-grid, .career-grid, .production-grid {
    grid-template-columns: 1fr;
  }

  .section {
    padding: var(--space-3xl) 0;
  }

  .campus-card {
    text-align: center;
    padding: var(--space-xl);
    flex-direction: column;
  }

  .btn {
    font-size: var(--text-base);
    white-space: nowrap;
    text-align: center;
    padding: .625rem 1.125rem;
  }

  .hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: .625rem;
  }

  .hero-actions .btn {
    font-size: var(--text-base);
    padding: var(--space-sm) 1.25rem;
    text-align: center;
    justify-content: center;
    width: 100%;
  }

  .highlight-name-wrap .highlight-icon {
    width: 1.75rem;
    height: 1.75rem;
  }

  .footer-main-grid {
    gap: var(--space-xl);
    grid-template-columns: 1fr !important;
  }

  .footer-bottom {
    gap: var(--space-md);
    text-align: center;
    flex-direction: column;
  }

  .footer-bottom-links {
    flex-wrap: wrap;
    justify-content: center;
  }
}

.page-hero {
  background: var(--bg);
  padding: 10rem 0 4.5rem;
}

.page-hero.page-hero-white {
  background: var(--bg-white);
  border-bottom: 1px solid var(--border);
}

.page-hero.page-hero-image {
  align-items: flex-end;
  min-height: 500px;
  padding: 0;
  display: flex;
  position: relative;
}

.breadcrumb {
  font-size: var(--text-sm);
  color: var(--muted);
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: 1.75rem;
  display: flex;
}

.breadcrumb a {
  color: var(--muted);
  transition: color var(--transition);
}

.breadcrumb a:hover {
  color: var(--red);
}

.breadcrumb .sep {
  color: var(--border);
  font-size: var(--text-xs);
}

.page-hero .hero-eyebrow {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--red);
  margin-bottom: var(--space-md);
  font-weight: 700;
  display: block;
}

.page-hero .hero-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-4xl);
  margin-bottom: var(--space-md);
  font-weight: 300;
  line-height: 1.15;
}

.page-hero .hero-subtitle {
  font-size: var(--text-lg);
  color: var(--text-light);
  max-width: 35rem;
  font-weight: 300;
  line-height: 1.75;
}

.page-hero .hero-subtitle em {
  font-style: italic;
}

.page-hero .hero-desc {
  font-size: var(--text-lg);
  color: var(--text-light);
  max-width: 620px;
  font-weight: 300;
  line-height: 1.75;
}

.hero-bg {
  background: url("/assets/img/karriere-hero.png") 50% 30% / cover no-repeat;
  position: absolute;
  inset: 0;
}

.hero-bg:after {
  content: "";
  background: #ffffffd1;
  position: absolute;
  inset: 0;
}

.hero-inner {
  z-index: 1;
  width: 100%;
  padding: 160px 0 80px;
  position: relative;
}

.section-white {
  background: var(--bg-white);
}

.section-alt {
  background: var(--bg);
}

.section-label {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--red);
  margin-bottom: var(--space-sm);
  font-weight: 700;
  display: block;
}

.section-heading {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-3xl);
  margin-bottom: var(--space-lg);
  font-weight: 300;
  line-height: 1.2;
}

.section-subtitle {
  font-size: var(--text-lg);
  color: var(--muted);
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--space-2xl);
  font-weight: 300;
  line-height: 1.75;
}

.section-intro {
  font-size: var(--text-lg);
  color: var(--text-light);
  max-width: 50rem;
  margin-bottom: var(--space-xl);
  font-weight: 300;
  line-height: 1.8;
}

.split {
  gap: var(--space-3xl);
  grid-template-columns: 1fr 1fr;
  align-items: center;
  display: grid;
}

.split-text p {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: var(--space-md);
  font-weight: 300;
  line-height: 1.8;
}

.split-image img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.link-arrow {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-base);
  color: var(--red);
  margin-top: var(--space-sm);
  transition: gap var(--transition);
  font-weight: 700;
  display: inline-flex;
}

.link-arrow:hover {
  gap: var(--space-sm);
}

.link-arrow svg {
  width: 1.125rem;
  height: 1.125rem;
}

.timeline {
  padding-left: var(--space-2xl);
  margin-top: var(--space-2xl);
  position: relative;
}

.timeline:before {
  content: "";
  background: var(--border);
  width: .125rem;
  position: absolute;
  top: 0;
  bottom: 0;
  left: .9375rem;
}

.timeline-item {
  margin-bottom: 2.5rem;
  position: relative;
}

.timeline-item:last-child {
  margin-bottom: 0;
}

.timeline-dot {
  background: var(--red);
  border: .1875rem solid var(--bg);
  border-radius: 50%;
  width: .75rem;
  height: .75rem;
  position: absolute;
  top: .25rem;
  left: -2.5625rem;
}

.timeline-year {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-xl);
  color: var(--text);
  margin-bottom: .25rem;
  font-weight: 600;
}

.timeline-desc {
  font-size: var(--text-lg);
  color: var(--text-light);
  font-weight: 300;
  line-height: 1.7;
}

.stats-grid {
  gap: var(--space-lg);
  margin-top: var(--space-2xl);
  grid-template-columns: repeat(4, 1fr);
  display: grid;
}

.stat-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  padding: 2.25rem var(--space-lg);
  text-align: center;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}

.stat-number {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-3xl);
  color: var(--red);
  margin-bottom: var(--space-xs);
  font-weight: 300;
  line-height: 1;
}

.stat-suffix {
  font-size: var(--text-2xl);
}

.stat-label {
  font-size: var(--text-base);
  color: var(--text);
  font-weight: 600;
}

.values-grid {
  gap: var(--space-lg);
  margin-top: var(--space-2xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.value-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  padding: 2.5rem var(--space-xl);
  text-align: center;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  transition: all var(--transition);
}

.value-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-.25rem);
}

.value-icon {
  background: var(--red-light);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 3.5rem;
  height: 3.5rem;
  margin: 0 auto 1.25rem;
  display: flex;
}

.value-icon svg {
  width: 1.625rem;
  height: 1.625rem;
  stroke: var(--red);
}

.value-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-lg);
  margin-bottom: var(--space-sm);
  font-weight: 600;
}

.value-desc {
  font-size: var(--text-md);
  color: var(--muted);
  line-height: 1.7;
}

.timeline-closing {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-top: var(--space-2xl);
  font-weight: 300;
  line-height: 1.8;
}

.section-body-text {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: var(--space-md);
  max-width: 45rem;
  font-weight: 300;
  line-height: 1.8;
}

.section-body-text-last {
  margin-bottom: 0;
}

.section-body-text-wide {
  margin-bottom: var(--space-2xl);
}

.values-grid-2col {
  grid-template-columns: repeat(2, 1fr);
}

.value-card-left {
  text-align: left;
  padding: 2.25rem var(--space-xl);
}

.prize-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-lg);
  margin-bottom: var(--space-sm);
  color: var(--red);
  font-weight: 600;
}

.prize-desc {
  font-size: var(--text-md);
  color: var(--text-light);
  line-height: 1.7;
}

.campus-link-wrap {
  margin-top: var(--space-xl);
}

.cta-band {
  background: linear-gradient(135deg, var(--red) 0%, var(--red-hover) 100%);
  text-align: center;
  padding: 5rem 0;
}

.cta-inner {
  justify-content: space-between;
  align-items: center;
  gap: var(--space-xl);
  text-align: left;
  display: flex;
}

.cta-band h2 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  color: #fff;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 300;
}

.cta-band p {
  color: #ffffffb3;
  font-size: var(--text-lg);
  margin-top: var(--space-xs);
}

.btn-white {
  align-items: center;
  gap: var(--space-xs);
  color: var(--red);
  padding: var(--space-md) 2.25rem;
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  transition: all var(--transition);
  white-space: nowrap;
  background: #fff;
  font-weight: 700;
  display: inline-flex;
}

.btn-white:hover {
  transform: translateY(-.125rem);
  box-shadow: 0 .25rem 1.25rem #00000026;
}

.btn-white svg {
  width: 1.125rem;
  height: 1.125rem;
}

.cta-section {
  background: linear-gradient(135deg, var(--red), var(--red-hover));
  padding: 5rem 0;
}

.cta-grid {
  justify-content: space-between;
  align-items: center;
  gap: 2.5rem;
  display: flex;
}

.cta-text h2 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  color: #fff;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 300;
}

.cta-text p {
  color: #ffffffb3;
  font-size: var(--text-lg);
  margin-top: var(--space-xs);
  max-width: 30rem;
  line-height: 1.7;
}

.page-hero-therapy {
  align-items: flex-end;
  min-height: 500px;
  padding: 0;
  display: flex;
  position: relative;
}

.page-hero-therapy .hero-bg {
  background: url("/assets/img/karriere-hero.png") 50% 30% / cover no-repeat;
}

.page-hero-therapy .hero-bg:after {
  background: linear-gradient(to right, #fffffff2 0%, #ffffffd9 35%, #fff6 60%, #fff0 100%);
}

.tiles-grid {
  gap: var(--space-xl);
  margin-top: var(--space-2xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.tile {
  background: var(--bg-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  flex-direction: column;
  transition: all .35s;
  display: flex;
  position: relative;
  overflow: hidden;
}

.tile:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-.5rem);
}

.tile-band {
  width: 100%;
  height: .3rem;
}

.tile-head {
  padding: var(--space-xl) var(--space-xl) 0;
  align-items: flex-start;
  gap: var(--space-lg);
  display: flex;
}

.tile-icon {
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 3.5rem;
  height: 3.5rem;
  display: flex;
}

.tile-icon img {
  width: 1.75rem;
  height: 1.75rem;
}

.tile-head-text {
  flex: 1;
  min-width: 0;
}

.tile-number {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: .1rem;
  color: var(--muted);
  margin-bottom: .25rem;
  font-weight: 700;
  display: block;
}

.tile-name {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-xl);
  font-weight: 600;
  line-height: 1.25;
}

.tile-body {
  padding: var(--space-lg) var(--space-xl);
  flex: 1;
}

.tile-desc {
  font-size: var(--text-md);
  color: var(--text-light);
  font-weight: 300;
  line-height: 1.7;
}

.tile-products {
  padding: 0 var(--space-xl) var(--space-lg);
  gap: var(--space-xs);
  flex-wrap: wrap;
  display: flex;
}

.tile-pill {
  font-size: var(--text-sm);
  padding: .25rem var(--space-sm);
  white-space: nowrap;
  border-radius: 6.25rem;
  align-items: center;
  gap: .2rem;
  font-weight: 500;
  line-height: 1.3;
  display: inline-flex;
}

.tile-foot {
  padding: var(--space-lg) var(--space-xl);
  border-top: 1px solid var(--border);
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.tile-link {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-base);
  color: var(--text-light);
  transition: gap var(--transition), color var(--transition);
  font-weight: 700;
  display: inline-flex;
}

.tile-link:hover {
  gap: var(--space-sm);
  color: var(--red);
}

.tile-link svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 1rem;
  height: 1rem;
}

.tile-count {
  font-size: var(--text-sm);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06rem;
  align-items: center;
  gap: .375rem;
  font-weight: 700;
  display: flex;
}

.tile-count-num {
  background: var(--border);
  width: 1.375rem;
  height: 1.375rem;
  font-size: var(--text-xs);
  color: var(--text-light);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  display: inline-flex;
}

.tile-intensiv .tile-band {
  background: var(--intensiv-accent);
}

.tile-intensiv .tile-icon {
  background: color-mix(in srgb, var(--intensiv-accent) 12%, transparent);
}

.tile-intensiv .tile-name {
  color: var(--intensiv-accent);
}

.tile-intensiv:hover {
  border-color: color-mix(in srgb, var(--intensiv-accent) 35%, transparent);
}

.pill-intensiv {
  background: color-mix(in srgb, var(--intensiv-accent) 12%, transparent);
  color: var(--intensiv-accent);
}

.tile-notfall .tile-band {
  background: var(--notfall-accent);
}

.tile-notfall .tile-icon {
  background: color-mix(in srgb, var(--notfall-accent) 10%, transparent);
}

.tile-notfall .tile-name {
  color: var(--notfall-accent);
}

.tile-notfall:hover {
  border-color: color-mix(in srgb, var(--notfall-accent) 30%, transparent);
}

.pill-notfall {
  background: color-mix(in srgb, var(--notfall-accent) 10%, transparent);
  color: var(--notfall-accent);
}

.tile-transplant .tile-band {
  background: var(--transplant-accent);
}

.tile-transplant .tile-icon {
  background: color-mix(in srgb, var(--transplant-accent) 12%, transparent);
}

.tile-transplant .tile-name {
  color: var(--transplant-accent);
}

.tile-transplant:hover {
  border-color: color-mix(in srgb, var(--transplant-accent) 35%, transparent);
}

.pill-transplant {
  background: color-mix(in srgb, var(--transplant-accent) 12%, transparent);
  color: var(--transplant-accent);
}

.tile-herz .tile-band {
  background: var(--herz-accent);
}

.tile-herz .tile-icon {
  background: color-mix(in srgb, var(--herz-accent) 12%, transparent);
}

.tile-herz .tile-name {
  color: var(--herz-accent);
}

.tile-herz:hover {
  border-color: color-mix(in srgb, var(--herz-accent) 30%, transparent);
}

.pill-herz {
  background: color-mix(in srgb, var(--herz-accent) 12%, transparent);
  color: var(--herz-accent);
}

.tile-faerben .tile-band {
  background: var(--faerben-accent);
}

.tile-faerben .tile-icon {
  background: color-mix(in srgb, var(--faerben-accent) 10%, transparent);
}

.tile-faerben .tile-name {
  color: var(--faerben-accent);
}

.tile-faerben:hover {
  border-color: color-mix(in srgb, var(--faerben-accent) 30%, transparent);
}

.pill-faerben {
  background: color-mix(in srgb, var(--faerben-accent) 10%, transparent);
  color: var(--faerben-accent);
}

.tile-diagnostik .tile-band {
  background: var(--diagnostik-accent);
}

.tile-diagnostik .tile-icon {
  background: color-mix(in srgb, var(--diagnostik-accent) 10%, transparent);
}

.tile-diagnostik .tile-name {
  color: var(--diagnostik-accent);
}

.tile-diagnostik:hover {
  border-color: color-mix(in srgb, var(--diagnostik-accent) 30%, transparent);
}

.pill-diagnostik {
  background: color-mix(in srgb, var(--diagnostik-accent) 10%, transparent);
  color: var(--diagnostik-accent);
}

.page-hero-therapy-detail {
  padding: 10rem 0 var(--space-3xl);
  background: #5b9bb50f;
  border-bottom: 3px solid #5b9bb5;
  position: relative;
  overflow: hidden;
}

.page-hero-therapy-detail:before {
  content: "";
  pointer-events: none;
  background: radial-gradient(circle, #5b9bb514 0%, #0000 70%);
  border-radius: 50%;
  width: 500px;
  height: 500px;
  position: absolute;
  top: -120px;
  right: -80px;
}

.page-hero-therapy-detail .hero-icon {
  width: 4rem;
  height: 4rem;
  margin-bottom: var(--space-lg);
  opacity: .7;
}

.page-hero-therapy-detail .hero-icon img {
  width: 100%;
  height: 100%;
}

.page-hero-therapy-detail .hero-grid {
  gap: var(--space-3xl);
  grid-template-columns: 1fr 1fr;
  align-items: center;
  display: grid;
}

.page-hero-therapy-detail .hero-image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.page-hero-therapy-detail .hero-image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
}

.page-hero-therapy-detail .hero-eyebrow {
  font-size: var(--text-base);
  text-transform: uppercase;
  letter-spacing: .19rem;
  color: #5b9bb5;
  margin-bottom: var(--space-lg);
  font-weight: 700;
  display: block;
}

.page-hero-therapy-detail .hero-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-4xl);
  color: var(--text);
  margin-bottom: var(--space-lg);
  font-weight: 300;
  line-height: 1.15;
}

.page-hero-therapy-detail .hero-subtitle {
  font-size: var(--text-lg);
  color: var(--muted);
  max-width: 36rem;
  font-weight: 300;
  line-height: 1.65;
}

.page-hero-therapy-detail .breadcrumb {
  margin-bottom: var(--space-lg);
}

.btn-outline-therapy {
  align-items: center;
  gap: var(--space-xs);
  color: #5b9bb5;
  padding: .75rem var(--space-xl);
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  transition: all var(--transition);
  cursor: pointer;
  background: none;
  border: 2px solid #5b9bb5;
  font-weight: 700;
  display: inline-flex;
}

.btn-outline-therapy:hover {
  color: #fff;
  background: #5b9bb5;
}

.btn-outline-therapy svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 1rem;
  height: 1rem;
}

.intro-split {
  gap: var(--space-3xl);
  grid-template-columns: 1fr 1fr;
  align-items: start;
  display: grid;
}

.intro-text p {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: var(--space-md);
  font-weight: 300;
  line-height: 1.8;
}

.intro-text blockquote {
  border-left: 3px solid var(--tb-accent, #5b9bb5);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-xl) 0;
  background: color-mix(in srgb, var(--tb-accent, #5b9bb5) 4%, transparent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-family: var(--font-source-serif), "Source Serif 4", Georgia, serif;
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--text-dark);
  font-weight: 400;
  line-height: 1.8;
}

.intro-text blockquote p {
  margin-bottom: 0;
}

.intro-text ul, .intro-text ol {
  padding-left: var(--space-lg);
  margin: var(--space-md) 0;
}

.intro-text ul {
  list-style: none;
}

.intro-text ul li {
  margin-bottom: var(--space-sm);
  font-size: var(--text-lg);
  color: var(--text-light);
  padding-left: 1.25rem;
  font-weight: 300;
  line-height: 1.8;
  position: relative;
}

.intro-text ul li:before {
  content: "";
  background: var(--tb-accent, #5b9bb5);
  border-radius: 50%;
  width: 8px;
  height: 8px;
  position: absolute;
  top: .75em;
  left: 0;
}

.intro-text ol li {
  margin-bottom: var(--space-sm);
  font-size: var(--text-lg);
  color: var(--text-light);
  font-weight: 300;
  line-height: 1.8;
}

.intro-text ol li::marker {
  color: var(--tb-accent, #5b9bb5);
  font-weight: 600;
}

.intro-accent {
  width: 4rem;
  height: .25rem;
  margin-bottom: var(--space-xl);
  background: #5b9bb5;
  border-radius: .125rem;
}

.therapy-product-box {
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  background: #5b9bb50f;
  border: 1px solid #5b9bb52e;
  border-left: .3rem solid #5b9bb5;
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.therapy-box-icon {
  width: 3rem;
  height: 3rem;
  margin-bottom: var(--space-lg);
}

.therapy-box-icon img {
  width: 100%;
  height: 100%;
}

.therapy-products-label {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .125rem;
  color: var(--muted);
  margin-bottom: var(--space-md);
  font-weight: 700;
}

.therapy-product-pills {
  gap: var(--space-sm);
  flex-wrap: wrap;
  display: flex;
}

.therapy-product-pill {
  font-size: var(--text-md);
  padding: var(--space-sm) var(--space-lg);
  white-space: nowrap;
  color: #5b9bb5;
  background: #5b9bb526;
  border-radius: 6.25rem;
  align-items: center;
  gap: .3rem;
  font-weight: 600;
  line-height: 1.3;
  display: inline-flex;
}

.therapy-visual-count {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .08rem;
  color: var(--muted);
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px solid #5b9bb526;
  align-items: center;
  gap: .375rem;
  width: 100%;
  font-weight: 700;
  display: inline-flex;
}

.therapy-visual-count .count-number {
  width: 1.5rem;
  height: 1.5rem;
  font-size: var(--text-sm);
  color: #fff;
  letter-spacing: 0;
  background: #5b9bb5;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  display: inline-flex;
}

.detail-text {
  font-size: var(--text-lg);
  color: var(--text-light);
  max-width: 48rem;
  font-weight: 300;
  line-height: 1.8;
}

.detail-text p {
  margin-bottom: var(--space-md);
}

.area-nav {
  padding: var(--space-xl) 0;
  border-top: 1px solid var(--border);
  margin-top: var(--space-2xl);
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.area-nav-link {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-md);
  transition: gap var(--transition), opacity var(--transition);
  font-weight: 600;
  display: inline-flex;
}

.area-nav-link:hover {
  gap: var(--space-sm);
  opacity: .7;
}

.area-nav-link svg {
  flex-shrink: 0;
}

.area-nav-link.prev {
  margin-right: auto;
}

.area-nav-link.next {
  margin-left: auto;
}

.back-link {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-base);
  color: var(--muted);
  transition: color var(--transition);
  font-weight: 600;
  display: inline-flex;
}

.back-link:hover {
  color: var(--red);
}

.back-link svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 1rem;
  height: 1rem;
}

.page-hero-produkte {
  padding: 8rem 0 var(--space-3xl);
  background: var(--bg-white);
  border-bottom: 1px solid var(--border);
}

.page-hero-produkte .kc-eyebrow {
  font-size: var(--text-base);
  text-transform: uppercase;
  letter-spacing: .08rem;
  color: var(--red);
  margin-bottom: var(--space-sm);
  font-weight: 700;
}

.page-hero-produkte h1 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-4xl);
  color: var(--text);
  margin-bottom: var(--space-sm);
  letter-spacing: -.03rem;
  font-weight: 300;
  line-height: 1.2;
}

.page-hero-produkte p {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-lg);
  color: var(--text-light);
  max-width: 680px;
  font-weight: 300;
  line-height: 1.6;
}

.product-list-section {
  padding: var(--space-2xl) 0 var(--space-4xl);
}

.product-list {
  gap: var(--space-lg);
  flex-direction: column;
  display: flex;
}

.filter-section {
  padding: var(--space-lg) 0;
  background: var(--bg-white);
  border-bottom: 1px solid var(--border);
  z-index: 50;
  position: sticky;
  top: 52px;
}

.filter-bar {
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
  display: flex;
}

.filter-label {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--muted);
  font-weight: 700;
}

.filter-btn {
  border: 1px solid var(--border);
  padding: var(--space-xs) var(--space-lg);
  font-size: var(--text-base);
  color: var(--text-light);
  cursor: pointer;
  transition: all var(--transition);
  background: none;
  border-radius: 20px;
  font-family: inherit;
  font-weight: 500;
}

.filter-btn:hover {
  border-color: var(--red);
  color: var(--red);
}

.filter-btn.active {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}

.filter-count {
  font-size: var(--text-sm);
  color: var(--muted);
  margin-left: auto;
  font-weight: 500;
}

.search-bar {
  margin-top: var(--space-md);
  justify-content: center;
  align-items: center;
  width: 18.75rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.search-bar svg {
  width: 16px;
  height: 16px;
  stroke: var(--muted);
  left: var(--space-sm);
  pointer-events: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.search-input {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--space-xs) var(--space-md) var(--space-xs) 2.25rem;
  font-size: var(--text-base);
  color: var(--text);
  background: var(--bg);
  width: 100%;
  transition: border-color var(--transition);
  font-family: inherit;
}

.search-input:focus {
  border-color: var(--red);
  outline: none;
}

.search-input::placeholder {
  color: var(--muted);
}

.product-row {
  background: var(--bg-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: all var(--transition);
  box-shadow: var(--shadow-sm);
  padding: 0;
  padding-left: var(--space-xl);
  grid-template-rows: 1fr auto;
  grid-template-columns: 340px 1fr auto;
  align-items: start;
  display: grid;
  position: relative;
  overflow: hidden;
}

.row-color-bar {
  width: var(--space-xl);
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
}

.product-row:hover {
  box-shadow: var(--shadow-md);
}

.row-product-info {
  padding: var(--space-xl) var(--space-xl);
  gap: var(--space-xs);
  border-right: 1px solid var(--border);
  flex-direction: column;
  grid-row: 1 / 3;
  align-self: stretch;
  min-width: 0;
  display: flex;
}

.row-product-name {
  font-family: var(--font-open-sans), "Open Sans", sans-serif;
  font-size: var(--text-xl);
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: .03em;
  font-weight: 700;
  line-height: 1.15;
}

.row-product-name sup {
  vertical-align: super;
  font-size: .6em;
  line-height: 0;
  position: relative;
  top: -.3125rem;
  left: .1rem;
}

.row-product-name a {
  color: var(--text);
  transition: color var(--transition);
}

.row-product-name a:hover {
  color: var(--red);
}

.row-tagline {
  font-size: var(--text-base);
  color: var(--muted);
  font-weight: 400;
  line-height: 1.3;
}

.row-content {
  padding: var(--space-xl);
  border-left: none;
  flex-direction: column;
  gap: 0;
  display: flex;
}

.row-section {
  padding: 0 0 var(--space-md);
}

.row-section + .row-section {
  padding-top: var(--space-md);
  border-top: 1px solid #f0efec;
}

.row-section:last-child {
  padding-bottom: 0;
}

.row-section-label {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  margin-bottom: var(--space-xs);
  align-items: center;
  gap: var(--space-xs);
  font-weight: 700;
  display: flex;
}

.row-section-label svg {
  width: 14px;
  height: 14px;
  stroke: var(--muted);
  opacity: .6;
}

.row-description {
  font-size: var(--text-base);
  color: var(--text-light);
  line-height: 1.6;
}

.dok-chips {
  gap: var(--space-xs);
  flex-wrap: wrap;
  display: flex;
}

.dok-chip {
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-md);
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  color: #fff;
  background: var(--pc);
  transition: all var(--transition);
  border: none;
  font-weight: 600;
  display: inline-flex;
}

.dok-chip:hover {
  opacity: .85;
  color: #fff;
}

.dok-chip sup {
  vertical-align: super;
  font-size: .6em;
  line-height: 0;
  position: relative;
  top: -.4125rem;
  left: -.4rem;
}

.dok-chip svg {
  stroke: #fff;
  flex-shrink: 0;
  width: 14px;
  height: 14px;
}

.row-arrow {
  padding: var(--space-xl) var(--space-xl) var(--space-xl) var(--space-xs);
  align-items: center;
  display: flex;
}

.row-arrow a {
  background: var(--bg);
  border: 1px solid var(--border);
  width: 40px;
  height: 40px;
  transition: all var(--transition);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  display: flex;
}

.row-arrow a:hover {
  background: var(--red);
  border-color: var(--red);
}

.row-arrow a:hover svg {
  stroke: #fff;
}

.row-arrow svg {
  width: 16px;
  height: 16px;
  stroke: var(--text-light);
}

.row-footer-lines {
  padding: 0 var(--space-xl) var(--space-sm);
  flex-direction: column;
  grid-column: 1 / -1;
  gap: 3px;
  margin-bottom: .3rem;
  display: flex;
}

.row-line-thick {
  border-radius: 2px;
  height: 2.5px;
}

.row-line-thin {
  border-radius: 1px;
  width: 100%;
  height: 1px;
}

.row-product-info > * {
  width: 100%;
  display: block;
}

.row-badge {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: .08em;
  z-index: 1;
  border-radius: 100px;
  align-self: flex-start;
  margin-bottom: 8px;
  padding: 3px 9px;
  font-weight: 500;
  display: inline-flex;
  position: relative;
}

.row-section-value {
  font-size: var(--text-base);
  color: var(--text-light);
  font-weight: 400;
  line-height: 1.6;
}

.row-description em {
  font-size: var(--text-sm);
  color: var(--muted);
}

.dok-chip-fk {
  background: var(--pc);
}

.dok-chip-fk:hover {
  opacity: .85;
  color: #fff;
}

.filter-count {
  display: none;
}

.kc-cta-band {
  background: var(--red);
  padding: 48px 0;
}

.kc-cta-band-inner {
  justify-content: space-between;
  align-items: center;
  gap: 32px;
  display: flex;
}

.kc-cta-band h3 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 600;
}

.kc-cta-band p {
  color: #ffffffd9;
  margin-top: 6px;
  font-size: .95rem;
}

.kc-btn-cta {
  color: var(--red);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  white-space: nowrap;
  background: #fff;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  font-size: .88rem;
  font-weight: 700;
  display: inline-flex;
}

.kc-btn-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 16px #00000026;
}

.benefits-grid {
  gap: var(--space-lg);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.benefit-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: all var(--transition);
  padding: 2.25rem 1.75rem;
}

.benefit-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-.25rem);
}

.benefit-icon {
  background: var(--red-light);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 1.25rem;
  display: flex;
}

.benefit-icon svg {
  width: 1.375rem;
  height: 1.375rem;
  stroke: var(--red);
  fill: none;
  stroke-width: 1.8px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.benefit-card h3 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-lg);
  margin-bottom: .625rem;
  font-weight: 600;
}

.benefit-card p {
  font-size: var(--text-md);
  color: var(--muted);
  line-height: 1.7;
}

.perks-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  display: grid;
}

.perk-item {
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  align-items: flex-start;
  display: flex;
}

.perk-icon {
  background: var(--red-light);
  border-radius: var(--space-xs);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
}

.perk-icon svg {
  width: 1.125rem;
  height: 1.125rem;
  stroke: var(--red);
  fill: none;
  stroke-width: 1.8px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.perk-item h4 {
  font-size: var(--text-md);
  margin-bottom: .25rem;
  font-weight: 600;
}

.perk-item p {
  font-size: var(--text-base);
  color: var(--muted);
  line-height: 1.7;
}

.process-timeline {
  margin-top: var(--space-3xl);
  padding: 0;
  position: relative;
}

.process-steps {
  counter-reset: step;
  justify-content: space-between;
  display: flex;
  position: relative;
}

.process-steps:before {
  content: "";
  background: var(--border);
  z-index: 0;
  height: 2px;
  position: absolute;
  top: 1.75rem;
  left: 8.33333%;
  right: 8.33333%;
}

.process-step {
  text-align: center;
  z-index: 1;
  flex-direction: column;
  flex: 1;
  align-items: center;
  padding: 0 .5rem;
  display: flex;
  position: relative;
}

.process-circle {
  background: var(--bg-white);
  border: 2px solid var(--border);
  width: 3.5rem;
  height: 3.5rem;
  margin-bottom: var(--space-lg);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  transition: all .4s;
  display: flex;
  position: relative;
}

.process-circle img {
  width: 1.375rem;
  height: 1.375rem;
}

.process-number {
  background: var(--red);
  color: #fff;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 1.5rem;
  height: 1.5rem;
  font-size: .65rem;
  font-weight: 700;
  line-height: 1;
  display: flex;
  position: absolute;
  top: -.5rem;
  right: -.5rem;
}

.process-step:hover .process-circle {
  border-color: var(--red);
  box-shadow: 0 0 0 4px var(--red-light);
  transform: translateY(-4px);
}

.process-step h4 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-md);
  margin-bottom: .375rem;
  font-weight: 600;
  line-height: 1.3;
}

.process-step p {
  font-size: var(--text-base);
  color: var(--muted);
  max-width: 10rem;
  line-height: 1.6;
}

.jobs-list {
  gap: var(--space-md);
  margin-top: var(--space-2xl);
  flex-direction: column;
  display: flex;
}

.job-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: all var(--transition);
  overflow: hidden;
}

.job-card:hover {
  box-shadow: var(--shadow-sm);
}

.job-card-header {
  padding: var(--space-lg) 1.75rem;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  display: flex;
}

.job-title {
  font-weight: 700;
  font-size: var(--text-lg);
  margin-bottom: var(--space-xs);
}

.job-tags {
  gap: var(--space-sm);
  flex-wrap: wrap;
  display: flex;
}

.job-tag {
  font-size: var(--text-sm);
  color: var(--muted);
  align-items: center;
  gap: .375rem;
  display: inline-flex;
}

.job-tag img {
  width: .875rem;
  height: .875rem;
}

.job-card-body-inner {
  padding: 0 1.75rem 1.75rem;
}

.job-card-body-inner p {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: 1.25rem;
  line-height: 1.75;
}

.ausbildung-expects {
  gap: var(--space-md);
  margin-top: var(--space-xl);
  grid-template-columns: repeat(2, 1fr);
  display: grid;
}

.ausbildung-expects li {
  font-size: var(--text-md);
  color: var(--text-light);
  align-items: flex-start;
  gap: .625rem;
  line-height: 1.7;
  list-style: none;
  display: flex;
}

img.check-icon {
  flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
  margin-top: .2rem;
}

.praktika-grid {
  gap: var(--space-lg);
  margin-top: var(--space-2xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.praktika-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  padding: 2rem 1.75rem;
}

.praktika-card h3 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-xl);
  margin-bottom: var(--space-md);
  font-weight: 600;
}

.praktika-card p {
  font-size: var(--text-md);
  color: var(--text-light);
  margin-bottom: var(--space-md);
  line-height: 1.7;
}

.praktika-card ul {
  margin-bottom: var(--space-md);
  list-style: none;
}

.praktika-card ul li {
  font-size: var(--text-base);
  color: var(--muted);
  align-items: flex-start;
  gap: .5rem;
  padding: .25rem 0;
  line-height: 1.7;
  display: flex;
}

.praktika-card ul li img {
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  margin-top: .2rem;
}

.initiativ-card {
  background: var(--bg-white);
  border-radius: var(--radius-lg);
  padding: var(--space-3xl);
  border: 1px solid var(--border);
  gap: var(--space-2xl);
  margin-top: var(--space-2xl);
  align-items: center;
  display: flex;
}

.initiativ-card .initiativ-text {
  flex: 1;
}

.initiativ-card h3 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-2xl);
  margin-bottom: var(--space-md);
  font-weight: 300;
}

.initiativ-card p {
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: var(--space-lg);
  font-weight: 300;
  line-height: 1.7;
}

.karriere-ov-card {
  border-radius: var(--radius-lg);
  background: #fff;
  transition: transform .25s, box-shadow .25s;
  display: block;
  overflow: hidden;
  box-shadow: 0 4px 24px #0000000f;
}

.karriere-ov-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 32px #0000001a;
}

.contact-cards {
  gap: var(--space-xl);
  margin-top: var(--space-3xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.contact-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  padding: var(--space-xl) var(--space-lg);
  border: 1px solid var(--border);
  text-align: center;
  transition: all var(--transition);
}

.contact-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-.25rem);
}

.contact-card-icon {
  width: 2.8rem;
  height: 2.8rem;
  margin: 0 auto var(--space-md);
  background: var(--red-light);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  display: flex;
}

.contact-card-icon svg {
  width: 1.2rem;
  height: 1.2rem;
  stroke: var(--red);
  fill: none;
  stroke-width: 1.8px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.contact-card h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-xs);
  font-weight: 700;
}

.contact-card p {
  font-size: var(--text-md);
  color: var(--muted);
  line-height: 1.7;
}

.contact-card a {
  color: var(--red);
  font-weight: 600;
}

.form-grid {
  gap: var(--space-3xl);
  grid-template-columns: 1.2fr .8fr;
  align-items: start;
  display: grid;
}

.form-group {
  margin-bottom: var(--space-md);
}

.form-row {
  gap: var(--space-md);
  grid-template-columns: 1fr 1fr;
  display: grid;
}

.form-group label {
  font-size: var(--text-base);
  margin-bottom: var(--space-xs);
  color: var(--text);
  font-weight: 600;
  display: block;
}

.form-group .optional {
  color: var(--muted);
  font-weight: 400;
  font-size: var(--text-sm);
}

.form-group input, .form-group select, .form-group textarea {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: var(--text-md);
  color: var(--text);
  background: var(--bg-white);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}

.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--red);
  box-shadow: 0 0 0 3px #b51d2814;
}

.form-group textarea {
  resize: vertical;
  min-height: 7rem;
}

.form-group select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b6b6b' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-sm) center;
}

.checkbox-group {
  gap: var(--space-sm);
  margin: var(--space-xl) 0;
  align-items: flex-start;
  display: flex;
}

.checkbox-group input[type="checkbox"] {
  width: .9rem;
  height: .9rem;
  accent-color: var(--red);
  cursor: pointer;
  margin-top: .1rem;
}

.checkbox-group label {
  font-size: var(--text-base);
  color: var(--text-light);
  cursor: pointer;
  line-height: 1.5;
}

.btn-submit {
  align-items: center;
  gap: var(--space-xs);
  background: var(--red);
  color: #fff;
  padding: var(--space-sm) var(--space-xl);
  border-radius: var(--radius-sm);
  font-size: var(--text-md);
  cursor: pointer;
  transition: all var(--transition);
  border: none;
  font-weight: 700;
  display: inline-flex;
}

.btn-submit:hover {
  background: var(--red-hover);
  transform: translateY(-1px);
}

.info-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  border: 1px solid var(--border);
}

.info-card h4 {
  font-size: var(--text-md);
  margin-bottom: var(--space-sm);
  align-items: center;
  gap: var(--space-xs);
  font-weight: 700;
  display: flex;
}

.info-card h4 svg {
  width: .9rem;
  height: .9rem;
  stroke: var(--red);
  fill: none;
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.info-card p {
  font-size: var(--text-base);
  color: var(--text-light);
  margin-bottom: var(--space-md);
  line-height: 1.75;
}

.notice-box {
  border-radius: var(--radius-sm);
  padding: var(--space-xl);
  margin-top: var(--space-xl);
  background: #b51d280a;
  border: 1px solid #b51d2826;
}

.notice-box h5 {
  font-size: var(--text-base);
  color: var(--red);
  margin-bottom: var(--space-xs);
  font-weight: 700;
}

.notice-box p {
  font-size: var(--text-base);
  color: var(--text-light);
  margin-bottom: 0;
  line-height: 1.7;
}

.notice-box-contact {
  margin-top: var(--space-xs);
}

.notice-box-link {
  color: var(--red);
}

.privacy-link {
  color: var(--red);
  text-decoration: underline;
}

.downloads-grid {
  gap: var(--space-md);
  margin-top: var(--space-3xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.download-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  border: 1px solid var(--border);
  gap: var(--space-md);
  transition: all var(--transition);
  cursor: pointer;
  align-items: center;
  display: flex;
}

.download-card:hover {
  border-color: var(--red);
  box-shadow: var(--shadow-sm);
}

.download-icon {
  background: var(--red-light);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 2.2rem;
  height: 2.2rem;
  display: flex;
}

.download-icon svg {
  width: 1rem;
  height: 1rem;
  stroke: var(--red);
  fill: none;
  stroke-width: 1.8px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.download-card h4 {
  font-size: var(--text-base);
  margin-bottom: .1rem;
  font-weight: 600;
}

.download-card span {
  font-size: var(--text-sm);
  color: var(--muted);
}

.map-placeholder {
  background: var(--border);
  border-radius: var(--radius-lg);
  justify-content: center;
  align-items: center;
  gap: var(--space-md);
  min-height: 16rem;
  margin-top: var(--space-3xl);
  flex-direction: column;
  display: flex;
}

.map-placeholder svg {
  width: 2.4rem;
  height: 2.4rem;
  stroke: var(--muted);
  fill: none;
  stroke-width: 1.5px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.map-placeholder p {
  font-size: var(--text-md);
  color: var(--muted);
  text-align: center;
}

.btn-fachkreise-cta {
  align-items: center;
  gap: var(--space-sm);
  color: var(--red);
  padding: var(--space-md) var(--space-xl);
  font-size: var(--text-md);
  transition: all var(--transition);
  background: #fff;
  border-radius: 2.5rem;
  font-weight: 700;
  display: inline-flex;
  box-shadow: 0 .2rem 1rem #00000026;
}

.btn-fachkreise-cta:hover {
  transform: translateY(-.1rem);
  box-shadow: 0 .4rem 1.6rem #0003;
}

.product-hero-card {
  margin-top: 0;
}

.product-hero-header {
  padding: 8.75rem 0 3rem;
  position: relative;
  overflow: hidden;
}

.product-hero-header:after {
  content: "";
  opacity: .18;
  pointer-events: none;
  z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.08'/%3E%3C/svg%3E");
  position: absolute;
  inset: 0;
}

.product-hero-header > .container {
  z-index: 1;
  position: relative;
}

.product-hero-body {
  background: var(--bg-white);
  padding: var(--space-2xl) 0;
  z-index: 1;
  position: relative;
  overflow: visible;
}

.product-hero-body > .container {
  z-index: 1;
  position: relative;
}

.hero-footer {
  flex-direction: column;
  gap: 3px;
  display: flex;
}

.hero-line-thick {
  height: 4px;
}

.hero-line-thin {
  opacity: .5;
  height: 1.5px;
}

.product-hero-grid {
  gap: var(--space-2xl);
  grid-template-columns: 1fr 1fr;
  align-items: start;
  display: grid;
}

.product-hero .breadcrumb {
  font-size: var(--text-sm);
  color: #ffffff80;
  margin-bottom: var(--space-lg);
  align-items: center;
  gap: var(--space-xs);
  display: flex;
}

.product-hero .breadcrumb a {
  color: #ffffff80;
  transition: color var(--transition);
  text-decoration: none;
}

.product-hero .breadcrumb a:hover {
  color: #fff;
}

.product-hero .breadcrumb .sep {
  color: #ffffff40;
}

.product-hero-badge {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .09375rem;
  padding: .375rem var(--space-md);
  border-radius: var(--radius-lg);
  color: #fff;
  margin-bottom: var(--space-lg);
  font-weight: 700;
  display: inline-block;
}

.product-hero-title {
  font-family: var(--font-open-sans), "Open Sans", sans-serif;
  font-size: var(--text-6xl);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin: 0;
  font-weight: 500;
  line-height: 1.1;
}

.product-hero-tagline {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-xl);
  margin-bottom: var(--space-md);
  font-weight: 600;
}

.product-hero-desc {
  font-size: var(--text-lg);
  color: var(--text-light);
  max-width: 32.5rem;
  margin-bottom: var(--space-lg);
  font-weight: 400;
  line-height: 1.7;
}

.product-hero-actions {
  gap: var(--space-sm);
  flex-wrap: wrap;
  display: flex;
}

.hero-packshot {
  z-index: 2;
  justify-content: center;
  align-items: flex-start;
  margin-top: -10rem;
  display: flex;
  position: relative;
}

.hero-packshot img {
  object-fit: contain;
  filter: drop-shadow(0 1rem 3rem #0000002e);
  width: 100%;
  max-width: 32.5rem;
  height: auto;
  max-height: 38.75rem;
  animation: .8s ease-out packshot-slide;
}

@keyframes packshot-slide {
  from {
    opacity: 0;
    transform: translateX(2.5rem);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.highlight-hero-card .product-hero-header {
  padding: 10rem 0 3.5rem;
}

.highlight-hero-card .product-hero-title {
  font-size: var(--text-7xl);
  line-height: 1.05;
}

.highlight-hero-card .hero-packshot img {
  max-width: 43.5rem;
  max-height: 52.5rem;
}

.highlight-hero-card .product-hero-badge {
  font-size: var(--text-xs);
  letter-spacing: .125rem;
  padding: .375rem 1.125rem;
}

.product-hero-body .hero-icon {
  opacity: .08;
  pointer-events: none;
  z-index: 0;
  width: auto;
  height: 20rem;
  position: absolute;
  top: -15.3125rem;
  right: 4%;
}

.product-section-eyebrow {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .1875rem;
  margin-bottom: var(--space-md);
  font-weight: 700;
}

.product-section-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-3xl);
  margin-bottom: var(--space-md);
  letter-spacing: -.01875rem;
  font-weight: 300;
  line-height: 1.2;
}

.disclaimer-box {
  padding: var(--space-xl);
  background: var(--bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  margin-top: var(--space-lg);
}

.disclaimer-box p {
  font-size: var(--text-base);
  color: var(--text-light);
  margin-bottom: var(--space-xs);
  font-weight: 300;
  line-height: 1.7;
}

.disclaimer-box p:last-child {
  margin-bottom: 0;
}

.product-hero-card {
  position: relative;
}

.fk-login-box {
  bottom: -8.25rem;
  right: calc((100vw - var(--max-width)) / 2 + var(--space-xl));
  z-index: 10;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  width: 19.375rem;
  padding: var(--space-xl) var(--space-lg);
  text-align: center;
  background: #fff;
  position: absolute;
  box-shadow: 0 4px 20px #00000014;
}

.fk-login-icon {
  margin-bottom: var(--space-md);
}

.fk-login-text {
  font-size: var(--text-sm);
  color: var(--text-light);
  margin-bottom: var(--space-lg);
  line-height: 1.7;
}

.fk-login-btn {
  background: var(--red);
  color: #fff;
  width: 100%;
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .05em;
  border-radius: var(--radius-sm);
  transition: opacity var(--transition);
  justify-content: center;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.5rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
}

.fk-login-btn:hover {
  opacity: .9;
  color: #fff;
}

@media (max-width: 768px) {
  .fk-login-box {
    width: 90%;
    margin: var(--space-lg) auto;
    position: static;
    bottom: auto;
    right: auto;
  }
}

.dok-group-title {
  font-size: var(--text-base);
  color: var(--text-dark);
  margin-top: var(--space-xl);
  margin-bottom: 0;
  font-weight: 700;
}

.dok-group-title:first-of-type {
  margin-top: var(--space-md);
}

.dokumente-grid {
  gap: var(--space-sm);
  margin-top: var(--space-sm);
  flex-wrap: wrap;
  display: flex;
}

.dok-btn {
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-base);
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--border);
  background: var(--bg-white);
  color: var(--text-light);
  transition: all var(--transition);
  cursor: pointer;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.dok-btn:hover {
  border-color: var(--product-accent);
  color: var(--product-accent);
}

.dok-btn-fk {
  background: var(--product-accent);
  color: #fff;
  border-color: var(--product-accent);
}

.dok-btn-fk:hover {
  opacity: .9;
  color: #fff;
}

.weitere-info-box {
  padding: var(--space-2xl);
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  margin-top: var(--space-lg);
}

.weitere-info-box h4 {
  font-size: var(--text-base);
  margin-bottom: var(--space-md);
  font-weight: 600;
}

.weitere-info-box ul {
  margin-bottom: var(--space-lg);
  padding: 0;
  list-style: none;
}

.weitere-info-box ul li {
  font-size: var(--text-base);
  color: var(--text-light);
  padding-left: var(--space-lg);
  line-height: 1.8;
  position: relative;
}

.weitere-info-box ul li:before {
  content: "";
  background: var(--product-dot-color, var(--sedalam));
  border-radius: 50%;
  width: .5rem;
  height: .5rem;
  position: absolute;
  top: .625rem;
  left: 0;
}

.weitere-info-box .login-hint {
  font-size: var(--text-base);
  color: var(--muted);
  margin-bottom: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border);
  line-height: 1.7;
}

.section:has(.pflichthinweise) {
  padding: var(--space-xl) 0;
}

.pflichthinweise {
  padding: var(--space-lg) var(--space-xl);
  background: var(--bg);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--product-accent, var(--sedalam-accent));
}

.pflichthinweise p {
  font-size: var(--text-base);
  color: var(--muted);
  margin-bottom: .25rem;
  line-height: 1.7;
}

.pflichthinweise p:last-child {
  margin-bottom: 0;
}

.related-grid {
  gap: var(--space-lg);
  margin-top: var(--space-2xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid;
}

.related-card {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  cursor: pointer;
  flex-direction: column;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  display: flex;
  overflow: hidden;
  box-shadow: 0 1px 3px #0000000f, 0 4px 16px #0000000d;
}

.related-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 8px #00000014, 0 12px 32px #0000001a;
}

.related-card-header {
  height: 6.875rem;
  padding: .875rem var(--space-lg);
  flex-direction: column;
  flex-shrink: 0;
  justify-content: flex-end;
  align-items: flex-start;
  display: flex;
  position: relative;
  overflow: hidden;
}

.related-card-header:after {
  content: "";
  opacity: .22;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.08'/%3E%3C/svg%3E");
  position: absolute;
  inset: 0;
}

.related-badge-row {
  margin-bottom: var(--space-xs);
  z-index: 1;
  gap: .375rem;
  display: flex;
  position: relative;
}

.related-card-header .related-badge {
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #fff;
  border-radius: 6.25rem;
  padding: .1875rem .5625rem;
  font-weight: 500;
}

.related-card-header .related-name {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-xl);
  color: #fff;
  z-index: 1;
  text-shadow: 0 1px 4px #00000026;
  font-weight: 300;
  line-height: 1.1;
  position: relative;
}

.related-card-body {
  padding: var(--space-md) 1.125rem .875rem;
  flex-direction: column;
  flex: 1;
  display: flex;
}

.related-card-body .related-tagline {
  font-size: var(--text-base);
  letter-spacing: -.01em;
  margin-bottom: .375rem;
  font-weight: 500;
}

.related-card-body p {
  font-size: var(--text-sm);
  color: #5a5a56;
  margin-bottom: var(--space-sm);
  flex: 1;
  font-weight: 300;
  line-height: 1.65;
}

.related-link {
  font-size: var(--text-sm);
  letter-spacing: .07em;
  text-transform: uppercase;
  color: #5a5a56;
  margin-bottom: var(--space-sm);
  font-weight: 500;
  transition: color .15s;
  display: inline-block;
}

.related-link:after {
  content: " →";
}

.related-card:hover .related-link {
  color: var(--text);
}

.related-card-footer {
  flex-direction: column;
  flex-shrink: 0;
  gap: .1875rem;
  display: flex;
}

.related-line-thick {
  height: .25rem;
}

.related-line-thin {
  opacity: .5;
  height: .09375rem;
}

.cta-band-product {
  background: var(--red);
  padding: var(--space-3xl) 0;
}

.cta-band-product-inner {
  justify-content: space-between;
  align-items: center;
  gap: var(--space-xl);
  display: flex;
}

.cta-band-product h3 {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-2xl);
  color: #fff;
  font-weight: 300;
}

.cta-band-product p {
  font-size: var(--text-base);
  color: #ffffffb3;
  margin-top: .375rem;
  font-weight: 300;
}

.cta-band-product .btn-cta {
  align-items: center;
  gap: var(--space-xs);
  color: var(--red);
  padding: .875rem var(--space-xl);
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  transition: all var(--transition);
  white-space: nowrap;
  cursor: pointer;
  background: #fff;
  border: none;
  font-weight: 700;
  display: inline-flex;
}

.cta-band-product .btn-cta:hover {
  background: #ffffffe6;
  transform: translateY(-1px);
}

.product-section-desc {
  font-size: var(--text-md);
  color: var(--muted);
  max-width: 40rem;
  font-weight: 300;
  line-height: 1.75;
}

@media (max-width: 1024px) {
  .split {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .stats-grid, .values-grid, .tiles-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .intro-split, .page-hero-therapy-detail .hero-grid {
    gap: var(--space-xl);
    grid-template-columns: 1fr;
  }

  .page-hero-therapy-detail .hero-image {
    max-height: 250px;
  }

  .product-hero-grid {
    grid-template-columns: 1fr;
  }

  .product-hero-body .hero-icon {
    height: 15rem;
    right: 2%;
  }

  .highlight-hero-card .product-hero-title {
    font-size: var(--text-6xl);
  }

  .highlight-hero-card .hero-packshot {
    flex: 0 0 17.5rem;
    max-width: 17.5rem;
  }

  .highlight-hero-card .hero-packshot img {
    max-height: 21.25rem;
  }

  .benefits-grid, .perks-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .praktika-grid, .ausbildung-expects {
    grid-template-columns: 1fr;
  }

  .process-steps {
    justify-content: center;
    gap: var(--space-xl);
    flex-wrap: wrap;
  }

  .process-steps:before {
    display: none;
  }

  .process-step {
    flex: 0 0 calc(33.33% - var(--space-xl));
  }

  .initiativ-card {
    text-align: center;
    flex-direction: column;
  }

  .contact-cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .form-grid {
    grid-template-columns: 1fr;
  }

  .downloads-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .page-hero {
    padding: 8.125rem 0 3.5rem;
  }

  .page-hero .hero-title {
    font-size: var(--text-2xl);
  }

  .tiles-grid {
    grid-template-columns: 1fr;
  }

  .stats-grid {
    gap: var(--space-md);
    grid-template-columns: repeat(2, 1fr);
  }

  .stat-number {
    font-size: var(--text-2xl);
  }

  .values-grid {
    grid-template-columns: 1fr;
  }

  .timeline {
    padding-left: var(--space-xl);
  }

  .timeline:before {
    left: .6875rem;
  }

  .timeline-dot {
    left: -1.8125rem;
  }

  .cta-inner, .cta-grid {
    text-align: center;
    flex-direction: column;
  }

  .benefits-grid, .perks-grid {
    grid-template-columns: 1fr;
  }

  .arbeitgeber-cols {
    grid-template-columns: 1fr !important;
  }

  .process-steps {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }

  .process-steps:before {
    width: 2px;
    height: auto;
    inset: 0 auto 0 1.75rem;
  }

  .process-step {
    text-align: left;
    gap: var(--space-lg);
    padding: var(--space-lg) 0;
    flex-direction: row;
  }

  .process-circle {
    flex-shrink: 0;
  }

  .process-step p {
    max-width: none;
  }

  .contact-cards, .downloads-grid, .form-row {
    grid-template-columns: 1fr;
  }

  .kc-cta-band-inner {
    text-align: center;
    flex-direction: column;
  }

  .product-hero-header {
    padding: 6.25rem 0 2rem;
  }

  .highlight-hero-card .product-hero-header {
    padding: 6.875rem 0 2.25rem;
  }

  .product-hero-body {
    padding: 1.75rem 0;
  }

  .product-hero-body .hero-icon {
    display: none;
  }

  .hero-packshot {
    margin-top: 0;
    max-width: 20.625rem;
    margin-inline: auto;
  }

  .hero-packshot img {
    max-width: 17.5rem !important;
    max-height: 20rem !important;
    animation-name: none !important;
  }

  .highlight-hero-card .product-hero-title {
    font-size: var(--text-5xl);
  }

  .product-hero-title {
    font-size: var(--text-4xl);
  }

  .product-hero-grid {
    grid-template-columns: 1fr;
  }

  .product-section-title {
    font-size: var(--text-3xl);
  }

  .related-grid {
    grid-template-columns: 1fr;
  }

  .dokumente-grid {
    flex-direction: column;
  }

  .cta-band-product-inner {
    text-align: center;
    flex-direction: column;
  }

  .product-row {
    grid-template-rows: auto auto auto;
    max-width: 100%;
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .row-product-info {
    flex-direction: column;
    grid-area: auto / 1;
    align-items: flex-start;
    gap: 6px;
    min-width: 0;
    min-height: 80px;
    padding: 16px;
    border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
  }

  .row-badge {
    margin-bottom: 0;
  }

  .row-content {
    border-top: none;
    border-left: none;
    flex-direction: column;
    grid-column: 1;
    min-width: 0;
    padding: 16px;
  }

  .row-arrow {
    display: none;
  }

  .row-footer-lines {
    grid-column: 1 / -1;
    min-width: 0;
  }

  .row-section + .row-section {
    padding-top: 12px;
  }

  .row-section-value, .row-description {
    overflow-wrap: break-word;
    word-break: break-word;
  }

  .filter-label {
    display: none;
  }

  .filter-bar {
    flex-wrap: wrap;
    gap: 6px;
  }

  .filter-btn {
    padding: 6px 12px;
    font-size: .78rem;
  }

  .filter-count {
    display: none;
  }

  .dok-chip {
    white-space: normal;
    max-width: 100%;
  }

  .dok-chips {
    max-width: 100%;
  }

  .product-list {
    gap: 12px;
  }

  .page-hero-produkte {
    padding: 100px 0 32px;
  }

  .page-hero-produkte h1 {
    font-size: var(--text-2xl);
  }

  .page-hero-produkte p {
    font-size: var(--text-base);
  }
}

.fade-up {
  opacity: 1;
  transform: translateY(0);
}

.testimonial-carousel {
  margin-top: var(--space-2xl);
  position: relative;
  overflow: hidden;
}

.testimonial-track {
  overflow: hidden;
}

.testimonial-slides {
  transition: transform .5s;
  display: flex;
}

.testimonial-slide {
  min-width: 100%;
  padding: 0 var(--space-md);
}

.testimonial-card {
  background: var(--bg-white);
  border-radius: var(--radius-lg);
  padding: var(--space-3xl) var(--space-2xl);
  border: 1px solid var(--border);
  text-align: center;
  max-width: 42.5rem;
  margin: 0 auto;
}

.testimonial-avatar {
  width: 12.5rem;
  height: 12.5rem;
  margin: 0 auto var(--space-lg);
  border: 3px solid var(--border);
  border-radius: 50%;
  overflow: hidden;
}

.testimonial-avatar img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.testimonial-card blockquote {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-lg);
  color: var(--text-light);
  margin-bottom: var(--space-lg);
  font-style: italic;
  font-weight: 400;
  line-height: 1.7;
}

.testimonial-author-name {
  font-weight: 700;
  font-size: var(--text-base);
  display: block;
}

.testimonial-author-role {
  font-size: var(--text-sm);
  color: var(--muted);
}

.testimonial-controls {
  justify-content: center;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-xl);
  display: flex;
}

.testimonial-btn {
  border: 1px solid var(--border);
  background: var(--bg-white);
  cursor: pointer;
  width: 2.5rem;
  height: 2.5rem;
  transition: all var(--transition);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  display: flex;
}

.testimonial-btn:hover {
  border-color: var(--red);
  color: var(--red);
}

.testimonial-btn svg {
  width: 1.125rem;
  height: 1.125rem;
}

.testimonial-dots {
  gap: var(--space-xs);
  display: flex;
}

.testimonial-dot {
  background: var(--border);
  cursor: pointer;
  width: .625rem;
  height: .625rem;
  transition: background var(--transition);
  border: none;
  border-radius: 50%;
}

.testimonial-dot.active {
  background: var(--red);
}

.perks-grid.collapsed .perk-item:nth-child(n+10) {
  display: none;
}

.perk-icon img {
  width: 1.125rem;
  height: 1.125rem;
}

.show-all-btn {
  margin: var(--space-xl) auto 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: var(--text-base);
  color: var(--text-light);
  cursor: pointer;
  transition: all var(--transition);
  background: none;
  justify-content: center;
  align-items: center;
  gap: .375rem;
  padding: .75rem 2rem;
  font-family: inherit;
  font-weight: 700;
  display: flex;
}

.show-all-btn:hover {
  border-color: var(--red);
  color: var(--red);
}

.show-all-btn svg {
  width: .875rem;
  height: .875rem;
  transition: transform .3s;
}

.show-all-btn.open svg {
  transform: rotate(180deg);
}

.hinweis-box {
  background: #b51d280f;
  border: 1px solid #b51d2826;
  border-radius: .75rem;
  margin-bottom: 2.5rem;
  padding: 1.5rem 2rem;
}

.job-toggle-icon {
  flex-shrink: 0;
  transition: transform .3s;
}

.job-toggle-icon svg {
  fill: none;
  width: 1.25rem;
  height: 1.25rem;
  stroke: var(--muted);
  stroke-width: 2px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.job-card.expanded .job-toggle-icon {
  transform: rotate(180deg);
}

.job-card-body {
  max-height: 0;
  transition: max-height .4s;
  overflow: hidden;
}

@media (max-width: 1024px) {
  .split {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .benefits-grid, .perks-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .praktika-grid, .ausbildung-expects {
    grid-template-columns: 1fr;
  }

  .process-steps {
    justify-content: center;
    gap: var(--space-xl);
    flex-wrap: wrap;
  }

  .process-steps:before {
    display: none;
  }

  .process-step {
    flex: 0 0 calc(33.33% - var(--space-xl));
  }

  .initiativ-card {
    text-align: center;
    flex-direction: column;
  }
}

@media (max-width: 768px) {
  .benefits-grid, .perks-grid {
    grid-template-columns: 1fr;
  }

  .arbeitgeber-cols {
    grid-template-columns: 1fr !important;
  }

  .process-steps {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }

  .process-steps:before {
    width: 2px;
    height: auto;
    inset: 0 auto 0 1.75rem;
  }

  .process-step {
    text-align: left;
    gap: var(--space-lg);
    padding: var(--space-lg) 0;
    flex-direction: row;
  }

  .process-circle {
    flex-shrink: 0;
  }

  .process-step p {
    max-width: none;
  }

  .cta-grid {
    text-align: center;
    flex-direction: column;
  }

  .testimonial-card {
    padding: var(--space-2xl) var(--space-lg);
  }
}

.highlight-card-body--compact {
  text-align: left;
  min-height: auto;
  padding: var(--space-xl) var(--space-xl) var(--space-md);
  align-items: flex-start;
}

.highlight-name--sans {
  font-family: var(--font-open-sans), "Open Sans", sans-serif;
  font-weight: 700;
  font-size: var(--text-xl);
  letter-spacing: normal;
  text-transform: uppercase;
}

.highlight-name--sans sup {
  vertical-align: super;
  font-size: .5em;
}

.fk-only {
  display: none !important;
}

body.fachkreise .fk-only {
  display: block !important;
}

body.fachkreise .fk-only.fk-inline {
  display: inline-flex !important;
}

body.fachkreise .fk-guest {
  display: none !important;
}

.fk-hero-desc {
  display: none;
}

body.fachkreise .fk-hero-desc {
  display: block;
}

body.fachkreise .public-hero-desc {
  display: none;
}

.fk-hero-desc ul {
  margin-top: var(--space-xs);
  padding: 0;
  list-style: none;
}

.fk-hero-desc ul li {
  font-size: var(--text-base);
  color: var(--text-light);
  padding-left: var(--space-md);
  line-height: 1.8;
  position: relative;
}

.fk-hero-desc ul li:before {
  content: "–";
  position: absolute;
  left: 0;
}

.fk-float-toggle {
  z-index: 200;
  color: #fff;
  font-family: var(--font-open-sans), "Open Sans", sans-serif;
  cursor: pointer;
  background: #b51d28;
  border: none;
  border-radius: 2.5rem;
  align-items: center;
  gap: .5rem;
  padding: .625rem 1.125rem;
  font-size: .92rem;
  font-weight: 600;
  transition: all .2s;
  display: flex;
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  box-shadow: 0 4px 16px #b51d2859;
}

.fk-float-toggle:hover {
  background: #961820;
  transform: translateY(-2px);
  box-shadow: 0 6px 24px #b51d2873;
}

.fk-float-toggle svg {
  flex-shrink: 0;
  width: 14px;
  height: 14px;
}

body.fachkreise .fk-float-toggle {
  background: #1a7a1a;
  box-shadow: 0 4px 16px #1a7a1a59;
}

body.fachkreise .fk-float-toggle:hover {
  background: #156015;
  box-shadow: 0 6px 24px #1a7a1a73;
}

.dosierung-table {
  border-collapse: collapse;
  width: 100%;
  margin-top: var(--space-lg);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  overflow: hidden;
}

.dosierung-table th {
  background: var(--text-light);
  color: #fff;
  font-size: var(--text-base);
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: .875rem var(--space-lg);
  text-align: left;
  font-weight: 600;
}

.dosierung-table td {
  padding: var(--space-md) var(--space-lg);
  font-size: var(--text-md);
  color: var(--text);
  background: var(--bg-white);
  border-bottom: 1px solid var(--border);
}

.dosierung-table tr:last-child td {
  border-bottom: none;
}

.eigenschaften-list {
  margin-top: var(--space-xl);
  gap: var(--space-lg);
  flex-direction: column;
  display: flex;
}

.eigenschaft-item {
  gap: var(--space-lg);
  padding: var(--space-lg);
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: all var(--transition);
  align-items: start;
  display: flex;
}

.eigenschaft-item:hover {
  box-shadow: var(--shadow-sm);
}

.eigenschaft-number {
  background: var(--bg);
  width: 44px;
  height: 44px;
  color: var(--text);
  font-size: var(--text-md);
  font-weight: 700;
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.eigenschaft-content h4 {
  font-size: var(--text-md);
  margin-bottom: .375rem;
  font-weight: 600;
}

.eigenschaft-content p {
  font-size: var(--text-md);
  color: var(--muted);
  line-height: 1.7;
}

.eigenschaft-content ul {
  margin-top: 6px;
  padding: 0;
  list-style: none;
}

.eigenschaft-content ul li {
  font-size: var(--text-base);
  color: var(--muted);
  padding-left: var(--space-md);
  line-height: 1.8;
  position: relative;
}

.eigenschaft-content ul li:before {
  content: "–";
  position: absolute;
  left: 0;
}

.indikationen-list {
  margin-top: var(--space-lg);
}

.indikationen-list ul {
  padding: 0;
  list-style: none;
}

.indikationen-list ul li {
  font-size: var(--text-base);
  color: var(--text-light);
  padding: var(--space-xs) 0 var(--space-xs) var(--space-lg);
  border-bottom: 1px solid var(--border);
  line-height: 1.8;
  position: relative;
}

.indikationen-list ul li:last-child {
  border-bottom: none;
}

.indikationen-list ul li:before {
  content: "";
  background: var(--text-light);
  border-radius: 50%;
  width: 10px;
  height: 10px;
  position: absolute;
  top: 16px;
  left: 0;
}

.pk-layout {
  margin-top: var(--space-xl);
  grid-template-columns: 1fr 1fr;
  align-items: start;
  gap: 48px;
  display: grid;
}

.pk-illustration {
  border-radius: var(--radius-lg);
  background: var(--bg);
  justify-content: center;
  align-items: center;
  min-height: 320px;
  display: flex;
  position: sticky;
  top: 120px;
  overflow: hidden;
}

.pk-illustration img {
  object-fit: contain;
  max-width: 100%;
  max-height: 100%;
}

.pk-steps-vertical {
  flex-direction: column;
  gap: 20px;
  display: flex;
}

.pk-step-v {
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  text-align: left;
  align-items: flex-start;
  gap: 20px;
  padding: 24px;
  display: flex;
}

.pk-step-number {
  background: var(--text-light);
  color: #fff;
  width: 48px;
  height: 48px;
  font-size: var(--text-lg);
  font-weight: 700;
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.pk-step-content {
  flex: 1;
}

.pk-step-content h4 {
  font-size: var(--text-lg);
  font-weight: 600;
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  margin-bottom: 8px;
}

.pk-step-content p {
  font-size: var(--text-md);
  color: var(--muted);
  margin: 0;
  line-height: 1.7;
}

.pk-arrow {
  color: var(--text-light);
  justify-content: center;
  margin: -6px 0;
  display: flex;
}

.dosierung-detail {
  padding: var(--space-xl);
  background: var(--bg-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  margin-top: var(--space-lg);
}

.dosierung-detail p {
  font-size: var(--text-md);
  color: var(--text-light);
  margin-bottom: var(--space-md);
  line-height: 1.8;
}

.dosierung-detail p:last-of-type {
  margin-bottom: var(--space-lg);
}

.campus-card {
  align-items: center;
  gap: var(--space-2xl);
  background: var(--bg-white);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  border: 1px solid var(--border);
  margin-top: var(--space-lg);
  display: flex;
}

.campus-icon {
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 88px;
  height: 88px;
  display: flex;
}

.campus-title {
  font-family: var(--font-source-serif), "Source Serif 4", serif;
  font-size: var(--text-2xl);
  margin-bottom: var(--space-sm);
  font-weight: 300;
}

.campus-desc {
  font-size: var(--text-md);
  color: var(--muted);
  margin-bottom: var(--space-lg);
  max-width: 36rem;
  line-height: 1.7;
}

.referenzen-list {
  margin-top: var(--space-lg);
  gap: var(--space-xs);
  flex-direction: column;
  display: flex;
}

.referenz-item {
  font-size: var(--text-sm);
  color: var(--muted);
  padding: var(--space-xs) 0;
  border-bottom: 1px solid var(--border);
  gap: var(--space-xs);
  line-height: 1.7;
  display: flex;
}

.referenz-item:last-child {
  border-bottom: none;
}

.referenz-num {
  flex-shrink: 0;
  min-width: 20px;
  font-weight: 700;
}

@media (max-width: 1024px) {
  .pk-layout {
    grid-template-columns: 1fr;
  }

  .pk-illustration {
    min-height: 200px;
    position: static;
  }

  .campus-card {
    text-align: center;
    flex-direction: column;
  }

  .campus-desc {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  .eigenschaft-item, .pk-step-v {
    gap: var(--space-sm);
    flex-direction: column;
  }
}

/*# sourceMappingURL=%5Broot-of-the-server%5D__e862ef07._.css.map*/