@import url("https://fonts.googleapis.com/css2?family=Kreon:wght@300;400;500;600;700&family=Prompt:wght@400;500;600;700;800;900&display=swap");

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-family: "Prompt", sans-serif;
}

body {
  display: flex;
  flex-direction: column;
}

#piece-title {
  font-weight: 600;
  font-size: 2.5rem;
  border: 0;
  text-align: center;
  text-transform: capitalize;
}

textarea {
  resize: vertical;
  min-height: 300px;
  padding: 1rem;
  background-color: rgb(195, 195, 195);
}

#output-content {
  font-size: 1.5rem;
  padding: 0 3cm;
  text-transform: uppercase;
  font-weight: 500;
  white-space: pre-line;
}

#output-content > span {
  box-sizing: content-box;
  display: inline-block;
  width: 2rem;
  text-align: center;
  height: 2rem;
  margin: 1rem 0;
  position: relative;
  text-underline-offset: 0.5rem;
}

.sharp::before {
  content: " ";
  position: absolute;
  display: block;
  width: 80%;
  height: 80%;
  top: 10%;
  left: 5%;
  border: 2px solid black;
  border-radius: 100rem;
}

.white {
  color: transparent !important;
}

hr {
  border-width: 1px;
  border-color: black;
  border-style: solid;
}

#controls {
  background-color: rgb(164, 164, 194);
  text-align: center;
}

button,
a,
select {
  padding: 1em;
  margin: 0.5rem;
  border: 2px solid black;
  border-radius: 0.5rem;
  background-color: rgb(179, 234, 216);
  font-size: 1rem;
}

button:hover,
a:hover,
select:hover {
  opacity: 0.5;
}

@media print {
  #input-content,
  #controls {
    display: none;
    visibility: hidden;
  }

  #output-content {
    padding: 0;
  }
}
