*{box-sizing:border-box;margin:0}html,body,#root{height:100%;overflow:hidden}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;font-size:13px}.app{display:flex;flex-direction:column;height:100%}.main{display:flex;flex:1;min-height:0}.toolbar{display:flex;align-items:center;gap:12px;padding:0 14px;height:46px;flex:none;background:#211f26;color:#e8e6ef;-webkit-user-select:none;user-select:none;overflow-x:auto}.doc-name{font:inherit;color:#e8e6ef;background:transparent;border:1px solid transparent;border-radius:6px;padding:5px 8px;width:160px}.doc-name:hover,.doc-name:focus{border-color:#46424f;background:#2a2731;outline:none}.maps-btn{margin-left:auto}.brand{font-weight:700;font-size:15px;letter-spacing:.02em}.tag{font-size:11px;color:#9b97a8;border:1px solid #3a3742;border-radius:4px;padding:2px 6px}.group{display:flex;gap:4px}.toolbar button{font:inherit;color:#e8e6ef;background:#322f3a;border:1px solid #46424f;border-radius:6px;padding:5px 12px;cursor:pointer}.toolbar button:hover:not(:disabled){background:#3d3947}.toolbar button.active{background:#4f46e5;border-color:#6b63f0}.toolbar button:disabled{opacity:.4;cursor:default}.hint{color:#9b97a8;font-size:12px;margin-left:auto}.canvas-wrap{position:relative;flex:1;min-height:0}.canvas-wrap canvas{position:absolute;inset:0;width:100%;height:100%;touch-action:none}.onboarding{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;pointer-events:none;-webkit-user-select:none;user-select:none;color:#8a8494;text-align:center}.onboarding strong{font-size:20px;color:#6f6a7c}.onboarding span{font-size:12px;line-height:1.7}.hud{position:absolute;left:10px;bottom:10px;padding:4px 8px;background:#211f26d1;color:#cfccda;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;border-radius:5px;pointer-events:none}.label-input{position:absolute;transform:translate(-50%,-50%);font:14px Georgia,serif;padding:4px 8px;border:1.5px solid #4f46e5;border-radius:4px;background:#fff;outline:none;width:160px}.sidebar{width:220px;flex:none;background:#26232c;color:#e8e6ef;padding:12px;overflow-y:auto;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;gap:18px}.sidebar h3{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#9b97a8;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.sidebar button{font:inherit;color:#e8e6ef;background:#322f3a;border:1px solid #46424f;border-radius:6px;padding:5px 10px;cursor:pointer}.sidebar button:hover:not(:disabled){background:#3d3947}.sidebar button.active{background:#4f46e5;border-color:#6b63f0}.sidebar button:disabled{opacity:.4;cursor:default}.sidebar button.mini{padding:1px 6px;font-size:11px;border-radius:4px}.sidebar button.mini.dim{opacity:.45}.option-row{display:flex;gap:6px;align-items:center;font-size:12px}.palette{display:grid;grid-template-columns:1fr 1fr;gap:6px}.palette button{font-size:12px;padding:8px 4px}.note{font-size:11px;color:#9b97a8;margin-top:8px}.layers{list-style:none;display:flex;flex-direction:column;gap:4px}.layers li{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:5px 8px;border-radius:6px;border:1px solid transparent;cursor:pointer;font-size:12px;min-height:30px}.layers li .hover-only{display:none}.layers li:hover .hover-only{display:inline-block}.layers li:hover{background:#2e2b36}.layers li.active{background:#322f3a;border-color:#4f46e5}.layers li input{font:inherit;width:90px;background:#211f26;color:inherit;border:1px solid #4f46e5;border-radius:4px;padding:2px 4px;outline:none}.layer-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-btns{display:flex;gap:2px}.modal-overlay{position:fixed;inset:0;background:#0a090c99;display:flex;align-items:center;justify-content:center;z-index:10}.modal{background:#26232c;color:#e8e6ef;border-radius:12px;padding:18px;width:min(720px,90vw);max-height:80vh;overflow-y:auto}.modal header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.modal header div{display:flex;gap:8px}.modal button{font:inherit;color:#e8e6ef;background:#322f3a;border:1px solid #46424f;border-radius:6px;padding:5px 12px;cursor:pointer}.modal button:hover{background:#3d3947}.map-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.map-card{background:#2e2b36;border:1px solid #46424f;border-radius:8px;overflow:hidden;cursor:pointer}.map-card:hover{border-color:#6b63f0}.map-card img,.thumb-empty{width:100%;aspect-ratio:8 / 5;object-fit:cover;display:block;background:#f5f2ea}.thumb-empty{display:flex;align-items:center;justify-content:center;color:#9b97a8}.map-card-meta{display:flex;align-items:center;gap:6px;padding:7px 9px;font-size:12px}.map-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-date{color:#9b97a8;font-size:11px}.map-card .mini{padding:1px 6px;font-size:11px}.import-error{color:#f0a5a5;margin-bottom:10px}.crash{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:#211f26;color:#e8e6ef;padding:24px;text-align:center}.crash p{max-width:480px;color:#9b97a8}.crash-actions{display:flex;gap:10px}.crash button{font:inherit;color:#e8e6ef;background:#4f46e5;border:1px solid #6b63f0;border-radius:6px;padding:8px 16px;cursor:pointer}.crash pre{font-size:11px;color:#6f6a7c;max-width:90vw;overflow-x:auto}.theme-list{display:flex;flex-direction:column;gap:6px}.theme-list button{display:flex;align-items:center;gap:8px;text-align:left;font-size:12px}.swatch{width:16px;height:16px;border-radius:4px;border:2px solid;flex:none}.export-modal section{margin-top:16px}.export-modal h3{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#9b97a8;margin-bottom:8px}.export-modal .option-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;font-size:12px}.export-modal input[type=number]{font:inherit;width:64px;background:#211f26;color:#e8e6ef;border:1px solid #46424f;border-radius:6px;padding:5px 8px}.export-modal .note{font-size:11px;color:#9b97a8;margin-top:8px}.export-formats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.export-formats button{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 12px;text-align:left}.export-formats button span{font-size:11px;color:#9b97a8}.export-formats button.active{background:#4f46e5;border-color:#6b63f0}.export-formats button.active span{color:#d6d3f0}.modal button.primary{background:#4f46e5;border-color:#6b63f0}.modal button.primary:hover{background:#5b52f0}
