@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{color:#2d3748;-webkit-font-smoothing:antialiased;background:#e8ecf1;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app-layout{min-height:100vh;display:flex}.app-content{flex-direction:column;flex:1;min-width:0;display:flex}.app-loading{background:#e8ecf1;justify-content:center;align-items:center;min-height:100vh;display:flex}.main{flex:1;width:100%;max-width:1500px;padding:28px 32px}.sidebar{background:linear-gradient(#0d1117 0%,#161b22 100%);flex-direction:column;flex-shrink:0;width:240px;height:100vh;transition:width .2s;display:flex;position:sticky;top:0;overflow:hidden}.sidebar.collapsed{width:64px}.sidebar-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:20px 16px 16px;display:flex}.sidebar-brand{letter-spacing:2px;font-size:20px;font-weight:800;display:flex;overflow:hidden}.brand-eco{color:#2196f6}.brand-cell{background:linear-gradient(135deg,#b0bec5 0%,#cfd8dc 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.sidebar-toggle{color:#78818f;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;transition:all .15s;display:flex}.sidebar-toggle:hover{color:#b0b8c4;background:#ffffff1a}.sidebar-nav{scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;flex:1;padding:12px 8px;overflow-y:auto}.nav-section{margin-bottom:20px}.nav-section-label{color:#4a5568;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px;padding:0 12px;font-size:10px;font-weight:700}.nav-item{color:#8892a2;border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:8px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .12s;display:flex}.nav-item:hover{color:#c8ccd4;background:#ffffff0d}.nav-item.active{color:#64b5f6;background:linear-gradient(135deg,#2196f626 0%,#2196f614 100%);font-weight:600;box-shadow:inset 3px 0 #2196f6}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.nav-label{white-space:nowrap}.collapsed .nav-item{justify-content:center;padding:10px}.collapsed .nav-section-label{display:none}.collapsed .nav-icon{font-size:18px}.sidebar-footer{border-top:1px solid #ffffff0f;padding:12px}.sidebar-user{align-items:center;gap:10px;margin-bottom:8px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#1e88e5 0%,#2196f6 100%);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.user-info{overflow:hidden}.user-name{color:#d0d5dd;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:#2196f6;text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.logout-btn{color:#78818f;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:6px;width:100%;padding:7px;font-size:12px;font-weight:500;transition:all .15s}.logout-btn:hover{color:#ef5350;background:#ef53501a;border-color:#ef535026}.btn{cursor:pointer;letter-spacing:.2px;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#1e88e5 0%,#2196f6 100%);box-shadow:0 2px 6px #2196f64d}.btn-primary:hover{background:linear-gradient(135deg,#1565c0 0%,#1e88e5 100%);transform:translateY(-1px);box-shadow:0 4px 12px #2196f666}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{color:#fff;box-shadow:none;cursor:not-allowed;background:#bfc6d0;transform:none}.btn-danger{color:#fff;background:linear-gradient(135deg,#d32f2f 0%,#ef5350 100%);box-shadow:0 2px 6px #ef535040}.btn-danger:hover{background:linear-gradient(135deg,#c62828 0%,#d32f2f 100%);transform:translateY(-1px)}.btn-secondary{color:#4a5568;background:#fff;border:1px solid #d2d8e0;box-shadow:0 1px 2px #0000000d}.btn-secondary:hover{color:#2d3748;background:#f7f8fa;border-color:#b0b8c4}.btn-sm{border-radius:6px;padding:6px 12px;font-size:12px}.card{background:#fff;border:1px solid #dce1e8;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000000a,0 1px 2px #00000008}input,select,textarea{color:#2d3748;background:#fff;border:1px solid #d2d8e0;border-radius:8px;outline:none;width:100%;padding:9px 14px;font-size:14px;transition:all .15s;box-shadow:0 1px 2px #0000000a}input:focus,select:focus,textarea:focus{border-color:#2196f6;box-shadow:0 0 0 3px #2196f61f,0 1px 2px #0000000a}input::placeholder,textarea::placeholder{color:#a0aab4}label{color:#6b7888;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.grade{border-radius:6px;padding:4px 10px;font-size:13px;font-weight:700;display:inline-block}.grade-A{color:#2e7d32;background:#e8f5e9}.grade-Bplus{color:#388e3c;background:#e8f5e9}.grade-B{color:#f57f17;background:#fff8e1}.grade-Bminus{color:#e65100;background:#fff3e0}.grade-Cplus{color:#bf360c;background:#fbe9e7}.grade-C{color:#c62828;background:#ffebee}.grade-D{color:#6a1b9a;background:#f3e5f5}.grade-null{color:#8892a2;background:#e2e6ec}.status{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.status-queued{color:#1565c0;background:#e3f2fd}.status-graded{color:#2e7d32;background:#e8f5e9}.status-failed{color:#c62828;background:#ffebee}.status-pending{color:#78818f;background:#e2e6ec}.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}.sidebar{display:none}.main{padding:16px}}.table-container{background:#fff;border:1px solid #dce1e8;border-radius:10px;max-width:100%;display:inline-block;overflow-x:auto;box-shadow:0 1px 3px #0000000a}table{border-collapse:collapse;width:auto}th{text-align:left;white-space:nowrap;color:#6b7888;text-transform:uppercase;letter-spacing:.6px;background:#f7f8fa;border-bottom:2px solid #b0b8c4;padding:11px 14px;font-size:11px;font-weight:700}td{white-space:nowrap;color:#374151;border-bottom:1px solid #b0b8c4;padding:5px 12px;font-size:14px;font-weight:600}tr:hover td{background:#eef3fa}tr{cursor:pointer;transition:background .1s}.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:2px solid #dce1e8;border-radius:8px;width:100%;transition:all .2s}.photo-grid img:hover{border-color:#2196f6;transform:scale(1.02);box-shadow:0 4px 12px #2196f626}.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 #2196f6;border-radius:50%;width:64px;height:64px;transition:all .2s;box-shadow:0 4px 16px #0000004d}.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 #dce1e8;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}.spinner{border:3px solid #dce1e8;border-top-color:#2196f6;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:#8892a2;padding:60px 20px}.empty-state h3{color:#6b7888;margin-bottom:8px;font-size:18px}.confidence-bar{background:#e8ecf1;border-radius:3px;width:80px;height:6px;overflow:hidden}.confidence-fill{border-radius:3px;height:100%;transition:width .3s}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#2d374880;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border:1px solid #dce1e8;border-radius:16px;width:90%;max-width:500px;padding:28px;box-shadow:0 20px 60px #00000026}.modal h3{color:#1a202c;margin-bottom:16px}.search-bar{gap:8px;margin-bottom:16px;display:flex}.search-bar input{flex:1}.login-page{background:linear-gradient(135deg,#0d1117 0%,#161b22 50%,#1a2332 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px;box-shadow:0 20px 60px #0000004d}.login-brand{letter-spacing:3px;text-align:center;margin-bottom:8px;font-size:28px;font-weight:800}.login-brand .brand-eco,.login-page .brand-eco{color:#2196f6}.login-brand .brand-cell,.login-page .brand-cell{color:#90a4ae}.login-card h2{text-align:center;color:#6b7888;margin-bottom:24px;font-size:16px;font-weight:400}.login-hint{text-align:center;color:#8892a2;margin:-16px 0 20px;font-size:13px}.form-group{margin-bottom:16px}.login-error{color:#c53030;background:#fff5f5;border:1px solid #feb2b2;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-btn{width:100%;padding:12px;font-size:15px}.user-table{width:auto}.user-table td{padding:8px 12px}.role-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.role-owner{color:#1565c0;background:#e3f2fd}.role-manager{color:#2e7d32;background:#e8f5e9}.role-tech{color:#e65100;background:#fff3e0}.role-viewer{color:#78818f;background:#e2e6ec}.tabs{border-bottom:2px solid #b0b8c4;gap:2px;margin-bottom:20px;display:flex}.tab{color:#8892a2;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 18px;font-size:13px;font-weight:600;transition:all .15s}.tab:hover{color:#4a5568}.tab.active{color:#2196f6;border-bottom-color:#2196f6}h1,h2,h3{color:#1a202c;letter-spacing:-.3px;font-weight:700}h2{margin:0 0 16px;font-size:22px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#c8cdd6;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0aab4}::selection{background:#2196f633}.nav,.nav-brand,.nav-links,.nav-user,.nav-user-name,.nav-user-role{display:none}
