:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.sidebar{width:280px;height:100%;background-color:#1a1a1a;border-right:1px solid #333;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:1.5rem;border-bottom:1px solid #333}.sidebar-header h2{margin:0 0 1rem;font-size:1.5rem;font-weight:600}.upload-button{width:100%;padding:.75rem 1rem;background-color:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.upload-button:hover{background-color:#535bf2}.clear-button{width:100%;padding:.75rem 1rem;margin-top:.5rem;background-color:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.clear-button:hover{background-color:#c82333}.thumbnail-list{flex:1;overflow-y:auto;padding:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#888;text-align:center;padding:2rem}.empty-state p{margin:.5rem 0}.thumbnail{margin-bottom:1rem;border:2px solid transparent;border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s;background-color:#242424;position:relative}.thumbnail:hover{border-color:#646cff;transform:translateY(-2px)}.thumbnail.selected{border-color:#646cff;box-shadow:0 0 10px #646cff4d}.delete-image-button{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border:none;border-radius:50%;background-color:#dc3545e6;color:#fff;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background-color .2s,transform .2s;z-index:10;padding:0}.thumbnail:hover .delete-image-button{opacity:1}.delete-image-button:hover{background-color:#c82333;transform:scale(1.1)}.thumbnail img{width:100%;height:150px;object-fit:cover;display:block}.thumbnail-name{padding:.5rem;font-size:.85rem;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thumbnail-list::-webkit-scrollbar{width:8px}.thumbnail-list::-webkit-scrollbar-track{background:#1a1a1a}.thumbnail-list::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.thumbnail-list::-webkit-scrollbar-thumb:hover{background:#555}@media(prefers-color-scheme:light){.sidebar{background-color:#f5f5f5;border-right-color:#ddd}.sidebar-header{border-bottom-color:#ddd}.thumbnail{background-color:#fff;border-color:#ddd}.thumbnail:hover,.thumbnail.selected{border-color:#646cff}.thumbnail-name{color:#333}.thumbnail-list::-webkit-scrollbar-track{background:#f5f5f5}.thumbnail-list::-webkit-scrollbar-thumb{background:#ccc}.thumbnail-list::-webkit-scrollbar-thumb:hover{background:#aaa}}.image-viewer{flex:1;height:100%;display:flex;flex-direction:column;background-color:#242424;overflow:hidden}.image-viewer.empty{display:flex;align-items:center;justify-content:center}.empty-message{text-align:center;color:#888}.empty-message p{margin:.5rem 0;font-size:1.1rem}.controls{padding:1.5rem;background-color:#1a1a1a;border-bottom:1px solid #333;display:flex;gap:2rem;align-items:center;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:.75rem}.control-group label{font-weight:500;white-space:nowrap}.control-group input[type=number]{width:120px;padding:.5rem;border:1px solid #444;border-radius:4px;background-color:#2a2a2a;color:#fff;font-size:1rem}.control-group input[type=number]:focus{outline:none;border-color:#646cff}.control-group input[type=number]:disabled{opacity:.5;cursor:not-allowed}.calibration-button{padding:.5rem 1rem;background-color:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.calibration-button:hover{background-color:#535bf2}.calibration-button.active{background-color:#ff6b6b}.calibration-button.active:hover{background-color:#ff5252}.measurement-display{padding:.5rem 1rem;background-color:#2a2a2a;border-radius:6px;border:1px solid #646cff;color:#fff;font-size:1.1rem}.measurement-display strong{color:#646cff;margin-right:.5rem}.instruction{color:#888;font-size:.9rem;font-style:italic;margin-left:auto}.canvas-container{flex:1;position:relative;overflow:auto;display:flex;align-items:center;justify-content:center;background-color:#1a1a1a;padding:1rem}.measurement-image{max-width:100%;max-height:100%;display:block;object-fit:contain;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.measurement-canvas{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-width:100%;max-height:100%}.zoom-window{position:absolute;bottom:20px;right:20px;border:3px solid #646cff;border-radius:8px;box-shadow:0 4px 12px #00000080;background-color:#000;pointer-events:none;z-index:100}.canvas-container::-webkit-scrollbar{width:10px;height:10px}.canvas-container::-webkit-scrollbar-track{background:#1a1a1a}.canvas-container::-webkit-scrollbar-thumb{background:#444;border-radius:5px}.canvas-container::-webkit-scrollbar-thumb:hover{background:#555}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background-color:#2a2a2a;border:1px solid #444;border-radius:8px;padding:2rem;min-width:400px;box-shadow:0 4px 20px #00000080}.modal h3{margin:0 0 1rem;color:#fff;font-size:1.5rem}.modal p{margin:0 0 1.5rem;color:#ccc}.modal input[type=number]{width:100%;padding:.75rem;border:1px solid #444;border-radius:4px;background-color:#1a1a1a;color:#fff;font-size:1rem;margin-bottom:1.5rem}.modal input[type=number]:focus{outline:none;border-color:#646cff}.modal-buttons{display:flex;gap:1rem;justify-content:flex-end}.modal-buttons button{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.submit-button{background-color:#646cff;color:#fff}.submit-button:hover{background-color:#535bf2}.cancel-button{background-color:#444;color:#fff}.cancel-button:hover{background-color:#555}@media(prefers-color-scheme:light){.image-viewer{background-color:#fff}.controls{background-color:#f5f5f5;border-bottom-color:#ddd}.control-group input[type=number]{border-color:#ccc;background-color:#fff;color:#333}.control-group input[type=number]:focus{border-color:#646cff}.measurement-display{background-color:#fff;border-color:#646cff;color:#333}.canvas-container{background-color:#f9f9f9}.canvas-container::-webkit-scrollbar-track{background:#f9f9f9}.canvas-container::-webkit-scrollbar-thumb{background:#ccc}.canvas-container::-webkit-scrollbar-thumb:hover{background:#aaa}.modal{background-color:#fff;border-color:#ddd}.modal h3{color:#333}.modal p{color:#666}.modal input[type=number]{border-color:#ccc;background-color:#fff;color:#333}.modal input[type=number]:focus{border-color:#646cff}.cancel-button{background-color:#e0e0e0;color:#333}.cancel-button:hover{background-color:#d0d0d0}}.app{display:flex;width:100%;height:100%;overflow:hidden}
