@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg:#0a0d12;--surface:#0f1318;--surface2:#141920;--surface3:#1a2030;--border:#1e2530;--border2:#252d3a;--cyan:#00d4ff;--cyan-dim:#09b;--amber:#f59e0b;--amber-dim:#b37a08;--red:#ef4444;--red-dim:#991b1b;--green:#22c55e;--green-dim:#15803d;--purple:#7c3aed;--text:#d4dce8;--text-dim:#6b7a8d;--text-muted:#3d4a5c;--font-mono:"JetBrains Mono", "Courier New", monospace;--font-sans:"Inter", system-ui, sans-serif;--radius:4px;--radius-lg:8px;--topbar-h:48px;--sidebar-w:380px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-size:13px;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-shell{flex-direction:column;height:100vh;display:flex;overflow:hidden}.workspace{flex:1;display:flex;position:relative;overflow:hidden}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;align-items:center;gap:8px;padding:0 12px;display:flex}.topbar-logo{font-family:var(--font-mono);color:var(--cyan);letter-spacing:-1px;align-items:center;gap:6px;margin-right:8px;font-size:16px;font-weight:700;display:flex}.topbar-logo .logo-dot{background:var(--cyan);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.topbar-divider{background:var(--border);width:1px;height:24px;margin:0 4px}.topbar-case{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:8px;max-width:280px;padding:4px 10px;transition:border-color .15s;display:flex}.topbar-case:hover{border-color:var(--cyan-dim)}.topbar-case-num{font-family:var(--font-mono);color:var(--cyan);letter-spacing:1px;font-size:10px}.topbar-case-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.topbar-spacer{flex:1}.topbar-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);font-size:12px;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:6px;padding:5px 10px;transition:all .15s;display:flex}.topbar-btn:hover{border-color:var(--cyan-dim);color:var(--cyan)}.topbar-btn.active{border-color:var(--cyan);color:var(--cyan);background:#00d4ff0f}.topbar-btn.danger:hover{border-color:var(--red);color:var(--red)}.topbar-badge{background:var(--cyan);color:var(--bg);font-size:9px;font-weight:700;font-family:var(--font-mono);border-radius:10px;padding:1px 5px}.canvas-wrap{background:var(--bg);background-image:linear-gradient(#00d4ff08 1px,#0000 1px),linear-gradient(90deg,#00d4ff08 1px,#0000 1px);background-size:40px 40px;flex:1;position:relative;overflow:hidden}.canvas-inner{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.canvas-image-wrap{-webkit-user-select:none;user-select:none;display:inline-block;position:relative}.canvas-image{max-width:100%;max-height:calc(100vh - var(--topbar-h) - 40px);object-fit:contain;pointer-events:none;display:block}.probe-selection{border:2px solid var(--cyan);pointer-events:none;background:#00d4ff14;position:absolute;box-shadow:0 0 0 1px #00d4ff4d}.probe-overlay{border:1.5px solid var(--amber);cursor:pointer;transition:border-color .15s;position:absolute}.probe-overlay:hover,.probe-overlay.selected{border-color:var(--cyan);box-shadow:0 0 0 1px #00d4ff66}.probe-overlay-label{background:var(--amber);color:var(--bg);font-size:9px;font-family:var(--font-mono);white-space:nowrap;padding:1px 5px;font-weight:700;position:absolute;top:-20px;left:0}.canvas-toolbar{background:var(--surface);border:1px solid var(--border);z-index:10;border-radius:24px;align-items:center;gap:4px;padding:6px 12px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.canvas-tool-btn{width:32px;height:32px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.canvas-tool-btn:hover{background:var(--surface2);color:var(--text)}.canvas-tool-btn.active{color:var(--cyan);background:#00d4ff1f}.canvas-zoom-label{font-family:var(--font-mono);color:var(--text-dim);text-align:center;min-width:44px;font-size:11px}.upload-zone{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:32px;padding:40px;display:flex}.upload-dropzone{border:2px dashed var(--border2);border-radius:var(--radius-lg);cursor:pointer;background:var(--surface);text-align:center;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:560px;padding:60px 40px;transition:all .2s;display:flex}.upload-dropzone:hover,.upload-dropzone.drag-over{border-color:var(--cyan);background:#00d4ff0a}.upload-icon{width:56px;height:56px;color:var(--cyan-dim)}.upload-title{color:var(--text);font-size:18px;font-weight:600}.upload-sub{color:var(--text-dim);font-size:13px;line-height:1.5}.upload-formats{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.upload-format-tag{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);font-family:var(--font-mono);border-radius:3px;padding:2px 8px;font-size:10px}.upload-progress{background:var(--border);border-radius:2px;width:100%;max-width:560px;height:3px;overflow:hidden}.upload-progress-bar{background:var(--cyan);height:100%;transition:width .3s}.sidebar{width:var(--sidebar-w);background:var(--surface);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex;overflow-x:auto}.sidebar-tab{font-size:11px;font-family:var(--font-mono);color:var(--text-dim);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:5px;padding:10px 12px;transition:all .15s;display:flex}.sidebar-tab:hover{color:var(--text)}.sidebar-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}.sidebar-content{flex:1;padding:16px;overflow-y:auto}.threat-meter{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px}.threat-label{font-family:var(--font-mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:10px}.threat-level{font-size:22px;font-weight:700;font-family:var(--font-mono);margin-bottom:8px}.threat-bar{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.threat-bar-fill{border-radius:2px;height:100%;transition:width .5s}.threat-low{color:#22c55e}.threat-medium{color:#f59e0b}.threat-high{color:#f97316}.threat-critical{color:#ef4444}.analysis-section{margin-bottom:16px}.analysis-section-title{font-family:var(--font-mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:6px;margin-bottom:8px;font-size:10px;display:flex}.analysis-section-title:after{content:"";background:var(--border);flex:1;height:1px}.analysis-text{color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-size:12px;line-height:1.6}.analysis-tags{flex-wrap:wrap;gap:6px;display:flex}.analysis-tag{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);font-size:11px;font-family:var(--font-mono);border-radius:3px;padding:3px 8px}.analysis-tag.cyan{border-color:var(--cyan-dim);color:var(--cyan)}.analysis-tag.amber{border-color:var(--amber-dim);color:var(--amber)}.analysis-tag.red{border-color:var(--red-dim);color:var(--red)}.run-analysis-btn{border:1px solid var(--cyan-dim);border-radius:var(--radius);width:100%;color:var(--cyan);font-family:var(--font-mono);cursor:pointer;background:#00d4ff14;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:12px;transition:all .15s;display:flex}.run-analysis-btn:hover{background:#00d4ff24}.run-analysis-btn:disabled{opacity:.5;cursor:not-allowed}.probe-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:10px;transition:border-color .15s;overflow:hidden}.probe-card:hover{border-color:var(--border2)}.probe-card.selected{border-color:var(--cyan)}.probe-card-header{background:var(--surface3);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 10px;display:flex}.probe-card-num{font-family:var(--font-mono);color:var(--cyan);letter-spacing:1px;font-size:9px;font-weight:700}.probe-card-label{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:11px;font-weight:500;overflow:hidden}.probe-card-actions{gap:4px;display:flex}.probe-card-action{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;transition:all .15s;display:flex}.probe-card-action:hover{background:var(--border);color:var(--text)}.probe-card-action.danger:hover{color:var(--red)}.probe-card-body{gap:10px;padding:10px;display:flex}.probe-card-thumb{object-fit:cover;border:1px solid var(--border);background:var(--bg);border-radius:3px;flex-shrink:0;width:72px;height:72px}.probe-card-info{flex:1;min-width:0}.probe-card-field{color:var(--text-dim);margin-bottom:4px;font-size:11px;line-height:1.4}.probe-card-field strong{color:var(--amber);font-weight:500}.probe-card-note{color:var(--text-dim);border-top:1px solid var(--border);margin-top:6px;padding-top:6px;font-size:11px;font-style:italic}.enhance-compare{border-radius:var(--radius);border:1px solid var(--border);-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.enhance-compare img{width:100%;display:block}.enhance-compare-slider{background:var(--cyan);cursor:ew-resize;z-index:10;width:2px;position:absolute;top:0;bottom:0}.enhance-compare-slider:before{content:"";background:var(--cyan);border:2px solid var(--bg);border-radius:50%;width:24px;height:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.audit-panel{right:0;top:var(--topbar-h);background:var(--surface);border-left:1px solid var(--border);z-index:200;flex-direction:column;width:480px;display:flex;position:fixed;bottom:0;box-shadow:-8px 0 32px #0006}.audit-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:14px 16px;display:flex}.audit-title{font-family:var(--font-mono);color:var(--cyan);text-transform:uppercase;letter-spacing:2px;flex:1;font-size:11px}.audit-close{width:28px;height:28px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;display:flex}.audit-close:hover{background:var(--surface2);color:var(--text)}.audit-list{flex:1;padding:8px;overflow-y:auto}.audit-entry{border-radius:var(--radius);gap:10px;margin-bottom:2px;padding:8px 10px;transition:background .1s;display:flex}.audit-entry:hover{background:var(--surface2)}.audit-entry-time{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;min-width:80px;padding-top:1px;font-size:10px}.audit-entry-body{flex:1;min-width:0}.audit-entry-action{color:var(--text);margin-bottom:2px;font-size:12px;font-weight:500}.audit-entry-detail{color:var(--text-dim);font-size:11px;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.audit-entry-sig{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:9px;overflow:hidden}.modal-overlay{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0009}.modal-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:20px 24px 16px;display:flex}.modal-title{font-family:var(--font-mono);color:var(--cyan);text-transform:uppercase;letter-spacing:2px;flex:1;font-size:13px}.modal-close{width:28px;height:28px;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--surface2);color:var(--text)}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.form-group{margin-bottom:14px}.form-label{font-size:11px;font-family:var(--font-mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;display:block}.form-input,.form-select,.form-textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-family:var(--font-sans);padding:8px 10px;font-size:13px;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--cyan-dim);outline:none}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-select{cursor:pointer}.form-select option{background:var(--surface2)}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.btn{border-radius:var(--radius);font-size:12px;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--cyan);color:var(--bg);border-color:var(--cyan)}.btn-primary:hover{background:#00b8d9;border-color:#00b8d9}.btn-secondary{color:var(--text-dim);border-color:var(--border);background:0 0}.btn-secondary:hover{border-color:var(--border2);color:var(--text)}.btn-danger{color:var(--red);border-color:var(--red-dim);background:0 0}.btn-danger:hover{background:#ef44441a}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:5px 10px;font-size:11px}.btn-full{justify-content:center;width:100%}.case-list{flex-direction:column;gap:6px;display:flex}.case-list-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:12px;padding:10px 12px;transition:all .15s;display:flex}.case-list-item:hover{border-color:var(--cyan-dim)}.case-list-num{font-family:var(--font-mono);color:var(--cyan);min-width:100px;font-size:10px}.case-list-title{color:var(--text);flex:1;font-size:13px;font-weight:500}.case-list-meta{color:var(--text-dim);font-size:11px}.case-status-badge{font-size:9px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1px;border-radius:3px;padding:2px 6px}.case-status-badge.active{color:var(--green);background:#22c55e26;border:1px solid #22c55e4d}.case-status-badge.closed{color:var(--text-muted);border:1px solid var(--border);background:#6b728026}.exif-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.exif-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px}.exif-key{font-size:10px;font-family:var(--font-mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.exif-val{color:var(--text);font-size:12px;font-family:var(--font-mono);word-break:break-all}.spinner{border:2px solid var(--border);border-top-color:var(--cyan);border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0a0d12b3;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.loading-text{font-family:var(--font-mono);color:var(--cyan);letter-spacing:2px;text-transform:uppercase;font-size:12px}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px 20px;display:flex}.empty-state-icon{color:var(--text-muted);opacity:.4}.empty-state-text{font-size:12px;line-height:1.5}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{font-family:var(--font-mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:1.5px;font-size:10px}.video-frames{grid-template-columns:repeat(3,1fr);gap:6px;margin-top:12px;display:grid}.video-frame-thumb{aspect-ratio:16/9;object-fit:cover;border:1px solid var(--border);cursor:pointer;border-radius:3px;width:100%;transition:border-color .15s}.video-frame-thumb:hover{border-color:var(--cyan)}.toast-container{z-index:999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{background:var(--surface3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);align-items:center;gap:8px;padding:10px 16px;font-size:12px;animation:.2s toast-in;display:flex;box-shadow:0 8px 24px #0006}.toast.success{border-color:var(--green-dim)}.toast.error{border-color:var(--red-dim)}.toast.info{border-color:var(--cyan-dim)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sketch-textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-family:var(--font-sans);resize:vertical;min-height:100px;padding:10px 12px;font-size:12px;line-height:1.5;transition:border-color .15s}.sketch-textarea:focus{border-color:var(--cyan-dim);outline:none}.sketch-style-select{gap:6px;margin-bottom:12px;display:flex}.sketch-style-btn{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-dim);cursor:pointer;text-align:center;flex:1;padding:6px;font-size:11px;transition:all .15s}.sketch-style-btn.active{border-color:var(--cyan);color:var(--cyan);background:#00d4ff0f}.sketch-result{border:1px solid var(--border);border-radius:var(--radius);margin-top:12px;overflow:hidden}.sketch-result img{width:100%;display:block}.timeline-list{flex-direction:column;gap:8px;display:flex}.timeline-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);cursor:grab;align-items:flex-start;gap:10px;padding:10px 12px;transition:border-color .15s;display:flex}.timeline-card:hover{border-color:var(--border2)}.timeline-card-thumb{object-fit:cover;border:1px solid var(--border);border-radius:3px;flex-shrink:0;width:48px;height:48px}.timeline-card-body{flex:1;min-width:0}.timeline-card-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:12px;font-weight:500;overflow:hidden}.timeline-card-meta{color:var(--text-dim);font-size:10px;font-family:var(--font-mono)}.timeline-card-remove{width:20px;height:20px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.timeline-card-remove:hover{color:var(--red);background:#ef44441a}.calibration-status{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:10px;margin-bottom:16px;padding:12px;display:flex}.calibration-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.calibration-dot.active{background:var(--green);box-shadow:0 0 6px var(--green)}.calibration-dot.inactive{background:var(--text-muted)}.calibration-info{flex:1}.calibration-label{color:var(--text-dim);font-size:11px}.calibration-value{font-family:var(--font-mono);color:var(--text);font-size:13px;font-weight:600}
