<div class="wrapper">
  <div class="options">
    <pre>
.element {
  font-size: <select class="option">
        <option value="10px">10px</option>
        <option value="16px" selected>16px</option>
        <option value="1.15rem">1.15rem</option>
        <option value="20px">20px</option>
      </select>;
}
</pre>
  </div>

  <div class="content">
    <div class="element">Lorem ipsum dolor sit amet consectetur adipisicing elit. Mollitia facilis aperiam. porro iusto iste itaque! Excepturi optio.</div>
  </div>

</div>
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400&display=swap');

html,
body { 
  height: 100%; 
  overflow: hidden;
}

body {
  display: flex;
  justify-content: center;
  align-items: center;
}

.wrapper {
  display: flex;
  width: 100%;
  max-width: 720px;
  flex-direction: column;
  flex-wrap: wrap;
  box-sizing: border-box;
  font-size: clamp(12px, 3.5vw, 18px);
}

.options { 
  flex: 0 0 auto;
  margin-bottom: 1em;
}

.content {
  position: relative;
  padding-right: 25px;
}

.element {
  display: flex;
  align-items: center;
  text-align: left;
  font-family: 'Roboto', sans-serif;
  font-size: 16px;
  padding: 0;
  margin: 0;
}
View Compiled
const option = document.querySelector('.option');
const element = document.querySelector('.element');

option.addEventListener('change', () => {
  element.style.fontSize = `${option.value}`;
})
View Compiled

External CSS

  1. https://tim-montmorency.com/timdoc/shared/styles/codepen.css

External JavaScript

This Pen doesn't use any external JavaScript resources.