[data-lazy-background] {
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important; }

.performance-wrap article {
  margin-top: 3rem;
  text-align: justify;
  text-justify: distribute; }

.performance-block {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin: 3rem auto;
  width: calc(50% + 1200px/2);
  margin-right: 0; }
  .performance-block.reverse {
    flex-direction: row-reverse;
    margin-right: auto;
    margin-left: 0; }
  .performance-block .performance-info {
    width: 50%; }
  .performance-block .performance-img {
    width: 45%;
    padding-top: calc(72% * 0.45); }

.performance-core {
  margin: 5rem auto; }

.performance-core-wrap {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  margin: 3rem 0; }

.performance-core-block {
  position: relative;
  width: 32%;
  padding-top: calc(67% * 0.32);
  color: #FFF;
  font-size: 1.25rem;
  line-height: 2rem;
  font-weight: bold;
  text-align: center; }
  .performance-core-block::after {
    position: absolute;
    display: block;
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5); }
  .performance-core-block > div {
    z-index: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }
    .performance-core-block > div img {
      display: block;
      width: 4rem;
      margin: auto;
      margin-bottom: 0.5rem; }

.performance-swiper-wrap {
  position: relative;
  margin: 5rem auto; }
  .performance-swiper-wrap .swiper-button-prev,
  .performance-swiper-wrap .swiper-button-next {
    width: 0.75rem; }
  .performance-swiper-wrap .swiper-button-prev {
    top: 4rem;
    left: 0;
    transform: none; }
  .performance-swiper-wrap .swiper-button-next {
    top: 4rem;
    right: 0;
    transform: none; }
  .performance-swiper-wrap .swiper-container {
    width: 90%;
    margin: auto; }
  .performance-swiper-wrap .swiper-slide {
    color: #cf152d;
    text-align: center; }
    .performance-swiper-wrap .swiper-slide h3 {
      font-size: 1rem;
      line-height: 1.75rem; }
      .body-en .performance-swiper-wrap .swiper-slide h3, .performance-swiper-wrap .swiper-slide h3.body-en {
        font-size: 1.1rem;
        line-height: 1.85rem; }
      @media only screen and (max-width: 640px) {
        .body-en .performance-swiper-wrap .swiper-slide h3, .performance-swiper-wrap .swiper-slide h3.body-en {
          font-size: 1rem;
          line-height: 1.75rem; } }
    .performance-swiper-wrap .swiper-slide p {
      font-size: 1.5rem;
      line-height: 2.5rem; }
    .performance-swiper-wrap .swiper-slide:first-child .dot::after {
      left: 0;
      width: 10rem;
      transform: none; }
    .performance-swiper-wrap .swiper-slide:last-child .dot::after {
      left: auto;
      right: 0;
      width: 10rem;
      transform: none; }
    .performance-swiper-wrap .swiper-slide .dot {
      position: relative;
      width: 15px;
      height: 15px;
      border-radius: 50%;
      -webkit-border-radius: 50%;
      background: #cf152d;
      margin: 1rem auto; }
      .performance-swiper-wrap .swiper-slide .dot::before {
        z-index: -1;
        position: absolute;
        display: block;
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 150%;
        height: 150%;
        border: 1px solid #cf152d;
        background: #FFF;
        border-radius: 50%;
        -webkit-border-radius: 50%; }
      .performance-swiper-wrap .swiper-slide .dot::after {
        z-index: -1;
        position: absolute;
        display: block;
        content: "";
        width: 18rem;
        height: 1px;
        top: 50%;
        left: 50%;
        background: #cf152d;
        transform: translateX(-50%); }

@media only screen and (max-width: 1440px) {
  .performance-block {
    width: calc(50% + 1024px/2); } }
@media only screen and (max-width: 1024px) {
  .performance-wrap article {
    margin: 3rem 0; }

  .performance-block {
    display: block;
    width: 100%; }
    .performance-block .performance-info {
      width: 1200px;
      margin: auto; } }
    @media only screen and (max-width: 1024px) and (max-width: 1440px) {
      .performance-block .performance-info {
        width: 1024px; } }
    @media only screen and (max-width: 1024px) and (max-width: 1024px) {
      .performance-block .performance-info {
        width: calc(100% - 3rem); } }
@media only screen and (max-width: 1024px) {
    .performance-block .performance-img {
      width: 100%;
      padding-top: 72%; }

  .performance-swiper-wrap {
    margin: 3rem 0; }
    .performance-swiper-wrap .swiper-container {
      width: 90%; }
    .performance-swiper-wrap .swiper-wrapper {
      display: block; }
    .performance-swiper-wrap .swiper-slide {
      position: relative;
      width: 100%;
      text-align: left;
      padding: 1.5rem 0; }
      .performance-swiper-wrap .swiper-slide h3, .performance-swiper-wrap .swiper-slide p {
        margin-left: 3rem; }
      .performance-swiper-wrap .swiper-slide:last-child .line {
        display: none; }
      .performance-swiper-wrap .swiper-slide .dot {
        position: absolute;
        width: 13px;
        height: 13px;
        margin: 0;
        top: 3.5rem;
        left: 1rem; }
        .performance-swiper-wrap .swiper-slide .dot::before {
          z-index: -1;
          position: absolute;
          display: block;
          content: "";
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%);
          width: 150%;
          height: 150%;
          border: 1px solid #cf152d;
          background: #FFF;
          border-radius: 50%;
          -webkit-border-radius: 50%; }
        .performance-swiper-wrap .swiper-slide .dot::after {
          display: none; }
      .performance-swiper-wrap .swiper-slide .line {
        position: absolute;
        width: 1px;
        height: 100%;
        top: calc(3.5rem + 6px);
        left: calc(1rem + 6px);
        background: #cf152d; } }
@media only screen and (max-width: 640px) {
  .performance-core {
    margin: 5rem auto; }

  .performance-core-wrap {
    display: block; }

  .performance-core-block {
    width: 100%;
    padding-top: 67%;
    margin: 1rem 0; }
    .performance-core-block > div img {
      width: 5rem; } }

/*# sourceMappingURL=performance.css.map */
