:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}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:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{font-family:Inter,system-ui,-apple-system,sans-serif;background:linear-gradient(180deg,#f5f7ff,#eff3ff,#e5e7ff);color:#111827;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.app-container{width:100%;display:flex;justify-content:center;align-items:center;min-height:100vh}.page-wrapper{width:100%;max-width:600px;padding:1rem}.card{background:#fff;border-radius:1.25rem;box-shadow:0 10px 30px #00000014;padding:2.5rem;width:100%;animation:fadeIn .6s ease-out;display:flex;flex-direction:column;gap:1.5rem;box-sizing:border-box}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.header-section{text-align:center;margin-bottom:1.5rem}.header-title{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-bottom:.75rem}.header-title h1{font-size:1.875rem;font-weight:700;background:linear-gradient(90deg,#8b5cf6,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.header-title .icon{height:1.75rem;width:1.75rem;color:#8b5cf6;flex-shrink:0}.subtitle{color:#78716c;font-size:1rem;margin:0}.form-section{display:flex;flex-direction:column;gap:1.25rem}.input-group{display:flex;flex-direction:column}.input-group label{display:flex;align-items:center;font-weight:500;font-size:.875rem;color:#374151;margin-bottom:.5rem}.input-icon{width:1rem;height:1rem;margin-right:.5rem;color:#a855f7;flex-shrink:0}input[type=text]{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid #e5e7eb;border-radius:.5rem;outline:none;transition:all .2s ease;box-sizing:border-box}input[type=text]:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem}.generate-btn{display:flex;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;border:none;border-radius:.5rem;background:linear-gradient(90deg,#8b5cf6,#ec4899);cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #8b5cf64d}.generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #8b5cf666}.generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.loader{animation:spin 1s linear infinite;width:1.25rem;height:1.25rem}@keyframes spin{to{transform:rotate(360deg)}}.generating-section{text-align:center;padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.loader-large{animation:spin 1s linear infinite;width:4rem;height:4rem;color:#8b5cf6}.generating-section h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0}.generating-section p{color:#6b7280;margin:0}.complete-section{display:flex;flex-direction:column;gap:1.5rem}.success-icon{display:inline-flex;align-items:center;justify-content:center;width:4rem;height:4rem;background-color:#d1fae5;border-radius:50%;margin:0 auto}.success-icon .icon{width:2rem;height:2rem;color:#059669}.complete-section h3{text-align:center;font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.complete-section>p{text-align:center;color:#6b7280;margin:0}.image-box{width:100%;background-color:#f3f4f6;border-radius:.75rem;overflow:hidden;box-shadow:0 4px 6px #0000001a}.image-box img{width:100%;height:auto;display:block}.prompt-box{background-color:#faf5ff;border:1px solid #e9d5ff;border-radius:.5rem;padding:1rem;text-align:left}.prompt-box.blue{background-color:#eff6ff;border-color:#bfdbfe}.prompt-label{font-size:.875rem;font-weight:600;color:#6b21a8;margin:0 0 .25rem}.prompt-box.blue .prompt-label{color:#1e40af}.prompt-text{font-size:.875rem;color:#7c3aed;margin:0;line-height:1.5}.prompt-box.blue .prompt-text{color:#2563eb}.action-buttons{display:flex;gap:.75rem}.download-btn,.reset-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s ease;text-decoration:none}.download-btn{background-color:#8b5cf6;color:#fff}.download-btn:hover{background-color:#7c3aed;transform:translateY(-1px)}.download-btn .icon{width:1.25rem;height:1.25rem}.reset-btn{background-color:#e5e7eb;color:#1f2937}.reset-btn:hover{background-color:#d1d5db}.footer{margin-top:2rem}.attribution-text{text-align:center;color:#9ca3af;font-size:.875rem;margin:0}@media(max-width:640px){.page-wrapper{max-width:100%;padding:.5rem}.card{padding:1.5rem}.header-title h1{font-size:1.5rem}.subtitle{font-size:.875rem}.action-buttons{flex-direction:column}}
