*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0;font-family:Arial,sans-serif;overflow:hidden}.dev-banner{position:fixed;top:0;left:0;width:100%;background-color:#27ae60;color:#fff;text-align:center;padding:.5rem;font-size:.9rem;font-weight:600;z-index:1000;box-shadow:0 2px 4px #0000001a}#container{display:flex;height:100vh;padding-top:0}.dev-banner+#container{padding-top:2rem;height:calc(100vh - 2rem)}#sidebar{width:280px;background:#f5f5f5;padding:20px;border-right:1px solid #ddd;overflow-y:auto}.sidebar-header{margin-bottom:30px;text-align:center}.sidebar-header h1{font-size:24px;color:#2c3e50;margin:0;font-weight:600}#canvas-container{flex:1;position:relative;overflow:hidden}#canvas{cursor:crosshair;display:block}#canvas.image-loaded{cursor:grab}#canvas.image-loaded.grabbing{cursor:grabbing}.canvas-controls{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:5px;z-index:100}.control-btn{width:40px;height:40px;border:none;border-radius:6px;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.control-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.control-btn:active{transform:translateY(0);box-shadow:0 2px 4px #00000026}.control-btn svg{width:20px;height:20px;stroke:#2c3e50;stroke-width:2}.control-group{margin-bottom:20px}.control-group.collapsed>*:not(h3){display:none!important}.expand-button{cursor:pointer;-webkit-user-select:none;user-select:none;color:#666;font-size:18px;font-weight:700;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:background-color .2s ease}.expand-button:hover{background-color:#e0e0e0}.control-group h3{margin:0 0 10px;color:#333;display:flex;justify-content:space-between;align-items:center}button{width:100%;padding:8px;margin:5px 0;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;gap:6px}button:hover{background:#f0f0f0}button.active{background:#007bff;color:#fff}button svg{width:16px;height:16px}input[type=file]{width:100%;margin:5px 0}input[type=number]{width:100%;margin:2px 0;padding:4px;border:1px solid #ddd;border-radius:3px}label{display:block;margin:5px 0;font-size:12px;color:#666}.coordinates{font-size:12px;color:#666;max-height:200px;overflow-y:auto;border:1px solid #ddd;padding:10px;background:#fff}.point-item{margin:2px 0;padding:5px;background:#f9f9f9;border-radius:3px}.line-item{margin:5px 0;padding:8px;border:1px solid #ddd;border-radius:3px;background:#f9f9f9}.line-item.selected{background:#e6f3ff;border-color:#007bff}.line-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.line-controls{display:flex;align-items:center;gap:5px;flex-shrink:0}.line-info{flex:1;min-width:0;cursor:pointer}.line-name{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#555}.line-type{font-size:11px;color:#666;font-style:italic}.color-picker{width:16px;height:16px;border:none;border-radius:2px;cursor:default;padding:0;flex-shrink:0}.small-button{padding:2px 6px;font-size:11px;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:3px}.small-button:hover{background:#f0f0f0}.icon-button{padding:2px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:#666;transition:color .2s ease}.icon-button:hover{color:#333}.icon-button svg{width:16px;height:16px}.image-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.image-controls{display:flex;align-items:center;gap:5px;flex-shrink:0}.image-item{margin:5px 0;padding:8px;border:1px solid #ddd;border-radius:3px;background:#f9f9f9}.image-info{flex:1;min-width:0}.image-name{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#555}.image-size{font-size:11px;color:#666;font-style:italic;margin-top:2px}.line-block{margin-bottom:10px}.line-block.disabled{opacity:.5}.line-block.disabled .line-block-lines{pointer-events:none}.line-block.disabled .line-block-controls{pointer-events:auto}.line-block-header{display:flex;align-items:center;justify-content:space-between;padding:8px;background:#f0f0f0;border-radius:3px;margin-bottom:5px}.line-block-title{display:flex;align-items:center;gap:8px;font-weight:700;color:#333}.line-block-controls{display:flex;align-items:center;gap:5px}.line-block-lines{padding-left:20px}.line-item.add-button{border:1px dashed #ccc;background:#f9f9f9;color:#666;font-style:italic}.line-item.add-button:hover{background:#f0f0f0;border-color:#007bff;color:#007bff}.settings-item{margin:5px 0;padding:12px;border:1px solid #ddd;border-radius:3px;background:#f9f9f9}.settings-header{display:flex;align-items:center;justify-content:space-between;gap:15px}.settings-info{flex:1;min-width:0}.settings-controls{display:flex;align-items:center;flex-shrink:0}.settings-name{font-weight:700;color:#555;font-size:13px}.settings-description{font-size:11px;color:#666;font-style:italic;margin-top:2px}.settings-select{padding:4px 8px;border:1px solid #ddd;border-radius:3px;background:#fff;font-size:12px;cursor:pointer}.settings-select:hover{border-color:#007bff}.settings-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.settings-button{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #007bff;border-radius:4px;background:#007bff;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.settings-button:hover{background:#0056b3;border-color:#0056b3}.settings-button:active{transform:translateY(1px)}.settings-button svg{width:14px;height:14px}.toggle-switch{position:relative;display:inline-block;width:44px;height:20px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ccc;border-radius:20px;transition:.3s}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:2px;bottom:2px;background-color:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px #0000004d}.toggle-switch input:checked+.toggle-slider{background-color:#007bff}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch:hover .toggle-slider{background-color:#bbb}.toggle-switch input:checked:hover+.toggle-slider{background-color:#0056b3}.validation-summary{font-weight:700;margin-bottom:8px}.validation-details{margin-top:8px}.validation-category{margin:8px 0;padding:8px;background:#ffffff80;border-radius:3px}.validation-category h5{margin:0 0 5px;font-size:11px;font-weight:700;text-transform:uppercase}.validation-issue{margin:3px 0;padding:4px 6px;border-radius:2px;font-size:11px}.validation-issue.error{background:#f8d7da;color:#721c24}.validation-issue.warning{background:#fff3cd;color:#856404}.validation-issue.info{background:#d1ecf1;color:#0c5460}.validation-actions{margin-top:8px;display:flex;gap:5px}.validation-actions button{padding:4px 8px;font-size:11px;border:1px solid #ccc;background:#fff;border-radius:2px;cursor:pointer}.validation-actions button:hover{background:#f8f9fa}.validation-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.validation-modal-content{background:#fff;padding:20px;border-radius:8px;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.validation-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}.validation-modal-title{font-size:18px;font-weight:700;color:#333}.validation-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.validation-modal-close:hover{background:#f5f5f5}.validation-report{font-family:monospace;font-size:12px}.validation-report-summary{background:#f8f9fa;padding:15px;border-radius:4px;margin-bottom:15px}.validation-report-categories{display:grid;gap:15px}.validation-report-category{border:1px solid #ddd;border-radius:4px;overflow:hidden}.validation-report-category-header{background:#f8f9fa;padding:10px 15px;font-weight:700;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;align-items:center}.validation-report-category-content{padding:10px 15px}.validation-report-issue{margin:8px 0;padding:8px;border-radius:3px;border-left:3px solid}.validation-report-issue.error{background:#fdf2f2;border-left-color:#e53e3e}.validation-report-issue.warning{background:#fffbf0;border-left-color:#dd6b20}.validation-report-issue.info{background:#f0f9ff;border-left-color:#2b77e6}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:20px;border-radius:8px;max-width:500px;min-width:300px;box-shadow:0 4px 6px #0000001a;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}.modal-title{font-size:18px;font-weight:700;color:#333;margin:0}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#f5f5f5}.modal-body{margin-bottom:20px;line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:10px}.modal-button{padding:8px 16px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:14px}.modal-button:hover{background:#f8f9fa}.modal-button.primary{background:#007bff;color:#fff;border-color:#007bff}.modal-button.primary:hover{background:#0056b3;border-color:#0056b3}.modal-button.danger{background:#dc3545;color:#fff;border-color:#dc3545}.modal-button.danger:hover{background:#c82333;border-color:#bd2130}.modal-button.success{background:#28a745;color:#fff;border-color:#28a745}.modal-button.success:hover{background:#218838;border-color:#1e7e34}.modal-content.success{border-top:4px solid #28a745}.modal-content.info{border-top:4px solid #17a2b8}.modal-content.warning{border-top:4px solid #ffc107}.modal-content.error{border-top:4px solid #dc3545}.modal-icon{font-size:48px;text-align:center;margin-bottom:15px}.modal-icon.success{color:#28a745}.modal-icon.info{color:#17a2b8}.modal-icon.warning{color:#ffc107}.modal-icon.error{color:#dc3545}
