@charset "utf-8";



/*
 base tag
 ------------------------------------------------- */
 h1{
	padding: 0;
	line-height: 2.2em;
	margin: 0 0 0.75em;
	font-size: 2em;
	text-align: center;
}

#header h1,
#header p#title{
	padding: 1rem 0;
}

#header h1 a,
#header p#title a{
	display: grid;
	grid-template-columns: 93px 1fr;
	gap: 33px;
	align-items: center;
}

h2 {
	position:relative;
	height: 2em;
	line-height: 2em;
	padding: 0.25em 1em;
	color: #FFFFFF;
	background-color: #115FAD;
	margin: 0 0 1em;
	font-size: 1.25em;
	border-radius: 6px;

}

body.about #midashi {
    background: url(../images/enquete/background_result.jpg) no-repeat;
    background-size: cover;
}

body.about #midashi h1 {
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

body.about #midashi h1 {
    font-size: 240%;
    font-weight: bold;
}

body.about #content_wrapper {
    max-width: 100%;
}
@media screen and (max-width: 768px) {
#header h1 a,
#header p#title a{
	grid-template-columns: 54px 1fr;
	gap: 20px;
}
}
@media screen and (max-width: 540px) {
	h1 {
		font-size: 1.375rem;
	}

	body.about #midashi h1  {
		height: 160px;
		font-size: 150%;
	}
}

/*-- keyframes --*/

@keyframes mov-waving {
    0%, 100% {
		transform: translateY(0);
    }
    50% {
		transform: translateY(-30px);
    }
}

@keyframes mov-zoom {
    0%, 100% {
		transform: scale(1);
    }
    50% {
      /* transform: scale(0.7) translateY(3.7px); */
		transform: scale(0.7) translateY(5.55px);
    }

}

.mov-waving {
    animation: 3800ms mov-waving infinite;
}

.mov-zoom {
    animation: 3800ms mov-zoom infinite;
}

.center {
	text-align: center;
}

.noto {
	font-family: 'Noto Sans JP', "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
}



/*-- about_list --*/
body.about .about_list {
	margin: 0 auto;
	padding: 30px;
	max-width: 1200px;
	border: solid 12px #f5f5f5;
	box-sizing: border-box;
	display: flex;
    flex-direction: column;
    gap: 1rem;
}

body.about .about_list li {
	display: flex;
	gap: 1em;
}

body.about .about_list li p {
	font-size: 1.125rem;
	font-weight: bold;
	width: calc(100% - 30px - 1em);
}

body.about .about_list li .num {
	color: #fff;
	display: flex;
	font-weight: bold;
	justify-content: center;
	align-items: center;
	width: 30px;
	height: 30px;
	background-color: #115fad;
	border-radius: 50%;
}



@media screen and (max-width: 1260px){

	body.about .about_list {
		max-width: calc(100% - 60px);
	}

}

@media screen and (max-width: 768px){

	body.about .about_list {
		padding: 15px;
		gap: 0.5rem;
	}

	body.about .about_list li {
		gap: 0.5em;
	}

	body.about .about_list li .num {
		width: 25px;
		height: 25px;
		font-size: 0.9rem;
	}

	body.about .about_list li p {
		font-size: 1rem;
		width: calc(100% - 25px - 0.5em);
	}

}

@media screen and (max-width: 540px) {

	body.about .about_list {
		max-width: calc(100% - 40px);
	}

}




/* --- contents_box --- */

body.about #contents_box {
	margin: 40px auto 0;
	padding: 0 0 40px;
	max-width: 1200px;
	border: solid 8px #115fad;
	box-sizing: border-box;
}

body.about #contents_box h2 {
	margin: 0;
	padding: calc(1rem - 8px) 0 1rem;
	height: auto;
	text-align: center;
	border-radius: 0;
}

body.about #contents_box h2 span {
	margin-left: 30px;
	font-size: 1.875rem;
	font-weight: 500;
	position: relative;
}

body.about #contents_box h2 span::before {
	content: "";
    display: block;
    width: 50px;
    height: 36px;
    background-image: url(../images/about/logo_white.png);
    background-size: contain;
	background-repeat: no-repeat;
    position: absolute;
    top: 6px;
    left: -65px;
}

body.about #contents_box .lead {
	margin: 30px auto 0;
	padding: 20px 30px;
	max-width: calc(100% - 60px);
	font-weight: bold;
	background-color: #e9f1f4;
	box-sizing: border-box;
	border-radius: 5px;
}

body.about #contents_box .pyramid {
	margin-top: 30px;
}

body.about #contents_box .mieru_arrow {
	margin-top: 10px;
}

body.about #contents_box h3 {
	margin: 0 0 12px;
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	position: relative;
}

body.about #contents_box h3::after {
	content: "";
	display: block;
	width: 60px;
	height: 5px;
	background: linear-gradient(118deg, rgba(145,196,223,1) 0%, rgba(16,107,175,1) 100%);;
	position: absolute;
	bottom: -12px;
	left: 0;
	right: 0;
	margin: auto;
}

body.about #contents_box .text {
	margin: 30px 0 0;
	padding: 0 30px;
	box-sizing: border-box;
}

body.about #contents_box .kekka {
	margin-top: 20px;
}

@media screen and (max-width: 1260px){

	body.about #contents_box {
		max-width: calc(100% - 60px);
	}

	body.about #contents_box .pic {
		max-width: calc(100% - 40px);
		margin: 4vw auto 0;
	}

}

@media screen and (max-width: 768px){

	body.about #contents_box h2 {
		padding: calc(0.5rem - 8px) 0 0.5rem;
	}

	body.about #contents_box h2 span {
		font-size: 1.5rem;
	}

	body.about #contents_box h2 span::before {
		width: calc(50px * 0.8);
	    height: calc(36px * 0.8);
		left: -50px;
	}

	body.about #contents_box .lead {
		margin-top: 20px;
		padding: 16px 20px;
		max-width: calc(100% - 40px);
		font-size: 0.9rem;
	}

	body.about #contents_box .mieru_arrow img {
		max-width: 12vw;
	}

	body.about #contents_box h3 {
		font-size: 1.75rem;
	}

	body.about #contents_box .text {
		font-size: 0.85rem;
	}

}


@media screen and (max-width: 540px){

	body.about #contents_box {
		margin-top: 20px;
		max-width: calc(100% - 40px);
	}

	body.about #contents_box h2 span {
		font-size: 1.15rem;
	}

	body.about #contents_box h2 span::before {
		width: calc(50px * 0.6);
		height: calc(36px * 0.6);
		top: 5px;
		left: -38px;
	}

	
	body.about #contents_box h3 {
		font-size: 1.125rem;
	}

}




/* --- btn_list --- */

body.about .btn_list {
	padding: 50px 0 80px;
	display: flex;
    justify-content: center;
	gap: 3%;
}

body.about .btn_list.col2 li {
	width: 280px;
    border-radius: 0.25em;
}

body.about .btn_list li a {
    text-align: center;
    line-height: 3em;
    font-size: 1.1em;
    color: #fff;
    text-decoration: none;
    display: block;
}

body.about .btn_list li.color01 {
    background: #00728e;
}

body.about .btn_list li.color02 {
    background: #999;
}

@media screen and (max-width: 660px){
	body.about .btn_list {
		flex-direction: column;
		align-items: center;
		gap: 20px;
	}

	body.about .btn_list.col2 li {
		max-width: 100%;
	}

}

/* --- footer --- */
#footer_wrapper {
	background-color: #1d1d1d;
	color: #fff;
}

#footer {
	margin: 0 auto;
	padding: 0.5em 0 3em;
}

#footer ul#footer_nav {
	list-style: none;
	margin: 0.5em auto 0;
}

#footer ul#footer_nav li {
	float: left;
	padding-right: 2em;
}

#footer ul#footer_nav li a
{
	display: block;
	line-height: 1.8em;
	padding:  0 0 0 18px;
	color: #000;
	position: relative;
	background: url(../../common/arrow.png) left 50% no-repeat;
}
/*
#footer ul#footer_nav li a:after
{
	position: absolute;
	border-right: 3px solid #67A139;
	border-top: 3px solid #67A139;
	content: "";
	width: 4px;
	height: 4px;
	left: 0px;
	top: 50%;
	margin-top: -4px;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	border: none\9;
	background-color: #67A139\9;
}
*/
#footer #footer_copyright {
	clear: both;
	margin: 3em auto 0;
	text-align: center;
	padding: 0.5em 0 1.5em;
}

#footer #footer_lead {
	clear: both;
	margin: 0 auto;
	text-align: left;
	padding: 1em 0 0;
}
