*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%;font-family:Arial,Helvetica,sans-serif;background:#09111f;color:#0f172a}button,input,select{font:inherit}body{background:radial-gradient(circle at top,rgba(148,163,184,.18),transparent 34%),linear-gradient(180deg,rgba(2,6,23,.92),rgba(15,23,42,.76))}.app-shell{min-height:100vh;padding:20px;position:relative}.container{position:relative;z-index:1;max-width:1800px;margin:0 auto;overflow-x:auto}.panel{background:rgba(255,255,255,.95);border:1px solid rgba(148,163,184,.3);border-radius:24px;box-shadow:0 24px 60px rgba(2,6,23,.28)}.header{padding:24px;margin-bottom:20px}.header h1{margin:0 0 10px;font-size:42px}.header p{margin:0;color:#475569}.header-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px}.fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:14px;font-weight:700;color:#475569}.field input,.field select{padding:12px 14px;border:1px solid rgba(148,163,184,.35);border-radius:14px;background:white}.field input[type=range]{padding:0}.layout{display:grid;grid-template-columns:320px minmax(0,1fr) 360px;gap:20px;align-items:start;min-width:1600px}.legend-sidebar{position:sticky;top:20px;align-self:start}.main,.sidebar{padding:20px}.section{display:grid;gap:12px}.section+.section{margin-top:18px;padding-top:18px;border-top:1px solid rgba(148,163,184,.25)}.section h2,.section h3{margin:0}.section p{margin:0;color:#64748b;font-size:14px;line-height:1.5}.legend-list,.tool-list{display:grid;gap:10px}.legend-item,.tool-btn{display:flex;align-items:center;gap:12px;border:1px solid rgba(148,163,184,.28);border-radius:18px;background:white}.tool-btn{width:100%;text-align:left;padding:12px;cursor:pointer}.tool-btn.active{outline:3px solid rgba(59,130,246,.2)}.swatch{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;color:white;font-weight:900;flex-shrink:0}.tool-symbol{min-width:32px;white-space:nowrap}.elevator-no-use-symbol,.tool-symbol{display:inline-flex;align-items:center;justify-content:center;line-height:1;font-weight:900;flex-shrink:0}.elevator-no-use-symbol{position:relative;width:2.4em;height:2.4em;border:.12em solid;border-radius:999px;background:rgba(255,255,255,.88);box-sizing:border-box}.elevator-no-use-symbol:after{content:"";position:absolute;width:140%;height:.12em;background:currentColor;transform:rotate(-45deg);transform-origin:center;border-radius:999px}.meta{display:grid;gap:4px}.meta strong{font-size:15px}.meta span{font-size:13px;color:#64748b;line-height:1.4}.toggle{display:flex;justify-content:space-between;gap:16px;align-items:center;border:1px solid rgba(148,163,184,.28);border-radius:18px;padding:12px 14px;background:white}.toggle input{width:22px;height:22px}.actions{display:grid;gap:10px}.actions button{padding:12px 14px;border-radius:14px;border:1px solid rgba(148,163,184,.28);background:white;cursor:pointer}.actions .primary{background:#0f172a;color:white;border-color:#0f172a}.actions .danger{background:#7f1d1d;color:white;border-color:#7f1d1d}.status{display:inline-block;padding:10px 14px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:13px;font-weight:700;border:1px solid rgba(148,163,184,.25)}.main-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap}.main-top h2{margin:0;font-size:28px}.main-top p{margin:6px 0 0;color:#64748b}.canvas-wrap{margin-top:16px;overflow:auto;border:1px solid rgba(148,163,184,.25);border-radius:24px;background:white}.canvas{width:1200px;height:760px;position:relative;background:linear-gradient(90deg,rgba(148,163,184,.15) 1px,transparent 0),linear-gradient(180deg,rgba(148,163,184,.15) 1px,transparent 0),white;background-size:24px 24px,24px 24px,auto}.floorplan{position:absolute;inset:0;pointer-events:none;z-index:1}.floorplan img,.floorplan object{width:100%;height:100%;object-fit:contain;border:0}.logo-inside{position:absolute;background-repeat:no-repeat;background-position:50%;background-size:contain;pointer-events:auto;z-index:3;border:1px dashed rgba(15,23,42,.18);border-radius:12px;cursor:grab;background-color:transparent}.logo-inside.dragging{cursor:grabbing}.route-layer{position:absolute;inset:0;pointer-events:none;z-index:4}.route-line{fill:none;stroke:#0f8f55;stroke-width:4;stroke-dasharray:10 6}.canvas-chip{position:absolute;z-index:5;background:rgba(255,255,255,.9);border:1px solid rgba(148,163,184,.25);border-radius:18px;padding:12px 14px}.canvas-chip.top{top:20px;left:20px}.canvas-chip.bottom{bottom:20px;left:20px}.canvas-chip strong{display:block;margin-bottom:6px}.marker{position:absolute;transform:translate(-50%,-50%);background:transparent;border:0;box-shadow:none;color:inherit;z-index:6;-webkit-user-select:none;user-select:none;touch-action:none;padding:0;min-width:0}.marker--plain{display:inline-flex;align-items:center;justify-content:center}.marker-symbol-only{font-weight:900;line-height:1;white-space:nowrap;text-shadow:0 0 2px rgba(255,255,255,.95),0 0 6px rgba(255,255,255,.8)}.marker.selected .marker-symbol-only{outline:2px solid rgba(59,130,246,.35);outline-offset:4px;border-radius:6px}.marker-elevator-no-use-symbol{text-shadow:none}.marker.selected .marker-elevator-no-use-symbol{outline:2px solid rgba(59,130,246,.35);outline-offset:4px}.marker.dragging{opacity:.85}.notes{margin-top:18px;display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.note-card{border:1px solid rgba(148,163,184,.28);border-radius:18px;padding:16px;background:#f8fafc}.note-card h3{margin:0 0 12px}.note-card ul{margin:0;padding-left:18px;display:grid;gap:10px;color:#475569}.footer{margin-top:20px;padding:16px;text-align:center;color:#475569}.legend-item{padding:12px}@media (max-width:1200px){.fields,.header-grid,.notes{grid-template-columns:1fr}}@media print{.sidebar{display:none!important}.layout{grid-template-columns:1fr}.app-shell,body{background:white}}.marker-symbol-image,.symbol-image{display:inline-block;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.marker-symbol-image{filter:drop-shadow(0 0 2px rgba(255,255,255,.95)) drop-shadow(0 0 6px rgba(255,255,255,.8))}.marker.selected .marker-symbol-image{outline:2px solid rgba(59,130,246,.35);outline-offset:4px;border-radius:6px}