@charset "UTF-8";


/* cell */
.cell {
	margin-bottom: 70px;
}

.cell:nth-last-child(1) {
	margin-bottom: 0;
}

.cell p.txt {
	margin-bottom: 15px;
}

.cell p.txt:nth-last-child(1) {
	margin-bottom: 0;
}

.cell p.txt a {
	color: #00F;
	text-decoration: underline;
}

.cell p.txt a:hover {
	text-decoration: none;
}

.cell p.txt_greeting {
	text-align: right;
	margin-top: 3%;
}

.flex_aboutus p {
	display: inline;
}

.cell p.txt_president {
	text-align: right;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	font-size: 2.8rem;
}

.cell p.txt_philosophy {
	text-align: center;
	line-height: 3em;
}

.cell p.txt_philosophy strong {
	font-size: 2rem;
}

.cell p.txt_philosophy_policy {
	width: 90%;
	margin-left: 12%;
	margin-bottom: 10px;
	padding-top: 10px;
	font-size: 1.5rem;
	font-weight: 300;
	line-height: 2em;
}

.cell p.txt_philosophy_policy strong {
	font-size: 2rem;
}


.cell p.txt_privacy_policy {
	padding-left: 20px;
}


/* width */
.width_philosophy {
	width: 70%;
	margin: auto;
	margin-bottom: 70px;
}


/* pht */
.pht {
	width: 80%;
	text-align: center;
	margin: auto;
}

/* table */
.table_aboutus {
	width: 80%;
	margin: auto;
	text-align: center;
	border-collapse: collapse;
	border-spacing: 0;
	border-top: solid 1px #ddd;
}

.table_aboutus th,
.table_aboutus td {
	padding: 15px;
	border-bottom: solid 1px #ddd;
	text-align: left;
}

.table_aboutus th {
	width: 20%;
	padding-left: 20px;
	vertical-align: top;
}


/* title */
.title {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: solid 1px #ddd;
	padding-bottom: 15px;
	margin-bottom: 40px;
}

.title h2 {
	font-size: 3.0rem;
	font-weight: 600;
	line-height: 1.3em;
}

.title .en {
	font-size: 1.2rem;
	line-height: 1.3em;
}


/* h3_tit */
.h3_tit {
	font-size: 2.4rem;
	font-weight: 600;
	line-height: 1.3em;
	padding-left: 30px;
	margin-bottom: 20px;
	background: url("../../common/img/icon_tit.svg") no-repeat left top 3px;
}


.h3_tit_philosophy {
	font-size: 2.4rem;
	font-weight: 400;
	line-height: 1.3em;
	text-align: center;
	margin: auto;
	border-bottom: #00F 1px solid;
	/* width: 60%; */
	padding-bottom: 10px;
	margin-bottom: 20px;
	margin-top: 10%;
}


/* h4_tit */
.h4_tit {
	font-size: 2.0rem;
	font-weight: 600;
	line-height: 1.3em;
	margin-bottom: 10px;
}


/* column02-list */
.column02-list {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.column02-list .box {
	display: block;
	width: 48%;
	margin-right: 4%;
	margin-bottom: 30px;
}

.column02-list .box:nth-child(2n) {
	margin-right: 0;
}

.column02-list .box .pht {
	margin-bottom: 15px;
}

.column02-list .box .txt-center {
	text-align: center;
}


/* column03-list */
.column03-list {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.column03-list .box {
	display: block;
	width: 31%;
	margin-right: 3.5%;
	margin-bottom: 30px;
}

.column03-list .box:nth-child(3n) {
	margin-right: 0;
}

.column03-list .box .pht {
	margin-bottom: 15px;
}


/* column04-list */
.column04-list {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.column04-list .box {
	display: block;
	width: 23.5%;
	margin-right: 2%;
	margin-bottom: 30px;
}

.column04-list .box:nth-child(4n) {
	margin-right: 0;
}

.column04-list .box .pht {
	margin-bottom: 15px;
}


/* text-pht */
.text-pht {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.text-pht .text {
	width: 55%;
	padding-right: 4%;
}

.text-pht .pht {
	width: 45%;
}


/* pht-text */
.pht-text {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.pht-text .text {
	width: 55%;
	padding-left: 4%;
	order: 2;
}

.pht-text .pht {
	width: 45%;
	order: 1;
}


/* list-icon */
ul.list-icon {
	margin-bottom: 30px;
}

ul.list-icon li {
	margin-bottom: 8px;
	font-size: 1.5rem;
	line-height: 1.6em;
	padding-left: 16px;
	position: relative;
}

ul.list-icon li:before {
	content: "";
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #00B1FD;
	position: absolute;
	top: 7px;
	left: 0;
}

ul.list_sitepolicy,
ul.list_privacy_policy {
	padding-left: 20px;
	list-style-position: outside;
}

ul.list_sitepolicy li,
ul.list_privacy_policy li {
	list-style-type: disc;

}

ol {
	list-style: none;
	counter-reset: my-counter;

}

ol li {
	display: flex;
	/* 行の高さを制御するために flex レイアウトを使用 */
}

ol li:before {
	content: "("counter(my-counter) ")";
	counter-increment: my-counter;
	margin-right: 0.5em;
}



/* btn */
.btn {
	width: 230px;
	margin: 20px auto 0 auto;
}

.btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 56px;
	border-radius: 28px;
	background: #00F url("../../common/img/icon_arrow_white.svg") no-repeat right 15px center;
	font-size: 1.6rem;
	color: #fff;
	text-align: center;
}

.btn a:hover {
	background: #00F url("../../common/img/icon_arrow_white.svg") no-repeat right 12px center;
}

.btn_aboutus {
	display: inline
}

.btn_aboutus a {
	padding: 0 6% 0 4%;
	margin-left: 20px;
	justify-content: center;
	align-items: center;
	border-radius: 28px;
	background: #00B1FD url("../../common/img/icon_arrow_white.svg") no-repeat right 15px center;
	font-size: 1.6rem;
	color: #fff;
	text-align: center;
}

.btn_aboutus a:hover {
	background: #00B1FD url("../../common/img/icon_arrow_white.svg") no-repeat right 10px center;
	opacity: 0.7;
}

/* chart */

.chart_sp {
	display: none;
}



/* history */
.history {
	display: flex;
	font-weight: bold;
	padding-top: 10px;
	font-size: 16px;
	position: relative;
	border-top: 2px solid #ddd;
	margin: auto;
	padding-bottom: 10px;
}

.history::before {
	content: '';
	position: absolute;
	top: -2px;
	width: 13%;
	height: 2px;
	background: #00F;
}

.history .year {
	width: 13%;
	color: #00F;
	font-family: 'Roboto', sans-serif;
	font-weight: 500;
	font-size: 1.8em;
	text-align: center;
}

.history .year_jp {
	width: 12%;
	text-align: center;
	margin-top: 11px;
}

.history .paragraph {
	width: 45%;
	font-weight: 400;
	margin-top: 11px;
}

.history .img {
	width: 30%;
	margin-top: 11px;
	margin-bottom: 12px;
}

.history_cont {
	display: flex;
	font-weight: bold;
	padding-top: 10px;
	font-size: 16px;
	position: relative;
	border-top: 2px solid #ddd;
	margin: auto;
	padding-bottom: 20px;
}



.history_cont::before {
	content: '';
	position: absolute;
	top: -10px;
	width: 25%;
	height: 10px;
	background: #fff;
}

#greeting,#philosophy,#about{
	padding-top: 70px;
}


/* 1200px */
@media screen and (max-width: 1200px) {}





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


	/* cell */
	.cell {
		margin-bottom: 50px;
	}

	.cell p.txt {
		margin-bottom: 12px;
	}

	.cell p.txt_philosophy_policy {
		width: 100%;
		margin-left: 0%;
	}

	/* title */
	.title {
		padding-bottom: 12px;
		margin-bottom: 30px;
	}

	.title h2 {
		font-size: 2.4rem;
	}

	.title .en {
		font-size: 1.0rem;
	}


	/* h3_tit */
	.h3_tit {
		font-size: 2.0rem;
		padding-left: 26px;
		background: url("../../common/img/icon_tit.svg") no-repeat left top 3px / 20px;
	}


	/* h4_tit */
	.h4_tit {
		font-size: 1.6rem;
		margin-bottom: 8px;
	}


	/* column02-list */
	.column02-list .box {
		margin-bottom: 25px;
	}

	.column02-list .box .pht {
		margin-bottom: 12px;
	}


	/* column03-list */
	.column03-list .box {
		margin-bottom: 25px;
	}

	.column03-list .box .pht {
		margin-bottom: 12px;
	}


	/* column04-list */
	.column04-list .box {
		margin-bottom: 25px;
	}

	.column04-list .box .pht {
		margin-bottom: 12px;
	}


	/* list-icon */
	ul.list-icon {
		margin-bottom: 25px;
	}

	ul.list-icon li {
		font-size: 1.4rem;
		padding-left: 14px;
	}

	ul.list-icon li:before {
		width: 8px;
		height: 8px;
	}


	/* btn */
	.btn a {
		font-size: 1.5rem;
	}

	.btn_aboutus a {
		padding: 0 10% 0 8%;
		font-size: 1.3rem;
	}



	/* chart */
	.chart {
		width: 100%;
	}

	#greeting,#philosophy,#about{
		padding-top: 60px;
	}
	


}




/* max 800px */
@media screen and (max-width: 800px) {
	.flex_aboutus p {
		display: block;
	}

}



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


	/* cell */
	.cell {
		margin-bottom: 40px;
	}

	.cell p.txt_philosophy {
		line-height: 1.8em;
	}

	/* width */
	.width_philosophy {
		width: 100%;
	}

	/* table */
	.table_aboutus {
		width: 100%;
	}

	.table_aboutus th,
	.table_aboutus td {
		padding: 5px;
	}

	.table_aboutus th {
		width: 15%;
		padding-left: 5px;
	}

	.btn_aboutus {
		display: inline;
	}

	/* title */
	.title {
		display: block;
		padding-bottom: 12px;
		margin-bottom: 30px;
	}

	.title h2 {
		margin-bottom: 5px;
	}


	/* column02-list */
	.column02-list {
		display: block;
	}

	.column02-list .box {
		width: 100%;
		margin-bottom: 20px;
	}


	/* column03-list */
	.column03-list {
		display: block;
	}

	.column03-list .box {
		width: 100%;
		margin-bottom: 20px;
	}


	/* column04-list */
	.column04-list {
		display: block;
	}

	.column04-list .box {
		width: 100%;
		margin-bottom: 20px;
	}


	/* text-pht */
	.text-pht {
		display: block;
	}

	.text-pht .text {
		width: 100%;
		padding: 0;
		margin-bottom: 18px;
	}

	.text-pht .pht {
		width: 100%;
	}




	/* pht-text */
	.pht-text {
		display: block;
	}

	.pht-text .text {
		width: 100%;
		padding: 0;
		margin-bottom: 18px;
	}

	.pht-text .pht {
		width: 100%;
	}



	/* btn */
	.btn {
		width: 80%;
		margin-top: 30px;
	}

	.btn_aboutus {
		display: block;
	}





	/* cell */
	.cell p.txt_greeting {
		margin-top: 3%;
		font-size: 1.5rem;
	}

	.cell p.txt_president {
		font-size: 2.3rem;
	}

	.cell p.txt_philosophy strong {
		font-size: 1.8rem;
	}

	/* chart */
	.chart {
		display: none;
	}

	.chart_sp {
		display: block;
	}


	/* history */
	.history {
		flex-wrap: wrap;
		padding-bottom: 20px;
	}

	.history::before {
		width: 15%;
	}

	.history .year {
		width: 15%;
	}

	.history .year_jp {
		width: 40%;
		text-align: left;
		margin-left: 3%;
	}

	.history .paragraph {
		width: 50%;
		margin-top: 0px;
		margin-left: 18%;
		margin-right: 10px;
	}

	.history .img {
		width: 30%;
		margin-top: 11px;
		margin-bottom: 12px;
	}

	.history_cont {
		padding-bottom: 20px;
	}

}


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


	/* history */
	.history {
		flex-wrap: wrap;
		padding-bottom: 10px;
	}

	.history::before {
		width: 25%;
	}

	.history .year {
		width: 25%;
	}

	.history .year_jp {
		width: 40%;
		text-align: left;
		margin-left: 5%;
	}

	.history .paragraph {
		width: 70%;
		margin-left: 30%;
		margin-right: 0px;
	}

	.history .img {
		width: 100%;
		margin-top: 11px;
		margin-bottom: 12px;
	}

	.history_cont {
		padding-bottom: 0px;
	}


	#greeting,#philosophy,#about{
		padding-top: 50px;
	}
	
}

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

	/* btn */
	.btn_aboutus a {
		padding: 0 15% 0 10%;
		margin-left: 20px;
	}

	/* chart */
	.chart_sp {
		width: 100%;
	}

	#greeting,#philosophy,#about{
		padding-top: 30px;
	}

}