@charset "utf-8";


@font-face {
    font-family: Cormorant;
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4c0BXOCl9bbnla_nHIq6oGzilJm9otsA9kQq_da4iWq4Ys.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: Cormorant;
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4c0BXOCl9bbnla_nHIq6oGzilJm9otsA9kQq_da6yWq4Ys.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Cormorant;
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4c0BXOCl9bbnla_nHIq6oGzilJm9otsA9kQq_da4CWq4Ys.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: Cormorant;
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4c0BXOCl9bbnla_nHIq6oGzilJm9otsA9kQq_da4SWq4Ys.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: Cormorant;
    font-style: italic;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4c0BXOCl9bbnla_nHIq6oGzilJm9otsA9kQq_da7yWq.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Cormorant;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4pu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq65u9uqc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Cormorant;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Ju9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Zu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq75u9.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Cormorant;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4pu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq65u9uqc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Cormorant;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Ju9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Zu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq75u9.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Cormorant;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4pu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq65u9uqc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Cormorant;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Ju9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Zu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq75u9.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Cormorant;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4pu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq65u9uqc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Cormorant;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Ju9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Zu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq75u9.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Cormorant;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4pu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq65u9uqc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Cormorant;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Ju9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq4Zu9uqc.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: Cormorant;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/cormorant/v24/H4clBXOCl9bbnla_nHIq75u9.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Inter;
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.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: Inter;
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2") format("woff2");
    unicode-range: U+1F00-1FFF;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.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: Inter;
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.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: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2") format("woff2");
    unicode-range: U+1F00-1FFF;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.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: Inter;
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.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: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2") format("woff2");
    unicode-range: U+1F00-1FFF;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.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: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.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: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2") format("woff2");
    unicode-range: U+1F00-1FFF;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.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: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2") format("woff2");
    unicode-range: U+0-FF, 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: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7SUc.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: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7SUc.woff2") format("woff2");
    unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7SUc.woff2") format("woff2");
    unicode-range: U+1F00-1FFF;
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7SUc.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: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7SUc.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: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("https://fonts.gstatic.com/s/inter/v20/UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7.woff2") format("woff2");
    unicode-range: U+0-FF, 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;
}

:root {
    --bg-core: #050505;
    --bg-surface: #0a0a0a;
    --bg-glass: rgba(5, 5, 5, 0.7);
    --text-primary: #FFFFFF;
    --text-secondary: #888888;
    --text-muted: #444444;
    --accent-gold: #d00062;
    --line-color: rgba(255, 255, 255, 0.1);
    --space-xs: 0.5rem;
    --space-sm: 1.5rem;
    --space-md: 3rem;
    --space-lg: 6rem;
    --space-xl: 12rem;
    --space-hu: 20rem;
    --container-width: 92vw;
    --grid-gap: 0;
    --font-sans: 'Inter', sans-serif;
    --font-serif: 'Cormorant', serif;
    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1.125rem;
    --text-lg: 1.5rem;
    --text-xl: 2.5rem;
    --text-2xl: 4rem;
    --text-3xl: 6rem;
    --text-huge: 10rem;
    --text-giga: 15rem;
    --ease-premium: cubic-bezier(0.16, 1, 0.3, 1);
    --duration-base: 0.8s;
}

.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: all var(--duration-base) var(--ease-premium);
    will-change: opacity, transform;
}

.reveal.active {
    opacity: 1;
    transform: translateY(0px);
}

.delay-1 {
    transition-delay: 0.1s;
}

.delay-2 {
    transition-delay: 0.2s;
}

.delay-3 {
    transition-delay: 0.3s;

}

.delay-4 {
    transition-delay: 0.4s;

}

*,
::before,
::after {
    box-sizing: border-box;
    margin: 0px;
    padding: 0px;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
    background-color: var(--bg-core);
}

body {
    background-color: var(--bg-core);
    color: var(--text-primary);
    font-family: var(--font-sans);
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -webkit-user-select: none;
    /* Safari */
    -moz-user-select: none;
    /* Firefox */
    -ms-user-select: none;
    /* IE10+/Edge */
    user-select: none;
    /* Standard */
}

h1,
h2,
h3,
h4,
.font-serif {
    font-family: var(--font-serif);
    font-weight: 300;
    line-height: 1;
    letter-spacing: -0.03em;
}

.text-hero {
    font-size: clamp(4rem, 15vw, var(--text-huge));
    line-height: 0.9;
    letter-spacing: -0.04em;
    color: var(--text-primary);
    position: relative;
    z-index: 10;
    padding-top: 0vh;
}

.text-display {
    font-size: clamp(3rem, 8vw, var(--text-3xl));
    margin-bottom: var(--space-md);
}

.text-body {
    font-family: var(--font-sans);
    font-size: var(--text-base);
    color: var(--text-secondary);
    font-weight: 300;
    max-width: 45ch;
    line-height: 1.8;
}

.text-gold {
    color: var(--accent-gold);
}

.italic {
    font-style: italic;
}

.grid-container {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    column-gap: var(--grid-gap);
    width: var(--container-width);
    margin: 0px auto;
    position: relative;
    z-index: 2;
    padding-top: 100px;
}

.grid-lines {
    position: fixed;
    top: 0px;
    left: calc(4vw - var(--sb-w, 0px) / 2);
    /* Centering without transform to fix background-attachment */
    /* transform: translateX(-50%); removed to fix background fixed attachment context */
    width: var(--container-width);
    height: 100vh;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    column-gap: var(--grid-gap);
    pointer-events: none;
    z-index: 1;
    background-image: url(../assets/back.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    background-attachment: fixed;
}

.line-wrapper {
    position: relative;
    height: 100%;
    width: 100%;
    pointer-events: auto;
    cursor: crosshair;
}

.line {
    width: 1px;
    height: 100%;
    background: var(--line-color);
    display: block;
    position: absolute;
    left: 0px;
    z-index: 4;
    animation: linePulse 4s ease-in-out infinite;
}



.line-wrapper:nth-child(1) .line {
    animation-delay: 2.3s;
}

.line-wrapper:nth-child(2) .line {
    animation-delay: 2.1s;
}

.line-wrapper:nth-child(3) .line {
    animation-delay: 1.9s;
}

.line-wrapper:nth-child(4) .line {
    animation-delay: 1.7s;
}

.line-wrapper:nth-child(5) .line {
    animation-delay: 1.5s;
}

.line-wrapper:nth-child(6) .line {
    animation-delay: 1.3s;
}

.line-wrapper:nth-child(7) .line {
    animation-delay: 1.1s;
}

.line-wrapper:nth-child(8) .line {
    animation-delay: 0.9s;
}

.line-wrapper:nth-child(9) .line {
    animation-delay: 0.7s;
}

.line-wrapper:nth-child(10) .line {
    animation-delay: 0.5s;
}

.line-wrapper:nth-child(11) .line {
    animation-delay: 0.3s;
}

.line-wrapper:nth-child(12) .line {
    animation-delay: 0.1s;
}

.line-wrapper:nth-child(13) .line {
    animation-delay: 0s;
}

@keyframes linePulse {

    0%,
    100% {
        opacity: 0.3;
    }

    50% {
        opacity: 1;
    }
}

.mack {
    height: 0px;
}

.nav ul li a:after {
    content: '';
    position: absolute;
    width: 0;
    height: 1px;
    bottom: -4px;
    left: 0;
    background-color: var(--accent-gold);
    transition: width 0.3s;
}

nav ul li a:hover:after {
    width: 100%;
}

.nav-login-btn {
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 0.5rem 1rem;
    border-radius: 0;
    transition: all 0.3s ease;
    text-shadow: none !important;
}

.nav-login-btn:hover {
    background: white;
    border-color: white;
    color: black;
    text-shadow: none !important;
}

.nav-login-btn:after {
    display: none;
    /* No underline for button */
}



/* Cursor Converge Reveal */

/* Default state: Full black (no clip) */
/* Magnetic Reveal Effect */
/* Magnetic Reveal Effect */
.line-reveal {
    position: absolute;
    top: 0px;
    left: -1px;
    width: calc(100% + 1px);
    height: 100%;
    background-color: black;
    z-index: 3;
    pointer-events: none;
    animation: revealCycle 3s ease-in-out;

    /* 
       Variables inherited from .line-wrapper (set by JS):
       --mouse-y
       --gap
    */

    /* 
       Calculation:
       Hole Half Height = var(--gap, 0) * 30%
    */
    --hole-size: calc(var(--gap, 0) * 30%);

    -webkit-mask-image: linear-gradient(to bottom,
            black calc(var(--mouse-y, 50%) - var(--hole-size)),
            rgba(0, 0, 0, 0.15) calc(var(--mouse-y, 50%) - var(--hole-size)),
            rgba(0, 0, 0, 0.15) calc(var(--mouse-y, 50%) + var(--hole-size)),
            black calc(var(--mouse-y, 50%) + var(--hole-size)));
    mask-image: linear-gradient(to bottom,
            black calc(var(--mouse-y, 50%) - var(--hole-size)),
            rgba(0, 0, 0, 0.15) calc(var(--mouse-y, 50%) - var(--hole-size)),
            rgba(0, 0, 0, 0.15) calc(var(--mouse-y, 50%) + var(--hole-size)),
            black calc(var(--mouse-y, 50%) + var(--hole-size)));

    will-change: mask-image;
    /* optimization */
}

/* IMPROVED READABILITY: Text Shadows */
/* Adds a subtle shadow to separate text from complex backgrounds */
h1,
h2,
h3,
h4,
h5,
h6,
p,
a,
span,
label,
.text-body,
.text-display,
.text-hero,
.nav a {
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
}

/* Stronger shadow for small text */
.text-xs,
.text-sm,
.group-desc {
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.9);
}

/* Optional: Highlight the 1px guide line when active */
.line-wrapper .line {
    /* Existing animation: linePulse */
    /* We can override opacity based on gap */
    transition: opacity 0.3s, background-color 0.3s;
}

/* When gap is high, make line brighter/gold */
.line-wrapper[data-active="true"] .line {
    opacity: 0.8 !important;
    background-color: transparent;
    box-shadow: 0 0 10px transparent;
}

@keyframes revealCycle {
    0% {
        opacity: 1;
        /* Маска видна, линия скрыта */
    }

    20% {
        opacity: 0;
        /* Маска прозрачна, линия видна */
    }

    80% {
        opacity: 1;
        /* Маска возвращается */
    }

    100% {
        opacity: 1;
    }
}

/* Ensure no residual specific animations from previous steps affect this */
.line-wrapper:nth-child(odd) .line-reveal,
.line-wrapper:nth-child(even) .line-reveal {
    /* animation-name: revealCycle; */
}

/* Staggered delays for the reveal text/animation */
.line-wrapper:nth-child(1) .line-reveal {
    animation-delay: 0.1s;
}

.line-wrapper:nth-child(2) .line-reveal {
    animation-delay: 0.2s;
}

.line-wrapper:nth-child(3) .line-reveal {
    animation-delay: 0.3s;
}

.line-wrapper:nth-child(4) .line-reveal {
    animation-delay: 0.4s;
}

.line-wrapper:nth-child(5) .line-reveal {
    animation-delay: 0.5s;
}

.line-wrapper:nth-child(6) .line-reveal {
    animation-delay: 0.6s;
}

.line-wrapper:nth-child(7) .line-reveal {
    animation-delay: 0.7s;
}

.line-wrapper:nth-child(8) .line-reveal {
    animation-delay: 0.8s;
}

.line-wrapper:nth-child(9) .line-reveal {
    animation-delay: 0.9s;
}

.line-wrapper:nth-child(10) .line-reveal {
    animation-delay: 1.0s;
}

.line-wrapper:nth-child(11) .line-reveal {
    animation-delay: 1.1s;
}

.line-wrapper:nth-child(12) .line-reveal {
    animation-delay: 1.2s;
}



.col-span-12 {
    grid-column-end: span 12;
}

.col-span-9 {
    grid-column-end: span 9;
}

.col-span-6 {
    grid-column-end: span 6;
}

.col-span-4 {
    grid-column-end: span 4;
}

.col-span-3 {
    grid-column-end: span 3;
}

.col-span-2 {
    grid-column-end: span 2;
}

.col-span-1 {
    grid-column-end: span 1;
}

.col-start-1 {
    grid-column-start: 1;
}

.col-start-2 {
    grid-column-start: 2;
}

.col-start-3 {
    grid-column-start: 3;
}

.col-start-4 {
    grid-column-start: 4;
}

.col-start-5 {
    grid-column-start: 5;
}

.col-start-6 {
    grid-column-start: 6;
}

.col-start-7 {
    grid-column-start: 7;
}

.col-start-8 {
    grid-column-start: 8;
}

.col-start-9 {
    grid-column-start: 9;
}

.col-start-10 {
    grid-column-start: 10;
}

.col-start-11 {
    grid-column-start: 11;
}

.col-start-12 {
    grid-column-start: 12;
}

@media (max-width: 768px) {
    .grid-container {
        display: flex;
        flex-direction: column;
        gap: var(--space-md);
    }

    .grid-lines {
        display: none;
    }

    .text-body {
        max-width: 100%;
    }
}

header {
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    padding: var(--space-sm) calc(4vw - var(--sb-w, 0px) / 2);
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 100;
    backdrop-filter: blur(10px);
    background: linear-gradient(rgba(5, 5, 5, 0.8), rgba(5, 5, 5, 0));
}

.logo {
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: var(--text-base);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--text-primary);
}

nav ul {
    display: flex;
    gap: var(--space-md);
    list-style: none;
}

nav a {
    color: var(--text-secondary);
    text-decoration: none;
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: color var(--duration-base) var(--ease-premium);
}

nav a:hover {
    color: var(--text-primary);
}

.btn-minimal {
    display: inline-block;
    width: fit-content;
    padding-bottom: 5px;
    border-bottom: 1px solid var(--text-muted);
    color: var(--text-primary);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: var(--text-sm);
    transition: all var(--duration-base) var(--ease-premium);
    margin-top: var(--space-md);
    cursor: pointer;
}

.btn-minimal:hover {
    border-color: var(--accent-gold);
    color: var(--accent-gold);
    padding-left: 10px;
}

.section-pad {
    padding: var(--space-xl) 0;
}

.hero-wrapper {
    height: 100vh;
    width: 100%;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
}

.hero-video-bg {
    display: none;
}

.hero-bg-strips {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    display: flex;
    flex-direction: column;
}

.hero-bg-strip {
    flex: 1;
    width: 100%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    background-image: url('../assets/hero_bg.png');
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    position: relative;
    /* Required for z-index */
    transition: all 0.4s ease;
    filter: brightness(0.4) grayscale(0.8);
}

.hero-bg-strip:hover {
    filter: brightness(1.1) grayscale(0);
    z-index: 10;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
    /* Add glow to emphasize active strip */
}

.map-container {
    position: relative;
    width: 100%;
    margin-top: var(--space-md);
}

.map-bg {
    width: 100%;
    height: auto;
    opacity: 0.8;
    display: block;
}

.map-point {
    position: absolute;
    width: 8px;
    height: 8px;
    background-color: rgb(0, 0, 0);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    cursor: pointer;
    transition: transform 0.3s;
    z-index: 10;
}

.map-point.highlight {
    background-color: rgb(208, 0, 98);
    box-shadow: rgba(208, 0, 98, 0.2) 0px 0px 0px 3px;
    z-index: 11;
}

.map-point::after {
    content: attr(data-title);
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    white-space: nowrap;
    font-size: 11px;
    font-weight: 600;
    color: rgb(68, 68, 68);
    pointer-events: none;
    font-family: var(--font-sans);
    letter-spacing: 0.02em;
}

.map-point:hover {
    transform: translate(-50%, -50%) scale(1.5);
    z-index: 20;
}

.stat-item {
    margin-top: var(--space-md);
}

.stat-val {
    font-family: var(--font-serif);
    font-size: var(--text-2xl);
    line-height: 1;
    display: block;
    margin-bottom: var(--space-xs);
}

.stat-lbl {
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-secondary);
}

.lang-switch {
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    cursor: pointer;
    opacity: 0.5;
    transition: opacity 0.3s;
}

.lang-switch:hover {
    opacity: 1;
}

.hidden {
    display: none !important;
}

.spacer-lg {
    height: var(--space-lg);
}

.group-list {
    display: flex;
    flex-direction: column;
    gap: 0px;
}

.group-item {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    align-items: center;
    position: relative;
    border-top: 1px solid var(--line-color);
    padding: var(--space-md) 0;
    transition: all 0.5s var(--ease-premium);
    overflow: hidden;
    background-image: url("../assets/section_bg.png");
    background-size: cover;
    background-position: center center;
    background-blend-mode: overlay;
    background-color: rgba(5, 5, 5, 0.9);
}

.group-item:last-child {
    border-bottom: 1px solid var(--line-color);
}

.group-item:hover {
    background-color: rgba(5, 5, 5, 0.7);
    padding-left: var(--space-sm);
}

.group-icon {
    grid-column: span 1;
    width: 32px;
    height: 32px;
    border: 1px solid var(--text-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    transition: 0.3s;
    cursor: pointer;
}

.group-item:hover .group-icon {
    border-color: var(--text-primary);
    color: var(--text-primary);
    transform: rotate(90deg);
}

.group-title {
    grid-column: span 3;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: var(--text-xl);
    padding-left: var(--space-sm);
    color: var(--text-primary);
}

.group-details {
    grid-column: span 8;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.group-subtitle {
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 5px;
    color: var(--text-primary);
}

.group-desc {
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

@media (max-width: 768px) {
    .group-item {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-sm);
    }

    .group-icon {
        margin-right: var(--space-sm);
    }

    .group-title {
        width: auto;
        font-size: var(--text-lg);
        flex-grow: 1;
    }

    .group-details {
        width: 100%;
        padding-left: 48px;
    }
}

.group-thesis {
    grid-column: 5 / -1;
    max-height: 0px;
    overflow: hidden;
    opacity: 0;
    color: var(--text-secondary);
    font-family: var(--font-serif);
    font-size: var(--text-base);
    font-style: italic;
    transition: all 0.5s var(--ease-premium);
    margin-top: 0px;
}

.group-item.active .group-thesis {
    padding-top: var(--space-sm);
    max-height: 800px;
    opacity: 1;
}

.group-item.active .group-icon {
    border-color: var(--accent-gold);
    color: var(--accent-gold);
    transform: rotate(45deg);
}

@media (max-width: 768px) {
    .group-thesis {
        padding-left: 0px;
        margin-top: 0px;
    }
}

.d3-country {
    fill: rgb(68, 68, 68);
    opacity: 0.4;
    stroke: rgb(51, 51, 51);
    stroke-width: 0.5;
    transition: fill 0.3s;
}

.d3-country:hover {
    fill: rgb(42, 42, 42);
}

.d3-city-marker {
    fill: rgb(255, 255, 255);
    filter: drop-shadow(rgba(255, 255, 255, 0.6) 0px 0px 5px);
    stroke: none;
    transform-box: fill-box;
    transform-origin: center center;
    transition: transform 1.5s, fill 1.5s;
    cursor: pointer;
}

.d3-city-marker.active-pulse {
    transform: scale(1.5);
}

.d3-city-marker:hover {
    transform: scale(1.5);
    transition: transform 0.2s, fill 0.2s;
}

.d3-city-label {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 500;
    pointer-events: none;
    fill: var(--text-secondary);
    letter-spacing: 0.05em;
}

.d3-coord-label {
    font-family: var(--font-sans);
    font-size: 10px;
    fill: rgb(255, 255, 255);
    pointer-events: none;
    opacity: 0;
    text-shadow: rgba(0, 0, 0, 0.8) 0px 0px 4px;
}

.d3-city-marker.highlight {
    fill: rgb(208, 0, 98);
    filter: drop-shadow(rgba(208, 0, 98, 0.8) 0px 0px 5px);
    stroke: none;
}

.news-item {
    padding: var(--space-sm) 0;
    border-top: 1px solid var(--line-color);
    transition: transform 0.3s;
}

.news-item:hover {
    transform: translateY(-5px);
}

.news-date {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--text-secondary);
    margin-bottom: var(--space-xs);
    letter-spacing: 0.05em;
}

.news-title {
    font-family: var(--font-serif);
    font-size: 1.75rem;
    line-height: 1.1;
    margin-bottom: var(--space-sm);
    color: var(--text-primary);
}

.news-link {
    display: inline-block;
    margin-top: var(--space-sm);
    font-family: var(--font-sans);
    font-size: var(--text-xs);
    color: var(--accent-gold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    text-decoration: none;
    transition: opacity 0.3s;
}

.news-link:hover {
    opacity: 0.8;
}

.arrow {
    display: inline-block;
    transition: transform 0.3s;
}

.news-link:hover .arrow {
    transform: translateX(5px);
}

/* Career Accordion Styles */
.career-item {
    grid-column: 1 / -1;
    /* Ensure full width in grid container */
    border-top: 1px solid var(--line-color);
    padding: var(--space-md) 0;
    transition: all 0.3s ease;
}

.career-item:last-child {
    border-bottom: 1px solid var(--line-color);
}

.career-header {
    display: flex;
    align-items: center;
    cursor: pointer;
    gap: var(--space-sm);
}

.career-icon {
    width: 32px;
    height: 32px;
    border: 1px solid var(--text-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    transition: 0.3s;
    flex-shrink: 0;
}

.career-item.active .career-icon,
.career-header:hover .career-icon {
    border-color: var(--accent-gold);
    color: var(--accent-gold);
}

.career-item.active .career-icon {
    transform: rotate(45deg);
}

.career-info {
    flex-grow: 1;
}

.career-dept {
    font-family: var(--font-serif);
    font-size: var(--text-base);
    font-style: italic;
    color: var(--text-secondary);
    /* or gold? Image uses white-ish on black, let's stick to secondary or primary. */
    margin-bottom: 0.2rem;
}

.career-title {
    font-family: var(--font-serif);
    font-size: var(--text-lg);
    color: var(--text-primary);
    margin-bottom: 0.2rem;
    font-weight: 300;
}

.career-loc {
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.career-body {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: all 0.5s var(--ease-premium);
    padding-left: calc(32px + var(--space-sm));
    padding-right: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}

.career-item.active .career-body {
    max-height: 1500px;
    opacity: 1;
    margin-top: var(--space-md);
    padding-bottom: var(--space-md);
}



.career-desc {
    margin-bottom: var(--space-sm);
    max-width: 800px;
    color: var(--text-secondary);
    line-height: 1.7;
    font-size: 1rem;
}

.career-reqs {
    background: #000;
    max-width: 800px;
    padding: var(--space-md);
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

/* Magnetic Circle Button Styles */
.btn-arrow-circle {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: var(--text-sm);
    color: var(--text-primary);
    text-decoration: none;
    transition: color 0.3s ease;
    cursor: pointer;
    margin-top: 2rem;
    font-weight: 500;
}

.btn-arrow-icon {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    color: var(--text-primary);
    flex-shrink: 0;
}

.btn-arrow-circle:hover {
    color: var(--accent-gold);
}

.btn-arrow-circle:hover .btn-arrow-icon {
    background: var(--accent-gold);
    border-color: var(--accent-gold);
    color: #000;
    /* Contrast on gold */
    transform: rotate(-45deg);
    /* Dynamic angle like "sending" */
}

.career-reqs ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.career-reqs li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.8rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
    line-height: 1.5;
}

.career-reqs li:last-child {
    margin-bottom: 0;
}

.career-reqs li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--accent-gold);
}

.news-link:hover {
    opacity: 0.7;
}

.news-link .arrow {
    display: inline-block;
    transition: transform 0.3s;
}

.news-link:hover .arrow {
    transform: translateX(4px);
}

.strat-card {
    padding: var(--space-sm);
    background: #000;
    border-top: 1px solid var(--line-color);
    border-bottom: 1px solid var(--line-color);
    border-left: none;
    border-right: none;
    position: relative;
    overflow: hidden;
    transition: 0.4s;
    min-height: 300px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    margin: 0;
}

.strat-card:hover {
    background: rgba(255, 255, 255, 0.05);
    transform: translateY(-5px);
    border-color: rgba(212, 175, 55, 0.3);
}

.strat-num {
    position: absolute;
    top: -10px;
    right: -5px;
    font-family: var(--font-serif);
    font-size: 6rem;
    color: rgba(255, 255, 255, 0.03);
    line-height: 1;
    pointer-events: none;
    transition: 0.4s;
}

.strat-card:hover .strat-num {
    color: rgba(212, 175, 55, 0.1);
    transform: scale(1.1);
}

.strat-title {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    margin-bottom: var(--space-sm);
    color: var(--text-primary);
    position: relative;
    z-index: 1;
}

.strat-loc {
    margin-top: auto;
    padding-top: var(--space-sm);
    font-family: 'Courier New', Courier, monospace;
    font-size: var(--text-xs);
    color: var(--accent-gold);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-weight: 600;
}

/* Team Section */
.team-card {
    padding: var(--space-sm);
    border: 1px solid transparent;
    background: black;
    transition: 0.3s;
    display: flex;
    flex-direction: column;
}

.team-card:hover {
    background: black;
    border-color: var(--accent-gold);
    transform: translateY(-5px);
}

.team-photo {
    width: 100%;
    aspect-ratio: 1/1;
    background: #1a1a1a;
    margin-bottom: var(--space-sm);
    /* Placeholder pattern */
    background-image: linear-gradient(45deg, #1f1f1f 25%, transparent 25%, transparent 75%, #1f1f1f 75%, #1f1f1f),
        linear-gradient(45deg, #1f1f1f 25%, transparent 25%, transparent 75%, #1f1f1f 75%, #1f1f1f);
    background-size: 20px 20px;
    background-position: 0 0, 10px 10px;
    opacity: 0.5;
}

.team-name {
    font-family: var(--font-serif);
    font-size: var(--text-lg);
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

.team-role {
    color: var(--accent-gold);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 1rem;
    font-weight: 600;
}

.team-desc {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: 1.5;
}

/* Portfolio Section */
/* Portfolio Section */
.portfolio-item {
    position: relative;
    height: 300px;
    width: 650px;
    flex-shrink: 0;
    border-right: 1px solid var(--line-color);
    overflow: hidden;
    cursor: pointer;
    background: rgba(255, 255, 255, 0.02);
    padding-left: 250px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.port-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 250px;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 0.6s ease;
    filter: none;
    border-right: 1px solid var(--line-color);
}

.port-bg.sketch {
    z-index: 2;
    filter: contrast(1.1);
    /* Sketch should be crisp */
    transition: opacity 0.5s ease, transform 0.6s ease;
}

.portfolio-item:hover .port-bg.sketch {
    opacity: 0;
}

.portfolio-item:hover .port-bg {
    transform: scale(1.05);
}

.port-overlay {
    position: relative;
    width: 100%;
    height: 100%;
    margin-top: 0;
    padding: var(--space-sm);
    background: transparent;
    display: flex;
    flex-direction: column;
    justify-content: center;
    pointer-events: none;
    transform: none;
    opacity: 1;
}

.portfolio-item:hover .port-overlay {
    background: transparent;
    transform: none;
}

.port-title {
    font-family: var(--font-serif);
    font-size: 1.75rem;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.port-subtitle {
    font-size: 0.75rem;
    color: var(--accent-gold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 1rem;
    font-weight: 600;
}

.port-desc {
    font-family: var(--font-sans);
    font-size: 0.95rem;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 1.5rem;
    display: block;
    max-width: 40ch;
}


.port-metrics {
    display: flex;
    gap: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1rem;
    opacity: 0.6;
    transform: none;
    transition: 0.3s;
}

.portfolio-item:hover .port-metrics {
    opacity: 1;
    transform: none;
}

.port-metric {
    display: flex;
    flex-direction: column;
}

.port-metric span {
    font-size: 1.1rem;
    color: white;
    font-family: var(--font-serif);
}

.port-metric label {
    font-size: 0.65rem;
    color: #666;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}

/* Partners Section */
.partners-strip {
    display: flex;
    gap: var(--space-md);
    opacity: 0.5;
    font-family: var(--font-serif);
    font-size: var(--text-lg);
    flex-wrap: wrap;
    margin-top: var(--space-sm);
    color: var(--text-muted);
}

/* ... existing styles ... */



/* Partners Section */
.partners-strip {
    display: flex;
    gap: var(--space-md);
    opacity: 0.5;
    font-family: var(--font-serif);
    font-size: var(--text-lg);
    flex-wrap: wrap;
    margin-top: var(--space-sm);
    color: var(--text-muted);
}

.partner-logo {
    letter-spacing: -0.02em;
}

.partner-logo-img {
    height: 1.5em;
    width: auto;
    vertical-align: middle;
    filter: grayscale(1) brightness(0.9);
    transition: 0.3s;
    cursor: pointer;
}

.partner-logo-img:hover {
    filter: grayscale(0) brightness(1);
    opacity: 1;
}

/* Footer Links */
.footer-link {
    font-size: var(--text-xs);
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    display: inline-block;
    margin-bottom: 0.5rem;
    transition: color 0.3s;
}

.footer-link:hover {
    color: var(--accent-gold);
}

.footer-logo {
    width: 30px;
    height: auto;
    margin-bottom: var(--space-md);
    filter: invert(1);
    opacity: 0.3;
    cursor: pointer;
}

.footer-logo:hover {
    opacity: 1;
}

/* D3 Map Styles */
#d3-map-view {
    position: relative;
    z-index: 10;
    left: -110px;
}

.d3-country {
    fill: #303030;
    opacity: 0.8;
    stroke: rgba(255, 255, 255, 0.05);
    stroke-width: 0.5px;
    transition: fill 0.3s;
}

.d3-country:hover {
    fill: rgba(255, 255, 255, 0.15);
}

.d3-city-marker {
    fill: var(--accent-gold);
    stroke: none;
    cursor: pointer;
    transition: r 0.3s ease;
}

.d3-city-marker.highlight {
    fill: #fff;
}

.d3-city-label {
    fill: white;
    font-family: var(--font-sans);
    font-size: 10px;
    letter-spacing: 0.05em;
    pointer-events: none;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
}

.d3-coord-label {
    fill: var(--text-secondary);
    font-family: var(--font-mono);
    font-size: 9px;
    pointer-events: none;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
}

/* Portfolio Carousel */
.portfolio-marquee {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding: var(--space-md) 0;
    /* Mask for fade effect on edges */
    mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
    -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}

.portfolio-track {
    display: flex;
    gap: var(--space-md);
    width: max-content;
    will-change: transform;
    /* Animation handled by JS */
}

.portfolio-item {
    flex: 0 0 650px;
    height: 300px;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    z-index: 5;
    background: black;
    padding-left: 300px;
    /* Space for image */
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.port-bg {
    position: absolute;
    background-repeat: no-repeat;
    background-position: top;
    top: 0;
    left: 0;
    width: 300px;
    background-size: contain;
    transition: transform 0.6s ease;
    filter: none;
    border-right: 1px solid var(--line-color);
}

.port-bg.sketch {
    z-index: 2;
    filter: contrast(1.1);
    transition: opacity 0.5s ease, transform 0.6s ease;
}

.portfolio-item:hover .port-bg.sketch {
    opacity: 0;
}

.portfolio-item:hover .port-bg {
    transform: scale(1.05);
}

.port-overlay {
    position: relative;
    width: 100%;
    height: 100%;
    margin-top: 0;
    padding: var(--space-sm);
    background: transparent;
    display: flex;
    flex-direction: column;
    justify-content: center;
    pointer-events: none;
    transform: none;
    opacity: 1;
}

.portfolio-item:hover .port-overlay {
    background: transparent;
    transform: none;
}

.port-title {
    font-family: var(--font-serif);
    font-size: 1.75rem;
    color: var(--text-primary);
    margin-bottom: 0.25rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.port-subtitle {
    font-size: 0.75rem;
    color: var(--accent-gold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 1rem;
    font-weight: 600;
}

.port-desc {
    font-family: var(--font-sans);
    font-size: 0.95rem;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 1.5rem;
    display: block;
    max-width: 40ch;
}

.port-metrics {
    display: flex;
    gap: 2rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1rem;
    opacity: 0.6;
    transform: none;
    transition: 0.3s;
}

.portfolio-item:hover .port-metrics {
    opacity: 1;
    transform: none;
}

.port-metric {
    display: flex;
    flex-direction: column;
}

.port-metric span {
    font-size: 1.1rem;
    color: white;
    font-family: var(--font-serif);
}

.port-metric label {
    font-size: 0.65rem;
    color: #666;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}

/* Static Window Interaction */
.static-window-trigger {
    cursor: crosshair;
    position: relative;
    z-index: 10;
}

/* Tiered Access / Locked Content */
.locked-content {
    filter: blur(8px);
    pointer-events: none;
    user-select: none;
    opacity: 0.5;
    transition: all 0.3s ease;
}

.lock-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 100;
    text-align: center;
    background: rgba(10, 10, 10, 0.9);
    padding: 2rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(10px);
}

.lock-icon {
    font-size: 2rem;
    margin-bottom: 1rem;
    color: var(--accent-gold);
}

.lock-title {
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
    color: var(--text-primary);
}

.lock-desc {
    font-size: 0.9rem;
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}