/* Minification failed. Returning unminified contents.
(2,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(3,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(4,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(5,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(7,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(8,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(9,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(10,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(11,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(12,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(13,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(14,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(15,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(16,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(17,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(18,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(19,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(20,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(21,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(22,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(23,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(24,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(25,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(40,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(41,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(42,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(43,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(44,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(45,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(46,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(47,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(48,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(49,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(50,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(51,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(52,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(53,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(54,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(55,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(56,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(57,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(58,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(59,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(60,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(61,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(62,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(63,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(71,49): run-time error CSS1039: Token not allowed after unary operator: '-red'
(73,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(76,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(77,55): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(79,39): run-time error CSS1039: Token not allowed after unary operator: '-red'
(86,51): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(91,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(92,24): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(94,40): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(94,95): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(96,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(97,24): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(99,42): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(101,40): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(102,29): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(102,60): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(105,40): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(105,64): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(107,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(108,24): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(110,38): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(112,40): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(113,27): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(113,58): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(116,48): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(116,72): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(117,76): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(124,34): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(126,38): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(133,44): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(134,49): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(137,46): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(141,29): run-time error CSS1039: Token not allowed after unary operator: '-red'
(145,49): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(150,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(152,46): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(155,46): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(165,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(173,51): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(178,49): run-time error CSS1039: Token not allowed after unary operator: '-text'
(180,34): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(193,56): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(227,33): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(227,73): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(228,41): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(231,43): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(260,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(278,42): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(279,55): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(286,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(291,36): run-time error CSS1039: Token not allowed after unary operator: '-red'
(303,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(303,59): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(307,38): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(310,65): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(320,24): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(325,49): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(351,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(377,34): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(378,21): run-time error CSS1039: Token not allowed after unary operator: '-shadow-lg'
(386,65): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(389,65): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(390,41): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(390,101): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(391,40): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(393,65): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(396,58): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(399,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(405,46): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(407,67): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(408,40): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(408,100): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(409,68): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(412,29): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(412,62): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(413,69): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(414,16): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(417,59): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(427,45): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(428,45): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(431,66): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(431,91): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(432,41): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(432,101): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(438,67): run-time error CSS1039: Token not allowed after unary operator: '-red'
(438,137): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(439,41): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(442,48): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(446,62): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(447,71): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(447,98): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(448,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(448,64): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(448,141): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(449,52): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(450,56): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(460,21): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(460,51): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(463,60): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(463,88): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(465,40): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(466,40): run-time error CSS1039: Token not allowed after unary operator: '-red'
(467,40): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(469,37): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(469,117): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(470,47): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(475,52): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(480,142): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(481,33): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(482,34): run-time error CSS1039: Token not allowed after unary operator: '-red'
(486,78): run-time error CSS1039: Token not allowed after unary operator: '-red'
(486,160): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(487,37): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(496,34): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(497,30): run-time error CSS1039: Token not allowed after unary operator: '-red'
(500,34): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(506,34): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(507,29): run-time error CSS1039: Token not allowed after unary operator: '-red'
(512,45): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(519,41): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(519,71): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(521,69): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(524,42): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(525,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(544,42): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(545,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(546,29): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(546,69): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(549,49): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(549,68): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(550,47): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(550,73): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(557,41): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(558,27): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(561,62): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(561,93): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(576,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(577,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(579,26): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(579,38): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(586,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(587,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(596,34): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(601,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(605,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(606,16): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(608,63): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(612,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(612,98): run-time error CSS1039: Token not allowed after unary operator: '-red'
(613,64): run-time error CSS1039: Token not allowed after unary operator: '-red'
(617,34): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(617,94): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(618,44): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(624,41): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(625,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(640,41): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(640,71): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(643,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(643,82): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(646,64): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(649,66): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(651,34): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(654,58): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(655,34): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(659,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(663,84): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(663,128): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(674,28): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(675,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(676,34): run-time error CSS1039: Token not allowed after unary operator: '-red'
(682,40): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(685,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(686,36): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(697,48): run-time error CSS1039: Token not allowed after unary operator: '-r-xl'
(699,119): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(699,244): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(700,40): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(701,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(701,99): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(702,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(703,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(703,98): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(704,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(706,63): run-time error CSS1039: Token not allowed after unary operator: '-text'
(707,74): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(707,105): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(707,146): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(707,170): run-time error CSS1039: Token not allowed after unary operator: '-text'
(708,41): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(710,74): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(710,105): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(710,146): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(710,170): run-time error CSS1039: Token not allowed after unary operator: '-text'
(710,291): run-time error CSS1062: Expected semicolon or closing curly-brace, found '='
(711,128): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(712,46): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(713,33): run-time error CSS1039: Token not allowed after unary operator: '-red'
(714,66): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(715,130): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(718,82): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(719,30): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(720,35): run-time error CSS1039: Token not allowed after unary operator: '-red'
(732,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(735,51): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(744,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(744,82): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(748,46): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(752,32): run-time error CSS1039: Token not allowed after unary operator: '-red'
(756,48): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(761,41): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(762,16): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(765,38): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(765,71): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(766,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(766,71): run-time error CSS1039: Token not allowed after unary operator: '-red'
(773,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(773,46): run-time error CSS1039: Token not allowed after unary operator: '-red'
(784,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(785,16): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(788,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(789,55): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(791,34): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(803,48): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(803,79): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(804,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(804,82): run-time error CSS1039: Token not allowed after unary operator: '-text'
(807,44): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(807,68): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(813,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(814,40): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(814,70): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(824,32): run-time error CSS1039: Token not allowed after unary operator: '-red'
(827,79): run-time error CSS1039: Token not allowed after unary operator: '-red'
(830,69): run-time error CSS1039: Token not allowed after unary operator: '-red'
(830,103): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(839,48): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(841,48): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(842,34): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(843,40): run-time error CSS1039: Token not allowed after unary operator: '-red'
(857,47): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(857,73): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(866,49): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(869,40): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(869,73): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(870,24): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(870,79): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(873,44): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(873,70): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(875,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(875,72): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(876,52): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(879,52): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(880,55): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(885,33): run-time error CSS1039: Token not allowed after unary operator: '-red'
(886,24): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(887,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(890,59): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(893,63): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(894,124): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(903,62): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(909,21): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(909,51): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(910,27): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(912,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(912,96): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(920,46): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(924,40): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(924,100): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(925,50): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(942,35): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(955,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(955,82): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(957,34): run-time error CSS1039: Token not allowed after unary operator: '-red'
(961,42): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(962,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(966,62): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(980,34): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(981,24): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(987,60): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(996,56): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(997,40): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1007,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1015,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1021,57): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1022,35): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1033,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1034,16): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1036,39): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1038,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1039,16): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1042,34): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1053,41): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1054,27): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1057,69): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(1057,100): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(1065,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1066,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1068,26): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(1068,38): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(1072,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1073,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1078,35): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1078,95): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1079,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1080,35): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1080,95): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1081,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1081,96): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1084,41): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(1085,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1091,58): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1092,46): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1097,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1100,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1100,82): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1109,55): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1114,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(1114,64): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(1117,37): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(1122,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1135,49): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(1139,41): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1150,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1152,39): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1154,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1155,32): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1165,16): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1167,41): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1169,42): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1174,21): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1181,41): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1182,72): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1190,40): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1196,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1198,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1200,33): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1208,40): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(1210,49): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(1210,73): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1213,64): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1214,47): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(1215,43): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1216,41): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1216,101): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1217,39): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1218,49): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1222,35): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1234,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1238,40): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1239,46): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(1244,35): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1261,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1271,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1271,117): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1275,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1278,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1278,84): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1292,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1295,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1301,47): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1313,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1325,37): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1326,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1330,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1335,49): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1336,53): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1344,85): run-time error CSS1039: Token not allowed after unary operator: '-text'
(1349,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1349,48): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1352,35): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1357,24): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(1357,51): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1360,51): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1361,45): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1366,29): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(1366,59): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1367,27): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1369,52): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1370,42): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1370,102): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1371,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1374,21): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1374,54): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1375,32): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1377,59): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1394,44): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1394,76): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1397,37): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1397,97): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1398,61): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1402,46): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1402,86): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1405,42): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1409,66): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(1410,24): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1410,54): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1415,49): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1416,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1416,99): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1419,21): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(1419,51): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1420,44): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1422,66): run-time error CSS1039: Token not allowed after unary operator: '-text'
(1424,58): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1425,24): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1425,65): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1426,33): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1429,64): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1430,39): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1431,34): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1435,49): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1438,57): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1439,46): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(1439,77): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1440,16): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1442,44): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1442,63): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1444,57): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1445,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1445,61): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1448,44): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1449,47): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(1456,46): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(1456,77): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1461,23): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1461,47): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(1462,49): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(1465,49): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(1466,21): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1467,16): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1470,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1472,42): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1474,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1477,90): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1490,36): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(1490,66): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1490,110): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1491,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1491,144): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1493,65): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1493,101): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1495,40): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1495,100): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1496,50): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1497,41): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1498,47): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1498,85): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1499,47): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(1502,64): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1503,64): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1505,40): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1506,60): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1507,60): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(1510,59): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1513,115): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1514,115): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1515,42): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1515,102): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1516,66): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1516,117): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1516,172): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1517,60): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(1518,83): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1519,33): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1520,39): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1529,44): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1529,104): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1530,43): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1532,43): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1532,103): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1533,43): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1533,103): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1537,24): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(1537,51): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1540,47): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1541,53): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(1542,49): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1542,74): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1543,55): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1544,75): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(1544,98): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1545,53): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1553,21): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(1563,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1564,16): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1567,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1572,41): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(1573,27): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1577,53): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1581,46): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(1583,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1584,16): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1587,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1595,21): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(1595,58): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1596,24): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1601,49): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(1601,73): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(1604,61): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1606,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1606,98): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1607,34): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(1608,40): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1609,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1610,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1611,61): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1615,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1621,32): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(1623,44): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1623,104): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1630,41): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1638,49): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(1639,24): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(1639,71): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(1642,70): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(1642,101): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(1648,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1649,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1654,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1655,22): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1660,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1660,98): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1661,64): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1662,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1662,98): run-time error CSS1039: Token not allowed after unary operator: '-red'
(1663,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1663,98): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1664,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(1672,63): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1682,112): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(1682,151): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(1682,197): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(1682,262): run-time error CSS1039: Token not allowed after unary operator: '-shadow-lg'
(2309,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2351,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(2354,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2366,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2375,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2398,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(2412,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2436,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(2451,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(2453,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(2457,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(2470,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2473,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2485,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2488,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2493,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(2497,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2502,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(2525,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2528,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2533,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2537,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(2627,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2628,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2629,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2630,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2631,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2632,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2633,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2634,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2635,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2636,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2637,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2638,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2639,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2640,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2641,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2642,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2643,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2644,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2645,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2646,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2647,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2648,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(2655,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2664,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(2668,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(2683,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2686,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2693,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2700,31): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2710,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(2712,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2716,35): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2724,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(2733,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2736,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(2742,35): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2742,69): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2743,35): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2743,69): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2758,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2759,22): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2777,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2780,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2787,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(2790,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(2793,15): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(2797,39): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2804,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(2806,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(2808,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(2811,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2814,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2825,15): run-time error CSS1039: Token not allowed after unary operator: '-text'
(2835,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(2836,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(2838,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(2839,15): run-time error CSS1039: Token not allowed after unary operator: '-text'
(2849,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2850,30): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2854,69): run-time error CSS1062: Expected semicolon or closing curly-brace, found '='
(2864,22): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2865,20): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(2869,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2880,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2894,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2950,15): run-time error CSS1039: Token not allowed after unary operator: '-text'
(2960,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(2978,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(2981,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(2984,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(2991,40): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(3000,30): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3004,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3005,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(3006,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(3009,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3015,38): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3015,65): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3017,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3020,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(3023,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3031,39): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(3051,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(3052,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(3053,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3056,15): run-time error CSS1039: Token not allowed after unary operator: '-text'
(3065,43): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3065,79): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(3071,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3074,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(3075,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(3084,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3094,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(3118,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3123,35): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3148,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3157,48): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(3158,33): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(3159,39): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3175,49): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3198,26): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3200,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(3201,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(3219,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3255,31): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3256,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(3269,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3275,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3283,50): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3284,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3287,41): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3305,30): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3313,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3315,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(3317,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3326,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(3352,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3358,48): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3389,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3408,25): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(3410,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3432,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3453,52): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3573,51): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3573,114): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3577,21): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3582,53): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3583,46): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(3584,52): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3586,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3586,86): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3588,35): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3591,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3591,86): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3598,74): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(3599,80): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3602,50): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3608,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3608,86): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3611,35): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3613,52): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3616,77): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3618,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3622,32): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3627,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3629,30): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(3629,79): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3633,42): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3633,67): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(3635,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3637,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3639,42): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(3656,30): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(3657,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3657,86): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3660,51): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3660,76): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(3687,30): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3688,25): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(3705,53): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(3706,61): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(3710,32): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3719,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3742,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3758,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3759,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3760,45): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(3760,57): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(3765,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3766,29): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(3766,41): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(3768,46): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3772,56): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3773,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3773,86): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3777,54): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3778,34): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(3781,34): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3781,78): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3783,45): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3784,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3790,64): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(3791,52): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(3792,23): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(3794,50): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(3795,57): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3797,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3798,29): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(3798,41): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(3802,55): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3803,34): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(3806,35): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(3806,79): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(3811,71): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(3913,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(3985,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4007,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4013,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4023,17): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4049,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4053,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4062,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4115,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4118,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4159,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4190,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4197,17): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4216,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4259,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4267,17): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4300,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4303,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4306,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(4314,20): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(4316,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(4321,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4325,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4326,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(4327,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(4335,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4336,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(4355,33): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4372,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4375,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4382,35): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4388,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4391,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4399,36): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4402,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4405,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4411,35): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4415,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(4425,20): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(4427,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(4435,16): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4445,15): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(4455,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(4456,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(4460,15): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(4466,22): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(4467,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(4471,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4483,28): run-time error CSS1030: Expected identifier, found ':'
(4483,36): run-time error CSS1031: Expected selector, found ')'
(4483,36): run-time error CSS1025: Expected comma or open brace, found ')'
(4504,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4507,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(4514,20): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(4527,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(4544,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(4549,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4633,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4636,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4643,17): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4648,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(4669,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4676,15): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(4693,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-lg'
(4697,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4722,22): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4726,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4737,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4787,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4793,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4809,15): run-time error CSS1039: Token not allowed after unary operator: '-text'
(4819,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(4820,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(4824,15): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(4825,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4861,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(4880,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4883,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4890,17): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4895,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(4911,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4913,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(4921,22): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(4923,22): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(4943,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4960,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-lg'
(4962,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(4971,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(4978,22): run-time error CSS1039: Token not allowed after unary operator: '-red'
(4984,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(4994,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5021,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5025,22): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5038,42): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5038,74): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(5041,35): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5041,95): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5042,59): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5046,44): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5046,84): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5049,40): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5053,64): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(5054,22): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5054,52): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5058,47): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5059,37): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5059,97): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5062,19): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5062,49): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5063,42): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5065,64): run-time error CSS1039: Token not allowed after unary operator: '-text'
(5067,56): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5068,22): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5068,63): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5069,31): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5072,62): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5073,37): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5074,32): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5078,47): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5081,55): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5082,44): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5082,75): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5083,14): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5085,42): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5085,61): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5087,55): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5088,19): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5088,59): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5091,42): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5092,45): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5098,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5098,48): run-time error CSS1039: Token not allowed after unary operator: '-r-xl'
(5114,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5118,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5143,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5146,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5156,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5156,57): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5157,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5160,43): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5163,57): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5164,65): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5168,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5184,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5185,32): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5188,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5191,39): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5196,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5200,46): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5201,50): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5205,35): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5205,69): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5213,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5214,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5216,53): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5260,19): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5268,30): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5273,39): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(5274,25): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5278,51): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5282,44): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5284,20): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5285,14): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5288,30): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5294,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5294,96): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5294,219): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5298,63): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5298,89): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5299,61): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5299,103): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5299,196): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(5299,231): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5300,67): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5301,71): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5301,104): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5301,173): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5304,49): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5304,101): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5304,147): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5309,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5311,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5317,38): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5319,41): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5320,47): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5322,51): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5322,75): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5322,106): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5322,138): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5322,184): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5323,40): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5324,128): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5328,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5328,96): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5329,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5330,34): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5330,59): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5330,99): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5330,144): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5331,40): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5332,41): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5332,65): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5333,47): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5339,83): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5364,28): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5367,126): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5368,64): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5368,108): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5369,35): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5369,72): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5372,31): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5372,64): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5372,96): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5375,185): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5377,84): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5377,115): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5377,150): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5378,42): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5378,60): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5378,83): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5383,106): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5384,58): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5389,57): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5389,88): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5389,107): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5389,136): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5390,39): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5390,67): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(5400,175): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5400,201): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5400,220): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5400,244): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5401,46): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5408,19): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(5408,56): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5409,22): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5414,47): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5414,71): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5417,59): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5419,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5419,96): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5420,32): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5421,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5422,46): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5423,46): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5424,59): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5428,30): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5434,30): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(5436,42): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5436,102): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5443,54): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5444,22): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5444,63): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(5445,14): run-time error CSS1039: Token not allowed after unary operator: '-text'
(5446,68): run-time error CSS1062: Expected semicolon or closing curly-brace, found '='
(5451,42): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5455,64): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5457,50): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5460,46): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(5461,32): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5471,39): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5472,39): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5476,38): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5477,38): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5479,44): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(5480,44): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5482,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5483,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5483,99): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5484,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5484,99): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5485,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5486,44): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5488,79): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5491,58): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5492,22): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5492,63): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(5493,14): run-time error CSS1039: Token not allowed after unary operator: '-text'
(5496,38): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5497,38): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5578,24): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5586,17): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(5596,30): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5604,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5607,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5609,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5616,22): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5617,17): run-time error CSS1039: Token not allowed after unary operator: '-text'
(5622,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5623,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5631,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5634,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5644,22): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5650,29): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5651,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5654,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5655,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5668,24): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5706,30): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5707,25): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(5708,17): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5709,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5716,22): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5750,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5752,25): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5754,23): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5757,22): run-time error CSS1039: Token not allowed after unary operator: '-shadow-lg'
(5773,128): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5777,36): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5777,96): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5778,48): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5779,34): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5779,59): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5779,99): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5779,144): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5780,40): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5781,41): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(5781,65): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5782,47): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5803,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5806,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5815,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5816,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5818,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5821,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5826,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5827,22): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5836,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(5839,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5849,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5850,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5851,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5857,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5858,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(5863,15): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(5867,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5875,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(5877,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(5890,24): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5894,24): run-time error CSS1039: Token not allowed after unary operator: '-red'
(5898,24): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5917,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(5923,16): run-time error CSS1039: Token not allowed after unary operator: '-rg-stores-map-height'
(5926,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(5927,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5928,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(5929,20): run-time error CSS1039: Token not allowed after unary operator: '-white'
(5934,20): run-time error CSS1039: Token not allowed after unary operator: '-white'
(5935,32): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5944,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(5952,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(5953,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(5954,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(5960,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(5961,20): run-time error CSS1039: Token not allowed after unary operator: '-white'
(5967,16): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5978,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(5979,15): run-time error CSS1039: Token not allowed after unary operator: '-text'
(5984,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(5991,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6004,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6005,15): run-time error CSS1039: Token not allowed after unary operator: '-white'
(6006,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(6009,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6033,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(6036,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6052,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6059,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(6063,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(6069,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(6071,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6079,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(6085,14): run-time error CSS1039: Token not allowed after unary operator: '-white'
(6094,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6097,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6103,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(6120,15): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(6121,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6127,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(6128,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6129,20): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(6131,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(6139,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(6149,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(6154,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(6165,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6166,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6176,21): run-time error CSS1039: Token not allowed after unary operator: '-rg-gm-zoom-stack'
(6181,10): run-time error CSS1039: Token not allowed after unary operator: '-rg-gm-zoom-stack'
(6181,36): run-time error CSS1039: Token not allowed after unary operator: '-rg-map-fab-gap'
(6196,20): run-time error CSS1039: Token not allowed after unary operator: '-white'
(6197,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(6204,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6230,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(6237,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6240,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6247,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(6253,15): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(6267,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(6268,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6278,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6279,15): run-time error CSS1039: Token not allowed after unary operator: '-white'
(6283,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(6287,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(6288,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6289,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(6293,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6294,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(6305,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(6309,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6326,26): run-time error CSS1039: Token not allowed after unary operator: '-white'
(6332,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(6336,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6340,15): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(6349,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6350,15): run-time error CSS1039: Token not allowed after unary operator: '-white'
(6352,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(6355,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6356,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-lg'
(6379,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6380,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6400,35): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6433,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6434,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6435,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6436,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6437,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6438,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6439,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6440,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6441,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6442,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6448,26): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-gray-line'
(6449,23): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(6451,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-surface'
(6460,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue'
(6462,28): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(6462,60): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(6493,26): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-surface'
(6500,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-surface'
(6514,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue-pale'
(6518,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-hover'
(6527,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-text'
(6539,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-text'
(6544,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-red'
(6551,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-muted'
(6560,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-muted'
(6568,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-surface'
(6569,30): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-gray-line'
(6570,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue'
(6577,32): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(6577,64): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(6582,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue-light'
(6852,114): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6853,80): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6853,117): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6854,35): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6854,95): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6855,44): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(6856,43): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6858,167): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6858,227): run-time error CSS1039: Token not allowed after unary operator: '-text'
(6858,282): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(6859,35): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(6860,79): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(6861,59): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(6863,56): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(6869,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6872,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6874,33): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(6877,35): run-time error CSS1039: Token not allowed after unary operator: '-rg-red'
(6885,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6900,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6901,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(6910,45): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(6920,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6921,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6922,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6923,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6924,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6925,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6926,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6927,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6928,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6929,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6930,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6931,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6932,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6933,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6934,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6935,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6936,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6937,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6938,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6939,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6945,26): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-gray-line'
(6946,23): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(6948,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-surface'
(6956,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-surface'
(6976,13): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-space-2'
(6978,17): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-space-3'
(6978,38): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-space-4'
(6979,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue'
(6980,23): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(6980,43): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(7030,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-muted-header'
(7040,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-red'
(7051,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-gray-line'
(7065,22): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-space-4'
(7070,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue'
(7086,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue-pale'
(7087,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue'
(7111,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-blue-mid'
(7112,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-icon-bg'
(7113,23): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-icon-corner'
(7122,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-logout-bg'
(7123,30): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-gray-line'
(7128,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-red'
(7129,32): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(7129,64): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-radius'
(7136,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-red'
(7140,15): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-red'
(7141,20): run-time error CSS1039: Token not allowed after unary operator: '-rg-dd-red-light'
(7168,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(7177,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(7200,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7207,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7213,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7237,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(7242,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7251,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7274,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7278,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(7284,40): run-time error CSS1039: Token not allowed after unary operator: '-red-light'
(7284,66): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7285,40): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(7285,66): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7288,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7291,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7300,15): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(7307,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(7314,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7337,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7339,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7350,15): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(7356,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(7357,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(7365,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7378,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7380,30): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(7400,49): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7408,20): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7408,80): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7411,32): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7414,20): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7414,80): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7418,35): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7419,57): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7424,20): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7425,14): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7427,32): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7428,43): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7431,42): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(7431,74): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(7435,20): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7435,80): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7438,59): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7449,42): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(7449,78): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7449,102): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7450,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7450,98): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7451,47): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7452,38): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7457,19): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7457,71): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(7458,39): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7462,56): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7463,39): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7464,60): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(7467,38): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7467,71): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(7468,22): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(7468,66): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7471,41): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7471,60): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7477,19): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(7477,55): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7478,22): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(7479,30): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7481,57): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7493,158): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7494,35): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7495,52): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7496,38): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7496,120): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7497,47): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(7498,62): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7498,105): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7504,20): run-time error CSS1039: Token not allowed after unary operator: '-white'
(7505,23): run-time error CSS1039: Token not allowed after unary operator: '-r-xl'
(7506,20): run-time error CSS1039: Token not allowed after unary operator: '-shadow-lg'
(7522,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7549,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7593,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7600,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(7610,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7612,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7624,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(7625,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(7632,20): run-time error CSS1039: Token not allowed after unary operator: '-white'
(7641,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(7646,63): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7650,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7651,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(7655,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7671,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7672,50): run-time error CSS1039: Token not allowed after unary operator: '-text'
(7678,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7680,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7681,41): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(7686,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(7687,32): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7693,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(7700,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7701,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7714,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(7715,23): run-time error CSS1039: Token not allowed after unary operator: '-r-sm'
(7724,16): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7729,32): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(7730,21): run-time error CSS1039: Token not allowed after unary operator: '-font-body'
(7740,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(7741,28): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(7743,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7744,15): run-time error CSS1039: Token not allowed after unary operator: '-text-body'
(7749,22): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7749,56): run-time error CSS1039: Token not allowed after unary operator: '-blue-pale'
(7749,90): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7754,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(7755,20): run-time error CSS1039: Token not allowed after unary operator: '-red'
(7756,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7762,81): run-time error CSS1039: Token not allowed after unary operator: '-red-mid'
(7763,69): run-time error CSS1039: Token not allowed after unary operator: '-gray-mid'
(7763,102): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7783,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(7917,20): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7918,23): run-time error CSS1039: Token not allowed after unary operator: '-r-lg'
(7927,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7956,23): run-time error CSS1039: Token not allowed after unary operator: '-r-pill'
(7957,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(7969,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(7973,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(7999,20): run-time error CSS1039: Token not allowed after unary operator: '-gray-bg'
(8000,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(8002,26): run-time error CSS1039: Token not allowed after unary operator: '-gray-line'
(8007,15): run-time error CSS1039: Token not allowed after unary operator: '-muted'
(8015,21): run-time error CSS1039: Token not allowed after unary operator: '-font-display'
(8018,15): run-time error CSS1039: Token not allowed after unary operator: '-blue'
(8022,15): run-time error CSS1039: Token not allowed after unary operator: '-red'
(8030,20): run-time error CSS1039: Token not allowed after unary operator: '-blue-light'
(8031,23): run-time error CSS1039: Token not allowed after unary operator: '-r-md'
(8034,15): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
(8043,16): run-time error CSS1039: Token not allowed after unary operator: '-blue-mid'
 */
:root {
    --blue:          #1B2B6B;   /* azul marino principal */
    --blue-mid:      #2E3FA3;   /* azul medio para Ã­conos/acciones */
    --blue-light:    #E8EBF7;   /* fondo azul suave */
    --blue-pale:     #F0F2F8;   /* fondo muy suave */
    --red:           #CE0037;   /* rojo acento */
    --red-light:     #FDEAEA;   /* fondo rojo suave */
    --red-mid:       #C0392B;   /* rojo hover */
    --gray-bg:       #F0F2F5;   /* fondo gris claro (app bg) */
    --gray-mid:      #DDE1EA;   /* bordes */
    --gray-line:     #EAEDF3;   /* separadores */
    --text:          #1B2B6B;
    --text-body:     #3A3A5C;
    --muted:         #8A8FA8;
    --white:         #ffffff;
    --font-display:  'Nunito',sans-serif;
    --font-body:     'Nunito Sans',sans-serif;
    --r-sm:   8px;
    --r-md:  14px;
    --r-lg:  20px;
    --r-xl:  28px;
    --r-pill:50px;
    --shadow-sm: 0 2px 8px rgba(27,43,107,0.08);
    --shadow-md: 0 8px 24px rgba(27,43,107,0.12);
    --shadow-lg: 0 20px 48px rgba(27,43,107,0.14);
  }


  /* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     RESET & BASE
  â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
  *, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
  html { scroll-behavior: smooth; max-width: 100vw; overflow-x: hidden; }
  body { font-family:'Nunito Sans',sans-serif; color:#1B2B6B; background:#fff; max-width: 100vw; overflow-x: hidden; }

  /* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     TOKENS  (extraÃ­dos directamente de la app)
  â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
  :root {
    --blue:          #1B2B6B;   /* azul marino principal */
    --blue-mid:      #2E3FA3;   /* azul medio para Ã­conos/acciones */
    --blue-light:    #E8EBF7;   /* fondo azul suave */
    --blue-pale:     #F0F2F8;   /* fondo muy suave */
    --red:           #CE0037;   /* rojo acento */
    --red-light:     #FDEAEA;   /* fondo rojo suave */
    --red-mid:       #C0392B;   /* rojo hover */
    --gray-bg:       #F0F2F5;   /* fondo gris claro (app bg) */
    --gray-mid:      #DDE1EA;   /* bordes */
    --gray-line:     #EAEDF3;   /* separadores */
    --text:          #1B2B6B;
    --text-body:     #3A3A5C;
    --muted:         #8A8FA8;
    --white:         #ffffff;
    --font-display:  'Nunito',sans-serif;
    --font-body:     'Nunito Sans',sans-serif;
    --r-sm:   8px;
    --r-md:  14px;
    --r-lg:  20px;
    --r-xl:  28px;
    --r-pill:50px;
    --shadow-sm: 0 2px 8px rgba(27,43,107,0.08);
    --shadow-md: 0 8px 24px rgba(27,43,107,0.12);
    --shadow-lg: 0 20px 48px rgba(27,43,107,0.14);
  }

  /* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     UTILITY
  â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
  .container { max-width:1160px; margin:0 auto; padding:0 40px; }
  .section-label {
    font-size:11px; font-weight:700; color:var(--red);
    letter-spacing:2.5px; text-transform:uppercase;
    font-family:var(--font-display); margin-bottom:10px; display:block;
  }
  .section-title {
    font-family:var(--font-display); font-weight:900;
    font-size:34px; letter-spacing:-0.8px; color:var(--blue); line-height:1.15;
  }
  .section-title .accent { color:var(--red); }

  /* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     BUTTONS
  â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
  .btn {
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    cursor:pointer; border:none; font-family:var(--font-display);
    font-weight:800; letter-spacing:0.2px; transition:all .2s;
    text-decoration:none; white-space:nowrap;
  }
  .btn-primary {
    background:var(--red); color:#fff;
    border-radius:var(--r-pill); padding:10px 24px; font-size:14px;
  }
  .btn-primary:hover { background:var(--red-mid); transform:translateY(-1px); box-shadow:var(--shadow-sm); }
  .btn-secondary {
    background:var(--blue); color:#fff;
    border-radius:var(--r-pill); padding:10px 24px; font-size:14px;
  }
  .btn-secondary:hover { background:var(--blue-mid); transform:translateY(-1px); }
  .btn-ghost {
    background:transparent; color:var(--blue);
    border:1.5px solid var(--gray-mid); border-radius:var(--r-pill);
    padding:9px 20px; font-size:14px;
  }
  .btn-ghost:hover { border-color:var(--blue); background:var(--blue-pale); }
  .btn-large {
    background:var(--red); color:#fff;
    border-radius:var(--r-pill); padding:15px 36px; font-size:16px;
  }
  .btn-large:hover { background:var(--red-mid); transform:translateY(-2px); box-shadow:0 8px 20px rgba(227,30,36,.25); }
  .btn-outline-large {
    background:transparent; color:var(--blue);
    border:2px solid var(--gray-mid); border-radius:var(--r-pill);
    padding:14px 32px; font-size:16px;
  }
  .btn-outline-large:hover { border-color:var(--blue); background:var(--blue-pale); }
  .btn-full { width:100%; padding:14px; font-size:15px; border-radius:var(--r-md); }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     NAVBAR
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #navbar {
    position:sticky; top:0; z-index:1000; background:#fff;
    border-bottom:1px solid var(--gray-line); transition:box-shadow .3s;
  }
  #navbar.scrolled { box-shadow:var(--shadow-md); }
  .nav-inner {
    max-width:1160px; margin:0 auto; padding:0 40px;
    display:flex; align-items:center; justify-content:space-between; height:68px;
  }
  .nav-logo {
    display:flex; align-items:center; gap:10px;
    text-decoration:none; font-family:var(--font-display);
    font-weight:900; font-size:22px; color:var(--blue);
  }
  .nav-logo-mark {
    width:36px; height:36px; background:var(--blue); border-radius:10px;
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
  }
  .nav-logo-mark svg { width:20px; height:20px; }
  .nav-logo em { color:var(--red); font-style:normal; }

  .nav-links { display:flex; align-items:center; gap:28px; }
  .nav-links a {
    font-size:14px; font-weight:600; color:var(--muted);
    text-decoration:none; transition:color .2s; position:relative;
  }
  .nav-links a::after {
    content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px;
    background:var(--red); border-radius:2px; transition:width .2s;
  }
  .nav-links a:hover            { color:var(--blue); }
  .nav-links a:hover::after,
  .nav-links a.active::after    { width:100%; }
  .nav-links a.active           { color:var(--blue); }

  .nav-actions { display:flex; align-items:center; gap:10px; }

  .nav-hamburger {
    display:none; flex-direction:column; gap:5px;
    cursor:pointer; padding:6px; background:none; border:none;
  }
  .nav-hamburger span {
    display:block; width:22px; height:2px;
    background:var(--blue); border-radius:2px; transition:all .3s;
  }
  .nav-hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
  .nav-hamburger.open span:nth-child(2) { opacity:0; }
  .nav-hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

  #mobile-menu {
    display:none; flex-direction:column;
    background:#fff; border-bottom:1px solid var(--gray-line);
    padding:16px 40px 24px;
  }
  #mobile-menu.open { display:flex; }
  #mobile-menu a {
    font-size:16px; font-weight:600; color:var(--text);
    text-decoration:none; padding:14px 0;
    border-bottom:1px solid var(--gray-line);
  }
  .mobile-actions { display:flex; flex-direction:column; gap:10px; margin-top:20px; }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     HERO
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     HERO â€” layout 8/4 con carrusel
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #hero {
    display:grid; grid-template-columns:8fr 4fr;
    min-height:520px; overflow:hidden; background:var(--blue);
  }

  /* â”€â”€ columna izquierda: carrusel de banners â”€â”€ */
  .hero-carousel {
    position:relative; overflow:hidden;
  }
  .hero-slides {
    display:flex; height:100%;
    transition:transform .6s cubic-bezier(.4,0,.2,1);
    will-change:transform;
  }
  .hero-slide {
    flex-shrink:0; width:100%; height:100%;
    position:relative; min-height:520px;
  }
  .hero-slide-img {
    position:absolute; inset:0; width:100%; height:100%;
    object-fit:cover; object-position:center;
  }
  /* overlay mÃ­nimo â€” solo para no tapar el banner */
  .hero-slide-overlay {
    position:absolute; inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.25) 0%, transparent 35%);
    pointer-events:none;
  }
  /* contenido: solo botÃ³n abajo a la izquierda */
  .hero-slide-content {
    position:absolute; inset:0; z-index:2;
    padding:24px 32px;
    display:flex; flex-direction:column; justify-content:flex-end;
  }
  .hero-slide-cta {
    display:inline-flex; align-items:center; gap:8px;
    background:#fff; color:var(--blue); border:none; border-radius:var(--r-pill);
    padding:11px 24px; font-family:var(--font-display); font-weight:800; font-size:13px;
    cursor:pointer; width:fit-content; transition:all .2s;
  }
  .hero-slide-cta:hover { background:var(--blue-light); transform:translateY(-1px); }

  /* flechas del carrusel */
  .hero-carr-arrow {
    position:absolute; top:50%; transform:translateY(-50%);
    width:40px; height:40px; border-radius:50%; border:none;
    background:rgba(255,255,255,.15); backdrop-filter:blur(4px);
    display:flex; align-items:center; justify-content:center;
    cursor:pointer; z-index:10; transition:all .2s; color:#fff;
  }
  .hero-carr-arrow:hover { background:rgba(255,255,255,.3); }
  .hero-carr-arrow svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; }
  .hero-carr-prev { left:16px; }
  .hero-carr-next { right:16px; }

  /* dots del carrusel */
  .hero-carr-dots {
    position:absolute; bottom:20px; left:50%; transform:translateX(-50%);
    display:flex; gap:7px; z-index:10;
  }
  .hero-carr-dot {
    width:7px; height:7px; border-radius:50%;
    background:rgba(255,255,255,.45); border:none; cursor:pointer;
    transition:all .3s; padding:0;
  }
  .hero-carr-dot.active { background:#fff; width:22px; border-radius:4px; }

  /* â”€â”€ columna derecha: panel info â”€â”€ */
  .hero-panel {
    background:var(--blue); padding:48px 36px;
    display:flex; flex-direction:column; justify-content:center; gap:24px;
    position:relative; z-index:1;
    border-left:1px solid rgba(255,255,255,.08);
  }
  /* patrÃ³n sutil de fondo */
  .hero-panel::before {
    content:''; position:absolute; inset:0; pointer-events:none;
    background:repeating-linear-gradient(
      -45deg,
      rgba(255,255,255,.025) 0px, rgba(255,255,255,.025) 1px,
      transparent 1px, transparent 24px
    );
  }

  .hero-badge {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(255,255,255,.12); color:rgba(255,255,255,.9);
    padding:6px 14px; border-radius:var(--r-pill);
    font-size:11px; font-weight:700; font-family:var(--font-display);
    border:1px solid rgba(255,255,255,.18); width:fit-content;
    position:relative; z-index:1;
  }
  .hero-badge-dot { width:6px; height:6px; background:#74C0FC; border-radius:50%; }

  .hero-title {
    font-family:var(--font-display); font-weight:900;
    font-size:clamp(28px, 2.5vw, 38px);
    line-height:1.1; letter-spacing:-1px; color:#fff;
    position:relative; z-index:1; text-transform:none;
  }
  .hero-title .accent { color:var(--red); }

  .hero-desc {
    font-size:14px; color:rgba(255,255,255,.68); line-height:1.65;
    position:relative; z-index:1; text-transform:none;
  }

  .hero-ctas {
    display:flex; flex-direction:column; gap:10px;
    position:relative; z-index:1;
  }
  .btn-large {
    background:var(--red); color:#fff; border-radius:var(--r-pill);
    padding:13px 28px; font-size:14px; text-align:center;
    transition:all .2s;
  }
  .btn-large:hover { background:var(--red-mid); transform:translateY(-2px); box-shadow:0 8px 20px rgba(227,30,36,.4); }
  .btn-outline-large {
    background:rgba(255,255,255,.1); color:#fff;
    border:1.5px solid rgba(255,255,255,.3); border-radius:var(--r-pill);
    padding:12px 28px; font-size:14px; text-align:center;
    transition:all .2s;
  }
  .btn-outline-large:hover { background:rgba(255,255,255,.2); border-color:rgba(255,255,255,.6); }

  /* activar tarjeta */
  .hero-activar-banner {
    display:flex; align-items:center; gap:10px;
    background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.15);
    border-radius:var(--r-md); padding:11px 14px; cursor:pointer;
    transition:all .2s; position:relative; z-index:1;
  }
  .hero-activar-banner:hover { background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.3); }
  .hero-activar-icon {
    width:32px; height:32px; border-radius:var(--r-sm);
    background:rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center;
    color:rgba(255,255,255,.85); flex-shrink:0;
  }
  .hero-activar-text { font-size:12px; color:rgba(255,255,255,.65); line-height:1.4; flex:1; }
  .hero-activar-text strong { color:#fff; display:block; font-weight:700; margin-bottom:1px; }
  .hero-activar-arrow { font-size:18px; color:rgba(255,255,255,.4); flex-shrink:0; transition:transform .2s; }
  .hero-activar-banner:hover .hero-activar-arrow { transform:translateX(3px); color:rgba(255,255,255,.8); }

  /* stats */
  .hero-stats {
    display:flex; gap:0; flex-wrap:wrap;
    border-top:1px solid rgba(255,255,255,.1);
    padding-top:20px; position:relative; z-index:1;
  }
  .hero-stat {
    flex:1; min-width:80px; text-align:center;
    cursor:pointer; border-radius:12px; padding:12px;
    transition:background .2s, transform .2s;
    text-decoration:none; display:flex; flex-direction:column; justify-content:center; align-items:center;
  }
  .hero-stat:hover {
    background:rgba(255,255,255,.14);
    transform:translateY(-2px);
  }
  .hero-stat-num {
    font-family:var(--font-display); font-weight:900;
    font-size:24px; color:#fff; letter-spacing:-0.5px; line-height:1;
  }
  .hero-stat-num .unit { font-size:14px; color:rgba(255,255,255,.7); vertical-align:top; }
  .hero-stat-label { font-size:12px; color:rgba(255,255,255,.7); font-weight:600; margin-top:4px; }

  /* responsive */
  @media (max-width:900px) {
    #hero { grid-template-columns:1fr; }
    .hero-panel { padding:36px 32px; gap:18px; }
    .hero-slide  { min-height:320px; }
    .hero-slide-content { padding:32px 28px; }
    .hero-title { font-size:28px; }
    .hero-ctas  { flex-direction:row; }
  }
  @media (max-width:600px) {
    .hero-panel { padding:28px 20px; }
    .hero-slide  { min-height:260px; }
    .hero-title  { font-size:24px; }
    .hero-ctas   { flex-direction:column; }
    .hero-carr-arrow { display:none; }
  }

  /* phone mockup */
  .phone-wrap { position:relative; z-index:2; }
  .phone {
    width:230px; background:var(--gray-bg); border-radius:38px;
    box-shadow:var(--shadow-lg); overflow:hidden; border:6px solid #fff;
  }
  .phone-topbar {
    background:#fff; padding:12px 16px 10px;
    display:flex; align-items:center; justify-content:space-between;
  }
  .phone-topbar-left { display:flex; align-items:center; gap:8px; }
  .phone-topbar-menu {
    width:34px; height:34px; border-radius:50%; background:var(--gray-bg);
    display:flex; align-items:center; justify-content:center;
  }
  .phone-topbar-menu svg { width:14px; height:14px; stroke:var(--blue); fill:none; stroke-width:2; stroke-linecap:round; }
  .phone-topbar-addr { font-family:var(--font-display); font-size:10px; font-weight:700; color:var(--blue); line-height:1.3; }
  .phone-topbar-addr span { color:var(--muted); font-weight:600; }
  .phone-cart {
    width:34px; height:34px; border-radius:50%; background:var(--gray-bg);
    display:flex; align-items:center; justify-content:center; position:relative;
  }
  .phone-cart svg { width:14px; height:14px; stroke:var(--blue); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
  .phone-cart-badge {
    position:absolute; top:2px; right:2px; width:14px; height:14px;
    background:var(--red); border-radius:50%; border:2px solid #fff;
    font-size:7px; font-weight:900; color:#fff;
    display:flex; align-items:center; justify-content:center;
  }
  .phone-pts-card {
    margin:8px 12px; background:#fff; border-radius:16px;
    padding:14px 16px; border:1px solid var(--gray-line);
  }
  .phone-pts-label  { font-size:10px; font-weight:700; color:var(--muted); margin-bottom:4px; }
  .phone-pts-num    { font-family:var(--font-display); font-weight:900; font-size:22px; color:var(--blue); letter-spacing:-0.5px; }
  .phone-pts-num sub { font-size:11px; font-weight:700; color:var(--muted); }
  .phone-pts-actions { display:flex; gap:8px; margin-top:10px; }
  .phone-pts-btn {
    flex:1; background:var(--blue-light); border-radius:var(--r-pill);
    padding:6px 0; font-size:9px; font-weight:700; font-family:var(--font-display);
    color:var(--blue-mid); text-align:center;
    display:flex; align-items:center; justify-content:center; gap:4px;
  }
  .phone-pts-btn svg { width:9px; height:9px; stroke:var(--blue-mid); fill:none; stroke-width:2; stroke-linecap:round; }
  .phone-icons {
    display:flex; justify-content:space-around;
    padding:12px 16px; background:#fff; margin-bottom:4px;
  }
  .phone-icon-item  { display:flex; flex-direction:column; align-items:center; gap:6px; }
  .phone-icon-circle {
    width:44px; height:44px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
  }
  .phone-icon-circle.blue { background:var(--blue-light); }
  .phone-icon-circle.red  { background:var(--red-light); }
  .phone-icon-circle.pink { background:#F5E6F0; }
  .phone-icon-circle svg  { width:20px; height:20px; }
  .phone-icon-label { font-size:9px; font-weight:700; color:var(--blue); font-family:var(--font-display); }
  .phone-promo-label { font-family:var(--font-display); font-weight:900; font-size:10px; color:var(--blue); padding:0 12px 6px; }
  .phone-promo-banner {
    margin:0 12px 8px; border-radius:12px; overflow:hidden; height:68px;
    background:linear-gradient(135deg,#2E3FA3 0%,#6B21A8 100%);
    display:flex; align-items:center; padding:10px 14px; gap:10px;
  }
  .phone-promo-tag   { font-size:8px; font-weight:900; color:var(--red); letter-spacing:1px; text-transform:uppercase; font-family:var(--font-display); }
  .phone-promo-price { font-family:var(--font-display); font-weight:900; font-size:16px; color:#fff; letter-spacing:-0.3px; }
  .phone-promo-emoji { font-size:28px; margin-left:auto; }
  .phone-bottom-nav {
    background:#fff; border-top:1px solid var(--gray-line);
    display:flex; justify-content:space-around; padding:8px 0 10px; margin-top:4px;
  }
  .phone-nav-item  { display:flex; flex-direction:column; align-items:center; gap:4px; }
  .phone-nav-item svg { width:18px; height:18px; stroke:var(--muted); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
  .phone-nav-label { font-size:8px; font-weight:700; font-family:var(--font-display); color:var(--muted); }
  .phone-nav-pill  { background:var(--red); border-radius:var(--r-pill); padding:2px 10px; font-size:8px; font-weight:800; font-family:var(--font-display); color:#fff; margin-top:-2px; }
  .phone-nav-item.active svg         { stroke:var(--blue); }
  .phone-nav-item.active .phone-nav-label { color:var(--blue); }


  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     FEATURES
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #features { padding:80px 0; background:#fff; }
  .section-header { text-align:center; margin-bottom:52px; }
  .features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
  .feature-card {
    background:var(--gray-bg); border-radius:var(--r-lg); padding:32px 28px;
    border:1px solid transparent; transition:all .25s; cursor:default;
  }
  .feature-card:hover { background:#fff; border-color:var(--gray-mid); box-shadow:var(--shadow-md); transform:translateY(-4px); }
  .feature-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
  .feature-icon.blue { background:var(--blue); }
  .feature-icon.red  { background:var(--red); }
  .feature-icon.mid  { background:var(--blue-mid); }
  .feature-icon svg  { width:24px; height:24px; stroke:#fff; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
  .feature-title { font-family:var(--font-display); font-weight:800; font-size:18px; margin-bottom:10px; color:var(--blue); }
  .feature-desc  { font-size:14px; color:var(--muted); line-height:1.65; }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     CÃ“MO FUNCIONA
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #como-funciona { padding:80px 0; background:var(--blue); }
  .cf-inner {
    max-width:1160px; margin:0 auto; padding:0 40px;
    display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center;
  }
  .cf-label  { color:rgba(255,255,255,.5); font-size:11px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; font-family:var(--font-display); margin-bottom:12px; display:block; }
  .cf-title  { font-family:var(--font-display); font-weight:900; font-size:34px; color:#fff; letter-spacing:-0.8px; line-height:1.15; margin-bottom:18px; }
  .cf-title .accent { color:var(--red); }
  .cf-desc   { font-size:15px; color:rgba(255,255,255,.55); line-height:1.7; margin-bottom:36px; }
  .cf-steps  { display:flex; flex-direction:column; gap:20px; }
  .cf-step   { display:flex; align-items:flex-start; gap:16px; }
  .cf-step-num { width:34px; height:34px; border-radius:50%; background:var(--red); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:900; font-size:13px; color:#fff; flex-shrink:0; margin-top:1px; }
  .cf-step-title { font-family:var(--font-display); font-weight:700; font-size:15px; color:#fff; margin-bottom:3px; }
  .cf-step-desc  { font-size:13px; color:rgba(255,255,255,.45); line-height:1.55; }
  .cf-visual { display:flex; align-items:center; justify-content:center; }
  .virtual-card {
    width:100%; max-width:300px;
    background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
    border-radius:24px; padding:28px;
  }
  .vc-header  { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:24px; }
  .vc-logo    { font-family:var(--font-display); font-weight:900; font-size:15px; color:#fff; }
  .vc-logo span { color:var(--red); }
  .vc-chip    { width:34px; height:26px; background:rgba(255,255,255,.15); border-radius:5px; }
  .vc-number  { font-family:'Courier New',monospace; font-size:13px; color:rgba(255,255,255,.3); letter-spacing:2px; margin-bottom:20px; }
  .vc-pts     { font-family:var(--font-display); font-weight:900; font-size:40px; color:#fff; letter-spacing:-1px; }
  .vc-pts sub { font-size:16px; color:rgba(255,255,255,.5); font-weight:700; bottom:0; }
  .vc-sublabel { font-size:10px; color:rgba(255,255,255,.35); font-weight:600; letter-spacing:1px; text-transform:uppercase; margin-top:4px; }
  .vc-divider { height:1px; background:rgba(255,255,255,.08); margin:20px 0; }
  .vc-footer  { display:flex; justify-content:space-between; }
  .vcf-lbl    { font-size:9px; color:rgba(255,255,255,.35); font-weight:600; text-transform:uppercase; letter-spacing:1px; }
  .vcf-val    { font-family:var(--font-display); font-weight:700; font-size:14px; color:#fff; margin-top:3px; }
  .vcf-val.red { color:var(--red); }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     CANJES
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #canjes { padding:80px 0; background:var(--gray-bg); }
  .canjes-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:20px; flex-wrap:wrap; gap:16px; }

  /* modos legend */
  .modos-legend {
    display:flex; align-items:center; gap:6px; flex-wrap:wrap;
    margin-bottom:32px; padding:14px 18px;
    background:#fff; border-radius:var(--r-md); border:1px solid var(--gray-line);
  }
  .modos-legend-title { font-size:12px; font-weight:700; color:var(--muted); margin-right:8px; text-transform:uppercase; letter-spacing:0.8px; }
  .modo-pill {
    display:inline-flex; align-items:center; gap:6px;
    padding:5px 12px; border-radius:var(--r-pill);
    font-family:var(--font-display); font-weight:700; font-size:11px;
    cursor:default; transition:transform .15s;
  }
  .modo-pill:hover { transform:scale(1.04); }
  .modo-pill-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
  .modo-pill.imbatible { background:#E8F8EE; color:#1A7F3C; }
  .modo-pill.imbatible .modo-pill-dot { background:#22C55E; }
  .modo-pill.antojo    { background:#FEF0E7; color:#C05A00; }
  .modo-pill.antojo    .modo-pill-dot { background:#F97316; }
  .modo-pill.derretido { background:#FEF9E7; color:#A16207; }
  .modo-pill.derretido .modo-pill-dot { background:#EAB308; }
  .modo-pill.congelado { background:#EFF6FF; color:#1D4ED8; }
  .modo-pill.congelado .modo-pill-dot { background:#60A5FA; }

  /* filter tabs */
  .canjes-filters {
    display:flex; gap:8px; flex-wrap:wrap; margin-bottom:24px;
  }
  .canjes-filter-btn {
    padding:7px 16px; border-radius:var(--r-pill);
    font-family:var(--font-display); font-weight:700; font-size:12px;
    border:1.5px solid var(--gray-mid); background:#fff; color:var(--muted);
    cursor:pointer; transition:all .2s;
  }
  .canjes-filter-btn:hover  { border-color:var(--blue); color:var(--blue); }
  .canjes-filter-btn.active { background:var(--blue); border-color:var(--blue); color:#fff; }

  /* grid */
  .beneficios-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }

  /* card base */
  .bcard {
    background:#fff; border-radius:var(--r-lg); overflow:hidden;
    border:1px solid var(--gray-line); transition:all .25s; cursor:pointer;
    display:flex; flex-direction:column;
  }
  .bcard:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:var(--gray-mid); }

  /* image area */
  .bcard-img-wrap {
    position:relative; height:160px; overflow:hidden; flex-shrink:0;
  }
  .bcard-img-wrap img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .35s;
  }
  .bcard:hover .bcard-img-wrap img { transform:scale(1.05); }

  /* PUNTOS+DINERO badge (fiel a la imagen) */
  .bcard-badge-pdm {
    position:absolute; top:10px; left:0;
    background:var(--blue); color:#fff;
    font-family:var(--font-display); font-weight:800; font-size:9px;
    letter-spacing:0.8px; padding:4px 10px;
    border-radius:0 var(--r-sm) var(--r-sm) 0;
    text-transform:uppercase;
  }

  /* CANJE label bar */
  .bcard-canje-bar {
    position:absolute; bottom:0; left:0; right:0;
    background:var(--blue); color:#fff;
    font-family:var(--font-display); font-weight:800; font-size:12px;
    text-align:center; padding:6px 0; letter-spacing:0.5px;
  }

  /* body */
  .bcard-body { padding:14px 14px 12px; flex:1; display:flex; flex-direction:column; gap:10px; }
  /* pts + discount row — puntos y descuento lado a lado, info debajo */
  .bcard-pts-row {
    display:flex; align-items:center; gap:0;
    border-bottom:1px solid var(--gray-line);
    padding-bottom:10px; margin-bottom:10px;
  }
  .bcard-pts-block {
    display:flex; flex-direction:column; align-items:center;
    border-right:1px solid var(--gray-line);
    padding-right:10px; flex-shrink:0; min-width:60px;
  }
  .bcard-pts-num {
    font-family:var(--font-display); font-weight:900; font-size:20px;
    color:var(--blue); letter-spacing:-0.5px; line-height:1;
  }
  .bcard-pts-lbl { font-size:9px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:0.5px; }
  .bcard-off-block {
    display:flex; flex-direction:column; align-items:center; flex-shrink:0; padding-left:10px;
  }
  .bcard-off-num  { font-family:var(--font-display); font-weight:900; font-size:20px; color:var(--red); letter-spacing:-0.5px; line-height:1; }
  .bcard-off-lbl  { font-size:9px; font-weight:700; color:var(--red); text-transform:uppercase; }

  /* info: nombre + descripción — elemento independiente, ocupa todo el ancho */
  .bcard-info { width:100%; }
  .bcard-name { font-family:var(--font-display); font-weight:800; font-size:13px; color:var(--blue); line-height:1.3; margin-bottom:4px; }
  .bcard-desc { font-size:11px; color:var(--muted); line-height:1.5; }

  /* modos row */
  .bcard-modos { display:flex; gap:4px; flex-wrap:wrap; margin-top:2px; }
  .bcard-modo-tag {
    display:inline-flex; align-items:center; gap:4px;
    padding:3px 8px; border-radius:var(--r-pill); font-size:10px; font-weight:700;
    font-family:var(--font-display);
  }
  .bcard-modo-tag .bmt-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
  .bcard-modo-tag.imbatible { background:#E8F8EE; color:#1A7F3C; }
  .bcard-modo-tag.imbatible .bmt-dot { background:#22C55E; }
  .bcard-modo-tag.antojo    { background:#FEF0E7; color:#C05A00; }
  .bcard-modo-tag.antojo    .bmt-dot { background:#F97316; }
  .bcard-modo-tag.derretido { background:#FEF9E7; color:#A16207; }
  .bcard-modo-tag.derretido .bmt-dot { background:#EAB308; }
  .bcard-modo-tag.congelado { background:#EFF6FF; color:#1D4ED8; }
  .bcard-modo-tag.congelado .bmt-dot { background:#60A5FA; }

  /* modo info tooltip section (below grid) */
  .modos-info {
    margin-top:40px; padding:28px 32px;
    background:#fff; border-radius:var(--r-lg); border:1px solid var(--gray-line);
  }
  .modos-info-title {
    font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--blue);
    margin-bottom:16px; display:flex; align-items:center; gap:8px;
  }
  .modos-info-title svg { width:16px; height:16px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; }
  .modos-table { width:100%; border-collapse:collapse; }
  .modos-table th {
    text-align:left; font-size:11px; font-weight:700; color:var(--muted);
    text-transform:uppercase; letter-spacing:0.8px; padding:0 12px 10px 0;
    border-bottom:1px solid var(--gray-line);
  }
  .modos-table td {
    padding:12px 12px 12px 0; font-size:13px; color:var(--text-body);
    border-bottom:1px solid var(--gray-line); vertical-align:middle;
  }
  .modos-table tr:last-child td { border-bottom:none; }
  .modos-table .modo-name {
    font-family:var(--font-display); font-weight:800; font-size:13px;
    display:flex; align-items:center; gap:8px;
  }
  .modos-table .modo-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
  .modos-table .modo-estado { font-size:11px; padding:3px 10px; border-radius:var(--r-pill); font-weight:700; font-family:var(--font-display); }
  .modo-estado.max    { background:#E8F8EE; color:#1A7F3C; }
  .modo-estado.leve   { background:#FEF0E7; color:#C05A00; }
  .modo-estado.alto   { background:#FEF9E7; color:#A16207; }
  .modo-estado.inact  { background:#EFF6FF; color:#1D4ED8; }

 

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     FOOTER
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  footer { background:var(--blue); padding:56px 64px 0; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; }
  .footer-logo  { font-family:var(--font-display); font-weight:900; font-size:22px; color:#fff; margin-bottom:14px; }
  .footer-logo span { color:var(--red); }
  .footer-desc  { font-size:13px; color:rgba(255,255,255,.38); line-height:1.65; max-width:220px; margin-bottom:20px; }
  .footer-social { display:flex; gap:10px; }
  .footer-social a { width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; transition:background .2s; }
  .footer-social a:hover { background:rgba(255,255,255,.18); }
  .footer-social svg { width:14px; height:14px; fill:rgba(255,255,255,.6); }
  .footer-col-title { font-family:var(--font-display); font-weight:800; font-size:13px; color:#fff; margin-bottom:16px; }
  .footer-links { display:flex; flex-direction:column; gap:10px; }
  .footer-links a { font-size:13px; color:rgba(255,255,255,.38); text-decoration:none; transition:color .2s; }
  .footer-links a:hover { color:var(--red); }
  .footer-bottom { background:var(--blue); margin:40px 64px 0; padding:20px 0 28px; border-top:1px solid rgba(255,255,255,.07); display:flex; justify-content:space-between; align-items:center; }
  .footer-copy  { font-size:12px; color:rgba(255,255,255,.22); }
  .footer-legal-links { display:flex; gap:20px; }
  .footer-legal-links a { font-size:12px; color:rgba(255,255,255,.3); text-decoration:none; transition:color .2s; }
  .footer-legal-links a:hover { color:rgba(255,255,255,.7); }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     MODALS
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  .modal-overlay { display:none; position:fixed; inset:0; z-index:2000; background:rgba(27,43,107,.5); backdrop-filter:blur(4px); align-items:center; justify-content:center; padding:20px; }
  .modal-overlay.open { display:flex; }
  .modal { background:#fff; border-radius:var(--r-xl); padding:40px; width:100%; max-width:420px; position:relative; box-shadow:0 32px 80px rgba(27,43,107,.22); animation:modalIn .25s ease; }
  @keyframes modalIn { from { opacity:0; transform:translateY(20px) scale(.97); } to { opacity:1; transform:translateY(0) scale(1); } }
  .modal-close { position:absolute; top:16px; right:16px; width:32px; height:32px; border-radius:50%; background:var(--gray-bg); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:20px; color:var(--muted); transition:background .2s; line-height:1; }
  .modal-close:hover { background:var(--gray-mid); }
  .modal-logo-text { font-family:var(--font-display); font-weight:900; font-size:18px; color:var(--blue); margin-bottom:20px; display:block; }
  .modal-logo-text span { color:var(--red); }
  .modal-title    { font-family:var(--font-display); font-weight:900; font-size:26px; color:var(--blue); margin-bottom:6px; letter-spacing:-0.5px; }
  .modal-subtitle { font-size:14px; color:var(--muted); margin-bottom:28px; line-height:1.5; }
  .form-group   { margin-bottom:16px; }
  .form-label   { font-size:12px; font-weight:700; color:var(--text); letter-spacing:0.3px; margin-bottom:6px; display:block; }
  .form-input   { width:100%; padding:12px 16px; border:1.5px solid var(--gray-mid); border-radius:var(--r-md); font-size:15px; font-family:var(--font-body); color:var(--text); outline:none; transition:border-color .2s; background:#fff; }
  .form-input:focus { border-color:var(--blue); }
  .form-row     { display:grid; grid-template-columns:1fr 2fr; gap:10px; }
  .form-select  { width:100%; padding:12px 16px; border:1.5px solid var(--gray-mid); border-radius:var(--r-md); font-size:15px; font-family:var(--font-body); color:var(--text); outline:none; background:#fff; appearance:none; background-image:url(/Content/App/data:image/svg+xml,%3Csvg xmlns='http:/www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8FA8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E); background-repeat:no-repeat; background-position:right 12px center; }
  .form-footer  { display:flex; justify-content:space-between; align-items:center; margin-top:18px; font-size:13px; color:var(--muted); flex-wrap:wrap; gap:8px; }
  .form-link    { font-size:13px; color:var(--blue-mid); font-weight:600; text-decoration:none; transition:color .2s; }
  .form-link:hover { color:var(--red); }
  .modal-divider { text-align:center; font-size:13px; color:var(--muted); margin:20px 0; position:relative; }
  .modal-divider::before, .modal-divider::after { content:''; position:absolute; top:50%; width:42%; height:1px; background:var(--gray-mid); }
  .modal-divider::before { left:0; }
  .modal-divider::after  { right:0; }
  .modal-alt    { text-align:center; margin-top:18px; font-size:13px; color:var(--muted); }
  .modal-alt a  { color:var(--blue); font-weight:700; text-decoration:none; }
  .modal-alt a:hover { color:var(--red); }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     ASOCIATE PAGE (full-page flow)
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #page-asociate {
    display:none; position:fixed; inset:0; z-index:1500;
    background:#fff; overflow-y:auto;
  }
  #page-asociate.open { display:block; }

  .ap-topbar {
    background:var(--blue); height:10px;
  }
  .ap-nav {
    background:#fff; border-bottom:1px solid var(--gray-line);
    position:sticky; top:0; z-index:10;
  }
  .ap-nav-inner {
    max-width:1200px; margin:0 auto; padding:0 40px; height:68px;
    display:flex; align-items:center; justify-content:space-between;
  }
  .ap-nav-logo {
    display:flex; align-items:center; gap:10px;
    font-family:var(--font-display); font-weight:900; font-size:20px; color:var(--blue);
    text-decoration:none; cursor:pointer;
  }
  .ap-nav-logo-mark {
    width:32px; height:32px; background:var(--blue); border-radius:8px;
    display:flex; align-items:center; justify-content:center;
  }
  .ap-nav-logo-mark svg { width:18px; height:18px; }
  .ap-nav-logo em { color:var(--red); font-style:normal; }

  /* progress steps bar */
  .ap-steps-bar {
    display:flex; border-bottom:1px solid var(--gray-line);
    background:#fff;
  }
  .ap-step-tab {
    flex:1; display:flex; align-items:center; justify-content:center; gap:10px;
    padding:14px 20px; font-family:var(--font-display); font-weight:700; font-size:13px;
    color:var(--muted); position:relative; cursor:default;
    border-bottom:3px solid transparent; transition:all .2s;
  }
  .ap-step-tab.active   { color:var(--blue); border-bottom-color:var(--blue); }
  .ap-step-tab.done     { color:var(--red);  border-bottom-color:var(--red); }
  .ap-step-num {
    width:24px; height:24px; border-radius:50%; border:2px solid currentColor;
    display:flex; align-items:center; justify-content:center;
    font-size:11px; font-weight:900; flex-shrink:0;
  }
  .ap-step-tab.done .ap-step-num {
    background:var(--red); border-color:var(--red); color:#fff;
  }
  /* checkmark for done */
  .ap-step-tab.done .ap-step-num::before { content:'âœ“'; font-size:11px; }
  .ap-step-tab.done .ap-step-num-inner   { display:none; }

  /* content area */
  .ap-body {
    max-width:800px; margin:0 auto; padding:48px 40px 80px;
  }
  .ap-section-title {
    font-family:var(--font-display); font-weight:900; font-size:28px;
    color:var(--blue); letter-spacing:-0.5px; margin-bottom:6px;
  }
  .ap-section-sub {
    font-size:14px; color:var(--muted); margin-bottom:32px;
    padding-bottom:20px; border-bottom:1px solid var(--gray-line);
  }
  .ap-section-sub a { color:var(--blue-mid); font-weight:600; text-decoration:none; }

  /* step panels */
  .ap-step-panel { display:none; }
  .ap-step-panel.active { display:block; }

  /* social login */
  .ap-social-row {
    display:flex; gap:12px; margin-bottom:20px; flex-wrap:wrap;
  }
  .ap-social-btn {
    flex:1; min-width:140px; display:flex; align-items:center; justify-content:center; gap:8px;
    padding:10px 16px; border:1.5px solid var(--gray-mid); border-radius:var(--r-md);
    font-family:var(--font-display); font-weight:700; font-size:13px; color:var(--text);
    background:#fff; cursor:pointer; transition:all .2s; white-space:nowrap;
  }
  .ap-social-btn:hover { border-color:var(--blue); background:var(--blue-pale); }
  .ap-social-btn svg  { width:16px; height:16px; flex-shrink:0; }
  .ap-social-btn.google  { }
  .ap-social-btn.facebook { color:#1877F2; }
  .ap-social-btn.apple    { }
  .ap-social-note {
    font-size:12px; color:var(--muted); margin-bottom:24px;
    padding:10px 14px; background:var(--gray-bg); border-radius:var(--r-sm);
  }

  /* form grid */
  .ap-form-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
  .ap-form-grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; }
  .ap-form-grid-custom { display:grid; grid-template-columns:auto 120px 1fr auto; gap:12px; align-items:end; }

  /* error message */
  .form-error {
    font-size:12px; color:var(--red); margin-top:5px; font-weight:600;
    display:flex; align-items:center; gap:4px;
  }
  .form-error::before { content:'!'; width:14px; height:14px; background:var(--red); color:#fff; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:9px; font-weight:900; flex-shrink:0; }

  /* input with error */
  .form-input.has-error, .form-select.has-error { border-color:var(--red) !important; background:var(--red-light); }

  /* phone row */
  .ap-phone-row { display:grid; grid-template-columns:180px 120px 1fr 180px; gap:12px; }

  /* checkboxes */
  .ap-check-group { display:flex; flex-direction:column; gap:10px; margin:20px 0; }
  .ap-check-item  { display:flex; align-items:flex-start; gap:10px; cursor:pointer; }
  .ap-check-item input[type="checkbox"] {
    width:18px; height:18px; accent-color:var(--blue); flex-shrink:0; margin-top:1px; cursor:pointer;
  }
  .ap-check-label { font-size:13px; color:var(--text-body); line-height:1.5; }
  .ap-check-label a { color:var(--blue-mid); font-weight:600; text-decoration:none; }
  .ap-check-label a:hover { color:var(--red); }

  /* captcha mock */
  .ap-captcha-wrap { margin:20px 0; }
  .ap-captcha-box {
    display:inline-flex; align-items:center; gap:14px;
    border:1px solid #d3d3d3; border-radius:4px; padding:14px 18px;
    background:#f9f9f9; max-width:300px;
  }
  .ap-captcha-check {
    width:24px; height:24px; border:2px solid #d3d3d3; border-radius:3px;
    display:flex; align-items:center; justify-content:center; cursor:pointer;
    flex-shrink:0; transition:all .2s; background:#fff;
  }
  .ap-captcha-check.checked { background:var(--blue); border-color:var(--blue); }
  .ap-captcha-check.checked::after { content:'âœ“'; color:#fff; font-size:13px; font-weight:900; }
  .ap-captcha-label { font-size:13px; color:#555; }
  .ap-captcha-badge { margin-left:auto; display:flex; flex-direction:column; align-items:center; gap:2px; }
  .ap-captcha-logo  { font-size:9px; color:#999; font-weight:600; }

  /* footer actions */
  .ap-actions {
    display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:36px;
    padding-top:28px; border-top:1px solid var(--gray-line);
  }
  .ap-actions .btn-back {
    background:transparent; color:var(--muted); border:1.5px solid var(--gray-mid);
    border-radius:var(--r-md); padding:14px; font-size:14px; font-family:var(--font-display);
    font-weight:700; cursor:pointer; transition:all .2s;
  }
  .ap-actions .btn-back:hover { color:var(--blue); border-color:var(--blue); }
  .ap-actions .btn-confirm {
    background:var(--red); color:#fff; border:none; border-radius:var(--r-md);
    padding:14px; font-size:14px; font-family:var(--font-display); font-weight:800;
    cursor:pointer; letter-spacing:0.3px; transition:all .2s;
  }
  .ap-actions .btn-confirm:hover { background:var(--red-mid); }
  .ap-actions .btn-confirm:disabled { background:var(--gray-mid); cursor:not-allowed; }

  /* single action */
  .ap-single-action { margin-top:24px; }
  .ap-single-action .btn-continue {
    width:100%; background:var(--red); color:#fff; border:none;
    border-radius:var(--r-md); padding:14px; font-size:15px;
    font-family:var(--font-display); font-weight:800; cursor:pointer;
    letter-spacing:0.3px; transition:all .2s;
  }
  .ap-single-action .btn-continue:hover { background:var(--red-mid); transform:translateY(-1px); }

  /* divider */
  .ap-divider { text-align:center; font-size:13px; color:var(--muted); margin:24px 0; position:relative; }
  .ap-divider::before, .ap-divider::after { content:''; position:absolute; top:50%; width:44%; height:1px; background:var(--gray-mid); }
  .ap-divider::before { left:0; }
  .ap-divider::after  { right:0; }

  /* password toggle */
  .ap-input-wrap { position:relative; }
  .ap-input-wrap .form-input { padding-right:44px; }
  .ap-pw-toggle {
    position:absolute; right:12px; top:50%; transform:translateY(-50%);
    background:none; border:none; cursor:pointer; color:var(--muted); padding:4px;
  }
  .ap-pw-toggle svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; }

  /* step 1 only - DNI validation */
  .ap-dni-card {
    background:var(--gray-bg); border-radius:var(--r-lg); padding:32px;
    border:1px solid var(--gray-line); max-width:480px;
  }
  .ap-dni-title { font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--blue); margin-bottom:20px; }

  /* success state */
  .ap-success {
    display:none; text-align:center; padding:48px 24px;
  }
  .ap-success.show { display:block; }
  .ap-success-icon {
    width:72px; height:72px; background:var(--blue-light); border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 24px; font-size:32px;
  }
  .ap-success-title { font-family:var(--font-display); font-weight:900; font-size:28px; color:var(--blue); margin-bottom:10px; }
  .ap-success-desc  { font-size:15px; color:var(--muted); line-height:1.7; margin-bottom:32px; }

  @media (max-width:700px) {
    .ap-form-grid-2 { grid-template-columns:1fr; }
    .ap-form-grid-3 { grid-template-columns:1fr 1fr; }
    .ap-phone-row   { grid-template-columns:1fr 1fr; }
    .ap-social-row  { flex-direction:column; }
    .ap-body        { padding:28px 20px 60px; }
    .ap-nav-inner   { padding:0 20px; }
    .ap-step-tab    { font-size:11px; padding:12px 10px; }
    .ap-actions     { grid-template-columns:1fr; }
  }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     HOME LOGUEADO â€” MODO + CANJES
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #logged-home {
    display:none; background:var(--gray-bg); padding:48px 0 56px;
  }
  #logged-home.visible { display:block; }

  .lh-inner {
    max-width:1160px; margin:0 auto; padding:0 40px;
  }

  /* modo badge con tooltip */
  .lh-modo-row {
    display:flex; align-items:center; gap:12px; margin-bottom:32px; flex-wrap:wrap;
  }
  .lh-greeting {
    font-family:var(--font-display); font-weight:900; font-size:22px; color:var(--blue);
  }
  .lh-greeting span { color:var(--red); }
  .lh-modo-badge-wrap { position:relative; display:inline-flex; }
  .lh-modo-badge {
    display:inline-flex; align-items:center; gap:8px;
    padding:7px 16px; border-radius:var(--r-pill);
    font-family:var(--font-display); font-weight:800; font-size:13px;
    background:#FEF0E7; color:#C05A00; border:1.5px solid #FDBA74;
    cursor:pointer; user-select:none; transition:all .2s;
  }
  .lh-modo-badge:hover { background:#FDE8D8; box-shadow:var(--shadow-sm); }
  .lh-modo-badge-dot { width:9px; height:9px; border-radius:50%; background:#F97316; flex-shrink:0; }
  .lh-modo-badge-icon {
    font-size:14px; display:flex; align-items:center; justify-content:center;
  }
  .lh-modo-badge-help {
    width:16px; height:16px; border-radius:50%; background:#FDBA74;
    display:flex; align-items:center; justify-content:center;
    font-size:9px; font-weight:900; color:#C05A00; flex-shrink:0;
  }

  /* tooltip */
  .lh-tooltip {
    display:none; position:absolute; top:calc(100% + 10px); left:0;
    width:320px; background:var(--blue); color:#fff;
    border-radius:var(--r-lg); padding:20px; z-index:400;
    box-shadow:0 16px 48px rgba(27,43,107,.25);
    animation:dropIn .2s ease;
  }
  .lh-tooltip::before {
    content:''; position:absolute; top:-7px; left:20px;
    border:7px solid transparent; border-bottom-color:var(--blue);
    border-top:0;
  }
  .lh-tooltip.open { display:block; }
  .lh-tt-header {
    display:flex; align-items:center; gap:8px; margin-bottom:12px;
  }
  .lh-tt-badge {
    display:inline-flex; align-items:center; gap:6px;
    background:#F97316; color:#fff; border-radius:var(--r-pill);
    padding:4px 12px; font-family:var(--font-display); font-weight:800; font-size:12px;
  }
  .lh-tt-badge-dot { width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.7); }
  .lh-tt-close {
    margin-left:auto; background:rgba(255,255,255,.15); border:none; border-radius:50%;
    width:24px; height:24px; display:flex; align-items:center; justify-content:center;
    color:#fff; cursor:pointer; font-size:14px; flex-shrink:0;
  }
  .lh-tt-close:hover { background:rgba(255,255,255,.25); }
  .lh-tt-title {
    font-family:var(--font-display); font-weight:800; font-size:13px;
    color:rgba(255,255,255,.65); margin-bottom:8px; text-transform:uppercase; letter-spacing:0.5px;
  }
  .lh-tt-text {
    font-size:12px; color:rgba(255,255,255,.85); line-height:1.6; margin-bottom:14px;
  }
  .lh-tt-divider { height:1px; background:rgba(255,255,255,.12); margin:12px 0; }
  .lh-tt-action-title {
    font-family:var(--font-display); font-weight:800; font-size:12px;
    color:rgba(255,255,255,.65); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.5px;
  }
  .lh-tt-action-text { font-size:12px; color:rgba(255,255,255,.85); line-height:1.6; }
  .lh-tt-cta {
    display:block; width:100%; margin-top:14px;
    background:#F97316; border:none; border-radius:var(--r-md);
    padding:9px; font-family:var(--font-display); font-weight:800; font-size:12px;
    color:#fff; cursor:pointer; transition:background .2s; text-align:center;
  }
  .lh-tt-cta:hover { background:#EA6C00; }

  /* header secciÃ³n canjes en home */
  .lh-section-header {
    display:flex; align-items:center; justify-content:space-between;
    margin-bottom:20px; flex-wrap:wrap; gap:12px;
  }
  .lh-section-title {
    font-family:var(--font-display); font-weight:900; font-size:20px;
    color:var(--blue); letter-spacing:-0.3px;
  }
  .lh-section-title span { color:var(--red); }
  .lh-see-all {
    font-family:var(--font-display); font-weight:700; font-size:13px;
    color:var(--blue-mid); background:none; border:none; cursor:pointer;
    text-decoration:none; transition:color .2s;
  }
  .lh-see-all:hover { color:var(--red); }

  /* mini grid (4 cards, horizontal scroll en mobile) */
  .lh-canjes-grid {
    display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
  }
  @media (max-width:900px) { .lh-canjes-grid { grid-template-columns:1fr 1fr; } }
  @media (max-width:500px) { .lh-canjes-grid { grid-template-columns:1fr 1fr; gap:10px; } }

  /* mini card â€” hereda estilos de .bcard pero mÃ¡s compacta */
  .lh-mini-card {
    background:#fff; border-radius:var(--r-lg); overflow:hidden;
    border:1px solid var(--gray-line); transition:all .25s; cursor:pointer;
    display:flex; flex-direction:column;
  }
  .lh-mini-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--gray-mid); }
  .lh-mini-img {
    position:relative; height:120px; overflow:hidden; flex-shrink:0;
  }
  .lh-mini-img img { width:100%; height:100%; object-fit:cover; transition:transform .35s; }
  .lh-mini-card:hover .lh-mini-img img { transform:scale(1.06); }
  .lh-mini-badge {
    position:absolute; top:8px; left:0;
    background:var(--blue); color:#fff;
    font-family:var(--font-display); font-weight:800; font-size:8px;
    letter-spacing:0.6px; padding:3px 8px;
    border-radius:0 var(--r-sm) var(--r-sm) 0; text-transform:uppercase;
  }
  .lh-mini-canje {
    position:absolute; bottom:0; left:0; right:0;
    background:var(--blue); color:#fff;
    font-family:var(--font-display); font-weight:800; font-size:11px;
    text-align:center; padding:5px 0;
  }
  .lh-mini-body { padding:12px; flex:1; display:flex; flex-direction:column; gap:8px; }
  .lh-mini-pts-row { display:flex; align-items:baseline; gap:6px; }
  .lh-mini-pts { font-family:var(--font-display); font-weight:900; font-size:17px; color:var(--blue); letter-spacing:-0.5px; }
  .lh-mini-pts-lbl { font-size:9px; color:var(--muted); font-weight:700; text-transform:uppercase; }
  .lh-mini-off { font-family:var(--font-display); font-weight:900; font-size:14px; color:var(--red); margin-left:auto; }
  .lh-mini-name { font-family:var(--font-display); font-weight:800; font-size:12px; color:var(--blue); line-height:1.3; }
  .lh-mini-modo {
    display:inline-flex; align-items:center; gap:4px;
    padding:2px 8px; border-radius:var(--r-pill); font-size:9px; font-weight:700;
    font-family:var(--font-display); background:#FEF0E7; color:#C05A00; width:fit-content;
  }
  .lh-mini-modo-dot { width:5px; height:5px; border-radius:50%; background:#F97316; flex-shrink:0; }

  /* progreso hacia imbatible */
  .lh-progress-bar-wrap {
    margin-top:28px; background:#fff; border-radius:var(--r-lg);
    padding:20px 24px; border:1px solid var(--gray-line);
    display:flex; align-items:center; gap:20px; flex-wrap:wrap;
  }
  .lh-progress-text { flex:1; min-width:180px; }
  .lh-progress-label {
    font-size:12px; color:var(--muted); font-weight:600; margin-bottom:4px;
  }
  .lh-progress-title {
    font-family:var(--font-display); font-weight:800; font-size:14px; color:var(--blue);
  }
  .lh-progress-track {
    flex:2; min-width:200px;
  }
  .lh-progress-levels {
    display:flex; justify-content:space-between; margin-bottom:6px;
  }
  .lh-progress-level {
    font-size:10px; font-weight:700; font-family:var(--font-display);
    display:flex; align-items:center; gap:4px;
  }
  .lh-progress-level-dot { width:7px; height:7px; border-radius:50%; }
  .lh-progress-bar-bg {
    height:8px; background:var(--gray-mid); border-radius:var(--r-pill); overflow:hidden;
  }
  .lh-progress-bar-fill {
    height:100%; border-radius:var(--r-pill);
    background:linear-gradient(90deg, #F97316 0%, #22C55E 100%);
    width:45%; transition:width 1s ease;
  }
  .lh-progress-hint {
    font-size:11px; color:var(--muted); margin-top:5px;
  }
  .lh-progress-hint strong { color:#1A7F3C; }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     MODO badge en dropdown
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  .nav-dd-modo {
    display:flex; align-items:center; gap:10px;
    padding:12px 20px; background:#FEF0E7;
    border-bottom:1px solid #FDBA74;
  }
  .nav-dd-modo-icon {
    width:32px; height:32px; border-radius:var(--r-sm); background:#F97316;
    display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0;
  }
  .nav-dd-modo-label { font-size:10px; color:#C05A00; font-weight:600; text-transform:uppercase; letter-spacing:0.5px; }
  .nav-dd-modo-name  { font-family:var(--font-display); font-weight:800; font-size:13px; color:#C05A00; }
  .nav-dd-modo-btn   { margin-left:auto; background:none; border:none; cursor:pointer; color:#F97316; font-size:14px; padding:2px; }
  .nav-user-area {
    display:none; align-items:center; gap:16px;
  }
  .nav-user-area.visible { display:flex; }

  .nav-user-greeting {
    text-align:right; line-height:1.3;
  }
  .nav-user-hello {
    font-size:13px; color:var(--muted); font-weight:600;
  }
  .nav-user-hello strong { color:var(--blue-mid); font-weight:800; }
  .nav-user-pts {
    font-family:var(--font-display); font-weight:900;
    font-size:14px; color:var(--red); cursor:pointer;
  }
  .nav-user-pts:hover { text-decoration:underline; }

  /* icon buttons cluster */
  .nav-icon-cluster { display:flex; align-items:center; gap:4px; }
  .nav-icon-btn {
    width:38px; height:38px; border-radius:50%; background:none; border:none;
    display:flex; align-items:center; justify-content:center;
    cursor:pointer; transition:background .2s; position:relative;
    color:var(--blue);
  }
  .nav-icon-btn:hover { background:var(--blue-light); }
  .nav-icon-btn svg { width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
  .nav-icon-btn.active { background:var(--blue-light); }

  /* notification badge */
  .nav-notif-badge {
    position:absolute; top:4px; right:4px; width:8px; height:8px;
    background:var(--red); border-radius:50%; border:2px solid #fff;
  }

  /* account dropdown */
  .nav-dropdown-wrap { position:relative; }
  .nav-dropdown {
    display:none; position:absolute; top:calc(100% + 12px); right:0;
    background:#fff; border-radius:var(--r-lg); width:260px;
    box-shadow:0 16px 48px rgba(27,43,107,0.18); border:1px solid var(--gray-line);
    z-index:200; overflow:hidden;
    animation:dropIn .2s ease;
  }
  .nav-dropdown.open { display:block; }
  @keyframes dropIn { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }

  .nav-dropdown-header {
    padding:16px 20px; background:var(--blue);
    display:flex; align-items:center; gap:12px;
  }
  .nav-dd-avatar {
    width:40px; height:40px; border-radius:50%; background:rgba(255,255,255,.15);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--font-display); font-weight:900; font-size:14px; color:#fff; flex-shrink:0;
  }
  .nav-dd-name  { font-family:var(--font-display); font-weight:700; font-size:14px; color:#fff; }
  .nav-dd-pts   { font-size:12px; color:rgba(255,255,255,.7); margin-top:2px; }
  .nav-dd-pts span { color:var(--red); font-weight:700; }

  .nav-dropdown-menu { padding:8px 0; }
  .nav-dd-item {
    display:flex; align-items:center; gap:14px;
    padding:11px 20px; cursor:pointer; transition:background .15s;
    border:none; background:none; width:100%; text-align:left;
  }
  .nav-dd-item:hover { background:var(--blue-pale); }
  .nav-dd-item-icon {
    width:32px; height:32px; border-radius:var(--r-sm); background:var(--blue-light);
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
  }
  .nav-dd-item-icon svg { width:15px; height:15px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
  .nav-dd-item-icon.red     { background:var(--red-light); }
  .nav-dd-item-icon.red svg { stroke:var(--red); }
  .nav-dd-item-label { font-family:var(--font-display); font-weight:700; font-size:13px; color:var(--blue); }
  .nav-dd-item-label.red { color:var(--red); }
  .nav-dd-divider { height:1px; background:var(--gray-line); margin:6px 0; }

  /* quick actions bar (below nav, logged-in only) */
  #logged-quickbar {
    display:none; background:var(--blue); padding:0;
  }
  #logged-quickbar.visible { display:block; }
  .qb-inner {
    max-width:1160px; margin:0 auto; padding:0 40px;
    display:flex; align-items:stretch; gap:0;
  }
  .qb-item {
    display:flex; align-items:center; gap:10px;
    padding:10px 24px; cursor:pointer; transition:background .2s;
    border:none; background:none; color:#fff;
    border-right:1px solid rgba(255,255,255,.1);
    font-family:var(--font-display); font-weight:700; font-size:13px;
  }
  .qb-item:hover { background:rgba(255,255,255,.1); }
  .qb-item svg { width:16px; height:16px; stroke:#fff; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }
  .qb-item.highlight { background:var(--red); }
  .qb-item.highlight:hover { background:var(--red-mid); }
  .qb-pts-display {
    margin-left:auto; display:flex; align-items:center; gap:8px;
    padding:10px 24px; border-left:1px solid rgba(255,255,255,.1);
  }
  .qb-pts-num  { font-family:var(--font-display); font-weight:900; font-size:18px; color:#fff; }
  .qb-pts-lbl  { font-size:11px; color:rgba(255,255,255,.6); font-weight:600; text-transform:uppercase; letter-spacing:1px; }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     PAGE â€” TARJETA VIRTUAL
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #page-tarjeta {
    display:none; position:fixed; inset:0; z-index:1500;
    background:#fff; overflow-y:auto;
  }
  #page-tarjeta.open { display:block; }

/* ────────────────────────────────────────
    INNER PAGE NAV (GLOBAL STANDARDIZED)
──────────────────────────────────────── */
.inner-page-nav {
  background: #fff !important; 
  border-bottom: 1px solid var(--gray-line) !important;
  box-shadow: none !important;
  position: sticky; top: 0; z-index: 1000;
}
.inner-page-nav-inner {
  max-width: 1160px; margin: 0 auto; padding: 0 40px; height: 64px;
  display: flex; align-items: center; justify-content: space-between;
}
.inner-page-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display) !important; font-weight: 800 !important; font-size: 14px !important; color: var(--blue) !important;
  background: none; border: none; cursor: pointer; transition: color .2s;
  text-decoration: none !important;
}
.inner-page-back:hover { color: var(--red) !important; text-decoration: none !important; }
.inner-page-back svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; margin-bottom: 2px; }
.inner-page-title-bar {
  font-family: var(--font-display); font-weight: 900; font-size: 15px; color: var(--blue); letter-spacing: 0.3px;
  position: absolute; left: 50%; transform: translateX(-50%);
}
.inner-page-spacer { width: 100px; }

/* ────────────────────────────────────────
    INNER PAGE GLOBAL CONTAINER
──────────────────────────────────────── */
.inner-page-layout {
  max-width: 1160px;
  margin: 0 auto;
  padding: 36px 40px 80px;
}
.inner-page-header {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 26px;
  color: var(--blue);
  letter-spacing: -0.3px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 24px;
}
  .tv-page-desc  { font-size:14px; color:var(--muted); line-height:1.65; margin-bottom:40px; max-width:700px; }

  /* tarjeta layout */
  .tv-layout { display:grid; grid-template-columns:auto 1fr; gap:48px; align-items:start; }

  /* la tarjeta en sÃ­ */
  .tv-card {
    width:340px; border-radius:16px; overflow:hidden;
    box-shadow:0 20px 56px rgba(27,43,107,.2);
    flex-shrink:0;
  }
  .tv-card-top {
    background:var(--blue); padding:28px 28px 20px;
    position:relative; overflow:hidden; min-height:200px;
  }
  /* cÃ­rculos decorativos fondo */
  .tv-card-top::before {
    content:''; position:absolute; width:220px; height:220px; border-radius:50%;
    border:40px solid rgba(255,255,255,.06); bottom:-60px; right:-40px;
  }
  .tv-card-top::after {
    content:''; position:absolute; width:140px; height:140px; border-radius:50%;
    border:28px solid rgba(255,255,255,.05); top:-20px; left:140px;
  }
  .tv-card-brand { font-family:var(--font-display); font-weight:900; font-size:32px; color:#fff; line-height:1; margin-bottom:4px; }
  .tv-card-tagline { font-family:var(--font-display); font-weight:700; font-size:12px; color:rgba(255,255,255,.7); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:24px; }
  .tv-card-name-vert {
    position:absolute; right:24px; top:0; bottom:0;
    display:flex; align-items:center;
    font-family:var(--font-display); font-weight:900; font-size:13px; color:rgba(255,255,255,.9);
    letter-spacing:3px; text-transform:uppercase;
    writing-mode:vertical-rl; text-orientation:mixed;
  }
  .tv-card-mid { display:flex; gap:0; }
  .tv-card-blue-block { flex:1; background:var(--blue); padding:16px 0 16px 28px; }
  .tv-card-red-block  { width:60px; background:var(--red); }

  /* barcode area */
  .tv-barcode-wrap {
    background:#fff; margin:0 28px 0; padding:14px 16px 10px;
    border-radius:8px 8px 0 0;
  }
  .tv-barcode-svg { width:100%; height:52px; display:block; }
  .tv-barcode-num { font-family:'Courier New',monospace; font-size:11px; color:var(--text); text-align:center; letter-spacing:2px; margin-top:4px; }

  /* info aside */
  .tv-info { padding-top:8px; }
  .tv-info-pts-card {
    background:var(--blue); border-radius:var(--r-lg); padding:28px 32px; margin-bottom:20px;
    display:flex; align-items:center; justify-content:space-between;
  }
  .tv-pts-big  { font-family:var(--font-display); font-weight:900; font-size:48px; color:#fff; letter-spacing:-1px; line-height:1; }
  .tv-pts-label { font-size:11px; color:rgba(255,255,255,.55); font-weight:600; text-transform:uppercase; letter-spacing:1px; margin-top:4px; }
  .tv-pts-actions { display:flex; flex-direction:column; gap:10px; }
  .tv-pts-btn {
    display:flex; align-items:center; gap:8px; padding:10px 18px;
    border-radius:var(--r-pill); font-family:var(--font-display); font-weight:700; font-size:13px;
    cursor:pointer; transition:all .2s; border:none; white-space:nowrap;
  }
  .tv-pts-btn.white { background:#fff; color:var(--blue); }
  .tv-pts-btn.white:hover { background:var(--blue-light); }
  .tv-pts-btn svg { width:15px; height:15px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

  .tv-info-row { display:flex; gap:12px; margin-bottom:20px; }
  .tv-info-chip {
    flex:1; background:var(--gray-bg); border-radius:var(--r-md); padding:16px;
    border:1px solid var(--gray-line);
  }
  .tv-info-chip-label { font-size:11px; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:0.8px; margin-bottom:4px; }
  .tv-info-chip-val   { font-family:var(--font-display); font-weight:800; font-size:16px; color:var(--blue); }
  .tv-info-chip-val.red { color:var(--red); }

  .tv-info-tip {
    background:var(--blue-light); border-radius:var(--r-md); padding:14px 16px;
    font-size:13px; color:var(--blue-mid); line-height:1.6; display:flex; gap:10px;
  }
  .tv-info-tip svg { width:16px; height:16px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; flex-shrink:0; margin-top:2px; }

  @media (max-width:760px) {
    .tv-layout { grid-template-columns:1fr; }
    .tv-card { width:100%; max-width:340px; }
  }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     PAGE â€” TRANSFERIR PUNTOS
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #page-transferir {
    display:none; position:fixed; inset:0; z-index:1500;
    background:#fff; overflow-y:auto;
  }
  #page-transferir.open { display:block; }

  .tr-card {
    background:#fff; border:1px solid var(--gray-line); border-radius:var(--r-lg);
    padding:32px; margin-bottom:20px;
  }
  .tr-card-title { font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--blue); margin-bottom:20px; display:flex; align-items:center; gap:10px; }
  .tr-card-title svg { width:18px; height:18px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

  .tr-search-row { display:grid; grid-template-columns:120px 1fr 44px; gap:8px; align-items:end; }
  .tr-search-btn {
    width:44px; height:44px; background:var(--blue); border:none; border-radius:var(--r-md);
    display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s;
  }
  .tr-search-btn:hover { background:var(--blue-mid); }
  .tr-search-btn svg { width:18px; height:18px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

  .tr-result {
    display:none; margin-top:20px; padding:16px; background:var(--blue-pale);
    border-radius:var(--r-md); border:1px solid var(--blue-light);
  }
  .tr-result.show { display:block; }
  .tr-result-row  { display:flex; gap:32px; flex-wrap:wrap; }
  .tr-result-item {}
  .tr-result-label { font-size:11px; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:0.8px; margin-bottom:3px; }
  .tr-result-val   { font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--blue); }

  .tr-amount-card {
    background:var(--gray-bg); border-radius:var(--r-md); padding:20px;
    margin-top:20px; border:1px solid var(--gray-line);
  }
  .tr-amount-label { font-size:12px; font-weight:700; color:var(--text); margin-bottom:8px; display:block; }
  .tr-amount-input {
    width:100%; padding:14px 16px; border:2px solid var(--blue-mid);
    border-radius:var(--r-md); font-size:22px; font-family:var(--font-display);
    font-weight:900; color:var(--blue); outline:none; background:#fff;
    letter-spacing:1px;
  }
  .tr-amount-meta { margin-top:8px; font-size:13px; color:var(--muted); }
  .tr-amount-meta strong { color:var(--blue); font-weight:700; }
  .tr-amount-meta a { color:var(--red); font-weight:600; text-decoration:none; }

  .tr-actions {
    display:flex; gap:12px; justify-content:flex-end; margin-top:28px;
    padding-top:24px; border-top:1px solid var(--gray-line);
  }
  .tr-btn-cancel {
    padding:12px 28px; font-size:14px; font-family:var(--font-display); font-weight:700;
    background:none; border:1.5px solid var(--gray-mid); border-radius:var(--r-md);
    color:var(--muted); cursor:pointer; transition:all .2s;
  }
  .tr-btn-cancel:hover { border-color:var(--blue); color:var(--blue); }
  .tr-btn-transfer {
    padding:12px 28px; font-size:14px; font-family:var(--font-display); font-weight:800;
    background:var(--blue); border:none; border-radius:var(--r-md);
    color:#fff; cursor:pointer; transition:all .2s;
  }
  .tr-btn-transfer:hover { background:var(--blue-mid); }
  .tr-btn-transfer:disabled { background:var(--gray-mid); cursor:not-allowed; }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     HERO â€” ACTIVAR BANNER
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  .hero-activar-banner {
    display:flex; align-items:center; gap:12px;
    background:#fff; border:1.5px solid var(--gray-mid); border-radius:var(--r-md);
    padding:12px 16px; cursor:pointer; transition:all .2s;
    max-width:480px;
  }
  .hero-activar-banner:hover {
    border-color:var(--blue); background:var(--blue-pale);
    transform:translateY(-1px); box-shadow:var(--shadow-sm);
  }
  .hero-activar-icon {
    width:36px; height:36px; border-radius:var(--r-sm);
    background:var(--blue-light); display:flex; align-items:center; justify-content:center;
    color:var(--blue-mid); flex-shrink:0;
  }
  .hero-activar-text {
    font-size:13px; color:var(--muted); line-height:1.5; flex:1;
  }
  .hero-activar-text strong { color:var(--blue); display:block; font-weight:700; margin-bottom:2px; }
  .hero-activar-arrow {
    font-size:20px; color:var(--muted); font-weight:300; flex-shrink:0;
    transition:transform .2s;
  }
  .hero-activar-banner:hover .hero-activar-arrow { transform:translateX(3px); color:var(--blue); }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     PAGE â€” ACTIVAR TARJETA
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  #page-activar {
    display:none; position:fixed; inset:0; z-index:1500;
    background:#fff; overflow-y:auto;
  }
  #page-activar.open { display:block; }
  .act-body { max-width:560px; margin:0 auto; padding:48px 40px 80px; }
  .act-state { display:none; }
  .act-state.active { display:block; }
  .act-form-card { background:var(--gray-bg); border-radius:var(--r-lg); padding:32px; border:1px solid var(--gray-line); }
  .act-form-intro { font-size:14px; color:var(--muted); line-height:1.6; margin-bottom:24px; padding-bottom:20px; border-bottom:1px solid var(--gray-line); }
  .act-loading { display:flex; flex-direction:column; align-items:center; gap:16px; padding:48px 24px; text-align:center; }
  .act-spinner { width:44px; height:44px; border:3px solid var(--blue-light); border-top-color:var(--blue); border-radius:50%; animation:spin .8s linear infinite; }
  @keyframes spin { to { transform:rotate(360deg); } }
  .act-loading-text { font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--blue); }
  .act-loading-sub  { font-size:13px; color:var(--muted); }
  .act-result-card { border-radius:var(--r-lg); padding:28px 32px; margin-bottom:24px; }
  .act-result-card.found    { background:var(--blue-light); border:1.5px solid var(--blue); }
  .act-result-card.notfound { background:var(--red-light);  border:1.5px solid #f5b8b8; }
  .act-result-card.already  { background:#FFF9E6;            border:1.5px solid #F5D76E; }
  .act-result-icon { width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:16px; }
  .act-result-card.found    .act-result-icon { background:var(--blue); }
  .act-result-card.notfound .act-result-icon { background:var(--red); }
  .act-result-card.already  .act-result-icon { background:#E6A817; }
  .act-result-title { font-family:var(--font-display); font-weight:900; font-size:20px; margin-bottom:8px; }
  .act-result-card.found    .act-result-title { color:var(--blue); }
  .act-result-card.notfound .act-result-title { color:var(--red-mid); }
  .act-result-card.already  .act-result-title { color:#7D5A00; }
  .act-result-desc { font-size:14px; line-height:1.65; margin-bottom:20px; }
  .act-result-card.found    .act-result-desc { color:var(--blue-mid); }
  .act-result-card.notfound .act-result-desc { color:#9B2B2B; }
  .act-result-card.already  .act-result-desc { color:#7D5A00; }
  .act-identity-row { display:flex; gap:24px; flex-wrap:wrap; background:rgba(255,255,255,.6); border-radius:var(--r-md); padding:14px 16px; margin-bottom:20px; }
  .act-identity-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--muted); margin-bottom:3px; }
  .act-identity-val   { font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--blue); }
  .act-single-action .btn-continue { width:100%; background:var(--red); color:#fff; border:none; border-radius:var(--r-md); padding:14px; font-size:15px; font-family:var(--font-display); font-weight:800; cursor:pointer; letter-spacing:0.3px; transition:all .2s; }
  .act-single-action .btn-continue:hover { background:var(--red-mid); transform:translateY(-1px); }
  .act-try-again { text-align:center; margin-top:16px; font-size:13px; color:var(--muted); }
  .act-try-again a { color:var(--blue-mid); font-weight:700; text-decoration:none; cursor:pointer; }
  .act-try-again a:hover { color:var(--red); }
  @media (max-width:600px) { .act-body { padding:28px 20px 60px; } }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     LOGGED-IN HERO OVERRIDE
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  /* when user logs in, hero shows personalized version */
  .hero-logged { display:none; flex-direction:column; justify-content:center; gap:24px; padding:80px 40px 80px 64px; }
  .hero-logged.visible { display:flex; }
  .hero-logged-greeting { font-family:var(--font-display); font-weight:900; font-size:42px; color:var(--blue); letter-spacing:-1.5px; line-height:1.1; }
  .hero-logged-greeting .red { color:var(--red); }
  .hero-logged-pts-row { display:flex; align-items:center; gap:16px; }
  .hero-logged-pts-big { font-family:var(--font-display); font-weight:900; font-size:64px; color:var(--blue); letter-spacing:-2px; line-height:1; }
  .hero-logged-pts-lbl { font-family:var(--font-display); font-weight:700; font-size:14px; color:var(--muted); text-transform:uppercase; letter-spacing:1.5px; }
  .hero-logged-quick { display:flex; gap:12px; flex-wrap:wrap; margin-top:8px; }
  .hero-logged-qbtn {
    display:flex; align-items:center; gap:8px; padding:12px 22px;
    border-radius:var(--r-pill); font-family:var(--font-display); font-weight:800; font-size:14px;
    cursor:pointer; border:none; transition:all .2s;
  }
  .hero-logged-qbtn.primary { background:var(--red); color:#fff; }
  .hero-logged-qbtn.primary:hover { background:var(--red-mid); transform:translateY(-1px); }
  .hero-logged-qbtn.secondary { background:var(--blue-light); color:var(--blue); }
  .hero-logged-qbtn.secondary:hover { background:var(--blue); color:#fff; }
  .hero-logged-qbtn.ghost { background:transparent; border:2px solid var(--gray-mid); color:var(--blue); }
  .hero-logged-qbtn.ghost:hover { border-color:var(--blue); }
  .hero-logged-qbtn svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

  /* ———————————————————————————————— 
     PAGE — MI CUENTA
  ———————————————————————————————— */
  #page-micuenta {
    display:none; position:fixed; inset:0; z-index:1500;
    background:var(--gray-bg); overflow-y:auto;
  }
  #page-micuenta.open { display:block; }

  .mc-layout {
    max-width:1160px; margin:0 auto; padding:36px 40px 80px;
  }

  /* page title */
  .mc-page-title {
    font-family:var(--font-display); font-weight:900; font-size:15px;
    color:var(--blue); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:6px;
  }
  .mc-page-desc {
    font-size:13px; color:var(--muted); line-height:1.6; margin-bottom:32px;
  }

  /* section block */
  .mc-section {
    background:#fff; border-radius:var(--r-lg); margin-bottom:16px;
    border:1px solid var(--gray-line); overflow:hidden;
  }
  .mc-section-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 24px; border-bottom:1px solid var(--gray-line);
    cursor:pointer; user-select:none;
    transition:background .15s;
  }
  .mc-section-header:hover { background:var(--gray-bg); }
  .mc-section-label {
    font-family:var(--font-display); font-weight:800; font-size:12px;
    color:var(--blue); text-transform:uppercase; letter-spacing:1px;
  }
  .mc-section-chevron {
    font-size:18px; color:var(--muted); transition:transform .25s; font-weight:300;
  }
  .mc-section.collapsed .mc-section-chevron { transform:rotate(180deg); }
  .mc-section-body { padding:20px 24px; }
  .mc-section.collapsed .mc-section-body { display:none; }

  /* —— NOTIFICACIONES —— */
  .mc-notif-card {
    background:var(--blue-pale); border:1.5px solid var(--blue-light);
    border-radius:var(--r-md); padding:16px 20px;
    display:flex; align-items:flex-start; gap:14px; margin-bottom:10px;
  }
  .mc-notif-card:last-child { margin-bottom:0; }
  .mc-notif-icon {
    width:36px; height:36px; border-radius:var(--r-sm); background:var(--blue-light);
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
  }
  .mc-notif-icon svg { width:16px; height:16px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; }
  .mc-notif-content { flex:1; }
  .mc-notif-title { font-family:var(--font-display); font-weight:800; font-size:14px; color:var(--blue); margin-bottom:3px; }
  .mc-notif-title a { color:var(--blue-mid); text-decoration:none; }
  .mc-notif-title a:hover { color:var(--red); text-decoration:underline; }
  .mc-notif-desc  { font-size:13px; color:var(--muted); line-height:1.5; }
  .mc-notif-time  { font-size:11px; color:var(--muted); margin-top:8px; display:flex; align-items:center; gap:4px; }
  .mc-notif-time svg { width:12px; height:12px; stroke:var(--muted); fill:none; stroke-width:1.8; stroke-linecap:round; }

  /* —— PREMIOS —— */
  .mc-empty {
    font-size:13px; color:var(--muted); font-style:italic;
  }

  /* â”€â”€ PUNTOS HEADER â”€â”€ */
  .mc-pts-header {
    display:flex; align-items:center; gap:8px; margin-bottom:16px;
    font-size:14px; color:var(--text-body);
  }
  .mc-pts-header strong { font-family:var(--font-display); font-weight:900; font-size:18px; color:var(--blue); }

  /* â”€â”€ CANJES CARRUSEL â”€â”€ */
  .mc-canjes-wrap {
    position:relative;
  }
  .mc-canjes-track-outer {
    overflow:hidden; border-radius:var(--r-md);
  }
  .mc-canjes-track {
    display:flex; gap:14px;
    transition:transform .45s cubic-bezier(.4,0,.2,1);
    will-change:transform;
  }
  .mc-canje-card {
    flex-shrink:0; width:180px; background:var(--gray-bg);
    border-radius:var(--r-md); overflow:hidden; border:1px solid var(--gray-line);
    cursor:pointer; transition:all .2s;
  }
  .mc-canje-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--gray-mid); }
  .mc-canje-img { position:relative; height:110px; overflow:hidden; }
  .mc-canje-img img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
  .mc-canje-card:hover .mc-canje-img img { transform:scale(1.06); }
  .mc-canje-pdm {
    position:absolute; top:0; left:0;
    background:var(--blue); color:#fff;
    font-family:var(--font-display); font-weight:800; font-size:8px;
    letter-spacing:0.5px; padding:3px 8px; text-transform:uppercase;
  }
  .mc-canje-bar {
    position:absolute; bottom:0; left:0; right:0;
    background:var(--blue); color:#fff;
    font-family:var(--font-display); font-weight:800; font-size:11px;
    text-align:center; padding:5px 0; letter-spacing:0.3px;
  }
  .mc-canje-body  { padding:10px 12px; }
  .mc-canje-pts-row { display:flex; align-items:baseline; gap:4px; margin-bottom:3px; }
  .mc-canje-pts   { font-family:var(--font-display); font-weight:900; font-size:18px; color:var(--blue); letter-spacing:-0.5px; }
  .mc-canje-lbl   { font-size:9px; font-weight:700; color:var(--muted); text-transform:uppercase; }
  .mc-canje-off   { font-family:var(--font-display); font-weight:900; font-size:13px; color:var(--red); margin-top:1px; }
  .mc-canje-name  { font-family:var(--font-display); font-weight:700; font-size:11px; color:var(--blue); line-height:1.3; margin-top:5px; }
  .mc-canje-desc  { font-size:10px; color:var(--muted); margin-top:2px; line-height:1.4; }

  /* carousel arrows */
  .mc-arrow {
    position:absolute; top:50%; transform:translateY(-50%);
    width:36px; height:36px; border-radius:50%; border:none;
    background:#fff; box-shadow:0 2px 12px rgba(0,0,0,.12);
    display:flex; align-items:center; justify-content:center;
    cursor:pointer; z-index:5; transition:all .2s; color:var(--blue);
  }
  .mc-arrow:hover { box-shadow:0 4px 18px rgba(0,0,0,.18); transform:translateY(-50%) scale(1.08); }
  .mc-arrow svg   { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; }
  .mc-arrow-prev  { left:-18px; }
  .mc-arrow-next  { right:-18px; }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     TOAST
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  .toast { position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--blue); color:#fff; border-radius:var(--r-pill); padding:12px 24px; font-family:var(--font-display); font-weight:700; font-size:14px; box-shadow:var(--shadow-lg); z-index:3000; opacity:0; transition:all .3s; pointer-events:none; white-space:nowrap; }
  .toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     WHATSAPP FLOAT
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  .whatsapp-float { position:fixed; bottom:24px; right:24px; z-index:500; width:52px; height:52px; border-radius:50%; background:#25D366; box-shadow:0 4px 16px rgba(37,211,102,.4); display:flex; align-items:center; justify-content:center; text-decoration:none; transition:all .2s; }
  .whatsapp-float:hover { transform:scale(1.1); box-shadow:0 6px 24px rgba(37,211,102,.5); }
  .whatsapp-float svg { width:26px; height:26px; fill:#fff; }

  /* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
     RESPONSIVE
  â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
  @media (max-width:900px) {
    #hero { display:block; }
    .hero-content { padding:48px 40px; text-align:center; align-items:center; }
    .hero-title { font-size:38px; }
    .features-grid { grid-template-columns:1fr 1fr; }
    .cf-inner, .tc-single-layout { grid-template-columns:1fr; gap:40px; }
    footer { grid-template-columns:1fr 1fr; }
    .beneficios-grid { grid-template-columns:1fr 1fr; }
    .app-inner { flex-direction:column; }
    .nav-links, .nav-actions { display:none; }
    .nav-hamburger { display:flex; }
  }
  @media (max-width:600px) {
    .container, .nav-inner, .cf-inner, .tc-single-layout, .app-inner { padding:0 20px; }
    .hero-content { padding:40px 20px; }
    .hero-title { font-size:32px; letter-spacing:-1px; }
    .features-grid { grid-template-columns:1fr; }
    .beneficios-grid { grid-template-columns:1fr; }
    footer { padding:40px 20px 0; grid-template-columns:1fr; gap:32px; }
    .footer-bottom { margin:24px 20px 0; flex-direction:column; gap:12px; text-align:center; }
    #como-funciona { padding:60px 0; }
  }

/* ── Suprimir overlay global de carga en la home (los skeleton loaders reemplazan el UX) ── */
body.home-revamp #loading {
  display: none !important;
}

/* ============================================================
   rg-revamp-postlogin.css
   Estilos para la vista post-login (IndexRevamp logueado).
   Alineado con diseño objetivo club-grido-revamp__21_.html
   ============================================================ */

/* ── Page Base ──────────────────────────────────────────── */
.rg-postlogin-page {
  background: #f3f4f6;
  min-height: calc(100vh - 90px);
  overflow-x: hidden;
}

/* Vista “Heladería cercana”: menos ruido; la barra azul de atajos no compite con el mapa */
.rg-postlogin-page.rg-heladeria-mode .rg-postlogin-actions {
  display: none !important;
}

.rg-postlogin-page.rg-heladeria-mode .rg-postlogin-top {
  padding-top: 12px;
}

/* ── Quick Actions Bar ──────────────────────────────────── */
.rg-postlogin-actions {
  background: #1B2B6B;
}

.rg-postlogin-actions-inner {
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 0 40px;
}

.rg-action-link {
  color: #ffffff;
  text-decoration: none;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 14px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  transition: background 0.2s;
}

.rg-action-link:last-child {
  border-right: 0;
}

.rg-action-link:hover {
  background: rgba(255, 255, 255, 0.06);
}

.rg-action-link-primary {
  background: #CE0037;
}

.rg-action-link-primary:hover {
  background: #d31f1e;
}

/* ── Top Section (Greeting + Fav Store) ─────────────────── */
.rg-postlogin-top,
.rg-postlogin-grid-section {
  max-width: 1160px;
  margin: 0 auto;
  padding: 28px 40px 0;
}

.rg-postlogin-top-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 16px;
}

/* ── Welcome Greeting ───────────────────────────────────── */
.rg-postlogin-welcome {
  font-family: 'Nunito', sans-serif;
  font-size: 42px !important;
  font-weight: 900;
  color: #1B2B6B;
  letter-spacing: -0.8px;
  line-height: 1.15;
  text-transform: none !important;
}

  .rg-postlogin-welcome .rg-user-name-accent {
    color: #CE0037;
  }

/* ── Tu Grido favorito (#logged-home .lh-modo-row chip en maqueta HTML) ── */
.rg-postlogin-fav-store {
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: 420px;
  padding: 10px 16px;
  background: #f0f2f8;
  border: 1px solid #eaedf3;
  border-radius: 14px;
  box-sizing: border-box;
  box-shadow: none;
  transition: border-color 0.2s;
}

.rg-postlogin-fav-chip-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: #e8ebf7;
}

.rg-postlogin-fav-chip-icon .material-icons {
  font-size: 18px;
  color: #2e3fa3;
}

.rg-postlogin-fav-chip-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.rg-postlogin-fav-title {
  font-family: 'Nunito', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #8a8fa8;
  margin: 0;
  line-height: 1.2;
}

.rg-postlogin-fav-name a {
  font-family: 'Nunito', sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: #1b2b6b;
  text-decoration: none;
  line-height: 1.3;
  transition: color 0.2s;
}

.rg-postlogin-fav-name a:hover {
  color: #CE0037;
}

.rg-postlogin-fav-address {
  font-family: 'Nunito', sans-serif;
  font-size: 12px;
  font-weight: 400;
  color: #8a8fa8;
  line-height: 1.35;
  margin: 0;
}

/* ── Summary (Tus canjes disponibles) ───────────────────── */
.rg-postlogin-summary {
  margin-top: 26px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
}

.rg-postlogin-summary h2 {
  margin: 0;
  color: #1B2B6B;
  font-family: 'Nunito', sans-serif;
  font-size: 42px !important;
  font-weight: 900;
  letter-spacing: -0.5px;
  line-height: 1.15;
  text-transform: none !important;
}

.rg-postlogin-summary p {
  margin: 8px 0 0;
  color: #3A3A5C;
  font-size: 15px;
  line-height: 1.6;
}

.rg-postlogin-summary p strong {
  color: #CE0037;
  font-weight: 800;
}

.rg-postlogin-account-link {
  color: #2E3FA3;
  text-decoration: none;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 13px;
  white-space: nowrap;
  transition: color 0.2s;
}

.rg-postlogin-account-link:hover {
  color: #CE0037;
}

/* ── Carousel Shell ─────────────────────────────────────── */
.rg-postlogin-carousel-shell {
  position: relative;
  margin-top: 18px;
}

.rg-postlogin-carousel-track {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding: 2px 40px 8px;
  scrollbar-width: none;
  scroll-behavior: smooth;
}

.rg-postlogin-carousel-track::-webkit-scrollbar {
  display: none;
}

.rg-postlogin-carousel-track .rg-card-revamp-root {
  flex: 0 0 200px;
}

/* ── Carousel Arrows ────────────────────────────────────── */
.rg-carr-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid #d8ddea;
  background: #ffffff;
  color: #1B2B6B;
  box-shadow: 0 4px 16px rgba(27, 43, 107, 0.18);
  cursor: pointer;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 300;
  line-height: 1;
  transition: all 0.2s ease;
}

.rg-carr-btn:hover {
  box-shadow: 0 6px 24px rgba(27, 43, 107, 0.28);
  transform: translateY(-50%) scale(1.08);
  color: #CE0037;
}

.rg-carr-btn:focus-visible {
  outline: 2px solid #2E3FA3;
  outline-offset: 2px;
}

.rg-carr-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.rg-carr-btn.prev {
  left: 2px;
}

.rg-carr-btn.next {
  right: 2px;
}

/* ── Grid Section (Canjeá tus puntos...) ────────────────── */
.rg-postlogin-grid-section {
  padding-bottom: 46px;
}

.rg-postlogin-grid-head {
  margin-top: 34px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
}

.rg-postlogin-grid-head span {
  text-transform: uppercase;
  letter-spacing: 2.5px;
  font-size: 11px;
  color: #CE0037;
  font-weight: 700;
  font-family: 'Nunito', sans-serif;
  display: block;
  margin-bottom: 8px;
}

.rg-postlogin-grid-head h3 {
  margin: 0;
  font-family: 'Nunito', sans-serif;
  font-size: 48px !important;
  line-height: 1.15;
  color: #1B2B6B;
  font-weight: 900;
  letter-spacing: -0.8px;
  text-transform: none !important;
}

.rg-postlogin-grid-head h3 em {
  color: #CE0037;
  font-style: normal;
}

.rg-postlogin-grid-head a {
  border: 1.5px solid #DDE1EA;
  border-radius: 50px;
  padding: 10px 24px;
  color: #1B2B6B;
  text-decoration: none;
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 14px;
  transition: all 0.2s;
  white-space: nowrap;
}

.rg-postlogin-grid-head a:hover {
  border-color: #1B2B6B;
  background: #F0F2F8;
  transform: translateY(-1px);
}

/* ── Grid Filter Tabs ───────────────────────────────────── */
.rg-postlogin-grid-filter {
  margin-top: 16px;
}

.rg-postlogin-grid-filter button {
  background: #1B2B6B;
  color: #fff;
  border: none;
  border-radius: 50px;
  padding: 8px 18px;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.2s;
}

.rg-postlogin-grid-filter button:hover {
  background: #2E3FA3;
  transform: translateY(-1px);
}

/* ── Benefits Grid ──────────────────────────────────────── */
.rg-postlogin-grid {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

/* ── No Results ─────────────────────────────────────────── */
.rg-postlogin-noresults {
  background: #ffffff;
  border: 1px solid #EAEDF3;
  border-radius: 20px;
  min-height: 260px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #8A8FA8;
  text-align: center;
}

.rg-postlogin-noresults i {
  display: block;
  font-size: 44px;
  margin-bottom: 8px;
  color: #8A8FA8;
}

.rg-postlogin-noresults p {
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  font-size: 15px;
  color: #8A8FA8;
  margin: 0;
}

/* ── Card Overrides for Carousel Context ────────────────── */
.rg-postlogin-carousel-track .bcard {
  border-radius: 14px;
}

.rg-postlogin-carousel-track .bcard-img-wrap {
  height: 130px;
}

.rg-postlogin-carousel-track .bcard-body {
  padding: 10px 12px 12px;
}

.rg-postlogin-carousel-track .bcard-pts-num {
  font-size: 17px;
}

.rg-postlogin-carousel-track .bcard-name {
  font-size: 12px;
}

.rg-postlogin-carousel-track .bcard-desc {
  font-size: 10px;
}

/* ════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════ */

@media (max-width: 992px) {
  .rg-postlogin-actions {
    display: none !important;
  }

  .rg-action-link:nth-child(2n) {
    border-right: 0;
  }

  .rg-postlogin-top,
  .rg-postlogin-grid-section {
    padding: 20px 20px 0;
    max-width: 100vw;
    overflow-x: hidden;
    box-sizing: border-box;
  }
  .rg-postlogin-carousel-shell {
    max-width: 100%;
  }

  .rg-postlogin-top-head {
    grid-template-columns: 1fr;
  }

  .rg-postlogin-welcome {
    font-size: 32px !important;
  }

  .rg-postlogin-summary {
    flex-direction: column;
    align-items: flex-start;
  }

  .rg-postlogin-summary h2 {
    font-size: 30px !important;
  }

  .rg-postlogin-grid-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .rg-postlogin-grid-head h3 {
    font-size: 34px !important;
  }

  .rg-postlogin-grid {
    display: flex;
    overflow-x: auto;
    flex-wrap: nowrap;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px; /* para la sombra si la hay */
    gap: 16px;
  }
  .rg-postlogin-grid::-webkit-scrollbar {
    display: none;
  }
  .rg-postlogin-grid .rg-card-revamp-root {
    flex: 0 0 280px;
    max-width: 85vw;
    scroll-snap-align: start;
  }

  .rg-postlogin-carousel-track {
    padding: 2px 20px 8px;
  }
}

@media (max-width: 600px) {
  .rg-postlogin-welcome {
    font-size: 28px !important;
  }

  .rg-postlogin-summary h2 {
    font-size: 26px !important;
  }

  .rg-postlogin-grid-head h3 {
    font-size: 28px !important;
  }

  .rg-carr-btn {
    display: none !important;
  }

  .rg-postlogin-carousel-track .rg-card-revamp-root {
    flex: 0 0 280px;
    max-width: 85vw;
  }

  .rg-postlogin-fav-store {
    max-width: none;
    padding: 10px 14px;
    gap: 10px;
  }

  .rg-postlogin-fav-chip-icon {
    width: 36px;
    height: 36px;
  }
}

/* Fuerza la ocultación total del footer global cuando la vista interna del mapa está activa en sociologo */
body.rg-hide-footer footer.revamp-footer,
body.rg-hide-footer footer.revamp-footer-logged,
body.rg-hide-footer .revamp-footer-bottom {
  display: none !important;
}

/* ── Skeleton Loaders ───────────────────────────────────── */
.rg-skeleton-card {
  background: white;
  border-radius: 12px;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding-bottom: 20px;
}

.rg-skeleton-img {
  width: 100%;
  aspect-ratio: 4/3;
  background: #e2e8f0;
  animation: pulse 1.5s infinite ease-in-out;
}

.rg-skeleton-text {
  height: 16px;
  background: #e2e8f0;
  margin: 16px 16px 8px;
  border-radius: 4px;
  animation: pulse 1.5s infinite ease-in-out;
}

.rg-skeleton-text.short {
  width: 60%;
  margin-top: 0;
}

@keyframes pulse {
  0% { opacity: 1; }
  50% { opacity: 0.4; }
  100% { opacity: 1; }
}

/* ════════════════════════════════════════════
   WHAT IS — Hero introductorio
   Estilos exclusivos de la pagina ¿Qué es?
   ════════════════════════════════════════════ */

.wi-hero {
  background: var(--blue);
  padding: 80px 0 72px;
  position: relative;
  overflow: hidden;
}

.wi-page {
  padding-top: 90px !important;
}

.wi-link-btn {
  text-decoration: none;
}
.wi-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    -45deg,
    rgba(255,255,255,.025) 0px, rgba(255,255,255,.025) 1px,
    transparent 1px, transparent 24px
  );
}
.wi-hero-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 40px;
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.wi-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.9);
  padding: 6px 14px;
  border-radius: var(--r-pill);
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font-display);
  border: 1px solid rgba(255,255,255,.18);
  width: fit-content;
  margin-bottom: 16px;
}
.wi-hero-badge-dot {
  width: 6px;
  height: 6px;
  background: #74C0FC;
  border-radius: 50%;
}
.wi-hero-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(30px, 3vw, 42px);
  line-height: 1.1;
  letter-spacing: -1px;
  color: #fff;
  margin-bottom: 18px;
}
.wi-hero-title .red {
  color: var(--red);
}
.wi-hero-desc {
  font-size: 16px;
  color: rgba(255,255,255,.68);
  line-height: 1.7;
  margin-bottom: 28px;
  max-width: 480px;
}
.wi-hero-ctas {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.wi-hero-stats {
  display: flex;
  gap: 0;
  justify-content: center;
}
.wi-hero-stat {
  flex: 1;
  text-align: center;
  padding: 24px 16px;
  border-radius: var(--r-lg);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  transition: background .2s, transform .2s;
  cursor: default;
}
.wi-hero-stat:hover {
  background: rgba(255,255,255,.12);
  transform: translateY(-2px);
}
.wi-hero-stat + .wi-hero-stat {
  margin-left: 12px;
}
.wi-hero-stat-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 32px;
  color: #fff;
  letter-spacing: -0.5px;
  line-height: 1;
}
.wi-hero-stat-num .unit {
  font-size: 16px;
  color: rgba(255,255,255,.55);
}
.wi-hero-stat-label {
  font-size: 12px;
  color: rgba(255,255,255,.55);
  font-weight: 600;
  margin-top: 6px;
}

/* ════════════════════════════════════════════
   WHAT IS — Sección instrucciones activación
   ════════════════════════════════════════════ */

.wi-activate {
  padding: 80px 0;
  background: var(--gray-bg);
}
.wi-activate-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 40px;
}
.wi-activate-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  margin-top: 40px;
}
.wi-activate-card {
  background: #fff;
  border-radius: var(--r-lg);
  padding: 32px;
  border: 1px solid var(--gray-line);
  transition: all .25s;
}
.wi-activate-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}
.wi-activate-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.wi-activate-icon.blue {
  background: var(--blue);
}
.wi-activate-icon.red {
  background: var(--red);
}
.wi-activate-icon svg {
  width: 24px;
  height: 24px;
  stroke: #fff;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.wi-activate-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 18px;
  color: var(--blue);
  margin-bottom: 12px;
}
.wi-activate-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.7;
}
.wi-activate-desc strong {
  color: var(--blue);
}
.wi-activate-list {
  margin: 14px 0 0;
  padding-left: 18px;
  color: var(--muted);
}
.wi-activate-list li {
  margin-bottom: 6px;
  line-height: 1.6;
  font-size: 13px;
}

/* ════════════════════════════════════════════
   WHAT IS — CTA final
   ════════════════════════════════════════════ */

.wi-cta-section {
  padding: 72px 0;
  background: #fff;
  text-align: center;
}
.wi-cta-inner {
  max-width: 600px;
  margin: 0 auto;
  padding: 0 40px;
}
.wi-cta-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 28px;
  color: var(--blue);
  letter-spacing: -0.5px;
  margin-bottom: 12px;
}
.wi-cta-title .accent {
  color: var(--red);
}
.wi-cta-desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 28px;
}
.wi-cta-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.wi-cta-btn {
  padding: 14px 32px;
  font-size: 15px;
}

.wi-club-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}

/* ════════════════════════════════════════════
   WHAT IS — Tarjeta Club override
   Fixes cut-off perks and footer overlap
   ════════════════════════════════════════════ */

.wi-page #tarjeta-club {
  padding-bottom: 100px;
  overflow: visible;
}
.wi-page #tarjeta-club .tc-single-layout {
  overflow: visible;
}
.wi-page #tarjeta-club .tc-single-text {
  overflow: visible;
}
.wi-page #tarjeta-club .tc-perks {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}

/* ════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════ */

@media (max-width: 900px) {
  .wi-hero-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .wi-hero-stats {
    justify-content: flex-start;
  }
  .wi-activate-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .wi-hero {
    padding: 48px 0 40px;
  }
  .wi-hero-inner {
    padding: 0 20px;
  }
  .wi-hero-title {
    font-size: 28px;
  }
  .wi-hero-ctas {
    flex-direction: column;
  }
  .wi-hero-stat-num {
    font-size: 24px;
  }
  .wi-activate-inner {
    padding: 0 20px;
  }
  .wi-cta-inner {
    padding: 0 20px;
  }
}

/* ─────────────────────────────
   TOKENS ESPECIFICOS DE REGISTER
───────────────────────────── */
:root {
  --blue:       #1B2B6B;
  --blue-mid:   #2E3FA3;
  --blue-light: #E8EBF7;
  --blue-pale:  #F0F2F8;
  --red:        #CE0037;
  --red-mid:    #C0392B;
  --red-light:  #FDEAEA;
  --gray-bg:    #F0F2F5;
  --gray-mid:   #DDE1EA;
  --gray-line:  #EAEDF3;
  --text:       #1B2B6B;
  --text-body:  #3A3A5C;
  --muted:      #8A8FA8;
  --font-display: 'Nunito', sans-serif;
  --font-body:    'Nunito Sans', sans-serif;
  --r-sm:   8px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  28px;
  --r-pill:50px;
  --shadow-sm: 0 2px 8px rgba(27,43,107,0.08);
  --shadow-md: 0 8px 24px rgba(27,43,107,0.12);
}

/* ─────────────────────────────
   ACCENT BAR TOP
───────────────────────────── */
.ap-topbar {
  background: var(--blue);
  height: 6px;
}

/* ─────────────────────────────
   NAVBAR
───────────────────────────── */
.ap-nav {
  background: #fff;
  border-bottom: 1px solid var(--gray-line);
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: var(--shadow-sm);
}
.ap-nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ap-nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 20px;
  color: var(--blue);
  text-decoration: none;
  cursor: pointer;
}
.ap-nav-logo-mark {
  width: 32px;
  height: 32px;
  background: var(--blue);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ap-nav-logo-mark svg { width:18px; height:18px; }
.ap-nav-logo em { color: var(--red); font-style: normal; }
.ap-nav-close {
  display: flex;
  align-items: center;
  gap: 6px;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  cursor: pointer;
  color: var(--muted);
  font-size: 13px;
  font-family: var(--font-display);
  font-weight: 700;
  transition: color .2s;
}
.ap-nav-close:hover { color: var(--blue); }

/* ─────────────────────────────
   STEPS BAR
───────────────────────────── */
.ap-steps-bar {
  display: flex;
  background: #fff;
  border-bottom: 3px solid var(--gray-line);
}
.ap-step-tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 20px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 13px;
  color: var(--muted);
  border-bottom: 3px solid transparent;
  transition: all .2s;
  cursor: default;
  margin-bottom: -3px; /* To overlap the parent's border */
}
.ap-step-tab.active { color: var(--blue); border-bottom-color: var(--blue); }
.ap-step-tab.done   { color: var(--red);  border-bottom-color: var(--red); }
.ap-step-num {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid currentColor;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 900;
  flex-shrink: 0;
  transition: all .2s;
}
.ap-step-tab.done .ap-step-num {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}
.ap-step-tab.done .ap-step-num::before { content: '✓'; font-size: 11px; }
.ap-step-tab.done .ap-step-num-inner   { display: none; }

/* ─────────────────────────────
   BODY / PANELS
───────────────────────────── */
.ap-body {
  max-width: 800px;
  margin: 0 auto;
  padding: 48px 40px 80px;
}
.ap-step-panel { display: none; }
.ap-step-panel.active { display: block; }

.ap-section-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 28px;
  color: var(--blue);
  letter-spacing: -0.5px;
  margin-bottom: 6px;
  margin-top: 0px;
}
.ap-section-sub {
  font-size: 14px;
  color: var(--muted);
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--gray-line);
}
.ap-section-sub a {
  color: var(--blue-mid);
  font-weight: 600;
  text-decoration: none;
}
.ap-section-sub a:hover { color: var(--red); }

/* ─────────────────────────────
   PASO 1 — DNI card
───────────────────────────── */
.ap-dni-card {
  background: #fff;
  border-radius: var(--r-lg);
  padding: 36px;
  border: 1px solid var(--gray-line);
  max-width: 480px;
  box-shadow: var(--shadow-sm);
}
.ap-dni-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--blue);
  margin-bottom: 20px;
}

/* ─────────────────────────────
   FORMULARIO BASE
───────────────────────────── */
.form-group   { margin-bottom: 16px; position:relative; }
.form-label   {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.3px;
  margin-bottom: 6px;
  display: block;
}
input.form-input, select.form-select,
.rg-active input.form-input, .rg-active select.form-select {
  width: 100% !important;
  padding: 0 16px !important; /* height is managed via padding inside if using height, else let's set height */
  height: 48px !important;
  border: 1.5px solid var(--gray-mid) !important;
  border-radius: var(--r-md) !important;
  font-size: 15px !important;
  font-family: var(--font-body) !important;
  color: var(--text) !important;
  outline: none !important;
  background: #fff !important;
  transition: border-color .2s, background .2s !important;
  box-sizing: border-box !important;
  margin-bottom: 0 !important;
  box-shadow: none !important;
}
input.form-input:focus, select.form-select:focus,
.rg-active input.form-input:focus, .rg-active select.form-select:focus { 
  border-color: var(--blue) !important; 
  box-shadow: 0 0 0 1px var(--blue) !important; 
}
select.form-select, .rg-active select.form-select {
  appearance: none !important;
  background-image: url(/Content/App/data:image/svg+xml,%3Csvg xmlns='http:/www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8FA8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E) !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
}
.form-input.has-error,
.form-select.has-error,
.form-input.input-validation-error,
.form-select.input-validation-error,
.form-input.validationElement,
.form-select.validationElement {
  border-color: var(--red) !important;
  background: var(--red-light);
}
.form-error {
  font-size: 12px;
  color: var(--red);
  margin-top: 5px;
  font-weight: 600;
  display: none;
  align-items: center;
  gap: 4px;
}
.form-error.show { display: flex; }
/* Soporte específico para validationMessage de Knockout/MVC */
.validationMessage {
  font-size: 12px;
  color: var(--red);
  margin-top: 5px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 4px;
}
.validationMessage:empty {
  display: none !important;
}

.form-error::before, .validationMessage::before {
  content: '!';
  width: 14px; height: 14px;
  background: var(--red);
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 900;
  flex-shrink: 0;
}

/* ─────────────────────────────
   GRIDS
───────────────────────────── */
.ap-form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px;}
.ap-form-grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px;}
.ap-phone-row   { display: grid; grid-template-columns: 140px 100px 1fr 150px; gap: 12px; }

/* Override legacy inline styles applied via JS on #OperatorCode2 */
#OperatorCode2 {
  padding: 0 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-height: 48px !important;
  box-sizing: border-box !important;
}
#OperatorCode2 > * {
  pointer-events: none !important;
}
#OperatorCode2 > div {
  background: transparent !important;
  border: none !important;
  height: auto !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
}
#OperatorCode2 > div > img {
  width: 20px !important;
  height: auto !important;
  margin-right: 8px !important;
  flex-shrink: 0;
}
#OperatorCode2 > div > p {
  padding-bottom: 0 !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  flex-grow: 1;
}
#OperatorCode2 > div > p:last-child {
  position: static !important;
  flex-grow: 0;
  margin-left: auto !important;
}
#OperatorCode2 i.material-icons {
  font-size: 20px !important;
  color: var(--blue) !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  line-height: 1 !important;
}
@media (max-width: 768px) {
  .ap-phone-row { 
    grid-template-columns: 100px 1fr; 
    gap: 8px; 
  }
}

/* ─────────────────────────────
   BOTONES CTA
───────────────────────────── */
.ap-single-action { margin-top: 24px; }
.btn-continue {
  width: 100%;
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: var(--r-md);
  padding: 14px;
  font-size: 15px;
  font-family: var(--font-display);
  font-weight: 800;
  cursor: pointer;
  letter-spacing: 0.3px;
  transition: all .2s;
  box-shadow: 0px 2px 4px rgba(0,0,0,0.1);
}
.btn-continue:hover { background: var(--red-mid); transform: translateY(-1px); }
.btn-continue:disabled { opacity: 0.6; cursor: not-allowed; transform: translateY(0); }

.ap-actions {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 16px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid var(--gray-line);
}
.btn-back-action {
  background: transparent;
  color: var(--muted);
  border: 1.5px solid var(--gray-mid);
  border-radius: var(--r-md);
  padding: 14px;
  font-size: 14px;
  font-family: var(--font-display);
  font-weight: 700;
  cursor: pointer;
  transition: all .2s;
  text-align: center;
}
.btn-back-action:hover { color: var(--blue); border-color: var(--blue); }
.btn-confirm {
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: var(--r-md);
  padding: 14px;
  font-size: 14px;
  font-family: var(--font-display);
  font-weight: 800;
  cursor: pointer;
  letter-spacing: 0.3px;
  transition: all .2s;
  box-shadow: 0px 2px 4px rgba(0,0,0,0.1);
  text-align: center;
}
.btn-confirm:hover { background: var(--red-mid); }
.btn-confirm:disabled { opacity: 0.6; cursor: not-allowed; }

/* ─────────────────────────────
   SOCIAL BUTTONS
───────────────────────────── */
.ap-social-row {
  display: flex;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.ap-social-btn {
  flex: 1;
  min-width: 140px;
  display: flex !important; 
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 16px !important;
  border: 1.5px solid var(--gray-mid) !important;
  border-radius: var(--r-md) !important;
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  color: var(--text) !important;
  background: #fff !important;
  cursor: pointer;
  transition: all .2s !important;
  white-space: nowrap;
  box-shadow: none !important;
  height: 44px;
  line-height: normal;
}
.ap-social-btn:hover { border-color: var(--blue) !important; background: var(--blue-pale) !important; }
.ap-social-btn i { font-size: 16px; flex-shrink: 0; }
.ap-social-btn.facebook { color: #1877F2 !important; }

.ap-social-note {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 8px;
  padding: 10px 14px;
  background: var(--gray-bg);
  border-radius: var(--r-sm);
}

/* ─────────────────────────────
   DIVISOR
───────────────────────────── */
.ap-divider {
  text-align: center;
  font-size: 13px;
  color: var(--muted);
  margin: 24px 0;
  position: relative;
}
.ap-divider::before, .ap-divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 44%;
  height: 1px;
  background: var(--gray-mid);
}
.ap-divider::before { left: 0; }
.ap-divider::after  { right: 0; }
.ap-divider span {
  position: relative;
  z-index: 1;
  background: #fff;
  padding: 0 10px;
}

/* ─────────────────────────────
   PASSWORD TOGGLE
───────────────────────────── */
.ap-input-wrap { position: relative; }
.ap-input-wrap .form-input { padding-right: 44px; }
.ap-pw-toggle {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  padding: 4px;
  transition: color .2s;
  z-index: 2; /* To sit over input */
}
.ap-pw-toggle:hover { color: var(--blue); }
.ap-pw-toggle i {
  font-size: 18px;
  stroke: currentColor;
}

/* ─────────────────────────────
   CHECKBOXES LEGALES
───────────────────────────── */
.ap-check-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 20px 0 6px;
}
.ap-check-item {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  position: relative;
}
.ap-check-item input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--blue);
  flex-shrink: 0;
  margin-top: 1px;
  cursor: pointer;
  position: relative !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  visibility: visible !important;
}
.ap-check-label { font-size: 13px; color: var(--text-body); line-height: 1.5; margin-left: 0; }
.ap-check-label a { color: var(--blue-mid); font-weight: 600; text-decoration: none; }
.ap-check-label a:hover { color: var(--red); }

/* Custom Overrides for Materialize */
.ap-check-item label {
   position: static;
   padding-left: 0;
   height: auto;
   line-height: 1.5;
}
.ap-check-item label:before { display: none !important; }
.ap-check-item label:after { display: none !important; }

/* ─────────────────────────────
   CAPTCHA MOCK
───────────────────────────── */
.ap-captcha-wrap { margin: 20px 0; }
.ap-captcha-note { font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.ap-captcha-box {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  border: 1px solid #d3d3d3;
  border-radius: 4px;
  padding: 14px 18px;
  background: #f9f9f9;
  max-width: 304px;
}

/* ─────────────────────────────
   MATERIALIZE TOASTS OVERRIDE
───────────────────────────── */
#toast-container {
  top: auto !important;
  bottom: 24px !important;
  right: 24px !important;
  left: auto !important;
  pointer-events: none;
}
.toast {
  background-color: var(--blue) !important;
  color: #fff !important;
  border-radius: var(--r-md) !important;
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  padding: 16px 24px !important;
  box-shadow: 0 12px 32px rgba(27,43,107,0.2) !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px;
  pointer-events: auto;
  max-width: 400px;
}
.toast::before {
  content: '!';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: var(--red);
  color: #fff;
  border-radius: 50%;
  font-size: 13px;
  font-weight: 900;
  flex-shrink: 0;
}

/* ─────────────────────────────
   RESPONSIVE
───────────────────────────── */
@media (max-width: 700px) {
  .ap-form-grid-2  { grid-template-columns: 1fr; }
  .ap-phone-row    { grid-template-columns: 1fr 1fr; }
  .ap-social-row   { flex-direction: column; }
  .ap-body         { padding: 28px 20px 60px; }
  .ap-nav-inner    { padding: 0 20px; }
  .ap-step-tab     { font-size: 11px; padding: 12px 8px; gap: 6px; }
  .ap-actions      { grid-template-columns: 1fr; }
  .ap-dni-card     { padding: 24px 20px; }
}

/* Fixes due to _SiteLayout Materialize styles leaking */
#ap-panel-1 select, #ap-panel-2 select {
    display: block !important;
}

/* ─────────────────────────────
   BANNER DE ERROR DE NEGOCIO (biz-error)
───────────────────────────── */
.biz-error {
  display: none;
  align-items: flex-start;
  gap: 12px;
  background: #FFF3F3;
  border: 1.5px solid #F5C2C2;
  border-left: 4px solid var(--red);
  border-radius: var(--r-md);
  padding: 14px 16px;
  margin-bottom: 20px;
  max-width: 480px;
  animation: bizErrIn .25s ease;
}
.biz-error.show { display: flex; }
@keyframes bizErrIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.biz-error-icon {
  width: 32px; height: 32px; flex-shrink: 0;
  background: var(--red); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.biz-error-icon svg { width: 16px; height: 16px; fill: #fff; }
.biz-error-body { flex: 1; min-width: 0; }
.biz-error-title {
  font-family: var(--font-display); font-weight: 800;
  font-size: 13px; color: #B91C1C; margin-bottom: 3px;
}
.biz-error-msg {
  font-size: 12px; color: #7F1D1D; line-height: 1.5;
}
.biz-error-action { margin-top: 8px; }
.biz-error-action a {
  font-size: 12px; font-weight: 700; color: var(--blue);
  font-family: var(--font-display); text-decoration: none;
  transition: color .2s;
}
.biz-error-action a:hover { color: var(--red); text-decoration: underline; }

@keyframes bizShake {
  0%,100% { transform: translateX(0); }
  20%      { transform: translateX(-6px); }
  40%      { transform: translateX(6px); }
  60%      { transform: translateX(-4px); }
  80%      { transform: translateX(4px); }
}
.ap-dni-card.shake { animation: bizShake .35s ease; }

/* ─────────────────────────────
   MODAL DE SOCIO ACTIVO (fullPartnerModal)
───────────────────────────── */
.rg-reg-modal-actions {
  display: flex;
  justify-content: center;
  padding: 20px 0 8px;
  border-top: 1px solid var(--gray-line);
  margin-top: 16px;
}

.rg-reg-modal-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--blue) !important;
  color: #fff !important;
  border-radius: var(--r-pill) !important;
  padding: 11px 28px !important;
  font-family: var(--font-display) !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background .2s !important;
  border: none !important;
}
.rg-reg-modal-btn:hover {
  background: var(--blue-mid) !important;
  color: #fff !important;
}

/* ─────────────────────────────
   REVAMP GLOBAL FOOTER
   Source: club-grido-footer (2).html
   ───────────────────────────── */

footer.revamp-footer {
    background: #1B2B6B;
    padding: 64px 64px 20px;
    display: grid !important;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 48px;
    border: none;
    min-height: 280px;
}

.revamp-footer .footer-col {
    display: flex;
    flex-direction: column;
}

/* col 1 — marca */
.revamp-footer .footer-logo {
    font-family: var(--font-display);
    font-weight: 900;
    font-size: 22px;
    color: #fff;
    margin-bottom: 14px;
}
.revamp-footer .footer-logo span { color: var(--red); }

.revamp-footer .footer-desc {
    font-size: 13px;
    color: rgba(255,255,255,.38);
    line-height: 1.65;
    max-width: 220px;
    margin-bottom: 20px;
}

.revamp-footer .footer-social { display: flex; gap: 10px; margin-bottom: 28px; flex-wrap: wrap; }
.revamp-footer .footer-social a {
    width: 34px; height: 34px;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
    display: flex; align-items: center; justify-content: center;
    text-decoration: none;
    transition: background .2s, transform .2s;
    position: relative;
}
.revamp-footer .footer-social a:hover { background: rgba(255,255,255,.2); transform: translateY(-2px); }
.revamp-footer .footer-social svg { width: 14px; height: 14px; fill: rgba(255,255,255,.6); }

/* Tooltip de red social */
.revamp-footer .footer-social a::after {
    content: attr(aria-label);
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%; transform: translateX(-50%);
    background: rgba(0,0,0,.75);
    color: #fff;
    font-family: var(--font-display);
    font-size: 10px;
    font-weight: 700;
    white-space: nowrap;
    padding: 4px 8px;
    border-radius: 4px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s;
}
.revamp-footer .footer-social a:hover::after { opacity: 1; }

/* badge de país */
.revamp-footer .footer-country-badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--r-pill);
    padding: 6px 14px;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 12px;
    color: rgba(255,255,255,.65);
    cursor: pointer;
    transition: all .2s;
}
.revamp-footer .footer-country-badge:hover {
    background: rgba(255,255,255,.13);
    color: #fff;
    border-color: rgba(255,255,255,.25);
}
.revamp-footer .footer-country-badge .chev {
    width: 7px; height: 7px;
    border-right: 1.5px solid rgba(255,255,255,.4);
    border-bottom: 1.5px solid rgba(255,255,255,.4);
    transform: rotate(45deg);
    margin-top: -3px;
}

/* cols 2-4 — nav */
.revamp-footer .footer-col-title {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 13px;
    color: #fff;
    margin-bottom: 16px;
    letter-spacing: 0.2px;
}

.revamp-footer .footer-links {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.revamp-footer .footer-links a {
    font-size: 13px;
    color: rgba(255,255,255,.38);
    text-decoration: none;
    transition: color .2s;
    line-height: 1.4;
    cursor: pointer;
}
.revamp-footer .footer-links a:hover { color: var(--red); }

/* ─────────────────────────────
   FOOTER BOTTOM
   ───────────────────────────── */
.revamp-footer-bottom {
    background: #152152; /* Slightly darker than main footer */
    padding: 24px 64px 32px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
    border-top: 1px solid rgba(255,255,255,.07);
}

.revamp-footer-bottom .footer-copy {
    font-size: 12px;
    color: rgba(255,255,255,.25);
    font-weight: 300;
}

.revamp-footer-bottom .footer-legal-wrap {
    display: flex;
    align-items: center;
    gap: 40px;
}

.revamp-footer-bottom .footer-legal-links { 
    display: flex; 
    gap: 20px; 
}
.revamp-footer-bottom .footer-legal-links a {
    font-size: 12px;
    color: rgba(255,255,255,.4);
    text-decoration: none;
    transition: color .2s;
    cursor: pointer;
}
.revamp-footer-bottom .footer-legal-links a:hover { color: #fff; }

.revamp-seals {
    display: flex;
    gap: 16px;
    align-items: center;
}

.revamp-seal-item img,
#siteseal img {
    height: 32px;
    width: auto;
    filter: grayscale(1) brightness(1.5);
    opacity: 0.4;
    transition: all .3s;
}
.revamp-seal-item:hover img,
#siteseal:hover img {
    filter: grayscale(0) brightness(1);
    opacity: 1;
}

/* ─────────────────────────────
   WHATSAPP FLOAT
   ───────────────────────────── */
.revamp-wa-float {
    position: fixed;
    bottom: 24px; right: 24px;
    width: 52px; height: 52px;
    border-radius: 50%;
    background: #25D366;
    display: flex; align-items: center; justify-content: center;
    text-decoration: none;
    box-shadow: 0 4px 16px rgba(37,211,102,.4);
    transition: transform .2s, box-shadow .2s;
    z-index: 500;
}
.revamp-wa-float:hover { transform: scale(1.1); box-shadow: 0 6px 24px rgba(37,211,102,.5); }
.revamp-wa-float svg { width: 26px; height: 26px; fill: #fff; }

/* ─────────────────────────────
   MODALES LEGALES
   ───────────────────────────── */
#revamp-legal-overlay {
    display: none;
    position: fixed; inset: 0; z-index: 2000;
    background: rgba(27,43,107,.5);
    backdrop-filter: blur(4px);
    align-items: center; justify-content: center;
    padding: 20px;
}
#revamp-legal-overlay.open { display: flex; }

.revamp-legal-modal {
    background: #fff; border-radius: 28px; padding: 40px;
    width: 100%; max-width: 560px; position: relative;
    box-shadow: 0 32px 80px rgba(27,43,107,.22);
    animation: revampModalIn .25s ease;
    max-height: 90vh; display: flex; flex-direction: column;
}
.revamp-legal-modal.revamp-faq-modal { max-width: 640px; }

@keyframes revampModalIn {
    from { opacity:0; transform: translateY(20px) scale(.97); }
    to   { opacity:1; transform: translateY(0)    scale(1);   }
}

.revamp-legal-modal .lm-close {
    position: absolute; top: 16px; right: 16px;
    width: 32px; height: 32px; border-radius: 50%;
    background: #F0F2F5; border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; color: #8A8FA8; transition: background .2s; line-height: 1;
}
.revamp-legal-modal .lm-close:hover { background: #DDE1EA; }

.revamp-legal-modal .lm-header { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.revamp-legal-modal .lm-icon {
    width: 36px; height: 36px; background: #E8EBF7; border-radius: 9px;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.revamp-legal-modal .lm-title { font-family: var(--font-display); font-weight: 900; font-size: 20px; color: var(--blue); text-transform: none; margin: 0; line-height: 1.2; }
.revamp-legal-modal .lm-body { overflow-y: auto; padding-right: 6px; flex: 1; }
    .revamp-legal-modal .lm-body p {
        font-size: 13px;
        color: var(--blue);
        line-height: 1.75;
        margin-bottom: 10px;
    }
.revamp-legal-modal .lm-body p:last-child { margin-bottom: 0; }
.revamp-legal-modal .lm-body p strong { color: var(--blue); }
.revamp-legal-modal .lm-body a { color: var(--blue-mid); font-weight: 600; text-decoration: none; }
.revamp-legal-modal .lm-body a:hover { color: var(--red); }
.revamp-legal-modal .lm-subtitle {
    font-family: var(--font-display); font-weight: 800; font-size: 12px; color: var(--blue);
    text-transform: uppercase; letter-spacing: 0.8px; margin-top: 18px; margin-bottom: 4px;
    border-bottom: 1px solid var(--gray-line); padding-bottom: 4px;
}
.revamp-legal-modal .lm-category {
    font-family: var(--font-display); font-weight: 900; font-size: 11px; color: var(--red);
    text-transform: uppercase; letter-spacing: 1.5px; margin-top: 22px; margin-bottom: 8px;
}

/* Custom scrollbar for modal body */
.revamp-legal-modal .lm-body::-webkit-scrollbar { width: 5px; }
.revamp-legal-modal .lm-body::-webkit-scrollbar-track { background: transparent; }
.revamp-legal-modal .lm-body::-webkit-scrollbar-thumb { background: var(--gray-mid); border-radius: 4px; }
.revamp-legal-modal .lm-body::-webkit-scrollbar-thumb:hover { background: var(--muted); }

/* Acordeón FAQ */
.revamp-faq-item { border-bottom: 1px solid var(--gray-line); }
.revamp-faq-item:last-child { border-bottom: none; }
.revamp-faq-q {
    width: 100%; text-align: left; background: none; border: none; cursor: pointer;
    display: flex; justify-content: space-between; align-items: center;
    padding: 11px 0; gap: 12px;
    font-family: var(--font-display); font-weight: 700; font-size: 13px; color: var(--blue);
    transition: color .2s;
}
.revamp-faq-q:hover { color: var(--red); }
.revamp-faq-icon {
    font-size: 18px; font-weight: 400; color: var(--muted);
    transition: transform .25s, color .2s; flex-shrink: 0; line-height: 1;
}
.revamp-faq-q.open .revamp-faq-icon { transform: rotate(45deg); color: var(--red); }
.revamp-faq-a { display: none; padding: 0 0 12px; }
.revamp-faq-a p { font-size: 13px; color: var(--muted); line-height: 1.7; margin-bottom: 0; }

.revamp-legal-modal .lm-footer {
    display: flex; justify-content: flex-end; gap: 10px; margin-top: 24px; padding-top: 18px;
    border-top: 1px solid var(--gray-line); flex-shrink: 0;
}

/* Modal button styles — matching mockup */
.lm-btn-ghost {
    font-family: var(--font-display); font-weight: 800; font-size: 13px;
    padding: 9px 18px; border-radius: 50px;
    border: 1.5px solid var(--gray-mid); background: transparent; color: var(--blue);
    cursor: pointer; text-decoration: none;
    display: inline-flex; align-items: center; transition: all .2s;
}
.lm-btn-ghost:hover { border-color: var(--blue); background: var(--blue-pale); }
.lm-btn-primary {
    font-family: var(--font-display); font-weight: 800; font-size: 13px;
    padding: 9px 18px; border-radius: 50px; border: none;
    background: var(--blue); color: #fff; cursor: pointer; transition: all .2s;
}
.lm-btn-primary:hover { background: var(--blue-mid); }



/* ─────────────────────────────
   COUNTRY SELECTOR MENU
   ───────────────────────────── */
#revamp-country-overlay { display: none; position: fixed; inset: 0; z-index: 2100; background: rgba(0,0,0,.3); backdrop-filter: blur(2px); }
#revamp-country-menu {
    display: none; position: fixed; bottom: 0; left: 0; right: 0; z-index: 2101;
    background: #fff; border-radius: 20px 20px 0 0; padding: 24px;
    box-shadow: 0 -8px 40px rgba(27,43,107,.18); animation: revampSlideUp .25s ease;
}
@keyframes revampSlideUp { from { transform: translateY(100%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.revamp-country-option {
    display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-radius: 12px;
    border: 1.5px solid var(--gray-mid); background: #fff; cursor: pointer;
    font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--blue);
    transition: all .2s; width: 100%; text-align: left;
}
.revamp-country-option:hover { border-color: var(--blue); background: var(--blue-pale); }
.revamp-country-option .check { margin-left: auto; visibility: hidden; }
.revamp-country-option.active .check { visibility: visible; }

/* Responsive adjustments */
@media (max-width: 900px) {
    footer.revamp-footer { grid-template-columns: 1fr 1fr; padding: 48px 24px 40px; }
    .revamp-footer-bottom { padding: 24px 24px 32px; }
}

@media (max-width: 768px) {
    .revamp-footer-bottom .footer-legal-wrap { flex-direction: column; gap: 20px; align-items: flex-start; }
}

@media (max-width: 600px) {
    footer.revamp-footer { grid-template-columns: 1fr; }
    .revamp-footer-bottom { flex-direction: column; text-align: center; align-items: center; }
    .revamp-footer-bottom .footer-legal-wrap { align-items: center; }
}

/* Hide legacy app store dialog in revamp mode */
body.rg-active #stores-dialog-container { display: none !important; }

/* ─────────────────────────────
   CÓMO CANJEAR — PDF card
   ───────────────────────────── */
.lm-canje-pdf-accordion {
    border: 1.5px solid var(--gray-line);
    border-radius: var(--r-md);
    overflow: hidden;
    margin-top: 8px;
    background: #fff;
}
.lm-canje-pdf-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    cursor: pointer;
    transition: background .2s;
    background: #fff;
    user-select: none;
    outline: none;
}
.lm-canje-pdf-card:hover,
.lm-canje-pdf-card:focus-visible { background: var(--blue-pale); }
.lm-canje-pdf-card[aria-expanded="true"] { background: var(--blue-light); }
#canje-pdf-chevron { transition: transform .25s ease; flex-shrink: 0; }

.lm-canje-pdf-viewer {
    border-top: 1px solid var(--gray-line);
    background: #3C3C3C;
}
.lm-canje-pdf-viewer-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 14px;
    background: #2C2C2C;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 11px;
    color: rgba(255,255,255,.55);
}
.lm-canje-pdf-viewer-frame {
    position: relative;
    background: #525659;
    height: 480px;
}
.lm-canje-pdf-viewer-frame iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}
.lm-canje-pdf-loading {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.75);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 13px;
    pointer-events: none;
}

@media (max-width: 600px) {
    .lm-canje-pdf-viewer-frame { height: 60vh; min-height: 320px; }
}

/* ─────────────────────────────
   CÓMO SUMAR PUNTOS — Modal
   ───────────────────────────── */
.revamp-legal-modal.revamp-points-modal { max-width: 720px; }

.lm-tabla-header {
    background: var(--blue); color: #fff;
    font-family: var(--font-display); font-weight: 800; font-size: 13px;
    padding: 10px 16px; border-radius: var(--r-sm) var(--r-sm) 0 0;
    margin-top: 16px;
}
.lm-tabla-cols {
    display: grid; grid-template-columns: 1fr 1fr;
    border: 1px solid var(--gray-line); border-top: none;
    border-radius: 0 0 var(--r-sm) var(--r-sm); overflow: hidden;
}
.lm-tabla-col { border-right: 1px solid var(--gray-line); }
.lm-tabla-col:last-child { border-right: none; }
.lm-tabla-col-head {
    display: grid; grid-template-columns: 1fr auto;
    padding: 8px 14px; border-bottom: 1.5px solid var(--gray-line);
    font-family: var(--font-display); font-weight: 800; font-size: 12px; color: var(--blue);
}
.lm-tabla-row {
    display: grid; grid-template-columns: 1fr auto;
    padding: 9px 14px; border-bottom: 1px solid var(--gray-line);
    font-size: 12px; color: var(--text-body); align-items: center;
}
.lm-tabla-row:last-child { border-bottom: none; }
.lm-tabla-row .pts { color: var(--blue); font-weight: 700; font-family: var(--font-display); white-space: nowrap; padding-left: 8px; }
.badge-new {
    display: inline-block; background: var(--red); color: #fff;
    font-family: var(--font-display); font-weight: 800; font-size: 9px;
    padding: 1px 5px; border-radius: 3px; margin-left: 5px; vertical-align: middle;
    text-transform: uppercase;
}
.lm-search-wrap { margin-bottom: 4px; }
.lm-search-wrap input {
    width: 100%; border: none; border-bottom: 1.5px solid var(--gray-mid);
    padding: 6px 2px; font-size: 13px; color: var(--text-body); outline: none;
    font-family: var(--font-body); background: transparent;
}
.lm-search-wrap input::placeholder { color: var(--muted); font-size: 12px; }
.lm-search-wrap input:focus { border-bottom-color: var(--blue); }
.lm-limites-table {
    border: 1px solid var(--gray-line); border-top: none;
    border-radius: 0 0 var(--r-sm) var(--r-sm);
}
.lm-limite-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 14px; border-bottom: 1px solid var(--gray-line);
    font-size: 12px; color: var(--text-body);
}
.lm-limite-row:last-child { border-bottom: none; }
.lm-limite-row .pts { color: var(--blue); font-weight: 700; font-family: var(--font-display); white-space: nowrap; padding-left: 8px; }

@media (max-width: 600px) {
    .revamp-legal-modal.revamp-points-modal .lm-points-header-grid { grid-template-columns: 1fr !important; }
    .lm-tabla-cols { grid-template-columns: 1fr; }
    .lm-tabla-col { border-right: none; border-bottom: 1px solid var(--gray-line); }
    .lm-tabla-col:last-child { border-bottom: none; }
}

/* ─────────────────────────────
   REVAMP GLOBAL FOOTER (EXTRAS)
   Ajustes para integrar contenido legacy
   de Footer.cshtml al nuevo diseño.
   ───────────────────────────── */

/* Reset del layout legacy del footer (SiteG2.css) solo en revamp.
   El footer viejo usa position:absolute + container con margin-bottom fijo. */
body.rg-active footer.revamp-footer {
  position: static !important;
  bottom: auto !important;
  width: 100% !important;
}

body.rg-active .container {
  margin-bottom: 0 !important;
}

/* El badge de país estaba estirándose por flex column. */
.revamp-footer .footer-country-badge {
  align-self: flex-start;
  width: auto;
  max-width: max-content;
}

/* Seals: mostrar versión nítida (sin grisado). */
.revamp-seal-item img,
#siteseal img {
  filter: none !important;
  opacity: 1 !important;
}

/* Marca */
.revamp-footer .footer-brand-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  margin-bottom: 14px;
}

.revamp-footer .footer-brand-image {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.revamp-footer .footer-brand-link .footer-logo {
  margin-bottom: 0;
}

/* AppStore / GooglePlay */
.revamp-footer .revamp-store-buttons {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

/* Ajustes visuales de store buttons dentro del revamp */
.revamp-footer .revamp-store-buttons .img-store-container img {
  max-height: 34px;
  width: auto;
}

/* Permisos */
.revamp-footer .revamp-permisos-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.revamp-footer .revamp-permiso-item {
  /* Queremos checkbox+label a la izquierda y warnings a la derecha */
  justify-content: space-between;
  gap: 0;
}

.revamp-footer .revamp-permiso-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.revamp-footer .revamp-permiso-warnings {
  display: flex;
  gap: 10px;
  align-items: center;
  padding-top: 2px;
}

.revamp-footer .revamp-permiso-warnings a {
  text-decoration: none;
}

.revamp-footer .revamp-permiso-warning-icon {
  font-size: 20px;
  color: var(--red);
  opacity: 0.95;
}

/* Link de cuenta (proviene de _LinkBtnFooter.cshtml, legacy). */
.revamp-footer .revamp-permisos-list .list-group-item.apple-sign-in-footer {
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
}

.revamp-footer .revamp-permisos-list .list-group-item.apple-sign-in-footer button {
  width: auto;
}

@media (max-width: 600px) {
  .revamp-footer .footer-country-badge {
    align-self: center;
  }

  .revamp-footer .footer-brand-link {
    justify-content: center;
  }

  .revamp-footer .footer-desc {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .revamp-footer .revamp-store-buttons {
    justify-content: center;
  }

  .revamp-footer .revamp-permiso-warnings {
    gap: 8px;
  }
}

body.rg-active footer.revamp-footer.revamp-footer-logged {
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  min-height: 280px;
  padding: 64px 64px 20px;
  align-items: flex-start;
  justify-items: start;
}

body.rg-active footer.revamp-footer.revamp-footer-logged .footer-links {
  gap: 8px;
}

body.rg-active footer.revamp-footer.revamp-footer-logged .footer-links a {
  color: rgba(255, 255, 255, 0.36);
}

@media (max-width: 900px) {
  body.rg-active footer.revamp-footer.revamp-footer-logged {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 36px 24px;
    min-height: auto;
  }
}


/* ════════════════════════════════
     CÓMO FUNCIONA
  ════════════════════════════════ */
#como-funciona {
  padding: 80px 0;
  background: var(--blue);
}

.cf-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 40px;
  display: grid;  
  gap: 72px;
  align-items: center;
}
@media only screen and (min-width: 993px) {
  .cf-inner {
    grid-template-columns: 1fr 1fr;
  }
}
.cf-label {
  color: rgba(255,255,255,.5);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  font-family: var(--font-display);
  margin-bottom: 12px;
  display: block;
}

.cf-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 34px;
  color: #fff;
  letter-spacing: -0.8px;
  line-height: 1.15;
  margin-bottom: 18px;
}

  .cf-title .accent {
    color: var(--red);
  }

.cf-desc {
  font-size: 15px;
  color: rgba(255,255,255,.55);
  line-height: 1.7;
  margin-bottom: 36px;
}

.cf-steps {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.cf-step {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.cf-step-num {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--red);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 13px;
  color: #fff;
  flex-shrink: 0;
  margin-top: 1px;
}

.cf-step-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  color: #fff;
  margin-bottom: 3px;
}

.cf-step-desc {
  font-size: 13px;
  color: rgba(255,255,255,.45);
  line-height: 1.55;
}

.cf-visual {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Pasos visuales (Opción A) en columna derecha de Cómo Funciona ── */
.cf-steps-visual {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  max-width: 100%;
}

.cf-sv-step {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  position: relative;
}
/* línea conectora entre pasos */
.cf-sv-connector {
  position: absolute;
  left: 27px;
  top: 56px;
  width: 2px;
  height: calc(100% - 8px);
  background: rgba(255,255,255,.08);
}

.cf-sv-icon-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  padding-bottom: 28px;
}

.cf-sv-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 10px;
  color: var(--red);
  letter-spacing: 2px;
  margin-bottom: 8px;
}

.cf-sv-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
  transition: background .2s, border-color .2s;
}

  .cf-sv-icon:hover {
    background: rgba(255,255,255,.13);
    border-color: rgba(255,255,255,.25);
  }

  .cf-sv-icon svg {
    width: 24px;
    height: 24px;
  }

.cf-sv-body {
  padding-top: 24px;
  padding-bottom: 28px;
  flex: 1;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.cf-sv-step:last-child .cf-sv-body {
  border-bottom: none;
}

.cf-sv-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 16px;
  color: #fff;
  margin-bottom: 6px;
  line-height: 1.2;
}

.cf-sv-desc {
  font-size: 13px;
  color: rgba(255,255,255,.5);
  line-height: 1.6;
}

.virtual-card {
  width: 100%;
  max-width: 300px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 24px;
  padding: 28px;
}

.vc-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 24px;
}

.vc-logo {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 15px;
  color: #fff;
}

  .vc-logo span {
    color: var(--red);
  }

.vc-chip {
  width: 34px;
  height: 26px;
  background: rgba(255,255,255,.15);
  border-radius: 5px;
}

.vc-number {
  font-family: 'Courier New',monospace;
  font-size: 13px;
  color: rgba(255,255,255,.3);
  letter-spacing: 2px;
  margin-bottom: 20px;
}

.vc-pts {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 40px;
  color: #fff;
  letter-spacing: -1px;
}

  .vc-pts sub {
    font-size: 16px;
    color: rgba(255,255,255,.5);
    font-weight: 700;
    bottom: 0;
  }

.vc-sublabel {
  font-size: 10px;
  color: rgba(255,255,255,.35);
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-top: 4px;
}

.vc-divider {
  height: 1px;
  background: rgba(255,255,255,.08);
  margin: 20px 0;
}

.vc-footer {
  display: flex;
  justify-content: space-between;
}

.vcf-lbl {
  font-size: 9px;
  color: rgba(255,255,255,.35);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.vcf-val {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  margin-top: 3px;
}

  .vcf-val.red {
    color: var(--red);
  }

/* rg-revamp-external-link.css
   Overrides para las vistas de Vinculación de cuentas externas.
   Estas reglas tienen mayor especificidad que .modal de rg-revamp-full.css
   para evitar que aplique su padding:40px genérico.
*/

/* El wrapper Materialize #modalConfirmPassword no debe tener padding propio */
#modalConfirmPassword.modal {
  padding: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  max-width: 440px !important;
  width: 440px !important;
}

/* La tarjeta interna de contenido (tanto password como éxito) toma el padding del diseño */
#modalConfirmPassword .cg-extlink-modal-card {
  background: #fff;
  border-radius: 20px;
  padding: 36px 40px 32px;
  position: relative;
  width: 100%;
  box-sizing: border-box;
}

/* === Botones de vinculación — igual al maquetado base === */

/* Boton primario: fondo rojo, letra blanca, hover rojo oscuro */
.cg-extlink-btn-primary {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 13px;
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: var(--r-pill);
  padding: 10px 24px;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s, box-shadow 0.15s;
  display: inline-flex;
  align-items: center;
}
.cg-extlink-btn-primary:hover {
  background: var(--red-mid);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

/* Botón ghost: fondo transparente/blanco, letra azul, borde gris fino */
.cg-extlink-btn-ghost {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 13px;
  background: transparent;
  color: var(--blue);
  border: 1.5px solid var(--gray-mid);
  border-radius: var(--r-pill);
  padding: 9px 20px;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  display: inline-flex;
  align-items: center;
}
.cg-extlink-btn-ghost:hover {
  border-color: var(--blue);
  background: var(--blue-pale);
}

/* rg-revamp-unsubscribe.css
   Estilos para la vista de Solicitud de Baja (UnsubscribeMemberRevamp)
*/

.baja-body {
  max-width: 680px;
  margin: 0 auto;
  padding: 48px 40px 80px;
}

.baja-header {
  margin-bottom: 32px;
}

.baja-nav {
  background: #fff;
  border-bottom: 3px solid var(--blue);
  position: sticky;
  top: 0;
  z-index: 10;
}

.baja-nav-inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 40px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.baja-nav-logo {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 20px;
  color: var(--blue);
  display: flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
}

.baja-nav-logo span { color: var(--red); }

.baja-nav-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 13px;
  color: var(--blue);
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: color .2s;
}

.baja-nav-back:hover { color: var(--red); }

.baja-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 26px;
  color: var(--blue);
  letter-spacing: -0.4px;
  margin-bottom: 6px;
  line-height: 1.2;
}

.baja-title .accent { color: var(--red); }

.baja-subtitle {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 28px;
}

/* Alerta roja */
.baja-alert {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--red-light);
  border: 1.5px solid #f5b8b8;
  border-radius: var(--r-md);
  padding: 16px 18px;
  margin-bottom: 24px;
}

.baja-alert svg {
  width: 20px;
  height: 20px;
  stroke: var(--red);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  flex-shrink: 0;
  margin-top: 1px;
}

.baja-alert-text {
  font-size: 13px;
  color: var(--red-mid);
  line-height: 1.6;
}

/* Motivos radio-cards */
.baja-motivo-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-radius: var(--r-md);
  border: 1.5px solid var(--gray-line);
  cursor: pointer;
  transition: all .2s;
  font-size: 14px;
  color: var(--text-body);
  font-weight: 600;
  margin-bottom: 10px;
}

.baja-motivo-item:hover {
  border-color: var(--blue-mid);
  background: var(--blue-pale);
}

.baja-motivo-item input[type=radio] {
  accent-color: var(--blue);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  /* Neutralizar estilos de Materialize que ocultan el radio */
  position: static !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  appearance: auto !important;
  -webkit-appearance: radio !important;
}

.baja-motivo-item:has(input:checked) {
  border-color: var(--blue);
  background: var(--blue-light);
}

.baja-motivo-label { flex: 1; }


/* Estado "completado" del stepper: verde (#22C55E) según diseño de referencia.
   Scoped a .baja-body para no afectar el stepper de transferencia de puntos. */
.baja-body .tr-step-tab.done {
  color: #22C55E;
  border-bottom-color: #22C55E;
}
.baja-body .tr-step-tab.done .tr-step-num {
  background: #22C55E;
  color: #fff;
}

/* Botón primario en contexto baja: rojo en lugar del azul por defecto */
.baja-body .tr-btn-transfer {
  background: var(--red);
  color: #fff;
  border: none;
  border-radius: var(--r-pill);
  padding: 10px 24px;
  cursor: pointer;
  transition: background .2s, transform .15s;
}

.baja-btn-confirm:hover {
  background: var(--red-mid);
  transform: translateY(-1px);
}

.baja-btn-confirm:disabled,
.baja-btn-confirm.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.baja-legal {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.6;
  margin-top: 16px;
}

/* Steps indicator */
.baja-steps {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 32px;
}

.baja-step-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gray-mid);
  transition: background .2s;
}

.baja-step-dot.active {
  background: var(--blue);
  width: 24px;
  border-radius: 4px;
}

/* Success state */
.baja-success {
  text-align: center;
  padding: 48px 0;
}

.baja-success-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: #E8F8EE;
  border: 2px solid #22C55E;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 24px;
}

.baja-doc-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 10px;
}

/* Responsive */
@media (max-width: 600px) {
  .baja-body {
    padding: 32px 20px 60px;
  }

  .baja-nav-inner {
    padding: 0 20px;
  }

  .baja-title {
    font-size: 22px;
  }

  .baja-actions {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .baja-btn-cancel,
  .baja-btn-confirm {
    text-align: center;
    justify-content: center;
    width: 100%;
  }

  .baja-doc-row {
    grid-template-columns: 1fr;
  }
}

/* ════════════════════════════════
     TARJETA CLUB
  ════════════════════════════════ */
#tarjeta-club {
  padding: 80px 0;
  background: #fff;
}

.tc-single-layout {
  display: grid;
  gap: 72px;
  align-items: center;
}

@media only screen and (min-width: 993px) {
  .tc-single-layout {
    grid-template-columns: 1fr 1fr;
  }
}

.tc-single-text {
}

.tc-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 34px;
  color: var(--blue);
  letter-spacing: -0.8px;
  line-height: 1.15;
  margin-bottom: 16px;
}

  .tc-title .accent {
    color: var(--red);
  }

.tc-desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 28px;
}

.tc-perks {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 36px;
}

.tc-perk {
  display: flex;
  align-items: center;
  gap: 12px;
}

.tc-perk-dot {
  width: 8px;
  height: 8px;
  background: var(--red);
  border-radius: 50%;
  flex-shrink: 0;
}

.tc-perk-text {
  font-size: 14px;
  color: var(--text-body);
  font-weight: 600;
}

/* preview card */
.tc-single-card-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.tc-preview-card {
  width: 100%;
  max-width: 460px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
/* ── Tarjeta rediseñada: sin círculos, sin nombre, layout limpio ── */
.tc-preview-top {
  background: var(--blue);
  padding: 28px 28px 24px;
  position: relative;
  overflow: hidden;
  min-height: 180px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
  /* Patrón de líneas diagonales sutil en lugar de círculos */
  .tc-preview-top::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: repeating-linear-gradient( -55deg, rgba(255,255,255,.028) 0px, rgba(255,255,255,.028) 1px, transparent 1px, transparent 18px );
  }
  /* Acento rojo: franja vertical derecha */
  .tc-preview-top::after {
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 8px;
    background: var(--red);
  }

.tc-preview-brand {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 28px;
  color: #fff;
  line-height: 1.05;
  letter-spacing: -0.5px;
  position: relative;
  z-index: 1;
}

.tc-preview-tagline {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 10px;
  color: rgba(255,255,255,.5);
  letter-spacing: 3px;
  text-transform: uppercase;
  position: relative;
  z-index: 1;
  margin-top: 4px;
}
/* Logo chip — esquina superior derecha */
.tc-preview-logo-chip {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 2;
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.18);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

  .tc-preview-logo-chip svg {
    width: 18px;
    height: 18px;
    fill: #fff;
    opacity: .85;
  }
/* Número de serie — parte inferior del panel azul */
.tc-preview-serial {
  position: relative;
  z-index: 1;
  margin-top: auto;
  padding-top: 18px;
  font-family: 'Courier New',monospace;
  font-size: 11px;
  color: rgba(255,255,255,.45);
  letter-spacing: 2px;
}

.tc-preview-bottom {
  display: flex;
}

.tc-preview-blue {
  flex: 1;
  background: var(--blue);
  padding: 14px 0 14px 20px;
}

.tc-preview-red {
  width: 52px;
  background: var(--red);
  flex-shrink: 0;
}

.tc-preview-barcode {
  background: #fff;
  border-radius: 6px 6px 0 0;
  padding: 10px 14px 7px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.tc-preview-barcode-num {
  font-family: 'Courier New',monospace;
  font-size: 10px;
  color: var(--text);
  text-align: center;
  letter-spacing: 2.5px;
  margin-top: 4px;
}

.tc-preview-info-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--blue-light);
  border-radius: var(--r-pill);
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 600;
  color: var(--blue-mid);
  font-family: var(--font-display);
  max-width: 460px;
  width: 100%;
}

.tc-cta-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
  padding-bottom: 4px;
  overflow: visible;
}

#tarjeta-club .tc-cta-row .btn {
  line-height: 1.2;
}

#tarjeta-club .tc-cta-row .btn-secondary,
#tarjeta-club .tc-cta-row .btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media only screen and (min-width: 993px) {
  .tc-single-card-wrap {
    align-items: flex-end;
  }
}

/* ════════════════════════════════
     APP DOWNLOAD
  ════════════════════════════════ */
#app-download {
  padding: 80px 0;
  background: var(--gray-bg);
}

.app-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 48px;
}

.app-content {
  max-width: 600px;
  text-align: center;
}

.app-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 34px;
  color: var(--blue);
  letter-spacing: -0.8px;
  line-height: 1.15;
  margin-bottom: 16px;
}

  .app-title .accent {
    color: var(--red);
  }

.app-desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 32px;
}

.app-store-btns {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.store-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--blue);
  color: #fff;
  border-radius: var(--r-md);
  padding: 11px 20px;
  cursor: pointer;
  text-decoration: none;
  transition: all .2s;
}

  .store-btn:hover {
    background: var(--blue-mid);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
  }

  .store-btn svg {
    width: 22px;
    height: 22px;
    fill: #fff;
    flex-shrink: 0;
  }

.store-btn-small {
  font-size: 9px;
  opacity: .6;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  display: block;
}

.store-btn-name {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 14px;
  display: block;
}

.app-phones-wrap {
  display: flex;
  gap: 16px;
  align-items: flex-end;
  flex-shrink: 0;
}

.app-phone-mini {
  width: 116px;
  background: #fff;
  border-radius: 22px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  border: 1px solid var(--gray-line);
}

  .app-phone-mini.up {
    transform: translateY(-20px);
  }

.apm-header {
  height: 52px;
  background: var(--blue);
  display: flex;
  align-items: flex-end;
  padding: 8px 12px;
}

  .apm-header.red {
    background: var(--red);
  }

.apm-title {
  font-size: 9px;
  font-weight: 800;
  font-family: var(--font-display);
  color: #fff;
}

.apm-body {
  padding: 12px;
}

.apm-bar {
  height: 5px;
  background: var(--gray-bg);
  border-radius: 3px;
  margin-bottom: 6px;
}

  .apm-bar.w80 {
    width: 80%;
  }

  .apm-bar.w60 {
    width: 60%;
  }

  .apm-bar.w90 {
    width: 90%;
  }

.apm-dots {
  display: flex;
  gap: 5px;
  margin-top: 8px;
}

.apm-dot {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  background: var(--blue-light);
}

  .apm-dot.red {
    background: var(--red-light);
  }

/* ════════════════════════════════
    PAGE — TRANSFERIR PUNTOS
════════════════════════════════ */






.tr-card {
  background:#fff; border:1px solid var(--gray-line); border-radius:var(--r-lg);
  padding:32px; margin-bottom:20px;
}
.tr-card-title { font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--blue); margin-bottom:20px; display:flex; align-items:center; gap:10px; }
.tr-card-title svg { width:18px; height:18px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

.tr-search-row { display:grid; grid-template-columns:120px 1fr 44px; gap:8px; align-items:end; }
.tr-search-btn {
  width:44px; height:44px; background:var(--blue); border:none; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s;
}
.tr-search-btn:hover { background:var(--blue-mid); }
.tr-search-btn svg { width:18px; height:18px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

.tr-result {
  display:none; margin-top:20px; padding:16px; background:var(--blue-pale);
  border-radius:var(--r-md); border:1px solid var(--blue-light);
}
.tr-result.show { display:block; }
.tr-result-row  { display:flex; gap:32px; flex-wrap:wrap; }
.tr-result-label { font-size:11px; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:0.8px; margin-bottom:3px; }
.tr-result-val   { font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--blue); }

.tr-amount-card {
  background:var(--gray-bg); border-radius:var(--r-md); padding:20px;
  margin-top:20px; border:1px solid var(--gray-line);
}
.tr-amount-label { font-size:12px; font-weight:700; color:var(--text); margin-bottom:8px; display:block; }
.tr-amount-input {
  width:100%; padding:14px 16px; border:2px solid var(--blue-mid);
  border-radius:var(--r-md); font-size:22px; font-family:var(--font-display);
  font-weight:900; color:var(--blue); outline:none; background:#fff;
  letter-spacing:1px;
}
.tr-amount-meta { margin-top:8px; font-size:13px; color:var(--muted); }
.tr-amount-meta strong { color:var(--blue); font-weight:700; }
.tr-amount-meta a { color:var(--red); font-weight:600; text-decoration:none; }

.tr-actions {
  display:flex; gap:12px; justify-content:flex-end; margin-top:28px;
  padding-top:24px; border-top:1px solid var(--gray-line);
}
.tr-btn-cancel {
  padding:12px 28px; font-size:14px; font-family:var(--font-display); font-weight:700;
  background:none; border:1.5px solid var(--gray-mid); border-radius:var(--r-md);
  color:var(--muted); cursor:pointer; transition:all .2s;
}
.tr-btn-cancel:hover { border-color:var(--blue); color:var(--blue); }
.tr-btn-transfer {
  padding:12px 28px; font-size:14px; font-family:var(--font-display); font-weight:800;
  background:var(--blue); border:none; border-radius:var(--r-md);
  color:#fff; cursor:pointer; transition:all .2s;
}
.tr-btn-transfer:hover { background:var(--blue-mid); }
.tr-btn-transfer:disabled { background:var(--gray-mid); cursor:not-allowed; }

/* ────────────────────────────────────────
    TRANSFERIR — VISTA DE CONFIRMACIÓN
──────────────────────────────────────── */
.tr-confirm-card {
  background: var(--blue); border-radius: var(--r-xl);
  padding: 36px 32px; margin-bottom: 20px;
  position: relative; overflow: hidden;
}
/* patrón diagonal sutil idéntico al hero-panel */
.tr-confirm-card::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: repeating-linear-gradient(
    -45deg,
    rgba(255,255,255,.025) 0px, rgba(255,255,255,.025) 1px,
    transparent 1px, transparent 24px
  );
}
.tr-confirm-label {
  font-size: 10px; font-weight: 700; letter-spacing: 2.5px;
  text-transform: uppercase; color: rgba(255,255,255,.5);
  font-family: var(--font-display); margin-bottom: 6px;
  position: relative; z-index: 1;
}
.tr-confirm-pts {
  font-family: var(--font-display); font-weight: 900;
  font-size: 56px; color: #fff; letter-spacing: -2px; line-height: 1;
  position: relative; z-index: 1;
}
.tr-confirm-pts-unit {
  font-size: 20px; color: rgba(255,255,255,.55); font-weight: 700;
  letter-spacing: 0; margin-left: 6px;
}
.tr-confirm-divider {
  border: none; border-top: 1px solid rgba(255,255,255,.12);
  margin: 24px 0; position: relative; z-index: 1;
}
.tr-confirm-row {
  display: flex; gap: 0; position: relative; z-index: 1;
}
.tr-confirm-block {
  flex: 1; padding-right: 24px;
}
.tr-confirm-block + .tr-confirm-block {
  padding-left: 24px; padding-right: 0;
  border-left: 1px solid rgba(255,255,255,.12);
}
.tr-confirm-block-label {
  font-size: 10px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: rgba(255,255,255,.45);
  font-family: var(--font-display); margin-bottom: 4px;
}
.tr-confirm-block-val {
  font-family: var(--font-display); font-weight: 800;
  font-size: 15px; color: #fff;
}
.tr-confirm-block-sub {
  font-size: 12px; color: rgba(255,255,255,.5); margin-top: 2px;
}

/* aviso de saldo restante */
.tr-confirm-balance {
  display: flex; align-items: center; gap: 12px;
  background: var(--blue-light); border: 1px solid var(--blue-mid);
  border-radius: var(--r-md); padding: 14px 18px; margin-bottom: 20px;
}
.tr-confirm-balance svg {
  width: 18px; height: 18px; stroke: var(--blue-mid); fill: none;
  stroke-width: 1.8; stroke-linecap: round; flex-shrink: 0;
}
.tr-confirm-balance-text { font-size: 13px; color: var(--blue); line-height: 1.55; }
.tr-confirm-balance-text strong { font-weight: 800; color: var(--blue); }

/* aviso legal */
.tr-confirm-legal {
  font-size: 11px; color: var(--muted); line-height: 1.6;
  text-align: center; padding: 0 8px;
}

/* estado de éxito */
.tr-success {
  display: none; text-align: center; padding: 16px 0 8px;
}
.tr-success.show { display: block; }
.tr-success-icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: #E8F8EE; border: 2px solid #22C55E;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px; font-size: 32px;
}
.tr-success-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: 22px; color: var(--blue); margin-bottom: 8px;
}
.tr-success-desc {
  font-size: 14px; color: var(--muted); line-height: 1.65;
  margin-bottom: 28px;
}
.tr-success-desc strong { color: var(--blue); font-weight: 700; }

/* pasos numerados del flujo de transferencia */
.tr-steps-bar {
  display: flex; gap: 0; margin-bottom: 32px;
  border-bottom: 1px solid var(--gray-line); padding-bottom: 0;
}
.tr-step-tab {
  flex: 1; display: flex; align-items: center; gap: 8px;
  padding: 12px 16px 14px; font-family: var(--font-display);
  font-weight: 700; font-size: 12px; color: var(--muted);
  border-bottom: 3px solid transparent; transition: all .2s;
  cursor: default; margin-bottom: -1px;
}
.tr-step-tab.active { color: var(--blue); border-bottom-color: var(--blue); }
  .tr-step-tab.done {
    color: #009FDF;
    border-bottom-color: #009FDF;
  }
.tr-step-num {
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--gray-mid); font-size: 11px; font-weight: 800;
  color: var(--muted); transition: all .2s;
}
.tr-step-tab.active .tr-step-num { background: var(--blue); color: #fff; }
.tr-step-tab.done .tr-step-num {
  background: #009FDF;
  color: #fff;
  font-size: 13px;
}

/* Acciones de éxito */
.tr-success-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.tr-success-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

@media (max-width: 600px) {
  .tr-confirm-pts { font-size: 40px; }
  .tr-confirm-row { flex-direction: column; gap: 16px; }
  .tr-confirm-block + .tr-confirm-block {
    padding-left: 0; border-left: none;
    border-top: 1px solid rgba(255,255,255,.12);
    padding-top: 16px;
  }
  .tr-step-tab { font-size: 11px; padding: 10px 8px 12px; gap: 6px; }
  
  .tr-success-actions {
    flex-direction: column;
  }
  .tr-success-actions a {
    width: 100%;
  }
}

/* ════════════════════════════════
   PAGE — MI CUENTA
════════════════════════════════ */
#page-micuenta {
  display:none; position:fixed; inset:0; z-index:1500;
  background:var(--gray-bg); overflow-y:auto;
}
#page-micuenta.open { display:block; }




.mc-page-desc {
  font-size:13px; color:var(--muted); line-height:1.6; margin-bottom:32px;
}

/* section block */
.mc-section {
  background:#fff; border-radius:var(--r-lg); margin-bottom:16px;
  border:1px solid var(--gray-line); overflow:hidden;
}
.mc-section-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; border-bottom:1px solid var(--gray-line);
  cursor:pointer; user-select:none;
  transition:background .15s;
}
.mc-section-header:hover { background:var(--gray-bg); }
.mc-section-label {
  font-family:var(--font-display); font-weight:800; font-size:12px;
  color:var(--blue); text-transform:uppercase; letter-spacing:1px;
}
.mc-section-chevron {
  font-size:18px; color:var(--muted); transition:transform .25s; font-weight:300;
}
.mc-section.collapsed .mc-section-chevron { transform:rotate(180deg); }
.mc-section-body { padding:20px 24px; }

/* ── CONFIGURACIÓN FIELDS ── */
.mc-group-title { font-family:var(--font-display); font-weight:800; font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:1.5px; margin:0 0 14px; padding-bottom:8px; border-bottom:1px solid var(--gray-line); }
.mc-fields-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.mc-field { display:flex; flex-direction:column; gap:5px; }
.mc-field-full { grid-column:1/-1; }
.mc-field label { font-size:11px; font-weight:700; color:var(--muted); font-family:var(--font-display); text-transform:uppercase; letter-spacing:0.8px; }
.mc-field input, .mc-field select { border:1.5px solid var(--gray-mid) !important; border-radius:var(--r-sm) !important; padding:10px 12px !important; font-size:14px !important; font-family:var(--font-body) !important; color:var(--blue) !important; background:#fff !important; outline:none !important; transition:border .2s; width:100% !important; box-sizing:border-box !important; height:auto !important; margin:0 !important; box-shadow:none !important; }
.mc-field input:focus, .mc-field select:focus { border-color:var(--blue-mid) !important; box-shadow:none !important; }
.mc-field input:disabled, .mc-field select:disabled { background:var(--gray-bg) !important; color:var(--muted) !important; cursor:not-allowed !important; border-color:var(--gray-mid) !important; }
.mc-section-group { margin-bottom:24px; }
.mc-section-group:last-child { margin-bottom:0; }
.mc-btn-save { margin-top:18px; background:var(--blue); color:#fff; border:none; border-radius:var(--r-pill); padding:10px 28px; font-family:var(--font-display); font-weight:800; font-size:13px; cursor:pointer; transition:background .2s; }
.mc-btn-most-info {
  margin-top: 18px;  
  color: #fff;
  border: none;
  border-radius: var(--r-pill);
  padding: 10px 28px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 13px;
  cursor: pointer;
  transition: background .2s;
}
.mc-btn-save:hover { background:var(--blue-mid); }
/* Override Materialize para el botón Cambiar contraseña */
#btn-cambiar-password { background:var(--blue) !important; }
#btn-cambiar-password:hover { background:var(--blue-mid) !important; }

.mc-btn-danger { margin-top:18px; background:var(--red-light); color:var(--red); border:1.5px solid var(--red-light); border-radius:var(--r-pill); padding:10px 28px; font-family:var(--font-display); font-weight:800; font-size:13px; cursor:pointer; transition:all .2s; }
.mc-btn-danger:hover { background:var(--red); color:#fff; }
.mc-social-row { display:flex; align-items:center; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--gray-line); }
.mc-social-row:last-child { border-bottom:none; }
.mc-social-info { display:flex; align-items:center; gap:10px; }
.mc-social-icon { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mc-social-name { font-family:var(--font-display); font-weight:700; font-size:13px; color:var(--blue); }
.mc-social-status { font-size:12px; color:var(--muted); }
.mc-social-btn { background:var(--blue-light); color:var(--blue); border:none; border-radius:var(--r-pill); padding:7px 16px; font-family:var(--font-display); font-weight:700; font-size:12px; cursor:pointer; transition:all .2s; }
.mc-social-btn:hover { background:var(--blue); color:#fff; }
.mc-social-btn.linked { background:var(--red-light); color:var(--red); }
.mc-social-btn.linked:hover { background:var(--red); color:#fff; }
@media (max-width:600px) { .mc-fields-grid { grid-template-columns:1fr; } }

/* ── PASSWORD FIELD con ojito ── */
.mc-pwd-field { position:relative; display:flex; flex-direction:column; }
.mc-pwd-field input { flex:1; padding-right:38px !important; }
.mc-pwd-eye { position:absolute; right:10px; top:10px; cursor:pointer; color:var(--muted); font-size:16px; line-height:1; user-select:none; }


/* ── DATOS PERSONALES — layout optimizado ── */
.dp-row { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.dp-row:last-of-type { margin-bottom:0; }

/* 2 columnas iguales */
.dp-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }

/* 3 columnas iguales */
.dp-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px; margin-bottom:14px; }

/* Tipo doc angosto + Número ancho (1:2) */
.dp-row-doc { display:grid; grid-template-columns:130px 1fr; gap:14px; margin-bottom:14px; }

/* Calle ancha + Altura angosta (2:1) */
.dp-row-calle { display:grid; grid-template-columns:2fr 1fr; gap:14px; margin-bottom:14px; }

/* Fecha: 3 selects en fila compacta */
.dp-date-row { display:grid; grid-template-columns:72px 1fr 90px; gap:8px; }
.dp-date-row select { padding:10px 8px; }

/* Hint texto bajo campo */
.dp-hint { font-size:11px; margin-top:3px; line-height:1.4; }
.dp-hint-warn { color:var(--red); }

/* Botones de sección */
.dp-actions { display:flex; gap:10px; justify-content:flex-end; margin-top:20px; padding-top:16px; border-top:0px solid var(--gray-line); }
.dp-btn-cancel { background:transparent !important; color:var(--muted) !important; border:1.5px solid var(--gray-mid) !important; }
.dp-btn-cancel:hover { color:var(--blue) !important; border-color:var(--blue) !important; }

/* Teléfono: fila superior País + Área + Número + X */
.mc-tel-row { background:var(--gray-bg); border:1px solid var(--gray-line); border-radius:var(--r-md); padding:16px; margin-bottom:12px; }
.dp-row-tel { display:grid; grid-template-columns:150px 100px 1fr 32px; gap:10px; align-items:end; margin-bottom:36px; }
.dp-row-tel .mc-field { position:relative; }
.dp-row-tel .mc-field .validationMessage { position:absolute; top:100%; left:0; font-size:11px; margin-top:3px; white-space:normal; line-height:1.2; width:100%; z-index:10; color:var(--red); }
.dp-tel-num { }
.dp-tel-remove { width:32px; height:38px; background:none; border:1.5px solid var(--gray-mid); border-radius:var(--r-sm); cursor:pointer; color:var(--muted); display:flex; align-items:center; justify-content:center; transition:all .2s; flex-shrink:0; }
.dp-tel-remove:hover { border-color:var(--red); color:var(--red); background:var(--red-light); }
.dp-tel-remove-mob { display:none; }

/* Teléfono: fila inferior Celular checkbox + Operadora */
.dp-row-tel-extra { display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:center; }
.dp-check-label { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:var(--muted); cursor:pointer; white-space:nowrap; padding-top:18px; }
.dp-check-label input[type=checkbox] { accent-color:var(--blue); width:16px; height:16px; flex-shrink:0; position:static !important; opacity:1 !important; pointer-events:auto !important; appearance:auto !important; margin:0 !important; }
.dp-check-label span { line-height:1; padding-left:0 !important; }
.dp-check-label span::before, .dp-check-label span::after { display:none !important; }

/* Agregar teléfono */
.dp-add-tel { background:none; border:1.5px dashed var(--gray-mid); border-radius:var(--r-md); color:var(--blue-mid); font-family:var(--font-display); font-weight:700; font-size:13px; cursor:pointer; padding:10px 16px; display:flex; align-items:center; gap:8px; margin-bottom:4px; width:100%; justify-content:center; transition:all .2s; }
.dp-add-tel:hover { border-color:var(--blue-mid); background:var(--blue-pale); }
.dp-add-tel svg { stroke:currentColor; flex-shrink:0; }

@media (max-width:640px) {
  .dp-row-2, .dp-row-3 { grid-template-columns:1fr; }
  .dp-row-doc { grid-template-columns:1fr; }
  .dp-row-calle { grid-template-columns:1fr 80px; }
  .dp-row-tel { grid-template-columns:1fr; gap:16px; align-items:start; }
  .dp-row-tel .mc-field .validationMessage { position:relative; top:auto; white-space:normal; margin-top:4px; }
  .hide-on-mob { display:none !important; }
  .dp-tel-remove-mob { display:flex; align-items:center; justify-content:center; gap:8px; width:100%; margin-top:20px; padding:12px; background:#fff; border:1.5px solid var(--red); border-radius:var(--r-md); color:var(--red); font-family:var(--font-display); font-weight:800; font-size:12px; cursor:pointer; transition:all .2s; }
  .dp-tel-remove-mob:hover { background:var(--red-light); }
  .dp-row-tel-extra { grid-template-columns:1fr; }
  .dp-check-label { padding-top:0; white-space:normal; }
}

/* ── NOTIFICACIONES ── */
.mc-notif-card {
  background:var(--blue-pale); border:1.5px solid var(--blue-light);
  border-radius:var(--r-md); padding:16px 20px;
  display:flex; align-items:flex-start; gap:14px; margin-bottom:10px;
}
.mc-notif-card:last-child { margin-bottom:0; }
.mc-notif-icon {
  width:36px; height:36px; border-radius:var(--r-sm); background:var(--blue-light);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.mc-notif-icon svg { width:16px; height:16px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; }
.mc-notif-content { flex:1; }
.mc-notif-title { font-family:var(--font-display); font-weight:800; font-size:14px; color:var(--blue); margin-bottom:3px; }
.mc-notif-title a { color:var(--blue-mid); text-decoration:none; }
.mc-notif-title a:hover { color:var(--red); text-decoration:underline; }
.mc-notif-desc  { font-size:13px; color:var(--muted); line-height:1.5; }
.mc-notif-time  { font-size:11px; color:var(--muted); margin-top:8px; display:flex; align-items:center; gap:4px; }
.mc-notif-time svg { width:12px; height:12px; stroke:var(--muted); fill:none; stroke-width:1.8; stroke-linecap:round; }

/* ── PREMIOS ── */
.mc-empty {
  font-size:13px; color:var(--muted); font-style:italic;
}

/* ── PUNTOS HEADER ── */
.mc-pts-header {
  display:flex; align-items:center; gap:8px; margin-bottom:16px;
  font-size:14px; color:var(--text-body);
}
.mc-pts-header strong { font-family:var(--font-display); font-weight:900; font-size:18px; color:var(--blue); }

/* ── MOVIMIENTOS ── */
.mc-mov-filter {
  display:flex; align-items:center; justify-content:flex-end; gap:10px; margin-bottom:16px;
}
.mc-mov-select {
  padding:9px 36px 9px 14px; border:1.5px solid var(--gray-mid);
  border-radius:var(--r-md); font-size:13px; font-family:var(--font-body);
  color:var(--text); background:#fff; appearance:none; outline:none;
  background-image:url(/Content/App/data:image/svg+xml,%3Csvg xmlns='http:/www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8FA8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E);
  background-repeat:no-repeat; background-position:right 10px center;
  cursor:pointer; font-weight:600; transition:border-color .2s;
  height:auto !important; width:max-content !important; line-height:normal !important;
}
.mc-mov-select:focus { border-color:var(--blue); }

.mc-mov-table { width:100%; border-collapse:collapse; }
.mc-mov-table th {
  text-align:left; font-size:11px; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:0.8px;
  padding:0 0 10px; border-bottom:1px solid var(--gray-line);
}
.mc-mov-table td {
  padding:13px 0; font-size:13px; color:var(--text-body);
  border-bottom:1px solid var(--gray-line); vertical-align:middle;
}
.mc-mov-table tr:last-child,
.mc-mov-table tr:last-child td { border-bottom:none !important; }
.mc-mov-tipo { display:flex; align-items:center; gap:10px; }
.mc-mov-icon {
  width:32px; height:32px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.mc-mov-icon.suma   { background:#E8F8EE; }
.mc-mov-icon.canje  { background:var(--red-light); }
.mc-mov-icon.trans  { background:var(--blue-light); }
.mc-mov-icon.regalo { background:#FFF3E0; }
.mc-mov-icon svg { width:14px; height:14px; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.mc-mov-icon.suma  svg { stroke:#22C55E; }
.mc-mov-icon.canje svg { stroke:var(--red); }
.mc-mov-icon.trans svg { stroke:var(--blue-mid); }
.mc-mov-icon.regalo svg { stroke:#F59E0B; }
.mc-mov-desc  { font-size:13px; color:var(--text-body); font-weight:600; }
.mc-mov-sub   { font-size:11px; color:var(--muted); margin-top:1px; }
.mc-mov-sub .right-align { display:none !important; }
.mc-mov-pts.suma   { font-family:var(--font-display); font-weight:800; font-size:14px; color:#22C55E; }
.mc-mov-pts.canje  { font-family:var(--font-display); font-weight:800; font-size:14px; color:var(--red); }
.mc-mov-pts.trans  { font-family:var(--font-display); font-weight:800; font-size:14px; color:var(--blue-mid); }
.mc-mov-pts.regalo { font-family:var(--font-display); font-weight:800; font-size:14px; color:#F59E0B; }
.mc-mov-date  { font-size:12px; color:var(--muted); }

.mc-mov-empty { text-align:center; padding:32px 0; font-size:13px; color:var(--muted); font-style:italic; }

.mc-buscar {
  width:100%; padding:10px 14px; border:1.5px solid var(--gray-mid);
  border-radius:var(--r-md); font-size:13px; font-family:var(--font-body);
  color:var(--text); outline:none; background:#fff; transition:border-color .2s;
  margin-top:12px;
}
.mc-buscar:focus { border-color:var(--blue); }
.mc-buscar::placeholder { color:var(--muted); }

/* ── DATA GRIDS DP-ROW (EXCLUSIVO DATOS PERSONALES) ── */
.dp-row {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-bottom: 14px;
}

  .dp-row:last-of-type {
    margin-bottom: 0;
  }

.dp-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.dp-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.dp-row-doc {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.dp-row-calle {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.dp-row-tel {
  display: grid;
  grid-template-columns: 150px 100px 1fr 32px;
  gap: 10px;
  align-items: end;
  margin-bottom: 36px;
}

.dp-row-tel-extra {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
}

.dp-date-row {
  display: grid;
  grid-template-columns: 1fr 1.5fr 1.2fr;
  gap: 6px;
}

/* HINTS, CHECKS Y BOTONES */
.dp-hint {
  font-size: 11px;
  margin-top: 4px;
  line-height: 1.4;
}

.dp-check-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  margin: 0;
}

  .dp-check-label input {
    width: 16px;
    height: 16px;
    accent-color: var(--blue);
    cursor: pointer;
    margin: 0 !important;
  }

  .dp-check-label span {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-body);
  }

.dp-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--gray-line);
}
.dp-actions button {
  margin-top: 0 !important;
}

.dp-btn-cancel {
  background: transparent;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 12px;
  color: var(--muted);
  border: 1.5px solid transparent;
  border-radius: var(--r-pill);
  padding: 10px 24px;
  cursor: pointer;
  transition: all .2s;
}

  .dp-btn-cancel:hover {
    background: var(--gray-bg);
    color: var(--text);
  }

/* ESTRUCTURA TELÉFONOS */
.mc-tel-row {
  background: var(--gray-bg);
  border-radius: var(--r-md);
  padding: 16px;
  margin-bottom: 12px;
}

.dp-tel-remove {
  width: 32px;
  height: 32px;
  border-radius: var(--r-sm);
  border: none;
  background: #FFE5E5;
  color: var(--red);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
  margin-bottom: 4px;
}

  .dp-tel-remove:hover {
    background: var(--red);
    color: #fff;
  }

.dp-add-tel {
  background: transparent;
  border: 1.5px dashed var(--gray-mid);
  border-radius: var(--r-md);
  padding: 12px;
  width: 100%;
  color: var(--blue);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: border-color .2s;
}

  .dp-add-tel:hover {
    border-color: var(--blue);
  }

/* RESPONSIVE */
@media (max-width:768px) {
  .dp-row-2, .dp-row-3 {
    grid-template-columns: 1fr;
  }

  .dp-row-doc {
    grid-template-columns: 1fr;
  }

  .dp-row-calle {
    grid-template-columns: 1fr 80px;
  }

  .dp-row-tel {
    grid-template-columns: 1fr;
    gap: 16px;
    align-items: start;
  }
  .dp-row-tel .mc-field .validationMessage {
    position: relative;
    top: auto;
    white-space: normal;
    margin-top: 4px;
  }
  .hide-on-mob { display: none !important; }
  .dp-tel-remove-mob {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin-top: 24px;
    padding: 12px;
    background: #fff;
    border: 1.5px solid var(--red);
    border-radius: var(--r-md);
    color: var(--red);
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 12px;
    cursor: pointer;
    transition: all .2s;
  }
  .dp-tel-remove-mob:hover {
    background: var(--red-light);
  }

  .dp-row-tel-extra {
    grid-template-columns: 1fr;
  }
}


/* ════════════════════════════════
   RESPONSIVE
════════════════════════════════ */
@media (max-width:900px) {
  /* Mi cuenta */
  .mc-layout { padding:32px 24px 60px; }
}

/* ── OVERRIDE TOAST MATERIALIZE ── */
#toast-container {
    top: auto !important;
    bottom: 28px !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    max-width: 90% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    pointer-events: none !important;
}

#toast-container .toast {
    position: relative !important;
    background: var(--blue) !important;
    color: #fff !important;
    border-radius: var(--r-pill) !important;
    padding: 12px 24px !important;
    font-family: var(--font-display) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    box-shadow: var(--shadow-lg) !important;
    white-space: nowrap !important;
    min-height: 0 !important;
    height: auto !important;
    line-height: normal !important;
    margin-top: 10px !important;
    width: auto !important;
    float: none !important;
    pointer-events: none !important;
    justify-content: center !important;
}
#toast-container .toast::before {
    display: none !important;
}

/* REDES SOCIALES REVAMP */
.mc-social-row { display:flex; align-items:center; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--gray-line); }
.mc-social-row:last-child { border-bottom:none; }
.mc-social-info { display:flex; align-items:center; gap:10px; }
.mc-social-icon { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mc-social-name { font-family:var(--font-display); font-weight:700; font-size:13px; color:var(--blue); }
.mc-social-status { font-size:12px; color:var(--muted); }
.mc-social-btn { background:var(--blue-light); color:var(--blue); border:none; border-radius:var(--r-pill); padding:7px 16px; font-family:var(--font-display); font-weight:700; font-size:12px; cursor:pointer; transition:all .2s; }
.mc-social-btn:hover { background:var(--blue); color:#fff; }
.mc-social-btn.linked { background:var(--red-light); color:var(--red); }
.mc-social-btn.linked:hover { background:var(--red); color:#fff; }

.cg-revamp-custom-modal.modal.open {
   position: fixed !important;
   top: 50% !important;
   left: 50% !important;
   transform: translate(-50%, -50%) !important;
   margin: 0 !important;
   bottom: auto !important;
   z-index: 100000 !important;
   display: block !important;
}

/* ── SEGURIDAD: Cabecera con botón Editar ── */
.dp-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.dp-section-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
}
.mc-btn-edit {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 1.5px solid var(--gray-mid);
  border-radius: var(--r-sm);
  padding: 7px 14px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 12px;
  color: var(--blue);
  cursor: pointer;
  transition: background .2s, border-color .2s;
}
.mc-btn-edit:hover {
  background: var(--blue-light);
  border-color: var(--blue-mid);
}
.mc-btn-edit svg { flex-shrink: 0; }

/* ── SEGURIDAD: Fila contraseña solo-lectura ── */
.mc-pwd-readonly-row {
  padding: 4px 0 8px;
}
.mc-pwd-readonly-label {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px;
}
.mc-pwd-readonly-body {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--gray-bg);
  border-radius: var(--r-sm);
  border: 1.5px solid var(--gray-line);
  width: fit-content;
}
.mc-pwd-readonly-icon {
  width: 34px;
  height: 34px;
  border-radius: var(--r-sm);
  background: var(--blue-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--blue-mid);
}
.mc-pwd-dots {
  font-size: 18px;
  color: var(--blue);
  letter-spacing: 3px;
  line-height: 1;
}

/* ── Mensaje de cambio de contraseña ── */
.mc-pwd-change-msg {
  padding: 10px 14px;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-family: var(--font-body);
  font-weight: 600;
  line-height: 1.4;
}
.mc-pwd-change-msg--error {
  background: #FEF2F2;
  border: 1px solid #FECACA;
  color: #B91C1C;
}

/* ── EFECTO DESTELLO/PULSO AL NAVEGAR POR URL HASH ── */
@keyframes rgSectionPulse {
  0% { 
    border-color: var(--red); 
    box-shadow: 0 0 0 0 rgba(227, 30, 36, 0.4); 
  }
  50% { 
    border-color: var(--red); 
    box-shadow: 0 0 0 10px rgba(227, 30, 36, 0); 
  }
  100% { 
    border-color: var(--gray-line); 
    box-shadow: 0 0 0 0 rgba(227, 30, 36, 0); 
  }
}

.mc-section.rg-flash-target {
  animation: rgSectionPulse 1.5s ease-out;
}

/* Heladerías / mapa — estilos alineados al maquetado club-grido-revamp (sección mapa). */

/* Ocultar sin quitar del DOM (evita que visible: de KO pise display:flex en contenedores) */
.rg-hide {
  display: none !important;
}

.rg-stores-map-root {
  width: 100%;
  margin-bottom: 24px;
  --rg-stores-map-height: clamp(420px, calc(100vh - 240px), 760px);
}

.rg-stores-map-root .mapa-layout {
  display: grid;
  grid-template-columns: 360px 1fr;
  height: var(--rg-stores-map-height);
  min-height: 420px;
  overflow: hidden;
  border-radius: var(--r-lg);
  border: 1px solid var(--gray-line);
  box-shadow: var(--shadow-sm);
  background: var(--white);
  contain: layout paint;
}

.rg-stores-map-root .mapa-sidebar {
  background: var(--white);
  border-right: 1px solid var(--gray-line);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}

.rg-stores-map-root .mapa-search-wrap {
  padding: 16px 20px;
  border-bottom: 1px solid var(--gray-line);
  flex-shrink: 0;
}

.rg-stores-map-root .mapa-search-box {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--gray-bg);
  border: 1.5px solid var(--gray-mid);
  border-radius: var(--r-pill);
  padding: 10px 16px;
  transition: border-color 0.2s;
}

.rg-stores-map-root .mapa-search-box:focus-within {
  border-color: var(--blue);
  background: var(--white);
}

.rg-stores-map-root .mapa-search-box svg {
  width: 16px;
  height: 16px;
  stroke: var(--muted);
  fill: none;
  stroke-width: 2;
  flex-shrink: 0;
}

.rg-stores-map-root .mapa-search-box input {
  border: none;
  background: none;
  outline: none;
  font-size: 14px;
  font-family: var(--font-body);
  color: var(--text);
  flex: 1;
}

.rg-stores-map-root .mapa-search-box input::placeholder {
  color: var(--muted);
}

.rg-stores-map-root .mapa-chip-wrap {
  display: none;
  gap: 8px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--gray-line);
  flex-wrap: wrap;
  flex-shrink: 0;
}

.rg-stores-map-root .mapa-chip-wrap.is-visible {
  display: flex;
}

.rg-stores-map-root .mapa-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--blue);
  color: var(--white);
  border-radius: var(--r-pill);
  padding: 5px 12px;
  font-size: 12px;
  font-family: var(--font-display);
  font-weight: 700;
}

.rg-stores-map-root .mapa-chip .chip-x {
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  opacity: 0.7;
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
  padding: 0;
}

.rg-stores-map-root .mapa-chip .chip-x:hover {
  opacity: 1;
}

.rg-stores-map-root .mapa-results-header {
  padding: 12px 20px 8px;
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-family: var(--font-display);
  flex-shrink: 0;
}

.rg-stores-map-root .mapa-list {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  overscroll-behavior: contain;
}

.rg-stores-map-root .mapa-list-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--gray-line);
  cursor: pointer;
  transition: background 0.15s;
  position: relative;
}

.rg-stores-map-root .mapa-list-item:hover {
  background: var(--blue-pale);
}

.rg-stores-map-root .mapa-list-item.active {
  background: var(--blue-light);
}

.rg-stores-map-root .mapa-list-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--r-sm);
  flex-shrink: 0;
  background: var(--blue);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}

.rg-stores-map-root .mapa-list-icon.fav {
  background: var(--red);
}

.rg-stores-map-root .mapa-list-icon svg {
  width: 16px;
  height: 16px;
  fill: var(--white);
}

.rg-stores-map-root .mapa-list-body {
  flex: 1;
  min-width: 0;
}

.rg-stores-map-root .mapa-list-name {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 14px;
  color: var(--blue);
  margin-bottom: 2px;
}

.rg-stores-map-root .mapa-list-addr {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rg-stores-map-root .mapa-list-meta {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.rg-stores-map-root .mapa-list-dist {
  font-size: 11px;
  font-weight: 700;
  color: var(--blue-mid);
  font-family: var(--font-display);
}

.rg-stores-map-root .mapa-list-fav-badge {
  font-size: 10px;
  font-weight: 800;
  color: var(--red);
  font-family: var(--font-display);
  background: var(--red-light);
  padding: 2px 8px;
  border-radius: var(--r-pill);
  letter-spacing: 0.3px;
}

.rg-stores-map-root .mapa-list-unfav-btn {
  font-size: 16px;
  font-weight: 900;
  line-height: 1;
  color: var(--muted);
  cursor: pointer;
  margin-left: 6px;
  opacity: 0.7;
  transition: all 0.2s;
  padding: 0 4px;
}

.rg-stores-map-root .mapa-list-unfav-btn:hover {
  opacity: 1;
  color: var(--red);
}

.rg-stores-map-root .mapa-list-horario {
  font-size: 11px;
  color: var(--muted);
}

/*
 * mapa-map-wrap: contenedor del tile + FABs (position relative).
 * --rg-map-fab-gap / --rg-gm-zoom-stack: alineación con controles nativos de Google Maps.
 */
.rg-stores-map-root .mapa-map-wrap {
  position: relative;
  overflow: hidden;
  min-height: 0;
  --rg-map-fab-gap: 14px;
  --rg-gm-zoom-stack: 56px;
}

.rg-stores-map-root .mapa-map-wrap .rg-map-fab {
  position: absolute;
  z-index: 930;
  right: max(12px, env(safe-area-inset-right, 0px));
}

.rg-stores-map-root .mapa-map-wrap .rg-map-fab-center {
  bottom: calc(var(--rg-gm-zoom-stack) + env(safe-area-inset-bottom, 0px));
}

.rg-stores-map-root .mapa-map-wrap .rg-map-fab-permission {
  bottom: calc(
    var(--rg-gm-zoom-stack) + var(--rg-map-fab-gap) + 56px + env(safe-area-inset-bottom, 0px)
  );
}

.rg-stores-map-root #leaflet-map {
  width: 100%;
  height: 100%;
  min-height: 0;
}

.rg-stores-map-root .mapa-popup {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--white);
  border-radius: var(--r-lg);
  padding: 20px 24px;
  box-shadow: 0 12px 40px rgba(27, 43, 107, 0.2);
  min-width: 280px;
  max-width: 340px;
  z-index: 800;
  display: none;
  border: 1px solid var(--gray-line);
  animation: rgMapaPopupIn 0.2s ease;
}

@keyframes rgMapaPopupIn {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

.rg-stores-map-root .mapa-popup.show {
  display: block;
}

.rg-stores-map-root .mapa-popup-close {
  position: absolute;
  top: 10px;
  right: 12px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--muted);
  font-size: 18px;
  line-height: 1;
  padding: 4px;
}

.rg-stores-map-root .mapa-popup-name {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 16px;
  color: var(--blue);
  margin-bottom: 4px;
  padding-right: 24px;
}

.rg-stores-map-root .mapa-popup-addr {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 12px;
}

.rg-stores-map-root .mapa-popup-schedule {
  font-size: 12px;
  color: var(--text-body);
  margin-bottom: 12px;
}

.rg-stores-map-root .mapa-popup-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.rg-stores-map-root .mapa-popup-btn {
  flex: 1;
  min-width: 120px;
  padding: 9px 14px;
  border-radius: var(--r-md);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 12px;
  cursor: pointer;
  border: none;
  transition: all 0.2s;
  text-align: center;
}

.rg-stores-map-root .mapa-popup-btn.primary {
  background: var(--blue);
  color: var(--white);
}

.rg-stores-map-root .mapa-popup-btn.primary:hover {
  background: var(--blue-mid);
}

.rg-stores-map-root .mapa-popup-btn.ghost {
  background: var(--gray-bg);
  color: var(--blue);
  border: 1.5px solid var(--gray-mid);
}

.rg-stores-map-root .mapa-popup-btn.ghost:hover {
  border-color: var(--blue);
  background: var(--blue-pale);
}

.rg-stores-map-legend {
  position: absolute;
  bottom: 16px;
  left: 16px;
  background: rgba(255, 255, 255, 0.92);
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 11px;
  font-family: var(--font-body);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
  backdrop-filter: blur(4px);
  z-index: 750;
  border: 1px solid var(--gray-line);
}

.rg-stores-map-legend-row {
  display: flex;
  align-items: center;
  gap: 6px;
}

.rg-stores-map-legend-row + .rg-stores-map-legend-row {
  margin-top: 5px;
}

.rg-stores-map-legend-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid var(--white);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  flex-shrink: 0;
}

.rg-stores-map-legend-dot.fav {
  background: var(--red);
}

.rg-stores-map-legend-dot.std {
  background: var(--blue);
}

.rg-stores-map-legend span {
  color: var(--text-body);
  font-weight: 600;
}

.rg-stores-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--blue);
  color: var(--white);
  padding: 12px 20px;
  border-radius: var(--r-pill);
  font-size: 14px;
  font-weight: 700;
  font-family: var(--font-display);
  box-shadow: var(--shadow-lg);
  z-index: 10000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s, transform 0.25s;
  max-width: min(420px, 92vw);
  text-align: center;
}

.rg-stores-toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@media (max-width: 900px) {
  .rg-stores-map-root .mapa-layout {
    grid-template-columns: 300px 1fr;
    height: clamp(380px, calc(100vh - 250px), 680px);
  }
}

@media (max-width: 800px) {
  .rg-stores-map-root {
    --rg-stores-map-height: min(calc(100vh - 180px), 900px);
    --rg-gm-zoom-stack: 52px;
  }

  /* Lista arriba + mapa abajo (sin toggle mapa/lista) */
  .rg-stores-map-root .mapa-layout {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(220px, 40vh) minmax(260px, 50vh);
    height: auto;
    min-height: 520px;
    max-height: none;
    position: relative;
  }

  .rg-stores-map-root .mapa-sidebar {
    display: flex;
    position: relative;
    inset: auto;
    z-index: 1;
    max-height: 40vh;
    border-right: none;
    border-bottom: 1px solid var(--gray-line);
    min-height: 0;
  }

  .rg-stores-map-root .mapa-map-wrap {
    min-height: 260px;
  }

  .rg-stores-map-root #leaflet-map {
    min-height: 0;
  }

  .rg-stores-map-root .mapa-popup {
    min-width: 240px;
    max-width: 90vw;
    bottom: 16px;
  }

  .rg-stores-map-legend {
    bottom: 12px;
    top: auto;
    left: 12px;
    font-size: 10px;
    padding: 8px 10px;
  }
}

/* ============================================================
   rg-notifications-dropdown-revamp.css
   Dropdown "Notificaciones" — alineado al nuevo sistema de diseño
   ============================================================ */

#dropdownUserNotifications {
  --rg-dd-blue: #1b2b6b;
  --rg-dd-blue-light: #e8ebf7;
  --rg-dd-blue-pale: #f0f2f8;
  --rg-dd-red: #CE0037;
  --rg-dd-surface: #ffffff;
  --rg-dd-gray-line: #eaedf3;
  --rg-dd-text: #1b2b6b;
  --rg-dd-muted: #8a8fa8;
  --rg-dd-hover: #f0f2f8;
  --rg-dd-radius: 20px;

  width: 320px !important;
  min-width: 320px !important;
  max-height: 70vh !important;
  overflow: hidden auto !important;
  border: 1px solid var(--rg-dd-gray-line);
  border-radius: var(--rg-dd-radius) !important;
  box-shadow: 0 16px 48px rgba(27, 43, 107, 0.18) !important;
  background: var(--rg-dd-surface) !important;
  padding: 0 !important;
}

#dropdownUserNotifications .cg-notif-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: var(--rg-dd-blue);
  color: #fff;
  border-radius: calc(var(--rg-dd-radius) - 1px) calc(var(--rg-dd-radius) - 1px) 0 0;
}

#dropdownUserNotifications .cg-notif-header-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: "Nunito", sans-serif;
  font-size: 15px;
  font-weight: 800;
}

#dropdownUserNotifications .cg-notif-header-title svg {
  stroke: #fff;
}

#dropdownUserNotifications .cg-notif-header-action {
  color: rgba(255, 255, 255, 0.7) !important;
  font-family: "Nunito Sans", sans-serif;
  font-size: 12px !important;
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s;
}

#dropdownUserNotifications .cg-notif-header-action:hover {
  color: #fff !important;
}

/* Ocultar el fondo rojo del diseño viejo */
#dropdownUserNotifications.cg-notifications-menu {
  background-color: var(--rg-dd-surface) !important;
}

#dropdownUserNotifications ul.collection {
  margin: 0 !important;
  padding: 8px 0 !important;
  list-style: none;
  background: var(--rg-dd-surface);
  border: none !important;
}

#dropdownUserNotifications li.collection-item.notification-item {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  transition: background-color 0.2s;
}

/* Elementos no leídos tienen un pequeño highlight */
#dropdownUserNotifications li.collection-item.notification-item.unread {
  background: var(--rg-dd-blue-pale) !important;
}

#dropdownUserNotifications li.collection-item.notification-item:hover {
  background: var(--rg-dd-hover) !important;
}

#dropdownUserNotifications a.cg-notification-action {
  display: block;
  padding: 12px 20px !important;
  text-align: left;
  cursor: pointer;
  text-decoration: none;
  color: var(--rg-dd-text) !important;
  white-space: normal !important;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

#dropdownUserNotifications p.cg-notification-message {
  font-family: "Nunito", sans-serif;
  font-size: 13px !important;
  font-weight: 700;
  line-height: 1.4 !important;
  margin: 0 0 6px 0 !important;
  color: var(--rg-dd-text);
}

/* El texto cambia sutilmente a rojo en las no leídas */
#dropdownUserNotifications li.unread p.cg-notification-message {
  color: var(--rg-dd-red) !important;
}

#dropdownUserNotifications h6.cg-notification-date {
  font-family: "Nunito Sans", sans-serif;
  font-size: 11px !important;
  font-weight: 600;
  color: var(--rg-dd-muted) !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center;
  gap: 4px;
}

#dropdownUserNotifications h6.cg-notification-date i.material-icons {
  font-size: 13px !important;
  color: var(--rg-dd-muted) !important;
}

/* Botón inferior "Ver todas" */
#dropdownUserNotifications a.see-all-notifications {
  display: block !important;
  width: 100%;
  padding: 14px 0 !important;
  background: var(--rg-dd-surface) !important;
  border-top: 1px solid var(--rg-dd-gray-line) !important;
  color: var(--rg-dd-blue) !important;
  font-family: "Nunito", sans-serif;
  font-size: 13px !important;
  font-weight: 800 !important;
  text-transform: none !important;
  text-align: center !important;
  cursor: pointer;
  border-radius: 0 0 calc(var(--rg-dd-radius) - 1px) calc(var(--rg-dd-radius) - 1px);
  transition: all 0.2s;
}

#dropdownUserNotifications a.see-all-notifications:hover {
  background: var(--rg-dd-blue-light) !important;
}

/* ============================================================
   Ajustes Responsive (Mobile)
   ============================================================ */
@media (max-width: 600px) {
  #dropdownUserNotifications {
    width: calc(100vw - 32px) !important;
    min-width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
    left: 16px !important;
    right: auto !important;
  }
}

/* ============================================================
   rg-navbar-revamp.css
   Estilos del Navbar V2 - Extraídos de NavbarRevamp.cshtml
   para evitar conflictos de parsing con el motor Razor
   ============================================================ */

/* ── Estructura principal ─────────────────────────────────── */
nav#navbar {
  height: 90px !important;
  line-height: normal !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  background: #fff !important;
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  z-index: 1000;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

#navbar .nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1160px;
  padding: 0 40px;
  box-sizing: border-box;
}

#navbar .nav-logo {
  flex-shrink: 0;
  gap: 0;
  font-size: 0;
  line-height: 0;
  color: transparent;
}

#navbar .nav-logo .nav-logo-wordmark {
  display: block;
  width: 72px;
  height: 36px;
}

/* ── Links de navegación ──────────────────────────────────── */
#navbar .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex: 1;
  margin: 0 16px;
}

/* En sesión iniciada no se renderiza .nav-links (sólo invitados / landing). */

#navbar .nav-links a {
  font-size: 14px !important;
  font-weight: 700;
  color: #555;
  text-transform: none !important;
  white-space: nowrap !important;
}

/* ── Acciones / Botones ───────────────────────────────────── */
#navbar .nav-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

#navbar .btn {
  font-size: 14px !important;
  font-weight: 700;
  text-transform: none !important;
  white-space: nowrap !important;
  letter-spacing: 0 !important;
  height: 44px !important;
  line-height: 44px !important;
  padding: 0 16px !important;
  border-radius: 100px !important;
}

#navbar .nav-user-name {
  color: #2E3FA3;
  font-weight: 800;
}

#navbar .nav-user-area.visible {
  display: flex !important;
}

#navbar .nav-user-greeting {
  text-align: right;
}

#navbar .nav-user-hello {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0;
  color: #8a8fa8;
}

#navbar .nav-user-pts {
  font-family: "Nunito", sans-serif;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.3;
  color: #CE0037;
}

#navbar .nav-user-pts:hover {
  text-decoration: underline;
}

#navbar .nav-icon-cluster {
  display: flex;
  align-items: center;
  gap: 4px;
}

#navbar .nav-icon-btn {
  width: 38px;
  height: 38px;
  padding: 0;
  border-radius: 50%;
  border: none;
  background: transparent;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  color: #1b2b6b;
  transition: background 0.2s;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

#navbar .nav-icon-btn:hover {
  background: #e8ebf7;
}

#navbar .nav-icon-btn svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* Dropdown de cuenta: ver Content/App/rg-account-dropdown-revamp.css */

#navbar .nav-hamburger {
  display: none;
}

@media (max-width: 992px) {
  #navbar .nav-inner {
    gap: 8px;
  }

  #navbar .nav-user-area.visible {
    margin-left: auto;
    gap: 8px;
  }

  #navbar .nav-user-greeting {
    text-align: left;
  }

  #navbar .nav-user-hello {
    font-size: 12px;
  }

  #navbar .nav-user-pts {
    font-size: 18px;
  }

  #navbar .nav-hamburger {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    width: 24px;
    height: 24px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    margin-left: 12px;
  }

  #navbar .nav-hamburger span {
    width: 24px;
    height: 2px;
    background: #1b2b6b;
    border-radius: 10px;
    transition: all 0.3s linear;
    position: relative;
    transform-origin: 1px;
  }

  #navbar .nav-links, #navbar .nav-actions {
    display: none !important;
  }
}

/* ── Override: el modal de Materialize NO debe tener fondo blanco propio ── */
/* El fondo blanco lo aporta el div interno, no el wrapper del modal          */
#modalMainMenu.modal.cg-mobile-modal {
  background-color: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: hidden !important;
  /* Anclaje a la derecha para que baje desde el botón hamburguesa */
  margin: 0 0 0 auto !important;
  left: auto !important;
  right: 0 !important;
  width: 85% !important;
  max-width: 380px !important;
}

/* La "tarjeta" blanca del menú ocupa solo su contenido, no toda la pantalla */
#modalMainMenu.modal.cg-mobile-modal > div {
  background-color: #fff;
  border-radius: 0 0 0 16px;
  overflow-y: auto;
  max-height: 85vh;
  padding: 0 !important;
}

/* Garantizar que el hamburger sea siempre visible en mobile */
@media only screen and (max-width: 993px) {
  .nav-hamburger {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  
  body #navbar .nav-inner .nav-user-area .nav-icon-cluster #nav-account-btn {
    display: none !important;
  }
  
  body #navbar .nav-inner .nav-user-area .nav-user-greeting {
    display: none !important;
  }
}

/* ── Menú mobile logueado (modal) ── */
.mob-user-header { display:flex; align-items:center; gap:14px; padding:20px 0 18px; border-bottom:1px solid var(--gray-line); margin-bottom:4px; }
.mob-user-avatar { width:44px; height:44px; border-radius:50%; background:var(--blue); color:#fff; font-family:var(--font-display); font-weight:900; font-size:16px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mob-user-name { font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--blue); }
.mob-user-pts { font-size:13px; color:var(--muted); margin-top:2px; }
.mob-group { border-bottom:1px solid var(--gray-line); padding:6px 0; }
.mob-group:last-child { border-bottom:none; }
.mob-item { width:100%; display:flex; align-items:center; gap:14px; background:none; border:none; cursor:pointer; padding:13px 4px; text-align:left; font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--text); transition:background .15s; border-radius:var(--r-sm); text-decoration:none !important; outline:none; }
.mob-item:hover { background:var(--gray-bg); }
.mob-item-icon { width:36px; height:36px; border-radius:10px; background:var(--blue-light); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mob-item-icon svg { width:18px; height:18px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.mob-item span { flex:1; }
.mob-item-arrow { width:16px; height:16px; stroke:var(--gray-mid); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }

/* ── Menú mobile NO logueado (modal) ── */
.mob-nav-link {
  display: block;
  padding: 16px 4px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  color: var(--blue);
  text-decoration: none !important;
  border-bottom: 1px solid var(--gray-line);
  transition: color .15s;
}
.mob-nav-link:hover { color: var(--rg-red, #CE0037); }

.mob-btn-primary {
  display: block;
  width: 100%;
  padding: 14px 24px;
  background: #CE0037;
  color: #fff !important;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 15px;
  text-align: center;
  text-decoration: none !important;
  border-radius: 10px;
  transition: background .2s;
}
.mob-btn-primary:hover { background: #c41f1f; }

.mob-btn-outline {
  display: block;
  width: 100%;
  padding: 13px 24px;
  background: transparent;
  color: var(--blue) !important;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 15px;
  text-align: center;
  text-decoration: none !important;
  border: 1.5px solid #d1d5e0;
  border-radius: 10px;
  transition: border-color .2s, background .2s;
}
.mob-btn-outline:hover { border-color: var(--blue); background: #f0f2f8; }


/* ============================================================
   rg-account-dropdown-revamp.css
   Dropdown "Mi cuenta" — alineado a club-grido-revamp__21_ (7).html
   (.nav-dropdown, .nav-dropdown-header, .nav-dd-*)
   ============================================================ */

#dropdownUserAccount.cg-account-menu {
  --rg-dd-blue: #1b2b6b;
  --rg-dd-blue-mid: #2e3fa3;
  --rg-dd-blue-light: #e8ebf7;
  --rg-dd-blue-pale: #f0f2f8;
  --rg-dd-red: #CE0037;
  --rg-dd-red-light: #fdeaea;
  --rg-dd-surface: #ffffff;
  --rg-dd-muted-header: rgba(255, 255, 255, 0.7);
  --rg-dd-gray-line: #eaedf3;
  --rg-dd-border: #eaedf3;
  --rg-dd-icon-bg: #e8ebf7;
  --rg-dd-hover: #f0f2f8;
  --rg-dd-logout-bg: #fafbfe;
  --rg-dd-space-1: 8px;
  --rg-dd-space-2: 12px;
  --rg-dd-space-3: 16px;
  --rg-dd-space-4: 20px;
  --rg-dd-radius: 20px;
  --rg-dd-row-h: auto;
  --rg-dd-icon-corner: 8px;

  width: 260px !important;
  min-width: 260px !important;
  max-height: 70vh !important;
  overflow: hidden auto !important;
  border: 1px solid var(--rg-dd-gray-line);
  border-radius: var(--rg-dd-radius);
  box-shadow: 0 16px 48px rgba(27, 43, 107, 0.18) !important;
  background: var(--rg-dd-surface);
  padding: 0 !important;
}

#dropdownUserAccount.cg-account-menu ul {
  margin: 0 !important;
  padding: 0 0 8px !important;
  list-style: none;
  background: var(--rg-dd-surface);
}

#dropdownUserAccount.cg-account-menu li {
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

#dropdownUserAccount.cg-account-menu li form {
  margin: 0 !important;
  padding: 0 !important;
  width: 100%;
  display: block;
}

/* Header (nav-dropdown-header) */
#dropdownUserAccount.cg-account-menu .rg-account-menu-header {
  display: flex;
  align-items: center;
  gap: var(--rg-dd-space-2);
  min-height: 0;
  padding: var(--rg-dd-space-3) var(--rg-dd-space-4);
  background: var(--rg-dd-blue);
  border-radius: var(--rg-dd-radius) var(--rg-dd-radius) 0 0;
  border-bottom: none;
  list-style: none;
}

#dropdownUserAccount.cg-account-menu li.rg-account-menu-header + li {
  margin-top: 8px;
}

#dropdownUserAccount.cg-account-menu .rg-account-avatar {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  margin: 0;
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  border: 0;
  box-shadow: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Nunito", sans-serif;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

#dropdownUserAccount.cg-account-menu .rg-account-meta {
  min-width: 0;
  flex: 1;
}

#dropdownUserAccount.cg-account-menu .rg-account-name {
  color: #fff;
  font-family: "Nunito", sans-serif;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

#dropdownUserAccount.cg-account-menu .rg-account-points {
  margin-top: 2px;
  font-family: "Nunito", sans-serif;
  font-size: 12px;
  line-height: 1.25;
  color: var(--rg-dd-muted-header);
}

#dropdownUserAccount.cg-account-menu .rg-account-points-label {
  font-weight: 400;
  color: inherit;
  margin-right: 0;
}

#dropdownUserAccount.cg-account-menu .rg-account-points-value {
  color: var(--rg-dd-red);
  font-weight: 700;
}

/* Dividers (.nav-dd-divider) */
#dropdownUserAccount.cg-account-menu li.rg-account-sep {
  height: 1px;
  margin: 6px 0;
  padding: 0 !important;
  border: 0;
  border-top: none;
  background: var(--rg-dd-gray-line);
  list-style: none;
  pointer-events: none;
}

/* Items (.nav-dd-item) */
#dropdownUserAccount.cg-account-menu li.rg-account-item > a,
#dropdownUserAccount.cg-account-menu li.rg-account-item .cg-link-button {
  display: flex !important;
  align-items: center;
  gap: 14px;
  width: 100%;
  min-height: 46px;
  height: auto !important;
  padding: 11px var(--rg-dd-space-4) !important;
  margin: 0 !important;
  box-sizing: border-box;
  border: 0;
  background: transparent;
  color: var(--rg-dd-blue) !important;
  font-family: "Nunito", sans-serif;
  font-size: 13px !important;
  font-weight: 700;
  line-height: 1.25 !important;
  text-decoration: none;
  text-transform: none !important;
  text-align: left !important;
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

#dropdownUserAccount.cg-account-menu li.rg-account-item > a:hover,
#dropdownUserAccount.cg-account-menu li.rg-account-item > a:focus-visible,
#dropdownUserAccount.cg-account-menu li.rg-account-item .cg-link-button:hover,
#dropdownUserAccount.cg-account-menu li.rg-account-item .cg-link-button:focus-visible {
  background: var(--rg-dd-blue-pale);
  color: var(--rg-dd-blue) !important;
  outline: none;
}

#dropdownUserAccount.cg-account-menu li.rg-account-item > a:focus-visible,
#dropdownUserAccount.cg-account-menu li.rg-account-item .cg-link-button:focus-visible {
  box-shadow: inset 0 0 0 2px rgba(46, 63, 163, 0.2);
}

/* Icon chip (.nav-dd-item-icon) */
#dropdownUserAccount.cg-account-menu li.rg-account-item > a i,
#dropdownUserAccount.cg-account-menu li.rg-account-item .cg-link-button i {
  flex-shrink: 0;
  width: 32px !important;
  min-width: 32px;
  height: 32px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  float: none !important;
  font-size: 16px !important;
  line-height: 1 !important;
  color: var(--rg-dd-blue-mid) !important;
  background: var(--rg-dd-icon-bg);
  border-radius: var(--rg-dd-icon-corner);
}

#dropdownUserAccount.cg-account-menu li.rg-account-item .cg-link-button i.fa {
  font-size: 15px !important;
}

/* Cerrar sesión (.nav-dd-item-icon.red) */
#dropdownUserAccount.cg-account-menu li.rg-account-item--logout {
  background: var(--rg-dd-logout-bg);
  border-top: 1px solid var(--rg-dd-gray-line);
  margin-top: 0;
}

#dropdownUserAccount.cg-account-menu li.rg-account-item--logout > a {
  color: var(--rg-dd-red) !important;
  border-radius: 0 0 calc(var(--rg-dd-radius) - 1px) calc(var(--rg-dd-radius) - 1px);
  padding-bottom: 11px !important;
}

#dropdownUserAccount.cg-account-menu li.rg-account-item--logout > a:hover,
#dropdownUserAccount.cg-account-menu li.rg-account-item--logout > a:focus-visible {
  background: #fff5f5;
  color: var(--rg-dd-red) !important;
}

#dropdownUserAccount.cg-account-menu li.rg-account-item--logout > a i {
  color: var(--rg-dd-red) !important;
  background: var(--rg-dd-red-light) !important;
}

/* ═══════════════════════════════════════════════════════
   DETAIL REVAMP MODAL — Popup de detalle de canje.
   Namespace: .rg-detail-*
   Tokens: heredados de rg-revamp-tokens.css
   ══════════════════════════════════════════════════════ */

.rg-detail-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2100;
  background: rgba(27, 43, 107, .5);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.rg-detail-overlay.open { display: flex; }

.rg-detail-card {
  position: relative;
  background: #fff;
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-width: 500px;
  width: 100%;
  max-height: 90vh;
  box-shadow: 0 24px 64px rgba(27, 43, 107, .2);
  animation: rgDetailIn .25s ease;
  font-family: var(--font-body);
}

@keyframes rgDetailIn {
  from { opacity: 0; transform: translateY(20px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.rg-detail-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .92);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  color: var(--muted);
  z-index: 2;
  transition: background .2s, color .2s;
}

.rg-detail-close:hover {
  background: #fff;
  color: var(--blue);
}

/* ── Columna izquierda ── */
.rg-detail-col-left {
  position: relative;
  background: var(--blue);
  display: flex;
  flex-direction: column;
}

.rg-detail-img-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  overflow: hidden;
}

.rg-detail-img {
  width: 100%;
  height: 260px;
  object-fit: cover;
}

.rg-detail-promo-box {
  margin: 0 16px 16px;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .2);
  border-radius: var(--r-md);
  padding: 14px 16px;
}

.rg-detail-promo-sub {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 11px;
  color: rgba(255, 255, 255, .7);
  line-height: 1.4;
  margin: 0 0 4px;
}

.rg-detail-promo-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 14px;
  color: #fff;
  margin: 0;
}

/* ── Columna derecha ── */
.rg-detail-col-right {
  padding: 28px 24px 24px;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}

.rg-detail-tags {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.rg-detail-tag {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 11px;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  display: inline-flex;
  align-items: center;
  line-height: 1.4;
}

.rg-detail-tag-red  { background: var(--red-light);  color: var(--red);  }
.rg-detail-tag-blue { background: var(--blue-light); color: var(--blue); }

.rg-detail-title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 19px;
  color: var(--blue);
  letter-spacing: -.4px;
  line-height: 1.2;
  margin: 0 0 10px;
  text-transform: uppercase;
}

.rg-detail-desc {
  font-size: 13px;
  color: var(--text-body);
  line-height: 1.65;
  margin: 0 0 16px;
}

.rg-detail-divider {
  height: 1px;
  background: var(--gray-line);
  margin-bottom: 16px;
}

.rg-detail-steps-lbl {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0 0 12px;
}

.rg-detail-steps {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}

.rg-detail-step {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.rg-detail-step-n {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--blue);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.rg-detail-step-t {
  font-size: 12px;
  color: var(--text-body);
  line-height: 1.5;
  margin: 0;
}

.rg-detail-byc-wrap {
  border: 1px solid var(--gray-line);
  border-radius: var(--r-sm);
  overflow: hidden;
}

.rg-detail-byc-wrap summary {
  padding: 9px 12px;
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.rg-detail-byc-wrap summary::-webkit-details-marker { display: none; }

.rg-detail-byc {
  padding: 10px 12px;
  font-size: 11px;
  color: var(--muted);
  line-height: 1.6;
  border-top: 1px solid var(--gray-line);
}

/* ── Responsive ── */
@media (max-width: 560px) {
  .rg-detail-card {
    grid-template-columns: 1fr;
  }
  .rg-detail-col-left  { min-height: 220px; }
  .rg-detail-col-right { max-height: none; }
}

/* ── Páginas de email redirect — navbar reducida ── */
.er-page {
  display:none; position:fixed; inset:0; z-index:2000;
  background:#fff; overflow-y:auto;
}
.er-page.open { display:block; }

.er-nav {
  background:#fff; border-bottom:3px solid var(--blue);
  position:sticky; top:0; z-index:10;
}
.er-nav-inner {
  max-width:900px; margin:0 auto; padding:0 40px; height:64px;
  display:flex; align-items:center; justify-content:space-between;
}
.er-nav-logo {
  font-family:var(--font-display); font-weight:900; font-size:20px; color:var(--blue);
  display:flex; align-items:center; gap:6px; text-decoration:none; cursor:pointer;
}
.er-nav-logo span { color:var(--red); }
.er-nav-action {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-display); font-weight:800; font-size:13px; color:var(--blue);
  background:none; border:none; cursor:pointer; text-decoration:none;
  transition:color .2s;
}
.er-nav-action:hover { color:var(--red); }
.er-nav-action svg { width:14px; height:14px; fill:var(--red); }

.er-body { max-width:640px; margin:0 auto; padding:56px 40px 80px; }

.er-title {
  font-family:var(--font-display); font-weight:900; font-size:28px;
  color:var(--blue); letter-spacing:-0.5px; margin-bottom:8px; line-height:1.15;
}
.er-title .accent { color:var(--red); }
.er-subtitle { font-size:14px; color:var(--muted); line-height:1.6; margin-bottom:36px; }

.er-card {
  background:#fff; border:1px solid var(--gray-line); border-radius:var(--r-lg);
  padding:28px 32px; margin-bottom:20px;
}
.er-card-title {
  font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--blue);
  margin-bottom:16px; display:flex; align-items:center; gap:10px;
}
.er-card-title svg { width:18px; height:18px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0; }

/* Success state */
.er-success {
  text-align:center; padding:20px 0;
}
.er-success-icon {
  width:72px; height:72px; border-radius:50%; margin:0 auto 20px;
  display:flex; align-items:center; justify-content:center; font-size:32px;
}
.er-success-icon.green { background:#E8F8EE; border:2px solid #22C55E; color: #22C55E; }
.er-success-icon.blue  { background:var(--blue-light); border:2px solid var(--blue-mid); color: var(--blue); }
.er-success-title { font-family:var(--font-display); font-weight:900; font-size:24px; color:var(--blue); margin-bottom:10px; }
.er-success-desc { font-size:14px; color:var(--muted); line-height:1.65; margin-bottom:28px; max-width:480px; margin-left:auto; margin-right:auto; }
.er-success-desc strong { color:var(--blue); font-weight:700; }

/* Botones */
.er-btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--blue); color:#fff; border:none; border-radius:var(--r-md);
  padding:13px 32px; font-family:var(--font-display); font-weight:800; font-size:14px;
  cursor:pointer; transition:all .2s; text-decoration:none;
}
.er-btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }
.er-btn-primary:hover:not(:disabled) { background:var(--blue-mid); transform:translateY(-1px); }
.er-btn-primary.red { background:var(--red); }
.er-btn-primary.red:hover:not(:disabled) { background:var(--red-mid); }
.er-btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:var(--muted); border:1.5px solid var(--gray-mid);
  border-radius:var(--r-md); padding:12px 24px; font-family:var(--font-display);
  font-weight:700; font-size:14px; cursor:pointer; transition:all .2s;
}
.er-btn-ghost:hover { border-color:var(--blue); color:var(--blue); }
.er-btn-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

/* Info box */
.er-info-box {
  display:flex; align-items:flex-start; gap:12px;
  background:var(--blue-light); border:1px solid var(--blue-mid);
  border-radius:var(--r-md); padding:14px 18px; margin-bottom:24px;
  font-size:13px; color:var(--blue); line-height:1.6;
}
.er-info-box svg { width:18px; height:18px; stroke:var(--blue-mid); fill:none; stroke-width:1.8; stroke-linecap:round; flex-shrink:0; margin-top:1px; }

@media (max-width:640px) {
  .er-body { padding:36px 20px 60px; }
  .er-nav-inner { padding:0 20px; }
}

.se-page { display:block; position:fixed; inset:0; z-index:2000; background:#fff; overflow-y:auto; }
.se-nav { width:100%; height:60px; border-bottom:1px solid #EAEDF3; display:flex; align-items:center; padding:0 24px; background:#fff; }
.se-nav-logo { cursor:pointer; text-decoration:none; display:inline-block; }
.se-body { max-width:560px; text-align:center; padding-top:80px; margin:0 auto; padding-left:16px; padding-right:16px;}
.se-btn-row { display:flex; justify-content:center; flex-direction:column; align-items:center; gap:12px; margin-top:32px; }
.se-btn-primary, .se-btn-ghost { text-decoration:none; display:inline-flex; align-items:center; justify-content:center; border-radius:50px; font-family:var(--font-display, 'Nunito', sans-serif); font-weight:800; font-size:14px; padding:12px 24px; cursor:pointer; width:280px; max-width:100%;}
.se-btn-primary { background:var(--red, #CE0037); color:#fff; border:none; }
.se-btn-ghost { background:transparent; color:var(--muted, #8A8FA8); border:1px solid #EAEDF3; }
.se-success-title { font-family:var(--font-display, 'Nunito', sans-serif); font-weight:900; font-size:24px; color:var(--blue, #1B2B6B); margin-bottom:12px; margin-top:8px; }
.se-success-desc { font-size:14px; color:var(--text-body, #4A4A4A); line-height:1.6; max-width:440px; margin:0 auto; }
.se-success-icon { background:#FDEAEA; border:2px solid var(--red, #CE0037); font-size:32px; color:var(--red, #CE0037); width:72px; height:72px; display:inline-flex; align-items:center; justify-content:center; border-radius:50%; margin:0 auto 16px auto; }

/* ─────────────────────────────────────────────
   MODAL CAMBIO DE PAÍS (Revamp) - NEW MOCKUP
───────────────────────────────────────────── */
#modalChangeLocation.rg-sl-modal {
  background: var(--white, #ffffff);
  border-radius: var(--r-xl, 28px);
  box-shadow: var(--shadow-lg, 0 20px 48px rgba(27,43,107,0.22));
  width: 100%;
  max-width: 440px;
  overflow-y: auto;
  padding: 0;
  max-height: 90vh;
  position: fixed !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  margin: auto !important;
  height: max-content !important;
}

#modalChangeLocation .rg-sl-header {
  background: var(--blue, #1B2B6B);
  padding: 20px 24px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#modalChangeLocation .rg-sl-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

#modalChangeLocation .rg-sl-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: rgba(255,255,255,0.13);
  display: flex; align-items: center; justify-content: center;
}

#modalChangeLocation .rg-sl-icon svg {
  width: 18px; height: 18px;
  stroke: #fff; fill: none;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
}

#modalChangeLocation .rg-sl-title {
  font-family: var(--font-display, 'Nunito', sans-serif);
  font-weight: 900; font-size: 15px; color: #fff;
  margin: 0;
}

#modalChangeLocation .rg-sl-close {
  width: 30px; height: 30px; border-radius: 50%;
  border: none; background: rgba(255,255,255,0.13);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
#modalChangeLocation .rg-sl-close:hover { background: rgba(255,255,255,0.24); }
#modalChangeLocation .rg-sl-close svg {
  width: 13px; height: 13px;
  stroke: #fff; fill: none; stroke-width: 2.4; stroke-linecap: round;
}

#modalChangeLocation .rg-sl-detection-banner {
  background: linear-gradient(90deg, #FFF8E1 0%, #FFF3CD 100%);
  border-bottom: 1.5px solid #FFE082;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  gap: 10px;
}

#modalChangeLocation .rg-sl-detection-icon {
  width: 32px; height: 32px; flex-shrink: 0;
  background: #FFD740;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}

#modalChangeLocation .rg-sl-detection-icon svg {
  width: 16px; height: 16px;
  stroke: #7A5200; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}

#modalChangeLocation .rg-sl-detection-text {
  flex: 1;
}

#modalChangeLocation .rg-sl-detection-label {
  font-family: var(--font-display, 'Nunito', sans-serif);
  font-weight: 800; font-size: 11px;
  color: #7A5200; text-transform: uppercase; letter-spacing: 0.6px;
  margin-bottom: 1px;
}

#modalChangeLocation .rg-sl-detection-desc {
  font-family: var(--font-body, 'Nunito Sans', sans-serif);
  font-size: 12px; color: #8B6914; line-height: 1.4;
  margin: 0;
}

#modalChangeLocation .rg-sl-body {
  padding: 20px 24px 24px;
}

#modalChangeLocation .rg-sl-section-label {
  font-family: var(--font-display, 'Nunito', sans-serif);
  font-weight: 900; font-size: 13px;
  color: var(--blue, #1B2B6B); text-transform: uppercase; letter-spacing: 0.7px;
  margin-bottom: 12px;
}

#modalChangeLocation .rg-sl-options-wrapper {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 18px;
}

#modalChangeLocation .rg-sl-option {
  border: 2px solid var(--gray-mid, #DDE1EA);
  border-radius: var(--r-lg, 20px);
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  transition: all .2s;
  background: var(--white, #ffffff);
  position: relative;
  overflow: hidden;
  margin: 0;
}

#modalChangeLocation .rg-sl-option::before {
  content: '';
  position: absolute; inset: 0;
  background: var(--blue-light, #E8EBF7);
  opacity: 0;
  transition: opacity .2s;
}

#modalChangeLocation .rg-sl-option:hover { border-color: var(--blue-mid, #2E3FA3); }
#modalChangeLocation .rg-sl-option:hover::before { opacity: 1; }

#modalChangeLocation .rg-sl-option.active {
  border-color: var(--blue, #1B2B6B);
  background: var(--blue-light, #E8EBF7);
}

#modalChangeLocation .rg-sl-option.recommended {
  border-color: var(--blue, #1B2B6B);
}

#modalChangeLocation .rg-sl-flag-lg {
  width: 44px; height: 30px;
  border-radius: 6px; overflow: hidden;
  border: 0.5px solid rgba(0,0,0,0.1);
  flex-shrink: 0; position: relative; z-index: 1;
  box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}

#modalChangeLocation .rg-sl-flag-lg svg { width: 100%; height: 100%; display: block; }

#modalChangeLocation .rg-sl-option-info { flex: 1; position: relative; z-index: 1; text-align: left; }

#modalChangeLocation .rg-sl-option-country {
  font-family: var(--font-display, 'Nunito', sans-serif);
  font-weight: 900; font-size: 15px; color: var(--text, #1B2B6B);
  display: flex; align-items: center; gap: 7px;
  margin: 0;
}

#modalChangeLocation .rg-sl-badge-recommended {
  font-family: var(--font-display, 'Nunito', sans-serif);
  font-weight: 800; font-size: 9px;
  background: var(--blue, #1B2B6B); color: #fff;
  padding: 2px 8px; border-radius: var(--r-pill, 50px);
  text-transform: uppercase; letter-spacing: 0.4px;
}

#modalChangeLocation .rg-sl-option-detail {
  font-family: var(--font-body, 'Nunito Sans', sans-serif);
  font-size: 12px; color: var(--muted, #8A8FA8); margin-top: 2px;
}

#modalChangeLocation .rg-sl-option-radio {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 2px solid var(--gray-mid, #DDE1EA);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; position: relative; z-index: 1;
  transition: all .18s;
}

#modalChangeLocation .rg-sl-option.active .rg-sl-option-radio {
  border-color: var(--blue, #1B2B6B);
  background: var(--blue, #1B2B6B);
}

#modalChangeLocation .rg-sl-option-radio svg {
  width: 11px; height: 11px;
  stroke: #fff; fill: none;
  stroke-width: 2.8; stroke-linecap: round; stroke-linejoin: round;
  opacity: 0; transition: opacity .15s;
}

#modalChangeLocation .rg-sl-option.active .rg-sl-option-radio svg { opacity: 1; }

#modalChangeLocation .rg-sl-info-box {
  background: var(--blue-light, #E8EBF7);
  border-radius: var(--r-sm, 8px);
  padding: 11px 13px;
  display: flex; align-items: flex-start; gap: 9px;
  margin-bottom: 20px;
}

#modalChangeLocation .rg-sl-info-box-icon { flex-shrink: 0; margin-top: 1px; }
#modalChangeLocation .rg-sl-info-box-icon svg {
  width: 14px; height: 14px;
  stroke: var(--blue-mid, #2E3FA3); fill: none;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
}

#modalChangeLocation .rg-sl-info-box p {
  font-size: 12px; color: var(--blue-mid, #2E3FA3); line-height: 1.5;
  font-family: var(--font-body, 'Nunito Sans', sans-serif);
  margin: 0;
}

#modalChangeLocation .rg-sl-footer { 
  display: flex; gap: 10px; height: auto; padding: 0; background: none; margin-bottom: 0;
}

#modalChangeLocation .rg-sl-btn-secondary {
  padding: 12px 20px;
  border-radius: var(--r-pill, 50px);
  border: 1.5px solid var(--gray-mid, #DDE1EA);
  background: transparent;
  font-family: var(--font-display, 'Nunito', sans-serif); font-weight: 800; font-size: 14px;
  color: var(--text-body, #3A3A5C); cursor: pointer; transition: all .18s;
  white-space: nowrap; height: auto; line-height: normal;
}

#modalChangeLocation .rg-sl-btn-secondary:hover {
  border-color: var(--blue, #1B2B6B); background: var(--blue-pale, #F0F2F8); color: var(--blue, #1B2B6B);
}

#modalChangeLocation .rg-sl-btn-primary {
  flex: 1; padding: 12px;
  border-radius: var(--r-pill, 50px); border: none;
  background: var(--red, #CE0037);
  font-family: var(--font-display, 'Nunito', sans-serif); font-weight: 900; font-size: 14px;
  color: #fff; cursor: pointer;
  transition: all .18s;
  display: flex; align-items: center; justify-content: center; gap: 7px; height: auto; line-height: normal;
}

#modalChangeLocation .rg-sl-btn-primary:hover:not(:disabled) { background: var(--red-mid, #C0392B); transform: translateY(-1px); box-shadow: 0 6px 18px rgba(227,30,36,0.28); }
#modalChangeLocation .rg-sl-btn-primary:disabled { background: var(--gray-mid, #DDE1EA); color: var(--muted, #8A8FA8); cursor: default; transform: none; box-shadow: none; }

#modalChangeLocation .rg-sl-btn-primary svg {
  width: 15px; height: 15px;
  stroke: #fff; fill: none;
  stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0;
}



.tv-page {
  background: #fff;
}





.tv-page-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.65;
  margin: 0 0 40px;
  max-width: 700px;
}

.tv-layout {
  display: grid;
  grid-template-columns: 460px 1fr;
  gap: 48px;
  align-items: start;
}

.cg-card {
  width: 360px;
  height: 220px;
  border-radius: 16px;
  background-color: #1B2B6B;
  position: relative;
  overflow: hidden;
  font-family: 'Nunito', sans-serif;
  box-shadow: 0 16px 40px rgba(27,43,107,0.35);
  flex-shrink: 0;
  margin: 0 auto;
}
.cg-body {
  position: absolute;
  inset: 0;
  padding: 22px 24px 0 24px;
}
.cg-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.cg-left {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.cg-logo-club,
.cg-logo-grido {
  font-family: 'Nunito', sans-serif;
  font-weight: 900;
  font-size: 26px;
  color: #fff;
  letter-spacing: -0.5px;
  display: block;
  line-height: 1;
}
.cg-logo-grido { margin-top: -2px; }
.cg-tagline {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: 3px;
}
.cg-tagline span {
  font-family: 'Nunito Sans', sans-serif;
  font-weight: 700;
  font-size: 11px;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.4px;
  display: block;
  line-height: 1.45;
  text-transform: uppercase;
}
.cg-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-end;
  padding-top: 3px;
  min-width: 0;
  max-width: 120px;
}
.cg-member-label {
  font-family: 'Nunito Sans', sans-serif;
  font-weight: 600;
  font-size: 9px;
  color: rgba(255,255,255,0.5);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 3px;
}
.cg-member-name {
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: 13px;
  color: #fff;
  letter-spacing: 0.3px;
  text-align: right;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 120px;
}
.cg-barcode-area {
  position: absolute;
  bottom: 30px;
  left: 24px;
  right: 24px;
  background: #fff;
  border-radius: 6px;
  padding: 8px 12px 5px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cg-barcode-num {
  font-family: 'Nunito Sans', sans-serif;
  font-size: 9px;
  color: #333;
  letter-spacing: 3px;
  margin-top: 3px;
  font-weight: 600;
}
.cg-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 12px;
  display: flex;
}
.cg-footer-blue { background: #4FC3F7; flex: 1; }
.cg-footer-red  { background: #CE0037; width: 72px; }

.tv-info {
  padding-top: 8px;
}

.tv-info-pts-card {
  background: var(--blue);
  border-radius: var(--r-lg);
  padding: 28px 32px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.tv-pts-big {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 48px;
  color: #fff;
  letter-spacing: -1px;
  line-height: 1;
}

.tv-pts-label {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.55);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 4px;
}

.tv-pts-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.tv-pts-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: var(--r-pill);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
  border: none;
  white-space: nowrap;
  text-decoration: none;
}

.tv-pts-btn.white {
  background: #fff;
  color: var(--blue);
}

.tv-pts-btn.white:hover {
  background: var(--blue-light);
}

.tv-pts-btn svg {
  width: 15px;
  height: 15px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

.tv-info-row {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
}

.tv-info-row-extra {
  margin-bottom: 20px;
}

.tv-info-chip {
  flex: 1;
  background: var(--gray-bg);
  border-radius: var(--r-md);
  padding: 16px;
  border: 1px solid var(--gray-line);
}

.tv-info-chip-label {
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 4px;
}

.tv-info-chip-val {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 16px;
  color: var(--blue);
}

.tv-info-chip-val.red {
  color: var(--red);
}

.tv-more-chip {
  min-width: 0;
}

.tv-info-tip {
  background: var(--blue-light);
  border-radius: var(--r-md);
  padding: 14px 16px;
  font-size: 13px;
  color: var(--blue-mid);
  line-height: 1.6;
  display: flex;
  gap: 10px;
}

.tv-info-tip svg {
  width: 16px;
  height: 16px;
  stroke: var(--blue-mid);
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  flex-shrink: 0;
  margin-top: 2px;
}

@media (max-width: 900px) {
  .tv-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .tv-card {
    width: 100%;
    max-width: 340px;
  }
}

@media (max-width: 760px) {
  .tv-body {
    padding: 30px 20px 48px;
  }

  .inner-page-nav-inner {
    padding: 0 20px;
  }

  .tv-info {
    padding-top: 0;
  }

  .tv-info-pts-card {
    padding: 20px;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  .tv-pts-big {
    font-size: 36px;
  }

  .tv-pts-actions {
    width: 100%;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
  }

  .tv-pts-btn {
    flex: 1;
    min-width: 120px;
  }

  .tv-info-row {
    flex-wrap: wrap;
    gap: 8px;
  }

  .tv-info-chip {
    min-width: calc(50% - 8px);
  }
}

@media (max-width: 480px) {
  .tv-page-title {
    font-size: 23px;
  }

  .tv-card-brand {
    font-size: 28px;
  }

  .tv-card-name-vert {
    right: 16px;
    font-size: 11px;
    letter-spacing: 2px;
  }

  .tv-card-blue-block {
    padding-left: 16px;
  }

  .tv-card-red-block {
    width: 48px;
  }

  .tv-barcode-wrap {
    margin-right: 16px;
  }

  .tv-info-chip {
    min-width: 100%;
  }
}

