.auth-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:480px;padding:40px;animation:.4s ease-out slideUp;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{margin-bottom:16px;display:inline-flex}.auth-header h1{color:#1e293b;margin:0 0 8px;font-size:28px;font-weight:700}.auth-header p{color:#64748b;margin:0;font-size:15px}.email-display{color:#3b82f6;justify-content:center;align-items:center;gap:12px;margin-top:12px;font-size:14px;display:flex}.edit-email-btn{color:#3b82f6;cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;text-decoration:underline}.edit-email-btn:hover{color:#2563eb}.email-edit{flex-direction:column;gap:8px;margin-top:12px;display:flex}.email-edit-input{text-align:center;border:1px solid #e2e8f0;border-radius:6px;padding:8px 12px;font-size:14px}.email-edit-actions{justify-content:center;gap:8px;display:flex}.btn-save,.btn-cancel{cursor:pointer;border:none;border-radius:6px;padding:6px 16px;font-size:13px;transition:all .2s}.btn-save{color:#fff;background:#3b82f6}.btn-save:hover{background:#2563eb}.btn-cancel{color:#475569;background:#e2e8f0}.btn-cancel:hover{background:#cbd5e1}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#334155;font-size:14px;font-weight:600}.form-group input,.form-group select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-size:15px;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group select{cursor:pointer}.password-input{width:100%;display:flex;position:relative}.password-input input{width:100%;padding-right:48px}.password-toggle{cursor:pointer;color:#94a3b8;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:color .2s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.password-toggle:hover{color:#3b82f6}.error-text{color:#ef4444;margin-top:-4px;font-size:13px}.hint-text{color:#94a3b8;margin-top:-4px;font-size:12px}.error-banner,.success-banner{border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;animation:.3s ease-out slideDown;display:flex}.error-banner{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.success-banner{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.btn-full{width:100%}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-footer{text-align:center;color:#64748b;margin-top:8px;font-size:14px}.auth-footer a{color:#3b82f6;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.otp-form{flex-direction:column;gap:24px;display:flex}.otp-inputs{justify-content:center;gap:12px;margin:8px 0;display:flex}.otp-input{text-align:center;border:2px solid #e2e8f0;border-radius:8px;width:48px;height:56px;font-size:24px;font-weight:600;transition:all .2s}.otp-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.resend-section{text-align:center;margin-top:-8px}.resend-timer{color:#64748b;margin:0;font-size:14px}.resend-timer strong{color:#3b82f6}.resend-btn{color:#3b82f6;cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:600;text-decoration:underline}.resend-btn:hover:not(:disabled){color:#2563eb}.resend-btn:disabled{color:#94a3b8;cursor:not-allowed}@media (width<=640px){.auth-card{padding:32px 24px}.auth-header h1{font-size:24px}.otp-input{width:40px;height:48px;font-size:20px}.otp-inputs{gap:8px}}.input-with-icon{position:relative}.input-with-icon svg{color:#9ca3af;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-with-icon input{border:1px solid #e5e7eb;border-radius:.5rem;width:100%;padding:.75rem .75rem .75rem 2.5rem;font-size:1rem;transition:all .2s}.input-with-icon input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.info-banner{color:#1e40af;background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:.5rem;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:1rem;display:flex}.info-banner svg{flex-shrink:0;margin-top:.125rem}.info-banner h4{margin-bottom:.5rem;font-size:.875rem;font-weight:600}.info-banner ul{margin:0;padding-left:0;list-style:none}.info-banner li{margin-bottom:.25rem;font-size:.875rem}.info-banner li:last-child{margin-bottom:0}.info-blue{color:#1e40af;background-color:#eff6ff;border-color:#bfdbfe}.button-group{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.btn-secondary{color:#374151;background-color:#f3f4f6;border:1px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb;transform:translateY(-1px)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.success-banner strong{margin-bottom:.25rem;font-size:.875rem;display:block}.success-banner p{margin:0;font-size:.875rem;line-height:1.4}*{box-sizing:border-box;margin:0;padding:0}:root{--green:#22c55e;--yellow:#eab308;--red:#ef4444;--bg:#f8fafc;--card:#fff;--text:#1e293b;--muted:#64748b;--border:#e2e8f0;--primary:#1e40af;--primary-light:#3b82f6;--primary-dark:#1e3a8a;--shadow:0 1px 3px #0000001a}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.header{background:var(--primary);z-index:100;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #00000026}.logo{color:#fff;align-items:center;gap:10px;font-size:1.2rem;font-weight:700;display:flex}.logo small{opacity:.8;margin-top:-2px;font-size:.65rem;font-weight:400;display:block}.nav-links{align-items:center;gap:6px;display:flex}.nav-links button{cursor:pointer;color:#ffffffb3;background:#ffffff26;border:1px solid #fff3;border-radius:8px;padding:7px 16px;font-size:.8rem;font-weight:600;transition:all .2s}.nav-links button:hover,.nav-links button.active{color:var(--primary);background:#fff;border-color:#fff}.location-badge{color:#ffffffb3;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:#ffffff1f;border:1px solid #ffffff26;border-radius:6px;max-width:200px;padding:4px 10px;font-size:.7rem;overflow:hidden}.location-badge:hover{background:#fff3}#app{max-width:1400px;margin:0 auto;padding:16px}.guard-view{max-width:480px;margin:0 auto}.hidden{display:none!important}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{cursor:not-allowed;background:#94a3b8}.btn-success{background:var(--green);color:#fff}.btn-danger{background:var(--red);color:#fff}.btn-warn{background:var(--yellow);color:#fff}.btn-outline{border:2px solid var(--border);color:var(--muted);background:0 0}.btn-outline:hover{border-color:var(--muted)}.status-badge{border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.status-verified{color:#166534;background:#dcfce7}.status-pending{color:#854d0e;background:#fef9c3}.status-flagged{color:#991b1b;background:#fee2e2}.spinner{border:3px solid var(--border);border-top-color:var(--primary-light);border-radius:50%;width:40px;height:40px;margin:0 auto 12px;animation:.6s linear infinite spin}.search-section{background:var(--card);box-shadow:var(--shadow);border-radius:16px;margin-bottom:16px;padding:20px}.search-section h2{color:var(--text);align-items:center;gap:8px;margin-bottom:14px;font-size:1rem;display:flex}.input-label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:4px;font-size:.72rem;font-weight:600}.input-group{margin-bottom:10px;position:relative}.input-group input{border:2px solid var(--border);border-radius:10px;outline:none;width:100%;padding:13px 13px 13px 42px;font-size:.95rem;transition:border .2s}.input-group input:focus{border-color:var(--primary-light)}.input-group .icon{color:var(--muted);width:18px;height:18px;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.gate-banner{color:#fff;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:14px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px 20px;display:flex}.gate-banner .gate-info h3{opacity:.8;font-size:.85rem;font-weight:400}.gate-banner .gate-info .gate-name{font-size:1.1rem;font-weight:700}.gate-stats{gap:16px;display:flex}.gate-stat{text-align:center}.gate-stat .gs-num{font-size:1.3rem;font-weight:800}.gate-stat .gs-lbl{text-transform:uppercase;letter-spacing:.5px;opacity:.7;font-size:.6rem}.result-card{background:var(--card);box-shadow:var(--shadow);border-radius:16px;margin-bottom:14px;padding:18px;animation:.3s slideUp}.result-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;margin-bottom:14px;padding-bottom:14px;display:flex}.result-avatar{background:#e2e8f0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;overflow:hidden}.result-name{font-size:1rem;font-weight:600}.result-id{color:var(--muted);font-size:.75rem}.check-list{list-style:none}.check-item{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:9px 0;display:flex}.check-item:last-child{border:none}.check-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.check-icon.pass{color:#166534;background:#dcfce7}.check-icon.fail{color:#991b1b;background:#fee2e2}.check-icon.warn{color:#854d0e;background:#fef9c3}.check-icon svg{width:14px;height:14px}.check-label{flex:1;font-size:.85rem}.check-value{font-size:.75rem;font-weight:600}.risk-meter{border-top:1px solid var(--border);margin-top:14px;padding-top:14px}.risk-bar{background:#e2e8f0;border-radius:3px;height:6px;margin-top:6px;overflow:hidden}.risk-fill{border-radius:3px;height:100%;transition:width .5s}.risk-label{color:var(--muted);justify-content:space-between;margin-top:3px;font-size:.7rem;display:flex}.submit-actions{gap:8px;margin-top:14px;display:flex}.submit-actions .btn{flex:1;padding:12px;font-size:.85rem}.confirm-box{background:var(--card);box-shadow:var(--shadow);border:2px solid var(--primary);border-radius:16px;margin-bottom:14px;padding:20px;animation:.3s slideUp}.confirm-box h3{margin-bottom:4px;font-size:.95rem}.confirm-box p{color:var(--muted);margin-bottom:14px;font-size:.82rem}.confirm-details{background:#f8fafc;border-radius:10px;margin-bottom:14px;padding:14px}.confirm-row{justify-content:space-between;padding:4px 0;font-size:.85rem;display:flex}.confirm-row .cl{color:var(--muted);font-size:.75rem}.confirm-row .cv{color:var(--primary);font-weight:700}.confirm-actions{gap:10px;display:flex}.confirm-actions .btn{flex:1;padding:11px}.history-item{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:9px 0;display:flex}.history-item:last-child{border:none}.history-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.history-dot.green{background:var(--green)}.history-dot.yellow{background:var(--yellow)}.history-dot.red{background:var(--red)}.history-info{flex:1;min-width:0}.history-name{white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.history-id{color:var(--muted);font-size:.68rem}.history-status{border-radius:10px;padding:2px 8px;font-size:.68rem;font-weight:600}.history-time{color:var(--muted);white-space:nowrap;font-size:.68rem}.admin-wrap{padding-bottom:40px}.ss-banner{color:#fff;border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:18px;padding:20px 24px;display:flex;box-shadow:0 4px 20px #00000026}.ss-left{align-items:center;gap:18px;display:flex}.ss-ring{flex-shrink:0}.ss-title{letter-spacing:.3px;font-size:1.1rem;font-weight:700}.ss-sub{opacity:.8;margin-top:4px;font-size:.75rem}.ss-status{white-space:nowrap;background:#ffffff26;border-radius:10px;padding:8px 18px;font-size:1rem;font-weight:700}@media (width<=600px){.ss-banner{text-align:center;flex-direction:column;gap:12px}.ss-left{flex-direction:column}}.gal-panel{overflow:hidden}.gal-count{background:var(--primary);color:#fff;border-radius:8px;padding:2px 8px;font-size:.65rem;font-weight:700}.gal-list{max-height:340px;overflow-y:auto}.gal-empty{text-align:center;color:var(--muted);padding:30px;font-size:.82rem}.gal-item{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:10px 18px;transition:background .15s;display:flex}.gal-item:hover{background:#f8fafc}.gal-item:last-child{border-bottom:none}.gal-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.gal-dot.green{background:#22c55e}.gal-dot.red{background:#ef4444}.gal-dot.yellow{background:#f59e0b}.gal-dot.blue{background:#3b82f6}.gal-dot.gray{background:#94a3b8}.gal-info{flex:1;min-width:0}.gal-row1{align-items:center;gap:6px;display:flex}.gal-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.gal-tag{white-space:nowrap;border-radius:4px;flex-shrink:0;padding:1px 6px;font-size:.58rem;font-weight:700}.gal-tag.green{color:#166534;background:#dcfce7}.gal-tag.red{color:#991b1b;background:#fee2e2}.gal-tag.yellow{color:#854d0e;background:#fef9c3}.gal-tag.blue{color:#1e40af;background:#dbeafe}.gal-tag.gray{color:#64748b;background:#f1f5f9}.gal-dl{color:var(--muted);margin-top:1px;font-size:.68rem;display:block}.gal-sub{margin-top:2px;font-size:.65rem;display:block}.gal-sub.green{color:#16a34a}.gal-sub.red{color:#dc2626}.gal-sub.yellow{color:#ca8a04}.gal-sub.blue{color:#2563eb}.gal-right{text-align:right;flex-shrink:0}.gal-time{color:var(--text);font-size:.78rem;font-weight:600;display:block}.gal-date{color:var(--muted);margin-top:1px;font-size:.62rem;display:block}.gal-loading{text-align:center;padding:12px}.stats-card{background:var(--card);border-radius:16px;margin-bottom:18px;overflow:hidden;box-shadow:0 1px 3px #00000014,0 4px 12px #0000000a}.sc-overview{align-items:center;gap:16px;padding:18px 22px;display:flex}.sc-main-num{flex-direction:column;align-items:center;min-width:90px;display:flex}.sc-big{color:var(--primary);font-size:2.2rem;font-weight:800;line-height:1}.sc-big-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:.58rem}.sc-pills{flex:1;gap:8px;display:flex}.sc-pill{text-align:center;border-radius:10px;flex:1;min-width:0;padding:10px 6px}.sc-pill.green{background:#f0fdf4}.sc-pill.yellow{background:#fefce8}.sc-pill.red{background:#fef2f2}.sc-pill.gray{background:#f8fafc}.sc-pill-num{font-size:1.25rem;font-weight:800;line-height:1;display:block}.sc-pill.green .sc-pill-num{color:#16a34a}.sc-pill.yellow .sc-pill-num{color:#ca8a04}.sc-pill.red .sc-pill-num{color:#dc2626}.sc-pill.gray .sc-pill-num{color:#64748b}.sc-pill-label{color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-top:3px;font-size:.56rem;display:block}.sc-divider{background:var(--border);height:1px;margin:0 22px}.sc-visual{gap:0;display:flex}.sc-viz-card{flex:1;min-width:0;padding:18px 22px 14px}.sc-viz-card:first-child{border-right:1px solid var(--border)}.sc-viz-header{align-items:center;gap:8px;margin-bottom:14px;display:flex}.sc-viz-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sc-viz-icon.license{color:#854d0e;background:#fef9c3}.sc-viz-icon.criminal{color:#991b1b;background:#fee2e2}.sc-viz-title{color:var(--text);font-size:.82rem;font-weight:700}.sc-tag{border-radius:6px;margin-left:auto;padding:3px 8px;font-size:.6rem;font-weight:700}.sc-tag.danger{color:#dc2626;background:#fee2e2}.sc-tag.safe{color:#16a34a;background:#dcfce7}.sc-viz-body{align-items:center;gap:16px;display:flex}.donut-wrap{flex-shrink:0}.sc-viz-legend{flex-direction:column;flex:1;gap:8px;display:flex}.sc-leg-item{align-items:center;gap:8px;display:flex}.sc-leg-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sc-leg-label{color:var(--text);flex:1;font-size:.75rem}.sc-leg-num{text-align:right;min-width:20px;font-size:.9rem;font-weight:800}.sc-leg-num.danger{color:#dc2626}.sc-leg-num.warn{color:#ca8a04}.sc-leg-num.safe{color:#16a34a}.sc-leg-num.purple{color:#6366f1}.sc-viz-alert{border-radius:8px;align-items:center;gap:6px;margin-top:12px;padding:8px 12px;font-size:.7rem;font-weight:600;display:flex}.sc-viz-alert.danger{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.sc-viz-alert.safe{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.sc-viz-alert svg{flex-shrink:0}@media (width<=700px){.sc-overview{flex-direction:column;gap:12px}.sc-pills{flex-wrap:wrap}.sc-pill{flex:calc(50% - 4px)}.sc-visual{flex-direction:column}.sc-viz-card:first-child{border-right:none;border-bottom:1px solid var(--border)}}.warehouse-selector{align-items:center;gap:10px;margin-bottom:16px;display:flex}.warehouse-selector label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-size:.75rem;font-weight:600}.warehouse-selector select{border:2px solid var(--border);color:var(--primary);background:var(--card);cursor:pointer;appearance:none;box-shadow:var(--shadow);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border-radius:10px;outline:none;padding:9px 32px 9px 14px;font-size:.85rem;font-weight:600}.warehouse-selector select:focus{border-color:var(--primary-light)}.posture-banner{color:#fff;background:linear-gradient(135deg,#166534,#22c55e);border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:20px 24px;display:flex;box-shadow:0 4px 15px #22c55e40}.posture-banner.warn{background:linear-gradient(135deg,#854d0e,#eab308);box-shadow:0 4px 15px #eab30840}.posture-banner.danger{background:linear-gradient(135deg,#991b1b,#ef4444);box-shadow:0 4px 15px #ef444440}.posture-left h3{opacity:.9;font-size:1rem;font-weight:400}.posture-left p{opacity:.7;margin-top:2px;font-size:.8rem}.posture-score{font-size:2.5rem;font-weight:800}.posture-score small{font-size:1rem}.kpi-hero{grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:20px;display:grid}.kpi-card{background:var(--card);box-shadow:var(--shadow);border-top:3px solid #0000;border-radius:14px;padding:18px}.k-blue{border-top-color:var(--primary)}.k-green{border-top-color:var(--green)}.k-red{border-top-color:var(--red)}.k-yellow{border-top-color:var(--yellow)}.k-purple{border-top-color:#8b5cf6}.kpi-val{color:var(--text);font-size:1.8rem;font-weight:800}.kpi-label{color:var(--muted);margin-top:2px;font-size:.75rem}.kpi-sub{margin-top:6px;font-size:.68rem}.kpi-sub.up{color:var(--green)}.kpi-sub.down{color:var(--red)}.kpi-sub.neutral{color:var(--muted)}.admin-panel{background:var(--card);box-shadow:var(--shadow);border-radius:16px;margin-bottom:20px;padding:20px}.panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.panel-title{font-size:1rem;font-weight:700}.panel-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-btn{border:1px solid var(--border);cursor:pointer;color:var(--muted);background:0 0;border-radius:8px;padding:5px 12px;font-size:.75rem;font-weight:600;transition:all .2s}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filter-btn:hover:not(.active){background:#f1f5f9}.search-box{border:1px solid var(--border);border-radius:8px;outline:none;width:160px;padding:5px 12px;font-size:.75rem}.search-box:focus{border-color:var(--primary-light)}.chart-area{padding:10px 0}.bar-chart{justify-content:space-around;align-items:flex-end;gap:8px;height:160px;display:flex}.bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.bar-value{color:var(--text);margin-bottom:4px;font-size:.7rem;font-weight:700}.bar{border-radius:6px 6px 0 0;width:100%;max-width:48px;min-height:4px;transition:height .5s}.bar-label{color:var(--muted);margin-top:6px;font-size:.68rem}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:2px solid var(--border);padding:10px 12px;font-size:.7rem}.data-table td{border-bottom:1px solid #f1f5f9;padding:12px;font-size:.85rem}.data-table tr{cursor:pointer;transition:background .15s}.data-table tbody tr:hover{background:#f8fafc}.person-cell{align-items:center;gap:10px;display:flex}.person-avatar{background:#f1f5f9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.person-avatar svg{width:18px;height:18px}.person-name{font-size:.85rem;font-weight:600}.person-id{color:var(--muted);font-size:.7rem}.risk-pill{border-radius:12px;padding:3px 10px;font-size:.75rem;font-weight:700}.risk-low{color:#166534;background:#dcfce7}.risk-med{color:#854d0e;background:#fef9c3}.risk-high{color:#991b1b;background:#fee2e2}.two-col{grid-template-columns:1fr 1fr;gap:20px;display:grid}.audit-item{border-bottom:1px solid #f1f5f9;align-items:flex-start;gap:10px;padding:10px 0;display:flex}.audit-item:last-child{border:none}.audit-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.audit-dot.guard{background:var(--primary-light)}.audit-dot.sys{background:#94a3b8}.audit-dot.admin{background:#8b5cf6}.audit-dot.alert{background:var(--red)}.audit-text{flex:1;min-width:0}.audit-action{font-size:.82rem;font-weight:600}.audit-detail{color:var(--muted);margin-top:1px;font-size:.7rem}.audit-meta{color:var(--muted);white-space:nowrap;font-size:.68rem}.alert-card{cursor:pointer;border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:10px 0;transition:background .15s;display:flex}.alert-card:hover{background:#fafafa}.alert-card:last-child{border:none}.alert-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.alert-icon.danger{color:#991b1b;background:#fee2e2}.alert-icon.warning{color:#854d0e;background:#fef9c3}.alert-info{flex:1;min-width:0}.alert-title{font-size:.82rem;font-weight:600}.alert-desc{color:var(--muted);margin-top:1px;font-size:.7rem}.admin-query{border-top:1px solid var(--border);gap:8px;margin-top:14px;padding-top:14px;display:flex}.admin-query input{border:1px solid var(--border);border-radius:8px;outline:none;flex:1;padding:9px 14px;font-size:.82rem}.admin-query input:focus{border-color:var(--primary-light)}.admin-query button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:9px 18px;font-size:.8rem;font-weight:600}.query-result{color:var(--text);border-left:3px solid var(--primary);background:#eff6ff;border-radius:10px;margin-top:10px;padding:12px 16px;font-size:.82rem;display:none}.query-result.show{display:block}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:18px;width:100%;max-width:680px;max-height:90vh;animation:.3s slideUp;overflow-y:auto}.modal-head{border-bottom:1px solid var(--border);z-index:1;background:#fff;border-radius:18px 18px 0 0;justify-content:space-between;align-items:center;padding:16px 22px;display:flex;position:sticky;top:0}.modal-head h3{font-size:.95rem}.modal-close{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.4rem}.modal-close:hover{background:#f1f5f9}.modal-body{padding:0}.modal-banner{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#f8fafc,#eff6ff);align-items:center;gap:16px;padding:20px 22px;display:flex}.modal-banner .person-avatar{width:56px;height:56px}.modal-banner-info{flex:1;min-width:0}.modal-banner-info .mb-name{font-size:1.15rem;font-weight:700}.modal-banner-info .mb-sub{color:var(--muted);flex-wrap:wrap;gap:10px;margin-top:2px;font-size:.75rem;display:flex}.modal-banner-info .mb-sub span{align-items:center;gap:3px;display:flex}.modal-banner-right{text-align:center;flex-shrink:0}.risk-gauge{width:72px;height:72px;position:relative}.risk-gauge svg{transform:rotate(-90deg)}.risk-gauge-val{justify-content:center;align-items:center;font-size:1.1rem;font-weight:800;display:flex;position:absolute;inset:0}.risk-gauge-label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-top:2px;font-size:.6rem}.modal-tabs{border-bottom:2px solid var(--border);z-index:1;background:#fff;padding:0 22px;display:flex;position:sticky;top:53px}.modal-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 18px;font-size:.8rem;font-weight:600;transition:all .2s}.modal-tab:hover{color:var(--text)}.modal-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.modal-tab-content{padding:20px 22px}.info-grid{grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:18px;display:grid}.info-card{background:#f8fafc;border-radius:10px;padding:10px 12px}.info-card .ic-label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:2px;font-size:.62rem}.info-card .ic-value{color:var(--text);font-size:.85rem;font-weight:600}.info-card .ic-value.danger{color:var(--red)}.info-card .ic-value.warn{color:var(--yellow)}.info-card .ic-value.safe{color:var(--green)}.check-result{border-radius:12px;align-items:center;gap:12px;margin-bottom:10px;padding:14px;display:flex}.check-result.pass{background:#f0fdf4;border:1px solid #bbf7d0}.check-result.fail{background:#fef2f2;border:1px solid #fecaca}.check-result.warn{background:#fefce8;border:1px solid #fef08a}.check-result .cr-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.check-result.pass .cr-icon{color:#166534;background:#dcfce7}.check-result.fail .cr-icon{color:#991b1b;background:#fee2e2}.check-result.warn .cr-icon{color:#854d0e;background:#fef9c3}.check-result .cr-icon svg{width:18px;height:18px}.check-result .cr-info{flex:1}.check-result .cr-title{font-size:.8rem;font-weight:600}.check-result .cr-detail{color:var(--muted);margin-top:1px;font-size:.72rem}.check-result .cr-badge{border-radius:12px;flex-shrink:0;padding:3px 10px;font-size:.7rem;font-weight:700}.check-result.pass .cr-badge{color:#166534;background:#dcfce7}.check-result.fail .cr-badge{color:#991b1b;background:#fee2e2}.check-result.warn .cr-badge{color:#854d0e;background:#fef9c3}.visit-summary{background:#f8fafc;border-radius:12px;align-items:center;gap:14px;margin-bottom:16px;padding:14px;display:flex}.visit-count{color:var(--primary);font-size:2rem;font-weight:800;line-height:1}.visit-label{color:var(--muted);font-size:.8rem}.visit-label strong{color:var(--text)}.location-chips{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.location-chip{color:var(--primary);background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:4px 10px;font-size:.7rem;font-weight:600}.risk-trend-mini{align-items:flex-end;gap:3px;height:32px;display:flex}.risk-trend-bar{border-radius:3px 3px 0 0;width:18px;transition:height .3s}.visits-table{border-collapse:collapse;width:100%;font-size:.78rem}.visits-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:6px 8px;font-size:.65rem}.visits-table td{border-bottom:1px solid #f1f5f9;padding:7px 8px}.detail-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px;display:grid}.detail-label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:2px;font-size:.68rem}.detail-value{font-size:.9rem;font-weight:600}.timeline-item{gap:12px;padding:8px 0;display:flex}.timeline-dot{width:20px;height:20px;color:var(--primary-light);flex-shrink:0}.timeline-dot svg{width:16px;height:16px}.timeline-content{flex:1}.timeline-title{font-size:.82rem;font-weight:600}.timeline-time{color:var(--muted);margin-top:2px;font-size:.68rem}.admin-notes{border-top:1px solid var(--border);margin-top:16px;padding-top:14px}.admin-notes label{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px;font-size:.7rem;font-weight:600;display:block}.admin-notes textarea{border:1px solid var(--border);resize:vertical;border-radius:10px;outline:none;width:100%;min-height:60px;padding:10px 12px;font-family:inherit;font-size:.82rem}.admin-notes textarea:focus{border-color:var(--primary-light)}.decision-bar{border-top:1px solid var(--border);background:#f8fafc;border-radius:0 0 18px 18px;padding:16px 22px;position:sticky;bottom:0}.decision-actions{gap:8px;display:flex}.decision-actions .btn{flex:1;padding:11px;font-size:.82rem}.decision-done{text-align:center;border-radius:10px;padding:12px;font-weight:600}.weekly-volume-panel{overflow:hidden}.weekly-volume-panel .panel-header{flex-wrap:nowrap}.wv-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.wv-title-section{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.wv-trend-badge{color:#166534;background:#f0fdf4;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.wv-trend-badge.down{color:#991b1b;background:#fef2f2}.wv-trend-badge svg{flex-shrink:0}.wv-controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.wv-week-nav{background:var(--bg);border-radius:10px;align-items:center;gap:8px;padding:4px;display:flex}.wv-nav-btn{cursor:pointer;width:28px;height:28px;color:var(--muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.wv-nav-btn:hover:not(:disabled){background:var(--card);color:var(--primary)}.wv-nav-btn:disabled{opacity:.4;cursor:not-allowed}.wv-week-label{color:var(--text);text-align:center;min-width:140px;padding:0 8px;font-size:.75rem;font-weight:600}.wv-export-btns{gap:6px;display:flex}.wv-export-btn{border:1px solid var(--border);background:var(--card);color:var(--muted);cursor:pointer;border-radius:8px;align-items:center;gap:5px;padding:6px 12px;font-size:.72rem;font-weight:600;transition:all .2s;display:flex}.wv-export-btn:hover{border-color:var(--primary);color:var(--primary);background:#eff6ff}.wv-summary-grid{border-bottom:1px solid var(--border);grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:12px;padding:16px 0;display:grid}.wv-summary-card{background:var(--bg);border-left:3px solid #0000;border-radius:12px;padding:14px;transition:transform .2s,box-shadow .2s;position:relative}.wv-summary-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.wv-summary-card.total{border-left-color:var(--primary);background:linear-gradient(135deg,#eff6ff 0%,#f8fafc 100%)}.wv-summary-card.allowed{border-left-color:var(--green)}.wv-summary-card.hold{border-left-color:var(--yellow)}.wv-summary-card.blocked{border-left-color:var(--red)}.wv-summary-card.cases{border-left-color:#8b5cf6}.wv-card-icon{background:#0000000a;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:absolute;top:12px;right:12px}.wv-summary-card.allowed .wv-card-icon{color:var(--green)}.wv-summary-card.hold .wv-card-icon{color:var(--yellow)}.wv-summary-card.blocked .wv-card-icon{color:var(--red)}.wv-summary-card.cases .wv-card-icon{color:#8b5cf6}.wv-card-value{color:var(--text);font-size:1.6rem;font-weight:800;line-height:1}.wv-card-label{color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-top:4px;font-size:.7rem}.wv-card-sub{color:var(--muted);margin-top:6px;font-size:.68rem}.wv-summary-card.total .wv-card-value{color:var(--primary)}.wv-tabs{background:var(--bg);border-radius:10px;gap:4px;margin-bottom:16px;padding:4px;display:flex}.wv-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px 16px;font-size:.78rem;font-weight:600;transition:all .2s}.wv-tab:hover:not(.active){background:#00000008}.wv-tab.active{background:var(--card);color:var(--primary);box-shadow:0 1px 3px #00000014}.wv-chart-area{min-height:200px;padding:8px 0}.wv-empty-state{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.wv-empty-state svg{opacity:.4;margin-bottom:12px}.wv-empty-state p{font-size:.85rem}.wv-bar-chart{justify-content:space-around;align-items:flex-end;gap:8px;padding:0 8px;display:flex}.wv-bar-col{flex-direction:column;flex:1;align-items:center;min-width:40px;display:flex;position:relative}.wv-bar-col:hover .wv-bar-tooltip{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.wv-bar-tooltip{color:#fff;white-space:nowrap;opacity:0;visibility:hidden;z-index:10;background:#1e293b;border-radius:10px;padding:10px 14px;font-size:.72rem;transition:all .2s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px);box-shadow:0 4px 12px #00000026}.wv-bar-tooltip:after{content:"";border:6px solid #0000;border-top-color:#1e293b;position:absolute;top:100%;left:50%;transform:translate(-50%)}.wv-bar-tooltip strong{margin-bottom:6px;font-size:.75rem;display:block}.wv-bar-tooltip span{opacity:.85;padding:2px 0;display:block}.wv-bar-tooltip span.allowed{color:#4ade80}.wv-bar-tooltip span.hold{color:#facc15}.wv-bar-tooltip span.blocked{color:#f87171}.wv-bar-tooltip span.completed{color:#4ade80}.wv-bar-tooltip span.pending{color:#facc15}.wv-bar-tooltip span.failed{color:#f87171}.wv-bar-tooltip span.civil{color:#60a5fa}.wv-bar-tooltip span.criminal{color:#f87171}.wv-bar-tooltip span.pending-case{color:#facc15}.wv-bar-value{color:var(--text);min-height:16px;margin-bottom:6px;font-size:.72rem;font-weight:700}.wv-bar-wrapper{border-radius:6px 6px 0 0;flex-direction:column;justify-content:flex-end;width:100%;max-width:48px;display:flex;overflow:hidden}.wv-bar-wrapper.stacked{flex-direction:column-reverse;display:flex}.wv-bar{border-radius:4px 4px 0 0;width:100%;min-height:0;transition:height .4s}.wv-bar.overview{background:linear-gradient(180deg, var(--primary) 0%, var(--primary-light) 100%)}.wv-bar.allowed{background:linear-gradient(#16a34a 0%,#22c55e 100%)}.wv-bar.hold{background:linear-gradient(#ca8a04 0%,#eab308 100%)}.wv-bar.blocked{background:linear-gradient(#dc2626 0%,#ef4444 100%)}.wv-bar.completed{background:linear-gradient(#16a34a 0%,#22c55e 100%)}.wv-bar.pending{background:linear-gradient(#ca8a04 0%,#eab308 100%)}.wv-bar.failed{background:linear-gradient(#dc2626 0%,#ef4444 100%)}.wv-bar.civil{background:linear-gradient(#2563eb 0%,#3b82f6 100%)}.wv-bar.criminal{background:linear-gradient(#dc2626 0%,#ef4444 100%)}.wv-bar.pending-case{background:linear-gradient(#ca8a04 0%,#eab308 100%)}.wv-bar.empty{background:#e2e8f0;border-radius:2px}.wv-bar-label{color:var(--muted);margin-top:8px;font-size:.68rem;font-weight:500}.wv-chart-legend{flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;margin-bottom:16px;display:flex}.wv-legend-item{color:var(--muted);align-items:center;gap:6px;font-size:.72rem;font-weight:500;display:flex}.wv-legend-dot{border-radius:3px;width:10px;height:10px}.wv-legend-item.allowed .wv-legend-dot{background:var(--green)}.wv-legend-item.hold .wv-legend-dot{background:var(--yellow)}.wv-legend-item.blocked .wv-legend-dot{background:var(--red)}.wv-legend-item.completed .wv-legend-dot{background:var(--green)}.wv-legend-item.pending .wv-legend-dot{background:var(--yellow)}.wv-legend-item.failed .wv-legend-dot{background:var(--red)}.wv-legend-item.civil .wv-legend-dot{background:#3b82f6}.wv-legend-item.criminal .wv-legend-dot{background:var(--red)}.wv-legend-item.pending-case .wv-legend-dot{background:var(--yellow)}.wv-stacked-chart{padding-top:8px}.wv-case-summary{background:var(--bg);border-radius:12px;gap:16px;margin-bottom:20px;padding:16px;display:flex}.wv-case-stat{background:var(--card);border-left:3px solid #0000;border-radius:10px;flex:1;align-items:center;gap:12px;padding:12px 16px;transition:transform .2s;display:flex}.wv-case-stat:hover{transform:translateY(-2px)}.wv-case-stat.civil{border-left-color:#3b82f6}.wv-case-stat.criminal{border-left-color:var(--red)}.wv-case-stat.pending-case{border-left-color:var(--yellow)}.wv-case-icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.wv-case-stat.civil .wv-case-icon{color:#3b82f6;background:#eff6ff}.wv-case-stat.criminal .wv-case-icon{color:var(--red);background:#fef2f2}.wv-case-stat.pending-case .wv-case-icon{color:var(--yellow);background:#fefce8}.wv-case-value{color:var(--text);font-size:1.4rem;font-weight:800}.wv-case-label{color:var(--muted);text-transform:uppercase;letter-spacing:.3px;font-size:.68rem}.wv-comparison-footer{background:var(--bg);border-radius:10px;justify-content:center;align-items:center;gap:24px;margin-top:16px;padding:14px;display:flex}.wv-comparison-item{text-align:center}.wv-comp-label{color:var(--muted);margin-bottom:2px;font-size:.68rem;display:block}.wv-comp-value{color:var(--text);font-size:.82rem;font-weight:700}.wv-comp-value.up{color:var(--green)}.wv-comp-value.down{color:var(--red)}.wv-comparison-divider{background:var(--border);width:1px;height:28px}.wv-retry-btn{background:var(--red);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:.8rem;font-weight:600;transition:background .2s}.wv-retry-btn:hover{background:#dc2626}@media (width<=1200px){.wv-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.wv-header{flex-direction:column;align-items:flex-start}.wv-controls{justify-content:space-between;width:100%}.wv-summary-grid{grid-template-columns:repeat(2,1fr)}.wv-case-summary{flex-direction:column}}@media (width<=640px){.wv-summary-grid{grid-template-columns:1fr 1fr}.wv-summary-card.total{grid-column:1/-1}.wv-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.wv-tab{white-space:nowrap;flex:none;padding:8px 12px}.wv-bar-chart{gap:4px}.wv-bar-col{min-width:32px}.wv-comparison-footer{flex-wrap:wrap;gap:16px}}@media (width<=1024px){.kpi-hero{grid-template-columns:repeat(3,1fr)}.two-col{grid-template-columns:1fr}}@media (width<=640px){.kpi-hero{grid-template-columns:repeat(2,1fr)}}
