*{box-sizing:border-box}html,body,#root{width:100vw;min-width:100vw;height:100%;margin:0;padding:0;overflow-x:hidden}html,body{background-color:#1e1e1e}#root{background-color:#1e1e1e;display:block}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;--color-bg-primary: #0B0B0B;--color-bg-secondary: #1a1a1a;--color-bg-tertiary: #252525;--color-orange-highlight: #FFA43A;--color-orange-primary: #FF7A18;--color-orange-mid: #FF6A00;--color-orange-deep: #E84A0F;--color-orange-dark: #C63A0A;--color-blue-light: #5A8FBF;--color-blue-primary: #3B6F9E;--color-blue-dark: #2F587E;--color-text-primary: #e0e0e0;--color-text-secondary: #999999;--color-text-muted: #666666;--color-border: #333333;--color-border-accent: #2F587E;--color-success: #2ecc71;--color-error: #E84A0F;--color-warning: #FFA43A;--color-info: #5A8FBF;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;background-color:var(--color-bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-blue-primary);text-decoration:inherit}a:hover{color:var(--color-blue-light)}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-orange-primary);color:#fff;cursor:pointer;transition:background-color .25s,border-color .25s}button:hover{background-color:var(--color-orange-highlight)}button:active{background-color:var(--color-orange-dark)}button:focus,button:focus-visible{outline:2px solid var(--color-blue-primary);outline-offset:2px}@media(prefers-color-scheme:light){:root{color:#ffffffde;background-color:#1e1e1e}html,body{background-color:#1e1e1e}a:hover{color:#535bf2}button{background-color:#1a1a1a}}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;max-width:100vw;margin:0;padding:0;overflow:hidden;background-color:var(--color-bg-primary);color:var(--color-text-primary)}.app-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-bg-secondary);border-bottom:2px solid var(--color-orange-primary)}.header-logo{height:50px;width:auto}.header-text{flex:1}.app-header h1{margin:0;font-size:1.8rem;color:var(--color-orange-primary);font-weight:700}.app-subtitle{margin:.25rem 0 0;font-size:.9rem;color:var(--color-text-secondary)}.app-main{flex:1;min-height:0;position:relative;display:flex;overflow:hidden}.viewer-section{position:absolute;inset:0;padding:var(--spacing-lg);background-color:var(--color-bg-primary);z-index:1}.viewer-section h2{margin:0 0 var(--spacing-md) 0;font-size:1.3rem;color:var(--color-text-primary);font-weight:600}.command-section{position:absolute;top:var(--spacing-md);left:var(--spacing-md);width:400px;max-width:calc(100vw - 2 * var(--spacing-md) - 300px);max-height:calc(100% - 2 * var(--spacing-md));display:flex;flex-direction:column;gap:var(--spacing-md);background-color:#1a1a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:8px;padding:var(--spacing-lg);z-index:10;box-shadow:0 4px 6px #0000004d;overflow:hidden}.command-section h2{margin:0 0 var(--spacing-md) 0;font-size:1.3rem;color:var(--color-text-primary);font-weight:600;flex:0 0 auto}.command-history-container{flex:1 1 0;min-height:0;overflow-y:auto}.shapes-section{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:280px;max-height:calc(100% - 2 * var(--spacing-md));background-color:#1a1a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:8px;padding:var(--spacing-lg);z-index:10;box-shadow:0 4px 6px #0000004d;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-md)}.email-display{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:#ffffff0d;border:1px solid var(--color-border);border-radius:4px;margin-bottom:var(--spacing-sm)}.email-text{flex:1;font-size:.85rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.change-email-btn{padding:var(--spacing-xs) var(--spacing-sm);background-color:transparent;border:1px solid var(--color-orange-primary);border-radius:4px;color:var(--color-orange-primary);cursor:pointer;font-size:.75rem;white-space:nowrap;transition:all .2s}.change-email-btn:hover{background-color:#e8740f1a;border-color:var(--color-orange-secondary);color:var(--color-orange-secondary)}.shapes-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.shapes-header h2{margin:0;font-size:1.3rem;color:var(--color-text-primary);font-weight:600}.reset-session-btn{padding:var(--spacing-xs) var(--spacing-sm);background-color:transparent;border:1px solid var(--color-error);border-radius:4px;color:var(--color-error);cursor:pointer;font-size:.75rem;white-space:nowrap;transition:all .2s}.reset-session-btn:hover:not(:disabled){background-color:#e84a0f1a;border-color:var(--color-orange-primary);color:var(--color-orange-primary)}.reset-session-btn:disabled{opacity:.5;cursor:not-allowed}.app-footer{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--color-bg-secondary);border-top:1px solid var(--color-border);color:var(--color-text-secondary)}.app-footer p{margin:0;text-align:center;font-size:.9rem}@media(max-width:1024px){.app-main{flex-direction:column;height:auto}.command-section,.viewer-section,.shapes-section{flex:1 1 auto;min-height:400px}}@media(max-width:768px){.app-header h1{font-size:2rem}.command-section,.viewer-section,.shapes-section{padding:var(--spacing-md)}}.shape-list{display:flex;flex-direction:column;height:100%}.shape-list h2{margin:0 0 var(--spacing-md) 0;font-size:1.2rem;color:var(--color-text-primary);font-weight:600}.shape-list-empty{color:var(--color-text-secondary);font-style:italic;margin:var(--spacing-md) 0}.shape-list-items{list-style:none;padding:0;margin:0}.shape-list-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;margin-bottom:var(--spacing-sm);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;transition:background-color .2s}.shape-list-item:hover{background-color:var(--color-bg-secondary)}.shape-info{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.shape-type{font-weight:700;color:var(--color-blue-primary);font-size:1rem}.shape-id{color:var(--color-text-secondary);font-size:.85rem}.shape-params{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:var(--spacing-xs)}.shape-param{color:var(--color-text-primary);font-size:.85rem;background-color:var(--color-bg-secondary);padding:.2rem var(--spacing-sm);border-radius:3px}.shape-actions{display:flex;gap:var(--spacing-sm)}.export-btn,.shape-delete-btn{background:none;border:1px solid var(--color-border);border-radius:4px;padding:.3rem var(--spacing-sm);cursor:pointer;font-size:1rem;transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.export-btn:hover{background-color:#3b6f9e33;border-color:var(--color-blue-primary)}.export-btn:disabled{opacity:.5;cursor:wait}.shape-delete-btn{background-color:transparent;color:#fff}.shape-delete-btn:hover{background-color:#e84a0f33;border-color:var(--color-orange-deep)}.shape-delete-btn:active,.export-btn:active{transform:scale(.95)}.error-display{background-color:#1a1a1a;border:1px solid #E84A0F;border-radius:8px;margin:1rem 0;overflow:hidden}.error-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#e84a0f1a;border-bottom:1px solid #E84A0F}.error-header h3{margin:0;color:#ffa43a;font-size:1rem}.dismiss-btn{background:none;border:none;color:#999;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.dismiss-btn:hover{color:#fff}.error-content{padding:1rem}.user-messages{margin-bottom:1rem}.user-message{color:#e0e0e0;font-size:1rem;line-height:1.5;margin:0 0 .5rem}.user-message:last-child{margin-bottom:0}.technical-details{margin-top:1rem;border-top:1px solid #333;padding-top:.75rem}.technical-details summary{cursor:pointer;color:#999;font-size:.85rem;margin-bottom:.5rem}.technical-details summary:hover{color:#ccc}.error-group{margin:.5rem 0;padding:.5rem;background-color:#252525;border-radius:4px}.stage-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;text-transform:uppercase;margin-bottom:.5rem}.error-validation .stage-badge{background-color:#ffa43a33;color:#ffa43a}.error-semantic .stage-badge{background-color:#ff6a0033;color:#ff6a00}.error-execution .stage-badge{background-color:#e84a0f33;color:#e84a0f}.error-item{font-size:.85rem;color:#999;margin:.25rem 0}.error-code{background-color:#333;padding:.1rem .3rem;border-radius:2px;font-family:monospace;margin-right:.5rem}.error-param{display:block;font-size:.8rem;color:#666;margin-top:.25rem}.error-actions{display:flex;gap:.5rem;padding:.75rem 1rem;background-color:#1a1a1a;border-top:1px solid #333}.retry-btn{background-color:#ff7a18;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-weight:500}.retry-btn:hover{background-color:#ffa43a}.copy-btn{background-color:transparent;color:#999;border:1px solid #444;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.copy-btn:hover{border-color:#666;color:#ccc}.command-helper{margin-top:var(--spacing-md);border:1px solid var(--color-border);border-radius:6px;background-color:var(--color-bg-secondary)}.command-helper-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.command-helper-header:hover{background-color:var(--color-bg-tertiary)}.command-helper-header h4{margin:0;font-size:.9rem;color:var(--color-text-primary)}.toggle-icon{color:var(--color-orange-primary);font-size:.8rem}.command-helper-content{padding:var(--spacing-md);border-top:1px solid var(--color-border);max-height:300px;overflow-y:auto}.command-category{margin-bottom:var(--spacing-md)}.command-category:last-child{margin-bottom:0}.command-category h5{margin:0 0 var(--spacing-sm) 0;font-size:.85rem;color:var(--color-orange-primary);font-weight:600}.command-category ul{margin:0;padding-left:var(--spacing-lg);list-style-type:disc}.command-category li{font-size:.8rem;color:var(--color-text-secondary);margin-bottom:.25rem;line-height:1.4}.feedback-box{padding:var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;display:flex;flex-direction:column;gap:var(--spacing-sm)}.feedback-box label{font-size:.9rem;color:var(--color-text-primary);font-weight:500}.feedback-box textarea{width:100%;padding:var(--spacing-sm);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:.85rem;resize:vertical}.feedback-box textarea::placeholder{color:var(--color-text-muted);font-style:italic}.feedback-box textarea:focus{outline:none;border-color:var(--color-blue-primary)}.feedback-submit{align-self:flex-end;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-orange-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background-color .2s}.feedback-submit:hover:not(:disabled){background-color:var(--color-orange-highlight)}.feedback-submit:disabled{opacity:.6;cursor:not-allowed}.feedback-error{padding:var(--spacing-sm);background-color:#e84a0f1a;border-left:3px solid var(--color-error);color:var(--color-error);font-size:.85rem}.email-modal-overlay{position:fixed;inset:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.email-modal-box{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid var(--primary-color, #6366f1);border-radius:16px;padding:48px;max-width:500px;width:90%;box-shadow:0 20px 60px #6366f14d;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.email-modal-box h2{margin:0 0 16px;font-size:32px;font-weight:700;color:#fff;text-align:center}.email-modal-description{margin:0 0 32px;font-size:16px;line-height:1.6;color:#fffc;text-align:center}.email-modal-input-group{margin-bottom:24px}.email-modal-input-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#ffffffe6}.email-modal-input-group input{width:100%;padding:14px 16px;font-size:16px;border:2px solid rgba(255,255,255,.2);border-radius:8px;background-color:#ffffff0d;color:#fff;transition:all .2s ease;box-sizing:border-box}.email-modal-input-group input:focus{outline:none;border-color:var(--primary-color, #6366f1);background-color:#ffffff14;box-shadow:0 0 0 3px #6366f11a}.email-modal-input-group input:disabled{opacity:.6;cursor:not-allowed}.email-modal-input-group input::placeholder{color:#fff6}.email-modal-error{margin-bottom:16px;padding:12px;background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#fca5a5;font-size:14px}.email-modal-submit{width:100%;padding:14px 24px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary-color, #6366f1) 0%,#7c3aed 100%);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #6366f14d}.email-modal-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.email-modal-submit:active:not(:disabled){transform:translateY(0)}.email-modal-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.email-modal-privacy{margin:24px 0 0;font-size:12px;color:#ffffff80;text-align:center;line-height:1.4}.rate-limit-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;background-color:#000c;padding:var(--spacing-lg);border-radius:8px;box-shadow:0 4px 20px #00000080}.rate-limit-content{text-align:center;color:#fff}.rate-limit-content h3{margin:0 0 var(--spacing-md) 0;font-size:1.5rem;color:var(--color-orange-primary)}.rate-limit-content p{margin:0 0 var(--spacing-md) 0;font-size:1rem}.rate-limit-countdown{font-size:2rem;font-weight:700;color:var(--color-orange-primary);margin-top:var(--spacing-md)}.usage-cap-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1001}.usage-cap-message{background-color:var(--color-bg-secondary);border:2px solid var(--color-orange-primary);border-radius:8px;padding:var(--spacing-lg);max-width:500px;text-align:center;box-shadow:0 4px 20px #00000080}.usage-cap-message h3{margin:0 0 var(--spacing-md) 0;font-size:1.5rem;color:var(--color-orange-primary)}.usage-cap-message p{margin:var(--spacing-sm) 0;font-size:1rem;color:var(--color-text-primary)}.usage-cap-dismiss{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-orange-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.usage-cap-dismiss:hover{background-color:var(--color-orange-highlight)}.mobile-blocker-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;z-index:10000;overflow-y:auto;padding:20px}.mobile-blocker-content{max-width:500px;width:100%;background:#fffffffa;border-radius:16px;padding:25px 25px 30px;box-shadow:0 20px 60px #0000004d;text-align:center;animation:slideUp .4s ease-out;margin:20px 0}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.mobile-blocker-logo{width:100px;height:auto;margin-bottom:20px;margin-top:10px}.mobile-blocker-title{font-size:24px;font-weight:700;color:#1a1a2e;margin:0 0 12px;line-height:1.3}.mobile-blocker-message{font-size:14px;color:#555;line-height:1.5;margin:0 0 10px}.mobile-blocker-progress{font-size:13px;color:#06c;font-weight:600;margin:0 0 20px}.mobile-blocker-divider{width:50px;height:2px;background:linear-gradient(90deg,#06c,#00a8ff);margin:20px auto;border-radius:2px}.mobile-blocker-feedback-section{margin-top:20px}.mobile-blocker-feedback-title{font-size:18px;font-weight:600;color:#1a1a2e;margin:0 0 10px;line-height:1.3}.mobile-blocker-feedback-prompt{font-size:13px;color:#666;line-height:1.5;margin:0 0 15px}.mobile-blocker-form{display:flex;flex-direction:column;gap:15px}.mobile-blocker-textarea{width:100%;padding:15px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;color:#666;resize:vertical;transition:border-color .3s ease;box-sizing:border-box}.mobile-blocker-textarea:focus{outline:none;border-color:#06c}.mobile-blocker-textarea::placeholder{color:#aaa}.mobile-blocker-email-input{width:100%;padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;color:#333;background-color:#fff;transition:all .3s ease;box-sizing:border-box}.mobile-blocker-email-input:focus{outline:none;border-color:#06c;background-color:#f0f8ff}.mobile-blocker-email-input::placeholder{color:#999}.mobile-blocker-email-input:-webkit-autofill,.mobile-blocker-email-input:-webkit-autofill:hover,.mobile-blocker-email-input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px white inset;-webkit-text-fill-color:#333;border:2px solid #0066cc;transition:background-color 5000s ease-in-out 0s}.mobile-blocker-submit-btn{padding:14px 30px;background:linear-gradient(135deg,#06c,#0052a3);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0066cc4d}.mobile-blocker-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#0052a3,#003d7a);transform:translateY(-2px);box-shadow:0 6px 16px #06c6}.mobile-blocker-submit-btn:active:not(:disabled){transform:translateY(0)}.mobile-blocker-submit-btn:disabled{opacity:.6;cursor:not-allowed}.mobile-blocker-success{padding:12px;background:#d4edda;border:1px solid #c3e6cb;color:#155724;border-radius:8px;font-size:14px;font-weight:500;animation:fadeIn .3s ease-out}.mobile-blocker-error{padding:12px;background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;border-radius:8px;font-size:14px;font-weight:500;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.mobile-blocker-content{padding:30px 20px}.mobile-blocker-logo{width:100px;margin-bottom:25px}.mobile-blocker-title{font-size:24px}.mobile-blocker-message{font-size:15px}.mobile-blocker-feedback-title{font-size:18px}.mobile-blocker-textarea{font-size:13px}}
