*{margin:0;padding:0;box-sizing:border-box}body,html{background-color:#a5a4ce;font-family:System,monospace;font-size:13px;color:#000;min-height:100vh}a{color:#00f}a:hover{color:red}.nav-bar{background-color:grey;padding:6px 12px;display:flex;align-items:center;gap:4px;border-bottom:2px solid #404040}.nav-bar a{color:#000;text-decoration:none;padding:2px 10px;font-size:13px}.nav-bar a:hover{text-decoration:underline;color:#000}.nav-bar a.active{background-color:#00f;color:#fff;font-weight:700}.nav-hamburger{background-color:green;color:#fff;padding:2px 8px;font-weight:700;margin-right:8px;cursor:pointer;position:relative}.nav-hamburger:hover{background-color:#00a000}.sidebar-menu{display:none;position:absolute;top:100%;left:0;background-color:#d4d0c8!important;border:2px outset #fff;box-shadow:4px 4px 0 rgba(0,0,0,.4);min-width:180px;z-index:1000;padding:0;font-weight:400}.sidebar-menu.open{display:block}.sidebar-menu a{display:block;padding:8px 12px;color:#000!important;text-decoration:none;border-bottom:1px solid #a0a0a0;background-color:#d4d0c8}.sidebar-menu a:last-child{border-bottom:none}.sidebar-menu a:hover{background-color:#00f!important;color:#fff!important}.sidebar-menu .menu-header{padding:6px 12px;font-weight:700;background-color:grey!important;color:#fff!important;font-size:11px}.nav-buttons{margin-left:auto;display:flex;gap:4px}.container{max-width:1400px;margin:0 auto;padding:20px}.header-banner{background-color:#3465a4;border:2px groove #69c;box-shadow:6px 6px 0 rgba(0,0,0,.4);padding:25px 20px;text-align:center;margin-bottom:15px}.header-banner h1{color:#fff;font-size:52px;font-weight:400;text-shadow:2px 2px 4px rgba(0,0,0,.5);font-family:Georgia,serif;display:flex;align-items:center;justify-content:center;gap:15px;margin:0}.header-banner h1 img{height:60px;width:auto}.status-banner{background-color:#3465a4;border:2px groove #69c;box-shadow:6px 6px 0 rgba(0,0,0,.4);padding:8px 16px;margin-bottom:15px;display:flex;align-items:center;justify-content:center;gap:10px}.status-banner .message{color:#fff;font-size:13px}.status-banner.error .message{color:#f66}.status-banner.success .message{color:#6f6}.main-layout{display:grid;grid-template-columns:300px 1fr;gap:20px;align-items:stretch}.left-column{display:flex;flex-direction:column;gap:15px;width:300px;min-width:0}.left-column>fieldset{width:100%;min-width:0;overflow:hidden}.right-column{display:flex;flex-direction:column}.right-column>fieldset{flex:1;display:flex;flex-direction:column}.right-column .viewer-box{flex:1}fieldset{background-color:#d4d0c8;border:2px groove #fff;box-shadow:6px 6px 0 rgba(0,0,0,.4);padding:15px;margin:0}legend{background-color:#d4d0c8;padding:2px 8px;font-weight:700}.btn{background-color:grey;color:#fff;border:2px outset #a0a0a0;padding:4px 16px;font-family:System,monospace;font-size:13px;font-weight:700;cursor:pointer;box-shadow:3px 3px 0 rgba(0,0,0,.4)}.btn:hover{background-color:#909090}.btn:active{border-style:inset;box-shadow:1px 1px 0 rgba(0,0,0,.4)}.btn:disabled{background-color:#606060;border-color:#606060;color:#a0a0a0;cursor:not-allowed}.btn-secondary{background-color:#a0a0a0;color:#000;border-color:silver}.btn-secondary:hover{background-color:#b0b0b0}.btn-primary{background-color:green;border-color:#00a000}.btn-primary:hover{background-color:#00a000}.btn.active{background-color:#90ee90;border-style:inset;color:#000}.button-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;justify-content:center}.viewer-buttons{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.viewer-box{width:100%;min-height:400px;background-color:#000;border:2px inset #efefef;position:relative}.viewer-box canvas{display:block;cursor:grab}.viewer-box canvas:active{cursor:grabbing}#viewer-container{width:100%;height:100%}.drop-zone{width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;color:#0f0;font-family:'Courier New',monospace;font-size:16px;cursor:pointer;position:absolute;top:0;left:0}.drop-zone.drag-over{background-color:#030}.drop-zone p{margin:5px 0;white-space:nowrap;font-size:clamp(10px, 2vw, 16px)}.drop-zone.hidden{display:none}#explorer-panel{max-height:200px;overflow-y:auto}.explorer-header{display:none}.explorer-tree{padding:4px;background-color:#fff;border:1px solid grey;margin:0}.tree-section{margin-bottom:5px}.tree-section.collapsed .tree-list{display:none}.tree-header{cursor:pointer;padding:3px 5px;background-color:#d0d0d0;border:1px solid grey;font-weight:700;font-size:12px}.tree-header:hover{background-color:silver}.tree-toggle{font-family:monospace;margin-right:5px}.tree-list{list-style:none;margin:0;padding:0;padding-left:15px}.tree-item{padding:2px 5px;cursor:pointer;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-item:hover{background-color:#c0c0ff}.tree-item.selected{background-color:navy;color:#fff}#preview-panel{max-height:200px}.preview-header{display:none}.preview-content{padding:6px;text-align:center;background-color:#fff;border:1px solid grey;margin:0}#preview-canvas{border:1px solid grey;background-color:#000;image-rendering:pixelated}.preview-info{font-size:11px;color:#404040;margin-top:5px}.editor-tabs{display:flex;background-color:grey;padding:2px 2px 0 2px;gap:2px;overflow-x:auto}.tab-btn{flex:1;padding:5px 4px;border:2px outset silver;border-bottom:none;background-color:silver;cursor:pointer;font-size:10px;font-family:System,monospace;white-space:nowrap;text-align:center}.tab-btn:hover{background-color:#d0d0d0}.tab-btn.active{background-color:#d4d0c8;border-style:inset;font-weight:700}.editor-panel{display:none;background-color:#d4d0c8;padding:8px;max-height:350px;min-height:120px;overflow-y:auto;border:2px inset silver}.editor-panel.active{display:block}.editor-form{font-size:12px}.editor-table{width:100%;border-collapse:collapse}.editor-table td{padding:3px 5px;vertical-align:middle}.editor-table .label{width:100px;text-align:right;font-weight:700;color:#404040}.editor-table hr{border:none;border-top:1px solid grey;margin:5px 0}.editor-select{width:100%;padding:2px;font-size:11px;background-color:#fff;border:2px inset silver}.editor-input{width:80px;padding:2px;font-size:11px;border:2px inset silver}.editor-input-text{width:100%;padding:2px;font-size:11px;border:2px inset silver}.editor-color{width:50px;height:20px;padding:0;border:2px inset silver;cursor:pointer}.geo-editor{font-size:12px}.geo-tabs{display:flex;gap:2px;margin-bottom:8px}.geo-tab{flex:1;padding:4px 8px;border:1px solid grey;background-color:silver;cursor:pointer;font-size:11px}.geo-tab:hover{background-color:#d0d0d0}.geo-tab.active{background-color:#d4d0c8;font-weight:700}.geo-panel{display:block}.geo-panel.hidden{display:none}.geo-search{margin-bottom:8px}.geo-search input{width:100%;padding:4px;border:2px inset silver;font-size:11px;box-sizing:border-box}.geo-list{height:120px;overflow-y:auto;border:2px inset silver;background-color:#fff;margin-bottom:8px}.geo-item{padding:3px 6px;cursor:pointer;font-size:11px;font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.geo-item:hover{background-color:#c0c0ff}.geo-item.selected{background-color:navy;color:#fff}.geo-item.more{font-style:italic;color:grey;cursor:default}.geo-item .idx{display:inline-block;min-width:30px;color:#00f}.geo-item.selected .idx{color:#ff0}.geo-form{background-color:silver;border:2px inset silver;padding:8px}.geo-form h4{margin:0 0 8px 0;font-size:12px;border-bottom:1px solid grey;padding-bottom:4px}.geo-form fieldset{margin:0 0 8px 0;padding:6px;border:1px solid grey;box-shadow:none}.geo-form fieldset legend{padding:0 4px;font-size:11px}.geo-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.geo-row label{min-width:20px;font-weight:700;color:#404040}.geo-row input[type=number],.geo-row input[type=text]{flex:1;padding:2px 4px;border:2px inset silver;font-size:11px;font-family:monospace}.geo-row input[type=color]{width:60px;height:24px;padding:0;border:2px inset silver;cursor:pointer}.geo-row input[type=range]{flex:1}.geo-apply{width:100%;margin-top:8px;padding:4px 8px;border:2px outset silver;background-color:silver;cursor:pointer;font-size:11px;font-weight:700}.geo-apply:hover{background-color:#d0d0d0}.geo-apply:active{border-style:inset}.color-item{display:flex;align-items:center;gap:6px}.color-swatch{display:inline-block;width:16px;height:16px;border:1px solid grey}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#d4d0c8;border:2px groove #fff;box-shadow:6px 6px 0 rgba(0,0,0,.4);min-width:400px;max-width:600px;display:flex;flex-direction:column}.modal-header{padding:8px 12px;background-color:navy;display:flex;justify-content:space-between;align-items:center}.modal-title{margin:0;font-size:14px;color:#fff;font-weight:700}.modal-close{background:0 0;border:none;color:#fff;font-size:16px;cursor:pointer}.modal-close:hover{color:red}.modal-body{padding:16px;color:#000;max-height:400px;overflow-y:auto}.modal-footer{padding:12px 16px;border-top:1px solid grey;display:flex;justify-content:flex-end}.modal-ok{background-color:grey;color:#fff;border:2px outset #a0a0a0;padding:4px 16px;cursor:pointer;font-weight:700}.modal-ok:hover{background-color:#909090}.modal-ok:active{border-style:inset}.model-info-stats{font-family:monospace}.stat-group{margin-bottom:16px}.stat-group h4{margin:0 0 8px 0;color:navy;font-size:14px}.stat-row{display:flex;justify-content:space-between;margin-bottom:4px;font-size:13px}.stat-row label{color:#404040}.footer{text-align:center;padding:20px;font-size:11px;color:#404040}.hit-counter{font-family:'Courier New',monospace;background-color:#000;color:#0f0;padding:2px 8px;font-size:11px}@media (max-width:900px){.main-layout{grid-template-columns:1fr}.left-column{order:2}.right-column{order:1}.viewer-box{height:400px}}@media (max-width:600px){.container{padding:10px}.header-banner{flex-direction:column;gap:10px}.header-banner .header-buttons{flex-wrap:wrap;justify-content:center}.nav-buttons{display:none}.viewer-buttons{flex-wrap:wrap;justify-content:center}.left-column,.right-column{width:100%}fieldset{margin-left:auto;margin-right:auto}}.btn-icon{background:0 0;border:none;cursor:pointer;font-size:16px;padding:2px}.btn-icon:hover{background-color:rgba(255,255,255,.2)}.about-content{line-height:1.6}.about-content h2{font-size:18px;margin-bottom:15px;font-weight:700;color:navy;border-bottom:2px solid grey;padding-bottom:5px}.about-content h3{font-size:14px;margin:15px 0 8px 0;font-weight:700}.about-content p{margin-bottom:12px}.about-content ul{margin-left:20px;margin-bottom:12px}.about-content li{margin-bottom:6px;line-height:1.5}.back-link{display:inline-block;margin-top:10px}