*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{margin:0;font-family:Arial,sans-serif;background-color:#111827;display:flex;justify-content:center;align-items:center;min-height:100vh;overflow:hidden}button{font-family:inherit;cursor:pointer;border:none;outline:none}.app-outer-wrapper{display:flex;justify-content:center;align-items:center;width:100vw;height:100vh}.app-container{background-color:#1f2937;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 25px 50px -12px #00000040;position:relative}.game-container{position:relative;background-color:#d1d5db;overflow:hidden;outline:none;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:4px solid #374151;border-radius:.375rem}.hud{position:absolute;top:0;left:0;right:0;padding:1rem;background-color:#00000080;color:#fff;display:flex;justify-content:space-between;align-items:center;z-index:50}.hud-score,.hud-time{font-size:1.5rem;font-weight:700}.hud-controls-toggle-group{display:flex;align-items:center}.hud-controls-toggle-group>*:not(:last-child){margin-right:1rem}.hud-controls-button{padding:.25rem .75rem;background-color:#4b5563;color:#fff;font-size:1.125rem;font-weight:700;border-radius:9999px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.hud-controls-button:hover{background-color:#6b7280}.hud-controls-button:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #6b7280}.player-element{position:absolute;transform:translateZ(0)}.platform-element{position:absolute;background-color:#4b5563;border:1px solid black}.coin-element{position:absolute;background-color:#eab308;border:1px solid #b45309;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#78350f;font-weight:700;font-size:.75rem}.portal-element{position:absolute;background-color:#9333ea;border:2px solid #6b21a8;border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;transform:translateZ(0);opacity:1;transition:opacity .3s ease-in-out}.portal-element-inactive{opacity:.5}.screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.start-screen{background-color:#e5e7eb}.start-screen-title{font-size:3rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.start-screen-graphic-container{margin-bottom:2rem;display:flex;align-items:center;justify-content:center}.start-screen-text-lg{font-size:1.125rem;color:#374151;margin-bottom:.5rem}.start-screen-text-md{font-size:1rem;color:#4b5563;margin-bottom:2rem}.start-screen-button{padding:1rem 2rem;background-color:#eab308;color:#000;font-size:1.5rem;font-weight:700;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:background-color .15s ease-in-out}.start-screen-button:hover{background-color:#facc15}.start-screen-button:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #ca8a04,0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.level-complete-screen{background-color:#d1fae5;color:#166534}.game-over-screen{background-color:#fee2e2;color:#991b1b}.inter-level-screen{background-color:#dbeafe;color:#1e40af}.screen-title{font-size:2.25rem;font-weight:700;margin-bottom:1rem}.game-over-screen .screen-title{margin-bottom:1.5rem}.inter-level-screen .screen-title{margin-bottom:1rem}.screen-text-xl{font-size:1.25rem;margin-bottom:.5rem}.inter-level-screen .screen-text-xl{margin-bottom:.25rem}.screen-text-2xl-bold{font-size:1.5rem;font-weight:700;margin-bottom:2rem}.inter-level-screen .screen-text-2xl-bold{margin-bottom:1.5rem}.screen-button-container{display:flex;flex-direction:column}.screen-button-container>*:not(:last-child){margin-bottom:1rem}@media (min-width: 768px){.screen-button-container{flex-direction:row}.screen-button-container>*:not(:last-child){margin-bottom:0;margin-right:1rem}}.screen-button{padding:.75rem 1.5rem;color:#fff;font-size:1.25rem;font-weight:600;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:background-color .15s ease-in-out}.screen-button:focus{outline:2px solid transparent;outline-offset:2px}.screen-button-green{background-color:#22c55e}.screen-button-green:hover{background-color:#16a34a}.screen-button-green:focus{box-shadow:0 0 0 2px #15803d}.screen-button-red{background-color:#ef4444}.screen-button-red:hover{background-color:#dc2626}.screen-button-red:focus{box-shadow:0 0 0 2px #b91c1c}.screen-button-blue{background-color:#3b82f6}.screen-button-blue:hover{background-color:#2563eb}.screen-button-blue:focus{box-shadow:0 0 0 2px #1d4ed8}.screen-button-gray{background-color:#6b7280}.screen-button-gray:hover{background-color:#4b5563}.screen-button-gray:focus{box-shadow:0 0 0 2px #374151}.controls-tooltip{position:absolute;top:5rem;right:1rem;background-color:#374151f2;color:#fff;padding:1rem;border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;z-index:60;width:15rem}.controls-tooltip-close-button{position:absolute;top:.5rem;right:.5rem;color:#d1d5db;font-size:1.5rem;line-height:1;font-weight:700;background:none;border:none}.controls-tooltip-close-button:hover{color:#fff}.controls-tooltip-title{font-weight:700;margin-bottom:.5rem;font-size:1.125rem;border-bottom:1px solid #4b5563;padding-bottom:.25rem}.controls-tooltip-list{list-style:none;padding:0;margin:0;font-size:.875rem}.controls-tooltip-list li:not(:last-child){margin-bottom:.25rem}.controls-tooltip-key{font-weight:600;color:#facc15}.reset-button-debug{position:absolute;bottom:.5rem;left:.5rem;background-color:#dc2626;color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .75rem;border-radius:.25rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:70}.reset-button-debug:hover{background-color:#b91c1c}.reset-button-debug:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #f87171bf}.rainbow-flash-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:90;animation:rainbowFlash .7s linear forwards;pointer-events:none}.red-flash-screen-overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:95;animation:redScreenFlash .9s linear forwards;pointer-events:none}.angry-holder-wrapper{position:absolute}.touch-controls-container{position:absolute;bottom:20px;left:20px;right:20px;display:flex;justify-content:space-between;align-items:flex-end;z-index:100;pointer-events:none}.touch-button{background-color:#32323299;color:#fff;border:2px solid rgba(200,200,200,.7);border-radius:50%;width:80px;height:80px;display:flex;justify-content:center;align-items:center;font-size:36px;font-weight:700;-webkit-user-select:none;user-select:none;pointer-events:auto;box-shadow:0 3px 6px #0003;transition:background-color .1s ease,transform .05s ease}.touch-button:active{background-color:#505050cc;transform:scale(.95)}.touch-controls-move{display:flex;pointer-events:auto}.touch-controls-move .touch-button:first-child{margin-right:30px}@media (max-width: 768px){.hud-score,.hud-time{font-size:1.25rem}.hud-controls-button{font-size:1rem;padding:.2rem .6rem}}@media (max-width: 480px){.touch-controls-container{bottom:10px;left:10px;right:10px}.touch-button{width:65px;height:65px;font-size:28px}.touch-controls-move .touch-button:first-child{margin-right:20px}.hud-score,.hud-time{font-size:1rem}.hud-controls-button{font-size:.8rem;padding:.15rem .5rem}}
