@import url(https://fonts.googleapis.com/icon?family=Material+Icons);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body{padding-top:40px}:root{--primary-color:#54124f;--secondary-color:#f1961e;--gray-color-1:#a9a9a9;--text-color:#f2f2f2}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}.header{box-sizing:border-box;margin:0 auto;max-width:1024px;padding:0 20px;width:100%}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.game-form{gap:20px}.form-group,.game-form{display:flex;flex-direction:column}.form-group{margin-bottom:15px}.form-label{font-size:18px;font-weight:700;margin-bottom:5px}.form-input{border:1px solid #ccc;border-radius:5px;font-size:16px;margin-bottom:15px;padding:10px;width:50%}.form-actions{display:flex;gap:10px;justify-content:flex-end}.cancel-btn,.submit-btn{border:none;border-radius:5px;cursor:pointer;font-size:16px;margin-right:10px;padding:10px 15px}.submit-btn{background-color:#4caf50;color:#fff}.cancel-btn:disabled,.submit-btn:disabled{background-color:#ccc;color:#666;cursor:not-allowed}.input-field{width:60%}.dropdown-field{width:20%}.cancel-btn{background-color:#f44336;color:#fff}.table{border-collapse:collapse;margin-left:auto;margin-right:auto;margin-top:0;max-width:1024px;width:100%}.header-container-center{text-align:center}.warning-icon{cursor:help;margin-left:10px}.tr:nth-child(odd){background-color:#f9f9f9}.th,th{background-color:#007bff;color:#fff;padding:10px;text-align:left}.th-actions{text-align:center}.table th:first-child{border-top-left-radius:10px}.table th:last-child{border-top-right-radius:10px}.td{border-bottom:1px solid #ddd;padding:10px}.tr:hover{background-color:#f2f2f2}.cursor-pointer{cursor:pointer}.modal{background-color:#0006;height:100%;left:0;overflow:auto;position:fixed;top:0;width:100%;z-index:1}.modal-content{background-color:#fefefe;border:1px solid #888;margin:15% auto;max-width:500px;padding:20px}.close{color:#aaa;float:right;font-size:28px;font-weight:700}.close:focus,.close:hover{color:#000;cursor:pointer;text-decoration:none}.button-icon{align-items:center;display:flex;gap:8px}.delete-btn,.edit-btn,.new-tab-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:5px}.edit-btn{color:#007bff}.delete-btn{color:red}.edit-btn:hover{color:#0056b3}.delete-btn:hover{color:#f05}.actions-column,.add-game-column{white-space:nowrap;width:1%}.actions-column{border-left:2px solid #000;border-right:2px solid #000}.action-buttons{display:flex;gap:10px;justify-content:left}.add-game-btn{align-items:center;background:none;border:none;color:#4caf50;cursor:pointer;display:flex;justify-content:center;padding:5px}.material-icons{font-size:24px}.confirmation-modal-content{background-color:#fff;border:1px solid #ccc;border-radius:8px;box-shadow:0 4px 6px #0000001a;margin:10% auto;padding:30px;position:relative;width:400px}.confirmation-modal-header{margin-bottom:20px}.confirmation-modal-button-container{display:flex;justify-content:space-between;margin-top:20px}.confirmation-modal-button{border:none;border-radius:5px;cursor:pointer;font-weight:700;padding:8px 20px}.confirmation-modal-confirm-button{background-color:#ff4d4d;color:#fff}.confirmation-modal-cancel-button{background-color:#ccc;color:#333}.confirmation-modal-confirm-button:hover{background-color:#f33}.confirmation-modal-cancel-button:hover{background-color:#bbb}.modal .close{color:#666;font-size:24px;position:absolute;right:20px;top:15px}.key-name{display:inline-block;font-weight:700;margin-right:10px;text-align:left;width:350px}.key-name.focused{background-color:#e0f7fa;border-radius:4px;color:#00796b;padding:2px 5px}.form-row{align-items:center;display:flex;margin-bottom:6px}.input-box{border:1px solid #ccc;border-radius:4px;padding:8px 10px;width:calc(100% - 500px)}.input-box.edited{background-color:#ffc}.provider-group{background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:15px}.provider-name{color:var(--primary-color);font-size:24px;margin-bottom:15px;text-decoration:underline}.changes-table .table-header,.changes-table .table-row{display:flex;justify-content:space-between;padding:8px 0}.table-header{border-bottom:2px solid #ccc;font-weight:700;margin-bottom:10px}.table-cell,.table-column{flex:1 1;padding:0 5px;text-align:left}.header-container{align-items:center;background-color:#fff;box-shadow:0 2px 5px #0000001a;display:flex;height:70px;justify-content:space-between;left:0;position:fixed;right:0;top:50px;z-index:1000}.game-details-container{margin:0 auto;max-width:1024px;padding-top:100px;width:100%}.back-to-games-list-btn{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;padding:8px 16px;transition:background-color .3s}.back-to-games-list-btn:hover{background-color:#0056b3}.old-value{color:#999;text-decoration:line-through}.input-box:disabled{background-color:#f0f0f0;color:#333;cursor:not-allowed}.new-value{color:#4caf50}.popup-actions{display:flex;justify-content:center;margin-top:20px}.cancel-btn,.confirm-btn{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;margin:0 10px;padding:10px 20px;transition:background-color .3s ease}.confirm-btn{background-color:#4caf50}.cancel-btn:hover{background-color:#0056b3}.confirm-btn:hover{background-color:#45a049}.popup-overlay{align-items:center;background-color:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.popup-content{background:#fff;border-radius:8px;box-shadow:0 4px 8px #0003;box-sizing:border-box;padding:16px;width:80%}.popup-navigation{display:flex;justify-content:space-between;margin-top:20px}.popup-navigation button{background:none;border:none;color:#1a73e8;cursor:pointer;font-size:16px;padding:8px}.popup-navigation button:disabled{color:#ccc}button.close-button{background-color:#f1f3f4;border:none;border-radius:4px;cursor:pointer;display:block;margin-top:16px;padding:8px 16px;width:100%}.change-details{color:#202124;font-size:14px;margin:12px 0}.change-details .username{font-weight:700}.change-details .timestamp{color:#5f6368}.change-details .change-description{margin-top:8px}.save-changes-btn:hover{background-color:#45a049}.save-changes-btn{background-color:#4caf50;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;padding:8px 16px;transition:background-color .3s}.popup-overlay{overflow-y:auto}.confirm-btn.saving{background-color:#ccc;color:#666}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.landing-page{flex-direction:column;height:100vh}.landing-page,.login-button{align-items:center;display:flex;justify-content:center}.login-button{background-color:#fff;border:1px solid #4285f4;border-radius:4px;box-shadow:0 2px 4px #00000026;color:#5f6368;cursor:pointer;font-family:Roboto,sans-serif;font-size:16px;font-weight:500;padding:10px 24px;transition:box-shadow .2s,background-color .2s}.login-button img{margin-right:10px}.login-button:hover{background-color:#f8f9fa;box-shadow:0 2px 6px #0003}nav{background:var(--secondary-color);box-shadow:0 2px 4px #0000001a;justify-content:space-between;left:0;padding:10px;position:fixed;right:0;top:0;width:100%;z-index:1000}.home-button,nav{align-items:center;display:flex}.home-button{background-color:initial;border:none;cursor:pointer}.user-info{color:var(--primary-color);font-weight:700;margin-right:20px}.logout-button{align-items:center;background-color:var(--primary-color);border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:16px;margin-right:20px;padding:5px 20px;transition:background-color .3s ease}.logout-button:hover{background-color:#3a0f3d}.material-icons{margin-right:5px;vertical-align:middle}.portal-home{text-align:center}.card-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:20px}.card{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 5px #0000001a;color:inherit;padding:20px;text-align:center;text-decoration:none;transition:transform .2s,box-shadow .2s}.card img{height:40px;margin-bottom:10px;width:40px}.card h2{font-size:1.2em;margin:10px 0 0}.card:hover{box-shadow:0 4px 10px #0003;transform:translateY(-5px)}.card.disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.card.disabled:hover{box-shadow:none;transform:none}.progressions-page-container{margin:0 auto;max-width:1024px;padding:0 20px}.add-group-section{margin-bottom:20px;text-align:right}.game-group-modal{max-width:600px}.form-field{margin-bottom:16px}.form-field label{display:block;font-weight:700;margin-bottom:6px}.game-selection-list{border:1px solid #ccc;border-radius:4px;max-height:250px;overflow-y:auto;padding:8px}.game-checkbox{align-items:center;cursor:pointer;display:flex;gap:8px;padding:4px 0}.game-checkbox input[type=checkbox]{cursor:pointer}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.progression-editor-container{box-sizing:border-box;margin:0 auto;max-width:1024px;padding:100px 20px 40px;width:100%}.group-games-info{background-color:#f0f0f0;border-radius:6px;color:#555;font-size:14px;margin-bottom:16px;padding:10px 14px}.add-progression-section{margin-bottom:20px}.add-progression-btn{background-color:#4caf50;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;padding:8px 16px;transition:background-color .3s}.add-progression-btn:hover{background-color:#45a049}.new-progression-input-row{align-items:center;display:flex;gap:10px}.new-progression-input-row .input-box{border:1px solid #ccc;border-radius:4px;flex:1 1;padding:8px 10px}.progression-group{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:16px;overflow:hidden}.progression-header{align-items:center;background-color:#f5f5f5;cursor:pointer;display:flex;padding:12px 16px;-webkit-user-select:none;user-select:none}.progression-header:hover{background-color:#eee}.progression-expand-icon{color:#666;margin-right:8px}.progression-name{color:var(--primary-color);flex:1 1;font-size:18px;font-weight:700}.progression-actions,.rename-row{display:flex;gap:8px}.rename-row{align-items:center;flex:1 1}.rename-row .input-box{border:1px solid #ccc;border-radius:4px;flex:1 1;padding:6px 10px}.progression-levels{padding:12px 16px 16px}.levels-toolbar{align-items:center;border-bottom:1px solid #e8e8e8;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:8px;padding:8px 0 12px}.levels-count{color:#888;font-size:13px;font-weight:500;white-space:nowrap}.levels-jump{align-items:center;display:flex;gap:6px;margin-left:auto}.levels-jump-label{color:#666;font-size:13px;white-space:nowrap}.levels-jump-input{border:1px solid #ccc;border-radius:4px;font-size:13px;padding:4px 8px;text-align:center;width:80px}.levels-jump-input:focus{border-color:#48f;outline:none}.levels-jump-btn{background:#48f;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;padding:4px 12px;transition:background .2s}.levels-jump-btn:hover{background:#36c}.levels-pagination{align-items:center;display:flex;gap:4px}.levels-page-btn{align-items:center;background:none;border:1px solid #ddd;border-radius:4px;color:#555;cursor:pointer;display:flex;justify-content:center;padding:2px 4px;transition:background .15s,border-color .15s}.levels-page-btn:hover:not(:disabled){background:#f0f0f0;border-color:#bbb}.levels-page-btn:disabled{cursor:default;opacity:.35}.levels-page-label{color:#555;font-size:13px;padding:0 8px;white-space:nowrap}.levels-list{display:flex;flex-direction:column}.level-row{border-bottom:1px solid #f0f0f0;transition:background .15s}.level-row:last-child{border-bottom:none}.level-row:hover{background:#fafafa}.level-row-expanded{background:#f8f9ff}.level-row[draggable=true]{cursor:grab}.level-row[draggable=true]:active{cursor:grabbing;opacity:.6}.level-row-main{align-items:center;display:flex;gap:8px;min-height:36px;padding:6px 4px}.drag-handle{color:#ccc;cursor:grab;flex-shrink:0;font-size:20px}.drag-handle:hover{color:#999}.level-row-number{color:#333;font-size:14px;font-weight:600;min-width:48px}.level-row-id{color:#aaa;flex:1 1;font-size:12px}.level-thumbnail{border:1px solid #d0d3db;border-radius:3px;flex-shrink:0;vertical-align:middle}.level-row-preview-btn{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;padding:2px 6px;transition:color .15s,background .15s}.level-row-preview-btn:hover{background:#eee;color:#555}.level-row-actions{display:flex;flex-shrink:0;gap:4px}.level-row-thumbnail-btn{align-items:center;border-radius:4px;cursor:pointer;display:flex;flex-shrink:0;transition:box-shadow .15s}.level-row-thumbnail-btn:hover{box-shadow:0 0 0 2px #4488ff44}.copy-json-btn{align-items:center;background:none;border:1px solid #0000;border-radius:4px;color:#999;cursor:pointer;display:flex;padding:2px 4px;transition:color .15s,background .15s}.copy-json-btn:hover{background:#e8f0fe;color:#48f}.level-row-preview{align-items:flex-start;border-top:1px solid #eee;display:flex;gap:16px;padding:12px 12px 12px 56px}.level-row-preview .level-thumbnail{border-radius:6px;flex-shrink:0}.level-row-preview-json{border-left:1px solid #eee;flex:1 1;max-height:200px;min-width:0;overflow:auto;padding-left:16px}.level-row-preview-json pre{color:#555;font-size:12px;margin:0;white-space:pre-wrap;word-break:break-word}.level-row-wrapper{position:relative}.level-row-dragging{background:#e8f0fe!important;opacity:.4}.drop-indicator{background:#48f;border-radius:2px;height:3px;margin:0 4px;position:relative}.drop-indicator-label{background:#fff;font-size:11px;left:8px;padding:0 6px;pointer-events:none;position:absolute;top:-10px}.drag-hint,.drop-indicator-label{color:#48f;font-weight:600;white-space:nowrap}.drag-hint{background:#e8f0fe;border-radius:10px;font-size:12px;padding:1px 8px}.move-to-btn{align-items:center;background:none;border:1px solid #0000;border-radius:4px;color:#999;cursor:pointer;display:flex;padding:2px 4px;transition:color .15s,background .15s}.move-to-btn:hover{background:#e8f0fe;color:#48f}.move-to-row{align-items:center;background:#f8f9ff;border-top:1px solid #e8e8e8;display:flex;gap:8px;padding:6px 12px 8px 56px}.move-to-label{color:#555;font-size:13px;white-space:nowrap}.move-to-input{border:1px solid #ccc;border-radius:4px;font-size:13px;padding:4px 8px;text-align:center;width:80px}.move-to-input:focus{border-color:#48f;outline:none}.move-to-cancel{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;padding:2px}.move-to-cancel:hover{background:#fff0f0;color:#f44}.add-level-btn{background:none;border:2px dashed #ccc;border-radius:6px;color:#666;cursor:pointer;font-size:14px;margin-top:12px;padding:10px;transition:border-color .2s,color .2s;width:100%}.add-level-btn:hover{border-color:#4caf50;color:#4caf50}.no-progressions-msg{color:#999;font-size:16px;margin-top:40px;text-align:center}.progression-button-row{display:flex;gap:10px}.import-progression-btn{background-color:#2196f3;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;padding:8px 16px;transition:background-color .3s}.import-progression-btn:hover{background-color:#1976d2}.import-modal{max-width:600px}.import-json-textarea{box-sizing:border-box;font-family:monospace;padding:10px;resize:vertical;width:100%}.import-file-btn,.import-json-textarea{border:1px solid #ccc;border-radius:4px;font-size:13px}.import-file-btn{align-items:center;background:#f0f0f0;color:#444;cursor:pointer;display:inline-flex;padding:5px 12px;transition:background .15s,border-color .15s}.import-file-btn:hover{background:#e4e4e4;border-color:#aaa}.import-file-info{color:#4caf50;display:block;font-size:13px;font-weight:500;margin-top:8px}.import-error{color:#ff4d4d;font-size:13px;margin:8px 0 0}.snake-editor-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.snake-editor-layout{display:flex;flex:1 1;overflow:hidden;padding-top:120px}.toolbox-panel{background-color:#f5f5f5;border-right:1px solid #ddd;display:flex;flex-direction:column;gap:16px;min-width:220px;overflow-y:auto;padding:12px;-webkit-user-select:none;user-select:none;width:220px}.toolbox-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000f;padding:10px}.toolbox-section-title{align-items:center;color:#888;display:flex;font-size:11px;font-weight:700;justify-content:space-between;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.toolbox-btn{align-items:center;background:#f9f9f9;border:2px solid #0000;border-radius:6px;color:#555;cursor:pointer;display:flex;font-size:13px;gap:8px;margin-bottom:4px;padding:8px 10px;transition:all .15s;width:100%}.toolbox-btn:hover{background:#eef;color:#333}.toolbox-btn.active{background:#e8f0ff;border-color:#48f;color:#26c;font-weight:600}.toolbox-btn .material-icons{font-size:20px}.palette-grid{display:flex;flex-wrap:wrap;gap:4px}.palette-swatch{align-items:center;border:2px solid #0000;border-radius:5px;cursor:pointer;display:flex;height:28px;justify-content:center;position:relative;transition:all .15s;width:28px}.palette-swatch:hover{transform:scale(1.15);z-index:1}.palette-swatch.active{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #333}.palette-check{color:#fff;font-size:16px!important;text-shadow:0 1px 2px #00000080}.palette-edit-toggle{background:none;border:none;border-radius:3px;color:#999;cursor:pointer;padding:2px}.palette-edit-toggle:hover{background:#eee;color:#555}.palette-editor{display:flex;flex-direction:column;gap:4px;margin-top:8px}.palette-editor-row{align-items:center;display:flex;gap:4px}.palette-editor-index{color:#999;flex-shrink:0;font-family:monospace;font-size:11px;width:22px}.palette-color-input{background:none;border:none;cursor:pointer;flex-shrink:0;height:24px;padding:0;width:28px}.palette-hex-input{border:1px solid #ddd;border-radius:3px;flex:1 1;font-family:monospace;font-size:11px;min-width:0;padding:3px 5px}.palette-remove-btn{background:none;border:none;border-radius:3px;color:#ccc;cursor:pointer;flex-shrink:0;padding:2px}.palette-remove-btn:hover:not(:disabled){background:#fee;color:#f44}.palette-remove-btn:disabled{cursor:default;opacity:.3}.palette-add-btn{background:none;border:1px dashed #ccc;border-radius:4px;color:#888;cursor:pointer;font-size:12px;margin-top:4px;padding:4px 8px;transition:all .15s}.palette-add-btn:hover{border-color:#4caf50;color:#4caf50}.grid-size-display{align-items:center;background:#f9f9f9;border:1px solid #ddd;border-radius:5px;color:#555;cursor:pointer;display:flex;font-size:14px;font-weight:600;padding:6px 10px;transition:background .15s;width:100%}.grid-size-display:hover{background:#eef}.grid-size-editor{display:flex;flex-direction:column;gap:8px}.grid-size-inputs{align-items:center;display:flex;gap:6px}.grid-size-inputs label{color:#888;font-size:12px;font-weight:600}.grid-size-inputs input{border:1px solid #ccc;border-radius:4px;font-size:14px;padding:4px 6px;text-align:center;width:48px}.grid-size-actions{display:flex;gap:6px}.grid-size-actions .cancel-btn,.grid-size-actions .confirm-btn{font-size:12px;padding:4px 10px}.grid-area{align-items:center;background-color:#e8ecf0;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:20px 20px 40px}.grid-board{grid-gap:3px;background-color:#c8cdd6;border:4px solid #fff;border-radius:12px;box-shadow:0 4px 16px #0000001f;display:grid;flex-shrink:0;gap:3px;padding:4px}.grid-cell{align-items:center;background-color:#bcc4d0;border-radius:4px;display:flex;justify-content:center;overflow:visible;position:relative;transition:background-color .1s;-webkit-user-select:none;user-select:none}.grid-cell.tool-active{cursor:crosshair}.grid-cell:hover{background-color:#cdd4df}.grid-cell-selected{outline:3px solid #48f;outline-offset:-2px;z-index:1}.grid-cell-coord{bottom:2px;color:#ffffff59;font-size:9px;right:3px;-webkit-user-select:none;user-select:none}.grid-cell-coord,.wall-segment{pointer-events:none;position:absolute}.wall-segment{z-index:2}.wall-border{cursor:default!important}.hole-element{align-items:center;border-radius:50%;box-shadow:inset 0 2px 6px #0000004d,0 2px 4px #00000026;display:flex;height:75%;justify-content:center;position:relative;width:75%}.hole-inner{background-color:#000000b3;border-radius:50%;box-shadow:inset 0 1px 3px #00000080;height:45%;width:45%}.snake-segment{align-items:center;box-shadow:inset 0 2px 4px #ffffff40,inset 0 -2px 4px #00000026;display:flex;justify-content:center;pointer-events:none;position:absolute;z-index:2}.snake-drawing{opacity:.75}.snake-eyes{display:flex;gap:4px;z-index:3}.snake-eye{align-items:center;background-color:#fff;border-radius:50%;box-shadow:0 1px 2px #0003;display:flex;height:10px;justify-content:center;width:10px}.snake-pupil{background-color:#1a1a2e;border-radius:50%;height:5px;width:5px}.snake-head-id{bottom:1px;color:#ffffffd9;font-weight:700;left:0;right:0;text-align:center;text-shadow:0 1px 2px #00000080}.snake-head-id,.snake-head-id-corner{font-size:9px;pointer-events:none;position:absolute}.snake-head-id-corner{color:#000;font-weight:800;left:2px;line-height:1;top:0;z-index:3}.level-nav{gap:4px}.level-nav,.level-nav-btn{align-items:center;display:flex}.level-nav-btn{background:none;border:1px solid #ddd;border-radius:5px;color:#555;cursor:pointer;justify-content:center;padding:4px;transition:all .15s}.level-nav-btn:hover:not(:disabled){background:#eef;border-color:#aac;color:#333}.level-nav-btn:disabled{cursor:default;opacity:.3}.level-nav-label{color:#444;font-size:15px;font-weight:600;padding:0 8px;white-space:nowrap}.level-nav-progression{border-right:1px solid #ddd;color:#888;font-size:13px;font-weight:500;margin-right:8px;padding-right:10px;white-space:nowrap}.level-nav-divider{color:#ccc;font-size:16px;margin:0 4px}.level-nav-goto-label{color:#888;font-size:13px;font-weight:600}.level-nav-input{-moz-appearance:textfield;border:1px solid #ccc;border-radius:4px;font-size:13px;padding:4px 8px;text-align:center;width:64px}.level-nav-input::-webkit-inner-spin-button,.level-nav-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.level-nav-input:focus{border-color:#48f;outline:none}.level-nav-go-btn{background:#48f;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;padding:4px 10px;transition:background .2s}.level-nav-go-btn:hover{background:#36c}.editor-header-actions{gap:8px}.editor-header-actions,.editor-header-actions .confirm-btn{align-items:center;display:flex}.properties-panel{background-color:#f5f5f5;border-left:1px solid #ddd;display:flex;flex-direction:row;overflow:hidden;position:relative;transition:width .2s ease}.properties-panel.open{min-width:280px;width:280px}.properties-panel.collapsed,.properties-toggle{min-width:32px;width:32px}.properties-toggle{align-items:flex-start;background:none;border:none;border-right:1px solid #e0e0e0;color:#888;cursor:pointer;display:flex;justify-content:center;padding-top:12px;transition:color .15s,background .15s}.properties-toggle:hover{background:#eee;color:#333}.properties-content{flex:1 1;overflow-y:auto;padding:12px}.properties-title{color:#888;font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.properties-empty{color:#aaa;font-size:13px;padding:20px 0;text-align:center}.properties-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000f;padding:10px}.properties-section-header{align-items:center;border-bottom:1px solid #eee;color:#444;display:flex;font-size:14px;font-weight:600;margin-bottom:10px;padding-bottom:8px}.properties-field{margin-bottom:10px}.properties-field.inline-field{align-items:center;display:flex;gap:8px}.properties-field.inline-field .properties-field-label{margin-bottom:0}.properties-field-label{color:#888;display:block;font-size:11px;font-weight:600;letter-spacing:.3px;margin-bottom:4px;text-transform:uppercase}.properties-field-value{color:#555;font-family:monospace;font-size:13px}.properties-color-picker{display:flex;flex-wrap:wrap;gap:4px}.properties-color-swatch{align-items:center;border:2px solid #0000;border-radius:4px;cursor:pointer;display:flex;height:24px;justify-content:center;transition:all .15s;width:24px}.properties-color-swatch:hover{transform:scale(1.15);z-index:1}.properties-color-swatch.active{border-color:#333;box-shadow:0 0 0 1px #fff,0 0 0 3px #333}.properties-info{color:#aaa;font-size:12px;font-style:italic}.properties-input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-family:monospace;font-size:13px;padding:4px 6px;width:100%}.drawing-badge{color:#f80;font-size:11px;font-style:italic;font-weight:400;margin-left:8px}.snake-positions-list{display:flex;flex-direction:column;gap:3px;max-height:200px;overflow-y:auto}.snake-pos-row{align-items:center;display:flex;font-size:12px;gap:3px}.snake-pos-index{color:#999;flex-shrink:0;font-size:10px;font-weight:700;text-align:center;width:18px}.snake-pos-label{color:#aaa;flex-shrink:0;font-size:10px}.snake-pos-input{border:1px solid #ddd;border-radius:3px;font-family:monospace;font-size:12px;padding:2px 4px;text-align:center;width:36px}.snake-pos-input:disabled{background:#f5f5f5;color:#999}.snake-pos-remove{align-items:center;background:none;border:none;border-radius:3px;color:#ccc;cursor:pointer;display:flex;flex-shrink:0;padding:1px}.snake-pos-remove:hover{background:#fee;color:#f44}.snake-reverse-btn{align-items:center;background:#f0f4ff;border:1px solid #c0d0ee;border-radius:5px;color:#36a;cursor:pointer;display:flex;font-size:12px;justify-content:center;padding:6px 10px;transition:all .15s;width:100%}.snake-reverse-btn:hover{background:#dde6ff;border-color:#99b0dd}.mechanics-group{border-top:1px solid #e8e8ee;margin-top:8px;padding-top:8px}.mechanics-group-label{color:#999;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.mechanic-section{background:#fafbfd;border:1px solid #e4e6ee;border-radius:6px;margin-bottom:6px}.mechanic-section.mechanic-enabled{background:#f4f8ff;border-color:#b8d0f0}.mechanic-header{align-items:center;cursor:pointer;display:flex;gap:4px;padding:6px 8px;transition:background .15s;-webkit-user-select:none;user-select:none}.mechanic-header:hover{background:#eef0f6}.mechanic-chevron{color:#aaa;font-size:16px!important}.mechanic-icon{color:#888}.mechanic-enabled .mechanic-icon{color:#48f}.mechanic-label{color:#555;flex:1 1;font-size:12px;font-weight:500}.mechanic-active-dot{background:#4caf50;border-radius:50%;flex-shrink:0;height:7px;width:7px}.mechanic-body{border-top:1px solid #e8eaef;padding:6px 10px 10px}.mechanic-toggle-row{margin-top:2px}.mechanic-checkbox{align-items:center;color:#555;cursor:pointer;display:flex;font-size:12px;gap:6px}.mechanic-checkbox input[type=checkbox]{cursor:pointer;margin:0}.mechanic-field-row{align-items:center;display:flex;gap:8px;margin-top:6px}.mechanic-field-label{color:#777;font-size:12px;white-space:nowrap}.mechanic-field-input{-moz-appearance:textfield;border:1px solid #ccc;border-radius:4px;font-size:12px;padding:3px 6px;text-align:center;width:48px}.mechanic-field-input::-webkit-inner-spin-button,.mechanic-field-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.mechanic-field-input:focus{border-color:#48f;outline:none}.color-swatch-btn-wrapper{display:inline-flex;position:relative}.color-swatch-btn{border:2px solid #fff;border-radius:4px;box-shadow:0 0 0 1px #ccc;cursor:pointer;height:22px;transition:box-shadow .15s;width:22px}.color-swatch-btn:hover{box-shadow:0 0 0 2px #48f}.color-popup{background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;display:flex;flex-wrap:wrap;gap:4px;left:0;padding:6px;position:absolute;top:28px;width:140px;z-index:100}.color-popup-swatch{align-items:center;border:2px solid #0000;border-radius:4px;cursor:pointer;display:flex;height:22px;justify-content:center;transition:border-color .1s,transform .1s;width:22px}.color-popup-swatch:hover{border-color:#fff;box-shadow:0 0 0 1px #888;transform:scale(1.15)}.color-popup-swatch.active{border-color:#fff;box-shadow:0 0 0 2px #333}.snake-frozen-overlay{align-items:center;background:linear-gradient(90deg,#aad7f080 0,#c8e6fa14 25%,#c8e6fa08 50%,#c8e6fa14 75%,#aad7f080),linear-gradient(180deg,#aad7f080 0,#c8e6fa14 25%,#c8e6fa08 50%,#c8e6fa14 75%,#aad7f080);background-blend-mode:multiply;border:1.5px solid #b4dcfa8c;border-radius:2px;bottom:-1px;box-shadow:inset 0 0 3px #ffffff4d,inset 1px 1px 0 #fff3;display:flex;justify-content:center;left:-1px;pointer-events:none;position:absolute;right:-1px;top:-1px;z-index:5}.snake-frozen-overlay:before{background:linear-gradient(135deg,#0000 20%,#ffffff1f 20.5%,#ffffff1f 21%,#0000 21.5%),linear-gradient(45deg,#0000 60%,#ffffff1a 60.5%,#ffffff1a 61%,#0000 61.5%);content:"";inset:0;pointer-events:none;position:absolute}.snake-frozen-number{color:#fff;font-size:18px;font-weight:900;line-height:1;pointer-events:none;text-shadow:0 0 8px #3c8cdce6,0 1px 3px #00285acc,0 0 16px #64b4ff66;z-index:6}.snake-stacked-inner{pointer-events:none;position:absolute;z-index:1}.stacked-snakes-list{display:flex;flex-direction:column;gap:6px;margin-top:4px}.stacked-snake-row{align-items:center;background:#f8f9fc;border:1px solid #e0e4ee;border-radius:5px;display:flex;gap:6px;padding:4px 6px}.stacked-snake-index{color:#888;font-size:11px;font-weight:600;min-width:14px;text-align:center}.stacked-snake-actions{display:flex;flex-shrink:0;gap:2px}.stacked-snake-btn{align-items:center;background:none;border:none;border-radius:3px;color:#999;cursor:pointer;display:flex;padding:1px;transition:color .15s,background .15s}.stacked-snake-btn:hover{background:#e8f0fe;color:#48f}.stacked-snake-remove:hover{background:#fff0f0;color:#f44}.stacked-snake-add{align-items:center;background:none;border:1px dashed #c8cdd8;border-radius:5px;color:#888;cursor:pointer;display:flex;font-size:12px;justify-content:center;padding:5px 8px;transition:all .15s;width:100%}.stacked-snake-add:hover{background:#f0f4ff;border-color:#48f;color:#48f}.grid-cell.tool-move{cursor:pointer}.grid-cell-dimmed{opacity:.25;pointer-events:none;transition:opacity .2s}.grid-cell-move-target{animation:move-pulse 1.5s ease-in-out infinite;outline:3px solid #f80;outline-offset:-1px;z-index:3}@keyframes move-pulse{0%,to{outline-color:#f80}50%{outline-color:#fb4}}.toolbox-group{background:#fafafa;border:1px solid #e8e8e8;border-radius:6px;margin-bottom:4px;padding:6px;transition:border-color .2s,background .2s}.toolbox-group-active{background:#f4f8ff;border-color:#c0d4ff}.toolbox-group-header{align-items:center;display:flex;gap:6px;padding:2px 4px 4px}.toolbox-group-label{color:#999;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.toolbox-group-items{display:flex;flex-direction:column}.toolbox-btn-sub{font-size:12px;margin-bottom:2px;padding:6px 8px}.toolbox-btn-sub .material-icons{font-size:18px}.toolbox-separator{background:#e0e0e0;height:1px;margin:6px 0}.toolbox-shortcut{background:#eee;border:1px solid #ddd;border-radius:3px;color:#aaa;font-family:monospace;font-size:10px;font-weight:500;line-height:1.4;margin-left:auto;padding:1px 5px}.toolbox-btn.active .toolbox-shortcut{background:#d0dfff;border-color:#a0b8ee;color:#46a}.toolbox-hint{background:#f0f4ff;border:1px solid #d0d8ee;border-radius:5px;color:#888;font-size:11px;line-height:1.4;margin:4px 0 2px;padding:6px 8px}.grid-cell.tool-resize{cursor:default}.grid-cell.snake-endpoint{cursor:grab;z-index:2}.grid-cell.snake-endpoint:active{cursor:grabbing}.grid-cell.snake-extending{z-index:2}
/*# sourceMappingURL=main.521c4e4b.css.map*/