@charset "utf-8";
/*
Theme Name: heartful-taxi - WEB SITE
Theme URI: 
Description: heartful-taxi
Version: 1.0
Author: heartful-taxi
Author URI: 
Tags: heartful-taxi
*/



/* 基本設定 */

html { overflow-y:scroll; }

html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, caption, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video 
{
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
	display:block;
}

body {line-height:1; color:#1f1512; }
article,aside,details,figcaption,figure, footer,header,hgroup,menu,nav,section { display:block; }
body {font-family: -apple-system, BlinkMacSystemFont, "メイリオ", Meiryo, "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;}
body:lang(en) {font-family: -apple-system, BlinkMacSystemFont, Meiryo, YuGothic, Hiragino Kaku Gothic ProN, Verdana, sans-serif;}


html,body { height:100%; }

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

/* ------------------------------- */


/*  img  */

img { border-width:0px; vertical-align:text-bottom; }
.img { margin:0; padding:0; clear:both; font-size:0px; line-height:0px; vertical-align:text-bottom; }

/* ------------------------------- */


/*  Link  */

a:link { color:#00a0e9; text-decoration:underline; }
a:visited { color:#00a0e9; text-decoration:underline; }
a:hover { color:#c53335; text-decoration:underline; }
a:active { color:#c53335; text-decoration:underline; }

/* ------------------------------- */


/* clearfix */

.clearfix:after {
  content: "."; 
  display: block; 
  height: 0; 
  clear: both; 
  visibility: hidden;
}

.clearfix { display: inline-table; }

/* Hides from IE-mac \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
/* End hide from IE-mac */

/* ------------------------------- */


/* load */

.load_box {
	width:100%;
	height: 100%;
	display:block;
	margin:0px;
	padding:0px;
	box-sizing: border-box;
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 500;
	clear:both;
	font-size:0px;
	line-height:0px;
	overflow:hidden;
	background: #fff;
}

/* ------------------------------------------------- load  ----*/



/*  header  */

.header {
	width:100%;
	height:117px;
	margin:0px;
	padding:0px;
	box-sizing:border-box;
	clear:both;
	display:inline-block;
	word-wrap:break-word;
	overflow-wrap:break-word;
	position:fixed;
	top:0px;
	left:0px;
	z-index:50;
    background-color: rgba(255,255,255,1);
}

.header_bg {
background-color: rgba(255,255,255,1);
}

.head_logo {
	width:180px;
	height:32px;
	margin:0px 0px 0px 0px;
	padding:0px;
	box-sizing:border-box;
	float:left;
	display:inline-block;
	word-wrap:break-word;
	overflow-wrap:break-word;
	position:absolute;
	top:41px;
	left:33px;
	text-align:center;
}

.head_logo a {
	display:block;
	width:180px;
	height:32px;
	margin:0px auto 0px auto;
	padding:0px;
	clear:both;
	position:relative;
}

.head_logo a img {
	width:100%;
	height:auto;
}

/* ------------------------------- */





/*  jp menu  ----------------------------------------------*/


.jp_menu {
	width:724px;
	height:117px;
	margin:0px auto;
	padding:0px;
	position: absolute;
	clear: both;
	top: 0px;
	right: 0px;
}

.jp_menu ul{
width:100%;
margin:0;
padding:0;
position:relative;
}

.jp_menu ul li {
  list-style: none;
  margin:0px;
  padding:0px;
  box-sizing:border-box;
  font-size:18px;
  letter-spacing:1px;
  line-height:117px;
  text-align:center;
  color: #fff;
  font-weight: bold;
  font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
  background: linear-gradient(#eef6fe, #eef6fe) left 0px bottom 0px / 100% 0px no-repeat;
  transition: background-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.jp_menu ul li:hover {
	background-position: left 0px bottom 0px;
	background-size: 100% 100%;
}

.menu1 {
  position: absolute;
  top: 0px;
  right: 910px;
  width:104px;
  height: 117px;
}

.menu2 {
  position: absolute;
  top: 0px;
  right: 770px;
  width:140px;
  height: 117px;
}

.menu3 {
  position: absolute;
  top: 0px;
  right: 666px;
  width:104px;
  height: 117px;
}

.menu4 {
  position: absolute;
  top: 0px;
  right: 562px;
  width:104px;
  height: 117px;
}

.menu5 {
  position: absolute;
  top: 0px;
  right: 438px;
  width:124px;
  height: 117px;
}

.menu6 {
  position: absolute;
  top: 0px;
  right: 298px;
  width:140px;
  height: 117px;
}

.jp_menu ul li .menu_link_R {
  color: #1f1512;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));
  background-position: calc(100% - 14px) calc(100% - 36px);
  background-size: 0px 1px;
  background-repeat: no-repeat;
  transition: background-size .3s;
}

.jp_menu ul li:hover .menu_link_R {
  color: #3c88e4;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));  
  background-position: 14px calc(100% - 36px);
  background-size: calc(100% - 28px) 1px;
  background-repeat: no-repeat;  
}

.jp_menu ul li .menu_link_X {
  color: #1f1512;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));
  background-position: calc(100% - 14px) calc(100% - 36px);
  background-size: 0px 1px;
  background-repeat: no-repeat;
  transition: background-size .3s;
}

.jp_menu ul li:hover .menu_link_X {
  color: #3c88e4;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));  
  background-position: 14px calc(100% - 36px);
  background-size: calc(100% - 28px) 1px;
  background-repeat: no-repeat;  
}

.jp_menu ul li p {
  position:fixed;
  top: 117px;
  right: 50px;
  width: 1160px;
  height: 0px;
  z-index:10;
  background-color: rgba(255,255,255,0);
  transition: 0.3s;
}

.jp_menu ul li p.he_height1 { height: 0px; }
.jp_menu ul li p.he_height2 { height: 0px; }

.jp_menu ul li p span {
  position:fixed;
  top: 137px;
  right: 50px;
  width: 1160px;
  height: 0px;
  margin: 0px 0px 0px 0px;
  padding: 0px 0px 0px 0px;
  box-sizing: border-box;
  z-index:10;
  background-color: rgba(255,255,255,0);
  border-radius: 20px;
  transition: 0.3s;
}

.jp_menu ul li p.he_height1 span { height: 0px; }
.jp_menu ul li p.he_height2 span { height: 0px; }


.jp_menu ul li:hover p {
  position:fixed;
  top: 117px;
  right: 50px;
  width: 1160px;
  height: 260px;
  z-index:10;
  background-color: rgba(255,255,255,0);
}

.jp_menu ul li:hover p.he_height1 { height: 210px; }
.jp_menu ul li:hover p.he_height2 { height: 260px; }

.jp_menu ul li:hover p span {
  position:fixed;
  top: 137px;
  right: 50px;
  width: 1160px;
  height: 260px;
  margin: 0px 0px 0px 0px;
  padding: 0px 0px 0px 0px;
  box-sizing: border-box;  
  z-index:10;
  background-color: rgba(255,255,255,1);
  border-radius: 20px;  
}

.jp_menu ul li:hover p.he_height1 span { height: 190px; }
.jp_menu ul li:hover p.he_height2 span { height: 260px; }


.jp_menu ul li p span .menu_btn_link {
  position:relative;
  width: 360px;
  height: 0px;
  margin: 20px 0px 0px 20px;
  padding: 0px;
  box-sizing: border-box;
  text-decoration: none;
  visibility: hidden;
  display: block;
  float: left;
  text-align: left;
  background-color: rgba(161,238,255,0);
  overflow: hidden;
  transition: 0.3s;
}

.jp_menu ul li:hover p span .menu_btn_link {
  position:relative;
  width: 360px;
  height: 60px;
  margin: 20px 0px 0px 20px;
  padding: 0px;
  box-sizing: border-box; 
  text-decoration: none;  
  visibility: visible;
  display: block;
  float: left;
  background-color: rgba(161,238,255,0);
  border: solid 0px #1f1512;
  border-bottom-width: 1px;
  overflow: hidden;
  transition: 0.3s;
  transform: translate3d(0, 0, 0);  
}

.jp_menu ul li:hover p span .menu_btn_link:hover {
  border: solid 0px #3c88e4;
  border-bottom-width: 1px;
  background-color: rgba(161,238,255,0);  
}

.jp_menu ul li p span .menu_btn_link em {
  position:relative;
  width: 360px;
  height: 0px;
  margin: 0px;
  padding: 22px 0px 0px 10px;
  box-sizing: border-box;
  text-decoration: none;
  visibility: hidden;
  display: block;
  text-align: left;
  overflow: hidden;
  transition: 0.1s;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: 1px;
  font-style: normal;
  font-weight: bold;
  color: #1f1512;
  font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif; 
  background: url("img/he_migi_704x682.svg") no-repeat;
  background-size: 14px 14px;
  background-position: right 15px top 25px;
}

.jp_menu ul li:hover p span .menu_btn_link em {
  position:relative;
  width: 360px;
  height: 60px;
  margin: 0px;
  padding: 22px 0px 0px 10px;
  box-sizing: border-box;
  text-decoration: none;
  visibility: visible;
  display: block;
  text-align: left;
  overflow: hidden;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: 1px;
  font-style: normal;
  color: #1f1512;
  font-weight: bold;
  font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif; 
  transition: 0.3s;
  background: url("img/he_migi_704x682.svg") no-repeat;
  background-size: 14px 14px;
  background-position: right 15px top 25px;  
}

.jp_menu ul li:hover p span .menu_btn_link:hover em {
color: #3c88e4;
background: url("img/he_migi2_704x682.svg") no-repeat;
background-size: 14px 14px;
background-position: right 15px top 25px;
}


.jp_menu * {
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -ms-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}


/* -----------------------------------------------------------------------------  jp menu --- */







/*  max-width:1400px  */
@media only screen and (max-width:1400px) {


.jp_menu {
	width:724px;
	height:117px;
	margin:0px auto;
	padding:0px;
	position: absolute;
	clear: both;
	top: 0px;
	right: 0px;
}

.jp_menu ul{
width:100%;
margin:0;
padding:0;
position:relative;
}

.jp_menu ul li {
  list-style: none;
  margin:0px;
  padding:0px;
  box-sizing:border-box;
  font-size:14px;
  letter-spacing:1px;
  line-height:117px;
  text-align:center;
  color: #fff;
  font-weight: bold;
  font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
  background: linear-gradient(#eef6fe, #eef6fe) left 0px bottom 0px / 100% 0px no-repeat;
  transition: background-size .3s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.jp_menu ul li:hover {
	background-position: left 0px bottom 0px;
	background-size: 100% 100%;
}

.menu1 {
  position: absolute;
  top: 0px;
  right: 810px;
  width:84px;
  height: 117px;
}

.menu2 {
  position: absolute;
  top: 0px;
  right: 690px;
  width:120px;
  height: 117px;
}

.menu3 {
  position: absolute;
  top: 0px;
  right: 606px;
  width:84px;
  height: 117px;
}

.menu4 {
  position: absolute;
  top: 0px;
  right: 522px;
  width:84px;
  height: 117px;
}

.menu5 {
  position: absolute;
  top: 0px;
  right: 418px;
  width:104px;
  height: 117px;
}

.menu6 {
  position: absolute;
  top: 0px;
  right: 298px;
  width:120px;
  height: 117px;
}

.jp_menu ul li .menu_link_R {
  color: #1f1512;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));
  background-position: calc(100% - 14px) calc(100% - 36px);
  background-size: 0px 1px;
  background-repeat: no-repeat;
  transition: background-size .3s;
}

.jp_menu ul li:hover .menu_link_R {
  color: #3c88e4;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));  
  background-position: 14px calc(100% - 36px);
  background-size: calc(100% - 28px) 1px;
  background-repeat: no-repeat;  
}

.jp_menu ul li .menu_link_X {
  color: #1f1512;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));
  background-position: calc(100% - 14px) calc(100% - 36px);
  background-size: 0px 1px;
  background-repeat: no-repeat;
  transition: background-size .3s;
}

.jp_menu ul li:hover .menu_link_X {
  color: #3c88e4;
  display:block;
  width: 100%;
  padding:0px 0px 0px 0px;
  box-sizing:border-box;
  text-decoration:none;
  background: linear-gradient(rgba(60,136,228,1), rgba(60,136,228,1));  
  background-position: 14px calc(100% - 36px);
  background-size: calc(100% - 28px) 1px;
  background-repeat: no-repeat;  
}

.jp_menu ul li p {
  position:fixed;
  top: 117px;
  right: 10px;
  width: 980px;
  height: 0px;
  z-index:10;
  background-color: rgba(255,255,255,0);
  transition: 0.3s;
}

.jp_menu ul li p.he_height1 { height: 0px; }
.jp_menu ul li p.he_height2 { height: 0px; }

.jp_menu ul li p span {
  position:fixed;
  top: 137px;
  right: 10px;
  width: 980px;
  height: 0px;
  margin: 0px 0px 0px 0px;
  padding: 0px 0px 0px 0px;
  box-sizing: border-box;
  z-index:10;
  background-color: rgba(255,255,255,0);
  border-radius: 20px;
  transition: 0.3s;
}

.jp_menu ul li p.he_height1 span { height: 0px; }
.jp_menu ul li p.he_height2 span { height: 0px; }


.jp_menu ul li:hover p {
  position:fixed;
  top: 117px;
  right: 10px;
  width: 980px;
  height: 260px;
  z-index:10;
  background-color: rgba(255,255,255,0);
}

.jp_menu ul li:hover p.he_height1 { height: 210px; }
.jp_menu ul li:hover p.he_height2 { height: 260px; }

.jp_menu ul li:hover p span {
  position:fixed;
  top: 137px;
  right: 10px;
  width: 980px;
  height: 260px;
  margin: 0px 0px 0px 0px;
  padding: 0px 0px 0px 0px;
  box-sizing: border-box;  
  z-index:10;
  background-color: rgba(255,255,255,1);
  border-radius: 20px;  
}

.jp_menu ul li:hover p.he_height1 span { height: 190px; }
.jp_menu ul li:hover p.he_height2 span { height: 260px; }


.jp_menu ul li p span .menu_btn_link {
  position:relative;
  width: 300px;
  height: 0px;
  margin: 20px 0px 0px 20px;
  padding: 0px;
  box-sizing: border-box;
  text-decoration: none;
  visibility: hidden;
  display: block;
  float: left;
  text-align: left;
  background-color: rgba(161,238,255,0);
  overflow: hidden;
  transition: 0.3s;
}

.jp_menu ul li:hover p span .menu_btn_link {
  position:relative;
  width: 300px;
  height: 60px;
  margin: 20px 0px 0px 20px;
  padding: 0px;
  box-sizing: border-box; 
  text-decoration: none;  
  visibility: visible;
  display: block;
  float: left;
  background-color: rgba(161,238,255,0);
  border: solid 0px #1f1512;
  border-bottom-width: 1px;
  overflow: hidden;
  transition: 0.3s;
  transform: translate3d(0, 0, 0);  
}

.jp_menu ul li:hover p span .menu_btn_link:hover {
  border: solid 0px #3c88e4;
  border-bottom-width: 1px;
  background-color: rgba(161,238,255,0);  
}

.jp_menu ul li p span .menu_btn_link em {
  position:relative;
  width: 300px;
  height: 0px;
  margin: 0px;
  padding: 22px 0px 0px 10px;
  box-sizing: border-box;
  text-decoration: none;
  visibility: hidden;
  display: block;
  text-align: left;
  overflow: hidden;
  transition: 0.1s;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: 1px;
  font-style: normal;
  font-weight: bold;
  color: #1f1512;
  font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif; 
  background: url("img/he_migi_704x682.svg") no-repeat;
  background-size: 14px 14px;
  background-position: right 15px top 25px;
}

.jp_menu ul li:hover p span .menu_btn_link em {
  position:relative;
  width: 300px;
  height: 60px;
  margin: 0px;
  padding: 22px 0px 0px 10px;
  box-sizing: border-box;
  text-decoration: none;
  visibility: visible;
  display: block;
  text-align: left;
  overflow: hidden;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: 1px;
  font-style: normal;
  color: #1f1512;
  font-weight: bold;
  font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif; 
  transition: 0.3s;
  background: url("img/he_migi_704x682.svg") no-repeat;
  background-size: 14px 14px;
  background-position: right 15px top 25px;  
}

.jp_menu ul li:hover p span .menu_btn_link:hover em {
color: #3c88e4;
background: url("img/he_migi2_704x682.svg") no-repeat;
background-size: 14px 14px;
background-position: right 15px top 25px;
}


.jp_menu * {
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -ms-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}

}
/* -----------------------------------------------------------------------------------------------  max-width:1400px   */







/*  jp menu bg  ----------------------------------------------*/

.menu_bg {
width: 0px;
height: 0px;
margin: 0px;
padding: 0px;
box-sizing: border-box;
display: none;
visibility: hidden;
position: relative;
z-index: 0;
}

.menu_bg.show_menu_bg {
width: 100vw;
height: 100vh;
margin: 0px;
padding: 0px;
box-sizing: border-box;
display: block;
visibility: visible;
background-color: rgba(30,30,30,0.5);
position: fixed;
top: 0px;
left: 0px;
z-index: 40;
}

/* -----------------------------------------------------------------------------  jp menu bg --- */



/*  header tel  ----------------------------------------------*/

.header_tel {
width: 290px;
height:117px;
margin:0px;
padding:0px 0px 0px 0px;
box-sizing: border-box;
position: absolute;
top: 0px;
right: 0px;
}

.header_tel img {
width: 290px;
height:117px;
}


/* -----------------------------------------------------------------------------  header tel  --- */












 
 
 
 

/*  footer  ----------------------------------------------*/

.footer {
width:100%;
margin:0px;
padding:40px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
clear:both;
position: relative;
}




.footer_tel {
	width:100%;
	height: 160px;
	margin:0px;
	padding:0px;
	box-sizing:border-box;
	clear:both;
	position:relative;
	background: #3c88e4;
}

.footer_tel h2 {
	margin:0px;
	padding:50px 0px 0px 0px;
	box-sizing:border-box;
	clear:both;
	position:relative;
	font-weight: bold;
	line-height: 1.2;
	font-size: 54px;
	color: #fff;
	text-align: center;
}

.footer_tel h2 span {
font-size: 24px;
display: inline-block;
vertical-align: middle;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
font-weight: bold;
}

.footer_tel h2 em {
font-size: 30px;
display: inline-block;
font-style: normal;
padding: 0px 0px 0px 20px;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
}

.footer_tel h2 u {
display: inline-block;
font-style: normal;
padding: 0px 0px 0px 5px;
text-decoration: none;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
}

.footer_tel h2 u a {
display: inline-block;
text-decoration: none;
color: #fff;
cursor: default;
pointer-events: none;
}

.footer_tel p {
	margin:0px;
	padding:5px 0px 0px 0px;
	box-sizing:border-box;
	clear:both;
	position:relative;
	font-weight: bold;
	line-height: 1.2;
	font-size: 16px;
	color: #fff;
	text-align: center;
	letter-spacing: 2px;
	font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
}



.footer_bana {
	width:100%;
	height: 160px;
	margin:0px;
	padding:30px 0px 0px 0px;
	box-sizing:border-box;
	clear:both;
	position:relative;
	background: #cae5f1;
}


.footer_bana h2 {
width: calc( 50% - 80px);
margin: 0px 0px 0px 80px;
padding: 0px;
float: left;
box-sizing: border-box;
text-align: right;
}

.footer_bana h2 a {
width: 500px;
height: 100px;
margin: 0px 50px 0px 0px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 24px;
line-height: 100px;
font-weight: bold;
color: #fff;
text-decoration: none;
letter-spacing: 0.05em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
position: relative;
background: #3c88e4;
border: solid 2px #3c88e4;
border-radius: 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h2 a:hover {
color: #3c88e4;
background: #fff;
}

.footer_bana h2 a p{
display:block;
width: 20px;
height: 20px;
margin:0px;
padding:0px;
box-sizing: border-box;
position: absolute;
top: 10px;
right: 10px;
z-index: 5;
clear: both;
background: url("img/link_icon01_334x334.svg") no-repeat;
background-size: 20px 20px;
background-position: left 0px top 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h2 a:hover p{
background: url("img/link_icon02_334x334.svg") no-repeat;
background-size: 20px 20px;
background-position: left 0px top 0px;
}

.footer_bana h2 a span {
width: 100%;
height: 100px;
margin: 0px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
position: absolute;
top: 0px;
left: 0px;
z-index: 3;
vertical-align: top;
text-align: center;
}


.footer_bana h3 {
width: calc( 50% - 80px);
margin: 0px 80px 0px 0px;
padding: 0px;
float: right;
box-sizing: border-box;
text-align: left;
}

.footer_bana h3 a {
width: 500px;
height: 100px;
margin: 0px 0px 0px 50px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 24px;
line-height: 100px;
font-weight: bold;
color: #fff;
text-decoration: none;
letter-spacing: 0.05em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
position: relative;
background: #e7899a;
border: solid 2px #e7899a;
border-radius: 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h3 a:hover {
color: #e7899a;
background: #fff;
}

.footer_bana h3 a p{
display:block;
width: 20px;
height: 20px;
margin:0px;
padding:0px;
box-sizing: border-box;
position: absolute;
top: 10px;
right: 10px;
z-index: 5;
clear: both;
background: url("img/link_icon01_334x334.svg") no-repeat;
background-size: 20px 20px;
background-position: left 0px top 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h3 a:hover p{
background: url("img/link_icon03_334x334.svg") no-repeat;
background-size: 20px 20px;
background-position: left 0px top 0px;
}

.footer_bana h3 a span {
width: 100%;
height: 100px;
margin: 0px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
position: absolute;
top: 0px;
left: 0px;
z-index: 3;
vertical-align: top;
text-align: center;
}




.footer_up {
width:100%;
margin:0px;
padding:60px 0px 60px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
clear:both;
background: #f3f3f3;
position: relative;
}


.footer_cp {
width: 420px;
margin:0px 0px 0px 80px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: left;
position: relative;
}

/*  max-width:1400px  */
@media only screen and (max-width:1400px) {

.footer_cp {
width: 420px;
margin:0px 0px 0px 30px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: left;
position: relative;
}

}
/* -----------------------------------------------------------------------------------------------  max-width:1400px   */



.footer_title {
width:100%;
margin:0px;
padding:0px;
box-sizing:border-box;
clear: both;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
}

.footer_title p {
width:100%;
margin:0px;
padding:0px;
box-sizing:border-box;
clear: both;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
}

.footer_title p a {
width:260px;
margin:0px;
padding:0px;
display: inline-block;
box-sizing:border-box;
clear: both;
position:relative;
}

.footer_title p a img {
width:100%;
height: auto;
}

.footer_title h2 {
width: 100%;
text-align: left;
margin: 0.5em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 18px;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.03em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h3 {
width: 100%;
text-align: left;
margin: 0.5em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 16px;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.02em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h3 em {
width: 3em;
margin: 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h3 u {
width: calc(100% - 3em);
margin: 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}


.footer_title h4 {
width: 100%;
text-align: left;
margin: 0.5em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 16px;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.02em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h4 em {
width: 3em;
margin: 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h4 u {
margin: 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h4 s {
width: 3em;
margin: 0px 0px 0px 2em;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h5 {
width: 100%;
text-align: left;
margin: 0.5em 0px 0.2em 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 16px;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.02em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h5 a {
margin: 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-weight: normal;
text-decoration: none;
color: #3c88e4;
}

.footer_title h5 a:hover {
color: #FF0B6A;
}

.footer_web {
width:100%;
margin:0px;
padding:20px 0px 0px 0px;
box-sizing:border-box;
clear: both;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
}

.footer_web p {
width:10%;
margin:0px 3% 0px 0px;
padding:0px;
box-sizing:border-box;
float: left;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
vertical-align: top;
}

.footer_web p a {
width:100%;
margin:0px;
padding:0px;
box-sizing:border-box;
clear: both;
display: inline-block;
position:relative;
vertical-align: top;
}

.footer_web p a img {
width:100%;
height: auto;
}

.footer_btn {
width: calc(100% - 580px);
margin:0px 80px 0px 0px;
padding:10px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: right;
position: relative;
display: flex;
flex-wrap: wrap;
flex-direction: row;
}

/*  max-width:1400px  */
@media only screen and (max-width:1400px) {

.footer_btn {
width: calc(100% - 480px);
margin:0px 30px 0px 0px;
padding:10px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: right;
position: relative;
display: flex;
flex-wrap: wrap;
flex-direction: row;
}

}
/* -----------------------------------------------------------------------------------------------  max-width:1400px   */

.footer_btn_gr {
width: 25%;
margin:0px 0px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: left;
position: relative;
display: block;
}

.footer_btn_gr h2 {
width: 100%;
margin:0px 0px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
display: inline-block;
position: relative;
}

.footer_btn_gr h2 a {
margin: 0px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 18px;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr h2 a:hover {
background-position: 0 calc(100%);
background-size: 100% 2px;
color: #3c88e4;
}

.footer_btn_gr h3 a {
margin: 20px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 18px;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr h3 a:hover {
background-position: 0 calc(100%);
background-size: 100% 2px;
color: #3c88e4;
}

.footer_btn_gr span {
width: calc(100% - 2px);
margin:10px 0px 0px 2px;
padding:0px 10px 0px 14px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
display: inline-block;
position: relative;
border: solid 0px #999;
border-left-width: 1px;
}

.footer_btn_gr span p {
width: 100%;
margin:5px 0px 5px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
clear: both;
position: relative;
display: inline-block;
}

.footer_btn_gr span p a {
margin: 0px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline;
box-sizing: border-box;
font-size: 16px;
font-weight: bold;
line-height: 1.8;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr span p a:hover {
background-position: 0 calc(100%);
background-size: 100% 2px;
color: #3c88e4;
}




/*  max-width:1400px  */
@media only screen and (max-width:1400px) {

.footer_btn_gr h2 a {
margin: 0px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 14px;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr h3 a {
margin: 20px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 14px;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr span p a {
margin: 0px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline;
box-sizing: border-box;
font-size: 14px;
font-weight: bold;
line-height: 1.8;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

}
/* -----------------------------------------------------------------------------------------------  max-width:1400px   */


.footer_bt {
width:100%;
margin:0px;
padding:40px 0px 30px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
clear:both;
background: #fff;
position: relative;
}


.footer_copy {
width: calc(50% - 80px);    
margin:0px 80px 0px 0px;
padding:0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: right;
position: relative;
text-align: right;
}

/*  max-width:1400px  */
@media only screen and (max-width:1400px) {

.footer_copy {
width: calc(50% - 30px);    
margin:0px 30px 0px 0px;
padding:0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: right;
position: relative;
text-align: right;
}

}
/* -----------------------------------------------------------------------------------------------  max-width:1400px   */

.footer_copy p{
display: inline-block;
margin:0px 0px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
clear: both;
position: relative;
font-style: normal;
font-size: 16px;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.02em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
text-align: right;
}


.footer_link {
width: calc(50% - 80px);
margin:0px 0px 0px 80px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: left;
position: relative;
display: block;
}

/*  max-width:1400px  */
@media only screen and (max-width:1400px) {

.footer_link {
width: calc(50% - 30px);
margin:0px 0px 0px 30px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: left;
position: relative;
display: block;
}

}
/* -----------------------------------------------------------------------------------------------  max-width:1400px   */

.footer_link h2 {
margin:0px 40px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
display: inline-block;
position: relative;
}

.footer_link h2 a {
margin: 0px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 16px;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_link h2 a:hover {
background-position: 0 calc(100%);
background-size: 100% 2px;
color: #3c88e4;
}



/* -----------------------------------------------------------------------------  footer --- */
 






/*  pagetitle  ----------------------------------------------*/

.pagetitle{
width: 100%;
margin: 0px;
padding: 0px 100px;
box-sizing: border-box;
font-size: 0px;
line-height: 0px;
clear: both;
position: relative;
}

.pagetitle h2 {
width: 100%;
text-align: left;
margin: 0px;
padding: 167px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 24px;
line-height: 1.2;
font-weight: bold;
color: #3c88e4;
letter-spacing: 0.05em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.pagetitle h3 {
width: 100%;
text-align: left;
margin: 0.5em 0px 0px 0px;
padding: 0px 0px 50px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 36px;
line-height: 1.2;
font-weight: bold;
color: #1f1512;
letter-spacing: 0.03em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

/* -----------------------------------------------------------------------------  pagetitle --- */




/* load3 */

.load_box3 {
width:100%;
height: 100%;
display:block;
margin:0px;
padding:0px;
box-sizing: border-box;
position: fixed;
top: 0px;
left: 0px;
z-index: 200;
clear:both;
font-size:0px;
line-height:0px;
overflow:hidden;
background: #fff;
}

.load_box3 span {
width:600px;
height:108px;
display:block;
margin:-68px 0px 0px -300px;
padding:0px;
box-sizing: border-box;
position: absolute;
top: 50%;
left: 50%;
z-index: 25;
font-size:0px;
line-height:0px;
overflow:hidden;
}

@keyframes LoadAnimeA{
   0% { background-color: #fff; opacity: 0; } 
  50% { background-color: #ddd; opacity: 1; }
 100% { background-color: #ddd; opacity: 0; }
}

.load_box3 span h2 {
margin: 0px;
padding: 0px;
display: block;
width: 105px;
height: 107px;
background-color: #fff;
position: absolute;
top: 1px;
left: 1px;
z-index: 270;
opacity: 0;
animation: LoadAnimeA 1s linear;
animation-delay: 1s;
animation-fill-mode: forwards;
}

.clip-me{
clip-path: url(#clipshape);
}

@keyframes LoadAnimeB{
   0% { background-color: #ddd; opacity: 0; } 
  50% { background-color: #ddd; opacity: 1; }  
 100% { background-color: #7ecef4; opacity: 1; }
}

.load_box3 span h3 {
margin: 0px;
padding: 0px;
display: block;
width: 105px;
height: 107px;
background-color: #ddd;
position: absolute;
top: 1px;
left: 1px;
z-index: 260;
opacity: 0;

animation: LoadAnimeB 1s linear;
animation-delay: 1.5s;
animation-fill-mode: forwards;
}

.clip-me2{
clip-path: url(#clipshape2);
}

@keyframes LoadAnimeC{
   0% { background-position: left 100% top 0px; } 
  50% { background-position: left 100% top 0px; }  
 100% { background-position: left 0% top 0px; }
}

.load_box3 span p {
margin: 0px;
padding: 0px;
display: block;
width: 455px;
height: 77px;
background: linear-gradient( 90deg, rgba(95,100,96,1.0) 0%, rgba(95,100,96,1) 50%, rgba(95,100,96,0) 50%, rgba(95,100,96,0) 100% );
background-size: 200% 100%;
background-position: left 100% top 0px;

position: absolute;
top: 23px;
left: 145px;
z-index: 260;
opacity: 1;

animation: LoadAnimeC 1s ease-in;
animation-delay: 1.5s;
animation-fill-mode: forwards;
}

.clip-me3{
clip-path: url(#clipshape3);
}




/* -----------------------------------------------------------------------------  load3 --- */































 
 
/* コンテンツのフェードイン ------------------- */ 
 
.fade-in {
  opacity: 0; /* 初期状態は非表示 */
  transition: opacity 0.5s ease-in-out; /* opacityプロパティを0.5秒で変更 */
}

.fade-in.active {
  opacity: 1; /* activeクラスが追加されると表示されるようになる */
}


.fadeinA {
  opacity : 0;
  transform : translate(0, 40px);
  transition : all 0.8s;
}
 
.fadeinA.activeA{
  opacity : 1;
  transform : translate(0, 0);
}


/* ------------------- コンテンツのフェードイン */
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 























/*  pagetop  ----------------------------------------------*/

.pagetop_arrow {
	width:54px;
	height:54px;
	margin:0px;
	padding:0px;
	box-sizing:border-box;
	clear:both;
	display:block;
	position:fixed;
	right: 50px;
	bottom: 150px;
	z-index: 9;
	background-image: url("img/pagetop_54x54.svg");
	background-repeat: no-repeat;
	background-position: 0px 0px;
	background-size: 54px 54px;
	cursor: pointer;
}

/*  ----------------------------------------------------------------- pagetop  ---*/

























































/*  下部ページを開いたときのフェードイン  ----------------------------------------------*/

.first {
opacity : 0;
transition : all 1s;
}

.first.first_fade {
opacity : 1;
}

/* -----------------------------------------------------------------------------  下部ページを開いたときのフェードイン --- */












/*  google  ----------------------------------------------*/


.grecaptcha-badge { visibility: hidden; }


/* -----------------------------------------------------------------------------  google --- */









/*  スマホ版を非表示処理  */


/*  sp ヘッダー  */

.sp_header { visibility:hidden; display:none; }
.hm_wrap { visibility:hidden; display:none; }

.sp_tel_link { visibility:hidden; display:none; }
.sp_tel_link2 { visibility:hidden; display:none; }

/* ------------------------------- */

/*  sp tel btn  */
.sp_tel_btn { visibility:hidden; display:none; }

/* ------------------------------- */







/*  スマートフォン ※iPhone6 Plus 以下を準拠  */
@media only screen and (max-width:899px) {


/*  基本設定  */

body { -webkit-text-size-adjust:100%; }

/* ------------------------------- */







/*  header  */

.header {
	width:0px;
	height:0px;
	margin:0px;
	padding:0px;
	box-sizing:border-box;
	clear:both;
	display:none;
    visibility: hidden;
	word-wrap:break-word;
	overflow-wrap:break-word;
	position:static;
	top: auto;
	left: auto;
	z-index:0;
    background-color: rgba(255,255,255,0);
}

/* ------------------------------- */


/*  jp menu bg  ----------------------------------------------*/

.menu_bg {
display: none;
visibility: hidden;
width: 0px;
height: 0px;
margin: 0px;
padding: 0px;
box-sizing: border-box;
position: relative;
z-index: 0;
}

.menu_bg.show_menu_bg {
width: 0px;
height: 0px;
margin: 0px;
padding: 0px;
box-sizing: border-box;
display: none;
visibility: hidden;
background-color: rgba(30,30,30,0);
position: static;
top: auto;
left: auto;
z-index: 0;
}

/* -----------------------------------------------------------------------------  jp menu bg --- */
 


/* load3 */

.load_box3 {
width:100%;
height: 100%;
display:block;
margin:0px;
padding:0px;
box-sizing: border-box;
position: fixed;
top: 0px;
left: 0px;
z-index: 200;
clear:both;
font-size:0px;
line-height:0px;
overflow:hidden;
background: #fff;
}

.load_box3 span {
width:300px;
height:54px;
display:block;
margin:-34px 0px 0px -150px;
padding:0px;
box-sizing: border-box;
position: absolute;
top: 45%;
left: 50%;
z-index: 25;
font-size:0px;
line-height:0px;
overflow:hidden;
}

@keyframes LoadAnimeA{
   0% { background-color: #fff; opacity: 0; } 
  50% { background-color: #ddd; opacity: 1; }
 100% { background-color: #ddd; opacity: 0; }
}

.load_box3 span h2 {
margin: 0px;
padding: 0px;
display: block;
width: 53px;
height: 54px;
background-color: #fff;
position: absolute;
top: 1px;
left: 1px;
z-index: 270;
opacity: 0;
animation: LoadAnimeA 1s linear;
animation-delay: 1s;
animation-fill-mode: forwards;
}

.clip-me{
clip-path: url(#clipshape);
}

@keyframes LoadAnimeB{
   0% { background-color: #ddd; opacity: 0; } 
  50% { background-color: #ddd; opacity: 1; }  
 100% { background-color: #7ecef4; opacity: 1; }
}

.load_box3 span h3 {
margin: 0px;
padding: 0px;
display: block;
width: 53px;
height: 54px;
background-color: #ddd;
position: absolute;
top: 1px;
left: 1px;
z-index: 260;
opacity: 0;

animation: LoadAnimeB 1s linear;
animation-delay: 1.5s;
animation-fill-mode: forwards;
}

.clip-me2{
clip-path: url(#clipshape2);
}

@keyframes LoadAnimeC{
   0% { background-position: left 100% top 0px; } 
  50% { background-position: left 100% top 0px; }  
 100% { background-position: left 0% top 0px; }
}

.load_box3 span p {
margin: 0px;
padding: 0px;
display: block;
width: 228px;
height: 39px;
background: linear-gradient( 90deg, rgba(95,100,96,1.0) 0%, rgba(95,100,96,1) 50%, rgba(95,100,96,0) 50%, rgba(95,100,96,0) 100% );
background-size: 200% 100%;
background-position: left 100% top 0px;

position: absolute;
top: 12px;
left: 71px;
z-index: 260;
opacity: 1;

animation: LoadAnimeC 1s ease-in;
animation-delay: 1.5s;
animation-fill-mode: forwards;
}

.clip-me3{
clip-path: url(#clipshape3);
}




/* -----------------------------------------------------------------------------  load3 --- */






/*  sp header  */

.sp_header {
	visibility:visible;
	width:100%;
	height:66px;
	margin:0px;
	padding:0px;
	box-sizing:border-box;
	clear:both;
	display:inline-block;
	word-wrap:break-word;
	overflow-wrap:break-word;
	position:fixed;
	top:0px;
	left:0px;
	z-index:50;
	background:#FFF;
}

.sp_head_logo {
	width:234px;
	height:42px;
	margin:13px 0px 0px 0px;
	padding:0px;
	box-sizing:border-box;
	float:left;
	display:inline-block;
	word-wrap:break-word;
	overflow-wrap:break-word;
	position:absolute;
	top:0px;
	left:10px;
	text-align:center;
}

.sp_head_logo a {
	display:block;
	width:234px;
	height:42px;
	margin:0px auto 0px auto;
	padding:0px;
	clear:both;
	position:relative;
}

.sp_head_logo a img {
	width:100%;
	height:auto;
}

/* ------------------------------- */



/* メニュー（ハンバーガーメニュー） */

.sp_menu {
	visibility:visible;
	width:100%;
	height:0px;
	margin:0px;
	padding:0px;
	box-sizing:border-box;
	clear:both;
	display:inline-block;
	word-wrap:break-word;
	overflow-wrap:break-word;
	position:absolute;
	top:66px;
	left:0px;
	z-index:50;
}

.hm_menu_check {/* チェックボックスを隠す */
  display:none;
}

.hm_wrap {
	display:inline-block;
	visibility:visible;
	position:fixed;
	top :0px;
	right:0px;
	width :100%;
	padding :0px;
	margin:0px 0px 0px 0px;
	z-index:50;
}

.hm_wrap_bg {
	visibility:hidden;
	display:inline-block;
	position:absolute;
	top :0px;
	right:0px;
	width :100%;
	height:100%;
	padding :0px;
	margin:0px;
	z-index:100;
}

.hm_bgimg {
	width:50px;
	height:66px;
	display:block;
	position:absolute;
	top:0px;
	right:0px;
	z-index:100;
	background:url(img/sp_menu_bg_50x66.svg) no-repeat;
	background-position:center center;
	background-size:50px 66px;
}


/* メニューボタン */
.hm_btn {
	position:absolute;
	top:0px;
	right:0px;
	width: 50px;
	height: 66px;
	cursor: pointer;
	display:block;
	float: left;
	z-index:150;
}

.hm_btn::before {
	-webkit-box-shadow: #00a0e9 0 9px 0;
	box-shadow: #00a0e9 0 9px 0;
}
.hm_btn::after {
	bottom: 0;
}
.hm_btn::before {
	width: 28px;
	height: 2px;
	background: #00a0e9;
	display:block;
	content:'';
	position:absolute;
	top:23px;
	right:11px;
	-webkit-transition: -webkit-box-shadow 0.2s linear, -webkit-transform 0.2s 0.2s;
	transition: box-shadow 0.2s linear, transform 0.2s 0.2s;
}
.hm_btn::after {
	width: 28px;
	height: 2px;
	background: #00a0e9;
	display:block;
	content:'';
	position:absolute;
	bottom:22px;
	right:11px;
	-webkit-transition: -webkit-box-shadow 0.2s linear, -webkit-transform 0.2s 0.2s;
	transition: box-shadow 0.2s linear, transform 0.2s 0.2s;
}


/* ------------------- メニューボタン */
 
 
.hm_menu_wrap {
	visibility:hidden;
	width:100%;
	height:100%;
	position: absolute;
	right:0px;
	top:0px;
	margin:0px;
	background: rgba(0,0,0,0);
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    -ms-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
	overflow: scroll;
	z-index:150;
}

 
/* 開閉時のアニメーション */



.hm_menu_check:checked ~ .sp_menu {
	width:100%;
	height:100vh;
}

.hm_menu_check:checked ~ .hm_btn {
	position:absolute;
	top:3px;
	right:0px;	
	width: 50px;
	height: 66px;
	margin:0px;
}

.hm_menu_check:checked ~ .hm_btn::before {
	-webkit-box-shadow: transparent 0 0 0;
	box-shadow: transparent 0 0 0;
	-webkit-transform: rotate(45deg) translate3d(5px, 8px, 0);
	transform: rotate(45deg) translate3d(5px, 8px, 0);
	position:absolute;
	top:20px;
	right:9px;
	margin:0px 0px 0px 0px;
}
.hm_menu_check:checked ~ .hm_btn::after {
	-webkit-transform: rotate(-45deg) translate3d(5px, -8px, 0);
	transform: rotate(-45deg) translate3d(5px, -8px, 0);
	top:38px;
	bottom:auto;
	right:9px;
	margin:0px 0px 0px 0px;
}

.hm_menu_check:checked ~ .hm_wrap_bg {
	display:inline-block;
	visibility:visible;	
	position:absolute;
	top :0px;
	right:0px;
	width :100%;
	height:100%;
	padding :0px;
	margin:0px;
}

.hm_menu_check:checked ~ .sp_menu .hm_wrap_bg .hm_menu_wrap {
	visibility:visible;
    background: rgba(189,228,244,1.0);
}

.hm_menu_check:checked ~ .sp_menu .hm_wrap_bg .hm_menu_wrap .hm_menu {
	visibility:visible;
    background: rgba(189,228,244,1.0);
	height:100vh;
	padding:10px 0px 200px 0px;	
}

.hm_menu_check:checked ~ .sp_menu .hm_wrap_bg .hm_menu_wrap .hm_menu .hm_list {
	visibility:visible;
}

.hm_menu_check:checked ~ .sp_menu .hm_wrap_bg .hm_menu_wrap .hm_menu .hm_list li {
	visibility:visible;
}


/* ---------------- 開閉時のアニメーション */

 
/* メニュー内のリストスタイル */
.hm_menu {
	visibility:hidden;
	width:100%;
	height:0px;
	display:inline-block;
    background: rgba(0,160,233,0);
	margin:0px;
	padding:0px 0px 0px 0px;
	box-sizing:border-box;
	position:absolute;
	top:0px;
	left:0px;
    -webkit-transition: all 0.1s;
    -moz-transition: all 0.1s;
    -ms-transition: all 0.1s;
    -o-transition: all 0.1s;
    transition: all 0.1s;
	z-index:200;
	overflow:scroll;
	-webkit-overflow-scrolling: touch;	
}

.hm_list {
	visibility:hidden;
	width:94%;
	display:block;
	list-style-type: none;
	position:relative;
	margin:0px auto 0px auto;
	box-sizing:border-box;
	padding:0px;
	clear:both;
}

.hm_list li {
	visibility:hidden;	
	width:100%;
	display:block;
	margin:0px;
	padding:0px;
	position: relative;
    -webkit-transition: all 0.1s;
    -moz-transition: all 0.1s;
    -ms-transition: all 0.1s;
    -o-transition: all 0.1s;
    transition: all 0.1s;	
}

.hm_list li a {
	width:100%;
	height:100%;
	color: #333;
	display:block;
	margin:0px;
	padding:8px 14px;
	box-sizing:border-box;
	position:relative;
	font-size:16px;
	line-height:1.6;
	text-decoration:none;
	border:solid 0px #bde4f4;
	border-top-width:1px;
}

.hm_list li a:link { background:#fff; color:#00a0e9; }
.hm_list li a:visited { background:#fff; color:#00a0e9; }
.hm_list li a:hover { background:#fff; color:#00a0e9; }
.hm_list li a:active { background:#fff; color:#00a0e9; }


.hm_list li a.link_arrow {
	margin:0px;
	padding:8px 14px 8px 32px;
	box-sizing:border-box;	
}


.hm_list li a.link_arrow::after {
	position: absolute;
	top: 46%;
	left: 14px;
	display: block;
	content: '';
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 2px solid #00a0e9;
	border-right: 2px solid #00a0e9;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}


.hm_list li a.link_web::before  {
	position: absolute;
	top:50%;
	right: 14px;
	display: block;
	content: '';
	width: 10px;
	height: 10px;
	margin-top: -4px;
    border: 1px solid #00a0e9;
	background-color:#fff;
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}

.hm_list li a.link_web::after {
	position: absolute;
	top:40%;
	right: 10px;
	display: block;
	content: '';
	width: 10px;
	height: 10px;
	margin-top: -4px;
    border: 1px solid #00a0e9;
	background-color:#fff;
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}



.hm_list li a.link_tel {
	width:100%;
	height:100%;
	color: #333;
	display:block;
	margin:0px;
	padding:0px 0px 0px 0px;
	box-sizing:border-box;
	position:relative;
	font-size:16px;
	line-height:1.6;
	text-decoration:none;
	border:solid 0px #bde4f4;
	border-top-width:10px;
}

.hm_list li a.link_tel:link { background:#00a0e9; color:#00a0e9; }
.hm_list li a.link_tel:visited { background:#00a0e9; color:#00a0e9; }
.hm_list li a.link_tel:hover { background:#00a0e9; color:#00a0e9; }
.hm_list li a.link_tel:active { background:#00a0e9; color:#00a0e9; }


.hm_list li a.link_tel img {
	width: 100%;
	height: auto;
}



/*  ----------------メニュー内のリストスタイル */


/* サブメニュー */

.link_menubox {
	width:100%;
	display:block;
}

.link_menu_checkA {/* チェックボックスを隠す */
  display:none;
}

.link_btnA {
	position:absolute;
	top:0px;
	right:0px;
	width:40px;
	height:40px;
	cursor: pointer;
	display:block;
	float:left;
	z-index:250;
}

.link_menu_checkB {/* チェックボックスを隠す */
  display:none;
}

.link_btnB {
	position:absolute;
	top:0px;
	right:0px;
	width:40px;
	height:40px;
	cursor: pointer;
	display:block;
	float:left;
	z-index:250;
}

.link_menu_checkC {/* チェックボックスを隠す */
  display:none;
}

.link_btnC {
	position:absolute;
	top:0px;
	right:0px;
	width:40px;
	height:40px;
	cursor: pointer;
	display:block;
	float:left;
	z-index:250;
}

.link_menu_checkD {/* チェックボックスを隠す */
  display:none;
}

.link_btnD {
	position:absolute;
	top:0px;
	right:0px;
	width:40px;
	height:40px;
	cursor: pointer;
	display:block;
	float:left;
	z-index:250;
}

.link_btnbox {
	width:100%;
	display:block;
	margin:0px;
	padding:0px;
	position:relative;
}

.link_btnbox h2 {
	width:100%;
	color: #00a0e9;
	display:block;
	margin:0px;
	padding:8px 14px;
	box-sizing:border-box;
	position:relative;
	font-size:16px;
	line-height:1.6;
	border:solid 0px #bde4f4;
	border-top-width:1px;
	font-weight:normal;
	background:linear-gradient(90deg,#fff 0%,#fff calc(100% - 40px),#f3f3f3 calc(100% - 40px),#f3f3f3 100%);
}

.link_btnbox h2 a {
	width:calc(100% - 40px);
	color: #00a0e9;
	display:block;
	margin:0px;
	padding:0px 0px;
	box-sizing:border-box;
	position:relative;
	font-size:16px;
	line-height:1.6;
	border:solid 0px #bde4f4;
	border-top-width:0px;
	font-weight:normal;
	background:#fff;
}


.link_btnbox h2 a.sp_menu_link_mukou {
cursor: default;
pointer-events: none;
}



.hm_list li .link_menubox .link_btnbox h2::before {
	position: absolute;
	top:55%;
	right: 12px;
	display: block;
	content: '';
	width: 14px;
	height: 2px;
	margin-top: -4px;
	background-color:#00a0e9;
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}

.hm_list li .link_menubox .link_btnbox h2::after {
	position: absolute;
	top:42%;
	right: 18px;
	display: block;
	content: '';
	width: 2px;
	height: 14px;
	margin-top: -4px;
	background-color:#00a0e9;
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}

.hm_list li .link_menubox .link_btnbox a.sp_menu_top {
	margin:0px;
	padding:0px 0px 0px 18px;
	box-sizing:border-box;
}

.hm_list li .link_menubox .link_btnbox a.sp_menu_top::after {
	position: absolute;
	top: 46%;
	left: 0px;
	display: block;
	content: '';
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 2px solid #00a0e9;
	border-right: 2px solid #00a0e9;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.link_list {
	width:100%;
	height:0px;
	visibility:hidden;
	display:block;
	margin:0px;
	padding:0px;
	position:relative;
}

div.link_list a {
	width:100%;
	height:100%;
	color: #333;
	display:block;
	margin:0px;
	padding:8px 14px 8px 44px;
	box-sizing:border-box;
	position:relative;
	font-size:16px;
	line-height:1.6;
	text-decoration:none;
	border:solid 0px #bde4f4;
	border-top-width:1px;
}

div.link_list a:link { background:#f3f3f3; color:#00a0e9; }
div.link_list a:visited { background:#f3f3f3; color:#00a0e9; }
div.link_list a:hover { background:#f3f3f3; color:#00a0e9; }
div.link_list a:active { background:#f3f3f3; color:#00a0e9; }

div.link_list a::after {
	position: absolute;
	top: 46%;
	left: 26px;
	display: block;
	content: '';
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 2px solid #00a0e9;
	border-right: 2px solid #00a0e9;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

div.link_list a.sp_menu_link {
	width:100%;
	height:100%;
	color: #333;
	display:block;
	margin:0px;
	padding:8px 14px 8px 60px;
	box-sizing:border-box;
	position:relative;
	font-size:16px;
	line-height:1.6;
	text-decoration:none;
	border:solid 0px #bde4f4;
	border-top-width:1px;
}

div.link_list a.sp_menu_link:link { background:#e6e8f7; color:#00a0e9; }
div.link_list a.sp_menu_link:visited { background:#e6e8f7; color:#00a0e9; }
div.link_list a.sp_menu_link:hover { background:#e6e8f7; color:#00a0e9; }
div.link_list a.sp_menu_link:active { background:#e6e8f7; color:#00a0e9; }

div.link_list a.sp_menu_link::after {
	position: absolute;
	top: 46%;
	left: 40px;
	display: block;
	content: '';
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 2px solid #00a0e9;
	border-right: 2px solid #00a0e9;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}



.link_menu_checkA:checked ~ .link_list {
	visibility:visible;
	height:auto;
}

.link_menu_checkA:checked ~ div.link_btnbox h2::after {
	width: 0px;
}

.link_menu_checkB:checked ~ .link_list {
	visibility:visible;
	height:auto;
}

.link_menu_checkB:checked ~ div.link_btnbox h2::after {
	width: 0px;
}

.link_menu_checkC:checked ~ .link_list {
	visibility:visible;
	height:auto;
}

.link_menu_checkC:checked ~ div.link_btnbox h2::after {
	width: 0px;
}

.link_menu_checkD:checked ~ .link_list {
	visibility:visible;
	height:auto;
}

.link_menu_checkD:checked ~ div.link_btnbox h2::after {
	width: 0px;
}


/* ---------------------------------------------- メニュー */



    
    
    
    
    
/*  sp フッター 電話 */

.sp_tel_btn {
	display:inline-block;
	visibility:visible;
	position:fixed;
	bottom: 0px;
	left: 0px;
	width :100%;
	height: 60px;
	padding :0px;
	margin:0px 0px 0px 0px;
	z-index:20;
	text-align: center;
	background-color: #3c88e4;
    transition: 0.3s;
    transform: translate3d(0, 0, 0);
}

.sp_tel_btn a {
	display:inline-block;
	position: relative;
	width : 320px;
	height: 44px;
	margin: 6px 0px 0px 0px;
	padding: 0px 0px 0px 0px;
}

.sp_tel_btn a img {
	width : 320px;
	height: 44px;
}

/* 非表示時 */
.sp_tel_btn.hide {
  opacity: 0;
  height: 0;
  padding: 0;
  margin: 0;
  pointer-events: none;
  overflow: hidden;
}

/* ------------------------------- */   
    
    
    





/*  footer  ----------------------------------------------*/

.footer {
width:100%;
margin:0px;
padding:20px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
clear:both;
position: relative;
container-type: inline-size;
}




.footer_tel {
width:100%;
height: auto;
margin:0px;
padding:0px;
box-sizing:border-box;
clear:both;
position:relative;
background: #3c88e4;
container-type: inline-size;
}

.footer_tel h2 {
margin:0px;
padding:0.5em 0px 0.5em 0px;
box-sizing:border-box;
clear:both;
position:relative;
font-weight: bold;
line-height: 1.2;
font-size: 8cqw;
color: #fff;
text-align: center;
}

.footer_tel h2 span {
width: 100cqw;
margin: 0px;
padding: 0px 0px 0.3em 0px;
box-sizing: border-box;
font-size: 5cqw;
display: inline-block;
vertical-align: middle;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
font-weight: bold;
}

.footer_tel h2 em {
font-size: 5cqw;
display: inline-block;
font-style: normal;
padding: 0px 0px 0px 0px;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
}

.footer_tel h2 u {
display: inline-block;
font-style: normal;
padding: 0px 0px 0px 2cqw;
text-decoration: none;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
}

.footer_tel h2 u a {
display: inline-block;
text-decoration: none;
color: #fff;
cursor: default;
pointer-events: auto;
}

.footer_tel p {
    display: none;
    visibility: hidden;
	margin:0px;
	padding:0px 0px 0px 0px;
	box-sizing:border-box;
	clear:none;
	position:relative;
	font-weight: bold;
	line-height: 0;
	font-size: 0px;
	color: #fff;
	text-align: center;
	letter-spacing: 0px;
	font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
}



.footer_bana {
width:100%;
height: auto;
margin:0px;
padding:10px 0px 10px 0px;
box-sizing:border-box;
clear:both;
position:relative;
background: #cae5f1;
container-type: inline-size;
}


.footer_bana h2 {
width: 88cqw;
margin: 0px auto 0px auto;
padding: 0px;
float: none;
clear: both;
box-sizing: border-box;
text-align: center;
container-type: inline-size;
}

.footer_bana h2 a {
width: 100cqw;
height: auto;
aspect-ratio: 5 / 1;
margin: 0px 0px 0px 0px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 4.5cqw;
line-height: 1.2;
font-weight: bold;
color: #fff;
text-decoration: none;
letter-spacing: 0.03em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
position: relative;
background: #3c88e4;
border: solid 2px #3c88e4;
border-radius: 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h2 a:hover {
color: #fff;
background: #3c88e4;
}

.footer_bana h2 a p{
display:block;
width: 14px;
height: 14px;
margin:0px;
padding:0px;
box-sizing: border-box;
position: absolute;
top: 8px;
right: 8px;
z-index: 5;
clear: both;
background: url("img/link_icon01_334x334.svg") no-repeat;
background-size: 14px 14px;
background-position: left 0px top 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h2 a:hover p{
background: url("img/link_icon01_334x334.svg") no-repeat;
background-size: 14px 14px;
background-position: left 0px top 0px;
}

.footer_bana h2 a span {
width: 100%;
height: auto;
margin: -0.5em 0px 0px 0px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
position: absolute;
top: 50%;
left: 0px;
z-index: 3;
vertical-align: top;
text-align: center;
}


.footer_bana h3 {
width: 88cqw;
margin: 10px auto 0px auto;
padding: 0px;
float: none;
clear: both;
box-sizing: border-box;
text-align: center;
container-type: inline-size;
}

.footer_bana h3 a {
width: 100cqw;
height: auto;
aspect-ratio: 5 / 1;
margin: 0px 0px 0px 0px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 4.5cqw;
line-height: 1.2;
font-weight: bold;
color: #fff;
text-decoration: none;
letter-spacing: 0.05em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
position: relative;
background: #e7899a;
border: solid 2px #e7899a;
border-radius: 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h3 a:hover {
color: #fff;
background: #e7899a;
}

.footer_bana h3 a p{
display:block;
width: 14px;
height: 14px;
margin:0px;
padding:0px;
box-sizing: border-box;
position: absolute;
top: 8px;
right: 8px;
z-index: 5;
clear: both;
background: url("img/link_icon01_334x334.svg") no-repeat;
background-size: 14px 14px;
background-position: left 0px top 0px;
transition: 0.3s;
transform: translate3d(0, 0, 0);
}

.footer_bana h3 a:hover p{
background: url("img/link_icon01_334x334.svg") no-repeat;
background-size: 14px 14px;
background-position: left 0px top 0px;
}

.footer_bana h3 a span {
width: 100%;
height: auto;
margin: -0.5em 0px 0px 0px;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
position: absolute;
top: 50%;
left: 0px;
z-index: 3;
vertical-align: top;
text-align: center;
}


.footer_up {
width:100%;
margin:0px;
padding:20px 0px 20px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
clear:both;
background: #f3f3f3;
position: relative;
container-type: inline-size;
}


.footer_cp {
width: 88cqw;
margin:0px auto 0px auto;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: none;
position: relative;
clear: both;
container-type: inline-size;
}


.footer_title {
width:100%;
margin:0px;
padding:0px;
box-sizing:border-box;
clear: both;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
container-type: inline-size;
}

.footer_title p {
width:80%;
margin:0px auto;
padding:0px;
box-sizing:border-box;
clear: both;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
}

.footer_title p a {
width:100%;
margin:0px;
padding:0px;
display: inline-block;
box-sizing:border-box;
clear: both;
position:relative;
}

.footer_title p a img {
width:100%;
height: auto;
}

.footer_title h2 {
width: 100%;
text-align: left;
margin: 1em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 6cqw;
line-height: 1.2;
font-weight: bold;
color: #1f1512;
letter-spacing: 0.01em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h3 {
width: 100%;
text-align: left;
margin: 1em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 4cqw;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.01em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h3 em {
width: 3em;
margin: 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h3 u {
width: calc(100cqw - 3em);
margin: 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}


.footer_title h4 {
width: 100%;
text-align: left;
margin: 0px 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 4cqw;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.01em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h4 em {
width: 3em;
margin: 1em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h4 u {
width: calc(50% - 3em);
margin: 1em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h4 s {
width: 3em;
margin: 1em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
font-style: normal;
text-decoration: none;
display: inline-block;
vertical-align: top;
}

.footer_title h5 {
width: 100%;
text-align: left;
margin: 0.7em 0px 0px 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 4cqw;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.01em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.footer_title h5 a {
margin: 0px;
padding: 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-weight: normal;
text-decoration: none;
color: #3c88e4;
}

.footer_title h5 a:hover {
color: #3c88e4;
}

.footer_web {
width:100%;
margin:0px;
padding:15px 0px 0px 0px;
box-sizing:border-box;
clear: both;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
}

.footer_web p {
width:10%;
margin:0px 3% 0px 0px;
padding:0px;
box-sizing:border-box;
float: left;
display: block;
word-wrap:break-word;
overflow-wrap:break-word;
position:relative;
vertical-align: top;
}

.footer_web p a {
width:100%;
margin:0px;
padding:0px;
box-sizing:border-box;
clear: both;
display: inline-block;
position:relative;
vertical-align: top;
}

.footer_web p a img {
width:100%;
height: auto;
}

.footer_btn {
width: 88cqw;
margin:0px auto 0px auto;
padding:10px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: none;
clear: both;
position: relative;
display: flex;
flex-wrap: wrap;
flex-direction: row;
container-type: inline-size;
}

.footer_btn_gr {
width: 100cqw;
margin:0px 0px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: none;
clear: both;
position: relative;
display: block;
container-type: inline-size;
}

.footer_btn_gr h2 {
width: 100%;
margin:0px 0px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
display: inline-block;
position: relative;
}

.footer_btn_gr h2 a {
margin: 1em 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 6cqw;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0.03em;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr h2 a:hover {
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
color: #1f1512;
}

.footer_btn_gr h3 a {
margin: 1em 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 6cqw;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0.03em;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr h3 a:hover {
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
color: #1f1512;
}

.footer_btn_gr span {
width: calc(100% - 2px);
margin:10px 0px 0px 2px;
padding:0px 10px 0px 14px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
display: inline-block;
position: relative;
border: solid 0px #999;
border-left-width: 1px;
}

.footer_btn_gr span p {
width: 100%;
margin:5px 0px 5px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
clear: both;
position: relative;
display: inline-block;
}

.footer_btn_gr span p a {
margin: 0px 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline;
box-sizing: border-box;
font-size: 5cqw;
font-weight: bold;
line-height: 1.8;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_btn_gr span p a:hover {
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
color: #1f1512;
}

.footer_bt {
width:100%;
margin:0px;
padding:10px 0px 120px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
clear:both;
background: #fff;
position: relative;
container-type: inline-size;
}

.footer_copy {
width: 88cqw;    
margin:0px auto 0px auto;
padding:0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: none;
clear: both;
position: relative;
text-align: center;
container-type: inline-size;
}

.footer_copy p{
display: inline-block;
margin:2em 0px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
clear: both;
position: relative;
font-style: normal;
font-size: 4cqw;
line-height: 1.2;
font-weight: normal;
color: #1f1512;
letter-spacing: 0.01em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
text-align: right;
}


.footer_link {
width: 88cqw;
margin:0px auto 0px auto;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
float: none;
clear: both;
position: relative;
display: block;
container-type: inline-size;
}

.footer_link h2 {
margin:0px 0px 0px 0px;
padding:0px 0px 0px 0px;
box-sizing:border-box;
font-size:0px;
line-height:0px;
display: inline-block;
position: relative;
}

.footer_link h2 a {
margin: 0.7em 0px 0px 0px;
padding: 0px 0px 4px 0px;
display: inline-block;
box-sizing: border-box;
font-size: 5cqw;
font-weight: bold;
line-height: 1.2;
letter-spacing: 0px;
position: relative;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
text-decoration: none;
color: #1f1512;
background: linear-gradient(#3c88e4, #3c88e4);
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
background-repeat: no-repeat;
transition: background-size .3s, color .3s;
transform: translate3d(0, 0, 0);
}

.footer_link h2 a:hover {
background-position: calc(100%) calc(100%);
background-size: 0px 2px;
color: #1f1512;
}



/* -----------------------------------------------------------------------------  footer --- */



    

/*  pagetitle  ----------------------------------------------*/

.pagetitle{
width: 100%;
margin: 0px;
padding: 66px 0px 0px 0px;
box-sizing: border-box;
font-size: 0px;
line-height: 0px;
clear: both;
position: relative;
container-type: inline-size;
}

.pagetitle h2 {
width: 88cqw;
text-align: left;
margin: 0px 0px 0px 6cqw;
padding: 1em 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 4cqw;
line-height: 1.2;
font-weight: bold;
color: #3c88e4;
letter-spacing: 0.03em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

.pagetitle h3 {
width: 88cqw;
text-align: left;
margin: 0.4em 0px 0px 6cqw;
padding: 0px 0px 0px 0px;
box-sizing: border-box;
display:  inline-block;
font-style: normal;
font-size: 6cqw;
line-height: 1.2;
font-weight: bold;
color: #1f1512;
letter-spacing: 0.03em;
font-family: -apple-system, BlinkMacSystemFont, "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Verdana, sans-serif;
vertical-align: top;
}

/* -----------------------------------------------------------------------------  pagetitle --- */
    





}
/* ----------------------------------------------------------------------------------------------------  スマートフォン ※iPhone6 Plus 以下を準拠  ---- */








/*  スマートフォン ※iPhone5S 旧SE 以下を準拠  */
@media only screen and (max-width:330px) {

}
/* ------------------------------- */

	
