*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;margin:0;padding:0;overflow:hidden;background:#1a1a2e;color:#eee;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.4;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100%;height:100%}@keyframes pop-in-out-3a5bda98{0%{transform:scale(.5);opacity:0}20%{transform:scale(1.1);opacity:1}80%{transform:scale(1);opacity:1}to{transform:scale(.5);opacity:0}}.stamp-container[data-v-3a5bda98]{position:absolute;display:flex;flex-direction:column;align-items:center;animation:pop-in-out-3a5bda98 1.5s ease-in-out forwards}.stamp-content[data-v-3a5bda98]{background-color:transparent;padding:0;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 4px 6px rgba(0,0,0,.3))}.stamp-content img[data-v-3a5bda98]{width:var(--stamp-base-size, 12vmin);height:var(--stamp-base-size, 12vmin);object-fit:contain;max-width:400px;max-height:400px}.display-screen[data-v-34c5f8f2]{width:100vw;height:100vh;background-color:transparent;position:relative;overflow:hidden}.control-area[data-v-34c5f8f2]{position:absolute;top:0;bottom:0;width:50%;z-index:10;cursor:pointer}.control-area.left[data-v-34c5f8f2]{left:0}.control-area.right[data-v-34c5f8f2]{right:0}.setup-overlay[data-v-34c5f8f2]{position:absolute;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:100}.setup-message[data-v-34c5f8f2]{text-align:center;color:#fff;font-family:system-ui,sans-serif}.setup-message h2[data-v-34c5f8f2]{font-size:2rem;margin-bottom:1rem}.setup-message p[data-v-34c5f8f2]{font-size:1.2rem;margin-bottom:2rem;opacity:.8}.setup-button[data-v-34c5f8f2]{display:inline-block;padding:1rem 2rem;background:#4f46e5;color:#fff;text-decoration:none;border-radius:.5rem;font-size:1.2rem;transition:background .2s}.setup-button[data-v-34c5f8f2]:hover{background:#4338ca}.debug-info[data-v-34c5f8f2]{position:fixed;bottom:10px;left:10px;background:#000c;color:#fff;padding:10px;font-size:12px;font-family:monospace;z-index:1000}.settings-link[data-v-34c5f8f2]{position:fixed;bottom:12px;left:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;color:#ffffff4d;text-decoration:none;border-radius:6px;font-size:18px;z-index:50;transition:all .2s}.settings-link[data-v-34c5f8f2]:hover{background:#fff3;color:#fffc}.config-view[data-v-73eeae75]{height:100vh;display:flex;flex-direction:column;background:#1a1a2e;color:#eee;font-family:system-ui,sans-serif;overflow:hidden}.header[data-v-73eeae75]{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#16213e;border-bottom:1px solid #0f3460;flex-shrink:0}.header h1[data-v-73eeae75]{font-size:1.2rem;margin:0}.header-actions[data-v-73eeae75]{display:flex;align-items:center;gap:1rem}.stamp-count[data-v-73eeae75]{font-size:.85rem;color:#9ca3af}.main[data-v-73eeae75]{flex:1;display:flex;flex-direction:column;gap:.5rem;padding:.5rem;overflow:hidden}.main-top[data-v-73eeae75]{flex:1;display:flex;gap:1rem;overflow:hidden}.sidebar[data-v-73eeae75]{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:.75rem}.panel[data-v-73eeae75]{background:#16213e;border-radius:.5rem;padding:.75rem}.panel h2[data-v-73eeae75]{margin:0 0 .5rem;font-size:.9rem;color:#e94560}.panel.highlight[data-v-73eeae75]{border:1px solid #e94560}.input-row[data-v-73eeae75]{display:flex;gap:.5rem}.input[data-v-73eeae75],.select[data-v-73eeae75]{flex:1;padding:.5rem;border:1px solid #0f3460;border-radius:.25rem;background:#1a1a2e;color:#eee;font-size:.85rem}.btn-sm[data-v-73eeae75]{padding:.5rem .75rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.85rem;background:#374151;color:#fff}.btn-sm[data-v-73eeae75]:hover{background:#4b5563}.btn-sm.btn-primary[data-v-73eeae75]{background:#4f46e5}.btn-sm.btn-primary[data-v-73eeae75]:hover{background:#4338ca}.btn-sm.btn-primary[data-v-73eeae75]:disabled{background:#6b7280;cursor:not-allowed}.btn-sm.btn-danger[data-v-73eeae75]{background:#dc2626}.btn-sm.btn-danger[data-v-73eeae75]:hover{background:#b91c1c}.btn-primary[data-v-73eeae75]{padding:.5rem 1rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.9rem;background:#4f46e5;color:#fff}.btn-primary[data-v-73eeae75]:hover{background:#4338ca}.btn-secondary[data-v-73eeae75]{padding:.5rem 1rem;border:none;border-radius:.25rem;cursor:pointer;font-size:.9rem;background:#374151;color:#fff}.btn-secondary[data-v-73eeae75]:hover{background:#4b5563}.btn-group[data-v-73eeae75]{display:flex;gap:.5rem;margin-top:.5rem}.led-color-section[data-v-73eeae75]{margin:.75rem 0}.led-color-section label[data-v-73eeae75]{display:block;font-size:.8rem;color:#9ca3af;margin-bottom:.4rem}.led-color-palette[data-v-73eeae75]{display:flex;gap:.4rem;flex-wrap:wrap}.led-color-btn[data-v-73eeae75]{width:28px;height:28px;border-radius:4px;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#333;transition:transform .1s,border-color .1s}.led-color-btn[data-v-73eeae75]:hover{transform:scale(1.1)}.led-color-btn.active[data-v-73eeae75]{border-color:#fff!important;box-shadow:0 0 6px #ffffff80}.info-text[data-v-73eeae75]{color:#9ca3af;font-size:.8rem;margin:.25rem 0 0}.success-text[data-v-73eeae75]{color:#10b981;font-size:.8rem;margin:.25rem 0 0}.warning-text[data-v-73eeae75]{color:#f59e0b;font-size:.8rem}.error-text[data-v-73eeae75]{color:#ef4444;font-size:.8rem;margin:.25rem 0 0}.blink[data-v-73eeae75]{animation:blink-73eeae75 1s infinite}@keyframes blink-73eeae75{50%{opacity:.5}}.midi-monitor[data-v-73eeae75]{margin-top:auto}.midi-info[data-v-73eeae75]{display:flex;gap:.5rem}.midi-row[data-v-73eeae75]{display:flex;flex-direction:column;align-items:center;flex:1;background:#1a1a2e;padding:.5rem;border-radius:.25rem}.midi-label[data-v-73eeae75]{font-size:.7rem;color:#9ca3af;text-transform:uppercase}.midi-value[data-v-73eeae75]{font-size:1.25rem;font-weight:700;font-family:monospace}.midi-value.highlight[data-v-73eeae75]{color:#10b981}.grid-container[data-v-73eeae75]{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.button-grid[data-v-73eeae75]{display:flex;gap:1.5rem}.grid-group[data-v-73eeae75]{background:#0f3460;padding:.75rem;border-radius:.5rem}.grid[data-v-73eeae75]{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}.grid-button[data-v-73eeae75]{width:70px;height:70px;border:2px solid #374151;border-radius:.4rem;background:#1a1a2e;color:#9ca3af;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;transition:all .15s}.grid-button[data-v-73eeae75]:hover{border-color:#4f46e5}.grid-button.selected[data-v-73eeae75]{border-color:#f59e0b!important;border-width:3px;background:#3d2f1a;box-shadow:0 0 10px #f59e0b66,inset 0 0 5px #f59e0b33}.grid-button.mapped[data-v-73eeae75]{border-color:var(--led-color, #10b981);background:#1a2e2e}.grid-button.active[data-v-73eeae75]{--glow-color: rgba(255, 255, 255, .6);box-shadow:0 0 8px var(--glow-color),0 0 16px var(--glow-color),0 0 24px var(--glow-color);border-color:transparent;transform:scale(1.08);animation:button-glow-73eeae75 .3s ease-out}@keyframes button-glow-73eeae75{0%{transform:scale(1.15);box-shadow:0 0 15px var(--glow-color),0 0 30px var(--glow-color),0 0 45px var(--glow-color)}to{transform:scale(1.08);box-shadow:0 0 8px var(--glow-color),0 0 16px var(--glow-color),0 0 24px var(--glow-color)}}.button-stamp-img[data-v-73eeae75]{width:45px;height:45px;object-fit:contain}.button-note[data-v-73eeae75]{position:absolute;bottom:1px;right:3px;font-size:.65rem;color:#9ca3af}.blank-icon[data-v-73eeae75]{font-size:1.5rem;color:#4b5563;line-height:1}.grid-button[data-v-73eeae75]:not(.mapped){border-style:dashed;border-color:#374151}.grid-button[data-v-73eeae75]:not(.mapped):hover{border-color:#4f46e5}.button-number[data-v-73eeae75]{font-size:1rem}.led-indicator[data-v-73eeae75]{position:absolute;top:3px;right:3px;width:8px;height:8px;border-radius:50%;border:1px solid rgba(255,255,255,.5)}.dialog-overlay[data-v-73eeae75]{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog[data-v-73eeae75]{background:#16213e;border-radius:.5rem;padding:1rem;max-width:600px;max-height:70vh;overflow-y:auto;width:90%}.dialog.dialog-sm[data-v-73eeae75]{max-width:320px}.dialog h3[data-v-73eeae75]{margin:0 0 .75rem;font-size:1rem}.category-tabs[data-v-73eeae75]{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.75rem}.category-tab[data-v-73eeae75]{padding:.4rem .75rem;border:1px solid #374151;border-radius:.25rem;background:transparent;color:#9ca3af;cursor:pointer;font-size:.8rem;transition:all .15s}.category-tab[data-v-73eeae75]:hover{border-color:#4f46e5;color:#eee}.category-tab.active[data-v-73eeae75]{background:#4f46e5;border-color:#4f46e5;color:#fff}.stamp-grid[data-v-73eeae75]{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem;margin-bottom:.75rem;max-height:300px;overflow-y:auto}.stamp-item[data-v-73eeae75]{display:flex;flex-direction:column;align-items:center;padding:.4rem;border:1px solid #374151;border-radius:.4rem;background:#1a1a2e;cursor:pointer;transition:all .15s}.stamp-item[data-v-73eeae75]:hover{border-color:#4f46e5;background:#2d1f3d}.stamp-item img[data-v-73eeae75]{width:50px;height:50px;object-fit:contain}.stamp-item span[data-v-73eeae75]{font-size:.7rem;color:#9ca3af;text-align:center;margin-top:.2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.dialog-close[data-v-73eeae75]{width:100%}.bottom-panel[data-v-73eeae75]{display:flex;gap:.75rem;background:#16213e;border-radius:.5rem;padding:.5rem;flex-shrink:0}.button-settings[data-v-73eeae75]{width:280px;flex-shrink:0;border-right:1px solid #374151;padding-right:.75rem}.settings-content h3[data-v-73eeae75]{margin:0 0 .4rem;font-size:1rem;color:#f59e0b}.settings-content h3.unselected[data-v-73eeae75]{color:#6b7280}.setting-row[data-v-73eeae75]{display:flex;align-items:center;gap:.4rem;margin-bottom:.35rem;min-height:24px;flex-wrap:wrap}.setting-label[data-v-73eeae75]{font-size:.75rem;color:#9ca3af;width:50px;flex-shrink:0}.midi-status-inline[data-v-73eeae75]{font-size:.8rem;color:#d1d5db;font-family:monospace}.midi-status-inline.unset[data-v-73eeae75]{color:#6b7280;font-family:inherit}.stamp-name-inline[data-v-73eeae75]{font-size:.75rem;color:#d1d5db;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.setting-stamp-thumb[data-v-73eeae75]{width:20px;height:20px;object-fit:contain;border-radius:2px}.btn-icon[data-v-73eeae75]{width:18px;height:18px;border:none;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.6rem;line-height:1;padding:0;flex-shrink:0}.btn-remove[data-v-73eeae75]{background:#4b5563;color:#d1d5db}.btn-remove[data-v-73eeae75]:hover{background:#dc2626;color:#fff}.led-color-palette[data-v-73eeae75]{display:flex;flex-wrap:wrap;gap:3px}.led-color-btn[data-v-73eeae75]{width:18px;height:18px;border:2px solid transparent;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.55rem;color:#333;padding:0}.led-color-btn.active[data-v-73eeae75]{border-color:#fff;box-shadow:0 0 4px #ffffff80}.led-color-btn[data-v-73eeae75]:disabled{opacity:.4;cursor:default}.settings-actions[data-v-73eeae75]{display:flex;gap:.5rem;margin-top:.5rem}.stamp-panel[data-v-73eeae75]{flex:1;display:flex;flex-direction:column;overflow:hidden}.category-tabs-compact[data-v-73eeae75]{display:flex;gap:.25rem;overflow-x:auto;padding-bottom:.25rem;flex-shrink:0}.category-tab-compact[data-v-73eeae75]{padding:.25rem .5rem;border:none;border-radius:.25rem;background:#374151;color:#9ca3af;font-size:.75rem;cursor:pointer;white-space:nowrap}.category-tab-compact.active[data-v-73eeae75]{background:#4f46e5;color:#fff}.stamp-list[data-v-73eeae75]{display:flex;flex-wrap:wrap;gap:.4rem;overflow-y:auto;flex:1;padding:.25rem 0}.stamp-item-compact[data-v-73eeae75]{width:50px;height:50px;padding:3px;border:2px solid #374151;border-radius:.25rem;background:#1a1a2e;cursor:pointer}.stamp-item-compact[data-v-73eeae75]:hover:not(.disabled){border-color:#4f46e5}.stamp-item-compact.disabled[data-v-73eeae75]{opacity:.4;cursor:not-allowed}.stamp-item-compact img[data-v-73eeae75]{width:100%;height:100%;object-fit:contain}
