*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--navy: #1b3a5c;--blue: #2d7dd2;--teal: #0d9e93;--bg: #f0f4f8;--surface:#ffffff;--border: #dde3ea;--text: #1e2d3d;--muted: #6b7c93;--green: #1db96a;--orange: #f5a623;--red: #e5533d;--sidebar-w: 224px;--header-h: 57px}[data-theme=dark]{--navy: #0f2233;--blue: #4d9fec;--teal: #14b8aa;--bg: #0d1b26;--surface:#152230;--border: #243447;--text: #d6e6f2;--muted: #7a9ab4;--green: #25d47a;--orange: #ffb84d;--red: #f06454}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}.app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--navy);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:10}.sidebar-logo{padding:18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.1);font-size:18px;font-weight:700;letter-spacing:.3px;color:#fff;text-decoration:none}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;color:#ffffffb8;text-decoration:none;font-size:13.5px;gap:8px;transition:background .15s,color .15s;cursor:pointer}.nav-item:hover{background:#ffffff17;color:#fff}.nav-item.active{background:#ffffff1f;color:#fff;border-left:3px solid var(--teal);padding-left:15px}.sidebar-footer{border-top:1px solid rgba(255,255,255,.1);padding:10px 0}.badge{background:var(--teal);color:#fff;border-radius:10px;font-size:11px;padding:1px 7px;font-weight:600;white-space:nowrap}.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-width:0}.page-header{background:var(--surface);border-bottom:1px solid var(--border);padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:5}.page-title{font-size:19px;font-weight:600}.page-subtitle{font-size:12.5px;color:var(--muted);margin-top:2px}.page-header-actions{display:flex;align-items:center;gap:8px}.page-body{padding:24px 28px;flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px}.card+.card{margin-top:16px}.card-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-size:14px;font-weight:600;padding:16px 20px 4px}.card-body{padding:16px 20px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;border:1px solid transparent;font-size:13.5px;font-weight:500;cursor:pointer;text-decoration:none;transition:opacity .15s,filter .15s;white-space:nowrap;font-family:inherit}.btn:hover{filter:brightness(.92)}.btn-primary{background:var(--blue);color:#fff}.btn-success{background:var(--green);color:#fff}.btn-teal{background:var(--teal);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn-sm{padding:5px 11px;font-size:12.5px}.btn-lg{padding:11px 22px;font-size:15px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}label,.form-label{display:block;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}input[type=text],input[type=email],input[type=password],input[type=datetime-local],input[type=number],select,textarea,.form-control{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;color:var(--text);background:var(--surface);transition:border-color .15s;outline:none;font-family:inherit;box-sizing:border-box}input:focus,select:focus,textarea:focus,.form-control:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2d7dd21f}textarea{resize:vertical;min-height:80px}.form-hint,.form-help{font-size:12px;color:var(--muted);margin-top:4px}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.table{width:100%;border-collapse:collapse}.table thead th{text-align:left;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:10px 16px;border-bottom:1px solid var(--border)}.table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.table tbody tr:hover{background:#f6f9fc}.table tbody tr:last-child{border-bottom:none}.table td{padding:11px 16px;font-size:13.5px}.status{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:12px;font-size:11.5px;font-weight:600;white-space:nowrap}.status:before{content:"●";font-size:8px}.s-uploaded{background:#e8f0fe;color:#3b5bdb}.s-processing{background:#fff3e0;color:#d84315}.s-ready,.s-validated{background:#e6f9f0;color:#1a7a4a}.s-error{background:#fdecea;color:#c62828}.s-temporary{background:#f3e8ff;color:#6d28d9}.s-confirmed{background:#e6f9f0;color:#1a7a4a}.s-draft{background:#f0f4f8;color:var(--muted)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px;padding:0 20px 20px}.photo-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--surface);cursor:pointer}.photo-thumb{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:28px;background:#c8d8e8;position:relative;overflow:hidden}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-thumb[data-clickable]{cursor:zoom-in}.photo-thumb-meta{padding:6px 8px}.dropzone{border:2px dashed var(--border);border-radius:8px;padding:40px 20px;text-align:center;color:var(--muted);cursor:pointer;transition:border-color .15s,background .15s;margin:0 20px 20px}.dropzone:hover{border-color:var(--blue);background:#f0f7ff}.validation-layout{display:grid;grid-template-columns:1fr 400px;gap:20px;align-items:start}.validation-photo-panel{position:sticky;top:var(--header-h)}.photo-preview-box{width:100%;aspect-ratio:4/3;background:#c8d8e8;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:60px;border:1px solid var(--border);overflow:hidden}.photo-preview-box[data-clickable]{cursor:zoom-in}.exif-table{padding:4px 20px 16px}.exif-row{display:grid;grid-template-columns:90px 1fr;gap:8px;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px}.exif-row:last-child{border-bottom:none}.exif-key{font-weight:600;color:var(--muted);font-size:12px;text-transform:uppercase}.candidates-list{padding:4px 20px 16px;display:flex;flex-direction:column;gap:8px}.candidate-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s;background:var(--surface)}.candidate-item:hover{border-color:var(--blue)}.candidate-item.selected{border-color:var(--teal);background:#f0fdfc}.candidate-rank{width:24px;height:24px;border-radius:50%;background:var(--blue);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.candidate-rank.rank-1{background:var(--teal)}.candidate-info{flex:1;min-width:0}.candidate-name{font-weight:600;font-size:13.5px}.score-bar{height:4px;background:#e0e8ef;border-radius:2px;margin-top:5px}.score-fill{height:100%;background:var(--teal);border-radius:2px}.score-pct{font-size:15px;font-weight:700;color:var(--teal);flex-shrink:0}.action-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:4px 20px 16px}.action-buttons .btn{justify-content:center}.modal-overlay{position:fixed;inset:0;background:#00000073;z-index:100;display:flex;align-items:center;justify-content:center}.modal{background:var(--surface);border-radius:10px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px #00000038}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:16px;font-weight:600}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--muted);line-height:1;padding:0}.modal-body{padding:20px 24px}.shark-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(172px,1fr));gap:16px}.shark-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;text-decoration:none;color:var(--text);transition:box-shadow .15s;cursor:pointer;display:block}.shark-card:hover{box-shadow:0 3px 14px #0000001c}.shark-card-photo{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:34px;background:#c8d8e8}.shark-card-body{padding:12px}.shark-name{font-weight:600;font-size:14px;margin-bottom:4px}.shark-picker-list{max-height:320px;overflow-y:auto;border:1px solid var(--border);border-radius:6px}.shark-picker-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.shark-picker-item:last-child{border-bottom:none}.shark-picker-item:hover{background:#f6f9fc}.shark-picker-item.selected{background:#f0fdfc}.profile-header{display:flex;gap:24px;align-items:flex-start;padding:20px}.profile-avatar{width:120px;height:90px;border-radius:8px;background:#c8d8e8;display:flex;align-items:center;justify-content:center;font-size:42px;flex-shrink:0;border:1px solid var(--border)}.profile-photos-strip{display:flex;gap:8px;flex-wrap:wrap;padding:0 20px 20px}.strip-photo{position:relative;width:80px;height:60px;border-radius:6px;border:2px solid var(--border);overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;background:#c8d8e8}.strip-photo.primary{border-color:var(--teal)}.strip-photo img{width:100%;height:100%;object-fit:cover}.strip-photo[data-clickable]{cursor:zoom-in}.strip-set-main{display:none;position:absolute;bottom:2px;right:2px;background:#000000a6;color:gold;border:none;border-radius:3px;padding:1px 4px;font-size:11px;line-height:1.4;cursor:pointer;z-index:1}.strip-photo:hover .strip-set-main{display:block}.annot-steps{display:flex;gap:0;margin-bottom:20px;border-radius:6px;overflow:hidden;border:1px solid var(--border)}.annot-step{flex:1;padding:8px 0;text-align:center;font-size:12px;font-weight:500;background:var(--bg);color:var(--muted);border-right:1px solid var(--border)}.annot-step:last-child{border-right:none}.annot-step.active{background:var(--teal);color:#fff}.annot-step.done{background:#0d9e931f;color:var(--teal)}.annot-photo-wrap{position:relative;display:block;-webkit-user-select:none;user-select:none;line-height:0}.annot-photo-wrap img{width:100%;display:block}.annot-svg{position:absolute;inset:0;width:100%;height:100%;cursor:crosshair;touch-action:none}.annot-crop-wrap{position:relative;width:100%;overflow:hidden;line-height:0}.annot-crop-wrap canvas{display:block;width:100%;height:auto}.annot-instructions{font-size:13px;color:var(--muted);margin-bottom:14px;line-height:1.5}.orientation-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.orientation-btn{padding:24px 8px;font-size:15px;font-weight:500;border-radius:8px;border:2px solid var(--border);background:var(--surface);cursor:pointer;text-align:center;transition:border-color .15s,background .15s}.orientation-btn:hover{border-color:var(--teal)}.orientation-btn.selected{border-color:var(--teal);background:#0d9e9314;color:var(--teal)}.auto-annot-badge{font-size:11px;font-weight:600;background:#0d9e931f;color:var(--teal);padding:2px 8px;border-radius:12px;white-space:nowrap}.video-list{display:flex;flex-direction:column;gap:0}.video-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border)}.video-item:last-child{border-bottom:none}.video-item-icon{font-size:22px;flex-shrink:0}.video-item-info{flex:1;min-width:0}.video-item-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.video-item-meta{font-size:12px;color:var(--muted);margin-top:2px}.video-item-status{display:flex;align-items:center;flex-shrink:0}.session-shark-row{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--border);transition:background .15s;border-radius:6px}.session-shark-row:last-child{border-bottom:none}.session-shark-row:hover{background:var(--bg)}.session-shark-thumb{width:52px;height:52px;border-radius:8px;background:var(--border);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:24px}.session-shark-thumb img{width:100%;height:100%;object-fit:cover}.lightbox{position:fixed;inset:0;background:#000000d9;z-index:200;display:flex;align-items:center;justify-content:center}.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;box-shadow:0 8px 60px #0009}.lightbox-close{position:fixed;top:20px;right:24px;background:none;border:none;color:#fff;font-size:32px;line-height:1;cursor:pointer;opacity:.8}.lightbox-close:hover{opacity:1}.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:64px;line-height:1;cursor:pointer;opacity:.6;padding:0 20px;-webkit-user-select:none;user-select:none}.lightbox-nav:hover{opacity:1}.lightbox-prev{left:12px}.lightbox-next{right:12px}.timeline{list-style:none;padding:4px 20px 20px}.tl-item{display:flex;gap:14px;padding-bottom:20px;position:relative}.tl-item:before{content:"";position:absolute;left:15px;top:32px;bottom:0;width:2px;background:var(--border)}.tl-item:last-child:before{display:none}.tl-dot{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.tl-content{flex:1;padding-top:4px}.tl-meta{font-size:12px;color:var(--muted);margin-bottom:4px}.stat-row{display:flex;gap:24px;flex-wrap:wrap}.stat{display:flex;flex-direction:column;gap:2px}.stat-val{font-size:22px;font-weight:700;color:var(--navy)}.stat-lbl{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.session-list{display:flex;flex-direction:column;gap:10px}.session-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px 20px;display:flex;align-items:center;gap:16px;text-decoration:none;color:var(--text);transition:box-shadow .15s}.session-item:hover{box-shadow:0 2px 12px #00000017}.session-date-block{background:var(--navy);color:#fff;border-radius:8px;padding:10px 14px;text-align:center;flex-shrink:0;min-width:60px}.session-date-block .day{font-size:22px;font-weight:700;line-height:1}.session-date-block .month{font-size:11px;text-transform:uppercase;opacity:.8}.session-info{flex:1}.session-title{font-weight:600;font-size:14.5px}.session-meta{font-size:12.5px;color:var(--muted);margin-top:3px}.session-stats{display:flex;gap:10px;margin-top:5px}.session-stat{font-size:12px;color:var(--muted)}.session-stat-queue{color:var(--blue)}.session-thumbs{display:flex;gap:4px;margin-top:8px}.session-thumb{width:36px;height:36px;object-fit:cover;border-radius:4px;border:1px solid var(--border)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1b3a5c,#0d6e8a)}.login-card{background:var(--surface);border-radius:12px;padding:40px;width:380px;box-shadow:0 16px 48px #0000004d}.login-logo{text-align:center;margin-bottom:28px}.login-logo-icon{font-size:48px;display:block;margin-bottom:8px}.login-logo h1{font-size:22px;font-weight:700;color:var(--navy)}.login-logo p{font-size:13px;color:var(--muted);margin-top:4px}.alert-error{background:#fdecea;color:#c62828;border:1px solid #f5c6c0;border-radius:6px;padding:10px 14px;font-size:13.5px;margin-bottom:16px}.confirmed-banner{background:#e6f9f0;color:#1a7a4a;border:1px solid #b2dfce;border-radius:6px;padding:12px 16px;font-weight:600}.inline-form{background:#f6f9fc;border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:16px}.breadcrumb{font-size:12.5px;color:var(--muted);margin-bottom:4px}.breadcrumb a{color:var(--blue);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.link{color:var(--blue);text-decoration:none;font-weight:500}.link:hover{text-decoration:underline}.muted{color:var(--muted);font-size:13px}.empty-state{text-align:center;padding:48px 20px;color:var(--muted);font-size:14px}.mt4{margin-top:4px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt24{margin-top:24px}.mb4{margin-bottom:4px}.mb8{margin-bottom:8px}.mb16{margin-bottom:16px}.mb24{margin-bottom:24px}.ml8{margin-left:8px}.flex-gap8{display:flex;gap:8px;align-items:center}.flex-gap12{display:flex;gap:12px;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}[data-theme=dark] .table tbody tr:hover,[data-theme=dark] .shark-picker-item:hover{background:#1b2e41}[data-theme=dark] .photo-thumb,[data-theme=dark] .photo-preview-box,[data-theme=dark] .shark-card-photo,[data-theme=dark] .profile-avatar,[data-theme=dark] .strip-photo{background:#1b3048}[data-theme=dark] .dropzone:hover{background:#4d9fec14}[data-theme=dark] .score-bar{background:var(--border)}[data-theme=dark] .inline-form{background:#ffffff0a}[data-theme=dark] .candidate-item.selected,[data-theme=dark] .shark-picker-item.selected{background:#14b8aa1a}[data-theme=dark] .orientation-btn.selected{background:#14b8aa14}[data-theme=dark] .s-uploaded{background:#4d87ff2e;color:#8cb5ff}[data-theme=dark] .s-processing{background:#ff8a462e;color:#ffb07a}[data-theme=dark] .s-ready,[data-theme=dark] .s-validated,[data-theme=dark] .s-confirmed{background:#25d47a26;color:#4dcc91}[data-theme=dark] .s-error{background:#f064542e;color:#ff8f80}[data-theme=dark] .s-temporary{background:#a78bfa2e;color:#c4a8ff}[data-theme=dark] .s-draft{background:var(--border)}[data-theme=dark] .alert-error{background:#f0645426;color:#ff8f80;border-color:#f064544d}[data-theme=dark] .confirmed-banner{background:#25d47a26;color:#4dcc91;border-color:#25d47a4d}.theme-switch-wrap{display:flex;align-items:center;justify-content:space-between;padding:8px 18px 0;font-size:13px;color:#ffffffa6}.theme-switch{position:relative;width:40px;height:22px;flex-shrink:0}.theme-switch input{opacity:0;width:0;height:0;position:absolute}.theme-switch-track{position:absolute;inset:0;border-radius:11px;background:#ffffff38;cursor:pointer;transition:background .2s}.theme-switch input:checked+.theme-switch-track{background:var(--teal)}.theme-switch-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;pointer-events:none}.theme-switch input:checked+.theme-switch-track .theme-switch-thumb{transform:translate(18px)}
