.auth-scene{--primary: rgb(0, 133, 219);--primary-dim: rgba(0, 133, 219, .12);--primary-soft: rgba(0, 133, 219, .06);--primary-strong: rgb(0, 110, 184);--on-bg: #1a2233;--muted: #5b6a82;--muted-2: #8a96a8;--outline: #e3e8ef;--bg: #eaf1f8;position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;background:var(--bg);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--on-bg)}.auth-scene:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(#cfdcec 1px,transparent 1px),linear-gradient(90deg,#cfdcec 1px,transparent 1px),linear-gradient(#dde8f3 1px,transparent 1px),linear-gradient(90deg,#dde8f3 1px,transparent 1px);background-size:140px 140px,140px 140px,28px 28px,28px 28px}.auth-scene:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(56% 56% at 50% 50%,rgba(234,241,248,.92) 0%,rgba(234,241,248,.35) 50%,transparent 100%)}.auth-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.auth-lbl{font-family:JetBrains Mono,ui-monospace,monospace;font-weight:600;paint-order:stroke;stroke:var(--bg);stroke-width:4px;stroke-linejoin:round}.auth-lang{position:absolute;top:22px;right:26px;z-index:10;display:inline-flex;align-items:center;gap:8px;font-size:.75rem;font-weight:700;color:var(--muted)}.auth-seg{display:inline-flex;background:#fff;border:1px solid var(--outline);border-radius:999px;padding:2px;gap:2px;box-shadow:0 2px 6px #0f172a0f}.auth-seg span{padding:4px 11px;border-radius:999px;cursor:pointer}.auth-seg span.on{background:var(--primary-soft);color:var(--primary)}.auth-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9;width:400px;max-width:calc(100% - 32px);background:#fff;border-radius:22px;box-shadow:0 18px 48px #0f172a38;padding:34px 36px 28px}.auth-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.15rem;letter-spacing:-.02em;justify-content:center}.auth-mark{width:34px;height:34px;border-radius:9px;background:var(--primary);display:grid;place-items:center;box-shadow:0 4px 10px #0085db59}.auth-title{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;margin:18px 0 4px;text-align:center}.auth-sub{color:var(--muted);font-size:.86rem;margin:0 0 20px;text-align:center}.auth-methods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}.auth-method{position:relative;border:1.5px solid var(--outline);border-radius:13px;padding:12px 11px;cursor:pointer;background:#fff;transition:.15s;text-align:left}.auth-method.on{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 3px var(--primary-dim)}.auth-mi{font-size:18px}.auth-ml{display:block;font-weight:700;font-size:.82rem;margin-top:5px}.auth-md{display:block;color:var(--muted-2);font-size:.7rem;margin-top:2px}.auth-chk{position:absolute;top:8px;right:9px;color:var(--primary);font-size:13px;font-weight:800}.auth-field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}.auth-field label{font-size:.68rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}.auth-control{display:flex;align-items:center;gap:8px;border:1.5px solid var(--outline);border-radius:11px;background:#fff;padding:0 11px}.auth-control:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}.auth-control input{flex:1;border:0;outline:0;background:transparent;font:inherit;font-size:.88rem;padding:11px 0;color:var(--on-bg)}.auth-toggle{cursor:pointer;color:var(--muted-2);-webkit-user-select:none;user-select:none}.auth-phone-row{display:flex;gap:8px}.auth-cc{border:1.5px solid var(--outline);border-radius:11px;background:#fff;padding:0 8px;font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;color:var(--on-bg)}.auth-cc:focus{outline:0;border-color:var(--primary)}.auth-row-between{display:flex;align-items:center;justify-content:flex-end;margin:-2px 0 16px}.auth-link{color:var(--primary);font-weight:700;font-size:.78rem;text-decoration:none;cursor:pointer}.auth-link:hover{text-decoration:underline}.auth-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 16px;border-radius:11px;font:inherit;font-size:.9rem;font-weight:700;cursor:pointer;border:1px solid transparent;background:var(--primary);color:#fff;box-shadow:0 4px 12px #0085db4d;margin-top:2px}.auth-btn:hover{background:var(--primary-strong)}.auth-btn:disabled{opacity:.55;cursor:not-allowed}.auth-foot{margin-top:16px;text-align:center;font-size:.74rem;color:var(--muted-2)}.auth-foot-row{display:flex;justify-content:space-between;align-items:center}.auth-foot .auth-link,.auth-foot-row .auth-link{font-size:.8rem}.auth-error{background:#fee2e2;color:#b91c1c;border-radius:10px;padding:9px 12px;font-size:.8rem;text-align:center;margin-bottom:12px}.auth-info{background:#dcfce7;color:#15803d;border-radius:10px;padding:9px 12px;font-size:.8rem;text-align:center;margin-bottom:12px}.auth-otp{display:flex;gap:8px;justify-content:center;margin:8px 0 18px}.auth-otp input{width:44px;height:52px;text-align:center;font-size:1.25rem;font-weight:700;border:1.5px solid var(--outline);border-radius:11px;outline:0;color:var(--on-bg)}.auth-otp input.f{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}.auth-boot{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#eaf1f8;color:#5b6a82;font-family:Plus Jakarta Sans,sans-serif;font-size:.9rem}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;color:#1a1a1a;background:#e9ecef}.app{display:flex;flex-direction:column;height:100vh}.toolbar{display:flex;align-items:center;gap:10px;padding:6px 12px;background:#212529;color:#fff;flex:0 0 auto}.file-btn{background:#1971c2;color:#fff;padding:6px 12px;border-radius:5px;cursor:pointer;font-weight:600}.filename{color:#adb5bd;font-size:12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-group{display:flex;gap:4px;margin-left:auto}.user-group{display:flex;align-items:center;gap:8px;margin-left:12px;padding-left:12px;border-left:1px solid #495057}.user-chip{color:#adb5bd;font-size:11px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.signout-btn{display:inline-flex;align-items:center;gap:5px;background:#343a40;color:#dee2e6;border:1px solid #495057;padding:6px 10px;border-radius:5px;cursor:pointer;font-size:12px}.signout-btn:hover{background:#c92a2a;color:#fff;border-color:#c92a2a}.signout-btn .ti{font-size:15px}.tools-collapse{display:grid;grid-template-columns:0fr;opacity:0;transition:grid-template-columns .35s ease-in-out,opacity .35s ease-in-out}.tools-collapse.open{grid-template-columns:1fr;opacity:1}.tools-collapse:not(.open){pointer-events:none}.tools-inner{display:flex;gap:4px;overflow:hidden;min-width:0}.tool{position:relative;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;background:#343a40;color:#dee2e6;border:1px solid #495057;padding:6px 10px;border-radius:5px;cursor:pointer;font-size:12px}.tool .ti{font-size:15px}.tool.active{background:#1971c2;color:#fff;border-color:#1971c2}.tool-key{position:absolute;right:3px;bottom:1px;font-family:ui-monospace,monospace;font-size:9px;line-height:1;color:#868e96;pointer-events:none}.tool.active .tool-key{color:#ffffffbf}.help-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#1971c2;color:#fff;border:1px solid #1971c2;cursor:pointer;padding:0}.help-btn:hover{background:#1864ab;border-color:#1864ab}.help-q{font-weight:700;font-size:15px;line-height:1;color:#fff}.sc-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;z-index:1300}.sc-modal{background:#fff;color:#212529;border-radius:8px;padding:18px 20px;width:460px;max-width:92vw;max-height:85vh;overflow-y:auto;box-shadow:0 12px 40px #0000004d}.sc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.sc-head h3{margin:0;font-size:16px}.sc-close{display:inline-flex;background:none;border:none;cursor:pointer;color:#868e96;font-size:18px;padding:2px}.sc-close:hover{color:#212529}.sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 28px}.sc-grp{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:#868e96;margin:0 0 4px}.sc-grp-mt{margin-top:14px}.sc-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:4px 0;font-size:13px}.sc-keys{display:inline-flex;gap:3px}.sc-kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;font-family:ui-monospace,monospace;font-size:11px;color:#495057;background:#f1f3f5;border:1px solid #dee2e6;border-radius:4px}.sc-kbd.sc-wide{min-width:auto;padding:0 7px}.buttons__burger{--size: 1.4rem;--clr: #ced4da;width:var(--size);height:calc(.7 * var(--size));cursor:pointer;position:relative;display:block;flex:0 0 auto;align-self:center;margin-right:4px}.buttons__burger:hover{--clr: #fff}.buttons__burger input{display:none;width:100%;height:100%}.buttons__burger span{display:block;position:absolute;width:100%;border-radius:.4rem;border:1.5px solid var(--clr);background-color:var(--clr);transition:.35s ease-in-out}.buttons__burger span:nth-of-type(1){top:0;right:0;transform-origin:right center}.buttons__burger span:nth-of-type(2){top:50%;transform:translateY(-50%)}.buttons__burger span:nth-of-type(3){top:100%;right:0;transform-origin:right center;transform:translateY(-100%)}.buttons__burger input:checked~span:nth-of-type(1){top:50%;width:55%;transform:translateY(-50%) rotate(40deg)}.buttons__burger input:checked~span:nth-of-type(3){top:50%;width:55%;transform:translateY(-50%) rotate(-40deg)}.cloud-group{display:flex;align-items:center;gap:8px;margin-left:12px;padding-left:12px;border-left:1px solid #495057}.proj-picker{position:relative;width:280px;flex:0 0 auto}.proj-input-wrap{display:flex;align-items:center;gap:6px;background:#343a40;border:1px solid #495057;border-radius:5px;padding:0 8px;height:32px}.proj-input-wrap:focus-within{border-color:#1971c2}.proj-search-ic{font-size:15px;color:#868e96;flex:0 0 auto}.proj-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:#f1f3f5;font-size:12px;padding:0}.proj-input::placeholder{color:#868e96}.proj-clear{display:inline-flex;align-items:center;background:transparent;border:none;color:#adb5bd;cursor:pointer;padding:2px;border-radius:4px}.proj-clear:hover{color:#fff;background:#495057}.proj-clear .ti{font-size:15px}.proj-dropdown{position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:1100;background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:5px;box-shadow:0 8px 24px #00000040;max-height:320px;overflow-y:auto}.proj-empty{padding:10px 8px;font-size:12px;color:#868e96;text-align:center}.proj-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.proj-item{width:100%;display:flex;flex-direction:column;gap:3px;align-items:stretch;background:transparent;border:none;border-radius:6px;padding:7px 9px;cursor:pointer;text-align:left}.proj-item.active{background:#e7f5ff}.proj-item.sel{background:#d0ebff}.proj-item-top{display:flex;align-items:center;gap:8px}.proj-item-name{font-size:13px;font-weight:600;color:#212529;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.proj-badge{flex:0 0 auto;margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#0c447c;background:#e6f1fb;border-radius:10px;padding:2px 8px}.proj-item-meta{display:flex;flex-wrap:wrap;gap:4px 12px}.proj-meta{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#868e96;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.proj-meta .ti{font-size:13px;flex:0 0 auto}.cloud-btn{background:#2f9e44;color:#fff;border:1px solid #2f9e44;padding:6px 10px;border-radius:5px;cursor:pointer;font-size:12px;font-weight:600}.cloud-btn:hover:not(:disabled){background:#2b8a3e}.cloud-btn:disabled{opacity:.5;cursor:not-allowed}.cloud-error{color:#ffa8a8;font-size:11px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cloud-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;z-index:1000}.cloud-modal{background:#fff;color:#212529;border-radius:8px;padding:18px 20px;width:420px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 12px 40px #0000004d}.cloud-modal h3{margin:0 0 12px;font-size:16px}.cloud-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.cloud-list-item{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;background:#f1f3f5;border:1px solid #dee2e6;border-radius:5px;padding:8px 10px;cursor:pointer;text-align:left;font-size:13px}.cloud-list-item:hover{background:#e7f5ff;border-color:#74c0fc}.cloud-list-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cloud-list-date{color:#868e96;font-size:11px;flex:0 0 auto}.cloud-modal-actions{display:flex;justify-content:flex-end;margin-top:14px}.cloud-modal-actions .cloud-btn{background:#495057;border-color:#495057}.cloud-list-main{display:flex;flex-direction:column;gap:2px;min-width:0}.cloud-list-project{font-size:11px;color:#868e96;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cloud-modal-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.cloud-modal-head h3{margin:0;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cloud-back{display:inline-flex;align-items:center;gap:3px;flex:0 0 auto;background:#f1f3f5;border:1px solid #dee2e6;border-radius:6px;padding:5px 9px;font-size:12px;color:#343a40;cursor:pointer}.cloud-back:hover{background:#e7f5ff;border-color:#74c0fc}.cloud-back .ti{font-size:15px}.cloud-search{width:100%;padding:8px 10px;margin-bottom:10px;font-size:13px;border:1px solid #ced4da;border-radius:6px;background:#fff;color:#212529}.cloud-search:focus{outline:none;border-color:#1971c2}.cloud-empty-line{color:#868e96;font-size:12px;text-align:center;padding:8px 0}.cloud-badge{flex:0 0 auto;align-self:center;font-size:11px;font-weight:700;letter-spacing:.02em;color:#495057;background:#f1f3f5;border:1px solid #e9ecef;border-radius:12px;padding:2px 9px}.cloud-badge.on{color:#0c447c;background:#e6f1fb;border-color:#d0e6fb}.cloud-popup-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:grid;place-items:center;z-index:1100}.cloud-popup{background:#fff;color:#212529;border-radius:8px;padding:18px 20px;width:380px;max-width:90vw;box-shadow:0 12px 40px #00000059}.cloud-popup h4{margin:0 0 8px;font-size:15px}.cloud-popup p{margin:0 0 8px;font-size:13px}.cloud-popup-warn{color:#e8590c;font-size:12px}.cloud-popup-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.cloud-btn.ghost{background:#495057;border-color:#495057}.cloud-btn.danger{background:#e8590c;border-color:#e8590c}.cloud-btn.danger:hover:not(:disabled){background:#d9480f}.docs-root{position:relative;display:flex;align-items:center;gap:8px}.Documents-btn{display:flex;align-items:center;justify-content:flex-start;width:fit-content;height:40px;border:none;padding:0 14px 0 10px;border-radius:7px;background-color:#343a40;gap:8px;cursor:pointer;transition:all .3s}.Documents-btn .folderContainer{width:34px;height:fit-content;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative}.Documents-btn .fileBack{z-index:1;width:80%;height:auto}.Documents-btn .filePage{width:50%;height:auto;position:absolute;z-index:2;transition:all .3s ease-out}.Documents-btn .fileFront{width:85%;height:auto;position:absolute;z-index:3;opacity:.95;transform-origin:bottom;transition:all .3s ease-out}.Documents-btn .text{color:#fff;font-size:13px;font-weight:600;letter-spacing:.3px;margin:0}.Documents-btn:hover{background-color:#1971c2}.Documents-btn:hover .filePage{transform:translateY(-5px)}.Documents-btn:hover .fileFront{transform:rotateX(30deg)}.Documents-btn:active{transform:scale(.95)}.docs-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:1100;background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:6px;box-shadow:0 8px 24px #00000040;display:flex;flex-direction:column;gap:2px;min-width:200px}.docs-menu button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:transparent;border:none;border-radius:5px;padding:8px 10px;font-size:13px;color:#212529;cursor:pointer}.docs-menu button:hover{background:#e7f5ff}.docs-menu-icon{font-size:18px;flex:0 0 auto;color:#1971c2}.save-fab{font-family:inherit;font-size:14px;background:#2f9e44;color:#fff;fill:#ffffffd9;padding:0 12px 0 11px;height:40px;display:flex;align-items:center;cursor:pointer;border:none;border-radius:9px;font-weight:800;overflow:hidden}.save-fab span{display:block;margin-left:.3em;white-space:nowrap;transition:all .3s ease-in-out}.save-fab .icon{display:block;width:26px;height:26px}.save-fab svg{display:block;transform-origin:center center;transition:transform .3s ease-in-out}.save-fab:hover:not(:disabled){background:#2b8a3e}.save-fab:hover:not(:disabled) .svg-wrapper{transform:scale(1.2);transition:.5s linear}.save-fab:hover:not(:disabled) svg{transform:translate(1.1em) scale(1.05);fill:#fff}.save-fab:hover:not(:disabled) span{opacity:0;transition:.5s linear}.save-fab:active:not(:disabled){transform:scale(.95)}.save-fab:disabled{opacity:.5;cursor:not-allowed}.save-fab.is-saved{background:#2b8a3e}.save-fab{position:relative}.save-dot{position:absolute;top:5px;right:5px;width:9px;height:9px;border-radius:50%;background:#ffd43b;border:1.5px solid #212529}.autosave-toggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.autosave-toggle input{position:absolute;opacity:0;width:0;height:0}.autosave-track{position:relative;width:32px;height:18px;border-radius:999px;background:#495057;transition:background .2s;flex:0 0 auto}.autosave-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#ced4da;transition:transform .2s,background .2s}.autosave-toggle.on .autosave-track{background:#2f9e44}.autosave-toggle.on .autosave-thumb{transform:translate(14px);background:#fff}.autosave-label{font-size:11px;font-weight:700;color:#adb5bd}.autosave-toggle.on .autosave-label{color:#69db7c}.main{flex:1 1 auto;display:flex;min-height:0}.sidebar{width:250px;flex:0 0 250px;background:#f8f9fa;border-right:1px solid #ced4da;overflow-y:auto;padding:8px}.center{flex:1 1 auto;position:relative;min-width:0;background:#495057}.table-panel{width:360px;flex:0 0 360px;background:#fff;border-left:1px solid #ced4da;overflow-y:auto;padding:10px}.sidebar section{margin-bottom:10px}.sidebar h3{margin:4px 0 6px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#495057}.acc-head{display:flex;align-items:center;gap:6px;width:100%;text-align:left;background:#eef1f4;border:1px solid #dee2e6;border-radius:6px;padding:7px 9px;cursor:pointer;font-size:12px;font-weight:700;color:#343a40;text-transform:uppercase;letter-spacing:.03em}.acc-head:hover{background:#e7f1fb}.acc-head>span:first-child{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.acc-head .ti{font-size:16px;color:#868e96;transition:transform .2s}.acc-head.collapsed .ti{transform:rotate(-90deg)}.acc-badge{flex:0 0 auto;background:#dde3ea;color:#495057;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700;max-width:92px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pagelist{display:flex;flex-direction:column;gap:2px;max-height:180px;overflow-y:auto}.pageitem{display:flex;align-items:center;gap:4px}.pageitem .pagename{flex:1;text-align:left;background:#fff;border:1px solid #dee2e6;padding:4px 8px;border-radius:4px;cursor:pointer}.pageitem.cur .pagename{background:#d0ebff;border-color:#74c0fc;font-weight:600}.pageitem.dropped .pagename{opacity:.45;text-decoration:line-through}.scaled{color:#2f9e44;margin-left:4px}.mini{background:#f1f3f5;border:1px solid #dee2e6;border-radius:4px;width:22px;height:24px;cursor:pointer}.preset-row,.pitch-quick{display:flex;flex-wrap:wrap;gap:4px;margin:6px 0}.chip{background:#fff;border:1px solid #ced4da;border-radius:12px;padding:3px 8px;font-size:11px;cursor:pointer}.chip.on{background:#1971c2;color:#fff;border-color:#1971c2}.chip.add{font-weight:700;color:#1971c2}.field-label{font-size:12px;color:#495057;margin:6px 0 2px}.legend-count{margin-left:auto;color:#868e96;font-size:11px}.wide{width:100%;padding:6px;margin-top:4px;border:1px solid #ced4da;background:#fff;border-radius:5px;cursor:pointer}.field{display:flex;flex-direction:column;gap:2px;margin:6px 0;font-size:12px;color:#495057}.field input,.field select{padding:4px 6px;border:1px solid #ced4da;border-radius:4px}.hint{font-size:11px;color:#868e96;margin:4px 0}.warn{color:#e8590c;font-weight:600}.ok{color:#2f9e44;font-weight:600}.scale-state{font-size:12px;margin-bottom:4px}.legend-row{display:flex;align-items:center;gap:6px;margin:4px 0}.legend-row input[type=color]{width:28px;height:22px;padding:0;border:none}.swatch{width:12px;height:12px;border-radius:3px;display:inline-block;flex:0 0 auto}.groupname{flex:1;padding:3px 5px;border:1px solid #dee2e6;border-radius:4px}.canvas-host{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;touch-action:none}.canvas-wrap{position:absolute;left:0;top:0}.overlay{position:absolute;left:0;top:0;overflow:visible}.canvas-hud{position:absolute;bottom:12px;display:flex;gap:9px;align-items:center;background:#212529e6;color:#f1f3f5;padding:6px 10px;border-radius:9px;font-size:12px;box-shadow:0 4px 16px #00000047;z-index:5}.canvas-hud.hud-left{left:12px}.canvas-hud.hud-center{left:50%;transform:translate(-50%)}.canvas-hud.hud-right{right:12px}.hud-sep{width:1px;height:20px;background:#ffffff29}.hud-ibtn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:6px;background:#4950578c;color:#f1f3f5;cursor:pointer;font-size:16px;transition:background .15s}.hud-ibtn:hover:not(:disabled){background:#1971c2}.hud-ibtn:active:not(:disabled){transform:scale(.93)}.hud-ibtn:disabled{opacity:.4;cursor:not-allowed}.hud-tbtn{display:inline-flex;align-items:center;gap:5px;border:none;border-radius:6px;background:#4950578c;color:#f1f3f5;padding:5px 9px;cursor:pointer;font-size:12px}.hud-tbtn:hover{background:#1971c2}.hud-tbtn .ti,.hud-ibtn .ti{font-size:16px}.hud-track{position:relative;width:104px;height:6px;border-radius:999px;background:#ffffff2e;cursor:pointer}.hud-track-fill{position:absolute;left:0;top:0;bottom:0;border-radius:999px;background:#4dabf7;pointer-events:none}.hud-track-knob{position:absolute;top:50%;width:13px;height:13px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);box-shadow:0 1px 4px #0006;pointer-events:none}.hud-zval{font-variant-numeric:tabular-nums;min-width:40px;text-align:center;font-weight:600}.hud-page{display:inline-flex;align-items:center;gap:6px;font-variant-numeric:tabular-nums}.hud-page .muted-of{color:#adb5bd}.hud-pnum{width:40px;height:26px;text-align:center;border-radius:6px;border:1px solid rgba(255,255,255,.22);background:#00000040;color:#f1f3f5;font-size:12.5px;font-variant-numeric:tabular-nums}.hud-pnum:focus{outline:none;border-color:#4dabf7}.canvas-hud .warn{color:#ffa94d;display:inline-flex;align-items:center;gap:5px;font-weight:600}.canvas-hud .ok{color:#69db7c;display:inline-flex;align-items:center;gap:5px;font-weight:600;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.canvas-hud .warn .ti,.canvas-hud .ok .ti{font-size:15px}.canvas-filters{position:absolute;top:10px;left:10px;z-index:6}.cf-fab{display:inline-flex;align-items:center;justify-content:center;position:relative;width:34px;height:34px;border:none;border-radius:8px;cursor:pointer;background:#212529e6;color:#f1f3f5;box-shadow:0 4px 16px #00000047}.cf-fab:hover{background:#1971c2}.cf-fab .ti{font-size:19px}.cf-badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#ffd43b;color:#212529;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid #212529}.cf-panel,.cf-row{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.cf-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid transparent;background:#212529e6;color:#f1f3f5;border-radius:14px;padding:5px 11px;font-size:11px;cursor:pointer;box-shadow:0 2px 8px #00000047;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cf-chip .swatch{width:10px;height:10px}.cf-chip:hover{border-color:#74c0fc}.cf-chip.off{opacity:.5;text-decoration:line-through}.cf-foot{display:flex;align-items:center;gap:6px}.cf-link{background:#212529e6;border:1px solid transparent;color:#74c0fc;font-size:11px;cursor:pointer;padding:5px 11px;border-radius:14px;box-shadow:0 2px 8px #00000047}.cf-link:hover{border-color:#74c0fc}.cf-collapse{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#212529e6;border:none;color:#adb5bd;cursor:pointer;box-shadow:0 2px 8px #00000047}.cf-collapse .ti{font-size:16px}.cf-collapse:hover{color:#fff}.empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#dee2e6;text-align:center}.empty .hint{color:#adb5bd}.panel-tabs{display:flex;gap:2px;border-bottom:1px solid #e9ecef;margin-bottom:8px;position:sticky;top:0;background:#fff;z-index:2}.panel-tabs button{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:none;border:none;padding:9px 4px;cursor:pointer;color:#868e96;font-size:12.5px;font-weight:600;border-bottom:2px solid transparent}.panel-tabs button .ti{font-size:16px}.panel-tabs button.on{color:#1971c2;border-bottom-color:#1971c2}.panel-tab-pill{background:#dde3ea;color:#495057;border-radius:9px;padding:0 6px;font-size:10px;font-weight:700}.panel-tabs button.on .panel-tab-pill{background:#d0ebff;color:#1862ab}.table-panel h3{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#495057;margin:8px 0 6px}.group-block{margin-bottom:12px;border:1px solid #e9ecef;border-radius:6px;overflow:hidden}.group-head{display:flex;align-items:center;gap:6px;background:#f1f3f5;padding:5px 8px;font-weight:700;font-size:12px}.grp-tot{margin-left:auto;color:#1971c2;font-weight:600}.subtotals{padding:4px 8px;background:#fbfcfd;border-bottom:1px solid #e9ecef}.sub-row{display:flex;align-items:center;gap:6px;font-size:11.5px;padding:1px 0}.sub-name{color:#343a40}.sub-row .cnt{color:#adb5bd;margin-left:auto}.sub-row .sub-val{min-width:70px;font-weight:600;color:#1971c2}.cnt{font-size:11px}.sum-lines{width:100%}.sum-lines td{padding:2px 6px;font-size:11px;color:#495057;border-bottom:1px solid #f5f6f7}.sum-lines tr.sel td{background:#d0ebff}.sum-lines .pg{color:#adb5bd;width:30px}.details{margin-top:14px;border-top:2px solid #dee2e6;padding-top:8px}table{border-collapse:collapse;width:100%}.sum-table th,.sum-table td,.detail-table th,.detail-table td{padding:4px 6px;font-size:11.5px;border-bottom:1px solid #f1f3f5;text-align:left;vertical-align:middle}.detail-table th{color:#868e96;font-weight:600}.detail-table td.pg,.detail-table th.pg{text-align:center;color:#adb5bd;width:28px}.detail-table td.act,.detail-table th.act{text-align:center;width:30px}.del-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;padding:2px;cursor:pointer;color:#adb5bd;line-height:1;border-radius:4px}.del-btn:hover{color:#e03131}.del-btn .ti{font-size:16px}.detail-table .swatch{vertical-align:middle;margin-right:5px}.detail-table select{vertical-align:middle}.count-type{display:inline-flex;align-items:center}.count-desc{vertical-align:middle;width:100px;padding:2px 6px;font-size:12px;background:#2b3035;color:#dee2e6;border:1px solid #495057;border-radius:5px}.num{text-align:right;font-variant-numeric:tabular-nums}.num .unit{color:#adb5bd;font-weight:400;font-size:10.5px}.pill-select{display:inline-flex;align-items:center;gap:4px;max-width:112px;border:1px solid #e9ecef;background:#fff;border-radius:12px;padding:2px 6px 2px 7px;font-size:11px;color:#343a40;cursor:pointer}.pill-select:hover{border-color:#74c0fc;background:#f1f8ff}.pill-select .pill-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pill-select .swatch{flex:0 0 auto}.pill-select .ti{font-size:13px;color:#adb5bd;flex:0 0 auto;margin-left:auto}.pill-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200}.pill-menu{position:fixed;background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 8px 24px #0003;padding:5px;overflow-y:auto;z-index:1201;overscroll-behavior:contain}.pill-opt{display:flex;align-items:center;gap:7px;width:100%;text-align:left;background:none;border:none;border-radius:5px;padding:6px 9px;font-size:12px;cursor:pointer;color:#212529;white-space:nowrap}.pill-opt .swatch{width:11px;height:11px}.pill-opt:hover{background:#e7f5ff}.pill-opt.on{background:#d0ebff;font-weight:600}.grand{margin-top:8px;padding:8px;background:#fff3bf;border-radius:6px;font-size:12px}.detail-table tr{cursor:pointer}.detail-table tr.sel{background:#d0ebff}.detail-table tr:hover{background:#f1f3f5}.pitch-in{width:56px;padding:2px 4px;border:1px solid #dee2e6;border-radius:3px}.type-in{max-width:96px;padding:2px;border:1px solid #dee2e6;border-radius:3px}.detail-table select{max-width:96px;padding:2px}.grand-linear{margin-top:6px;display:flex;flex-wrap:wrap;gap:4px 10px;font-size:11.5px}.lin-tot{white-space:nowrap}
