.moreButton {
  color: #ffffff;
  background: linear-gradient(128deg, #209CC6 0%, #7DC3C8 70%, #F1D3D2 100%);
  border-radius: 70px;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  font-weight: bold;
}
.moreButton:hover {
  text-decoration: none;
}

@media only screen and (max-width: 767px) {
  .moreButton {
    font-size: clamp(14px, 4.1vw, 16px);
    width: min(43.6vw, 170px);
    padding: min(3.85vw, 15px) 0;
  }
}
@media print, screen and (min-width: 768px) {
  .moreButton {
    font-size: clamp(14px, 1.39vw, 20px);
    width: min(11.5vw, 220px);
    padding: min(1vw, 20px) 0;
  }
}
@media screen and (min-width: 768px) {
  @keyframes fadeIn {
    0% {
      opacity: 0;
      filter: blur(10px);
    }
    50% {
      opacity: 0;
      filter: blur(10px);
    }
    100% {
      opacity: 1;
      filter: blur(0px);
    }
  }
}
@media screen and (max-width: 767px) {
  @keyframes fadeIn {
    0% {
      opacity: 0;
    }
    50% {
      opacity: 0;
    }
    100% {
      opacity: 1;
    }
  }
}
.op_animation img {
  filter: blur(0px);
  animation-duration: 1s;
  animation-name: fadeIn;
}

.secService {
  background: #EFEFEF;
}
.secService .secServiceIn .serviceCaption {
  font-weight: bold;
  line-height: 180%;
}
.secService .secServiceIn .serviceListArea .serviceList .serviceImg {
  position: relative;
  transition: 0.5s;
}
.secService .secServiceIn .serviceListArea .serviceList .serviceImg .imgPhoto {
  opacity: 0;
  filter: blur(10px);
  transition: 0.5s;
}
.secService .secServiceIn .serviceListArea .serviceList .serviceImg .serviceImgText {
  position: absolute;
  left: 0;
  top: 0;
  mix-blend-mode: difference;
  opacity: 0;
  filter: blur(10px);
  transition: 0.5s;
}
.secService .secServiceIn .serviceListArea .serviceList .serviceImg.animated .imgPhoto {
  filter: blur(0px);
  opacity: 1;
}
.secService .secServiceIn .serviceListArea .serviceList .serviceImg.animated .serviceImgText {
  filter: blur(0px);
  opacity: 1;
}
.secService .secServiceIn .serviceListArea .serviceList .listCaption {
  line-height: 227%;
  letter-spacing: 0.03em;
}
.secService .secServiceIn .serviceListArea .serviceList .tagBox {
  border-bottom: solid 1px #000000;
}
.secService .secServiceIn .serviceListArea .serviceList .tagBox.first {
  border-top: solid 1px #000000;
}
.secService .secServiceIn .serviceListArea .serviceList .tagBox .tagText {
  color: #9B9B9B;
  line-height: 190%;
}

@media only screen and (max-width: 767px) {
  .secService {
    padding-top: 60px;
  }
  .secService .secServiceIn .serviceTitle {
    font-size: clamp(24px, 10.25vw, 40px);
    padding-bottom: 10px;
  }
  .secService .secServiceIn .serviceCaption {
    font-size: clamp(14px, 4.1vw, 16px);
    padding-left: 1.5em;
    text-indent: -1.5em;
    padding-bottom: 40px;
    margin-left: 10px;
  }
  .secService .secServiceIn .serviceListArea .serviceList {
    padding-bottom: 80px;
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg {
    max-width: 270px;
    margin: 0 auto;
    padding-bottom: 35px;
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg .serviceImgText {
    left: max(-8.72vw, -34px);
    top: 60%;
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg .serviceImgText.img01 {
    width: 62.2%;
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg .serviceImgText.img02 {
    width: 96.3%;
  }
  .secService .secServiceIn .serviceListArea .serviceList .listCaption {
    font-size: clamp(14px, 4.1vw, 16px);
    padding-bottom: 30px;
  }
  .secService .secServiceIn .serviceListArea .serviceList .tagBox {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  .secService .secServiceIn .serviceListArea .serviceList .tagBox .tagTitle {
    font-size: clamp(14px, 4.61vw, 18px);
    padding: 0 0 5px 0;
  }
  .secService .secServiceIn .serviceListArea .serviceList .tagBox .tagText {
    font-size: 13px;
  }
}
@media print, screen and (min-width: 768px) {
  .secService {
    padding-top: min(7.3vw, 140px);
  }
  .secService .secServiceIn .serviceTitle {
    font-size: clamp(48px, 5.55vw, 80px);
    padding-bottom: min(2.6vw, 50px);
    width: min(90vw, 1500px);
    margin: 0 auto;
  }
  .secService .secServiceIn .serviceCaption {
    font-size: clamp(15px, 1.67vw, 24px);
    padding-left: 1.5em;
    text-indent: -1.5em;
    padding-bottom: min(4.7vw, 90px);
  }
  .secService .secServiceIn .serviceListArea {
    display: flex;
    justify-content: space-between;
  }
  .secService .secServiceIn .serviceListArea .serviceList {
    width: 45%;
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg {
    padding-bottom: min(2.86vw, 55px);
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg .serviceImgText {
    left: max(-3.38vw, -65px);
    top: 60%;
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg .serviceImgText.img01 {
    width: 62.2%;
  }
  .secService .secServiceIn .serviceListArea .serviceList .serviceImg .serviceImgText.img02 {
    width: 96.3%;
  }
  .secService .secServiceIn .serviceListArea .serviceList .listCaption {
    font-size: clamp(14px, 1.25vw, 18px);
    padding-bottom: min(2.6vw, 50px);
  }
  .secService .secServiceIn .serviceListArea .serviceList .tagBox {
    padding-top: min(1.3vw, 25px);
    padding-bottom: min(1.04vw, 20px);
  }
  .secService .secServiceIn .serviceListArea .serviceList .tagBox .tagTitle {
    font-size: clamp(14px, 1.53vw, 22px);
    padding: 0 0 8px 0;
  }
  .secService .secServiceIn .serviceListArea .serviceList .tagBox .tagText {
    font-size: clamp(14px, 1.11vw, 16px);
  }
}
.secWorks {
  background: #EFEFEF;
}
.secWorks .secWorksIn .titleArea .titleJp {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.secWorks .secWorksIn .titleArea .titleJp .titleJpIn {
  font-weight: bold;
  flex-grow: 1;
}
.secWorks .secWorksIn .moreButtonArea {
  text-align: center;
}

@media only screen and (max-width: 767px) {
  .secWorks {
    padding-top: 20px;
    padding-bottom: 80px;
  }
  .secWorks .secWorksIn .titleArea .titleEn {
    font-size: clamp(24px, 10.25vw, 40px);
    padding-bottom: 20px;
  }
  .secWorks .secWorksIn .titleArea .titleJp {
    padding-bottom: 50px;
    padding-left: min(7.7vw, 30px);
  }
  .secWorks .secWorksIn .titleArea .titleJp .titleJpIn {
    padding-left: 8px;
    font-size: clamp(14px, 4.1vw, 16px);
  }
  .secWorks .secWorksIn .moreButtonArea {
    padding-top: 20px;
  }
}
@media print, screen and (min-width: 768px) {
  .secWorks {
    padding-top: min(5.46vw, 105px);
    padding-bottom: min(5.46vw, 105px);
  }
  .secWorks .secWorksIn .titleArea {
    width: min(90vw, 1500px);
    margin: 0 auto;
  }
  .secWorks .secWorksIn .titleArea .titleEn {
    font-size: clamp(48px, 5.55vw, 80px);
    padding-bottom: min(2.6vw, 50px);
  }
  .secWorks .secWorksIn .titleArea .titleJp {
    padding-bottom: min(6.25vw, 120px);
  }
  .secWorks .secWorksIn .titleArea .titleJp .titleJpIn {
    padding-left: 20px;
    font-size: clamp(15px, 1.67vw, 24px);
  }
  .secWorks .secWorksIn .moreButtonArea {
    padding-top: 20px;
  }
}
.secNews {
  background: #ffffff;
}
.secNews .secNewsIn .titleArea .titleJp {
  font-weight: bold;
}
.secNews .secNewsIn .newsListArea .newsList {
  border-bottom: solid 1px #000000;
}
.secNews .secNewsIn .newsListArea .newsList:first-of-type {
  border-top: solid 1px #000000;
}
.secNews .secNewsIn .newsListArea .newsList .newsDate {
  color: #209CC6;
}
.secNews .secNewsIn .newsListArea .newsList .newsTitle a {
  text-decoration: none;
  color: #000000;
}
@media only screen and (max-width: 767px) {
  .secNews {
    padding-top: 70px;
  }
  .secNews .secNewsIn .titleArea .titleEn {
    font-size: clamp(24px, 10.25vw, 40px);
    padding-bottom: 20px;
  }
  .secNews .secNewsIn .titleArea .titleJp {
    font-size: clamp(14px, 4.1vw, 16px);
    padding-left: 30px;
  }
  .secNews .secNewsIn .newsListArea {
    padding-top: 40px;
  }
  .secNews .secNewsIn .newsListArea .newsList {
    padding: 20px 0;
  }
  .secNews .secNewsIn .newsListArea .newsList .newsDate {
    font-size: clamp(14px, 4.1vw, 16px);
    padding-bottom: 15px;
  }
  .secNews .secNewsIn .newsListArea .newsList .newsTitle {
    font-size: clamp(14px, 4.61vw, 18px);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }
  .secNews .secNewsIn .newsListArea .moreButtonArea {
    text-align: center;
    padding: 40px 0 0 0;
  }
}
@media print, screen and (min-width: 768px) {
  .secNews {
    padding-top: min(8.33vw, 160px);
  }
  .secNews .secNewsIn {
    display: flex;
    justify-content: space-between;
    width: min(90vw, 1500px);
    margin: 0 auto;
  }
  .secNews .secNewsIn .titleArea .titleEn {
    font-size: clamp(48px, 5.55vw, 80px);
    padding-bottom: min(2.6vw, 50px);
  }
  .secNews .secNewsIn .titleArea .titleJp {
    font-size: clamp(15px, 1.67vw, 24px);
    padding-left: min(7.3vw, 140px);
  }
  .secNews .secNewsIn .newsListArea {
    width: 73.7%;
    padding-top: 18px;
  }
  .secNews .secNewsIn .newsListArea .newsList {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 45px 0;
  }
  .secNews .secNewsIn .newsListArea .newsList .newsDate {
    min-width: 120px;
    max-width: 120px;
    font-size: clamp(14px, 1.11vw, 16px);
  }
  .secNews .secNewsIn .newsListArea .newsList .newsTitle {
    flex-grow: 1;
    font-size: clamp(14px, 1.39vw, 20px);
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
  }
  .secNews .secNewsIn .newsListArea .moreButtonArea {
    text-align: right;
    padding: 60px 0 0 0;
  }
}/*# sourceMappingURL=style.css.map */