@import "https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0;cursor:url(/assets/sprites/cursor.svg),auto!important}html,body{color:#e0e0e0;background:#1a1a2e;width:100%;height:100%;font-family:"Press Start 2P",monospace;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#12121e}::-webkit-scrollbar-thumb{background:#336;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#4a4a80}::-webkit-scrollbar-corner{background:#12121e}*{scrollbar-width:thin;scrollbar-color:#336 #12121e}#game-canvas{width:100%;height:100%;display:block;position:absolute;top:0;left:0;cursor:url(/assets/sprites/cursor.svg),crosshair!important}#ui-overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}#ui-overlay>*{pointer-events:auto}#screen-container{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.menu-btn{color:#e0e0e0;text-shadow:1px 1px #000;letter-spacing:1px;background:#2a2a4a;border:2px solid #444;border-radius:0;justify-content:center;align-items:center;gap:8px;width:300px;margin:.6rem auto;padding:.85rem 1.5rem;font-family:"Press Start 2P",monospace;font-size:.85rem;transition:background .15s,border-color .15s;display:flex}.menu-btn:hover{color:#fff;background:#3a3a6a;border-color:#f0c040}.menu-btn:disabled{opacity:.35;cursor:url(/assets/sprites/cursor.svg),crosshair!important}.menu-btn-sm{color:#e0e0e0;text-shadow:1px 1px #000;background:#2a2a4a;border:2px solid #444;border-radius:0;align-items:center;gap:6px;padding:.5rem .9rem;font-family:"Press Start 2P",monospace;font-size:.65rem;transition:background .15s,border-color .15s;display:inline-flex}.menu-btn-sm:hover{color:#fff;background:#3a3a6a;border-color:#f0c040}.menu-btn-sm:disabled{opacity:.35;cursor:url(/assets/sprites/cursor.svg),crosshair!important}.menu-btn-sm.active{color:#f0c040;background:#3a3a6a;border-color:#f0c040}.px-arrow{width:14px;height:12px;image-rendering:pixelated;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='12' fill='%23e0e0e0'%3E%3Crect x='0' y='5' width='2' height='2'/%3E%3Crect x='2' y='3' width='2' height='2'/%3E%3Crect x='2' y='7' width='2' height='2'/%3E%3Crect x='4' y='1' width='2' height='2'/%3E%3Crect x='4' y='9' width='2' height='2'/%3E%3Crect x='4' y='5' width='10' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.menu-btn-sm:hover .px-arrow,.builder-btn:hover .px-arrow{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='12' fill='%23fff'%3E%3Crect x='0' y='5' width='2' height='2'/%3E%3Crect x='2' y='3' width='2' height='2'/%3E%3Crect x='2' y='7' width='2' height='2'/%3E%3Crect x='4' y='1' width='2' height='2'/%3E%3Crect x='4' y='9' width='2' height='2'/%3E%3Crect x='4' y='5' width='10' height='2'/%3E%3C/svg%3E")}.px-play{width:12px;height:14px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='14' fill='%23e0e0e0'%3E%3Crect x='0' y='0' width='2' height='14'/%3E%3Crect x='2' y='2' width='2' height='10'/%3E%3Crect x='4' y='4' width='2' height='6'/%3E%3Crect x='6' y='5' width='2' height='4'/%3E%3Crect x='8' y='6' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.menu-btn:hover .px-play,.menu-btn-sm:hover .px-play,.builder-btn:hover .px-play,.overlay-btn:hover .px-play{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='14' fill='%23fff'%3E%3Crect x='0' y='0' width='2' height='14'/%3E%3Crect x='2' y='2' width='2' height='10'/%3E%3Crect x='4' y='4' width='2' height='6'/%3E%3Crect x='6' y='5' width='2' height='4'/%3E%3Crect x='8' y='6' width='2' height='2'/%3E%3C/svg%3E")}.px-play-sm{width:8px;height:10px;image-rendering:pixelated;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='10' fill='%2381c784'%3E%3Crect x='0' y='0' width='2' height='10'/%3E%3Crect x='2' y='2' width='2' height='6'/%3E%3Crect x='4' y='3' width='2' height='4'/%3E%3Crect x='6' y='4' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.level-card-test:hover .px-play-sm{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='10' fill='%23a5d6a7'%3E%3Crect x='0' y='0' width='2' height='10'/%3E%3Crect x='2' y='2' width='2' height='6'/%3E%3Crect x='4' y='3' width='2' height='4'/%3E%3Crect x='6' y='4' width='2' height='2'/%3E%3C/svg%3E")}.px-edit{width:10px;height:10px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23e0e0e0'%3E%3Crect x='8' y='0' width='2' height='2'/%3E%3Crect x='6' y='2' width='2' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3Crect x='2' y='6' width='2' height='2'/%3E%3Crect x='0' y='8' width='2' height='2'/%3E%3Crect x='0' y='6' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-x{width:8px;height:8px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' fill='%23ef9a9a'%3E%3Crect x='0' y='0' width='2' height='2'/%3E%3Crect x='6' y='0' width='2' height='2'/%3E%3Crect x='2' y='2' width='2' height='2'/%3E%3Crect x='4' y='2' width='2' height='2'/%3E%3Crect x='2' y='4' width='2' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3Crect x='0' y='6' width='2' height='2'/%3E%3Crect x='6' y='6' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.level-card-delete:hover .px-x{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' fill='%23ffcdd2'%3E%3Crect x='0' y='0' width='2' height='2'/%3E%3Crect x='6' y='0' width='2' height='2'/%3E%3Crect x='2' y='2' width='2' height='2'/%3E%3Crect x='4' y='2' width='2' height='2'/%3E%3Crect x='2' y='4' width='2' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3Crect x='0' y='6' width='2' height='2'/%3E%3Crect x='6' y='6' width='2' height='2'/%3E%3C/svg%3E")}.px-copy{width:10px;height:10px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%2390caf9'%3E%3Crect x='0' y='2' width='6' height='2'/%3E%3Crect x='0' y='2' width='2' height='8'/%3E%3Crect x='0' y='8' width='6' height='2'/%3E%3Crect x='4' y='2' width='2' height='8'/%3E%3Crect x='4' y='0' width='6' height='2'/%3E%3Crect x='4' y='0' width='2' height='8'/%3E%3Crect x='4' y='6' width='6' height='2'/%3E%3Crect x='8' y='0' width='2' height='8'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.level-card-duplicate:hover .px-copy{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23bbdefb'%3E%3Crect x='0' y='2' width='6' height='2'/%3E%3Crect x='0' y='2' width='2' height='8'/%3E%3Crect x='0' y='8' width='6' height='2'/%3E%3Crect x='4' y='2' width='2' height='8'/%3E%3Crect x='4' y='0' width='6' height='2'/%3E%3Crect x='4' y='0' width='2' height='8'/%3E%3Crect x='4' y='6' width='6' height='2'/%3E%3Crect x='8' y='0' width='2' height='8'/%3E%3C/svg%3E")}.px-check{width:10px;height:8px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' fill='%2381c784'%3E%3Crect x='8' y='0' width='2' height='2'/%3E%3Crect x='6' y='2' width='2' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3Crect x='2' y='4' width='2' height='2'/%3E%3Crect x='0' y='2' width='2' height='4'/%3E%3Crect x='2' y='6' width='4' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-chevron-down{width:10px;height:8px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' fill='%23e0e0e0'%3E%3Crect x='0' y='0' width='2' height='2'/%3E%3Crect x='8' y='0' width='2' height='2'/%3E%3Crect x='2' y='2' width='2' height='2'/%3E%3Crect x='6' y='2' width='2' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-chevron-up{width:10px;height:8px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' fill='%23e0e0e0'%3E%3Crect x='4' y='0' width='2' height='2'/%3E%3Crect x='2' y='2' width='2' height='2'/%3E%3Crect x='6' y='2' width='2' height='2'/%3E%3Crect x='0' y='4' width='2' height='2'/%3E%3Crect x='8' y='4' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-close{width:10px;height:10px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23e0e0e0'%3E%3Crect x='0' y='0' width='2' height='2'/%3E%3Crect x='8' y='0' width='2' height='2'/%3E%3Crect x='2' y='2' width='2' height='2'/%3E%3Crect x='6' y='2' width='2' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3Crect x='2' y='6' width='2' height='2'/%3E%3Crect x='6' y='6' width='2' height='2'/%3E%3Crect x='0' y='8' width='2' height='2'/%3E%3Crect x='8' y='8' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-warning{width:10px;height:10px;image-rendering:pixelated;vertical-align:middle;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23f44336'%3E%3Crect x='4' y='0' width='2' height='2'/%3E%3Crect x='3' y='2' width='4' height='2'/%3E%3Crect x='2' y='4' width='6' height='2'/%3E%3Crect x='1' y='6' width='8' height='2'/%3E%3Crect x='0' y='8' width='10' height='2'/%3E%3Crect x='4' y='2' width='2' height='4' fill='%23000'/%3E%3Crect x='4' y='8' width='2' height='2' fill='%23000'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-star{width:10px;height:10px;image-rendering:pixelated;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23ffd700'%3E%3Crect x='4' y='0' width='2' height='2'/%3E%3Crect x='2' y='2' width='6' height='2'/%3E%3Crect x='0' y='4' width='10' height='2'/%3E%3Crect x='2' y='6' width='6' height='2'/%3E%3Crect x='2' y='6' width='2' height='2'/%3E%3Crect x='6' y='6' width='2' height='2'/%3E%3Crect x='0' y='8' width='2' height='2'/%3E%3Crect x='8' y='8' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-check-sm{width:10px;height:10px;image-rendering:pixelated;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%234caf50'%3E%3Crect x='8' y='0' width='2' height='2'/%3E%3Crect x='6' y='2' width='2' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3Crect x='2' y='6' width='2' height='2'/%3E%3Crect x='0' y='4' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-dropdown{-webkit-user-select:none;user-select:none;min-width:180px;font-family:"Press Start 2P",monospace;font-size:.7rem;display:inline-block;position:relative}.px-dropdown-selected{color:#e0e0e0;text-shadow:1px 1px #000;white-space:nowrap;background:#224;border:2px solid #444;justify-content:space-between;align-items:center;gap:10px;padding:8px 12px;display:flex}.px-dropdown-selected:hover{background:#2a2a50;border-color:#f0c040}.px-dropdown-selected:after{content:"";width:10px;height:8px;image-rendering:pixelated;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' fill='%23888'%3E%3Crect x='0' y='0' width='10' height='2'/%3E%3Crect x='2' y='2' width='6' height='2'/%3E%3Crect x='4' y='4' width='2' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.px-dropdown.open .px-dropdown-selected{z-index:301;background:#2a2a50;border-color:#f0c040 #f0c040 #1a1a36;position:relative}.px-dropdown.open .px-dropdown-selected:after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' fill='%23f0c040'%3E%3Crect x='4' y='2' width='2' height='2'/%3E%3Crect x='2' y='4' width='6' height='2'/%3E%3Crect x='0' y='6' width='10' height='2'/%3E%3C/svg%3E")}.px-dropdown-list{z-index:300;background:#1a1a36;border:2px solid #f0c040;border-top:none;margin-top:-2px;display:none;position:absolute;top:100%;left:0;right:0}.px-dropdown.open .px-dropdown-list{display:block}.px-dropdown-item{color:#ccc;white-space:nowrap;text-shadow:1px 1px #000;padding:8px 12px}.px-dropdown-item:hover{color:#fff;background:#2a2a50}.px-dropdown-item.selected{color:#f0c040}@keyframes kenBurns{0%{transform:scale(1.15)translate(0)}25%{transform:scale(1.22)translate(-1.5%,-1%)}50%{transform:scale(1.18)translate(-.5%,1%)}75%{transform:scale(1.25)translate(1%,-.5%)}to{transform:scale(1.15)translate(0)}}.start-screen{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.start-screen:before{content:"";will-change:transform;background:url(/assets/title.png) 50%/cover no-repeat;animation:50s ease-in-out infinite kenBurns;position:absolute;inset:-10%}.start-bg-overlay{pointer-events:none;background:radial-gradient(#1a1a2e80 0%,#0a0a14e6 100%);position:absolute;inset:0}.level-browser{width:100%;height:100%;position:relative;overflow:hidden}.level-browser:before{content:"";filter:brightness(.55)saturate(.8);will-change:transform;background:url(/assets/title.png) 50%/cover no-repeat;animation:60s ease-in-out infinite kenBurns;position:absolute;inset:-10%}.level-browser:after{content:"";pointer-events:none;background:radial-gradient(at top,#1a1a2ea6 0%,#0a0a14eb 80%);position:absolute;inset:0}.level-browser>.screen-panel{z-index:1;-webkit-backdrop-filter:blur(6px);background:#1a1a2e8c;position:relative}.start-content{text-align:center;z-index:1;position:relative}.start-logo-img{width:96px;height:96px;image-rendering:pixelated;filter:drop-shadow(0 0 16px #f0c04040);margin-bottom:.8rem}.start-logo{color:#f0c040;text-shadow:3px 3px #000,0 0 30px #f0c0404d;letter-spacing:6px;margin-bottom:.4rem;font-size:3rem}.start-tagline{color:#ccc;letter-spacing:3px;text-shadow:1px 1px 4px #000c;margin-bottom:2.5rem;font-size:.75rem}.start-menu{flex-direction:column;align-items:center;gap:0;display:flex}.menu-btn-settings{margin-top:30px}.start-version{color:#fff;letter-spacing:2px;text-shadow:1px 1px 4px #000c;font-size:.55rem}.start-footer{flex-direction:column;align-items:center;gap:.6rem;margin-top:2.5rem;display:flex}.start-features{justify-content:center;align-items:center;gap:16px;margin-bottom:2rem;display:flex}.start-feature{flex-direction:column;align-items:center;gap:4px;display:flex}.start-feature-num{color:#f0c040;text-shadow:2px 2px #000;letter-spacing:2px;font-size:1.1rem}.start-feature-label{color:#ccc;letter-spacing:1px;text-shadow:1px 1px 4px #000c;font-size:.45rem}.start-feature-sep{opacity:.5;background:#444;width:2px;height:28px}.menu-btn-primary{color:#f0c040!important;background:#3a3020!important;border-color:#f0c040!important}.menu-btn-primary:hover{color:#ffd866!important;background:#4a3d28!important;border-color:#ffd866!important}.menu-btn-secondary{color:#c8a83a!important;background:#1e1e36!important;border-color:#7a6530!important}.menu-btn-secondary:hover{color:#f0c040!important;background:#2a2840!important;border-color:#f0c040!important}.legal-links{align-items:center;gap:10px;display:flex}.legal-link{color:#ddd;letter-spacing:1px;background:0 0;border:none;padding:2px 0;font-family:"Press Start 2P",monospace;font-size:.5rem;transition:color .2s}.legal-link:hover{color:#fff}.legal-sep{background:#aaa;width:2px;height:10px}.auth-legal{margin-top:20px}.legal-overlay{z-index:700;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.legal-modal{background:#1a1a36;border:2px solid #f0c040;flex-direction:column;width:90%;max-width:540px;height:80vh;max-height:640px;display:flex;position:relative;overflow:hidden}.legal-modal-header{justify-content:flex-end;align-items:center;padding:12px 12px 0;display:flex}.legal-modal-body{scrollbar-width:thin;scrollbar-color:#f0c040 #111128;flex:1;padding:20px 24px;overflow-y:auto}.legal-modal-body::-webkit-scrollbar{width:8px}.legal-modal-body::-webkit-scrollbar-track{background:#111128}.legal-modal-body::-webkit-scrollbar-thumb{background:#f0c040;border-radius:4px}.legal-modal-body h3{color:#f0c040;text-shadow:2px 2px #000;letter-spacing:2px;margin-bottom:8px;font-size:.85rem}.legal-modal-body h4{color:#f0c040;letter-spacing:1px;margin-top:18px;margin-bottom:6px;font-size:.6rem}.legal-modal-body p{color:#bbb;margin-bottom:6px;font-size:.5rem;line-height:1.8}.legal-modal-body .legal-updated{color:#666;margin-bottom:14px;font-size:.45rem}.screen-panel{background:#1a1a2e;flex-direction:column;width:100%;height:100%;padding:24px 32px;display:flex;overflow-y:auto}.screen-header{flex-shrink:0;align-items:center;gap:16px;margin-bottom:20px;display:flex}.screen-title{color:#f0c040;text-shadow:2px 2px #000;letter-spacing:2px;font-size:1.1rem}.level-source-tabs{background:#2249;border:2px solid #333;flex-shrink:0;gap:4px;margin-bottom:16px;padding:3px;display:inline-flex}.level-source-tabs .source-tab{text-align:center;flex:1;padding:8px 12px;transition:all .2s;color:#888!important;background:0 0!important;border:none!important}.level-source-tabs .source-tab:hover{color:#ccc!important;background:#3a3a6a66!important}.level-source-tabs .source-tab.active{text-shadow:0 0 8px #f0c0404d;color:#f0c040!important;background:#f0c04026!important}.level-filters{background:#2246;border:1px solid #44446680;flex-wrap:wrap;flex-shrink:0;align-items:flex-end;gap:12px;margin-bottom:20px;padding:10px 14px;display:inline-flex}.level-filters label{color:#888;letter-spacing:1px;flex-direction:column;gap:6px;font-size:.6rem;display:flex}.level-filters select,.level-filters input{color:#e0e0e0;background:#224;border:2px solid #444;padding:12px 10px;font-family:"Press Start 2P",monospace;font-size:.65rem}.level-filters select:focus,.level-filters input:focus{border-color:#f0c040;outline:none}.level-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));align-content:start;align-items:start;gap:16px;display:grid}.level-card{-webkit-backdrop-filter:blur(4px);background:#222244bf;border:4px solid #4469;flex-direction:column;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;overflow:hidden}.level-card:hover{border-color:#f0c040;transform:translateY(-3px);box-shadow:0 6px 24px #f0c0401f,0 2px 8px #0000004d}.level-card-thumb{aspect-ratio:16/9;background:#0d0d22;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.level-card-thumb img{object-fit:cover;width:100%;height:100%;image-rendering:pixelated}.level-card-no-thumb{color:#444;font-size:1.5rem}.level-card-info{flex-direction:column;flex:1;padding:10px;display:flex}.level-card-title{color:#e0e0e0;white-space:nowrap;text-overflow:ellipsis;margin-bottom:8px;font-size:.75rem;overflow:hidden}.level-card-meta{justify-content:space-between;align-items:center;margin-bottom:0;display:flex}.level-card-creator{color:#888;font-size:.55rem}.level-card-diff{border:1px solid #555;padding:3px 8px;font-size:.55rem}.level-card-stats{color:#888;align-items:center;gap:10px;margin-top:auto;padding-top:10px;font-size:.55rem;display:flex}.level-card-plays,.level-card-score{align-items:center;gap:4px;display:inline-flex}.level-card-score{color:gold}.level-card-desc{color:#777;max-height:3.2em;margin-top:6px;font-size:.55rem;line-height:1.6;overflow:hidden}.level-empty{color:#555;text-align:center;letter-spacing:2px;grid-column:1/-1;padding:40px 20px;font-size:.75rem}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.level-card-enter{animation:.35s ease-out both cardFadeIn}.diff-beginner{color:#4fc3f7;border-color:#4fc3f7}.diff-easy{color:#81c784;border-color:#81c784}.diff-normal{color:#f0c040;border-color:#f0c040}.diff-hard{color:#ff8a65;border-color:#ff8a65}.diff-brutal{color:#ef5350;border-color:#ef5350}.level-pagination{flex-shrink:0;justify-content:center;align-items:center;gap:16px;padding:16px 0;display:flex}.pag-arrow-btn{cursor:default;background:#2a2a4a;border:2px solid #444;justify-content:center;align-items:center;padding:8px 12px;transition:background .15s,border-color .15s;display:inline-flex}.pag-arrow-btn:hover:not(:disabled){background:#3a3a6a;border-color:#f0c040}.pag-arrow-btn:disabled{opacity:.35;cursor:default}.px-arrow-right{width:14px;height:12px;image-rendering:pixelated;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='12' fill='%23e0e0e0'%3E%3Crect x='12' y='5' width='2' height='2'/%3E%3Crect x='10' y='3' width='2' height='2'/%3E%3Crect x='10' y='7' width='2' height='2'/%3E%3Crect x='8' y='1' width='2' height='2'/%3E%3Crect x='8' y='9' width='2' height='2'/%3E%3Crect x='0' y='5' width='10' height='2'/%3E%3C/svg%3E") 50% no-repeat;flex-shrink:0;display:inline-block}.pag-arrow-btn:hover:not(:disabled) .px-arrow,.pag-arrow-btn:hover:not(:disabled) .px-arrow-right{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='12' fill='%23fff'%3E%3Crect x='12' y='5' width='2' height='2'/%3E%3Crect x='10' y='3' width='2' height='2'/%3E%3Crect x='10' y='7' width='2' height='2'/%3E%3Crect x='8' y='1' width='2' height='2'/%3E%3Crect x='8' y='9' width='2' height='2'/%3E%3Crect x='0' y='5' width='10' height='2'/%3E%3C/svg%3E")}.pag-arrow-btn:hover:not(:disabled) .px-arrow{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='12' fill='%23fff'%3E%3Crect x='0' y='5' width='2' height='2'/%3E%3Crect x='2' y='3' width='2' height='2'/%3E%3Crect x='2' y='7' width='2' height='2'/%3E%3Crect x='4' y='1' width='2' height='2'/%3E%3Crect x='4' y='9' width='2' height='2'/%3E%3Crect x='4' y='5' width='10' height='2'/%3E%3C/svg%3E")}.pag-info{color:#888;letter-spacing:1px;font-size:.6rem}.sb-tabs{flex-shrink:0;gap:8px;margin-bottom:16px;display:flex}.sb-layout{flex:1;gap:20px;min-height:0;display:flex}.sb-target-list{flex-direction:column;flex-shrink:0;gap:4px;width:240px;padding-right:8px;display:flex;overflow-y:auto}.sb-target-btn{text-align:left;color:#ccc;white-space:nowrap;text-overflow:ellipsis;background:#224;border:2px solid #333;width:100%;padding:10px 12px;font-family:"Press Start 2P",monospace;font-size:.55rem;transition:border-color .15s;display:block;overflow:hidden}.sb-target-btn:hover{border-color:#f0c040}.sb-target-btn.active{color:#f0c040;background:#2a2a4a;border-color:#f0c040}.sb-table-wrap{flex:1;overflow-y:auto}.sb-table{width:100%}.sb-row{color:#ccc;border-bottom:1px solid #2a2a4a;align-items:center;gap:12px;padding:10px 12px;font-size:.6rem;display:flex}.sb-row.sb-header{color:#888;letter-spacing:1px;border-bottom:2px solid #333;font-size:.5rem}.sb-rank{flex-shrink:0;align-items:center;gap:6px;width:40px;display:flex}.sb-name{flex:1;min-width:0}.sb-score{text-align:right;color:#f0c040;flex-shrink:0;width:100px}.sb-waves{text-align:right;flex-shrink:0;width:70px}.sb-diff{text-align:right;flex-shrink:0;width:80px}.sb-maps{text-align:right;color:#90caf9;flex-shrink:0;width:70px}.sb-row-clickable{cursor:pointer;transition:background .15s}.sb-row-clickable:hover{background:#f0c04014}.px-medal{width:12px;height:14px;image-rendering:pixelated;flex-shrink:0;display:inline-block}.px-medal-gold{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='14' shape-rendering='crispEdges'%3E%3Crect x='4' y='0' width='4' height='2' fill='%23e53935'/%3E%3Crect x='2' y='2' width='2' height='2' fill='%23e53935'/%3E%3Crect x='8' y='2' width='2' height='2' fill='%23e53935'/%3E%3Crect x='4' y='4' width='4' height='2' fill='%23ffd54f'/%3E%3Crect x='2' y='6' width='8' height='2' fill='%23ffd54f'/%3E%3Crect x='2' y='8' width='8' height='2' fill='%23ffca28'/%3E%3Crect x='2' y='10' width='8' height='2' fill='%23ffd54f'/%3E%3Crect x='4' y='12' width='4' height='2' fill='%23ffca28'/%3E%3C/svg%3E") 50% no-repeat}.px-medal-silver{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='14' shape-rendering='crispEdges'%3E%3Crect x='4' y='0' width='4' height='2' fill='%234fc3f7'/%3E%3Crect x='2' y='2' width='2' height='2' fill='%234fc3f7'/%3E%3Crect x='8' y='2' width='2' height='2' fill='%234fc3f7'/%3E%3Crect x='4' y='4' width='4' height='2' fill='%23bdbdbd'/%3E%3Crect x='2' y='6' width='8' height='2' fill='%23e0e0e0'/%3E%3Crect x='2' y='8' width='8' height='2' fill='%23bdbdbd'/%3E%3Crect x='2' y='10' width='8' height='2' fill='%23e0e0e0'/%3E%3Crect x='4' y='12' width='4' height='2' fill='%23bdbdbd'/%3E%3C/svg%3E") 50% no-repeat}.px-medal-bronze{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='14' shape-rendering='crispEdges'%3E%3Crect x='4' y='0' width='4' height='2' fill='%2381c784'/%3E%3Crect x='2' y='2' width='2' height='2' fill='%2381c784'/%3E%3Crect x='8' y='2' width='2' height='2' fill='%2381c784'/%3E%3Crect x='4' y='4' width='4' height='2' fill='%23cd7f32'/%3E%3Crect x='2' y='6' width='8' height='2' fill='%23d4944a'/%3E%3Crect x='2' y='8' width='8' height='2' fill='%23cd7f32'/%3E%3Crect x='2' y='10' width='8' height='2' fill='%23d4944a'/%3E%3Crect x='4' y='12' width='4' height='2' fill='%23cd7f32'/%3E%3C/svg%3E") 50% no-repeat}.sb-pagination{flex-shrink:0;justify-content:center;align-items:center;gap:16px;padding:12px 0;display:flex}.sb-pag-info{color:#888;letter-spacing:1px;font-size:.5rem}.sb-modal-overlay{z-index:2000;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.sb-modal{background:#1a1a2e;border:2px solid #f0c040;flex-direction:column;width:90%;max-width:600px;max-height:80vh;padding:24px;display:flex}.sb-modal-header{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.sb-modal-title{color:#f0c040;font-family:"Press Start 2P",monospace;font-size:.65rem}.sb-modal-body{flex:1;min-height:0;overflow-y:auto}.sb-modal-row{color:#ccc;border-bottom:1px solid #2a2a4a;padding:8px 0;font-size:.55rem;display:flex}.sb-modal-map{flex:1}.sb-modal-score{text-align:right;color:#f0c040;flex-shrink:0;width:100px}.sb-full-table{flex-direction:column;flex:1;min-height:0;display:flex}.campaign-detail{flex:1}.campaign-meta{color:#888;margin-bottom:16px;font-size:.6rem;line-height:1.8}.campaign-meta p{color:#aaa;margin-top:8px}.campaign-maps-label{color:#f0c040;letter-spacing:1px;margin-bottom:8px;font-size:.65rem}.campaign-map-list{flex-direction:column;gap:6px;display:flex}.campaign-map-item{background:#224;border:1px solid #333;align-items:center;gap:10px;padding:10px 12px;font-size:.55rem;display:flex}.campaign-map-num{color:#f0c040;width:24px}.campaign-map-name{color:#ccc;flex:1}.campaign-map-ver{color:#666;font-size:.5rem}.campaign-form{max-width:500px}.campaign-form label{color:#888;letter-spacing:1px;flex-direction:column;gap:6px;margin-bottom:14px;font-size:.6rem;display:flex}.campaign-form input,.campaign-form textarea,.campaign-form select{color:#e0e0e0;resize:vertical;background:#224;border:2px solid #444;padding:12px 10px;font-family:"Press Start 2P",monospace;font-size:.65rem}.campaign-form input:focus,.campaign-form textarea:focus,.campaign-form select:focus{border-color:#f0c040;outline:none}.campaign-maps-section{margin:16px 0}.campaign-maps-hint{color:#666;margin-bottom:10px;font-size:.5rem;line-height:1.6}.campaign-add-maps{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.campaign-selected-maps{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.campaigns-section{flex:1;margin-bottom:0}.campaigns-header{align-items:center;gap:12px;margin-bottom:10px;display:flex}.campaigns-label{color:#f0c040;letter-spacing:2px;font-size:.65rem}.campaigns-list{flex-direction:column;gap:6px;display:flex}.campaign-card-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;padding-bottom:8px;display:grid!important}.campaign-card-grid .campaign-card{background:#222244b3;border:2px solid #f0c04040}.campaign-card-grid .campaign-card:hover{border-color:#f0c040;box-shadow:0 4px 20px #f0c04026}.campaign-card-thumbs{aspect-ratio:16/8;background:#181832;grid-template-columns:1fr 1fr;gap:2px;display:grid;overflow:hidden}.campaign-card-mini-thumb{background:#1a1a36;justify-content:center;align-items:center;display:flex;overflow:hidden}.campaign-card-mini-thumb img{object-fit:cover;width:100%;height:100%;image-rendering:pixelated}.campaign-draft-badge{color:#f0c040;border:1px solid #f0c040;border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:.45rem}.camp-edit-btn{flex-shrink:0;margin-top:6px}.campaign-description{color:#aaa;max-width:600px;margin-bottom:20px;font-size:.55rem;line-height:1.8}.map-detail-overlay{z-index:500;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.map-detail-panel{background:#1a1a36;border:2px solid #f0c040;flex-direction:column;width:90%;max-width:520px;max-height:85vh;display:flex;overflow:hidden}.map-detail-top{aspect-ratio:16/8;background:#0d0d22;flex-shrink:0;width:100%;position:relative;overflow:hidden}.map-detail-thumb-wide{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.map-detail-thumb-wide img{object-fit:cover;width:100%;height:100%;image-rendering:pixelated}.map-detail-close-x{z-index:2;background:#0a0a18cc;border:1px solid #555;justify-content:center;align-items:center;width:28px;height:28px;transition:border-color .15s;display:flex;position:absolute;top:8px;right:8px}.map-detail-close-x:hover{border-color:#f0c040}.map-detail-title-row{justify-content:space-between;align-items:center;gap:12px;padding:12px 16px 0;display:flex}.map-detail-title{color:#e0e0e0;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.8rem;overflow:hidden}.map-detail-subtitle{color:#888;align-items:center;gap:12px;padding:6px 16px 0;font-size:.5rem;display:flex}.map-detail-tabs{border-bottom:2px solid #333;gap:0;margin:12px 16px 0;display:flex}.map-detail-tab{color:#888;letter-spacing:1px;text-align:center;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:8px;font-family:"Press Start 2P",monospace;font-size:.5rem;transition:color .15s,border-color .15s;cursor:url(/assets/sprites/cursor.svg),crosshair!important}.map-detail-tab:hover{color:#ccc}.map-detail-tab.active{color:#f0c040;border-bottom-color:#f0c040}.map-detail-tab-content{flex:1;min-height:80px;padding:12px 16px;overflow-y:auto}.map-detail-description{color:#aaa;margin-bottom:12px;font-size:.5rem;line-height:2}.map-detail-my-score{color:#ccc;align-items:center;gap:8px;font-size:.55rem;line-height:1.6;display:flex}.map-detail-rank{color:#888}.map-detail-actions{border-top:1px solid #333;flex-shrink:0;padding:12px 16px}.map-detail-play-btn{width:100%}.sb-highlight{background:#f0c0401a}.level-card-completed{border:4px solid #4caf50}.level-card-completed .level-card-thumb:after{content:"";pointer-events:none;border-bottom:2px solid #4caf5059;position:absolute;inset:0}.level-card-completed-badge{color:#4caf50;letter-spacing:1px;white-space:nowrap;align-items:center;gap:4px;margin-left:auto;font-size:.5rem;display:flex}.campaign-maps-grid{gap:12px}.level-section-label{color:#f0c040;letter-spacing:2px;border-bottom:2px solid #333;margin-bottom:12px;padding-bottom:8px;font-size:.65rem}.campaign-status{min-height:1.2em;margin-top:10px;font-size:.6rem}.name-prompt-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.name-prompt-box{text-align:center;background:#1a1a2e;border:2px solid #f0c040;min-width:320px;padding:32px 40px}.name-prompt-title{color:#f0c040;letter-spacing:2px;margin-bottom:20px;font-size:.85rem}.name-prompt-input{color:#e0e0e0;text-align:center;background:#224;border:2px solid #444;width:100%;margin-bottom:20px;padding:14px 12px;font-family:"Press Start 2P",monospace;font-size:.75rem;display:block}.name-prompt-input:focus{border-color:#f0c040;outline:none}.name-prompt-btns{justify-content:center;gap:12px;display:flex}.name-prompt-ok{color:#f0c040!important;border-color:#f0c040!important}.my-maps-creator{align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.my-maps-creator label{color:#888;letter-spacing:1px;flex-direction:column;gap:6px;font-size:.6rem;display:flex}.my-maps-creator input{color:#e0e0e0;background:#224;border:2px solid #444;width:240px;padding:12px 10px;font-family:"Press Start 2P",monospace;font-size:.65rem}.my-maps-creator input:focus{border-color:#f0c040;outline:none}.my-maps-new{max-width:400px;width:100%!important;margin:0 0 20px!important}.my-maps-divider{color:#f0c040;letter-spacing:2px;border-bottom:2px solid #333;margin-bottom:12px;padding-bottom:10px;font-size:.65rem}.my-maps-filters{gap:6px;margin-bottom:14px;display:flex}.my-maps-filter{padding:5px 12px!important;font-size:.55rem!important}.my-maps-filter.active{color:#f0c040;background:#3a3a6a;border-color:#f0c040}.level-card-buttons{gap:6px;margin-top:6px;display:flex}.level-card-btn{white-space:nowrap;flex:1;justify-content:center;align-items:center;gap:4px;display:inline-flex;padding:6px 4px!important;font-size:.5rem!important}.level-card-test{color:#81c784!important;background:#1a3a1a!important;border-color:#4caf50!important}.level-card-test:hover{background:#2a5a2a!important}.level-card-duplicate{color:#90caf9!important;background:#1a2a3a!important;border-color:#42a5f5!important}.level-card-duplicate:hover{background:#2a3a5a!important}.level-card-delete{color:#ef9a9a!important;background:#3a1a1a!important;border-color:#ef5350!important}.level-card-delete:hover{background:#5a2020!important}.level-card-status{letter-spacing:1px;border:1px solid #555;padding:3px 8px;font-size:.55rem}.level-card-status-published{color:#81c784;background:#81c7841a;border-color:#81c784}.level-card-status-draft{color:#888;border-color:#555}.level-card-published{border-color:#81c7844d}.level-card-published:hover{border-color:#81c784}.px-confirm-overlay{z-index:9999;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.px-confirm-box{text-align:center;background:#0a0a18;border:3px solid #f0c040;min-width:320px;max-width:440px;padding:24px 28px}.px-confirm-title{color:#f0c040;text-shadow:1px 1px #000;letter-spacing:1px;margin-bottom:14px;font-family:"Press Start 2P",monospace;font-size:.75rem}.px-confirm-message{color:#ccc;text-shadow:1px 1px #000;margin-bottom:20px;font-family:"Press Start 2P",monospace;font-size:.55rem;line-height:2}.px-confirm-buttons{justify-content:center;gap:12px;display:flex}.px-confirm-buttons .menu-btn-sm{justify-content:center;min-width:100px}.px-confirm-btn-danger{color:#ef9a9a!important;background:#3a1a1a!important;border-color:#ef5350!important}.px-confirm-btn-danger:hover{color:#ffcdd2!important;background:#5a2020!important;border-color:#ff6b6b!important}.my-map-vis{border:1px solid #555;padding:1px 5px}.my-map-vis.draft{color:#888;border-color:#555}.my-map-vis.public{color:#81c784;border-color:#81c784}.my-map-vis.private{color:#f0c040;border-color:#f0c040}.title-screen{text-align:center}.title-screen h1{color:#f0c040;text-shadow:2px 2px 4px #00000080;margin-bottom:.5rem;font-size:2rem}.title-screen p{color:#aaa;margin-bottom:2rem;font-size:.8rem;line-height:1.6}.start-user{color:#ccc;letter-spacing:1px;text-shadow:1px 1px 4px #000c;margin-bottom:1.5rem;font-size:.6rem}.start-user-name{color:#f0c040}.my-maps-user{color:#888;letter-spacing:1px;margin-bottom:16px;font-size:.65rem}.my-maps-user-name{color:#f0c040}.auth-screen{background:0 0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-screen:before{content:"";filter:brightness(.5)saturate(.8);will-change:transform;background:url(/assets/title.png) 50%/cover no-repeat;animation:55s ease-in-out infinite kenBurns;position:absolute;inset:-10%}.auth-screen:after{content:"";pointer-events:none;background:radial-gradient(#1a1a2e99 0%,#0a0a14eb 80%);position:absolute;inset:0}.auth-box{z-index:1;text-align:center;width:100%;max-width:420px;position:relative}.auth-title{color:#f0c040;text-shadow:2px 2px #000;letter-spacing:3px;margin-bottom:24px;font-size:1.2rem}.auth-form{text-align:left}.auth-form label{color:#888;letter-spacing:1px;flex-direction:column;gap:8px;margin-bottom:16px;font-size:.65rem;display:flex}.auth-form input{color:#e0e0e0;background:#224;border:2px solid #444;padding:14px 12px;font-family:"Press Start 2P",monospace;font-size:.7rem}.auth-form input:focus{border-color:#f0c040;outline:none}.auth-submit{width:100%!important;margin-top:8px!important}.auth-error{color:#f44336;min-height:1.4em;margin-bottom:8px;font-size:.6rem;line-height:1.6}.auth-success{color:#4caf50;min-height:1.4em;margin-bottom:8px;font-size:.6rem;line-height:1.6}.auth-alt{color:#888;justify-content:center;align-items:center;gap:12px;margin-top:24px;font-size:.55rem;display:flex}.auth-forgot{text-align:center;margin-top:8px}.auth-forgot .menu-btn-sm{color:#aaa;font-size:.5rem}.auth-hint{color:#999;text-align:center;margin-bottom:12px;font-size:.55rem;line-height:1.5}.auth-back{margin-top:16px}.settings-divider{color:#f0c040;letter-spacing:2px;border-top:1px solid #333;margin-top:8px;padding:16px 0 8px;font-size:.65rem}.settings-overlay{z-index:600;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.settings-modal{background:#1a1a36;border:2px solid #f0c040;flex-direction:column;width:90%;max-width:480px;height:75vh;max-height:600px;display:flex;position:relative;overflow:hidden}.settings-modal .map-detail-close-x{flex-shrink:0;position:static}.settings-modal-header{justify-content:space-between;align-items:center;padding:16px 16px 0;display:flex}.settings-modal-title{color:#f0c040;text-shadow:2px 2px #000;letter-spacing:2px;margin:0;font-size:.9rem}.settings-modal .settings-tabs{margin:12px 16px;padding-bottom:4px}.settings-modal .settings-tab-content{scrollbar-width:thin;scrollbar-color:#f0c040 #111128;flex:1;padding:16px;overflow-y:auto}.settings-modal .settings-tab-content::-webkit-scrollbar{width:8px}.settings-modal .settings-tab-content::-webkit-scrollbar-track{background:#111128}.settings-modal .settings-tab-content::-webkit-scrollbar-thumb{background:#f0c040;border:1px solid #111128}.settings-modal .settings-tab-content::-webkit-scrollbar-thumb:hover{background:#ffd866}.settings-tabs{border-bottom:2px solid #333;gap:0;margin-bottom:0;display:flex}.settings-tab{color:#888;letter-spacing:1px;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;padding:10px 8px;font-family:"Press Start 2P",monospace;font-size:.55rem;transition:color .15s,border-color .15s;cursor:url(/assets/sprites/cursor.svg),crosshair!important}.settings-tab:hover{color:#ccc}.settings-tab.active{color:#f0c040;border-bottom-color:#f0c040}.settings-tab-content{min-height:140px}#tab-audio .auth-form label,#tab-ui .auth-form label{flex-direction:row;align-items:center;gap:12px}.auth-form input[type=range],#esc-settings-panel input[type=range]{appearance:none;background:#333;border:1px solid #555;border-radius:0;outline:none;height:8px;padding:0}.auth-form input[type=range]::-webkit-slider-thumb{appearance:none;background:gold;border:2px solid #a80;border-radius:0;width:20px;height:20px;cursor:url(/assets/sprites/cursor.svg),crosshair!important}#esc-settings-panel input[type=range]::-webkit-slider-thumb{appearance:none;background:gold;border:2px solid #a80;border-radius:0;width:20px;height:20px;cursor:url(/assets/sprites/cursor.svg),crosshair!important}.auth-form input[type=range]::-moz-range-thumb{background:gold;border:2px solid #a80;border-radius:0;width:20px;height:20px;cursor:url(/assets/sprites/cursor.svg),crosshair!important}#esc-settings-panel input[type=range]::-moz-range-thumb{background:gold;border:2px solid #a80;border-radius:0;width:20px;height:20px;cursor:url(/assets/sprites/cursor.svg),crosshair!important}.settings-logout{text-align:center;border-top:1px solid #333;margin-top:32px;padding-top:16px}#test-sidebar{z-index:50;pointer-events:auto;background:#0a0a18eb;border:2px solid #4a9fff;border-left:none;flex-direction:column;gap:6px;width:220px;padding:12px 10px;display:flex;position:absolute;top:50%;left:0;transform:translateY(-50%)}.test-sidebar-title{color:#4a9fff;text-shadow:1px 1px #000;text-align:center;letter-spacing:1px;margin-bottom:4px;font-family:"Press Start 2P",monospace;font-size:11px}.test-sidebar-group{flex-direction:column;gap:4px;display:flex}.test-sidebar-label{color:#888;text-shadow:1px 1px #000;font-family:"Press Start 2P",monospace;font-size:9px}.test-sidebar-speed{grid-template-columns:1fr 1fr;gap:3px;display:grid}.test-btn{color:#4a9fff;text-shadow:1px 1px #000;white-space:nowrap;background:#0a1a2a;border:1px solid #2a5a8a;padding:7px 6px;font-family:"Press Start 2P",monospace;font-size:9px}.test-btn:hover{color:#6ab8ff;background:#1a2a4a;border-color:#4a9fff}.test-btn:active{color:#000;text-shadow:none;background:#4a9fff}.test-btn-active{color:#fff;background:#1a3a5a;border-color:#4a9fff}.test-btn-wide{text-align:center;width:100%;padding:6px 4px}.test-btn-danger{color:#f66;background:#2a0a0a;border-color:#a33}.test-btn-danger:hover{background:#3a1a1a;border-color:#f66}.test-btn-danger:active{color:#000;background:#f66}.test-btn-exit{color:#f0c040;background:#2a2a0a;border-color:#8a6a10;margin-top:4px}.test-btn-exit:hover{background:#3a3a1a;border-color:#f0c040}.test-btn-exit:active{color:#000;background:#f0c040}.test-spawn-row{grid-template-columns:1fr auto;align-items:center;gap:4px;display:grid}.test-input{color:#4a9fff;text-shadow:1px 1px #000;box-sizing:border-box;-moz-appearance:textfield;background:#0a1a2a;border:1px solid #2a5a8a;width:100%;padding:5px 6px;font-family:"Press Start 2P",monospace;font-size:9px}.test-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.test-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.test-input:focus{border-color:#4a9fff;outline:none}.px-book{width:24px;height:24px;image-rendering:pixelated;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' shape-rendering='crispEdges'%3E%3Crect x='2' y='1' width='12' height='13' fill='%23ffffff'/%3E%3Crect x='2' y='1' width='2' height='13' fill='%23cccccc'/%3E%3Crect x='4' y='13' width='10' height='1' fill='%23e0e0e0'/%3E%3Crect x='6' y='4' width='6' height='1' fill='%23999999'/%3E%3Crect x='6' y='7' width='5' height='1' fill='%23999999'/%3E%3Crect x='6' y='10' width='6' height='1' fill='%23999999'/%3E%3C/svg%3E") 50%/contain no-repeat;flex-shrink:0;display:inline-block}.menu-btn:hover .px-book{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' shape-rendering='crispEdges'%3E%3Crect x='2' y='1' width='12' height='13' fill='%23f0c040'/%3E%3Crect x='2' y='1' width='2' height='13' fill='%23c8a030'/%3E%3Crect x='4' y='13' width='10' height='1' fill='%23e8d88a'/%3E%3Crect x='6' y='4' width='6' height='1' fill='%238a6a10'/%3E%3Crect x='6' y='7' width='5' height='1' fill='%238a6a10'/%3E%3Crect x='6' y='10' width='6' height='1' fill='%238a6a10'/%3E%3C/svg%3E")}.tb-overlay{z-index:700;background:#000000bf;justify-content:center;align-items:center;font-family:"Press Start 2P",monospace;display:flex;position:fixed;inset:0}.tb-modal{background:#14111e;border:3px solid #8b6914;flex-direction:column;width:92%;max-width:780px;height:85vh;max-height:720px;display:flex;position:relative;overflow:hidden;box-shadow:0 0 0 2px #1a1a2e,0 0 40px #8b69144d,inset 0 0 60px #00000080}.tb-header{background:linear-gradient(#1e1a12 0%,#14111e 100%);border-bottom:2px solid #332a14;justify-content:space-between;align-items:center;padding:14px 18px 10px;display:flex}.tb-title{color:#d4a830;text-shadow:2px 2px #000;letter-spacing:3px;margin:0;font-size:1rem}.tb-close-btn{background:0 0;border:2px solid #555;justify-content:center;align-items:center;padding:6px 8px;transition:border-color .15s;display:flex}.tb-close-btn:hover{border-color:#f44336}.tb-categories{background:#14111ecc;border-bottom:2px solid #332a14;gap:0;padding:0 18px;display:flex}.tb-cat{color:#888;letter-spacing:1px;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 8px;font-family:"Press Start 2P",monospace;font-size:.55rem;transition:color .15s,border-color .15s}.tb-cat:hover{color:#ccc}.tb-cat.active{border-bottom-style:solid;border-bottom-width:2px}.tb-body{scrollbar-width:thin;scrollbar-color:#8b6914 #14111e;flex:1;padding:16px 18px;overflow-y:auto}.tb-body::-webkit-scrollbar{width:8px}.tb-body::-webkit-scrollbar-track{background:#14111e}.tb-body::-webkit-scrollbar-thumb{background:#8b6914;border:1px solid #14111e}.tb-body::-webkit-scrollbar-thumb:hover{background:#b08a1a}.tb-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;display:grid}.tb-card{text-align:center;background:#1e1c2dcc;border:2px solid #333;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;font-family:"Press Start 2P",monospace;transition:border-color .15s,background .15s;display:flex}.tb-card:hover{background:#322a1480;border-color:#8b6914}.tb-card-sprite{width:56px;height:56px;image-rendering:pixelated;object-fit:contain}.tb-card-name{color:#d4a830;letter-spacing:1px;font-size:.55rem}.tb-card-desc{color:#888;font-size:.45rem;line-height:1.6}.tb-detail{flex-direction:column;gap:12px;display:flex}.tb-back-btn{color:#e0e0e0;background:#2a2a4a;border:2px solid #444;align-self:flex-start;align-items:center;gap:6px;padding:6px 12px;font-family:"Press Start 2P",monospace;font-size:.55rem;transition:background .15s,border-color .15s;display:inline-flex}.tb-back-btn:hover{color:#fff;background:#3a3a6a;border-color:#f0c040}.tb-detail-name{color:#d4a830;text-shadow:2px 2px #000;margin:4px 0 0;font-size:.9rem}.tb-detail-tagline{color:#aaa;margin:0;font-size:.6rem;line-height:1.6}.tb-detail-lore{color:#ccc;background:#1e1c2d99;border-left:3px solid #8b6914;margin:0;padding:10px 14px;font-size:.55rem;line-height:2}.tb-no-upgrade{color:#f96;letter-spacing:1px;margin:6px 0 0;font-size:.55rem;font-style:italic}.tb-section-title{color:#8b6914;letter-spacing:2px;border-bottom:1px solid #332a14;margin:8px 0 4px;padding-bottom:4px;font-size:.6rem}.tb-sprites{background:#14111e80;border:1px solid #332a14;flex-wrap:wrap;gap:8px;padding:8px;display:flex}.tb-sprite-item{flex-direction:column;align-items:center;gap:4px;display:flex}.tb-sprite-img{width:48px;height:48px;image-rendering:pixelated;object-fit:contain}.tb-sprite-label{color:#666;font-size:.4rem}.tb-stats-scroll{scrollbar-width:thin;scrollbar-color:#8b6914 #14111e;overflow-x:auto}.tb-stats-table{border-collapse:collapse;white-space:nowrap;width:100%;font-size:.5rem}.tb-stats-table th{color:#8b6914;text-align:left;letter-spacing:1px;border-bottom:2px solid #332a14;padding:6px 10px;font-weight:400}.tb-stats-table td{color:#ccc;text-align:left;border-bottom:1px solid #1e1a14;padding:5px 10px}.tb-stats-table tr:hover td{background:#8b69141a}.tb-specials-const{flex-wrap:wrap;gap:16px;padding:6px 0;display:flex}.tb-const-item{color:#aaa;font-size:.5rem}.start-menu-settings-row{gap:8px;width:300px;margin:30px auto 0;display:flex}.start-menu-settings-row .menu-btn{flex:1;width:auto;margin:0}.menu-btn-book{flex:0 0 48px!important;width:48px!important;padding:.85rem 0!important}#builder-ui{pointer-events:none;z-index:10;font-family:"Press Start 2P",monospace;position:absolute;inset:0}#builder-ui>*{pointer-events:auto}.builder-toolbar{z-index:20;background:#0a0a18;border-bottom:2px solid #333;align-items:center;gap:8px;height:52px;padding:0 12px;display:flex;position:absolute;top:0;left:0;right:0}.builder-title-display{color:#f0c040;text-align:center;text-overflow:ellipsis;white-space:nowrap;text-shadow:1px 1px #000;flex:1;font-size:12px;overflow:hidden}.builder-toolbar-right{align-items:center;gap:4px;display:flex}.builder-btn{color:#ccc;white-space:nowrap;text-shadow:1px 1px #000;background:#1a1a30;border:2px solid #444;border-radius:0;align-items:center;gap:6px;padding:6px 12px;font-family:"Press Start 2P",monospace;font-size:11px;display:inline-flex}.builder-btn:hover{color:#fff;background:#2a2a50;border-color:#f0c040}.builder-btn:active{color:#000;text-shadow:none;background:#f0c040}.builder-btn-primary{color:#4c4;background:#1a3a1a;border-color:#4c4}.builder-btn-primary:hover{color:#8f8;background:#2a5a2a;border-color:#8f8}.builder-btn-accent{color:#f0c040;background:#3a2a0a;border-color:#f0c040}.builder-btn-accent:hover{color:#ffd860;background:#5a4a1a;border-color:#ffd860}.builder-btn-test{color:#4a9fff;background:#0a2a4a;border-color:#4a9fff}.builder-btn-test:hover{color:#6ab8ff;background:#1a3a5a;border-color:#6ab8ff}.builder-btn-danger{color:#ef9a9a;background:#3a1a1a;border-color:#ef5350;align-items:center;gap:4px;display:inline-flex}.builder-btn-danger:hover{color:#ffcdd2;background:#5a2020;border-color:#ff6b6b}.builder-meta-actions{gap:8px;margin-top:8px;display:flex}.builder-meta-actions .builder-btn{text-align:center;flex:1;justify-content:center}.builder-sidebar{z-index:15;background:#0a0a18;border-right:2px solid #333;width:310px;transition:transform .2s;position:absolute;top:52px;bottom:32px;left:0;overflow:hidden auto}.builder-sidebar.sidebar-collapsed{transform:translate(-100%)}.sidebar-toggle{color:#f0c040;z-index:16;text-shadow:1px 1px #000;background:#0a0a18;border:2px solid #333;justify-content:center;align-items:center;width:22px;height:40px;padding:0;font-family:"Press Start 2P",monospace;font-size:10px;transition:left .2s,right .2s;display:flex;position:absolute;top:52px}.sidebar-toggle:hover{background:#1a1a30;border-color:#f0c040}.sidebar-toggle-left{border-left:none;border-radius:0 4px 4px 0;left:310px}.sidebar-toggle-left.toggled{left:0}.sidebar-toggle-right{border-right:none;border-radius:4px 0 0 4px;right:240px}.sidebar-toggle-right.toggled{right:0}.builder-sidebar::-webkit-scrollbar{width:8px}.builder-sidebar::-webkit-scrollbar-track{background:#0a0a18}.builder-sidebar::-webkit-scrollbar-thumb{background:#333;border:1px solid #555}.palette-section-header{color:#f0c040;text-shadow:1px 1px #000;-webkit-user-select:none;user-select:none;letter-spacing:1px;background:#0f0f20;border-bottom:1px solid #222;padding:10px 10px 6px;font-family:"Press Start 2P",monospace;font-size:11px}.palette-section-header:before{content:"▼ ";font-size:9px}.palette-section-header.collapsed:before{content:"► "}.palette-section-header:hover{color:#ffd860;background:#1a1a30}.palette-section-body.collapsed{display:none}.palette-sub-header{color:#8ac;text-shadow:1px 1px #000;-webkit-user-select:none;user-select:none;letter-spacing:.5px;background:#0c0c1a;padding:6px 10px 4px 18px;font-family:"Press Start 2P",monospace;font-size:9px}.palette-sub-header:before{content:"▼ ";font-size:7px}.palette-sub-header.collapsed:before{content:"► "}.palette-sub-header:hover{color:#adf;background:#151530}.palette-sub-header+.palette-grid.collapsed{display:none}.palette-grid{grid-template-columns:repeat(4,1fr);gap:5px;padding:4px 8px 8px;display:grid}.palette-grid.collapsed{display:none}.palette-tile-btn{aspect-ratio:1;image-rendering:pixelated;background:#112;border:2px solid #2a2a3a;border-radius:0;justify-content:center;align-items:center;padding:2px;display:flex;position:relative;overflow:hidden}.palette-tile-btn img{object-fit:contain;width:100%;height:100%;image-rendering:pixelated;pointer-events:none}.palette-tile-btn .text-icon{color:#f55;text-shadow:1px 1px #000;font-family:"Press Start 2P",monospace;font-size:14px}.palette-tile-btn:hover{z-index:1;background:#1a1a3a;border-color:#f0c040}.builder-tooltip{color:#f0c040;white-space:nowrap;text-shadow:1px 1px #000;pointer-events:none;z-index:100;opacity:0;background:#0a0a18;border:2px solid #f0c040;padding:5px 10px;font-family:"Press Start 2P",monospace;font-size:9px;transition:opacity .12s;position:absolute}.builder-tooltip.visible{opacity:1}.palette-tile-btn.active{background:#2a2a10;border-color:#f0c040;box-shadow:0 0 0 1px #f0c040,inset 0 0 8px #f0c04026}.palette-tile-btn.active:after{content:"";pointer-events:none;border:1px solid #f0c04080;position:absolute;inset:0}.builder-meta-panel{z-index:15;background:#0a0a18;border-left:2px solid #333;flex-direction:column;width:240px;padding:12px;transition:transform .2s;display:flex;position:absolute;top:52px;bottom:32px;right:0;overflow-y:auto}.builder-meta-panel.sidebar-collapsed{transform:translate(100%)}.builder-meta-panel::-webkit-scrollbar{width:8px}.builder-meta-panel::-webkit-scrollbar-track{background:#0a0a18}.builder-meta-panel::-webkit-scrollbar-thumb{background:#333;border:1px solid #555}.meta-section-title{color:#f0c040;text-shadow:1px 1px #000;letter-spacing:1px;margin-bottom:12px;font-family:"Press Start 2P",monospace;font-size:11px}.builder-meta-panel label{color:#888;text-shadow:1px 1px #000;letter-spacing:.5px;margin-bottom:12px;font-family:"Press Start 2P",monospace;font-size:10px;display:block}.builder-meta-panel input,.builder-meta-panel textarea,.builder-meta-panel select{color:#ddd;background:#112;border:2px solid #333;border-radius:0;width:100%;margin-top:4px;padding:12px 10px;font-family:"Press Start 2P",monospace;font-size:10px;display:block}.builder-meta-panel input:focus,.builder-meta-panel textarea:focus,.builder-meta-panel select:focus{border-color:#f0c040;outline:none}.builder-meta-panel textarea{resize:vertical;min-height:160px}.builder-meta-panel textarea::-webkit-scrollbar{width:8px}.builder-meta-panel textarea::-webkit-scrollbar-track{background:#0a0a18}.builder-meta-panel textarea::-webkit-scrollbar-thumb{background:#333;border:1px solid #555}.builder-meta-panel .px-dropdown{width:100%;min-width:0;display:block}.builder-publish-btn{text-align:center;flex-shrink:0;width:100%;margin-top:auto;padding:10px 12px}.builder-meta-panel .input-error{animation:.6s ease-in-out 3 error-pulse;border-color:#f44!important}@keyframes error-pulse{0%,to{box-shadow:none;border-color:#f44}50%{border-color:#f88;box-shadow:0 0 8px #ff444480}}.builder-status{color:#8f8;text-shadow:1px 1px #000;z-index:20;background:#0a0a18;border-top:2px solid #333;justify-content:space-between;align-items:center;height:32px;padding:0 12px;font-family:"Press Start 2P",monospace;font-size:10px;display:flex;position:absolute;bottom:0;left:0;right:0}#builder-tile-info{color:#888}.builder-validation-overlay{z-index:100;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.builder-validation-box{background:#0a0a18;border:3px solid #f0c040;min-width:280px;max-width:460px;padding:16px 20px}.validation-header{text-shadow:1px 1px #000;text-align:center;margin-bottom:10px;font-family:"Press Start 2P",monospace;font-size:14px}.builder-validation-box ul{color:#f88;text-shadow:1px 1px #000;margin:0 0 12px 12px;font-family:"Press Start 2P",monospace;font-size:10px;line-height:1.8}.builder-validation-box li{margin-bottom:4px}.builder-validation-box .builder-btn{text-align:center;width:80px;margin:0 auto;display:block}.builder-confirm-overlay{z-index:110;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.builder-confirm-box{text-align:center;background:#0a0a18;border:3px solid #f0c040;min-width:300px;max-width:420px;padding:20px 24px}.builder-confirm-box .confirm-title{color:#f0c040;text-shadow:1px 1px #000;margin-bottom:12px;font-family:"Press Start 2P",monospace;font-size:14px}.builder-confirm-box .confirm-message{color:#ccc;text-shadow:1px 1px #000;margin-bottom:18px;font-family:"Press Start 2P",monospace;font-size:10px;line-height:1.8}.builder-confirm-buttons{justify-content:center;gap:12px;display:flex}.builder-confirm-buttons .builder-btn{text-align:center;min-width:90px}
