#topImageContainer {
  height: 456px;
  background: url(../images/mainvisual.jpg) no-repeat center center;
  display: flex;
  margin-bottom: 4rem;
}

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

#topImageContainer {
  height: auto;
  background: url(../images/mainvisual_mobile.jpg) no-repeat right top;
  background-size: cover;
  padding-top: 16rem;
}

}

/* ---------- header02 ---------- */

.pagecss_topHeader02 {
  font-size: 3.5rem;
  line-height: 5.3rem;
  font-weight: 700;
  padding-bottom: 3rem;
  margin: 0 0 3.7rem;
  text-align: center;
  position: relative;
}

.pagecss_topHeader02::after {
  content: "";
  position: absolute;
  left: calc(50% - 2rem);
  bottom: 0;
  height: 0.1rem;
  width: 4rem;
  background-color: #333333;
}

.pagecss_topHeader02Deco {
  display: block;
  margin: 0 auto 2.5rem;
}

.pagecss_topHeader02Left .pagecss_topHeader02Deco {
  margin-left: 0;
}

.pagecss_topHeader02DecoMobile {
  display: none;
}

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

.pagecss_topHeader02Deco {
  display: none;
}

.pagecss_topHeader02DecoMobile {
  display: block;
  margin: 0 auto 1rem;
}

}

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

.pagecss_topHeader02 {
  font-size: 2.5rem;
  line-height: 3.9rem;
  padding-bottom: 2rem;
  margin: 0 0 2.2rem;
}

}

/* ---------- News Release ---------- */

#pagecss_newsReleaseGridContainer {
  display: grid;
  grid-template-columns: 20rem 1fr;
  grid-template-areas:
    "newsReleaseTitle newsReleaseContents";
  display: -ms-grid;
  -ms-grid-columns: 20rem 1fr;
  border-radius: 2.5rem;
  box-shadow: 0 0 1rem 0 rgba(0,0,0,0.20);
  padding: 3rem 0;
  background-color: #ffffff;
  position: relative;
  z-index: 4;
}

#pagecss_newsReleaseTitle {
  grid-area: newsReleaseTitle;
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  border-right: 1px solid #e5e5e5;
  padding: 2rem 0 1.85rem 0.6rem;
  display: grid;
  grid-template-rows: 1fr 2.5rem;
  grid-template-areas:
    "newsReleaseTitleLogo"
    "newsReleaseButton";
}

#pagecss_newsReleaseContents {
  grid-area: newsReleaseContents;
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  padding: 0 5.3rem 0 4.3rem;
  list-style: none;
}

#pagecss_newsReleaseTitleLogo {
  grid-area: newsReleaseTitleLogo;
  text-align: center;
  padding-bottom: 2rem;
}

#pagecss_newsReleaseButton {
  grid-area: newsReleaseButton;
  text-align: center;
}

#pagecss_newsReleaseButton a {
  font-size: 1.5rem;
  font-weight: 700;
}

#pagecss_newsReleaseButton a .pagecss_newsReleaseButtonUnderline::after {
  content: "";
  position: absolute;
  right: 0;
  top: calc(50% - 1.5rem);
  width: 3rem;
  height: 3rem;
  background-color: #000000;
  -webkit-mask-image: url("/common/images/linkarrow02Black.svg");
  mask-image: url("/common/images/linkarrow02Black.svg");
  -webkit-mask-size: cover;
  mask-size: cover;
  transition-duration: 0.4s;
}

#pagecss_newsReleaseButton a .pagecss_newsReleaseButtonUnderline {
  position: relative;
  display: inline;
  padding-left: 0.5rem;
  padding-right: 3.5rem;
  margin-left: -0.5rem;
  margin-right: -0.5rem;
  background: linear-gradient(#109189, #109189) 100% 100% / 0 1px no-repeat;
  transition: background-size 0.4s cubic-bezier(.23,1,.32,1) 0s, color 0.4s;
}

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

#pagecss_newsReleaseButton a:hover .pagecss_newsReleaseButtonUnderline {
  color: #109189;
  background-position: 0 100%;
  background-size: 100% 1px;
  transition-duration: 0.4s;
}

}

#pagecss_newsReleaseButton a:hover .pagecss_newsReleaseButtonUnderline::after {
  background-color: #109189;
  transition-duration: 0.4s;
}

#pagecss_newsReleaseContents > li {
  padding: 1.2rem 0;
  border-bottom: 1px dotted #cccccc;
}

#pagecss_newsReleaseContents > li:last-of-type {
  padding: 1.2rem 0 0;
  border-bottom: none;
}

#pagecss_newsReleaseContents .pagecss_newsReleaseContentsElement {
  display: grid;
  grid-template-columns: 12rem 10rem 1fr;
  grid-template-areas:
    "newsReleaseDate newsReleaseCategory newsReleaseText";
  display: -ms-grid;
  -ms-grid-columns: 12rem 9rem 1fr;
  position: relative;
}

#pagecss_newsReleaseContents .pagecss_newsReleaseContentsElement::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0.7rem;
  height: 2.1rem;
  width: 2.1rem;
  background: url("../images/linkArrow_news_release.png") center center no-repeat;
  transition: 0.2s;
}

.pagecss_newsReleaseDate {
  grid-area: newsReleaseDate;
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  display: block;
  font-size: 2rem;
  font-weight: 700;
}

.pagecss_newsReleaseCategory {
  grid-area: newsReleaseCategory;
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  display: block;
}

.pagecss_newsReleaseCategory .pagecss_categoryPict {
  display: inline-block;
  width: 10rem;
	color: #ffffff;
	text-align: center;
	font-size: 1.2rem;
  padding: 0.3rem 0 0.5rem;
  margin: 0.3rem 0 0;
  border-radius: 0.5rem;
}

.pagecss_newsReleaseText {
  grid-area: newsReleaseText;
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  display: block;
  padding: 0.4rem 3.6rem 0 1.5rem;
  transition: 0.2s;
}

.pagecss_newsReleaseText .pagecss_newsReleaseTextUnderline {
  display: inline;
  background: linear-gradient(#109189, #109189) 100% 100% / 0 1px no-repeat;
  transition: background-size .4s cubic-bezier(.23,1,.32,1) 0s;
}

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

#pagecss_newsReleaseContents .pagecss_newsReleaseContentsElement:hover::after {
  background: url("../images/linkArrow_news_release_green.png") center center no-repeat;
  transition: 0.2s;
}

#pagecss_newsReleaseContents .pagecss_newsReleaseContentsElement:hover .pagecss_newsReleaseText {
  color: #109189;
  transition: 0.2s;
}

#pagecss_newsReleaseContents .pagecss_newsReleaseContentsElement:hover .pagecss_newsReleaseTextUnderline {
  background-position: 0 100%;
  background-size: 100% 1px;
}

}

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

#pagecss_newsReleaseGridContainer {
  display: grid;
  grid-template-rows: auto auto;
  grid-template-columns: 100%;
  grid-template-areas:
    "newsReleaseTitle"
    "newsReleaseContents";
  display: -ms-grid;
  -ms-grid-rows: auto auto;
  -ms-grid-columns: 100%;
  padding: 2.5rem 4rem 2rem;
}

#pagecss_newsReleaseTitle {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "newsReleaseTitleLogo newsReleaseButton";
  border-right: none;
  padding: 0 0 1.4rem;
}

#pagecss_newsReleaseTitleLogo {
  text-align: left;
  padding: 0;
}

#pagecss_newsReleaseButton {
  text-align: right;
  padding-top: 3.1rem;
}

#pagecss_newsReleaseContents {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  padding: 0;
  list-style: none;
}

#pagecss_newsReleaseContents .pagecss_newsReleaseContentsElement {
  display: grid;
  grid-template-rows: auto auto;
  grid-template-columns: 11rem 1fr;
  grid-template-areas:
    "newsReleaseDate newsReleaseCategory"
    "newsReleaseText newsReleaseText";
  display: -ms-grid;
  -ms-grid-rows: auto auto;
  -ms-grid-columns: 12rem 1fr;
  position: relative;
}

.pagecss_newsReleaseText {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  padding: 0.4rem 3.6rem 0 0.1rem;
}

#pagecss_newsReleaseContents .pagecss_newsReleaseContentsElement::after {
  top: 3.6rem;
/*
  top: auto;
  bottom: 0.1rem;
*/
}

}

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

#pagecss_newsReleaseGridContainer {
  padding: 1.5rem 2.5rem 1rem;
}

#pagecss_newsReleaseTitle {
  text-align: left;
  border-right: none;
  padding: 0 0 0.9rem;
}

.pagecss_newsReleaseDate {
  font-size: 1.7rem;
  margin-top: 0.1rem;
}

.pagecss_newsReleaseCategory .pagecss_categoryPict {
  width: 9rem;
  padding: 0.1rem 0 0.3rem;
  margin: 0 0 0 -1.5rem;
}

}

/* ---------- 会社情報 ---------- */

#pagecss_companyContainer {
  display: grid;
  grid-template-columns: 50.834% 1fr;
  column-gap: 7.5%;
  grid-template-areas:
    "companyPhoto companyContents";
  display: -ms-grid;
  -ms-grid-columns: 50.834% 7.5% 1fr;
  margin: 7rem 0;
}

#pagecss_companyPhoto {
  grid-area: companyPhoto;
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  text-align: center;
}

#pagecss_companyPhotoMobile {
  display: none;
}

#pagecss_companyContents {
  grid-area: companyContents;
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  padding: 5.8rem 0 0;
}

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

.pagecss_topHeader02Left {
  text-align: left;
}

.pagecss_topHeader02Left::after {
  left: 0;
}

}

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

#pagecss_companyContainer {
  display: grid;
  grid-template-columns: 100%;
  grid-template-areas:
    "companyContents";
  display: -ms-grid;
  -ms-grid-columns: 100%;

  margin: 0 0 5rem;
}

#pagecss_companyContents {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  text-align: center;
}

#pagecss_companyPhotoMobile {
  display: block;
  text-align: center;
  margin: 4rem 0 0;
}

}

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

#pagecss_companyContainer {
  margin-top: 4rem;
  margin-bottom: 2rem;
}

#pagecss_companyContents {
  padding: 1rem 0 0;
}

#pagecss_companyPhotoMobile {
  display: block;
  text-align: center;
  margin: 3rem 0 0;
}

}

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

.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;
}

}

/* タブレット用とモバイル用のgeneral系で、このページで使っているモノだけ移植（そして、その2つのcss読み込みを外す（pageSpeedInsight対策）） */

@media screen and (min-width: 560px) and (max-width: 959px) {

.ts_pl0 { padding-left: 0; }
.ts_pb3rem { padding-bottom: 3rem; }
.ts_mw500{ width:100%;max-width:500px;*width:500px;}
.ts_tl{text-align:left;}
.ts_mLRA{
	margin-left: auto;
	margin-right:auto;
}

}

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

.ms_mt2rem { margin-top: 2rem; }
.ms_mt3rem { margin-top: 3rem; }
.ms_mb2rem { margin-bottom: 2rem; }
.ms_mb3rem { margin-bottom: 3rem; }
.ms_mb4rem { margin-bottom: 4rem; }
.ms_pl0 { padding-left: 0; }
.ms_pt2rem { padding-top: 2rem; }
.ms_pt5rem { padding-top: 5rem; }
.ms_pb1rem { padding-bottom: 1rem; }
.ms_w100p{ width:100%;}
.ms_mw300{ width:100%;max-width:300px;*width:300px;}
.ms_tl{text-align:left;}
.ms_mLRA{
	margin-left: auto;
	margin-right:auto;
}
.ms_fxdC { flex-direction: column; }
.ms_aiFe { align-items: flex-end; }

}

