.app-shell{width:100vw;height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at top,#25252dd9,#0f1016 60%);color:#f1f5f9}.app-header{display:flex;align-items:center;padding:.85rem 1.5rem;background:#0a0a0ebf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.05);gap:1rem}.brand-mark{font-weight:800;font-size:1.1rem;letter-spacing:.4px;display:flex;align-items:center;gap:.35rem;text-transform:uppercase}.tab-nav{display:flex;gap:.25rem;flex:1}.tab-button{padding:.5rem 1rem;border-radius:10px;border:none;background:transparent;color:#a5b4fc;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.tab-button.active{background:linear-gradient(135deg,#3b82f633,#6366f166);color:#fff}.tab-button:hover{background:#6366f126;color:#fff}.header-actions{display:flex;gap:.5rem}.ghost-button,.solid-button{border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#ffffff0d;color:inherit;padding:.45rem .9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.ghost-button:hover{background:#ffffff1f}.solid-button{background:linear-gradient(135deg,#8b5cf659,#4f46e580);color:#fff;border:none}.solid-button.primary{background:linear-gradient(135deg,#f97316,#facc15);color:#0f0f1e}.app-body{flex:1;display:flex;overflow:hidden}.sidebar-panel{width:380px;max-width:40vw;background:#0c0d14bf;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-right:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column}.panel-header{padding:.9rem 1.2rem;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.2px;border-bottom:1px solid rgba(255,255,255,.05)}.panel-content{flex:1;overflow:auto;padding:.5rem .75rem 1.5rem}.panel-footer{padding:.85rem 1rem;border-top:1px solid rgba(255,255,255,.05);font-size:.8rem;color:#e2e8f0b3;display:flex;flex-direction:column;gap:.35rem}.panel-footer a{color:#93c5fd;text-decoration:none}.panel-footer a:hover{text-decoration:underline}.preview-panel{flex:1;position:relative;background:radial-gradient(circle at 30% 20%,#3b82f61f,#020617e6)}.preview-panel>*{width:100%;height:100%}.placeholder-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:1.5rem}.placeholder-card{max-width:420px;padding:1.5rem;background:#0d1018d9;border-radius:16px;border:1px solid rgba(255,255,255,.08);box-shadow:0 15px 35px #0006;text-align:center}.placeholder-card h3{margin-bottom:.5rem}@media (max-width: 960px){.sidebar-panel{width:100%;max-width:none}.app-body{flex-direction:column}.header-actions{flex-wrap:wrap;justify-content:flex-end}}@media (max-width: 640px){.app-header{flex-wrap:wrap;gap:.5rem}.tab-nav{order:3;width:100%;justify-content:space-between}.header-actions{width:100%;justify-content:flex-start}.solid-button,.ghost-button{flex:1;justify-content:center}}.vfx-viewer{flex:1;position:relative;overflow:hidden;background:radial-gradient(ellipse at center,#5858602e,#1e1e2499 55%,#0f0f12f2)}.vfx-canvas{width:100%;height:100%;display:block;cursor:grab}.vfx-canvas:active{cursor:grabbing}.vfx-info{position:absolute;bottom:1rem;left:1rem;background:#18181ccc;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:saturate(120%) blur(10px);backdrop-filter:saturate(120%) blur(10px);padding:.75rem 1rem;border-radius:8px;color:#e5e7eb;font-size:.875rem;font-weight:500;display:flex;flex-direction:column;gap:.25rem;pointer-events:none}.vfx-info-item{display:flex;align-items:center;gap:.5rem}.vfx-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:1.2rem;font-weight:600;text-shadow:0 2px 10px rgba(0,0,0,.5)}@media (max-width: 768px){.vfx-viewer{height:52vh;min-height:320px;flex:0 0 auto}.vfx-info{font-size:.75rem;padding:.5rem .75rem}}.texture-preview-overlay{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:8px;background:#141418b3;border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:saturate(120%) blur(8px);backdrop-filter:saturate(120%) blur(8px);padding:6px 8px;border-radius:8px;z-index:10}.texture-preview-overlay img{width:36px;height:36px;image-rendering:pixelated;border-radius:4px;border:1px solid rgba(255,255,255,.12)}.texture-preview-overlay .texture-download{background:#ffffff14;color:#e5e7eb;border:1px solid rgba(255,255,255,.12);padding:2px 6px;font-size:11px;border-radius:6px;cursor:pointer}.texture-preview-overlay .texture-download:hover{background:#ffffff24}.generator-panel{width:100%;max-width:400px;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-left:none;padding:0;overflow-y:visible;display:flex;flex-direction:column;gap:1.5rem}.panel-section{display:flex;flex-direction:column;gap:1rem}.section-title{font-size:1rem;font-weight:700;color:#e5e7eb;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-label{font-size:.875rem;font-weight:600;color:#ffffffe6;display:flex;justify-content:space-between;align-items:center}.control-value{color:#fff9;font-size:.8rem}.control-input{width:100%;padding:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:.875rem;transition:all .2s ease}.control-input:focus{outline:none;border-color:#fbbf24d9;background:#ffffff26}.control-input option{background:#2a2a2a;color:#fff}.range-input{width:100%;height:6px;background:#fff3;border-radius:3px;outline:none;-webkit-appearance:none}.range-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:linear-gradient(135deg,#fbbf24,#d97706);cursor:pointer;border-radius:50%;box-shadow:0 2px 8px #0000004d}.range-input::-moz-range-thumb{width:18px;height:18px;background:linear-gradient(135deg,#fbbf24,#d97706);cursor:pointer;border-radius:50%;border:none;box-shadow:0 2px 8px #0000004d}.color-input-wrapper{display:flex;gap:.5rem;align-items:center}.color-input{width:60px;height:40px;border:2px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;background:transparent}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:none;border-radius:6px}.color-hex{flex:1;padding:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:.875rem;text-align:center;font-family:monospace}.panel-textarea{width:100%;min-height:80px;padding:.6rem;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:10px;color:#f8fafc;font-size:.85rem;resize:vertical}.randomize-button{display:inline-flex;width:100%;padding:1rem;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1rem;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 15px #f5576c66}.randomize-button:hover{box-shadow:0 6px 20px #f5576c99}.button-group{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.button-option{padding:.75rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;transition:all .2s ease}.button-option:hover{background:#ffffff26;border-color:#ffffff4d}.button-option.active{background:linear-gradient(135deg,#fbbf24,#d97706);border-color:transparent}.effect-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.effect-type-button{padding:1rem .5rem;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-size:.875rem;font-weight:600;display:flex;flex-direction:row;align-items:center;gap:.75rem;text-align:left;transition:all .2s ease}.effect-type-button:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px)}.effect-type-button.active{background:linear-gradient(135deg,#fbbf24,#d97706);border-color:transparent;box-shadow:0 4px 15px #fbbf2459}.effect-icon{font-size:1.5rem;flex-shrink:0}.effect-type-text{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.effect-name{font-size:.9rem;font-weight:700}.effect-animation-label{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#ffffffb3}.toggle-input{position:relative;display:inline-flex;align-items:center;width:48px;height:24px;border-radius:24px;background:#ffffff26;transition:background .2s ease;cursor:pointer}.toggle-input input{opacity:0;width:0;height:0;position:absolute}.toggle-display{position:relative;width:100%;height:100%;border-radius:24px;background:transparent}.toggle-display:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s ease,background .2s ease}.toggle-input input:checked+.toggle-display{background:linear-gradient(135deg,#fbbf24,#d97706)}.toggle-input input:checked+.toggle-display:after{transform:translate(24px);background:#fff}.vector-input{display:flex;gap:.5rem;flex-wrap:wrap}.vector-field{display:flex;align-items:center;gap:.35rem;color:#ffffffb3;font-size:.8rem}.vector-field input{width:80px}.inline-input{max-width:120px}.vector-field input.inline-input{width:100%}@media (max-width: 768px){.generator-panel{max-width:100%;border-left:none;border-top:1px solid rgba(255,255,255,.1);max-height:50vh;padding:1rem 0 0}.effect-type-grid{grid-template-columns:repeat(4,1fr);gap:.5rem}.effect-type-button{padding:.75rem .25rem;font-size:.75rem;flex-direction:column;text-align:center;align-items:center;gap:.35rem}.effect-icon{font-size:1.2rem}.effect-type-text{align-items:center}.effect-animation-label{font-size:.6rem}.randomize-button{display:flex;margin-top:.75rem}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Fredoka,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,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;-webkit-text-size-adjust:100%}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}button{font-family:inherit;cursor:pointer;transition:all .2s ease}button:hover{transform:translateY(-2px)}button:active{transform:translateY(0)}input,select{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}
