/*============================
Home - Base
============================*/
main section {
  margin-bottom: -150px;
  position: relative;
}
main, footer {
  overflow: hidden;
}

/*============================
Home - Subnavi
============================*/
.subNavi.hide {
  display: none;
}

/*============================
Home - SidePos
============================*/
#sidePos {
  z-index: 10 !important;
}

/*============================
Home - ctsHero
============================*/
#ctsHero {
  max-width: 1920px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: -150px;
  overflow: hidden;
  position: relative;
}
#ctsHero .background {
  background-image: url(/img/bg_hero01.jpg?20200601);
  background-position: 50% 0;
  background-repeat: no-repeat;
}
#ctsHero .background.bg1 {
  background-image: url(/img/bg_hero03.jpg?2);
}
#ctsHero .background.bg2 {
  background-image: url(/img/bg_hero04.jpg?2);
}
#ctsHero .background.bg3 {
  background-image: url(/img/bg_hero05.jpg?2);
}
#ctsHero .background.bg4 {
  background-image: url(/img/bg_hero06.jpg?2);
}
#ctsHero .cover {
  background: #1690e0;
  display: none;
  z-index: 2;
}
section#ctsHero {
  z-index: 9;
}
#ctsHero .ctsInner {
  padding-top: 14.7%;
  width: 80%;
  max-width: 1820px;
}
#ctsHero .topUnit {
  display: none;
}
#ctsHero .topUnit__link {
  color: #fff;
  display: block;
}
#ctsHero .topUnit__link:hover {
  opacity: 1;
}
#ctsHero .topUnit__link:hover .lead, #ctsHero .topUnit__link:hover h2, #ctsHero .topUnit__link:hover .copy {
  opacity: 0.7;
}
#ctsHero .topUnit__link:hover .leadLink {
  background: #2356a7;
  color: #fff;
  border-color: #2356a7;
}
#ctsHero .topUnit__link--nocopy h2 {
  margin-top: 0.2em;
  margin-bottom: 0.52em;
}
#ctsHero .topUnit:first-child {
  display: block;
}
#ctsHero h2 {
  padding-top: 0;
  font-size: 73px;
  display: block;
}
#ctsHero h2.small {
  padding-top: 2%;
  padding-bottom: 2%;
  font-size: 50px;
  line-height: 1.3;
}
#ctsHero h2.large {
  padding-top: 0;
  font-size: 80px;
}
#ctsHero h2 > span {
  margin-top: -15px;
  margin-bottom: 20px;
  font-size: 20px;
  display: block;
}
#ctsHero .textArea {
  background: url(/img/bg_title_circle.png) 100% 18% no-repeat;
  background-size: contain;
  margin-left: -59.8%;
  margin-bottom: -45vw;
  padding: 0 0 0 60.7%;
  min-width: 1120px;
  width: 134.6%;
  min-height: 950px;
  max-height: 1450px;
  height: 83.6vw;
  color: #fff;
  text-align: left;
}
#ctsHero .lead {
  padding: 11% 0 0;
  font-size: 22px;
  line-height: 1.5909090909;
}
#ctsHero .leadLink {
  width: 230px;
  padding: 7px 20px;
  color: #fff;
  font-size: 1.1em;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: .1em;
  border: 1px #fff solid;
  display: block;
}
#ctsHero .leadLink.link--blank03 {
  position: relative;
}
#ctsHero .leadLink.link--blank03:hover .linkArrow {
  margin-left: 0;
}
#ctsHero .leadLink.link--blank03:after {
  position: absolute;
  top: 32%;
}
#ctsHero .leadLink.link--blank03 .linkArrow {
  margin-left: 0;
  border: none;
}
#ctsHero .leadLink.link--blank03 .linkArrow:after {
  content: none;
}
#ctsHero .copy {
  margin: 0.5em 0 1.3em;
  font-size: 26px;
  line-height: 1.6em;
}
#ctsHero .copy--small {
  font-size: 24px;
}
#ctsHero .linkArrow {
  vertical-align: middle;
}
#ctsHero .topLinks li {
  margin-right: 0.5em;
  margin-bottom: 1em;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.05em;
  display: inline-block;
}
#ctsHero .topLinks li.current {
  border-bottom: #fff 3px solid;
}
#ctsHero .topLinks a {
  padding: 0 0.3em;
  color: #fff;
}
#ctsHero .topLinksWrap {
  margin-top: 2.15em;
}
#ctsHero .topLinksWrap__link {
  width: 190px;
  font-size: 18px;
}
#ctsHero .topLinksWrap__link a {
  padding: 0 0.3em;
  color: #fff;
  font-weight: 700;
}

/*============================
Home - cts
============================*/
.cts {
  color: #fff;
  top: 0px;
  background-size: cover !important;
  position: relative;
  background: #f0f;
  background: center;
  overflow: hidden;
  margin-bottom: -150px;
}
.cts h2 {
  padding-top: 2.5em;
  text-align: center;
  font-size: 2.2em;
}
.cts .ctsUnit {
  display: inline-block;
  vertical-align: top;
  width: 100%;
  position: relative;
}
.cts .ctsUnit.item {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .cts .ctsUnit.item {
    display: block;
  }
  .cts .ctsUnit.item .ctsCircle.item1 {
    width: 28em !important;
    height: 28em !important;
  }
  .cts .ctsUnit.item .ctsCircle.item2 {
    margin-top: 0 !important;
    left: auto;
  }
}
@media screen and (min-width: 769px) {
  .cts .ctsUnit.item .ctsCircle {
    margin: 20px 4% 20px 4% !important;
  }
}
.cts .ctsUnit.item .ctsCircle.item2 {
  opacity: 0.8;
  background: url(/img/bg_ictpicks.png) center no-repeat !important;
}
.cts .ctsUnit.item .ctsCircle .leadLink.link--blank03:hover .linkArrow {
  margin-left: 0;
}
.cts .ctsUnit.item .ctsCircle .leadLink.link--blank03 .linkArrow {
  margin-left: 0;
  border: none;
}
.cts .ctsUnit.item .ctsCircle .leadLink.link--blank03 .linkArrow:after {
  content: none;
}
.cts .ctsUnit.item .ctsCircle .link--blank02:after, .cts .ctsUnit.item .ctsCircle .link--blank03:after {
  position: absolute;
  top: 32%;
}
.cts .ctsCircle {
  background: url(/img/bg_unit01.png) center no-repeat;
  display: inline-block;
  position: relative;
  background-size: cover !important;
  border-radius: 50%;
  width: 58.2em;
  height: 40em;
  text-align: left;
  box-sizing: border-box;
  padding-left: 0;
  margin: 20px 1% 20px 27vw;
  margin-right: 0;
}
.cts .ctsCircle.select {
  display: inline-block !important;
}
.cts .ctsCircle .textArea {
  position: absolute;
  top: 47.5%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: auto;
  min-width: 60%;
  z-index: 1;
  white-space: normal;
}
.cts .ctsCircle h2 {
  font-size: 1.8em;
  line-height: 1.4em;
  margin-bottom: 0.4em;
  white-space: nowrap;
}
.cts .ctsCircle h3 {
  font-size: 1.8em;
  line-height: 1.4em;
  margin-bottom: 0.4em;
  white-space: nowrap;
}
.cts .ctsCircle h3 ruby rt {
  font-weight: normal;
  font-size: 0.4em;
  transform: translateY(0.3em);
}
.cts .ctsCircle h4 {
  font-size: 1.3em;
  font-weight: normal;
  margin: 0.6em 0;
}
.cts .ctsCircle p {
  line-height: 2em;
  margin-top: 1.2em;
  letter-spacing: 0.03em;
  white-space: nowrap;
}
.cts .leadLink {
  color: #fff;
  font-weight: 600;
  letter-spacing: .1em;
  font-size: 1.2em;
  text-indent: 0;
  position: relative;
  display: block;
  margin-top: 1.3em;
  border: 1px #fff solid;
  padding: 10px 20px;
  width: 200px;
}
.cts .leadLink:hover {
  background: #2356a7;
  color: #fff;
  border-color: #2356a7;
  opacity: 1;
}
.cts .leadLink .linkArrow {
  vertical-align: middle;
}
.cts .ctsInner {
  text-align: center;
  width: 100%;
  max-width: 1820px;
}
.cts .scroll {
  white-space: nowrap;
  position: relative;
}
.cts.select .scroll {
  margin-left: 0 !important;
}
.cts .ctsCircle nav {
  position: absolute;
  bottom: -3.5em;
}
.cts .ctsCircle nav span {
  display: inline-block;
  width: 51px;
  height: 2px;
  margin: 0 2px;
  background: #fff;
  opacity: 0.5;
  position: relative;
}
.cts .ctsCircle nav span.current {
  opacity: 1;
  height: 3px;
}
.cts .ctsCircle nav span:hover {
  opacity: 1;
}
.cts .ctsCircle nav span.all {
  margin-left: 21px;
  height: 7px;
  background: url(/img/icon_ctsnav_all.png) no-repeat;
}
.cts .ctsCircle nav span.all:hover {
  opacity: 1;
}
.cts.select .ctsUnit {
  width: 18em;
}
.cts.select .ctsUnit:nth-child(2n-1) {
  margin-top: 18em;
}
.cts.select .ctsCircle {
  display: inline-block;
  float: none !important;
  cursor: pointer;
  background: #1da5dd;
  width: 19em;
  height: 19em;
  width: 21em !important;
  height: 21em;
  padding-left: 3em;
  margin-right: 0.9em;
  vertical-align: top;
  white-space: normal;
  margin-left: 0%;
}
.cts.select .ctsInner {
  text-align: center !important;
}
.cts.select .ctsCircle h3 {
  font-size: 1.2em;
}
.cts.select .ctsCircle h4, .cts.select .ctsCircle p, .cts.select .ctsCircle a, .cts.select .ctsCircle nav {
  display: none;
}
.cts.select .ctsCircle .textArea {
  padding-bottom: 0;
}
.cts.select .scroll {
  transform: translateX(0) !important;
  width: auto !important;
  margin-top: 5%;
}
#ctsCollaboration.current .ctsCircle, #ctsServices li .fig, #ctsInfomation li .fig, #ctsPartner.current .ctsCircle, .current .ctsCircle .bg {
  animation-name: ctsCircle-anm;
  animation-duration: 8s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

#ctsServices li:nth-child(2n) .fig, #ctsInfomation li:nth-child(2n) .fig {
  animation-name: ctsCircle-anm-rev;
}
.cts.current .ctsCircle:nth-child(2n) {
  animation-duration: 5s;
}
.cts nav.pageButton {
  position: absolute;
  top: 50%;
  margin-top: 75px;
  width: 100%;
  z-index: 2;
  transition: opacity 0.5s;
}
.cts.select nav.pageButton {
  opacity: 0;
}
.cts nav .prev, .cts nav .next {
  border-top: #fff 1px solid;
  display: inline-block;
  width: 90px;
  height: 0;
  margin: 0 80px 0 0;
  transition: all 0.2s;
  left: 2.6%;
  position: absolute;
}
.cts .ctsCircle nav span::before, .cts nav .prev::before, .cts nav .next::before {
  content: "";
  height: 40px;
  width: 100%;
  margin-top: -20px;
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  opacity: 0.2;
  cursor: pointer;
}
.cts nav .prev::after, .cts nav .next::after {
  border: #fff 1px solid;
  content: "";
  width: 35px;
  height: 35px;
  display: block;
  transform-origin: -1px 0;
  transform: rotate(-45deg);
  border-right: 0;
  border-bottom: 0;
  pointer-events: none;
}
.cts nav .next {
  transform: scaleX(-1);
  transform-origin: 100% 0;
  left: auto;
  right: 2.6%;
}
#ctsHero, .cts.end {
  animation-duration: 12s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  overflow: hidden;
}

/*============================
Home - ctsCollaboration
============================*/
#ctsCollaboration {
  z-index: 6;
  min-height: 70em;
  max-width: 1920px;
  margin-right: auto;
  margin-left: auto;
}
#ctsCollaboration .background {
  background-image: url(/img/bg_collaboration06.jpg?20191120);
  background-repeat: no-repeat;
  display: inline-block;
}
#ctsCollaboration .background.bg2 {
  background-image: url(/img/bg_collaboration08.jpg?20200622);
  background-position: 50% 50%;
}
#ctsCollaboration .background.bg3 {
  background-image: url(/img/bg_collaboration07.jpg?20191120);
  background-position: 50% 50%;
}
#ctsCollaboration .background.bg4 {
  background-image: url(/img/bg_collaboration02.jpg?20191120);
}
#ctsCollaboration .background.bg5 {
  background-image: url(/img/bg_collaboration03.jpg?20191120);
}
#ctsCollaboration .cover {
  background: #1690e0;
  z-index: 1;
  display: none;
}
#ctsCollaboration .ctsInner {
  text-align: center;
}
#ctsCollaboration .ctsCircle {
  display: inline-block;
  width: 43.2em;
  vertical-align: top;
}
#ctsCollaboration.select .blurBG {
  opacity: 1;
}
#ctsCollaboration .ctsCircle .textArea {
  padding-bottom: 0%;
  margin-left: 2em;
}
#ctsCollaboration .scroll {
  position: relative;
  height: 100%;
  display: block;
  pointer-events: all;
}
#ctsCollaboration .pageButton .next, #ctsCollaboration .pageButton .prev {
  opacity: 1 !important;
}

/*============================
Home - ctsPartner
============================*/
#ctsPartner {
  z-index: 4;
  max-width: 1920px;
  margin-right: auto;
  margin-left: auto;
}
#ctsPartner .background {
  background: url(/img/bg_partner.jpg) 50% 0 no-repeat;
}
#ctsPartner .ctsCircle {
  background: url(/img/bg_unit02.png) center no-repeat;
  margin-top: 5%;
  margin-bottom: 0%;
  margin-left: -35%;
  margin-left: calc(200px - 65%);
  padding-left: 6.2em;
  width: 35em;
  height: 35em;
}
#ctsPartner h2 {
  text-align: left;
}

/*============================
Home - banner
============================*/
.bannerArea01 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-flow: nowrap;
  margin-top: 65px;
}
.bannerArea01 a {
  display: block;
}
.bannerArea01 a:hover {
  opacity: 0.95;
  transition: all 0.2s;
}
.bannerArea01 a:nth-of-type(1) {
  order: 2;
}
.bannerArea01 a:nth-of-type(2) {
  order: 1;
}
.bannerArea01 a img {
  max-width: 435px;
}

@media screen and (max-width: 768px) {
  .bannerArea01 {
    display: block;
    margin-top: 20%;
  }
  .bannerArea01 a:nth-of-type(2) {
    margin-top: 6%;
  }
  .bannerArea01 a img {
    max-width: 100%;
  }
}
/*============================
Home - ctsPointsofview
============================*/
#ctsPointsofview {
  z-index: 7;
  max-width: 1920px;
  margin-right: auto;
  margin-left: auto;
}
#ctsPointsofview p.lead {
  margin: 1.5em 0 2.5em;
}
#ctsPointsofview .background {
  background: url(/img/bg_pov.jpg?2) center top no-repeat;
}
#ctsPointsofview .ctsInner {
  text-align: center;
}
#ctsPointsofview .ctsUnit {
  margin-left: 0;
  width: 140vw;
}
#ctsPointsofview .ctsCircle {
  background: none;
  margin-left: -24%;
  margin-top: 3%;
  margin-bottom: 4em;
  padding-left: 4.2em;
  width: 33.4em;
  height: 32.4em;
}
#ctsPointsofview .textArea {
  z-index: 2;
}
#ctsPointsofview .bg {
  background: url(/img/bg_unit04.png) center no-repeat;
  background-size: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 50%;
  z-index: 1;
}
#ctsPointsofview .img {
  width: 37.6em;
  height: 36.7em;
  position: absolute;
  left: 84%;
  top: -8%;
  border-radius: 50%;
  overflow: hidden;
  transition-delay: 5s;
  transition: .5s;
}
#ctsPointsofview div[aria-hidden="false"] .img {
  opacity: 1;
}
#ctsPointsofview .img img {
  width: 100%;
  height: auto;
  position: absolute;
  left: 0;
  top: 0;
}
#ctsPointsofview .ctsNavi {
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  z-index: 1;
}
#ctsPointsofview .ctsNavi li {
  margin: 0 1.2em;
  padding: 0 .2em;
  font-weight: 600;
  letter-spacing: .05em;
  display: inline-block;
  cursor: pointer;
  transition: opacity .2s;
}
#ctsPointsofview .ctsNavi li:hover {
  opacity: 0.7;
}
#ctsPointsofview .ctsNavi li:hover, #ctsPointsofview .ctsNavi li.current {
  padding-bottom: 0.2em;
  border-bottom: #fff 1px solid;
}
#ctsPointsofview .pageButton .next, #ctsPointsofview .pageButton .prev {
  opacity: 1 !important;
}

/*============================
Home - ctsNews
============================*/
#ctsNews {
  z-index: 8;
  max-width: 1920px;
  margin-right: auto;
  margin-left: auto;
}
#ctsNews .bottomCurve {
  background: #fff;
}
#ctsNews h2 {
  font-size: 2.2em;
  color: #2356a7;
  position: relative;
  z-index: 1;
  margin: 1.55em 0 1.8em;
}
#ctsNews .release {
  width: 100%;
  text-align: left;
  margin: 3em 0 2em;
  letter-spacing: 0.11em;
}
#ctsNews dd {
  margin-bottom: 1.6em;
  border-bottom: #2356a7 1px solid;
  padding-bottom: 1em;
}
#ctsNews dd a {
  color: #000;
}
#ctsNews .list {
  color: #000;
  font-size: 1.2em;
  font-weight: 600;
}
#ctsNews .linkArrow, #ctsServices .linkArrow {
  border-bottom: #000 1px solid;
}
#ctsNews .linkArrow::after, #ctsServices .linkArrow::after {
  border-bottom: #000 1px solid;
}
#ctsNews a:hover .linkArrow, #ctsServices a:hover .linkArrow {
  margin: 0 -.15em 0 .75em;
}
#ctsNews .important .linkArrow {
  border-bottom: #f00 1px solid;
  width: 1.1em;
}
#ctsNews .important .linkArrow::after {
  border-bottom: #f00 1px solid;
  width: 0.5em;
}
#ctsNews .important {
  border: #f00 1px solid;
  color: #f00;
  text-align: left;
  padding: 1.5em 2.7em 1.3em;
  width: 500px;
  margin: 4.3em auto 3.8em;
}
#ctsNews .important h3 {
  text-align: center;
  font-size: 1.3em;
  margin-bottom: 0.9em;
  letter-spacing: 0;
}
#ctsNews .important h3::before {
  content: "";
  background: url(/img/icon_important.png) no-repeat;
  background-size: contain;
  margin: 0 10px 3px 0px;
  width: 24px;
  height: 24px;
  vertical-align: middle;
  display: inline-block;
}
#ctsNews .important a {
  margin-bottom: 0.6em;
  color: #f00;
  display: block;
}
#ctsNews .important__lead {
  color: #000;
}
#ctsNews .important__lead + p {
  margin-top: 20px;
}
#ctsNews .important--full {
  width: 100%;
}
#ctsNews .ctsInner {
  margin-bottom: 8em;
  padding-bottom: 0;
}
#ctsNews .boxBtn03--auto {
  margin-top: 45px;
}
#ctsNews .boxBtn03--auto > a {
  padding: 0.57em calc(35px + 0.57em) 0.57em 0.57em;
  width: 100%;
}
#ctsNews .boxBtn03--auto > a:hover {
  opacity: 1;
}

/*============================
Home - ctsImportant
============================*/
#ctsImportant {
  z-index: 8;
  max-width: 1920px;
  margin-right: auto;
  margin-left: auto;
}
#ctsImportant .bottomCurve {
  background: #fff;
}
#ctsImportant h2 {
  margin: 3.55em 0 1.8em;
  font-size: 2.2em;
  color: #2356a7;
  position: relative;
  z-index: 1;
}
#ctsImportant .release {
  margin: 3em 0 2em;
  width: 100%;
  text-align: left;
  letter-spacing: 0.11em;
}
#ctsImportant .important .linkArrow {
  width: 1.1em;
  border-bottom: #f00 1px solid;
}
#ctsImportant .important .linkArrow::after {
  width: 0.5em;
  border-bottom: #f00 1px solid;
}
#ctsImportant .important {
  margin: 6.5em auto 3.8em;
  padding: 1.5em 2.5em 1.3em;
  width: 500px;
  color: #f00;
  text-align: left;
  border: #f00 1px solid;
}
#ctsImportant .important h2, #ctsImportant .important h3 {
  margin: 0 0 0.9em 0;
  font-size: 1.3em;
  color: #f00;
  text-align: center;
  letter-spacing: 0;
}
#ctsImportant .important h2::before, #ctsImportant .important h3::before {
  content: "";
  background: url(/img/icon_important.png) no-repeat;
  background-size: contain;
  margin: 0 10px 3px 0px;
  width: 24px;
  height: 24px;
  vertical-align: middle;
  display: inline-block;
}
#ctsImportant .important a {
  margin-bottom: 0.6em;
  color: #f00;
  display: block;
}
#ctsImportant .ctsInner {
  margin-bottom: 12em;
  padding-bottom: 0;
}

/*============================
Home - ctsServices
============================*/
#ctsServices {
  color: #fff;
  max-width: 1920px;
  margin-right: auto;
  margin-left: auto;
  z-index: 5;
}
#ctsServices .background {
  background: url(/img/bg_service.jpg) center top no-repeat;
}
#ctsServices h2 {
  margin: 3.55em 0 1.8em;
  font-size: 2.2em;
}
#ctsServices .carousel {
  position: relative;
}
#ctsServices ul {
  margin-left: -5%;
  padding-bottom: 0.3em;
}
#ctsServices li {
  margin: 0 16px;
  margin-bottom: 5.7em;
  width: 30%;
  text-align: left;
  vertical-align: top;
  text-align: center;
  display: inline-block;
}
#ctsServices li .fig {
  overflow: hidden;
  display: inline-block;
}
#ctsServices li:nth-child(2n) {
  margin-right: 0;
}
#ctsServices li h3 {
  margin-bottom: 1.9em;
  height: 2.1em;
  position: relative;
}
#ctsServices li h3 img {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
#ctsServices li h4 {
  margin: 10px auto 4px;
  width: 83.7%;
  font-size: 1.15em;
  letter-spacing: 0.04em;
  text-align: left;
}
#ctsServices li a {
  color: #fff !important;
}
#ctsServices p {
  margin: 0 auto;
  width: 83.7%;
  text-align: left;
  letter-spacing: 0.04em;
}
#ctsServices li a {
  color: #000;
  line-height: 2em;
}
#ctsServices .list {
  font-size: 1.2em;
  color: #000;
  font-weight: 600;
  display: block;
}

@media screen and (max-width: 1100px) {
  #ctsPointsofview .img {
    opacity: 0;
  }
}
@media screen and (min-width: 1920px) {
  #ctsHero {
    height: 900px;
  }
}
/* ==========================================
 Home - sp
========================================== */
@media screen and (max-width: 768px) {
  html {
    min-width: 100%;
    overflow-x: hidden;
  }

  body {
    min-width: 100%;
    font-size: 3.653vw;
    overflow-x: hidden;
  }

  html.subopen {
    position: absolute;
    overflow: hidden;
  }

  main section {
    position: relative;
    margin-bottom: 0px;
  }

  #ctsHero {
    margin-bottom: -24%;
    background-size: 277%;
    background-position: 77.6% 99%;
  }

  #ctsHero .background {
    background: url(/img/bg_hero01_sp.jpg?20200601) center top no-repeat;
  }

  #ctsHero .background.bg1 {
    background: url(/img/bg_hero03_sp.jpg?2) center top no-repeat;
  }

  #ctsHero .background.bg2 {
    background: url(/img/bg_hero04_sp.jpg?2) center top no-repeat;
  }

  #ctsHero .background.bg3 {
    background: url(/img/bg_hero05_sp.jpg?2) center top no-repeat;
  }

  #ctsHero .background.bg4 {
    background: url(/img/bg_hero06_sp.jpg?2) center top no-repeat;
  }

  #ctsHero .ctsInner {
    padding-top: 27.5%;
    width: 100%;
    max-width: 1820px;
    padding-bottom: 0;
  }

  #ctsHero .topUnit__link--nocopy h2 {
    margin-top: 0;
    margin-bottom: 0.35em;
  }

  #ctsHero h2 {
    font-size: 2.7em;
    padding: 0.3em 0 0 0;
  }

  #ctsHero h2.large {
    font-size: 3.5em;
    padding-top: 0;
    margin-top: -0.3em;
  }

  #ctsHero h2.small {
    font-size: 2.1em;
    padding-top: 0.5em;
  }

  #ctsHero h2 span {
    font-size: 0.4em;
    margin: -0.6em 0 1.4em;
  }

  #ctsHero .textArea {
    padding: 21.7% 0 20em 15.3em;
    width: 111.3em;
    width: 136vw;
    max-width: unset;
    min-width: 0;
    margin-left: -12.5em;
    height: 121vw;
    max-height: unset;
    margin-bottom: 24%;
    min-height: 0;
  }

  #ctsHero .lead {
    font-size: 1em;
    line-height: 1.6em;
    margin: 0em 0 -0.8em 0.2em;
    padding-top: 0;
  }

  #ctsHero .copy {
    font-size: 1em;
    line-height: 1.6em;
    margin: 0.5em 0 1em 0.2em;
  }

  #ctsHero .leadLink {
    letter-spacing: .1em;
    font-size: 14px;
    width: 160px;
    display: inline-block;
    border: 2px #fff solid;
    padding: 0.5em 1em;
    margin: 0;
  }

  #ctsHero .topLinksWrap__link {
    font-size: 12px;
  }

  #ctsHero .topLinks {
    margin-right: 0;
    margin-bottom: 1.25em;
  }

  #ctsHero .topLinks li {
    font-size: 12px;
    margin-right: 0.8em;
    margin-top: 0;
    margin-bottom: 0.7em;
  }

  #ctsHero .topLinks li.current {
    padding-bottom: 0em;
    border-bottom: 2px #fff solid;
  }

  #ctsHero .topLinks a {
    padding: 0 0.3em;
  }

  .cts {
    padding-top: 17%;
    margin-bottom: -20%;
  }

  main h2, .cts h2 {
    font-size: 1.7em;
    padding-top: 3em;
    padding-bottom: 1em;
    text-align: left;
    padding-left: 2em;
    position: relative;
    z-index: 1;
  }

  .cts .ctsUnit {
    width: 100%;
  }

  .cts .ctsCircle {
    border-radius: 50%;
    width: 35em;
    height: 35em;
    padding-left: 0;
    margin: 1.2% 1% 30% 0;
    margin-right: 0;
    left: -27%;
  }

  .cts .ctsCircle .textArea {
    width: 58%;
    padding-bottom: 0;
  }

  .cts .ctsCircle h2 {
    font-size: 1.65em;
    line-height: 1.2em;
    margin-bottom: 0.4em;
  }

  .cts .ctsCircle h3 {
    font-size: 1.65em;
    line-height: 1.2em;
    margin-bottom: 0.4em;
  }

  .cts .ctsCircle h4 {
    font-size: 1.1em;
    font-weight: normal;
    margin: 0.6em 0;
  }

  .cts .ctsCircle p {
    line-height: 1.6em;
    margin-top: 0.5em;
    white-space: normal;
  }

  .cts .leadLink {
    font-weight: 600;
    letter-spacing: .1em;
    font-size: 0.8em;
    text-indent: -0.1em;
    margin-top: 1.8em;
    width: 150px;
    border: 2px #fff solid;
    padding: 8px 20px;
  }

  .cts .ctsInner {
    max-width: unset;
    padding: 0;
  }

  .cts .ctsCircle nav {
    bottom: -1.6em;
  }

  .cts .ctsCircle nav span {
    width: 2.2em;
    height: 2px;
    margin: 0 2px;
    opacity: 0.5;
  }

  .cts .ctsCircle nav span.current {
    opacity: 1;
    height: 3px;
  }

  .cts .ctsCircle nav span:hover {
    opacity: 1;
  }

  .cts .ctsCircle nav span.all {
    margin-left: 1.1em;
    height: 0.4em;
    width: 2.8em;
    background-size: contain;
  }

  .cts.select .scroll {
    white-space: normal;
    text-align: left;
  }

  .cts.select .ctsUnit {
    width: 12em;
    margin-left: 1em;
  }

  .cts.select .ctsUnit:nth-child(2n-1) {
    margin-top: 0;
  }

  .cts.select .ctsUnit:nth-child(2n) {
    margin: 13.6em 2em -1.5em -2em;
  }

  .cts.select .ctsCircle {
    width: 15em !important;
    height: 14em;
    padding-left: 2.3em;
    margin-right: 0.9em;
    margin-bottom: 1em;
    margin-left: 0%;
  }

  .cts.select .ctsCircle .textArea {
    width: 80%;
    padding-bottom: 0% !important;
  }

  .cts.select .ctsCircle h3 {
    font-size: 1em;
    line-height: 1.4em;
  }

  .cts nav.pageButton {
    top: auto;
    bottom: 3.8em;
    height: 2em;
  }

  .cts nav .prev, .cts nav .next {
    width: 2.7em;
    margin: 0;
    left: 12%;
  }

  .cts .ctsCircle nav span::before, .cts nav .prev::before, .cts nav .next::before {
    height: 3em;
    width: 100%;
    margin-top: -1.5em;
  }

  .cts nav .prev::after, .cts nav .next::after {
    border: #fff 1px solid;
    width: 1em;
    height: 1em;
    transform-origin: -1px 0;
    transform: rotate(-45deg);
    border-right: 0;
    border-bottom: 0;
  }

  .cts nav .next {
    left: auto;
    right: 12%;
    transform-origin: 50% 0;
  }

  #ctsCollaboration {
    margin-top: -7em;
    min-height: 50em;
    background-size: 267% !important;
    background-position: 37.6% 100%;
  }

  #ctsCollaboration .ctsCircle {
    width: 38em;
    font-size: 1em;
  }

  #ctsCollaboration.select .blurBG {
    opacity: 1;
  }

  #ctsCollaboration .ctsCircle {
    opacity: 0;
  }

  #ctsCollaboration [aria-hidden="false"] .ctsCircle {
    opacity: 1;
  }

  #ctsCollaboration .bx-viewport {
    height: auto !important;
  }

  #ctsPartner {
    min-height: 38em;
  }

  #ctsPartner h2 {
    padding: 1em 0;
    letter-spacing: 0.05em;
    font-size: 1.7em;
    text-align: left;
  }

  #ctsPartner .ctsCircle {
    width: 27em;
    height: 25em;
    padding-left: 4.9em;
    margin-left: 20%;
    margin-bottom: 15%;
    margin-top: 15%;
  }

  #ctsPartner .ctsCircle .textArea {
    width: 68%;
  }

  #ctsInfomation {
    max-width: 100vw;
  }

  #ctsInfomation .ctsInner {
    padding-bottom: 3%;
  }

  #ctsInfomation h2 {
    padding: 1em;
    letter-spacing: 0.05em;
    margin: 3.5em 0 0.7em;
    font-size: 1.7em;
    text-align: center;
  }

  #ctsInfomation ul {
    width: 100%;
    margin-left: 0;
    white-space: nowrap;
  }

  #ctsInfomation li {
    width: 100%;
    margin: 0 0 3em;
    white-space: normal;
    max-width: 92.5vw;
  }

  #ctsInfomation li .fig {
    margin: 0 7% 4%;
  }

  #ctsInfomation li h4 {
    width: 83.7%;
    margin: 2% auto 0;
    letter-spacing: 0.04em;
    line-height: 1.75;
  }

  #ctsInfomation li p {
    width: 83.7%;
    letter-spacing: 0.04em;
  }

  #ctsInfomation .carousel nav {
    margin: 5% 0 17%;
  }

  #ctsInfomation .date {
    width: auto;
    margin-left: -2%;
    letter-spacing: 0.09em;
  }

  #ctsInfomation li .category {
    width: auto;
    color: #fff;
    line-height: 1.7;
    font-size: 0.9em;
    margin-right: 3.3em;
    position: absolute;
    width: auto;
    right: 0;
    padding: 0 1em;
    top: 20.6em;
  }

  #ctsInfomation .ctsUnit {
    padding-right: 7vw;
    width: 150vw;
  }

  #ctsInfomation.select .ctsUnit {
    padding-right: 7vw;
    width: 12em;
  }

  #ctsInfomation .ctsCircle {
    width: 35em;
    height: 35em;
    margin-right: 2%;
    margin-top: 7%;
    margin-bottom: 21.6%;
  }

  #ctsInfomation.select .ctsCircle {
    width: 35em;
    height: 35em;
    margin-right: 2%;
    margin-top: 0;
    margin-bottom: -18.4%;
    height: 15em;
    margin-left: 1em;
  }

  #ctsInfomation.select .ctsUnit:nth-child(2n) {
    margin: 12.6em 2em -0.1em -2em;
  }

  #ctsInfomation.select .img {
    opacity: 0;
    width: 0;
    height: 0;
    left: 50%;
    top: 50%;
  }

  #ctsInfomation.select .bg {
    height: 15em;
    background: #1da5dd;
  }

  #ctsInfomation .textArea {
    z-index: 2;
  }

  #ctsInfomation .bg {
    z-index: 1;
    transition: .2s;
  }

  #ctsInfomation .img {
    width: 59em;
    height: 58em;
    left: -83%;
    top: -35%;
    border-radius: 50%;
    transition: .2s;
    opacity: 0;
  }

  #ctsInfomation .select .img {
    opacity: 1;
  }

  #ctsPointsofview {
    margin-top: -6em;
  }

  #ctsPointsofview p.lead {
    margin: 0 0 1em 3.4em;
    font-size: 1em;
    text-align: left;
    position: relative;
    z-index: 2;
  }

  #ctsPointsofview .ctsUnit {
    padding-right: 0;
    width: 169vw;
  }

  #ctsPointsofview .ctsCircle {
    width: 25em;
    height: 25em;
    margin-right: 0;
    margin-left: 26%;
    margin-top: 5.1%;
    margin-bottom: 3.2%;
    padding-left: 4.1em;
  }

  #ctsPointsofview .textArea {
    z-index: 2;
    width: 70%;
    padding-bottom: 0;
    top: 50%;
  }

  #ctsPointsofview .bg {
    border-radius: 50%;
  }

  #ctsPointsofview .img {
    top: -8%;
    width: 50em;
    height: 50em;
    left: 28.6%;
    top: -47%;
  }

  #ctsPointsofview .ctsNavi {
    margin-bottom: 26.2%;
    text-align: left;
    padding-left: 2.6em;
    font-size: 0.93em;
    width: 90%;
    pointer-events: none;
    margin-top: 0;
  }

  #ctsPointsofview .ctsNavi li {
    margin: 0 0.7em 0.6em;
    font-weight: 600;
    letter-spacing: .05em;
    padding: 0 .2em .2em;
    border-bottom: rgba(255, 255, 255, 0) 1px solid;
    pointer-events: all;
  }

  #ctsPointsofview .ctsNavi li:hover {
    opacity: 0.7;
  }

  #ctsPointsofview .ctsNavi li:hover,
  #ctsPointsofview .ctsNavi li.current {
    border-bottom: #fff 1px solid;
    padding-bottom: 0.2em;
  }

  #ctsPointsofview nav.pageButton {
    top: auto;
    bottom: -4.1em;
    margin-top: 0;
  }

  #ctsPointsofview .leadLink {
    margin-top: 0.7em;
    margin-bottom: 0;
  }

  #ctsPointsofview .bx-viewport {
    height: auto !important;
  }

  #ctsNews {
    margin-top: 6em;
  }

  #ctsNews .bottomCurve {
    border-bottom-right-radius: 50% 2em;
  }

  #ctsNews .release {
    margin: 3.5em 0 2.7em;
    letter-spacing: 0.11em;
  }

  #ctsNews .ctsInner {
    width: 65%;
    padding: 0;
    margin-bottom: 3em;
  }

  #ctsNews h2 {
    font-size: 1.7em;
    margin: 0;
  }

  #ctsNews dd {
    margin-bottom: 1.4em;
    padding-bottom: 0.8em;
  }

  #ctsNews .list {
    font-size: 0.9em;
    display: table-cell;
    text-align: left;
  }

  #ctsNews a:hover .linkArrow,
  #ctsServices a:hover .linkArrow {
    margin: 0 -.15em 0 .75em;
  }

  #ctsNews .important {
    margin: 4.5em auto 2.1em;
    padding: 1.1em 1.1em 0.9em;
    width: 100%;
  }
  #ctsNews .important h3 {
    margin-bottom: 0.9em;
    font-size: 1em;
    letter-spacing: 0;
  }
  #ctsNews .important h3::before {
    background-size: contain;
    margin: 0 0.5em 0.2em -0.3em;
    width: 1.1em;
    height: 1.1em;
  }
  #ctsNews .important .linkArrow {
    width: 1.1em;
  }
  #ctsNews .important .linkArrow::after {
    width: 0.5em;
  }
  #ctsNews .important a {
    margin-bottom: 0.4em;
    width: 100%;
    font-size: 0.9em;
    white-space: nowrap;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-text-overflow: ellipsis;
    /* Safari */
    -o-text-overflow: ellipsis;
    /* Opera */
  }

  #ctsImportant {
    margin-top: 6em;
  }

  #ctsImportant .ctsInner {
    padding: 0;
    margin-bottom: 3em;
  }

  #ctsImportant a:hover .linkArrow,
  #ctsServices a:hover .linkArrow {
    margin: 0 -.15em 0 .75em;
  }

  #ctsImportant .important .linkArrow {
    width: 1.1em;
  }

  #ctsImportant .important .linkArrow:after {
    width: 0.5em;
  }

  #ctsImportant .important {
    padding: 1.1em 1.1em 0.9em;
    width: 100%;
    margin: 3em auto 2.1em;
  }

  #ctsImportant .important h2, #ctsImportant .important h3 {
    font-size: 1em;
    margin: 0 0 0.9em 0;
    letter-spacing: 0;
    padding: 0;
  }
  #ctsImportant .important h2::before, #ctsImportant .important h3::before {
    width: 1.1em;
    height: 1.1em;
    margin: 0 0.5em 0.2em -0.3em;
    background-size: contain;
  }

  #ctsImportant .important a {
    margin-bottom: 0.4em;
    font-size: 0.9em;
    white-space: nowrap;
    width: 100%;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-text-overflow: ellipsis;
    /* Safari */
    -o-text-overflow: ellipsis;
    /* Opera */
  }

  #ctsServices {
    padding-bottom: 0;
    padding-top: 14%;
    margin-bottom: -25%;
  }

  #ctsServices .ctsInner {
    padding: 0;
    padding-bottom: 7em;
  }

  #ctsServices h2 {
    padding: 2.7em 0 1em;
    text-align: left;
    position: relative;
    z-index: 1;
    margin: 0;
    font-size: 1.7em;
  }

  #ctsServices ul {
    padding-bottom: 0.3em;
  }

  #ctsServices li {
    margin-right: 0;
    width: 100%;
    margin-bottom: 2.5em;
  }

  #ctsServices li:nth-child(2n) {
    margin-right: 0;
  }

  #ctsServices li h3 {
    margin-bottom: 1.9em;
    height: 2.1em;
  }

  #ctsServices li h3 img {
    width: 100%;
  }

  #ctsServices li a {
    line-height: 2em;
  }

  #ctsServices .list {
    font-size: 0.9em;
    display: table-cell;
    text-align: left;
  }

  #ctsServices .carousel nav {
    margin-top: 0;
  }

  .bx-wrapper, .bx-viewport {
    height: auto !important;
    display: inline-block;
  }
}
.bx-viewport {
  position: relative;
  overflow: visible !important;
}

/*# sourceMappingURL=top.css.map */
