:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%}body{background:#101615;margin:0}button,input,select,textarea{font:inherit}.board-app{background:#101615;grid-template-columns:minmax(0,7fr) minmax(320px,3fr);min-height:100vh;display:grid}.viewer-shell{background:#0b1110;border-right:1px solid #ffffff1a;min-width:0;min-height:100vh;position:relative}.viewer-canvas{width:100%;height:100vh}.project-title{z-index:3;color:#f4f0e6;text-align:center;text-overflow:ellipsis;white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;background:#080e0dc7;border:1px solid #ffffff29;border-radius:8px;max-width:min(520px,100% - 430px);height:34px;padding:0 14px;font-size:.86rem;font-weight:700;line-height:32px;position:absolute;top:12px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 8px 24px #0000003d}.viewer-actions{z-index:4;gap:6px;display:inline-flex;position:absolute;top:12px;right:12px}.bom-github-link{color:#171b20;background:#fffaf0;border:1px solid #171b2024;border-radius:7px;flex:none;place-content:center;width:34px;height:34px;display:grid}.bom-github-link svg{width:19px;height:19px;display:block}.side-switch{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#080e0dc7;border:1px solid #ffffff2e;border-radius:8px;gap:4px;padding:4px;display:inline-flex;box-shadow:0 8px 24px #0000003d}.side-switch button,.close-project-button{appearance:none;letter-spacing:0;cursor:pointer;border:0;border-radius:6px;height:32px;font-size:.82rem;font-weight:700}.side-switch button{color:#f4f0e6;background:0 0;min-width:56px;padding:0 12px}.side-switch button.is-active{color:#141008;background:#f4c64f}.close-project-button{color:#f4f0e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#080e0dc7;border:1px solid #ffffff2e;place-content:center;width:42px;height:42px;display:grid;box-shadow:0 8px 24px #0000003d}.side-switch button:hover,.close-project-button:hover{filter:brightness(1.08)}.hidden-file-input{display:none}.viewer-status{color:#f5efe1;text-align:center;background:#070b0ad1;place-content:center;gap:12px;padding:24px;display:grid;position:absolute;inset:0}.viewer-status strong{font-size:1rem}.viewer-status span{color:#d7cdbb;max-width:min(520px,72vw);font-size:.88rem}.viewer-error{color:#ffb7a8!important}.import-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:4px;display:flex}.primary-import-button,.secondary-import-button{appearance:none;cursor:pointer;border-radius:7px;min-width:132px;height:38px;font-size:.88rem;font-weight:800}.primary-import-button{color:#141008;background:#f4c64f;border:0}.secondary-import-button{color:#f5efe1;background:#f5efe114;border:1px solid #f5efe13d}.primary-import-button:hover,.secondary-import-button:hover{filter:brightness(1.08)}.component-panel{color:#171b20;background:#f4f0e7;flex-direction:column;min-width:0;max-height:100vh;display:flex}.panel-header{border-bottom:1px solid #171b201f;justify-content:space-between;align-items:center;gap:16px;padding:12px 14px 10px;display:flex}.panel-heading{align-items:center;gap:10px;min-width:0;display:flex}.panel-title-text{min-width:0}.bom-github-link:hover{background:#f7df91;border-color:#171b2038}.app-version-badge{appearance:none;color:#4e5754;cursor:default;background:#fffaf0c7;border:1px solid #171b201f;border-radius:6px;align-items:center;gap:5px;min-width:54px;height:24px;padding:0 8px;font-size:.72rem;font-weight:800;line-height:1;display:inline-flex}.app-version-badge:disabled{opacity:1}.app-version-badge:not(:disabled){color:#171b20;cursor:pointer;background:#fff7f3;border-color:#b41b1b38}.app-version-badge strong{color:#fff6f2;background:#c82626;border-radius:999px;place-content:center;min-width:32px;height:16px;padding:0 5px;font-size:.58rem;line-height:1;display:inline-grid}.app-version-badge:not(:disabled):hover{background:#ffecea;border-color:#b41b1b70}.panel-label{color:#59625f;letter-spacing:.08em;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap;margin:0 0 2px;font-size:.68rem;font-weight:700;line-height:1.1;overflow:hidden}.panel-header h1{margin:0;font-size:1.15rem;line-height:1.1}.count-badge{color:#f6d779;background:#18211f;border-radius:6px;place-content:center;min-width:36px;height:28px;font-size:.78rem;font-weight:800;display:inline-grid}.selection-summary{background:#ebe4d8;border-bottom:1px solid #171b201f;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;min-height:28px;padding:4px 12px;display:grid}.selection-summary span{color:#5a625f;font-size:.72rem}.selection-summary strong{color:#171b20;text-overflow:ellipsis;white-space:nowrap;font-size:.86rem;overflow:hidden}.component-search{background:#f4f0e7;border-bottom:1px solid #171b201f;padding:10px 12px;position:relative}.component-search input{appearance:none;color:#171b20;background:#fffaf0;border:1px solid #171b2029;border-radius:7px;outline:none;width:100%;min-width:0;height:36px;padding:0 40px 0 12px;font-size:.88rem}.component-search input:focus{border-color:#be501cbd;box-shadow:0 0 0 3px #f6c66b5c}.component-search input:disabled{color:#858c89;background:#fffaf08a}.component-search button{appearance:none;color:#2b302e;cursor:pointer;background:#18211f14;border:0;border-radius:5px;place-content:center;width:26px;height:26px;font-size:.78rem;font-weight:800;display:grid;position:absolute;top:50%;right:18px;transform:translateY(-50%)}.component-search button:hover{background:#18211f24}.component-list{flex:auto;min-height:0;padding:8px;overflow:auto}.empty-component-list{color:#68716d;text-align:center;place-content:center;min-height:140px;padding:24px;font-size:.88rem;display:grid}.component-row{width:100%;min-height:56px;color:inherit;text-align:left;background:0 0;border:1px solid #0000;border-radius:7px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:2px 12px;padding:9px 10px;display:grid}.component-row:hover{background:#18211f0f}.component-row.is-matched{background:#f6cc5442;border-color:#c38b1561}.component-row.is-selected{background:#f6c66b;border-color:#be501cb8}.component-row.is-cross-side{border-color:#18211f29}.component-designators{flex-wrap:wrap;align-content:center;align-self:center;gap:4px;min-width:0;display:flex}.component-side-badge{color:#f6d779;background:#18211f;border-radius:4px;align-self:center;padding:2px 5px;font-size:.66rem;font-weight:800;line-height:1.25}.component-tag{appearance:none;min-width:0;color:inherit;font:inherit;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:3px 5px;font-size:.95rem;font-weight:800;line-height:1.25}.component-tag:hover{background:#18211f14}.component-tag.is-matched{background:#f6cc5461}.component-tag.is-selected{background:#f6c66b;border-color:#be501cb8}.component-identity{appearance:none;min-width:0;color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;align-content:center;gap:2px;padding:0;display:grid}.component-meta{text-overflow:ellipsis;white-space:nowrap;font-size:.86rem;font-weight:700;overflow:hidden}.component-footprint{color:#626b67;text-overflow:ellipsis;white-space:nowrap;font-size:.74rem;overflow:hidden}.update-dialog-backdrop{z-index:20;background:#04080794;place-content:center;padding:24px;display:grid;position:fixed;inset:0}.update-dialog{color:#171b20;background:#fffaf0;border:1px solid #171b2024;border-radius:8px;gap:14px;width:min(420px,100vw - 48px);padding:18px;display:grid;box-shadow:0 20px 48px #00000052}.update-dialog p{color:#9f2b22;letter-spacing:.08em;text-transform:uppercase;margin:0 0 4px;font-size:.7rem;font-weight:800}.update-dialog h2{margin:0;font-size:1.08rem;line-height:1.2}.update-dialog span{color:#59625f;font-size:.88rem;line-height:1.45}.update-dialog-error{color:#9f2b22;background:#ffe4df;border-radius:6px;padding:8px 10px;font-size:.78rem;line-height:1.4}.update-dialog-actions{justify-content:flex-end;gap:8px;display:flex}.update-dialog-actions button:disabled{cursor:wait;filter:saturate(.65)}@media (width<=900px){.board-app{grid-template-rows:minmax(420px,70vh) minmax(0,30vh);grid-template-columns:1fr}.viewer-shell,.viewer-canvas{height:70vh;min-height:0}.component-panel{max-height:30vh}.project-title{max-width:calc(100% - 24px);top:56px}.viewer-actions{right:8px}.side-switch button{min-width:48px;padding:0 10px}}
