@charset "utf-8";
/*----------------------------------------------------------------------------------------------
	page 共通
----------------------------------------------------------------------------------------------*/
body {
  /*animation: fadeIn 2s ease 0s 1 normal;
  -webkit-animation: fadeIn 2s ease 0s 1 normal;*/
}
/* #page_wrap {
  padding-top: 20px;
  margin-bottom: 30vw;
} */
.is_scroll #page_wrap {
  padding-top: 96px;
}

.container {
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 768px) {
  .container {
    /*width: 750px;*/
    width: 710px;
  }
}
@media (min-width: 992px) {
  .container {
    /*width: 984px;*/
    width: 945px;
  }
}
@media (min-width: 1100px) {
  .container {
    width: 1080px;
  }
}
@media (min-width: 1240px) {
  .container {
    width: 1140px;
  }
}
.mt_sec_block {
  margin-top: 120px;
}

/*PCで表示させないセレクタ*/
#sp_header,
.tel-btn_sp{
  display: none;
}
.pc_hidden {
  display: none;
}

@media screen and (max-width:768px) {
  #page_wrap {
  margin-bottom: 30px;
  }
  .is_scroll #page_wrap {
    padding-top: 60px;
  }
  .mt_sec_block {
    margin-top: 60px;
  }
}
@font-face {
  font-family: 'Bodoni-Book';
  src: url('Bodoni-Book.woff2') format('woff2'),url('Bodoni-Book.woff') format('woff');
  font-style: normal;
  font-weight: normal;
}
.iot_kouzouji {
	margin-right: auto;
	display: block;
	background-color: silver;
	width: 100%;
}
/*----------------------------------------------------------------------------------------------
	base
----------------------------------------------------------------------------------------------*/
.page_title {
  margin: 40px auto 40px;
  font-size: 26px;
  font-weight: normal;
  letter-spacing: .2em;
  color: #373374;
  background : linear-gradient(90deg, rgba(0, 132, 138, 1) 5.89%, rgba(55, 51, 116, 1) 59.8%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  text-align: center;
}
.sec__block {
  max-width: 1110px;
  margin-left: auto;
  margin-right: auto;
}
.sec__block_outline {
  max-width: 900px;
  margin: 0 auto 60px;
}
@media screen and (max-width:768px) {
  .sec__block_outline {
    margin: 0 15px 30px;
  }
}
table.tbl_outline {
  width: 100%;
  margin: 0 0 10px;
  border-top: 1px solid #e4e4e4;
  border-collapse: separate;
  border-spacing: 0;
  line-height: 1.8;
  font-size: 13px;
}
table.tbl_outline th {
  width: 200px;
  padding: 10px 15px;
  white-space: nowrap;
  border-bottom: 1px solid #e4e4e4;
  border-right: 1px dotted #e4e4e4;
  background-color: #f3f3f3;
  text-align: left;
  color: #222;
  font-weight: normal;
}
table.tbl_outline td {
  padding: 10px 5px 10px 15px;
  line-height: 140%;
  border-bottom: 1px solid #e4e4e4;
  color: #222;
}
p.notes {
  line-height: 140%;
  font-size: 10px;
}
table.tbl_outline th.yokoku_txt {
  font-size: 130%;
}
.btn_center {
  text-align: center;
  margin-bottom: 60px;
  padding-top: 50px;
}
.btn_center_map {
  text-align: center;
  margin-bottom: 60px;
  padding-top: 20px;
}
ul.page_navi_btn2.map_navi {
  padding: 50px 0 0px;
  text-align: center;
}
.map {
  text-align: center;
  position: relative;
}
.map img {
  max-width: 100%;
  height: auto;
}
.map_border {
  border: 1px solid #ccc;
}
.map02 {
  max-width: 540px;
  margin: 0 auto 30px;
}
.map_t01 {
  color: #3C4955;
  font-size: 22px;
  margin-bottom: .5em;
}
.map_t02 {
  margin-bottom: 1em;
}
.map_t03 {
/*
	font-size: 16px;
	color: #8C2126;
  margin-bottom: 2em;
*/
	/* max-width: 700px; */
	font-size: 18px;
	color: #b36060;
	/* background: #e9e9e9; */
  margin: 0 auto 50px;
	/* padding: .7em; */
}
.map_t04 {
  color: #5eb1ac;
  font-size: 30px;
  margin-bottom: .5em;
}
.map_t05 {
  margin-bottom: 1em;
}
.base_map {
  max-width: 900px;
  margin: 0 auto 50px;
}
.map_zoom {
  max-width: 600px;
  margin: 0 auto 30px;
}
.map_zoom01 {
  max-width: 500px;
  margin: 0 auto;
}
.map_zoom_box {
  display: flex;
  justify-content: space-between;
}
.map_zoom_box_in01 {
  width: 50%;
}
.map_zoom_box_in02 {
  width: 48%;
}
.map_guide_txt {
  color: #fff;
  background: #bd1224;
  font-size: 19px;
  font-weight: 700;
  /* margin-top: -.2em; */
  margin-bottom: 10px;
  padding: 0.05em 5px 0.15em;
}
.map_info {
	font-size: 24px;
	text-align: center;
	color: #fff;
	padding: .4em 1em .5em;
/*	max-width: 700px;*/
	margin: 50px auto 30px;
	background : -moz-linear-gradient(0% 50% 0deg,rgba(0, 64, 130, 1) 0%,rgba(1, 31, 92, 1) 100%);
  background : -webkit-linear-gradient(0deg, rgba(0, 64, 130, 1) 0%, rgba(1, 31, 92, 1) 100%);
  background : -webkit-gradient(linear,0% 50% ,100% 50% ,color-stop(0,rgba(0, 64, 130, 1) ),color-stop(1,rgba(1, 31, 92, 1) ));
  background : -ms-linear-gradient(0deg, rgba(0, 64, 130, 1) 0%, rgba(1, 31, 92, 1) 100%);
  -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr='#004082', endColorstr='#011F5C' ,GradientType=0)";
  background : linear-gradient(90deg, rgba(0, 64, 130, 1) 0%, rgba(1, 31, 92, 1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#004082',endColorstr='#011F5C' , GradientType=1);
}
.outline_ttl2 {
  font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 16px;
  margin-bottom: 5px;
  color: #4e5565;
}
.outline_atte {
  color: #333;
  font-size: 12px;
}
.gmapBtn {
  display: block;
  background: #fff;
  font-size: 15px;
  text-align: center;
  color: #383374 !important;
  border: 1px solid #383374;
  margin: 0 auto 40px;
  padding: 15px;
  width: 100%;
  max-width: 300px;
  -webkit-transition: all 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: all 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
a:hover.gmapBtn {
  background: #383374;
  color: #fff !important;
}
.map_jyohoukan {
  max-width: 900px;
  margin: 0 auto 50px;
}
.yokoku {
  margin-top: 40px
}
.yokoku ._head {
  margin-bottom: .75em;
  padding: .5em;
  border: 1px solid #000;
  text-align: center;
  font-size: 18px;
  letter-spacing: .1em
}
.yokoku ._text {
  text-align: justify;
  margin-bottom: 40px;
}
/*----------------------------------------------------------------------------------------------
	共通タイトル
----------------------------------------------------------------------------------------------*/
.page_ttl {
  text-align: center;
  font-size: 30px;
  line-height: 1.2;
  color: #0A0000;
  padding: 60px 15px;
  position: relative;
}

.page_ttl.page_ttl_white::after {
  background: #fff;
}
.lead_lv-02 {
  line-height: 2;
  margin-top: 2em;
}

/* 下層ページ　circleタイトル */

@media screen and (max-width:768px) {
  .page_ttl {
    font-size: 24px;
    padding: 20px 15px;
  }
  .page_ttl img {
    height: 20px;
    width: auto;
  }
  .page_ttl::after {
    width: 60px;
    left: 50%;
    bottom: 0;
  }
  .lead_lv-02 {
    line-height: 2;
    margin-top: 1em;
  }
}
/*----------------------------------------------------------------------------------------------
	プランニング
----------------------------------------------------------------------------------------------*/
.page_title_set {
  background: url(../../img/05plan/plan_bg01.jpg);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  height: 380px;
  width: 100%;
}
.plan_sec01 {
  text-align: center;
  margin: -60px auto 0;
}
.plan_ttl_lv02 {
	padding-top:80px;
  font-size: 40px;
  margin-top: .8em;
  line-height: 1.7;
  letter-spacing: .12em;
}
.plan_txt02 {
  font-size: 16px;
  margin-top: 1.2em;
  line-height: 2;
  letter-spacing: .05em;
}
.plan_nav_sec {
  background: url(../../img/05plan/plan_bg02.jpg);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  padding: 150px 0;
  margin-top: 100px;
}
.plan_nav {
  max-width: 790px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 57px 57px;
}
.plan_nav li {
}
.plan_nav a {
  display: block;
  background: rgba(255, 255, 255, .8);
}
.btn_soon {
  background: rgba(255, 255, 255, .8);
}
.plan_nav a:hover {
  background: rgba(255, 255, 255, 1);
}
.plan_sec_madori {
  text-align: center;
  padding: 0 0 80px;
}
.plan_midashi {
  background: #040000;
}
.plan_point {
  font-size: 29px;
  margin-top: 60px;
  line-height: 2;
  letter-spacing: .05em;
  font-weight: normal;
}
.madori_zu_set {
  display: flex;
  max-width: 930px;
  margin: 80px auto 0;
  justify-content: space-between;
}
.bg_mystyle {
  background: url(../../img/05plan/plan_bg03.jpg);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  text-align: center;
  padding: 100px 15px;
  margin-bottom: 60px;
}
.banner_mystyle588 {
  max-width: 588px;
  margin: 0 auto;
}
  .page_title_square {
	  position:relative;
  }
/* sp
---------------------------------------------------------------------- */
@media screen and (max-width:768px) {
  .page_title_set {
    background: url(../../img/05plan/plan_bg01_sp.jpg);
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
    height: 330px;
    width: 100%;
  }
  .plan_sec01 {
    text-align: center;
    margin: -60px auto 0;
  }
  .page_title_square {
    width: 40%;
    margin: -30px auto 0 auto;
  }
  .plan_ttl_lv02 {
	  padding-top:40px;
    font-size: 25px;
    margin-top: 1em;
    line-height: 1.5;
    letter-spacing: .12em;
  }
  .plan_txt02 {
    font-size: 15px;
    margin-top: 1.5em;
  }
  .plan_nav_sec {
    background: url(../../img/05plan/plan_bg02.jpg);
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
    padding: 60px 0;
    margin-top: 60px;
  }
  .plan_nav {
    width: 75%;
    margin: 0 auto;
    gap: 20px;
  }
  .plan_sec_madori {
    padding: 0 0 60px;
  }
  .plan_midashi {
    padding: 0 5%;
  }
  .plan_point {
    font-size: 20px;
    margin-top: 30px;
    line-height: 1.6;
  }
  .madori_zu_set {
    display: flex;
    max-width: 930px;
    margin: 30px auto 0;
    flex-direction: column-reverse;
  }
  .madori_zu {
    width: 90%;
    margin: 0 auto;
  }
  .madori_zu_txt {
    width: 70%;
    margin: 30px auto 0;
  }
  .bg_mystyle {
    background: url(../../img/05plan/plan_bg03.jpg);
    background-repeat: no-repeat;
    background-position: top center;
    background-size: cover;
    text-align: center;
    padding: 50px 30px;
    margin-bottom: 50px;
  }
}


/* ===================================================================
//animation
=================================================================== */
.pageHddAnim {
  opacity: 0 !important;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}
.pageHddAnim.is_view {
  opacity: 1 !important;
}
.fadeAnim {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.fadeAnim.is_view {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}
.fadeAnimB {
  opacity: 0;
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.fadeAnimB.is_view {
  opacity: 1;
}
.fadeAnimC {
  opacity: 1;
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.fadeAnimC.is_hide {
  opacity: 0;
}
.fadeAnimRightIn {
  opacity: 0;
  -webkit-transform: translateX(20px);
  transform: translateX(20px);
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.fadeAnimRightIn.is_view {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}
.fadeAnimLeftIn {
  opacity: 0;
  -webkit-transform: translateX(-20px);
  transform: translateX(-20px);
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.fadeAnimLeftIn.is_view {
  opacity: 1;
  -webkit-transform: translateX(0);
  transform: translateX(0);
}
.delay01 {
-webkit-transition-delay: .1s !important;
transition-delay: .1s !important;
}
.delay02 {
-webkit-transition-delay: .2s !important;
transition-delay: .2s !important;
}
.delay03 {
-webkit-transition-delay: .3s !important;
transition-delay: .3s !important;
}
.delay04 {
  -webkit-transition-delay: .4s !important;
  transition-delay: .4s !important;
}
.delay05 {
  -webkit-transition-delay: .5s !important;
  transition-delay: .5s !important;
}
.delay06 {
-webkit-transition-delay: .6s !important;
transition-delay: .6s !important;
}
.delay07 {
-webkit-transition-delay: .7s !important;
transition-delay: .7s !important;
}
.delay08 {
-webkit-transition-delay: .8s !important;
transition-delay: .8s !important;
}
.delay09 {
-webkit-transition-delay: .9s !important;
transition-delay: .9s !important;
}
.delay015 {
  -webkit-transition-delay: .15s !important;
  transition-delay: .15s !important;
}
.delay025 {
  -webkit-transition-delay: .25s !important;
  transition-delay: .25s !important;
}
.delay035 {
  -webkit-transition-delay: .35s !important;
  transition-delay: .35s !important;
}
.delay075 {
  -webkit-transition-delay: .75s !important;
  transition-delay: .75s !important;
}
.delay1 {
  -webkit-transition-delay: 1s !important;
  transition-delay: 1s !important;
}
.delay15 {
  -webkit-transition-delay: 1.5s !important;
  transition-delay: 1.5s !important;
}

.animImg {
  position: relative;
  overflow: hidden;
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.animImg * {
  -webkit-transition: all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 600ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.animImg::before {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 5;
  background: #000;
}
.animImg.is_view::before {
  -webkit-animation: animImgMask 1s ease;
  -moz-animation: animImgMask 1s ease;
  animation: animImgMask 1s ease;
} @-webkit-keyframes animImgMask {
0%   {
  top: 100%;
}
25% {
  top: 0;
}
75% {
  top: 0;
}
100% {
  bottom: 100%;
}
} @-moz-keyframes animImgMask {
0%   {
  top: 100%;
}
25% {
  top: 0;
}
75% {
  top: 0;
}
100% {
  bottom: 100%;
}
} @keyframes animImgMask {
0%   {
  top: 100%;
}
25% {
  top: 0;
}
75% {
  top: 0;
}
100% {
  bottom: 100%;
}
}
.animImg img {
  opacity: 0;
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  -webkit-transition: all 1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition:         all 1s cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.animImg.is_view img {
  opacity: 1;
  -webkit-transform: scale(1);
  transform: scale(1);
}
/* 光らせるためのstyle */
.shine{
position: relative;
overflow: hidden;
display: block;
}
/* 光の疑似要素 */
.shine::before{
content: "";
animation: shine 3s cubic-bezier(0.25, 0, 0.25, 1) infinite;
background-color: #fff;
width: 140%;
height: 100%;
transform: skewX(-45deg);
top: 0;
left: -160%;
opacity: 0.5;
position: absolute;
}
/* 光の動き */
@keyframes shine{
0% {
  left: -160%;
  opacity: 0;
}
70% {
  left: -160%;
  opacity: 0.5;
}
71% {
  left: -160%;
  opacity: 1;
}
100% {
  left: -20%;
  opacity: 0;
}
}
/**********
//fadeText
**********/
.fadeText > span {
opacity: 0;
-webkit-transition: all 2s ease;
transition: all 2s ease;
}
.fadeText > span.is_view {
opacity: 1;
}
.fadeText > span:nth-child(3n+1) {
-webkit-transition-delay: .15s;
transition-delay: .15s;
}
.fadeText > span:nth-child(2n) {
-webkit-transition-delay: .3s;
transition-delay: .3s;
}