.game-ops-sidebar{width:250px;background:#0a0a0a;border-right:1px solid #333;display:flex;flex-direction:column;height:100vh}.sidebar-header{padding:20px;border-bottom:1px solid #333}.sidebar-header h1{margin:0;font-size:24px;color:#fff;font-weight:700}.sidebar-subtitle{margin:4px 0 0;font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#aaa;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-link:hover{background:#1a1a1a;color:#fff}.nav-link.active{background:#1a1a1a;color:#4a9eff;border-left-color:#4a9eff}.nav-link span{font-size:14px;font-weight:500}.sidebar-footer{padding:20px;border-top:1px solid #333;display:flex;align-items:center;justify-content:space-between;gap:10px}.admin-info{display:flex;align-items:center;gap:10px;flex:1}.admin-badge{background:#4a9eff;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.admin-name{color:#aaa;font-size:14px}.logout-button{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:8px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.logout-button:hover{background:#ef444433;border-color:#ef444480;transform:translateY(-1px)}.logout-button:active{transform:translateY(0)}.game-ops-layout{display:flex;height:100vh;overflow:hidden}.game-ops-content{flex:1;overflow-y:auto;background:#1a1a1a}.page-container{padding:40px;max-width:1400px;margin:0 auto}.page-header{margin-bottom:40px}.page-header h1{margin:0 0 8px;font-size:32px;color:#fff}.page-header p{margin:0;color:#888;font-size:16px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:#0f0f0f;border:1px solid #333;border-radius:8px;padding:24px;display:flex;gap:16px;transition:transform .2s,border-color .2s}.stat-card:hover{transform:translateY(-2px);border-color:#4a9eff}.stat-icon{font-size:32px;flex-shrink:0}.stat-content{flex:1}.stat-content h3{margin:0 0 8px;font-size:14px;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{margin:0 0 4px;font-size:28px;font-weight:700;color:#fff}.stat-value.status-online{color:#4ade80}.stat-label{font-size:12px;color:#666}.dashboard-section{margin-bottom:40px}.dashboard-section h2{margin:0 0 20px;font-size:20px;color:#fff}.quick-actions{display:flex;gap:16px;flex-wrap:wrap}.action-button{display:flex;align-items:center;gap:10px;padding:16px 24px;background:#0f0f0f;border:1px solid #333;border-radius:8px;color:#fff;text-decoration:none;font-size:15px;font-weight:500;transition:all .2s}.action-button:hover{background:#1a1a1a;border-color:#4a9eff;transform:translateY(-2px)}.restart-banner{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;padding:20px;border-radius:8px;display:flex;align-items:center;gap:16px;margin-bottom:20px}.restart-confirm{background:#ef44441a;border:2px solid rgba(239,68,68,.3);color:#fff;padding:24px;border-radius:8px;margin-bottom:20px}.restart-control{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:20px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.restart-btn{background:#fff!important;color:#ef4444!important;border:none!important}.restart-btn:hover{background:#fee2e2!important}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:60px 20px;background:#0f0f0f;border:1px solid #333;border-radius:8px;color:#666}.empty-state p:first-child{font-size:48px;margin:0 0 16px}.match-card{background:#0f0f0f;border:1px solid #333;border-radius:8px;padding:20px}.status-badge{padding:4px 12px;background:#4ade801a;color:#4ade80;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.team-score{padding:12px;border-radius:6px}.team-score.team1{background:#3b82f61a;color:#3b82f6}.team-score.team2{background:#ef44441a;color:#ef4444}.players-table{background:#0f0f0f;border:1px solid #333;border-radius:8px;overflow:hidden;max-height:500px;overflow-y:auto}.players-table table{width:100%;border-collapse:collapse}.players-table th{background:#1a1a1a;padding:12px;text-align:left;font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #333}.players-table td{padding:12px;border-bottom:1px solid #222;color:#fff}.players-table tr:last-child td{border-bottom:none}.player-status{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.player-status.status-online{background:#4ade801a;color:#4ade80}.player-status.status-offline{background:#9ca3af1a;color:#9ca3af}.player-status.status-in-match{background:#fbbf241a;color:#fbbf24}.info-card{background:#0f0f0f;border:1px solid #333;border-radius:8px;padding:20px}.info-card h3{margin:0 0 16px;font-size:16px;color:#fff;font-weight:600}.info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #222}.info-row:last-child{border-bottom:none}.info-row span{color:#888;font-size:14px}.info-row strong{color:#fff;font-size:14px}.error-text{color:#ef4444}.hidden-file-input{display:none}.map-editor{display:flex;height:100vh;background:#1a1a1a;color:#e0e0e0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.toolbar{background:#2d2d2d;border-bottom:1px solid #444;padding:8px 16px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;z-index:100;min-height:48px}.toolbar-section{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.toolbar-divider{width:1px;height:24px;background:#444;margin:0 8px}.project-info h2{margin:0;font-size:14px;font-weight:500;color:#e0e0e0}.tool-group{display:flex;gap:4px;align-items:center}.tool-group-label{font-size:12px;color:#999;margin-right:8px}.btn{background:#3a3a3a;color:#e0e0e0;border:1px solid #555;border-radius:4px;padding:8px 12px;cursor:pointer;font-size:13px;transition:all .2s}.btn:hover{background:#4a4a4a;border-color:#666}.btn.active{background:#0078d4;border-color:#106ebe}.tool-btn{background:#3a3a3a;color:#e0e0e0;border:1px solid #555;border-radius:4px;padding:8px 12px;cursor:pointer;font-size:13px;transition:all .2s;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}.tool-btn:hover{background:#4a4a4a;border-color:#666}.tool-btn.active{background:#0078d4;border-color:#106ebe;box-shadow:0 0 0 2px #0078d44d}.btn.btn-small{padding:4px 8px;font-size:12px}.btn.btn-icon{padding:6px;display:flex;align-items:center;justify-content:center}.btn.btn-tiny{padding:2px}.btn.btn-danger{background:#c33;border-color:#a22}.btn.btn-danger:hover{background:#d44}.btn.btn-primary{background:#0078d4;border-color:#106ebe}.btn.btn-primary:hover{background:#106ebe;border-color:#005a9e}.btn.btn-secondary{background:#3a3a3a;border-color:#555}.btn.btn-secondary:hover{background:#4a4a4a;border-color:#666}.btn.disabled{opacity:.4;cursor:not-allowed;color:#666}.dropdown{position:relative;display:inline-block}.dropdown-toggle{display:flex;align-items:center;gap:4px}.dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:#2d2d2d;border:1px solid #555;border-radius:4px;box-shadow:0 4px 12px #00000080;min-width:200px;z-index:1000;overflow:hidden}.dropdown-item{width:100%;background:transparent;color:#e0e0e0;border:none;padding:10px 16px;text-align:left;cursor:pointer;font-size:13px;display:flex;align-items:center;gap:12px;transition:background .15s}.dropdown-item:hover:not(.disabled){background:#3a3a3a}.dropdown-item.active{background:#0078d4;color:#fff}.dropdown-item.disabled{opacity:.4;cursor:not-allowed;color:#666}.dropdown-item span:first-of-type{flex:1}.dropdown-item .shortcut{font-size:11px;color:#999;margin-left:auto;padding-left:16px}.dropdown-item .toggle-indicator{margin-left:auto;padding-left:16px;color:#0078d4;font-weight:700}.dropdown-divider{height:1px;background:#444;margin:4px 0}.zoom-display{font-size:13px;color:#e0e0e0;padding:0 8px;min-width:50px;text-align:center}.editor-main{flex:1;display:flex;flex-direction:column}.editor-content{flex:1;display:flex}.editor-canvas{flex:1;display:flex;flex-direction:column;min-width:0}.sidebar{width:400px;background:#2d2d2d;border-left:1px solid #444;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden}.sidebar-left{width:450px;border-right:1px solid #444;border-left:none;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;max-height:100vh}.sidebar-left>.panel{flex:0 0 auto;max-height:85vh;min-height:200px}.map-canvas-container{flex:1;overflow:hidden;position:relative;background:#1a1a1a;min-height:0}.map-canvas{display:block;cursor:crosshair}.map-canvas[data-tool=select]{cursor:grab}.map-canvas[data-tool=select]:active{cursor:grabbing}.map-canvas[data-tool=tile]{cursor:crosshair}.map-canvas[data-tool=paint]{cursor:cell}.map-canvas[data-tool=prop],.map-canvas[data-tool=collision]{cursor:copy}.map-canvas[data-tool=death]{cursor:not-allowed}.map-canvas[data-tool=slope]{cursor:alias}.map-canvas[data-tool=spawn]{cursor:pointer}.map-canvas[data-tool=koth]{cursor:crosshair}.map-canvas[data-tool=eraser]{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2"><path d="m7 21-4.3-4.3c-1-1-1-2.5 0-3.4l9.6-9.6c1-1 2.5-1 3.4 0l5.6 5.6c1 1 1 2.5 0 3.4L13 21"/><path d="M22 21H7"/><path d="m5 11 9 9"/></svg>') 12 12,auto}.map-canvas[data-panning=true]{cursor:grab!important}.map-canvas[data-panning=true]:active{cursor:grabbing!important}.map-canvas[data-picking-coordinates=true]{cursor:crosshair!important}.panel{background:#2a2a2a;border-bottom:1px solid #3a3a3a;display:flex;flex-direction:column;min-height:0;max-height:100%}.panel-content{padding:12px;overflow-y:auto;flex:1;min-height:0}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #444;background:#333;flex-shrink:0}.panel-header h3{margin:0;font-size:14px;font-weight:600}.layers-panel{display:flex;flex-direction:column;max-height:500px;min-height:250px;margin-bottom:8px}.layers-list{flex:1;overflow-y:auto;padding:8px}.layer-item{background:#3a3a3a;border:1px solid #555;border-radius:4px;padding:8px;margin-bottom:4px;cursor:pointer;transition:all .2s}.layer-item:hover{background:#404040}.layer-item.selected{background:#0078d4;border-color:#106ebe}.layer-controls{display:flex;align-items:center;gap:8px;margin-bottom:8px}.layer-order-controls{display:flex;flex-direction:column;gap:2px}.layer-info{margin-bottom:8px}.layer-name{font-weight:500;font-size:13px}.layer-details{font-size:11px;color:#999}.layer-actions{display:flex;align-items:center;justify-content:space-between}.opacity-control{display:flex;align-items:center;gap:8px;font-size:11px}.opacity-control input[type=range]{width:60px}.layers-info{padding:8px 16px;border-top:1px solid #444;background:#333;font-size:11px}.info-row{margin-bottom:4px}.tileset-palette{flex:1;display:flex;flex-direction:column;max-height:50%}.palette-header{padding:12px 16px;border-bottom:1px solid #444;background:#333}.palette-header h3{margin:0 0 8px;font-size:14px;font-weight:600}.tileset-info{display:flex;gap:16px;font-size:11px;color:#999}.palette-content{flex:1;overflow-y:auto;padding:8px}.tileset-placeholder{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.placeholder-content{text-align:center;color:#999}.placeholder-content h4{margin:0 0 8px;font-size:16px;color:#bbb}.placeholder-content p{margin:0 0 8px;font-size:14px}.placeholder-content small{font-size:12px;color:#777}.panel-placeholder{padding:20px 16px;text-align:center;color:#888;border-top:1px solid #444;background:#2a2a2a;margin:0}.panel-placeholder h3{padding:12px 16px;border-bottom:1px solid #444;background:#333;margin:-20px -16px 16px;font-size:14px;font-weight:600}.panel-placeholder p{margin:0 0 8px;font-size:13px;line-height:1.4}.panel-placeholder small{font-size:11px;color:#666;display:block;margin-top:4px}.panel-placeholder .w-8{margin-bottom:8px;opacity:.6}.palette-row{display:flex;gap:4px;margin-bottom:4px}.tile-button{width:40px;height:40px;border:2px solid;border-radius:4px;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;text-shadow:1px 1px 1px rgba(0,0,0,.7);transition:all .2s}.tile-button:hover{transform:scale(1.1);z-index:10}.tile-button.selected{border-width:3px;transform:scale(1.1)}.tile-id{position:absolute;top:2px;left:2px;font-size:8px;background:#000000b3;padding:1px 3px;border-radius:2px}.tile-flag{position:absolute;font-size:8px;font-weight:700;width:12px;height:12px;display:flex;align-items:center;justify-content:center;border-radius:50%}.tile-flag.collision{top:2px;right:2px;background:#4a4}.tile-flag.death{bottom:2px;right:2px;background:#f44}.tile-flag.slope{bottom:2px;left:2px;background:#ff4;color:#000}.palette-footer{padding:12px 16px;border-top:1px solid #444;background:#333}.selected-tile-info h4{margin:0 0 8px;font-size:12px}.tile-properties{display:flex;gap:12px}.property{font-size:11px}.property label{display:flex;align-items:center;gap:4px;cursor:pointer}.properties-panel{display:flex;flex-direction:column;height:100%;min-height:0}.properties-content{flex:1;overflow-y:auto;padding:8px;min-height:0}.properties-section{margin-bottom:16px;background:#3a3a3a;border-radius:4px;overflow:hidden}.properties-section h4{margin:0;padding:8px 12px;background:#2d2d2d;font-size:12px;font-weight:600;border-bottom:1px solid #444}.section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#2d2d2d;border-bottom:1px solid #444}.section-header h4{margin:0;font-size:12px;font-weight:600}.property-group{padding:12px}.property-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px}.property-item label{font-weight:500;color:#ccc}.properties-list{max-height:150px;overflow-y:auto}.property-list-item{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border-bottom:1px solid #4a4a4a;font-size:11px;font-family:monospace}.property-list-item:last-child{border-bottom:none}.empty-list{padding:12px;text-align:center;color:#999;font-style:italic;font-size:11px;margin:0}.zoom-controls{display:flex;align-items:center;gap:8px;font-size:12px}.zoom-display{min-width:40px;text-align:center;font-family:monospace}input[type=range]{background:#555}input[type=checkbox]{accent-color:#0078d4}::-webkit-scrollbar-track{background:#2d2d2d}::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.prop-tilesets{max-height:400px;overflow-y:auto}.prop-tileset{border:1px solid #444;border-radius:4px;margin-bottom:8px}.prop-tileset-header{padding:8px 12px;background:#333;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s}.prop-tileset-header:hover{background:#3a3a3a}.prop-tileset-name{font-weight:500;font-size:13px}.prop-tileset-info{display:flex;align-items:center;gap:8px}.prop-count{font-size:11px;color:#999}.prop-grid{padding:12px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.prop-thumbnail-btn{background:#2d2d2d;border:1px solid #444;border-radius:4px;padding:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:56px}.prop-thumbnail-btn:hover{background:#3a3a3a;border-color:#555}.prop-thumbnail-btn.selected{background:#0078d4;border-color:#106ebe;box-shadow:0 0 0 2px #0078d44d}.prop-thumbnail-btn img{max-width:48px;max-height:48px;object-fit:contain}.panel-footer{border-top:1px solid #444;padding:12px;background:#333}.selected-prop-info{font-size:12px}.selected-prop-title{font-weight:500;margin-bottom:4px;color:#e0e0e0}.selected-prop-name{margin-bottom:2px;color:#ccc}.selected-prop-tileset{color:#999}.placed-props-list{max-height:300px;overflow-y:auto}.placed-prop-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border:1px solid #444;border-radius:4px;margin-bottom:4px;background:#2d2d2d;cursor:pointer;transition:all .2s}.placed-prop-item:hover{background:#3a3a3a;border-color:#555}.placed-prop-item.selected{background:#0078d4;border-color:#106ebe}.placed-prop-info{flex:1}.placed-prop-name{font-size:12px;font-weight:500;margin-bottom:2px;display:flex;align-items:center;gap:4px}.dynamic-indicator{font-size:10px;opacity:.7;cursor:help}.placed-prop-details{font-size:11px;color:#999}.placed-prop-actions{display:flex;gap:4px}.section{margin-bottom:16px}.section-title{font-size:13px;font-weight:500;margin-bottom:8px;color:#e0e0e0;border-bottom:1px solid #444;padding-bottom:4px}.detail-group{margin-bottom:12px}.detail-group-title{font-size:11px;font-weight:500;margin-bottom:6px;color:#ccc;text-transform:uppercase;letter-spacing:.5px}.detail-row{font-size:12px;margin-bottom:2px;color:#ccc}.detail-label{color:#999;margin-right:4px}.position-controls{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:8px}.position-center{display:flex;align-items:center;justify-content:center;padding:4px;border:1px solid #444;border-radius:2px;background:#333;color:#999}.rotation-controls{display:flex;gap:8px;margin-bottom:6px}.rotation-display{font-size:11px;color:#999}.flip-controls{display:flex;gap:8px}.scale-slider{width:100%;margin-bottom:6px}.scale-display{font-size:11px;color:#999;text-align:center}.number-input{width:100%;padding:4px 8px;border:1px solid #444;border-radius:2px;background:#2d2d2d;color:#e0e0e0;font-size:12px;margin-bottom:4px}.number-input:focus{border-color:#0078d4;outline:none}.z-index-help{font-size:10px;color:#999}.dynamic-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;margin-bottom:4px}.dynamic-toggle input[type=checkbox]{margin:0;cursor:pointer}.dynamic-label{font-size:12px;color:#e0e0e0;cursor:pointer;-webkit-user-select:none;user-select:none}.dynamic-help{font-size:10px;color:#999;font-style:italic}.visual-indicators-help{margin-top:6px}.visual-indicators-help small{font-size:9px;color:#666;font-style:italic}.bulk-actions{display:flex;gap:8px;margin-bottom:8px;padding:8px 0;border-bottom:1px solid #444;flex-shrink:0}.bulk-actions .btn{flex:1;font-size:11px}::-webkit-scrollbar-thumb:hover{background:#666}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-dialog{background:#2d2d2d;border-radius:8px;border:1px solid #444;min-width:400px;max-width:500px;max-height:80vh;overflow:hidden;box-shadow:0 10px 25px #00000080}.modal-header{padding:16px 20px;border-bottom:1px solid #444;display:flex;align-items:center;justify-content:space-between;background:#333}.modal-header h3{margin:0;font-size:16px;font-weight:600;color:#e0e0e0}.modal-close-btn{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close-btn:hover{background:#444;color:#e0e0e0}.modal-body{padding:20px;max-height:60vh;overflow-y:auto}.modal-form{display:flex;flex-direction:column;height:100%}.form-field{margin-bottom:16px}.form-field:last-child{margin-bottom:0}.form-field label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#e0e0e0}.form-field .required{color:#ff6b6b;margin-left:2px}.form-field input{width:100%;padding:10px 12px;border:1px solid #555;border-radius:4px;background:#1a1a1a;color:#e0e0e0;font-size:14px;transition:border-color .2s}.form-field input:focus{outline:none;border-color:#4a9eff;box-shadow:0 0 0 2px #4a9eff33}.form-field input::placeholder{color:#999}.modal-footer{padding:16px 20px;border-top:1px solid #444;display:flex;gap:12px;justify-content:flex-end;background:#333}.modal-footer .btn{min-width:80px}.toast-container{position:fixed;top:20px;right:20px;z-index:1100;display:flex;flex-direction:column;gap:10px;max-width:400px}.toast{padding:12px 16px;border-radius:6px;border:1px solid;display:flex;align-items:center;min-height:48px;box-shadow:0 4px 12px #0000004d;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:#1a472a;border-color:#2d7a2d;color:#4ade80}.toast-error{background:#472a2a;border-color:#7a2d2d;color:#f87171}.toast-info{background:#2a3547;border-color:#2d5a7a;color:#60a5fa}.toast-warning{background:#47472a;border-color:#7a7a2d;color:#fbbf24}.toast-content{display:flex;align-items:center;justify-content:space-between;width:100%}.toast-message{flex:1;font-size:14px;font-weight:500}.toast-close{background:none;border:none;font-size:18px;font-weight:700;cursor:pointer;color:inherit;opacity:.7;margin-left:12px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s}.toast-close:hover{opacity:1;background:#ffffff1a}.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:#333;border-radius:6px;border:1px solid;min-width:300px;max-width:500px;box-shadow:0 4px 12px #0000004d;pointer-events:auto;animation:toast-slide-in .3s ease-out}.toast-success{border-color:#4ade80;background:linear-gradient(135deg,#333,#2d4a2d)}.toast-error{border-color:#f87171;background:linear-gradient(135deg,#333,#4a2d2d)}.toast-warning{border-color:#fbbf24;background:linear-gradient(135deg,#333,#4a452d)}.toast-info{border-color:#60a5fa;background:linear-gradient(135deg,#333,#2d3a4a)}.toast-content{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.toast-message{color:#e0e0e0;font-size:14px;flex:1}.toast-close{background:none;border:none;color:#999;font-size:18px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s;flex-shrink:0}.toast-close:hover{background:#ffffff1a;color:#e0e0e0}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.maps-list{max-width:1200px;margin:0 auto}.map-editor-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;background:#1a1a1a;z-index:1000}.map-editor-fullscreen .editor-toolbar-extended{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;background:#2a2a2a;border-bottom:1px solid #444;padding:0;flex-shrink:0;gap:.5rem;min-height:48px}.map-editor-fullscreen .editor-workspace{flex:1;display:flex;overflow:hidden;min-height:0}.map-editor-fullscreen .left-panels{width:280px;flex-shrink:0;background:#1e1e1e;border-right:1px solid #444;overflow:hidden;display:flex;flex-direction:column}.map-editor-fullscreen .layers-panel{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.map-editor-fullscreen .properties-panel{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;border-top:1px solid #444}.map-editor-fullscreen .canvas-container{flex:1;overflow:auto;background:#0d0d0d;min-height:0;display:flex;flex-direction:column}.map-editor-fullscreen .map-canvas-container{flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:flex-start;min-height:0}.map-editor-fullscreen .map-canvas{display:block}.map-editor-fullscreen .right-panels{width:300px;display:flex;flex-direction:column;background:#1e1e1e;border-left:1px solid #444;overflow-y:auto;flex-shrink:0}.maps-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.maps-list-header h2{margin:0;font-size:1.5rem}.maps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.map-card{background:#2a2a2a;border:1px solid #444;border-radius:8px;padding:1.5rem;transition:all .2s}.map-card:hover{border-color:#666;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.map-card-content h3{margin:0 0 .5rem;font-size:1.25rem;color:#fff}.map-card-meta{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.map-card-meta span{font-size:.875rem;color:#999}.badge-official{background:#4caf50;color:#fff;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.map-card-date{font-size:.875rem;color:#666;margin:.5rem 0 0}.map-card-actions{margin-top:1rem;display:flex;gap:.5rem}.btn{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover{background:#1976d2}.btn-secondary{background:#555;color:#fff}.btn-secondary:hover{background:#666}.btn-small{padding:.375rem .75rem;font-size:.8125rem;background:#444;color:#fff}.btn-small:hover{background:#555}.btn-db{background:#4caf50;color:#fff}.btn-db:hover{background:#45a049}.btn:disabled{opacity:.5;cursor:not-allowed}.empty-state{text-align:center;padding:3rem;color:#999}.empty-state p{margin:0;font-size:1.125rem}.editor-toolbar-extended{display:flex;justify-content:space-between;align-items:center;background:#2a2a2a;border-bottom:1px solid #444;padding:0 1rem}.db-actions{display:flex;gap:.5rem;align-items:center;padding:.5rem 0}.current-map-info{font-size:.875rem;color:#999;padding:.5rem}.config-sections{max-width:1000px}.config-section{background:#0f0f0f;border:1px solid #333;border-radius:8px;padding:24px;margin-bottom:24px}.config-section h2{margin:0 0 20px;font-size:18px;color:#fff;padding-bottom:12px;border-bottom:1px solid #333}.config-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.config-item{display:flex;flex-direction:column;gap:8px}.config-item label{font-size:13px;color:#888;font-weight:500}.config-item input[type=number]{background:#1a1a1a;border:1px solid #333;border-radius:4px;padding:10px 12px;color:#fff;font-size:14px}.config-item input[type=number]:focus{outline:none;border-color:#4a9eff}.config-unit{font-size:12px;color:#666}.config-actions{display:flex;gap:12px;margin-top:32px}.btn{padding:12px 24px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:#4a9eff;color:#fff}.btn-primary:hover{background:#3a8eef}.btn-secondary{background:#333;color:#fff}.btn-secondary:hover{background:#444}.empty-state{text-align:center;padding:60px 20px;color:#666}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px}.login-container{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:48px;width:100%;max-width:420px;box-shadow:0 8px 32px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:32px;font-weight:700;color:#fff;margin:0 0 8px;text-transform:uppercase;letter-spacing:2px}.login-header p{font-size:14px;color:#fff9;margin:0}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#fffc;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:12px 16px;font-size:15px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;transition:all .2s ease}.form-group input:focus{outline:none;border-color:#4a9eff;background:#4a9eff1a;box-shadow:0 0 0 3px #4a9eff1a}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group input::placeholder{color:#ffffff4d}.login-error{padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:14px;text-align:center}.login-button{padding:14px 24px;font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:1px;background:linear-gradient(135deg,#4a9eff,#357abd);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4a9eff66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);text-align:center}.login-footer p{font-size:12px;color:#fff6;margin:0}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background:#1a1a1a;color:#fff;overflow:hidden}#root{width:100vw;height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#2a2a2a}::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#5a5a5a}.btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}
