@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap";:root{font-family:Plus Jakarta Sans,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{margin:0;min-width:320px;min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-md);flex-shrink:0}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:14px}.logo-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-md);color:#fff;box-shadow:0 4px 16px #7c3aed59}.logo-text{display:flex;flex-direction:column;gap:2px}.logo-text h1{font-size:1.25rem;font-weight:700;color:var(--text-primary);line-height:1.2;letter-spacing:-.02em}.tagline{font-size:.8rem;color:var(--text-muted);font-weight:500}.header-right{display:flex;align-items:center;gap:12px}.download-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 12px #7c3aed40}.download-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed66}.download-btn:active:not(:disabled){transform:translateY(0)}.download-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:640px){.header{padding:12px 16px}.logo-icon{width:38px;height:38px}.logo-icon svg{width:20px;height:20px}.logo-text h1{font-size:1.1rem}.tagline,.download-btn span{display:none}.download-btn{padding:10px 12px}}.canvas-container{position:relative;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0;height:100%}.canvas-container:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;border-radius:inherit}.canvas-inner{width:100%;height:100%;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-inner);position:relative;overflow:hidden}#canvas{width:100%;height:100%;display:block;background:#fff;border-radius:var(--radius-md)}.canvas-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;transition:opacity var(--transition-normal);display:flex;flex-direction:column;align-items:center;gap:16px}.canvas-placeholder.hidden{opacity:0}.placeholder-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:var(--surface-alt);border-radius:var(--radius-xl);color:var(--text-muted);border:1px solid var(--border)}.placeholder-icon svg{width:36px;height:36px;opacity:.6}.placeholder-text{display:flex;flex-direction:column;gap:6px}.placeholder-text h3{font-size:1rem;font-weight:600;color:var(--text-secondary)}.placeholder-text p{font-size:.875rem;color:var(--text-muted);max-width:240px;line-height:1.5}@media(max-width:640px){.canvas-container{padding:12px}.placeholder-icon{width:64px;height:64px}.placeholder-icon svg{width:28px;height:28px}.placeholder-text h3{font-size:.9rem}.placeholder-text p{font-size:.8rem;max-width:200px}}.input-section{position:relative}.input-section label{display:block;font-weight:600;margin-bottom:8px;color:var(--text-primary);font-size:.85rem}#textInput{width:100%;padding:12px 14px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:Plus Jakarta Sans,system-ui,sans-serif;font-size:.9rem;resize:vertical;transition:all var(--transition-fast);min-height:72px;line-height:1.5}#textInput:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed26;background:var(--surface-elevated)}#textInput::placeholder{color:var(--text-muted)}.char-count{position:absolute;bottom:-18px;right:0;font-size:.7rem;color:var(--text-muted);font-weight:500}.char-count span{color:var(--primary-light)}.control-panel{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:24px;box-shadow:var(--shadow-md);overflow-y:auto;display:flex;flex-direction:column;gap:20px}.control-panel::-webkit-scrollbar{width:6px}.control-panel::-webkit-scrollbar-track{background:var(--surface-alt);border-radius:3px}.control-panel::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.control-panel::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.control-section{display:flex;flex-direction:column;gap:12px}.section-header{display:flex;justify-content:space-between;align-items:center}.section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.controls-grid{display:flex;flex-direction:column;gap:20px}.control-group{display:flex;flex-direction:column;gap:10px}.control-group>label{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.85rem;color:var(--text-primary)}.value-display{font-weight:500;color:var(--primary-light);font-size:.8rem;background:#7c3aed26;padding:2px 8px;border-radius:var(--radius-full)}.control-divider{height:1px;background:var(--divider);margin:4px 0}.button-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,1fr));gap:8px}.btn-option{padding:10px 8px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;flex-direction:column;align-items:center;gap:4px}.btn-option .icon{font-size:1.1rem;line-height:1}.btn-option:hover{background:var(--surface-elevated);border-color:var(--primary-light);color:var(--text-primary)}.btn-option.active{background:#7c3aed26;border-color:var(--primary);color:var(--primary-light)}.color-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:8px}.color-option{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);position:relative}.color-option:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.color-option.active{border-color:#fff;transform:scale(1.1);box-shadow:var(--shadow-lg)}.color-option.active:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#fff;border-radius:50%;box-shadow:0 1px 2px #0000004d}.slider-container{display:flex;flex-direction:column;gap:8px}.slider{width:100%;height:6px;border-radius:var(--radius-full);background:var(--surface-alt);outline:none;-webkit-appearance:none;appearance:none;border:1px solid var(--border)}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--primary));cursor:pointer;box-shadow:0 2px 8px #7c3aed66;transition:all var(--transition-fast);border:2px solid var(--surface)}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--primary));cursor:pointer;border:2px solid var(--surface);box-shadow:0 2px 8px #7c3aed66;transition:all var(--transition-fast)}.slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 16px #7c3aed80}.slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 4px 16px #7c3aed80}.generate-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 16px #7c3aed59;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:auto}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #7c3aed80}.generate-btn:active:not(:disabled){transform:translateY(0)}.generate-btn:disabled{opacity:.4;cursor:not-allowed}.generate-btn svg{transition:transform .3s ease}.generate-btn.generating svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-upload-controls{display:flex;gap:8px}.upload-btn{flex:1;padding:14px 16px;background:var(--surface-alt);border:2px dashed var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:8px}.upload-btn:hover{background:#7c3aed1a;border-color:var(--primary);color:var(--primary-light)}.image-actions{display:flex;align-items:center;gap:8px;flex:1}.action-btn{padding:10px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.action-btn:hover{background:#7c3aed1a;border-color:var(--primary);color:var(--primary-light)}.action-btn.danger:hover{background:#ef44441a;border-color:var(--danger);color:var(--danger)}.image-status{font-size:.8rem;color:var(--accent);font-weight:500;margin-left:auto;display:flex;align-items:center;gap:4px}.image-status:before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%}.helper-text{font-size:.75rem;color:var(--text-muted);margin:4px 0 0;line-height:1.4}@media(max-width:1024px){.control-panel{max-height:320px}}@media(max-width:640px){.control-panel{padding:16px;gap:16px}.color-grid{grid-template-columns:repeat(8,1fr);gap:6px}}.tools-panel{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:16px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:20px;width:72px;align-items:center}.tools-section{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.tools-section-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.tools-grid{display:flex;flex-direction:column;gap:6px;width:100%}.tool-btn{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.tool-btn:hover{background:var(--surface-elevated);border-color:var(--primary-light)}.tool-btn.active{background:#7c3aed26;border-color:var(--primary)}.tool-icon{font-size:1.2rem}.tools-colors{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;width:100%}.color-btn{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:#fff;box-shadow:0 0 8px #ffffff4d}.tools-slider-vertical{display:flex;flex-direction:column;align-items:center;gap:8px;height:80px}.vertical-slider{writing-mode:vertical-lr;direction:rtl;width:6px;height:60px;-webkit-appearance:none;appearance:none;background:var(--surface-alt);border-radius:var(--radius-full);border:1px solid var(--border)}.vertical-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--primary));cursor:pointer;box-shadow:0 2px 6px #7c3aed66;border:2px solid var(--surface)}.vertical-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--primary));cursor:pointer;border:2px solid var(--surface);box-shadow:0 2px 6px #7c3aed66}.slider-value{font-size:.7rem;font-weight:600;color:var(--primary-light);background:#7c3aed26;padding:2px 6px;border-radius:var(--radius-full)}.rotation-dial{display:flex;align-items:center;justify-content:center;gap:2px;width:100%}.rotation-btn{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.rotation-btn svg{display:block;width:14px;height:14px}.rotation-btn:hover{background:#7c3aed26;border-color:var(--primary);color:var(--primary-light)}.rotation-value{font-size:.6rem;font-weight:600;color:var(--text-secondary);min-width:28px;text-align:center;flex-shrink:0}.reset-rotation-btn{width:100%;padding:6px 8px;font-size:.65rem;font-weight:500;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.reset-rotation-btn:hover:not(:disabled){background:#7c3aed1a;border-color:var(--primary);color:var(--primary-light)}.reset-rotation-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:1200px){.tools-panel{display:none}}:root{--primary: #7c3aed;--primary-dark: #6d28d9;--primary-light: #a78bfa;--secondary: #06b6d4;--accent: #10b981;--accent-light: #34d399;--background: #0a0a0f;--surface: #12121a;--surface-alt: #1a1a24;--surface-elevated: #22222e;--paper: #1e1e28;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--text-light: #52525b;--border: #27272a;--border-light: #3f3f46;--divider: #27272a;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .7);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px rgba(124, 58, 237, .3);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px}body{font-family:Plus Jakarta Sans,system-ui,-apple-system,sans-serif;background:var(--background);color:var(--text-primary);overflow:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 20%,rgba(124,58,237,.08) 0%,transparent 40%),radial-gradient(circle at 80% 80%,rgba(6,182,212,.06) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(16,185,129,.04) 0%,transparent 50%);pointer-events:none;z-index:0;animation:ambientGlow 20s ease infinite}@keyframes ambientGlow{0%,to{opacity:1}50%{opacity:.7}}.container{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;padding:24px;gap:20px;max-width:1800px;margin:0 auto}.main-content{flex:1;min-height:0;display:grid;grid-template-columns:auto 1fr 360px;gap:20px}@media(max-width:1200px){.main-content{grid-template-columns:1fr 360px}}@media(max-width:1024px){.main-content{grid-template-columns:1fr;grid-template-rows:1fr auto}}@media(max-width:640px){.container{padding:12px;gap:12px}.main-content{gap:12px}}
