*{box-sizing:border-box;margin:0;padding:0}body{color:#e0e0e0;background:#0a0a0a;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.nav{z-index:100;background:#111;border-bottom:1px solid #222;align-items:center;gap:32px;height:56px;padding:0 20px;display:flex;position:sticky;top:0}.nav-brand{color:#4fc3f7;letter-spacing:1px;font-size:18px;font-weight:700}.nav-links{gap:8px;display:flex}.nav-links a{color:#888;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s}.nav-links a:hover{color:#e0e0e0;background:#1a1a1a}.nav-links a.active{color:#4fc3f7;background:#1a2a35}.main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:20px}.btn{cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.btn-primary{color:#000;background:#4fc3f7}.btn-primary:hover{background:#29b6f6}.btn-primary:disabled{color:#666;cursor:not-allowed;background:#333}.btn-danger{color:#fff;background:#ef5350}.btn-danger:hover{background:#e53935}.btn-secondary{color:#e0e0e0;background:#333}.btn-secondary:hover{background:#444}.btn-sm{padding:6px 12px;font-size:12px}.card{background:#141414;border:1px solid #222;border-radius:12px;padding:20px}input,select,textarea{color:#e0e0e0;background:#1a1a1a;border:1px solid #333;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border .2s}input:focus,select:focus,textarea:focus{border-color:#4fc3f7}label{color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.grade{border-radius:6px;padding:4px 10px;font-size:13px;font-weight:700;display:inline-block}.grade-A{color:#a5d6a7;background:#1b5e20}.grade-Bplus{color:#c8e6c9;background:#2e7d32}.grade-B{color:#fff9c4;background:#f57f17}.grade-Bminus{color:#ffe0b2;background:#e65100}.grade-Cplus{color:#ffccbc;background:#bf360c}.grade-C{color:#ffcdd2;background:#b71c1c}.grade-D{color:#e1bee7;background:#4a148c}.grade-null{color:#888;background:#333}.status{text-transform:uppercase;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-block}.status-queued{color:#9fa8da;background:#1a237e}.status-graded{color:#a5d6a7;background:#1b5e20}.status-failed{color:#ffcdd2;background:#b71c1c}.status-pending{color:#888;background:#333}.flex{display:flex}.flex-col{flex-direction:column}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-center{text-align:center}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.nav{gap:16px}.main{padding:12px}}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;display:grid}.photo-grid img{aspect-ratio:1;object-fit:cover;cursor:pointer;border:1px solid #333;border-radius:8px;width:100%;transition:transform .2s}.photo-grid img:hover{transform:scale(1.02)}.camera-container{aspect-ratio:4/3;background:#000;border-radius:12px;position:relative;overflow:hidden}.camera-container video{object-fit:cover;width:100%;height:100%}.camera-controls{gap:12px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.capture-btn{cursor:pointer;background:#fff;border:4px solid #4fc3f7;border-radius:50%;width:64px;height:64px;transition:all .2s}.capture-btn:hover{transform:scale(1.1)}.thumb-strip{gap:8px;padding:8px 0;display:flex;overflow-x:auto}.thumb-strip .thumb{object-fit:cover;border:2px solid #333;border-radius:8px;flex-shrink:0;width:80px;height:80px}.thumb-strip .thumb-remove{position:relative}.thumb-strip .thumb-remove:after{content:"x";color:#fff;cursor:pointer;background:#ef5350;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;display:flex;position:absolute;top:-4px;right:-4px}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:#888;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #222;padding:10px 12px;font-size:11px;font-weight:600}td{border-bottom:1px solid #1a1a1a;padding:10px 12px;font-size:14px}tr:hover td{background:#1a1a1a}tr{cursor:pointer}.spinner{border:3px solid #333;border-top-color:#4fc3f7;border-radius:50%;width:40px;height:40px;margin:40px auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:#666;padding:60px 20px}.empty-state h3{color:#888;margin-bottom:8px;font-size:18px}.confidence-bar{background:#222;border-radius:3px;width:80px;height:6px;overflow:hidden}.confidence-fill{border-radius:3px;height:100%;transition:width .3s}.modal-overlay{z-index:200;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#141414;border:1px solid #333;border-radius:16px;width:90%;max-width:500px;padding:24px}.modal h3{margin-bottom:16px}.search-bar{gap:8px;margin-bottom:16px;display:flex}.search-bar input{flex:1}.login-page{background:#0a0a0a;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#141414;border:1px solid #222;border-radius:16px;width:100%;max-width:400px;padding:40px}.login-brand{color:#4fc3f7;letter-spacing:2px;text-align:center;margin-bottom:8px;font-size:24px;font-weight:700}.login-card h2{text-align:center;color:#e0e0e0;margin-bottom:24px;font-size:18px}.login-hint{text-align:center;color:#888;margin:-16px 0 20px;font-size:13px}.form-group{margin-bottom:16px}.login-error{color:#ef5350;background:#2d1111;border:1px solid #ef5350;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-btn{width:100%;padding:12px;font-size:15px}.nav-user{align-items:center;gap:10px;margin-left:auto;display:flex}.nav-user-name{color:#e0e0e0;font-size:13px;font-weight:500}.nav-user-role{color:#4fc3f7;text-transform:uppercase;background:#1a2a35;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.user-table{width:100%}.user-table td{padding:8px 12px}.role-badge{text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.role-owner{color:#9fa8da;background:#1a237e}.role-manager{color:#a5d6a7;background:#1b5e20}.role-tech{color:#ffe0b2;background:#e65100}.role-viewer{color:#888;background:#333}.tabs{border-bottom:1px solid #222;gap:4px;margin-bottom:20px;padding-bottom:4px;display:flex}.tab{color:#888;cursor:pointer;background:0 0;border:none;border-radius:6px 6px 0 0;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.tab:hover{color:#e0e0e0}.tab.active{color:#4fc3f7;background:#1a2a35}
