@charset "UTF-8";
/* CSS Document */

html {
}

img {
width: 100%;
}

body {
	background-color: #f5f5f5;
  font-family: "Zen Kaku Gothic New", serif;
  font-weight: 500;
	letter-spacing: 0.04em;
  color: #0068c3;
	width: 100%;
	min-width: 768px;
	max-width: 100%;
	min-height: 100vh;
  position: relative;/*←相対位置*/
  padding-bottom: 350px;/*←footerの高さ*/
  box-sizing: border-box;/*←全て含めてmin-height:100vhに*6*/
	}
/* Sections */
/* ============================================ */

section,
footer {
	width: 100%;
	min-width: 768px;
	max-width: 100%;
	margin: 0 auto;
}
footer {
	position: absolute;/*←絶対位置*/
  bottom: 0; /*下に固定*/
	margin: 0 auto;
	background-color: #fff;
}
.wrapper,
.container {
	width: 100%;
	min-width: 768px;
	max-width: 100%;
  height: 100%;
	background-color: #f5f5f5;
  line-height: 1.6em;
	margin: 0 auto;
}
.main_content {
	width: 100%;
	max-width: 100%;
  height: 100%;
	margin: 0 auto;
	background-color: #f5f5f5;
}
.top_content,
.problems_content,
.achievements_content,
.features_content{
	width: 100%;
	min-width: 768px;
	max-width: 1280px;
	margin: 0 auto;
	}


.top_content {
	width: 82%;
	padding: 100px 0px 50px 16px;
	background-image: url("../images/top_content_back.svg");
	background-position: right 90px;
	background-size: 34%;
	background-repeat: no-repeat;
	min-height: auto;
	
}

.top_content_logo {
	width: 58%;
	background-color: #F4f4f4;
	}
.top_contact {
	width: 58%;
	padding: 50px 0 0 0;

}
	a.contact_button {
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	width: 80%;
	min-width: 540px;
	margin: auto;
	padding: 1.5rem 2rem;
	font-weight: 500;
	font-size: 1.5rem;
	border-radius: 100vh;
	border-bottom: 7px solid #fed0c2;
	background: #ec6841;
	color: #fff;
}
a.contact_button:hover {
	margin-top: 6px;
	border-bottom: 1px solid #fed0c2;
	color: #fff;
}

.contact_button_menu {
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	width: 80%;
	min-width: 200px;
	margin: auto;
	padding: 1rem 1rem;
	font-weight: 500;
	font-size: 1.5rem;
	border-radius: 100vh;
	background: #ec6841;
	color: #fff;
}
a.contact_button_menu:hover {
	color: #fff;
}

.problems_content{
margin-bottom: 60px;
	}
.problems_waku {
	width: 74%;
	max-width: 1070px;
	min-width: 698px;
	margin: 0 auto;
	padding: 20px 40px;
	background: #FFF;
	border: 5px solid #0068c3;
	border-radius: 16px;
	position: relative;
	}
	
.problems_title {
	font-size: 2rem;
	font-weight: 800;
	text-align: center;
	padding: 0 0 8px 0;
	border-bottom: 8px double #0068c3;
	line-height: 1.8;
		}
.problems_list {
		font-size: 1.3rem;
		font-weight: 500;
		padding: 24px 0 24px 30px;
		list-style-type: none;
		}
.problems_list li {
		padding: 10px 0;
		line-height: 1.4;
		text-align: left;
		border-bottom: none;
		}	
.problems_list li::before {
	position: relative;
  top: -6px;
  left: -12px;
  display: inline-block;
  width: 6px;
  height: 6px;
  content: ''; 
  border-radius: 100%;
  background: #0068c3;
	}
.problems_list li strong {
  background:linear-gradient(transparent 70%, #fddcd1 20%);
	font-weight: 500;
	}
.problems_img {
 	width: 250px;
 	height: 206px;
 	position: absolute;
	right: -30px;
	bottom: -20px; 
	margin: auto;
	}
.problems_contact {
	width: 100%;
	padding: 50px 0 0 0;
	}	
.problems_contact .contact_button {
	width: 38%;
	margin: 0 auto;
	}
.achievements_area {
	background-color: #3184cd;
	padding: 30px 0 70px;
	}
.achievements_content {
	width: 80%;
	margin: 0 auto;
	}
	.achievements_tit {
	text-align: center;
	font-size: 3.1rem;
	line-height: 1.3;
	color: #fff;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: 40px;
	}
	.achievements_tit span {
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	}
.achievements_list {
	width: 100%;
	margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
	}
.achievements_list li {
	background-color: #FFF;
	font-size: 1.04rem;
	font-weight: 500;
	color: #444444;
	padding: 24px 24px 184px 0;
	width: 340px;
	margin:8px;
  border-radius: 8px;
	background-repeat: no-repeat;
	background-size:20%;
	background-position: top 24px left 8px;
	position: relative;
	}
	
	
.achievements_list li.achievements01 {
	background-image: url("../images/achievements_namber01.svg");
}
.achievements_list li.achievements02 {
	background-image: url("../images/achievements_namber02.svg");
}
.achievements_list li.achievements03 {
	background-image: url("../images/achievements_namber03.svg");
}
.achievements_list li.achievements04 {
	background-image: url("../images/achievements_namber04.svg");
}
.achievements_list li.achievements05 {
	background-image: url("../images/achievements_namber05.svg");
}
.achievements_list li.achievements06 {
	background-image: url("../images/achievements_namber06.svg");
}
.achievements_list li h3 {
	font-size: 1.4rem;
	font-weight: 700;
	color: #0068c3;
	margin: 0 0 8px 74px;
	padding: 0 0 8px 0;
	border-bottom: dotted #0068c3 2px;
	}
.achievements_list li p {
	padding: 0 0 8px 74PX;
	line-height: 1.3;
	}
.achievements_img {
	width: 290px;
	height: 160px;
	background-color: #999999;
	margin: 0 auto;
	position: absolute;
	bottom: 24px;
	left: 24px;
}

.features_content {
	margin: 0 auto;
	padding: 30px 0 50px 0;
	font-weight: 700;
	}
.features_tit {
	text-align: center;
	font-size: 3.1rem;
	line-height: 1.3;
	font-weight: 700;
	letter-spacing: 0.04em;
	margin-bottom: 60px;
	}
.features_tit span {
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	}
.features_list {
	width: 690px;
	margin: 0 auto 20px;
	font-size: 1.3rem;
	line-height: 1.3;
	}
.features_list li {
	border-bottom: solid 2px #0068c3;
	padding: 1.4rem 0 1.4rem 66px;
	background-repeat: no-repeat;
	background-size:4%;
	background-position: center left 8px ;
}
.features_list li.features01 {
	background-image: url("../images/features_list_namber01.png");
}
.features_list li.features02 {
	background-image: url("../images/features_list_namber02.png");
}
.features_list li.features03 {
	background-image: url("../images/features_list_namber03.png");
}
.features_list li.features04 {
	background-image: url("../images/features_list_namber04.png");
}
.features_list li.features05 {
	background-image: url("../images/features_list_namber05.png");
}
.features_list li.features06 {
	background-image: url("../images/features_list_namber06.png");
}
.features_list li strong {
  background:linear-gradient(transparent 70%, #fddcd1 20%);
	}
.features_list li small {
	line-height: 1;
	}
.features_supplement {
	width: 740px;
	margin: 0 auto;
	font-size: 1.1rem;
	text-align: center;
}
.features_contact {
	width: 100%;
	padding: 50px 0 0 0;
	}	
.features_contact .contact_button {
	width: 20%;
	margin: 0 auto;
	}
.footer_content {
 padding: 100px 0 30px 0;;
	margin: 0 auto;
	text-align: center;
	color: #333;
}
.footer_company_details {
	width: auto;
	margin: 0 0 10px 0;
	font-size: 1.1rem;
}
.footer_company_details img {
	width: 228px;
	margin: 0 auto 20px; 
}




@media screen and (max-width:767px) {
body {
	min-width: 601px;
	max-width: 767px;
	}
/* Sections */
/* ============================================ */

section,
footer {
	min-width: 601px;
	max-width: 767px;
}
.wrapper,
.container {
	width: 100%;
	min-width: 601px;
	max-width: 767px;
	margin: 0 auto;
}
.main_content {
}
.top_content,
.problems_content,
.achievements_content,
.features_content{
	width: 100%;
	min-width: 601px;
	max-width: 767px;
	}

.problems_waku {
	width: 90%;
	min-width: 580px;
	max-width: 767px;
	padding: 20px 40px;
	}
	
.problems_title {
	font-size: 2rem;
	line-height: 1.4;
		}
.problems_list {
		padding: 24px 0 24px 10px;
		}
.problems_list li {
		line-height: 1.4;
		}
.problems_img {
 	width: 190px;
 	height: 157px;
 	position: absolute;
	right: -30px;
	bottom: -10px; 
	}

.features_list {
	width: 90%;
	margin: 0 auto 20px;
	font-size: 1.3rem;
	line-height: 1.3;
	}
.features_supplement {
	width: 80%;
	font-size: 1rem;
	text-align: left;
}




	}
@media screen and (max-width:600px) {
body {
	min-width: auto;
	max-width: 600px;
	}
/* Sections */
/* ============================================ */

section,
footer {
	min-width: auto;
	max-width: 600px;
}
.wrapper,
.container {
	min-width: auto;
	max-width: 600px;
}
.main_content {
}
.top_content,
.problems_content,
.achievements_content,
.features_content{
	width: 100%;
	min-width: auto;
	max-width: 600px;
	}


.top_content {
	width: 100%;
	padding: 100px 10% 10% 10%;
	background-image: url("../images/top_content_back.svg");
	background-position: center bottom 20%;
	background-size: 62%;
	background-repeat: no-repeat;
	min-height: 568px;
	
}

.top_content_logo {
	width:100%;
	margin: 0 auto 90% auto;
	}
.top_contact {
	width: 100%;
	padding: 50px 0 0 0;

}
.problems_waku {
	width: 90%;
	min-width: auto;
	max-width: 600px;
	padding: 20px 40px 90px;
	}
	
.problems_title {
	font-size: 1.5rem;
	line-height: 1.4;
	text-align: left;
		}
.problems_list {
		padding: 20px 0 24px 10px;
		}
.problems_list li {
		padding: 20px 0;
		line-height: 1.4;
		text-align: left;
		border-bottom: 1px solid #b2d1ed;
		}	
.problems_list li::before {
	content: inherit;
	}
.problems_img {
 	width: 190px;
 	height: 157px;
	right: 50%;
	bottom: -40px;
	margin: 0 -100px 0 0; 
	
	}
	
	.achievements_area {
	background-color: #3184cd;
	padding: 20px 0 30px;
	}
.achievements_content {
	width: 100%;
	margin: 0 auto;
	}
	.achievements_tit {
	text-align: center;
	font-size: 3.1rem;
	line-height: 1.3;
	color: #fff;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: 40px;
	}
	.achievements_tit span {
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	}
.achievements_list {
	width: 100%;
	margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
	}
.achievements_list li {
	width: 94%;
	font-size: 1.04rem;
	font-weight: 500;
	color: #444444;
	padding: 24px;
	margin:8px;
  border-radius: 8px;
	background-repeat: no-repeat;
	background-size:20%;
	background-position: top 24px left 8px;
	position: static;
	}
	
.achievements_list li h3 {
	margin: 0 0 8px 28%;
	padding: 0 0 8px 0;
	border-bottom: dotted #0068c3 2px;
	}
.achievements_list li p {
	padding: 0 0 24px 28%;
	line-height: 1.3;
	}
.achievements_img {
	width: 65%;
	height: auto;
	position:static;
	bottom: inherit;
	left: inherit;
	background-color: #FFF;
	margin: 0 0 0 28%;
}
	
	
.features_list {
	width: 94%;
	margin: 0 auto 20px;
	font-size: 1.2rem;
	line-height: 1.4;
	}
.features_supplement {
	width: 80%;
	font-size: 1rem;
	text-align: left;
}


	a.contact_button {
	width: 100%;
	min-width: 300px;
	margin: auto;
	padding: 1rem 1rem;
	font-weight: 500;
	font-size: 1rem;
	border-bottom: none;
}
a.contact_button:hover {
	margin-top: 0;
	border-bottom: none;
}

.problems_contact .contact_button {
	width: 80%;
	}
.features_contact .contact_button {
	width: 80%;
	margin: 0 auto;
	}

.features_list li {
	background-size:8%;
	background-position: center left 8px;
}
.features_list li small {
	line-height: 1;
	}

	}