*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;width:100%;height:100%}body{overflow:hidden;font-family:system-ui,-apple-system,sans-serif}.app{position:relative;width:100%;height:100%}.app canvas{display:block;width:100%;height:100%;touch-action:none}.dev-tools{position:absolute;top:12px;left:12px;z-index:10;display:flex;flex-direction:column;align-items:flex-start;gap:6px}.dev-tools button{padding:6px 12px;border:1px solid #444;border-radius:4px;background:#1a1a1ad9;color:#ddd;font:13px/1.4 system-ui,-apple-system,sans-serif;cursor:pointer}.dev-tools button:hover{background:#282828f2;border-color:#666}.dev-tools__meta{padding:4px 8px;border-radius:4px;background:#1a1a1ad9;color:#888;font:11px/1.3 system-ui,-apple-system,sans-serif}.overlay-panel{padding:10px 12px;border:1px solid #444;border-radius:6px;background:#1a1a1ae6;color:#ddd;font:13px/1.4 system-ui,-apple-system,sans-serif}.overlay-panel__title{margin:0;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#aaa}.overlay-panel__header{display:flex;align-items:center;justify-content:space-between;gap:8px}.overlay-panel__collapse{flex-shrink:0;width:22px;height:22px;padding:0;border:1px solid #444;border-radius:4px;background:#282828cc;color:#ccc;font:16px/1 system-ui,-apple-system,sans-serif;cursor:pointer}.overlay-panel__collapse:hover{background:#373737f2;border-color:#666;color:#fff}.overlay-panel__body{margin-top:8px}.overlay-panel--collapsed{padding-bottom:10px}.layers-panel{position:absolute;top:12px;right:12px;z-index:10;min-width:180px}.selection-panel{position:absolute;bottom:12px;right:12px;z-index:10;width:min(260px,calc(100vw - 24px));max-height:calc(100vh - 24px);overflow-y:auto}.layers-panel__list{margin:0;padding:0;list-style:none}.layers-panel__item{display:flex;align-items:center;gap:8px;padding:4px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.layers-panel__item input{margin:0;cursor:pointer}.layers-panel__label{flex:1;text-transform:capitalize}.layers-panel__count{font-size:11px;color:#888}.layers-panel__hint{margin:8px 0 0;font-size:11px;color:#666}.view-panel{position:absolute;bottom:12px;left:12px;z-index:10;width:min(280px,calc(100vw - 24px))}.view-panel__group+.view-panel__group{margin-top:12px;padding-top:12px;border-top:1px solid #333}.view-panel__heading{margin:0 0 8px;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:#888}.view-panel__buttons{display:grid;grid-template-columns:1fr 1fr;gap:6px}.view-panel__button{padding:6px 8px;border:1px solid #444;border-radius:4px;background:#282828cc;color:#ddd;font:12px/1.3 system-ui,-apple-system,sans-serif;cursor:pointer}.view-panel__button:hover{background:#373737f2;border-color:#666}.view-panel__row{display:flex;align-items:center;gap:8px;margin-bottom:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.view-panel__row--slider{flex-direction:column;align-items:stretch;gap:4px;cursor:default}.view-panel__row input[type=checkbox]{margin:0;cursor:pointer}.view-panel__label{font-size:12px;color:#bbb}.view-panel__label strong{color:#eee;font-weight:600}.view-panel__select{flex:1;padding:4px 6px;border:1px solid #444;border-radius:4px;background:#282828e6;color:#ddd;font:12px system-ui,-apple-system,sans-serif}.view-panel__select:disabled,.view-panel__slider:disabled{opacity:.45;cursor:not-allowed}.view-panel__slider{width:100%;margin:0;cursor:pointer}.zone-label{padding:4px 10px;border:1px solid rgba(255,255,255,.35);border-radius:4px;background:#000000b8;color:#f0f0f0;font:600 13px/1.3 system-ui,-apple-system,sans-serif;white-space:nowrap;-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px rgba(0,0,0,.8)}.selection-panel__hint{margin:0 0 8px;font-size:12px;color:#888}.selection-panel__details{margin:0 0 8px}.selection-panel__row{display:grid;grid-template-columns:64px 1fr;gap:8px;margin-bottom:4px;font-size:12px}.selection-panel__row dt{margin:0;color:#888}.selection-panel__row dd{margin:0;color:#eee;word-break:break-word}.selection-panel__clear{width:100%;padding:5px 8px;margin-bottom:10px;border:1px solid #444;border-radius:4px;background:#282828cc;color:#ddd;font:12px system-ui,-apple-system,sans-serif;cursor:pointer}.selection-panel__clear:hover{background:#373737f2;border-color:#666}.selection-panel__list-section{padding-top:10px;border-top:1px solid #333}.selection-panel__list-toggle{width:100%;padding:5px 8px;margin-bottom:8px;border:1px solid #444;border-radius:4px;background:#282828cc;color:#ddd;font:12px system-ui,-apple-system,sans-serif;cursor:pointer;text-align:left}.selection-panel__list-toggle:hover{background:#373737f2;border-color:#666}.selection-panel__search{width:100%;padding:5px 8px;margin-bottom:6px;border:1px solid #444;border-radius:4px;background:#282828e6;color:#ddd;font:12px system-ui,-apple-system,sans-serif}.selection-panel__list{margin:0;padding:0;list-style:none;max-height:160px;overflow-y:auto}.selection-panel__list-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:5px 6px;border:none;border-radius:3px;background:transparent;color:#ddd;font:12px/1.3 system-ui,-apple-system,sans-serif;cursor:pointer;text-align:left}.selection-panel__list-item:hover{background:#ffffff0f}.selection-panel__list-item--active{background:#ffcc001f}.selection-panel__list-id{color:#eee;font-weight:600}.selection-panel__list-meta{color:#888;font-size:11px}.selection-panel__section-label{grid-column:1 / -1;margin:8px 0 4px;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:#888}.scale-bar{position:absolute;bottom:12px;left:50%;z-index:10;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 10px;border:1px solid #444;border-radius:6px;background:#1a1a1ae6;transform:translate(-50%);pointer-events:none;-webkit-user-select:none;user-select:none}.scale-bar__line{position:relative;height:0;border-top:2px solid #ddd}.scale-bar__tick{position:absolute;top:-6px;width:2px;height:10px;background:#ddd}.scale-bar__tick--start{left:0}.scale-bar__tick--end{right:0}.scale-bar__label{color:#ccc;font:11px/1.2 system-ui,-apple-system,sans-serif}.compass{position:absolute;top:72px;left:12px;z-index:10;pointer-events:none;-webkit-user-select:none;user-select:none}.compass__ring{position:relative;width:56px;height:56px;border:1px solid #444;border-radius:50%;background:#1a1a1ae6}.compass__dial{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%}.compass__label{position:absolute;top:50%;left:50%;width:14px;margin:-6px 0 0 -7px;color:#aaa;font:600 10px/1 system-ui,-apple-system,sans-serif;text-align:center;transform-origin:center center}.compass__label--north{color:#e85d5d;font-size:11px}.compass__tick{position:absolute;background:#666}.compass__tick--north{top:6px;left:50%;width:2px;height:6px;margin-left:-1px;background:#e85d5d}.compass__tick--east,.compass__tick--west{top:50%;width:5px;height:2px;margin-top:-1px}.compass__tick--east{right:6px}.compass__tick--west{left:6px}.compass__tick--south{bottom:6px;left:50%;width:2px;height:5px;margin-left:-1px}.compass__center{position:absolute;top:50%;left:50%;width:4px;height:4px;margin:-2px 0 0 -2px;border-radius:50%;background:#ccc}.pan-pad{position:absolute;right:12px;bottom:100px;z-index:10;display:grid;gap:2px;justify-items:center;touch-action:none;-webkit-user-select:none;user-select:none}.pan-pad__row{display:flex;align-items:center;gap:2px}.pan-pad__btn{width:40px;height:40px;padding:0;border:1px solid #444;border-radius:6px;background:#1a1a1ae6;color:#ddd;font:14px/1 system-ui,-apple-system,sans-serif;cursor:pointer}.pan-pad__btn:active{background:#373737f2;border-color:#666;color:#fff}.pan-pad__center{width:40px;height:40px;border-radius:6px;background:#28282880;border:1px solid #333}.touch-hints{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#00000073;cursor:pointer;transition:opacity .6s ease}.touch-hints--in{opacity:1}.touch-hints--out{opacity:0;pointer-events:none}.touch-hints__card{width:min(300px,100%);padding:18px 20px 14px;border:1px solid #555;border-radius:12px;background:#161616f5;box-shadow:0 12px 40px #0000008c;animation:touch-hints-rise .45s ease-out}.touch-hints__title{margin:0 0 14px;font:600 13px/1.3 system-ui,-apple-system,sans-serif;letter-spacing:.06em;text-transform:uppercase;text-align:center;color:#aaa}.touch-hints__list{margin:0;padding:0;list-style:none}.touch-hints__item{display:flex;align-items:center;gap:14px;padding:10px 0}.touch-hints__item+.touch-hints__item{border-top:1px solid #333}.touch-hints__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid #444;border-radius:10px;background:#282828e6;color:#e8c547;font:600 20px/1 system-ui,-apple-system,sans-serif}.touch-hints__text{display:flex;flex-direction:column;gap:2px;font:13px/1.35 system-ui,-apple-system,sans-serif;color:#ddd}.touch-hints__text strong{font-weight:600;color:#f0f0f0}.touch-hints__detail{font-size:11px;color:#888}.touch-hints__dismiss{margin:12px 0 0;font:11px/1.3 system-ui,-apple-system,sans-serif;text-align:center;color:#666}@keyframes touch-hints-rise{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:640px),(pointer:coarse)and (max-width:900px){.view-panel{bottom:12px;left:12px;right:auto;width:min(240px,calc(50vw - 18px));max-height:min(42vh,320px);overflow-y:auto}.selection-panel{bottom:12px;right:12px;left:auto;width:min(240px,calc(50vw - 18px));max-height:min(42vh,320px)}.scale-bar{bottom:auto;top:12px;left:50%;transform:translate(-50%)}.layers-panel{top:56px;max-width:min(180px,calc(100vw - 24px))}.compass{top:auto;bottom:68px;left:12px}.pan-pad{right:12px;bottom:88px}}
