:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#2c3e50;background-color:#ecf0f1;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;scroll-behavior:smooth;touch-action:manipulation}*{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh;min-height:100dvh;overscroll-behavior:none;-webkit-overflow-scrolling:touch;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}#root{min-height:100vh;min-height:100dvh;width:100%;display:flex;flex-direction:column}button{border-radius:8px;border:2px solid transparent;font-family:inherit;cursor:pointer;transition:all .15s ease-in-out;min-height:44px;min-width:44px;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;font-size:16px;touch-action:manipulation;-ms-touch-action:manipulation}button:focus,button:focus-visible{outline:3px solid #27ae60;outline-offset:2px}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2}html,body{overflow-x:hidden}@media (prefers-contrast: high){:root{--border-width: 3px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}#root{width:100%;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding:8px;align-items:center;justify-content:flex-start}@media (min-width: 768px){#root{padding:16px;max-width:800px;margin:0 auto}}@media (min-width: 1024px){#root{padding:24px;max-width:1200px}}@media (min-width: 1440px){#root{padding:32px;max-width:1440px}}@media (max-height: 600px) and (orientation: landscape){#root{padding:4px;justify-content:center}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@supports (padding: max(0px)){#root{padding-left:max(8px,env(safe-area-inset-left));padding-right:max(8px,env(safe-area-inset-right));padding-top:max(8px,env(safe-area-inset-top));padding-bottom:max(8px,env(safe-area-inset-bottom))}}@media (orientation: landscape) and (max-height: 600px){#root{padding:max(4px,env(safe-area-inset-top)) max(4px,env(safe-area-inset-right)) max(4px,env(safe-area-inset-bottom)) max(4px,env(safe-area-inset-left))}}@media print{#root{display:none}body:after{content:"This is an interactive game that cannot be printed.";display:block;text-align:center;padding:50px;font-size:18px}}
