/* arabic */
@font-face {
	font-family: "Amiri Quran";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/01-_Xmo-Hk0rD6DbUL4_vH8Zp5v5i2-sf-3O38.woff2") format("woff2");
	unicode-range:
		U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E, U+2010-2011, U+204F, U+2E41,
		U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F,
		U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B,
		U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A,
		U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB,
		U+1EEF0-1EEF1;
}
/* latin */
@font-face {
	font-family: "Amiri Quran";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/02-_Xmo-Hk0rD6DbUL4_vH8Zp5q5i2-sf-3.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/03-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtFmSqn7B6DxjY.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/04-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtMmSqn7B6DxjY.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
	font-family: "Cormorant Garamond";
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/05-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtHmSqn7B6DxjY.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/06-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtGmSqn7B6DxjY.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/07-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtImSqn7B6D.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/03-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtFmSqn7B6DxjY.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/04-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtMmSqn7B6DxjY.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
	font-family: "Cormorant Garamond";
	font-style: italic;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/05-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtHmSqn7B6DxjY.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/06-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtGmSqn7B6DxjY.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: "Cormorant Garamond";
	font-style: italic;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/07-co3ZmX5slCNuHLi8bLeY9MK7whWMhyjYrEtImSqn7B6D.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/08-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYpHtKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/09-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYrXtKky2F7i6C.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
	font-family: "Cormorant Garamond";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/10-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYpntKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/11-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYp3tKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/12-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYqXtKky2F7g.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/08-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYpHtKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/09-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYrXtKky2F7i6C.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
	font-family: "Cormorant Garamond";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/10-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYpntKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/11-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYp3tKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/12-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYqXtKky2F7g.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/08-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYpHtKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/09-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYrXtKky2F7i6C.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
	font-family: "Cormorant Garamond";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/10-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYpntKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/11-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYp3tKky2F7i6C.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: "Cormorant Garamond";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/12-co3bmX5slCNuHLi8bLeY9MK7whWMhyjYqXtKky2F7g.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: "Inter";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/13-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/14-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/15-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/16-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/17-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/18-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("fonts/19-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7W0Q5nw.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: "Inter";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/13-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/14-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/15-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/16-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/17-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/18-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("fonts/19-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7W0Q5nw.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: "Inter";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/13-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2JL7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/14-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa0ZL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/15-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2ZL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/16-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1pL7W0Q5n-wU.woff2") format("woff2");
	unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
	font-family: "Inter";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/17-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa2pL7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/18-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa25L7W0Q5n-wU.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: "Inter";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("fonts/19-UcC73FwrK3iLTeHuS_nVMrMxCp50SjIa1ZL7W0Q5nw.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;
}

/* ============================================
   ISCJ WES — Tokens, base, utilities
   ============================================ */

:root {
	/* Light theme — warm ivory, deep emerald, muted gold */
	--bg: #f8f5ec;
	--bg-elev: #fffdf7;
	--bg-tint: #f1ecdd;
	--bg-deep: #ece3cd;
	--surface: #fffdf7;
	--primary: #0b4f3a;
	--primary-soft: rgba(11, 79, 58, 0.08);
	--primary-line: rgba(11, 79, 58, 0.18);
	--secondary: #102a43;
	--accent: #c9a646;
	--accent-soft: rgba(201, 166, 70, 0.16);
	--accent-line: rgba(201, 166, 70, 0.42);
	--sand: #e8dcc5;
	--sage: #a9bfa8;
	--text: #1f2933;
	--text-muted: #52606d;
	--text-dim: #7b8794;
	--border: #ddd3bd;
	--border-soft: rgba(221, 211, 189, 0.6);
	--grid-line: rgba(11, 79, 58, 0.045);
	--grid-glow: rgba(201, 166, 70, 0.06);
	--on-primary: #f8f5ec;

	/* radii */
	--r-sm: 10px;
	--r-md: 16px;
	--r-lg: 24px;
	--r-xl: 32px;

	/* fonts */
	--f-display: "Cormorant Garamond", "EB Garamond", Georgia, serif;
	--f-body: "Inter", system-ui, -apple-system, sans-serif;
	--f-arabic: "Amiri Quran", "Amiri", "Cormorant Garamond", serif;
	--f-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

	/* shadows */
	--sh-sm: 0 1px 2px rgba(31, 41, 51, 0.04), 0 2px 6px rgba(31, 41, 51, 0.04);
	--sh-md: 0 4px 12px rgba(31, 41, 51, 0.06), 0 12px 32px rgba(31, 41, 51, 0.06);
	--sh-lg: 0 24px 60px rgba(16, 42, 67, 0.12), 0 8px 20px rgba(16, 42, 67, 0.06);

	/* layout */
	--container: 1180px;
}

[data-theme="dark"] {
	--bg: #0e1b26;
	--bg-elev: #122230;
	--bg-tint: #16273a;
	--bg-deep: #0a1620;
	--surface: #14253a;
	--primary: #7fcba4;
	--primary-soft: rgba(127, 203, 164, 0.16);
	--primary-line: rgba(127, 203, 164, 0.34);
	--secondary: #e6dcc2;
	--accent: #d4b560;
	--accent-soft: rgba(212, 181, 96, 0.14);
	--accent-line: rgba(212, 181, 96, 0.45);
	--sand: #2a3344;
	--sage: #5c7a6e;
	--text: #ece3cd;
	--text-muted: #b5ae9b;
	--text-dim: #8a8674;
	--border: rgba(212, 181, 96, 0.18);
	--border-soft: rgba(212, 181, 96, 0.1);
	--grid-line: rgba(212, 181, 96, 0.05);
	--grid-glow: rgba(212, 181, 96, 0.04);
	--on-primary: #0e1b26;
	--sh-sm: 0 1px 2px rgba(0, 0, 0, 0.3), 0 2px 6px rgba(0, 0, 0, 0.2);
	--sh-md: 0 4px 12px rgba(0, 0, 0, 0.3), 0 12px 32px rgba(0, 0, 0, 0.3);
	--sh-lg: 0 24px 60px rgba(0, 0, 0, 0.45), 0 8px 20px rgba(0, 0, 0, 0.25);
}

* {
	box-sizing: border-box;
}
html,
body {
	margin: 0;
	padding: 0;
	overflow-x: hidden;
}
html {
	scroll-behavior: smooth;
}
body {
	background: var(--bg);
	background-image:
		linear-gradient(to right, var(--grid-line) 1px, transparent 1px),
		linear-gradient(to bottom, var(--grid-line) 1px, transparent 1px),
		radial-gradient(ellipse 80% 60% at 50% 0%, var(--grid-glow), transparent 70%);
	background-size:
		64px 64px,
		64px 64px,
		100% 100%;
	background-position:
		0 0,
		0 0,
		0 0;
	background-attachment: scroll, scroll, scroll;
	color: var(--text);
	font-family: var(--f-body);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	transition:
		background-color 360ms ease,
		color 360ms ease;
}

img,
svg {
	display: block;
	max-width: 100%;
}
a {
	color: inherit;
	text-decoration: none;
}
button {
	font: inherit;
	color: inherit;
	background: none;
	border: 0;
	cursor: pointer;
}

::selection {
	background: var(--accent-soft);
	color: var(--secondary);
}

/* type ramp */
.display,
h1.display {
	font-family: var(--f-display);
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1.05;
}
.h-hero {
	font-family: var(--f-display);
	font-weight: 500;
	font-size: clamp(2.6rem, 6.2vw, 5.4rem);
	line-height: 1.02;
	letter-spacing: -0.015em;
}
.h-section {
	font-family: var(--f-display);
	font-weight: 500;
	font-size: clamp(2rem, 3.6vw, 3.4rem);
	line-height: 1.08;
	letter-spacing: -0.01em;
}
.h-card {
	font-family: var(--f-display);
	font-weight: 500;
	font-size: clamp(1.5rem, 1.8vw, 2.1rem);
	line-height: 1.15;
}
.body-lg {
	font-size: 1.125rem;
	line-height: 1.65;
	color: var(--text-muted);
}
.body {
	color: var(--text-muted);
}

.kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	font-family: var(--f-body);
	font-size: 0.72rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.28em;
	color: var(--accent);
}
.kicker::before {
	content: "";
	display: inline-block;
	width: 28px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--accent-line));
}

.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding-inline: clamp(1.25rem, 4vw, 2rem);
}
.container-narrow {
	width: 100%;
	max-width: 920px;
	margin: 0 auto;
	padding-inline: clamp(1.25rem, 4vw, 2rem);
}
.section {
	padding-block: clamp(3.5rem, 8vw, 7rem);
}
.section-tight {
	padding-block: clamp(2.5rem, 5vw, 4rem);
}

/* buttons */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	font-family: var(--f-body);
	font-size: 0.96rem;
	font-weight: 500;
	letter-spacing: 0.005em;
	border-radius: 999px;
	padding: 0.85rem 1.4rem;
	transition:
		transform 220ms cubic-bezier(0.2, 0.7, 0.2, 1),
		background-color 200ms,
		color 200ms,
		box-shadow 220ms,
		border-color 200ms;
	white-space: nowrap;
	cursor: pointer;
	position: relative;
	border: 1px solid transparent;
}
.btn:hover {
	transform: translateY(-1px);
}
.btn-primary {
	background: var(--primary);
	color: var(--on-primary);
	box-shadow: 0 1px 2px rgba(11, 79, 58, 0.2);
}
.btn-primary:hover {
	background: #0e6149;
	box-shadow: 0 8px 20px rgba(11, 79, 58, 0.22);
}
[data-theme="dark"] .btn-primary {
	background: var(--accent);
	color: #0e1b26;
}
[data-theme="dark"] .btn-primary:hover {
	background: #e2c170;
}
.btn-secondary {
	background: transparent;
	color: var(--primary);
	border-color: var(--primary-line);
}
.btn-secondary:hover {
	background: var(--primary-soft);
}
[data-theme="dark"] .btn-secondary {
	color: var(--secondary);
	border-color: var(--accent-line);
}
.btn-ghost {
	background: transparent;
	color: var(--text);
}
.btn-ghost:hover {
	background: var(--primary-soft);
}
.btn-accent {
	background: var(--accent);
	color: #2a1f00;
}
.btn-accent:hover {
	background: #d4b560;
}
.btn-lg {
	padding: 1rem 1.7rem;
	font-size: 1rem;
}
.btn-sm {
	padding: 0.55rem 1rem;
	font-size: 0.86rem;
}

/* card */
.card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--r-lg);
	padding: 1.6rem;
	transition:
		transform 280ms cubic-bezier(0.2, 0.7, 0.2, 1),
		box-shadow 280ms,
		border-color 200ms;
}
.card:hover {
	transform: translateY(-2px);
	box-shadow: var(--sh-md);
	border-color: var(--accent-line);
}
[data-theme="dark"] .card {
	background: var(--surface);
	border-color: var(--border);
}

/* ornament */
.ornament-grid {
	background-image: radial-gradient(circle at center, var(--accent-soft) 1px, transparent 1.5px);
	background-size: 28px 28px;
}
.ornament-stars {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 60'><g fill='none' stroke='%23C9A646' stroke-width='0.5' opacity='0.32'><polygon points='30,6 36,18 49,20 39.5,29 42,42 30,36 18,42 20.5,29 11,20 24,18'/></g></svg>");
	background-size: 60px 60px;
}
.ornament-arabesque {
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'><g fill='none' stroke='%23C9A646' stroke-width='0.55' opacity='0.28'><path d='M40 0 L80 40 L40 80 L0 40 Z'/><path d='M40 14 L66 40 L40 66 L14 40 Z'/><circle cx='40' cy='40' r='8'/><path d='M40 8 L40 24 M40 56 L40 72 M8 40 L24 40 M56 40 L72 40'/></g></svg>");
	background-size: 80px 80px;
}

/* arched (mihrab) frame */
.arch-mask {
	-webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 280' preserveAspectRatio='none'><path d='M100 0 C155 0 200 45 200 100 L200 280 L0 280 L0 100 C0 45 45 0 100 0 Z' fill='black'/></svg>");
	mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 280' preserveAspectRatio='none'><path d='M100 0 C155 0 200 45 200 100 L200 280 L0 280 L0 100 C0 45 45 0 100 0 Z' fill='black'/></svg>");
	-webkit-mask-size: 100% 100%;
	mask-size: 100% 100%;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
}

/* image placeholder */
.img-placeholder {
	position: relative;
	background:
		repeating-linear-gradient(135deg, var(--bg-tint), var(--bg-tint) 8px, var(--bg-deep) 8px, var(--bg-deep) 9px), var(--bg-tint);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--text-dim);
	font-family: var(--f-mono);
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-align: center;
	padding: 1rem;
}

/* reveal motion */
.reveal {
	opacity: 0;
	transform: translate3d(0, 24px, 0);
	transition:
		opacity 760ms ease,
		transform 860ms cubic-bezier(0.2, 0.7, 0.2, 1);
	will-change: opacity, transform;
}
.reveal.in {
	opacity: 1;
	transform: translate3d(0, 0, 0);
}
.reveal-delay-1 {
	transition-delay: 80ms;
}
.reveal-delay-2 {
	transition-delay: 160ms;
}
.reveal-delay-3 {
	transition-delay: 240ms;
}
.reveal-delay-4 {
	transition-delay: 320ms;
}
.reveal-delay-5 {
	transition-delay: 400ms;
}
.reveal-delay-6 {
	transition-delay: 480ms;
}

@media (prefers-reduced-motion: reduce) {
	.reveal {
		opacity: 1;
		transform: none;
		filter: none;
		transition: none;
	}
	* {
		animation-duration: 0.001ms !important;
		transition-duration: 0.001ms !important;
	}
}

/* divider ornament */
.divider {
	display: flex;
	align-items: center;
	gap: 1rem;
	color: var(--accent);
}
.divider::before,
.divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--accent-line), transparent);
}

/* nav */
.navbar {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	z-index: 50;
	backdrop-filter: saturate(180%) blur(14px);
	-webkit-backdrop-filter: saturate(180%) blur(14px);
	background: color-mix(in srgb, var(--bg) 78%, transparent);
	border-bottom: 1px solid var(--border-soft);
	transition:
		background 300ms,
		border-color 300ms;
}
.navlink {
	position: relative;
	font-size: 0.92rem;
	color: var(--text-muted);
	padding: 0.45rem 0.8rem;
	border-radius: 999px;
	transition:
		color 200ms,
		background 200ms;
}
.navlink:hover {
	color: var(--text);
	background: var(--primary-soft);
}
.navlink.active {
	color: var(--primary);
}
[data-theme="dark"] .navlink.active {
	color: var(--secondary);
}
.navlink.active::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -2px;
	transform: translateX(-50%);
	width: 18px;
	height: 2px;
	border-radius: 2px;
	background: var(--accent);
}

/* footer */
.footer {
	background: #102a43;
	color: rgba(248, 245, 236, 0.86);
	position: relative;
	overflow: hidden;
	--footer-text: rgba(248, 245, 236, 0.96);
	--footer-text-muted: rgba(248, 245, 236, 0.7);
	--footer-text-dim: rgba(248, 245, 236, 0.62);
	--footer-link: rgba(248, 245, 236, 0.78);
	--footer-divider: rgba(201, 166, 70, 0.24);
}
[data-theme="dark"] .footer {
	background: #07111a;
	--footer-text: rgba(236, 227, 205, 0.96);
	--footer-text-muted: rgba(181, 174, 155, 0.85);
	--footer-text-dim: rgba(138, 134, 116, 0.85);
	--footer-link: rgba(236, 227, 205, 0.82);
	--footer-divider: rgba(212, 181, 96, 0.2);
}
.footer::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 80'><g fill='none' stroke='%23C9A646' stroke-width='0.5' opacity='0.16'><polygon points='40,8 48,24 65,28 52,40 56,57 40,48 24,57 28,40 15,28 32,24'/></g></svg>");
	background-size: 80px 80px;
	pointer-events: none;
	opacity: 0.5;
}

/* utility helpers */
.muted {
	color: var(--text-muted);
}
.dim {
	color: var(--text-dim);
}
.serif {
	font-family: var(--f-display);
}
.arabic {
	font-family: var(--f-arabic);
	direction: rtl;
}
.no-wrap {
	white-space: nowrap;
}
.flex {
	display: flex;
}
.grid {
	display: grid;
}
.center {
	display: flex;
	align-items: center;
	justify-content: center;
}
.between {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

/* hero variants ============================ */

/* Atelier — quiet editorial */
.hero-atelier {
	padding-top: clamp(3rem, 6vw, 5rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
	position: relative;
}

/* Mihrab — cinematic immersive */
.hero-mihrab {
	position: relative;
	min-height: clamp(560px, 88vh, 820px);
	margin-top: -64px;
	background: linear-gradient(180deg, #0b2a22 0%, #0b4f3a 50%, #102a43 100%);
	color: #f8f5ec;
	overflow: hidden;
}
.hero-mihrab > svg {
	overflow: hidden;
}
.hero-mihrab .vignette {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at center, transparent 30%, rgba(0, 0, 0, 0.55) 100%),
		radial-gradient(ellipse at 50% 0%, rgba(201, 166, 70, 0.18) 0%, transparent 50%);
	pointer-events: none;
}

/* Riwaq — architectural grid */
.hero-riwaq {
	position: relative;
	padding-top: clamp(3rem, 6vw, 5rem);
}

/* loaded indicator */
.cursor-link {
	cursor: pointer;
}

/* accordion */
.accordion-item {
	border-bottom: 1px solid var(--border-soft);
}
.accordion-trigger {
	width: 100%;
	padding: 1.4rem 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-align: left;
	font-family: var(--f-display);
	font-size: 1.4rem;
	color: var(--secondary);
}
[data-theme="dark"] .accordion-trigger {
	color: var(--secondary);
}
.accordion-icon {
	width: 28px;
	height: 28px;
	border-radius: 999px;
	border: 1px solid var(--accent-line);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--accent);
	transition:
		transform 280ms cubic-bezier(0.2, 0.7, 0.2, 1),
		background 200ms;
	flex-shrink: 0;
	margin-left: 1rem;
}
.accordion-item.open .accordion-icon {
	transform: rotate(45deg);
	background: var(--accent-soft);
}
.accordion-content {
	max-height: 0;
	overflow: hidden;
	transition:
		max-height 380ms cubic-bezier(0.2, 0.7, 0.2, 1),
		opacity 280ms;
	opacity: 0;
	color: var(--text-muted);
	font-size: 1rem;
	line-height: 1.7;
}
.accordion-item.open .accordion-content {
	opacity: 1;
	padding-bottom: 1.4rem;
}

/* form controls */
.input {
	width: 100%;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--r-md);
	padding: 0.85rem 1rem;
	font-family: var(--f-body);
	font-size: 1rem;
	color: var(--text);
	transition:
		border-color 180ms,
		box-shadow 180ms,
		background 180ms;
}
.input:focus {
	outline: none;
	border-color: var(--accent);
	box-shadow: 0 0 0 4px var(--accent-soft);
}

/* badge */
.badge {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.32rem 0.7rem;
	border-radius: 999px;
	background: var(--accent-soft);
	color: var(--accent);
	font-size: 0.74rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border: 1px solid var(--accent-line);
}
.badge-emerald {
	background: var(--primary-soft);
	color: var(--primary);
	border-color: var(--primary-line);
}
[data-theme="dark"] .badge-emerald {
	color: var(--secondary);
}

/* mobile drawer */
.drawer {
	position: fixed;
	inset: 0;
	background: var(--bg);
	z-index: 100;
	transform: translateX(100%);
	transition: transform 360ms cubic-bezier(0.2, 0.7, 0.2, 1);
	display: flex;
	flex-direction: column;
}
.drawer.open {
	transform: none;
}

[data-theme="dark"] .brand-logo,
.footer .brand-logo {
	background: rgba(255, 255, 255, 0.9);
	border-radius: 999px;
	padding: 3px;
}

/* arch SVG decoration */
.arch-svg path {
	fill: var(--bg-elev);
	stroke: var(--accent-line);
	stroke-width: 1;
}

/* tweaks density helpers */
[data-density="cozy"] .section {
	padding-block: clamp(2.5rem, 5vw, 5rem);
}
[data-density="airy"] .section {
	padding-block: clamp(4.5rem, 10vw, 9rem);
}

/* page transitions */
.page {
	animation: none;
}
@keyframes pageIn {
	from {
		opacity: 0;
		transform: translateY(8px);
	}
	to {
		opacity: 1;
		transform: none;
	}
}

.route-page {
	display: none;
	opacity: 0;
	transform: translateY(12px);
	transition:
		opacity 300ms ease,
		transform 380ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.route-page.active,
.route-page.route-leaving {
	display: block;
}
.route-page.active {
	opacity: 1;
	transform: translateZ(0);
	-webkit-transform: translateZ(0);
}
.route-page.active.route-entering {
	opacity: 0;
	transform: translate3d(0, 14px, 0);
	-webkit-transform: translate3d(0, 14px, 0);
}
.route-page.active.route-ready {
	opacity: 1;
	transform: translateZ(0);
	-webkit-transform: translateZ(0);
}
.route-page.active.route-leaving {
	opacity: 0;
	transform: translate3d(0, -10px, 0);
	-webkit-transform: translate3d(0, -10px, 0);
	pointer-events: none;
}
@media (max-width: 980px) {
	.two-col {
		grid-template-columns: 1fr !important;
	}
	.three-col,
	.four-col,
	.five-col {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}
}
@media (max-width: 640px) {
	.three-col,
	.four-col,
	.five-col {
		grid-template-columns: 1fr !important;
	}
	.route-page[data-route="curriculum"] .card[style*="grid-template-columns: auto 1fr 2fr"] {
		grid-template-columns: auto 1fr !important;
		gap: 1rem !important;
		align-items: start !important;
	}
	.route-page[data-route="curriculum"] .card[style*="grid-template-columns: auto 1fr 2fr"] p {
		grid-column: 1 / -1;
	}
	[data-register-stepper] {
		flex-wrap: wrap;
	}
}
.drawer {
	will-change: transform;
}
.drawer:not(.open) {
	pointer-events: none;
}
button:disabled {
	cursor: not-allowed;
}
.route-page img {
	background: var(--bg-tint);
}
.route-page[data-route="home"] .hero-stats {
	max-width: 1080px !important;
	grid-template-columns: minmax(120px, 0.8fr) minmax(140px, 0.85fr) minmax(230px, 1.15fr) minmax(230px, 1.15fr) !important;
	gap: clamp(1rem, 3vw, 2.4rem) !important;
}
.route-page[data-route="home"] .hero-stats > div > div:first-child {
	white-space: nowrap;
	font-size: clamp(1.55rem, 2.1vw, 2.2rem) !important;
	line-height: 1.08;
}
.route-page[data-route="home"] .hero-stats > div > div:last-child {
	white-space: nowrap;
	letter-spacing: 0.15em !important;
}
@media (max-width: 720px) {
	.route-page[data-route="home"] .hero-stats {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		max-width: 560px !important;
		width: 100% !important;
		gap: 1rem 0.75rem !important;
	}
	.route-page[data-route="home"] .hero-stats > div {
		min-width: 0;
	}
	.route-page[data-route="home"] .hero-stats > div > div:first-child {
		font-size: clamp(1.45rem, 7vw, 2rem) !important;
		white-space: normal !important;
	}
	.route-page[data-route="home"] .hero-stats > div > div:last-child {
		white-space: normal;
	}
}
.calendar-intro {
	padding-top: clamp(3.5rem, 6vw, 5.5rem);
	padding-bottom: 0;
}
.calendar-intro-grid {
	display: grid;
	grid-template-columns: minmax(360px, 0.9fr) repeat(2, minmax(280px, 0.72fr));
	gap: clamp(1rem, 2vw, 1.4rem);
	align-items: start;
}
.calendar-copy {
	max-width: 62ch;
}
.calendar-disclaimer {
	margin-top: 1.8rem;
	border: 1px solid var(--accent-line);
	background: var(--accent-soft);
	border-radius: var(--r-lg);
	padding: 1.15rem 1.25rem;
	color: var(--text-muted);
	line-height: 1.65;
}
.calendar-disclaimer strong {
	color: var(--secondary);
	font-weight: 600;
}
.calendar-schedules {
	display: contents;
	opacity: 1 !important;
	transform: none !important;
	filter: none !important;
}
.calendar-schedule-card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	padding: clamp(1.35rem, 2.8vw, 1.8rem);
	box-shadow: var(--sh-sm);
}
.calendar-schedule-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}
.calendar-day {
	font-family: var(--f-display);
	font-size: clamp(1.65rem, 3vw, 2.2rem);
	line-height: 1.05;
	color: var(--secondary);
}
.calendar-time {
	font-size: 0.72rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--accent);
	font-weight: 600;
	white-space: nowrap;
}
.calendar-periods {
	margin-top: 1.25rem;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.65rem;
}
.calendar-period {
	border: 1px solid var(--border-soft);
	background: var(--bg);
	border-radius: var(--r-md);
	padding: 0.85rem 0.9rem;
	min-width: 0;
}
.calendar-period.wide {
	grid-column: span 2;
}
.calendar-period-label {
	font-size: 0.68rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--text-dim);
	font-weight: 600;
}
.calendar-period-time {
	margin-top: 0.3rem;
	color: var(--secondary);
	font-weight: 600;
}
.calendar-panel {
	padding-top: clamp(0.5rem, 1.5vw, 1rem);
	padding-bottom: clamp(4rem, 7vw, 6rem);
}
.calendar-board {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	padding: clamp(1.5rem, 3.8vw, 3rem);
	box-shadow: var(--sh-md);
}
.calendar-board-head {
	display: flex;
	justify-content: space-between;
	gap: 1.5rem;
	align-items: end;
	flex-wrap: wrap;
}
.calendar-timeline {
	margin-top: 2rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}
.calendar-row {
	display: grid;
	grid-template-columns: minmax(9rem, 12rem) 1.8rem minmax(0, 1fr);
	gap: 1.1rem;
	align-items: stretch;
}
.calendar-date {
	padding-top: 0.85rem;
	text-align: right;
}
.calendar-year {
	font-size: 0.74rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--text-dim);
	font-weight: 600;
}
.calendar-date-main {
	font-family: var(--f-display);
	font-size: 1.35rem;
	color: var(--secondary);
	line-height: 1.1;
	margin-top: 0.2rem;
}
.calendar-date-day {
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--accent);
	margin-top: 0.45rem;
	font-weight: 600;
}
.calendar-spine {
	position: relative;
	display: flex;
	justify-content: center;
}
.calendar-spine:before {
	content: "";
	width: 1px;
	background: var(--border);
	position: absolute;
	top: 0;
	bottom: -1rem;
}
.calendar-dot {
	position: relative;
	z-index: 1;
	width: 0.85rem;
	height: 0.85rem;
	border-radius: 999px;
	background: var(--surface);
	border: 2px solid var(--accent);
	margin-top: 1.25rem;
	box-shadow: 0 0 0 5px var(--accent-soft);
}
.calendar-card {
	border: 1px solid var(--border);
	background: var(--bg);
	border-radius: var(--r-lg);
	padding: 1.1rem 1.2rem;
	min-width: 0;
}
.calendar-card.break {
	background: rgba(165, 75, 69, 0.08);
	border-color: rgba(165, 75, 69, 0.26);
}
.calendar-card.special {
	background: var(--bg);
	border-color: var(--border);
}
.calendar-tags {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	flex-wrap: wrap;
}
.calendar-tag {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	border: 1px solid var(--accent-line);
	background: var(--accent-soft);
	color: var(--accent);
	font-size: 0.68rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 600;
	padding: 0.3rem 0.62rem;
}
.calendar-tag.no-classes {
	background: rgba(165, 75, 69, 0.1);
	border-color: rgba(165, 75, 69, 0.26);
	color: #a54b45;
}
.calendar-event {
	margin-top: 0.8rem;
	font-size: 1.02rem;
	line-height: 1.65;
	color: var(--text);
}
@media (max-width: 1080px) {
	.calendar-intro-grid {
		grid-template-columns: 1fr;
	}
	.calendar-copy {
		max-width: 72ch;
	}
	.calendar-schedules {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1rem;
	}
	.calendar-schedule-card {
		min-height: auto;
	}
}
@media (max-width: 900px) {
	.calendar-intro-grid {
		grid-template-columns: 1fr;
	}
	.calendar-schedules {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1rem;
	}
	.calendar-row {
		grid-template-columns: 1fr;
	}
	.calendar-date {
		text-align: left;
		padding-top: 0;
		display: grid;
		grid-template-columns: auto 1fr;
		gap: 0.25rem 1rem;
		align-items: end;
	}
	.calendar-year {
		grid-column: 1/-1;
	}
	.calendar-date-main {
		margin-top: 0;
	}
	.calendar-date-day {
		margin-top: 0;
	}
	.calendar-spine {
		display: none;
	}
}
@media (max-width: 640px) {
	.calendar-schedules {
		grid-template-columns: 1fr;
	}
	.calendar-periods {
		grid-template-columns: 1fr;
	}
	.calendar-period.wide {
		grid-column: auto;
	}
	.calendar-board {
		padding: 1.1rem;
	}
	.calendar-row {
		gap: 0.55rem;
	}
	.calendar-card {
		padding: 1rem;
	}
	.calendar-board-head {
		align-items: start;
	}
	.calendar-time {
		white-space: normal;
		text-align: right;
	}
}
.team-overview {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	padding: clamp(1.5rem, 3vw, 2.2rem);
	box-shadow: var(--sh-md);
}
.team-overview-list {
	margin-top: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.team-overview-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	border: 1px solid var(--border-soft);
	background: var(--bg);
	border-radius: var(--r-md);
	padding: 1rem 1.1rem;
}
.team-overview-title {
	font-family: var(--f-display);
	font-size: 1.3rem;
	color: var(--secondary);
	line-height: 1.1;
}
.team-count {
	font-size: 0.68rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--accent);
	font-weight: 700;
	white-space: nowrap;
}
.team-section-head {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 1.5rem;
	flex-wrap: wrap;
}
.team-session-grid {
	margin-top: 2rem;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.2rem;
}
.team-card {
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--r-xl);
	padding: clamp(1.5rem, 3vw, 2rem);
	box-shadow: var(--sh-sm);
	position: relative;
	overflow: hidden;
}
.team-card:before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: linear-gradient(90deg, var(--primary), var(--accent));
	opacity: 0.9;
}
.team-card-title {
	font-family: var(--f-display);
	font-size: clamp(1.9rem, 3.4vw, 2.5rem);
	line-height: 1.05;
	color: var(--secondary);
}
.team-card-note {
	margin-top: 0.55rem;
	color: var(--text-muted);
	font-size: 0.95rem;
	line-height: 1.6;
}
.team-people {
	margin-top: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.team-person {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1rem;
	align-items: center;
	border: 1px solid var(--border-soft);
	background: var(--bg);
	border-radius: var(--r-lg);
	padding: 1rem;
}
.team-mark {
	width: 46px;
	height: 46px;
	border-radius: 999px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--primary-soft);
	border: 1px solid var(--primary-line);
	color: var(--primary);
	font-family: var(--f-display);
	font-size: 1.15rem;
	font-weight: 600;
	flex-shrink: 0;
}
.team-name {
	font-family: var(--f-display);
	font-size: 1.45rem;
	line-height: 1.1;
	color: var(--secondary);
}
.team-role {
	margin-top: 0.32rem;
	font-size: 0.7rem;
	letter-spacing: 0.17em;
	text-transform: uppercase;
	color: var(--accent);
	font-weight: 700;
}
.team-governance {
	margin-top: 1.2rem;
	background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
	border-color: rgba(201, 166, 70, 0.28);
	color: var(--on-primary);
}
.team-governance .team-card-title,
.team-governance .team-name {
	color: rgba(248, 245, 236, 0.98);
}
.team-governance .team-card-note {
	color: rgba(248, 245, 236, 0.72);
}
.team-governance .team-person {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.14);
}
.team-governance .team-mark {
	background: rgba(201, 166, 70, 0.18);
	border-color: rgba(201, 166, 70, 0.38);
	color: var(--accent);
}
@media (max-width: 860px) {
	.team-session-grid {
		grid-template-columns: 1fr;
	}
	.team-overview-row {
		align-items: flex-start;
		flex-direction: column;
	}
	.team-count {
		white-space: normal;
	}
}
/* ── Gallery ── */
.gallery-hero { padding-top: clamp(3rem,6vw,5rem); padding-bottom: clamp(2rem,4vw,3.5rem); }
.gallery-albums { display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 1.5rem; margin-top: 2.5rem; }
.gallery-album-card { border-radius: var(--r-xl); overflow: hidden; cursor: pointer; border: 1px solid var(--border); background: var(--surface); box-shadow: var(--sh-sm); transition: transform 220ms, box-shadow 220ms; }
.gallery-album-card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }
.gallery-album-cover-wrap { position: relative; }
.gallery-album-cover { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; background: var(--bg-tint); }
.gallery-year-badge {
	position: absolute;
	top: 0.65rem;
	right: 0.7rem;
	background: rgba(0,0,0,0.52);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	color: #fff;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.25rem 0.6rem;
	border-radius: 999px;
	pointer-events: none;
}
.gallery-album-info { padding: 1.2rem 1.4rem; }
.gallery-album-title { font-family: var(--f-display); font-size: 1.25rem; color: var(--secondary); line-height: 1.2; }
.gallery-album-meta { font-size: 0.8rem; color: var(--text-muted); margin-top: 0.25rem; }
.gallery-album-view { display: none; }
.gallery-album-view.active { display: block; }
.gallery-albums-view { display: block; }
.gallery-albums-view.hidden { display: none; }
/* Spinner */
.gallery-spinner-wrap {
	display: flex; align-items: center; justify-content: center;
	padding: 4rem 0; gap: 0.8rem; color: var(--text-muted); font-size: 0.9rem;
}
@keyframes gallery-spin { to { transform: rotate(360deg); } }
.gallery-spinner {
	width: 22px; height: 22px; border-radius: 50%;
	border: 2px solid var(--border);
	border-top-color: var(--primary);
	animation: gallery-spin 0.7s linear infinite;
	flex-shrink: 0;
}
/* Photo grid — masonry columns. Each cell reserves its true, orientation-corrected
   aspect ratio (from albums.json) so the layout is stable and images stream in
   gracefully instead of popping in and shoving everything around. */
.gallery-photo-grid {
	columns: 4;
	column-gap: 0.55rem;
	margin-top: 2rem;
}
.gallery-cell {
	position: relative;
	break-inside: avoid;
	display: block;
	width: 100%;
	margin-bottom: 0.55rem;
	border-radius: var(--r-md);
	cursor: pointer;
	overflow: hidden;
	aspect-ratio: var(--ar, 3 / 2);
	background: var(--bg-tint);
	border: 1px solid var(--border-soft);
}
/* Skeleton shimmer shown until the media paints. */
.gallery-cell.is-loading::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(100deg, var(--bg-tint) 30%, var(--border-soft) 50%, var(--bg-tint) 70%);
	background-size: 220% 100%;
	animation: gallery-shimmer 1.3s ease-in-out infinite;
	z-index: 0;
}
@keyframes gallery-shimmer { to { background-position: -220% 0; } }
.gallery-cell img,
.gallery-cell video {
	position: absolute;
	top: 0; left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	z-index: 1;
	image-orientation: none;            /* orientation handled deterministically below */
	opacity: 0;
	transition: opacity 360ms ease, transform 280ms ease;
}
.gallery-cell img.loaded,
.gallery-cell video.loaded { opacity: 1; }
.gallery-cell:hover img.loaded,
.gallery-cell:hover video.loaded { opacity: 0.92; }

/* EXIF orientation correction — we strip the browser's auto-orient (above) and
   rotate the raw pixels ourselves so behavior is identical in every browser.
   --ohw = display-height / display-width (set per cell in JS). */
.gallery-cell img.gx-rot180,
.gallery-lb-frame img.gx-rot180 { transform: rotate(180deg); }
.gallery-cell img.gx-rot90,
.gallery-cell img.gx-rot270,
.gallery-lb-frame img.gx-rot90,
.gallery-lb-frame img.gx-rot270 {
	width: calc(100% * var(--ohw, 1));
	height: auto;
	top: 50%;
	left: 50%;
	object-fit: fill;
}
.gallery-cell img.gx-rot90,
.gallery-lb-frame img.gx-rot90 { transform: translate(-50%, -50%) rotate(90deg); }
.gallery-cell img.gx-rot270,
.gallery-lb-frame img.gx-rot270 { transform: translate(-50%, -50%) rotate(-90deg); }
.gallery-play-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.gallery-play-overlay svg { width: 46px; height: 46px; filter: drop-shadow(0 2px 8px rgba(0,0,0,.6)); }
.gallery-video-badge { position: absolute; bottom: 6px; right: 7px; background: rgba(0,0,0,.55); color: #fff; font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; padding: 2px 6px; border-radius: 4px; text-transform: uppercase; }
/* Lightbox */
.gallery-lightbox { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.96); z-index: 200; flex-direction: column; align-items: center; justify-content: center; }
.gallery-lightbox.open { display: flex; }
.gallery-lightbox-media { max-width: 90vw; max-height: 82vh; border-radius: var(--r-lg); object-fit: contain; }
/* Frame sized to the image's true (orientation-corrected) aspect ratio so the
   deterministic rotation fills it exactly. --ar = width / height. */
.gallery-lb-frame {
	position: relative;
	aspect-ratio: var(--ar, 3 / 2);
	width: min(90vw, calc(82vh * var(--ar, 1.5)));
	max-width: 90vw;
	max-height: 82vh;
}
.gallery-lb-frame img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	image-orientation: none;
	border-radius: var(--r-lg);
}
.gallery-lightbox-download {
	position: absolute; top: 1.1rem; right: 4.9rem;
	color: rgba(255,255,255,.75); background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.13); width: 44px; height: 44px;
	border-radius: 999px; cursor: pointer; display: flex; align-items: center;
	justify-content: center; transition: background 160ms, color 160ms;
}
.gallery-lightbox-download:hover { background: rgba(255,255,255,.16); color: #fff; }
.gallery-lightbox-download[hidden] { display: none; }
.gallery-lightbox-close { position: absolute; top: 1.1rem; right: 1.4rem; color: rgba(255,255,255,.75); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.13); width: 44px; height: 44px; border-radius: 999px; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; line-height: 1; transition: background 160ms, color 160ms; }
.gallery-lightbox-close:hover { background: rgba(255,255,255,.16); color: #fff; }
.gallery-lightbox-nav { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.13); color: rgba(255,255,255,.8); width: 48px; height: 48px; border-radius: 999px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 160ms, color 160ms; }
.gallery-lightbox-nav:hover { background: rgba(255,255,255,.18); color: #fff; }
.gallery-lightbox-prev { left: 1.2rem; }
.gallery-lightbox-next { right: 1.2rem; }
.gallery-lightbox-counter { position: absolute; bottom: 1.2rem; left: 50%; transform: translateX(-50%); color: rgba(255,255,255,.4); font-size: 0.78rem; letter-spacing: 0.07em; white-space: nowrap; }
@media (max-width: 1080px) { .gallery-photo-grid { columns: 3; } }
@media (max-width: 720px)  { .gallery-photo-grid { columns: 2; } }
@media (max-width: 640px)  { .gallery-albums { grid-template-columns: 1fr; } .gallery-photo-grid { columns: 2; column-gap: 0.4rem; } .gallery-lightbox-nav { width: 42px; height: 42px; touch-action: manipulation; } .gallery-lightbox-prev { left: 0.4rem; } .gallery-lightbox-next { right: 0.4rem; } }


@media (max-width: 920px) {
	.hide-mobile {
		display: none !important;
	}
	.show-mobile {
		display: inline-flex !important;
		align-items: center;
		justify-content: center;
	}
}

				@media (max-width: 720px) {
					.route-page[data-route="home"] .hero-stats {
						grid-template-columns: repeat(2, 1fr) !important;
					}
				}

				@media (max-width: 880px) {
					.route-page[data-route="home"] .two-col {
						grid-template-columns: 1fr !important;
					}
				}

				@media (max-width: 880px) {
					.route-page[data-route="home"] .three-col {
						grid-template-columns: 1fr !important;
					}
				}

				@media (max-width: 980px) {
					.route-page[data-route="home"] .four-col {
						grid-template-columns: 1fr 1fr !important;
					}
				}
				@media (max-width: 540px) {
					.route-page[data-route="home"] .four-col {
						grid-template-columns: 1fr !important;
					}
				}

				@media (max-width: 980px) {
					.route-page[data-route="home"] .five-col {
						grid-template-columns: 1fr 1fr !important;
					}
				}

				@media (max-width: 880px) {
					.route-page[data-route="home"] .two-col {
						grid-template-columns: 1fr !important;
					}
				}

				@media (max-width: 880px) {
					.route-page[data-route="team"] .two-col {
						grid-template-columns: 1fr !important;
					}
					.team-governance .team-people {
						grid-template-columns: 1fr !important;
					}
				}

	@media (max-width: 820px) {
		.footer .grid {
			grid-template-columns: 1fr 1fr !important;
			gap: 2rem !important;
		}
	}
	@media (max-width: 520px) {
		.footer .grid {
			grid-template-columns: 1fr !important;
		}
	}