body {
  font-family: Arial, sans-serif;
  margin: 20px;
}

#mainContainer {
  display: flex;
  gap: 20px;
}

/* Éditeur de bulle */
#bubbleEditor {
  flex: 0 0 250px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#bubbleEditor textarea {
  width: 100%;
  height: 100px;
}

#bubbleEditor input {
  width: 60px;
}

/* Conteneur image */
#canvasContainer {
  position: relative;
  border: 1px solid #ccc;
}

canvas {
  display: block;
  max-width: 100%;
}

/* Bulle */
.bubble {
  position: absolute;
  background: rgba(255, 255, 255, 0.95); /* fond très opaque */
  border: 2px solid #000;
  border-radius: 15px;
  padding: 5px;
  font-size: 14px;
  cursor: default;
  user-select: none;
}

.bubble span {
  display: inline-block;
  vertical-align: middle;
}

.bubble .icon {
  margin-left: 5px;
  cursor: pointer;
  font-size: 14px;
}
