:root{color:#1f2937;background:#edf1f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--panel: #ffffff;--panel-border: #d8dee6;--text-muted: #667085;--control: #f5f7fa;--control-border: #cfd7e3;--accent: #1976d2;--accent-soft: #e8f1fc;--danger: #c62828;--danger-soft: #fbe9e7}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}button,input,select{font:inherit}button{color:inherit}.app-shell{display:grid;grid-template-rows:56px minmax(0,1fr);height:100%;min-width:900px}.topbar{display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--panel-border);background:#fbfcfe;padding:0 16px}.brand-block{display:flex;align-items:center;gap:10px;min-width:235px}.brand-mark{display:grid;place-items:center;width:32px;height:32px;border-radius:7px;background:#111827;color:#fff;font-weight:800}.brand-icon-image{width:32px;height:32px;border:1px solid rgba(17,24,39,.18);border-radius:7px;object-fit:cover}.brand-name{font-size:15px;font-weight:800}.brand-subtitle{max-width:180px;overflow:hidden;color:var(--text-muted);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.toolbar-group{display:flex;align-items:center;gap:6px;border:1px solid var(--panel-border);border-radius:8px;background:#fff;padding:4px}.mode-toggle,.icon-button,.text-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;background:transparent;cursor:pointer;transition:background .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.icon-button{width:32px;height:32px;flex:0 0 32px}.icon-button:hover,.text-button:hover,.mode-toggle:hover{border-color:var(--control-border);background:var(--control)}.icon-button:disabled{cursor:not-allowed;opacity:.36}.icon-button.is-active,.icon-button.is-primary{border-color:#9fc4ec;background:var(--accent-soft);color:var(--accent)}.icon-button.is-danger,.text-button.is-danger{color:var(--danger)}.icon-button.is-danger:hover,.text-button.is-danger:hover{border-color:#efb8b8;background:var(--danger-soft)}.icon-button.is-ghost{width:28px;height:28px;flex-basis:28px}.mode-toggle{gap:7px;height:36px;border-color:var(--panel-border);background:#fff;padding:0 12px;font-weight:700}.link-toggle{text-decoration:none}.topbar-spacer{flex:1}.editor-grid{display:grid;grid-template-columns:280px minmax(360px,1fr) 320px;min-height:0}.is-view-mode .editor-grid{grid-template-columns:minmax(0,1fr)}.is-view-mode.has-preview-detail .editor-grid{grid-template-columns:minmax(0,1fr) 320px}.side-panel{min-height:0;border-right:1px solid var(--panel-border);background:var(--panel);overflow:auto}.property-panel{border-right:0;border-left:1px solid var(--panel-border)}.panel-header,.panel-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 12px}h2{margin:0;color:#111827;font-size:14px;font-weight:800;letter-spacing:0}p{margin:5px 0 0;color:var(--text-muted);font-size:12px}.line-list{display:grid;gap:8px;padding:0 14px 14px}.line-row{display:grid;grid-template-columns:16px 1fr;align-items:center;gap:10px;width:100%;border:1px solid transparent;border-radius:8px;background:#fff;padding:10px;text-align:left;cursor:pointer}.line-row:hover{border-color:var(--control-border);background:#f8fafc}.line-row.is-current{border-color:#9fc4ec;background:var(--accent-soft)}.line-color{width:14px;height:14px;flex:0 0 14px;border:1px solid rgba(17,24,39,.16);border-radius:4px}.line-meta{display:grid;min-width:0}.line-meta strong,.order-name{overflow:hidden;color:#111827;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.line-meta span{color:var(--text-muted);font-size:12px}.text-button{gap:6px;height:34px;border-color:var(--control-border);background:#fff;font-size:13px;font-weight:700}.canvas-shell{position:relative;min-width:0;min-height:0;background:#eef2f6}.metro-canvas{display:block;width:100%;height:100%;touch-action:none;user-select:none;-webkit-user-select:none}.metro-canvas text{user-select:none;-webkit-user-select:none}.canvas-background{fill:#f7f9fc}.metro-canvas.tool-add-station{cursor:crosshair}.metro-canvas.tool-connect{cursor:cell}.metro-canvas.tool-delete{cursor:not-allowed}.metro-canvas.tool-box-select{cursor:crosshair}.line-hit-target,.station-node{cursor:pointer}.metro-line{pointer-events:none}.metro-line-selection{opacity:.22;pointer-events:none}.line-marker-box{filter:drop-shadow(0 2px 5px rgba(15,23,42,.16));stroke:#fffffff0;stroke-width:2px}.line-marker-node text{fill:#fff;font-size:11px;font-weight:800;letter-spacing:0;pointer-events:none;stroke:none}.origin-axis-layer{pointer-events:none}.origin-axis{stroke:#0f172a57;stroke-linecap:round;stroke-width:2.6px}.station-node{paint-order:stroke}.station-dot{transition:r .14s ease,stroke-width .14s ease}.station-node.is-selected .station-dot{stroke-width:3px}.station-label{fill:#2f3a46;font-size:12px;font-weight:650;letter-spacing:0;paint-order:stroke;pointer-events:none;stroke:#fffffff2;stroke-linejoin:round;stroke-width:4px}.station-data-label{letter-spacing:0;paint-order:stroke;pointer-events:none;stroke:#fffffff2;stroke-linejoin:round;stroke-width:3px}.station-order-badge{pointer-events:none}.station-order-badge circle{stroke:#fff;stroke-width:2px}.station-order-badge text{fill:#fff;font-size:10px;font-weight:800;letter-spacing:0;stroke:none}.snap-guide{pointer-events:none;stroke:#1976d2;stroke-dasharray:8 6;stroke-linecap:round;stroke-width:1.5}.selection-marquee{fill:#1976d21f;pointer-events:none;stroke:#1976d2;stroke-dasharray:7 5;stroke-width:1.4px}.canvas-status{position:absolute;right:14px;bottom:14px;display:flex;align-items:center;gap:8px;border:1px solid rgba(148,163,184,.72);border-radius:8px;background:#ffffffeb;box-shadow:0 8px 22px #0f172a17;color:#475467;font-size:12px;padding:7px 9px}.status-pill{display:inline-flex;align-items:center;gap:5px;color:#111827;font-weight:700}.inspector{display:grid;gap:14px;padding-bottom:18px}.field,.section-label,.section-title-row,.custom-field-list,.membership-list,.preview-data-list,.station-order-list,.metric-grid{margin-inline:18px}.field{display:grid;gap:6px}.field span,.section-label{color:#475467;font-size:12px;font-weight:800}.field input,.field select{width:100%;height:36px;border:1px solid var(--control-border);border-radius:8px;background:#fff;color:#111827;padding:0 10px;outline:none}.field textarea{width:100%;min-height:88px;border:1px solid var(--control-border);border-radius:8px;background:#fff;color:#111827;resize:vertical;padding:8px 10px;outline:none}.field:has(textarea){display:none}.field input:focus,.field select:focus{border-color:#80b6ed;box-shadow:0 0 0 3px #1976d21f}.field textarea:focus{border-color:#80b6ed;box-shadow:0 0 0 3px #1976d21f}.icon-picker-actions{display:flex;flex-wrap:wrap;gap:8px;margin-inline:18px}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.field-grid .field{margin-inline:0}.field-grid{margin-inline:18px}.color-field input{height:38px;padding:3px 5px}.membership-list,.station-order-list{display:grid;gap:7px}.membership-row,.station-order-row{display:grid;align-items:center;gap:8px;min-height:38px;border:1px solid var(--panel-border);border-radius:8px;background:#fff;padding:5px 7px}.membership-row{grid-template-columns:14px 1fr 28px}.membership-row.marker-membership-row,.preview-detail-panel .membership-row{grid-template-columns:14px 1fr}.station-order-row{grid-template-columns:28px minmax(0,1fr) 28px 28px 28px;cursor:grab;-webkit-user-select:none;user-select:none}.station-order-row:active{cursor:grabbing}.station-order-row.is-dragging{border-color:#80b6ed;background:#eef6ff;opacity:.64}.station-order-row.is-drop-target{border-color:#1976d2;box-shadow:inset 0 0 0 1px #1976d259}.order-index{display:grid;place-items:center;width:24px;height:24px;border-radius:6px;background:#eef2f7;color:#475467;font-size:12px;font-weight:800}.coordinate-readout{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-inline:18px}.coordinate-readout div{display:grid;gap:4px;border:1px solid var(--panel-border);border-radius:8px;background:#f8fafc;padding:10px}.coordinate-readout span{color:#667085;font-size:12px;font-weight:800}.coordinate-readout strong{color:#111827;font-size:15px}.empty-state{border:1px dashed #c5ced9;border-radius:8px;background:#f8fafc;color:var(--text-muted);font-size:12px;padding:12px;text-align:center}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.custom-field-list,.preview-data-list{display:grid;gap:8px}.custom-field-card{display:grid;gap:10px;border:1px solid var(--panel-border);border-radius:8px;background:#fff;padding:10px}.custom-field-grid,.custom-style-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.compact-field{margin-inline:0}.compact-field input{height:32px}.toggle-row{display:inline-flex;align-items:center;gap:8px;color:#475467;font-size:12px;font-weight:700}.toggle-row input{width:15px;height:15px}.inspector-toggle{margin-inline:18px}.preview-data-row{display:grid;gap:4px;border:1px solid var(--panel-border);border-radius:8px;background:#fff;padding:10px}.preview-data-row span{color:#667085;font-size:12px;font-weight:800}.preview-data-row strong{color:#111827;font-size:14px;overflow-wrap:anywhere}.toast{position:fixed;right:18px;bottom:18px;z-index:20;border:1px solid #b9c8dc;border-radius:8px;background:#111827eb;box-shadow:0 12px 28px #0f172a33;color:#fff;font-size:13px;font-weight:700;padding:10px 12px}.metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.map-icon-preview{margin-inline:18px;border:1px solid var(--panel-border);border-radius:8px;background:#f8fafc;padding:10px}.map-icon-preview img{display:block;width:48px;height:48px;border:1px solid rgba(17,24,39,.16);border-radius:8px;object-fit:cover}.metric{display:grid;gap:4px;border:1px solid var(--panel-border);border-radius:8px;background:#fff;padding:12px 8px;text-align:center}.metric strong{color:#111827;font-size:20px}.metric span{color:var(--text-muted);font-size:12px;font-weight:700}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap}.preview-loading{display:grid;place-items:center;align-content:center;gap:12px;height:100%;color:#475467;font-size:14px;font-weight:700}@media (max-width: 1050px){.app-shell{min-width:760px}.editor-grid{grid-template-columns:230px minmax(300px,1fr) 280px}.brand-block{min-width:185px}}
