@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}.validate-btn{background:none;border:none;border-radius:4px;color:#4caf50;cursor:pointer;padding:4px;transition:background .15s}.validate-btn:hover{background:#4caf501a}.validate-btn:disabled{cursor:default;opacity:.5}.validation-results-panel{background:#fafbfc;border:1px solid #e0e0e0;border-radius:6px;margin:0 16px 12px;overflow:hidden}.validation-results-header{align-items:center;background:#f5f5f5;border-bottom:1px solid #e0e0e0;display:flex;font-size:14px;font-weight:600;padding:10px 14px}.validation-results-header .material-icons:first-child{color:#4caf50}.validation-results-header:has(+.validation-results-list) .material-icons:first-child{color:#ff9800}.validation-close-btn{background:none;border:none;border-radius:3px;color:#999;cursor:pointer;margin-left:auto;padding:2px}.validation-close-btn:hover{background:#e0e0e0;color:#555}.validation-results-list{max-height:400px;overflow-y:auto;padding:8px 0}.validation-result-item{border-bottom:1px solid #f0f0f0;padding:8px 14px}.validation-result-item:last-child{border-bottom:none}.validation-result-level{align-items:center;color:#333;display:flex;font-size:13px;gap:8px}.validation-warning-count{background:#fff3e0;border-radius:10px;color:#ff9800;font-size:11px;font-weight:600;padding:1px 6px}.validation-warning-list{color:#666;font-size:12px;list-style:disc;margin:4px 0 0 18px;padding:0}.validation-warning-list li{margin:2px 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}.ribbon-overlay{z-index:20}.constraint-arrows-overlay,.ribbon-overlay{left:0;pointer-events:none;position:absolute;top:0}.constraint-arrows-overlay{z-index:15}.grid-board-wrapper{flex-shrink:0;position:relative}.grid-board{grid-gap:3px;background-color:#c8cdd6;border:4px solid #fff;border-radius:12px;box-shadow:0 4px 16px #0000001f;display:grid;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.tool-eraser{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Crect x='1' y='1' width='22' height='22' rx='3' fill='%23f44' stroke='%23a00' stroke-width='1.5'/%3E%3Cpath d='m7 7 10 10m0-10L7 17' stroke='%23fff' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E") 12 12,not-allowed}.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%}.hole-element.hole-infinite{border-radius:4px;height:100%;width:100%}.hole-under-badge{align-items:center;border:2px solid #ffffffe6;border-radius:50%;box-shadow:0 1px 3px #0006;display:flex;height:16px;justify-content:center;position:absolute;right:-4px;top:-4px;width:16px;z-index:2}.hole-under-badge-icon{color:#fff;font-size:11px;font-weight:900;line-height:1;text-shadow:0 1px 2px #00000080}.ribbon-anchor{align-items:center;background:linear-gradient(135deg,sienna,#8b4513 50%,sienna);border-radius:6px;box-shadow:inset 0 1px 3px #0000004d,0 2px 4px #0003;display:flex;height:80%;justify-content:center;position:relative;width:80%}.ribbon-anchor .material-icons{color:wheat;font-size:16px;opacity:.9}.ribbon-anchor-start{border:2px solid #daa520}.ribbon-anchor-end{border:2px solid peru}.snake-segment{align-items:center;box-shadow:inset 0 2px 4px #ffffff40,inset 0 -2px 4px #00000026;display:flex;justify-content:center;overflow:hidden;pointer-events:none;position:absolute;z-index:2}.snake-drawing{opacity:.75}.snake-eyes{display:flex;gap:4px;opacity:.5;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:url(/static/media/iceTx.cd27a765d0f1256a86f4.png) 50%/100% 100% no-repeat;border-radius:3px;bottom:-2px;display:flex;justify-content:center;left:-2px;pointer-events:none;position:absolute;right:-2px;top:-2px;z-index:5}.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:move}.grid-cell-dimmed{opacity:.25;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:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='m12 2 3 3h-2v5h5V8l3 3-3 3v-2h-5v5h2l-3 3-3-3h2v-5H5v2l-3-3 3-3v2h5V5H8l3-3z' fill='%23333' stroke='%23fff' stroke-width='.5'/%3E%3C/svg%3E") 12 12,nwse-resize}.grid-cell.tool-resize.snake-endpoint{cursor:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='m12 2 3 3h-2v5h5V8l3 3-3 3v-2h-5v5h2l-3 3-3-3h2v-5H5v2l-3-3 3-3v2h5V5H8l3-3z' fill='%23333' stroke='%23fff' stroke-width='.5'/%3E%3C/svg%3E") 12 12,grab;z-index:2}.grid-cell.tool-resize.snake-endpoint:active{cursor:grabbing}.grid-cell:not(.tool-resize).snake-endpoint{cursor:grab;z-index:2}.grid-cell:not(.tool-resize).snake-endpoint:active{cursor:grabbing}.grid-cell.snake-extending{z-index:2}.snake-locked-overlay{background:#50505059;border-radius:inherit;inset:0;pointer-events:none;position:absolute;z-index:4}.snake-indicator-panel{align-items:center;background:#ffffffe6;border-radius:4px;box-shadow:0 1px 3px #00000040;display:flex;flex-direction:column;gap:2px;left:50%;padding:2px 4px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:8}.snake-indicator-panel.snake-hidden-overlay{border-radius:inherit;inset:0;justify-content:center;left:0;padding:4px;top:0;transform:none}.snake-indicator-item .material-icons{filter:drop-shadow(0 1px 1px rgba(0,0,0,.3));font-size:16px}.key-type-selector{display:flex;gap:4px;margin-top:4px}.key-type-btn{align-items:center;background:#f5f5f5;border:2px solid #ddd;border-radius:5px;color:#666;cursor:pointer;display:flex;flex:1 1;font-size:11px;font-weight:600;gap:2px;justify-content:center;padding:4px 6px;transition:all .15s}.key-type-btn:hover{background:#fff;border-color:var(--key-color)}.key-type-btn.active{background:var(--key-color);border-color:var(--key-color);box-shadow:0 1px 3px #0003;color:#333}.key-type-btn .material-icons{color:inherit}.snake-hidden-checker{background:repeating-conic-gradient(#fffc 0 25%,#0000 0 50%) 0 0 /30px 30px;z-index:6}.snake-hidden-checker,.snake-stuck-tail{border-radius:inherit;inset:0;pointer-events:none;position:absolute}.snake-stuck-tail{align-items:center;display:flex;justify-content:center;z-index:8}.snake-stuck-tail .material-icons{color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.7));font-size:22px;transform:rotate(45deg)}.snake-dirty-overlay{background:radial-gradient(ellipse 30% 22% at 22% 28%,#3e2608eb 0,#3e2608b3 40%,#0000 70%),radial-gradient(ellipse 22% 30% at 72% 65%,#372005e6 0,#372005a6 45%,#0000 72%),radial-gradient(ellipse 18% 18% at 50% 45%,#462a0ae0 0,#462a0a99 50%,#0000 75%),radial-gradient(ellipse 24% 16% at 38% 78%,#3a2306d9 0,#3a23068c 50%,#0000 75%),radial-gradient(ellipse 15% 20% at 82% 22%,#412808d9 0,#4128088c 45%,#0000 70%),radial-gradient(ellipse 50% 38% at 18% 55%,#5a3c1480 0,#0000 100%),radial-gradient(ellipse 40% 50% at 65% 30%,#50320f73 0,#0000 100%),radial-gradient(ellipse 35% 28% at 55% 85%,#4b2d0c66 0,#0000 100%);border-radius:inherit;inset:0;pointer-events:none;position:absolute;z-index:6}.snake-hidden-number{color:#555;font-size:16px;font-weight:900;line-height:1;text-shadow:0 1px 2px #fffc;z-index:7}.validation-warnings{background:#fff8e1;border:1px solid #ffcc02;border-radius:6px;margin-bottom:8px;overflow:hidden}.validation-warnings-header{align-items:center;color:#8a6d00;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;padding:6px 8px}.validation-warning-icon{color:#f5a623;font-size:16px}.validation-warnings-list{list-style:none;margin:0;padding:0 8px 8px}.validation-warnings-list li{border-top:1px solid #ffe082;color:#6b5500;font-size:11px;line-height:1.3;padding:4px 0}.grid-area-warning{background:#fff3cd66}@keyframes warning-pulse{0%,85%{transform:scale(1)}90%{transform:scale(1.05)}95%{transform:scale(.98)}to{transform:scale(1)}}.validation-warnings{animation:warning-pulse 4s ease-in-out infinite}.hole-frozen{overflow:visible}.hole-ice-overlay{align-items:center;background:url(/static/media/iceTx.cd27a765d0f1256a86f4.png) 50%/100% 100% no-repeat;border-radius:4px;bottom:-6px;display:flex;justify-content:center;left:-6px;pointer-events:none;position:absolute;right:-6px;top:-6px;z-index:2}.hole-ice-number{color:#fff;font-size:18px;font-weight:900;line-height:1;text-shadow:0 0 8px #3c8cdce6,0 1px 3px #00285acc,0 0 16px #64b4ff66;z-index:3}.baby-snake-element{align-items:center;border:2px solid #fff6;border-radius:50%;box-shadow:inset 0 2px 6px #0003,0 2px 5px #00000040;display:flex;height:60%;justify-content:center;position:relative;width:60%}.baby-snake-eyes{align-items:center;display:flex;gap:3px}.baby-snake-eye{align-items:center;background:#fff;border-radius:50%;box-shadow:0 1px 2px #0003;display:flex;height:8px;justify-content:center;width:8px}.baby-snake-pupil{background:#222;border-radius:50%;height:4px;width:4px}.stone-wall-element{align-items:center;background:linear-gradient(145deg,#8a8a8a,#6b6b6b 30%,#7a7a7a 50%,#5c5c5c 80%,#6e6e6e);border:1px solid #555;border-radius:4px;box-shadow:inset 0 2px 4px #ffffff26,inset 0 -2px 4px #0000004d,0 2px 4px #00000040;display:flex;height:90%;justify-content:center;position:relative;width:90%}.stone-wall-number{color:#fff;font-size:16px;font-weight:900;line-height:1;text-shadow:0 1px 3px #000000b3}.colored-stone-element{align-items:center;border:2px solid #0003;border-radius:6px;box-shadow:inset 0 2px 4px #ffffff4d,inset 0 -2px 4px #0000004d,0 2px 4px #0003;display:flex;height:85%;justify-content:center;width:85%}.colored-path-element{border-radius:3px;bottom:0;left:0;opacity:.45;position:absolute;right:0;top:0}.snake-mother-hole{background:radial-gradient(circle,#000c 30%,#0006 60%,#0000 75%);border-radius:50%;box-shadow:inset 0 2px 6px #00000080;inset:15%;pointer-events:none;position:absolute;z-index:7}.movable-box-segment{background:linear-gradient(135deg,#c9a96e,#b8944f 40%,#a07838 70%,#c9a96e);border:1.5px solid #78501e80;box-shadow:inset 0 2px 4px #ffffff40,inset 0 -2px 4px #0003;position:absolute;z-index:1}.movable-box-segment:after{background:#78501e59;box-shadow:0 4px 0 #78501e40,0 8px 0 #78501e26;content:"";height:1.5px;left:15%;position:absolute;right:15%;top:25%}.movable-box-drawing{opacity:.7}.crate-segment{align-items:center;background:repeating-linear-gradient(0deg,#0000,#0000 8px,#50321440 0,#50321440 9px),repeating-linear-gradient(90deg,#0000,#0000 8px,#50321440 0,#50321440 9px),#b482468c;border:2px solid #78501e99;box-shadow:inset 0 1px 3px #fff3,inset 0 -1px 3px #00000026;display:flex;justify-content:center;position:absolute;z-index:25}.crate-drawing{opacity:.6}.crate-break-number{-webkit-text-stroke:2px #000c;color:#fff;font-size:16px;font-weight:800;paint-order:stroke fill;text-shadow:0 1px 4px #000000e6,0 0 8px #00000080;z-index:26}.cleaning-bucket-element{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.cleaning-bucket-icon{font-size:60px;line-height:1}
/*# sourceMappingURL=main.ff3fe6b6.css.map*/