@charset "UTF-8";

/* ---------------------------------------------------------------------------
  ★共通
--------------------------------------------------------------------------- */

html {
  font-size: 62.5%;
}

object {
  pointer-events: none;
}

.sp {
  display: none !important;
}

a[href^="tel:"] {
  pointer-events: none;
}

a {
  text-decoration: none;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.img_r,
.img_l {
  overflow: hidden;
}

.img_r > img,
.img_l > img {
  width: 33%;
  margin-bottom: 15px;
}

.img_r > img {
  float: right;
  margin-left: 15px;
}
.img_l > img {
  float: left;
  margin-right: 15px;
}

.pc_center {
  text-align: center;
}

.cl50,
.cl33,
.cl7_3,
.cl3_7,
.cl6_4,
.cl4_6,
.cl25 {
  display: flex;
  flex-wrap: wrap;
}
.reverse {
  flex-direction: row-reverse;
  justify-content: space-between;
}
/* ---------------------------------------------------------------------------
  ★フォントファミリー
--------------------------------------------------------------------------- */

/* ---------------------------------------------------------------------------
  ★LIST
--------------------------------------------------------------------------- */

/* ---------------------------------------------------------------------------
  ★BASE
--------------------------------------------------------------------------- */

/* ---------------------------------------------------------------------------
  ★タイトル
--------------------------------------------------------------------------- */

.tit02 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  margin: 0 auto 35px;
}

.tit02 b {
  font-size: 5rem;
  line-height: 1.5;
  letter-spacing: 2px;
  display: inline-block;
  position: relative;
}

.tit02 span {
  color: #8c8c8c;
  font-size: 1.6rem;
  display: block;
  line-height: 1;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro",
    "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", cursive, sans-serif, serif;
}

.txt_shinfo {
  position: relative;
}

.txt_shinfo > small {
  position: absolute;
  top: -22px;
  left: 0;
  font-size: 41%;
  word-break: keep-all;
}

/* ---------------------------------------------------------------------------
  ★テキスト
--------------------------------------------------------------------------- */

/* ---------------------------------------------------------------------------
  ★インスタグラム
--------------------------------------------------------------------------- */

.instagramcont li {
  width: calc(100% / 4);
}

.instagramcont li a {
  display: block;
  overflow: hidden;
  position: relative;
  width: 100%;
  padding: 0 0 100%;
  background: #949494;
}

.instagramcont li a img {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

/* ---------------------------------------------------------------------------
  ★パーツ集
--------------------------------------------------------------------------- */

/* ---------------------------------------------------------------------------
  ★パーツ集:テーブル
--------------------------------------------------------------------------- */

.c_phoneArea {
  max-width: 765px;
  margin: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}

.c_phoneArea > div:nth-child(1) {
  width: 50%;
  margin-right: 15px;
}

.c_table_01 {
  /* border: 2px solid #eaf1f8; */
  /* border-radius: 0.5em; */
}

.c_table_01 table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: inherit;
  width: 100%;
  border-radius: 0.5em;
}

.c_table_01 table tbody tr th {
  border-bottom: 1px solid #eaf1f87a;
  /* background: #f3f8fc; */
  vertical-align: top;
  padding: 16px 15px;
  font-weight: 500;
  width: 24.5%;
  word-break: break-all;
  background: url(../img/f_bg.jpg) top -4px center;
  color: #fff;
}

.c_table_01 table tbody tr:nth-of-type(1) th {
  border-radius: 0.5em 0 0 0;
}

.c_table_01 table tbody tr:last-child th {
  border-radius: 0 0 0 0.5em;
}

.c_table_01 table tbody tr td {
  border-bottom: 1px solid #edf2f6;
  vertical-align: top;
  padding: 16px 21px;
  word-break: break-all;
}

.c_table_02 table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: inherit;
  width: 100%;
}

.c_table_02 table thead {
  background-color: #666;
  color: #fff;
  margin: 0;
  border: 0;
}

.c_table_02 table thead tr th {
  padding: 10px;
  text-align: center;
}

.c_table_02 table tbody tr th,
.c_table_02 table tbody tr td {
  padding: 10px;
  font-size: 14px;
  word-break: break-all;
}

.c_table_02 table tbody tr:nth-child(even) {
  background-color: #e4e4e4;
}

/* ---------------------------------------------------------------------------
  ★パーツ集:NEWS
--------------------------------------------------------------------------- */

.c_newslist_01 > a {
  display: block;
  color: #000;
  margin: 10px 0;
  border-bottom: solid 1px #c1c1c1;
}

.c_newslist_01 > a dl dt {
  float: left;
  width: 18%;
  margin-right: 2%;
}

.c_newslist_01 > a dl dd {
  float: left;
  width: 80%;
  word-break: break-all;
}

.c_newslist_02 dl {
  margin: 10px 0;
  border-bottom: solid 1px #c1c1c1;
}

.c_newslist_02 dl dt {
  float: left;
  width: 18%;
  margin-right: 2%;
}

.c_newslist_02 dl dd {
  float: left;
  width: 80%;
  word-break: break-all;
}

.c_newslist_02 dl dd > a {
  display: block;
  color: #000;
}

.c_newslist_03 a {
  display: block;
  margin: 10px 0;
  border-bottom: solid 1px #c1c1c1;
  color: #000;
}

.c_newslist_03 dl {
  margin: 10px 0;
}

.c_newslist_03 dl dt {
  float: left;
  width: 18%;
  margin-right: 2%;
}

.c_newslist_03 dl dt .imgBox {
  position: relative;
  overflow: hidden;
  padding-bottom: 66.6%;
}

.c_newslist_03 dl dd {
  float: left;
  width: 80%;
  word-break: break-all;
}

.c_newslist_03 dl dd .days_tx,
.c_newslist_03 dl dd .news_txt {
  display: block;
}

.icon_new {
  margin-left: 15px;
  display: inline-block;
  color: #e60012;
  z-index: 3;
}

.days_txt {
  color: #000;
}

.lr_xBox .main_xBox {
  float: left;
  width: 70%;
}

.lr_xBox .aside_xBox {
  float: right;
  width: 25%;
}

.archive_xBox > dl a {
  position: relative;
  display: block;
  margin-bottom: 5px;
}

.archive_xBox > dl dd {
  display: none;
}

.c_postlink li:first-child {
  float: left;
  width: 40%;
}

.c_postlink li:last-child {
  float: right;
  width: 40%;
  text-align: right;
}

.c_dBox h1,
.c_dBox h2,
.c_dBox h3,
.c_dBox h4,
.c_dBox h5,
.c_dBox h6 {
  font-weight: bold;
}

.c_dBox img {
  max-width: 100%;
  width: auto !important;
  height: auto !important;
}

/* ---------------------------------------------------------------------------
  ★パーツ集:カテゴリ
--------------------------------------------------------------------------- */

.c_cateBox_01 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.c_cateBox_01 > a {
  width: calc(100% / 4);
  display: block;
  color: #000;
  margin: 10px 0;
  border-bottom: solid 1px #c1c1c1;
  position: relative;
}

.c_cateBox_01 > a .txtBox {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

.c_cateBox_02 dl {
  margin: 10px 0;
  border-bottom: solid 1px #c1c1c1;
}

.c_cateBox_02 dl dt {
  float: left;
  width: 18%;
  margin-right: 2%;
}

.c_cateBox_02 dl dd {
  float: left;
  width: 80%;
  word-break: break-all;
}

.c_cateBox_02 dl dd > a {
  display: block;
  color: #000;
}

.cate_xBox a {
  display: block;
  padding: 10px;
  background: #eee;
  margin-bottom: 5px;
}

/* =======================================
	★ページャー
========================================== */

.pager {
  width: auto;
  margin: 0 auto;
  padding-bottom: 100px;
}

.wp-pagenavi {
  clear: both;
  font-size: 14px;
  text-align: center;
}

.wp-pagenavi a,
.wp-pagenavi span {
  display: inline-block;
  width: 35px;
  height: 35px;
  line-height: 2.6;
  border: 1px solid #000000;
  -webkit-transition: ease-out 0.5s;
  transition: ease-out 0.5s;
  color: #000000;
  font-size: 14px;
  margin: 5px;
  vertical-align: top;
  padding: 0px;
  background-color: #fff;
  border-radius: 4px;
}

.wp-pagenavi span.extend {
  border: 1px solid rgba(245, 245, 245, 0);
}

.wp-pagenavi span.current {
  color: #fff;
  background-color: #000000;
  font-size: 14px;
  vertical-align: top;
  text-decoration: none;
}

/* ---------------------------------------------------------------------------
  ★パーツ集:フォーム
--------------------------------------------------------------------------- */

.c_form01 {
  margin-bottom: 50px;
}

.c_form01 table {
  margin-bottom: 30px;
  border-top: 1px solid #ccc;
  width: 100%;
  /* IE */
  /* Edge */
}

.c_form01 table tbody tr {
  border-bottom: 1px solid #afafaf;
}

.c_form01 table tbody tr th {
  vertical-align: top;
  padding: 24px;
  font-size: 16px;
  color: #000000;
  font-weight: bold;
  width: 24.5%;
}

.c_form01 table tbody tr th span {
  margin-left: 10px;
}

.c_form01 table tbody tr td {
  vertical-align: top;
  padding: 24px;
}

.c_form01 table tbody tr td select {
  padding: 0;
  font-size: 14px;
  width: 400px;
  padding: 11px;
}

.c_form01 table tbody tr td label {
  margin-right: 10px;
}

.c_form01 table .inp01,
.c_form01 table .inp02 {
  padding: 5px 10px;
  font-size: 1.4rem;
  border: 1px solid #afafaf;
}

.c_form01 table .inp01 input[type="text"],
.c_form01 table .inp02 input[type="text"] {
  font-size: 1.4rem;
}

.c_form01 table .inp_txtarea {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 1.4rem;
  padding: 10px;
  width: 90%;
  height: 200px !important;
  border: 1px solid #afafaf;
}

.c_form01 table input:-ms-input-placeholder {
  color: #a9a9a9;
}

.c_form01 table input::-ms-input-placeholder {
  color: #a9a9a9;
}

.c_form01 .kojin_wrap {
  background: #fff;
  padding: 5%;
  margin-bottom: 20px;
}

.c_form01 .submit_wrap {
  margin-bottom: 5%;
  text-align: center;
}

.c_form01 .submit_wrap .submit {
  max-width: 340px;
  width: 90%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 10px 0;
  text-align: center;
  margin: auto;
  font-size: 1.6rem;
  cursor: pointer;
}

input::-webkit-input-placeholder {
  color: #a9a9a9;
}

input:-ms-input-placeholder {
  color: #a9a9a9;
}

input::-ms-input-placeholder {
  color: #a9a9a9;
}

input::placeholder {
  color: #a9a9a9;
}

input.short {
  width: 25%;
}

input.middle {
  width: 50%;
}

/* ---------------------------------------------------------------------------
  ★パーツ集:jsPage
--------------------------------------------------------------------------- */

.close {
  width: 48px;
  height: 48px;
  background-color: rgba(0, 0, 0, 0.5);
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
}

.close::before {
  content: "";
  display: block;
  width: 26px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%) rotate(45deg);
  transform: translateY(-50%) translateX(-50%) rotate(45deg);
  z-index: 10;
}

.close::after {
  content: "";
  display: block;
  width: 26px;
  height: 2px;
  background-color: #fff;
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%) rotate(135deg);
  transform: translateY(-50%) translateX(-50%) rotate(135deg);
}

.popup_Box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  background: rgba(0, 0, 0, 0.6);
  z-index: -9;
  opacity: 0;
  top: 0;
  left: 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}

.popup_Box.on {
  z-index: 1;
  opacity: 1;
}

.popup_Box.on .close {
  z-index: 1 !important;
}

.popup_Box .popup_Box_inner {
  position: relative;
  padding: 30px 60px;
  width: 100%;
}

.popup_Box .popup_Box_inner .close {
  position: absolute;
  right: 0;
  top: 0;
  z-index: -9;
}

.popup_Box .popup_Box_inner .popup_Box_cont {
  color: #fff;
}

#js_listItem .is_hidden {
  display: none;
}

#input_plural {
  margin: 10px 0;
}

#input_plural input.form-control {
  display: inline-block;
  color: #555;
}

#input_plural .btn_wrap {
  float: right;
}

#input_plural .pluralBtn {
  width: 30px;
  height: 30px;
  border: 1px solid #ccc;
  background: #fff;
  border-radius: 5px;
  padding: 0;
  margin: 0;
  display: inline-block;
  text-align: center;
}

/* ---------------------------------------------------------------------------
  ★パーツ集:slickPage
--------------------------------------------------------------------------- */

.csl_slider_01 .imgBox img {
  display: block;
  width: 96%;
  margin: 0 auto;
}

.csl_slider_01 .sclick_previmg {
  max-width: 68px;
  width: 5%;
  margin: auto;
  position: absolute;
  z-index: 10;
  left: 17%;
  top: 50%;
  cursor: pointer;
}

.csl_slider_01 .sclick_nextimg {
  max-width: 68px;
  width: 5%;
  margin: auto;
  position: absolute;
  z-index: 10;
  right: 17%;
  top: 50%;
  cursor: pointer;
}

.csl_slider_02 .imgBox img {
  display: block;
  width: 96%;
  margin: 0 auto;
}

.csl_slider_02 .sclick_previmg {
  max-width: 68px;
  width: 5%;
  margin: auto;
  position: absolute;
  z-index: 10;
  left: 0;
  right: 60%;
  top: 50%;
  cursor: pointer;
}

.csl_slider_02 .sclick_nextimg {
  max-width: 68px;
  width: 5%;
  margin: auto;
  position: absolute;
  z-index: 10;
  right: 0;
  left: 60%;
  top: 50%;
  cursor: pointer;
}

.csl_slider_03_wp {
  margin-bottom: 20px;
  background: #00a0b4;
}

.csl_slider_03_wp .img_wrap {
  display: block;
}

.csl_slider_03_wp .img_wrap *:not(img) {
  display: none;
}

/* ---------------------------------------------------------------------------
  ★パーツ集:よくあるご質問
--------------------------------------------------------------------------- */

.c_faq_box_01 .sToggle {
  counter-reset: numb2;
}

.c_faq_box_01 .sToggle dl {
  counter-increment: numb2;
  padding: 10px;
  border-radius: 10px;
  border: solid 1px #0c3380;
  background: #fff;
  margin: 0 0 30px;
}

.c_faq_box_01 .sToggle dl dt {
  padding: 5px 35px 5px 60px;
  font-size: 1.8rem;
  position: relative;
  font-weight: bold;
  color: #0c3380;
  cursor: pointer;
  pointer-events: auto;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  word-break: break-all;
}

.c_faq_box_01 .sToggle dl dt::after {
  content: "";
  width: 13px;
  height: 13px;
  border-top: 2px solid #ff9595;
  border-right: 2px solid #de0101;
  position: absolute;
  top: 45%;
  right: 15px;
  margin: auto;
  -webkit-transform: translateY(-50%) translateX(-50%) rotate(135deg);
  transform: translateY(-50%) translateX(-50%) rotate(135deg);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.c_faq_box_01 .sToggle dl dt::before {
  content: "Q" counter(numb2);
  /* content: "Q.01"; */
  display: block;
  position: absolute;
  font-size: 2rem;
  font-weight: bold;
  color: #008f96;
  top: 47%;
  left: 29px;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-family: "Lora", serif;
}

.c_faq_box_01 .sToggle dl dt.togg::after {
  -webkit-animation: sTog 0.7s;
  animation: sTog 0.7s;
  -webkit-transform: translateY(-20%) translateX(-50%) rotate(315deg);
  transform: translateY(-20%) translateX(-50%) rotate(315deg);
}

.c_faq_box_01 .sToggle dl dd {
  padding: 5px 35px 5px 60px;
  display: none;
  position: relative;
  word-break: break-all;
}

.c_faq_box_01 .sToggle dl dd::before {
  content: "A" counter(numb2);
  /* content: "A.01"; */
  display: block;
  position: absolute;
  font-size: 2rem;
  font-weight: bold;
  color: #da0000;
  top: 0;
  left: 29px;
  -webkit-transform: translate(-50%, 0%);
  transform: translate(-50%, 0%);
  font-family: "Lora", serif;
}

@-webkit-keyframes sTog {
  0% {
    opacity: 1;
    -webkit-transform: translateY(-50%) translateX(-50%) rotate(135deg);
    transform: translateY(-50%) translateX(-50%) rotate(135deg);
  }
  25% {
    opacity: 0;
  }
  50% {
    opacity: 0;
    -webkit-transform: translateY(70%) translateX(-50%) rotate(135deg);
    transform: translateY(70%) translateX(-50%) rotate(135deg);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translateY(70%) translateX(-50%) rotate(315deg);
    transform: translateY(70%) translateX(-50%) rotate(315deg);
  }
  75% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(-20%) translateX(-50%) rotate(315deg);
    transform: translateY(-20%) translateX(-50%) rotate(315deg);
  }
}

@keyframes sTog {
  0% {
    opacity: 1;
    -webkit-transform: translateY(-50%) translateX(-50%) rotate(135deg);
    transform: translateY(-50%) translateX(-50%) rotate(135deg);
  }
  25% {
    opacity: 0;
  }
  50% {
    opacity: 0;
    -webkit-transform: translateY(70%) translateX(-50%) rotate(135deg);
    transform: translateY(70%) translateX(-50%) rotate(135deg);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translateY(70%) translateX(-50%) rotate(315deg);
    transform: translateY(70%) translateX(-50%) rotate(315deg);
  }
  75% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(-20%) translateX(-50%) rotate(315deg);
    transform: translateY(-20%) translateX(-50%) rotate(315deg);
  }
}

.flex_row_reverse.cl50 > li:not(:nth-child(2n)) {
  margin-right: 0%;
  margin-left: 4%;
}

/* ---------------------------------------------------------------------------
  header01
--------------------------------------------------------------------------- */

header > .inner01 {
  box-shadow: 3px 3px 5px #0202213d;
  border-radius: 50em;
  padding: 0px 26px;
  background: #fff;
}

@media (max-width: 1270px) {
  .inner01 {
    width: 94%;
  }

  .header01 h1 img {
    width: 180px;
  }
}

@media (max-width: 1155px) {
  header .h_btn span {
    display: none;
  }

  header .h_btn {
    display: flex;
  }

  header .h_btn a {
    width: 40px;
    height: 40px;
    padding: 0;
  }
  header .h_btn a > span {
    display: none;
  }

  header .h_btn02 a {
    background: url(../img/h_contact.svg) no-repeat center top 14px/1em,
      linear-gradient(to right, #120060, #0339e5);
    width: 40px;
    height: 40px;
    padding: 0;
  }

  .dropdown-menu {
    left: -80px;
  }

  .dropdown-menu > li > a {
    background: none;
    width: 13em;
    height: auto;
    padding: 10px;
  }
}
.dropdown-menu {
  position: absolute;
  top: 100%;
  /* メニューを初めは非表示にする */
  left: -70px;
  background-color: #fff;
  list-style: none;
  padding: 0;
  opacity: 0;
  /* メニューを初めは透明にする */
  transform: translateY(10px);
  /* メニューを少し上に配置しておく */
  transition: opacity 0.3s, transform 0.3s;
  /* アニメーションの速度を調整できます */
  z-index: 5;
  background: #262626;
  padding: 10px 12px 9px;
  border-radius: 1em;
  /* box-shadow: 3px 5px 6px #18192512; */
  /* border: 1px solid #e8e8e8; */
}

.dropdown-menu li {
  text-align: center;
  overflow: hidden;
  height: 0;
  transition: 0.3s;
}

.dropdown-menu li a {
  background: none;
  padding: 10px 3px;
  border-radius: 0;
  font-size: 1.4rem;
  /* border-bottom: 1px solid #fff; */
  color: #f5f5f5;
  width: 190px;
}

/* ホバー時にドロップダウンメニューを表示 */
.dropdown-toggle:hover + .dropdown-menu {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.3s, transform 0.3s;
  z-index: 99;
}

nav a:hover {
  opacity: 0.7;
}

.nav a {
  color: #1e1e1e;
  display: block;
  position: relative;
  padding: 21px 0 21px;
  letter-spacing: 0.05em;
  line-height: 120%;
  text-align: center;
}

.h_btn > a {
  width: 95px;
  padding-top: 47px;
  background: url(../img/h_icon01.png) no-repeat center top 13px;
  background-size: 28px;
  font-size: 13px;
  font-weight: 500;
}
.nav a span {
  display: block;
}

.nav > ul > li:nth-child(-n + 5) a span:nth-child(1) {
  color: #101010;
  position: relative;
}

.nav > ul {
  display: flex;
  align-items: center;
}

.nav > ul > li {
  margin-left: 29px;
}
.dropdown-toggle-box {
  position: relative;
}
/* ホバー時にドロップダウンメニューを表示 */
.dropdown-toggle:hover + .dropdown-menu {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.3s, transform 0.3s;
}

.dropdown-toggle-box:hover .dropdown-menu {
  opacity: 1;
  /* メニューを表示する際に不透明にする */
  transform: translateY(0);
  /* メニューを下から上に移動させる */
  transition: opacity 0.3s, transform 0.3s;
  z-index: 9;
}

.dropdown-toggle-box:hover .dropdown-menu li {
  overflow: visible;
  height: auto;
}
.c_imgHiritu {
  position: relative;
  display: block;
  padding-bottom: 20%;
  overflow: hidden;
}
.c_imgHiritu > img {
  position: absolute;
  width: 100%;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  border-radius: 0;
}

.footer01 ul {
  display: flex;
}

.footer01 ul li {
  margin: 0 15px;
  width: 50%;
  text-align: center;
}

.footer02 > div:nth-child(1) {
  display: flex;
  justify-content: space-between;
  padding: 50px 0 30px;
}

.footer02 .f_logo {
  width: 300px;
}

.footer02 .f_nav {
  display: flex;
}

.footer02 .f_nav a {
  color: #dbfc1d;
}

.footer02 .f_nav ul {
  margin-left: 42px;
}
.footer02 .f_nav li {
  margin-bottom: 10px;
}
.footer02 .f_nav .sub {
  font-size: 13px;
  margin-bottom: 0px;
}

.footer02 .f_nav .sub a {
  color: #ebf3ff;
  font-weight: 500;
}

.header02 > div {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

header .inner,
.mv .inner {
  max-width: calc(100% - 130px) !important;
}

.header02 {
  background: url(../img/bg_header.jpg) bottom center;
  color: #fff;
  padding: 5px 0;
}

.header02 span {
  margin-left: 9px;
}

.home03 .inner {
  max-width: 1020px !important;
}

.inner {
  width: 90%;
}
@media (max-width: 1080px) {
  .nav > ul > li {
    margin-left: 17px;
  }
  .nav a {
    margin-top: 5px;
  }
  header .h_btn {
    transform: translate(0px, -10px);
  }
  .h_btn:before {
    top: 12px;
  }
  .footer01_dec02 {
    left: -20px;
    transform: scale(0.9);
  }
}

@media (min-width: 1500px) {
  .mv .inner .img {
    margin: 3vw auto 7vw;
  }
  .mv .main_img > img {
    width: 85%;
  }
}
.pc_ceneter {
  text-align: center;
}
.cl33_02,
.cl50_02 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.cl33_02 li {
  width: 32.5%;
}

.cl50_02 li {
  width: 49.4%;
}
.home02 ul {
  display: flex;
  justify-content: center;
  gap: 22px;
}
.footer01 > .inner {
  display: flex;
  max-width: 917px !important;
  justify-content: center;
}

.footer01 > div > div:nth-child(1) {
  border-right: 1px solid #dbb6d2;
  margin-right: 24px;
  padding-right: 35px;
}

.btn_r:before {
  border-radius: 50em 0 0 50em;
}

.h_btn02:before {
  border-radius: 0 50em 50em 0;
}

.h_btn:before {
  content: "";
  background: #f9f7f7;
  width: 112%;
  height: 45px;
  position: absolute;
  left: -1px;
  top: 32px;
}

.sdgsTit {
  display: flex;
  align-items: baseline;
}
.h_btn.h_btn02 a {
  background: url(../img/h_icon02.png) no-repeat center top 15px;
  background-size: 34px;
}
#esg #esg01 img {
  max-width: 536px;
  margin: auto;
}

.btn01:hover {
  filter: contrast(1.2);
}

.home03 a:hover,
.footer02 .f_nav a:hover {
  opacity: 0.7;
}
