:root{--primary:#212121;--primary-dark:#111;--accent:#e65100;--accent-dark:#bf360c;--bg:#fafafa;--card:#fff;--text:#212121;--text-light:#616161;--border:#e0e0e0;--success:#388e3c;--danger:#d32f2f;--warn:#f57c00}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}header{background:var(--primary);color:#fff;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex;box-shadow:0 2px 4px #0000001a}header h1{font-size:1.3rem}header .subtitle{opacity:.8;font-size:.85rem}header .status{margin-left:auto;font-size:.85rem;font-weight:600}.btn-logout{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:4px;margin-left:.5rem;padding:.25rem .6rem;font-size:.8rem}.btn-logout:hover{background:#ffffff40}.app{height:calc(100vh - 48px);display:flex}.sidebar{background:var(--card);border-right:1px solid var(--border);flex-direction:column;gap:1rem;width:320px;min-width:280px;padding:1rem;display:flex;overflow-y:auto}.main-area{background:#e2e8f0;flex-direction:column;flex:1;display:flex;overflow:hidden}.canvas-wrap{flex:1;position:relative;overflow:hidden}.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1rem}.card h3{color:var(--primary);margin-bottom:.5rem;font-size:.95rem}.upload-area{border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:8px;padding:1.5rem;transition:all .2s}.upload-area:hover{border-color:var(--primary);background:#eff6ff}.upload-area p{color:var(--text-light);font-size:.85rem}.btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;gap:.4rem;width:100%;padding:.5rem 1rem;font-size:.85rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{cursor:not-allowed;background:#94a3b8}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.9)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(.9)}.btn-warn{background:var(--warn);color:#fff}.btn-sm{width:auto;padding:.35rem .75rem;font-size:.8rem}.btn-row{gap:.5rem;display:flex}.btn-row .btn{flex:1}.instructions{color:var(--primary-dark);background:#eff6ff;border-radius:8px;padding:.75rem;font-size:.82rem;line-height:1.6}.instructions strong{margin-bottom:.2rem;display:block}.line-list{max-height:250px;overflow-y:auto}.line-item{border-bottom:1px solid var(--border);cursor:pointer;border-radius:4px;justify-content:space-between;align-items:center;padding:.4rem .5rem;font-size:.82rem;display:flex}.line-item:hover{background:var(--bg-card)}.line-item.selected{outline:2px solid var(--primary);background:#dbeafe}.line-item:last-child{border-bottom:none}.line-item .info{color:var(--text-light)}.line-item .delete-line-btn{cursor:pointer;color:var(--text-light);background:0 0;border:none;padding:0 .2rem;font-size:1rem;line-height:1}.line-item .delete-line-btn:hover{color:var(--danger)}#imageCanvas{cursor:crosshair;width:100%;height:100%;position:absolute;top:0;left:0}.zoom-controls{z-index:10;gap:.3rem;display:flex;position:absolute;bottom:1rem;right:1rem}.zoom-controls button{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.seed-dot{pointer-events:none;z-index:5;background:#f59e0b;border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 4px #0006}.seed-dot.confirmed{background:var(--danger)}.form-row{align-items:center;gap:.5rem;margin-bottom:.3rem;font-size:.85rem;display:flex}.form-row label{color:var(--text-light);flex:1}.form-row input[type=number]{border:1px solid var(--border);border-radius:4px;width:80px;padding:.3rem;font-size:.85rem}.hidden{display:none!important}.keyboard-hint{color:var(--text-light);text-align:center;margin-top:.3rem;font-size:.72rem}.keyboard-hint kbd{border:1px solid var(--border);background:#f1f5f9;border-radius:3px;padding:.1rem .35rem;font-family:monospace;font-size:.72rem;display:inline-block}.endpoint-handle{z-index:10;cursor:grab;border:2.5px solid #fff;border-radius:50%;width:16px;height:16px;transition:box-shadow .1s;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 6px #00000080}.endpoint-handle:hover,.endpoint-handle.dragging{cursor:grabbing;box-shadow:0 0 10px #000000b3}.endpoint-handle.start{background:#22c55e}.endpoint-handle.end{background:#ef4444}.magnifier{pointer-events:none;z-index:100;width:180px;height:180px;image-rendering:pixelated;border:3px solid #fff;border-radius:50%;display:none;position:fixed;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 0 12px #0009}.magnifier canvas{width:100%;height:100%;image-rendering:pixelated;display:block}.magnifier-crosshair{pointer-events:none;width:0;height:0;position:absolute;top:50%;left:50%}.magnifier-crosshair:before,.magnifier-crosshair:after{content:"";background:#ffffffb3;position:absolute}.magnifier-crosshair:before{width:1px;height:20px;top:-10px;left:0}.magnifier-crosshair:after{width:20px;height:1px;top:0;left:-10px}.view-tabs{background:var(--card);border-bottom:2px solid var(--border);flex-shrink:0;gap:.4rem;padding:.3rem .5rem 0;display:none}.view-tabs button{color:var(--text-light);cursor:pointer;background:#f1f5f9;border:none;border-bottom:4px solid #0000;border-radius:8px 8px 0 0;margin-bottom:-2px;padding:.55rem 1.3rem;font-size:.9rem;font-weight:700;transition:all .15s}.view-tabs button:hover{color:var(--text);background:#e2e8f0}.view-tabs button.active{color:var(--primary);border-bottom-color:var(--primary);background:#fff;box-shadow:0 -2px 6px #2563eb1f}.view-panel{border-bottom:2px solid var(--border);background:var(--card);flex-shrink:0;padding:.5rem;display:none}.view-panel-header{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.view-panel-header h4{color:var(--primary);margin:0;font-size:.85rem}.view-panel-header .header-left{align-items:center;gap:.5rem;display:flex}.view-panel-header button{cursor:pointer;color:var(--text-light);background:0 0;border:none;padding:0 .3rem;font-size:1.1rem}.view-panel-header button:hover{color:var(--danger)}#resetCropBtn{border-radius:4px;background:var(--bg-card)!important;border:1px solid var(--border)!important;color:var(--text-light)!important;padding:.15rem .4rem!important;font-size:.7rem!important}#resetCropBtn:hover{color:var(--primary)!important;border-color:var(--primary)!important}.view-previews{gap:.5rem;height:340px;display:flex}.view-preview{flex-direction:column;flex:1;min-width:0;display:flex}.view-preview .view-label{color:var(--text-light);text-align:center;margin-bottom:.25rem;font-size:.75rem;font-weight:600}.view-preview img,.view-preview canvas{object-fit:contain;border:1px solid var(--border);background:#1e293b;border-radius:6px;flex:1;width:100%;min-height:0}.view-preview canvas{cursor:ns-resize}.spinner-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;display:none;position:absolute;inset:0}.spinner-overlay.active{display:flex}.spinner{border:4px solid #ffffff40;border-top-color:#424242;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#loginOverlay{z-index:10000;background:var(--bg);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-box{background:var(--card);border-radius:8px;width:400px;overflow:hidden;box-shadow:0 8px 40px #00000026}.login-toolbar{background:var(--primary);color:#fff;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.login-toolbar img{width:auto;height:28px}.login-toolbar span{font-size:1.1rem;font-weight:500}.login-body{padding:1.75rem 1.5rem 1.5rem}.login-field{align-items:center;gap:.6rem;margin-bottom:1rem;display:flex}.login-field .field-icon{color:var(--text-light);text-align:center;width:24px;font-size:1.2rem}.login-field input{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:6px;flex:1;padding:.65rem .8rem;font-size:.95rem}.login-field input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2121211f}.login-actions{justify-content:flex-end;margin-top:1.25rem;display:flex}.login-actions .btn{background:var(--primary);color:#fff;cursor:pointer;letter-spacing:.02em;border:none;border-radius:6px;padding:.55rem 1.5rem;font-size:.95rem;font-weight:500}.login-actions .btn:hover{background:var(--primary-dark)}.login-error{color:var(--danger);background:#ffebee;border-radius:4px;min-height:1.2em;margin-top:.8rem;padding:.5rem .75rem;font-size:.85rem;display:none}.login-error.visible{display:block}header.hidden,.app.hidden{display:none!important}
