.doc-tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:0}.doc-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;top:1px}.doc-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.doc-tab.active{color:var(--accent-cyan);border-bottom-color:var(--accent-cyan)}.doc-tab-icon{font-size:16px}.doc-content-wrapper{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.doc-section{max-width:1400px}.doc-section-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 16px}.doc-subtitle{font-size:18px;font-weight:600;color:var(--text-primary);margin:32px 0 16px;padding-bottom:8px;border-bottom:1px solid var(--border)}.doc-badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.doc-badge{padding:6px 12px;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:600}.badge-react{border-color:var(--accent-cyan);color:var(--accent-cyan)}.badge-ts{border-color:var(--accent-blue);color:var(--accent-blue)}.badge-vite{border-color:var(--accent-purple);color:var(--accent-purple)}.badge-canvas{border-color:var(--accent-green);color:var(--accent-green)}.doc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.doc-card h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.doc-card p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0}.doc-card p+p{margin-top:12px}.doc-list{margin:12px 0 0;padding-left:20px}.doc-list li{font-size:14px;line-height:1.7;color:var(--text-secondary);margin:8px 0}.doc-list li strong{color:var(--accent-cyan);font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-top:16px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--accent-cyan);border-radius:var(--radius);padding:16px;text-align:center}.stat-value{font-size:28px;font-weight:700;color:var(--accent-cyan);line-height:1.2}.stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:6px}.diagram-box{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-card) 100%);border:2px solid var(--border);border-radius:var(--radius);padding:32px;margin:20px 0;overflow-x:auto;box-shadow:0 4px 12px #0000004d}.mermaid-rendered{display:flex;justify-content:center;align-items:center;min-height:600px;padding:40px}.mermaid-rendered svg{width:100%;min-width:800px;height:auto;max-width:1400px}.diagram-caption{margin:24px 0 0;padding-top:16px;border-top:1px solid var(--border);font-size:12px;font-style:italic;color:var(--accent-cyan);text-align:center;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.code-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin:16px 0;overflow-x:auto}.code-box code{display:block;color:var(--accent-green);font-family:Courier New,monospace;font-size:13px;line-height:1.6;white-space:pre}.module-card{background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--accent-yellow);border-radius:var(--radius);padding:20px;margin:20px 0}.module-card h4{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.module-card h5{font-size:14px;font-weight:600;color:var(--text-primary);margin:16px 0 8px}.module-card p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:8px 0}.module-card ul{margin:8px 0;padding-left:20px}.module-card li{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:6px 0}.module-badges{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0}.module-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}.badge-green{background:var(--accent-green)}.badge-blue{background:var(--accent-blue)}.badge-purple{background:var(--accent-purple)}.badge-orange{background:var(--accent-orange)}.doc-table{width:100%;border-collapse:collapse;margin:20px 0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.doc-table th{background:var(--bg-secondary);color:var(--text-primary);padding:12px;text-align:left;font-weight:600;font-size:13px;border-bottom:1px solid var(--border)}.doc-table td{padding:12px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.doc-table tr:last-child td{border-bottom:none}.doc-table code{background:var(--bg-secondary);padding:2px 6px;border-radius:3px;font-size:12px;color:var(--accent-cyan)}.status-pass{color:var(--accent-green);font-weight:600}.checklist{margin:16px 0}.checklist-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;margin:8px 0;background:var(--bg-card);border-left:3px solid var(--accent-green);border-radius:var(--radius-sm);font-size:13px;color:var(--text-secondary)}.checklist-item code{background:var(--bg-secondary);padding:2px 6px;border-radius:3px;font-size:12px;color:var(--accent-cyan)}@media(max-width:768px){.doc-tabs{overflow-x:auto;flex-wrap:nowrap}.doc-tab{flex-shrink:0}.stats-grid{grid-template-columns:repeat(2,1fr)}}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-card: #1c2128;--bg-hover: #21262d;--border: #30363d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681;--accent-blue: #58a6ff;--accent-cyan: #00d4ff;--accent-green: #3fb950;--accent-yellow: #d29922;--accent-orange: #db6d28;--accent-red: #f85149;--accent-purple: #bc8cff;--radius: 8px;--radius-sm: 4px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}code,.mono{font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:12px}.top-nav{display:flex;align-items:center;gap:0;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 16px;height:48px;position:sticky;top:0;z-index:100}.top-nav .logo{font-weight:700;font-size:15px;color:var(--accent-cyan);margin-right:24px;white-space:nowrap}.top-nav a{display:flex;align-items:center;height:48px;padding:0 16px;color:var(--text-secondary);font-size:13px;font-weight:500;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.top-nav a:hover{color:var(--text-primary);text-decoration:none}.top-nav a.active{color:var(--accent-cyan);border-bottom-color:var(--accent-cyan)}.top-nav a.docs-link{background:#ffd7001a;border-radius:6px;margin-left:8px;height:36px}.top-nav a.docs-link:hover{background:#ffd70033}.top-nav a.docs-link.active{background:#00d4ff26;color:var(--accent-cyan);border-bottom-color:transparent}.page-container{max-width:1600px;margin:0 auto;padding:16px}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--accent-cyan);border-radius:var(--radius);padding:14px 16px;text-align:center}.kpi-icon{font-size:20px;display:block;margin-bottom:4px}.kpi-value{font-size:28px;font-weight:700;line-height:1.2}.kpi-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.module-layout{display:grid;grid-template-columns:1fr 380px;gap:16px;margin-bottom:16px}@media(max-width:1100px){.module-layout{grid-template-columns:1fr}}.video-overlay-wrapper{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.video-overlay-wrapper canvas{border-radius:var(--radius)}.video-overlay-root{display:flex;flex-direction:column;gap:10px}.sim-controls{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px}.sim-time{font-size:12px;color:var(--text-secondary);min-width:120px;text-align:right}.sim-slider{flex:1;height:4px;appearance:none;background:var(--border);border-radius:2px}.sim-slider::-webkit-slider-thumb{appearance:none;width:12px;height:12px;background:var(--accent-cyan);border-radius:50%;cursor:pointer}.whitebox-inspector{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}.whitebox-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:600;font-size:13px}.whitebox-header:hover{background:var(--bg-hover)}.whitebox-toggle{color:var(--text-muted);font-size:11px}.whitebox-title{color:var(--accent-cyan)}.whitebox-body{padding:12px 14px;max-height:500px;overflow-y:auto}.whitebox-body::-webkit-scrollbar{width:6px}.whitebox-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.state-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid var(--border);font-size:12px}.state-row:last-child{border-bottom:none}.state-key{color:var(--text-secondary)}.state-val{font-family:monospace;color:var(--text-primary)}.state-val.green{color:var(--accent-green)}.state-val.red{color:var(--accent-red)}.state-val.yellow{color:var(--accent-yellow)}.state-val.cyan{color:var(--accent-cyan)}.threshold-slider{margin:6px 0}.threshold-slider label{display:flex;justify-content:space-between;font-size:12px;margin-bottom:2px}.threshold-label{color:var(--text-secondary)}.threshold-value{color:var(--accent-cyan);font-family:monospace}.threshold-slider input[type=range]{width:100%;height:4px;appearance:none;background:var(--border);border-radius:2px;outline:none}.threshold-slider input[type=range]::-webkit-slider-thumb{appearance:none;width:14px;height:14px;background:var(--accent-cyan);border-radius:50%;cursor:pointer}.event-log{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.event-log-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg-secondary)}.event-log-header h3{font-size:13px;font-weight:600;color:var(--text-primary)}.event-log-body{max-height:300px;overflow-y:auto}.event-log-body::-webkit-scrollbar{width:6px}.event-log-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.event-log-body table{width:100%;border-collapse:collapse;font-size:12px}.event-log-body th{text-align:left;padding:6px 10px;color:var(--text-muted);font-weight:500;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-card)}.event-log-body td{padding:5px 10px;border-bottom:1px solid var(--border)}.event-log-body tr:hover{background:var(--bg-hover)}.event-log-empty{padding:24px;text-align:center;color:var(--text-muted)}.event-detail{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-filename-hint{padding:6px 14px;font-size:11px;color:var(--text-muted);border-top:1px solid var(--border)}.event-filename-hint code{color:var(--accent-purple)}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;background:var(--bg-hover)}.badge-employee{background:#3fb95026;color:var(--accent-green)}.badge-product{background:#2196f326;color:var(--accent-blue)}.badge-openclose{background:#d2992226;color:var(--accent-yellow)}.badge-visitor{background:#bc8cff26;color:var(--accent-purple)}.btn-sm{padding:4px 12px;font-size:12px;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer}.btn-sm:hover{background:var(--border)}.btn-xs{padding:2px 6px;font-size:11px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer}.btn-xs:hover{color:var(--accent-cyan);border-color:var(--accent-cyan)}.json-preview{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;font-family:monospace;font-size:11px;white-space:pre-wrap;max-height:200px;overflow-y:auto;color:var(--accent-green)}.gauge-bar{position:relative;height:24px;background:var(--bg-primary);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);margin:8px 0}.gauge-fill{height:100%;transition:width .2s ease-out;border-radius:var(--radius-sm)}.gauge-markers{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.gauge-marker{position:absolute;top:0;width:2px;height:100%;background:var(--accent-red)}.gauge-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.inspector-column{max-height:calc(100vh - 120px);overflow-y:auto}.inspector-column::-webkit-scrollbar{width:6px}.inspector-column::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.section-heading{font-size:18px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.section-desc{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:16px;margin-top:16px}.overview-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.overview-card h3{font-size:15px;margin-bottom:8px;color:var(--accent-cyan)}.overview-card p{font-size:13px;color:var(--text-secondary);line-height:1.6}.overview-card .link-btn{display:inline-block;margin-top:12px;padding:6px 16px;background:#00d4ff1a;color:var(--accent-cyan);border:1px solid rgba(0,212,255,.3);border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer}.overview-card .link-btn:hover{background:#00d4ff33;text-decoration:none}.prox-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px}.prox-indicator.active{background:var(--accent-green)}.prox-indicator.inactive{background:var(--border)}.video-selector{margin-bottom:12px}.video-selector select{padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px}.state-tag{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:700}.state-tag.open{background:#3fb95033;color:var(--accent-green)}.state-tag.closed{background:#f8514933;color:var(--accent-red)}.state-tag.init{background:#8b949e33;color:var(--text-secondary)}
