*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background:#0f0f23}html,body,#root{height:100%;overflow:hidden}.app{color:#e0e0e0;box-sizing:border-box;flex-direction:column;height:100vh;padding:8px 12px;font-family:monospace;display:flex}h1{text-align:center;color:#c8b432;flex-shrink:0;margin:0 0 8px;font-size:18px}.main-layout{flex:1;gap:12px;min-height:0;display:flex}.canvas-container{flex:1;min-width:0;position:relative}canvas{border:1px solid #444;border-radius:4px;width:100%;height:100%;display:block}.canvas-hint{color:#777;pointer-events:none;background:#0f0f23cc;border-radius:3px;padding:2px 10px;font-size:11px;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}.sidebar{flex-direction:column;flex-shrink:0;width:300px;min-height:0;display:flex;overflow-y:auto}.image-controls{flex-shrink:0;margin-bottom:4px}.image-buttons{gap:8px;margin-bottom:6px;display:flex}.slider-label{color:#999;margin:4px 0;font-size:11px;display:block}.slider-label input[type=range]{accent-color:#4af;width:100%;margin-top:2px}.sidebar h2{color:#aaa;flex-shrink:0;margin:8px 0 4px;font-size:13px}.mode-toolbar{flex-wrap:wrap;flex-shrink:0;gap:4px;margin-bottom:4px;display:flex}.mode-btn{color:#ccc;cursor:pointer;background:#2a2a4a;border:1px solid #444;border-radius:4px;padding:5px 8px;font-family:monospace;font-size:11px;transition:background .15s,border-color .15s}.mode-btn:hover{background:#3a3a5a}.mode-btn.active{color:#fff;background:#1a3a5a;border-color:#4af;font-weight:700}.overlay-buttons{flex-shrink:0;gap:4px;margin-bottom:4px;display:flex}.distance-panel{background:#1a1a2e;border:1px solid #333;border-radius:4px;flex-shrink:0;margin-bottom:4px;padding:8px}.distance-steps{margin-bottom:6px}.distance-step{color:#666;padding:2px 0;font-size:11px}.distance-step.current{color:#4af;font-weight:700}.distance-step.done{color:#0fc}.step-done{color:#0fc;font-weight:400}.distance-input-row{align-items:center;gap:6px;margin-bottom:4px;display:flex}.distance-input-row label{color:#aaa;white-space:nowrap;font-size:12px}.distance-input{color:#fff;background:#111;border:1px solid #444;border-radius:3px;flex:1;width:60px;padding:4px 6px;font-family:monospace;font-size:12px}.distance-input:focus{border-color:#4af;outline:none}.action-btn{color:#4af;cursor:pointer;background:#1a3a5a;border:1px solid #4af;border-radius:3px;padding:4px 10px;font-family:monospace;font-size:12px}.action-btn:hover:not(:disabled){background:#2a4a6a}.action-btn:disabled{opacity:.3;cursor:default}.action-btn.full-width{width:100%;margin-top:4px}.distance-current{color:#888;font-size:11px}.path-list{background:#1a1a2e;border:1px solid #333;border-radius:4px;flex-shrink:0;margin-bottom:4px}.path-item{cursor:pointer;border-bottom:1px solid #2a2a3a;align-items:center;gap:6px;padding:4px 8px;font-size:12px;display:flex}.path-item:hover{background:#2a2a4a}.path-item.active{background:#1a2a3a;border-left:3px solid #4af;font-weight:700}.path-color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.path-name{cursor:text;flex:1}.path-name-input{color:#fff;background:#111;border:1px solid #4af;border-radius:3px;outline:none;flex:1;padding:1px 4px;font-family:monospace;font-size:12px}.path-count{color:#666;font-size:11px}.add-hole-btn{color:#4af;cursor:pointer;background:#2a2a4a;border:none;border-top:1px solid #333;width:100%;padding:4px;font-family:monospace;font-size:12px}.add-hole-btn:hover:not(:disabled){background:#3a3a5a}.add-hole-btn:disabled{opacity:.3;cursor:default}.point-list{background:#1a1a2e;border:1px solid #333;border-radius:4px;flex-shrink:0;max-height:25vh;overflow-y:auto}.point-item{cursor:pointer;border-bottom:1px solid #2a2a3a;align-items:center;gap:6px;padding:4px 8px;display:flex}.point-item:hover{background:#2a2a4a}.point-item.selected{background:#3a1a1a;border-left:3px solid #f44}.point-index{color:#888;min-width:20px;font-size:11px}.point-coords{flex:1;font-size:13px}.point-coord-input{color:#fff;text-align:right;background:#111;border:1px solid #444;border-radius:3px;width:55px;padding:2px 4px;font-family:monospace;font-size:11px}.point-coord-input:focus{border-color:#4af;outline:none}.inline-btn{color:#aaa;cursor:pointer;background:0 0;border:1px solid #555;border-radius:3px;padding:1px 6px;font-family:monospace;font-size:12px}.inline-btn:hover:not(:disabled){color:#fff;background:#4af}.inline-btn:disabled{opacity:.3;cursor:default}.danger-btn{color:#f66;cursor:pointer;background:0 0;border:1px solid #555;border-radius:3px;padding:1px 6px;font-family:monospace;font-size:12px}.danger-btn:hover:not(:disabled){color:#fff;background:#f66}.danger-btn:disabled{opacity:.3;cursor:default}.convexity-label{background:#1a1a2e;border:1px solid #333;border-radius:4px;flex-shrink:0;align-items:center;gap:6px;margin:6px 0;padding:5px 10px;font-size:13px;display:flex}.convex{color:#4e4;font-weight:700}.concave{color:#e94;font-weight:700}.output-area{color:#c8b432;resize:vertical;background:#0d0d1a;border:1px solid #444;border-radius:4px;flex:1 0;width:100%;min-height:80px;padding:8px;font-family:monospace;font-size:13px}.import-panel{flex-direction:column;gap:4px;margin-top:4px;display:flex}.import-textarea{color:#aaa;resize:vertical;background:#0d0d1a;border:1px solid #444;border-radius:4px;width:100%;min-height:60px;padding:6px;font-family:monospace;font-size:11px}.history-section{flex-direction:column;flex:1;min-height:0;display:flex}.history-section h2{margin-top:10px}.history-controls{gap:8px;margin-bottom:4px;display:flex}.history-list{background:#1a1a2e;border:1px solid #333;border-radius:4px;flex:1;min-height:60px;overflow-y:auto}.history-item{cursor:pointer;border-bottom:1px solid #2a2a3a;align-items:center;gap:8px;padding:3px 8px;font-size:12px;display:flex}.history-item:hover{background:#2a2a4a}.history-item.active{background:#1a3a1a;border-left:3px solid #4e4;font-weight:700}.history-item.future{opacity:.45}.history-index{color:#666;min-width:22px}.history-summary{color:#aaa}
