HTML / CSS текст без отступов внутри полей

Эта веб-страница предназначена для анимации блоков и отображения некоторых текстовых деталей, однако, когда поле переворачивается, я не могу сделать отступ для текста внутри поля.

Я хочу уменьшить размер текста для поля, которое переворачивается. Однако выравнивание не влияет на текст. Я хочу добавить весь текст внутри поля, и они не должны выходить за пределы поля.

https://codepen.io/srinabh/pen/XBKQdm

flexbox{
	margin: 0;
	padding: 0;
	list-style-type: none;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
}
.panels{
  list-style-type: none;
  padding: 0;
   width: 100%;
  margin: 2% auto;
}

.panels li{
  position: relative;
  width: 20%;
  margin: 5px;
  display: block;
  box-sizing: border-box;
  float: left
}

.panels li div{
  width: 100%;
  padding: 50% 0;
  text-align: center;
  line-height: 0;
  cursor: pointer;
    -moz-box-shadow: 0px 2px 7px rgba(0, 0, 0,0.2);
    -webkit-box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
    box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
}

.panels div.back{
  background: linear-gradient(to bottom, #e40000, #f07611);
	transform: rotateY(90deg);

  font-family: Cabin;
  font-size: 1.4707843137254901vw;
  color: #3d4250;
		position: absolute;
    left: 0;
    top:0;
}
.panel div.front{
  background: white;  
  font-family: Cabin;
  font-size: 1.9607843137254901vw;
  color: #3d4250;
	  position: relative;
}

/*// ANIMATION STYLES //*/

.panels li:hover div.front{
  animation: twirl 0.2s ease-in forwards;
}

.panels li:hover div.back{
  animation: twirl 0.2s 0.2s ease-in forwards reverse;  
}
@keyframes twirl{
  0%{
    transform: rotateY(0deg);
  }
  100%{
    transform: rotateY(90deg);
  }
}
<ul class = "panels flexbox">
      <li>
        <div class = "front">Sense of Purpose</div>
        <div class = "back"><h6>Sense of purpose</h6>
        "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. </div>
      </li>
      <li>
        <div class = "front" style = "background: #9126f4">Get to</div>
        <div class = "back">The chopper</div>
      </li>
      <li>
        <div class = "front" style = "background: #21bf3b">foo</div>
        <div class = "back">bar</div>
      </li>
      <li>
        <div class = "front" style = "background: #c3333d">tempus</div>
        <div class = "back" >fugit</div>
      </li>
      <li>
        <div class = "front" style = "background: #c3333d">html</div>
        <div class = "back">rocks</div>
      </li>
      <li>
        <div class = "front" style = "background: #21bf3b">A</div>
        <div class = "back">B</div>
      </li>
      <li>
        <div class = "front" style = "background: #9126f4">Super</div>
        <div class = "back" >Mariokart</div>
      </li>
      <li>
        <div class = "front" style = "background: #267df4">j</div>
        <div class = "back">Query</div>
      </li>
    </ul>

🤔 А знаете ли вы, что...
HTML поддерживает механизмы для встраивания JavaScript-кода для создания интерактивных элементов.


1
62
1

Ответ:

Решено

Удаление высоты строки решит проблему перекрытия текста.

.panels li div{
  width: 100%;
  padding: 50% 0;
  text-align: center;
  /*line-height: 0;*/
  cursor: pointer;
    -moz-box-shadow: 0px 2px 7px rgba(0, 0, 0,0.2);
    -webkit-box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
    box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
}

И добавьте высоту в div.

.panels div.back{
        background: linear-gradient(to bottom, #e40000, #f07611);
        transform: rotateY(90deg);
        height: 18px;
        font-family: Cabin;
        /* font-size: 1.4707843137254901vw;*/
        color: #3d4250;
          position: absolute;
          left: 0;
          top:0;
      }
      .panel div.front{
        background: white;  
        font-family: Cabin;
        /*font-size: 1.9607843137254901vw;*/
         color: #3d4250;
          position: relative;
      }