*{box-sizing:border-box}body,html{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f172a;color:#e2e8f0}.app{position:fixed;inset:0;display:grid;grid-template-rows:auto 1fr}.topbar{padding:8px 16px;background:#0f172a;border-bottom:1px solid #1e293b;display:flex;align-items:center;gap:16px;font-size:13px}.topbar h1{margin:0;font-size:14px;font-weight:600}.topbar .muted{color:#64748b}.map{width:100%;height:100%}.popup{font-size:12px;line-height:1.4}.popup .cell-id{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;word-break:break-all}.popup .row{padding:2px 0}.popup .label{color:#64748b;margin-right:6px}.layer-panel{position:fixed;top:56px;right:16px;width:220px;padding:12px 14px 10px;background:rgba(15,23,42,.88);border:1px solid #1e293b;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.4);color:#e2e8f0;font-size:12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:900}.layer-panel h3{margin:0 0 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}.layer-row{display:flex;align-items:center;gap:8px;padding:3px 0;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.layer-row input[type=checkbox]{margin:0;cursor:pointer}.swatch{display:inline-block;width:14px;height:14px;border-radius:3px;flex-shrink:0}.layer-label{flex:1 1}.error-banner{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);max-width:640px;padding:10px 16px;background:#7f1d1d;color:#fecaca;border:1px solid #b91c1c;border-radius:6px;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;box-shadow:0 4px 12px rgba(0,0,0,.4);z-index:1000}