:root{--bg: #1a1a1a;--panel: #252525;--text: #e0e0e0;--accent: #2d7af6;--header-height: 40px;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;overflow:hidden;overscroll-behavior:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}.app{display:flex;flex-direction:column;height:100%;width:100%}.header-bar{flex:0 0 var(--header-height);height:var(--header-height);display:flex;align-items:center;padding:0 16px;background:var(--panel);border-bottom:1px solid #000;z-index:10}.header-title{font-size:15px;font-weight:600;letter-spacing:.02em}.header-gear{margin-left:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:#cfcfcf;font-size:18px;line-height:1;width:30px;height:30px;border-radius:6px;cursor:pointer}.header-gear:hover{background:#333;color:#fff}.map-area{position:relative;flex:1 1 auto;min-height:0;overflow:hidden}.load-map{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.load-map-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #3a3a3a;background:var(--panel);color:var(--text);font-size:16px;font-weight:500;padding:14px 32px;border-radius:10px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.load-map-button:hover{background:#303030;border-color:var(--accent)}.load-map-button:active{background:#383838}.load-map-hint{margin:0;font-size:13px;color:#888}.map-container{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;touch-action:none;cursor:grab;background:#0e0e0e}.map-container:active{cursor:grabbing}.map-transform{position:absolute;top:0;left:0;will-change:transform}.map-image{display:block;-webkit-user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}.svg-layer{overflow:visible}.units-group{pointer-events:auto}.unit-tray{position:fixed;top:var(--header-height);right:0;bottom:0;width:280px;z-index:20;display:flex;flex-direction:column;background:#1e1e1e;border-left:1px solid #333;overflow-y:auto;overscroll-behavior:contain}.tray-section{border-bottom:1px solid #2c2c2c}.tray-section-header{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:#252525;border:none;color:var(--text);font-size:13px;font-weight:600;text-align:left;cursor:pointer}.tray-section-header:hover{background:#2a2a2a}.tray-section-caret{width:12px;color:#888;font-size:10px}.tray-section-title{flex:1 1 auto;letter-spacing:.02em}.tray-section-count{min-width:22px;padding:1px 7px;border-radius:10px;background:#333;color:#bbb;font-size:11px;text-align:center}.tray-section-body{padding:4px 0 8px}.tray-category-label{padding:6px 12px 2px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#777}.tray-empty{padding:4px 12px 8px;font-size:12px;color:#5a5a5a;font-style:italic}.tray-entry{display:flex;align-items:center;padding:5px 12px;cursor:grab}.tray-entry:hover{background:#2a2a2a}.unit-chip{display:inline-flex;align-items:center;gap:9px}.unit-chip-shape{display:block;flex:0 0 auto}.unit-chip-label{font-size:13px;color:var(--text)}.tray-dropzones{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;flex-direction:column;background:#141414}.tray-dropzone{flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:2px dashed #3a3a3a;margin:-1px 0 0;color:#aaa;transition:background .1s ease,border-color .1s ease,color .1s ease}.tray-dropzone.is-over{background:#2d7af638;border-color:var(--accent);border-style:solid;color:#fff}.tray-dropzone-label{font-size:16px;font-weight:600}.tray-dropzone-count{font-size:12px;color:inherit;opacity:.7}.drag-ghost{position:fixed;z-index:1000;transform:translate(-50%,-50%);pointer-events:none;padding:6px 10px;border-radius:8px;background:#2c2c2c;border:1px solid #444;box-shadow:0 6px 18px #00000080;opacity:.95}.radial-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.radial-svg{position:fixed;z-index:41;pointer-events:none;animation:radialIn .12s ease-out}@keyframes radialIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.radial-wedge{pointer-events:auto;fill:#0a0a0ad1;stroke:#4a4a4a;stroke-width:1;cursor:pointer;transition:fill .1s ease}.radial-wedge:hover,.radial-wedge.pressed{fill:var(--accent)}.radial-label{pointer-events:none;fill:#fff;font-size:14px;font-weight:600;-webkit-user-select:none;user-select:none}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49;background:#00000040}.detail-sheet{position:fixed;left:0;right:0;bottom:0;z-index:50;max-height:72vh;display:flex;flex-direction:column;background:#1e1e1e;border-top:1px solid #333;border-radius:14px 14px 0 0;box-shadow:0 -8px 24px #00000080;animation:sheetUp .2s ease-out}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{display:flex;justify-content:center;padding:8px;cursor:grab;touch-action:none}.sheet-grabber{width:40px;height:4px;border-radius:2px;background:#555}.sheet-header{display:flex;align-items:center;padding:0 16px 10px;border-bottom:1px solid #2c2c2c}.sheet-title{flex:1 1 auto;font-size:16px;font-weight:600}.sheet-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:#aaa;font-size:26px;line-height:1;cursor:pointer;width:32px;height:32px}.sheet-body{padding:12px 16px 20px;overflow-y:auto}.field{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #262626}.field-label{width:96px;flex:0 0 auto;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#888}.field-readonly{font-size:14px;color:var(--text)}.field-input{flex:1 1 auto;background:#161616;border:1px solid #3a3a3a;border-radius:6px;color:var(--text);font-size:14px;padding:7px 10px}.field-input:focus{outline:none;border-color:var(--accent)}.notes{padding-top:14px}.note-list{margin-top:8px;display:flex;flex-direction:column;gap:4px;max-height:32vh;overflow-y:auto}.note-empty{color:#5a5a5a;font-style:italic;font-size:13px;padding:4px 0}.note-row{display:flex;align-items:center;gap:8px}.note-text{flex:1 1 auto;min-width:0;background:#161616;border:1px solid transparent;border-radius:6px;color:var(--text);font-size:14px;padding:6px 8px}.note-text:focus{outline:none;border-color:var(--accent);background:#101010}.note-time{flex:0 0 auto;font-size:11px;color:#777}.note-del{flex:0 0 auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:#888;font-size:18px;line-height:1;cursor:pointer;width:24px}.note-del:hover{color:#e06464}.note-add{display:flex;gap:8px;margin-top:10px}.note-input{flex:1 1 auto;min-width:0;background:#161616;border:1px solid #3a3a3a;border-radius:6px;color:var(--text);font-size:14px;padding:8px 10px}.note-input:focus{outline:none;border-color:var(--accent)}.note-add-btn{flex:0 0 auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--accent);background:#2d7af62e;color:#cfe0ff;border-radius:6px;padding:8px 14px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}.note-add-btn:active{background:#2d7af64d}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#00000080;display:flex;align-items:center;justify-content:center;padding:24px}.modal-panel{width:100%;max-width:540px;max-height:86vh;display:flex;flex-direction:column;background:#1e1e1e;border:1px solid #333;border-radius:14px;box-shadow:0 12px 40px #0009}.modal-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid #2c2c2c}.modal-title{flex:1 1 auto;font-size:16px;font-weight:600}.modal-body{padding:14px 16px 18px;overflow-y:auto}.type-list{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.type-row{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;background:#242424}.type-row-info{flex:1 1 auto;display:flex;flex-direction:column;min-width:0}.type-row-name{font-size:14px;font-weight:600}.type-row-meta{font-size:12px;color:#888}.btn-primary,.btn-subtle,.btn-danger{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:7px;font-size:13px;font-weight:600;padding:8px 14px;cursor:pointer;white-space:nowrap}.btn-primary{border:1px solid var(--accent);background:#2d7af633;color:#cfe0ff}.btn-primary:active{background:#2d7af659}.btn-subtle{border:1px solid #3a3a3a;background:#2a2a2a;color:var(--text)}.btn-danger{border:1px solid #5a2a2a;background:#2a1a1a;color:#e06464}.type-form{display:flex;flex-direction:column}.count-control{display:flex;align-items:center;gap:6px}.count-control button{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:30px;height:30px;border:1px solid #3a3a3a;background:#2a2a2a;color:var(--text);border-radius:6px;font-size:18px;line-height:1;cursor:pointer}.count-control input{width:56px;text-align:center;background:#161616;border:1px solid #3a3a3a;border-radius:6px;color:var(--text);font-size:14px;padding:6px}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.style-editor{display:flex;flex-direction:column;gap:12px;padding:8px 0}.style-preview{display:flex;justify-content:center;padding:6px 0;background:#161616;border-radius:10px}.style-field{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.style-label{width:84px;flex:0 0 auto;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#888}.style-options{display:flex;gap:6px;flex-wrap:wrap}.symbol-grid{max-width:360px}.style-swatch-btn,.space-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px;border:2px solid transparent;border-radius:8px;background:#242424;cursor:pointer;color:#aaa;font-size:11px}.style-swatch-btn.selected,.space-btn.selected{border-color:var(--accent);background:#2c2c2c;color:#fff}.toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #3a3a3a;background:#2a2a2a;color:var(--text);border-radius:7px;padding:6px 16px;font-size:13px;font-weight:600;cursor:pointer}.toggle.on{border-color:var(--accent);background:#2d7af633;color:#cfe0ff}.style-value{font-size:13px;color:var(--text);min-width:24px}.color-control{display:flex;flex-direction:column;gap:6px}.swatch-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.swatch-row-label{font-size:11px;color:#777;margin-right:2px}.swatch{width:22px;height:22px;border-radius:5px;border:2px solid transparent;box-shadow:inset 0 0 0 1px #ffffff26;cursor:pointer;padding:0}.swatch.selected{border-color:#fff}.swatch-more{width:26px;height:22px;border-radius:5px;border:1px solid #3a3a3a;background:#2a2a2a;color:#bbb;cursor:pointer;font-size:14px;line-height:1}.color-custom{width:48px;height:30px;padding:0;border:1px solid #3a3a3a;border-radius:6px;background:#161616;cursor:pointer}.style-section{padding:8px 0;border-bottom:1px solid #262626}.style-section-header{display:flex;align-items:center;gap:8px}.style-section-toggle{flex:1 1 auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--text);font-size:13px;font-weight:600;text-align:left;cursor:pointer;padding:4px 0}.markers-group{pointer-events:auto}.map-container.placing{cursor:crosshair}.placement-fab{position:fixed;left:18px;bottom:18px;z-index:25;width:52px;height:52px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:28px;line-height:1;cursor:pointer;box-shadow:0 4px 14px #00000073}.placement-fab.armed{background:#fff;color:var(--accent);box-shadow:0 0 0 3px var(--accent)}.placement-hint{position:fixed;left:50%;bottom:26px;transform:translate(-50%);z-index:25;background:#141414eb;color:#fff;font-size:13px;padding:8px 14px;border-radius:18px;pointer-events:none}.grid-headers{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:5}.grid-header-strip{position:absolute;overflow:hidden}.grid-header-top{top:0;left:0;right:0;height:22px}.grid-header-left{top:0;left:0;bottom:0;width:24px}.grid-header-label{position:absolute;background:#121212b8;color:#f0f0f0;font-size:11px;font-weight:600;line-height:1;padding:3px 4px;min-width:14px;text-align:center;border-radius:4px;white-space:nowrap}.grid-header-top .grid-header-label{top:2px;transform:translate(-50%)}.grid-header-left .grid-header-label{left:2px;transform:translateY(-50%)}.grid-pill{position:fixed;left:84px;bottom:30px;z-index:25;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #3a3a3a;background:#141414eb;color:#cfcfcf;font-size:13px;font-weight:600;letter-spacing:.02em;padding:8px 16px;border-radius:18px;cursor:pointer;box-shadow:0 4px 14px #00000073}.grid-pill.on{background:var(--accent);border-color:var(--accent);color:#fff}.marker-icon-preview,.cat-preview{display:inline-flex;align-items:center;justify-content:center}.marker-notes{resize:vertical;min-height:56px;font-family:inherit}.field-notes{align-items:flex-start}.toast{position:fixed;left:50%;bottom:80px;transform:translate(-50%);z-index:1100;display:flex;align-items:center;gap:14px;background:#2c2c2c;border:1px solid #444;color:var(--text);font-size:14px;padding:10px 16px;border-radius:10px;box-shadow:0 6px 18px #00000080}.toast-action{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--accent);font-size:14px;font-weight:700;cursor:pointer}.modal-tabs{display:flex;gap:4px;padding:8px 12px 0;border-bottom:1px solid #2c2c2c}.tab-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:#999;font-size:13px;font-weight:600;padding:8px 12px;border-bottom:2px solid transparent;cursor:pointer}.tab-btn.active{color:#fff;border-bottom-color:var(--accent)}.settings-hint{margin:4px 0 0;font-size:12px;color:#888}.icon-picker{display:flex;flex-direction:column;gap:8px}.icon-search{width:100%}.icon-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px}.icon-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;align-items:center;justify-content:center;aspect-ratio:1;border:2px solid transparent;border-radius:8px;background:#242424;color:#cfcfcf;cursor:pointer}.icon-btn:hover{background:#2c2c2c}.icon-btn.selected{border-color:var(--accent);color:#fff}.icon-browse-toggle{align-self:flex-start}.placement-panel{max-width:460px}.picker-section{margin-bottom:14px}.picker-section .field-label{display:block;margin-bottom:6px}.category-chips{display:flex;flex-wrap:wrap;gap:8px}.category-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;align-items:center;gap:8px;border:1px solid #3a3a3a;background:#242424;color:var(--text);border-radius:8px;padding:8px 12px;font-size:13px;cursor:pointer}.category-chip:hover{background:#2c2c2c}.placement-name{display:flex;flex-direction:column;align-items:center;gap:12px;padding:8px 0}.placement-name .field-input{width:100%}.pdf-panel{max-width:520px}.spinner{width:22px;height:22px;border-radius:50%;border:3px solid #3a3a3a;border-top-color:var(--accent);animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.pdf-progress{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 0;color:var(--text);font-size:14px}.pdf-error{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 0;text-align:center;color:#e06464}.pdf-diag-details{width:100%;text-align:left;color:#cfcfcf}.pdf-diag-details>summary{cursor:pointer;font-size:13px;color:#9aa0a6;-webkit-user-select:none;user-select:none}.pdf-diag{margin:8px 0;max-height:220px;overflow:auto;padding:10px;background:#141414;border:1px solid #333;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;line-height:1.45;color:#d0d0d0;white-space:pre-wrap;word-break:break-word;user-select:text;-webkit-user-select:text}.pdf-pages{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.pdf-page{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;background:#242424;border:1px solid #3a3a3a;border-radius:8px;cursor:pointer}.pdf-page:hover{border-color:var(--accent)}.pdf-thumb{width:100%;height:130px;object-fit:contain;background:#fff;border-radius:4px}.pdf-thumb-loading{display:flex;align-items:center;justify-content:center;background:#1a1a1a}.pdf-page-num{font-size:12px;color:#bbb}
