:root{font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif}body{margin:0;background:#0b0d12;color:#e8eaf0}#app{max-width:1200px;margin:0 auto;padding:18px}.header{margin-bottom:12px}h1{margin:0 0 4px;font-size:22px}h2{margin:0;font-size:16px}.muted{color:#a8afc2}.small{font-size:12px}.card{background:#121624;border:1px solid #1c2236;border-radius:14px;padding:12px;box-shadow:0 12px 30px #00000040}.row{display:flex;gap:10px;align-items:center}.row.wrap{flex-wrap:wrap}.row.between{justify-content:space-between}.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.btn{background:#1b2340;color:#e8eaf0;border:1px solid #2a3561;padding:8px 10px;border-radius:10px;cursor:pointer}.btn:hover{filter:brightness(1.05)}.btn.small{padding:6px 8px;border-radius:10px;font-size:12px}.btn.primary{background:#2a5cff;border-color:#2a5cff}.chk{display:inline-flex;gap:8px;align-items:center;padding:6px 10px;background:#0f1322;border:1px solid #1c2236;border-radius:10px}.field{display:flex;flex-direction:column;gap:6px;font-size:12px}.field input{padding:8px 10px;border-radius:10px;border:1px solid #2a3561;background:#0f1322;color:#e8eaf0}.field.grow{flex:1;min-width:280px}.progress{margin-top:10px;padding:10px;background:#0f1322;border:1px solid #1c2236;border-radius:10px}.upload{display:grid;gap:10px}.dropzone{border:2px dashed rgba(255,255,255,.25);border-radius:14px;padding:22px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:170px;gap:10px}.dropzone.dragover{border-color:#78b4ffe6;box-shadow:0 0 0 4px #78b4ff26}.dropzone.busy{opacity:.9}.dzTitle{font-size:18px}.dzActions{display:flex;gap:10px;align-items:center;justify-content:center}.fileHint{margin-top:4px}.dzStatus{margin-top:6px;display:flex;align-items:center;justify-content:center;gap:10px}.progressText{font-size:14px;opacity:.9}.spinner{width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.25);border-top-color:#ffffffe6;animation:spin .9s linear infinite}.hidden{display:none!important}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.scroll{margin-top:10px;max-height:320px;overflow:auto;border:1px solid #1c2236;border-radius:10px;background:#0f1322;padding:8px}.item{display:flex;justify-content:space-between;gap:10px;padding:6px 8px;border-radius:8px}.item:hover{background:#ffffff0a}.item label{display:flex;gap:8px;align-items:center}.badge{font-size:11px;color:#a8afc2}table{border-collapse:collapse;width:100%;font-size:12px}th,td{border:1px solid #1c2236;padding:6px 8px;vertical-align:top}th{position:sticky;top:0;background:#121624;z-index:1}.propsCard{display:flex;flex-direction:column}#propsBox{height:360px;overflow:auto}@media(max-width:900px){#propsBox{height:260px}}.grid{margin-bottom:12px}#propsBox,.activeScroll{height:360px;overflow:auto}@media(max-width:900px){#propsBox,.activeScroll{height:260px}}.propsSpacer{height:18px}.draggableItem{cursor:grab}.draggableItem:active{cursor:grabbing}.activeDraggable{cursor:grab}.activeDraggable:active{cursor:grabbing}.propItem{display:flex;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:10px;border:1px solid #1c2236;background:#0f1322;cursor:grab;-webkit-user-select:none;user-select:none}.propItem:active{cursor:grabbing}.propItem:hover{background:#ffffff0a}.propItem.isActive{outline:2px solid rgba(120,180,255,.35);outline-offset:0}.propText{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.propRight{display:inline-flex;align-items:center;gap:8px}.dropOver{outline:2px dashed rgba(120,180,255,.9);outline-offset:4px}.dropItemOver{background:#78b4ff1f}.activeRow{cursor:grab}.activeRow:active{cursor:grabbing}.thWithFilter{position:sticky;top:0;background:#121624;z-index:1;padding-right:34px}.thTitle{display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filterBtn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:6px;border:1px solid #2a3561;background:#0f1322;cursor:pointer}.filterBtn:after{content:"▾";font-size:12px;opacity:.9}.filterBtn.isOn{outline:2px solid rgba(120,180,255,.35);outline-offset:0}.filterPopup{position:absolute;width:300px;max-height:420px;display:flex;flex-direction:column;gap:8px;padding:10px;border-radius:12px;border:1px solid #2a3561;background:#0b0d12;box-shadow:0 18px 60px #0000008c;z-index:9999}.filterSearch{padding:8px 10px;border-radius:10px;border:1px solid #2a3561;background:#0f1322;color:#e8eaf0}.filterList{overflow:auto;border:1px solid #1c2236;border-radius:10px;background:#0f1322;padding:6px;max-height:280px}.filterRow{display:flex;gap:8px;align-items:center;padding:6px;border-radius:8px;-webkit-user-select:none;user-select:none}.filterRow:hover{background:#ffffff0a}.filterFooter{display:flex;justify-content:flex-end;gap:8px}.groupBar{margin-top:10px;margin-bottom:10px;display:flex;gap:10px;align-items:center;padding:10px;border-radius:14px;border:1px solid #1c2236;background:#ffffff05}.groupBarLeft{display:flex;align-items:center;gap:10px;min-width:220px}.groupBarLabel{padding:6px 10px;border-radius:10px;background:#ffffff0f;border:1px solid #2a3561;font-weight:600}.groupPills{display:flex;flex-wrap:wrap;gap:8px}.groupPill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid #2a3561;background:#0f1322}.groupPillText{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.groupPillX{width:22px;height:22px;border-radius:999px;border:1px solid #2a3561;background:transparent;color:inherit;cursor:pointer}.groupDrop{flex:1;min-height:40px;display:flex;align-items:center;padding:0 12px;border-radius:12px;border:1px dashed #2a3561;color:#ffffffa6}.groupDrop.dropOver{outline:2px dashed rgba(120,180,255,.9);outline-offset:3px}.thTitleWrap{display:inline-flex;align-items:center;gap:6px;max-width:100%}.sumIcon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:6px;border:1px solid #2a3561;background:#ffffff0a;font-size:12px;opacity:.95}.groupRow td{background:#78b4ff12;font-weight:600}.treeCell{display:flex;align-items:center;gap:8px}.treeArrow{width:22px;height:22px;border-radius:8px;border:1px solid #2a3561;background:#0f1322;color:inherit;cursor:pointer}.treeArrow:disabled{opacity:.4;cursor:default}.treeLabel{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}th[draggable=true]{cursor:grab}th[draggable=true]:active{cursor:grabbing}.groupPills.dropOver{outline:2px dashed rgba(120,180,255,.9);outline-offset:3px;border-radius:12px}.groupPill{display:inline-flex;align-items:center;gap:6px}.groupPillHandle{cursor:grab;font-size:14px;line-height:1;color:#9aa4b2;padding:2px 4px;border-radius:4px;-webkit-user-select:none;user-select:none;opacity:0}.groupPill:hover .groupPillHandle{opacity:1}.groupPillHandle:active{cursor:grabbing}.groupPill.dropItemOver{outline:2px dashed rgba(120,180,255,.9);outline-offset:2px}.unitsPanel{margin-top:10px;padding:10px;border-radius:14px;border:1px solid #1c2236;background:#ffffff05}.unitsGrid{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:10px}@media(max-width:900px){.unitsGrid{grid-template-columns:repeat(2,minmax(160px,1fr))}}@media(max-width:560px){.unitsGrid{grid-template-columns:1fr}}.field select{padding:8px 10px;border-radius:10px;border:1px solid #2a3561;background:#0f1322;color:#e8eaf0}.chk.disabled{opacity:.5;pointer-events:none}.chk input:disabled{cursor:not-allowed}
