/* ---------- 当社の特徴 ---------- */

.pagecss_bg01 {
  background: url("../images/bg01.jpg") top center no-repeat;
}

#pagecss_featureContainer {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  column-gap: 6.5rem;
  grid-template-areas:
    "feature01 feature02 feature03";
  display: -ms-grid;
  -ms-grid-columns: 1fr 6.5rem 1fr 6.5rem 1fr;
  padding: 4rem 0 9rem;
}

#pagecss_feature01 {
  grid-area: feature01;
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  display: block;
}

#pagecss_feature02 {
  grid-area: feature02;
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  display: block;
}

#pagecss_feature03 {
  grid-area: feature03;
  -ms-grid-row: 1;
  -ms-grid-column: 5;
  display: block;
}

.pagecss_featureLink {
  width: 36rem;
  height: 36rem;
  perspective: 72rem;
}

.pagecss_featureBox {
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.5s;
  backface-visibility: hidden;
  transform-origin: center center -18rem;
  width: 36rem;
  height: 36rem;
}

_::-webkit-full-page-media, _:future, :root .pagecss_featureBox { /* Safari用 Z-indexにバグがあるための処置 ／ 2022.07.08時点の最新Safariでは、これを削除して、以下のコメントアウト4つ分を有効にすると、Chromeと同等の動作になるが、少し古いSafariでは異なる挙動となってしまうため、保留 */ 
  transform-origin: center center;
}

.pagecss_featureBoxFront {
  border: 0.8rem solid #d0d9de;
  background-color: #ffffff;
  font-size: 3.5rem;
  line-height: 5.3rem;
  font-weight: 700;
  text-align: center;
  transform: rotateX(0);
}

/*
_::-webkit-full-page-media, _:future, :root .pagecss_featureBoxFront {
  transform: rotateX(0) translateZ(-18rem);
}
*/

.pagecss_featureBoxFrontPict {
  display: block;
  margin: 6rem auto 3rem;
}

.pagecss_featureBoxFrontText {
  display: none;
}

.pagecss_featureBoxFrontBtn {
  display: none;
}

.pagecss_featureBoxBack {
  color: #ffffff;
  background-color: #163f59;
  font-size: 2.0rem;
  line-height: 3.6rem;
  font-weight: 400;
  padding: 3.2rem 4rem;
  transform: rotateX(-90deg);
}

/*
_::-webkit-full-page-media, _:future, :root .pagecss_featureBoxBack {
  transform: rotateX(-90deg);
}
*/

.pagecss_featureBoxBack::after {
  content: "詳しくはこちら";
  position: absolute;
  right: 3.1rem;
  bottom: 2.6rem;
  font-size: 1.5rem;
  background: url("/common/images/linkarrow02White.svg") center right no-repeat;
  background-size: 2.6rem;
  padding-right: 3rem;
}

@media screen and (min-width: 1250px) {

.pagecss_featureLink:hover .pagecss_featureBoxFront {
  transform: rotateX(90deg);
}

/*
_::-webkit-full-page-media, _:future, :root .pagecss_featureLink:hover .pagecss_featureBoxFront {
  transform: rotateX(90deg);
}
*/

.pagecss_featureLink:hover .pagecss_featureBoxBack {
  transform: rotateX(0);
}

/*
_::-webkit-full-page-media, _:future, :root .pagecss_featureLink:hover .pagecss_featureBoxBack {
  transform: rotateX(0) translateZ(-18rem);
}
*/

}

@media screen and (max-width: 1249px) {

#pagecss_featureContainer {
  display: grid;
  grid-template-columns: 1fr;
  column-gap: 6.5rem;
  grid-template-areas:
    "feature01"
    "feature02"
    "feature03";
  display: -ms-grid;
  -ms-grid-columns: 1fr;
  padding: 4rem 0 5rem;
}

.pagecss_featureLink {
  width: auto;
  height: auto;
  margin-bottom: 3rem;
}

.pagecss_featureBox {
  position: relative;
  width: 100%;
  height: auto;
}

.pagecss_featureBoxFrontPict {
  margin: 4rem auto 3rem;
}

.pagecss_featureBoxFrontText {
  display: block;
  font-size: 2.0rem;
  line-height: 3.2rem;
  font-weight: 400;
  margin: 2rem 4rem;
  text-align: left;
}

.pagecss_featureBoxFrontBtn {
  display: block;
  margin: 3rem 4rem 4rem;
  width: auto;
}

.pagecss_featureBoxBack {
  display: none;
}

}

@media screen and (max-width: 559px) {

#pagecss_featureContainer {
  padding: 2rem 0;
}

.pagecss_featureBoxFrontPict {
  margin: 0 auto -1rem;
  transform: scale(0.7);
}

.pagecss_featureBoxFront {
  font-size: 2.5rem;
  line-height: 3.9rem;
}

.pagecss_featureBoxFrontText {
  font-size: 1.7rem;
  line-height: 2.7rem;
  margin: 1rem 2.5rem 2rem;
}

.pagecss_featureBoxFrontBtn {
  margin: 2rem 2.5rem 2.5rem;
}

}

/* ---------- 事例 ---------- */

#showcase_slider {
  margin-top: 1.5rem;
  max-width: 100vw;
}

#showcase_slider .arrow_prev {
  position: absolute;
  left: calc(((100vw - 120rem) / 2) - 4.3rem);
  top: calc(50% - 5.3rem);
  width: 7.6rem;
  height: 6.6rem;
  background: url("../images/showcase_slider_arrow_prev.png") right center no-repeat;
  z-index: 2;
  transition: 0.2s ease-in-out;
  cursor: pointer;
}

#showcase_slider .arrow_next {
  position: absolute;
  right: calc(((100vw - 120rem) / 2) - 4.3rem);
  top: calc(50% - 5.3rem);
  width: 7.6rem;
  height: 6.6rem;
  background: url("../images/showcase_slider_arrow_next.png") left center no-repeat;
  z-index: 2;
  transition: 0.2s ease-in-out;
  cursor: pointer;
}

@media screen and (min-width: 960px) {

#showcase_slider .arrow_prev:hover {
  background: url("../images/showcase_slider_arrow_prev_hover.png") left center no-repeat;
  transition: 0.2s ease-in-out;
}

#showcase_slider .arrow_next:hover {
  background: url("../images/showcase_slider_arrow_next_hover.png") right center no-repeat;
  transition: 0.2s ease-in-out;
}

}

#showcase_slider .showcase_slider_box {
  width: 36.6rem;
  border-radius: 2.5rem;
  box-shadow: 0 0 1rem 0 rgba(0,0,0,0.20);
  margin: 3rem 2.5rem 1rem;
  transition: 0.2s ease-in-out;
}

@media screen and (min-width: 960px) {

#showcase_slider .showcase_slider_box:hover {
  transform: translateY(-2rem);
  transition: 0.2s ease-in-out;
}

}

#showcase_slider .showcase_slider_box a {
  display: block;
}

#showcase_slider .showcase_slider_logo {
  margin: 3rem 3rem 2.5rem;
}

#showcase_slider .showcase_slider_logo img {
  margin: 0 auto;
}

#showcase_slider .showcase_slider_text01 {
  margin: 2rem 3rem 0;
  font-size: 1.8rem;
  line-height: 2.9rem;
  font-weight: 500;
  color: #109189;
}

#showcase_slider .showcase_slider_text02 {
  font-size: 1.5rem;
  line-height: 2.0rem;
  margin: 0.3rem 3rem 0;
}

#showcase_slider .showcase_slider_text03 {
  margin: 0.4rem 3rem 0;
}

#showcase_slider .showcase_slider_category {
  margin: 2rem 3rem 3rem;
  display: inline-block;
  color: #7e95a3;
  border: 1px solid #7e95a3;
  padding: 0.1rem 1.5rem 0.2rem;
  font-size: 1.2rem;
  line-height: 2.0rem;
  border-radius: 3rem;
}

@media screen and (max-width: 1300px) {

#showcase_slider .arrow_prev {
  left: calc(50vw - 18.3rem - 9.5rem);
}

#showcase_slider .arrow_next {
  right: calc(50vw - 18.3rem - 9.5rem);
}

}

@media screen and (max-width: 559px) {

#showcase_slider .showcase_slider_box {
  width: 70vw;
  max-width: 36.6rem;
  margin: 2rem 1.0rem 1rem;
}

#showcase_slider .arrow_prev {
  left: calc(15vw - 3rem);
  width: 4.0rem;
  height: 4.0rem;
  background-size: contain;
}

#showcase_slider .arrow_next {
  right: calc(15vw - 3rem);
  width: 4.0rem;
  height: 4.0rem;
  background-size: contain;
}

#showcase_slider .showcase_slider_logo {
  margin: 3rem 2rem 2.5rem;
}

#showcase_slider .showcase_slider_text01 {
  margin: 2rem 2rem 0;
}

#showcase_slider .showcase_slider_text02 {
  margin: 0.3rem 2rem 0;
}

#showcase_slider .showcase_slider_text03 {
  margin: 0.4rem 2rem 0;
}

#showcase_slider .showcase_slider_category {
  margin: 2rem 2rem 2rem;
}

}

