.header{height:60px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);flex-shrink:0}.mode-switch{display:flex;background:var(--bg-tertiary);border-radius:20px;padding:4px;gap:4px}.mode-btn{padding:6px 16px;border-radius:16px;color:var(--text-secondary);font-size:14px;font-weight:500;transition:all .2s ease}.mode-btn.active{background-color:var(--text-primary);color:var(--bg-primary);box-shadow:0 2px 4px #0003}.mode-btn:hover:not(.active){color:var(--text-primary)}.stats-bar{display:flex;gap:var(--spacing-xl);font-size:14px;color:var(--text-secondary)}.stat-item{display:flex;gap:var(--spacing-sm)}.stat-value{color:var(--text-primary);font-weight:600}.summary-btn{background-color:var(--bg-tertiary);color:var(--text-primary);padding:8px 16px;border-radius:var(--border-radius);font-size:14px;font-weight:500;transition:background-color .2s;border:1px solid transparent}.summary-btn:hover{background-color:var(--border-color);border-color:var(--text-secondary)}.photo-stream{height:140px;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;align-items:center;padding:0 var(--spacing-md);overflow-x:auto;gap:var(--spacing-md);flex-shrink:0;white-space:nowrap}.stream-item{position:relative;width:100px;height:100px;border-radius:var(--border-radius);overflow:hidden;border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:all .2s;background:var(--bg-tertiary)}.stream-item:hover{transform:translateY(-2px)}.stream-item.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f64d}.stream-img-container{width:100%;height:100%;border-radius:inherit;overflow:hidden;position:relative;background:var(--bg-tertiary)}.stream-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text-secondary);background:#222}.stream-img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.stream-status{position:absolute;top:4px;left:4px;display:flex;align-items:center;gap:4px;background:#0009;padding:2px 6px;border-radius:10px;font-size:10px;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.pass{background-color:var(--success);box-shadow:0 0 4px var(--success)}.status-dot.fail{background-color:var(--error);box-shadow:0 0 4px var(--error)}.add-photo-btn{width:100px;height:100px;border:2px dashed var(--border-color);border-radius:var(--border-radius);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);gap:4px;cursor:pointer;transition:border-color .2s}.add-photo-btn:hover{border-color:var(--text-primary);color:var(--text-primary)}.single-mode{display:flex;height:100%;overflow:hidden;background-color:var(--bg-primary)}.preview-area{flex:1;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border-right:1px solid var(--border-color)}.main-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000004d}.main-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0a0a0a}.placeholder-content{text-align:center;display:flex;flex-direction:column;gap:12px}.placeholder-type{font-size:3rem;font-weight:900;color:var(--accent);opacity:.3}.placeholder-text{color:var(--text-secondary);font-size:.9rem}.info-panel{width:350px;background-color:var(--bg-secondary);border-left:1px solid var(--border-color);padding:var(--spacing-lg);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.info-section{margin-bottom:var(--spacing-xl)}.info-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-primary)}.meta-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-xs)}.meta-item{display:flex;justify-content:space-between;font-size:.875rem;padding:4px 0;border-bottom:1px solid var(--border-color)}.meta-label{color:var(--text-secondary)}.meta-value{color:var(--text-primary);text-align:right;word-break:break-all;margin-left:8px}.action-area{margin-top:auto;display:flex;flex-direction:column;gap:var(--spacing-md)}.identify-btn{background-color:var(--text-secondary);background:linear-gradient(135deg,#4f46e5,#3b82f6);color:#fff;padding:12px;border-radius:var(--border-radius);font-weight:600;font-size:1rem;width:100%;text-transform:uppercase;letter-spacing:.5px;transition:opacity .2s}.identify-btn:hover{opacity:.9}.result-box{background-color:var(--bg-tertiary);border-radius:var(--border-radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.result-percentage{font-size:1.5rem;font-weight:700;margin-bottom:4px}.result-percentage.pass{color:var(--success)}.result-percentage.fail{color:var(--error)}.result-time{font-size:.75rem;color:var(--text-secondary)}.export-btn{background-color:var(--bg-tertiary);color:var(--text-primary);padding:8px;border-radius:var(--border-radius);font-size:.875rem;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border-color)}.export-btn:hover{background-color:var(--border-color)}.result-reasons{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem;color:var(--text-secondary)}.reason-item{color:#fbbf24;margin-bottom:4px}.modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:var(--bg-secondary);border-radius:var(--border-radius-lg);width:800px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;border:1px solid var(--border-color);box-shadow:0 20px 25px -5px #00000080;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.close-btn{color:var(--text-secondary);padding:4px;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.stat-card{background-color:var(--bg-tertiary);padding:var(--spacing-md);border-radius:var(--border-radius);text-align:center}.stat-card-label{color:var(--text-secondary);font-size:.875rem;margin-bottom:4px}.stat-card-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.chart-container{height:300px;width:100%;position:relative}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-md)}.pdf-btn{background-color:var(--accent-color);color:#fff;padding:8px 16px;border-radius:var(--border-radius);display:flex;align-items:center;gap:8px;font-weight:500;transition:background-color .2s}.pdf-btn:hover{background-color:var(--accent-hover)}.batch-mode{display:flex;flex-direction:column;height:100%;background-color:var(--bg-primary);padding:var(--spacing-lg);overflow:hidden}.batch-toolbar{display:flex;justify-content:space-between;margin-bottom:var(--spacing-md);flex-shrink:0}.batch-actions{display:flex;gap:var(--spacing-md)}.batch-btn{padding:8px 16px;background-color:var(--bg-tertiary);color:var(--text-primary);border-radius:var(--border-radius);font-size:.875rem;transition:all .2s}.batch-btn:hover{background-color:var(--border-color)}.batch-btn.primary{background-color:var(--accent-color);color:#fff}.batch-btn.primary:hover{background-color:var(--accent-hover)}.batch-btn:disabled{opacity:.5;cursor:not-allowed}.batch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md);overflow-y:auto;padding-bottom:var(--spacing-xl)}.batch-item{position:relative;aspect-ratio:1;background-color:var(--bg-tertiary);border-radius:var(--border-radius);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s}.batch-item:hover{transform:translateY(-2px)}.batch-item.selected{border-color:var(--accent-color);box-shadow:0 0 0 4px #3b82f633}.batch-img-container{width:100%;height:100%;position:relative}.batch-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#1a1a1a;color:var(--text-secondary);font-size:14px;font-weight:700}.batch-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.batch-badge{position:absolute;top:8px;right:8px;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:700;color:#fff;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.batch-badge.pass{background-color:var(--success)}.batch-badge.fail{background-color:var(--error)}.context-menu{position:fixed;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:4px;min-width:150px;box-shadow:0 4px 12px #00000080;z-index:2000;color:var(--text-primary)}.context-item{padding:8px 12px;cursor:pointer;border-radius:4px;font-size:.875rem;transition:background-color .2s;display:flex;align-items:center;gap:8px}.context-item:hover{background-color:var(--border-color)}.context-item.danger{color:var(--error)}.context-item.danger:hover{background-color:var(--error-bg)}:root{--bg-primary: #1a1a1a;--bg-secondary: #252525;--bg-tertiary: #303030;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #666666;--accent-color: #3b82f6;--accent-hover: #2563eb;--success: #22c55e;--success-bg: rgba(34, 197, 94, .1);--error: #ef4444;--error-bg: rgba(239, 68, 68, .1);--border-color: #404040;--border-radius: 8px;--border-radius-lg: 12px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji"}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden;height:100vh;width:100vw}#root{height:100%;width:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-color)}button{font-family:inherit;cursor:pointer;border:none;background:none}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.hidden{display:none}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.font-bold{font-weight:700}.text-secondary{color:var(--text-secondary)}.bg-secondary{background-color:var(--bg-secondary)}.p-4{padding:16px}.h-full{height:100%}.w-full{width:100%}
