*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0e0e0f;--surface: #161618;--surface2: #1e1e21;--border: #2a2a2e;--border2: #3a3a40;--text: #e8e8ea;--text2: #9090a0;--text3: #5a5a6a;--accent: #c8ff57;--accent2: #a8e040;--accent-dim: rgba(200,255,87,.12);--accent-glow: rgba(200,255,87,.06);--red: #ff5f57;--amber: #febc2e;--green: #28c840;--font-mono: "DM Mono", monospace;--font-serif: "Instrument Serif", serif;--font-sans: "DM Sans", sans-serif;--radius: 10px;--radius-sm: 6px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);height:100vh;display:flex;flex-direction:column;overflow:hidden}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-overlay.hidden{display:none}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:32px;width:420px;display:flex;flex-direction:column;gap:16px}.modal-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:15px;font-weight:500;color:var(--text);margin-bottom:4px}.modal-title{font-family:var(--font-serif);font-size:22px;color:var(--text);letter-spacing:-.02em}.modal-sub{font-size:13px;color:var(--text3);line-height:1.6}.modal-input{width:100%;font-family:var(--font-mono);font-size:13px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text);padding:10px 14px;outline:none;transition:border-color .15s}.modal-input:focus{border-color:#c8ff5766}.modal-btn{width:100%;justify-content:center;padding:10px}header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg)}.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:15px;font-weight:500;color:var(--text);letter-spacing:-.02em}.logo-icon{width:28px;height:28px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center}.logo-icon svg{width:16px;height:16px}.header-actions{display:flex;align-items:center;gap:8px}.btn{font-family:var(--font-sans);font-size:13px;font-weight:500;padding:7px 14px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface2);color:var(--text2);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn:hover{border-color:var(--border2);color:var(--text);background:#252529}.btn-primary{background:var(--accent);border-color:var(--accent);color:#0e0e0f;font-weight:500}.btn-primary:hover{background:var(--accent2);border-color:var(--accent2);color:#0e0e0f}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.app-body{display:flex;flex:1;overflow:hidden}.left-panel{width:420px;min-width:260px;max-width:70vw;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--surface)}.panel-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 16px;gap:2px}.tab{font-family:var(--font-mono);font-size:12px;padding:12px 14px 10px;cursor:pointer;color:var(--text3);border-bottom:2px solid transparent;transition:all .15s;-webkit-user-select:none;user-select:none;margin-bottom:-1px}.tab:hover{color:var(--text2)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{display:none;flex:1;flex-direction:column;overflow:hidden}.tab-content.active{display:flex}.prompt-area{flex:1;display:flex;flex-direction:column;padding:16px;gap:12px;overflow-y:auto}.message-list{display:flex;flex-direction:column;gap:12px}.msg{display:flex;gap:10px;animation:fadeUp .25s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.msg-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;margin-top:2px}.msg.user .msg-avatar{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(200,255,87,.2)}.msg.ai .msg-avatar{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.msg-bubble{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-size:13.5px;line-height:1.6;color:var(--text2);max-width:calc(100% - 42px);word-break:break-word}.msg.user .msg-bubble{background:var(--accent-dim);border-color:#c8ff5733;color:var(--text)}.msg-time{font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-top:4px}.input-zone{border-top:1px solid var(--border);padding:14px 16px;background:var(--surface)}.prompt-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.suggestion{font-size:11.5px;font-family:var(--font-mono);padding:5px 10px;border-radius:20px;border:1px solid var(--border2);color:var(--text3);cursor:pointer;transition:all .15s;white-space:nowrap}.suggestion:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.input-row{display:flex;gap:8px;align-items:flex-end}textarea{flex:1;font-family:var(--font-sans);font-size:14px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text);padding:10px 14px;resize:none;outline:none;transition:border-color .15s;min-height:44px;max-height:160px;line-height:1.5}textarea::placeholder{color:var(--text3)}textarea:focus{border-color:#c8ff5766}.canvas-toolbar{display:flex;flex-direction:column;gap:0;border-bottom:1px solid var(--border);flex-shrink:0}.toolbar-row{display:flex;align-items:center;gap:5px;padding:7px 12px}.toolbar-row+.toolbar-row{border-top:1px solid var(--border);background:#ffffff03}.toolbar-label{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-right:2px}.toolbar-divider{width:1px;height:20px;background:var(--border);margin:0 3px}.tool-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}.tool-btn:hover,.tool-btn.active{background:var(--accent-dim);border-color:#c8ff574d;color:var(--accent)}.color-dot{width:20px;height:20px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:border-color .15s}.color-dot.active{border-color:var(--accent)}.stroke-select{background:var(--surface2);border:1px solid var(--border);color:var(--text2);padding:4px 6px;border-radius:4px;font-size:12px;font-family:var(--font-mono)}#draw-canvas{cursor:crosshair;background:#fff;display:block;width:100%}#draw-canvas.is-drawing{outline:1px solid rgba(200,255,87,.25)}.canvas-footer{border-top:1px solid var(--border);padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}.canvas-hint{font-size:12px;color:var(--text3);font-family:var(--font-mono)}.panel-resizer{width:4px;flex-shrink:0;background:var(--border);cursor:col-resize;transition:background .15s;position:relative;z-index:10}.panel-resizer:hover,.panel-resizer.dragging{background:var(--accent)}.right-panel{flex:1;display:flex;flex-direction:column;background:#0a0a0b;overflow:hidden}.preview-bar{display:flex;align-items:center;gap:10px;padding:0 16px;height:44px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.traffic-lights{display:flex;gap:6px;align-items:center}.light{width:12px;height:12px;border-radius:50%}.light.r{background:var(--red)}.light.a{background:var(--amber)}.light.g{background:var(--green)}.url-bar{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:5px 12px;font-family:var(--font-mono);font-size:12px;color:var(--text3);display:flex;align-items:center;gap:6px}.preview-actions{display:flex;gap:6px}.preview-container{flex:1;position:relative;overflow:hidden}#preview-frame{width:100%;height:100%;border:none;background:#fff}.empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:#0a0a0b;transition:opacity .4s ease}.empty-state.hidden{opacity:0;pointer-events:none}.empty-icon{width:72px;height:72px;border:1px solid var(--border2);border-radius:16px;display:flex;align-items:center;justify-content:center;background:var(--surface)}.empty-title{font-family:var(--font-serif);font-size:26px;color:var(--text);text-align:center;letter-spacing:-.02em}.empty-sub{font-size:14px;color:var(--text3);text-align:center;max-width:280px;line-height:1.6}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0be6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10}.loading-overlay.active{opacity:1;pointer-events:all}.spinner{width:40px;height:40px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-steps{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.loading-step{font-family:var(--font-mono);font-size:12px;color:var(--text3);display:flex;align-items:center;gap:8px;transition:color .3s}.loading-step.done{color:var(--accent)}.loading-step .dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.status-bar{display:flex;align-items:center;gap:16px;padding:6px 16px;border-top:1px solid var(--border);background:var(--surface);font-family:var(--font-mono);font-size:11px;color:var(--text3);flex-shrink:0}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--text3);flex-shrink:0}.status-dot.online{background:var(--green)}.code-panel{display:none;flex:1;overflow:auto;background:#0a0a0b}.code-panel.active{display:block}.code-panel pre{font-family:var(--font-mono);font-size:12px;color:var(--text2);padding:20px;line-height:1.7;white-space:pre-wrap;word-break:break-all}.view-toggle{display:flex;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.view-btn{padding:5px 12px;font-family:var(--font-mono);font-size:11px;cursor:pointer;color:var(--text3);background:transparent;border:none;transition:all .15s}.view-btn.active{background:var(--accent-dim);color:var(--accent)}.size-badge{font-family:var(--font-mono);font-size:10px;color:var(--text3);padding:3px 8px;background:var(--surface2);border:1px solid var(--border);border-radius:4px}.token-counter{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm)}.token-bar{width:48px;height:3px;background:var(--border2);border-radius:2px;overflow:hidden}.token-bar-fill{height:100%;background:var(--accent);border-radius:2px;width:0%;transition:width .4s ease}.token-stat{font-family:var(--font-mono);font-size:10px;color:var(--text3);white-space:nowrap}.token-divider{font-size:10px;color:var(--text3);opacity:.4}.figma-tab{padding:20px 16px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;flex:1}.figma-tab-head{display:flex;align-items:flex-start;gap:12px}.figma-tab-title{font-family:var(--font-serif);font-size:16px;color:var(--text);letter-spacing:-.01em;margin-bottom:2px}.figma-tab-sub{font-size:12px;color:var(--text3)}.figma-fields{display:flex;flex-direction:column;gap:8px}.figma-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);display:flex;align-items:center;gap:6px}.figma-label-link{color:var(--accent);text-decoration:none;opacity:.8}.figma-label-link:hover{opacity:1}.figma-input{font-family:var(--font-mono);font-size:12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:7px 10px;outline:none;transition:border-color .15s}.figma-input:focus{border-color:var(--border2)}.figma-fetch-btn{width:100%;justify-content:center}.figma-frames{display:flex;flex-wrap:wrap;gap:5px;max-height:96px;overflow-y:auto}.figma-frame-chip{font-family:var(--font-mono);font-size:10px;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:4px 8px;cursor:pointer;transition:all .15s;white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis}.figma-frame-chip:hover{border-color:var(--border2);color:var(--text)}.figma-frame-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.figma-build-row{display:flex;align-items:center;gap:8px}.figma-selected-label{font-family:var(--font-mono);font-size:10px;color:var(--text3);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.figma-empty,.figma-error{font-family:var(--font-mono);font-size:10px;color:var(--text3);padding:4px 0}.figma-error{color:var(--red)}.component-palette{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:16px}.component-category-title{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:8px}.component-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.component-chip{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px 8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);cursor:grab;-webkit-user-select:none;user-select:none;transition:all .15s;text-align:center}.component-chip:hover{border-color:#c8ff574d;background:var(--accent-dim);transform:translateY(-1px)}.component-chip.dragging{opacity:.4;cursor:grabbing}.component-chip-emoji{font-size:16px;line-height:1}.component-chip-label{font-family:var(--font-mono);font-size:10px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.drop-canvas-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#0a0a0b}.drop-zone{flex:1;overflow-y:auto;padding:16px;transition:background .15s}.drop-zone.drag-over{background:#c8ff570a}.drop-zone-empty{height:100%;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text3);font-family:var(--font-mono);font-size:13px;text-align:center;border:1.5px dashed var(--border2);border-radius:12px}.drop-zone-sub{font-size:11px;color:var(--text3);opacity:.6}.drop-zone-items{display:flex;flex-direction:column;gap:6px}.dropped-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:default;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.dropped-item:hover{border-color:var(--border2);background:var(--surface2)}.dropped-item.dragging{opacity:.35}.dropped-item.drag-target-above{border-top:2px solid var(--accent)}.dropped-item.drag-target-below{border-bottom:2px solid var(--accent)}.dropped-item-drag{color:var(--text3);font-size:14px;cursor:grab;flex-shrink:0;line-height:1}.dropped-item-drag:active{cursor:grabbing}.dropped-item-emoji{font-size:16px;flex-shrink:0}.dropped-item-label{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--text);flex-shrink:0}.dropped-item-desc{font-size:11.5px;color:var(--text3);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropped-item-remove{flex-shrink:0;width:20px;height:20px;border-radius:50%;border:none;background:transparent;color:var(--text3);cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s}.dropped-item-remove:hover{background:#ff5f5726;color:var(--red)}.drop-canvas-footer{border-top:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:8px;background:var(--surface);flex-shrink:0}
