*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}#app{width:100%;height:100%;background-color:#1a1d23}.panels-container{display:flex;flex-direction:column;height:100%;overflow:hidden}bim-panel{flex-shrink:0}bim-viewport{position:relative}.viewport-toolbar{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);z-index:100}.viewport-settings{position:absolute;top:.5rem;right:.5rem;z-index:100}.info-panel{position:absolute;top:.5rem;left:.5rem;background:#2a2d33f2;padding:.75rem 1rem;border-radius:8px;color:#888;font-size:12px;z-index:100;max-width:300px}.info-panel.success{color:#4f4}.info-panel.error{color:#f44}.dashboard-card{background-color:#23272e;border-radius:8px;padding:1rem;height:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#1a1d23}::-webkit-scrollbar-thumb{background:#3a3d43;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#4a4d53}bim-table{--bim-ui-background-primary: #23272e;--bim-ui-background-secondary: #1a1d23}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#1a1d23e6;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:9999}.loading-overlay.hidden{display:none}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#4a90d9;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}@keyframes spin{to{transform:rotate(360deg)}}.bcf-topic-card{background:#2a2d33;border-radius:8px;padding:.75rem;margin-bottom:.5rem}.bcf-topic-title{font-weight:600;color:#fff;margin-bottom:.25rem}.bcf-topic-meta{font-size:11px;color:#888}.viewpoints-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.viewpoint-card{background:#2a2d33;border-radius:8px;padding:.5rem;cursor:pointer;transition:background .2s;text-align:center}.viewpoint-card:hover{background:#3a3d43}.viewpoint-card img{width:100%;border-radius:4px;margin-bottom:.25rem}.viewpoint-name{font-size:11px;color:#ccc;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
