retro-react
Version:
A React component library for building retro-style websites
1 lines • 106 kB
JavaScript
"use strict";var c=require("@emotion/styled/base"),X=require("@emotion/react"),H=require("../../constants/colors.js"),x=require("../../constants/fonts.js");const l=X.css("&:active:not(:disabled){border-color:",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_HIGHLIGHT," ",H.WIN31_BUTTON_HIGHLIGHT," ",H.WIN31_BUTTON_SHADOW,";transform:translate(1px, 1px);filter:brightness(0.95);}"+("production"===process.env.NODE_ENV?"":";label:retroButtonPress;"),"production"===process.env.NODE_ENV?"":"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.styled.tsx"],"names":[],"mappings":"AAK6B","file":"Button.styled.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { VGA_BLACK, VGA_BLUE, VGA_GREEN, VGA_WHITE, VGA_YELLOW, WIN31_BUTTON_FACE, WIN31_BUTTON_HIGHLIGHT, WIN31_BUTTON_SHADOW, } from \"../../constants/colors\";\r\nimport { SYSTEM_FONT } from \"../../constants/fonts\";\r\n// Authentic retro button press effect\r\nconst retroButtonPress = css `\r\n\t&:active:not(:disabled) {\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t\ttransform: translate(1px, 1px);\r\n\t\t/* Slight darkening effect on press */\r\n\t\tfilter: brightness(0.95);\r\n\t}\r\n`;\r\n// Get variant-specific styling\r\nconst getVariantStyles = (variant) => {\r\n    switch (variant) {\r\n        case 'primary':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'secondary':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.05);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'success':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_GREEN};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'warning':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_YELLOW};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'outline':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: ${VGA_BLUE} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${VGA_BLUE};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'flat':\r\n        default:\r\n            return css `\r\n\t\t\t\tbackground: transparent;\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: transparent transparent transparent transparent;\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\t\t\t`;\r\n    }\r\n};\r\nexport const Button = styled.button `\r\n\t/* Base authentic WIN31 button styling */\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\r\n\t/* Authentic Windows button dimensions and spacing */\r\n\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '60px';\r\n        case 'large':\r\n            return '100px';\r\n        default:\r\n            return '75px'; // medium\r\n    }\r\n}};\r\n\r\n\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 6px';\r\n        case 'large':\r\n            return '6px 16px';\r\n        default:\r\n            return '3px 12px'; // medium - authentic WIN31 spacing\r\n    }\r\n}};\r\n\r\n\theight: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '18px';\r\n        case 'large':\r\n            return '28px';\r\n        default:\r\n            return '23px'; // medium - standard WIN31 button height\r\n    }\r\n}};\r\n\r\n\t/* Authentic WIN31 typography */\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '10px';\r\n        case 'large':\r\n            return '12px';\r\n        default:\r\n            return '11px'; // Standard WIN31 button text size\r\n    }\r\n}};\r\n\tfont-weight: normal;\r\n\ttext-align: center;\r\n\tline-height: 1;\r\n\r\n\t/* Authentic WIN31 border style */\r\n\tborder: 2px solid;\r\n\tborder-radius: 0; /* Sharp corners like authentic Windows */\r\n\tcursor: pointer;\r\n\r\n\t/* Remove all modern effects */\r\n\tbox-shadow: none;\r\n\ttransition: none;\r\n\toutline: none;\r\n\ttext-decoration: none;\r\n\tuser-select: none;\r\n\r\n\t/* Apply variant-specific styles */\r\n\t${(props) => getVariantStyles(props.variant)}\r\n\r\n\t/* Authentic button press effect */\r\n\t${(props) => !props.$disableClickEffect && retroButtonPress}\r\n\t\r\n\t/* Disabled state - authentic WIN31 grayed out look */\r\n\t&:disabled {\r\n\t\tcursor: not-allowed;\r\n\t\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW};\r\n\t\tfilter: none;\r\n\t\ttransform: none;\r\n\t}\r\n\r\n\t/* ButtonGroup integration - seamless borders */\r\n\t${(props) => props.$isButtonGroup &&\r\n    css `\r\n\t\t\tborder-radius: 0;\r\n\r\n\t\t\t/* Remove right border for group effect except last child */\r\n\t\t\t& + & {\r\n\t\t\t\tborder-left-width: 1px;\r\n\t\t\t}\r\n\t\t`}\r\n\r\n\t/* Loading state */\r\n\t&[aria-busy='true'] {\r\n\t\tcursor: progress;\r\n\t\tposition: relative;\r\n\r\n\t\t/* Simple loading indicator - no fancy spinners in retro UI */\r\n\t\t&::after {\r\n\t\t\tcontent: '...';\r\n\t\t\tposition: absolute;\r\n\t\t\tright: 4px;\r\n\t\t\tanimation: loading 1s infinite;\r\n\t\t}\r\n\t}\r\n\r\n\t@keyframes loading {\r\n\t\t0%,\r\n\t\t33% {\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t\t34%,\r\n\t\t66% {\r\n\t\t\topacity: 0.5;\r\n\t\t}\r\n\t\t67%,\r\n\t\t100% {\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Responsive considerations */\r\n\t@media (max-width: 480px) {\r\n\t\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '50px';\r\n        case 'large':\r\n            return '80px';\r\n        default:\r\n            return '65px';\r\n    }\r\n}};\r\n\r\n\t\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 4px';\r\n        case 'large':\r\n            return '4px 12px';\r\n        default:\r\n            return '2px 8px';\r\n    }\r\n}};\r\n\t}\r\n`;\r\n//# sourceMappingURL=Button.styled.js.map"]} */");var I="production"===process.env.NODE_ENV?{name:"5vs986",styles:"border-radius:0;&+&{border-left-width:1px;}"}:{name:"fttwuj-Button",styles:"border-radius:0;&+&{border-left-width:1px;};label:Button;",map:"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.styled.tsx"],"names":[],"mappings":"AAsNQ","file":"Button.styled.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { VGA_BLACK, VGA_BLUE, VGA_GREEN, VGA_WHITE, VGA_YELLOW, WIN31_BUTTON_FACE, WIN31_BUTTON_HIGHLIGHT, WIN31_BUTTON_SHADOW, } from \"../../constants/colors\";\r\nimport { SYSTEM_FONT } from \"../../constants/fonts\";\r\n// Authentic retro button press effect\r\nconst retroButtonPress = css `\r\n\t&:active:not(:disabled) {\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t\ttransform: translate(1px, 1px);\r\n\t\t/* Slight darkening effect on press */\r\n\t\tfilter: brightness(0.95);\r\n\t}\r\n`;\r\n// Get variant-specific styling\r\nconst getVariantStyles = (variant) => {\r\n    switch (variant) {\r\n        case 'primary':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'secondary':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.05);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'success':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_GREEN};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'warning':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_YELLOW};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'outline':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: ${VGA_BLUE} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${VGA_BLUE};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'flat':\r\n        default:\r\n            return css `\r\n\t\t\t\tbackground: transparent;\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: transparent transparent transparent transparent;\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\t\t\t`;\r\n    }\r\n};\r\nexport const Button = styled.button `\r\n\t/* Base authentic WIN31 button styling */\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\r\n\t/* Authentic Windows button dimensions and spacing */\r\n\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '60px';\r\n        case 'large':\r\n            return '100px';\r\n        default:\r\n            return '75px'; // medium\r\n    }\r\n}};\r\n\r\n\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 6px';\r\n        case 'large':\r\n            return '6px 16px';\r\n        default:\r\n            return '3px 12px'; // medium - authentic WIN31 spacing\r\n    }\r\n}};\r\n\r\n\theight: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '18px';\r\n        case 'large':\r\n            return '28px';\r\n        default:\r\n            return '23px'; // medium - standard WIN31 button height\r\n    }\r\n}};\r\n\r\n\t/* Authentic WIN31 typography */\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '10px';\r\n        case 'large':\r\n            return '12px';\r\n        default:\r\n            return '11px'; // Standard WIN31 button text size\r\n    }\r\n}};\r\n\tfont-weight: normal;\r\n\ttext-align: center;\r\n\tline-height: 1;\r\n\r\n\t/* Authentic WIN31 border style */\r\n\tborder: 2px solid;\r\n\tborder-radius: 0; /* Sharp corners like authentic Windows */\r\n\tcursor: pointer;\r\n\r\n\t/* Remove all modern effects */\r\n\tbox-shadow: none;\r\n\ttransition: none;\r\n\toutline: none;\r\n\ttext-decoration: none;\r\n\tuser-select: none;\r\n\r\n\t/* Apply variant-specific styles */\r\n\t${(props) => getVariantStyles(props.variant)}\r\n\r\n\t/* Authentic button press effect */\r\n\t${(props) => !props.$disableClickEffect && retroButtonPress}\r\n\t\r\n\t/* Disabled state - authentic WIN31 grayed out look */\r\n\t&:disabled {\r\n\t\tcursor: not-allowed;\r\n\t\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW};\r\n\t\tfilter: none;\r\n\t\ttransform: none;\r\n\t}\r\n\r\n\t/* ButtonGroup integration - seamless borders */\r\n\t${(props) => props.$isButtonGroup &&\r\n    css `\r\n\t\t\tborder-radius: 0;\r\n\r\n\t\t\t/* Remove right border for group effect except last child */\r\n\t\t\t& + & {\r\n\t\t\t\tborder-left-width: 1px;\r\n\t\t\t}\r\n\t\t`}\r\n\r\n\t/* Loading state */\r\n\t&[aria-busy='true'] {\r\n\t\tcursor: progress;\r\n\t\tposition: relative;\r\n\r\n\t\t/* Simple loading indicator - no fancy spinners in retro UI */\r\n\t\t&::after {\r\n\t\t\tcontent: '...';\r\n\t\t\tposition: absolute;\r\n\t\t\tright: 4px;\r\n\t\t\tanimation: loading 1s infinite;\r\n\t\t}\r\n\t}\r\n\r\n\t@keyframes loading {\r\n\t\t0%,\r\n\t\t33% {\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t\t34%,\r\n\t\t66% {\r\n\t\t\topacity: 0.5;\r\n\t\t}\r\n\t\t67%,\r\n\t\t100% {\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Responsive considerations */\r\n\t@media (max-width: 480px) {\r\n\t\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '50px';\r\n        case 'large':\r\n            return '80px';\r\n        default:\r\n            return '65px';\r\n    }\r\n}};\r\n\r\n\t\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 4px';\r\n        case 'large':\r\n            return '4px 12px';\r\n        default:\r\n            return '2px 8px';\r\n    }\r\n}};\r\n\t}\r\n`;\r\n//# sourceMappingURL=Button.styled.js.map"]} */",toString:function(){return"You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."}};const d=c("button","production"===process.env.NODE_ENV?{target:"e1uf03490"}:{target:"e1uf03490",label:"Button"})("display:inline-flex;align-items:center;justify-content:center;position:relative;box-sizing:border-box;min-width:",(c=>{switch(c.$size){case"small":return"60px";case"large":return"100px";default:return"75px"}}),";padding:",(c=>{switch(c.$size){case"small":return"1px 6px";case"large":return"6px 16px";default:return"3px 12px"}}),";height:",(c=>{switch(c.$size){case"small":return"18px";case"large":return"28px";default:return"23px"}}),";font-family:",x.SYSTEM_FONT,";font-size:",(c=>{switch(c.$size){case"small":return"10px";case"large":return"12px";default:return"11px"}}),";font-weight:normal;text-align:center;line-height:1;border:2px solid;border-radius:0;cursor:pointer;box-shadow:none;transition:none;outline:none;text-decoration:none;user-select:none;",(c=>(c=>{switch(c){case"primary":return X.css("background:",H.VGA_BLUE,";color:",H.VGA_WHITE,";border-color:",H.WIN31_BUTTON_HIGHLIGHT," ",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_HIGHLIGHT,";&:hover:not(:disabled){filter:brightness(1.1);}&:focus:not(:disabled){outline:1px dotted ",H.VGA_WHITE,";outline-offset:-3px;}"+("production"===process.env.NODE_ENV?"":";label:getVariantStyles;"),"production"===process.env.NODE_ENV?"":"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.styled.tsx"],"names":[],"mappings":"AAkBuB","file":"Button.styled.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { VGA_BLACK, VGA_BLUE, VGA_GREEN, VGA_WHITE, VGA_YELLOW, WIN31_BUTTON_FACE, WIN31_BUTTON_HIGHLIGHT, WIN31_BUTTON_SHADOW, } from \"../../constants/colors\";\r\nimport { SYSTEM_FONT } from \"../../constants/fonts\";\r\n// Authentic retro button press effect\r\nconst retroButtonPress = css `\r\n\t&:active:not(:disabled) {\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t\ttransform: translate(1px, 1px);\r\n\t\t/* Slight darkening effect on press */\r\n\t\tfilter: brightness(0.95);\r\n\t}\r\n`;\r\n// Get variant-specific styling\r\nconst getVariantStyles = (variant) => {\r\n    switch (variant) {\r\n        case 'primary':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'secondary':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.05);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'success':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_GREEN};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'warning':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_YELLOW};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'outline':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: ${VGA_BLUE} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${VGA_BLUE};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'flat':\r\n        default:\r\n            return css `\r\n\t\t\t\tbackground: transparent;\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: transparent transparent transparent transparent;\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\t\t\t`;\r\n    }\r\n};\r\nexport const Button = styled.button `\r\n\t/* Base authentic WIN31 button styling */\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\r\n\t/* Authentic Windows button dimensions and spacing */\r\n\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '60px';\r\n        case 'large':\r\n            return '100px';\r\n        default:\r\n            return '75px'; // medium\r\n    }\r\n}};\r\n\r\n\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 6px';\r\n        case 'large':\r\n            return '6px 16px';\r\n        default:\r\n            return '3px 12px'; // medium - authentic WIN31 spacing\r\n    }\r\n}};\r\n\r\n\theight: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '18px';\r\n        case 'large':\r\n            return '28px';\r\n        default:\r\n            return '23px'; // medium - standard WIN31 button height\r\n    }\r\n}};\r\n\r\n\t/* Authentic WIN31 typography */\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '10px';\r\n        case 'large':\r\n            return '12px';\r\n        default:\r\n            return '11px'; // Standard WIN31 button text size\r\n    }\r\n}};\r\n\tfont-weight: normal;\r\n\ttext-align: center;\r\n\tline-height: 1;\r\n\r\n\t/* Authentic WIN31 border style */\r\n\tborder: 2px solid;\r\n\tborder-radius: 0; /* Sharp corners like authentic Windows */\r\n\tcursor: pointer;\r\n\r\n\t/* Remove all modern effects */\r\n\tbox-shadow: none;\r\n\ttransition: none;\r\n\toutline: none;\r\n\ttext-decoration: none;\r\n\tuser-select: none;\r\n\r\n\t/* Apply variant-specific styles */\r\n\t${(props) => getVariantStyles(props.variant)}\r\n\r\n\t/* Authentic button press effect */\r\n\t${(props) => !props.$disableClickEffect && retroButtonPress}\r\n\t\r\n\t/* Disabled state - authentic WIN31 grayed out look */\r\n\t&:disabled {\r\n\t\tcursor: not-allowed;\r\n\t\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW};\r\n\t\tfilter: none;\r\n\t\ttransform: none;\r\n\t}\r\n\r\n\t/* ButtonGroup integration - seamless borders */\r\n\t${(props) => props.$isButtonGroup &&\r\n    css `\r\n\t\t\tborder-radius: 0;\r\n\r\n\t\t\t/* Remove right border for group effect except last child */\r\n\t\t\t& + & {\r\n\t\t\t\tborder-left-width: 1px;\r\n\t\t\t}\r\n\t\t`}\r\n\r\n\t/* Loading state */\r\n\t&[aria-busy='true'] {\r\n\t\tcursor: progress;\r\n\t\tposition: relative;\r\n\r\n\t\t/* Simple loading indicator - no fancy spinners in retro UI */\r\n\t\t&::after {\r\n\t\t\tcontent: '...';\r\n\t\t\tposition: absolute;\r\n\t\t\tright: 4px;\r\n\t\t\tanimation: loading 1s infinite;\r\n\t\t}\r\n\t}\r\n\r\n\t@keyframes loading {\r\n\t\t0%,\r\n\t\t33% {\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t\t34%,\r\n\t\t66% {\r\n\t\t\topacity: 0.5;\r\n\t\t}\r\n\t\t67%,\r\n\t\t100% {\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Responsive considerations */\r\n\t@media (max-width: 480px) {\r\n\t\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '50px';\r\n        case 'large':\r\n            return '80px';\r\n        default:\r\n            return '65px';\r\n    }\r\n}};\r\n\r\n\t\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 4px';\r\n        case 'large':\r\n            return '4px 12px';\r\n        default:\r\n            return '2px 8px';\r\n    }\r\n}};\r\n\t}\r\n`;\r\n//# sourceMappingURL=Button.styled.js.map"]} */");case"secondary":return X.css("background:",H.WIN31_BUTTON_FACE,";color:",H.VGA_BLACK,";border-color:",H.WIN31_BUTTON_HIGHLIGHT," ",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_HIGHLIGHT,";&:hover:not(:disabled){filter:brightness(1.05);}&:focus:not(:disabled){outline:1px dotted ",H.VGA_BLACK,";outline-offset:-3px;}"+("production"===process.env.NODE_ENV?"":";label:getVariantStyles;"),"production"===process.env.NODE_ENV?"":"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.styled.tsx"],"names":[],"mappings":"AAmCuB","file":"Button.styled.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { VGA_BLACK, VGA_BLUE, VGA_GREEN, VGA_WHITE, VGA_YELLOW, WIN31_BUTTON_FACE, WIN31_BUTTON_HIGHLIGHT, WIN31_BUTTON_SHADOW, } from \"../../constants/colors\";\r\nimport { SYSTEM_FONT } from \"../../constants/fonts\";\r\n// Authentic retro button press effect\r\nconst retroButtonPress = css `\r\n\t&:active:not(:disabled) {\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT}\r\n\t\t\t${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW};\r\n\t\ttransform: translate(1px, 1px);\r\n\t\t/* Slight darkening effect on press */\r\n\t\tfilter: brightness(0.95);\r\n\t}\r\n`;\r\n// Get variant-specific styling\r\nconst getVariantStyles = (variant) => {\r\n    switch (variant) {\r\n        case 'primary':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'secondary':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\t/* Subtle brightness increase on hover */\r\n\t\t\t\t\tfilter: brightness(1.05);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'success':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_GREEN};\r\n\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_WHITE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'warning':\r\n            return css `\r\n\t\t\t\tbackground: ${VGA_YELLOW};\r\n\t\t\t\tcolor: ${VGA_BLACK};\r\n\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tfilter: brightness(1.1);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLACK};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'outline':\r\n            return css `\r\n\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: ${VGA_BLUE} ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t${VGA_BLUE};\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${VGA_BLUE};\r\n\t\t\t\t\tcolor: ${VGA_WHITE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t}\r\n\t\t\t`;\r\n        case 'flat':\r\n        default:\r\n            return css `\r\n\t\t\t\tbackground: transparent;\r\n\t\t\t\tcolor: ${VGA_BLUE};\r\n\t\t\t\tborder-color: transparent transparent transparent transparent;\r\n\r\n\t\t\t\t&:hover:not(:disabled) {\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\r\n\t\t\t\t&:focus:not(:disabled) {\r\n\t\t\t\t\toutline: 1px dotted ${VGA_BLUE};\r\n\t\t\t\t\toutline-offset: -3px;\r\n\t\t\t\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\t\t\t\tborder-color: ${WIN31_BUTTON_HIGHLIGHT} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_HIGHLIGHT};\r\n\t\t\t\t}\r\n\t\t\t`;\r\n    }\r\n};\r\nexport const Button = styled.button `\r\n\t/* Base authentic WIN31 button styling */\r\n\tdisplay: inline-flex;\r\n\talign-items: center;\r\n\tjustify-content: center;\r\n\tposition: relative;\r\n\tbox-sizing: border-box;\r\n\r\n\t/* Authentic Windows button dimensions and spacing */\r\n\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '60px';\r\n        case 'large':\r\n            return '100px';\r\n        default:\r\n            return '75px'; // medium\r\n    }\r\n}};\r\n\r\n\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 6px';\r\n        case 'large':\r\n            return '6px 16px';\r\n        default:\r\n            return '3px 12px'; // medium - authentic WIN31 spacing\r\n    }\r\n}};\r\n\r\n\theight: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '18px';\r\n        case 'large':\r\n            return '28px';\r\n        default:\r\n            return '23px'; // medium - standard WIN31 button height\r\n    }\r\n}};\r\n\r\n\t/* Authentic WIN31 typography */\r\n\tfont-family: ${SYSTEM_FONT};\r\n\tfont-size: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '10px';\r\n        case 'large':\r\n            return '12px';\r\n        default:\r\n            return '11px'; // Standard WIN31 button text size\r\n    }\r\n}};\r\n\tfont-weight: normal;\r\n\ttext-align: center;\r\n\tline-height: 1;\r\n\r\n\t/* Authentic WIN31 border style */\r\n\tborder: 2px solid;\r\n\tborder-radius: 0; /* Sharp corners like authentic Windows */\r\n\tcursor: pointer;\r\n\r\n\t/* Remove all modern effects */\r\n\tbox-shadow: none;\r\n\ttransition: none;\r\n\toutline: none;\r\n\ttext-decoration: none;\r\n\tuser-select: none;\r\n\r\n\t/* Apply variant-specific styles */\r\n\t${(props) => getVariantStyles(props.variant)}\r\n\r\n\t/* Authentic button press effect */\r\n\t${(props) => !props.$disableClickEffect && retroButtonPress}\r\n\t\r\n\t/* Disabled state - authentic WIN31 grayed out look */\r\n\t&:disabled {\r\n\t\tcursor: not-allowed;\r\n\t\tcolor: ${WIN31_BUTTON_SHADOW};\r\n\t\tbackground: ${WIN31_BUTTON_FACE};\r\n\t\tborder-color: ${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW}\r\n\t\t\t${WIN31_BUTTON_SHADOW} ${WIN31_BUTTON_SHADOW};\r\n\t\tfilter: none;\r\n\t\ttransform: none;\r\n\t}\r\n\r\n\t/* ButtonGroup integration - seamless borders */\r\n\t${(props) => props.$isButtonGroup &&\r\n    css `\r\n\t\t\tborder-radius: 0;\r\n\r\n\t\t\t/* Remove right border for group effect except last child */\r\n\t\t\t& + & {\r\n\t\t\t\tborder-left-width: 1px;\r\n\t\t\t}\r\n\t\t`}\r\n\r\n\t/* Loading state */\r\n\t&[aria-busy='true'] {\r\n\t\tcursor: progress;\r\n\t\tposition: relative;\r\n\r\n\t\t/* Simple loading indicator - no fancy spinners in retro UI */\r\n\t\t&::after {\r\n\t\t\tcontent: '...';\r\n\t\t\tposition: absolute;\r\n\t\t\tright: 4px;\r\n\t\t\tanimation: loading 1s infinite;\r\n\t\t}\r\n\t}\r\n\r\n\t@keyframes loading {\r\n\t\t0%,\r\n\t\t33% {\r\n\t\t\topacity: 0;\r\n\t\t}\r\n\t\t34%,\r\n\t\t66% {\r\n\t\t\topacity: 0.5;\r\n\t\t}\r\n\t\t67%,\r\n\t\t100% {\r\n\t\t\topacity: 1;\r\n\t\t}\r\n\t}\r\n\r\n\t/* Responsive considerations */\r\n\t@media (max-width: 480px) {\r\n\t\tmin-width: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '50px';\r\n        case 'large':\r\n            return '80px';\r\n        default:\r\n            return '65px';\r\n    }\r\n}};\r\n\r\n\t\tpadding: ${(props) => {\r\n    switch (props.$size) {\r\n        case 'small':\r\n            return '1px 4px';\r\n        case 'large':\r\n            return '4px 12px';\r\n        default:\r\n            return '2px 8px';\r\n    }\r\n}};\r\n\t}\r\n`;\r\n//# sourceMappingURL=Button.styled.js.map"]} */");case"success":return X.css("background:",H.VGA_GREEN,";color:",H.VGA_WHITE,";border-color:",H.WIN31_BUTTON_HIGHLIGHT," ",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_SHADOW," ",H.WIN31_BUTTON_HIGHLIGHT,";&:hover:not(:disabled){filter:brightness(1.1);}&:focus:not(:disabled){outline:1px dotted ",H.VGA_WHITE,";outline-offset:-3px;}"+("production"===process.env.NODE_ENV?"":";label:getVariantStyles;"),"production"===process.env.NODE_ENV?"":"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJ1dHRvbi5zdHlsZWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9EdUIiLCJmaWxlIjoiQnV0dG9uLnN0eWxlZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgVkdBX0JMQUNLLCBWR0FfQkxVRSwgVkdBX0dSRUVOLCBWR0FfV0hJVEUsIFZHQV9ZRUxMT1csIFdJTjMxX0JVVFRPTl9GQUNFLCBXSU4zMV9CVVRUT05fSElHSExJR0hULCBXSU4zMV9CVVRUT05fU0hBRE9XLCB9IGZyb20gXCIuLi8uLi9jb25zdGFudHMvY29sb3JzXCI7XHJcbmltcG9ydCB7IFNZU1RFTV9GT05UIH0gZnJvbSBcIi4uLy4uL2NvbnN0YW50cy9mb250c1wiO1xyXG4vLyBBdXRoZW50aWMgcmV0cm8gYnV0dG9uIHByZXNzIGVmZmVjdFxyXG5jb25zdCByZXRyb0J1dHRvblByZXNzID0gY3NzIGBcclxuXHQmOmFjdGl2ZTpub3QoOmRpc2FibGVkKSB7XHJcblx0XHRib3JkZXItY29sb3I6ICR7V0lOMzFfQlVUVE9OX1NIQURPV30gJHtXSU4zMV9CVVRUT05fSElHSExJR0hUfVxyXG5cdFx0XHQke1dJTjMxX0JVVFRPTl9ISUdITElHSFR9ICR7V0lOMzFfQlVUVE9OX1NIQURPV307XHJcblx0XHR0cmFuc2Zvcm06IHRyYW5zbGF0ZSgxcHgsIDFweCk7XHJcblx0XHQvKiBTbGlnaHQgZGFya2VuaW5nIGVmZmVjdCBvbiBwcmVzcyAqL1xyXG5cdFx0ZmlsdGVyOiBicmlnaHRuZXNzKDAuOTUpO1xyXG5cdH1cclxuYDtcclxuLy8gR2V0IHZhcmlhbnQtc3BlY2lmaWMgc3R5bGluZ1xyXG5jb25zdCBnZXRWYXJpYW50U3R5bGVzID0gKHZhcmlhbnQpID0+IHtcclxuICAgIHN3aXRjaCAodmFyaWFudCkge1xyXG4gICAgICAgIGNhc2UgJ3ByaW1hcnknOlxyXG4gICAgICAgICAgICByZXR1cm4gY3NzIGBcclxuXHRcdFx0XHRiYWNrZ3JvdW5kOiAke1ZHQV9CTFVFfTtcclxuXHRcdFx0XHRjb2xvcjogJHtWR0FfV0hJVEV9O1xyXG5cdFx0XHRcdGJvcmRlci1jb2xvcjogJHtXSU4zMV9CVVRUT05fSElHSExJR0hUfSAke1dJTjMxX0JVVFRPTl9TSEFET1d9XHJcblx0XHRcdFx0XHQke1dJTjMxX0JVVFRPTl9TSEFET1d9ICR7V0lOMzFfQlVUVE9OX0hJR0hMSUdIVH07XHJcblxyXG5cdFx0XHRcdCY6aG92ZXI6bm90KDpkaXNhYmxlZCkge1xyXG5cdFx0XHRcdFx0LyogU3VidGxlIGJyaWdodG5lc3MgaW5jcmVhc2Ugb24gaG92ZXIgKi9cclxuXHRcdFx0XHRcdGZpbHRlcjogYnJpZ2h0bmVzcygxLjEpO1xyXG5cdFx0XHRcdH1cclxuXHJcblx0XHRcdFx0Jjpmb2N1czpub3QoOmRpc2FibGVkKSB7XHJcblx0XHRcdFx0XHRvdXRsaW5lOiAxcHggZG90dGVkICR7VkdBX1dISVRFfTtcclxuXHRcdFx0XHRcdG91dGxpbmUtb2Zmc2V0OiAtM3B4O1xyXG5cdFx0XHRcdH1cclxuXHRcdFx0YDtcclxuICAgICAgICBjYXNlICdzZWNvbmRhcnknOlxyXG4gICAgICAgICAgICByZXR1cm4gY3NzIGBcclxuXHRcdFx0XHRiYWNrZ3JvdW5kOiAke1dJTjMxX0JVVFRPTl9GQUNFfTtcclxuXHRcdFx0XHRjb2xvcjogJHtWR0FfQkxBQ