*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f13;--surface: #1a1a24;--surface2: #23232f;--border: #2e2e3f;--accent: #7c5cfc;--accent-hover: #9579fd;--text: #e8e8f0;--text-muted: #888899;--red: #e05c5c;--green: #5ce0a0;--radius: 10px}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5}#root{min-height:100vh}.app{max-width:1200px;margin:0 auto;padding:24px 16px 48px}.app-header{text-align:center;margin-bottom:32px}.app-header h1{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#7c5cfc,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-muted);margin-top:4px;font-size:13px}.app-main{display:grid;grid-template-columns:400px 1fr;gap:24px;align-items:start}@media (max-width: 768px){.app-main{grid-template-columns:1fr}}.generator-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:16px}.result-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;min-height:300px;display:flex;flex-direction:column;gap:12px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:600;color:var(--text-muted);display:flex;justify-content:space-between;align-items:center}.value{font-weight:400;color:var(--accent);font-size:13px}textarea,input[type=text],input[type=number],select{background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:10px 12px;font-size:14px;font-family:inherit;width:100%;transition:border-color .15s;resize:vertical}textarea:focus,input:focus,select:focus{outline:none;border-color:var(--accent)}select{cursor:pointer}input[type=range]{width:100%;accent-color:var(--accent);padding:0;height:20px;border:none;background:transparent}input[type=color]{width:48px;height:36px;padding:2px;cursor:pointer;border-radius:6px}.seed-row{display:flex;gap:8px}.seed-row input{flex:1}.gen-params{display:flex;flex-direction:column;gap:12px}.param-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.param-grid .field:last-child{grid-column:1 / -1}.btn-primary,.btn-secondary,.btn-cancel{padding:10px 20px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-cancel{background:var(--red);color:#fff;width:100%}.btn-cancel:hover{opacity:.85}.btn-small{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:8px 10px;cursor:pointer;font-size:16px;flex-shrink:0}.btn-small:hover{border-color:var(--accent)}.btn-icon{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px}.btn-icon:hover{color:var(--text);background:var(--surface2)}.form-actions{margin-top:4px}.status-bar{border-radius:8px;padding:10px 14px;font-size:13px;display:flex;align-items:center;gap:10px}.status-bar.running{background:#7c5cfc26;border:1px solid rgba(124,92,252,.3)}.status-bar.error{background:#e05c5c26;border:1px solid rgba(224,92,92,.3);color:var(--red)}.spinner{width:16px;height:16px;border:2px solid rgba(124,92,252,.3);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.current-image{display:flex;flex-direction:column;gap:12px}.current-image img{width:100%;border-radius:8px;display:block}.image-actions{display:flex;gap:8px}.image-actions .btn-secondary,.image-actions a.btn-secondary{flex:1;text-align:center;text-decoration:none;display:inline-block}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);min-height:200px}.empty-icon{font-size:48px;opacity:.4}.gallery{margin-top:40px}.gallery h2{font-size:1.1rem;color:var(--text-muted);margin-bottom:16px;font-weight:600}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.gallery-item{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;border:1px solid var(--border);aspect-ratio:1}.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.gallery-item:hover img{transform:scale(1.04)}.gallery-item-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 50%);opacity:0;transition:opacity .2s;display:flex;flex-direction:column;justify-content:flex-end;padding:10px}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-prompt{font-size:11px;color:#ddd;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:6px}.gallery-item-actions{display:flex;gap:6px}.gallery-item-actions button,.gallery-item-actions a{background:#ffffff26;border:none;border-radius:4px;color:#fff;font-size:14px;padding:4px 8px;cursor:pointer;text-decoration:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s}.gallery-item-actions button:hover,.gallery-item-actions a:hover{background:#ffffff4d}.meme-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.meme-editor{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:900px;max-height:90vh;overflow-y:auto}.meme-editor-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.meme-editor-header h2{font-size:1rem;font-weight:700}.meme-editor-body{display:grid;grid-template-columns:1fr 300px;gap:20px;padding:20px}@media (max-width: 640px){.meme-editor-body{grid-template-columns:1fr}}.meme-canvas{width:100%;height:auto;border-radius:8px;display:block}.meme-controls{display:flex;flex-direction:column;gap:14px}.color-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.meme-actions{display:flex;flex-direction:column;gap:8px;margin-top:auto}.prompt-form{display:flex;flex-direction:column;gap:12px}
