*,*:before,*:after{box-sizing:border-box}body,h1,h2,h3,p,figure,blockquote,dl,dd{margin:0}html{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture{max-width:100%;display:block}input,button,textarea,select{font:inherit}:root{font-family:Inter,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}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}}:root{--primary-color: #4361ee;--primary-hover: #3a56d4;--secondary-color: #6c757d;--secondary-hover: #5a6268;--success-color: #4CAF50;--success-hover: #45a049;--danger-color: #e63946;--danger-hover: #d32f2f;--background-color: #f5f5f5;--card-background: #fff;--text-color: #333;--border-color: #ddd;--shadow-color: rgba(0, 0, 0, .1);--border-radius: 8px;--transition-speed: .3s;--input-background: #fff;--button-primary: #3498db;--button-primary-text: #fff;--button-secondary: #e0e0e0;--button-secondary-text: #333;--button-danger: #e74c3c;--hover-color: #f0f0f0;--active-color: #e0e0e0;--spinner-color: #3498db}.dark-mode{--background-color: #1e1e1e;--card-background: #2d2d2d;--text-color: #f0f0f0;--border-color: #444;--input-background: #3d3d3d;--button-primary: #2980b9;--button-primary-text: #f0f0f0;--button-secondary: #444;--button-secondary-text: #f0f0f0;--button-danger: #c0392b;--hover-color: #3a3a3a;--active-color: #444;--shadow-color: rgba(0, 0, 0, .3);--spinner-color: #2980b9}body{font-family:Segoe UI,Roboto,Helvetica Neue,sans-serif;margin:0;padding:0;background-color:var(--background-color);color:var(--text-color);transition:background-color var(--transition-speed),color var(--transition-speed)}.app-container{min-height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:var(--card-background);border-bottom:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-color);position:relative;z-index:10}.app-header h1{margin:0;font-size:1.5rem;font-weight:600;color:var(--primary-color)}.app-content{flex:1;display:flex;flex-direction:row;padding:.5rem;gap:.75rem;max-width:1600px;margin:0 auto;width:100%;min-height:0}.content-wrapper{flex:1;display:flex;flex-direction:column;gap:.5rem;min-height:0;overflow:hidden}.sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column}.canvas-container{flex:1;display:flex;flex-direction:row;position:relative;gap:.25rem;background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:0 4px 6px var(--shadow-color);overflow:hidden;padding:0;max-height:calc(100vh - 16rem);min-height:0}.main-canvas-wrapper,.preview-canvas-wrapper{position:relative;background-color:#0000000d;border-radius:0;display:flex;align-items:center;justify-content:center;overflow:hidden;margin:0;padding:0;width:50%;flex-shrink:0;max-height:calc(100vh - 16rem)}.dark-mode .main-canvas-wrapper,.dark-mode .preview-canvas-wrapper{background-color:#ffffff0d}@media (max-width: 1200px){.canvas-container{flex-direction:column}.main-canvas-wrapper,.preview-canvas-wrapper{width:100%}}.card{background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:0 4px 6px var(--shadow-color);padding:.6rem;margin-bottom:.5rem;transition:box-shadow .2s}.card:hover{box-shadow:0 6px 12px var(--shadow-color)}.card h2{margin-top:0;margin-bottom:.5rem;font-size:1rem;font-weight:600;color:var(--primary-color)}.dropzone{border:1px dashed var(--border-color);border-radius:var(--border-radius);padding:.75rem .5rem;text-align:center;transition:all .2s;cursor:pointer;background-color:#00000005;display:flex;flex-direction:column;align-items:center;justify-content:center}.dark-mode .dropzone{background-color:#ffffff0d}.dropzone:hover{border-color:var(--primary-color);background-color:#4361ee0d}.dropzone input[type=file]{display:none}.file-input-label{display:inline-block;padding:.4rem .8rem;background-color:var(--primary-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;font-weight:500;transition:background-color .2s;font-size:.85rem}.file-input-label:hover{background-color:var(--primary-hover)}.control-group{margin-bottom:.6rem}.control-group label{display:block;margin-bottom:.25rem;font-size:.8rem;color:var(--text-color)}.control-group input[type=range]{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--border-color);border-radius:3px;outline:none}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background-color:var(--primary-color);border-radius:50%;cursor:pointer;transition:background-color .2s}.control-group input[type=range]::-webkit-slider-thumb:hover{background-color:var(--primary-hover)}.preview-toggle,.edge-detection-toggle{display:flex;align-items:center;margin-bottom:0}.preview-toggle label,.edge-detection-toggle label{display:flex;align-items:center;margin-bottom:0;cursor:pointer}.preview-toggle input[type=checkbox],.edge-detection-toggle input[type=checkbox]{width:14px;height:14px;cursor:pointer;margin:0}.select-label{display:block;margin-bottom:.25rem;font-size:.8rem;color:var(--text-color)}.select-input{width:100%;padding:.4rem .5rem;border-radius:var(--border-radius);border:1px solid var(--border-color);background-color:var(--card-background);color:var(--text-color);font-size:.85rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23444' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:16px 12px}.dark-mode .select-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23ccc' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3E%3C/svg%3E")}.button-group{display:flex;flex-direction:column;gap:.5rem}button{padding:.5rem 1rem;border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:500;transition:background-color .2s,transform .1s;font-size:.9rem}button:active{transform:translateY(1px)}button:disabled{background-color:var(--secondary-color);opacity:.5;cursor:not-allowed}.primary-button{background-color:var(--primary-color);color:#fff}.primary-button:hover:not(:disabled){background-color:var(--primary-hover)}.secondary-button{background-color:var(--secondary-color);color:#fff}.secondary-button:hover:not(:disabled){background-color:var(--secondary-hover)}.mode-toggle{background:transparent;border:none;font-size:1.4rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s;padding:0}.mode-toggle:hover{background-color:#0000000d}.dark-mode .mode-toggle:hover{background-color:#ffffff1a}.main-canvas,.preview-canvas{max-width:100%;height:auto;object-fit:contain;display:block;margin:0}.canvas-label{position:absolute;top:5px;left:5px;background-color:var(--primary-color);color:#fff;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:500;z-index:15}.upload-prompt{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:0 4px 6px var(--shadow-color);padding:3rem;min-height:300px}.upload-prompt p{margin:.5rem 0}.small-text{font-size:.85rem;color:var(--secondary-color)}.app-footer{text-align:center;padding:.75rem;margin-top:.5rem;color:var(--secondary-color);font-size:.8rem}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;border-radius:var(--border-radius);color:#fff}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.upload-instructions{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-instructions p{margin:.25rem 0 0;font-size:.75rem;color:var(--secondary-color)}.uploaded-image-info{display:flex;flex-direction:column;align-items:center;gap:.5rem}.uploaded-image-info p{margin:.25rem 0 0;font-size:.8rem;color:var(--secondary-color)}.position-info{margin-top:.6rem;border-top:1px solid var(--border-color);padding-top:.4rem}.position-label{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.5rem}.help-text{font-size:.75rem;color:var(--secondary-color);margin:0;font-style:italic}.results-tray-container{background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:0 4px 6px var(--shadow-color);padding:.75rem;max-height:180px;overflow-y:auto;min-height:150px}.results-tray-container h3{font-size:.9rem;margin-top:0;margin-bottom:.5rem;color:var(--primary-color)}.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.history-item{position:relative;cursor:pointer;border-radius:4px;overflow:hidden;box-shadow:0 2px 4px var(--shadow-color);transition:transform .2s,box-shadow .2s;aspect-ratio:1}.history-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow-color)}.history-item img{width:100%;height:100%;object-fit:cover;display:block}.history-item .actions{position:absolute;bottom:0;left:0;right:0;background-color:#000000b3;display:flex;opacity:0;transition:opacity .2s;padding:.25rem}.history-item:hover .actions{opacity:1}.history-item .actions button{flex:1;padding:.25rem;font-size:.7rem;min-width:0;background-color:transparent;color:#fff;border:none}.history-item .actions button:hover{background-color:#fff3}.history-item .actions button.download{color:#3498db}.history-item .actions button.remove{color:#e74c3c}.history-time{position:absolute;top:0;right:0;background-color:#000000b3;color:#fff;font-size:.6rem;padding:.15rem .3rem;border-bottom-left-radius:4px}.button-row{display:flex;gap:.5rem;margin-bottom:.5rem}.button-row button{flex:1}.process-buttons{display:flex;flex-direction:column;gap:.5rem}.control-row{display:flex;align-items:center;gap:.5rem;width:100%}.control-button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;min-width:24px;padding:0;font-size:1rem;line-height:1;background-color:var(--card-background);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:background-color .2s,color .2s;color:var(--text-color)}.control-button:hover{background-color:var(--hover-color)}.control-button:active{background-color:var(--active-color)}.numeric-input{width:50px;text-align:center;padding:2px 4px;font-size:.8rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--input-background);color:var(--text-color)}input[type=range]{flex:1;margin:0}.logo-container{display:flex;align-items:center;gap:12px}.app-logo{height:40px;width:auto}
