.image-uploader{border:2px dashed var(--border-color);border-radius:12px;padding:32px;cursor:pointer;transition:all .2s ease;background:var(--bg-secondary)}.image-uploader:hover{border-color:var(--accent-dim);background:var(--bg-tertiary)}.image-uploader.dragging{border-color:var(--accent);background:#00ff880d}.image-uploader.has-image{padding:16px}.upload-content{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.upload-icon{color:var(--text-secondary);transition:color .2s ease}.image-uploader:hover .upload-icon,.image-uploader.dragging .upload-icon{color:var(--accent)}.upload-text{font-size:14px;color:var(--text-primary);font-weight:500}.upload-hint{font-size:12px;color:var(--text-secondary)}.image-uploader.has-image .upload-content{flex-direction:row;gap:12px}.image-uploader.has-image .upload-icon svg{width:24px;height:24px}.image-uploader.has-image .upload-hint{display:none}.dither-controls{display:flex;flex-direction:column;gap:24px}.dither-controls.disabled{opacity:.5;pointer-events:none}.control-group{display:flex;flex-direction:column;gap:8px}.control-label{display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.control-value{color:var(--accent);font-weight:500}.algorithm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.algorithm-button{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:10px 12px;color:var(--text-white);font-family:var(--font-mono);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.algorithm-button:hover{background:var(--bg-tertiary);border-color:var(--text-secondary)}.algorithm-button.active{background:var(--accent);border-color:var(--accent);color:var(--text-white)}.control-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;outline:none;cursor:pointer}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--accent);border-radius:50%;cursor:pointer;transition:transform .15s ease}.control-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.control-slider::-moz-range-thumb{width:18px;height:18px;background:var(--accent);border:none;border-radius:50%;cursor:pointer}.colors-group{gap:12px}.color-inputs{display:flex;gap:16px}.color-input{flex:1;display:flex;flex-direction:column;gap:6px}.color-input label{font-size:11px;color:var(--text-secondary)}.color-picker-wrapper{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:6px 8px}.color-picker-wrapper input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;padding:0}.color-picker-wrapper input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-wrapper input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}.color-hex{font-size:11px;color:var(--text-secondary);text-transform:uppercase}.swap-colors-button{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:10px;color:var(--text-secondary);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all .15s ease}.swap-colors-button:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-secondary)}.preview-placeholder{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;min-height:400px}.placeholder-content{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-secondary);text-align:center}.placeholder-icon{opacity:.4}.placeholder-content p{font-size:14px;max-width:200px}.preview-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px;position:relative;overflow:hidden}.preview-canvas{box-shadow:0 4px 24px #0006;border-radius:4px}.preview-info{position:absolute;bottom:12px;right:12px;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:4px 8px;border-radius:4px;font-size:11px;color:var(--text-secondary)}.download-button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 20px;background:var(--accent);border:none;border-radius:10px;color:var(--text-white);font-family:var(--font-sans);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.download-button:hover:not(.disabled){background:var(--accent-dim);transform:translateY(-1px);box-shadow:0 4px 12px #ff4f004d}.download-button:active:not(.disabled){transform:translateY(0)}.download-button.disabled{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}.download-text{display:flex;align-items:center;gap:8px}.file-size{font-weight:400;opacity:.8}.app{min-height:100%;display:flex;flex-direction:column;padding:24px;max-width:1400px;margin:0 auto}.header{display:flex;flex-direction:column;gap:4px;margin-bottom:32px}.logo{display:flex;align-items:center;gap:12px}.logo-icon{font-size:32px;color:var(--accent);line-height:1}.logo h1{font-size:28px;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{font-size:14px;color:var(--text-secondary);margin-left:44px}.main{flex:1;display:grid;grid-template-columns:320px 1fr;gap:32px}.sidebar{display:flex;flex-direction:column;gap:24px}.preview-area{display:flex;min-height:500px}.footer{margin-top:32px;padding-top:16px;border-top:1px solid var(--border-color);text-align:center}.footer p{font-size:12px;color:var(--text-secondary)}.heart{color:#ff4757;animation:heartbeat 1.5s ease infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width: 900px){.main{grid-template-columns:1fr}.preview-area{order:-1;min-height:300px}.tagline{margin-left:0}}@media (max-width: 480px){.app{padding:16px}.logo h1{font-size:24px}.logo-icon{font-size:28px}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0a0a;--bg-secondary: #141414;--bg-tertiary: #1a1a1a;--border-color: #2a2a2a;--text-primary: #ffffff;--text-secondary: #e8e8e8;--text-white: #ffffff;--accent: #ff4f00;--accent-dim: #cc3f00;--font-sans: "Geist", sans-serif}html,body,#root{height:100%;width:100%}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.5}a{color:var(--accent);text-decoration:none;transition:opacity .15s ease}a:hover{opacity:.8}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;background-image:radial-gradient(circle,var(--border-color) 1px,transparent 1px);background-size:24px 24px;opacity:.3;z-index:-1}
