:root{--ink: #1b3a5c;--muted: #5a6a7e;--line: #d5dce6;--paper: #eaf2f6;--panel: #ffffff;--workspace-bg: #eef3f6;--surface: #ffffff;--surface-subtle: #f6f9fb;--surface-rail: #e8eef3;--accent: #268f86;--accent-strong: #146c73;--accent-soft: rgba(38, 143, 134, .11);--danger: #b83b3b;--warning: #a96b22;--success: #34785d;--green: #4a7c59;--blue: #3d8b7a;--amber: #8b5a3c;--shadow: 0 1px 2px rgba(20, 45, 68, .05);color:var(--ink);background:var(--paper);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;background:var(--paper);overflow-x:hidden}h1,h2,h3,p,span,b,small,button,a,label{overflow-wrap:anywhere}button,input,select,a{font:inherit}input[type=checkbox],input[type=radio]{accent-color:var(--blue)}button{border:0}:focus-visible{outline:3px solid rgba(61,139,122,.56);outline-offset:3px;border-radius:3px}button:disabled{cursor:not-allowed;opacity:.48}.app-shell{display:grid;grid-template-rows:54px minmax(0,1fr) 30px;height:100vh;overflow:hidden;animation:app-fade-in .4s ease-out}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:10px 20px;border-bottom:1px solid var(--line);background:var(--panel)}.topbar h1{margin:0;font-size:22px;line-height:1.1;letter-spacing:0}.topbar-brand{display:flex;align-items:center;gap:10px;min-width:max-content}.project-status{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:220px;max-width:42vw;padding:7px 12px;border:1px solid rgba(61,139,122,.18);border-radius:999px;background:#eaf2f6b8;color:var(--ink);font-size:13px;font-weight:700}.project-status-dot,.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);flex:0 0 auto}.project-status-dot,.status-dot.is-live{background:var(--green)}.eyebrow{margin:0 0 3px;color:var(--muted);font-size:12px;font-weight:780;letter-spacing:.08em;text-transform:uppercase}.topbar-actions{display:flex;align-items:center;gap:8px;min-width:0}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 14px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:650;text-decoration:none;text-align:center;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.primary-button:active,.secondary-button:active,.inline-button:active{transform:scale(.97);transition-duration:.06s}.primary-button{background:var(--blue);color:var(--panel);box-shadow:0 1px 2px #3d8b7a33}.secondary-button{border:1px solid var(--line);background:var(--panel);color:var(--ink)}.secondary-button:hover{border-color:var(--blue);box-shadow:0 2px 8px #3d8b7a1a}.subscribe-button{border-color:#3d8b7a80;color:var(--blue)}.placeholder-button{border-color:#1b3a5c24}.toolbar-button{width:32px;min-height:28px;padding:0;font-size:12px;white-space:nowrap}.toolbar-action-icon{display:block;width:16px;height:16px;color:currentColor}.toolbar-action-symbol{display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:780;line-height:1}.full-button{width:100%}.export-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.inline-button{width:100%;min-height:32px;margin-top:10px;border:1px solid var(--line);border-radius:6px;background:#f0f5f9;color:var(--ink);cursor:pointer;font-size:12px;font-weight:650;transition:transform .18s ease,background .18s ease}.workspace{display:grid;grid-template-columns:300px minmax(420px,1fr) 320px;min-height:0}.left-panel,.right-panel{min-height:0;overflow-y:auto;padding:14px;background:#f0f5f9}.left-panel{border-right:1px solid var(--line)}.right-panel{border-left:1px solid var(--line)}.panel-stack{display:flex;flex-direction:column;gap:12px}.workspace-card{padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:0 1px 2px #1b3a5c0a;transition:box-shadow .22s ease,transform .22s ease}.workspace-card:hover{box-shadow:0 3px 8px #1b3a5c14;transform:translateY(-1px)}.compact-card{display:grid;gap:8px}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;color:var(--ink);font-size:14px;font-weight:700}.section-heading small{color:var(--muted);font-size:12px;font-weight:500}.workflow-list{display:grid;gap:9px;margin:0;padding:0;list-style:none}.workflow-step{position:relative;display:grid;gap:2px;padding:10px 10px 10px 34px;border:1px solid var(--line);border-radius:8px;background:#f0f5f9;color:var(--muted)}.workflow-step:before{content:"";position:absolute;left:12px;top:13px;width:12px;height:12px;border:2px solid #99a8b8;border-radius:50%;background:var(--panel)}.workflow-step b{color:var(--ink);font-size:13px}.workflow-step span{font-size:12px}.workflow-step.is-active{border-color:#3d8b7a4d;background:#3d8b7a0a}.workflow-step.is-active:before{border-color:var(--blue);box-shadow:0 0 0 3px #3d8b7a1f}.workflow-step.is-complete:before{border-color:var(--green);background:var(--green)}.workflow-accordion{display:grid;gap:8px}.workflow-section{position:relative;padding:0;overflow:hidden}.workflow-section-button{position:relative;z-index:1;display:grid;grid-template-columns:auto 1fr;gap:2px 10px;width:100%;padding:14px;background:transparent;color:var(--ink);cursor:pointer;text-align:left}.workflow-section-index{grid-row:1 / span 2;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid rgba(61,139,122,.28);border-radius:50%;background:#fff;color:var(--blue);font-size:11px;font-weight:800}.workflow-section-title{font-size:15px;font-weight:800}.workflow-section-summary{color:var(--muted);font-size:12px}.workflow-section.is-open{border-color:#3d8b7a5c;box-shadow:0 3px 9px #1b3a5c0f}.workflow-section.is-open .workflow-section-index,.workflow-section.is-active .workflow-section-index{background:var(--blue);border-color:var(--blue);box-shadow:0 0 0 3px #3d8b7a1a;color:#fff}.workflow-section.is-complete .workflow-section-index{background:var(--green);border-color:var(--green);color:#fff;font-size:0}.workflow-section.is-complete .workflow-section-index:before{content:"✓";font-size:13px}.workflow-section.is-pending{background:#ffffffa3}.workflow-section-body{display:grid;gap:10px;padding:0 14px 14px;position:relative;z-index:1;animation:workflow-section-in .18s ease-out}.workflow-action{margin-top:12px}.workflow-addon{margin-top:auto;padding:0;overflow:hidden;border-color:#142d4414;background:#ffffff94;box-shadow:none}.workflow-addon .workflow-section-title{color:var(--muted);font-size:13px;font-weight:700}.workflow-addon-status{grid-column:2;color:var(--muted);font-size:11px;font-weight:650}.workflow-addon .workspace-card{border:0;box-shadow:none}.compute-status-block{display:grid;gap:8px}.drop-zone{margin-top:10px;border:1px dashed #99a8b8;border-radius:8px;background:#f0f5f9;display:grid;grid-template-columns:minmax(0,1fr);align-items:start;transition:border-color .16s ease,background .16s ease,box-shadow .2s ease}.drop-zone:hover{border-color:var(--blue);box-shadow:0 0 0 3px #3d8b7a0f}.drop-zone.is-dragging{border-color:var(--blue);background:#3d8b7a0f}.drop-zone-label{display:grid;gap:4px;padding:12px;cursor:pointer}.drop-zone-label input{display:none}.drop-zone-title{color:var(--ink);font-size:13px;font-weight:700}.drop-zone-desc,.drop-zone-status{color:var(--muted);font-size:12px}.drop-zone-status{color:var(--blue)}.drop-zone-action{display:flex;justify-content:flex-end;padding:0 12px 10px;min-width:0}.drop-zone-actions{display:flex;justify-content:flex-end;gap:6px;width:100%;min-width:0}.import-action-button{min-height:28px;padding:0 10px;border:1px solid rgba(61,139,122,.28);border-radius:5px;background:#ffffffd6;color:var(--blue);cursor:pointer;font-size:12px;font-weight:750;white-space:nowrap}.import-action-button:hover:not(:disabled){border-color:#3d8b7a85;background:#3d8b7a14}.import-action-button.is-danger{border-color:#b83b3b3d;color:var(--danger)}.import-action-button.is-danger:hover:not(:disabled){border-color:#b83b3b6b;background:#b83b3b12}.import-action-button:disabled{color:#9aa8b8;cursor:not-allowed}.link-button{color:var(--blue);cursor:pointer;font-size:12px;font-weight:750;max-width:100%;white-space:normal}.link-button:disabled{color:#9aa8b8;cursor:not-allowed}.link-button.is-warning{color:var(--amber)}.issue-text{margin:8px 0 0;color:var(--muted);font-size:12px;line-height:1.45}.metric-row,.layer-list{display:grid;grid-template-columns:1fr auto;gap:8px;color:var(--muted);font-size:12px}.metric-row b,.layer-list b{color:var(--ink);font-weight:700}.metric-warning{color:var(--amber)!important}.batch-panel{display:grid;gap:8px}.batch-style-row{margin:4px 0 0}.phase4-status-list{display:grid;gap:8px;margin:10px 0 12px;padding-top:10px;border-top:1px solid var(--line)}.phase4-action-grid{display:grid;gap:8px}.phase4-action-grid .secondary-button{width:100%;justify-content:flex-start;min-height:34px}.phase4-template-editor{display:grid;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.advanced-block{margin-top:12px;padding-top:10px;border-top:1px solid var(--line)}.advanced-block summary{cursor:pointer;color:var(--ink);font-size:12px;font-weight:700}.advanced-block .field{margin-top:10px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:28px;background:#14263852}.mapping-dialog{width:min(960px,92vw);max-height:min(720px,86vh);overflow:auto;border:1px solid var(--line);border-radius:10px;background:var(--panel);box-shadow:0 24px 80px #1426383d}.mapping-dialog .workspace-card{border:0;border-radius:0;box-shadow:none}.mapping-dialog-header{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid var(--line);background:var(--panel)}.mapping-dialog-header h2{margin:0;color:var(--ink);font-size:18px;letter-spacing:0}.mapping-dialog-header p{margin:3px 0 0;color:var(--muted);font-size:12px}.inspector-card{background:linear-gradient(180deg,#fff,#fbfdff)}.inspector-empty{display:grid;gap:12px;color:var(--muted);font-size:12px;line-height:1.5}.inspector-empty b{display:block;margin-bottom:3px;color:var(--ink);font-size:13px}.inspector-empty p{margin:0}.empty-metric-list{display:grid;gap:6px}.metric-row.is-placeholder{border-color:#142d4414;background:#142d4406;color:var(--muted)}.inspector-section{display:grid;gap:8px;padding-top:10px;border-top:1px solid var(--line)}.inspector-section:first-of-type{padding-top:0;border-top:0}.right-panel-tabs{position:sticky;top:-14px;z-index:2;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin:-14px -14px 12px;padding:12px 14px;border-bottom:1px solid var(--line);background:#f0f5f9}.right-panel-tab{min-height:30px;border:1px solid var(--line);border-radius:6px;background:var(--panel);color:var(--ink);cursor:pointer;font-size:12px;font-weight:750}.right-panel-tab.is-active{border-color:var(--blue);background:#3d8b7a1a;color:var(--blue)}.map-stage{display:grid;grid-template-rows:auto minmax(0,1fr);min-width:0;min-height:0;padding:14px;background:#f0f5f9}.map-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;min-height:46px;padding:8px 12px;border:1px solid var(--line);border-bottom:0;border-radius:8px 8px 0 0;background:var(--panel)}.map-toolbar div:first-child{display:flex;align-items:baseline;gap:10px;flex:1 1 220px;min-width:0}.map-toolbar-actions{display:flex;align-items:center;justify-content:flex-end;flex:1 1 420px;flex-wrap:wrap;gap:6px;min-width:0}.map-toolbar strong{font-size:14px}.map-toolbar span{color:var(--muted);font-size:12px}.view-pill{padding:4px 8px;border-radius:999px;background:#3d8b7a14;color:var(--blue);font-size:12px;font-weight:700}.canvas-wrap{position:relative;min-height:0;background:#fafaf7;overflow:hidden;border:1px solid var(--line);border-radius:0 0 8px 8px;box-shadow:inset 0 0 0 1px #1b3a5c14;background:linear-gradient(90deg,rgba(27,58,92,.04) 1px,transparent 1px),linear-gradient(rgba(27,58,92,.04) 1px,transparent 1px),#eaf2f6;background-size:32px 32px;cursor:default}.canvas-wrap:active{cursor:default}.canvas-wrap canvas{display:block}.empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:30px;text-align:center;color:var(--muted)}.empty-state h2{max-width:520px;margin:0;color:var(--ink);font-size:24px;letter-spacing:0}.empty-state p{max-width:560px;margin:0;font-size:14px;line-height:1.6}.loading-mask{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:10px;background:#ffffffb8;color:var(--blue);font-size:14px;font-weight:700;animation:fade-in .25s ease-out}.spinner{width:18px;height:18px;border:3px solid rgba(61,139,122,.18);border-top-color:var(--blue);border-radius:50%;animation:spin .9s linear infinite}.map-tooltip{position:absolute;display:flex;gap:10px;padding:5px 10px;border:1px solid var(--line);border-radius:6px;background:var(--panel);box-shadow:0 2px 8px #1b3a5c1f;color:var(--ink);font-size:11px;font-weight:600;pointer-events:none;white-space:nowrap;z-index:10;will-change:left,top}.quality-banner{padding:10px 12px;border:1px solid rgba(74,124,89,.3);border-radius:8px;background:#4a7c590f;color:var(--green);font-size:12px;line-height:1.45}.quality-banner.is-stale{border-color:#8b5a3c4d;background:#8b5a3c0f;color:var(--amber)}.error-toast{padding:10px 12px;border:1px solid rgba(184,59,59,.32);border-radius:8px;background:#b83b3b12;color:var(--danger);font-size:12px;line-height:1.45}.map-toast-stack{position:absolute;bottom:12px;left:12px;right:12px;z-index:12;display:grid;gap:8px;width:auto;pointer-events:none}.map-toast{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;margin:0;box-shadow:0 10px 26px #142d441f;pointer-events:auto;animation:toast-in .18s ease-out}.toast-close{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:1px solid currentColor;border-radius:5px;background:transparent;color:inherit;cursor:pointer;font-size:13px;font-weight:800;line-height:1}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.field{display:grid;gap:5px}.field-label{display:block;margin-bottom:5px;color:var(--muted);font-size:12px;font-weight:600}.control-input{width:100%;min-height:34px;padding:6px 9px;font-size:13px;border:1px solid var(--line);border-radius:6px;background:var(--panel);color:var(--ink);outline:none}.control-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3d8b7a1f}.switch-row{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--ink);font-size:13px}.layer-list{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.compact-layer-list{display:grid;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}.layer-toggle{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;min-height:32px;padding:6px 8px;border:1px solid rgba(27,58,92,.1);border-radius:6px;background:#ffffffb8;color:var(--ink)}.layer-toggle.is-disabled{opacity:.58}.layer-toggle input{width:15px;height:15px;margin:0;accent-color:var(--blue)}.layer-toggle-title,.layer-toggle-detail{display:block;min-width:0}.layer-toggle-title{color:var(--ink);font-size:12px;font-weight:760;line-height:1.2}.layer-toggle-detail{margin-top:2px;color:var(--muted);font-size:11px;line-height:1.2}.layer-toggle-state{color:var(--blue);font-size:11px;font-weight:800}.compact-field{display:grid;gap:5px;margin-top:10px;color:var(--ink);font-size:12px;font-weight:700}.export-readiness{display:grid;gap:9px;margin-top:10px}.export-readiness-group{display:grid;gap:8px;padding:8px;border:1px solid rgba(27,58,92,.08);border-radius:6px;background:#ffffff94}.export-readiness-group.is-planned{border-color:#8b5a3c2e;background:#8b5a3c0a}.export-group-heading{display:grid;gap:2px;color:var(--ink);font-size:12px;font-weight:800;line-height:1.2}.export-group-heading small{color:var(--muted);font-size:11px;font-weight:700;line-height:1.25;text-align:left}.export-command-row,.planned-format-row{display:flex;flex-wrap:wrap;gap:6px}.planned-format{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:5px 7px;border:1px solid rgba(139,90,60,.2);border-radius:6px;background:#ffffff9e;color:var(--amber);font-size:12px;font-weight:760}.display-object-list{display:grid;gap:8px}.display-object{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px 10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:8px;background:#f7fafc}.display-object.is-enabled{border-color:#3d8b7a4d;background:#3d8b7a0b}.display-object-main{display:grid;gap:2px;min-width:0}.display-object-main b{color:var(--ink);font-size:13px}.display-object-main span,.object-inline-toggle{color:var(--muted);font-size:12px}.display-object-controls{grid-column:1 / -1;display:grid;gap:8px;padding-top:8px;border-top:1px solid rgba(153,168,184,.32)}.object-inline-toggle{display:inline-flex;align-items:center;gap:6px}.object-inline-toggle input{width:14px;height:14px;margin:0}.parameter-toggle{grid-column:1 / -1;min-height:30px;padding:6px 8px;border:1px solid rgba(153,168,184,.24);border-radius:5px;background:var(--surface-subtle)}.parameter-row-group{grid-column:1 / -1;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;align-items:end}.parameter-row-group .field{min-width:0}.parameter-row-group .parameter-label{display:flex;align-items:flex-end;min-height:2.45em}.mini-switch{display:inline-flex;align-items:center;justify-content:flex-end;gap:6px}.mini-switch input{width:14px;height:14px;margin:0}.statusbar{display:flex;align-items:center;gap:18px;padding:0 14px;border-top:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:12px;white-space:nowrap}.statusbar-group{display:inline-flex;align-items:center;gap:5px}.statusbar-help{flex:1 1 260px;min-width:220px;color:var(--ink);font-weight:700}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes app-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes workflow-section-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.topbar{min-height:54px;padding:7px 14px;background:var(--surface);box-shadow:0 1px #142d440a}.topbar h1{font-size:18px;font-weight:780}.topbar-brand img{width:24px;height:24px}.project-status{min-height:30px;padding:5px 10px;border-color:#268f8633;background:var(--surface-subtle);font-size:12px;font-weight:680}.primary-button,.secondary-button,.inline-button{border-radius:5px;box-shadow:none}.primary-button{background:var(--accent)}.primary-button:hover{background:var(--accent-strong)}.secondary-button:hover{border-color:#268f8675;box-shadow:none}.workspace{grid-template-columns:300px minmax(520px,1fr) 320px;background:var(--workspace-bg)}.left-panel,.right-panel,.map-stage{background:var(--workspace-bg)}.left-panel,.right-panel{padding:8px}.left-panel{border-right-color:#142d441f}.right-panel{border-left-color:#142d441f}.panel-stack{gap:9px}.workspace-card{width:100%;padding:10px;border-color:#142d4421;border-radius:6px;background:var(--surface);box-shadow:var(--shadow);transition:border-color .16s ease,background .16s ease}.workspace-card:hover{border-color:#142d442e;box-shadow:var(--shadow);transform:none}.section-heading{min-height:22px;margin-bottom:9px;font-size:13px;font-weight:760}.section-heading small{font-size:11px;font-weight:680}.workflow-accordion{gap:7px}.workflow-section{border-left:3px solid transparent}.workflow-section.is-active,.workflow-section.is-open{border-color:#142d4421;border-left-color:var(--accent);box-shadow:var(--shadow)}.workflow-section.is-complete{border-left-color:var(--success)}.workflow-section.is-pending{background:#ffffffc2}.workflow-section-button{grid-template-columns:24px minmax(0,1fr);gap:1px 8px;min-height:52px;padding:10px 11px}.workflow-section-index{width:22px;height:22px;border-radius:50%;font-size:10px}.workflow-section-title{font-size:13px;font-weight:780}.workflow-section-summary{font-size:11px;line-height:1.25}.workflow-section-body{gap:8px;padding:0 10px 10px}.workflow-addon-status{color:var(--success)}.drop-zone{margin-top:7px;border-radius:6px;background:var(--surface-subtle)}.drop-zone-label{padding:10px}.drop-zone-action{padding:0 10px 9px}.issue-text{margin-top:6px;font-size:11px}.field-grid{gap:7px}.field{gap:4px}.field-label{margin-bottom:3px;font-size:11px;font-weight:680}.parameter-label.is-nowrap{white-space:nowrap}.control-input{min-height:30px;padding:4px 8px;border-radius:5px;background:var(--surface-subtle);font-size:12px}.control-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #268f8624}.inline-button{min-height:30px;margin-top:8px;background:var(--surface-subtle);font-size:11px}.advanced-block{margin-top:9px;padding-top:8px}.risk-badge{display:inline-flex;align-items:center;min-height:20px;padding:2px 7px;border:1px solid color-mix(in srgb,var(--risk-color) 35%,transparent);border-radius:999px;background:color-mix(in srgb,var(--risk-color) 10%,white);color:var(--risk-color);white-space:nowrap}.risk-low{--risk-color: var(--success) !important}.risk-medium{--risk-color: var(--warning) !important}.risk-high{--risk-color: var(--danger) !important}.display-object-list{gap:6px}.display-object{min-height:44px;padding:8px;border-radius:5px;background:var(--surface-subtle)}.display-object.is-enabled{border-color:#268f8647;background:var(--accent-soft)}.display-object-main b{font-size:12px}.display-object-main span,.object-inline-toggle{font-size:11px}.mini-switch b{font-size:11px;color:var(--accent-strong)}.right-panel-tabs{top:-8px;gap:2px;margin:-8px -8px 8px;padding:8px;background:var(--surface-rail)}.right-panel-tab{min-height:28px;border-color:transparent;border-radius:5px;background:transparent;font-size:11px}.right-panel-tab.is-active{border-color:#268f8638;background:var(--surface);color:var(--accent-strong);box-shadow:0 1px 2px #142d440d}.inspector-card{background:var(--surface)}.inspector-section{gap:5px;padding-top:9px}.metric-row,.layer-list{min-height:24px;align-items:center;gap:10px;padding:3px 0;border-bottom:1px solid rgba(20,45,68,.07);font-size:11px}.metric-row:last-child,.layer-list:last-child{border-bottom:0}.metric-row b,.layer-list b{max-width:150px;text-align:right;font-weight:720}.metric-warning,.link-button.is-warning{color:var(--warning)!important}.map-stage{padding:8px}.map-toolbar{min-height:42px;gap:10px;padding:7px 9px;border-color:#142d4424;border-radius:6px 6px 0 0;background:var(--surface);flex-wrap:nowrap}.map-toolbar-summary{display:grid!important;gap:1px!important;align-items:center!important;flex:1 1 auto!important;min-width:0!important}.map-toolbar-kicker{color:var(--muted);font-size:10px!important;font-weight:760;letter-spacing:.08em;text-transform:uppercase}.map-toolbar strong{font-size:13px;font-weight:760;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-toolbar-detail{color:var(--muted);font-size:.92em;font-weight:620}.map-toolbar-actions{flex:0 0 auto;flex-wrap:nowrap;gap:5px;white-space:nowrap}.toolbar-button-group{flex:0 0 auto;display:inline-flex;align-items:center;gap:3px}.toolbar-button-group+.toolbar-button-group{padding-left:5px;border-left:1px solid rgba(20,45,68,.12)}.toolbar-button{width:30px;min-height:28px;border-radius:5px;background:var(--surface-subtle)}.view-pill{min-height:28px;padding:5px 8px;border:1px solid rgba(38,143,134,.16);border-radius:5px;background:var(--accent-soft);color:var(--accent-strong)}.canvas-wrap{border-color:#142d4424;border-radius:0 0 6px 6px;box-shadow:inset 0 0 0 1px #142d440d;background:linear-gradient(90deg,rgba(20,45,68,.035) 1px,transparent 1px),linear-gradient(rgba(20,45,68,.035) 1px,transparent 1px),#f8faf8;background-size:28px 28px}.empty-state{gap:9px;background:#f8faf8c7}.empty-state h2{font-size:20px;font-weight:780}.empty-state p{max-width:440px;font-size:13px;line-height:1.45}.loading-mask{background:#f8faf8c2;color:var(--accent-strong)}.spinner{border-color:#268f862e;border-top-color:var(--accent)}.quality-banner{border-color:#34785d40;border-radius:6px;background:#34785d12;color:var(--success)}.quality-banner.is-stale{border-color:#a96b2247;background:#a96b2212;color:var(--warning)}.map-toast{margin:0;background:#fffffff0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.map-toast.is-stale{background:#fffaf2f0}.statusbar{min-height:30px;gap:14px;padding:0 12px;background:var(--surface);font-size:11px}.statusbar-readout,.statusbar-cursor{color:var(--ink);font-variant-numeric:tabular-nums}.statusbar-help{min-width:180px;color:var(--accent-strong);font-weight:680}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media(max-width:1180px){.workspace{grid-template-columns:260px minmax(360px,1fr) 280px}.topbar-actions .secondary-button:nth-of-type(n+3){display:none}}@media(max-width:980px){.app-shell{grid-template-rows:auto minmax(0,1fr) auto;height:auto;min-height:100vh;overflow:visible}.topbar{align-items:flex-start;flex-direction:column}.project-status{justify-content:flex-start;max-width:100%;width:100%}.topbar-actions{width:100%;flex-wrap:wrap}.topbar-actions button,.topbar-actions a{flex:0 1 auto}.workspace{grid-template-columns:1fr}.left-panel,.right-panel{border:0;overflow:visible}.map-stage{min-height:620px;order:2}.right-panel{order:3}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.statusbar{flex-wrap:wrap;gap:8px 14px;min-height:34px;padding:8px 14px}}@media(max-width:560px){.topbar-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.topbar-actions button,.topbar-actions a{min-height:32px;padding:0 8px;font-size:12px}.topbar-actions .primary-button,.topbar-actions .subscribe-button{grid-column:1 / -1}.drop-zone{overflow:hidden}.drop-zone-action{justify-content:flex-start}.drop-zone-actions{justify-content:flex-start;flex-wrap:wrap}.link-button{text-align:left}.map-stage{min-height:520px;padding:10px}.map-toolbar div:first-child{display:grid;gap:2px}.map-toolbar{align-items:flex-start;flex-direction:column;flex-wrap:wrap;padding:8px}.map-toolbar-actions{width:100%;flex-wrap:wrap;justify-content:flex-start}.field-grid{grid-template-columns:1fr}.control-input,.control-select{min-height:30px;padding:4px 7px;font-size:13px}.field-label{font-size:12px;margin-bottom:3px}.field{gap:3px}.empty-state h2{font-size:20px}}
