:root{font-family:Inter,Arial,Helvetica,sans-serif;color:#1a1a1a;background:#fff;font-synthesis:none}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit;border-radius:2px}button{cursor:pointer}.topbar{height:64px;background:#000;color:#fff;display:flex;align-items:center;padding:0 32px;gap:24px}.brand,.status-dot{display:flex;align-items:center;gap:10px}.corner-square{width:12px;height:12px;background:#76b900}.topbar-copy{color:#ccc;font-size:14px;flex:1;border-left:1px solid #5e5e5e;padding-left:24px}.status-dot{font-size:11px;color:#ffffffb3;font-weight:700}.status-dot span{width:8px;height:8px;background:#76b900}.hero{background:#000;color:#fff;padding:42px 48px;display:flex;justify-content:space-between;border-top:1px solid #1a1a1a}.hero h1{font-size:42px;line-height:1.12;margin:8px 0 12px}.hero h1 span,.eyebrow{color:#76b900}.hero p{color:#ffffffb3;max-width:680px}.eyebrow{font-size:11px;font-weight:700;letter-spacing:1.5px}.hero-stat{border-left:1px solid #5e5e5e;padding:12px 32px;display:flex;flex-direction:column;justify-content:center}.hero-stat strong{font-size:38px;color:#76b900}.hero-stat span{font-size:13px;color:#ccc}.workspace{display:grid;grid-template-columns:280px minmax(500px,1fr) 290px;gap:16px;max-width:1600px;margin:0 auto;padding:24px}.panel,.map-section{border:1px solid #ccc;background:#fff;padding:16px;position:relative}.panel:before,.map-section:before{content:"";position:absolute;width:10px;height:10px;background:#76b900;top:-1px;left:-1px}.panel-title{display:flex;align-items:center;gap:8px;font-size:17px;margin:4px 0 14px;border-bottom:1px solid #ccc;padding-bottom:10px}.panel-title span{margin-left:auto;width:8px;height:8px;background:#76b900}.segmented{display:grid;grid-template-columns:1fr 1fr;border:1px solid #ccc;margin-bottom:14px}.segmented button{border:0;background:#fff;padding:10px 6px;min-height:40px;display:flex;gap:4px;align-items:center;justify-content:center;font-size:12px;font-weight:700}.segmented button.active{background:#000;color:#fff}.field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:700;margin:12px 0}.field select,.animation-controls select{height:38px;border:1px solid #ccc;background:#fff;padding:0 8px}.check{display:flex;gap:8px;align-items:center;font-size:13px;padding:6px 0}.check input{accent-color:#76b900}.size-row{display:flex;align-items:center;gap:6px}.size-row input{width:54px;height:36px;border:1px solid #ccc;padding:4px}.size-row button,.animation-controls button{height:36px;width:36px;border:1px solid #76b900;background:#fff;display:grid;place-items:center}.brush-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin:12px 0}.brush{border:1px solid #ccc;background:#fff;min-height:38px;display:flex;align-items:center;gap:4px;padding:5px;font-size:11px}.brush.active{border:2px solid #76b900}.brush span{margin-left:auto}.button-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.button-grid button,.robot-editor-head button{border:1px solid #ccc;background:#f7f7f7;min-height:38px;padding:5px;display:flex;align-items:center;justify-content:center;gap:4px;font-size:11px;font-weight:700}.map-section{min-width:0}.map-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.map-toolbar div:first-child{display:flex;flex-direction:column;font-size:14px}.map-toolbar span{color:#757575;font-size:11px;margin-top:4px}.compact{margin:0;display:flex}.compact button{padding:7px}.grid-scroll{overflow:auto;background:#f7f7f7;border:1px solid #ccc;padding:8px}.warehouse-grid{display:grid;gap:2px;min-width:480px}.grid-cell{aspect-ratio:1;border:1px solid #ccc;background:#fff;min-width:22px;font-size:11px;font-weight:700;position:relative;display:grid;place-items:center;overflow:visible}.cell-1{background:#1a1a1a;color:#fff}.cell-2{background:#650b0b;color:#fff}.cell-3{background:#000;color:#76b900}.cell-4{background:#76b900;color:#000}.grid-cell.expanded:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border:1px solid #76b900;background:#76b90029}.route-markers{position:absolute;z-index:3;top:1px;right:1px;bottom:1px;left:1px;display:flex;align-items:center;justify-content:center;gap:1px;pointer-events:none}.route-marker{min-width:13px;height:14px;padding:0 1px;display:grid;place-items:center;font-size:12px;font-style:normal;font-weight:700;line-height:1;border:1px solid #76b900;background:#fff;color:#000}.route-marker.outbound{background:#76b900}.route-marker.return{background:#000;color:#fff}.route-marker.trail{background:#fff;color:#000}.robot-token{position:absolute;z-index:4;background:#000;color:#76b900;border:1px solid #76b900;padding:1px;font-size:8px}.legend,.route-legend{display:flex;flex-wrap:wrap;gap:11px;margin-top:12px;font-size:11px}.legend span,.route-legend span{display:flex;align-items:center;gap:4px}.legend i{width:9px;height:9px;border:1px solid #ccc}.legend-1{background:#1a1a1a}.legend-2{background:#650b0b}.legend-3{background:#000}.legend-4{background:#76b900}.route-legend{padding:8px;background:#f7f7f7;border-left:3px solid #76b900}.route-legend i{font-style:normal;font-weight:700;border:1px solid #76b900;padding:0 3px}.route-outbound{background:#76b900}.route-return{background:#000;color:#fff}.route-trail{background:#fff}.route-legend small{color:#757575}.primary-action{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:44px;border:0;background:#76b900;font-weight:700;margin-bottom:14px}.empty-state{text-align:center;color:#757575;padding:30px 4px;font-size:13px}.error-box,.result-banner{padding:11px;border-left:4px solid #e52020;background:#f7f7f7;font-size:13px;margin-bottom:12px}.result-banner.success{border-color:#76b900}.result-banner{font-weight:700}.result-banner small{display:block;color:#757575;margin-top:4px}.metric-grid,.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}.metric-card,.compare-card{border:1px solid #ccc;padding:10px;display:flex;flex-direction:column;gap:4px}.metric-card strong{color:#76b900;font-size:24px}.metric-card span,.compare-card span{font-size:11px;color:#757575}.animation-controls{display:flex;gap:6px}.animation-controls select{flex:1}.progress-track{height:5px;background:#eee;margin:12px 0 5px}.progress-track span{height:100%;display:block;background:#76b900}.robot-editor{margin:8px 0 12px}.robot-editor-head,.robot-row{display:flex;align-items:center;gap:5px}.robot-editor-head{justify-content:space-between;margin-bottom:5px;font-size:12px}.robot-row{border:1px solid #ccc;padding:4px;margin-bottom:4px}.robot-row.selected{border:2px solid #76b900}.robot-row input{min-width:0;flex:1;border:0}.robot-row button{border:0;background:#fff}.robot-editor small,.results-panel small{font-size:10px;color:#757575}.robot-result-list div{display:flex;justify-content:space-between;font-size:11px;padding:6px 0;border-bottom:1px solid #eee}.cbs-guide,.point-select-hint{background:#f7f7f7;border-left:3px solid #76b900;padding:8px;margin:8px 0;font-size:11px}.cbs-guide ol{padding-left:17px;margin:6px 0}.cbs-guide button{display:flex;align-items:center;gap:4px;background:#fff;border:1px solid #76b900;padding:5px;font-size:11px;font-weight:700}.point-select-hint strong{color:#5a8d00}@media(max-width:1150px){.workspace{grid-template-columns:250px minmax(480px,1fr)}.results-panel{grid-column:1/-1}.hero{padding:32px}.hero h1{font-size:34px}}@media(max-width:780px){.topbar{padding:0 16px}.topbar-copy,.status-dot{display:none}.hero{padding:26px 20px}.hero h1{font-size:29px}.hero-stat{display:none}.workspace{display:flex;flex-direction:column;padding:12px}.map-section{order:-1}.warehouse-grid{min-width:420px}}.github-link{display:flex;align-items:center;gap:5px;color:#fff;font-size:12px;font-weight:700;text-decoration:none}.github-link:hover{color:#76b900}.route-markers{top:3px;right:3px;bottom:3px;left:3px;align-items:flex-start;justify-content:flex-start;gap:0}.route-marker{position:relative;width:16px;min-width:16px;height:16px;padding:1px;border:0;background:transparent}.route-marker:nth-child(2){transform:translate(7px,7px)}.route-marker:nth-child(3){transform:translate(14px,14px)}.route-marker svg{width:14px;height:14px;overflow:visible}.route-marker path{fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.route-marker.outbound{color:#5a8d00;background:#fff}.route-marker.return{color:#fff;background:#000}.route-marker.trail{color:#000;background:#fff;border:1px solid #76b900}.route-marker small{position:absolute;right:-4px;top:-5px;color:#000;background:#76b900;font-size:7px;line-height:9px;padding:0 2px}.marker-overflow{position:absolute;right:-2px;bottom:-2px;background:#000;color:#fff;font-size:7px;font-style:normal;padding:1px}.route-endpoints,.task-markers{position:absolute;z-index:5;display:flex;gap:1px;pointer-events:none}.route-endpoints{right:1px;bottom:1px}.task-markers{left:1px;bottom:1px;max-width:100%;flex-wrap:wrap}.route-endpoints i,.task-markers i{background:#000;color:#fff;border:1px solid #fff;font-size:7px;font-style:normal;line-height:11px;min-width:12px;padding:0 1px;text-align:center}.task-markers i.selected{background:#76b900;color:#000;border-color:#000}.robot-token{right:1px;top:1px}.robot-row-main{display:flex;min-width:0;flex:1;flex-direction:column}.robot-round-trip{display:flex;align-items:center;gap:2px;font-size:9px;white-space:nowrap}.robot-round-trip input{width:12px}.route-wait{background:#fff;color:#000}.warehouse-grid{position:relative}.map-toolbar-actions{display:flex;gap:7px;align-items:center}.path-style-switch button{min-width:42px}.curve-overlay{position:absolute;z-index:2;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.curve-overlay path{fill:none;stroke-width:.13;stroke-linecap:round;stroke-linejoin:round;opacity:.86}.heatmap-value{position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#000;font-size:9px;pointer-events:none}.teaching-panel{margin-top:16px;border-top:1px solid #ccc;padding-top:8px}.teaching-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.teaching-grid .metric-card{padding:7px;min-width:0}.teaching-grid .metric-card strong{font-size:13px;overflow-wrap:anywhere}.teaching-grid small{grid-column:1/-1;padding:5px 0}.hover-observation{margin-top:7px;padding:6px;border-left:3px solid #76b900;background:#f7f7f7;font-size:10px}.curve-overlay+.grid-cell{position:relative}.multi-edit-switch{margin-top:8px}.multi-edit-switch button{font-size:11px}.search-expansion{position:absolute;z-index:2;pointer-events:none}.outbound-expansion{top:2px;right:2px;bottom:2px;left:2px;border:1px solid #76b900;background:#76b90029}.return-expansion{top:4px;right:4px;bottom:4px;left:4px;border:2px dashed #111;background:repeating-linear-gradient(135deg,transparent 0 3px,rgba(0,0,0,.16) 3px 5px)}.current-expansion{animation:search-pulse .58s ease-in-out infinite alternate;box-shadow:0 0 0 2px #76b900}.search-legend-outbound,.search-legend-return{width:14px;height:12px}.search-legend-outbound{background:#76b90029}.search-legend-return{border:2px dashed #111!important;background:repeating-linear-gradient(135deg,transparent 0 3px,rgba(0,0,0,.16) 3px 5px)}@keyframes search-pulse{0%{transform:scale(.9)}to{transform:scale(1.05)}}
