@charset "utf-8";


/* 幅644px以下から ヘッダー等微調節
--------------------------------------------------------------------------------------------------*/
@media only screen and (max-width: 481px){
	
.spDisp {
	display:block;
}

.spHide {
	display:none;
}

.box {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
}

.img100 img{
	width:100%;
	height:auto;
}

/*　見出し・画像　*/

.pic-left {
	float: none;
	width:94%;
	height:auto;
}



/*　見出し・画像　*/

.midashi1 {
	margin-bottom:35px;
}

.midashi1 span{
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 700;
	font-size: 45px;
	border-bottom-width: 5px;
	border-bottom-style: solid;
	border-bottom-color: #4849e8;
	padding-bottom: 10px;
}

.midashi2 {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-size: 18px;
}

.m2_g {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	font-size: 18px;
	color: #4849e8;
}

.m2_under {
	background: linear-gradient(transparent 60%, #FFF 60%);
	color: #000;
}

.midashi3 {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	font-size: 22px;
	margin-bottom: 30px;
	padding-bottom: 15px;
	border-bottom-width: 4px;
	border-bottom-style: dotted;
	border-bottom-color: #CCCCCC;
}



/*　ヘッダー　*/


header {

}

.header_cont {
	width: 100%;
	background-repeat: repeat;
	overflow: hidden;
}

.header_logo {
	float: none;
	padding-top: 20px;
	padding-bottom: 20px;
	width: 100%;
	text-align: center;
}

.header_logo img{
	width: 20%;
	height: auto;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 10px;
}

.toph1 {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-size: 16px;
}

.toph1 span{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-size:30px;
	padding-top:5px;
	display:block;
}

.main_img {
	background-image: url(../img/main_img.webp);
	background-repeat: no-repeat;
	background-position: right center;
	background-size:cover;
}

.main_icont {
	width: 90%;
	margin-left: 5%;
	margin-right: 5%;
	padding-top: 12%;
	padding-bottom: 12%;
}

.main_icont h2{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	font-size: 25px;
	color: #FFFFFF;
	text-shadow: 2px 2px 8px #333333;
	line-height: 1.4em;
}

.main_icont h2 span{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	font-size: 35px;
	color: #FFFFFF;
	text-shadow: 2px 2px 8px #333333;
}

.main_icont h3 {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	font-size: 16px;
	color: #FFFFFF;
	text-shadow: 2px 2px 8px #333333;
	margin-bottom: 30px;
}

.main1 {
	background-color: #F2F2F2;
	padding-top: 60px;
	padding-bottom: 100px;
}

.main1_c {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
}

.main1_l {
	width: 100%;
	text-align: center;
	margin-bottom: 40px;
}

.main1_r {
	width:100%;
}

.main1_r p{
	font-size: 18px;
	line-height: 1.8em;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
}

.main2 {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 80px;
}

.main2_cir {
	margin-bottom: 40px;
	margin-top:-50px;
}

.main2_cir ul{
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}

.main2_cir ul li{
	background-color: #4849e8;
	height: 100px;
	width: 100px;
	border-radius: 50%;
	margin-right: 5px;
	margin-left: 5px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom:10px;
}

.main2_cir ul li p{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	font-size: 17px;
	text-align: center;
	line-height: 1.3em;
	color: #FFF;
}

.main2_m {
	text-align: center;
	margin-bottom:50px;
}

.main2_pic {
	margin-bottom:50px;
}

.main2_pic img{
	width:100%;
	height:auto;
}

.main2_list {
	margin-bottom:50px;
}

.main2_list ul{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}

.main2_list ul li{
	width: 46%;
	text-align: center;
	margin-bottom: 3%;
	display: block;
	display: block;
	border: 5px solid #4849e8;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	padding-top: 15px;
	padding-bottom: 15px;
}

.main2_list ul li a{
	text-decoration: none;
}

.main2_list ul li img{
	width:100%;
	height:auto;
	margin-bottom:10px;
}

.main2_list ul li p {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	color: #000;
}

.main2_list ul li a:hover{
	opacity: 0.7;
    filter: alpha(opacity=70);
    -moz-opacity: 0.7;
}

.main2_work ul{
	margin-bottom:30px;
}

.main2_work ul li{
	width:100%;
	margin-bottom:20px;
}

.main2_work ul li img{
	width:100%;
	height:auto;
	margin-bottom:5px;
}

.main2_work ul p{
	text-align: center;
	font-size:16px;
}

.main2_btn {
	display: flex;
	justify-content: center;
	width: 85%;
	text-align: center;
	text-decoration: none;
	margin-right: auto;
	margin-left: auto;
	border-radius: 50px;
	-webkit-border-radius: 50px;
	-moz-border-radius: 50px;
	padding-top: 10px;
	padding-bottom: 15px;
	background-color: #4849e8;
}

.main2_btn p{
	font-size: 20px;
	color: #FFFFFF;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
}

.main2_btn:hover {
	background-color: #6363EB;
}


.main3_wrap {
	background-color: #F2F2F2;
	padding-top: 80px;
	padding-bottom: 80px;
}

.main3 {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
	margin-bottom: 30px;
}

.main3_m {
	text-align: center;
	margin-bottom: 80px;
}

.main3_c {
	width: 84%;
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	padding-right: 8%;
	padding-bottom: 8%;
	padding-left: 8%;
	margin-bottom: 50px;
	background-color: #FFF;
}

.main3_nb {
	background-color: #4849e8;
	height: 80px;
	width: 80px;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-right: auto;
	margin-left: auto;
	margin-top: -40px;
	margin-bottom: 20px;
}

.main3_nb p{
	color: #FFF;
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 700;
	font-size: 60px;
	text-align: center;
	padding-bottom:5px;
}

.main3_c h5{	
	text-align: center;
	margin-bottom: 30px;
}

.main3_c h5 p{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-size: 27px;
}

.main3_list {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 80px;
}

.main3_list ul li{
	text-indent: -1em;
	padding-left: 1em;
	margin-bottom: 10px;
}

.main3_btn {
	display: flex;
	justify-content: center;
	width: 80%;
	text-align: center;
	text-decoration: none;
	margin-right: auto;
	margin-left: auto;
	border-radius: 50px;
	-webkit-border-radius: 50px;
	-moz-border-radius: 50px;
	padding-top: 10px;
	padding-bottom: 15px;
	background-color: #4849e8;
}

.main3_btn p{
	font-size: 20px;
	color: #FFFFFF;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
}

.main3_btn:hover {
	background-color: #4849e8;
}

.main4 {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
	padding-top: 80px;
	padding-bottom: 80px;
}

.main4_c {
}

.main4_in {
	width: 100%;
	margin-bottom:30px;
}

.main4_in img{
	width:100%;
	height:auto;
	margin-bottom:20px;
}

.main4_m {
	display: flex;
	align-items: flex-start;
	justify-content:flex-start;
	margin-bottom:25px;
}

.main4_nb {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 700;
	font-size: 60px;
	color: #4849e8;
	margin-right: 10px;
}

.main4_mt {
	font-size: 20px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	margin-top: 10px;
	line-height: 1.2em;
}

.main5 {
}

.main5_1 {
	width: 84%;
	background-color: #F8F8F8;
	padding: 8%;
}

.main5_2 {
	width: 100s%;
	background-image: url(../img/main5.webp);
	background-repeat: no-repeat;
	background-position: right center;
	background-size:cover;
	height:350px;
}

.main5_m {
	margin-bottom:50px;
}

.main5_t {
	line-height: 1.8em;
}

.main6 {
	background-color: #66bfaf;
	text-align: center;
	padding-top: 50px;
	padding-bottom: 50px;
	background-image: url(../img/contact_back.jpeg);
	background-size:cover;
}

.main6 h5{
	font-size: 30px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	color: #FFF;
	margin-bottom: 45px;
	letter-spacing: 0.05em;
}

.main6_btn {
	display: flex;
	justify-content: center;
	width: 80%;
	text-align: center;
	text-decoration: none;
	margin-right: auto;
	margin-left: auto;
	border-radius: 50px;
	-webkit-border-radius: 50px;
	-moz-border-radius: 50px;
	padding-top: 10px;
	padding-bottom: 15px;
	background-color: #FFFFFF;
}

.main6_btn p{
	font-size: 20px;
	color: #000000;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
}

.main6_btn:hover {
	background-color: #CCCCCC;
}

.comp_pro {
	width: 85%;
	padding-top: 80px;
	padding-bottom: 80px;
	margin-right: auto;
	margin-left: auto;
}

.comp_dl dl{
}

.comp_dl dl dt{
	padding-top: 20px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	padding-left: 10px;
}

.comp_dl dl dd{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #999;
	flex: 1;
	padding-top: 20px;
	padding-bottom: 20px;
	padding-left: 10px;
}

footer {
	background-color: #F2F2F2;
	padding-top: 55px;
	padding-bottom: 55px;
}

.footer_c {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
}

.foot_info {
	text-align: center;
}

.foot_info a{
	text-decoration: none;
	color: #000;
}

.foot_logo {
	width: 100px;
	margin-bottom: 30px;
	margin-right: auto;
	margin-left: auto;
}

.foot_logo img{
	width:100%;
	height:auto;
}

.foot_sn {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-size:16px;
	margin-bottom:30px;
}

.foot_sn span{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-size:23px;
}


.foot_info p{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
}


.copyright {
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 700;
	color: #000;
	float: none;
	padding-top: 50px;
	text-align: center;
}

.page_title {
	width: 100%;
	text-align: center;
	padding-top: 50px;
	border-top-width: 1px;
	border-bottom-width: 1px;
	border-top-style: solid;
	margin-bottom:40px;
}

.page_title h3 {
	position: relative;
	display: inline-block;
	margin-bottom: 1em;
	font-size: 30px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
}

.page_title h3:before {
	content: '';
	position: absolute;
	bottom: -30px;
	display: inline-block;
	width: 60px;
	height: 5px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	background-color: black;
	border-radius: 2px;
}

.page_cont {
	width: 85%;
	margin-right: auto;
	margin-left: auto;
	padding-bottom: 200px;
}

.cont_bo {
	background-color: #F3F3F3;
	text-align: left;
	padding: 5%;
	margin-bottom: 50px;
}

.works_wrap {
	margin-bottom: 10%;
	padding-bottom: 10%;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCC;
}


.works_c {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
	margin-bottom:20px;
}

.works_pic {
	width:100%;
	margin-bottom:20px;
}

.works_pic img{
	width:100%;
}

.works_txt {
	width:100%;
}

.works_txt h4{
	font-size: 18px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
	margin-bottom:20px;
}

.works_txt table{
	width:100%;
	border-collapse:collapse;
}

.works_txt table th {
	background-color: #4849e8;
	padding: 8px;
	color: #FFF;
	width:120px;
	font-size:15px;
	border-bottom-width: 2px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
	vertical-align: middle;
}

.works_txt table td {
	padding: 8px;
	background-color: #F9F9F9;
	border-bottom-width: 2px;
	border-left-width: 2px;
	border-bottom-style: solid;
	border-left-style: solid;
	border-bottom-color: #FFF;
	border-left-color: #FFF;

}

.works_wrap ul{
	display: flex;
	justify-content:flex-start;
	align-items: stretch;
	flex-wrap: wrap;
}

.works_wrap ul li{
	width:100%;
	margin-bottom:5px;
}

.works_wrap ul li img{
	width:100%;
	height:auto;
}


.pay_logo {
	width:100%;
	margin-bottom: 20px;
}

.pay_logo img{
	width:100%;
	height:auto;
}

.foot_banner ul {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}

.foot_banner ul li{
	width: 80%;
	margin-bottom:5px;
}

.foot_banner ul li img{
	width:100%;
	height:auto;
}

}
