@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0b1220;color:#eee;min-height:100vh}.app{max-width:1400px;margin:0 auto;padding:20px}.header{text-align:center;margin-bottom:30px}.header h1{font-size:2rem;color:#f59e0b}.header p{color:#888;margin-top:5px}.main-content{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:900px){.main-content{grid-template-columns:1fr}}.video-section{background:#0f1a2e;border-radius:12px;padding:20px}.work-zone-control{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.work-zone-toggle{display:flex;align-items:center;gap:12px;cursor:pointer}.work-zone-toggle input{position:absolute;opacity:0;pointer-events:none}.toggle-track{width:46px;height:26px;border-radius:999px;background:#34405f;border:1px solid #52607f;padding:2px;flex:0 0 auto;transition:background .2s,border-color .2s}.toggle-thumb{display:block;width:20px;height:20px;border-radius:50%;background:#d8deea;transition:transform .2s}.work-zone-toggle input:checked+.toggle-track{background:#f59e0b;border-color:#f59e0b}.work-zone-toggle input:checked+.toggle-track .toggle-thumb{transform:translate(20px)}.toggle-title,.toggle-subtitle{display:block}.toggle-title{font-weight:700;color:#f3f7ff}.toggle-subtitle{margin-top:2px;font-size:.78rem;color:#aab3c8}.work-zone-badge{flex:0 0 auto;border-radius:6px;padding:6px 10px;font-size:.75rem;font-weight:800;letter-spacing:.04em;border:1px solid #52607f;color:#c4ccda;background:#0b1220}.work-zone-badge.on{border-color:#f59e0b;color:#1a1205;background:#f59e0b}.top-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}.report-button,.print-button{border:0;border-radius:6px;background:#f59e0b;color:#06131a;cursor:pointer;font-weight:800}.report-button{min-height:32px;padding:7px 12px;font-size:.78rem}.print-button{padding:9px 14px;font-size:.85rem}.report-button:disabled{cursor:not-allowed;opacity:.65}@media(max-width:560px){.work-zone-control{align-items:flex-start;flex-direction:column}.top-actions{width:100%;align-items:stretch;flex-direction:column}}.video-container{position:relative;border-radius:8px;overflow:hidden;background:#000}.video-container video{width:100%;display:block}.video-container canvas{display:none}.capture-indicator{position:absolute;top:10px;right:10px;background:#00d4ffe6;color:#000;padding:5px 10px;border-radius:4px;font-size:.8rem;font-weight:700}.status-bar{margin-top:15px;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:8px}.status-dot.active{background:#16a34a;animation:pulse 1.5s infinite}.status-dot.error{background:#dc2626}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.results-section{display:flex;flex-direction:column;gap:20px}.latest-result{background:#0f1a2e;border-radius:12px;padding:20px}.latest-result h2{margin-bottom:15px;font-size:1.2rem}.ppe-checklist{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:14px}.ppe-row{min-height:42px;display:flex;justify-content:space-between;align-items:center;gap:8px;padding:9px 10px;border-radius:6px;background:#0b1220;border:1px solid #34405f}.ppe-row.present{border-color:#00ff888c}.ppe-row.missing{border-color:#f44c}.ppe-label{font-size:.84rem;font-weight:700;color:#d8deea}.ppe-state{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-size:1rem;font-weight:900;flex:0 0 auto}.ppe-row.present .ppe-state{color:#001f10;background:#16a34a}.ppe-row.missing .ppe-state{color:#fff;background:#dc2626}.ppe-row.pending .ppe-state{color:#aab3c8;background:#34405f}@media(max-width:560px){.ppe-checklist{grid-template-columns:1fr}}.result-card{padding:15px;border-radius:8px;border-left:4px solid}.result-card.safe{background:#00ff881a;border-color:#16a34a}.result-card.low{background:#ffff001a;border-color:#8a99ad}.result-card.medium{background:#ffa5001a;border-color:#f59e0b}.result-card.high{background:#ff44441a;border-color:#dc2626}.result-status{font-size:1.5rem;font-weight:700;margin-bottom:10px}.result-card.high .result-status{color:#dc2626}.result-details p{margin:8px 0;line-height:1.4}.result-details strong{color:#f59e0b}.log-section{background:#0f1a2e;border-radius:12px;padding:20px;max-height:400px;overflow:hidden;display:flex;flex-direction:column}.log-section h2{margin-bottom:15px;font-size:1.2rem}.log-list{flex:1;overflow-y:auto;font-size:.85rem}.log-entry{padding:10px;margin-bottom:8px;background:#0b1220;border-radius:6px;border-left:3px solid}.log-entry.safe{border-color:#16a34a}.log-entry.low{border-color:#8a99ad}.log-entry.medium{border-color:#f59e0b}.log-entry.high{border-color:#dc2626}.log-entry .time{color:#666;font-size:.75rem}.log-entry .summary{margin-top:4px}.no-result{color:#666;text-align:center;padding:40px}.error-message{background:#f443;border:1px solid #DC2626;padding:15px;border-radius:8px;text-align:center}.report-error{margin-top:20px;padding:14px 16px;border-radius:8px;background:#f443;border:1px solid #DC2626}.shift-report{margin-top:24px;padding:28px;border-radius:8px;background:#f7f9fc;color:#15202f;box-shadow:0 18px 50px #00000040}.report-heading{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;padding-bottom:18px;border-bottom:2px solid #d8dee9}.report-kicker{color:#526173;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.report-heading h2{margin-top:4px;font-size:1.8rem;color:#0f1724}.report-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px}.report-meta div,.total-tile,.report-section{border:1px solid #d8dee9;border-radius:8px;background:#fff}.report-meta div{padding:12px}.report-meta span,.total-tile span{display:block;color:#66758a;font-size:.76rem;font-weight:800;text-transform:uppercase}.report-meta strong{display:block;margin-top:6px;color:#15202f;font-size:.95rem}.report-section{margin-top:18px;padding:16px}.report-section h3{margin-bottom:12px;color:#0f1724;font-size:1rem}.report-totals{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.total-tile{padding:14px}.total-tile strong{display:block;margin-top:8px;font-size:2rem;line-height:1}.total-tile.high strong{color:#c53030}.total-tile.medium strong{color:#f59e0b}.total-tile.low strong{color:#6b7280}.report-breakdowns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.breakdown-list{list-style:none}.breakdown-list li{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid #e4e9f1}.breakdown-list li:last-child{border-bottom:0}.empty-report-note,.supervisor-summary{color:#445166;line-height:1.5}.report-table-wrap{overflow-x:auto}.report-table{width:100%;border-collapse:collapse;font-size:.86rem}.report-table th,.report-table td{padding:11px 10px;border-bottom:1px solid #e4e9f1;text-align:left;vertical-align:top}.report-table th{color:#526173;font-size:.72rem;text-transform:uppercase}.severity-pill{display:inline-block;min-width:66px;border-radius:999px;padding:4px 8px;color:#fff;font-size:.7rem;font-weight:900;text-align:center}.severity-pill.high{background:#c53030}.severity-pill.medium{background:#f59e0b}.severity-pill.low{background:#6b7280}.severity-pill.none{background:#2f855a}@media(max-width:760px){.report-meta,.report-totals,.report-breakdowns{grid-template-columns:1fr}.report-heading{flex-direction:column}}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top left,rgba(245,158,11,.08),transparent 28rem),#0b1220;color:#e6edf5}.app{max-width:1440px;padding:22px 24px 28px}.header{display:flex;flex-direction:column;align-items:flex-start;text-align:left;margin-bottom:14px}.header h1{display:inline-flex;align-items:center;gap:12px;color:#f8fafc;font-size:clamp(1.5rem,3vw,2.4rem);font-weight:900;letter-spacing:.08em;line-height:1}.header h1:before{content:"";width:34px;height:38px;display:inline-block;background:radial-gradient(circle at 50% 50%,#0B1220 0 3px,transparent 4px),radial-gradient(ellipse at 50% 50%,transparent 0 6px,#F59E0B 7px 8px,transparent 9px),linear-gradient(145deg,#f59e0bf2,#f59e0b8c);clip-path:polygon(50% 0,92% 15%,82% 78%,50% 100%,18% 78%,8% 15%);filter:drop-shadow(0 0 14px rgba(245,158,11,.22))}.header p{margin-top:8px;color:#8a99ad;font-size:.9rem;font-weight:600}.ops-status-bar{display:flex;flex-wrap:wrap;align-items:center;gap:16px;min-height:38px;margin-bottom:20px;padding:9px 14px;border:1px solid #1F2A3D;border-radius:12px;background:#0f1a2ee0;box-shadow:0 18px 45px #0000002e;color:#8a99ad;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.ops-status-bar span{display:inline-flex;align-items:center;gap:7px}.ops-dot{width:7px;height:7px;border-radius:50%;background:#16a34a;box-shadow:0 0 14px #16a34abf}.main-content{gap:24px}.video-section,.latest-result,.log-section{border:1px solid #1F2A3D;border-radius:12px;background:#0f1a2e;box-shadow:0 22px 60px #0000003d}.video-section,.latest-result{padding:24px}.log-section{padding:22px}.work-zone-control{gap:18px;margin-bottom:18px}.work-zone-toggle{min-width:0}.toggle-track{width:48px;height:28px;border:1px solid #1F2A3D;background:#0b1220}.toggle-thumb{width:22px;height:22px;background:#8a99ad}.work-zone-toggle input:checked+.toggle-track{background:#f59e0b38;border-color:#f59e0b;box-shadow:inset 0 0 0 1px #f59e0b33}.work-zone-toggle input:checked+.toggle-track .toggle-thumb{background:#f59e0b}.toggle-title,.latest-result h2,.log-section h2{color:#e6edf5;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.toggle-title{font-size:.82rem}.toggle-subtitle{color:#8a99ad;font-size:.78rem;font-weight:500}.top-actions{gap:12px}.work-zone-badge{border:1px solid #1F2A3D;border-radius:999px;background:#0b1220;color:#8a99ad;padding:7px 12px;font-size:.68rem;letter-spacing:.08em}.work-zone-badge.on{border-color:#f59e0b9e;background:#f59e0b26;color:#fcd34d}.report-button,.print-button{border-radius:10px;background:#f59e0b;color:#111827;box-shadow:0 12px 28px #f59e0b2e;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.report-button:hover,.print-button:hover{transform:translateY(-1px);box-shadow:0 16px 36px #f59e0b3d}.report-button{min-height:36px;padding:8px 14px;font-size:.76rem;letter-spacing:.02em}.video-container{border:1px solid #1F2A3D;border-radius:12px;background:#050814;box-shadow:inset 0 0 0 1px #ffffff05}.capture-indicator{top:12px;right:12px;border:1px solid rgba(245,158,11,.4);border-radius:999px;background:#f59e0beb;color:#111827;padding:6px 11px;font-size:.7rem;letter-spacing:.08em}.status-bar{margin-top:16px;color:#8a99ad;font-size:.82rem;font-weight:600}.status-dot.active{background:#16a34a;box-shadow:0 0 14px #16a34a99}.status-dot.error{background:#dc2626;box-shadow:0 0 14px #dc26268c}.latest-result h2,.log-section h2{margin-bottom:16px;font-size:.84rem}.ppe-checklist{gap:10px;margin-bottom:18px}.ppe-row{min-height:48px;border:1px solid #1F2A3D;border-radius:999px;background:#0b1220;padding:9px 12px 9px 14px}.ppe-row.present{border-color:#16a34a6b;background:#16a34a14}.ppe-row.missing{border-color:#dc262680;background:#dc262617}.ppe-label{color:#e6edf5;font-size:.78rem;letter-spacing:.03em;text-transform:uppercase}.ppe-state{width:26px;height:26px;font-size:.92rem}.ppe-row.present .ppe-state{background:#16a34a;color:#ecfdf5}.ppe-row.missing .ppe-state{background:#dc2626;color:#fef2f2;box-shadow:0 0 18px #dc262638}.ppe-row.pending .ppe-state{background:#1f2a3d;color:#8a99ad}.result-card{border:1px solid #1F2A3D;border-left-width:4px;border-radius:12px;padding:18px;background:#0b1220}.result-card.safe{border-color:#16a34a38;border-left-color:#16a34a;background:#16a34a12}.result-card.low{border-color:#8a99ad38;border-left-color:#8a99ad;background:#8a99ad14}.result-card.medium{border-color:#f59e0b3d;border-left-color:#f59e0b;background:#f59e0b17}.result-card.high{border-color:#dc26265c;border-left-color:#dc2626;background:#dc26261a;box-shadow:0 0 35px #dc262624}.result-status{margin-bottom:12px;font-size:1.2rem;font-weight:900;letter-spacing:.04em}.result-card.safe .result-status{color:#16a34a}.result-card.low .result-status{color:#8a99ad}.result-card.medium .result-status{color:#f59e0b}.result-card.high .result-status{color:#f87171}.result-details p{color:#cbd5e1;font-size:.9rem}.result-details strong{color:#e6edf5}.log-section{max-height:420px}.log-list{font-size:.82rem}.log-entry{border:1px solid #1F2A3D;border-left-width:3px;border-radius:10px;background:#0b1220;padding:11px 12px}.log-entry.safe{border-left-color:#16a34a}.log-entry.low{border-left-color:#8a99ad}.log-entry.medium{border-left-color:#f59e0b}.log-entry.high{border-left-color:#dc2626;box-shadow:0 0 24px #dc262614}.log-entry .time{color:#8a99ad;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.72rem}.log-entry .summary{color:#e6edf5;font-weight:600}.no-result{color:#8a99ad}.error-message,.report-error{border-color:#dc26268c;background:#dc26261f;color:#fca5a5}.shift-report{border-radius:12px;box-shadow:0 24px 70px #00000047}.app-footer{margin-top:24px;padding:16px 0 2px;border-top:1px solid #1F2A3D;color:#8a99ad;font-size:.72rem;font-weight:500;line-height:1.8;text-align:center}.app-footer a{color:#a8b3c4;text-decoration:none}.app-footer a:hover{color:#f59e0b}@media(max-width:900px){.app{padding:18px}.header{align-items:center;text-align:center}.ops-status-bar{justify-content:center}}@media print{@page{margin:.5in}*{print-color-adjust:exact;-webkit-print-color-adjust:exact}body{background:#fff;color:#000;font-size:10px}.header,.ops-status-bar,.main-content,.report-error,.print-button,.app-footer{display:none}.app{max-width:none;padding:0}.shift-report{position:relative;margin:0;padding:0 0 18px;border-radius:0;box-shadow:none;background:#fff}.shift-report:after{content:"Report ID: SOAI-" attr(id) " | Generated by Factory Guardian Safety Officer AI";position:absolute;left:0;right:0;bottom:0;padding-top:6px;border-top:1px solid #d8dee9;color:#66758a;font-size:8px;text-align:right}.report-heading{gap:10px;padding-bottom:8px;border-bottom-width:1px}.report-kicker{font-size:8px;letter-spacing:.06em}.report-heading h2{margin-top:2px;font-size:18px}.report-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}.report-meta div{padding:6px 7px;border-radius:4px}.report-meta span,.total-tile span{font-size:7px}.report-meta strong{margin-top:3px;font-size:9px}.report-section{margin-top:8px;padding:8px;border-radius:4px}.report-section h3{margin-bottom:5px;font-size:10px}.report-totals{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.total-tile{padding:6px 7px;border-radius:4px}.total-tile strong{margin-top:3px;font-size:18px}.report-breakdowns{display:grid;grid-template-columns:1fr 1fr;gap:8px}.breakdown-list li{padding:4px 0}.empty-report-note,.supervisor-summary{font-size:9px;line-height:1.35}.report-table{font-size:8px}.report-table th,.report-table td{padding:5px 6px}.report-table th{font-size:7px}.severity-pill{min-width:46px;padding:2px 5px;font-size:7px}.report-section,.report-meta div,.total-tile,.report-heading,.report-table tr{break-inside:avoid}}
