/* Minification failed. Returning unminified contents.
(358,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(359,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(361,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(362,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(363,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(370,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(371,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(372,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(373,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(376,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(379,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(380,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(381,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(382,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(383,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(384,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(385,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(386,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(389,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(390,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(395,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(396,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(397,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(398,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(399,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(402,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(403,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(404,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(405,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(409,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(415,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(416,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(422,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(423,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(437,21): run-time error CSS1039: Token not allowed after unary operator: '-btn-font-weight'
(477,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(497,36): run-time error CSS1019: Unexpected token, found ' '
(497,36): run-time error CSS1019: Unexpected token, found ' '
(497,36): run-time error CSS1042: Expected function, found ' '
(497,36): run-time error CSS1062: Expected semicolon or closing curly-brace, found ' '
(505,36): run-time error CSS1019: Unexpected token, found ' '
(505,36): run-time error CSS1019: Unexpected token, found ' '
(505,36): run-time error CSS1042: Expected function, found ' '
(505,36): run-time error CSS1062: Expected semicolon or closing curly-brace, found ' '
(515,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(537,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(630,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-apps-shell-bg'
(665,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(668,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-apps-row-bg'
(675,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(679,53): run-time error CSS1030: Expected identifier, found '.'
(679,98): run-time error CSS1031: Expected selector, found ')'
(679,98): run-time error CSS1025: Expected comma or open brace, found ')'
(758,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(763,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(784,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(791,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(809,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(814,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-white'
(815,17): run-time error CSS1039: Token not allowed after unary operator: '-cr-page-band-y'
(817,30): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(924,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-shadow-hover'
(939,19): run-time error CSS1039: Token not allowed after unary operator: '-cr-font-eyebrow'
(946,31): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(959,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-h3'
(964,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(990,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(1033,21): run-time error CSS1039: Token not allowed after unary operator: '-btn-font-weight'
(1037,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(1042,20): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(1055,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(1073,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red-dark'
(1084,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red-dark'
(1116,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-card-bg-soft'
(1117,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-border'
(1118,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-shadow'
(1145,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-card-bg-soft'
(1146,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-border'
(1147,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-shadow'
(1201,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-card-bg-soft'
(1202,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-border'
(1203,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-shadow'
(1208,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-h4'
(1233,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-card-bg-soft'
(1234,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-border'
(1235,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-bento-shadow'
(1239,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-h4'
(1245,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(1274,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(1400,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(1417,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(1419,26): run-time error CSS1039: Token not allowed after unary operator: '-border-light'
(1447,22): run-time error CSS1039: Token not allowed after unary operator: '-border-light'
(1448,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(1540,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(1549,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(1560,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1560,163): run-time error CSS1031: Expected selector, found ')'
(1560,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1569,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1569,163): run-time error CSS1031: Expected selector, found ')'
(1569,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1574,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1574,163): run-time error CSS1031: Expected selector, found ')'
(1574,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1580,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1580,163): run-time error CSS1031: Expected selector, found ')'
(1580,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1586,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1586,163): run-time error CSS1031: Expected selector, found ')'
(1586,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1594,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1594,163): run-time error CSS1031: Expected selector, found ')'
(1594,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1604,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1604,163): run-time error CSS1031: Expected selector, found ')'
(1604,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1622,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1622,163): run-time error CSS1031: Expected selector, found ')'
(1622,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1638,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1638,163): run-time error CSS1031: Expected selector, found ')'
(1638,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1644,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1644,163): run-time error CSS1031: Expected selector, found ')'
(1644,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1651,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1651,163): run-time error CSS1031: Expected selector, found ')'
(1651,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1659,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1659,163): run-time error CSS1031: Expected selector, found ')'
(1659,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1667,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1667,163): run-time error CSS1031: Expected selector, found ')'
(1667,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1676,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1676,163): run-time error CSS1031: Expected selector, found ')'
(1676,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1685,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1685,163): run-time error CSS1031: Expected selector, found ')'
(1685,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1693,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1693,163): run-time error CSS1031: Expected selector, found ')'
(1693,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1701,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1701,163): run-time error CSS1031: Expected selector, found ')'
(1701,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1710,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1710,163): run-time error CSS1031: Expected selector, found ')'
(1710,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1722,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1722,163): run-time error CSS1031: Expected selector, found ')'
(1722,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1738,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1738,163): run-time error CSS1031: Expected selector, found ')'
(1738,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1751,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1751,163): run-time error CSS1031: Expected selector, found ')'
(1751,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1756,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1756,163): run-time error CSS1031: Expected selector, found ')'
(1756,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1762,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1762,163): run-time error CSS1031: Expected selector, found ')'
(1762,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1774,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1774,163): run-time error CSS1031: Expected selector, found ')'
(1774,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1779,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1779,163): run-time error CSS1031: Expected selector, found ')'
(1779,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1785,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1785,163): run-time error CSS1031: Expected selector, found ')'
(1785,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1790,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1790,163): run-time error CSS1031: Expected selector, found ')'
(1790,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1794,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1794,163): run-time error CSS1031: Expected selector, found ')'
(1794,163): run-time error CSS1025: Expected comma or open brace, found ')'
(1802,7): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1802,165): run-time error CSS1031: Expected selector, found ')'
(1802,165): run-time error CSS1025: Expected comma or open brace, found ')'
(1812,7): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1812,165): run-time error CSS1031: Expected selector, found ')'
(1812,165): run-time error CSS1025: Expected comma or open brace, found ')'
(1818,7): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(1818,165): run-time error CSS1031: Expected selector, found ')'
(1818,165): run-time error CSS1025: Expected comma or open brace, found ')'
(1832,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-page-divider-gap'
(1861,3): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(1862,17): run-time error CSS1039: Token not allowed after unary operator: '-cr-page-band-y'
(1864,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-white'
(1865,30): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(1930,15): run-time error CSS1039: Token not allowed after unary operator: '-cr-dual-rail'
(1936,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(1937,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red-dark'
(1947,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(1949,15): run-time error CSS1039: Token not allowed after unary operator: '-text-muted'
(1963,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(1982,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(1983,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red-dark'
(2013,20): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(2023,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(2086,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(2143,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(2210,19): run-time error CSS1039: Token not allowed after unary operator: '-cr-font-eyebrow'
(2221,19): run-time error CSS1039: Token not allowed after unary operator: '-cr-font-spec'
(2285,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-stripe-a'
(2286,22): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-border'
(2292,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-stripe-b'
(2293,22): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-border'
(2299,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-stripe-a'
(2300,22): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-border'
(2306,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-stripe-b'
(2307,22): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-border'
(2311,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(2311,119): run-time error CSS1031: Expected selector, found ')'
(2311,119): run-time error CSS1025: Expected comma or open brace, found ')'
(2319,5): run-time error CSS1030: Expected identifier, found '#legacy-readers-section'
(2319,163): run-time error CSS1031: Expected selector, found ')'
(2319,163): run-time error CSS1025: Expected comma or open brace, found ')'
(2327,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(2339,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(2403,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(2412,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(2416,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(2420,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(2473,17): run-time error CSS1039: Token not allowed after unary operator: '-cr-page-band-y'
(2474,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-alt'
(2475,30): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(2487,16): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade-height'
(2488,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade'
(2499,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-alt'
(2592,41): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red-rgb'
(2625,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-icon-well-bg'
(2646,58): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(2701,10): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(2704,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-border'
(2704,57): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(2718,44): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(2718,72): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red-deep'
(2724,38): run-time error CSS1039: Token not allowed after unary operator: '-font-size-h1'
(2735,15): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(2744,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(2761,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(2762,26): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-border'
(2762,57): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(2763,31): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(2777,19): run-time error CSS1039: Token not allowed after unary operator: '-cr-font-eyebrow'
(2822,30): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(2911,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red-dark'
(2912,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(3021,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-alt'
(3024,30): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(3035,16): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade-height'
(3036,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade'
(3055,30): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(3091,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(3133,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-large'
(3146,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-alt'
(3149,30): run-time error CSS1039: Token not allowed after unary operator: '-cr-border-subtle'
(3160,16): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade-height'
(3161,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade'
(3174,10): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-bg'
(3181,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-card-elevated-border'
(3183,26): run-time error CSS1039: Token not allowed after unary operator: '-border-light'
(3194,43): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(3220,19): run-time error CSS1039: Token not allowed after unary operator: '-cr-font-eyebrow'
(3227,31): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(3240,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(3256,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(3331,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-h4'
(3341,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-white'
(3353,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-surface-alt'
(3363,16): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade-height'
(3364,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-section-alt-top-fade'
(3378,10): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(3379,15): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red-rgb'
(3411,10): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(3412,10): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red-deep'
(3427,40): run-time error CSS1039: Token not allowed after unary operator: '-font-size-h2'
(3436,25): run-time error CSS1039: Token not allowed after unary operator: '-font-size-small'
(3436,57): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(3439,15): run-time error CSS1039: Token not allowed after unary operator: '-gray-600'
(3513,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red'
(3514,10): run-time error CSS1039: Token not allowed after unary operator: '-magtek-red-dark'
(3557,15): run-time error CSS1039: Token not allowed after unary operator: '-cr-accent-red'
(3562,15): run-time error CSS1039: Token not allowed after unary operator: '-white'
(3599,20): run-time error CSS1039: Token not allowed after unary operator: '-cr-page-divider-gap'
(3600,23): run-time error CSS1039: Token not allowed after unary operator: '-cr-page-divider-gap'
(3605,19): run-time error CSS1039: Token not allowed after unary operator: '-cr-font-eyebrow'
(3613,19): run-time error CSS1039: Token not allowed after unary operator: '-font-size-h4'
(3632,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-large'
(3652,21): run-time error CSS1039: Token not allowed after unary operator: '-font-size-body'
(4073,5): run-time error CSS1030: Expected identifier, found '#check-scanners-catalog-section'
(4073,71): run-time error CSS1031: Expected selector, found ')'
(4073,71): run-time error CSS1025: Expected comma or open brace, found ')'
 */
/* Slider */
.slick-slider
{
    position: relative;

    display: block;

    -moz-box-sizing: border-box;
         box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0px auto;
    padding: 0;
	width:95%;
	
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
         -o-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}

    

    
@charset 'UTF-8';
/* Slider */
.slick-loading .slick-list
{
    background: #fff url('../slick/ajax-loader.gif') center center no-repeat;
}

/* Icons */
/*@font-face
{
    font-family: 'slick';
    font-weight: normal;
    font-style: normal;

    src: url('./fonts/slick.eot');
    src: url('./fonts/slick.eot?#iefix') format('embedded-opentype'), url('./fonts/slick.woff') format('woff'), url('./fonts/slick.ttf') format('truetype'), url('./fonts/slick.svg#slick') format('svg');
}*/
/* Arrows */
.slick-prev,
.slick-next
{
    /*
	font-size: 0;
    line-height: 0;
	*/
	
	position: absolute;
    top: 50%;
	z-index:100;
    display: block;

    width: 28px;
    height: 44px;
    /*margin-top: -10px;*/
    padding: 0;

    cursor: pointer;
	
	color: transparent;
    border: none;
    outline: none;
    background: transparent;
}
.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus
{
	/*
    color: transparent;
    outline: none;
    background: transparent;
	*/
}
.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before
{
    opacity: .5;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before
{
    opacity: .25;
}

.slick-prev:before,
.slick-next:before
{
    font-family: 'slick';
    font-size: 20px;
    line-height: 1;

    opacity: .20;
    color: white;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-prev
{
    left: 15px;
}
[dir='rtl'] .slick-prev
{
    right: -25px;
    left: auto;
}
.slick-prev:before
{
    content: '←';
}
[dir='rtl'] .slick-prev:before
{
    content: '→';
}

.slick-next
{
    right: 15px;
}
[dir='rtl'] .slick-next
{
    right: auto;
    left: -25px;
}
.slick-next:before
{
    content: '→';
}
[dir='rtl'] .slick-next:before
{
    content: '←';
}

/* Dots */
.slick-slider
{
    margin-bottom: 30px;
}



.slick-dots
{
    position: absolute;
    bottom: -45px;

    display: block;

    width: 100%;
    padding: 0;

    list-style: none;

    text-align: center;
}
.slick-dots li
{
    position: relative;

    display: inline-block;

    width: 20px;
    height: 20px;
    margin: 0 5px;
    padding: 0;

    cursor: pointer;
}
.slick-dots li button
{
    font-size: 0;
    line-height: 0;

    display: block;

    width: 20px;
    height: 20px;
    padding: 5px;

    cursor: pointer;

    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
}
.slick-dots li button:hover,
.slick-dots li button:focus
{
    outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before
{
    opacity: 1;
}
.slick-dots li button:before
{
    font-family: 'slick';
    font-size: 6px;
    line-height: 20px;

    position: absolute;
    top: 0;
    left: 0;

    width: 20px;
    height: 20px;

    content: '•';
    text-align: center;

    opacity: .25;
    color: black;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before
{
    opacity: .75;
    color: black;
}



/* ==========================================================================
   card-readers.css
   ───────────────────────────────────────────────────────────────────────────
   OWNERSHIP: Loaded on ALL four hardware hub pages (always first hub-specific sheet).

   Primary view: Views/Products/CardReaders.cshtml (.card-readers-page).
   Also styles shared #products patterns used by OEM, Check Scanners, Instant Issuance, Dyna partials,
   _CategorySectionHeader, API-injected catalog cards, and :root tokens consumed by oem-components.css.

   :root tokens (--cr-surface-*, --cr-card-* hub card system, --cr-accent-red, --cr-bento-*, …)
   — change sparingly; OEM + product-family-hub-shared depend on them.

   Major regions (search comments): "MMS Dyna", "Payment & access applications", "Legacy reader",
   "One Kernel", "Tap to Pay", "video modal", "DynaCast", "split hero", "services-marketing-banner",
   "CategorySectionHeader", "Check scanners".

   Pair with: product-family-hub-shared.css (always). oem-components.css does NOT load on Card Readers.
   ========================================================================== */

/* Tokens used by this file (cards, accents). */
:root {
  /*
   * Page bands — parity with Views/Services/Services.cshtml + magtek-standardization.css
   * (.section-bg-white / .section-bg-alt) and services-page.css .section-bg-alt::before top wash.
   */
  --cr-surface-white: var(--bg-white, #ffffff);
  --cr-surface-alt: linear-gradient(180deg, #fafbfc 0%, #f8f9fa 100%);
  /* Same gradient + height as services-page.css .section-bg-alt::before */
  --cr-section-alt-top-fade: linear-gradient(to bottom, rgba(255, 255, 255, 0.6) 0%, transparent 100%);
  --cr-section-alt-top-fade-height: 100px;
  --cr-border-subtle: rgba(38, 60, 80, 0.08);

  /*
   * Hardware hubs — unified card surfaces (4 siblings: Card Readers, OEM, Check Scanners, Instant Issuance).
   * Elevated cards: white panel + one shadow recipe; icon wells share one chrome gradient.
   * Dense grids: two alternating neutrals only (scanability without rainbow grays).
   */
  --cr-card-elevated-bg: var(--bg-white, #ffffff);
  --cr-card-elevated-border: rgba(38, 60, 80, 0.08);
  --cr-card-elevated-radius: 20px;
  --cr-card-elevated-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 12px 36px rgba(15, 23, 42, 0.07);
  --cr-card-elevated-shadow-hover:
    0 4px 12px rgba(15, 23, 42, 0.06),
    0 18px 44px rgba(38, 60, 80, 0.1);
  --cr-card-accent-border-hover: rgba(210, 18, 66, 0.2);
  --cr-card-icon-well-bg: linear-gradient(145deg, #f8fafc 0%, #f1f5f9 100%);
  --cr-card-icon-well-border: rgba(38, 60, 80, 0.09);
  --cr-card-icon-well-shadow: 0 4px 14px rgba(15, 23, 42, 0.05);
  --cr-card-stripe-a: #fafbfc;
  --cr-card-stripe-b: #f4f6f8;
  --cr-card-apps-shell-bg: linear-gradient(180deg, #ffffff 0%, #fcfcfc 55%, #fafafa 100%);
  --cr-card-apps-row-bg: var(--cr-card-elevated-bg);

  /* Canonical brand red (parity with magtek-buttons / lockups) */
  --magtek-red: #d21242;
  --magtek-red-dark: #b01035;
  /*
   * Corporate accent: same hue family as MagTek red, lower chroma — rules, headings, glows.
   * Keeps recognition without the high-chroma “alarm” read of pure #d21242 at large scale.
   */
  --cr-accent-red: #a04558;
  --cr-accent-red-deep: #853a4a;
  --cr-accent-red-rgb: 160, 69, 88;
  --white: #ffffff;
  --gray-600: #4b5563;

  /* MMS Dyna bento — unified card skin (PED/SCR/Go/Prox); brand cue stays on PED overline + CTAs */
  --cr-bento-card-bg: #ffffff;
  --cr-bento-card-bg-soft: linear-gradient(165deg, #ffffff 0%, #fafbfc 50%, #f6f8fa 100%);
  --cr-bento-border: rgba(38, 60, 80, 0.09);
  --cr-bento-shadow:
    0 1px 0 rgba(255, 255, 255, 0.92) inset,
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 8px 28px rgba(15, 23, 42, 0.07);
  --cr-bento-shadow-hover:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 4px 12px rgba(15, 23, 42, 0.06),
    0 16px 40px rgba(15, 23, 42, 0.09);

  /* Vertical rhythm: CardReaders + OEM (#products) section breaks & dense bands */
  --cr-page-divider-gap: clamp(2rem, 4.5vw, 3rem);
  --cr-page-band-y: clamp(3.2rem, 5.5vw, 5.6rem);

  /*
   * Typography alignment: Content/magtek-standardization.css (--font-size-*).
   * Services.cshtml loads the same stack; html { font-size: 10px } → 1rem = 10px.
   */
  --cr-font-eyebrow: 1.2rem; /* micro: uppercase / spec labels (~12px) */
  --cr-font-spec: 1.3rem; /* between --font-size-small and --font-size-body */
}

.main-content {
  position: relative;
}

/*
 * Card Readers: other .btn-text uses .btn-md → 1.6rem (magtek-buttons.css).
 * MMS Dyna card CTAs use 1.5rem + same weight — without that, “SDK docs” / learn-more
 * links read thinner. Match the Dyna chip treatment site-wide on this page.
 */
#products .btn-text:not(.mms-dyna-card-cta-btn) {
  font-size: 1.5rem !important;
  font-weight: var(--btn-font-weight, 700) !important;
  padding-bottom: 0.2rem !important;
}

/* Long label must still wrap (Tap to Pay block) */
#products .btn-text.cr-ttp-more {
  white-space: normal !important;
}

@media (max-width: 767px) {
  #products .btn-text:not(.mms-dyna-card-cta-btn) {
    font-size: 1.4rem !important;
  }
}

/* --- MMS Dyna device grid (shared partial _MmsDynaHardwareCardsStudy) --- */
.cr-mms-dyna-showcase#featuredHardwareSection,
.cr-mms-dyna-showcase#oemMmsDynaSection {
  scroll-margin-top: 88px;
}

.cr-mms-dyna-showcase .mms-dyna-card-readers-section .section-header {
  max-width: 720px;
  margin-bottom: 2.25rem;
}

.cr-mms-dyna-showcase .dyna-devices {
  margin-top: 0 !important;
  position: relative;
  z-index: 2;
}

.cr-mms-dyna-showcase .cr-mms-dyna-mms-explainer {
  max-width: 720px;
  margin: -0.5rem auto 2.25rem;
  padding: 0 4px;
}

.cr-mms-dyna-showcase .cr-mms-dyna-mms-explainer p {
  margin: 0 0 12px;
  font-size: var(--font-size-body);
  line-height: 1.62;
  color: #475569;
}

.cr-mms-dyna-showcase .cr-mms-dyna-mms-explainer p:last-child {
  margin-bottom: 0;
}

/*
 * Card Readers product page only (#products): MMS Dyna bento typography matches legacy
 * .cr-catalog-card (title / tagline / spec lines) — same system as OEM Components bento.
 */
#products #featuredHardwareSection .cr-mms-dyna-mms-explainer strong {
  color: #0f172a;
  font-weight: 700;
}

#products #featuredHardwareSection .mms-dyna-card-title {
  margin: 0 0 8px;
  font-size: clamp(1.75rem, 1.5vw + 1.4rem, 2.1rem);
  line-height: 1.22;
  letter-spacing: -0.02em;
  font-weight: 700;
  color: #0f172a;
}

#products #featuredHardwareSection .mms-dyna-card--ped .mms-dyna-card-title {
  font-size: clamp(1.75rem, 1.5vw + 1.4rem, 2.1rem);
}

#products #featuredHardwareSection .mms-dyna-card--scr .mms-dyna-card-title {
  margin-bottom: 8px;
}

#products #featuredHardwareSection .mms-dyna-card-lead,
#products #featuredHardwareSection .mms-dyna-card-text {
  margin: 0 0 16px;
  font-size: var(--font-size-small);
  line-height: 1.5;
  font-weight: 600;
  font-style: normal;
  color: #475569;
}

#products #featuredHardwareSection .mms-dyna-checklist {
  margin: 0 0 16px;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

#products #featuredHardwareSection .mms-dyna-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 0;
  line-height: 1.5;
  font-size: var(--font-size-body);
  font-weight: 500;
  color: #0f172a;
  overflow-wrap: anywhere;
}

#products #featuredHardwareSection .mms-dyna-checklist .mms-dyna-check {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  margin-top: 3px;
  border-radius: 4px;
  font-size: 1rem;
  background: #263c50;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}

#products #featuredHardwareSection .mms-dyna-card--scr .mms-dyna-card-lead {
  flex: 0 1 auto;
}

/* --- Payment & access applications — under Dyna hardware grid (CardReaders.cshtml) --- */
#products #card-reader-applications {
  scroll-margin-top: 88px;
}

#products #oem-mms-dyna-applications {
  scroll-margin-top: 88px;
}

#products #tap-to-pay-iphone-card-readers {
  scroll-margin-top: 88px;
}

#products .cr-mms-dyna-showcase .cr-mms-dyna-applications.cr-applications-showcase {
  margin-top: clamp(1.25rem, 2.5vw, 2rem);
  padding-top: clamp(1.5rem, 2.8vw, 2.25rem);
  border-top: 1px solid rgba(38, 60, 80, 0.08);
}

#products .cr-applications-showcase {
  padding: 0 0 clamp(2.5rem, 5vw, 3.25rem);
}

#products .cr-applications-showcase__row {
  margin-left: -12px;
  margin-right: -12px;
}

#products .cr-applications-showcase__col {
  padding-left: 12px;
  padding-right: 12px;
  margin-bottom: 22px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

@media (min-width: 992px) {
  #products .cr-applications-showcase__col {
    margin-bottom: 0;
  }

  /* Card Readers: Payment & Access panels — match OEM equal-height treatment (#oem-mms-dyna-applications in oem-components.css). */
  #products #card-reader-applications .cr-applications-showcase__row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
  }

  #products #card-reader-applications .cr-applications-showcase__row > .cr-applications-showcase__col {
    float: none;
    width: 50%;
    display: flex;
    flex-direction: column;
  }

  #products #card-reader-applications .cr-applications-showcase__card {
    flex: 1 1 auto;
    width: 100%;
    min-height: 100%;
  }
}

/* Near-white panels — Card Readers + OEM Payment & Access (token: --cr-card-apps-shell-bg) */
#products .cr-applications-showcase__card {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: var(--cr-card-apps-shell-bg);
  border-radius: 12px;
  border: 1px solid rgba(38, 60, 80, 0.055);
  padding: clamp(22px, 2.8vw, 28px) clamp(20px, 2.5vw, 26px) clamp(18px, 2.2vw, 24px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 1),
    0 1px 8px -2px rgba(15, 23, 42, 0.035);
}

#products .cr-applications-showcase__card-title {
  margin: 0 0 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(38, 60, 80, 0.08);
  font-size: clamp(1.45rem, 1.9vw, 1.75rem);
  font-weight: 800;
  line-height: 1.25;
  color: #334155;
  letter-spacing: -0.018em;
}

#products .cr-applications-showcase__list {
  margin: 0;
  padding: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#products .cr-applications-showcase__item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 11px 12px;
  margin: 0 -4px;
  font-size: var(--font-size-body, 1.6rem);
  line-height: 1.45;
  color: #334155;
  background: var(--cr-card-apps-row-bg);
  border: 1px solid rgba(38, 60, 80, 0.045);
  border-radius: 8px;
  transition: background-color 0.16s ease, box-shadow 0.16s ease;
}

#products .cr-applications-showcase__item--link:hover {
  background-color: var(--cr-card-elevated-bg);
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.04);
}

#products .cr-applications-showcase__item--link:has(.cr-applications-showcase__link:focus-visible) {
  background-color: var(--cr-card-elevated-bg);
  box-shadow: 0 0 0 1px rgba(38, 60, 80, 0.08);
}

#products .cr-applications-showcase__item--last,
#products .cr-applications-showcase__item:last-child {
  padding-bottom: 11px;
}

#products .cr-applications-showcase__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  min-width: 0;
  background: none;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

#products .cr-applications-showcase__icon img {
  width: 4.8rem;
  height: 4.8rem;
  max-width: min(4.8rem, 18vw);
  max-height: min(4.8rem, 18vw);
  object-fit: contain;
  display: block;
}

#products .cr-applications-showcase__text {
  color: #334155;
  flex: 1;
  min-width: 0;
}

#products .cr-applications-showcase__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex: 1;
  min-width: 0;
  margin: -2px 0;
  padding: 2px 0;
  text-decoration: none;
  color: inherit;
  border-radius: 4px;
}

#products .cr-applications-showcase__link-text {
  font-weight: 600;
  color: #334155;
  line-height: 1.45;
  transition: color 0.16s ease;
}

#products .cr-applications-showcase__link-suffix {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  font-size: 0.62rem;
  color: rgba(38, 60, 80, 0.28);
  border-radius: 6px;
  background: rgba(38, 60, 80, 0.04);
  transition:
    color 0.16s ease,
    background-color 0.16s ease,
    transform 0.16s ease;
}

#products .cr-applications-showcase__link:hover .cr-applications-showcase__link-text,
#products .cr-applications-showcase__link:focus-visible .cr-applications-showcase__link-text {
  color: var(--magtek-red, #d21242);
}

#products .cr-applications-showcase__link:hover .cr-applications-showcase__link-suffix,
#products .cr-applications-showcase__link:focus-visible .cr-applications-showcase__link-suffix {
  color: var(--magtek-red, #d21242);
  background: rgba(210, 18, 66, 0.08);
  transform: translateX(2px);
}

#products .cr-applications-showcase__link:focus {
  outline: none;
}

#products .cr-applications-showcase__link:focus-visible {
  outline: 2px solid rgba(210, 18, 66, 0.4);
  outline-offset: 3px;
}

#products .cr-applications-showcase__link--featured .cr-applications-showcase__link-text {
  font-weight: 700;
  color: #334155;
}

#products .cr-applications-showcase__link--featured:hover .cr-applications-showcase__link-text,
#products .cr-applications-showcase__link--featured:focus-visible .cr-applications-showcase__link-text {
  color: var(--magtek-red, #d21242);
}

#products .cr-applications-showcase__footnote {
  margin: 0.5rem 0 0;
  padding-top: 0.75rem;
  text-align: right;
  font-size: var(--font-size-small, 1.3rem);
  line-height: 1.4;
  color: #64748b;
  border-top: 1px solid rgba(38, 60, 80, 0.07);
}

#products .cr-applications-showcase__fn-ref {
  font-size: 0.72em;
  font-weight: 600;
}

#products .cr-applications-showcase__fn-anchor {
  color: #64748b;
  text-decoration: none;
}

#products .cr-applications-showcase__fn-anchor:hover,
#products .cr-applications-showcase__fn-anchor:focus {
  color: var(--magtek-red, #d21242);
}

/* MMS Dyna device cards — magtek-standardization .section-bg-white (Services.cshtml rhythm) */
.cr-mms-dyna-showcase .mms-dyna-card-readers-section {
  background: var(--cr-surface-white);
  padding: var(--cr-page-band-y) 0 clamp(3.6rem, 6.2vw, 4.4rem);
  margin-top: 0;
  border-top: 1px solid var(--cr-border-subtle);
}

.cr-mms-dyna-showcase .mms-dyna-card-readers-section .dyna-devices {
  margin-top: 0 !important;
}

/* MMS Dyna bento grid — Card Readers page only (.cr-mms-dyna-showcase); see _MmsDynaHardwareCardsStudy.cshtml */
.cr-mms-dyna-showcase .mms-dyna-card-readers-row {
  margin-left: -12px;
  margin-right: -12px;
}

.cr-mms-dyna-showcase .mms-dyna-card-readers-row > [class*="col-"] {
  padding-left: 12px;
  padding-right: 12px;
}

@media (min-width: 768px) {
  .cr-mms-dyna-showcase .mms-dyna-card-readers-row {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-readers-row > .mms-dyna-readers-col {
    float: none;
    display: flex;
    flex-direction: column;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-col--stack {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-col--stack .mms-dyna-readers-subrow {
    display: flex;
    flex-wrap: wrap;
    margin-left: -12px;
    margin-right: -12px;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-col--stack .mms-dyna-readers-subrow + .mms-dyna-readers-subrow {
    flex: 1;
    min-height: 0;
    margin-top: 16px;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-col--stack .mms-dyna-readers-subrow > [class*="col-"] {
    float: none;
    display: flex;
    flex-direction: column;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-half > .mms-dyna-card-link {
    flex: 1;
  }
}

.cr-mms-dyna-showcase .mms-dyna-card-link {
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  text-decoration: none !important;
  color: inherit;
  border-radius: 12px;
  padding: 26px 30px 24px;
  height: 100%;
  min-height: 100%;
  isolation: isolate;
  transition:
    transform 0.22s ease,
    box-shadow 0.22s ease,
    border-color 0.22s ease;
}

.cr-mms-dyna-showcase .mms-dyna-card-link::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.22s ease;
  background: rgba(38, 60, 80, 0.03);
  z-index: 0;
}

.cr-mms-dyna-showcase .mms-dyna-card-link:hover::before,
.cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible::before {
  opacity: 1;
}

.cr-mms-dyna-showcase .mms-dyna-card-link > * {
  position: relative;
  z-index: 1;
}

.cr-mms-dyna-showcase .mms-dyna-card-link:hover,
.cr-mms-dyna-showcase .mms-dyna-card-link:focus {
  text-decoration: none !important;
  color: inherit;
  transform: translateY(-2px);
  box-shadow: var(--cr-bento-shadow-hover);
  border-color: rgba(38, 60, 80, 0.14);
}

.cr-mms-dyna-showcase .mms-dyna-card-link:active {
  transform: translateY(0);
  transition-duration: 0.1s;
}

.cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible {
  outline: 2px solid #263c50;
  outline-offset: 3px;
}

.cr-mms-dyna-showcase .mms-dyna-overline {
  font-size: var(--cr-font-eyebrow);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #64748b;
  margin: 0 0 10px;
  padding-left: 10px;
  border-left: 3px solid var(--cr-accent-red);
}

.cr-mms-dyna-showcase .mms-dyna-card-title {
  font-size: 2.4rem;
  font-weight: 700;
  color: #1e293b;
  margin: 0 0 12px;
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.cr-mms-dyna-showcase .mms-dyna-card--ped .mms-dyna-card-title {
  font-size: var(--font-size-h3);
}

.cr-mms-dyna-showcase .mms-dyna-card-lead,
.cr-mms-dyna-showcase .mms-dyna-card-text {
  font-size: var(--font-size-body);
  line-height: 1.55;
  color: #5a6570;
  margin: 0 0 16px;
}

.cr-mms-dyna-showcase .mms-dyna-card-foot {
  font-size: 13px;
  line-height: 1.45;
  color: #5a6570;
  margin: 12px 0 0;
}

.cr-mms-dyna-showcase .mms-dyna-card-text--light {
  color: rgba(255, 255, 255, 0.92);
}

.cr-mms-dyna-showcase .mms-dyna-checklist {
  margin: 0 0 14px;
  padding: 0;
}

.cr-mms-dyna-showcase .mms-dyna-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--font-size-body);
  color: #3d4a57;
  margin-bottom: 8px;
  line-height: 1.5;
}

.cr-mms-dyna-showcase .mms-dyna-checklist li:last-child {
  margin-bottom: 0;
}

.cr-mms-dyna-showcase .mms-dyna-check {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 4px;
  background: #263c50;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  margin-top: 3px;
}

.cr-mms-dyna-showcase .mms-dyna-learn-more {
  font-size: 14px;
  font-weight: 700;
  color: #b3002d;
  margin-top: auto;
}

/* Shared bento CTA row (_MmsDynaHardwareCardsStudy — MagTek btn-text + arrow; load magtek-buttons.css on DynaConnect) */
.cr-mms-dyna-showcase .mms-dyna-card-cta-row {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.cr-mms-dyna-showcase .mms-dyna-card-cta-btn.btn-text {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  font-size: 1.5rem !important;
  font-weight: var(--btn-font-weight, 700) !important;
  letter-spacing: 0.02em !important;
  padding-bottom: 0.2rem !important;
  white-space: nowrap !important;
  color: var(--magtek-red) !important;
  -webkit-font-smoothing: antialiased !important;
}

.cr-mms-dyna-showcase .mms-dyna-card-cta-btn.btn-text::after {
  background: var(--magtek-red) !important;
}

.cr-mms-dyna-showcase .mms-dyna-card-cta-arrow {
  position: absolute;
  left: 100%;
  top: 50%;
  margin-left: 0.35em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25em;
  height: 1.25em;
  color: var(--magtek-red);
  opacity: 1;
  transform: translateY(-50%) translateX(0);
  transition: opacity 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}

.cr-mms-dyna-showcase .mms-dyna-card-cta-arrow i {
  font-size: 1.05rem;
  line-height: 1;
  display: block;
  -webkit-font-smoothing: antialiased;
}

.cr-mms-dyna-showcase .mms-dyna-card-link:hover .mms-dyna-card-cta-arrow,
.cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible .mms-dyna-card-cta-arrow {
  opacity: 1;
  transform: translateY(-50%) translateX(3px);
  color: var(--magtek-red-dark);
}

.cr-mms-dyna-showcase .mms-dyna-card-link:hover .mms-dyna-card-cta-btn.btn-text::after,
.cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible .mms-dyna-card-cta-btn.btn-text::after {
  transform: scaleX(1) !important;
  transform-origin: left !important;
}

.cr-mms-dyna-showcase .mms-dyna-card-link:hover .mms-dyna-card-cta-btn.btn-text,
.cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible .mms-dyna-card-cta-btn.btn-text {
  color: var(--magtek-red-dark) !important;
}

.cr-mms-dyna-showcase .mms-dyna-card-actions--ped {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 1.25rem;
  padding-top: 0.25rem;
  width: 100%;
}

.cr-mms-dyna-showcase .mms-dyna-card-actions--scr {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(38, 60, 80, 0.08);
  width: 100%;
}

.cr-mms-dyna-showcase .mms-dyna-card-actions--stack {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: auto;
  padding-top: 1rem;
  width: 100%;
}

.cr-mms-dyna-showcase .mms-dyna-card--ped.mms-dyna-card-link {
  background: var(--cr-bento-card-bg-soft);
  border: 1px solid var(--cr-bento-border);
  box-shadow: var(--cr-bento-shadow);
}

.cr-mms-dyna-showcase .mms-dyna-card--ped .mms-dyna-card-img-wrap {
  margin-top: 0;
  text-align: center;
  padding-top: 8px;
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
}

.cr-mms-dyna-showcase .mms-dyna-card--ped .mms-dyna-card-img {
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(52vw, 440px);
  object-fit: contain;
  margin-left: auto;
  margin-right: auto;
  transition: transform 0.25s ease;
  transform-origin: 50% 80%;
}

.cr-mms-dyna-showcase .mms-dyna-card--scr.mms-dyna-card-link {
  background: var(--cr-bento-card-bg-soft);
  border: 1px solid var(--cr-bento-border);
  box-shadow: var(--cr-bento-shadow);
  padding: 24px 30px 22px;
}

.cr-mms-dyna-showcase .mms-dyna-card--scr-inner {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 20px;
  width: 100%;
  min-height: 140px;
}

.cr-mms-dyna-showcase .mms-dyna-card--scr-copy {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.cr-mms-dyna-showcase .mms-dyna-card--scr .mms-dyna-card-title {
  font-size: 2.2rem;
  margin-bottom: 0;
}

.cr-mms-dyna-showcase .mms-dyna-card--scr .mms-dyna-card-text {
  margin-bottom: 0;
  flex: 0 1 auto;
}

.cr-mms-dyna-showcase .mms-dyna-card-img-wrap--scr {
  flex-shrink: 0;
  width: 48%;
  max-width: 320px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 140px;
}

.cr-mms-dyna-showcase .mms-dyna-card-img-wrap--scr .mms-dyna-card-img {
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(28vw, 220px);
  object-fit: contain;
  margin: 0 auto;
  transition: transform 0.25s ease;
  transform-origin: 50% 70%;
}

.cr-mms-dyna-showcase .mms-dyna-card--go.mms-dyna-card-link {
  background: var(--cr-bento-card-bg-soft);
  border: 1px solid var(--cr-bento-border);
  box-shadow: var(--cr-bento-shadow);
  padding: 22px 20px 24px;
}

.cr-mms-dyna-showcase .mms-dyna-card--go .mms-dyna-card-title {
  font-size: var(--font-size-h4);
  margin-bottom: 10px;
}

.cr-mms-dyna-showcase .mms-dyna-card-img-wrap--go {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 168px;
  padding: 2px 0 8px;
}

.cr-mms-dyna-showcase .mms-dyna-card-img-wrap--go .mms-dyna-card-img {
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(36vw, 260px);
  object-fit: contain;
  transition: transform 0.25s ease;
  transform-origin: 50% 75%;
}

.cr-mms-dyna-showcase .mms-dyna-card--prox.mms-dyna-card-link {
  padding: 22px 20px 24px;
  background: var(--cr-bento-card-bg-soft);
  border: 1px solid var(--cr-bento-border);
  box-shadow: var(--cr-bento-shadow);
}

.cr-mms-dyna-showcase .mms-dyna-card--prox .mms-dyna-card-title {
  font-size: var(--font-size-h4);
  margin-bottom: 8px;
  color: #1e293b;
}

.cr-mms-dyna-showcase .mms-dyna-card--prox .mms-dyna-card-text {
  font-size: var(--font-size-body);
  line-height: 1.6;
  margin-bottom: 12px;
  color: #5a6570;
}

.cr-mms-dyna-showcase .mms-dyna-card-img-wrap--prox {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 168px;
  padding: 2px 0 8px;
}

.cr-mms-dyna-showcase .mms-dyna-card-img-wrap--prox .mms-dyna-card-img {
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(36vw, 260px);
  object-fit: contain;
  transition: transform 0.25s ease;
  transform-origin: 50% 75%;
}

.cr-mms-dyna-showcase .mms-dyna-card--go .mms-dyna-card-foot {
  margin-top: 0;
  margin-bottom: 0;
  padding-bottom: 1px;
  font-size: var(--font-size-body);
  line-height: 1.55;
  color: #475569;
}

.cr-mms-dyna-showcase .mms-dyna-card-img {
  filter: drop-shadow(0 6px 14px rgba(15, 23, 42, 0.08));
}

.cr-mms-dyna-showcase .mms-dyna-card-link:hover .mms-dyna-card-img,
.cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible .mms-dyna-card-img {
  transform: scale(1.012);
}

@media (max-width: 767px) {
  .cr-mms-dyna-showcase .mms-dyna-card-readers-section {
    padding: 32px 0 40px;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-half {
    margin-bottom: 16px;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-col--stack .mms-dyna-readers-subrow + .mms-dyna-readers-subrow {
    margin-top: 0;
  }

  .cr-mms-dyna-showcase .mms-dyna-card--scr-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-img-wrap--scr {
    width: 100%;
    max-width: none;
    align-self: center;
    min-height: 160px;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-img-wrap--scr .mms-dyna-card-img {
    max-height: min(58vw, 260px);
  }

  .cr-mms-dyna-showcase .mms-dyna-card--ped .mms-dyna-card-img-wrap {
    min-height: 200px;
  }

  .cr-mms-dyna-showcase .mms-dyna-card--ped .mms-dyna-card-img {
    max-height: min(88vw, 400px);
  }

  .cr-mms-dyna-showcase .mms-dyna-card-img-wrap--go .mms-dyna-card-img,
  .cr-mms-dyna-showcase .mms-dyna-card-img-wrap--prox .mms-dyna-card-img {
    max-height: min(55vw, 280px);
  }

  .cr-mms-dyna-showcase .mms-dyna-card--ped .mms-dyna-card-title {
    font-size: 2.6rem;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-readers-row > [class*="col-"] + [class*="col-"] {
    margin-top: 16px;
  }
}

@media (max-width: 480px) {
  .cr-mms-dyna-showcase .mms-dyna-readers-subrow .col-xs-6 {
    width: 100%;
    float: none;
  }

  .cr-mms-dyna-showcase .mms-dyna-readers-half {
    margin-bottom: 16px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cr-mms-dyna-showcase .mms-dyna-card-link,
  .cr-mms-dyna-showcase .mms-dyna-card-img,
  .cr-mms-dyna-showcase .mms-dyna-card-cta-btn,
  .cr-mms-dyna-showcase .mms-dyna-card-cta-arrow {
    transition: none !important;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-link:hover,
  .cr-mms-dyna-showcase .mms-dyna-card-link:focus {
    transform: none;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-link:hover .mms-dyna-card-img,
  .cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible .mms-dyna-card-img {
    transform: none;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-link:hover .mms-dyna-card-cta-arrow,
  .cr-mms-dyna-showcase .mms-dyna-card-link:focus-visible .mms-dyna-card-cta-arrow {
    opacity: 1;
    transform: translateY(-50%) translateX(3px);
  }

  .cr-mms-dyna-showcase .mms-dyna-card-link::before {
    transition: none;
  }
}

/* --- Injected product cards (Scripts/apis/hardware/card-readers/fetch-card-readers.js) --- */
.caption {
  flex-grow: 1 !important;
  min-height: 265px;
}

.caption ul li {
  margin-bottom: 5px !important;
}

.caption h3 {
  font-size: 2.2rem;
  font-weight: 700;
  margin-top: 14px;
  color: #1e293b;
  letter-spacing: -0.02em;
  line-height: 1.25;
  transition: color 0.2s ease;
}

.caption p {
  font-size: var(--font-size-body);
  font-weight: 400;
  color: #475569;
  margin: 6px 0 14px;
  line-height: 1.5;
}

.caption ul {
  text-align: left !important;
}

.caption.flex-grow-1 {
  min-height: 265px !important;
}

.product-card {
  position: relative;
  background-color: var(--cr-card-elevated-bg, #ffffff);
  border-radius: 12px;
  border: 1px solid var(--border-light, #e2e8f0);
  overflow: hidden;
  padding: 22px 22px 20px;
  transition:
    transform 0.22s ease,
    box-shadow 0.22s ease,
    border-color 0.22s ease,
    background-color 0.22s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  flex-grow: 1;
  text-align: left;
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 8px 24px rgba(15, 23, 42, 0.05);
}

.product-card-bootstrap-container {
  margin-bottom: 28px;
}

.product-card:hover {
  transform: translateY(-2px);
  box-shadow:
    0 14px 32px rgba(15, 23, 42, 0.07),
    0 0 0 1px rgba(38, 60, 80, 0.1);
  border-color: var(--border-light, #cbd5e1);
  background-color: var(--cr-card-elevated-bg, #ffffff);
}

@media (prefers-reduced-motion: reduce) {
  .product-card {
    transition:
      border-color 0.2s ease,
      box-shadow 0.2s ease;
  }

  .product-card:hover {
    transform: none;
  }

  .product-card .arrow-icon {
    transition: opacity 0.2s ease;
  }

  .product-card:hover .arrow-icon {
    transform: none;
  }
}

.product-card-link {
  text-decoration: none;
  color: inherit;
}

.image-wrapper {
  padding: 12px;
  background-color: #f8fafc;
  border-radius: 10px;
  border: 1px solid rgba(148, 163, 184, 0.2);
  display: flex;
  justify-content: center;
}

.image-wrapper img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
  min-height: 278px;
  max-height: 100px;
  transition: opacity 0.2s ease;
}

.product-card:hover .image-wrapper img {
  opacity: 0.9;
}

.product-card:hover .caption h3 {
  color: #263c50;
}

.product-card .arrow-icon {
  position: absolute;
  bottom: 16px;
  right: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  color: #475569;
  opacity: 0;
  transform: translate(4px, 0);
  transition:
    opacity 0.2s ease,
    transform 0.2s ease;
  pointer-events: none;
}

.product-card .arrow-icon i {
  font-size: 1.05rem;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
}

.product-card:hover .arrow-icon {
  opacity: 1;
  transform: translate(0, 0);
  color: #263c50;
}

.list-unstyled {
  padding: 0;
  list-style: none;
  margin-top: 10px;
}

.list-unstyled li {
  margin-bottom: 6px;
  font-size: var(--font-size-small);
  color: #334155;
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.4;
}

.glyphicon {
  font-size: var(--font-size-body);
  color: #263c50;
  opacity: 0.9;
}

#legacy-readers-section,
#oemMmsDynaSection {
  scroll-margin-top: 88px;
}

/* Legacy reader grids: injected .cr-catalog-card (fetch-card-readers.js); flex caption needs no min-height lock */
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .product-card .caption {
  min-height: 0 !important;
}

/*
 * Legacy catalog cards (fetch-card-readers.js): product art uses white backgrounds.
 * Entire card + media rail must stay #fff — global .image-wrapper uses gray and wins
 * in some orders; !important keeps tops from reading as a separate “gray tray.”
 */
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-legacy-catalog-grid.row {
  display: flex;
  flex-wrap: wrap;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-legacy-catalog-grid.row::before,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-legacy-catalog-grid.row::after {
  content: none !important;
  display: none !important;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-legacy-catalog-grid .cr-catalog-grid-card-col {
  float: none;
  display: flex;
  flex-direction: column;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  width: 100%;
  min-height: 100%;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card.product-card {
  background-color: #ffffff !important;
  border-color: rgba(38, 60, 80, 0.11);
  padding: 0;
  overflow: hidden;
  flex: 1 1 auto;
  width: 100%;
  min-height: 100%;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__media.image-wrapper,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card .image-wrapper {
  margin: 0;
  /* Uniform “stage” so mixed aspect ratios don’t make the row feel uneven */
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: clamp(168px, 26vw, 228px);
  height: clamp(168px, 26vw, 228px);
  padding: 12px clamp(12px, 3vw, 20px);
  background-color: #ffffff !important;
  background-image: none !important;
  border: none !important;
  border-bottom: 1px solid rgba(38, 60, 80, 0.06);
  border-radius: 0 !important;
  box-shadow: none !important;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__img {
  display: block;
  margin: 0 auto;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  min-height: 0;
  object-fit: contain;
  object-position: center;
  opacity: 1;
  filter: none;
  box-shadow: none;
  transition: opacity 0.2s ease;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .cr-catalog-card__img {
  opacity: 1;
  filter: none;
  transform: none;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .cr-catalog-card__img,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible .cr-catalog-card__img {
  filter: none;
  box-shadow: none;
  transform: none;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__body.caption {
  flex: 1 1 auto;
  min-height: 0 !important;
  padding: 20px 20px 16px;
  margin: 0;
  background-color: #ffffff !important;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__title {
  margin: 0 0 8px;
  font-size: clamp(1.75rem, 1.5vw + 1.4rem, 2.1rem);
  line-height: 1.22;
  letter-spacing: -0.02em;
  color: #0f172a;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-tagline {
  margin: 0 0 16px;
  font-size: var(--font-size-small);
  line-height: 1.5;
  font-weight: 600;
  font-style: normal;
  color: #475569;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-specs {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-specs .cr-catalog-card-spec {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 0;
  line-height: 1.5;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-spec__glyph {
  flex-shrink: 0;
  margin-top: 3px;
  font-size: var(--font-size-small);
  opacity: 0.92;
  color: #334155;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-spec__text {
  flex: 1 1 auto;
  min-width: 0;
  font-size: var(--font-size-body);
  color: #0f172a;
  font-weight: 500;
  overflow-wrap: anywhere;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: auto;
  padding: 16px 20px 18px;
  border-top: 1px solid rgba(38, 60, 80, 0.08);
  background-color: #ffffff !important;
}

/* Catalog card CTA: unified with MMS Dyna bento .mms-dyna-card-cta-btn.btn-text (magtek-buttons .btn-text) */
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__cta {
  position: relative;
  display: inline-block;
  max-width: calc(100% - 3rem);
  padding-bottom: 0.2rem;
  line-height: 1.6;
  text-decoration: none;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-size: 1.5rem;
  font-weight: var(--btn-font-weight, 700);
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--magtek-red, #d21242);
  -webkit-font-smoothing: antialiased;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__cta::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--magtek-red, #d21242);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.25s ease;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .cr-catalog-card__cta,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible .cr-catalog-card__cta {
  color: var(--magtek-red-dark, #b3002d);
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .cr-catalog-card__cta::after,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible .cr-catalog-card__cta::after {
  transform: scaleX(1);
  transform-origin: left;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__cta-chev {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background: rgba(210, 18, 66, 0.08);
  color: var(--magtek-red, #d21242);
  transition: transform 0.2s ease, background 0.2s ease;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__cta-chev i {
  font-size: 1.05rem;
  line-height: 1;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .cr-catalog-card__cta-chev,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible .cr-catalog-card__cta-chev {
  transform: translateX(3px);
  background: rgba(210, 18, 66, 0.14);
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .cr-catalog-card__title,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible .cr-catalog-card__title {
  color: #263c50;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible {
  outline: none;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible .cr-catalog-card {
  box-shadow:
    0 0 0 2px #fff,
    0 0 0 4px var(--magtek-red, #d21242),
    0 12px 32px rgba(15, 23, 42, 0.08);
}

@media (max-width: 767px) {
  :is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__cta {
    font-size: 1.4rem;
  }

  .cr-mms-dyna-showcase .mms-dyna-card-cta-btn.btn-text {
    font-size: 1.4rem !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  :is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__img,
  :is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__cta-chev,
  :is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card__cta::after {
    transition: none;
  }

  :is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .cr-catalog-card__cta-chev,
  :is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-visible .cr-catalog-card__cta-chev {
    transform: none;
  }
}

/* Legacy catalog subsections: shared MagTek section-header (matches MMS Dyna pattern) */
#products #legacy-readers-section .cr-legacy-catalog-subsection .section-header,
#products #oem-catalogs-section .cr-legacy-catalog-subsection .section-header {
  max-width: 720px;
}

/* Stacked legacy catalog subsections (MagneSafe → magstripe → keypads), full-width grids */
.cr-legacy-catalog-subsection + .cr-legacy-catalog-subsection {
  margin-top: var(--cr-page-divider-gap);
  padding-top: clamp(1.5rem, 3vw, 2.25rem);
  border-top: 1px solid rgba(38, 60, 80, 0.1);
}

.cr-legacy-catalog-grid {
  margin-left: -10px;
  margin-right: -10px;
}

.cr-legacy-catalog-grid::before,
.cr-legacy-catalog-grid::after {
  display: table;
  content: " ";
}

.cr-legacy-catalog-grid::after {
  clear: both;
}

.cr-catalog-grid-card-col {
  padding-left: 10px;
  padding-right: 10px;
  margin-bottom: 20px;
}

/* --- Dual catalog: MagneSafe + Magstripe (two columns, horizontal spec cards) --- */
/* Type: magtek-standardization --font-size-* + --cr-font-eyebrow / --cr-font-spec */
.cr-dual-catalog-band {
  --cr-dual-rail: 3px;
  padding: var(--cr-page-band-y) 0 clamp(2.25rem, 5vw, 3.75rem);
  /* magtek-standardization .section-bg-white — alternates with .section-bg-alt value bands (Services rhythm) */
  background: var(--cr-surface-white);
  border-top: 1px solid var(--cr-border-subtle);
  position: relative;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.cr-dual-catalog-row {
  margin-left: -12px;
  margin-right: -12px;
}

.cr-dual-catalog-row::before,
.cr-dual-catalog-row::after {
  display: table;
  content: " ";
}

.cr-dual-catalog-row::after {
  clear: both;
}

.cr-dual-catalog-col {
  padding-left: 14px;
  padding-right: 14px;
}

@media (min-width: 992px) {
  .cr-dual-catalog-col--magnesafe {
    border-right: 1px solid rgba(38, 60, 80, 0.1);
    padding-right: clamp(20px, 3vw, 36px);
  }

  .cr-dual-catalog-col--magstripe {
    padding-left: clamp(20px, 3vw, 36px);
  }
}

@media (max-width: 991px) {
  .cr-dual-catalog-col--magstripe {
    margin-top: 44px;
    padding-top: 36px;
    border-top: 1px solid rgba(38, 60, 80, 0.12);
  }
}

.cr-dual-catalog-header {
  margin-bottom: clamp(16px, 2vw, 24px);
  text-align: left;
}

.cr-dual-catalog-title {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 0 6px;
  font-size: clamp(1.8rem, 1.65vw, 2rem);
  font-weight: 700;
  color: #1e293b;
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.cr-dual-catalog-title__accent {
  flex-shrink: 0;
  width: var(--cr-dual-rail);
  min-height: 1.2em;
  margin-top: 0.18em;
  border-radius: 2px;
  background: linear-gradient(
    180deg,
    var(--magtek-red) 0%,
    var(--magtek-red-dark) 100%
  );
}

.cr-dual-catalog-title__text {
  flex: 1;
  min-width: 0;
}

.cr-dual-catalog-subtitle {
  font-size: var(--font-size-small);
  line-height: 1.45;
  color: var(--text-muted);
  margin: 0;
  padding-bottom: 2px;
  max-width: 34em;
  font-weight: 400;
}

/* Program context (MagneSafe column): faster glance than body copy alone */
.cr-dual-catalog-badge {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 0 0 8px;
  padding: 7px 10px;
  font-size: var(--font-size-small);
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: 0.01em;
  color: #334155;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(38, 60, 80, 0.1);
  border-radius: 6px;
  max-width: 36em;
}

.cr-dual-catalog-badge__dot {
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  margin-top: 5px;
  border-radius: 50%;
  background: linear-gradient(
    145deg,
    var(--magtek-red) 0%,
    var(--magtek-red-dark) 100%
  );
  box-shadow: 0 0 0 1px rgba(210, 18, 66, 0.2);
}

.cr-dual-catalog-card-col {
  margin-bottom: 20px;
}

.cr-dual-catalog-card-col:last-child {
  margin-bottom: 0;
}

.cr-dual-catalog-band .product-card-link--dual-catalog {
  display: block;
  cursor: pointer;
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
}

.cr-dual-catalog-band .product-card-link:focus-visible {
  outline: none;
}

.cr-dual-catalog-band
  .product-card-link:focus-visible
  .product-card--dual-catalog {
  box-shadow:
    0 0 0 2px #fff,
    0 0 0 4px var(--magtek-red),
    0 16px 36px rgba(38, 60, 80, 0.12);
}

.cr-dual-catalog-band .product-card--dual-catalog {
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  padding: 0;
  border-radius: 14px;
  font-size: var(--font-size-small);
  border-width: 1px;
  border-style: solid;
  box-shadow:
    0 1px 3px rgba(15, 23, 42, 0.05),
    0 14px 32px rgba(15, 23, 42, 0.065);
  transition:
    transform 0.22s ease,
    box-shadow 0.22s ease,
    border-color 0.22s ease,
    background-color 0.22s ease;
}

.cr-dual-catalog-band .product-card-dual__main {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 18px;
  padding: 18px 20px 16px;
  flex: 1 1 auto;
  min-height: 0;
}

.cr-dual-catalog-band .product-card-dual__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: auto;
  padding: 13px 20px 15px;
  border-top: 1px solid rgba(38, 60, 80, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.55) 0%, rgba(241, 245, 249, 0.95) 100%);
  border-radius: 0 0 13px 13px;
  /* Match magtek-buttons label stack so 700 reads true (body font can fake “thin” at small caps) */
  font-family:
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    sans-serif !important;
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.045em;
  text-transform: uppercase;
  color: #d21242 !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.cr-dual-catalog-band .product-card-dual__cta-text {
  font-weight: 700 !important;
  font-family: inherit !important;
  color: inherit !important;
}

.cr-dual-catalog-band .product-card-dual__cta-chev {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: rgba(210, 18, 66, 0.1);
  color: var(--magtek-red, #d21242);
  transition: transform 0.22s ease, background 0.22s ease;
}

.cr-dual-catalog-band .product-card-dual__cta-chev i {
  font-size: 0.9rem;
  line-height: 1;
}

.cr-dual-catalog-band
  .product-card-link--dual-catalog:hover
  .product-card--dual-catalog
  .product-card-dual__cta-text {
  text-decoration: underline;
  text-underline-offset: 0.14em;
}

.cr-dual-catalog-band
  .product-card-link--dual-catalog:hover
  .product-card--dual-catalog
  .product-card-dual__cta-chev {
  transform: translateX(4px);
  background: rgba(210, 18, 66, 0.16);
}

.cr-dual-catalog-band
  .product-card-link--dual-catalog:focus-visible
  .product-card--dual-catalog
  .product-card-dual__cta-text {
  text-decoration: underline;
  text-underline-offset: 0.14em;
}

.cr-dual-catalog-band
  .product-card-link--dual-catalog:focus-visible
  .product-card--dual-catalog
  .product-card-dual__cta-chev {
  transform: translateX(4px);
}

.cr-dual-catalog-band .caption,
.cr-dual-catalog-band .caption.flex-grow-1 {
  flex-grow: 1 !important;
  min-height: 0 !important;
}

.cr-dual-catalog-band .product-card--dual-catalog .caption h3 {
  margin-top: 0;
  margin-bottom: 3px;
  font-size: clamp(1.8rem, 1.75vw, 2rem);
  font-weight: 700;
  color: #0f172a;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.cr-dual-catalog-band .product-card-tagline {
  font-size: var(--font-size-small);
  font-style: italic;
  font-weight: 400;
  color: #475569;
  margin: 0 0 10px !important;
  line-height: 1.45;
}

.cr-dual-catalog-band .product-card-tagline__q {
  color: #94a3b8;
}

/* Specs: soft panel — lighter edge so the open image rail stays the hero */
.cr-dual-catalog-band .product-card-spec-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: 0;
  row-gap: 6px;
  align-items: start;
  margin: 12px 0 0 !important;
  padding: 12px 14px 11px;
  border-top: none;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(38, 60, 80, 0.07);
  border-radius: 11px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.035);
  text-align: left !important;
}

.cr-dual-catalog-band .product-card-spec-cell {
  margin: 0;
  min-width: 0;
  padding: 0 12px;
  background: none;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

/* Light vertical rules between OS | Entry | Connectivity only */
.cr-dual-catalog-band
  .product-card-spec-grid
  > .product-card-spec-cell:nth-child(3n + 1),
.cr-dual-catalog-band
  .product-card-spec-grid
  > .product-card-spec-cell:nth-child(3n + 2) {
  border-right: 1px solid rgba(38, 60, 80, 0.09);
}

.cr-dual-catalog-band .product-card-spec-cell dt.product-card-spec-label {
  margin: 0;
}

.cr-dual-catalog-band .product-card-spec-cell dd.product-card-spec-value {
  margin: 0;
}

.cr-dual-catalog-band .product-card-spec-grid > .product-card-spec-cell--full {
  grid-column: 1 / -1;
  padding: 8px 0 0;
  margin-top: 4px;
  border-top: 1px solid rgba(38, 60, 80, 0.07);
  border-right: none !important;
}

.cr-dual-catalog-band .product-card-spec-label {
  display: block;
  font-size: var(--cr-font-eyebrow);
  font-weight: 700;
  letter-spacing: 0.055em;
  text-transform: uppercase;
  color: #64748b;
  margin-bottom: 3px;
  line-height: 1.25;
}

.cr-dual-catalog-band .product-card-spec-value {
  display: block;
  font-size: var(--cr-font-spec);
  color: #1e293b;
  line-height: 1.42;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  hyphens: auto;
  overflow-wrap: anywhere;
}

/* Product image — compact left rail (small thumbnail, more room for copy) */
.cr-dual-catalog-band .product-card--dual-catalog .image-wrapper {
  flex: 0 0 32%;
  width: 32%;
  min-width: 96px;
  max-width: min(36%, 200px);
  padding: 0 !important;
  margin: 0;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: none !important;
}

.cr-dual-catalog-band .product-card--dual-catalog .image-wrapper img {
  min-height: 0;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: clamp(72px, 16vw, 130px);
  object-fit: contain;
  object-position: center;
  filter: drop-shadow(0 3px 10px rgba(15, 23, 42, 0.12));
  transition: filter 0.22s ease, transform 0.22s ease;
}

@media (min-width: 992px) {
  .cr-dual-catalog-band .product-card--dual-catalog .image-wrapper {
    flex-basis: 30%;
    width: 30%;
    max-width: min(34%, 220px);
  }

  .cr-dual-catalog-band .product-card--dual-catalog .image-wrapper img {
    max-height: clamp(88px, 11vw, 150px);
  }
}

.cr-dual-catalog-band
  .product-card-link--dual-catalog:hover
  .product-card--dual-catalog
  .image-wrapper
  img {
  filter: drop-shadow(0 5px 14px rgba(15, 23, 42, 0.16));
  transform: translateY(-1px);
}

/* OEM page: side-by-side columns still use .cr-dual-catalog-col + .cr-dual-catalog-card-col */
.cr-dual-catalog-col--magnesafe
  .cr-dual-catalog-card-col:nth-child(odd)
  .product-card {
  background-color: var(--cr-card-stripe-a);
  border-color: var(--cr-card-elevated-border);
}

.cr-dual-catalog-col--magnesafe
  .cr-dual-catalog-card-col:nth-child(even)
  .product-card {
  background-color: var(--cr-card-stripe-b);
  border-color: var(--cr-card-elevated-border);
}

.cr-dual-catalog-col--magstripe
  .cr-dual-catalog-card-col:nth-child(odd)
  .product-card {
  background-color: var(--cr-card-stripe-a);
  border-color: var(--cr-card-elevated-border);
}

.cr-dual-catalog-col--magstripe
  .cr-dual-catalog-card-col:nth-child(even)
  .product-card {
  background-color: var(--cr-card-stripe-b);
  border-color: var(--cr-card-elevated-border);
}

/* Injected legacy catalog cards (fetch-card-readers.js / fetch-oem-components.js): always white; striping removed — was overridden anyway */
:is(#legacy-readers-section, #oem-catalogs-section, #check-scanners-catalog-section, #instant-issuance-catalog-section)
  .cr-legacy-catalog-subsection
  .cr-catalog-grid-card-col
  .product-card.cr-catalog-card {
  background-color: var(--cr-card-elevated-bg) !important;
  border-color: var(--cr-card-elevated-border) !important;
}

:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:hover .product-card.cr-catalog-card,
:is(#legacy-readers-section, #oemMmsDynaSection, #oem-catalogs-section, #oem-insertion-section, #check-scanners-catalog-section, #instant-issuance-catalog-section) .cr-catalog-card-link:focus-within .product-card.cr-catalog-card {
  background-color: var(--cr-card-elevated-bg) !important;
}

.cr-dual-catalog-band
  .product-card-link--dual-catalog:hover
  .product-card--dual-catalog {
  background-color: var(--cr-card-elevated-bg);
  border-color: rgba(38, 60, 80, 0.18);
  transform: translateY(-3px);
  box-shadow:
    0 16px 36px rgba(15, 23, 42, 0.1),
    0 0 0 1px rgba(38, 60, 80, 0.08);
}

.cr-dual-catalog-band
  .product-card-link:focus-within
  .product-card--dual-catalog {
  border-color: rgba(38, 60, 80, 0.18);
  background-color: var(--cr-card-elevated-bg);
  transform: translateY(-2px);
  box-shadow:
    0 14px 32px rgba(15, 23, 42, 0.09),
    0 0 0 1px rgba(38, 60, 80, 0.1);
}

@media (max-width: 520px) {
  .cr-dual-catalog-band .product-card-spec-grid {
    grid-template-columns: 1fr;
    row-gap: 0;
    padding-top: 10px;
  }

  .cr-dual-catalog-band .product-card-spec-grid > .product-card-spec-cell {
    padding: 10px 0;
    border-right: none !important;
    border-bottom: 1px solid rgba(38, 60, 80, 0.09);
  }

  .cr-dual-catalog-band
    .product-card-spec-grid
    > .product-card-spec-cell:last-child {
    border-bottom: none;
    padding-bottom: 2px;
  }

  .cr-dual-catalog-band .product-card-spec-cell--full {
    grid-column: 1;
    margin-top: 0;
    padding-top: 10px;
    border-top: none;
  }
}

@media (max-width: 767px) {
  .cr-dual-catalog-band .product-card-dual__main {
    flex-direction: column;
    align-items: stretch;
    padding: 16px 16px 14px;
  }

  .cr-dual-catalog-band .product-card-dual__footer {
    padding: 12px 16px 14px;
  }

  .cr-dual-catalog-band .product-card--dual-catalog .image-wrapper {
    flex: 0 0 auto;
    width: 100%;
    max-width: none;
    text-align: center;
    padding: 4px 0 10px;
    align-self: stretch;
  }

  .cr-dual-catalog-band .product-card--dual-catalog .image-wrapper img {
    max-height: min(140px, 38vw);
  }

  .cr-dual-catalog-title {
    font-size: clamp(1.7rem, 3.6vw, 2rem);
  }

  .cr-dual-catalog-subtitle {
    font-size: var(--font-size-small);
    line-height: 1.45;
  }

  .cr-dual-catalog-band .product-card--dual-catalog .caption h3 {
    font-size: clamp(1.9rem, 3.7vw, 2.2rem);
  }

  .cr-dual-catalog-band .product-card-tagline {
    font-size: var(--font-size-small);
  }

  .cr-dual-catalog-band .product-card-spec-label {
    font-size: var(--font-size-small);
  }

  .cr-dual-catalog-band .product-card-spec-value {
    font-size: var(--font-size-body);
  }
}

@media (prefers-reduced-motion: reduce) {
  .cr-dual-catalog-band .product-card--dual-catalog,
  .cr-dual-catalog-band .product-card-dual__cta-chev,
  .cr-dual-catalog-band .product-card--dual-catalog .image-wrapper img {
    transition:
      border-color 0.2s ease,
      box-shadow 0.2s ease,
      background-color 0.2s ease,
      filter 0.2s ease;
  }

  .cr-dual-catalog-band
    .product-card-link--dual-catalog:hover
    .product-card--dual-catalog,
  .cr-dual-catalog-band
    .product-card-link:focus-within
    .product-card--dual-catalog {
    transform: none;
  }

  .cr-dual-catalog-band
    .product-card-link--dual-catalog:hover
    .product-card--dual-catalog
    .product-card-dual__cta-chev,
  .cr-dual-catalog-band
    .product-card-link--dual-catalog:focus-visible
    .product-card--dual-catalog
    .product-card-dual__cta-chev {
    transform: none;
  }

  .cr-dual-catalog-band
    .product-card-link--dual-catalog:hover
    .product-card--dual-catalog
    .image-wrapper
    img {
    transform: none;
  }
}

/* Card Readers: same value-band shell as Check Scanners / Instant Issuance; video row replaces cards. */
#products.card-readers-page .cr-value-band--with-kernel-showcase .cr-one-kernel-block.video-showcase-section--one-kernel {
  padding: 0;
  border-top: 0;
  background: transparent;
}

/* Default One Kernel surface for other placements (e.g. Tap to Pay variant). */
.cr-one-kernel-block.video-showcase-section--one-kernel {
  padding: var(--cr-page-band-y) 0 clamp(3.6rem, 6.5vw, 5.5rem);
  background: var(--cr-surface-alt);
  border-top: 1px solid var(--cr-border-subtle);
  position: relative;
  overflow: hidden;
}

/* services-page.css .section-bg-alt::before — nested in Card Readers value band uses transparent bg; no double fade */
.cr-one-kernel-block.video-showcase-section--one-kernel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: var(--cr-section-alt-top-fade-height);
  background: var(--cr-section-alt-top-fade);
  pointer-events: none;
  z-index: 0;
}

#products.card-readers-page .cr-value-band--with-kernel-showcase .cr-one-kernel-block.video-showcase-section--one-kernel::before {
  content: none;
}

/* Tap to Pay band: same section-bg-alt shell as One Kernel (Services DNA) */
.cr-one-kernel-block--ttp.video-showcase-section--one-kernel {
  background: var(--cr-surface-alt);
}

.cr-one-kernel-block.video-showcase-section--one-kernel > .container {
  position: relative;
  z-index: 1;
}

@media (min-width: 992px) {
  .one-kernel-split-row--ttp .one-kernel-split-col--copy {
    padding-left: 0;
    padding-right: 16px;
  }

  .one-kernel-split-row--ttp .one-kernel-split-col--player {
    padding-left: 16px;
    padding-right: 0;
  }
}

@media (max-width: 991px) {
  .one-kernel-split-row--ttp .one-kernel-split-col--player {
    margin-top: 28px;
  }
}

.one-kernel-split-row {
  margin-left: -20px;
  margin-right: -20px;
}

.one-kernel-split-row > [class*="col-"] {
  padding-left: 20px;
  padding-right: 20px;
}

@media (min-width: 992px) {
  .one-kernel-split-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }

  .one-kernel-split-row > .one-kernel-split-col {
    float: none;
  }
}

.one-kernel-player-shell {
  position: relative;
}

.one-kernel-player-frame {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  height: 0;
  border-radius: 16px;
  box-shadow:
    0 4px 6px -1px rgba(38, 60, 80, 0.06),
    0 22px 44px -12px rgba(38, 60, 80, 0.18),
    0 0 0 1px rgba(38, 60, 80, 0.07);
  overflow: hidden;
}

.one-kernel-player {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  border-radius: 16px;
  text-align: left;
  transition:
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.3s ease;
}

.one-kernel-player:hover,
.one-kernel-player:focus {
  outline: none;
  transform: scale(1.008);
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.14);
}

.one-kernel-player:focus-visible {
  outline: 3px solid #263c50;
  outline-offset: 4px;
  box-shadow: inset 0 0 0 2px rgba(var(--cr-accent-red-rgb), 0.35);
}

.one-kernel-player-bg {
  position: absolute;
  inset: 0;
  background-color: #1b2838;
  background-image:
    linear-gradient(
      155deg,
      #263c50 0%,
      rgba(38, 60, 80, 0.95) 38%,
      #1a2430 78%,
      #141c26 100%
    ),
    radial-gradient(ellipse 90% 70% at 80% 20%, rgba(210, 18, 66, 0.09) 0%, transparent 55%),
    repeating-linear-gradient(
      -11deg,
      transparent,
      transparent 2px,
      rgba(255, 255, 255, 0.025) 2px,
      rgba(255, 255, 255, 0.025) 3px
    );
}

.one-kernel-play-circle {
  position: absolute;
  top: 42%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 82px;
  height: 82px;
  border-radius: 50%;
  background: var(--cr-card-icon-well-bg, linear-gradient(145deg, #ffffff 0%, #f1f5f9 100%));
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(255, 255, 255, 0.35) inset;
  transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

.one-kernel-player:hover .one-kernel-play-circle,
.one-kernel-player:focus .one-kernel-play-circle {
  transform: translate(-50%, -50%) scale(1.07);
}

.one-kernel-play-triangle {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12px 0 12px 20px;
  border-color: transparent transparent transparent var(--magtek-red, #d21242);
  margin-left: 6px;
}

/* MMS Dyna overview — YouTube launcher poster (#videoModalDyna) */
.one-kernel-player-bg.cr-mms-dyna-poster-bg {
  background-color: #1b2838;
  background-image:
    linear-gradient(180deg, rgba(27, 40, 56, 0.28) 0%, rgba(20, 28, 38, 0.72) 100%),
    url("/Content/images/dyna-devices-thumb.jpg");
  background-size: cover;
  background-position: center;
}

/* Tap to Pay — poster launcher opens HD MP4 in modal (#videoModalTapToPay) */
.one-kernel-player-bg.cr-ttp-poster-bg {
  background-color: #0f172a;
  background-image:
    linear-gradient(180deg, rgba(15, 23, 42, 0.35) 0%, rgba(15, 23, 42, 0.72) 100%),
    url("/Content/images/toptopayimage.png");
  background-size: cover;
  background-position: center;
}

.cr-one-kernel-block--ttp .cr-ttp-more.btn-text {
  white-space: normal !important;
  max-width: 100%;
  line-height: 1.45 !important;
  text-align: left;
}

.cr-one-kernel-block--ttp .cr-ttp-more.btn-text i {
  margin-left: 0.35em;
  font-size: 0.9em;
  vertical-align: -0.05em;
}

/* Copy column — panel like Services content blocks */
.one-kernel-split-col--copy {
  padding-top: 8px;
}

@media (min-width: 992px) {
  .one-kernel-split-col--copy {
    padding-top: 0;
    padding-left: 12px;
  }
}

.cr-one-kernel-copy {
  position: relative;
  padding: 28px 28px 30px;
  border-radius: 16px;
  background: linear-gradient(
    165deg,
    var(--cr-card-elevated-bg, #ffffff) 0%,
    #f8fafc 100%
  );
  border: 1px solid var(--cr-card-elevated-border, var(--cr-border-subtle));
  box-shadow:
    0 2px 4px -1px rgba(38, 60, 80, 0.04),
    0 14px 32px -14px rgba(38, 60, 80, 0.1);
}

.cr-one-kernel-copy::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: linear-gradient(180deg, var(--magtek-red, #d21242), var(--cr-accent-red-deep));
  opacity: 0.92;
  pointer-events: none;
}

.one-kernel-heading {
  font-size: clamp(2.8rem, 4vw, var(--font-size-h1));
  font-weight: 700;
  color: #263c50;
  margin: 0 0 4px;
  line-height: 1.12;
  letter-spacing: -0.03em;
}

.one-kernel-subheading {
  font-size: clamp(2.4rem, 3.4vw, 3.6rem);
  font-weight: 700;
  color: var(--magtek-red, #d21242);
  margin: 0 0 18px;
  line-height: 1.15;
  border: none;
  padding: 0;
  letter-spacing: -0.025em;
}

.one-kernel-body {
  font-size: var(--font-size-body);
  line-height: 1.68;
  color: rgba(38, 60, 80, 0.75);
  margin: 0 0 24px;
  max-width: 48ch;
}

.cr-one-kernel-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 0 0 22px;
}

.cr-one-kernel-metric {
  padding: 18px 16px 16px;
  border-radius: 12px;
  background: var(--cr-card-elevated-bg, #fff);
  border: 1px solid var(--cr-card-elevated-border, var(--cr-border-subtle));
  border-left: 3px solid var(--cr-accent-red);
  box-shadow: 0 1px 2px rgba(38, 60, 80, 0.04);
}

.cr-one-kernel-metric-value {
  font-size: clamp(3rem, 4.5vw, 3.85rem);
  font-weight: 700;
  color: #263c50;
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -0.03em;
}

.cr-one-kernel-metric-label {
  font-size: var(--cr-font-eyebrow);
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(38, 60, 80, 0.52);
  line-height: 1.35;
}

/* Card Readers: two-line metric stack (primary / secondary) */
#products.card-readers-page .cr-one-kernel-metric-value {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.4rem;
  margin-bottom: 0;
  text-transform: none;
  letter-spacing: 0;
}

#products.card-readers-page .cr-one-kernel-metric-line--primary {
  font-size: clamp(1.55rem, 2.65vw, 2.05rem);
  font-weight: 700;
  color: #263c50;
  line-height: 1.08;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

#products.card-readers-page .cr-one-kernel-metric-line--secondary {
  font-size: clamp(0.88rem, 1.4vw, 1.05rem);
  font-weight: 600;
  color: rgba(38, 60, 80, 0.72);
  line-height: 1.35;
  text-transform: none;
  letter-spacing: 0.02em;
}

#products.card-readers-page .cr-one-kernel-block--ttp .cr-ttp-terms {
  font-style: italic;
  color: rgba(38, 60, 80, 0.65);
  white-space: nowrap;
}

.cr-one-kernel-cta {
  padding-top: 16px;
  border-top: 1px solid var(--cr-border-subtle);
}

/* Uses magtek-buttons .btn-text; icon aligns with link style */
#products .cr-one-kernel-block .cr-one-kernel-sdk-btn.btn-text {
  font-size: 1.72rem !important;
}

#products .cr-one-kernel-block .cr-one-kernel-sdk-btn i {
  font-size: 1.12em;
  opacity: 0.95;
}

@media (max-width: 767px) {
  #products .cr-one-kernel-block .cr-one-kernel-sdk-btn.btn-text {
    font-size: 1.56rem !important;
  }
}

@media (max-width: 991px) {
  .cr-one-kernel-block.video-showcase-section--one-kernel {
    padding: 48px 0 56px;
  }

  .one-kernel-split-col--player {
    margin-bottom: 8px;
  }

  .cr-one-kernel-copy {
    padding: 22px 20px 24px;
  }
}

@media (max-width: 480px) {
  .cr-one-kernel-metrics {
    grid-template-columns: 1fr;
  }

  .one-kernel-play-circle {
    width: 72px;
    height: 72px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .one-kernel-player:hover,
  .one-kernel-player:focus {
    transform: none;
  }

  .one-kernel-player:hover .one-kernel-play-circle,
  .one-kernel-player:focus .one-kernel-play-circle {
    transform: translate(-50%, -50%);
  }
}

/* --- Dyna / L3 video modal (CardReaders #videoModalDyna, Bootstrap 3) --- */
.cr-dyna-video-modal .modal-dialog.cr-dyna-video-modal__dialog {
  margin-top: 48px;
  width: auto;
  max-width: min(920px, calc(100vw - 24px));
}

.cr-dyna-video-modal .modal-content.cr-dyna-video-modal__content {
  border: none;
  border-radius: 16px;
  overflow: hidden;
  box-shadow:
    0 25px 50px -12px rgba(15, 23, 42, 0.45),
    0 0 0 1px rgba(38, 60, 80, 0.1);
  background: #fff;
}

.cr-dyna-video-modal .modal-header.cr-dyna-video-modal__header {
  position: relative;
  border-bottom: 1px solid rgba(38, 60, 80, 0.09) !important;
  padding: 20px 52px 18px 24px !important;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
}

.cr-dyna-video-modal .modal-header.cr-dyna-video-modal__header::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(
    90deg,
    var(--magtek-red-dark, #b01035) 0%,
    var(--magtek-red, #d21242) 42%,
    rgba(210, 18, 66, 0.65) 100%
  );
  pointer-events: none;
}

.cr-dyna-video-modal .modal-title.cr-dyna-video-modal__title {
  margin: 0;
  font-size: clamp(1.6rem, 2.5vw, 2rem);
  font-weight: 700;
  color: #263c50;
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.cr-dyna-video-modal .close.cr-dyna-video-modal__close {
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  float: none;
  opacity: 1 !important;
  width: 40px;
  height: 40px;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 10px;
  font-size: 22px;
  font-weight: 300;
  line-height: 1;
  color: rgba(38, 60, 80, 0.5) !important;
  text-shadow: none !important;
  background: rgba(38, 60, 80, 0.07) !important;
  border: none !important;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, color 0.2s ease;
}

.cr-dyna-video-modal .close.cr-dyna-video-modal__close:hover,
.cr-dyna-video-modal .close.cr-dyna-video-modal__close:focus {
  color: #263c50 !important;
  background: rgba(38, 60, 80, 0.12) !important;
  opacity: 1 !important;
}

.cr-dyna-video-modal .modal-body.cr-dyna-video-modal__body {
  padding: 0 !important;
  background: #0f172a;
}

.cr-dyna-video-modal .cr-dyna-video-modal__embed {
  margin: 0;
  border-radius: 0;
}

.cr-dyna-video-modal .cr-dyna-video-modal__embed .embed-responsive-item {
  border: 0;
}

/* Tap to Pay video modal — native <video> (HD MP4) */
.cr-tap-video-modal .cr-tap-video-modal__body {
  background: #0a0f18;
}

.cr-tap-video-modal .cr-tap-video-modal__video {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
  max-height: min(72vh, 680px);
  background: #000;
}

.cr-tap-video-modal .cr-dyna-video-modal__title .cr-tap-video-modal__subtitle {
  font-weight: 600;
  font-size: 0.88em;
  color: rgba(38, 60, 80, 0.48);
}

@media (max-width: 767px) {
  .cr-tap-video-modal .cr-tap-video-modal__video {
    max-height: 56vh;
  }

  .cr-dyna-video-modal .modal-dialog.cr-dyna-video-modal__dialog {
    margin: 12px 10px 12px;
  }

  .cr-dyna-video-modal .modal-header.cr-dyna-video-modal__header {
    padding: 18px 46px 14px 18px !important;
  }

  .cr-dyna-video-modal .close.cr-dyna-video-modal__close {
    right: 10px;
    width: 36px;
    height: 36px;
    font-size: 20px;
  }
}

/* --- DynaCast / Tap to Pay / OEM promos --- */
.cr-split-promo {
  padding: 56px 0;
  scroll-margin-top: 88px;
}

.cr-split-promo--dynacast {
  background: var(--cr-surface-alt);
  padding-top: 56px;
  padding-bottom: 56px;
  border-top: 1px solid var(--cr-border-subtle);
  position: relative;
  overflow: hidden;
}

.cr-split-promo--dynacast::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: var(--cr-section-alt-top-fade-height);
  background: var(--cr-section-alt-top-fade);
  pointer-events: none;
  z-index: 0;
}

.cr-split-promo--dynacast > .container {
  position: relative;
  z-index: 1;
}

.cr-dynacast-panel {
  background: linear-gradient(180deg, #243548 0%, #1a2634 52%, #141c28 100%);
  border-radius: 16px;
  padding: 40px 36px 40px 40px;
  box-shadow:
    0 16px 48px rgba(15, 23, 42, 0.2),
    0 0 0 1px rgba(255, 255, 255, 0.06);
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-top: 3px solid var(--cr-accent-red);
}

.cr-dynacast-row {
  margin-left: -16px;
  margin-right: -16px;
}

.cr-dynacast-row > [class*="col-"] {
  padding-left: 16px;
  padding-right: 16px;
}

@media (min-width: 992px) {
  .cr-dynacast-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }

  .cr-dynacast-row > .cr-dynacast-col {
    float: none;
  }
}

.cr-dynacast-title {
  color: #fff;
  font-size: clamp(2rem, 2.5vw, 2.8rem);
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 16px;
  letter-spacing: -0.02em;
}

.cr-dynacast-lead {
  color: rgba(255, 255, 255, 0.82);
  font-size: var(--font-size-body);
  line-height: 1.65;
  margin: 0 0 28px;
  max-width: 520px;
}

/* MagTek standardized .btn-primary / .btn-secondary (magtek-buttons.css) */
.cr-dynacast-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 1rem 1.25rem;
}

.cr-dynacast-actions .btn:focus-visible {
  outline-offset: 3px;
}

.cr-dynacast-device-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 220px;
  padding: 12px 8px 8px;
}

.cr-dynacast-device-img {
  max-height: 320px;
  width: auto;
  max-width: 100%;
  margin: 0 auto;
  filter: drop-shadow(0 16px 40px rgba(0, 0, 0, 0.55));
  opacity: 0.95;
}

@media (max-width: 991px) {
  .cr-dynacast-panel {
    padding: 32px 24px 28px;
    border-radius: 14px;
  }

  .cr-dynacast-title {
    font-size: var(--font-size-large);
  }

  .cr-dynacast-col--visual {
    margin-top: 28px;
  }

  .cr-dynacast-device-img {
    max-height: 260px;
  }
}

.cr-split-promo--oem {
  background: var(--cr-surface-alt);
  padding-top: 56px;
  padding-bottom: 64px;
  border-top: 1px solid var(--cr-border-subtle);
  position: relative;
  overflow: hidden;
}

.cr-split-promo--oem::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: var(--cr-section-alt-top-fade-height);
  background: var(--cr-section-alt-top-fade);
  pointer-events: none;
  z-index: 0;
}

.cr-split-promo--oem > .container {
  position: relative;
  z-index: 1;
}

.cr-oem-panel {
  background: linear-gradient(
    180deg,
    var(--cr-card-elevated-bg, #ffffff) 0%,
    #f8fafc 100%
  );
  border-radius: 18px;
  padding: 36px 32px 36px 36px;
  box-shadow:
    0 16px 44px rgba(15, 23, 42, 0.08),
    0 0 0 1px var(--cr-card-elevated-border, rgba(38, 60, 80, 0.08));
  overflow: hidden;
  border: 1px solid var(--border-light, #e2e8f0);
  position: relative;
}

.cr-oem-panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--cr-accent-red) 0%, #2f4a64 100%);
}

.cr-oem-row {
  margin-left: -16px;
  margin-right: -16px;
}

.cr-oem-row > [class*="col-"] {
  padding-left: 16px;
  padding-right: 16px;
}

@media (min-width: 992px) {
  .cr-oem-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }

  .cr-oem-row > .cr-oem-col {
    float: none;
  }
}

.cr-oem-eyebrow {
  font-size: var(--cr-font-eyebrow);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #64748b;
  margin: 0 0 12px;
  padding-left: 12px;
  border-left: 3px solid var(--cr-accent-red);
}

.cr-oem-title {
  font-size: clamp(1.8rem, 2.2vw, 2rem);
  font-weight: 700;
  color: #1e293b;
  line-height: 1.22;
  margin: 0 0 16px;
  letter-spacing: -0.02em;
}

.cr-oem-lead {
  font-size: var(--font-size-body);
  line-height: 1.65;
  color: #475569;
  margin: 0 0 22px;
  max-width: 540px;
}

.cr-oem-points {
  margin: 0 0 26px;
  padding: 0;
}

.cr-oem-points li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: var(--font-size-body);
  line-height: 1.45;
  color: #334155;
  margin-bottom: 12px;
}

.cr-oem-points li:last-child {
  margin-bottom: 0;
}

.cr-oem-point-icon {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 4px;
  background: rgba(38, 60, 80, 0.08);
  color: #263c50;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  margin-top: 2px;
}

/* MagTek .btn-primary */
.cr-oem-cta i {
  font-size: 0.92em;
  opacity: 0.95;
}

.cr-oem-cta.cr-oem-cta--text {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.cr-oem-cta.cr-oem-cta--text i {
  transition: transform 160ms ease;
}

.cr-oem-cta.cr-oem-cta--text:hover i,
.cr-oem-cta.cr-oem-cta--text:focus i {
  transform: translateX(2px);
}

.cr-oem-img-wrap {
  border-radius: 12px;
  overflow: hidden;
  box-shadow:
    0 14px 38px rgba(15, 23, 42, 0.1),
    0 0 0 1px rgba(38, 60, 80, 0.08);
  background: #f8fafc;
  line-height: 0;
}

.cr-oem-img {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 991px) {
  .cr-split-promo--oem {
    padding-top: 40px;
    padding-bottom: 52px;
  }

  .cr-oem-panel {
    padding: 28px 22px 26px;
    border-radius: 14px;
  }

  .cr-oem-title {
    font-size: var(--font-size-h4);
  }

  .cr-oem-col--visual {
    margin-top: 28px;
  }
}

/* --- MMS Dyna + One Kernel wrapper band (matches Services first content: section-bg-white) --- */
.card-readers-dyna-band {
  background: var(--cr-surface-white);
  position: relative;
  overflow: hidden;
}

/* --- Bottom CTA (Views/Shared/Catalog/_CategoryCta.cshtml + _MagTekCtaButtons + magtek-buttons.css) --- */
.catalog-cta-band {
  position: relative;
  margin-top: clamp(3rem, 6vw, 5rem);
  margin-bottom: 0;
  padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(3rem, 6vw, 4.5rem);
  overflow: hidden;
  background: var(--cr-surface-alt);
}

/* services-page.css .section-bg-alt::before (accent rail keeps ::before) */
.catalog-cta-band::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: var(--cr-section-alt-top-fade-height);
  background: var(--cr-section-alt-top-fade);
  pointer-events: none;
  z-index: 0;
}

.catalog-cta-band::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 4px;
  background: linear-gradient(
    90deg,
    var(--cr-accent-red) 0%,
    rgba(var(--cr-accent-red-rgb), 0.38) 28%,
    rgba(38, 60, 80, 0.2) 100%
  );
  pointer-events: none;
  z-index: 1;
}

.catalog-cta-band__container {
  position: relative;
  z-index: 2;
}

.catalog-cta-band__panel {
  position: relative;
  max-width: 920px;
  margin: 0 auto;
  border-radius: 18px;
  background: #ffffff;
  box-shadow:
    0 24px 48px rgba(38, 60, 80, 0.1),
    0 0 0 1px rgba(38, 60, 80, 0.07);
  overflow: hidden;
}

.catalog-cta-band__accent {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 5px;
  background: linear-gradient(
    180deg,
    var(--cr-accent-red) 0%,
    var(--cr-accent-red-deep) 50%,
    #263c50 100%
  );
}

.catalog-cta-band__body {
  padding: clamp(2rem, 4vw, 3rem) clamp(1.5rem, 4vw, 3rem)
    clamp(2.25rem, 4vw, 3.25rem);
  padding-left: clamp(2rem, 4vw, 3.25rem);
  text-align: center;
}

.catalog-cta-band__title {
  margin: 0 0 1rem;
  font-weight: 700;
  font-size: clamp(2.4rem, 2.8vw, var(--font-size-h2));
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #1e293b;
}

.catalog-cta-band__lede {
  margin: 0 auto 0.25rem;
  max-width: 44rem;
  font-size: clamp(var(--font-size-small), 1.35vw, var(--font-size-body));
  line-height: 1.65;
  font-weight: 400;
  color: var(--gray-600);
}

.catalog-cta-band .section-cta-buttons {
  margin-top: 1.75rem;
  margin-bottom: 0;
  padding: 0;
  display: flex;
  gap: 1rem 1.25rem;
  justify-content: center;
  flex-wrap: wrap;
}

@media (max-width: 576px) {
  .catalog-cta-band .section-cta-buttons {
    flex-direction: column;
    align-items: stretch;
  }

  .catalog-cta-band .section-cta-buttons .btn-primary,
  .catalog-cta-band .section-cta-buttons .btn-secondary {
    width: 100%;
    justify-content: center;
  }

  .product-card {
    padding: 1rem;
  }

  .product-card-bootstrap-container a {
    width: 100%;
  }

  .image-wrapper {
    padding: 0;
    display: flex;
    justify-content: center;
  }
}

/* --- Shared catalog section header (Views/Shared/Catalog/_CategorySectionHeader.cshtml)
     Font sizes: Content/magtek-standardization.css (.section-title / .section-subtitle + breakpoints).
     Layout only for pages that load this sheet (CardReaders, OemComponents, CheckScanners). --- */
.main-content .section-header {
  text-align: center;
  margin-bottom: 5rem;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 2rem;
  position: relative;
}

.main-content .section-title {
  font-weight: 800;
  color: #1e293b;
  margin: 0 auto 2rem;
  line-height: 1.15;
  letter-spacing: -0.02em;
  position: relative;
  padding-bottom: 1.5rem;
}

.main-content .section-title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 4px;
  /* MagTek brand red (matches buttons / primary CTAs) */
  background: linear-gradient(
    135deg,
    var(--magtek-red) 0%,
    var(--magtek-red-dark) 100%
  );
  border-radius: 2px;
  opacity: 1;
}

.main-content .section-subtitle {
  color: #475569;
  line-height: 1.65;
  margin: 0 auto;
  font-weight: 400;
  text-align: center;
  max-width: 800px;
}

@media (min-width: 768px) and (max-width: 1023px) {
  .main-content .section-header {
    margin-bottom: 4rem;
    padding: 0 1.5rem;
  }

  .main-content .section-title {
    margin-bottom: 1.5rem;
  }
}

@media (max-width: 767px) {
  .main-content .section-header {
    margin-bottom: 3rem;
    padding: 0 1rem;
  }

  .main-content .section-title {
    margin-bottom: 1.2rem;
  }
}

/* Check scanners / other catalog pages using the same main-content id */
#products-check-and-services-main-content-wrappers .section-header {
  margin-bottom: 3rem;
}

.highlight-section .section-title span {
  color: var(--cr-accent-red);
}

.section-header--on-dark .section-title,
.section-title--on-dark {
  color: var(--white);
}

.section-header--on-dark .section-title::after,
.section-title--on-dark::after {
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.95) 0%,
    rgba(255, 255, 255, 0.65) 100%
  );
}

.section-subtitle--on-dark {
  color: rgba(255, 255, 255, 0.88) !important;
}

/* Horizontal rule between bands (CardReaders, OEM, etc.). */
.main-content hr.section-divider {
  border: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 0, 0, 0.08) 20%,
    rgba(0, 0, 0, 0.08) 80%,
    transparent 100%
  );
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

/* Product hub pages: consistent vertical breathing room around dividers */
#products hr.section-divider {
  margin-top: var(--cr-page-divider-gap);
  margin-bottom: var(--cr-page-divider-gap);
}

/* Split hero (#products: CardReaders + OemComponents); rem scale from magtek-standardization.css */
#products .split-hero-eyebrow {
  font-size: var(--cr-font-eyebrow);
}

#products .split-hero h1 {
  font-size: clamp(3.4rem, 4.5vw, 4.8rem);
}

#products .split-hero-subtitle {
  font-size: var(--font-size-h4);
}

@media (max-width: 1199px) {
  #products .split-hero h1 {
    font-size: 4.4rem;
  }

  #products .split-hero-subtitle {
    font-size: 1.9rem;
  }
}

@media (max-width: 991px) {
  #products .split-hero h1 {
    font-size: 3.8rem;
  }

  #products .split-hero-subtitle {
    font-size: var(--font-size-large);
  }
}

@media (max-width: 767px) {
  #products .split-hero h1 {
    font-size: 3.4rem;
  }

  #products .split-hero-subtitle {
    font-size: 1.7rem;
  }
}

@media (max-width: 420px) {
  #products .split-hero h1 {
    font-size: 3.1rem;
  }

  #products .split-hero-subtitle {
    font-size: var(--font-size-body);
  }
}

/* Services marketing banner — same classes as Views/Services/Services.cshtml */
.services-marketing-banner {
  background: linear-gradient(135deg, #263c50 0%, #1e293b 100%);
  padding: 3rem 0;
  position: relative;
  overflow: hidden;
}

.services-marketing-banner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="banner-grid" width="20" height="20" patternUnits="userSpaceOnUse"><path d="M 20 0 L 0 0 0 20" fill="none" stroke="rgba(255,255,255,0.05)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23banner-grid)"/></svg>');
  opacity: 0.5;
  z-index: 1;
}

.marketing-banner-content {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 3rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

.marketing-banner-icon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(210, 18, 66, 0.15);
  border-radius: 16px;
  border: 2px solid rgba(210, 18, 66, 0.3);
}

.marketing-banner-icon i {
  font-size: 2.8rem;
  color: #d21242;
}

.marketing-banner-text {
  flex: 1;
  min-width: 0;
}

.marketing-banner-title {
  font-size: 2.2rem;
  font-weight: 700;
  color: #ffffff;
  margin: 0 0 0.8rem 0;
  line-height: 1.2;
}

.marketing-banner-subtitle {
  font-size: 1.6rem;
  color: rgba(255, 255, 255, 0.85);
  margin: 0;
  line-height: 1.5;
}

.marketing-banner-cta {
  flex-shrink: 0;
}

.marketing-banner-cta--dual {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

@media (max-width: 992px) {
  .marketing-banner-content {
    flex-direction: column;
    text-align: center;
    gap: 2rem;
  }

  .marketing-banner-icon {
    width: 56px;
    height: 56px;
  }

  .marketing-banner-icon i {
    font-size: 2.4rem;
  }

  .marketing-banner-title {
    font-size: 2rem;
  }

  .marketing-banner-subtitle {
    font-size: 1.5rem;
  }

  .marketing-banner-cta {
    width: 100%;
    max-width: 300px;
  }

  .marketing-banner-cta .btn-primary {
    width: 100%;
  }

  .marketing-banner-cta--dual {
    justify-content: center;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
  }

  .marketing-banner-cta--dual .btn-primary,
  .marketing-banner-cta--dual .btn-secondary {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 768px) {
  .services-marketing-banner {
    padding: 2.5rem 0;
  }

  .marketing-banner-content {
    padding: 0 1.5rem;
    gap: 1.5rem;
  }

  .marketing-banner-title {
    font-size: 1.8rem;
  }

  .marketing-banner-subtitle {
    font-size: 1.4rem;
  }
}

@media (max-width: 480px) {
  .services-marketing-banner {
    padding: 2rem 0;
  }

  .marketing-banner-content {
    padding: 0 1rem;
  }

  .marketing-banner-icon {
    width: 48px;
    height: 48px;
  }

  .marketing-banner-icon i {
    font-size: 2rem;
  }

  .marketing-banner-title {
    font-size: 1.6rem;
  }

  .marketing-banner-subtitle {
    font-size: 1.3rem;
  }
}

/* =============================================================================
   CARD READERS (#products) — responsive matrix
   Phone · foldable · landscape · tablet · desktop · large · ultrawide · safe-area
   ============================================================================= */

#products.main-content {
  overflow-x: clip;
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
}

#products .services-marketing-banner .marketing-banner-content {
  padding-left: max(1.5rem, calc(0.75rem + env(safe-area-inset-left, 0px)));
  padding-right: max(1.5rem, calc(0.75rem + env(safe-area-inset-right, 0px)));
}

@supports not (overflow: clip) {
  #products.main-content {
    overflow-x: hidden;
  }
}

/* Bootstrap 3 .container: grow cap on very wide monitors (readable line length) */
@media (min-width: 1400px) {
  #products .container {
    width: auto !important;
    max-width: min(1320px, calc(100vw - 3rem)) !important;
  }
}

@media (min-width: 1920px) {
  #products .container {
    max-width: min(1440px, calc(100vw - 5rem)) !important;
  }
}

@media (min-width: 2560px) {
  #products .container {
    max-width: min(1560px, calc(100vw - 6rem)) !important;
  }
}

/* Foldables & very narrow phones */
@media (max-width: 360px) {
  #products .split-hero h1 {
    font-size: clamp(2.6rem, 9.2vw, 3.2rem) !important;
    line-height: 1.14 !important;
    word-break: break-word;
    hyphens: auto;
  }

  /* Hardware hubs: keep descenders / multi-line titles readable (no tight line-box clip) */
  #products.product-family-hub .split-hero.split-hero--family-hub h1 {
    line-height: 1.2 !important;
  }

  #products .split-hero-subtitle {
    font-size: clamp(1.45rem, 4.2vw, 1.65rem) !important;
    padding-left: 2px;
    padding-right: 2px;
  }

  #products .split-hero .split-hero-copy {
    padding-left: 4px !important;
    padding-right: 4px !important;
  }

  #products .cr-dual-catalog-band .product-card-dual__main {
    padding: 14px 12px 12px !important;
  }

  #products .cr-dual-catalog-band .product-card-dual__footer {
    padding: 12px 12px 13px !important;
    font-size: 1.25rem !important;
    letter-spacing: 0.035em !important;
  }

  #products .container {
    padding-left: max(10px, env(safe-area-inset-left, 0px)) !important;
    padding-right: max(10px, env(safe-area-inset-right, 0px)) !important;
  }
}

@media (max-width: 320px) {
  #products .split-hero h1 {
    font-size: 2.5rem !important;
  }
}

/* Tablet portrait / small laptop — rhythm */
@media (min-width: 768px) and (max-width: 1024px) {
  #products .split-hero h1 {
    font-size: clamp(3.2rem, 3.6vw, 3.9rem) !important;
  }

  #products .split-hero-subtitle {
    font-size: clamp(1.65rem, 1.8vw, 1.85rem) !important;
  }

  #products .cr-dual-catalog-band {
    padding-left: max(0px, env(safe-area-inset-left, 0px));
    padding-right: max(0px, env(safe-area-inset-right, 0px));
  }

  #products .cr-one-kernel-block.video-showcase-section--one-kernel {
    padding-left: max(0px, env(safe-area-inset-left, 0px));
    padding-right: max(0px, env(safe-area-inset-right, 0px));
  }
}

/* Phone + small tablet landscape (short viewport): compact hero & bands */
@media (max-height: 520px) and (orientation: landscape) and (max-width: 1060px) {
  #products .split-hero {
    padding-top: 20px !important;
    padding-bottom: 24px !important;
  }

  #products .split-hero h1 {
    font-size: clamp(2.4rem, 5.5vh, 3.4rem) !important;
    margin-bottom: 8px !important;
  }

  #products .split-hero-subtitle {
    font-size: clamp(1.45rem, 2.8vh, 1.65rem) !important;
    line-height: 1.4 !important;
  }

  #products .split-hero-actions {
    margin-top: 14px !important;
  }

  #products .split-hero .split-hero-media {
    margin-top: 12px !important;
  }

  #products .split-hero .split-hero-media-inner {
    min-height: 0 !important;
  }

  #products .split-hero .split-hero-media img {
    max-height: min(42vh, 200px) !important;
  }

  #products .cr-mms-dyna-showcase .mms-dyna-card-readers-section {
    padding-top: 36px !important;
    padding-bottom: 40px !important;
  }

  #products .cr-one-kernel-block.video-showcase-section--one-kernel {
    padding-top: 2.5rem !important;
    padding-bottom: 2.75rem !important;
  }

  #products .cr-split-promo {
    padding-top: 36px !important;
    padding-bottom: 36px !important;
  }

  #products .cr-dual-catalog-band {
    padding-top: 28px !important;
    padding-bottom: 32px !important;
  }

  #products .services-marketing-banner {
    padding: 1.75rem 0 !important;
  }

  #products .cr-split-promo--oem {
    padding-top: 40px !important;
    padding-bottom: 44px !important;
  }
}

/* Extra-short landscape (e.g. folded outer display) */
@media (max-height: 400px) and (orientation: landscape) and (max-width: 900px) {
  #products .split-hero .split-hero-media img {
    max-height: min(36vh, 160px) !important;
  }

  #products .split-hero h1 {
    font-size: 2.2rem !important;
  }
}

/* Touch / coarse pointer: comfortable targets (WCAG-friendly) */
@media (pointer: coarse) {
  #products .one-kernel-player {
    min-height: 48px;
  }

  #products .cr-dynacast-actions .btn-primary,
  #products .cr-dynacast-actions .btn-secondary {
    min-height: 44px;
    align-items: center;
  }

  #products .cr-dual-catalog-band .product-card-dual__footer {
    min-height: 48px;
    padding-top: 14px !important;
    padding-bottom: 14px !important;
  }

  #products .services-marketing-banner .marketing-banner-cta .btn-primary,
  #products .services-marketing-banner .marketing-banner-cta .btn-secondary {
    min-height: 44px;
  }
}

/* Dual-screen / fold aware (supported browsers) */
@media (horizontal-viewport-segments: 2) {
  #products .container {
    max-width: 100% !important;
    padding-left: max(16px, env(safe-area-inset-left, 16px)) !important;
    padding-right: max(16px, env(safe-area-inset-right, 16px)) !important;
  }
}

/* Card Readers video modals (markup follows <main>) — short landscape */
@media (max-height: 520px) and (orientation: landscape) {
  .cr-dyna-video-modal .modal-dialog.cr-dyna-video-modal__dialog {
    margin: 10px auto !important;
    max-width: min(920px, calc(100vw - 20px)) !important;
  }

  .cr-dyna-video-modal .modal-header.cr-dyna-video-modal__header {
    padding-top: 12px !important;
    padding-bottom: 10px !important;
  }

  .cr-tap-video-modal .cr-tap-video-modal__video {
    max-height: min(48vh, 360px) !important;
  }
}

@media (max-height: 400px) and (orientation: landscape) {
  .cr-tap-video-modal .cr-tap-video-modal__video {
    max-height: min(40vh, 280px) !important;
  }
}

/* ==========================================================================
   Check Scanners & Instant Issuance — value band + catalog shells (no bento)
   ========================================================================== */

:is(#check-scanners-catalog-section, #instant-issuance-catalog-section)
  .cr-catalog-grid-card-col
  .product-card.cr-catalog-card {
  background-color: #ffffff !important;
  border-color: rgba(38, 60, 80, 0.11) !important;
}

/* Check Scanners grid: compact category pills (B2B — inline, not full-width bars) */
#check-scanners-catalog-section .cr-catalog-card__kind {
  margin: 0 0 10px;
}

#check-scanners-catalog-section .cr-catalog-card__kind-pill {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: 0.28rem 0.75rem;
  border-radius: 999px;
  font-size: 1.05rem;
  font-weight: 650;
  line-height: 1.25;
  letter-spacing: 0.055em;
  text-transform: uppercase;
  border: 1px solid transparent;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

#check-scanners-catalog-section .cr-catalog-card__kind-pill--micr {
  color: #f8fafc;
  background: linear-gradient(180deg, #2d4a5e 0%, #1e3648 100%);
  border-color: rgba(15, 23, 42, 0.2);
}

#check-scanners-catalog-section .cr-catalog-card__kind-pill--scanner {
  color: #f8fafc;
  background: linear-gradient(180deg, #5b6570 0%, #3d4650 100%);
  border-color: rgba(15, 23, 42, 0.18);
}

#check-scanners-catalog-section .cr-catalog-card__kind-pill--neutral {
  color: #334155;
  background: rgba(248, 250, 252, 0.95);
  border-color: rgba(38, 60, 80, 0.14);
}

@media (max-width: 767px) {
  #check-scanners-catalog-section .cr-catalog-card__kind-pill {
    font-size: 1rem;
  }
}

/* Hardware hub chrome (hero, nav, MagCare skin, value bands, final CTA): ~/Content/product-family-hub-shared.css */

