:root{--color-primary: #646cff;--color-primary-hover: #747bff;--color-primary-text: #ffffff;--color-bg: #f9f9f9;--color-surface: #ffffff;--color-surface-hover: #f5f5f5;--color-text: #213547;--color-text-muted: #666666;--color-text-light: #999999;--color-border: #e0e0e0;--color-border-hover: #bdbdbd;--color-danger: #ff4444;--color-danger-hover: #ff2222;--color-danger-text: #ffffff;--font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-bold: 700;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-focus: 0 0 0 3px rgba(100, 108, 255, .3);--transition-fast: .15s ease;--transition-normal: .25s ease}@media (prefers-color-scheme: dark){:root{--color-bg: #242424;--color-surface: #2a2a2a;--color-surface-hover: #333333;--color-text: #ffffff;--color-text-muted: rgba(255, 255, 255, .7);--color-border: #444444;--color-border-hover: #555555}}@font-face{font-family:Roboto Black;src:url(/fonts/Roboto-Black.ttf) format("truetype");font-weight:900;font-style:normal}:root{font-family:var(--font-family);line-height:1.5;font-weight:var(--font-weight-regular);color-scheme:light dark;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--color-bg);color:var(--color-text)}h1{font-size:3.2em;line-height:1.1}button{border-radius:var(--radius-md);border:1px solid var(--color-border);padding:.5rem 1rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:inherit;background-color:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast)}button:hover{border-color:var(--color-primary);background-color:var(--color-surface)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color;outline-color:var(--color-primary);outline-offset:2px}@media (prefers-color-scheme: light){:root{color:var(--color-text);background-color:var(--color-bg)}a:hover{color:var(--color-primary-hover)}button{background-color:var(--color-surface)}}.control-group{margin-bottom:var(--space-5)}.control-label{display:block;margin-bottom:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.efficiency-stat{font-size:.75em;opacity:.8;margin-top:var(--space-1)}input[type=number],input[type=text],select{width:100%;padding:.6rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--font-size-sm);transition:border-color var(--transition-fast)}input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #646cff33}button{padding:.6rem 1rem;font-size:var(--font-size-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}button.primary{background-color:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}button.primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}button.danger{background-color:var(--color-danger);color:var(--color-danger-text);border-color:var(--color-danger)}button.danger:hover{background-color:var(--color-danger-hover);border-color:var(--color-danger-hover)}.sub-controls{margin-top:var(--space-3);padding-left:var(--space-4);border-left:2px solid var(--color-border)}.search-container.svelte-1y7g5i3{position:relative;width:100%}.input-wrapper.svelte-1y7g5i3 input:where(.svelte-1y7g5i3){width:100%;padding:.6rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);font-size:var(--font-size-sm)}.dropdown.svelte-1y7g5i3{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:250px;overflow-y:auto;z-index:100;padding:0;list-style:none}.dropdown.svelte-1y7g5i3 li:where(.svelte-1y7g5i3){margin:0;padding:0}.result-btn.svelte-1y7g5i3{width:100%;text-align:left;background:none;border:none;padding:.5rem 1rem;font-size:var(--font-size-sm);color:var(--color-text);border-radius:0;cursor:pointer}.result-btn.svelte-1y7g5i3:hover,.result-btn.svelte-1y7g5i3:focus,.result-btn.active.svelte-1y7g5i3{background:var(--color-surface-hover);color:var(--color-primary);outline:none}.controls-panel.svelte-d1h2e2{width:380px;height:100vh;background-color:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;box-shadow:var(--shadow-md);z-index:10}.header.svelte-d1h2e2{padding:var(--space-5);border-bottom:1px solid var(--color-border)}.header.svelte-d1h2e2 h1:where(.svelte-d1h2e2){font-size:var(--font-size-xl);margin:0;color:var(--color-primary)}.brand.svelte-d1h2e2{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.logo.svelte-d1h2e2{width:32px;height:32px;object-fit:contain}.header.svelte-d1h2e2 p:where(.svelte-d1h2e2){margin:0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.controls-content.svelte-d1h2e2{flex:1;overflow-y:auto;padding:var(--space-5)}.preset-buttons.svelte-d1h2e2{display:flex;gap:var(--space-3);margin-top:var(--space-2)}.preset-btn.svelte-d1h2e2{flex:1;background:var(--color-bg-subtle);border:1px solid var(--color-border);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:all .2s}.preset-btn.svelte-d1h2e2:hover{background:var(--color-bg-hover);border-color:var(--color-primary)}.preset-btn.active.svelte-d1h2e2{background:var(--color-primary-muted);border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.file-input.svelte-d1h2e2{width:100%;padding:.5rem;font-size:var(--font-size-sm)}.footer.svelte-d1h2e2{padding:var(--space-5);border-top:1px solid var(--color-border);background-color:var(--color-surface)}.export-btn.svelte-d1h2e2:disabled{opacity:.7;cursor:not-allowed}.version.svelte-d1h2e2{font-size:.65rem;opacity:.6}.panel-footer.svelte-d1h2e2{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:.5rem}.footer-links.svelte-d1h2e2{display:flex;gap:.8rem}.panel-footer.svelte-d1h2e2 a:where(.svelte-d1h2e2){display:flex;align-items:center;gap:4px;color:var(--color-text-muted);text-decoration:none;transition:color .2s}.panel-footer.svelte-d1h2e2 a:where(.svelte-d1h2e2):hover{color:var(--color-primary)}input[type=text].svelte-d1h2e2:focus,input[type=number].svelte-d1h2e2:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #3b82f61a}input.disabled.svelte-d1h2e2{opacity:.5;cursor:not-allowed;background:#f9fafb}.checkbox-container.svelte-d1h2e2{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-container.svelte-d1h2e2 input[type=checkbox]:where(.svelte-d1h2e2){width:16px;height:16px;cursor:pointer}.checkbox-label.svelte-d1h2e2{font-size:var(--font-size-xs);color:var(--color-text-muted)}.credits.svelte-d1h2e2{text-align:right;opacity:.8;line-height:1.2}.credits.svelte-d1h2e2 span:where(.svelte-d1h2e2){display:block}.export-overlay.svelte-d1h2e2{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:svelte-d1h2e2-fadeIn .3s ease-out}.export-card.svelte-d1h2e2{background:var(--color-surface);padding:40px 40px 56px;border-radius:28px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px var(--color-border);width:460px;text-align:center;position:relative}.export-card.svelte-d1h2e2 h3:where(.svelte-d1h2e2){margin:var(--space-4) 0 var(--space-2);color:var(--color-text);font-size:var(--font-size-lg);font-weight:700;letter-spacing:-.02em}.export-card.svelte-d1h2e2 p:where(.svelte-d1h2e2){font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-8)}.label-badge.svelte-d1h2e2{background:var(--color-bg-subtle);color:var(--color-primary);padding:2px 8px;border-radius:4px;font-family:monospace;font-weight:600;border:1px solid var(--color-primary-muted)}.progress-container.svelte-d1h2e2{display:flex;flex-direction:column;gap:var(--space-3)}.progress-bar.svelte-d1h2e2{height:12px;background:var(--color-bg-subtle);border-radius:6px;overflow:hidden;box-shadow:inset 0 2px 4px #0000000d;position:relative}.progress-fill.svelte-d1h2e2{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-hover));transition:width .4s cubic-bezier(.4,0,.2,1);border-radius:6px;position:relative}.progress-fill.svelte-d1h2e2:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:svelte-d1h2e2-shimmer 2s infinite}.progress-stats.svelte-d1h2e2{display:flex;justify-content:space-between;align-items:center;padding:0 12px;margin-top:4px}.progress-text.svelte-d1h2e2{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.loader-container.svelte-d1h2e2{display:flex;justify-content:center;margin-bottom:var(--space-4)}.d20-loader.svelte-d1h2e2{width:64px;height:64px;color:var(--color-primary);animation:svelte-d1h2e2-d20-float 3s ease-in-out infinite,svelte-d1h2e2-d20-pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(100,108,255,.3))}@keyframes svelte-d1h2e2-d20-float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(5deg)}}@keyframes svelte-d1h2e2-d20-pulse{0%,to{opacity:1;filter:drop-shadow(0 0 10px rgba(100,108,255,.3))}50%{opacity:.8;filter:drop-shadow(0 0 20px rgba(100,108,255,.5))}}@keyframes svelte-d1h2e2-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes svelte-d1h2e2-fadeIn{0%{opacity:0}to{opacity:1}}.success-icon-container.svelte-d1h2e2{display:flex;justify-content:center;margin-bottom:var(--space-4)}.success-icon.svelte-d1h2e2{width:64px;height:64px;color:#10b981;filter:drop-shadow(0 0 10px rgba(16,185,129,.2));animation:svelte-d1h2e2-success-pop .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes svelte-d1h2e2-success-pop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.download-actions.svelte-d1h2e2{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.download-btn.svelte-d1h2e2{display:flex;align-items:center;justify-content:center;padding:var(--space-3);font-weight:600;font-size:var(--font-size-md)}.close-btn.svelte-d1h2e2{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);padding:var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-size:var(--font-size-sm)}.close-btn.svelte-d1h2e2:hover{background:var(--color-bg-subtle);color:var(--color-text);border-color:var(--color-text-muted)}.editor-container.svelte-17jy819{flex:1 1 0%;display:flex;flex-direction:column;background-color:var(--color-background);overflow:hidden}.header.svelte-17jy819{padding:var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface);text-align:center}.header.svelte-17jy819 h2:where(.svelte-17jy819){font-size:var(--font-size-lg);color:var(--color-text);margin:0}.header.svelte-17jy819 p:where(.svelte-17jy819){font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}.canvas-wrapper.svelte-17jy819{flex:1;display:flex;justify-content:center;align-items:center;padding:var(--space-4);overflow:hidden;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20"><rect width="10" height="10" fill="rgba(0,0,0,0.02)"/><rect x="10" y="10" width="10" height="10" fill="rgba(0,0,0,0.02)"/></svg>')}.interactive-svg.svelte-17jy819{max-width:100%;max-height:100%;box-shadow:var(--shadow-sm);background-color:#fff;border-radius:var(--radius-md);border:1px solid var(--color-border)}.draggable.svelte-17jy819{cursor:grab}.draggable.svelte-17jy819:active{cursor:grabbing}.hover-box.svelte-17jy819{opacity:0;transition:opacity .2s;pointer-events:none}.draggable.svelte-17jy819:hover .hover-box:where(.svelte-17jy819),.draggable.svelte-17jy819:active .hover-box:where(.svelte-17jy819){opacity:1}.preview-container.svelte-o4ydsk{flex:1 1 0%;display:flex;flex-direction:column;background-color:var(--color-background);position:relative;border-left:1px solid var(--color-border)}@media (max-width: 1100px){.preview-container.svelte-o4ydsk{border-left:none;border-top:1px solid var(--color-border);min-height:400px}}.header.svelte-o4ydsk{padding:var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface);text-align:center;z-index:10;position:relative}.header.svelte-o4ydsk h2:where(.svelte-o4ydsk){font-size:var(--font-size-lg);color:var(--color-text);margin:0}.header.svelte-o4ydsk p:where(.svelte-o4ydsk){font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}.canvas-wrapper.svelte-o4ydsk{flex:1;display:flex;justify-content:center;align-items:center;padding:var(--space-4);overflow:hidden;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20"><rect width="10" height="10" fill="rgba(0,0,0,0.02)"/><rect x="10" y="10" width="10" height="10" fill="rgba(0,0,0,0.02)"/></svg>')}.canvas-measure.svelte-o4ydsk{position:absolute;top:var(--space-4);left:var(--space-4);right:var(--space-4);bottom:var(--space-4);pointer-events:none;z-index:-1}.interactive-canvas-box.svelte-o4ydsk{box-shadow:var(--shadow-sm);background-color:#f5f5f5;border-radius:var(--radius-md);border:1px solid var(--color-border);overflow:hidden;position:relative;transition:opacity .2s}.interactive-canvas-box.paused.svelte-o4ydsk{opacity:.6}.pause-overlay.svelte-o4ydsk{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:8px 16px;border-radius:4px;font-weight:700;pointer-events:none;z-index:100;display:flex;align-items:center}.spinner.svelte-o4ydsk{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:svelte-o4ydsk-spin 1s linear infinite;margin-right:8px}@keyframes svelte-o4ydsk-spin{to{transform:rotate(360deg)}}canvas.svelte-o4ydsk{width:100%;height:100%;display:block;outline:none}.app-container.svelte-1n46o8q{display:flex;flex-direction:row;height:100vh;width:100vw;overflow:hidden}.previews-container.svelte-1n46o8q{flex:1;display:flex;flex-direction:row;overflow:hidden}.previews-container.svelte-1n46o8q>*{flex:1 1 0px!important;min-width:0!important}@media (max-width: 1100px){.previews-container.svelte-1n46o8q{flex-direction:column;overflow-y:auto}}
