*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0d0d0f;--surface: #141416;--surface-2: #1a1a1e;--border: #232328;--border-hover: #3a3a42;--text: #e8e8ec;--text-muted: #8a8a96;--text-dim: #56565e;--accent: #c9a96e;--accent-hover: #dbbf86;--success: #6ee7a0;--canvas-bg: #faf9f7;--radius: 14px;--radius-sm: 8px}body{min-height:100vh;background:var(--bg);color:var(--text);font-family:DM Sans,system-ui,-apple-system,sans-serif;display:flex;flex-direction:column;align-items:center;padding:2.5rem 1rem 3rem;gap:1.5rem;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9999}.site-header{text-align:center;max-width:680px}.site-header h1{font-family:Playfair Display,Georgia,serif;font-size:1.75rem;font-weight:500;letter-spacing:-.02em;color:var(--text);display:flex;align-items:center;justify-content:center;gap:.6rem}.site-header h1 svg{width:22px;height:22px;opacity:.5}.site-subtitle{font-size:.85rem;color:var(--text-dim);margin-top:.35rem;letter-spacing:.01em}.card{width:min(92vw,680px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .25s,box-shadow .25s}.card:hover{border-color:var(--border-hover);box-shadow:0 4px 24px #00000040}.card-header{padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;justify-content:space-between;font-weight:500}.mode-toggle{display:flex;border-bottom:1px solid var(--border);background:var(--surface)}.mode-btn{flex:1;padding:.75rem 1rem;font-size:.82rem;font-weight:500;color:var(--text-dim);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;border-radius:0;transition:all .2s;text-align:center;font-family:inherit;letter-spacing:.02em}.mode-btn:hover{color:var(--text-muted)}.mode-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--surface-2)}.canvas-wrap{position:relative;background:var(--canvas-bg);cursor:crosshair;touch-action:none}.canvas-wrap canvas{display:block;width:100%;height:auto;touch-action:none}.canvas-hint{position:absolute;bottom:14px;left:50%;transform:translate(-50%);font-size:.78rem;color:#9a9a9a;pointer-events:none;transition:opacity .3s;display:flex;align-items:center;gap:.4rem}.canvas-hint .kbd{display:inline-block;padding:.1rem .4rem;font-size:.65rem;background:#e0e0e0;border:1px solid #ccc;border-radius:4px;font-family:DM Sans,system-ui,sans-serif;color:#666;line-height:1.4}.canvas-hint.hidden{opacity:0}.btn-row{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border);align-items:center}button{font-family:DM Sans,system-ui,sans-serif;font-size:.8rem;padding:.45rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s;font-weight:500}button:hover{border-color:var(--border-hover);color:var(--text);background:var(--surface-2)}button.primary{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:500}button.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}button:disabled{opacity:.3;cursor:default;pointer-events:none}.spacer{flex:1}.stroke-count{font-variant-numeric:tabular-nums;font-size:.75rem;color:var(--text-dim)}.style-controls{padding:.75rem 1rem;display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:.5rem}.control-group label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-weight:500;white-space:nowrap}.color-row{display:flex;align-items:center;gap:.35rem}.color-row input[type=color]{width:28px;height:28px;border:1px solid var(--border);border-radius:6px;padding:2px;background:var(--surface-2);cursor:pointer;-webkit-appearance:none;appearance:none}.color-row input[type=color]::-webkit-color-swatch-wrapper{padding:2px}.color-row input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}.swatch{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);padding:0;cursor:pointer;transition:border-color .2s;min-width:22px}.swatch:hover{border-color:var(--border-hover)}.swatch.active{border-color:var(--accent)}.weight-row{display:flex;align-items:center;gap:.5rem}.weight-row input[type=range]{width:100px;-webkit-appearance:none;appearance:none;height:3px;background:var(--border);border-radius:2px;outline:none}.weight-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 0 1px var(--accent)}.weight-val{font-size:.72rem;color:var(--text-dim);font-variant-numeric:tabular-nums;min-width:2rem}.type-section{padding:1.25rem 1rem}.type-input{width:100%;padding:.75rem 1rem;font-size:1rem;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:Playfair Display,Georgia,serif;font-style:italic;outline:none;transition:border-color .2s,box-shadow .2s}.type-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #c9a96e1f}.font-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;margin-top:1rem}.font-btn{padding:.6rem .8rem;font-size:.82rem;border-radius:var(--radius-sm);text-align:center;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);transition:all .2s;line-height:1.3}.font-btn:hover{border-color:var(--border-hover);color:var(--text)}.font-btn.active{border-color:var(--accent);color:var(--accent);background:#c9a96e14}.font-label{display:block;font-family:DM Sans,system-ui,sans-serif;font-size:.55rem;color:var(--text-dim);margin-top:.15rem;text-transform:uppercase;letter-spacing:.04em}.type-live-preview{margin-top:1.25rem;padding:1.5rem;background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border);text-align:center;min-height:80px;display:flex;align-items:center;justify-content:center;overflow:hidden}.type-live-preview svg{width:100%;height:auto;max-height:120px;overflow:visible}.type-live-preview .sig-path{fill:none;stroke:var(--text);stroke-linecap:round;stroke-linejoin:round}.upload-section{padding:1.25rem 1rem}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:2.5rem 1rem;text-align:center;cursor:pointer;transition:all .25s;color:var(--text-dim)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:#c9a96e0a;color:var(--text-muted)}.drop-zone svg{margin-bottom:.75rem;opacity:.5}.drop-zone p{font-size:.85rem;margin-top:.25rem}.drop-hint{font-size:.7rem!important;color:var(--text-dim);margin-top:.5rem!important}.upload-controls{margin-top:1rem}.upload-preview-row{background:var(--canvas-bg);border-radius:var(--radius-sm);border:1px solid var(--border);padding:.5rem;text-align:center;margin-bottom:1rem}.upload-preview-row canvas{max-width:100%;height:auto;max-height:200px;display:block;margin:0 auto;image-rendering:pixelated}.upload-sliders{display:flex;gap:1.5rem;flex-wrap:wrap}.preview-wrap{padding:2rem;display:flex;align-items:center;justify-content:center;min-height:140px;background:var(--surface-2);border-radius:var(--radius-sm);margin:.5rem 1rem;border:1px solid var(--border)}.preview-wrap svg{width:100%;height:auto;overflow:visible;filter:drop-shadow(0 0 8px rgba(201,169,110,.1))}.preview-header-controls{display:flex;align-items:center;gap:.5rem}.bg-toggle{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.bg-btn{padding:.3rem .45rem;border:none;border-radius:0;background:none;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;transition:all .2s}.bg-btn:not(:last-child){border-right:1px solid var(--border)}.bg-btn:hover{color:var(--text-muted)}.bg-btn.active{color:var(--accent);background:#c9a96e1a}.preview-wrap.bg-light{background:#fff;border-color:#e0e0e0}.preview-wrap.bg-light svg{filter:none}.preview-wrap.bg-transparent{background-image:linear-gradient(45deg,#2a2a2e 25%,transparent 25%),linear-gradient(-45deg,#2a2a2e 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#2a2a2e 75%),linear-gradient(-45deg,transparent 75%,#2a2a2e 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0;background-color:#1e1e22}.export-block{position:relative}.export-block pre{padding:1rem;overflow-x:auto;font-size:.72rem;line-height:1.6;color:var(--text-muted);font-family:SF Mono,Fira Code,Cascadia Code,ui-monospace,monospace;max-height:360px;overflow-y:auto}.copy-btn{position:absolute;top:8px;right:8px;font-size:.7rem;padding:.3rem .7rem;border-radius:4px;z-index:2}.copy-btn.copied{color:var(--success);border-color:var(--success)}.tab-bar{display:flex;border-bottom:1px solid var(--border)}.tab{padding:.6rem 1.2rem;font-size:.75rem;color:var(--text-dim);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;border-radius:0;transition:all .2s;font-family:inherit;font-weight:500}.tab:hover{color:var(--text-muted)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{display:none}.tab-content.active{display:block}.download-row{display:flex;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border)}.download-btn{display:flex;align-items:center;gap:.4rem;flex:1;justify-content:center}.download-btn svg{flex-shrink:0}.speed-row{display:flex;align-items:center;gap:.75rem;padding:0 1rem .75rem}.speed-row label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-weight:500}.speed-row input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:3px;background:var(--border);border-radius:2px;outline:none}.speed-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 0 1px var(--accent)}.speed-val{font-size:.72rem;color:var(--text-dim);font-variant-numeric:tabular-nums;min-width:2.5rem;text-align:right}.site-footer{margin-top:1rem;text-align:center;font-size:.72rem;color:var(--text-dim);max-width:680px}.site-footer a{color:var(--text-muted);text-decoration:none;transition:color .2s}.site-footer a:hover{color:var(--accent)}.site-footer .separator{margin:0 .5rem;opacity:.3}@media(max-width:480px){body{padding:1.5rem .75rem 2rem}.site-header h1{font-size:1.4rem}.font-grid{grid-template-columns:1fr}}
