/* CSS Document */
html {
	font-size: 62.5%;
}
body {
	font-family: "Avenir", "Avenir Next", Verdana, 'Verdana', "游ゴシック体", "Yu Gothic", "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "YuGothic", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 10px;
	font-size: 1.0rem;
	letter-spacing: 0.05em;
	line-height: 1.5;
	color: #1a1a1a;
	-webkit-text-size-adjust: 100%;
	-webkit-print-color-adjust: exact;
	font-feature-settings: 'palt' 1;
    font-kerning: none;
}
img{
	vertical-align: middle;
	max-width: 100%;
	height: auto;
}
a {
	color: inherit;
	display: block;
	text-decoration: none;
}
a:hover {
	text-decoration: none;
	color: inherit;
}
h1, h2, h3, h4, h5, h6 {
	font-weight: normal;
	font-size: 10px;
	font-size: 1.0rem;
}
.cf:before, .cf:after {
	content: "";
	display: table;
}
.cf:after {
	clear: both;
}
/* For IE 6/7 (trigger hasLayout) */
.cf {
	zoom: 1;
}
p {
	font-size: 1.4rem;
	line-height: 1.5;
	letter-spacing: 0.05em;
}
li {
	list-style: none;
}
*{
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

.open_btn{
	display: none;
}
a{
	color: inherit;
	text-decoration: none;
}
header{
	text-align: center;
}
header h1{
	text-align: left;
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
}
header h2{
	padding-top: 32px;
	padding-bottom: 32px;
}
header div {
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
}
header div h4{
	font-size: 16px;
}
header nav{
	width: 100%;
	background-color: #111230;
	margin-top: 32px;
}
header nav ul{
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	
	
}
header nav ul li{
	position: relative;
	width: 165px;
	font-size: 14px;
	color: #fff;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-left: 10px;
}
header nav ul li:nth-of-type(2){
	width: 199px;
	padding-left: 19px;
}
header nav ul li:first-of-type::before{
	content:  " ";
	display: block;
	position: absolute;
	bottom: 50%;
	left: -25px;
	-webkit-transform: translate(0, 50%);
	transform: translate(0, 50%);
	
	width: 49px;
	height: 39px;
	background-image: url(../img/head/menu_slant.png);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
header nav ul li::after{
	content:  " ";
	display: block;
	position: absolute;
	bottom: 50%;
	right: -25px;
	-webkit-transform: translate(0, 50%);
	transform: translate(0, 50%);
	
	width: 49px;
	height: 39px;
	background-image: url(../img/head/menu_slant.png);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.contact_foot{
	background-image: url(../img/foot/bg_contact.png),url(../img/foot/bg_contact_humen.png);
	background-size: auto,453px;
	background-position: center, right top;
	background-repeat: repeat,no-repeat;
	text-align: center;
	padding-top: 48px;
	padding-bottom: 48px;
}
.contact_foot h2{
	font-family: "Times New Roman","游明朝", "Yu Mincho",YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 36px;
	color: #fff;
	letter-spacing: 0.08em;
	position: relative;
	display: inline-block;
	border-bottom: 1pt solid #fff;
	padding-left: 40px;
	padding-right: 40px;
	margin-bottom: 48px;
}
.contact_foot h2::after,.contact_foot h2::before{
	content: " ";
	display: block;
	top: -5px;
	bottom: -20px;
	width: 1px;
	background-color: #fff;
	position: absolute;
}
.contact_foot h2::before{
	left: 20px;
}
.contact_foot h2::after{
	right: 20px;
}
.contact_foot p{
	color: #fff;
	font-size: 16px;
	line-height: 2;
	margin-bottom: 32px;
}
.contact_foot section{
	background : -moz-linear-gradient(9.98% 248.21% 30deg,rgba(17, 18, 48, 1) 0%,rgba(65, 65, 89, 1) 22.91%,rgba(65, 65, 89, 1) 47.47%,rgba(17, 18, 48, 1) 100%);
	background : -webkit-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	background : -webkit-gradient(linear,9.98% 248.21% ,170.07% -544.62% ,color-stop(0,rgba(17, 18, 48, 1) ),color-stop(0.2291,rgba(65, 65, 89, 1) ),color-stop(0.4747,rgba(65, 65, 89, 1) ),color-stop(1,rgba(17, 18, 48, 1) ));
	background : -o-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	background : -ms-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	border: 1px solid #fff;
	
	width: 676px;
	margin-left: auto;
	margin-right: auto;
	
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
	position: relative;
}
.contact_foot section h3{
	font-size: 46px;
	font-weight: 900;
	color: #fff;
	position: relative;
	letter-spacing: 0.02em;
	margin-right: 0.5em;
}
.contact_foot section i{
	position: absolute;
	top: -32px;
	left: -32px;
}
.contact_foot section p{
	margin-bottom: 0;
}
.organizations_foot{
	margin-top: 32px;
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}
.organizations_foot ul{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-align-items: center;
	align-items: center;
}
.organizations_foot ul li{
	padding-bottom: 24px;
}
.organizations_foot ul li:last-of-type{
	width: 100%;
}
.organizations_foot h6{
	font-size: 16px;
	letter-spacing: 0.08em;
}
.info_foot{
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 56px;
}
.info_foot h2{
	font-size: 16px;
	vertical-align: middle;
}
.info_foot h2 img{
	vertical-align: middle;
}
.info_foot h2 em{
	vertical-align: middle;
	text-decoration: none;
	font-style: normal;
	position: relative;
	margin-left: 2em;
	padding-left: 1em;
	padding-right: 1em;
}
.info_foot h2 em::before,.info_foot h2 em::after{
	width: 25px;
	height: 50px;
	content: " ";
	display: inline-block;
	position: absolute;
	bottom: 50%;
	
	-webkit-transform: translate(0, 50%);
	transform: translate(0, 50%);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
.info_foot h2 em::before{
	background-image: url(../img/foot/title_left.png);
	left: 0;
}
.info_foot h2 em::after{
	background-image: url(../img/foot/title_right.png);
	right: 0;
}
.info_foot h2 span{
	font-size: 32px;
	margin-left: 0.5em;
	vertical-align: middle;
}
.info_foot > div{
	padding-top: 24px;
}
.info_foot > div div.info_sec{
	width: 520px;
	float: left;
}
.info_foot > div div.info_sec dl{
	background-color: #414159;
	color: #fff;
	font-weight: bold;
	
}
.info_foot > div div.info_sec dl dt{
	position: relative;
	display: inline-block;
	font-size: 18px;
	background-color: rgba(255,255,255,0.15);
	padding-top: 20px;
	padding-bottom: 18px;
	padding-left: 1em;
	padding-right: 1.7em;
	height: 65px;
	border-radius: 0 65px 65px 0;
}
.info_foot > div div.info_sec dl dd{
	display: inline-block;
	vertical-align: -8px;
	font-size: 36px;
	letter-spacing: 0;
	margin-left: 10px;
	line-height: 1;
}
.info_foot > div div.info_sec dl dd img{
	vertical-align: 2px;
	margin-right: 10px;
}
.info_foot > div div.info_sec table{
	margin-top: 24px;
	width: 100%;
}
.info_foot > div div.info_sec table tr{
	font-size: 16px;
	line-height: 1.65;
	text-align: left;
	vertical-align: middle;
	position: relative;
	border-bottom: 1px solid #111230;
	border-left: 1px solid #111230;
}
.info_foot > div div.info_sec table tr th{
	font-weight: bold;
	vertical-align: middle;
	padding-top: 24px;
	padding-bottom: 8px;
	padding-left: 16px;
	position: relative;
}
.info_foot > div div.info_sec table tr th::after{
	content: " ";
	display: block;
	width: 100%;
	height: 16px;
	background-color: #fff;
	position: absolute;
	left: -1px;
	top: 0;
}
.info_foot > div div.info_sec table tr th::before{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 14px 0 0 14px;
	border-color: transparent transparent transparent #111230;
	content: " ";
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
}
.info_foot > div div.info_sec table tr td{
	padding-top: 24px;
	padding-bottom: 8px;
	vertical-align: middle;
	
}
.info_foot > div div.map_sec{
	width: 462px;
	float: right;
}
.info_foot > div div.map_sec .map_wrap{
	position: relative;
	width: 100%;
	margin-top: 8px;
}
.info_foot > div div.map_sec .map_wrap:before {
    content:"";
    display: block;
    padding-top: 48%; /* 高さを幅の75%に固定 */
}
.info_foot > div div.map_sec .map_wrap iframe{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.info_foot > ul{
	margin-top: 32px;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	position: relative;
	padding-right: 258px;
}
.info_foot > ul li{
	padding-bottom: 16px;
}
.info_foot > ul li:last-of-type{
	position: absolute;
	right: 0;
	top: 0;
}
.info_foot.info_tokyo > ul{
	flex-wrap: wrap;
	padding-right: 0;
}
.info_foot.info_tokyo > ul li{
	width: 32%;
}

.info_foot.info_tokyo > ul li:last-of-type{
	position: relative;
}

.profile_foot{
	background-color: #d1d1d8;
	padding-top: 48px;
	padding-bottom: 72px;
	margin-top: 48px;
}
.profile_foot > div{
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	
	padding-right: 405px;
}
.profile_foot > div h2{
	font-size: 40px;
	font-family: "Times New Roman","游明朝", "Yu Mincho",YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	position: relative;
	margin-bottom: 32px;
}
.profile_foot > div h3{
	font-size: 28px;
	position: relative;
	font-family: "Times New Roman","游明朝", "Yu Mincho",YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	padding-left: 48px;
}
.profile_foot > div h3 em{
	font-size: 22px;
	margin-right: 1em;
}
.profile_foot > div h3 span{
	display: inline-block;
	background-color: #d1d1d8;
	position: relative;
	padding-left: 1em;
	padding-right: 1em;
	z-index: 50;
}
.profile_foot > div h3::after{
	content: " ";
	display: block;
	width: 100%;
	height: 2px;
	position: absolute;
	bottom: 50%;
	right: 50%;
	-webkit-transform: translate(50%, 50%);
	transform: translate(50%, 50%);
	
	background : -moz-linear-gradient(11.61% 587.53% 30deg,rgba(0, 0, 51, 1) 0%,rgba(51, 113, 133, 1) 32.69%,rgba(102, 128, 156, 1) 77.43%,rgba(0, 0, 51, 1) 100%);
	background : -webkit-linear-gradient(30deg, rgba(0, 0, 51, 1) 0%, rgba(51, 113, 133, 1) 32.69%, rgba(102, 128, 156, 1) 77.43%, rgba(0, 0, 51, 1) 100%);
	background : -webkit-gradient(linear,11.61% 587.53% ,88.39% -487.53% ,color-stop(0,rgba(0, 0, 51, 1) ),color-stop(0.3269,rgba(51, 113, 133, 1) ),color-stop(0.7743,rgba(102, 128, 156, 1) ),color-stop(1,rgba(0, 0, 51, 1) ));
	background : -o-linear-gradient(30deg, rgba(0, 0, 51, 1) 0%, rgba(51, 113, 133, 1) 32.69%, rgba(102, 128, 156, 1) 77.43%, rgba(0, 0, 51, 1) 100%);
	background : -ms-linear-gradient(30deg, rgba(0, 0, 51, 1) 0%, rgba(51, 113, 133, 1) 32.69%, rgba(102, 128, 156, 1) 77.43%, rgba(0, 0, 51, 1) 100%);
	background : linear-gradient(60deg, rgba(0, 0, 51, 1) 0%, rgba(51, 113, 133, 1) 32.69%, rgba(102, 128, 156, 1) 77.43%, rgba(0, 0, 51, 1) 100%);
	z-index: 1;
}

.profile_foot > div h5{
	position: absolute;
	right: 0;
	top: 110px;
}
.profile_foot > div dl{
	margin-left: 16px;
	margin-top: 16px;
}
.profile_foot > div dl dt{
	font-weight: bold;
	font-size: 18px;
	border-bottom: 2px solid #000000;
	position: relative;
}
.profile_foot > div dl dt::before{
	content: " ";
    display: block;
    width: 31px;
    height: 2px;
    position: absolute;
    background-color: #000;
    bottom: 50%;
    left: -22px;
    -webkit-transform: translate(0, 50%) rotate(45deg);
    transform: translate(0, 50%) rotate(64deg);
}
.profile_foot > div dl dd{
	font-size: 16px;
	margin-top: 16px;
	line-height: 1.75;
}
.profile_foot > div table{
	text-align: left;
	margin-top: 32px;
}
.profile_foot > div table caption{
	font-weight: bold;
	font-size: 18px;
	border-bottom: 2px solid #000000;
	position: relative;
	text-align: left;
	margin-left: 16px;
	margin-bottom: 20px;
}
.profile_foot > div table caption::before{
	content: " ";
    display: block;
    width: 31px;
    height: 2px;
    position: absolute;
    background-color: #000;
    bottom: 50%;
    left: -22px;
    -webkit-transform: translate(0, 50%) rotate(45deg);
    transform: translate(0, 50%) rotate(64deg);
}
.profile_foot > div table tr{
	border-bottom: 1px solid #000;
	font-size: 16px;
}
.profile_foot > div table tr:last-of-type{
	border-bottom: none;
}
.profile_foot > div table th{
	padding-left: 16px;
	padding-right: 8px;
	padding-top: 0.8em;
	padding-bottom: 0.7em;
	border-right: 1px dashed #000;
	vertical-align: top;
	white-space: nowrap;
}
.profile_foot > div table td{
	vertical-align: top;
	padding-left: 8px;
	padding-top: 0.8em;
	padding-bottom: 0.7em;
}
footer{
	background-color: #414159;
	color: #fff;
	text-align: center;
	padding-top: 32px;
	padding-bottom: 24px;
}
footer nav{
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
}
footer nav ul{
	
}
footer nav ul li{
	display: inline-block;
	font-size: 16px;
	position: relative;
	padding-left: 8px;
	padding-right: 8px;
}
footer nav ul li::after{
	content: " ";
	display: block;
	width: 1px;
	height: 100%;
	position: absolute;
	bottom: 50%;
	right: 0;
	-webkit-transform: translate(0, 50%);
	transform: translate(0, 50%);
	background-color: #fff;
}
footer nav ul li:first-of-type::before{
	content: " ";
	display: block;
	width: 1px;
	height: 100%;
	position: absolute;
	bottom: 50%;
	left: 0;
	-webkit-transform: translate(0, 50%);
	transform: translate(0, 50%);
	background-color: #fff;
}
footer p{
	font-size: 14px;
	font-weight: normal;
}
footer a {
	display: inline;
}

.button-menu {
	background-color: #111230;
	display: inline-block;
	position: fixed;
	top: 50%;
	right: 0;
	z-index: 100;
  }
  
  .button-menu ul {
	padding: 0 3.5px;
  }
  
  .button-menu ul li {
	background-repeat: no-repeat;
	background-size: 75%;
	background-position: 50% 20%;
	font-size: 10px;
	text-align: center;
	width: 70px;
  }
  
  .button-menu ul li a {
	display: block;
	color: #fff;
	padding-top: 62px;
  }
  
  .button-menu ul li:first-child {
	background-image: url('../img/fix-web.png');
  }
  
  .button-menu ul li:nth-child(2) {
	background-image: url('../img/fix-tel.png');
  }
  
  .button-menu ul li:nth-child(2) a {
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
  }
  
  .button-menu ul li:nth-child(3) {
	background-image: url('../img/fix-top.png');
  }


@media screen and (max-width:1024px){
	header h1{
		width: 100%;
	}
	header{
		padding-bottom: 4%;
		border-bottom: 2px solid #111230;
	}
	header img{
		width: 100%;
		height: auto;
	}
	header{
		padding-left: 4%;
		padding-right: 4%;
	}
	
	header h2{
		padding-top: 6%;
		padding-bottom: 4%;
		width: 60%;
		margin-left: auto;
	margin-right: auto;
		margin-bottom: 4%;
	}
	header h3{
		width: 50%;
	}
	header div{
		width: 100%;
			-webkit-align-items: center;
		align-items: center;
	}
	header div h4{
		font-size: 10px;
		text-align: right;
		margin-top: 0;
	}
	header nav{
		margin-top: 0;
		display: block;
		left: 0;
		right: 0;
	}
	header nav ul{
		width: 100%;
		display: none;
		position: fixed;
		padding-top: 8%;
		padding-bottom: 8%;
		top: 0;
		left: 0;
		right: 0;
		z-index: 500;
		background-color: #111230;
	}
	header nav ul li{
		width: 100%;
	}
	header nav ul li:nth-of-type(2){
		width: 100%;
	}
	header nav ul li:nth-of-type(n + 2){
		border-top: 1px dashed #fff;
	}
	header nav ul li:first-of-type::before,header nav ul li::after{
		content: none;
	}
	.open_btn,
	.open_btn span {
	  display: inline-block;
	  transition: all .4s;
	  box-sizing: border-box;
	}
	.open_btn::before{
		content: " ";
		display: block;
		width: 40px;
		height: 40px;
		background-color: #111230;
		position: absolute;
	bottom: 50%;
	right: 50%;
	-webkit-transform: translate(50%, 50%);
	transform: translate(50%, 50%);
	}
	.open_btn {
	  position: fixed;
		display: block;
		top: 4%;
		right: 4%;
	  width: 30px;
	  height: 30px;
		z-index: 600;
		
		padding: 5px;
	}
	.open_btn span {
	  position: absolute;
	  left: 0;
	  width: 100%;
	  height: 4px;
	  background-color: #fff;
	  border-radius: 4px;
	}
	.open_btn span:nth-of-type(1) {
	  top: 0;
	}
	.open_btn span:nth-of-type(2) {
	  top: 13px;
	}
	.open_btn span:nth-of-type(3) {
	  bottom: 0;
	}
	.open_btn.active span:nth-of-type(1) {
	  -webkit-transform: translateY(13px) rotate(-45deg);
	  transform: translateY(13px) rotate(-45deg);
	}
	.open_btn.active span:nth-of-type(2) {
	  opacity: 0;
	}
	.open_btn.active span:nth-of-type(3) {
	  -webkit-transform: translateY(-13px) rotate(45deg);
	  transform: translateY(-13px) rotate(45deg);
	}
	
	
	.contact_foot{
		padding: 10% 4% 24%;
		background-size: auto, contain;
   		background-position: center, right bottom;
	}
	.contact_foot h2{
		font-size: 28px;
	}
	.contact_foot section{
		width: 100%;
		display: block;
	}
	.contact_foot section h3{
		font-size: 24px;
	}
	.contact_foot section i{
		width: 32px;
		height: 34px;
		top: -17px;
		left: -7px;
	}
	.contact_foot section i img{
		width: 100%;
		height: auto;
	}
	
	.organizations_foot{
		width: 100%;
		padding-left: 4%;
		padding-right: 4%;
		margin-top: 12%;
	}
	.organizations_foot ul li{
		display: inline-block;
		padding-bottom: 4%;
	}
	.organizations_foot ul li img{
		zoom: 0.5;
	}
	.organizations_foot ul li:last-of-type{
		width: auto;
	}
	
	.info_foot{
		width: 100%;
		padding-left: 4%;
		padding-right: 4%;
	}
	.info_foot h2{
		text-align: center;
	}
	.info_foot h2 img{
		margin-bottom: 4%;
	}
	.info_foot h2 em{
		display: inline-block;
		margin-left: 0;
		margin-top: 1em;
	}
	.info_foot h2 span{
		display: block;
		margin-top: 0.5em;
		margin-left: 0;
	}
	.info_foot > div div.info_sec{
		width: 100%;
		float: none;
	}
	.info_foot > div{
		margin-top: 8%;
		padding-top: 10%;
	}
	.info_foot > div div.info_sec dl{
		display: -webkit-flex;
	display: flex;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
		-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
		-webkit-align-items: center;
	align-items: center;
	}
	.info_foot > div div.info_sec dl dt{
		font-size: 12px;
		padding-top: 16px;
    	padding-bottom: 12px;
		height: auto;
		margin-right: 10px;
	}
	.info_foot > div div.info_sec dl dd{
		font-size: 18px;
		margin-left: 0;
		margin-top: 0;
	}
	.info_foot > div div.info_sec dl dd img{
		zoom: 0.5;
	}
	.info_foot > div div.info_sec table{
		margin-top: 4%;
		display: block;
	}
	.info_foot > div div.info_sec table tbody{
		display: block;
	}
	.info_foot > div div.info_sec table tr{
		display: block;
		position: relative;
		padding: 8% 4%;
	}
	.info_foot > div div.info_sec table tr::after{
		    width: 0;
			height: 0;
			border-style: solid;
			border-width: 14px 0 0 14px;
			border-color: transparent transparent transparent #111230;
			content: " ";
			display: block;
			position: absolute;
			left: 0;
			bottom: 0;
	}
	.info_foot > div div.info_sec table tr::before{
		content: " ";
		display: block;
		width: 100%;
		height: 16px;
		background-color: #fff;
		position: absolute;
		left: -1px;
		top: 0;
	}
	.info_foot > div div.info_sec table tr th{
		display: block;
		padding: 0;
		padding-bottom: 0.8em;
		margin-bottom: 0.8em;
		border-bottom: 1px dashed #111230;
	}
	.info_foot > div div.info_sec table tr th::before,.info_foot > div div.info_sec table tr th::after{
		content: none;
		
	}
	.info_foot > div div.info_sec table tr td{
		display: block;
		padding: 0;
	}
	
	.info_foot > div div.map_sec{
		margin-top: 8%;
		float: none;
		width: 100%;
		
	}
	.info_foot > div div.map_sec img{
		width: 100%;
		height: auto;
	}
	
	.info_foot > ul{
		padding-right: 0;
	}
	.info_foot > ul li{
		width: 48%;
		padding-bottom: 4%;
	}
	.info_foot > ul li img{
		width: 100%;
		height: auto;
	}
	.info_foot > ul li:nth-of-type(n + 5 ){
		width: 100%;
		padding-right: 52%;
	}
	.info_foot > ul li:last-of-type{
		position: absolute;
		top: auto;
		bottom: 0;
		width: 48%;
		padding-right: 0;
	}
	.info_foot.info_tokyo > ul li{
		width: 32%;
		padding-right: 0;
	}


	.profile_foot{
		padding-left: 4%;
		padding-right: 4%;
	}
	.profile_foot > div{
		padding-right: 0;
		width: 100%;
	}
	.profile_foot > div h5{
		position: relative;
		width: 100%;
		top: auto;
		right: auto;
		margin-top: 2%;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 4%;
	}
	.profile_foot > div h5 img{
		width: 100%;
		height: auto;
	}
	footer{
		padding: 8% 4%;
	}
	footer nav{
		width: 100%;
	}
	footer nav ul{
		display: -webkit-flex;
	display: flex;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
		-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
		-webkit-align-items: stretch;
	align-items: stretch;
	}
	footer nav ul li{
		width: 33%;
		display: -webkit-flex;
	display: flex;
		-webkit-justify-content: center;
	justify-content: center;
		-webkit-align-items: center;
	align-items: center;
		font-size: 12px;
		margin-bottom: 2%;
	}
	footer nav ul li a{
		width: 100%;
	}
	footer nav ul li:nth-of-type(3n + 1)::before{
		    content: " ";
		display: block;
		width: 1px;
		height: 100%;
		position: absolute;
		bottom: 50%;
		left: 0;
		-webkit-transform: translate(0, 50%);
		transform: translate(0, 50%);
		background-color: #fff;
	}
	footer p{
		margin-top: 6%;
		font-size: 10px;
	}
}
@media screen and (max-width:768px){
.button-menu {
    bottom: 0;
    width: 100%;
    top: auto;
  }

  .button-menu ul {
    padding: 5px 3.5px;
  }

  .button-menu ul::after {
    content: "";
    display: block;
    clear: both;
  }

  .button-menu ul li {
    width: 33%;
    background-size: 20%;
    float: left;
  }

  .button-menu ul li:nth-child(2) a {
    border-top: none;
    border-bottom: none;
    border-left: 1px solid #fff;
    border-right: 1px solid #fff;
  }
  .button-menu ul li a {
    padding-top: 30px;
  }
}




.case_add {
	max-width: 1024px;
	width: 92%;
	margin-left: auto;
	margin-right: auto;
}
.case_add article {
	padding: 0 4%;
}

.under article.cases > section h3 {
	border-left: 4px solid #3f2965;
    font-size: 18px;
    font-weight: bold;
    margin-top: 3rem;
    margin-bottom: 1.5rem;
    padding: 0 0 0 1.4rem;
    cursor: pointer;
	text-align: left;
}
.case_add article .case_slider img {
	width: 100%;
	height: auto;
}
.case_add article h3 {
	border-left: 4px solid #3f2965;
	font-size: 18px;
	font-weight: bold;
	margin-top: 3rem;
	margin-bottom: 1.5rem;
	padding: 0 0 0 1.4rem;
	cursor: pointer;
}
.case_add article h3::after {
	font-family: "Font Awesome 5 Free";
	content: "\f078";
	display: inline-block;
	vertical-align: 0em;
	line-height: 1;
	margin-left: 0.5em;
}
.case_add article p {
	font-size: 16px;
	text-align: left;
	letter-spacing: 0.08em;
	line-height: 1.7;
}

.case_add article h3.accordion_title ~ p {
	display: none;
}
@media only screen and (max-width: 640px) {
	.case_add article:nth-of-type(n + 2) {
	  margin-top: 6vw;
	}
	.case_add article h3 {
	  font-size: 16px;
	}
	.case_add article p {
	  font-size: 14px;
	}
}


/* contact */
.contact{
	background-image: url(../img/foot/bg_contact.png),url(../img/foot/bg_contact_humen.png);
	background-size: auto,453px;
	background-position: center, right top;
	background-repeat: repeat,no-repeat;
	text-align: center;
	padding-top: 48px;
	padding-bottom: 48px;
}
.under article.contact > h2{
	font-family: "Times New Roman","游明朝", "Yu Mincho",YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 36px;
	color: #fff;
	letter-spacing: 0.08em;
	position: relative;
	display: inline-block;
	border-bottom: 1pt solid #fff;
	padding-left: 40px;
	padding-right: 40px;
	margin-bottom: 48px;
	background-color: transparent;
}
.under article.contact > h2::after,.under article.contact > h2::before{
	content: " ";
	display: block;
	top: -5px;
	bottom: -20px;
	width: 1px;
	background-color: #fff;
	position: absolute;
}
.under article.contact > h2::before{
	left: 20px;
}
.under article.contact > h2::after{
	right: 20px;
}
.contact h3{
	color: #fff;
	font-size: 20px;
	line-height: 2;
	margin-bottom: 32px;
}
.under article.contact > section {
	background-color: transparent;
	padding: 20px 0 30px;
}
.contact section i {
	position: absolute;
	top: -32px;
	left: -32px;
}
.contact section a {
	display: flex;
	align-items: center;
	justify-content: space-around;
	background: #efeff3;
	background : -moz-linear-gradient(9.98% 248.21% 30deg,rgba(17, 18, 48, 1) 0%,rgba(65, 65, 89, 1) 22.91%,rgba(65, 65, 89, 1) 47.47%,rgba(17, 18, 48, 1) 100%);
	background : -webkit-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	background : -webkit-gradient(linear,9.98% 248.21% ,170.07% -544.62% ,color-stop(0,rgba(17, 18, 48, 1) ),color-stop(0.2291,rgba(65, 65, 89, 1) ),color-stop(0.4747,rgba(65, 65, 89, 1) ),color-stop(1,rgba(17, 18, 48, 1) ));
	background : -o-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	background : -ms-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	border: 1px solid #fff;
	width: 400px;
	margin: auto;
	font-size: 35px;
	font-weight: 800;
	padding: 30px;
	color: #fff;
}
.contact section a:nth-child(2) {
	font-size: 30px;
}
.contact section a span {
	display: block;
	font-size: 14px;
	border: 1px solid #FFF;
	padding: 10px 15px;
}
.contact section a:nth-child(2) span {
	font-size: 12px;
	border: none;
}
.contact section a + a {
	margin-top: 35px;
}
.under .contact p {
	margin-bottom: 0;
	font-size: 16px;
	color: #fff;
}

.contact .link_text {
	font-size: 18px;
	color: #fff;
	cursor: pointer;
	margin-top: 1.5em;
	opacity: 1;
	font-weight: 600;
}

.contact .link_text:hover {
	opacity: 0.7;
}


@media screen and (max-width:1024px){
	.contact{
		padding: 10% 4% 24%;
		background-size: auto, contain;
		background-position: center, right bottom;
	}
	.contact h2{
		font-size: 28px;
	}
	.contact section{
		width: 100%;
		display: block;
	}
	.contact h3{
		font-size: 16px;
		margin-bottom: 20px;
	}
	.contact section i{
		width: 32px;
		height: 34px;
		top: -17px;
		left: -7px;
	}
	.contact section i img{
		width: 100%;
		height: auto;
	}

	.contact section a {
		width: 100%;
		font-size: 25px;
		padding: 20px 30px;
	}
	.contact section a:nth-child(2) {
		font-size: 20px;
	}
	.contact section a span {
		display: block;
		font-size: 12px;
		border: 1px solid #FFF;
		padding: 10px 15px;
	}
	
	.contact section a:nth-child(2) span {
		font-size: 12px;
		border: none;
		padding: 0;
	}
	.contact section a + a {
		margin-top: 20px;
	}

	.under .contact p {
		font-size: 14px;
	}
	
	.contact .link_text {
		font-size: 16px;
	}
}


/* info_foot */
.info_foot .btn_wrap a {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #efeff3;
	background : -moz-linear-gradient(9.98% 248.21% 30deg,rgba(17, 18, 48, 1) 0%,rgba(65, 65, 89, 1) 22.91%,rgba(65, 65, 89, 1) 47.47%,rgba(17, 18, 48, 1) 100%);
	background : -webkit-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	background : -webkit-gradient(linear,9.98% 248.21% ,170.07% -544.62% ,color-stop(0,rgba(17, 18, 48, 1) ),color-stop(0.2291,rgba(65, 65, 89, 1) ),color-stop(0.4747,rgba(65, 65, 89, 1) ),color-stop(1,rgba(17, 18, 48, 1) ));
	background : -o-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	background : -ms-linear-gradient(30deg, rgba(17, 18, 48, 1) 0%, rgba(65, 65, 89, 1) 22.91%, rgba(65, 65, 89, 1) 47.47%, rgba(17, 18, 48, 1) 100%);
	border: 1px solid #fff;
	width: 100%;
	margin: auto;
	font-size: 35px;
	font-weight: 800;
	padding: 20px;
	color: #fff;
}
.info_foot .btn_wrap a:nth-child(2) {
	font-size: 30px;
}
.info_foot .btn_wrap a span {
	display: block;
	font-size: 14px;
	border: 1px solid #FFF;
	padding: 10px 15px;
	margin-left: 20px;
}
.info_foot .btn_wrap a:nth-child(2) span {
	font-size: 12px;
	border: none;
}
.info_foot .btn_wrap a + a {
	margin-top: 20px;
}

@media screen and (max-width: 768px) {
	.info_foot .btn_wrap a {
		width: 100%;
		font-size: 25px;
		padding: 20px 30px;
	}
	.info_foot .btn_wrap a:nth-child(2) {
		font-size: 20px;
	}
	.info_foot .btn_wrap a span {
		display: block;
		font-size: 12px;
		border: 1px solid #FFF;
		padding: 10px 15px;
	}
	.info_foot .btn_wrap a:nth-child(2) span {
		font-size: 12px;
		border: none;
		padding: 0;
	}
	.info_foot .btn_wrap a + a {
		margin-top: 20px;
	}
}




