*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f0f2f5;--color-surface: #ffffff;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-success: #16a34a;--color-warning: #ca8a04;--color-error: #dc2626;--color-text: #1e293b;--color-text-muted: #64748b;--color-border: #e2e8f0;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:24px}header{text-align:center;margin-bottom:24px}header h1{font-size:2rem;font-weight:700;color:var(--color-text);margin-bottom:16px}.tab-nav{display:flex;justify-content:center;gap:4px;border-bottom:2px solid var(--color-border);padding-bottom:0}.tab-btn{padding:10px 24px;border:none;border-bottom:3px solid transparent;background:none;font-size:.95rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:color .2s,border-color .2s;margin-bottom:-2px}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.tab-panel{display:none}.tab-panel.active{display:block}.tab-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);color:var(--color-text-muted);text-align:center}.tab-placeholder .placeholder-icon{font-size:4rem;margin-bottom:16px}.tab-placeholder p{font-size:1.1rem}.subtitle{color:var(--color-text-muted);margin-top:8px;font-size:1rem}.subtitle kbd{display:inline-block;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;padding:2px 8px;font-family:monospace;font-size:.9rem;box-shadow:0 1px #0003}.main-grid{display:grid;grid-template-columns:1fr 400px;gap:24px;align-items:start}.camera-section{position:relative}.camera-select{width:100%;max-width:320px;padding:8px 12px;margin-bottom:10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.85rem;color:var(--color-text);background:var(--color-surface);appearance:auto;cursor:pointer;transition:border-color .2s,box-shadow .2s}.camera-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.camera-wrapper{position:relative;background:#000;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16 / 9;min-height:360px}.camera-wrapper video{width:100%;height:100%;object-fit:cover}.camera-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1e293b;color:#94a3b8;text-align:center}.placeholder-icon{font-size:3rem;margin-bottom:12px}.error-detail{font-size:.8rem;margin-top:8px;opacity:.7;max-width:300px}.capture-flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;transition:opacity .1s ease-out;border-radius:var(--radius)}.capture-flash.active{opacity:.6}.capture-hint{text-align:center;margin-top:10px;font-size:.85rem;color:var(--color-text-muted)}.capture-hint kbd{display:inline-block;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;padding:2px 10px;font-family:monospace;font-size:.9rem;font-weight:600;box-shadow:0 1px #0003}.card{background:var(--color-surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:16px}.card h2{font-size:1.1rem;font-weight:600;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--color-border)}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--color-text-muted);margin-bottom:4px}.form-group input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.95rem;color:var(--color-text);background:#f8fafc;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26;background:var(--color-surface)}.form-group input::placeholder{color:#94a3b8}.capture-list{max-height:300px;overflow-y:auto}.empty-state{color:var(--color-text-muted);text-align:center;padding:24px 0;font-size:.9rem}.capture-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);margin-bottom:6px;background:#f8fafc;font-size:.85rem;transition:background .2s}.capture-item .capture-thumb{width:40px;height:40px;border-radius:4px;object-fit:cover;flex-shrink:0;background:#e2e8f0}.capture-item .capture-info{flex:1;min-width:0}.capture-item .capture-id{font-weight:600;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.capture-item .capture-time{color:var(--color-text-muted);font-size:.75rem}.capture-item .capture-status{flex-shrink:0;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:20px}.status-pending{background:#fef3c7;color:#92400e}.status-uploading{background:#dbeafe;color:#1e40af}.status-sent{background:#dcfce7;color:#166534}.status-failed{background:#fee2e2;color:#991b1b}.capture-actions{display:flex;gap:4px;flex-shrink:0}.btn-action{width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .1s;line-height:1}.btn-action:active{transform:scale(.9)}.btn-retry{background:#dbeafe;color:#1e40af}.btn-retry:hover{background:#bfdbfe}.btn-delete{background:#fee2e2;color:#991b1b}.btn-delete:hover{background:#fecaca}footer{margin-top:24px;padding-top:16px;border-top:1px solid var(--color-border)}.status-bar{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--color-text-muted)}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.status-dot.online{background:var(--color-success);box-shadow:0 0 6px #16a34a66}.status-dot.offline{background:var(--color-error)}.separator{color:var(--color-border)}.lista-main{display:flex;flex-direction:column;gap:16px}.image-list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--color-surface);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow);flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:4px}.filter-btn{padding:6px 14px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.82rem;font-weight:500;border-radius:var(--radius);cursor:pointer;transition:background .2s,border-color .2s}.filter-btn:hover{background:#f1f5f9}.filter-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.filter-custom{position:relative;display:inline-flex;align-items:center}.custom-period{display:flex;align-items:center;gap:4px;margin-left:6px}.period-select{padding:5px 8px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.8rem;background:var(--color-surface);color:var(--color-text)}.date-nav{display:flex;align-items:center;gap:8px}.btn-icon{width:32px;height:32px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius);cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-icon:hover{background:#f1f5f9}.date-range-label{font-size:.85rem;font-weight:500;color:var(--color-text);min-width:180px;text-align:center}.page-size-control{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--color-text-muted)}.page-size-select{padding:5px 8px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.82rem;background:var(--color-surface);color:var(--color-text)}.image-table-wrapper{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.image-table{width:100%;border-collapse:collapse;font-size:.85rem}.image-table thead{background:#f8fafc;border-bottom:2px solid var(--color-border)}.image-table th{padding:10px 12px;text-align:left;font-weight:600;color:var(--color-text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.image-table th:last-child{text-align:center;width:200px}.image-table td{padding:10px 12px;border-bottom:1px solid var(--color-border);vertical-align:middle}.image-table tbody tr:hover{background:#f8fafc}.image-table .empty-row td{text-align:center;color:var(--color-text-muted);padding:32px 12px}.table-actions{display:flex;gap:6px;justify-content:center}.btn-table-action{padding:4px 10px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.78rem;font-weight:500;border-radius:var(--radius);cursor:pointer;transition:background .15s,color .15s,border-color .15s;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.btn-table-action:hover{background:#f1f5f9}.btn-table-action.btn-delete{color:var(--color-error);border-color:var(--color-error)}.btn-table-action.btn-delete:hover{background:#fee2e2}.btn-table-action:disabled{opacity:.4;cursor:not-allowed}.btn-table-action:disabled:hover{background:var(--color-surface)}.pagination-bar{display:flex;align-items:center;justify-content:center;gap:16px;padding:8px 0}.page-info{font-size:.85rem;color:var(--color-text-muted)}.input-readonly{background:#f1f5f9!important;color:var(--color-text-muted)!important;cursor:default}.edit-divider{border:none;border-top:1px dashed var(--color-border);margin:20px 0 16px}.btn{padding:8px 18px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s}.btn-small{padding:5px 12px;font-size:.8rem}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text)}.btn-secondary:hover{background:#f1f5f9}.btn-danger{background:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover{background:#b91c1c}.btn:disabled{opacity:.4;cursor:not-allowed}.edit-card{margin-bottom:24px}.form-actions{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:90vw;max-height:85vh;overflow:auto;position:relative}.modal-close{position:absolute;top:8px;right:12px;background:#00000080;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s}.modal-close:hover{background:#000000b3}.modal-content img{display:block;max-width:90vw;max-height:85vh;object-fit:contain}.confirm-modal{background:var(--color-surface);border-radius:var(--radius);padding:32px;max-width:420px;width:100%;text-align:center}.confirm-modal h3{margin-bottom:16px;font-size:1.1rem}.confirm-modal p{color:var(--color-text-muted);margin-bottom:24px;font-size:.9rem;line-height:1.5}.confirm-actions{display:flex;gap:8px;justify-content:center}@media(max-width:768px){.main-grid{grid-template-columns:1fr}header h1{font-size:1.5rem}}.edit-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.edit-modal-container{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:95vw;max-width:1100px;max-height:95vh;display:flex;flex-direction:column;overflow:hidden}.edit-modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.edit-modal-header h3{font-size:1.1rem;font-weight:600;margin:0}.edit-modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;padding:0;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s,color .15s}.edit-modal-close:hover{background:var(--color-border);color:var(--color-text)}.edit-modal-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.edit-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--color-border);flex-shrink:0}.edit-canvas-container{background:#e5e7eb;border-radius:var(--radius);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;min-height:300px;max-height:55vh;overflow:hidden;position:relative}.edit-canvas-container canvas{display:block;max-width:100%;max-height:55vh}.edit-toolbar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0}.edit-toolbar .tool-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;font-size:.8rem;font-weight:500;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all .15s}.edit-toolbar .tool-btn:hover,.edit-toolbar .tool-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.edit-toolbar .tool-btn svg{width:14px;height:14px;flex-shrink:0}.edit-adjust-panel{display:flex;flex-direction:column;gap:10px;padding:12px 16px;background:#f8fafc;border-radius:var(--radius);border:1px solid var(--color-border)}.adjust-group{display:flex;flex-direction:column;gap:4px}.adjust-group label{display:flex;justify-content:space-between;font-size:.8rem;font-weight:500;color:var(--color-text-muted)}.adjust-group label span{color:var(--color-text);font-variant-numeric:tabular-nums}.adjust-group input[type=range]{width:100%;accent-color:var(--color-primary);height:6px}.crop-hint{position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:#000000bf;color:#fff;font-size:.78rem;padding:6px 14px;border-radius:20px;white-space:nowrap;z-index:10;pointer-events:none}.edit-progress-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);z-index:20}.edit-progress-content{background:var(--color-surface);border-radius:var(--radius);padding:32px 48px;text-align:center;box-shadow:var(--shadow-lg)}.edit-progress-content p{margin-top:16px;color:var(--color-text-muted);font-size:.9rem}.edit-progress-content .spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}
