.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2rem 3rem;border-radius:10px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;margin-bottom:.5rem;color:#333}.login-box h2{text-align:center;margin-bottom:2rem;color:#666;font-size:1.2rem;font-weight:400}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:5px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.error-message{color:#d32f2f;background:#ffebee;padding:.75rem;border-radius:5px;margin-bottom:1rem;font-size:.9rem}.login-button{width:100%;padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:5px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.login-button:hover:not(:disabled){background:#5568d3}.login-button:disabled{background:#ccc;cursor:not-allowed}.map-container{display:flex;height:100vh;width:100vw}.sidebar{width:300px;background:#2c3e50;color:#fff;padding:2rem;overflow-y:auto;box-shadow:2px 0 10px #0000001a}.sidebar h1{margin-bottom:.5rem;font-size:1.8rem}.sidebar p{margin-bottom:2rem;color:#ecf0f1}.status{margin-bottom:2rem}.status-item{margin-bottom:1rem;padding:.75rem;background:#ffffff1a;border-radius:5px}.status-item strong{display:block;margin-bottom:.25rem;font-size:.9rem;color:#bdc3c7}.status-details{margin-top:.5rem;display:flex;flex-direction:column;gap:.35rem}.status-badge{display:inline-block;padding:.35rem .6rem;border-radius:999px;font-size:.85rem;font-weight:600;background:#ffffff26;color:#ecf0f1;width:fit-content}.status-badge.running{background:#2ecc7133;color:#2ecc71}.status-badge.idle{background:#3498db33;color:#3498db}.status-subtext{font-size:.8rem;color:#d0d6db;line-height:1.35}.status-note{padding:.75rem;background:#3498db2e;border:1px solid rgba(52,152,219,.35);border-radius:5px;margin-bottom:1rem;color:#d6ecff}.overlay-controls{margin-top:1rem;padding:.75rem;background:#ffffff1f;border-radius:6px;display:flex;flex-direction:column;gap:.75rem}.overlay-title{display:flex;justify-content:space-between;align-items:center;font-size:.95rem}.overlay-date{font-size:.8rem;color:#bdc3c7}.overlay-name{font-size:.9rem;color:#ecf0f1}.overlay-toggle{display:flex;justify-content:space-between;align-items:center;gap:.5rem;font-size:.9rem}.overlay-toggle-control{display:flex;align-items:center;gap:.4rem}.overlay-toggle-label{font-weight:600;color:#ecf0f1}.overlay-opacity{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.overlay-opacity input[type=range]{width:100%;accent-color:#1a73e8}.overlay-coordinates{font-size:.8rem}.overlay-coordinates ol{margin:.5rem 0 0;padding-left:1.2rem}.overlay-coordinates li{margin-bottom:.25rem}.loading{padding:1rem;text-align:center;background:#ffffff1a;border-radius:5px;margin-bottom:1rem}.error{padding:1rem;background:#e74c3c33;border:1px solid #e74c3c;border-radius:5px;margin-bottom:1rem;color:#faa}.overlay-upload-panel{margin-top:1rem;margin-bottom:1.5rem;padding:1.25rem;background:#ffffff14;border-radius:8px;border:1px solid rgba(255,255,255,.12);display:flex;flex-direction:column;gap:1rem}.overlay-upload-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.overlay-upload-header h3{margin:0;font-size:1.1rem;color:#ecf0f1}.overlay-upload-header p{margin:.35rem 0 0;color:#ecf0f1d9;font-size:.9rem}.overlay-upload-close{background:transparent;color:#ecf0f1bf;border:none;font-size:1.2rem;cursor:pointer}.overlay-upload-progress{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem}.overlay-upload-progress-step{padding:.5rem;border-radius:6px;background:#ffffff0d;border:1px solid transparent;text-align:center;font-size:.8rem;color:#ecf0f1b3}.overlay-upload-progress-step .number{display:inline-block;margin-bottom:.35rem;width:1.8rem;height:1.8rem;line-height:1.8rem;border-radius:50%;background:#ffffff1f;color:#ecf0f1;font-weight:600}.overlay-upload-progress-step.active{border-color:#ffffff59;background:#2ecc711a;color:#ecf0f1}.overlay-upload-progress-step.complete{border-color:#2ecc7166;background:#2ecc711f;color:#2ecc71}.overlay-upload-error{padding:.75rem;border-radius:6px;border:1px solid rgba(231,76,60,.5);background:#e74c3c26;color:#ffe3df;font-size:.9rem}.overlay-upload-step{display:flex;flex-direction:column;gap:.75rem;font-size:.9rem}.overlay-upload-file-preview{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#ecf0f1cc}.overlay-upload-placeholder{display:flex;align-items:center;justify-content:center;width:100%;min-height:260px;border:1px dashed rgba(255,255,255,.3);border-radius:8px;color:#ecf0f199}.overlay-image-wrapper{position:relative;width:100%;max-height:380px;overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.overlay-image{display:block;width:100%;height:auto;cursor:crosshair}.overlay-image-point{position:absolute;transform:translate(-50%,-100%);background:#1a73e8e6;color:#fff;padding:.2rem .35rem;border-radius:4px;font-size:.7rem;pointer-events:none;white-space:nowrap}.overlay-image-next{position:absolute;left:50%;top:10px;transform:translate(-50%);background:#0009;padding:.35rem .5rem;border-radius:999px;font-size:.75rem;color:#f8f9fa}.overlay-upload-inline-actions{display:flex;gap:.75rem;flex-wrap:wrap}.overlay-image-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;justify-content:center;align-items:center;padding:2rem;z-index:2000}.overlay-image-modal-content{background:#1f2933;border-radius:10px;border:1px solid rgba(255,255,255,.2);width:min(90vw,1200px);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 16px 48px #00000073}.overlay-image-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem .75rem}.overlay-image-modal-header h4{margin:0;color:#ecf0f1;font-size:1.1rem}.overlay-image-modal-body{padding:0 1.5rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.overlay-image-modal-canvas{position:relative;width:100%;max-height:70vh;overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.3)}.overlay-image-modal-img{display:block;width:100%;height:auto;cursor:crosshair}.overlay-image-modal-hint{margin:0;font-size:.85rem;color:#ecf0f1bf}.overlay-point-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem;font-family:monospace;font-size:.8rem;color:#ecf0f1d9}.overlay-upload-actions{display:flex;gap:.75rem;flex-wrap:wrap}.overlay-upload-link-button{background:none;border:none;color:#74b9ff;cursor:pointer;font-size:.85rem;padding:0;text-decoration:underline}.overlay-upload-link-button:disabled{color:#bdc3c799;cursor:default;text-decoration:none}.overlay-upload-map-instructions,.overlay-upload-field{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:#ecf0f1d9}.overlay-upload-field input[type=text],.overlay-upload-field input[type=datetime-local]{padding:.5rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#ecf0f1}.overlay-upload-field input[type=range]{accent-color:#1a73e8}.overlay-upload-checkbox{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:#ecf0f1d9}.overlay-upload-summary{background:#00000059;border-radius:6px;padding:.75rem;font-size:.82rem;color:#ecf0f1d9}.overlay-upload-summary h4{margin:0 0 .5rem;font-size:.9rem;color:#ecf0f1}.overlay-upload-summary ol{margin:.35rem 0 0;padding-left:1.2rem}.overlay-upload-footer{display:flex;justify-content:space-between;gap:.75rem}.overlay-upload-primary{padding:.6rem 1.1rem;border:none;border-radius:6px;background:#1a73e8;color:#fff;cursor:pointer;font-size:.95rem;transition:background .3s,opacity .3s}.overlay-upload-primary:disabled{background:#1a73e866;cursor:default}.overlay-upload-primary:not(:disabled):hover{background:#1669c1}.overlay-floating-preview{position:absolute;right:20px;bottom:20px;width:min(420px,36vw);max-height:55vh;background:#111827eb;border-radius:10px;border:1px solid rgba(255,255,255,.18);box-shadow:0 16px 40px #0006;display:flex;flex-direction:column;overflow:hidden;z-index:1100}.overlay-floating-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#0f172ae6;font-size:.9rem;color:#ecf0f1}.overlay-floating-close{background:transparent;border:none;color:#ecf0f1cc;font-size:1.1rem;cursor:pointer}.overlay-floating-body{padding:.75rem 1rem 1rem;display:flex;flex-direction:column;gap:.75rem}.overlay-floating-canvas{position:relative;width:100%;max-height:40vh;overflow:hidden;border-radius:8px;border:1px solid rgba(255,255,255,.25)}.overlay-floating-canvas img{display:block;width:100%;height:auto}.overlay-floating-point{position:absolute;transform:translate(-50%,-100%);background:#1a73e8e6;color:#fff;padding:.2rem .35rem;border-radius:4px;font-size:.7rem;pointer-events:none;white-space:nowrap;border:1px solid rgba(255,255,255,.9)}.overlay-floating-hint{margin:0;font-size:.8rem;color:#ecf0f1bf}.overlay-fullscreen-capture{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a;display:flex;align-items:center;justify-content:center;cursor:crosshair;z-index:2000}.overlay-fullscreen-img{max-width:100%;max-height:100%;object-fit:contain}.overlay-fullscreen-instructions{position:absolute;top:16px;left:50%;transform:translate(-50%);background:#0f172ad9;padding:.6rem 1.1rem;border-radius:999px;font-size:.9rem;color:#ecf0f1;border:1px solid rgba(255,255,255,.2)}.overlay-fullscreen-point{position:absolute;transform:translate(-50%,-100%);background:#1a73e8e6;color:#fff;padding:.25rem .4rem;border-radius:4px;font-size:.75rem;pointer-events:none;border:1px solid rgba(255,255,255,.85);box-shadow:0 4px 12px #0000004d}.overlay-map-marker{background:#1a73e8e6;color:#fff;padding:.15rem .4rem;border-radius:4px;font-size:.75rem;font-weight:600;border:1px solid rgba(255,255,255,.8)}.pipeline-button{width:100%;padding:.75rem;background:#27ae60;color:#fff;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:background .3s,opacity .3s;margin-bottom:1rem}.pipeline-button:hover{background:#1f8a4c}.pipeline-button:disabled{background:#27ae6099;cursor:not-allowed}.logout-button{width:100%;padding:.75rem;background:#e74c3c;color:#fff;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:background .3s;margin-top:1rem}.logout-button:hover{background:#c0392b}.map{flex:1;position:relative}.fit-controls{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem}.fit-button{padding:.55rem .9rem;border:none;border-radius:6px;background:#1a73e8;color:#fff;font-size:.9rem;cursor:pointer;transition:background .3s,opacity .3s}.fit-button:disabled{background:#1a73e866;cursor:default}.fit-button:not(:disabled):hover{background:#1669c1}.fit-toggle{display:flex;align-items:center;gap:.45rem;font-size:.85rem;color:#ecf0f1d9}.overlay-handle{width:16px;height:16px;border-radius:50%;border:2px solid #fff;background:#000c;box-shadow:0 0 4px #0006;cursor:grab}.overlay-handle-center{background:#ffffffe6;border-color:#1a73e8}.overlay-handle-scale{background:#1a73e8e6;border-color:#fff}.overlay-alignment-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000073;z-index:1200;padding:24px}.overlay-alignment-content{width:420px;max-width:100%;background:#fff;border-radius:12px;box-shadow:0 20px 45px #00000040;padding:24px;display:flex;flex-direction:column;gap:16px}.overlay-alignment-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.overlay-alignment-header h3{margin:0 0 4px;font-size:1.3rem}.overlay-alignment-header p{margin:0;color:#5f6368;font-size:.95rem}.overlay-alignment-close{background:transparent;border:none;font-size:1.2rem;cursor:pointer;line-height:1}.overlay-alignment-section{display:flex;flex-direction:column;gap:12px}.overlay-alignment-section h4{margin:0;font-size:1rem}.overlay-alignment-section ul{margin:0;padding-left:18px;color:#5f6368;font-size:.95rem}.overlay-alignment-field{display:flex;flex-direction:column;gap:6px;font-size:.95rem}.overlay-alignment-field input[type=text],.overlay-alignment-field input[type=datetime-local]{padding:6px 10px;border:1px solid #c4c4c4;border-radius:6px;font-size:.95rem}.overlay-alignment-field input[type=range]{width:100%}.overlay-alignment-checkbox{display:flex;align-items:center;gap:8px;font-size:.95rem}.overlay-alignment-summary{padding:12px;border:1px solid #e0e0e0;border-radius:8px;background:#fafafa;font-size:.9rem;color:#3c4043;display:flex;flex-direction:column;gap:4px}.overlay-alignment-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.overlay-alignment-hud{position:absolute;left:20px;bottom:20px;width:min(360px,32vw);background:#0f172aeb;border-radius:12px;border:1px solid rgba(148,163,184,.35);box-shadow:0 16px 40px #0f172aa6;padding:1.1rem 1.2rem 1rem;color:#ecf0f1;display:flex;flex-direction:column;gap:.75rem;z-index:1200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.overlay-alignment-opacity{display:flex;flex-direction:column;gap:.4rem;font-size:.85rem}.overlay-alignment-opacity input[type=range]{width:100%;accent-color:#38bdf8}.overlay-alignment-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.overlay-alignment-header h3{margin:0;font-size:1rem;font-weight:600;color:#f8fafc}.overlay-alignment-hud p{margin:0;font-size:.85rem;color:#e2e8f0d9;line-height:1.5}.overlay-alignment-anchor{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem}.overlay-alignment-anchor-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.overlay-align-anchor-button{border:1px solid rgba(148,163,184,.4);background:#1e293ba6;color:#e2e8f0;border-radius:8px;padding:.45rem .4rem;font-size:.85rem;font-weight:500;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .15s ease}.overlay-align-anchor-button:hover:not(:disabled){background:#3b82f659;border-color:#3b82f699;color:#f8fafc}.overlay-align-anchor-button.active{background:#3b82f6a6;border-color:#3b82f6e6;color:#f8fafc;box-shadow:0 0 0 1px #3b82f673 inset}.overlay-align-anchor-button:disabled{opacity:.6;cursor:not-allowed}.overlay-alignment-actions{display:flex;justify-content:space-between;gap:.75rem}.app{height:100vh;width:100vw;overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}body{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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
