@charset "utf-8";

/* ****************************************************************************

目次

-------------------------------------------------------------------------------

　00. module
　00. 汎用スタイル

******************************************************************************* */
/* ==

　00. module

=============================================================================== */
/* heading01
------------------------------------------------------------------------------- */
.heading01 {
  position: relative;
  min-width: 1240px;
  min-height: 251px;
  margin: 0 0 80px;
  padding: 0 40px;
  box-sizing: border-box;
}
.heading01::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 251px;
  background-color: #f6f6f6;
}
.heading01_wrap {
  position: relative;
  max-width: 1240px;
  margin: 0 auto;
  z-index: 2;
}
.heading01_in {
  padding: 58px 0 0;
}
.heading01_tit {
  position: relative;
  line-height: 52px;
  margin: 0 0 30px;
  color: #212529;
  font-size: 4.8rem;
  font-weight: 400;
}
.heading01_tit::before {
  content: "";
  display: block;
  position: absolute;
  bottom: -9px;
  width: 64px;
  height: 2px;
  background-color: #DE163D;
  z-index: 1;
}
.heading01_img {
  max-width: 520px;
}
/* heading02
------------------------------------------------------------------------------- */
.heading02 {
  line-height: 1.4;
  margin: 0 0 44px;
  color: #212529;
  font-size: 4rem;
  font-weight: 400;
}
.heading02::after {
  content: "";
  display: block;
  max-width: 64px;
  height: 2px;
  margin: 0;
  background-color: #DE163D;
}
/* breadcrumbs
------------------------------------------------------------------------------- */
.breadcrumbs {
  position: relative;
  box-sizing: border-box;
  padding: 0;
  z-index: 2;
}
.breadcrumbs .baseIn {
  margin: 0 auto;
  padding: 18px 0 16px;
  max-width: 1240px;
}
.breadcrumbs .breadcrumbs_navs {
  display: flex;
  line-height: 1.0;
  color: #212529;
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: -0.5em;
}
.breadcrumbs_navs li {
  display: inline-block;
  position: relative;
  margin: 0 0 0 16px;
  vertical-align: top;
  letter-spacing: normal;
}
.breadcrumbs_navs li:first-child {
  margin-left: 0;
}
.breadcrumbs_navs li::before {
  content: ">";
  display: block;
  position: absolute;
  top: 1px;
  left: -12px;
  font-size: 8px;
}
.breadcrumbs_navs li:first-child::before {
  display: none !important;
}
.breadcrumbs_navs a {
  color: #6e6e6e;
  text-decoration: none;
}
.breadcrumbs_navs a:hover {
  color: #e40330;
}
/* btn01
------------------------------------------------------------------------------- */
.btn01 {
  margin: 30px 0 0;
}
.btn01 a {
  position: relative;
  display: inline-block;
  line-height: 26px;
  padding: 9px 36px 4px 20px;
  border: 1.5px solid #333;
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  text-decoration: none;
}
.btn01 a:hover {
  opacity: 0.7;
}
.btn01 a::after {
  content: "";
  display: inline-block;
  position: absolute;
  right: 11px;
  width: 20px;
  height: 20px;
  margin: 7px 0 0;
  background: url(../images/ico_arrow_bk.svg);
  background-repeat: no-repeat;
  background-size: 12px;
  transition: all 0.3s ease-in-out;
}
.btn01 a:hover:after {
  right: 5px;
}
/* btn02
------------------------------------------------------------------------------- */
.btn02 {
  margin: 17px 0 0;
}
.btn02 a {
  position: relative;
  display: inline-block;
  line-height: 26px;
  padding: 9px 36px 4px 20px;
  background: #de163d;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 400;
  text-decoration: none;
}
.btn02 a:hover {
  opacity: 0.9;
}
.btn02 a::after {
  content: "";
  display: inline-block;
  position: absolute;
  right: 11px;
  width: 20px;
  height: 20px;
  margin: 7px 0 0;
  background: url(../images/ico_arrow_wh.svg);
  background-repeat: no-repeat;
  background-size: 12px;
  transition: all 0.3s ease-in-out;
}
.btn02 a:hover:after {
  right: 5px;
}
/* Group Companies
------------------------------------------------------------------------------- */
.topGroup01 {
  padding: 50px 40px 80px;
  background-color: #F6F6F6;
}
.topGroup01_in {
  max-width: 1240px;
  margin: 0 auto;
}
.topGroup02 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 0 40px;
  background-color: #fff;
}
.topGroup02_img {
  width: 48.388%;
  max-width: 600px;
}
.topGroup02_info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
  width: 51.612%;
  padding: 24px 24px 24px 80px;
  box-sizing: border-box;
}
.topGroup02_info .btn01 {
  position: absolute;
  right: 24px;
  bottom: 24px;
}
.topGroup01_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.topGroup01_list::before {
  display: block;
  order: 1;
  width: calc((100% - 100px) / 3);
  content: "";
}
.topGroup01_item {
  margin: 0;
  padding: 0 0 24px;
  width: 31.613%;
  max-width: 392px;
  background-color: #fff;
  text-align: center;
}
.topGroup01_tit {
  margin: 24px 0;
}
.topGroup01_tit-t2,
.topGroup01_tit-t3,
.topGroup01_tit-t4 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  height: 66px;
}
.topGroup01_tit-t1 img {
  max-width: 180px;
}
.topGroup01_tit-t3 img {
  max-width: 145px;
}
.topGroup01_tit-t4 img {
  max-width: 222px;
}
.topGroup01 .btn01 {
  margin: 0;
}
/* ==

　00. 汎用スタイル

=============================================================================== */
/* 余白調整
------------------------------------------------------------------------------- */
.mt00 { margin-top: 0 !important; }
.mt05 { margin-top: 5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }

.mr00 { margin-right: 0 !important; }
.mr05 { margin-right: 5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }

.mb00 { margin-bottom: 0 !important; }
.mb05 { margin-bottom: 5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }

.ml00 { margin-left: 0 !important; }
.ml05 { margin-left: 5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }

.pt00 { padding-top: 0 !important; }
.pt05 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }

.pr00 { padding-right: 0 !important; }
.pr05 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }

.pb00 { padding-bottom: 0 !important; }
.pb05 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }

.pl00 { padding-left: 0 !important; }
.pl05 { padding-left: 5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }

/* 幅調整
------------------------------------------------------------------------------- */
.w00 { width: 0 !important; }
.w05p { width: 5% !important; }
.w10p { width: 10% !important; }
.w15p { width: 15% !important; }
.w20p { width: 20% !important; }
.w25p { width: 25% !important; }
.w30p { width: 30% !important; }
.w35p { width: 35% !important; }
.w40p { width: 40% !important; }
.w45p { width: 45% !important; }
.w50p { width: 50% !important; }
.w55p { width: 55% !important; }
.w60p { width: 60% !important; }
.w65p { width: 65% !important; }
.w70p { width: 70% !important; }
.w75p { width: 75% !important; }
.w80p { width: 80% !important; }
.w85p { width: 85% !important; }
.w90p { width: 90% !important; }
.w95p { width: 95% !important; }
.w100p { width: 100% !important; }
