:root{color-scheme:dark;--bg: #07101f;--panel: rgba(0, 0, 0, .34);--panel-strong: rgba(25, 25, 28, .48);--panel-line: rgba(255, 255, 255, .14);--text: rgba(255, 255, 255, .94);--muted: rgba(255, 255, 255, .58);--soft: rgba(255, 255, 255, .78);--green: #26e7a6;--green-strong: #10b981;--yellow: #ffcd7d;--red: #f43f5e;--box-red: #ef4444}*{box-sizing:border-box}html,body{width:100%;height:100%;margin:0;overflow:hidden;overscroll-behavior:none;background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}#app{width:100%;height:100%}button{border:0;font:inherit;color:inherit;-webkit-tap-highlight-color:transparent}.camera-shell{position:relative;width:100vw;height:100dvh;min-height:100dvh;overflow:hidden;background:#07101f;color:var(--text);isolation:isolate;touch-action:none;-webkit-user-select:none;user-select:none}.camera-video,.fallback-scene,.overlay-canvas,.frame-canvas,.camera-dim{position:absolute;inset:0;width:100%;height:100%}.camera-video{z-index:1;object-fit:cover;background:#07101f;transform-origin:center center;will-change:transform}.fallback-scene{z-index:0;display:grid;place-items:center;background:radial-gradient(circle at 50% 34%,rgba(255,255,255,.1),transparent 22%),linear-gradient(155deg,#0b1e33,#0b1726 52%,#08101d)}.fallback-scene.active{z-index:1}.scene-wall{position:relative;width:min(86vw,420px);aspect-ratio:3 / 4;overflow:hidden;border:1px solid rgba(255,255,255,.08);border-radius:8px;background:linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px) 0 0 / 34px 34px,linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px) 0 0 / 34px 34px,#14202e;box-shadow:0 26px 80px #00000061}.scene-light,.scene-sign,.scene-extinguisher,.scene-hydrant,.scene-smoke{position:absolute}.scene-light{left:18%;top:11%;width:34%;height:10%;border-radius:4px;background:#dce9f7;box-shadow:0 0 36px #dce9f747}.scene-sign{right:11%;top:20%;width:34%;height:12%;border-radius:3px;background:linear-gradient(90deg,transparent 22%,rgba(255,255,255,.88) 22% 34%,transparent 34% 48%,rgba(255,255,255,.9) 48% 56%,transparent 56%),#12b981}.scene-extinguisher{left:16%;bottom:12%;width:17%;height:34%;border-radius:22px 22px 8px 8px;background:linear-gradient(#ef4444,#b91c1c)}.scene-extinguisher:before{content:"";position:absolute;left:26%;top:-13%;width:48%;height:14%;border-radius:8px 8px 2px 2px;background:#d8dde6}.scene-extinguisher span{position:absolute;left:16%;top:34%;width:68%;height:17%;border-radius:3px;background:#f8fafc}.scene-hydrant{right:12%;bottom:12%;width:38%;height:30%;border:5px solid #dc2626;border-radius:6px;background:#7f1d1d57}.scene-hydrant:after{content:"";position:absolute;inset:17% 16%;border:4px solid rgba(248,113,113,.72);border-radius:50%}.scene-smoke{right:15%;top:8%;width:17%;aspect-ratio:1;border-radius:50%;background:#e5e7eb;box-shadow:inset 0 0 0 9px #aeb7c2}.overlay-canvas{z-index:4;pointer-events:none}.frame-canvas{display:none}.camera-dim{z-index:2;pointer-events:none;background:linear-gradient(to bottom,rgba(3,8,18,.22),transparent 18%,transparent 72%,rgba(3,8,18,.42)),#03081214}.start-panel{position:absolute;z-index:12;inset:auto 18px calc(18px + env(safe-area-inset-bottom)) 18px;display:grid;grid-template-columns:1fr;gap:16px;justify-items:stretch}.start-copy{display:grid;gap:4px;padding:0 2px;text-shadow:0 1px 12px rgba(0,0,0,.62)}.start-copy p,.start-copy h1{margin:0}.start-copy p{color:#ffffffb8;font-size:13px;font-weight:700}.start-copy h1{color:#fff;font-size:32px;font-weight:900;letter-spacing:0}.start-copy span{color:#ffffffc2;font-size:13px}.start-button{display:inline-grid;grid-template-columns:auto auto;justify-content:center;align-items:center;gap:9px;min-height:56px;border-radius:999px;background:var(--green-strong);box-shadow:0 16px 40px #10b9814d;color:#fff;font-size:18px;font-weight:900}.runtime-panel{position:absolute;z-index:10;top:max(12px,calc(env(safe-area-inset-top) + 10px));overflow:hidden;border:1px solid var(--panel-line);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.checklist-panel{left:12px;width:min(45vw,232px);min-width:150px;max-height:36dvh;padding:8px;border-radius:10px;background:#080e1980;box-shadow:0 10px 28px #0000002e}.checklist-panel header,.gate-panel header{display:flex;align-items:center;justify-content:space-between;gap:8px}.checklist-panel header strong{color:#ffffffc7;font-size:10px;font-weight:800}.checklist-panel header span{flex:none;min-width:34px;text-align:right;color:#00d29c;font-size:10px;font-weight:900}.checklist-scroll{display:grid;max-height:calc(36dvh - 28px);gap:5px;margin-top:7px;overflow:auto;scrollbar-width:none}.checklist-scroll::-webkit-scrollbar,.log-container::-webkit-scrollbar{display:none}.target-row{position:relative;display:grid;grid-template-columns:18px minmax(0,1fr) auto;align-items:center;gap:6px;min-height:28px;padding:4px 6px 4px 5px;border:1px solid rgba(255,255,255,.07);border-radius:8px;background:#ffffff0e;color:#ffffffbd;font-size:10.5px;line-height:1.2;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease}.target-row.child{margin-left:14px;grid-template-columns:18px minmax(0,1fr) auto;background:#ffffff0a}.target-row.child:before{content:"";position:absolute;left:-8px;top:-6px;width:8px;height:20px;border-bottom:1px solid rgba(255,255,255,.18);border-left:1px solid rgba(255,255,255,.18);border-radius:0 0 0 5px}.target-row.active{border-color:#ffffff38;background:#ffffff14;color:#fff}.target-row.detecting{border-color:#f59e0b94;background:#f59e0b29;color:#fff}.target-row.success,.target-row.done{border-color:#00d29c3d;background:#00d29c1a;color:var(--green)}.target-index{display:grid;width:18px;height:18px;place-items:center;border-radius:50%;background:#ffffff1c;color:#ffffff9e;font-size:9px;font-weight:800}.target-row.active .target-index{background:#ffffff29;color:#fff}.target-row.detecting .target-index{background:#f59e0b42;color:#fbbf24}.target-row.success .target-index,.target-row.done .target-index{background:#26e7a638;color:var(--green)}.target-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:800}.target-state{min-width:46px;padding:2px 5px;border-radius:999px;background:#ffffff14;color:#ffffff7a;font-size:9px;font-weight:800;text-align:center}.target-row.active .target-state{background:#ffffff1a;color:#ffffffb8}.target-row.detecting .target-state{background:#f59e0b33;color:#fbbf24}.target-row.success .target-state,.target-row.done .target-state{background:#26e7a62e;color:#79efa8}.gate-panel{right:12px;width:min(44vw,230px);min-width:158px;padding:7px;border-radius:8px;background:#19191c52}.gate-panel header{height:21px}.gate-panel header strong{color:#ffffffdb;font-size:11px;font-weight:500}.gate-panel header span{color:var(--yellow);font-size:9.5px}.gate-panel dl{display:grid;gap:0;margin:0}.gate-panel dl div{display:grid;grid-template-columns:52px 1fr;align-items:center;min-height:20px}.gate-panel dt,.gate-panel dd{overflow:hidden;margin:0;text-overflow:ellipsis;white-space:nowrap;font-size:9.5px;line-height:20px}.gate-panel dt{color:#cdcdce}.gate-panel dd{color:var(--yellow)}.gate-panel dd.pass{color:#79efa8}.log-container{position:absolute;z-index:9;right:0;bottom:calc(92px + env(safe-area-inset-bottom));left:0;height:234px;overflow:auto;background:linear-gradient(to bottom,transparent,rgba(3,8,18,.28),transparent);scrollbar-width:none}.log-panel{display:flex;min-height:100%;flex-direction:column;justify-content:flex-end;gap:4px;padding:10px 14px}.log-text,.photo-log{border-radius:10px;background:#0000002e;color:#ffffffdb;font-size:11px;line-height:1.45}.log-text{width:fit-content;max-width:100%;min-height:28px;padding:5px 10px}.photo-log{display:grid;grid-template-columns:64px 1fr;gap:8px;align-items:center;min-height:48px;padding:6px 10px;background:#0003}.photo-log button{width:64px;height:36px;overflow:hidden;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:#ffffff14;cursor:pointer}.photo-log img{width:100%;height:100%;object-fit:cover;display:block}.bottom-actions{position:absolute;z-index:14;right:14px;bottom:calc(12px + env(safe-area-inset-bottom));left:14px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;align-items:center;min-height:62px;padding:7px;border:1px solid rgba(255,255,255,.13);border-radius:18px;background:#03081294;box-shadow:0 12px 34px #0000004d;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.action-button{position:relative;display:flex;justify-content:center;align-items:center;gap:6px;min-width:0;height:48px;padding:0 8px;border-radius:13px;color:#fff;font-size:13px;font-weight:900;box-shadow:none;white-space:nowrap}.action-button:disabled{cursor:not-allowed;opacity:.46}.action-button.ghost{border:1px solid rgba(255,255,255,.22);background:#ffffffe6;color:#101827}.action-button.list{border:1px solid rgba(37,99,235,.26);background:#eff3fff2;color:#1d4ed8}.action-button.list.pulsing{animation:capture-list-pulse .46s ease}.action-button.list em{position:absolute;top:5px;right:7px;display:grid;min-width:16px;height:16px;place-items:center;padding:0 4px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;font-style:normal;line-height:1}.action-button.danger{border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,#fb7185,var(--red))}.camera-mark{position:relative;width:21px;height:16px;border:2px solid currentColor;border-radius:5px}.camera-mark:before{content:"";position:absolute;left:4px;top:-6px;width:7px;height:5px;border:2px solid currentColor;border-bottom:0;border-radius:4px 4px 0 0}.camera-mark:after{content:"";position:absolute;left:50%;top:50%;width:6px;height:6px;border:2px solid currentColor;border-radius:50%;transform:translate(-50%,-50%)}.list-mark{position:relative;width:18px;height:18px;border:2px solid currentColor;border-radius:5px}.list-mark:before,.list-mark:after{content:"";position:absolute;left:3px;right:3px;height:2px;border-radius:999px;background:currentColor}.list-mark:before{top:5px}.list-mark:after{top:10px}.capture-flyaway-layer{position:fixed;inset:0;z-index:25;pointer-events:none}.capture-flyaway{position:fixed;overflow:hidden;border:1px solid rgba(255,255,255,.5);border-radius:14px;background:#0f172abf;box-shadow:0 18px 52px #0000005c,0 0 0 1px #2563eb29;transform-origin:center;animation:capture-fly-to-list .76s cubic-bezier(.18,.86,.2,1) forwards;will-change:transform,opacity,filter}.capture-flyaway img{display:block;width:100%;height:100%;object-fit:cover}.capture-flyaway:after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.32),transparent 38%),radial-gradient(circle at 50% 50%,transparent 48%,rgba(37,99,235,.24));opacity:.72}.captured-sheet-layer{position:fixed;inset:0;z-index:26;display:flex;align-items:flex-end;justify-content:center;background:#0308126b;color:#172033}.captured-sheet{width:100%;height:65dvh;max-height:65dvh;overflow:hidden;border-radius:22px 22px 0 0;background:#f8fafc;box-shadow:0 -22px 60px #0000005c;transition:transform .2s ease;touch-action:pan-y}.captured-sheet.dragging{transition:none}.sheet-drag-zone{display:grid;height:28px;place-items:center;cursor:grab;touch-action:none}.sheet-drag-handle{width:44px;height:5px;border-radius:999px;background:#cbd5e1}.captured-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px 12px}.captured-sheet-header div{display:grid;gap:2px}.captured-sheet-header strong{color:#111827;font-size:18px;font-weight:950}.captured-sheet-header span{color:#64748b;font-size:12px;font-weight:800}.captured-list{height:calc(65dvh - 76px);overflow:auto;padding:0 12px 18px;overscroll-behavior:contain}.captured-card{display:grid;margin-bottom:12px;overflow:hidden;padding:0;border:1px solid #e1e8f2;border-radius:14px;background:#fff;box-shadow:0 12px 28px #0f172a0f}.captured-photo{position:relative;width:100%;height:156px;overflow:hidden;border:0;border-radius:14px 14px 0 0;background:#f1f5f9}.captured-photo img{display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit}.captured-photo span{position:absolute;top:8px;right:8px;padding:4px 7px;border-radius:999px;background:#ffffffeb;font-size:10px;font-weight:900}.captured-photo span.manual{color:#2563eb}.captured-photo span.auto{color:#10b981}.captured-analysis{display:grid;gap:8px;padding:10px 12px 12px;background:#fff}.analysis-bar{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:8px;align-items:center;min-height:28px}.analysis-bar .analysis-label{color:#64748b;font-size:11px;font-weight:800}.analysis-bar strong{overflow:hidden;color:#111827;font-size:14px;font-weight:950;text-overflow:ellipsis;white-space:nowrap}.analysis-tags{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px;min-width:58px}.analysis-tags span{max-width:100%;padding:4px 8px;overflow:hidden;border:1px solid rgba(37,99,235,.14);border-radius:999px;background:#2563eb14;color:#2563eb;font-size:11px;font-weight:900;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.analysis-tags span.abnormal{border-color:#e11d4829;background:#e11d481a;color:#e11d48}.analysis-tags span.normal{border-color:#10b98129;background:#10b9811a;color:#059669}.analysis-tags span.invalid{border-color:#64748b2e;background:#64748b1f;color:#64748b}.hazard-detail-list{display:grid;gap:8px;padding-top:2px}.hazard-detail-list section{padding:9px 10px;border:1px solid rgba(225,29,72,.12);border-radius:10px;background:#fff1f2b3}.hazard-detail-list dl{display:grid;gap:7px;margin:0}.hazard-detail-list dl div{display:grid;grid-template-columns:64px minmax(0,1fr);gap:8px}.hazard-detail-list dt{color:#9f1239;font-size:11px;font-weight:900}.hazard-detail-list dd{min-width:0;margin:0;color:#334155;font-size:12px;font-weight:750;line-height:1.45;word-break:break-word}.captured-empty{display:grid;height:calc(65dvh - 76px);place-content:center;gap:8px;padding:20px;text-align:center}.captured-empty strong{color:#111827;font-size:17px;font-weight:950}.captured-empty span{color:#64748b;font-size:13px;line-height:1.5}.preview-dialog{position:fixed;inset:0;z-index:30;width:100vw;height:100dvh;max-width:none;max-height:none;margin:0;padding:0;border:0;background:#030812eb}.preview-dialog::backdrop{background:#030812e0}.preview-dialog img{position:absolute;inset:50% auto auto 50%;max-width:calc(100vw - 24px);max-height:calc(100dvh - 92px);border-radius:8px;object-fit:contain;transform:translate(-50%,-50%);box-shadow:0 24px 80px #0000008a}.dialog-close{position:absolute;z-index:31;top:max(18px,env(safe-area-inset-top));right:18px;display:grid;width:38px;height:38px;place-items:center;border-radius:50%;background:#ffffff24;color:#fff;font-size:24px}.toast-stack{position:absolute;z-index:28;top:max(18px,env(safe-area-inset-top));right:64px;left:64px;display:grid;justify-items:center;gap:8px;pointer-events:none}.toast{max-width:min(420px,100%);padding:9px 13px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#00000075;color:#fff;font-size:13px;line-height:1.45;box-shadow:0 10px 34px #0000003d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hidden{display:none!important}.debug-console{position:fixed;right:14px;bottom:calc(92px + env(safe-area-inset-bottom));z-index:60;color:#ecfdf5;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;pointer-events:none}.debug-console-button{position:relative;display:inline-flex;align-items:center;gap:6px;height:38px;padding:0 12px;border-radius:999px;background:#16a34a;color:#fff;font-size:12px;font-weight:900;box-shadow:0 10px 26px #16a34a5c;pointer-events:auto}.debug-console-button span{display:grid;min-width:18px;height:18px;place-items:center;padding:0 5px;border-radius:999px;background:#ffffff38;font-size:11px}.debug-console-panel{position:absolute;right:0;bottom:48px;width:min(420px,calc(100vw - 24px));max-height:min(58dvh,520px);overflow:hidden;border:1px solid rgba(34,197,94,.36);border-radius:12px;background:#020617f0;box-shadow:0 18px 60px #0000006b;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);pointer-events:auto}.debug-console-panel header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid rgba(34,197,94,.18)}.debug-console-panel header button{height:28px;padding:0 10px;border-radius:999px;background:#22c55e29;color:#86efac;font-size:12px}.debug-console-list{max-height:calc(min(58dvh,520px) - 49px);overflow:auto;padding:10px}.debug-console-list article{overflow:hidden;margin-bottom:10px;border:1px solid rgba(148,163,184,.2);border-radius:10px;background:#0f172ac2}.debug-console-list article>div{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-bottom:1px solid rgba(148,163,184,.12)}.debug-console-list article>div>span{display:grid;min-width:0;gap:2px}.debug-console-list article>div>button{flex:0 0 auto;height:26px;padding:0 9px;border-radius:999px;background:#22c55e29;color:#86efac;font-size:11px;font-weight:900}.debug-console-list time{color:#94a3b8;font-size:11px}.debug-console-list pre{max-height:260px;margin:0;overflow:auto;padding:10px;color:#bbf7d0;font-size:11px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.debug-console-panel p{margin:0;padding:16px;color:#94a3b8;font-size:12px}@keyframes capture-fly-to-list{0%{opacity:0;transform:translateZ(0) scale(.92);filter:saturate(1) brightness(1)}12%{opacity:1;transform:translate3d(0,-8px,0) scale(1)}72%{opacity:1;filter:saturate(1.04) brightness(1.04)}to{opacity:.18;transform:translate3d(var(--fly-x),var(--fly-y),0) scale(var(--fly-scale));filter:saturate(.9) brightness(1.15)}}@keyframes capture-list-pulse{0%,to{transform:scale(1);box-shadow:none}45%{transform:scale(1.04);box-shadow:0 0 0 3px #2563eb2e,0 10px 24px #2563eb38}}@media(min-width:680px){.checklist-panel,.gate-panel{width:220px}.start-panel{right:28px;left:28px;max-width:520px}.bottom-actions{right:50%;left:auto;width:min(420px,calc(100vw - 28px));transform:translate(50%)}}@media(max-width:359px){.checklist-panel{left:8px;min-width:128px}.gate-panel{right:8px;min-width:146px}.gate-panel dl div{grid-template-columns:48px 1fr}.bottom-actions{right:10px;left:10px}.action-button{height:50px;font-size:13px}}@media(orientation:landscape)and (max-height:560px){.camera-shell{min-height:420px}.runtime-panel{top:12px}.checklist-panel,.gate-panel{max-height:calc(100dvh - 126px)}.log-container{height:118px;bottom:78px}.bottom-actions{right:18px;bottom:8px;left:18px;min-height:60px}.action-button{height:46px}.start-panel{grid-template-columns:1fr 210px;align-items:end}}
