/* --- Import de la police Android (Roboto) --- */
/* cyrillic-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3GUBGEe.woff2) format('woff2');
	unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

/* cyrillic */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3iUBGEe.woff2) format('woff2');
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* greek-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3CUBGEe.woff2) format('woff2');
	unicode-range: U+1F00-1FFF;
}

/* greek */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3-UBGEe.woff2) format('woff2');
	unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}

/* math */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMawCUBGEe.woff2) format('woff2');
	unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}

/* symbols */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMaxKUBGEe.woff2) format('woff2');
	unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}

/* vietnamese */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3OUBGEe.woff2) format('woff2');
	unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3KUBGEe.woff2) format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 300;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3yUBA.woff2) format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* cyrillic-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3GUBGEe.woff2) format('woff2');
	unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

/* cyrillic */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3iUBGEe.woff2) format('woff2');
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* greek-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3CUBGEe.woff2) format('woff2');
	unicode-range: U+1F00-1FFF;
}

/* greek */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3-UBGEe.woff2) format('woff2');
	unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}

/* math */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMawCUBGEe.woff2) format('woff2');
	unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}

/* symbols */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMaxKUBGEe.woff2) format('woff2');
	unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}

/* vietnamese */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3OUBGEe.woff2) format('woff2');
	unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3KUBGEe.woff2) format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 400;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3yUBA.woff2) format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* cyrillic-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3GUBGEe.woff2) format('woff2');
	unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

/* cyrillic */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3iUBGEe.woff2) format('woff2');
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* greek-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3CUBGEe.woff2) format('woff2');
	unicode-range: U+1F00-1FFF;
}

/* greek */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3-UBGEe.woff2) format('woff2');
	unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}

/* math */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMawCUBGEe.woff2) format('woff2');
	unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}

/* symbols */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMaxKUBGEe.woff2) format('woff2');
	unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}

/* vietnamese */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3OUBGEe.woff2) format('woff2');
	unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3KUBGEe.woff2) format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 500;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3yUBA.woff2) format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* cyrillic-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3GUBGEe.woff2) format('woff2');
	unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

/* cyrillic */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3iUBGEe.woff2) format('woff2');
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

/* greek-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3CUBGEe.woff2) format('woff2');
	unicode-range: U+1F00-1FFF;
}

/* greek */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3-UBGEe.woff2) format('woff2');
	unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}

/* math */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMawCUBGEe.woff2) format('woff2');
	unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}

/* symbols */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMaxKUBGEe.woff2) format('woff2');
	unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}

/* vietnamese */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3OUBGEe.woff2) format('woff2');
	unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

/* latin-ext */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3KUBGEe.woff2) format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* latin */
@font-face {
	font-family: 'Roboto';
	font-style: normal;
	font-weight: 700;
	font-stretch: 100%;
	font-display: swap;
	src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3yUBA.woff2) format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
	font-family: 'Undertale';
	src: url('./assets/fonts/undertale-deltarune-text-font-extended.ttf');
	font-weight: normal;
	font-style: normal;
}

/* --- Utility classes --- */
.opacity-0 {
	opacity: 0;
}

.mt-1 {
	margin-top: 4px;
}

.mt-2 {
	margin-top: 8px;
}

.mt-3 {
	margin-top: 12px;
}

.mt-4 {
	margin-top: 16px;
}

.mb-1 {
	margin-bottom: 4px;
}

.mb-2 {
	margin-bottom: 8px;
}

.mb-3 {
	margin-bottom: 12px;
}

.mb-4 {
	margin-bottom: 16px;
}

.ml-1 {
	margin-left: 4px;
}

.ml-2 {
	margin-left: 8px;
}

.ml-3 {
	margin-left: 12px;
}

.ml-4 {
	margin-left: 16px;
}

.mr-1 {
	margin-right: 4px;
}

.mr-2 {
	margin-right: 8px;
}

.mr-3 {
	margin-right: 12px;
}

.mr-4 {
	margin-right: 16px;
}

.p-1 {
	padding: 4px;
}

.p-2 {
	padding: 8px;
}

.p-3 {
	padding: 12px;
}

.p-4 {
	padding: 16px;
}

.px-1 {
	padding-left: 4px;
	padding-right: 4px;
}

.px-2 {
	padding-left: 8px;
	padding-right: 8px;
}

.px-3 {
	padding-left: 12px;
	padding-right: 12px;
}

.px-4 {
	padding-left: 16px;
	padding-right: 16px;
}

.py-1 {
	padding-top: 4px;
	padding-bottom: 4px;
}

.py-2 {
	padding-top: 8px;
	padding-bottom: 8px;
}

.py-3 {
	padding-top: 12px;
	padding-bottom: 12px;
}

.py-4 {
	padding-top: 16px;
	padding-bottom: 16px;
}

.text-sm {
	font-size: 0.875rem;
}

.text-base {
	font-size: 1rem;
}

.text-lg {
	font-size: 1.125rem;
}

/* --- Styles Généraux --- */
* {
	box-sizing: border-box;
	-webkit-tap-highlight-color: transparent;
}

:root {
	--background-start: #1a237e;
	--background-mid: #3f51b5;
	--background-end: #00bcd4;
	--app-bg: #f5f5f5;
	--text-color: #212121;
	--header-color: #ffffff;
	--accent-color: #448aff;
	--game-accent: #4caf50;
	--icon-shadow: #00000033;
	--primary-color: #448aff;
	--primary-dark-color: #144599;
	--primary-background-color: #f5f5f5;
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Roboto', sans-serif;
	overflow: hidden;
	background-color: #444;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100vh;
}

input[type="range"] {
	margin: auto;
	-webkit-appearance: none;
	position: relative;
	overflow: hidden;
	height: 20px;
	width: 200px;
	cursor: pointer;
	border-radius: 0;
	/* iOS */
}

input[type="range"]::-webkit-slider-runnable-track {
	background: #ddd;
}

/*
 * 1. Set to 0 width and remove border for a slider without a thumb
 * 2. Shadow is negative the full width of the input and has a spread 
 *    of the width of the input.
 */
input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	width: 20px;
	/* 1 */
	height: 20px;
	background: #fff;
	box-shadow: -200px 0 0 200px var(--primary-color);
	/* 2 */
	border: 2px solid #999;
	/* 1 */
}

input[type="range"]::-moz-range-track {
	height: 20px;
	background: #ddd;
}

input[type="range"]::-moz-range-thumb {
	background: #fff;
	height: 20px;
	width: 20px;
	/* 1 */
	border: 3px solid #999;
	/* 1 */
	border-radius: 0 !important;
	box-shadow: -200px 0 0 200px var(--primary-color);
	box-sizing: border-box;
}

input[type="range"]::-ms-fill-lower {
	background: var(--primary-color);
}

input[type="range"]::-ms-thumb {
	background: #fff;
	border: 2px solid #999;
	/* 1 */
	height: 20px;
	width: 20px;
	/* 1 */
	box-sizing: border-box;
}

input[type="range"]::-ms-ticks-after {
	display: none;
}

input[type="range"]::-ms-ticks-before {
	display: none;
}

input[type="range"]::-ms-track {
	background: #ddd;
	color: transparent;
	height: 20px;
	border: none;
}

input[type="range"]::-ms-tooltip {
	display: none;
}

/* --- Conteneur principal (l'écran du téléphone) --- */
#android-screen {
	width: 100%;
	height: 100%;
	background: #fff;
	border-radius: 30px;
	box-shadow: 0 0 40px rgba(0, 0, 0, 0.5), inset 0 0 10px rgba(0, 0, 0, 0.3);
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	border: 5px solid #111;
}

#android-screen.phone-mode {
	max-width: 450px;
	max-height: 850px;
}

#android-screen.tablet-mode {
	width: 90vw;
	height: 95vh;
	max-width: none;
	max-height: none;
}

@media (min-width: 500px) {
	#android-screen {
		height: 95vh;
	}
}

/* --- Barre de statut Android --- */
#status-bar {
	background-color: #0007;
	color: white;
	padding: 5px 15px;
	text-align: right;
	font-size: 14px;
	z-index: 100;
	position: absolute;
	border: 0;
	top: 0;
	left: 0;
	right: 0;
	backdrop-filter: blur(4px);
}

#status-bar #time {
	font-weight: 500;
}

/* --- Conteneur Principal --- */
#main-container {
	flex-grow: 1;
	position: relative;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}


/* --- Bureau "Swipeable" --- */
#desktop-container {
	flex-grow: 1;
	position: relative;
	overflow: hidden;
}

#desktop-wrapper {
	display: flex;
	width: 200%;
	height: 100%;
	transition: transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.desktop-page {
	width: 50%;
	/* 1/2 de la largeur du wrapper */
	height: 100%;
	padding: 20px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
	/* Important */
	position: relative;
	/* Ancien fond d'écran supprimé d'ici */
}

/* --- NOUVEAU FOND D'ÉCRAN --- */
.desktop-background {
	--color-0: #fff;
	/* light off */
	--color-1: #111;
	--color-2: #222;
	--color-3: #333;
	--color-4: #2e2e2e;
	/* light on */
	--color-5: #d2b48c;
	--color-6: #b22222;
	--color-7: #871a1a;
	--color-8: #ff6347;
	--color-9: #ff3814;

	width: 100%;
	height: 100%;
	background-color: var(--color-1);
	background-image: linear-gradient(to top,
			var(--color-2) 5%,
			var(--color-1) 6%,
			var(--color-1) 7%,
			transparent 7%),
		linear-gradient(to bottom, var(--color-1) 30%, transparent 80%),
		linear-gradient(to right, var(--color-2), var(--color-4) 5%, transparent 5%),
		linear-gradient(to right,
			transparent 6%,
			var(--color-2) 6%,
			var(--color-4) 9%,
			transparent 9%),
		linear-gradient(to right,
			transparent 27%,
			var(--color-2) 27%,
			var(--color-4) 34%,
			transparent 34%),
		linear-gradient(to right,
			transparent 51%,
			var(--color-2) 51%,
			var(--color-4) 57%,
			transparent 57%),
		linear-gradient(to bottom, var(--color-1) 35%, transparent 35%),
		linear-gradient(to right,
			transparent 42%,
			var(--color-2) 42%,
			var(--color-4) 44%,
			transparent 44%),
		linear-gradient(to right,
			transparent 45%,
			var(--color-2) 45%,
			var(--color-4) 47%,
			transparent 47%),
		linear-gradient(to right,
			transparent 48%,
			var(--color-2) 48%,
			var(--color-4) 50%,
			transparent 50%),
		linear-gradient(to right,
			transparent 87%,
			var(--color-2) 87%,
			var(--color-4) 91%,
			transparent 91%),
		linear-gradient(to bottom, var(--color-1) 37.5%, transparent 37.5%),
		linear-gradient(to right,
			transparent 14%,
			var(--color-2) 14%,
			var(--color-4) 20%,
			transparent 20%),
		linear-gradient(to bottom, var(--color-1) 40%, transparent 40%),
		linear-gradient(to right,
			transparent 10%,
			var(--color-2) 10%,
			var(--color-4) 13%,
			transparent 13%),
		linear-gradient(to right,
			transparent 21%,
			var(--color-2) 21%,
			#1a1a1a 25%,
			transparent 25%),
		linear-gradient(to right,
			transparent 58%,
			var(--color-2) 58%,
			var(--color-4) 64%,
			transparent 64%),
		linear-gradient(to right,
			transparent 92%,
			var(--color-2) 92%,
			var(--color-4) 95%,
			transparent 95%),
		linear-gradient(to bottom, var(--color-1) 48%, transparent 48%),
		linear-gradient(to right,
			transparent 96%,
			var(--color-2) 96%,
			#1a1a1a 99%,
			transparent 99%),
		linear-gradient(to bottom,
			transparent 68.5%,
			transparent 76%,
			var(--color-1) 76%,
			var(--color-1) 77.5%,
			transparent 77.5%,
			transparent 86%,
			var(--color-1) 86%,
			var(--color-1) 87.5%,
			transparent 87.5%),
		linear-gradient(to right,
			transparent 35%,
			var(--color-2) 35%,
			var(--color-4) 41%,
			transparent 41%),
		linear-gradient(to bottom, var(--color-1) 68%, transparent 68%),
		linear-gradient(to right,
			transparent 78%,
			var(--color-3) 78%,
			var(--color-3) 80%,
			transparent 80%,
			transparent 82%,
			var(--color-3) 82%,
			var(--color-3) 83%,
			transparent 83%),
		linear-gradient(to right,
			transparent 66%,
			var(--color-2) 66%,
			var(--color-4) 85%,
			transparent 85%);
	background-size: 300px 150px;
	background-position: center bottom;
}

.desktop-background:before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	inset: 0;
	background-color: var(--color-1);
	background-image: linear-gradient(to top,
			var(--color-5) 5%,
			var(--color-1) 6%,
			var(--color-1) 7%,
			transparent 7%),
		linear-gradient(to bottom, var(--color-1) 30%, transparent 30%),
		linear-gradient(to right, var(--color-6), var(--color-7) 5%, transparent 5%),
		linear-gradient(to right,
			transparent 6%,
			var(--color-8) 6%,
			var(--color-9) 9%,
			transparent 9%),
		linear-gradient(to right,
			transparent 27%,
			#556b2f 27%,
			#39481f 34%,
			transparent 34%),
		linear-gradient(to right,
			transparent 51%,
			#fa8072 51%,
			#f85441 57%,
			transparent 57%),
		linear-gradient(to bottom, var(--color-1) 35%, transparent 35%),
		linear-gradient(to right,
			transparent 42%,
			#008080 42%,
			#004d4d 44%,
			transparent 44%),
		linear-gradient(to right,
			transparent 45%,
			#008080 45%,
			#004d4d 47%,
			transparent 47%),
		linear-gradient(to right,
			transparent 48%,
			#008080 48%,
			#004d4d 50%,
			transparent 50%),
		linear-gradient(to right,
			transparent 87%,
			#789 87%,
			#4f5d6a 91%,
			transparent 91%),
		linear-gradient(to bottom, var(--color-1) 37.5%, transparent 37.5%),
		linear-gradient(to right,
			transparent 14%,
			#bdb76b 14%,
			#989244 20%,
			transparent 20%),
		linear-gradient(to bottom, var(--color-1) 40%, transparent 40%),
		linear-gradient(to right,
			transparent 10%,
			#808000 10%,
			#4d4d00 13%,
			transparent 13%),
		linear-gradient(to right,
			transparent 21%,
			#8b4513 21%,
			#5e2f0d 25%,
			transparent 25%),
		linear-gradient(to right,
			transparent 58%,
			#8b4513 58%,
			#5e2f0d 64%,
			transparent 64%),
		linear-gradient(to right,
			transparent 92%,
			#2f4f4f 92%,
			#1c2f2f 95%,
			transparent 95%),
		linear-gradient(to bottom, var(--color-1) 48%, transparent 48%),
		linear-gradient(to right,
			transparent 96%,
			#2f4f4f 96%,
			#1c2f2f 99%,
			transparent 99%),
		linear-gradient(to bottom,
			transparent 68.5%,
			transparent 76%,
			var(--color-1) 76%,
			var(--color-1) 77.5%,
			transparent 77.5%,
			transparent 86%,
			var(--color-1) 86%,
			var(--color-1) 87.5%,
			transparent 87.5%),
		linear-gradient(to right,
			transparent 35%,
			#cd5c5c 35%,
			#bc3a3a 41%,
			transparent 41%),
		linear-gradient(to bottom, var(--color-1) 68%, transparent 68%),
		linear-gradient(to right,
			transparent 78%,
			#bc8f8f 78%,
			#bc8f8f 80%,
			transparent 80%,
			transparent 82%,
			#bc8f8f 82%,
			#bc8f8f 83%,
			transparent 83%),
		linear-gradient(to right,
			transparent 66%,
			#a52a2a 66%,
			#7c2020 85%,
			transparent 85%);
	background-size: 300px 150px;
	background-position: center bottom;
	clip-path: circle(150px at var(--mouse-x, 0px) var(--mouse-y, 0px));
}

#desktop-dots {
	position: absolute;
	bottom: 10px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	z-index: 5;
}

.dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.4);
	margin: 0 4px;
	transition: background 0.3s;
	cursor: pointer;
}

.dot:hover {
	background: rgba(255, 255, 255, 0.6);
}

.dot.active {
	background: rgba(255, 255, 255, 1);
}


.main-title {
	color: white;
	text-align: center;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
	z-index: 2;
	font-family: 'Undertale', 'Roboto', sans-serif;
}

.main-title h1 {
	font-size: 3em;
	margin: 0;
	font-weight: 300;
}

.main-title h2 {
	font-size: 2em;
	margin: 15px 0 0;
	font-weight: 400;
}

.app-drawer {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 15px;
	width: 100%;
	padding: 20px;
	margin-top: auto;
	box-sizing: border-box;
	z-index: 2;
	/* S'assurer que les icônes sont au-dessus du fond */
}

@media (max-width: 380px) {
	.app-drawer {
		grid-template-columns: repeat(3, 1fr);
	}
}

.app-icon {
	text-align: center;
	color: white;
	text-decoration: none;
	cursor: pointer;
	transition: transform 0.2s ease;
}

.app-icon:hover {
	transform: scale(1.1);
}

.app-icon .icon-bg {
	width: 60px;
	height: 60px;
	border-radius: 15px;
	background-color: rgba(255, 255, 255, 0.2);
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 auto 8px;
	box-shadow: 0 2px 5px var(--icon-shadow);
	backdrop-filter: blur(5px);
}

.app-icon .icon-bg svg {
	width: 32px;
	height: 32px;
	fill: white;
}

.app-icon span {
	font-family: 'Undertale', 'Roboto', sans-serif;
	font-size: 14px;
	font-weight: 500;
	text-shadow: 0 1px 3px var(--icon-shadow);
}

/* --- Conteneur de Fenêtres d'Application --- */
#app-window-container {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 200;
	pointer-events: none;
	/* Laisse passer les clics vers le bureau en dessous */
}

.app-window {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--app-bg);
	z-index: 1;
	/* Chaque fenêtre est sur son propre z-index */
	display: flex;
	flex-direction: column;
	pointer-events: all;
	/* La fenêtre ouverte capture les clics */

	/* Animation d'ouverture/fermeture */
	transform: scale(1.2);
	opacity: 0;
	visibility: hidden;
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease, visibility 0.3s;
}

.app-window.open {
	transform: scale(1);
	opacity: 1;
	visibility: visible;
}

.app-header {
	display: flex;
	align-items: center;
	padding: 10px 15px;
	background-color: var(--accent-color);
	color: var(--header-color);
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
	flex-shrink: 0;
	z-index: 10;
}

.app-header .back-btn {
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px;
	border-radius: 50%;
}

.app-header .back-btn:hover {
	background: #FFF4;
}

.app-header .back-btn svg {
	width: 24px;
	height: 24px;
	fill: var(--header-color);
}

.app-header h2 {
	margin: 0;
	font-family: 'Undertale', 'Roboto', sans-serif;
	font-size: 1.2em;
	font-weight: 500;
	margin-left: 15px;
}

.app-content {
	flex-grow: 1;
	overflow-y: auto;
	padding: 20px;
}

.app-content h1 {
	font-family: 'Undertale', 'Roboto', sans-serif;
	color: var(--accent-color);
	border-bottom: 2px solid #eee;
	padding-bottom: 5px;
	margin-top: 0;
	font-size: 1.2em;
}

.app-content select {
	cursor: pointer;
	padding: 4px 18px;
	border-radius: 50vh;
	color: var(--accent-color);
	font-family: 'Undertale', 'Roboto', sans-serif;
	border: 2px solid #ddd;
	background-color: #eee;
	outline: none;
}

.app-content select:hover {
	border-color: #448aff;
	background-color: #bcd5ff;
}

.app-content select:focus {
	border-color: #448aff;
}

/* --- Style collapsible --- */
.collapsible {
	cursor: pointer;
	padding: 4px 18px;
	margin: 8px;
	border-radius: 50vh;
	width: calc(100% - 16px);
	text-align: left;
	outline: none;
	font-size: 1.2em;
	font-family: 'Undertale', 'Roboto', sans-serif;
	color: var(--accent-color);
	border: 2px solid #ddd;
	background-color: #eee;
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
}

.collapsible:hover,
.collapsible.active {
	border-color: #448aff;
	background-color: #bcd5ff;
}

.collapsible:focus {
	border: 2px solid #448aff;
}

.collapsible:after {
	content: '+';
	font-size: 18px;
	font-weight: bold;
	margin-left: 5px;
}

.collapsible.active:after {
	content: '-';
}

/* --- Styles des Jeux --- */
.game-container {
	margin: 0;
	padding: 0;
	position: relative;
	width: 100%;
	height: 100%;
	color: white;
	background-color: var(--primary-background-color);
	display: flex;
	flex-direction: column;
	align-items: center;
	overflow: hidden;
	font-family: 'Undertale', 'Roboto', sans-serif;
	gap: 15px;
}

/* --- GAME MENUS --- */
.game-menu-screen {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
	background-color: #646464;
	opacity: 1;
	background-image: radial-gradient(circle at center center, var(--primary-color), #646464), repeating-radial-gradient(circle at center center, var(--primary-color), var(--primary-color), 16px, transparent 32px, transparent 16px);
	background-blend-mode: multiply;
}

.game-title {
	font-size: 3rem;
	color: var(--primary-color);
	text-transform: uppercase;
	letter-spacing: 4px;
	text-shadow: 0 0 10px #ccc;
}

.game-menu-buttons {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.game-btn {
	padding: 15px 40px;
	font-size: 1.2rem;
	background: var(--primary-dark-color);
	border: none;
	color: white;
	margin: 10px;
	cursor: pointer;
	border-radius: 5px;
	transition: all 0.2s;
	min-width: 200px;
	text-transform: uppercase;
	font-weight: bold;
	font-family: 'Undertale', 'Roboto', sans-serif;
}

.game-btn:hover {
	background: var(--primary-color);
	color: #111;
	transform: scale(1.05);
}

.game-version {
	margin-bottom: 20px;
	color: #666;
	font-size: 0.8em;
	font-style: italic;
}

/* --- LEVEL SELECT --- */
.game-level-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 15px;
	max-width: 600px;
	margin-bottom: 30px;
}

.game-level-btn {
	width: 70px;
	height: 70px;
	background: #333;
	border: 2px solid #555;
	color: #888;
	font-size: 1.2rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 8px;
	transition: all 0.2s;
}

.game-level-btn.unlocked {
	background: #444;
	color: white;
	border-color: var(--primary-color);
}

.game-level-btn.unlocked:hover {
	background: var(--primary-color);
	color: black;
}

.game-level-btn.locked {
	opacity: 0.5;
	cursor: not-allowed;
}

.game-level-btn.completed {
	background: #2e4a23;
	border-color: var(--primary-color);
}

/* --- GAME UI --- */
.game-content {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.game-header {
	flex: 0 0 auto;
	padding: 10px;
	background: var(--primary-dark-color);
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
	z-index: 5;
}

.game-main {
	flex: 1 1 auto;          /* prend TOUT l’espace restant */
	min-height: 0;           /* CRITIQUE pour éviter débordement */
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	overflow: hidden;
}

.game-footer {
	flex: 0 0 auto;
	padding: 10px;
	background: var(--primary-dark-color);
	box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
	z-index: 5;
}

.game-top-row {
	display: flex;
	width: 100%;
	justify-content: space-between;
	align-items: center;
	padding: 0 10px;
}

.game-score-board {
	display: flex;
	gap: 40px;
}

.game-score {
	font-weight: bold;
	font-size: 1.1rem;
	color: var(--primary-color);
	text-shadow: 1px 1px 2px black;
}

.game-score span {
	color: white;
}

.game-message {
	font-size: 0.95rem;
	color: #ddd;
	min-height: 1.2em;
	font-style: italic;
	margin-top: 5px;
}

.game-canvas-wrapper {
	flex-grow: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-height: 100%;
	overflow: hidden;
	position: relative;
	box-sizing: border-box;
}

.game-canvas {
	background: #111;
	border-radius: 8px;
	width: 90%;
	max-width: 90%;
	max-height: 100%;
	aspect-ratio: 1 / 1;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.game-message-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.85);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	z-index: 20;
	text-align: center;
	padding: 20px;
	backdrop-filter: blur(2px);
}

.game-message-overlay h2 {
	color: var(--primary-color);
	margin-bottom: 15px;
	font-size: 2rem;
	text-transform: uppercase;
	letter-spacing: 2px;
}

.game-message-overlay p {
	font-size: 1.1rem;
	margin-bottom: 25px;
	max-width: 400px;
	line-height: 1.5;
}

.overlay-buttons {
	display: flex;
	gap: 15px;
}

.game-message-overlay button {
	padding: 12px 30px;
	font-size: 1.1rem;
	cursor: pointer;
	background: var(--primary-color);
	border: none;
	border-radius: 50px;
	color: #1a1a1a;
	font-weight: bold;
	transition: transform 0.2s, box-shadow 0.2s;
}

.game-message-overlay button:hover {
	transform: scale(1.05);
	box-shadow: 0 0 15px var(--primary-color);
}

.btn-secondary {
	background: #555 !important;
	color: white !important;
}

.game-action-btn {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 0.5rem;
	min-width: 40px;
	min-height: 40px;
	padding: 5px 10px;
	background: #444;
	border: 1px solid #666;
	color: white;
	border-radius: 4px;
	cursor: pointer;
	font-size: 0.8rem;
	transition: opacity 0.2s;
	font-family: 'Undertale', 'Roboto', sans-serif;
}

.game-action-btn:hover {
	background: #666;
}

.game-action-btn svg {
	height: 16px;
	width: 16px;
	fill: #fff;
}

/* GAME CONTROLS */
.game-controls {
	display: grid;
	grid-template-areas:
		"up-left up up-right"
		"left center right"
		"down-left down down-right";
	gap: 8px;
	margin-bottom: 20px;
	z-index: 5;
	align-self: center;
}

.game-controls button {
	width: 55px;
	height: 55px;
	font-size: 24px;
	cursor: pointer;
	border: none;
	border-radius: 12px;
	background: #444;
	color: #eee;
	box-shadow: 0 4px 0 #222;
	transition: transform 0.1s, background 0.2s;
}

.game-controls button:active {
	transform: translateY(4px);
	box-shadow: 0 0 0 #222;
	background: var(--primary-color);
	color: #000;
}

/* mapping */
.game-controls .up-left {
	grid-area: up-left;
}

.game-controls .up {
	grid-area: up;
}

.game-controls .up-right {
	grid-area: up-right;
}

.game-controls .left {
	grid-area: left;
}

.game-controls .center {
	grid-area: center;
}

.game-controls .right {
	grid-area: right;
}

.game-controls .down-left {
	grid-area: down-left;
}

.game-controls .down {
	grid-area: down;
}

.game-controls .down-right {
	grid-area: down-right;
}