@charset "UTF-8";
.page__ttl {
  padding-block: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 90%;
  max-width: 573px;
  margin-inline: auto;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .page__ttl {
    width: 61%;
    max-width: 573px;
  }
}
.page__ttl img {
  width: 100%;
  height: auto;
}
.page__ttl::after {
  content: "";
  display: flex;
  align-items: center;
  width: 11.3%;
  height: auto;
  aspect-ratio: 65/87;
  background: url(/recruit/assets/images/common/chara01.svg) center center/contain no-repeat;
  position: absolute;
  right: 6.5%;
  top: 50%;
  z-index: 1;
  margin: auto;
  animation: float-bobbing 3s ease-in-out infinite;
}
@media only screen and (max-width: 767px) {
  .page__ttl::after {
    width: 13%;
  }
}

.sec__data {
  padding-bottom: 80px;
}
.sec__data:has(.sec__ttl) {
  padding-bottom: 200px;
}
.sec__data .sec__ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(1.875rem, 2.7777777778vw, 2.5rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.2em;
  margin-bottom: 80px;
}
.sec__data .sec__ttl::after {
  content: "";
  display: block;
  background: url(/recruit/assets/images/common/icon_cup.svg) center center/contain no-repeat;
  width: 42px;
  height: 26px;
  margin-left: 20px;
}
.sec__data .grid__box {
  width: 90%;
  max-width: 1400px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 2.5%;
  box-sizing: border-box;
  grid-auto-rows: auto;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box {
    display: block;
  }
}
.sec__data .grid__box li {
  background: #ffffff;
  border-radius: 20px;
  position: relative;
  display: grid;
  padding: 24px;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 0;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li {
    row-gap: 20px;
    padding: 18px;
  }
  .sec__data .grid__box li + li {
    margin-top: 20px;
  }
}
.sec__data .grid__box li {
  /* ▼ フリップアニメーション用の追加スタイル ▼ */
  transform-style: preserve-3d;
  transition: transform 0.3s ease-in-out;
  transform: perspective(1000px) rotateY(-180deg);
}
.sec__data .grid__box li.is-flipped {
  transform: perspective(1000px) rotateY(0deg);
}
.sec__data .grid__box li {
  /* 裏返っている間は既存の::before(アイコン)や::after(注釈)を隠す */
}
.sec__data .grid__box li::before, .sec__data .grid__box li::after {
  opacity: 0;
  transition: opacity 0.1s;
}
.sec__data .grid__box li.is-flipped::before, .sec__data .grid__box li.is-flipped::after {
  opacity: 1;
  transition: opacity 0.3s 0.2s; /* 表面に戻ってからふわっと出す */
}
.sec__data .grid__box li {
  /* 前面のコンテンツ（裏から透けないようにする設定） */
}
.sec__data .grid__box li > *:not(.card__back) {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.sec__data .grid__box li {
  /* 裏面要素のスタイル（絶対配置なのでsubgridを壊さない） */
}
.sec__data .grid__box li .card__back {
  position: absolute;
  inset: 0;
  background-color: #fcee21; /* ※黄色一色の変数（または #ffd700 など） */
  border-radius: 20px; /* li本体と同じ角丸 */
  display: flex;
  justify-content: center;
  align-items: center;
  /* 180度反転させ、1px手前に出してliの背景を隠す */
  transform: rotateY(180deg) translateZ(1px);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  z-index: 10;
}
.sec__data .grid__box li {
  /* ▲ フリップアニメーション用の追加スタイルここまで ▲ */
}
.sec__data .grid__box li::before {
  content: "";
  display: block;
  position: absolute;
  right: 24px;
  top: 24px;
}
.sec__data .grid__box li .list__ttl {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", sans-serif;
  font-size: clamp(0.9375rem, 1.3888888889vw, 1.25rem);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.5em;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li .list__ttl {
    font-size: 16px;
  }
}
.sec__data .grid__box li .list__ttl span {
  text-indent: -0.5em;
  display: block;
  font-weight: 400;
  letter-spacing: 0.03em;
}
.sec__data .grid__box li .list__detail p {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", sans-serif;
  font-weight: 700;
  color: #40bbf0;
}
.sec__data .grid__box li .list__detail p .no {
  font-size: clamp(2.0625rem, 3.0555555556vw, 2.75rem);
  font-weight: 700;
  align-items: baseline;
}
.sec__data .grid__box li .list__detail p .no em {
  font-family: "Oswald", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", sans-serif;
  font-weight: 700;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.sec__data .grid__box li .list__comment {
  margin-top: 10px;
  display: grid;
  grid-template-columns: 1fr max-content;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.sec__data .grid__box li .list__comment:after {
  content: "";
  display: block;
  margin-top: -10px;
}
.sec__data .grid__box li .list__comment.face01:after {
  width: 52px;
  height: 54px;
  background: url(/recruit/assets/images/data/asamin_face01.svg) center center/contain no-repeat;
}
.sec__data .grid__box li .list__comment.face02:after {
  width: 52px;
  height: 54px;
  background: url(/recruit/assets/images/data/asamin_face02.svg) center center/contain no-repeat;
}
.sec__data .grid__box li .list__comment p {
  font-size: clamp(0.75rem, 1.0416666667vw, 0.9375rem);
  text-align: center;
  position: relative;
  padding: 10px;
  border-right: 1px solid #40bbf0;
  border-bottom: 1px solid #40bbf0;
}
.sec__data .grid__box li .list__comment p::before, .sec__data .grid__box li .list__comment p:after {
  content: "";
  display: block;
  position: absolute;
  inset: 0 0 0 auto;
  margin: auto;
  aspect-ratio: 0.8660254038;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.sec__data .grid__box li .list__comment p::before {
  height: 11px;
  background: #40bbf0;
  right: -10px;
}
.sec__data .grid__box li .list__comment p:after {
  height: 11px;
  background: #ffffff;
  right: -8px;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li .list__comment p {
    text-align: left;
  }
}
.sec__data .grid__box li.li__staff::before {
  width: clamp(4.3125rem, 6.3888888889vw, 5.75rem);
  height: clamp(2.4375rem, 3.6111111111vw, 3.25rem);
  background: url(/recruit/assets/images/data/data_staff.svg) center center/contain no-repeat;
}
.sec__data .grid__box li.li__staff .list__detail {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-block: calc((1em - 1lh) / 2);
}
.sec__data .grid__box li.li__staff .list__detail p {
  font-size: clamp(2.8125rem, 4.1666666667vw, 3.75rem);
  line-height: clamp(6.375rem, 9.4444444444vw, 8.5rem);
  margin-block: calc((1em - 1lh) / 2);
  display: flex;
  align-items: end;
  white-space: nowrap;
}
.sec__data .grid__box li.li__staff .list__detail p .no {
  line-height: clamp(6.375rem, 9.4444444444vw, 8.5rem);
  margin-block: calc((1em - 1lh) / 2);
  -moz-column-gap: 20px;
       column-gap: 20px;
  flex-shrink: 0;
}
.sec__data .grid__box li.li__staff .list__detail p .no em {
  font-size: clamp(6.375rem, 9.4444444444vw, 8.5rem);
  line-height: clamp(6.375rem, 9.4444444444vw, 8.5rem);
  margin-block: calc((1em - 1lh) / 2);
  min-width: 3ch;
  text-align: right;
  display: inline-block;
}
.sec__data .grid__box li.li__staff .list__detail img {
  width: 100%;
  max-width: 70px;
  height: auto;
  margin-top: 10px;
}
.sec__data .grid__box li.li__generation .list__detail {
  position: relative;
}
.sec__data .grid__box li.li__generation .list__detail .img__box {
  display: flex;
  justify-content: center;
  align-items: center;
}
.sec__data .grid__box li.li__generation .list__detail .img__box img {
  aspect-ratio: 1;
  height: 100%;
}
.sec__data .grid__box li.li__generation .p__gene {
  display: flex;
  align-items: baseline;
  position: absolute;
  white-space: nowrap;
  gap: 5px;
  /**/
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__generation .p__gene {
    gap: 3px;
  }
}
.sec__data .grid__box li.li__generation .p__gene::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  background: #636263;
  height: 1px;
  width: 100%;
}
.sec__data .grid__box li.li__generation .p__gene::after {
  content: "";
  display: block;
  width: 4.5px;
  height: 4.5px;
  border-radius: 10px;
  background: #636263;
  position: absolute;
  bottom: -2px;
}
.sec__data .grid__box li.li__generation .p__gene.gene--60th, .sec__data .grid__box li.li__generation .p__gene.gene--50th, .sec__data .grid__box li.li__generation .p__gene.gene--40th {
  left: 0;
  justify-content: flex-start;
}
.sec__data .grid__box li.li__generation .p__gene.gene--60th::before, .sec__data .grid__box li.li__generation .p__gene.gene--50th::before, .sec__data .grid__box li.li__generation .p__gene.gene--40th::before {
  left: 0;
}
.sec__data .grid__box li.li__generation .p__gene.gene--60th::after, .sec__data .grid__box li.li__generation .p__gene.gene--50th::after, .sec__data .grid__box li.li__generation .p__gene.gene--40th::after {
  right: -2px;
}
.sec__data .grid__box li.li__generation .p__gene.gene--30th, .sec__data .grid__box li.li__generation .p__gene.gene--20th, .sec__data .grid__box li.li__generation .p__gene.gene--10th {
  right: 0;
  justify-content: flex-end;
}
.sec__data .grid__box li.li__generation .p__gene.gene--30th::before, .sec__data .grid__box li.li__generation .p__gene.gene--20th::before, .sec__data .grid__box li.li__generation .p__gene.gene--10th::before {
  right: 0;
}
.sec__data .grid__box li.li__generation .p__gene.gene--30th::after, .sec__data .grid__box li.li__generation .p__gene.gene--20th::after, .sec__data .grid__box li.li__generation .p__gene.gene--10th::after {
  left: -2px;
}
.sec__data .grid__box li.li__generation .p__gene.gene--60th {
  color: #a0c9e5;
  top: 0;
  width: 47%;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__generation .p__gene.gene--60th {
    width: 45%;
  }
}
.sec__data .grid__box li.li__generation .p__gene.gene--50th {
  color: #a0c9e5;
  top: 50%;
  transform: translateY(calc(-50% - 10px));
  width: 39.8%;
}
.sec__data .grid__box li.li__generation .p__gene.gene--40th {
  bottom: 20px;
  width: 44%;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__generation .p__gene.gene--40th {
    width: 42%;
  }
}
.sec__data .grid__box li.li__generation .p__gene.gene--30th {
  bottom: 20px;
  width: 46%;
}
.sec__data .grid__box li.li__generation .p__gene.gene--20th {
  top: 50%;
  transform: translateY(calc(-50% - 10px));
  width: 42%;
}
.sec__data .grid__box li.li__generation .p__gene.gene--10th {
  color: #a0c9e5;
  top: 0;
  width: 50.5%;
}
.sec__data .grid__box li.li__generation .p__gene .gene {
  font-size: clamp(0.75rem, 0.9722222222vw, 0.875rem);
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__generation .p__gene .gene {
    -webkit-text-stroke: 2px #ffffff;
    text-stroke: 2px #ffffff;
    paint-order: stroke;
  }
}
.sec__data .grid__box li.li__generation .p__gene .gene > span {
  font-family: "Oswald", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", sans-serif;
  font-size: clamp(1.03125rem, 1.5277777778vw, 1.375rem);
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__generation .p__gene .gene > span {
    -webkit-text-stroke: 2px #ffffff;
    text-stroke: 2px #ffffff;
    paint-order: stroke;
  }
}
.sec__data .grid__box li.li__generation .p__gene .no {
  font-size: clamp(1.03125rem, 1.5277777778vw, 1.375rem);
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__generation .p__gene .no {
    -webkit-text-stroke: 2px #ffffff;
    text-stroke: 2px #ffffff;
    paint-order: stroke;
  }
}
.sec__data .grid__box li.li__generation .p__gene .no > em {
  font-family: "Oswald", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", sans-serif;
  font-size: clamp(1.828125rem, 2.7083333333vw, 2.4375rem);
  line-height: 1;
  display: inline-block;
  min-width: 4ch;
  text-align: right;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__generation .p__gene .no > em {
    -webkit-text-stroke: 2px #ffffff;
    text-stroke: 2px #ffffff;
    paint-order: stroke;
  }
}
.sec__data .grid__box li.li__license::before {
  width: clamp(3.75rem, 5.5555555556vw, 5rem);
  height: clamp(2.8125rem, 4.1666666667vw, 3.75rem);
  background: url(/recruit/assets/images/data/data_license.svg) center center/contain no-repeat;
  z-index: 1;
}
.sec__data .grid__box li.li__license .list__detail {
  z-index: 2;
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  justify-content: center;
  gap: 20px;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__license .list__detail {
    grid-template-columns: max-content auto;
    gap: 10px;
    grid-template-columns: max-content auto;
  }
}
.sec__data .grid__box li.li__license .list__detail .all .no em {
  font-size: clamp(5.25rem, 7.7777777778vw, 7rem);
  line-height: 1cap;
  display: inline-block;
  min-width: 3ch;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__license .list__detail .all .no em {
    font-size: clamp(4.21875rem, 6.25vw, 5.625rem);
  }
}
.sec__data .grid__box li.li__license .list__detail .ratio {
  position: relative;
  border-left: 2px solid #40bbf0;
}
.sec__data .grid__box li.li__license .list__detail .ratio::before, .sec__data .grid__box li.li__license .list__detail .ratio:after {
  content: "";
  display: block;
  position: absolute;
  inset: 0 auto 0 0;
  margin: auto;
  aspect-ratio: 0.8660254038;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
}
.sec__data .grid__box li.li__license .list__detail .ratio::before {
  height: 11px;
  background: #40bbf0;
  left: -10px;
}
.sec__data .grid__box li.li__license .list__detail .ratio:after {
  height: 11px;
  background: #ffffff;
  left: -6px;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner {
  padding-block: 5px;
  padding-left: 10px;
  position: relative;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner::before, .sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  width: 5px;
  height: 2px;
  background: #40bbf0;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner::before {
  top: 0;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner:after {
  bottom: 0;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner p {
  font-size: clamp(0.75rem, 0.9027777778vw, 0.8125rem);
  color: #000000;
  line-height: 1.5;
  display: flex;
  align-items: center;
  margin-right: 15px;
  flex-shrink: 0;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner p + p {
  margin-top: 10px;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner p::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 10px;
  background: #40bbf0;
  margin-right: 5px;
  flex-shrink: 0;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner p .no {
  line-height: clamp(1.3125rem, 1.9444444444vw, 1.75rem);
  display: flex;
  align-items: center;
}
.sec__data .grid__box li.li__license .list__detail .ratio .ratio__inner p .no em {
  font-size: clamp(1.3125rem, 1.9444444444vw, 1.75rem);
  line-height: clamp(1.3125rem, 1.9444444444vw, 1.75rem);
  color: #40bbf0;
  display: inline-block;
  min-width: 3ch;
  text-align: right;
}
.sec__data .grid__box li {
  /*
  &.li__money {
      &::before {
          width: 96px;
          height: 76px;
          background: url(/recruit/assets/images/data/data_money.svg) center center / contain no-repeat;
      }

      .list__detail {
          p {
              font-size: function.size(35);
              line-height: 1;
              text-align: center;
              .no {
                  line-height: 1;
                  gap: 20px;
                  em {
                      font-size: function.size(88);
                      line-height: 1.5;
                      text-align: center;
                      display: block;
                  }
              }
          }
          img {
              width: 100%;
              max-width: 70px;
              height: auto;
              margin-top: 10px;
          }
      }
  }
      */
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__runk {
    margin-bottom: 70px;
  }
}
.sec__data .grid__box li.li__runk::before {
  width: clamp(2.34375rem, 3.4722222222vw, 3.125rem);
  aspect-ratio: 50/37;
  background: url(/recruit/assets/images/data/data_runk.svg) center center/contain no-repeat;
}
.sec__data .grid__box li.li__runk::after {
  content: "※出典：建通新聞 2026年1月8日号（元データ：CIIC 経営事項審査結果）\a 2025年11月28日時点。";
  display: block;
  position: absolute;
  white-space: pre-wrap;
  word-wrap: break-word;
  top: calc(100% + 5px);
  left: 0;
  width: 100%;
  text-indent: -1em;
  padding-left: 1em;
  font-size: clamp(0.75rem, 0.7638888889vw, 0.6875rem);
  line-height: 1.5;
  color: inherit;
  pointer-events: none;
}
.sec__data .grid__box li.li__runk .list__ttl {
  text-align: center;
  color: #40bbf0;
  letter-spacing: normal;
  z-index: 2;
}
.sec__data .grid__box li.li__runk .list__ttl sup {
  font-size: clamp(0.75rem, 0.8333333333vw, 0.75rem);
  color: #000000;
}
.sec__data .grid__box li.li__runk .list__detail p {
  display: flex;
  align-items: baseline;
  justify-content: center;
  font-size: clamp(1.03125rem, 1.5277777778vw, 1.375rem);
  line-height: 1;
  text-align: center;
  margin-block: calc((1em - 1lh) / 2);
}
.sec__data .grid__box li.li__runk .list__detail p .no {
  font-size: clamp(2.0625rem, 3.0555555556vw, 2.75rem);
  line-height: clamp(2.0625rem, 3.0555555556vw, 2.75rem);
  margin-block: calc((1em - 1lh) / 2);
  display: flex;
  align-items: baseline;
}
.sec__data .grid__box li.li__runk .list__detail p .no + .no {
  font-family: "Oswald", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", "Meiryo", sans-serif;
  font-size: clamp(3.09375rem, 4.5833333333vw, 4.125rem);
  line-height: clamp(3.09375rem, 4.5833333333vw, 4.125rem);
  margin-block: calc((1em - 1lh) / 2);
  position: relative;
}
.sec__data .grid__box li.li__runk .list__detail p .no + .no::before {
  content: "";
  display: block;
  height: clamp(3.09375rem, 4.5833333333vw, 4.125rem);
  width: 1px;
  background: #40bbf0;
  transform: rotate(20deg);
  margin-inline: 20px 10px;
}
.sec__data .grid__box li.li__runk .list__detail p .no em {
  font-size: clamp(6.234375rem, 9.2361111111vw, 8.3125rem);
  line-height: clamp(6.234375rem, 9.2361111111vw, 8.3125rem);
  text-align: center;
  display: block;
  margin-block: calc((1em - 1lh) / 2);
  position: relative;
  min-width: 1ch;
}
.sec__data .grid__box li.li__runk .list__detail p .no em::before {
  content: "";
  display: block;
  width: clamp(0.9375rem, 1.3888888889vw, 1.25rem);
  aspect-ratio: 1;
  background: url(/recruit/assets/images/data/data_shine01.svg) center center/contain no-repeat;
  position: absolute;
  right: -35%;
  top: 25%;
}
.sec__data .grid__box li.li__runk .list__detail p .no em::after {
  content: "";
  display: block;
  width: clamp(2.390625rem, 3.5416666667vw, 3.1875rem);
  aspect-ratio: 51/65;
  background: url(/recruit/assets/images/data/data_shine02.svg) center center/contain no-repeat;
  position: absolute;
  left: -60%;
  bottom: 10%;
}
.sec__data .grid__box li.li__calendar .list__detail {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-block: 40px;
  gap: 30px;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__calendar .list__detail {
    padding-block: 10px;
  }
}
.sec__data .grid__box li.li__calendar .list__detail p {
  font-size: clamp(2.8125rem, 4.1666666667vw, 3.75rem);
  line-height: clamp(6.375rem, 9.4444444444vw, 8.5rem);
  display: flex;
  align-items: end;
}
.sec__data .grid__box li.li__calendar .list__detail p .no {
  line-height: 1;
  gap: 20px;
  white-space: nowrap;
}
.sec__data .grid__box li.li__calendar .list__detail p .no em {
  font-size: clamp(6.375rem, 9.4444444444vw, 8.5rem);
  line-height: 1cap;
  min-width: 3ch;
  text-align: right;
  display: inline-block;
}
@media only screen and (max-width: 767px) {
  .sec__data .grid__box li.li__calendar .list__detail p .no em {
    font-size: clamp(4.21875rem, 6.25vw, 5.625rem);
  }
}
.sec__data .grid__box li.li__calendar .list__detail img {
  width: 100%;
  max-width: 70px;
  height: auto;
  margin-top: 10px;
}

@keyframes float-bobbing {
  0%, 100% {
    transform: translateY(-50%);
  }
  50% {
    transform: translateY(-80%);
  }
}