:root{--vt-c-white: #ffffff;--vt-c-white-soft: #f8f8f8;--vt-c-white-mute: #f2f2f2;--vt-c-black: #181818;--vt-c-black-soft: #222222;--vt-c-black-mute: #282828;--vt-c-indigo: #2c3e50;--vt-c-divider-light-1: rgba(60, 60, 60, .29);--vt-c-divider-light-2: rgba(60, 60, 60, .12);--vt-c-divider-dark-1: rgba(84, 84, 84, .65);--vt-c-divider-dark-2: rgba(84, 84, 84, .48);--vt-c-text-light-1: var(--vt-c-indigo);--vt-c-text-light-2: rgba(60, 60, 60, .66);--vt-c-text-dark-1: var(--vt-c-white);--vt-c-text-dark-2: rgba(235, 235, 235, .64)}:root{--color-background: var(--vt-c-white);--color-background-soft: var(--vt-c-white-soft);--color-background-mute: var(--vt-c-white-mute);--color-border: var(--vt-c-divider-light-2);--color-border-hover: var(--vt-c-divider-light-1);--color-heading: var(--vt-c-text-light-1);--color-text: var(--vt-c-text-light-1);--section-gap: 160px}@media (prefers-color-scheme: dark){:root{--color-background: var(--vt-c-black);--color-background-soft: var(--vt-c-black-soft);--color-background-mute: var(--vt-c-black-mute);--color-border: var(--vt-c-divider-dark-2);--color-border-hover: var(--vt-c-divider-dark-1);--color-heading: var(--vt-c-text-dark-1);--color-text: var(--vt-c-text-dark-2)}}*,*:before,*:after{box-sizing:border-box;margin:0;font-weight:400}body{min-height:100vh;color:var(--color-text);background:var(--color-background);transition:color .5s,background-color .5s;line-height:1.6;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:15px;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{margin:0 auto;padding:2rem;font-weight:400}a,.green{text-decoration:none;color:#00bd7e;transition:.4s;padding:3px}@media (hover: hover){a:hover{background-color:#00bd7e33}}@media (min-width: 1024px){body{display:flex;place-items:center}}.canvas-container[data-v-5111f006]{position:relative;display:inline-block}.highlighter-canvas[data-v-5111f006]{border:1px solid #ccc;display:block;width:100%;height:100%}.highlighter-demo[data-v-dad78e3e]{max-width:1200px;margin:0 auto;padding:20px}.demo-section[data-v-dad78e3e]{margin:30px 0;padding:20px;border:1px solid #ddd;border-radius:8px;background:#fafafa}.demo-section h2[data-v-dad78e3e]{margin-top:0;color:#333}textarea[data-v-dad78e3e]{width:100%;margin:10px 0;padding:10px;border:1px solid #ccc;border-radius:4px;font-family:monospace;font-size:12px;resize:vertical;background-color:#f8f8f8}.data-actions[data-v-dad78e3e]{display:flex;gap:10px;margin-top:10px}button[data-v-dad78e3e]{padding:8px 16px;border:1px solid #007bff;background:#fff;color:#007bff;border-radius:4px;cursor:pointer;font-size:14px}button[data-v-dad78e3e]:hover{background:#007bff;color:#fff}ul[data-v-dad78e3e]{padding-left:20px}li[data-v-dad78e3e]{margin:5px 0}.fabric-highlighter[data-v-dad78e3e]{position:relative;display:inline-block}.toolbar[data-v-dad78e3e]{display:flex;gap:8px;margin:8px 0}.tool-button[data-v-dad78e3e]{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:14px;transition:all .2s ease;min-width:80px;position:relative}.tool-button[data-v-dad78e3e]:hover{border-color:#999;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.tool-button.active[data-v-dad78e3e]{background:#06c;color:#fff;border-color:#0052a3;box-shadow:0 2px 8px #0066cc4d}.tool-icon[data-v-dad78e3e]{font-size:24px;line-height:1}.tool-label[data-v-dad78e3e]{font-weight:500;font-size:12px}.tool-shortcut[data-v-dad78e3e]{font-size:10px;opacity:.6;font-weight:400}.tool-button.active .tool-shortcut[data-v-dad78e3e]{opacity:.8}.color-palette[data-v-dad78e3e]{flex:1;background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px;margin:8px 0;box-shadow:0 2px 8px #0000001a;max-width:320px}.color-palette-header[data-v-dad78e3e]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.palette-title[data-v-dad78e3e]{margin:0;font-size:16px;font-weight:600;color:#333}.custom-color-toggle[data-v-dad78e3e]{background:none;border:1px solid #ddd;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:16px;transition:all .2s ease}.custom-color-toggle[data-v-dad78e3e]:hover{background:#f0f0f0}.custom-color-toggle.active[data-v-dad78e3e]{background:#06c;border-color:#06c}.color-section[data-v-dad78e3e]{margin-bottom:16px}.color-section[data-v-dad78e3e]:last-child{margin-bottom:0}.section-title[data-v-dad78e3e]{margin:0 0 8px;font-size:12px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px}.color-grid[data-v-dad78e3e]{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.color-button[data-v-dad78e3e]{width:40px;height:40px;border:2px solid #ddd;border-radius:6px;cursor:pointer;transition:all .2s ease;position:relative}.color-button[data-v-dad78e3e]:hover{border-color:#999;transform:scale(1.05);box-shadow:0 2px 6px #0003}.color-button.active[data-v-dad78e3e]{border-color:#06c;border-width:3px;transform:scale(1.1);box-shadow:0 2px 8px #06c6}.color-button.active[data-v-dad78e3e]:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;text-shadow:0 0 3px rgba(0,0,0,.5);font-size:14px}.recent-color[data-v-dad78e3e]{position:relative}.recent-color[data-v-dad78e3e]:before{content:"";position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:#06c;border-radius:50%;border:1px solid white}.custom-color-section[data-v-dad78e3e]{border-top:1px solid #eee;padding-top:12px}.custom-color-inputs[data-v-dad78e3e]{display:flex;gap:8px;align-items:center}.color-input[data-v-dad78e3e]{width:50px;height:40px;border:2px solid #ddd;border-radius:6px;cursor:pointer;padding:0}.color-text-input[data-v-dad78e3e]{flex:1;height:40px;padding:0 12px;border:2px solid #ddd;border-radius:6px;font-family:monospace;font-size:14px}.color-text-input[data-v-dad78e3e]:focus{outline:none;border-color:#06c}.data-controls[data-v-dad78e3e]{display:flex;gap:8px;margin:8px 0}.data-controls button[data-v-dad78e3e]{padding:8px 12px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer}.data-controls button[data-v-dad78e3e]:hover{background:#e9e9e9}.size-controls[data-v-dad78e3e]{flex:1;background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px;margin:8px 0;box-shadow:0 2px 8px #0000001a}.size-controls-header[data-v-dad78e3e]{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.controls-title[data-v-dad78e3e]{margin:0;font-size:14px;font-weight:600;color:#333}.size-preview[data-v-dad78e3e]{display:flex;align-items:center;justify-content:center;width:60px;height:60px;border:2px solid #e0e0e0;border-radius:50%;background-color:#f9f9f9}.preview-circle[data-v-dad78e3e]{border-radius:50%;transition:all .2s ease}.size-section[data-v-dad78e3e]{margin-bottom:20px}.size-control[data-v-dad78e3e]{margin-bottom:16px}.size-label[data-v-dad78e3e]{display:block;margin-bottom:8px;font-size:13px;font-weight:500;color:#555}.size-slider-container[data-v-dad78e3e]{position:relative}.size-slider[data-v-dad78e3e]{width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none;opacity:.8;transition:opacity .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.size-slider[data-v-dad78e3e]:hover{opacity:1}.size-slider[data-v-dad78e3e]:disabled{opacity:.4;cursor:not-allowed}.size-slider[data-v-dad78e3e]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#007bff;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s ease}.size-slider[data-v-dad78e3e]::-webkit-slider-thumb:hover{background:#0056b3;transform:scale(1.1)}.size-slider[data-v-dad78e3e]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#007bff;cursor:pointer;border:none;box-shadow:0 2px 4px #0003;transition:all .2s ease}.size-marks[data-v-dad78e3e]{display:flex;justify-content:space-between;margin-top:4px;font-size:11px;color:#999}.mark-small[data-v-dad78e3e],.mark-large[data-v-dad78e3e]{font-size:10px;color:#aaa}.size-presets[data-v-dad78e3e]{border-top:1px solid #eee;padding-top:16px}.preset-buttons[data-v-dad78e3e]{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.preset-button[data-v-dad78e3e]{display:flex;flex-direction:column;align-items:center;padding:12px 8px;border:1px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:12px}.preset-button[data-v-dad78e3e]:hover{background:#f5f5f5;border-color:#007bff;transform:translateY(-1px)}.preset-button.active[data-v-dad78e3e]{background:#007bff;border-color:#007bff;color:#fff}.preset-icon[data-v-dad78e3e]{font-size:16px;margin-bottom:4px}.preset-name[data-v-dad78e3e]{font-weight:500}.rectangle-controls[data-v-dad78e3e]{display:flex;flex-direction:column;background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px;margin:8px 0;box-shadow:0 2px 8px #0000001a}.rectangle-controls button[data-v-dad78e3e]{padding:8px 16px;margin-right:8px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.rectangle-controls button[data-v-dad78e3e]:hover{background:#f5f5f5;border-color:#007bff}.rectangle-controls button.active[data-v-dad78e3e]{background:#007bff;color:#fff;border-color:#007bff}.rectangle-controls button[data-v-dad78e3e]:disabled{opacity:.6;cursor:not-allowed}.rectangle-info[data-v-dad78e3e]{margin-top:8px;font-size:12px;color:#666;font-weight:500}.history-controls[data-v-dad78e3e]{background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px;margin:8px 0;box-shadow:0 2px 8px #0000001a;display:flex;gap:8px}.history-button[data-v-dad78e3e]{padding:8px 16px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;gap:4px}.history-button[data-v-dad78e3e]:hover:not(:disabled){background:#f5f5f5;border-color:#007bff;transform:translateY(-1px)}.history-button[data-v-dad78e3e]:disabled{opacity:.4;cursor:not-allowed;background:#f8f9fa}.background-controls[data-v-dad78e3e]{flex:1;display:flex;flex-direction:column;background:#fff;border:1px solid #ddd;border-radius:8px;padding:16px;margin:8px 0;box-shadow:0 2px 8px #0000001a}.background-controls h3[data-v-dad78e3e]{margin:0 0 12px;color:#333;font-size:16px}.background-actions[data-v-dad78e3e]{display:flex;flex-direction:column;gap:8px;flex-wrap:wrap}.bg-button[data-v-dad78e3e]{padding:8px 16px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;display:flex;align-items:center;gap:4px}.bg-button[data-v-dad78e3e]:hover:not(:disabled){background:#f5f5f5;border-color:#007bff;transform:translateY(-1px)}.bg-button[data-v-dad78e3e]:disabled{opacity:.4;cursor:not-allowed;background:#f8f9fa}.bg-button.remove-btn[data-v-dad78e3e]:hover:not(:disabled){background:#f8d7da;border-color:#dc3545;color:#721c24}.background-info[data-v-dad78e3e]{margin-top:8px;padding:6px 12px;background:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:4px;font-size:12px}#app{font-family:Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2c3e50}body{margin:0;padding:0}
