*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0c12;--surface: #0f1118;--surface-2: #141720;--border: rgba(255, 255, 255, .06);--border-2: rgba(255, 255, 255, .1);--accent: #4f8ef7;--accent-dim: rgba(79, 142, 247, .12);--accent-glow: rgba(79, 142, 247, .2);--accent-2: #4fd1c5;--accent-pid: #f7904f;--accent-pid-dim: rgba(247, 144, 79, .13);--text: #d8dae8;--text-muted: #4a5068;--text-dim: #6b7494;--radius: 8px;--radius-sm: 5px;--mono: "Space Mono", monospace;--sans: "Space Grotesk", sans-serif;--panel-w: 340px}html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased}#app{width:100vw;height:100vh;display:flex}#viewer-wrap{position:relative;flex:1;min-width:0;display:flex;flex-direction:row;overflow:hidden}#viewer-container{position:relative;flex:1;min-width:0;background:var(--bg);overflow:hidden}#viewer-container>canvas{position:absolute;inset:0;width:100%!important;height:100%!important}#viewer-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;pointer-events:none;z-index:1}#placeholder-logo{width:180px;height:180px;object-fit:contain;opacity:.18;filter:grayscale(.3)}.placeholder-hint{font-family:var(--mono);font-size:11px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}#right-panel{position:relative;height:100vh;width:var(--panel-w);min-width:280px;max-width:70vw;background:var(--surface);border-left:1px solid var(--border);overflow:hidden;z-index:50;flex-shrink:0;display:flex;flex-direction:column}#right-panel>.panel-header{flex-shrink:0;border-radius:0;border-left:none;border-right:none;border-top:none;margin:0;padding:14px 16px 12px;background:var(--surface);position:relative;z-index:5}#right-panel>.panel-header:before{border-radius:0}#right-panel-inner{flex:1;overflow-y:auto;padding:12px 16px 24px;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:var(--border-2) transparent}#right-panel-inner::-webkit-scrollbar{width:4px}#right-panel-inner::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:2px}#panel-resize-handle{position:absolute;top:0;left:0;width:4px;height:100%;cursor:ew-resize;z-index:10;background:transparent;transition:background .2s}#panel-resize-handle:hover,#panel-resize-handle.dragging{background:#4f8ef74d}.panel-header{padding:14px 14px 12px;border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(135deg,#4f8ef712,#4fd1c50a);position:relative;overflow:hidden}.panel-header:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--accent),var(--accent-2));opacity:.65}.panel-header-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.panel-title{font-family:var(--sans);font-size:18px;font-weight:600;letter-spacing:-.02em;color:var(--text)}.title-accent{color:var(--accent)}.panel-sub{margin-top:4px;font-family:var(--mono);font-size:10px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.sub-accent{color:var(--accent-2);letter-spacing:.04em}#panel-logo{height:30px;width:auto;max-width:80px;object-fit:contain;opacity:.9;flex-shrink:0;display:block}.panel-section{border:1px solid var(--border);border-radius:var(--radius);padding:12px;background:#ffffff03;display:flex;flex-direction:column;gap:10px}.section-label{font-family:var(--mono);font-size:10px;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;gap:6px}.section-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}.section-header:hover .chevron{color:var(--accent)}.chevron{color:var(--text-muted);transition:transform .2s,color .2s;flex-shrink:0}.section-body{display:flex;flex-direction:column;gap:10px;overflow:hidden}.collapsible.collapsed .section-body{display:none}.collapsible.collapsed .chevron{transform:rotate(-90deg)}.collapsible.collapsed{gap:0}.count-chip{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(79,142,247,.25);border-radius:3px;padding:1px 6px;font-size:9px;font-family:var(--mono);letter-spacing:.04em}.badge-soon{background:#4fd1c51a;color:var(--accent-2);border:1px solid rgba(79,209,197,.2);border-radius:3px;padding:1px 5px;font-size:9px;letter-spacing:.04em}.kv{display:grid;grid-template-columns:80px 1fr;gap:8px;align-items:start}.k{font-family:var(--mono);font-size:10px;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;padding-top:1px}.v{font-family:var(--sans);font-size:12px;color:var(--text);word-break:break-all;line-height:1.5}.v.mono{font-family:var(--mono);font-size:10px}#top-bar{position:absolute;top:0;left:0;right:0;height:56px;display:flex;align-items:center;gap:14px;padding:0 18px;background:transparent;z-index:100;pointer-events:none}#logo-wrap{pointer-events:none;display:flex;align-items:baseline;gap:5px}.logo-text{font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.06em;color:var(--text)}.logo-version{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:.04em;background:var(--accent-dim);border:1px solid rgba(79,142,247,.25);border-radius:3px;padding:1px 5px}#btn-load{pointer-events:all;display:inline-flex;align-items:center;gap:7px;padding:7px 14px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-sm);color:var(--text);font-family:var(--sans);font-size:13px;font-weight:500;cursor:pointer;transition:border-color .2s,background .2s,color .2s;white-space:nowrap;user-select:none}#btn-load:hover{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}#btn-load:active{transform:scale(.98)}#ifc-file{display:none}#model-info{pointer-events:none;display:flex;align-items:center;gap:6px}#model-info.hidden{display:none}#model-name-badge{font-family:var(--mono);font-size:10px;color:var(--accent-2);border:1px solid rgba(79,209,197,.2);background:#4fd1c512;border-radius:3px;padding:2px 8px;letter-spacing:.04em}#loading-spinner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#0a0c12d1;backdrop-filter:blur(6px);z-index:200}#loading-spinner.hidden{display:none}.spinner-ring{width:40px;height:40px;border:2px solid var(--border-2);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-label{font-family:var(--mono);font-size:11px;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}.scene-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}.toggle-label input[type=checkbox]{display:none}.toggle-track{width:30px;height:16px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border-2);position:relative;transition:background .2s,border-color .2s;flex-shrink:0}.toggle-thumb{position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:var(--text-muted);transition:transform .2s,background .2s}input[type=checkbox]:checked+.toggle-track{background:var(--accent-dim);border-color:#4f8ef759}input[type=checkbox]:checked+.toggle-track .toggle-thumb{transform:translate(14px);background:var(--accent)}.toggle-text{font-family:var(--mono);font-size:10px;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase}.color-pill{display:flex;align-items:center;justify-content:center;width:28px;height:20px;border-radius:4px;border:1px solid var(--border-2);overflow:hidden;cursor:pointer;flex-shrink:0}.color-pill input[type=color]{width:32px;height:24px;border:none;background:none;cursor:pointer;transform:scale(1.5)}#split-divider{flex-shrink:0;width:6px;height:100%;position:relative;cursor:ew-resize;z-index:10;display:flex;align-items:center;justify-content:center;background:transparent;transition:background .15s}#split-divider:hover,#split-divider.dragging{background:#4f8ef726}#split-divider-line{width:2px;height:40px;border-radius:1px;background:var(--border-2);transition:background .15s,height .15s}#split-divider:hover #split-divider-line,#split-divider.dragging #split-divider-line{background:var(--accent);height:60px}#split-divider.hidden{display:none}#viewer-wrap{display:flex;flex-direction:row;overflow:hidden}#viewer-wrap #viewer-container{flex:1;min-width:0;position:relative;transition:flex .3s ease}#viewer-wrap.split-active #viewer-container{flex:1}#svg-pane{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--surface);border-left:1px solid var(--border-2);overflow:hidden;animation:fadeIn .25s ease}#svg-pane.hidden{display:none}@keyframes fadeIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}#svg-pane-header{flex-shrink:0;display:flex;flex-direction:column;gap:5px;padding:8px 14px;background:var(--surface-2);border-bottom:1px solid var(--border)}.svg-header-top{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.svg-hints{display:flex;gap:12px;flex-wrap:wrap}.svg-hint{font-family:var(--mono);font-size:9px;color:var(--text-muted);letter-spacing:.03em;background:#ffffff0a;border:1px solid var(--border);border-radius:3px;padding:2px 6px}#svg-pane-inner{flex:1;overflow:hidden;display:flex;flex-direction:column;position:relative}#svg-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);text-align:center;z-index:2}#svg-viewport{flex:1;overflow:hidden;display:none;position:relative;background:#fff;cursor:default;user-select:none}#svg-canvas{position:absolute;top:0;left:0;width:100%;height:100%;transform-origin:0 0;will-change:transform}#svg-canvas svg{width:100%;height:100%;display:block}#svg-canvas svg text.pid-highlight{fill:#ff6b35!important;font-weight:700;filter:drop-shadow(0 0 4px rgba(255,107,53,.9))}#svg-notfound{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;background:#f7904f26;border:1px solid rgba(247,144,79,.35);border-radius:var(--radius-sm);padding:6px 12px;color:var(--accent-pid);font-family:var(--mono);font-size:10px;letter-spacing:.04em;white-space:nowrap;z-index:3;animation:fadeIn .2s ease}#svg-notfound.hidden{display:none}.scene-row--split{padding-top:4px;border-top:1px solid var(--border);margin-top:2px}@media(max-width:768px){#viewer-wrap.split-active{flex-direction:column}#viewer-wrap.split-active #viewer-container{height:50%}#svg-pane{height:50%;border-left:none;border-top:1px solid var(--border-2)}}.rp-empty-hint{font-family:var(--mono);font-size:10px;color:var(--text-muted);text-align:center;padding:10px 0 4px;letter-spacing:.05em}.rp-description{font-size:11px;color:var(--text-dim);line-height:1.55;max-height:72px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-2) transparent}.pid-tag-inline{font-family:var(--mono);font-size:10px;color:var(--text-dim);transition:color .2s}.pid-tag-inline.has-value{color:var(--accent-pid);background:var(--accent-pid-dim);border:1px solid rgba(247,144,79,.25);border-radius:3px;padding:1px 6px;display:inline-block}.rp-url-wrap{display:flex;align-items:center}.rp-link-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;background:var(--accent-dim);border:1px solid rgba(79,142,247,.3);border-radius:var(--radius-sm);color:var(--accent);font-family:var(--sans);font-size:11px;font-weight:500;text-decoration:none;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.rp-link-btn:hover{background:#4f8ef733;border-color:#4f8ef78c}.rp-link-btn--pano{background:#4fd1c51a;border-color:#4fd1c540;color:var(--accent-2)}.rp-link-btn--pano:hover{background:#4fd1c533;border-color:#4fd1c580}.rp-url-btn.hidden{display:none}.search-wrap{display:flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-muted)}.search-wrap input{flex:1;background:none;border:none;outline:none;color:var(--text);font-family:var(--sans);font-size:12px}.search-wrap input::placeholder{color:var(--text-muted)}.fb-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;display:inline-block;transition:background .3s,box-shadow .3s}.fb-dot--off{background:var(--text-muted)}.fb-dot--on{background:#34d399;box-shadow:0 0 6px #34d399b3;animation:fb-pulse 1.5s ease-in-out infinite}@keyframes fb-pulse{0%,to{box-shadow:0 0 4px #34d39999}50%{box-shadow:0 0 10px #34d399e6}}.fb-info{display:flex;flex-direction:column;gap:5px;padding:8px 10px;background:#34d3990d;border:1px solid rgba(52,211,153,.15);border-radius:var(--radius-sm)}.fb-info.hidden{display:none}.fb-info-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.fb-info-label{font-family:var(--mono);font-size:9px;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.fb-info-val{font-family:var(--mono);font-size:10px;color:var(--text)}.fb-log-wrap{display:flex;flex-direction:column;gap:6px}.fb-log-wrap.hidden{display:none}.fb-log-header{display:flex;align-items:center;justify-content:space-between}.fb-log-title{font-family:var(--mono);font-size:9px;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.fb-log-actions{display:flex;gap:5px}.fb-log-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:3px;color:var(--text-dim);font-family:var(--mono);font-size:9px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.fb-log-btn:hover{background:var(--accent-dim);border-color:#4f8ef74d;color:var(--accent)}.fb-log-btn--clear:hover{background:#f7904f1f;border-color:#f7904f4d;color:var(--accent-pid)}.fb-log{max-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:3px;padding:6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);scrollbar-width:thin;scrollbar-color:var(--border-2) transparent}.fb-log::-webkit-scrollbar{width:3px}.fb-log::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:2px}.fb-log-empty{font-family:var(--mono);font-size:9px;color:var(--text-muted);text-align:center;padding:8px 0;letter-spacing:.04em}.fb-log-entry{display:flex;align-items:baseline;gap:6px;font-family:var(--mono);font-size:9px;line-height:1.5;animation:fadeIn .2s ease}.fb-log-time{color:var(--text-muted);flex-shrink:0}.fb-log-tag{font-weight:700;flex-shrink:0;min-width:80px}.fb-log-msg{color:var(--text-dim)}.fb-log-entry--on .fb-log-tag{color:#f44}.fb-log-entry--off .fb-log-tag{color:#34d399}#svg-canvas svg text.pid-disassemble{fill:#f22!important;font-weight:700;filter:drop-shadow(0 0 3px rgba(255,34,34,.7))}.dl-hint{font-family:var(--mono);font-size:10px;color:var(--text-muted);letter-spacing:.04em}.dl-list{display:flex;flex-direction:column;gap:6px}.dl-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff03;text-decoration:none;cursor:pointer;transition:background .15s,border-color .15s}.dl-row:hover{background:var(--accent-dim);border-color:#4f8ef74d}.dl-row:hover .dl-arrow{color:var(--accent)}.dl-icon{width:34px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.06em;flex-shrink:0}.dl-icon-ifc{background:#4f8ef726;color:var(--accent);border:1px solid rgba(79,142,247,.25)}.dl-icon-dwg{background:#ffb4501f;color:#f6a623;border:1px solid rgba(255,180,80,.2)}.dl-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.dl-name{font-family:var(--sans);font-size:12px;font-weight:500;color:var(--text)}.dl-meta{font-family:var(--mono);font-size:9px;color:var(--text-muted);letter-spacing:.04em}.dl-arrow{color:var(--text-muted);flex-shrink:0;transition:color .15s}.dl-qr-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff03;cursor:pointer;transition:background .15s,border-color .15s;margin-top:6px}.dl-qr-row:hover{background:var(--accent-dim);border-color:#4f8ef74d}.dl-qr-row:hover .dl-arrow{color:var(--accent)}.dl-icon-qr{width:34px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;background:#4fd1c51f;color:var(--accent-2);border:1px solid rgba(79,209,197,.2);flex-shrink:0}.qr-lightbox{position:fixed;inset:0;z-index:600;display:flex;align-items:center;justify-content:center}.qr-lightbox.hidden{display:none}.qr-lightbox-backdrop{position:absolute;inset:0;background:#05060ae0;backdrop-filter:blur(6px)}.qr-lightbox-content{position:relative;max-width:92vw;max-height:92vh;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.qr-lightbox-img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:var(--radius);box-shadow:0 32px 80px #000000b3;display:block}.qr-lightbox-close{position:absolute;top:-14px;right:-14px;width:34px;height:34px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,border-color .15s;z-index:10}.qr-lightbox-close:hover{background:#ffffff1a;border-color:var(--border-2)}.tools-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;color:var(--text-muted)}.tools-placeholder span{font-family:var(--mono);font-size:10px;text-align:center;line-height:1.5;letter-spacing:.04em}#mobile-panel-toggle{display:none;position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--accent);border:none;color:#fff;cursor:pointer;z-index:300;box-shadow:0 4px 20px #4f8ef766;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}#mobile-panel-toggle:active{transform:scale(.93)}#mobile-panel-toggle svg{width:22px;height:22px;flex-shrink:0}#mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:149;backdrop-filter:blur(2px)}@media(max-width:768px){#app{flex-direction:column}#viewer-wrap{width:100vw;height:100vh;flex:none}#right-panel{position:fixed;inset:auto 0 0;width:100%!important;max-width:100%;height:75vh;border-left:none;border-top:1px solid var(--border-2);border-radius:20px 20px 0 0;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);z-index:150}#right-panel.open{transform:translateY(0)}#panel-resize-handle{width:100%;height:20px;cursor:grab;background:transparent;display:flex;align-items:center;justify-content:center;top:0;left:0}#panel-resize-handle:after{content:"";width:40px;height:4px;background:var(--border-2);border-radius:2px}#mobile-panel-toggle{display:flex}#mobile-overlay.visible{display:block}#top-bar{padding:0 12px;gap:10px}#btn-load{padding:6px 10px;font-size:12px}.logo-text{font-size:13px}#right-panel-inner{height:calc(75vh - 60px);padding:8px 14px 24px}#right-panel>.panel-header{padding:10px 14px}}
