@keyframes checkPop{0%{transform:scale(0) rotate(-45deg);opacity:0}70%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}#main-container{position:fixed!important;top:0;left:0;width:100%;height:100vh;margin:0;padding:0;background:#f8f9fa;z-index:1000;overflow:hidden}@media (min-width:992px){#canvas-wrapper,.canvas-container{overflow:hidden;display:flex;align-items:center;justify-content:center}#canvas-wrapper{background:#e9ecef;height:100vh;padding:0;margin:0}#canvas{width:100vw!important;height:100vh!important;max-width:100vw;max-height:100vh;object-fit:contain;border:0;box-shadow:none;background:#fff;position:relative!important}.canvas-container{background-color:#e9ecef;width:auto!important;height:auto!important}.canvas-container .upper-canvas{cursor:default}}#canvas-wrapper,.canvas-container,.lower-canvas,.upper-canvas,canvas{touch-action:pan-x pan-y pinch-zoom!important;-webkit-user-select:none;user-select:none}.lower-canvas,.upper-canvas,canvas{touch-action:manipulation!important}.aperture-row{align-items:center;margin-bottom:8px;padding:8px;background:#f8f9fa;border-radius:6px;border:1px solid #dee2e6}@media (max-width:992px){#main-container{position:relative!important;overflow:auto}.container-fluid{display:flex;flex-direction:column;height:100vh;padding:0;margin:0;overflow:hidden}#canvas-wrapper,.canvas-container{display:flex;justify-content:center}#canvas-wrapper{order:1;flex:1 1 auto;min-height:40vh;overflow:hidden;align-items:flex-start;background:#e9ecef}.canvas-container{width:100%;height:100%;align-items:center}#canvas{width:100%!important;height:auto!important;max-height:none!important;object-fit:contain;display:block;margin:0 auto}#controls,#controls-two{order:2;flex:0 1 auto;max-height:50vh;-webkit-overflow-scrolling:touch;background:#fff;border-top:1px solid #dee2e6}}.aperture-row input{font-size:12px;height:24px!important;width:45px}.aperture-row.selected{background:#e3f2fd;border-color:#007bff}.aperture-row button{font-size:16px;padding:2px 8px}.sidebar-right{right:0;border-left:1px solid #dee2e6;border-right:none}#controls,#controls-two{max-height:100vh;-webkit-overflow-scrolling:touch;padding:1rem}.form-range::-webkit-slider-runnable-track{background-color:#fff}.form-switch .form-check-input:checked{background-color:#222529;border-color:#fff}.joystick-container{display:grid;grid-template-columns:repeat(3,40px);grid-template-rows:repeat(3,40px);gap:1px;width:fit-content;padding:6px;border-radius:20px;margin:20px auto}.filter-check+label,.joy-btn{cursor:pointer;user-select:none}.joy-btn{background:#fff;border:0;border-radius:50%;width:40px;height:40px;color:#222529;font-size:28px;font-weight:700;box-shadow:0 5px 15px rgba(0,0,0,.4);transition:all .2s ease;outline:0}.joy-btn:hover{background:#96a9bb;box-shadow:0 8px 20px rgba(0,0,0,.5)}.joy-btn:active{transform:translateY(2px);box-shadow:0 2px 8px rgba(0,0,0,.4)}.joy-down:hover{transform:translateY(3px)}.joy-up:hover{transform:translateY(-3px)}.joy-left:hover{transform:translateX(-3px)}.joy-right:hover{transform:translateX(3px)}.joy-up{grid-column:2;grid-row:1}.joy-left{grid-column:1;grid-row:2}.joy-center{grid-column:2;grid-row:2;background:#0c2d47;font-size:26px}.joy-right{grid-column:3;grid-row:2}.joy-down{grid-column:2;grid-row:3}.joy-center:hover{background:#0056b3;box-shadow:0 0 20px rgba(0,123,255,.6)}.aperture-row small{font-size:10px;display:block}.upper-canvas{cursor:default}.btn-group .btn.active{background-color:#fff;color:#222529!important;border-color:#fff}.aperture-item{padding:8px;background:#f9f9f9;border:1px solid #ddd;border-radius:4px;margin-bottom:6px}.aperture-item.selected{background:#e3f2fd;border-color:#007bff}.btn-outline-light{border:1px solid #fff}.filter-check{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.filter-check+label{position:relative;padding-left:25px;font-weight:500;color:#00c1d5;display:inline-block;line-height:1;transition:color .3s ease;padding-top:4px;font-size:12px}.filter-check+label::before{content:'';position:absolute;left:0;top:0;width:20px;height:20px;background:rgba(255,255,255,.1);border:2px solid rgba(0,193,213,.4);border-radius:5px;transition:all .3s cubic-bezier(.25,.46,.45,.94);backdrop-filter:blur(4px)}.filter-check+label:hover::before{border-color:#00c1d5;box-shadow:0 0 20px rgba(0,193,213,.4);transform:scale(1.05)}.filter-check:checked+label::before{background:#00c1d5;border-color:#00c1d5;box-shadow:0 0 25px rgba(0,193,213,.6)}.filter-check:checked+label::after{content:'\2713';position:absolute;left:4px;font-size:14px;font-weight:700;color:#fff;animation:checkPop .3s ease}.filter-check:checked+label{color:#00c1d5}.filter-check:focus+label::before{box-shadow:0 0 0 4px rgba(0,193,213,.3)}.filter-check:checked+label:hover::before{box-shadow:0 0 35px rgba(0,193,213,.8);transform:scale(1.1)}