*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#1a1a1a;color:#c5c5c5;overflow:hidden;user-select:none}.main-layout{display:grid;grid-template-rows:48px 1fr 200px;height:100vh;width:100vw}.top-bar{background:#2a2a2a;border-bottom:1px solid #181818;display:flex;align-items:center;padding:0 16px;gap:16px;grid-row:1;z-index:100}.brand{font-weight:600;font-size:14px;color:#fff;min-width:160px}.upload-controls{display:flex;gap:8px}.upload-btn{background:#3e3e3e;border:1px solid #555;color:#e0e0e0;padding:6px 14px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s}.upload-btn:hover{background:#4a9eff;border-color:#4a9eff;color:#fff}.upload-btn.secondary{background:#2e2e2e;border-color:#444}.status-bar{flex:1;display:flex;gap:16px;font-size:11px;color:#888}.vxr-status{color:#6f9cd3}.vxr-status.is-error{color:#ff6b6b}.error-display{background:#3d1a1a;color:#ff6b6b;padding:4px 12px;border-radius:4px;font-size:11px;display:none}.error-display:not(:empty){display:block}.workspace{display:grid;grid-template-columns:280px 1fr;grid-row:2;overflow:hidden}.sidebar-left{background:#252525;border-right:1px solid #181818;display:flex;flex-direction:column;overflow:hidden}.panel-header{background:#2d2d2d;border-bottom:1px solid #1a1a1a;padding:10px 14px;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#e0e0e0}.panel-icon{font-size:14px}.panel-title{flex:1}.hierarchy-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px}.hierarchy-container::-webkit-scrollbar{width:8px}.hierarchy-container::-webkit-scrollbar-track{background:#1a1a1a}.hierarchy-container::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:4px}.hierarchy-container::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.node-item{padding:6px 8px;margin:2px 0;background:#2a2a2a;border-radius:4px;font-size:12px;display:flex;align-items:center;gap:6px;cursor:pointer;transition:all .15s;border:1px solid transparent}.node-item:hover{background:#333;border-color:#444}.node-item.selected{background:#4a9eff;color:#fff;border-color:#6bb3ff}.node-indent{width:16px;display:inline-block}.node-icon{font-size:11px;opacity:.7}.keyframe-indicator-small{width:6px;height:6px;background:orange;border-radius:50%;margin-left:auto}.viewport{position:relative;background:#1a1a1a;overflow:hidden}#canvas{width:100%;height:100%;display:block}#labels3d{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.node-label-3d{position:absolute;color:#fff;font-size:11px;font-family:Courier New,monospace;background:#000000d9;padding:6px 10px;border-radius:4px;pointer-events:none;white-space:nowrap;border:1px solid #4a9eff;backdrop-filter:blur(4px)}.node-label-3d .label-title{color:#4a9eff;font-weight:600;margin-bottom:4px}.node-label-3d .label-data{color:#d0d0d0;line-height:1.5;font-size:10px}.floating-panel{position:absolute;top:20px;right:20px;width:340px;background:#1e1e1ef2;border:1px solid #3a3a3a;border-radius:8px;box-shadow:0 8px 24px #00000080;backdrop-filter:blur(10px);z-index:50;display:flex;flex-direction:column;max-height:600px}.floating-panel.hidden{display:none}.floating-panel-header{background:#2d2d2d;border-bottom:1px solid #3a3a3a;padding:10px 12px;display:flex;align-items:center;gap:8px;cursor:move;border-radius:8px 8px 0 0}.floating-panel-header .panel-title{font-size:12px;font-weight:600;color:#e0e0e0}.panel-close{background:transparent;border:none;color:#888;font-size:20px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s}.panel-close:hover{background:#f44;color:#fff}.floating-panel-content{padding:14px;overflow-y:auto;flex:1}.floating-panel-content::-webkit-scrollbar{width:6px}.floating-panel-content::-webkit-scrollbar-track{background:transparent}.floating-panel-content::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}.property-empty{font-size:12px;color:#777;padding:20px;text-align:center;background:#4a9eff0d;border-radius:6px;border:1px dashed rgba(74,158,255,.2)}.property-details{display:flex;flex-direction:column;gap:14px}.property-details.hidden{display:none}.property-node-name{font-size:14px;font-weight:600;color:#4a9eff;padding-bottom:8px;border-bottom:1px solid #3a3a3a}.property-section{display:flex;flex-direction:column;gap:8px}.property-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.property-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:#222;border-radius:4px;border:1px solid #333}.prop-name{font-size:11px;color:#aaa}.prop-value{font-size:11px;color:#e0e0e0;font-family:Courier New,monospace;font-weight:500}.property-checkbox{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#222;border-radius:4px;border:1px solid #333;cursor:pointer;font-size:11px;color:#aaa;transition:all .2s}.property-checkbox:hover{border-color:#4a9eff;background:#252525}.property-checkbox input{cursor:pointer}.property-checkbox input:checked+span{color:#4a9eff;font-weight:500}#enablePositionX:checked+span{color:#ff6b6b!important}#enablePositionY:checked+span{color:#4ade80!important}#enablePositionZ:checked+span{color:#4a9eff!important}.timeline-panel{grid-row:3;background:#232323;border-top:1px solid #181818;display:flex;flex-direction:column;overflow:hidden}.timeline-header{background:#2a2a2a;border-bottom:1px solid #1a1a1a;padding:8px 12px;display:flex;align-items:center;justify-content:space-between;gap:16px}.playback-controls{display:flex;align-items:center;gap:8px}.timeline-btn{background:#3a3a3a;border:1px solid #4a4a4a;color:#ccc;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s;min-width:36px}.timeline-btn:hover{background:#4a4a4a;border-color:#5a5a5a}.timeline-btn.play{background:#4a9eff;border-color:#4a9eff;color:#fff}.timeline-btn.play.active{background:#ff6b6b;border-color:#ff6b6b}.frame-counter{padding:6px 12px;background:#1f1f1f;border-radius:4px;font-family:Courier New,monospace;font-size:12px;color:#4a9eff;font-weight:600;min-width:100px;text-align:center}.speed-control{display:flex;align-items:center;gap:6px;font-size:11px;color:#888}.speed-control input[type=number]{background:#1f1f1f;border:1px solid #3a3a3a;color:#e0e0e0;padding:4px 8px;border-radius:3px;width:50px;font-size:11px;text-align:center}.speed-control input[type=number]:focus{outline:none;border-color:#4a9eff}.timeline-zoom{display:flex;align-items:center;gap:8px;font-size:11px;color:#888}.zoom-slider{width:100px;height:4px;background:#1f1f1f;border-radius:2px;outline:none;-webkit-appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#4a9eff;border-radius:50%;cursor:pointer}.timeline-scrubber{background:#2a2a2a;padding:8px 12px;border-bottom:1px solid #1a1a1a}.scrubber-bar{position:relative;height:24px}.scrubber-slider{width:100%;height:4px;background:linear-gradient(90deg,#4a9eff,#4a9eff4d);border-radius:2px;outline:none;-webkit-appearance:none;position:absolute;top:10px}.scrubber-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#4a9eff;border:2px solid #fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #00000080}.scrubber-markers{position:absolute;top:0;left:0;width:100%;height:24px;pointer-events:none}.timeline-tracks{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px}.timeline-tracks::-webkit-scrollbar{width:8px;height:8px}.timeline-tracks::-webkit-scrollbar-track{background:#1a1a1a}.timeline-tracks::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:4px}.timeline-track-simple{display:flex;align-items:center;margin:4px 0;height:28px;background:#2a2a2a;border-radius:4px;padding:4px 8px;border:1px solid #333}.track-label-simple{width:80px;font-size:11px;color:#aaa;font-weight:500;padding-right:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-canvas-simple{flex:1;height:20px;background:#1a1a1a;border-radius:3px;position:relative;border:1px solid #2a2a2a}.keyframe-marker{position:absolute;width:4px;height:14px;background:orange;border-radius:2px;top:3px;cursor:pointer;transition:all .1s}.keyframe-marker:hover{background:#ffb733;height:18px;top:1px;width:6px;box-shadow:0 2px 6px #ffa50099}.timeline-empty{font-size:12px;color:#666;padding:20px;text-align:center;background:#ffffff05;border-radius:6px;border:1px dashed rgba(255,255,255,.05)}@media (max-width: 1200px){.main-layout{grid-template-rows:48px 1fr 180px}.workspace{grid-template-columns:240px 1fr}.floating-panel{width:260px;max-height:400px}.mapping-panel{width:520px}.timeline-panel{font-size:11px}}@media (max-width: 768px){.workspace{grid-template-columns:200px 1fr}.mapping-panel{width:480px}.floating-panel{top:10px;right:10px;width:240px}.top-bar{flex-wrap:wrap;height:auto;padding:8px}.status-bar{flex-basis:100%;order:3}}.upload-btn.ai-btn{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;font-weight:600}.upload-btn.ai-btn:hover{background:linear-gradient(135deg,#7b92f7,#8a5cb3);border-color:#7b92f7;transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.ai-panel{width:380px;max-height:80vh;left:50%;top:80px;transform:translate(-50%)}.ai-config{display:flex;flex-direction:column;gap:16px}.ai-input-group{display:flex;flex-direction:column;gap:6px}.ai-input-group label{font-size:11px;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.5px}.ai-input,.ai-select,.ai-textarea{background:#2a2a2a;border:1px solid #444;color:#e0e0e0;padding:8px 10px;border-radius:4px;font-size:12px;font-family:inherit;transition:all .2s}.ai-input:focus,.ai-select:focus,.ai-textarea:focus{outline:none;border-color:#667eea;background:#323232;box-shadow:0 0 0 3px #667eea1a}.ai-textarea{resize:vertical;min-height:80px;font-family:inherit;line-height:1.4}.ai-hint{font-size:10px;color:#777;margin-top:4px}.ai-hint a{color:#667eea;text-decoration:none}.ai-hint a:hover{text-decoration:underline}.ai-actions{display:flex;gap:8px;padding-top:8px}.ai-generate-btn{flex:1;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;padding:12px 20px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.ai-generate-btn:hover:not(:disabled){background:linear-gradient(135deg,#7b92f7,#8a5cb3);transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.ai-generate-btn:active:not(:disabled){transform:translateY(0)}.ai-generate-btn:disabled{opacity:.5;cursor:not-allowed}.ai-status{background:#2a2a2a;border:1px solid #444;border-radius:6px;padding:12px;margin-top:8px}.ai-status.hidden{display:none}.ai-status-text{font-size:11px;color:#aaa;margin-bottom:8px;text-align:center}.ai-progress-bar{height:4px;background:#1a1a1a;border-radius:2px;overflow:hidden}.ai-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);width:0%;transition:width .3s;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.ai-status.success .ai-status-text{color:#6dd47e}.ai-status.error .ai-status-text{color:#ff6b6b}.ai-status.generating .ai-progress-fill{width:100%;background:linear-gradient(90deg,#667eea,#764ba2,#667eea);background-size:200% 100%}.retarget-btn{background:linear-gradient(135deg,#f093fb,#f5576c);border:none;color:#fff;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 2px 8px #f093fb4d}.retarget-btn:hover:not(:disabled){background:linear-gradient(135deg,#f5a4fc,#f76a7d);transform:translateY(-1px);box-shadow:0 4px 12px #f093fb66}.retarget-btn:active:not(:disabled){transform:translateY(0)}.retarget-btn:disabled{opacity:.5;cursor:not-allowed}.retarget-panel{width:420px;max-height:60vh}.mapping-panel{width:680px}.retarget-config{display:flex;flex-direction:column;gap:12px}.mapping-summary-compact{font-size:12px;color:#ddd}.retarget-info{font-size:11px;color:#999;background:#2a2a2a;padding:8px 12px;border-radius:4px;border-left:3px solid #f093fb;margin-bottom:8px}.coordinate-info{margin-top:12px;padding:12px;background:#252525;border-radius:6px;border:1px solid #3a3a3a}.coord-detail{font-size:12px;color:#b0b0b0;padding:4px 0;display:flex;justify-content:space-between}.coord-detail strong{color:#e0e0e0;font-weight:500}.coord-detail span{color:#4a9eff;font-family:Courier New,monospace}.retarget-status{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#2a2a2a;border:1px solid #444;border-radius:6px;font-size:12px}.retarget-status .status-icon{font-size:16px}.retarget-status .status-text{flex:1;color:#ccc}.retarget-status.success{border-color:#6dd47e;background:#6dd47e1a}.retarget-status.success .status-icon,.retarget-status.success .status-text{color:#6dd47e}.retarget-status.error{border-color:#ff6b6b;background:#ff6b6b1a}.retarget-status.error .status-icon,.retarget-status.error .status-text{color:#ff6b6b}.retarget-actions{display:flex;gap:8px;margin-top:8px}.retarget-actions .retarget-btn{flex:1}.retarget-btn.secondary{background:linear-gradient(135deg,#667eea,#764ba2)}.retarget-btn.secondary:hover:not(:disabled){background:linear-gradient(135deg,#7b92f7,#8a5cb3)}.retarget-btn.primary{background:linear-gradient(135deg,#f093fb,#f5576c);padding:12px 20px;font-size:13px}.retarget-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#f5a4fc,#f76a7d)}.retarget-btn.success{background:linear-gradient(135deg,#6dd47e,#56ab67)}.retarget-btn.success:hover:not(:disabled){background:linear-gradient(135deg,#7ddf8e,#66bc77)}.mapping-summary{background:#2a2a2a;border:1px solid #444;border-radius:6px;padding:12px;margin:8px 0}.mapping-summary .summary-text{font-size:12px;color:#ccc;text-align:center}.mapping-summary strong{color:#f093fb;font-weight:700}.mapping-list{max-height:200px;overflow-y:auto;background:#1a1a1a;border:1px solid #333;border-radius:4px;padding:8px}.mapping-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#2a2a2a;border:1px solid #444;border-radius:4px;margin-bottom:4px;font-size:11px}.mapping-item:last-child{margin-bottom:0}.mapping-item .bone-name{flex:1;color:#ccc;font-family:Courier New,monospace}.mapping-item .arrow{color:#f093fb;font-weight:700}.mapping-item .node-name{flex:1;color:#6dd47e;font-family:Courier New,monospace;text-align:right}.mapping-item{cursor:pointer;transition:background .2s,border-color .2s}.mapping-item:hover{background:#353535;border-color:#555}.mapping-item.selected{background:#2a4a6a;border-color:#4a9eff;border-left:3px solid #4a9eff}.manual-mapping-section{margin-top:16px;padding:16px;background:#1a1a1a;border:1px solid #333;border-radius:6px}.manual-mapping-header{margin-bottom:16px}.manual-mapping-title{font-size:14px;font-weight:600;color:#4a9eff;margin-bottom:8px}.manual-mapping-container{display:flex;gap:12px;align-items:stretch;margin-bottom:16px}.bone-list-container{flex:1;display:flex;flex-direction:column;background:#0f0f0f;border:1px solid #333;border-radius:4px;overflow:hidden}.bone-list-header{padding:10px 12px;background:#252525;border-bottom:1px solid #333;display:flex;flex-direction:column;gap:8px}.bone-list-title{font-size:11px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px}.bone-search-input{width:100%;padding:6px 10px;background:#1a1a1a;border:1px solid #333;border-radius:3px;color:#e0e0e0;font-size:11px;outline:none;transition:border-color .2s}.bone-search-input:focus{border-color:#4a9eff}.bone-search-input::placeholder{color:#666}.bone-list{height:250px;overflow-y:auto;overflow-x:hidden}.bone-list-item{padding:8px 12px;border-bottom:1px solid #2a2a2a;cursor:pointer;transition:background .2s;font-size:11px;font-family:Courier New,monospace;color:#e0e0e0;display:flex;align-items:center;gap:8px}.bone-list-item:hover{background:#252525}.bone-list-item.selected{background:#2a4a6a;color:#fff;border-left:3px solid #4a9eff}.bone-list-item.mapped{color:#4ade80;position:relative}.bone-list-item.mapped:after{content:"✓";margin-left:auto;color:#4ade80;font-weight:700;font-size:14px}.bone-list-item.disabled{opacity:.4;cursor:not-allowed;text-decoration:line-through}.bone-list-item.disabled:hover{background:transparent}.bone-list-item .bone-role{font-size:10px;color:#666;margin-left:auto;font-style:italic}.mapping-arrow{display:flex;align-items:center;justify-content:center;font-size:24px;color:#666;width:30px;flex-shrink:0}.manual-mapping-actions{display:flex;gap:8px;align-items:center}.manual-mapping-hint{font-size:11px;color:#999;font-style:italic;margin-left:auto}.retarget-btn.danger{background:linear-gradient(135deg,#ef4444,#dc2626);border:1px solid #b91c1c}.retarget-btn.danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466}.export-actions{margin-top:12px;padding:12px;background:#2a2a2a;border:1px solid #444;border-radius:6px}.export-actions .property-label{margin-bottom:8px}.export-actions .retarget-info{margin-bottom:4px;padding:4px 0;background:transparent;border:none}.upload-btn.retarget-btn{background:linear-gradient(135deg,#f093fb,#f5576c)}.upload-btn.retarget-btn:hover{background:linear-gradient(135deg,#f5a4fc,#f76a7d)}
