*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;overflow:hidden}#root{height:100vh;width:100vw}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;overflow:hidden;display:flex;background-color:#f5f7fa;color:#1a202c;font-size:14px;line-height:1.5}.app{display:flex;height:100vh;width:100vw}.sidebar{resize:horizontal;width:480px;min-width:280px;max-width:650px;height:100vh;background:linear-gradient(180deg,#fff,#f8f9fa);padding:0;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;border-right:2px solid #e2e8f0;display:flex;flex-direction:column;box-shadow:2px 0 8px #0000000d}.viewer-container{flex-grow:1;height:100vh}.ribbon-menu{background:#fff;border-bottom:2px solid #e2e8f0;flex-shrink:0;box-shadow:0 2px 4px #0000000a;position:sticky;top:0;z-index:100}.ribbon-tabs{display:flex;background-color:#f8f9fa;border-bottom:1px solid #e2e8f0;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scrollbar-color:#cbd5e0 transparent;-webkit-overflow-scrolling:touch}.ribbon-tabs::-webkit-scrollbar{height:6px}.ribbon-tabs::-webkit-scrollbar-track{background:#f1f5f9}.ribbon-tabs::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.ribbon-tabs::-webkit-scrollbar-thumb:hover{background:#94a3b8}.ribbon-tab{background-color:transparent;color:#64748b;border:none;border-right:1px solid #e2e8f0;padding:12px 20px;cursor:pointer;font-size:.8125rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:100px;max-width:140px;position:relative;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;text-align:center}.ribbon-tab:hover{background-color:#f1f5f9;color:#334155}.ribbon-tab.active{background-color:#fff;color:#2563eb;border-bottom:3px solid #2563eb;z-index:1}.ribbon-tab.active:after{content:"";position:absolute;bottom:-3px;left:0;right:0;height:3px;background-color:#2563eb;border-radius:2px 2px 0 0}.ribbon-tab:last-child{border-right:none}.ribbon-content{background-color:#fff;padding:20px;min-height:140px;max-height:60vh;overflow-y:auto;scrollbar-width:thin}.ribbon-content::-webkit-scrollbar{width:6px}.ribbon-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.ribbon-panel{display:flex;flex-wrap:wrap;gap:24px;align-items:flex-start}.ribbon-group{display:flex;flex-direction:column;gap:12px;min-width:220px;flex:1;background:#f8f9fa;padding:16px;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s ease}.ribbon-group:hover{border-color:#cbd5e0;box-shadow:0 2px 4px #0000000a}.ribbon-group h4{margin:0 0 12px;color:#1e293b;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid #e2e8f0;padding-bottom:8px}.ribbon-buttons{display:flex;flex-wrap:wrap;gap:6px}.ribbon-button{background-color:#fff;color:#475569;border:1.5px solid #cbd5e0;border-radius:6px;padding:8px 16px;cursor:pointer;font-size:.8125rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;white-space:nowrap;box-shadow:0 1px 2px #0000000d}.ribbon-button:hover{background-color:#f1f5f9;border-color:#94a3b8;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.ribbon-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000000d}.ribbon-button.active{background-color:#2563eb;color:#fff;border-color:#2563eb;box-shadow:0 2px 4px #2563eb4d}.ribbon-button.active:hover{background-color:#1d4ed8;border-color:#1d4ed8}.ribbon-button.primary{background-color:#2563eb;color:#fff;border-color:#2563eb}.ribbon-button.primary:hover{background-color:#1d4ed8;border-color:#1d4ed8;box-shadow:0 4px 6px #2563eb4d}.ribbon-button.danger{background-color:#ef4444;color:#fff;border-color:#ef4444}.ribbon-button.danger:hover{background-color:#dc2626;border-color:#dc2626;box-shadow:0 4px 6px #ef44444d}.ribbon-button:disabled{background-color:#3a414c;color:#666;cursor:not-allowed;opacity:.6}.ribbon-controls{display:flex;flex-direction:column;gap:12px}.ribbon-control{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ribbon-control label{font-size:.8125rem;color:#475569;min-width:90px;font-weight:600;text-align:left}.ribbon-control input[type=text],.ribbon-control input[type=number],.ribbon-control select{background-color:#fff;color:#1e293b;border:1.5px solid #cbd5e0;border-radius:6px;padding:8px 12px;font-size:.8125rem;flex:1;min-width:120px;transition:all .2s ease}.ribbon-control input[type=text]:focus,.ribbon-control input[type=number]:focus,.ribbon-control select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.ribbon-control input[type=range]{width:60px}.ribbon-control input[type=color]{width:24px;height:24px;border:none;border-radius:3px;cursor:pointer}.ribbon-control span{font-size:.75em;color:#aaa;min-width:20px}.ribbon-checkbox{display:flex;align-items:center;gap:6px;font-size:.8em;color:#f1f1f1;cursor:pointer}.ribbon-checkbox input[type=checkbox]{width:14px;height:14px;accent-color:#4f5b6f}.file-button{position:relative;overflow:hidden}.file-button input[type=file]{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}canvas{display:block}h3,h4{margin:0 0 12px;padding-bottom:12px;border-bottom:2px solid #e2e8f0;color:#1e293b;font-weight:700}.control-section{margin:16px;padding:20px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.control-section h4{margin:0 0 16px;color:#1e293b;font-size:1rem;font-weight:700;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.file-input-wrapper{margin-bottom:15px}input[type=file],input[type=range],input[type=number]{display:none}input[type=range],input[type=number]{display:block;width:100%;margin-bottom:10px}input[type=number]{background-color:#fff;color:#1e293b;padding:8px 12px;border-radius:6px;border:1.5px solid #cbd5e0;font-size:.875rem;transition:all .2s ease}input[type=number]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.file-input-label,button,select{background-color:#fff;color:#475569;padding:10px 16px;border-radius:6px;cursor:pointer;display:block;text-align:center;border:1.5px solid #cbd5e0;width:100%;box-sizing:border-box;font-size:.875rem;font-weight:600;margin-bottom:12px;appearance:none;-webkit-appearance:none;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.file-input-label:hover,button:not(:disabled):hover,select:not(:disabled):hover{background-color:#f1f5f9;border-color:#94a3b8;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}button:disabled,select:disabled{background-color:#f1f5f9;color:#94a3b8;cursor:not-allowed;opacity:.6;border-color:#e2e8f0}.hierarchy-item{display:flex;align-items:center;padding:8px 12px;margin:4px 0;border-radius:6px;transition:background-color .2s ease}.hierarchy-item:hover{background-color:#f8f9fa}.hierarchy-item label{margin-left:12px;font-size:.875rem;white-space:normal;word-wrap:break-word;overflow-wrap:break-word;flex:1;min-width:0;color:#334155;font-weight:500;cursor:pointer}.hierarchy-item input[type=checkbox]{width:14px;height:14px;cursor:pointer}.hierarchy-item input[type=checkbox]:first-of-type{accent-color:#4f5b6f}.hierarchy-item input[type=checkbox]:nth-of-type(2){accent-color:#00aa00}.hierarchy-children{margin-left:20px;border-left:1px solid #444;padding-left:10px}.grid-controls{display:flex;flex-wrap:wrap;gap:10px}.grid-controls button{flex:1;min-width:80px}.status-message{padding:14px 18px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;font-size:.875rem;text-align:left;min-height:24px;margin:16px;border:none;color:#fff;font-weight:500;box-shadow:0 2px 8px #667eea4d;word-wrap:break-word;line-height:1.5}.collapse-button{background:none;border:none;color:#64748b;cursor:pointer;margin-right:8px;font-size:12px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;border-radius:4px}.collapse-button:hover{color:#2563eb;background-color:#f1f5f9}.collapse-spacer{width:16px;margin-right:5px}.hidden{display:none!important}.hierarchy-item input[type=color]{width:20px;height:20px;border:none;border-radius:3px;cursor:pointer;padding:0;background:none}.hierarchy-item input[type=color]::-webkit-color-swatch-wrapper{padding:0}.hierarchy-item input[type=color]::-webkit-color-swatch{border:none;border-radius:3px}.hierarchy-item input[type=color]::-moz-color-swatch{border:none;border-radius:3px}.color-controls{display:flex;align-items:center;gap:8px;margin-left:12px}.collapsible-section{margin-bottom:16px}.collapsible-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.collapsible-header:hover{background:#f1f5f9;border-color:#cbd5e0}.collapsible-header h4{margin:0;font-size:.875rem;font-weight:700;color:#1e293b;text-transform:uppercase;letter-spacing:.5px;border:none;padding:0}.collapsible-icon{transition:transform .2s ease;color:#64748b;font-size:.875rem}.collapsible-header.collapsed .collapsible-icon{transform:rotate(-90deg)}.collapsible-content{padding:16px;background:#fff;border:1px solid #e2e8f0;border-top:none;border-radius:0 0 8px 8px;animation:slideDown .2s ease-out}.collapsible-content.collapsed{display:none}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.workflow-steps{display:flex;gap:8px;margin-bottom:20px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e2e8f0}.workflow-step{flex:1;text-align:center;padding:8px;border-radius:6px;font-size:.75rem;font-weight:600;color:#64748b;background:#fff;border:2px solid #e2e8f0;transition:all .2s ease}.workflow-step.active{color:#2563eb;border-color:#2563eb;background:#eff6ff}.workflow-step.completed{color:#10b981;border-color:#10b981;background:#ecfdf5}.button-group{display:flex;gap:8px;flex-wrap:wrap}.button-group .ribbon-button{flex:1;min-width:100px}.info-badge{display:inline-block;padding:4px 8px;background:#eff6ff;color:#2563eb;border-radius:4px;font-size:.75rem;font-weight:600;margin-left:8px}.info-badge.success{background:#ecfdf5;color:#10b981}.info-badge.warning{background:#fffbeb;color:#f59e0b}.info-badge.error{background:#fef2f2;color:#ef4444}.color-controls button{font-size:.7em;padding:2px 4px;background-color:#ff6b6b;color:#fff;border:none;border-radius:2px;cursor:pointer;min-width:auto;width:auto;margin:0}.color-controls button:hover{background-color:#ff5252}.text-controls{margin-top:12px;padding:16px;background-color:#f8f9fa;border-radius:8px;border:1px solid #e2e8f0}.text-controls label{display:block;margin-bottom:8px;font-size:.875rem;color:#475569;font-weight:600}.text-controls input[type=text]{display:block;width:100%;margin-bottom:12px;background-color:#fff;color:#1e293b;border:1.5px solid #cbd5e0;border-radius:6px;padding:10px 14px;box-sizing:border-box;font-size:.875rem;transition:all .2s ease}.text-controls input[type=text]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.text-controls input[type=range]{display:block;width:100%;margin-bottom:5px}.text-controls input[type=color]{display:block;width:100%;height:40px;margin-bottom:10px;border:none;border-radius:4px;cursor:pointer}.text-controls input[type=checkbox]{width:16px;height:16px;margin-right:8px;accent-color:#4f5b6f}.text-labels-list{margin-top:15px;max-height:200px;overflow-y:auto}.text-labels-list h5{margin:0 0 10px;color:#f1f1f1;font-size:.9em}.text-label-item{display:flex;align-items:center;margin-bottom:8px;padding:10px 12px;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;transition:all .2s ease}.text-label-item:hover{border-color:#cbd5e0;box-shadow:0 1px 3px #0000000d}.text-label-item button{margin:0 4px;padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s ease}.text-label-item button:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{background:#fff;border-radius:8px;padding:16px 20px;box-shadow:0 4px 12px #00000026;border-left:4px solid #2563eb;display:flex;align-items:flex-start;gap:12px;animation:slideIn .3s ease-out;min-width:300px}.toast.success{border-left-color:#10b981}.toast.error{border-left-color:#ef4444}.toast.warning{border-left-color:#f59e0b}.toast.info{border-left-color:#2563eb}.toast-content{flex:1}.toast-title{font-weight:600;font-size:.875rem;color:#1e293b;margin-bottom:4px}.toast-message{font-size:.8125rem;color:#64748b;line-height:1.5}.toast-close{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:18px;line-height:1;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.toast-close:hover{color:#475569}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast.slide-out{animation:slideOut .3s ease-in forwards}.location-list{max-height:300px;overflow-y:auto;scrollbar-width:thin}.location-list::-webkit-scrollbar{width:6px}.location-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.location-item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px;border:1px solid #e2e8f0;margin:8px 0;border-radius:8px;background:#fff;transition:all .2s ease}.location-item:hover{border-color:#cbd5e0;box-shadow:0 2px 4px #0000000d}.grid-controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.grid-controls button{flex:1;min-width:100px;font-size:.8125rem}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23475569' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 40px #0003;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1a202c}.modal-close{background:none;border:none;font-size:28px;color:#64748b;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background-color:#f1f5f9;color:#1a202c}.modal-body{padding:24px}
