@charset "utf-8";
*
{
    margin: 0;
    padding: 0;
}

body
{
	background-color: #ffffff;
	color: #000000;
	font-family: 'Noto Sans JP', sans-serif;
	min-width: 350px;

}

	/*menu-modal*/
	#modal{
	    position: fixed;
	    top: 0;
	    z-index: 100;
	    width: 100%;
	    height: 100%;
	    background-color: #fff;
	}


.header-res{
    display: none;
}

header .head_texts
{
/*	max-width: 1000px; */
/*	margin: 0 auto; */
/*	text-align: center; */
}

header .head_texts .header_text
{
	height: 40px;
	margin: 25px 30px 0px 30px;
	font-size: 14px;
}
header .head_texts .header a
{
	text-decoration: none;
	color: #000000;
}

header .head_texts .header
{
	height: 69px;
	padding: 0px 30px 0px 30px;
	font-size: 35px;
}

header .head_texts .header .icon
{
	vertical-align: middle;
	margin-right: 21px;
}

header .head_texts .header .mailico
{
	float: right;
	margin-right: 32px;
}

header .head_texts .mailico .middlesize
{
	display: none; 
}

header .navigation
{
	margin: 0 auto;
	text-align: center;

	height: 52px;
	width: 100%;
	background-color: #d7eff1;
/*	max-width: 1000px; */
}

header .home
{
/*	background-image: url('../common/img/home_on.gif'); */
/*	background-color: #d7eff1;
	background-repeat: no-repeat;
 	background-size: cover;
*/
}

header .navigation ul.mainul
{
    list-style: none;
/*    padding: 0;*/
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
/*	padding: 8px 50px 0px 50px;  */
}

header .navigation ul.mainul ul
{
    display: none; 
    margin: 0px;
    padding: 0px;
    position: absolute;
/*	width: 350px; */
   z-index: 3;
}

header .navigation ul.mainul ul li
{
/*   line-height: 35px;*/
   text-align: left;      /* 文字列の配置(左寄せ) */
   padding-left: 5px;     /* 文字列前方の余白(5px) */
   z-index: 3;
   font-size: 18px;
   width: 100%;
   display: block;
}

eader .navigation ul.mainul ul li:last-child
{
	width: 100%; 
}



header .navigation ul.mainul ul li a
{
	display: block;
}


header .navigation ul.mainul li:hover
{
	background-color: #b2d6db; 
}


header .navigation ul.mainul li:hover ul, header .navigation ul.mainul li.mainli.naname:hover ul
{
   display: block  !important; 
}

header .navigation ul.mainul li.home
{
	background-color: #f0fed8 !important;
/*	background:linear-gradient(107deg, #f0fed8 0%, #f0fed8 90%, #d7eff1 50%, #d7eff1 100%);  */
	clip-path: polygon(0% 0%, 100% 0%, 75% 100%, 0% 100%) !important;
}

header .navigation ul.mainul li.naname
{
	background-color: #f0fed8 !important;
/*	background:linear-gradient(107deg, #f0fed8 0%, #f0fed8 90%, #d7eff1 50%, #d7eff1 100%);  */
	clip-path: polygon(25% 0%, 100% 0%, 75% 100%, 0% 100%) !important;
}

header .navigation ul.mainul li.about
{
	background-color: #f0fed8 !important;
/*	background:linear-gradient(107deg, #f0fed8 0%, #f0fed8 90%, #d7eff1 50%, #d7eff1 100%);  */
	clip-path: polygon(25% 0%, 100% 0%, 100% 100%, 0% 100%) !important;
}

header .navigation ul.mainul li.mainli ul li
{
	height: 48px; 
/*	height: auto; */

/*
	font-weight: 400;
	text-align: center;
	line-height: 1.1;
*/
/*	line-height: 48px; */
	background-color: #ebf8f9;
	padding-top: 11px; 
	padding-left: 6px;
	padding-right: 6px;
	padding-bottom: 11px;
	position: relative;  
	border: 1px dotted #9ba2a3;
/*
	vertical-align: middle; 
	display: inline-block;
*/
	display: flex;
    align-items: center;

}


#service_child li
{
	height: 48px; 
/*	height: auto; */

/*
	font-weight: 400;
	text-align: center;
	line-height: 1.1;
*/
	line-height: 48px; 
	background-color: #ebf8f9;
	padding-top: 11px; 
	padding-left: 6px;
	padding-right: 6px;
	padding-bottom: 11px;
	position: relative;  
	border: 1px dotted #9ba2a3;
/*
	vertical-align: middle; 
	display: inline-block;
*/
	display: block;
	vertical-align: middle; 
    align-items: center;
	text-align: left;
}

#service_child 
{
	display: none;
	position: absolute;
	top: 0;
	z-index: 5;
/*	bottom: 0;
	position: absolute;
*/
}

#service_child li a
{
	text-decoration: none;
	color: #000000;
	display: block;

}

#service_child li.selected
{
	background-color: #f0fed8;
/*	background-color: #000000 !important; */
}


#service_child li a:hover
{
	background-color: #b2d6db; 
}


header .navigation ul.mainul li.mainli
{
	height: 52px;
	font-weight: 400;
	text-align: center;
	line-height: 1.1;
	font-size: 11px;
	width: 18%; 
	background-color: #d7eff1;
	padding-top: 11px; 
   position: relative;  
}

header .navigation ul.mainul li.mainli:last-child
{
	width: 28%; 

}

.header .navigation ul.mainul li.mainli .big
{
	font-size: 22px;
}

header .navigation ul.mainul li.mainli a:hover
{
	background-color: #b2d6db; 
}

header .navigation ul.mainul li.mainli a
{
	display: block; 
    color: #000;
    text-decoration: none;
}

header .catchcopy
{
	position: relative;
}

header .catchcopy p
{
	position: absolute;
	color: #ffffff;
/*	top: 95px; */
	top: 27%;
	left: 10%;
	font-size: 20px;
	width: 60%;
	line-height: 2;
}

header .catchcopy img
{
	width: 100%;
}

header .catchcopy_subpage
{
	position: relative;
}

header .catchcopy_subpage p
{
	position: absolute;
	color: #ffffff;
/*	top: 95px; */
	top: 22%;
	left: 10%;
	font-size: 40px;
	width: 60%;
	line-height: 2;
}

header .catchcopy_subpage img
{
	width: 100%;
}



#main
{
	max-width: 1000px;
	margin: 50px auto 0px auto;
	text-align: center;
}

#main .pankuzu
{
	text-align: left;

	margin-top: -25px;
	margin-bottom: 25px;
	font-size: 80%;
}


.news_and_books
{
    display: flex;
    justify-content: space-between;
	align-items:stretch;

	padding: 45px 32px 25px 32px;
}

.news_and_books .left
{
	width: 66%;
	display:flex;
	flex-direction:column;
	align-items:stretch;
}

.news_and_books .newsbox
{
	border: 1px solid;
	height: 256px;
	overflow-y: scroll;
	padding: 25px 20px 25px 20px;
}

.news_and_books .newsbox .newstexts
{
	border-bottom: dotted 1px #222222;
	padding: 0px 20px 20px 20px;
	text-align: left;
}

.news_and_books .newsbox .newstexts:not(:first-child)
{
	padding: 20px 20px 20px 20px;
}


.news_and_books .newsbox .newstexts .news_head
{
	margin-bottom: 5px;
	display: block;
}

.news_and_books .newsbox .newstexts a
{
    text-decoration: none;
	display: block;
	color: #000000;

}

.news_and_books .newsbox .newstexts .text_inner
{
    display: flex;
    justify-content: space-between;
/*    align-items: flex-end; */
	align-items:stretch;
}

.news_and_books .newsbox .newstexts .text_inner .text
{
	display:flex;
	flex-direction:column;
	align-items:stretch;
	width: 95%;
}

.news_and_books .newsbox .newstexts .text_inner .right_link
{
	display:flex;
	flex-direction:column;
	align-items:stretch;
	text-align: right;
	width: 5%;
}

.news_and_books .newsbox .newstexts .text_inner .right_link a
{
    text-decoration: none;
}

.news_and_books .newsbox .newstexts .text_day
{
	font-size: 17px;
	margin-right: 45px;
}

.news_and_books .newsbox .newstexts .text_title
{
	font-size: 17px;
	color: #60d3ce;
}

.news_and_books .right
{
/*	display:flex; */
	flex-direction:column;
	align-items:stretch;
	width: 31%;
}

.news_and_books .right .book
{
	width: 100%
/*	275; */

	border: 1px solid #f4f4f4;
	box-shadow: 2px 2px 4px gray;
	padding: 10px;
/*	margin-top: 0px;*/
}

.news_and_books .right div.book:nth-child(n+2)
{
	margin-top: 20px;
}

.news_and_books .right .book .inner
{
    display: flex;
    justify-content: space-between;
	align-items:stretch;
	word-break: break-all;

}

.news_and_books .right .book .inner .imgbox
{
	display:flex;
	flex-direction:column;
	align-items:stretch;
	width: 71px;
	margin-right: 12px;
}

.news_and_books .right .book .inner .text
{
	display:flex;
	flex-direction:column;
	align-items:stretch;
	width: 200px;
	font-size: 14px;
	text-align: left;
}

.news_and_books .right .book .inner .title_book
{
	font-size: 17px;
	line-height: 1.1;
	margin-bottom: 4px;
}

.news_and_books .title
{
	font-size: 22px;
	margin-bottom: 20px;
}

.service_box
{
    display: flex;
    justify-content: space-between;
/*    align-items: flex-end; */
	align-items:stretch;

}

.service_box .box1btn_sp, .service_box .box2btn_sp, .service_box .box3btn_sp 
{
	display: none;
}

.service_box .box1btn, .service_box .box2btn, .service_box .box3btn 
{
	display:flex;
	flex-direction:column;
	
	height:auto;
	width: 31%;
	background-color: #ffffff;
	border-radius: 0px 0px 10px 10px;
	font-size: 16px;
	text-align: center;
	margin-bottom: 8px
}


.service_box .box1btn .btn, .service_box .box2btn .btn, .service_box .box3btn .btn
{
	margin-bottom: 8px;
}

.service_box .box1btn .btn img, .service_box .box2btn .btn img, .service_box .box3btn .btn img
{
	max-width: 100%;
	width: auto;
}

.service_box .box1
{
	display:flex;
	flex-direction:column;
	
	height:auto;
	width: 31%;
	background-color: #ffffff;
	border-radius: 10px 10px 0px 0px;
	font-size: 16px;
}

.service_box .box1 .inner_text
{
	margin: 25px;
	text-align: left;
}

.service_box .box1 .inner_text .imgbox, .service_box .box2 .inner_text .imgbox, .service_box .box3 .inner_text .imgbox
{
	text-align: center;
}

.service_box .box1 .inner_text .title, .service_box .box2 .inner_text .title, .service_box .box3 .inner_text .title
{
	line-height: 1.1;
	font-size: 22px;
}

.service_box .box2
{
	display:flex;
	flex-direction:column;
	align-items:stretch;
	height:auto;
	width: 31%;
	background-color: #ffffff;
	border-radius: 10px 10px 0px 0px;
	font-size: 16px;
}
.service_box .box2 .inner_text
{
	margin: 25px;
	text-align: left;
}

.service_box .box3
{
	display:flex;
	flex-direction:column;
	align-items:stretch;
	height:auto;
	width: 31%;
	background-color: #ffffff;
	border-radius: 10px 10px 0px 0px;
	font-size: 16px;

}
.service_box .box3 .inner_text
{
	margin: 25px;
	text-align: left;
}


.ourservice
{
	padding: 25px 32px 25px 32px;
	background-color: #f3efe6;
}

.ourservice .title
{
	font-size: 22px;
	margin-bottom: 25px;
}



footer
{
	margin: 30px auto 0px auto;
	text-align: center;
	background-color: #b1dedc;
}

footer .title
{
	font-size: 33px;
	padding-top: 55px;
	padding-bottom: 30px;
}

footer .text
{
	font-size: 14px;
	margin-top: 30px;
	margin-bottom: 30px;
}

footer .copyright
{
	padding-bottom: 20px;
	font-size: 14px;
}

footer input
{
	width: 215;
	height: 50px;
	text-align: center;

}

.sansExtraLight
{
	font-weight: 100;
}

.sansLight
{
	font-weight: 300;
}
.sansBold
{
	font-weight: 700;
}
.sansMedium
{
	font-weight: 500;
}

.sansRegular
{
	font-weight: 400;
}

#menu-modal{
    width: 90%;
    height: 100%;
    padding: 20px 5%;
    overflow-y: scroll;
    scrollbar-width: none;
}
#modal-wrap::-webkit-scrollbar {
    display:none;
}
#close{
    float: right;
    font-size: 30px;
    cursor: pointer;
}
.modal-top{
    margin-top: 50px;
}
.menu-btn-wrap{
    display: none;
	height: 50px;
}

@media all and (max-width: 890px) {

	.news_and_books .title
	{
		font-size: 19px;
	}

}

@media all and (max-width: 810px) {

	.news_and_books .title
	{
		font-size: 18px;
	}

	header .head_texts .header .mailico
	{
		margin-right: 10px;
	}

	.header .head_texts .mailico .middlesize
	{
		display: inline;
	}

	.header .head_texts .mailico .maxsize
	{
		display: none;
	}

	header .catchcopy p
	{
		position: absolute;
		color: #ffffff;
	/*	top: 95px; */
		top: 27%;
		left: 10%;
		font-size: 20px;
		width: 60%;
		line-height: 1.5;
	}

}

@media all and (max-width: 750px) {

	.news_and_books .title
	{
		font-size: 17px;
	}

	.header .navigation ul li .big
	{
		font-size: 19px;
	}
}

/* news and book 100%へ */
@media all and (max-width: 710px)
{
	.news_and_books
	{
		display: inline-block;
	}
	.news_and_books .left
	{
		width: 100%;
	}

	.news_and_books .right
	{
		width: 100%;
		margin-top: 15px;
	}
	.news_and_books .right .book .inner .text
	{
		width: auto;
	}
	header .catchcopy_subpage p
	{
		top: 18%;
		left: 10%;
		font-size: 40px;
		width: 60%;
		line-height: 2;
	}


}

@media all and (max-width: 660px) {

	.header .head_texts .mailico .middlesize
	{
		display: none;
	}

	.service_box
	{
		display: inline-block;
	}

	header .catchcopy p
	{
		position: absolute;
		color: #ffffff;
	/*	top: 95px; */
		top: 4%;
		left: 4%;
		font-size: 18px;
		width: 65%;
		line-height: 1.5;
		background-color: rgba(30, 30, 30, 0.12);
		padding: 5px;
	}

	.service_box .box1btn_sp, .service_box .box2btn_sp, .service_box .box3btn_sp 
	{
		display:flex;
		flex-direction:column;

		height:auto;
/*		width: 100%; */
		background-color: #ffffff;
		border-radius: 0px 0px 10px 10px;
		font-size: 16px;
		text-align: center;
		margin-bottom: 20px
	}


	.service_box .box1btn_sp .btn, .service_box .box2btn_sp .btn, .service_box .box3btn_sp .btn
	{
		margin-bottom: 12px;
	}

	.service_box .box1btn_sp .btn img, .service_box .box2btn_sp .btn img, .service_box .box3btn_sp .btn img
	{
		max-width: 100%;
		width: auto;
	}


	.service_box .box1, .service_box .box2, .service_box .box3 
	{
		width: 100%;
	}

	.service_box .box1btn, .service_box .box2btn, .service_box .box3btn 
	{
		display: none;
	}

	header .head_texts .header
	{
		font-size: 30px;
	}

	header .head_texts .header
	{
	    padding: 0px 0px 0px 30px;
	}

	header .head_texts .header .mailico
	{
		margin-right: 0px;
	}
    .menu-btn-wrap{
        display: block;
		height: 50px;
    }

    .menu-btn-wrap img{
		width: 50px;
	}
	.menu-btn-wrap
	{
		text-align: center;
		line-height: 1.0;
	}
	.menu-btn-wrap .txt
	{
		font-size: 10px;
		margin-top: -10px;
	}
	.navigation
	{
		display: none;
	}

}

@media all and (max-width: 539px) {

	header .head_texts .header
	{
	    padding: 0px 0px 0px 5px;
	}

	header .head_texts .header_text
	{
		margin: 25px 5px 0px 5px;
/*		margin: 25px 30px 0px 30px; */
	}

/*	header .head_texts .header
	{
		font-size: 28px;
	}
*/
}
@media all and (max-width: 505px) {
	header .head_texts .header
	{
		font-size: 26px;
	}
	header .head_texts .header .icon 
	{
		margin-right: 5px;
	}
	header .catchcopy p
	{
		position: absolute;
		color: #ffffff;
	/*	top: 95px; */
		top: 3%;
		left: 3%;
		font-size: 17px;
		width: 65%;
		line-height: 1.5;
		background-color: rgba(30, 30, 30, 0.12);
		padding: 5px;
	}

	header .catchcopy_subpage p
	{
		top: 15%;
		left: 10%;
		font-size: 40px;
		width: 60%;
		line-height: 2;
	}
	footer .text
	{
		font-size: 12px;
	}

}

@media all and (max-width: 450px) {
	header .head_texts .header
	{
		font-size: 24px;
	}
	header .head_texts .header_text
	{
		height: auto;
	}

	header .catchcopy p
	{
		top: 2%;
		left: 2%;
		font-size: 15px;
		line-height: 1.4;
		padding: 5px;
	}
	.news_and_books .newsbox
	{
		padding: 10px 10px 10px 10px;
	}
	.news_and_books .newsbox .newstexts
	{
		padding: 10px 10px 10px 10px;
	}

}
@media all and (max-width: 400px) {
	header .head_texts .header
	{
		font-size: 22px;
	}
	header .catchcopy p
	{
		top: 2%;
		left: 2%;
		font-size: 14px;
		line-height: 1.4;
		padding: 5px;
		background-color: rgba(30, 30, 30, 0.2);
	}

	header .catchcopy_subpage p
	{
		top: 13%;
		left: 10%;
		font-size: 40px;
		width: 60%;
		line-height: 2;
	}

}
@media all and (max-width: 418px) {
	header .head_texts .header
	{
		font-size: 20px;
	}
	footer .title
	{
		font-size: 30px;
	}

}

@media all and (max-width: 375px) {
	header .head_texts .header
	{
		font-size: 20px;
	}
	header .catchcopy p
	{
		top: 2%;
		left: 2%;
		font-size: 13px;
		line-height: 1.4;
		padding: 5px;
		background-color: rgba(30, 30, 30, 0.2);

	}
	footer .title
	{
		font-size: 28px;
	}

}

@media all and (max-width: 367px) {
	header .head_texts .header
	{
		font-size: 19px;
	}
}

@media all and (max-width: 350px) {

	header .head_texts .header
	{
		font-size: 19px;
	}

}

