*{box-sizing:border-box;margin:0;padding:0}:root{--bg-overlay:#ffffffe0;--bg-overlay-solid:#fff;--bg-secondary:#f5f5f7;--bg-tertiary:#eaeaef;--text-primary:#1d1d1f;--text-secondary:#86868b;--accent:#007aff;--accent-hover:#0066d6;--border:#00000014;--selected:#007aff1f;--accent-bg:#007aff14;--danger:#ff3b30;--radius:12px;--shadow:0 8px 32px #0000001f, 0 2px 8px #0000000f}body{color:var(--text-primary);background:#e8e8ed;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{height:100vh}.app{width:100vw;height:100vh;position:relative;overflow:hidden}.app-title{color:var(--accent);font-size:13px;font-weight:600}.connection-dot{background:var(--danger);border-radius:50%;width:8px;height:8px;transition:background .3s}.connection-dot.connected{background:#2ecc71}.overlay-left{z-index:10;position:absolute;top:16px;left:16px}.toolbar{background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);flex-direction:column;gap:2px;padding:8px;display:flex}.toolbar-header{border-bottom:1px solid var(--border);align-items:center;gap:6px;margin-bottom:4px;padding:6px 10px;display:flex}.toolbar-section{flex-direction:column;gap:2px;display:flex}.toolbar-divider{background:var(--border);height:1px;margin:6px 4px}.tool-btn{color:var(--text-primary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;min-width:120px;padding:8px 12px;font-size:13px;transition:background .15s;display:flex}.tool-btn:hover{background:#0000000a}.tool-btn.active{background:var(--selected);color:var(--accent)}.tool-btn span{font-size:13px}.overlay-right{z-index:10;width:260px;max-height:calc(100vh - 200px);position:absolute;top:140px;right:16px}.layer-panel{background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);flex-direction:column;max-height:calc(100vh - 160px);display:flex;overflow:hidden}.panel-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;font-size:12px;font-weight:600;display:flex}.add-group-btn{background:var(--bg-secondary);border:1px solid var(--border);color:var(--accent);cursor:pointer;border-radius:6px;align-items:center;gap:3px;padding:3px 8px;font-size:11px;transition:background .15s;display:inline-flex}.add-group-btn:hover{background:var(--bg-tertiary)}.panel-header-actions{align-items:center;gap:4px;display:flex}.panel-header-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:background .15s,color .15s;display:flex}.panel-header-btn:hover{color:var(--text-primary);background:#0000000f}.panel-header-btn:disabled{opacity:.3;cursor:default}.panel-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:background .15s;display:flex}.panel-close-btn:hover{color:var(--text-primary);background:#0000000f}.layer-tree{flex:1;padding:4px 0;overflow-y:auto}.layer-item{cursor:grab;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:6px;min-height:32px;margin:1px 6px 1px 0;padding:5px 10px;font-size:13px;transition:background .1s;display:flex}.layer-item:active{cursor:grabbing}.layer-item:hover{background:#0000000a}.layer-item.selected{background:var(--selected)}.layer-collapse-btn{cursor:pointer;color:var(--text-secondary);flex-shrink:0;align-items:center;margin-right:2px;padding:0;display:flex}.layer-collapse-btn:hover{color:var(--text-primary)}.layer-chevron{transition:transform .15s}.layer-chevron.open{transform:rotate(90deg)}.layer-icon{color:var(--text-secondary);flex-shrink:0;align-items:center;display:flex}.layer-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;overflow:hidden}.rename-input{background:var(--bg-secondary);border:1px solid var(--accent);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:2px 6px;font-size:12px}.bool-op-select{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:4px;padding:2px 4px;font-size:10px}.role-btn,.vis-btn,.del-btn{color:var(--text-secondary);cursor:pointer;opacity:.4;background:0 0;border:none;align-items:center;padding:2px;transition:opacity .15s,color .15s;display:flex}.role-btn:hover,.vis-btn:hover,.del-btn:hover{opacity:1}.role-btn.role-hole{opacity:.9;color:#ff8c00}.role-btn.role-hole:hover{opacity:1}.del-btn:hover{color:var(--danger)}.hole-icon{color:#ff8c00}.overlay-properties{z-index:10;width:260px;max-height:50vh;position:absolute;bottom:16px;right:16px}.properties-panel{background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);flex-direction:column;max-height:50vh;display:flex;overflow-y:auto}.prop-empty{color:var(--text-secondary);text-align:center;padding:16px 14px;font-size:12px}.prop-section{border-bottom:1px solid var(--border);padding:10px 14px}.prop-section:last-child{border-bottom:none}.prop-section-toggle{cursor:pointer;width:100%;color:inherit;background:0 0;border:none;align-items:center;gap:4px;margin-bottom:0;padding:0;display:flex}.prop-section-toggle .prop-section-title{margin-bottom:0}.prop-section-toggle:hover .prop-section-title{color:var(--text-primary)}.prop-chevron{color:var(--text-secondary);flex-shrink:0;transition:transform .15s}.prop-chevron.open{transform:rotate(90deg)}.prop-section-toggle+*{margin-top:8px}.prop-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px;font-weight:600}.prop-field{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.prop-field label{color:var(--text-secondary);min-width:50px;font-size:12px}.prop-field input[type=number]{background:var(--bg-secondary);border:1px solid var(--border);width:80px;color:var(--text-primary);text-align:right;-moz-appearance:textfield;border-radius:6px;outline:none;padding:4px 8px;font-size:12px;transition:border-color .15s}.prop-field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.prop-field input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.prop-field input[type=number]:focus{border-color:var(--accent)}.prop-field select{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;outline:none;flex:1;padding:4px 8px;font-size:12px}.prop-field span{color:var(--text-primary);font-size:12px}.input-with-unit{align-items:center;gap:4px;display:flex}.unit-label{color:var(--text-secondary);white-space:nowrap;font-size:11px}.inline-xyz{gap:6px;display:flex}.xyz-field{flex:1;align-items:center;gap:3px;display:flex}.xyz-field label{color:var(--text-secondary);font-size:12px;font-weight:500}.xyz-field input[type=number]{background:var(--bg-secondary);border:1px solid var(--border);width:100%;min-width:0;color:var(--text-primary);-moz-appearance:textfield;text-align:right;border-radius:6px;outline:none;padding:4px 6px;font-size:12px;transition:border-color .15s}.xyz-field input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.xyz-field input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.xyz-field input[type=number]:focus{border-color:var(--accent)}.model-info{margin-top:8px}.color-picker-row{flex-wrap:wrap;gap:6px;padding:4px 0;display:flex}.color-swatch{cursor:pointer;background-position:50%;background-size:cover;border:2px solid #0000;border-radius:6px;width:28px;height:28px;padding:0;transition:transform .1s,border-color .15s;box-shadow:inset 0 0 0 1px #0000001a}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--accent);box-shadow:inset 0 0 0 1px #0000001a, 0 0 0 2px var(--accent)}.color-input::-webkit-color-swatch-wrapper{padding:2px}.color-input::-webkit-color-swatch{border:none;border-radius:2px}.overlay-chat{z-index:10;width:340px;max-height:calc(100vh - 80px);position:absolute;top:16px;left:160px}.chat-panel{background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);flex-direction:column;max-height:calc(100vh - 120px);display:flex;overflow:hidden}.chat-messages{flex-direction:column;flex:1;gap:8px;min-height:120px;max-height:50vh;padding:12px;display:flex;overflow-y:auto}.chat-empty{color:var(--text-secondary);text-align:center;padding:24px 16px;font-size:12px;line-height:1.5}.chat-bubble{word-wrap:break-word;white-space:pre-wrap;border-radius:12px;max-width:85%;padding:8px 12px;font-size:13px;line-height:1.4}.chat-user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-assistant{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px;align-self:flex-start}.chat-loading{color:var(--text-secondary);font-style:italic}.chat-bubble code{background:#0000000f;border-radius:3px;padding:1px 4px;font-family:SF Mono,Monaco,monospace;font-size:12px}.chat-user code{background:#fff3}.chat-error{color:#c33;background:#fff0f0;border:1px solid #fcc;border-bottom-left-radius:4px;flex-direction:column;align-self:flex-start;gap:8px;display:flex}.chat-resend-btn{color:#c33;cursor:pointer;background:#fff;border:1px solid #c33;border-radius:6px;align-self:flex-start;align-items:center;gap:4px;padding:4px 10px;font-size:12px;transition:background .15s;display:inline-flex}.chat-resend-btn:hover:not(:disabled){background:#fff0f0}.chat-resend-btn:disabled{opacity:.5;cursor:not-allowed}.chat-bullet{padding-left:12px;display:block;position:relative}.chat-bullet:before{content:"•";position:absolute;left:0}.dot-pulse{background:var(--text-secondary);border-radius:50%;width:4px;height:4px;margin-right:6px;animation:1.2s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,80%,to{opacity:.3}40%{opacity:1}}.chat-input-area{border-top:1px solid var(--border);align-items:flex-end;gap:6px;padding:10px 12px;display:flex}.chat-input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);resize:none;border-radius:8px;outline:none;flex:1;max-height:80px;padding:8px 12px;font-family:inherit;font-size:13px;line-height:1.4;transition:border-color .15s}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-secondary)}.chat-input:disabled{opacity:.6}.chat-send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s;display:flex}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-attach-btn{border:1px solid var(--border);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.chat-attach-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.chat-attach-btn:disabled{opacity:.4;cursor:not-allowed}.chat-image-previews{flex-wrap:wrap;gap:6px;padding:8px 12px 0;display:flex}.chat-image-thumb{border:1px solid var(--border);border-radius:6px;width:48px;height:48px;position:relative;overflow:hidden}.chat-image-thumb img{object-fit:cover;width:100%;height:100%}.chat-image-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;padding:0;display:flex;position:absolute;top:2px;right:2px}.overlay-bottom-left{z-index:10;background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);gap:4px;padding:6px;display:flex;position:absolute;bottom:16px;left:16px}.bottom-btn{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.bottom-btn:hover{color:var(--text-primary);background:#0000000f}.bottom-btn.active{background:var(--selected);color:var(--accent)}.bottom-btn:disabled{opacity:.25;cursor:not-allowed;pointer-events:none}.export-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.export-dialog{background:var(--bg-overlay-solid);border-radius:var(--radius);border:1px solid var(--border);width:340px;overflow:hidden;box-shadow:0 20px 60px #0003}.export-preview{background:var(--bg-secondary);border-bottom:1px solid var(--border);justify-content:center;align-items:center;height:180px;display:flex}.export-preview-placeholder{color:var(--text-secondary);text-align:center;font-size:12px}.export-field{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 16px;display:flex}.export-field label{color:var(--text-secondary);min-width:65px;font-size:12px}.export-name-input{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;outline:none;flex:1;padding:6px 10px;font-family:inherit;font-size:13px}.export-name-input:focus{border-color:var(--accent)}.export-format-row{flex:1;gap:6px;display:flex}.export-format-btn{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:6px;flex:1;padding:6px 12px;font-size:12px;font-weight:600;transition:all .15s}.export-format-btn:hover{background:var(--bg-tertiary)}.export-format-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.export-error{color:var(--danger);padding:8px 16px;font-size:12px}.export-submit-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;width:100%;padding:12px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s}.export-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.export-submit-btn:disabled{opacity:.5;cursor:not-allowed}.edge-dropdown{flex-shrink:0;position:relative}.edge-dropdown-trigger{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:4px;align-items:center;gap:4px;min-width:78px;padding:2px 6px 2px 4px;font-size:11px;transition:border-color .15s;display:flex}.edge-dropdown-trigger:hover{border-color:#00000026}.edge-dropdown-chevron{opacity:.5;margin-left:auto}.edge-dropdown-menu{z-index:50;background:var(--bg-overlay-solid);border:1px solid var(--border);border-radius:6px;min-width:110px;padding:3px;position:absolute;top:calc(100% + 2px);left:0;box-shadow:0 4px 16px #0000001f}.edge-dropdown-item{width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:6px;padding:5px 8px;font-size:11px;transition:background .1s;display:flex}.edge-dropdown-item:hover{background:#0000000a}.edge-dropdown-item.active{background:var(--selected);color:var(--accent)}.viewcube{z-index:10;pointer-events:auto;cursor:grab;width:80px;height:80px;position:absolute;top:8px;right:8px}.viewcube:active{cursor:grabbing}.measure-label{color:#fff;pointer-events:none;white-space:nowrap;z-index:50;background:#282828bf;border-radius:3px;padding:2px 7px;font-family:-apple-system,BlinkMacSystemFont,sans-serif;font-size:12px;font-weight:500;position:absolute;transform:translate(-50%,-150%)}.toast-container{z-index:200;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%)}.toast{background:var(--bg-overlay-solid);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);pointer-events:auto;border-radius:10px;align-items:center;gap:10px;max-width:400px;padding:10px 16px;font-size:13px;animation:.25s ease-out toast-in;display:flex;box-shadow:0 8px 24px #00000026}.toast-error{border-left:3px solid var(--danger)}.toast-success{border-left:3px solid #2ecc71}.toast-info{border-left:3px solid var(--accent)}.toast-message{color:var(--text-primary);flex:1}.toast-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:background .15s;display:flex}.toast-close:hover{background:#0000000f}@keyframes toast-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.evaluating-indicator{z-index:10;background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:var(--shadow);color:var(--text-secondary);border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:12px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.evaluating-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#00000026;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#00000040}@media (width<=900px){.overlay-right,.overlay-properties{width:220px}.overlay-chat{width:280px;left:140px}.tool-btn{gap:8px;min-width:0;padding:8px 10px}}@media (width<=640px){.overlay-left{top:8px;left:8px}.tool-btn span{display:none}.tool-btn{justify-content:center;min-width:0;padding:8px}.toolbar{padding:6px}.toolbar-header .app-title{display:none}.overlay-right{width:200px;max-height:40vh;top:auto;bottom:64px;right:8px}.overlay-properties{width:200px;max-height:35vh;bottom:64px;right:8px}.overlay-chat{width:auto;max-height:50vh;inset:auto 8px 64px}.overlay-bottom-left{padding:4px;bottom:8px;left:8px}.bottom-btn{width:32px;height:32px}.viewcube{display:none}.export-dialog{width:90vw;max-width:340px}}
