/* Minification failed. Returning unminified contents.
(118,22): run-time error CSS1039: Token not allowed after unary operator: '-ft-bg'
(119,30): run-time error CSS1039: Token not allowed after unary operator: '-ft-border'
(148,22): run-time error CSS1039: Token not allowed after unary operator: '-ft-color'
(167,21): run-time error CSS1039: Token not allowed after unary operator: '-size-base'
(175,21): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(224,22): run-time error CSS1039: Token not allowed after unary operator: '-ft-color'
(258,22): run-time error CSS1039: Token not allowed after unary operator: '-ft-color'
(338,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(339,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(340,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(341,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(342,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(343,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(344,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(345,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(346,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(347,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(348,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(349,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(350,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(352,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(353,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(354,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(355,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(356,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(357,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(358,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(359,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(360,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(361,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(372,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(374,28): run-time error CSS1039: Token not allowed after unary operator: '-white'
(436,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(441,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(460,46): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(460,68): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(461,17): run-time error CSS1039: Token not allowed after unary operator: '-white'
(490,28): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(491,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(496,32): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(497,21): run-time error CSS1039: Token not allowed after unary operator: '-white'
(512,46): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(512,71): run-time error CSS1039: Token not allowed after unary operator: '-light-bg'
(610,17): run-time error CSS1039: Token not allowed after unary operator: '-colorWhite'
(617,23): run-time error CSS1039: Token not allowed after unary operator: '-fontDisplay'
(645,17): run-time error CSS1039: Token not allowed after unary operator: '-white'
(649,19): run-time error CSS1039: Token not allowed after unary operator: '-size-xxs'
(649,35): run-time error CSS1039: Token not allowed after unary operator: '-size-3xl'
(651,28): run-time error CSS1039: Token not allowed after unary operator: '-white'
(662,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(692,22): run-time error CSS1039: Token not allowed after unary operator: '-colorWhite'
(718,21): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(724,21): run-time error CSS1039: Token not allowed after unary operator: '-colorMid'
(767,22): run-time error CSS1039: Token not allowed after unary operator: '-white'
(796,17): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(802,17): run-time error CSS1039: Token not allowed after unary operator: '-colorMid'
(813,22): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(825,26): run-time error CSS1039: Token not allowed after unary operator: '-colorOceanLight'
(850,22): run-time error CSS1039: Token not allowed after unary operator: '-colorCoral'
(852,23): run-time error CSS1039: Token not allowed after unary operator: '-fontDisplay'
(862,46): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(862,74): run-time error CSS1039: Token not allowed after unary operator: '-light-bg'
(905,17): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(929,17): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(941,17): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(947,17): run-time error CSS1039: Token not allowed after unary operator: '-colorMid'
(964,22): run-time error CSS1039: Token not allowed after unary operator: '-colorWhite'
(966,35): run-time error CSS1039: Token not allowed after unary operator: '-colorSandDark'
(980,22): run-time error CSS1039: Token not allowed after unary operator: '-colorSand'
(985,17): run-time error CSS1039: Token not allowed after unary operator: '-colorMid'
(988,28): run-time error CSS1039: Token not allowed after unary operator: '-colorSandDark'
(992,22): run-time error CSS1039: Token not allowed after unary operator: '-colorSand'
(1008,22): run-time error CSS1039: Token not allowed after unary operator: '-colorWhite'
(1051,17): run-time error CSS1039: Token not allowed after unary operator: '-slider-w'
(1096,22): run-time error CSS1039: Token not allowed after unary operator: '-colorCoral'
(1132,17): run-time error CSS1039: Token not allowed after unary operator: '-colorMid'
(1144,26): run-time error CSS1039: Token not allowed after unary operator: '-colorCoral'
(1160,35): run-time error CSS1039: Token not allowed after unary operator: '-colorSandDark'
(1179,21): run-time error CSS1039: Token not allowed after unary operator: '-colorDark'
(1180,27): run-time error CSS1039: Token not allowed after unary operator: '-fontBody'
(1185,17): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(1194,17): run-time error CSS1039: Token not allowed after unary operator: '-colorMid'
(1214,28): run-time error CSS1039: Token not allowed after unary operator: '-light-bg'
(1224,22): run-time error CSS1039: Token not allowed after unary operator: '-white'
(1251,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1266,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1276,36): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(1282,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(1294,28): run-time error CSS1039: Token not allowed after unary operator: '-colorOcean'
(1301,28): run-time error CSS1039: Token not allowed after unary operator: '-colorOceanLight'
(1302,37): run-time error CSS1039: Token not allowed after unary operator: '-colorOceanLight'
(1308,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1322,17): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(1326,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1333,28): run-time error CSS1039: Token not allowed after unary operator: '-white'
(1338,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1344,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1511,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1511,78): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1516,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1520,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1541,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1541,78): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1545,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1549,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1606,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1606,78): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1610,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1614,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1668,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1668,78): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1672,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1676,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1774,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1774,78): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1778,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1782,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1812,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1812,78): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1816,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1820,48): run-time error CSS1039: Token not allowed after unary operator: '-i'
(1837,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1838,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1839,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1840,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1841,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1842,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1843,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1844,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1856,17): run-time error CSS1039: Token not allowed after unary operator: '-text-primary'
(1874,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1883,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(1906,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(1919,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(1922,33): run-time error CSS1039: Token not allowed after unary operator: '-border-color'
(1928,17): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(1929,29): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(1933,17): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(1935,29): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(1945,17): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(1947,29): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(1970,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(1973,35): run-time error CSS1039: Token not allowed after unary operator: '-border-color'
(1978,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(1994,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2000,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(2015,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2021,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(2037,17): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(2043,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(2055,17): run-time error CSS1039: Token not allowed after unary operator: '-text-secondary'
(2059,35): run-time error CSS1039: Token not allowed after unary operator: '-border-color'
(2068,17): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(2074,17): run-time error CSS1039: Token not allowed after unary operator: '-text-primary'
(2084,22): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(2121,38): run-time error CSS1039: Token not allowed after unary operator: '-border-color'
(2145,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2146,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2147,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2148,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2149,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2150,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2151,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2152,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2153,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2154,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2155,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2157,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2158,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2159,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2160,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2161,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2162,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2163,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2164,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2165,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2166,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2182,21): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(2202,21): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(2204,17): run-time error CSS1039: Token not allowed after unary operator: '-cb-pri'
(2206,23): run-time error CSS1039: Token not allowed after unary operator: '-cb-font'
(2212,21): run-time error CSS1039: Token not allowed after unary operator: '-cb-pri'
(2228,46): run-time error CSS1039: Token not allowed after unary operator: '-cb-pri'
(2228,61): run-time error CSS1039: Token not allowed after unary operator: '-cb-acc'
(2237,23): run-time error CSS1039: Token not allowed after unary operator: '-cb-font'
(2311,22): run-time error CSS1039: Token not allowed after unary operator: '-cb-panel'
(2312,25): run-time error CSS1039: Token not allowed after unary operator: '-cb-r'
(2313,22): run-time error CSS1039: Token not allowed after unary operator: '-cb-shadow'
(2314,28): run-time error CSS1039: Token not allowed after unary operator: '-cb-border'
(2318,23): run-time error CSS1039: Token not allowed after unary operator: '-cb-font'
(2334,46): run-time error CSS1039: Token not allowed after unary operator: '-cb-pri'
(2334,64): run-time error CSS1039: Token not allowed after unary operator: '-cb-sec'
(2364,21): run-time error CSS1039: Token not allowed after unary operator: '-size-base'
(2372,21): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(2474,46): run-time error CSS1039: Token not allowed after unary operator: '-cb-pri'
(2474,61): run-time error CSS1039: Token not allowed after unary operator: '-cb-acc'
(2488,22): run-time error CSS1039: Token not allowed after unary operator: '-cb-bg'
(2489,28): run-time error CSS1039: Token not allowed after unary operator: '-cb-border'
(2492,21): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(2494,17): run-time error CSS1039: Token not allowed after unary operator: '-cb-text'
(2501,46): run-time error CSS1039: Token not allowed after unary operator: '-cb-pri'
(2501,61): run-time error CSS1039: Token not allowed after unary operator: '-cb-sec'
(2504,21): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(2523,22): run-time error CSS1039: Token not allowed after unary operator: '-cb-acc'
(2552,32): run-time error CSS1039: Token not allowed after unary operator: '-cb-border'
(2562,22): run-time error CSS1039: Token not allowed after unary operator: '-cb-bg'
(2567,23): run-time error CSS1039: Token not allowed after unary operator: '-cb-font'
(2568,17): run-time error CSS1039: Token not allowed after unary operator: '-cb-text'
(2591,46): run-time error CSS1039: Token not allowed after unary operator: '-cb-pri'
(2591,61): run-time error CSS1039: Token not allowed after unary operator: '-cb-sec'
(2627,17): run-time error CSS1039: Token not allowed after unary operator: '-cb-muted'
(2657,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2658,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2659,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2660,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2661,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2662,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2663,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2664,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2665,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2666,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2667,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2668,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2669,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2670,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2671,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2672,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2673,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2674,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2675,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2676,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2677,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2678,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2689,28): run-time error CSS1039: Token not allowed after unary operator: '-background-color'
(2698,17): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(2709,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2716,28): run-time error CSS1039: Token not allowed after unary operator: '-background-color'
(2742,17): run-time error CSS1039: Token not allowed after unary operator: '-sidebar-width'
(2743,28): run-time error CSS1039: Token not allowed after unary operator: '-background-color'
(2787,21): run-time error CSS1039: Token not allowed after unary operator: '-size-xl'
(2789,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2797,22): run-time error CSS1039: Token not allowed after unary operator: '-background-color'
(2804,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2809,26): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(2864,50): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2864,72): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(2871,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2880,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2957,22): run-time error CSS1039: Token not allowed after unary operator: '-background-color'
(2958,29): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2973,46): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2973,68): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(2991,21): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(2993,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(2999,21): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(3052,26): run-time error CSS1039: Token not allowed after unary operator: '-background-color'
(3053,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3062,26): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(3063,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3077,25): run-time error CSS1039: Token not allowed after unary operator: '-size-lg'
(3087,25): run-time error CSS1039: Token not allowed after unary operator: '-size-lg'
(3118,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3133,50): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3133,75): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(3154,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3161,21): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(3165,18): run-time error CSS1039: Token not allowed after unary operator: '-size-5xl'
(3171,15): run-time error CSS1039: Token not allowed after unary operator: '-size-xxs'
(3176,19): run-time error CSS1039: Token not allowed after unary operator: '-size-xxs'
(3176,35): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(3177,28): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3179,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3180,25): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(3183,21): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(3189,32): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3194,19): run-time error CSS1039: Token not allowed after unary operator: '-size-xxs'
(3194,35): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(3195,28): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3197,25): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(3200,21): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(3203,28): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3207,32): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(3208,28): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(3235,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3236,28): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(3237,19): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(3237,34): run-time error CSS1039: Token not allowed after unary operator: '-size-xxs'
(3238,25): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(3266,21): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3274,25): run-time error CSS1039: Token not allowed after unary operator: '-accent-color'
(3318,34): run-time error CSS1039: Token not allowed after unary operator: '-color-border-tertiary'
(3328,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-tertiary'
(3353,22): run-time error CSS1039: Token not allowed after unary operator: '-color-border-secondary'
(3359,26): run-time error CSS1039: Token not allowed after unary operator: '-color-text-primary'
(3365,26): run-time error CSS1039: Token not allowed after unary operator: '-color-text-secondary'
(3371,25): run-time error CSS1039: Token not allowed after unary operator: '-border-radius-md'
(3372,30): run-time error CSS1039: Token not allowed after unary operator: '-color-border-tertiary'
(3378,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-secondary'
(3384,26): run-time error CSS1039: Token not allowed after unary operator: '-color-background-secondary'
(3385,28): run-time error CSS1039: Token not allowed after unary operator: '-color-border-secondary'
(3397,15): run-time error CSS1039: Token not allowed after unary operator: '-size-xxs'
(3398,22): run-time error CSS1039: Token not allowed after unary operator: '-size-lg'
(3399,19): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(3409,21): run-time error CSS1039: Token not allowed after unary operator: '-size-xs'
(3410,21): run-time error CSS1039: Token not allowed after unary operator: '-size-sm'
(3412,17): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3421,32): run-time error CSS1039: Token not allowed after unary operator: '-background-color'
(3422,28): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(3423,21): run-time error CSS1039: Token not allowed after unary operator: '-secondary-color'
(3429,32): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3431,28): run-time error CSS1039: Token not allowed after unary operator: '-primary-color'
(3447,25): run-time error CSS1039: Token not allowed after unary operator: '-size-base'
(3462,21): run-time error CSS1039: Token not allowed after unary operator: '-sidebar-collapsed-width'
(3480,25): run-time error CSS1039: Token not allowed after unary operator: '-sidebar-collapsed-width'
(3486,27): run-time error CSS1039: Token not allowed after unary operator: '-sidebar-collapsed-width'
(3488,33): run-time error CSS1039: Token not allowed after unary operator: '-sidebar-collapsed-width'
(3523,21): run-time error CSS1039: Token not allowed after unary operator: '-sidebar-width'
 */

/* ── Container ───────────────────────────────────────────── */
.ft_container {
    position: fixed;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
    padding: 16px;
}

.ft_container--bottom-right {
    bottom: 0;
    right: 0;
    align-items: flex-end;
}

.ft_container--bottom-left {
    bottom: 0;
    left: 0;
    align-items: flex-start;
}

.ft_container--top-right {
    top: 0;
    right: 0;
    align-items: flex-end;
    flex-direction: column-reverse;
}

.ft_container--top-left {
    top: 0;
    left: 0;
    align-items: flex-start;
    flex-direction: column-reverse;
}

/* ── Toast shell ─────────────────────────────────────────── */
.ft {
    position: relative;
    min-width: 280px;
    max-width: 380px;
    pointer-events: all;
    font-family: "Pilcrow Rounded", system-ui, -apple-system, sans-serif;
    opacity: 0;
    transform: translateY(20px) scaleY(0.88) scaleX(0.96);
    transform-origin: bottom center;
    transition: opacity 180ms ease-out;
}

.ft--visible {
    opacity: 1;
    transition: opacity 180ms ease-out;
    animation: ftSpringEnter 360ms cubic-bezier(0.2, 0, 0, 1) forwards;
    transform-origin: bottom center;
}

@keyframes ftSpringEnter {
    0% {
        transform: translateY(20px) scaleY(0.88) scaleX(0.96);
    }

    55% {
        transform: translateY(-6px) scaleY(1.04) scaleX(1.01);
    }

    72% {
        transform: translateY(3px) scaleY(0.98) scaleX(1.00);
    }

    86% {
        transform: translateY(-2px) scaleY(1.01) scaleX(1.00);
    }

    94% {
        transform: translateY(1px) scaleY(1.00) scaleX(1.00);
    }

    100% {
        transform: translateY(0) scaleY(1) scaleX(1);
    }
}

.ft--exit {
    animation: ftExit 260ms cubic-bezier(0.4, 0, 1, 1) forwards;
    pointer-events: none;
}

@keyframes ftExit {
    0% {
        opacity: 1;
        transform: translateX(0) translateY(0);
        max-height: 120px;
        margin-bottom: 10px;
    }

    60% {
        opacity: 0;
        transform: translateX(60px) translateY(0);
    }

    100% {
        opacity: 0;
        transform: translateX(100px) translateY(0);
        max-height: 0;
        margin-bottom: 0;
        padding: 0;
    }
}

/* ── Inner layout ────────────────────────────────────────── */
.ft_inner {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 13px 14px 13px 13px;
    background: var(--ft-bg, rgba(0,84,97,0.07));
    border: 1.5px solid var(--ft-border, rgba(0,84,97,0.18));
    border-radius: 16px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.10), 0 2px 6px rgba(0,0,0,0.06);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    background-clip: padding-box;
    position: relative;
    overflow: hidden;
    background-image: linear-gradient( 180deg, rgba(255,255,255,0.55) 0%, rgba(255,255,255,0.0) 100% );
}
    .ft_inner::after {
        content: "";
        position: absolute;
        inset: 0;
        border-radius: inherit;
        filter: blur(10px);
        opacity: 0.4;
        pointer-events: none;
    }

.ft_iconWrap {
    flex-shrink: 0;
    margin-top: 1px;
}

.ft_icon {
    width: 28px;
    height: 28px;
    border-radius: 9px;
    background: var(--ft-color, #005461);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    flex-shrink: 0;
}

    .ft_icon svg {
        width: 15px;
        height: 15px;
    }

.ft_content {
    flex: 1;
    min-width: 0;
}

.ft_title {
    font-size: var(--size-base);
    font-weight: 800;
    color: #0f172a;
    line-height: 1.3;
    letter-spacing: -0.01em;
}

.ft_desc {
    font-size: var(--size-sm);
    font-weight: 500;
    color: rgba(15,23,42,0.65);
    margin-top: 2px;
    line-height: 1.4;
}

/* ── Close button ────────────────────────────────────────── */
.ft_close {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    border-radius: 6px;
    border: none;
    background: rgba(0,0,0,0.06);
    color: rgba(15,23,42,0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    margin-top: 1px;
    transition: background 120ms, color 120ms;
}

    .ft_close:hover {
        background: rgba(0,0,0,0.12);
        color: rgba(15,23,42,0.80);
    }

    .ft_close svg {
        width: 11px;
        height: 11px;
    }

/* ── Progress bar ────────────────────────────────────────── */
.ft_progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: rgba(0,0,0,0.06);
    border-radius: 0 0 14px 14px;
    overflow: hidden;
}

.ft_progressBar {
    height: 100%;
    background: var(--ft-color, #005461);
    border-radius: 0 0 14px 14px;
    transform-origin: left;
    animation: ftProgress linear forwards;
    opacity: 0.70;
}

@keyframes ftProgress {
    from {
        transform: scaleX(1);
    }

    to {
        transform: scaleX(0);
    }
}

/* ── Goo filter holder ───────────────────────────────────── */
.ft_goo {
    position: absolute;
    width: 0;
    height: 0;
    overflow: hidden;
    pointer-events: none;
}

.ft--success .ft_inner::before {
    content: "";
    position: absolute;
    left: 0;
    top: 12%;
    bottom: 12%;
    width: 3px;
    border-radius: 0 2px 2px 0;
    background: var(--ft-color);
}

.ft--error .ft_icon {
    animation: ftScaleBreathe 2.6s ease-in-out 600ms infinite;
    will-change: transform, opacity;
}

@keyframes ftScaleBreathe {
    0%, 100% {
        transform: scale(1);
        opacity: 1;
    }

    50% {
        transform: scale(1.13);
        opacity: 0.78;
    }
}

.ft--warning .ft_icon {
    animation: ftBounce 480ms cubic-bezier(0.34, 1.56, 0.64, 1) 580ms both;
}

@keyframes ftBounce {
    0% {
        transform: scale(1);
    }

    45% {
        transform: scale(1.18);
    }

    75% {
        transform: scale(0.95);
    }

    100% {
        transform: scale(1);
    }
}

/* ── Mobile ──────────────────────────────────────────────── */
@media (max-width: 480px) {
    .ft_container {
        padding: 10px;
    }

    .ft {
        min-width: 0;
        max-width: calc(100vw - 20px);
        width: calc(100vw - 20px);
    }

    .ft_container--bottom-right,
    .ft_container--bottom-left {
        left: 0;
        right: 0;
        align-items: stretch;
    }
}

@media (prefers-reduced-motion: reduce) {
    .ft {
        transition: opacity 150ms;
        transform: none;
    }

    .ft--exit {
        animation: none;
        opacity: 0;
    }

    .ft--error .ft_icon,
    .ft--warning .ft_icon {
        animation: none;
    }
}

:root {
    --primary-color: #005461;
    --secondary-color: #018790;
    --light-bg: #f0fdfa;
    --white: #ffffff;
    --gray-bg: #f9fafb;
    --colorOcean: #005461;
    --colorOceanLight: #018790;
    --colorCoral: #00B7B5;
    --colorSand: #f0fdfa;
    --colorWhite: #ffffff;
    --colorSandDark: #ccfbf1;
    --colorMid: #018790;
    --fontDisplay: 'Pilcrow Rounded', sans-serif;
    /* sizes */
    --size-xxs: 0.5rem;
    --size-xs: 0.75rem;
    --size-sm: 0.875rem;
    --size-base: 1rem;
    --size-lg: 1.125rem;
    --size-xl: 1.25rem;
    --size-2xl: 1.5rem;
    --size-3xl: 1.875rem;
    --size-4xl: 2.25rem;
    --size-5xl: 3rem;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Sentient', sans-serif;
    color: var(--primary-color);
    line-height: 1.6;
    background-color: var(--white);
    overflow-x: hidden;
}

h1,
h2,
h3 {
    font-family: 'Pilcrow Rounded', serif;
    line-height: 1.2;
}

img {
    max-width: 100%;
    display: block;
}


.glassNav {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
    backdrop-filter: blur(12px);
    background: rgba(255,255,255,0.6);
    border-bottom: 1px solid rgba(0,0,0,0.05);
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(40px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.slideIn {
    opacity: 0;
    animation: slideUp 0.8s ease-out forwards;
}

.siteContainer {
    width: 90%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1rem;
}

.sectionPadding {
    padding: 3rem 0;
}

.sectionHeader {
    text-align: center;
    margin-bottom: 2.5rem;
}

.sectionHeader_title {
    font-size: 2.75rem;
    color: var(--primary-color);
    margin-bottom: 0.5rem;
}

.sectionHeader p {
    color: var(--primary-color);
    font-size: 0.95rem;
}

.actionButton {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    border-radius: 50px;
    font-weight: 600;
    text-decoration: none;
    transition: 0.3s ease;
    cursor: pointer;
    gap: 10px;
    font-size: 0.95rem;
}

.actionButton_primary {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: var(--white);
    border: none;
}

    .actionButton_primary::before {
        content: '';
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
        transition: left 0.5s;
    }

    .actionButton_primary:hover::before {
        left: 100%;
    }

    .actionButton_primary:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 24px rgba(0, 84, 97, 0.4);
    }

    .actionButton_primary:active {
        transform: translateY(0);
    }

.actionButton_outline {
    border: 1px solid var(--primary-color);
    color: var(--primary-color);
    background-color: transparent;
}

    .actionButton_outline:hover {
        background-color: var(--primary-color);
        color: var(--white);
    }

.svgIcon {
    width: 20px;
    height: 20px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.hero {
    min-height: 100vh;
    background: linear-gradient(160deg, var(--primary-color) 0%, var(--light-bg) 100%);
    position: relative;
    display: flex;
    align-items: center;
    overflow: hidden;
    padding-top: 72px;
}

.heroWaves {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 120px;
    overflow: hidden;
}

    .heroWaves svg {
        width: 100%;
        height: 100%;
    }

.heroBubbles {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.bubble {
    position: absolute;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.132);
    animation: float 8s ease-in-out infinite;
}

    .bubble:nth-child(1) {
        width: 300px;
        height: 300px;
        top: 10%;
        left: -80px;
        animation-delay: 0s;
    }

    .bubble:nth-child(2) {
        width: 180px;
        height: 180px;
        top: 40%;
        right: 5%;
        animation-delay: -3s;
    }

    .bubble:nth-child(3) {
        width: 120px;
        height: 120px;
        bottom: 25%;
        left: 30%;
        animation-delay: -5s;
    }

    .bubble:nth-child(4) {
        width: 240px;
        height: 240px;
        top: -60px;
        right: 25%;
        animation-delay: -1.5s;
    }

@keyframes float {

    0%, 100% {
        transform: translateY(0) scale(1);
    }

    50% {
        transform: translateY(-20px) scale(1.02);
    }
}

.heroContent {
    position: relative;
    z-index: 2;
    max-width: 1200px;
    margin: 0 auto;
    padding: 80px 40px 140px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.quote {
    font-size: 14px;
    opacity: 60%;
}

.heroTitle {
    font-family: 'Sentient', serif;
    font-size: clamp(2.8rem, 5vw, 4.2rem);
    color: var(--colorWhite);
    line-height: 1.1;
    font-weight: 700;
    margin-bottom: 10px;
}

.heroSubtitle {
    font-family: var(--fontDisplay);
    font-size: clamp(1.1rem, 2vw, 1.4rem);
    color: rgba(255, 255, 255, 0.7);
    font-style: italic;
    margin-bottom: 28px;
}

    .heroSubtitle em {
        color: #a5f3f0;
    }

.heroText {
    color: rgba(255, 255, 255, 0.75);
    font-size: 1rem;
    line-height: 1.7;
    margin-bottom: 36px;
    max-width: 520px;
}

.heroCtas {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}


.btnHeroOutline {
    background: transparent;
    color: var(--white);
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 700;
    padding: var(--size-xxs) var(--size-3xl);
    border-radius: 50px;
    border: 1px solid var(--white);
    transition: border-color 0.2s, background 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
}

    .btnHeroOutline:hover {
        border-color: white;
        background: white;
        color: var(--primary-color);
    }

.heroRight {
    position: relative;
    display: flex;
    justify-content: center;
}

.heroImgWrap {
    position: relative;
    width: 100%;
    max-width: 480px;
}

.heroImgMain {
    width: 100%;
    border-radius: 24px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.1);
    display: block;
    object-fit: cover;
    object-position: center;
    aspect-ratio: 7/7;
    background: linear-gradient(135deg, #005461 0%, #013d47 100%);
}

.heroImgFloat {
    position: absolute;
    bottom: -24px;
    left: -30px;
    background: var(--colorWhite);
    border-radius: 16px;
    padding: 16px 20px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
    display: flex;
    align-items: center;
    gap: 12px;
}

    .heroImgFloat .avatar {
        width: 48px;
        height: 48px;
        border-radius: 50%;
        background: linear-gradient(135deg, #a5f3f0, #005461);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 22px;
    }

.heroImgFloatText {
    font-size: 0.78rem;
}

    .heroImgFloatText strong {
        display: block;
        color: var(--colorOcean);
        font-weight: 700;
        font-size: 0.9rem;
    }

    .heroImgFloatText span {
        color: var(--colorMid);
    }

.imageSection {
    position: relative;
    width: 100%;
    line-height: 0;
}

.imageSection_topDivider,
.imageSection_bottomDivider {
    position: absolute;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 1;
    line-height: 0;
}

.imageSection_topDivider {
    top: 0;
}

.imageSection_bottomDivider {
    bottom: 0;
}

    .imageSection_topDivider svg,
    .imageSection_bottomDivider svg {
        display: block;
        width: 100%;
        height: clamp(40px, 6vw, 80px);
    }

.imageSection_img {
    width: 100%;
    height: clamp(220px, 45vw, 680px);
    object-fit: cover;
    object-position: center;
    display: block;
}

.intro {
    background: var(--white);
    padding: 80px 0 0;
    position: relative;
}

.intro_bottomDivider {
    line-height: 0;
    width: 100%;
}

    .intro_bottomDivider svg {
        display: block;
        width: 100%;
        height: clamp(40px, 6vw, 80px);
    }

.introInner {
    max-width: 1200px;
    margin: 0 auto;
    padding:  0 40px 40px 40px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.introText h2 {
    font-family: 'Sentient', sans-serif;
    font-size: 2.7rem;
    color: var(--colorOcean);
    margin-bottom: 20px;
    line-height: 0.9;
}

.introText p {
    color: var(--colorMid);
    line-height: 1.8;
    margin-bottom: 25px;
    font-size: 0.97rem;
}


.introText .ctaLink {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--colorOcean);
    color: white;
    text-decoration: none;
    padding: 12px 24px;
    border-radius: 50px;
    font-weight: 600;
    font-size: 0.9rem;
    margin-top: 12px;
    transition: background 0.2s, transform 0.2s;
}

    .introText .ctaLink:hover {
        background: var(--colorOceanLight);
        transform: translateY(-1px);
    }

.introImg {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 60px rgba(0, 0, 0, 0.15);
    aspect-ratio: 4/3;
    background: linear-gradient(135deg, #ccfbf1 0%, #f0fdfa 100%);
    position: relative;
}

    .introImg img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        display: block;
    }

.smileMakeWaves {
    position: absolute;
    bottom: 16px;
    right: 16px;
    background: var(--colorCoral);
    color: white;
    font-family: var(--fontDisplay);
    font-style: italic;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 8px 14px;
    border-radius: 50px;
}

.familiesSection {
    position: relative;
    background: linear-gradient(180deg, var(--primary-color) -170%, var(--light-bg) 55%);
    padding-bottom: 80px;
}

.familiesSection_topDivider {
    line-height: 0;
    width: 100%;
}

    .familiesSection_topDivider svg {
        display: block;
        width: 100%;
        height: clamp(40px, 6vw, 80px);
    }

.familiesSection_inner {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    padding: 60px 24px 20px;
    text-align: center;
}

.familiesSection_bgLogo {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: clamp(180px, 30vw, 480px);
    opacity: 0.07;
    pointer-events: none;
    z-index: 0;
}

    .familiesSection_bgLogo svg {
        width: 100%;
        height: auto;
        display: block;
    }

.familiesSection_title {
    font-family: 'Sentient', sans-serif;
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    color: var(--colorOcean);
    margin-bottom: clamp(32px, 5vw, 60px);
    position: relative;
    z-index: 1;
}

.familiesSection_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(16px, 3vw, 40px);
    position: relative;
    z-index: 1;
}

.familiesCard {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 16px;
    text-align: center;
}

.familiesCard_icon {
    font-size: clamp(4rem, 4vw, 2.8rem);
    color: var(--colorOcean);
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: clamp(52px, 7vw, 72px);
    height: clamp(52px, 7vw, 72px);
}

.familiesCard_title {
    font-family: 'Sentient', sans-serif;
    font-size: clamp(0.95rem, 1.6vw, 1.15rem);
    color: var(--colorOcean);
    margin-bottom: 14px;
}

.familiesCard_text {
    font-size: clamp(0.82rem, 1.2vw, 0.93rem);
    color: var(--colorMid);
    line-height: 1.75;
}

@media (max-width: 768px) {
    .familiesSection_grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .familiesCard {
        max-width: 480px;
        margin: 0 auto;
    }
}

.logos {
    background: var(--colorWhite);
    padding: 40px;
    border-bottom: 1px solid var(--colorSandDark);
}

.logosInner {
    max-width: 1000px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
}

.logoPill {
    background: var(--colorSand);
    padding: 10px 22px;
    border-radius: 50px;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--colorMid);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--colorSandDark);
}

.gallery {
    background: var(--colorSand);
    padding: 90px 40px;
}

.galleryGrid {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.baCard {
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0, 84, 97, 0.1);
    background: var(--colorWhite);
}


.baSlider {
    position: relative;
    aspect-ratio: 4/3;
    overflow: hidden;
    cursor: col-resize;
    user-select: none;
    border-radius: 0;
}


.baSliderAfter {
    position: absolute;
    inset: 0;
}


.baSliderBefore {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    overflow: hidden;
}


.ba-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}


.ba-before {
    left: 0;
    width: var(--slider-w, 100%);
    max-width: none;
}


.baSliderHandle {
    position: absolute;
    top: 0;
    bottom: 0;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 10;
    pointer-events: none;
}

    .baSliderHandle > * {
        pointer-events: auto;
    }

.baHandleLine {
    flex: 1;
    width: 2px;
    background: rgba(255,255,255,0.85);
    box-shadow: 0 0 6px rgba(0,0,0,0.25);
}

.baHandleBtn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 3px solid white;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    box-shadow: 0 4px 16px rgba(0,0,0,0.25);
    cursor: col-resize;
    flex-shrink: 0;
    transition: transform 0.15s, background 0.15s;
}

.baSlider:hover .baHandleBtn {
    transform: scale(1.1);
    background: var(--colorCoral);
}

.baSliderLabel {
    position: absolute;
    top: 14px;
    background: rgba(0,0,0,0.55);
    color: white;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 5px 11px;
    border-radius: 50px;
    z-index: 8;
    opacity: 0;
    transition: opacity 0.25s;
    pointer-events: none;
    backdrop-filter: blur(4px);
}

    .baSliderLabel.visible {
        opacity: 1;
    }

.baLabelBefore {
    left: 12px;
}

.baLabelAfter {
    right: 12px;
}

.baLabel {
    padding: 14px 18px;
    font-size: 0.78rem;
    color: var(--colorMid);
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
}

    .baLabel::before {
        content: '';
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--colorCoral);
        flex-shrink: 0;
    }

.faq {
   padding-top:150px;
   padding-right: 40px;
   padding-left: 40px;
}

.faqInner {
    max-width: 860px;
    margin: 0 auto;
}

.faqItem {
    border-bottom: 1px solid var(--colorSandDark);
}

.faqQ {
    width: 100%;
    text-align: left;
    padding: 22px 0;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

    .faqQ span {
        font-weight: 600;
        font-size: 1rem;
        color: var(--colorDark);
        font-family: var(--fontBody);
        text-align: left;
    }

.faqChevron {
    color: var(--colorOcean);
    font-size: 1.2rem;
    flex-shrink: 0;
    transition: transform 0.3s;
}

.faqA {
    display: none;
    padding: 0 0 22px;
    color: var(--colorMid);
    font-size: 0.92rem;
    line-height: 1.8;
}

.faqItem.open .faqChevron {
    transform: rotate(180deg);
}

.faqItem.open .faqA {
    display: block;
}

.google_map {
    width: 100%;
    height: 100%;
    border-radius: 16px;
}

.servicesSection {
    background-color: var(--light-bg);
}

.servicesSection_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

.serviceCard {
    background: var(--white);
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
    transition: all 0.3s ease;
}

    .serviceCard:hover {
        transform: translateY(-5px);
        box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
    }

.serviceCard_img {
    height: 200px;
    object-fit: cover;
    width: 100%;
}

.serviceCard_content {
    padding: 1.5rem;
    flex: 1;
}

.serviceCard_content_title {
    color: var(--primary-color);
    margin-bottom: 1rem;
    font-size: 1.25rem;
}

.serviceChecklist {
    list-style: none;
}

    .serviceChecklist li {
        display: flex;
        align-items: flex-start;
        gap: 10px;
        margin-bottom: 10px;
        font-size: 0.95rem;
        color: var(--primary-color);
        line-height: 1.5;
    }

        .serviceChecklist li::before {
            content: "";
            width: 18px;
            height: 18px;
            min-width: 18px;
            margin-top: 2px;
            background-color: var(--secondary-color);
            mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center;
            -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center;
        }

.locationSection {
    background-color: var(--gray-bg);
}

.locationSection_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

.locationSection_mapBox {
    height: 350px;
    border-radius: 16px;
    border: 2px solid var(--colorOcean);
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
}

    .locationSection_mapBox:hover {
        border-color: var(--colorOceanLight);
        box-shadow: 0 5px 40px var(--colorOceanLight);
    }

    .location_intro {
        margin: 1rem 0 1.5rem;
        font-size: 1rem;
        color: var(--primary-color);
        line-height: 1.6;
    }

.location_item {
    display: flex;
    gap: 15px;
    margin-bottom: 1.5rem;
    align-items: flex-start;
}

.location_icon {
    min-width: 24px;
    margin-top: 2px;
    color: var(--secondary-color);
}

.location_item strong {
    color: var(--primary-color);
}

.siteFooter {
    padding: 3rem 0;
    text-align: center;
    border-top: 1px solid #e5e7eb;
    background-color: var(--white);
}

.footer_title {
    font-size: 1.5rem;
    color: var(--primary-color);
    margin-bottom: 0.5rem;
}

.footer_text {
    font-size: 0.9rem;
    color: var(--primary-color);
    line-height: 1.6;
}


@media (min-width: 475px) {
    .siteContainer {
        width: 88%;
    }

    .heroSection_title1 {
        font-size: 2.5rem;
    }

    .causesDeck {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.25rem;
    }

    .causeCard_img {
        height: 160px;
    }
}

@media (min-width: 640px) {
    .sectionPadding {
        padding: 4rem 0;
    }

    .sectionHeader {
        margin-bottom: 3rem;
    }


    .heroSection_title1 {
        font-size: 2.75rem;
    }

    .heroSection_desc {
        font-size: 1.05rem;
    }

    .heroSection_imageBox {
        height: 320px;
    }

    .servicesSection_grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.75rem;
    }

    .causesDeck {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }

    .causeCard_img {
        height: 180px;
    }
}

@media (max-width: 768px) {
    .stickyBottom {
        display: flex;
    }

    .navLinks,
    .btnCall {
        display: none;
    }

    .heroContent,
    .introInner,
    .paymentInner,
    .locationInner {
        grid-template-columns: 1fr;
    }

    .galleryGrid,
    .whyGrid {
        grid-template-columns: 1fr;
    }

    .gallery {
        padding: 60px 20px;
    }

    .galleryGrid {
        max-width: 480px;
        margin: 0 auto;
        gap: 16px;
    }

    .baSlider {
        aspect-ratio: 4/2;
    }

    .techGrid {
        grid-template-columns: 1fr;
    }

    .footerNav {
        gap: 0;
    }

    .footerToothIcon {
        font-size: 6rem;
        right: 20px;
    }

    nav {
        padding: 0 20px;
    }

    .heroContent {
        padding: 60px 20px 120px;
    }
}


@media (min-width: 850px) {
    .siteContainer {
        width: 85%;
    }

    .sectionPadding {
        padding: 4.5rem 0;
    }

    .sectionHeader_title {
        font-size: 2.75rem;
    }

    .heroSection {
        min-height: 70vh;
        padding: 3rem 0;
    }

    .heroSection_title1 {
        font-size: 3.25rem;
    }

    .heroSection_desc {
        font-size: 1.1rem;
    }

    .heroSection_imageBox {
        height: 360px;
    }


    .causesDeck {
        position: relative;
        height: 200px;
        display: flex;
        justify-content: center;
        align-items: center;
        margin: 4rem auto 0;
        overflow: visible;
        max-width: 100%;
    }

    .causeCard {
        position: absolute;
        left: 50%;
        width: 155px;
        height: 165px;
        transform: translateX(calc(-80% + var(--i) * 20px)) rotate(calc(var(--i) * -5deg));
        transition: transform 0.55s ease;
    }

    .causesDeck:hover .causeCard {
        transform: translateX(calc(-50% + var(--i) * 175px - 437.5px)) rotate(0deg);
    }

    .causeCard:hover {
        transform: translateX(calc(-50% + var(--i) * 175px - 437.5px)) rotate(0deg) translateY(-10px);
    }

    .causeCard_img {
        height: 115px;
    }

    .locationSection_mapBox {
        height: 400px;
    }
}

@media (min-width: 1024px) {

    .causesDeck {
        height: 210px;
    }

    .causeCard {
        width: 165px;
        height: 175px;
        transform: translateX(calc(-80% + var(--i) * 21px)) rotate(calc(var(--i) * -5deg));
    }

    .causesDeck:hover .causeCard {
        transform: translateX(calc(-50% + var(--i) * 185px - 462.5px)) rotate(0deg);
    }

    .causeCard:hover {
        transform: translateX(calc(-50% + var(--i) * 185px - 462.5px)) rotate(0deg) translateY(-10px);
    }

    .causeCard_img {
        height: 125px;
    }
}

@media (min-width: 1176px) {
    .sectionPadding {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .sectionHeader {
        margin-bottom: 4rem;
    }


    .heroSection {
        min-height: 90vh;
        padding: 4rem 0;
    }

    .heroSection_grid {
        grid-template-columns: 1.1fr 0.9fr;
        gap: 3rem;
    }

    .heroSection_title1 {
        font-size: 3.5rem;
    }

    .heroSection_imageBox {
        height: 400px;
    }

    .servicesSection_grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 2rem;
    }

    .serviceCard_img {
        height: 220px;
    }

    .causesSection {
        padding: 5rem 0;
    }

    .causesDeck {
        height: 230px;
    }

    .causeCard {
        width: 190px;
        height: 195px;
        transform: translateX(calc(-80% + var(--i) * 24px)) rotate(calc(var(--i) * -5deg));
    }

    .causesDeck:hover .causeCard {
        transform: translateX(calc(-50% + var(--i) * 215px - 537.5px)) rotate(0deg);
    }

    .causeCard:hover {
        transform: translateX(calc(-50% + var(--i) * 215px - 537.5px)) rotate(0deg) translateY(-10px);
    }

    .causeCard_img {
        height: 140px;
    }

    .locationSection_grid {
        grid-template-columns: 1fr 1fr;
        gap: 3rem;
        align-items: center;
    }

    .locationSection_mapBox {
        height: 450px;
    }
}

@media (min-width: 1280px) {
    .heroSection {
        min-height: 100vh;
    }

    .siteContainer {
        max-width: 1280px;
    }

    .sectionHeader_title {
        font-size: 2.75rem;
    }

    .heroSection_title1 {
        font-size: 3.75rem;
    }

    .heroSection_imageBox {
        height: 420px;
    }

    .sectionPadding {
        padding-bottom: 6rem;
    }

    .causesSection {
        padding: 6rem 0;
    }

    .causesDeck {
        height: 250px;
    }

    .causeCard {
        width: 215px;
        height: 210px;
        transform: translateX(calc(-80% + var(--i) * 27px)) rotate(calc(var(--i) * -5deg));
    }

    .causesDeck:hover .causeCard {
        transform: translateX(calc(-50% + var(--i) * 242px - 605px)) rotate(0deg);
    }

    .causeCard:hover {
        transform: translateX(calc(-50% + var(--i) * 242px - 605px)) rotate(0deg) translateY(-10px);
    }

    .causeCard_img {
        height: 155px;
    }

    .serviceCard_img {
        height: 240px;
    }

    .locationSection_mapBox {
        height: 480px;
    }
}

@media (min-width: 1536px) {
    .heroSection {
        min-height: 100vh;
    }

    .siteContainer {
        max-width: 1400px;
    }

    .sectionHeader_title {
        font-size: 2.7rem;
    }

    .heroSection {
        min-height: 80vh;
    }

    .sectionPadding {
        padding-top: 7rem;
        padding-bottom: 7rem;
    }

    .causesSection {
        padding: 7rem 0;
    }

    .heroSection_grid {
        grid-template-columns: 1.2fr 0.8fr;
        gap: 4rem;
    }

    .heroSection_title1 {
        font-size: 4rem;
    }

    .heroSection_desc {
        font-size: 1.15rem;
        max-width: 600px;
    }

    .heroSection_imageBox {
        height: 450px;
    }

    .servicesSection_grid {
        gap: 2.25rem;
    }

    .serviceCard_img {
        height: 260px;
    }

    .locationSection_grid {
        gap: 4rem;
    }

    .locationSection_mapBox {
        height: 500px;
    }
}

@media (min-width: 1680px) {
    .heroSection {
        min-height: 90vh;
    }

    .sectionPadding {
        padding-top: 7rem;
        padding-bottom: 7rem;
    }

    .causesSection {
        padding: 7rem 0;
    }

    .causesDeck {
        height: 290px;
    }

    .causeCard {
        width: 265px;
        height: 245px;
        transform: translateX(calc(-80% + var(--i) * 33px)) rotate(calc(var(--i) * -5deg));
    }

    .causesDeck:hover .causeCard {
        transform: translateX(calc(-50% + var(--i) * 297px - 742.5px)) rotate(0deg);
    }

    .causeCard:hover {
        transform: translateX(calc(-50% + var(--i) * 297px - 742.5px)) rotate(0deg) translateY(-10px);
    }

    .causeCard_img {
        height: 190px;
    }
}


@media (min-width: 1920px) {
    .heroSection {
        min-height: 90vh;
    }

    .sectionPadding {
        padding-top: 8rem;
        padding-bottom: 7rem;
    }

    .causesSection {
        padding: 8rem 0;
    }

    .causesDeck {
        height: 310px;
    }

    .causeCard {
        width: 290px;
        height: 260px;
        transform: translateX(calc(-80% + var(--i) * 36px)) rotate(calc(var(--i) * -5deg));
    }

    .causesDeck:hover .causeCard {
        transform: translateX(calc(-50% + var(--i) * 325px - 812.5px)) rotate(0deg);
    }

    .causeCard:hover {
        transform: translateX(calc(-50% + var(--i) * 325px - 812.5px)) rotate(0deg) translateY(-10px);
    }

    .causeCard_img {
        height: 205px;
    }
}


@media print {
    .heroSection_btnGroup,
    .actionButton {
        display: none;
    }
}

:root {
    --primary-color: #005461;
    --secondary-color: #018790;
    --accent-color: #00B7B5;
    --text-primary: #1F2937;
    --text-secondary: #6B7280;
    --bg-primary: #F9FAFB;
    --bg-secondary: #FFFFFF;
    --border-color: #E5E7EB;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Pilcrow Rounded', sans-serif;
    background-color: white;
    color: var(--text-primary);
    line-height: 1.7;
    min-height: 100vh;
}

.policyContainer {
    max-width: 1080px;
    margin: 0 auto;
    padding: 4rem 1.5rem;
}

.policyHeader {
    margin-bottom: 3rem;
}

.policyHeader_title {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 0.5rem;
    letter-spacing: -0.02em;
    line-height: 1.15;
}

.policyHeader_subtitle {
    font-size: 1.0625rem;
    font-weight: 400;
    color: var(--text-secondary);
}

.policyLayout {
    display: flex;
    gap: 3rem;
    align-items: flex-start;
}

.policyToc {
    width: 220px;
    flex-shrink: 0;
    position: sticky;
    top: 2.5rem;
    max-height: calc(100vh - 5rem);
    overflow-y: auto;
}

.policyToc_title {
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-secondary);
    margin-bottom: 0.875rem;
}

.policyToc_list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.policyToc_item a {
    display: block;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    text-decoration: none;
    padding: 0.3rem 0.625rem;
    border-left: 2px solid var(--border-color);
    line-height: 1.45;
    transition: color 0.15s, border-color 0.15s;
}

.policyToc_item a:hover {
    color: var(--secondary-color);
    border-left-color: var(--secondary-color);
}

.policyToc_item.is-active a {
    color: var(--secondary-color);
    font-weight: 600;
    border-left-color: var(--accent-color);
}

.policyToc_item.is-sub a {
    padding-left: 1.125rem;
    font-size: 0.75rem;
    color: #9CA3AF;
}

.policyToc_item.is-sub.is-active a {
    color: var(--secondary-color);
    font-weight: 600;
    border-left-color: var(--accent-color);
}

.policyMain {
    flex: 1;
    min-width: 0;
}

.policyContent {
    padding: 0;
}

.policySection {
    margin-bottom: 3.5rem;
}

.policySection:last-child {
    margin-bottom: 0;
}

.policySection_title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--border-color);
}

.policySection_text {
    font-size: 0.9375rem;
    color: var(--text-secondary);
    margin-bottom: 2rem;
    line-height: 1.8;
}

.policySubsection {
    margin-bottom: 1.75rem;
}

.policySubsection:last-child {
    margin-bottom: 0;
}

.policySubsection_title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--primary-color);
    margin-bottom: 0.375rem;
}

.policySubsection_text {
    font-size: 0.9375rem;
    color: var(--text-secondary);
    line-height: 1.8;
}

.policyArticle {
    margin-bottom: 2.5rem;
}

.policyArticle:last-child {
    margin-bottom: 0;
}

.policyArticle_number {
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--primary-color);
    margin-bottom: 1.25rem;
}

.policyArticle_intro {
    font-size: 0.9375rem;
    color: var(--text-secondary);
    font-style: italic;
    margin-bottom: 1.25rem;
}

.policyItem {
    margin-bottom: 1.5rem;
}

.policyItem:last-child {
    margin-bottom: 0;
}

.policyItem_title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--secondary-color);
    margin-bottom: 0.25rem;
}

.policyItem_text {
    font-size: 0.9375rem;
    color: var(--text-secondary);
    line-height: 1.8;
}

.policyItem_list {
    list-style: none;
    padding: 0;
    margin-top: 0.75rem;
}

.policyItem_list li {
    font-size: 0.9375rem;
    color: var(--text-secondary);
    line-height: 1.8;
    padding: 0.375rem 0 0.375rem 1.125rem;
    position: relative;
    border-bottom: 1px solid var(--border-color);
}

.policyItem_list li:last-child {
    border-bottom: none;
}

.policyItem_list li::before {
    content: "–";
    color: var(--accent-color);
    position: absolute;
    left: 0;
}

.policyItem_list li strong {
    color: var(--text-primary);
    font-weight: 600;
}

.tocToggle {
    display: none;
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 1000;
    background: var(--secondary-color);
    color: white;
    border: none;
    border-radius: 50%;
    width: 42px;
    height: 42px;
    font-size: 1rem;
    box-shadow: 0 2px 10px rgba(1, 135, 144, 0.3);
    cursor: pointer;
    align-items: center;
    justify-content: center;
}

.tocOverlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.25);
    z-index: 998;
}

.tocOverlay.is-open { display: block; }

@media (max-width: 820px) {
    .policyLayout { flex-direction: column; }

    .policyToc {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 250px;
        height: 100vh;
        max-height: 100vh;
        background: white;
        padding: 2rem 1.5rem;
        z-index: 999;
        border-right: 1px solid var(--border-color);
    }

    .policyToc.is-open { display: block; }
    .tocToggle { display: flex; }
}

@media (min-width: 640px) {
    .policyContainer { padding: 5rem 2rem; }
    .policyHeader_title { font-size: 3rem; }
}

@media (min-width: 1024px) {
    .policyContainer { padding: 5rem 2rem; }
    .policyHeader_title { font-size: 3.25rem; }
}

@media print {
    body { background: white; }
    .policyContainer { max-width: 100%; padding: 1rem; }
    .policyToc { display: none; }
    .policyLayout { display: block; }
}
:root {
    --cb-pri: #005461;
    --cb-sec: #018790;
    --cb-acc: #00B7B5;
    --cb-bg: #F2FAFA;
    --cb-panel: #ffffff;
    --cb-text: #0f172a;
    --cb-muted: rgba(0,84,97,0.52);
    --cb-border: rgba(0,84,97,0.11);
    --cb-shadow: 0 8px 40px rgba(0,84,97,0.18);
    --cb-r: 18px;
    --cb-font: "Pilcrow Rounded", system-ui, sans-serif;
    /* sizes */
    --size-xxs: 0.5rem;
    --size-xs: 0.75rem;
    --size-sm: 0.875rem;
    --size-base: 1rem;
    --size-lg: 1.125rem;
    --size-xl: 1.25rem;
    --size-2xl: 1.5rem;
    --size-3xl: 1.875rem;
    --size-4xl: 2.25rem;
    --size-5xl: 3rem;
}

.cb-chips-container {
    padding: 10px;
    background: #f9f9f9;
    border-top: 1px solid #eee;
    max-height: 130px; 
    overflow-y: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.cb-chips-label {
    width: 100%;
    font-size: var(--size-xs);
    color: #888;
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cb-chips {
    padding: 10px 12px 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    flex-shrink: 0;
}

.cb-chip {
    background: rgba(0,183,181,0.09);
    border: 1px solid rgba(0,183,181,0.25);
    border-radius: 99px;
    padding: 5px 11px;
    font-size: var(--size-xs);
    font-weight: 700;
    color: var(--cb-pri);
    cursor: pointer;
    font-family: var(--cb-font);
    transition: background 130ms, border-color 130ms, transform 130ms;
    white-space: nowrap;
}

    .cb-chip:hover {
        color: var(--cb-pri);
        background: rgba(0,183,181,0.18);
        border-color: rgba(0,183,181,0.50);
        transform: translateY(-1px);
    }

/* ── FAB ─────────────────────────────────────────────────── */
#cb-fab {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 9998;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: none;
    background: linear-gradient(135deg, var(--cb-pri), var(--cb-acc));
    color: #fff;
    cursor: pointer;
    box-shadow: 0 6px 24px rgba(0,84,97,0.40);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 220ms cubic-bezier(0.34,1.56,0.64,1), box-shadow 200ms ease;
    outline: none;
    font-family: var(--cb-font);
}

    #cb-fab:hover {
        transform: scale(1.10);
        box-shadow: 0 12px 32px rgba(0,84,97,0.48);
    }

    #cb-fab:active {
        transform: scale(0.94);
    }

    #cb-fab svg {
        width: 27px;
        height: 27px;
        position: absolute;
        transition: opacity 180ms ease, transform 180ms ease;
    }

    #cb-fab .cb-ico-chat {
        opacity: 1;
        transform: scale(1) rotate(0deg);
    }

    #cb-fab .cb-ico-close {
        opacity: 0;
        transform: scale(0.4) rotate(-90deg);
    }

    #cb-fab.cb-open .cb-ico-chat {
        opacity: 0;
        transform: scale(0.4) rotate(90deg);
    }

    #cb-fab.cb-open .cb-ico-close {
        opacity: 1;
        transform: scale(1) rotate(0deg);
    }

    #cb-fab .cb-dot {
        position: absolute;
        top: 3px;
        right: 3px;
        width: 13px;
        height: 13px;
        background: #f87171;
        border: 2.5px solid #fff;
        border-radius: 50%;
        animation: cbPulse 2.2s ease-in-out infinite;
        transition: opacity 200ms;
    }

    #cb-fab.cb-open .cb-dot {
        opacity: 0;
        pointer-events: none;
    }

@keyframes cbPulse {
    0%,100% {
        box-shadow: 0 0 0 0 rgba(248,113,113,0.55);
    }

    60% {
        box-shadow: 0 0 0 7px rgba(248,113,113,0);
    }
}

#cb-window {
    position: fixed;
    bottom: 100px; 
    right: 28px;
    z-index: 9999;
    width: 310px; 
    height: 420px; 
    background: var(--cb-panel);
    border-radius: var(--cb-r);
    box-shadow: var(--cb-shadow);
    border: 1px solid var(--cb-border);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    font-family: var(--cb-font);
    opacity: 0;
    transform: translateY(18px) scale(0.95);
    pointer-events: none;
    transition: opacity 220ms cubic-bezier(0.4,0,0.2,1), transform 240ms cubic-bezier(0.34,1.2,0.64,1);
    transform-origin: bottom right;
}

    #cb-window.cb-open {
        opacity: 1;
        transform: translateY(0) scale(1);
        pointer-events: all;
    }

/* ── Header ──────────────────────────────────────────────── */
.cb-header {
    background: linear-gradient(135deg, var(--cb-pri) 0%, var(--cb-sec) 100%);
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 11px;
    flex-shrink: 0;
}

.cb-header-avatar {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: rgba(255,255,255,0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

    .cb-header-avatar svg {
        width: 20px;
        color: #fff;
    }

.cb-header-info {
    flex: 1;
    min-width: 0;
}

.cb-header-name {
    font-size: var(--size-base);
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.01em;
    margin: 0 0 1px;
}

.cb-header-status {
    font-size: var(--size-xs);
    font-weight: 600;
    color: rgba(255,255,255,0.72);
    display: flex;
    align-items: center;
    gap: 5px;
}

.cb-status-dot {
    width: 7px;
    height: 7px;
    background: #4ade80;
    border-radius: 50%;
    animation: cbStatusBlink 2.5s ease-in-out infinite;
}

@keyframes cbStatusBlink {
    0%,100% {
        opacity: 1;
    }

    50% {
        opacity: 0.4;
    }
}

.cb-header-close {
    background: rgba(255,255,255,0.15);
    border: none;
    border-radius: 8px;
    width: 30px;
    height: 30px;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 140ms;
    flex-shrink: 0;
}

    .cb-header-close:hover {
        background: rgba(255,255,255,0.26);
    }

    .cb-header-close svg {
        width: 16px;
    }

/* ── Messages ────────────────────────────────────────────── */
.cb-messages {
    flex: 1;
    overflow-y: auto;
    padding: 12px 14px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    scroll-behavior: smooth;
}

    .cb-messages::-webkit-scrollbar {
        width: 4px;
    }

    .cb-messages::-webkit-scrollbar-thumb {
        background: rgba(0,84,97,0.15);
        border-radius: 99px;
    }

.cb-msg {
    display: flex;
    gap: 8px;
    align-items: flex-end;
    animation: cbMsgIn 0.26s cubic-bezier(0.34,1.3,0.64,1) both;
    max-width: 100%;
}

@keyframes cbMsgIn {
    from {
        opacity: 0;
        transform: translateY(10px) scale(0.96);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.cb-msg.bot {
    align-self: flex-start;
}

.cb-msg.user {
    align-self: flex-end;
    flex-direction: row-reverse;
}

.cb-bot-avatar {
    width: 28px;
    height: 28px;
    border-radius: 9px;
    background: linear-gradient(135deg, var(--cb-pri), var(--cb-acc));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-bottom: 2px;
}

    .cb-bot-avatar svg {
        width: 14px;
        color: #fff;
    }

.cb-bubble-bot {
    background: var(--cb-bg);
    border: 1px solid var(--cb-border);
    border-radius: 14px 14px 14px 4px;
    padding: 9px 13px;
    font-size: var(--size-sm);
    font-weight: 500;
    color: var(--cb-text);
    line-height: 1.58;
    max-width: 210px; 
    word-break: break-word;
}

.cb-bubble-user {
    background: linear-gradient(135deg, var(--cb-pri), var(--cb-sec));
    border-radius: 14px 14px 4px 14px;
    padding: 9px 13px;
    font-size: var(--size-xs);
    font-weight: 600;
    color: #fff;
    line-height: 1.58;
    max-width: 255px;
    word-break: break-word;
}

.cb-msg.bot .cb-bubble-bot.cb-typing-bubble {
    padding: 11px 16px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.cb-typing-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--cb-acc);
    animation: cbDot 1.3s ease-in-out infinite;
    display: inline-block;
    flex-shrink: 0;
}

    .cb-typing-dot:nth-child(2) {
        animation-delay: 0.18s;
    }

    .cb-typing-dot:nth-child(3) {
        animation-delay: 0.36s;
    }

@keyframes cbDot {
    0%,80%,100% {
        transform: scale(0.65);
        opacity: 0.35;
    }

    40% {
        transform: scale(1.15);
        opacity: 1;
    }
}

/* ── Input bar ───────────────────────────────────────────── */
.cb-inputbar {
    padding: 10px 12px 11px;
    border-top: 1px solid var(--cb-border);
    display: flex;
    align-items: flex-end;
    gap: 8px;
    background: #fff;
    flex-shrink: 0;
}

#cb-input {
    flex: 1;
    background: var(--cb-bg);
    border: 1.5px solid rgba(0,84,97,0.13);
    border-radius: 12px;
    padding: 9px 13px;
    font-size: 13px;
    font-family: var(--cb-font);
    color: var(--cb-text);
    outline: none;
    resize: none;
    max-height: 88px;
    line-height: 1.5;
    transition: border-color 130ms, box-shadow 130ms;
    overflow-y: auto;
}

    #cb-input::placeholder {
        color: rgba(0,84,97,0.32);
    }

    #cb-input:focus {
        border-color: rgba(0,183,181,0.55);
        box-shadow: 0 0 0 3px rgba(0,183,181,0.11);
    }

#cb-send {
    width: 38px;
    height: 38px;
    border-radius: 11px;
    border: none;
    background: linear-gradient(135deg, var(--cb-pri), var(--cb-sec));
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 3px 10px rgba(0,84,97,0.28);
    transition: transform 150ms, box-shadow 150ms, opacity 150ms;
}

    #cb-send:hover {
        transform: translateY(-1px);
        box-shadow: 0 6px 16px rgba(0,84,97,0.38);
    }

    #cb-send:active {
        transform: scale(0.93);
    }

    #cb-send:disabled {
        opacity: 0.38;
        cursor: not-allowed;
        transform: none;
        box-shadow: none;
    }

    #cb-send svg {
        width: 17px;
    }

/* ── Footer ──────────────────────────────────────────────── */
.cb-footer {
    text-align: center;
    font-size: 10px;
    font-weight: 600;
    color: var(--cb-muted);
    padding: 0 12px 8px;
    background: #fff;
    letter-spacing: 0.01em;
}

/* ── Mobile ──────────────────────────────────────────────── */
@media (max-width: 480px) {
    #cb-window {
        right: 10px;
        bottom: 88px;
        width: calc(100vw - 20px);
        height: 72vh;
    }

    #cb-fab {
        bottom: 18px;
        right: 14px;
    }
}

@media (prefers-reduced-motion: reduce) {
    #cb-fab, #cb-window, .cb-msg, .cb-chip,
    .cb-typing-dot, .cb-status-dot, .cb-dot {
        animation: none;
        transition: none;
    }
}

:root {
    --primary-color: #005461;
    --secondary-color: #018790;
    --accent-color: #00B7B5;
    --background-color: #F4F4F4;
    --dark-color: #121212;
    --size-xxs: 0.5rem;
    --size-xs: 0.75rem;
    --size-sm: 0.875rem;
    --size-base: 1rem;
    --size-lg: 1.125rem;
    --size-xl: 1.25rem;
    --size-2xl: 1.5rem;
    --size-3xl: 1.875rem;
    --size-4xl: 2.25rem;
    --size-5xl: 3rem;
    --size-6xl: 3.75rem;
    --size-7xl: 4.5rem;
    --size-8xl: 6rem;
    --size-9xl: 8rem;
    --size-10xl: 10rem;
    --sidebar-width: 260px;
    --sidebar-collapsed-width: 80px;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background-color: var(--background-color);
    overflow-x: hidden;
}

[ng-cloak] {
    display: none !important;
}

a {
    color: var(--accent-color);
}

.icon {
    width: 24px;
    height: 24px;
}

h1, h2, h3 {
    font-family: 'Sentient', sans-serif;
    font-weight: 700;
    color: var(--primary-color);
    letter-spacing: -0.5px;
}

.root_layout {
    display: flex;
    min-height: 80vh;
    background-color: var(--background-color);
}

.sidebar_overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 999;
    opacity: 0;
    transition: opacity 0.3s;
}

    .sidebar_overlay.active {
        display: block;
        opacity: 1;
    }

.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: var(--sidebar-width);
    background-color: var(--background-color);
    display: flex;
    flex-direction: column;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 1000;
    transform: translateX(-100%);
}

    .sidebar.active {
        transform: translateX(0);
        border-top-right-radius: 12px;
        border-bottom-right-radius: 12px;
    }

.sidebar_header {
    padding: 1.5rem;
    border-bottom: 1px solid #e2e8f0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 80px;
}

.sidebar_logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none;
    transition: all 0.3s;
}

.logo_icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.25rem;
    flex-shrink: 0;
}

.logo_text {
    font-family: 'Pilcrow Rounded', sans-serif;
    font-size: var(--size-xl);
    font-weight: 700;
    color: var(--primary-color);
    white-space: nowrap;
    transition: opacity 0.3s;
}

.sidebar_toggle {
    width: 32px;
    height: 32px;
    background: var(--background-color);
    border: none;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--primary-color);
    transition: all 0.3s;
}

    .sidebar_toggle:hover {
        background: var(--accent-color);
        color: white;
    }

.sidebar_nav {
    flex: 1;
    padding: 1rem 0;
    overflow-y: auto;
    overflow-x: hidden;
}

    .sidebar_nav::-webkit-scrollbar {
        width: 4px;
    }

    .sidebar_nav::-webkit-scrollbar-thumb {
        background: #cbd5e0;
        border-radius: 2px;
    }

.nav_section {
    margin-bottom: 1.5rem;
}

.nav_section_title {
    padding: 0 1.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    color: #94a3b8;
    letter-spacing: 0.5px;
    white-space: nowrap;
    transition: opacity 0.3s;
}

.nav_item {
    display: flex;
    align-items: center;
    padding: 0.75rem 1.5rem;
    color: #64748b;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    white-space: nowrap;
}

    .nav_item::before {
        content: '';
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 4px;
        height: 0;
        background: linear-gradient(180deg, var(--primary-color), var(--accent-color));
        border-radius: 0 4px 4px 0;
        transition: height 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .nav_item:hover {
        background: linear-gradient(90deg, rgba(0, 183, 181, 0.08), transparent);
        color: var(--primary-color);
    }

        .nav_item:hover::before {
            height: 70%;
        }

    .nav_item.active {
        background: linear-gradient(90deg, rgba(0, 183, 181, 0.12), transparent);
        color: var(--primary-color);
        font-weight: 600;
    }

        .nav_item.active::before {
            height: 70%;
        }

.nav_icon {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    margin-right: 1rem;
    flex-shrink: 0;
    transition: transform 0.3s;
}

.nav_item:hover .nav_icon {
    transform: scale(1.1);
}

.nav_text {
    transition: opacity 0.3s;
}

@keyframes navPulse {
    0%, 100% {
        opacity: 1;
    }

    50% {
        opacity: 0.4;
    }
}

.nav_skeleton_item {
    cursor: default;
    pointer-events: none;
}

.nav_skeleton_icon {
    display: inline-block;
    width: 20px;
    height: 20px;
    border-radius: 6px;
    background: #e2e8f0;
    margin-right: 1rem;
    flex-shrink: 0;
    animation: navPulse 1.4s ease-in-out infinite;
}

.nav_skeleton_text {
    display: inline-block;
    height: 12px;
    width: 90px;
    border-radius: 6px;
    background: #e2e8f0;
    animation: navPulse 1.4s ease-in-out infinite 0.2s;
}

.nav_skeleton_text--short {
    width: 70px;
}

.sidebar_footer {
    padding: 1rem;
    border-top: 1px solid #e2e8f0;
    position: relative;
}

.user_menu_toggle {
    max-height: 60px;
    display: flex;
    align-items: center;
    width: 100%;
    padding: 0.75rem;
    background: var(--background-color);
    border: 1px dashed var(--primary-color);
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.3s;
    gap: 0.75rem;
}

    .user_menu_toggle:hover {
        background: linear-gradient(135deg, rgba(0, 183, 181, 0.1), rgba(0, 84, 97, 0.1));
    }

.user_avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-family: 'Pilcrow Rounded', sans-serif;
    font-weight: 800;
}

.user_info {
    flex: 1;
    text-align: left;
    transition: opacity 0.3s;
    overflow: hidden;
    word-break: break-word;
}

.user_name {
    font-size: var(--size-sm);
    font-weight: 600;
    color: var(--primary-color);
    display: block;
    white-space: nowrap;
}

.user_email {
    font-size: var(--size-xs);
    color: #64748b;
    display: block;
    text-wrap: wrap;
    text-overflow: ellipsis;
}

.menu_icon {
    color: #64748b;
    font-size: 1rem;
    transition: transform 0.3s, opacity 0.3s;
    border: 1px solid red;
}

.user_menu_toggle:hover .menu_icon {
    transform: rotate(90deg);
}

.user_dropdown {
    position: absolute;
    bottom: 100%;
    left: 1rem;
    right: 1rem;
    background: white;
    border-radius: 10px;
    box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.1);
    padding: 0.5rem;
    margin-bottom: 0.5rem;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

    .user_dropdown.active {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

.dropdown_item {
    display: flex;
    align-items: center;
    padding: 0.75rem 1rem;
    color: #64748b;
    text-decoration: none;
    border-radius: 8px;
    transition: all 0.3s;
    gap: 0.75rem;
    white-space: nowrap;
}

    .dropdown_item:hover {
        background: var(--background-color);
        color: var(--primary-color);
    }

    .dropdown_item.danger:hover {
        background: rgba(239, 68, 68, 0.1);
        color: #ef4444;
    }

    .dropdown_item.success:hover {
        background: var(--accent-color);
        color: var(--primary-color);
    }

.dropdown_icon {
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.page_wrapper {
    flex: 1;
    width: 100%;
    margin-left: 0;
    border-radius: var(--size-lg);
    border: 1px solid #e0e0e0;
}

.top_nav {
    background: rgba(0, 183, 181, 0.12);
    border-bottom: 1px solid rgba(0, 183, 181, 0.3);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 12px 24px;
    border-radius: var(--size-lg);
    position: sticky;
    top: 0;
    z-index: 120;
    box-shadow: 0 4px 24px rgba(0, 84, 97, 0.04);
}

.modal-backdrop {
    z-index: 1040 !important;
}

.modal {
    z-index: 1050 !important;
}

.modal-dialog {
    z-index: 1055 !important;
}

.modal-content {
    z-index: 1055 !important;
}

.top_nav_btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    background: rgba(0, 183, 181, 0.12);
    border: 1px solid rgba(0, 183, 181, 0.3);
    border-radius: 999px;
    color: var(--primary-color);
    font-weight: 800;
    font-size: 14px;
    letter-spacing: -0.01em;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

    .top_nav_btn svg {
        width: 18px;
        height: 18px;
        transition: transform 0.2s ease;
    }

    .top_nav_btn:hover {
        background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
        color: #ffffff;
        border-color: transparent;
        box-shadow: 0 8px 20px rgba(0, 84, 97, 0.18);
        transform: translateY(-2px);
    }

        .top_nav_btn:hover svg {
            transform: scale(1.1);
        }

.top-left {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.hamburger {
    background: transparent;
    border: none;
    font-size: 24px;
    color: var(--primary-color);
    cursor: pointer;
    padding: 4px;
    transition: color 0.2s;
}

    .hamburger:hover {
        color: var(--accent-color);
    }

.top_logo {
    height: var(--size-5xl);
    width: auto;
}

.nav_actions {
    display: flex;
    gap: var(--size-xxs);
    align-items: center;
}

.btn_outline {
    padding: var(--size-xxs) var(--size-xs);
    border: 2px solid var(--primary-color);
    background-color: transparent;
    color: var(--primary-color);
    border-radius: var(--size-sm);
    text-decoration: none;
    font-weight: 600;
    font-size: var(--size-sm);
    transition: all 0.3s;
    display: inline-block;
}

    .btn_outline:hover {
        background-color: var(--primary-color);
        color: white;
    }

.btn_primary {
    padding: var(--size-xxs) var(--size-xs);
    background-color: var(--primary-color);
    color: white;
    border-radius: var(--size-sm);
    text-decoration: none;
    font-weight: 600;
    font-size: var(--size-sm);
    transition: all 0.3s;
    display: inline-block;
    border: 2px solid var(--primary-color);
}

    .btn_primary:hover {
        background-color: var(--secondary-color);
        border-color: var(--secondary-color);
        color: white;
    }

.content {
    padding: 0;
    margin: 0;
}

.modal-backdrop {
    z-index: 1040 !important;
}

.modal {
    z-index: 1050 !important;
}

.modal-dialog {
    z-index: 1055 !important;
}

.modal-content {
    z-index: 1055 !important;
}

.badge {
    background-color: transparent;
    color: var(--primary-color);
    border: 2px solid var(--accent-color);
    padding: var(--size-xs) var(--size-xxs);
    border-radius: var(--size-xs);
}

.sidebar-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 999;
}

    .sidebar-overlay.show {
        display: block;
    }

.landing-footer {
    background-color: white;
    padding: 1.5rem 0;
    border-top: 1px solid #e5e7eb;
    text-align: center;
    color: #6b7280;
    font-size: 0.875rem;
}

    .landing-footer a {
        color: var(--primary-color);
        text-decoration: none;
        margin: 0 0.5rem;
        transition: color 0.3s;
        font-size: 0.875rem;
    }

        .landing-footer a:hover {
            color: var(--accent-color);
        }

.fade_out {
    opacity: 0;
    transform: translateX(-20px);
    pointer-events: none;
}

.fade_in {
    opacity: 1;
    transform: translateX(0);
    animation: slideIn 0.4s ease-out forwards;
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes float {
    0%, 100% {
        transform: translate(0, 0) scale(1);
    }

    50% {
        transform: translate(50px, 50px) scale(1.1);
    }
}

.apptPaginator,
.pRecPaginator,
.recPaginator {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 0 2px;
    border-top: 0.5px solid var(--color-border-tertiary, #e2e8f0);
    margin-top: 24px;
}

.apptPaginator {
    margin-top: 8px;
}

.pagMeta {
    font-size: 12px;
    color: var(--color-text-tertiary, #94a3b8);
    letter-spacing: 0.01em;
    white-space: nowrap;
}

.pagControls {
    display: flex;
    align-items: center;
    gap: 2px;
}

.pagDots {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 10px;
}

.pagDot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    border: none;
    padding: 0;
    cursor: pointer;
    background: var(--color-border-secondary, #cbd5e1);
    transition: background 0.15s, transform 0.15s;
    flex-shrink: 0;
}

    .pagDot.active {
        background: var(--color-text-primary, #1e293b);
        transform: scale(1.5);
        cursor: default;
    }

    .pagDot:hover:not(.active) {
        background: var(--color-text-secondary, #64748b);
    }

.pagArrow {
    width: 28px;
    height: 28px;
    border-radius: var(--border-radius-md, 8px);
    border: 0.5px solid var(--color-border-tertiary, #e2e8f0);
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--color-text-secondary, #64748b);
    transition: background 0.12s, border-color 0.12s;
    padding: 0;
}

    .pagArrow:hover:not([disabled]) {
        background: var(--color-background-secondary, #f8fafc);
        border-color: var(--color-border-secondary, #cbd5e1);
    }

    .pagArrow[disabled] {
        opacity: 0.3;
        cursor: not-allowed;
    }

.apptPaginator {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--size-xxs);
    margin-top: var(--size-lg);
    padding: var(--size-sm) 0;
    user-select: none;
}

.apptPagBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    height: 2.5rem;
    padding: 0 var(--size-xs);
    font-size: var(--size-sm);
    font-weight: 600;
    color: var(--primary-color);
    background-color: white;
    border: 1px solid rgba(0, 84, 97, 0.1);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
}

    .apptPagBtn:hover:not(:disabled) {
        background-color: var(--background-color);
        border-color: var(--secondary-color);
        color: var(--secondary-color);
        transform: translateY(-1px);
        box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    }

    .apptPagBtn.active {
        background-color: var(--primary-color);
        color: #ffffff;
        border-color: var(--primary-color);
        box-shadow: 0 4px 12px rgba(0, 84, 97, 0.25);
    }

    .apptPagBtn:disabled {
        opacity: 0.4;
        cursor: not-allowed;
        background-color: #fcfcfc;
        border-color: #eee;
    }

    .apptPagBtn:active:not(:disabled) {
        transform: scale(0.95);
    }

    .apptPagBtn i {
        font-size: var(--size-base);
        line-height: 0;
    }

@media (min-width: 475px) {
    .top-logo {
        height: 36px;
    }
}

@media (min-width: 640px) {
}

@media (min-width: 768px) and (max-width: 1280px) {
    .sidebar {
        width: var(--sidebar-collapsed-width);
        transform: translateX(0);
    }

    .logo_text,
    .nav_section_title,
    .nav_text,
    .user_info,
    .menu_icon {
        opacity: 0;
        pointer-events: none;
    }

    .nav_icon {
        margin-left: 6px;
    }

    .user_dropdown {
        left: calc(var(--sidebar-collapsed-width) + 0.5rem);
        right: auto;
        bottom: 1rem;
    }

    .page_wrapper {
        margin-left: var(--sidebar-collapsed-width);
        margin-right: 10px;
        width: calc(100% - var(--sidebar-collapsed-width) - 20px);
    }

    .hamburger {
        display: none;
    }

    .nav_item::after {
        content: attr(data-tooltip);
        position: absolute;
        left: calc(100% + 10px);
        top: 50%;
        transform: translateY(-50%);
        background: #1e293b;
        color: white;
        padding: 0.5rem 0.75rem;
        border-radius: 6px;
        font-size: 0.875rem;
        white-space: nowrap;
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.3s;
        z-index: 1001;
    }

    .nav_item:hover::after {
        opacity: 1;
    }
}

@media (min-width: 1024px) {
}

@media (min-width: 1280px) {
    .sidebar {
        width: var(--sidebar-width);
        transform: translateX(0);
    }

    .sidebar_toggle {
        display: none;
    }

    .page_wrapper {
        margin-right: 10px;
        margin-left: 265px;
        width: calc(100% - 280px);
    }

    .hamburger {
        display: none;
    }
}

@media (min-width: 1536px) {
}

