@charset "utf-8";

/* ------------------------------------------------------------------------------------------------
 * style
 * ------------------------------------------------------------------------------------------------ */
header {
	text-align: center;
	min-width: 1200px;
}
header h1 img{
	width: auto;
	margin: 30px auto 34px;
}
main.g-wrapper {
  background: url("../img/mv_img.jpg") no-repeat top center #F0F0F0;
  min-width: 1200px;
}
.g-container {padding: 239px 0 0;}
.contents {
  background: #fff;
  width: 1200px;
  margin: 0 auto;
  font-family: "Roboto", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Osaka, sans-serif;
  padding: 37px 0 80px;
  letter-spacing: 0.05em;
}
.inner {
  width: 1000px;
  margin: 0 auto;
}
h2,h3,h4 {
    font-family: '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', serif;
    /* font-feature-settings: "palt"; */
}
h3 {
	font-size: 26px;
	margin: 30px 0 20px;
	letter-spacing: 0.15em;
	font-feature-settings: "palt";
}
h3 span {
	font-size: 14px;
	font-family: "Roboto", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Osaka, sans-serif;
	font-weight: normal;
	margin-left: 16px;
	letter-spacing: 0.05em;
	font-feature-settings: normal;
	display: inline-block;
	vertical-align: middle;
}
h4 {
	position: relative;
	padding-left: 34px;
	font-size: 20px;
	margin: 0px 0 23px;
	letter-spacing: 0.15em;
}
h4:before {
	content: "";
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  width: 22px;
  height: 1px;
  background: #E40808;
}
.flex_block {
  display: flex;
  justify-content: space-between;
  margin-top: 37px;
}
.txt p {
	font-size: 18px;
	line-height: 2;
	letter-spacing: 0.05em;
	margin: 0;
}
.txt p + p {
	margin-top: 36px;
}
.img img {
  width: 100%;
}
.flex_img .img {
  margin: 0;
  width: 480px;
  position: relative;
}
.flex_img .img span {
  color: #fff;
  background: #E33C0B;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 16px;
  padding: 7px 9px;
}
.flex_img .img:nth-child(2) span {
  background: #F9B11A;
}
figcaption {
  text-align: center;
  margin-top: 19px;
}
.btn {
  width: 100%;
  text-align: center;
}

.btn a {
  font-family: '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', serif;
  background: #008842;
  color: #fff;
  font-size: 24px;
  width: 750px;
  height: 90px;
  line-height: 90px;
  display: block;
  margin: 60px auto 0;
  border-radius: 70px;
  text-decoration: none;
  letter-spacing: 0.05em;
  font-weight: bold;
  position: relative;
}
.btn a::after{
  position: absolute;
  top: 0;
  bottom: 0;
  right: 30px;
  margin: auto;
  content: "";
  vertical-align: middle;
  width: 10px;
  height: 10px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.sec01 h2 {
	text-align: center;
	font-size: 32px;
	position: relative;
	margin: 27px 0 41px;
	padding: 0;
	letter-spacing: 0.12em;
	line-height: 1.5;
}
.sec01 h2 figure {
	margin: 10px 0 0;
}
.sec01 h2 img {
	width: 152px;
}
.sec01 h2 span{
	display: block;
	color: #E40808;
	font-size: 24px;
	line-height: 2;
	margin: 0 0 20px;
	letter-spacing: 0.1em;
}
.sec01 h2::before,
.sec01 h2::after{
	content: "";
	display: block;
	height: 5px;
	background: linear-gradient(-42deg,transparent 35%,#E9E9E9 45%, #E9E9E9 55%,transparent 65%);
	background-size: 5px 6px;
	border: none;
}
.sec01 .block .txt {
	margin-top: 44px;
}
.sec01 .block .txt p {
	margin-top: 27px;
}
.sec01 .graph {
  margin-top: 34px;
}
.sec01 .graph .txt {
  margin-right: 32px;
  width: 730px;
}
.sec01 .graph .img {
	border: solid 3px #F3F3F3;
	padding: 7px 20px 20px;
	font-weight: bold;
	margin: 7px 0;
	width: 410px;
}
.sec01 .graph .img img{
	margin-top: 10px;
  width: 360px;
}
.sec01 .graph .graph_img span {
	font-size: 13px;
	text-align: right;
	display: block;
	margin-top: 22px;
	/* margin-right: 5px; */
}
.sec02 {
	margin-top: 88px;
}
.sec02 .block{


	margin-top: 36px;
}


.sec02 .block + .block {
	margin-top: 62px;
}
.sec02 .block + .block .flex_block {
	margin-top: 0;
}
.sec02 .block + .block .flex_block figcaption {
	line-height: 2;
	margin-top: 10px;
}
.sec02 .block + .block .txt{
	margin-top: 28px;
}
.sec03 {
	margin-top: 80px;
}
.sec03 .control {
  margin-top: 34px;
}
.sec03 .control .img{
	font-weight: bold;
	margin: 0;
}
.sec03 .control img{
  margin: 0;
  position: relative;
}
.sec03 .control .txt {
	width: 480px;
	margin-top: -7px;
}
.sec03 .control + .txt {
	margin-top: 33px;
}
.sec03 .bg_gray {
	background: #F3F3F3;
	padding: 50px 50px 43px;
	position: relative;
	margin-top: 53px;
}
.sec03 .bg_gray h4{
	position: absolute;
	top: -10px;
	right: 49px;
	font-size: 26px;
}
.sec03 .bg_gray h4::before{
	display: none;
}
.sec03 .bg_gray .flex_img {
	margin-top: 0;
}
.sec03 .bg_gray .flex_img .img {
	width: calc(100% / 2 - 20px);
}
.sec03 .bg_gray .flex_img figcaption {
	text-align: left;
	letter-spacing: 0.03em;
	line-height: 2;
	margin-top: 16px;
}
.cv_area {
	padding-top: 18px;
	margin-top: 0px;
	text-align: center;
}
.cv_area .txt_area{
	width: 660px;
	margin: 0 auto;
	padding-top: 32px;
	margin-top: 20px;
	text-align: center;
	letter-spacing: 0.05em;
}
.cv_area .txt_area h4 {
	padding: 0;
	line-height: 2;
	font-size: 26px;
	margin-bottom: 17px;
}
.cv_area .txt_area h4::before {
	display: none;
}
.cv_area .txt_area h4 span {
	display: block;
	font-family: "Roboto", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Osaka, sans-serif;
	font-size: 14px;
	letter-spacing: 0.2em;
}
.cv_area .txt_area .txt {
	font-size: 14px;
	position: relative;
	letter-spacing: 0.2em;
}
.cv_area .txt_area .txt::before,
.cv_area .txt_area .txt::after {
    content: "";
    display: inline-block;
    background: url("../img/arrow.png") no-repeat top right;
    background-size: contain;
    width: 49px;
    height: 6px;
    vertical-align: middle;
}
.cv_area .txt_area .txt span {
	padding: 0 10px 0 15px;
}
.youtube {
	margin-top: 27px;
}
footer {
	text-align: center;
	color: #5e5e5e;
	background: #f0f0f0;
	padding-top: 42px;
}
footer .footer_logo {
	width: 320px;
	margin: 0 auto;
}
footer .footer_logo img {
	width: auto;
}
footer .pagetop {
  position: absolute;
  transform: translateY(14.76%);
  -webkit-transform: translateY(14.76%);
  right: 18px;
  width: 69px;
}
.footer__btm p {
	height: 80px;
	line-height: 80px;
	margin-top: 40px;
	font-size: 15px;
}

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




} /* END RESPONSIVE 1199px */




@media screen and (max-width:767px) {
header {
	text-align: center;
	min-width: 100%;
}
header h1 img{
	width: 57%;
	margin: 8vw auto 5vw;
}
main.g-wrapper {
  background: url("../img/mv_img_sp@2x.jpg") no-repeat top center #F0F0F0;
  background-size: contain;
  min-width: 100%;
}
.g-container {
  padding-top: 60vw;
}
.contents {
  width: 92%;
  padding: 4vw 0 16vw;
  letter-spacing: 0.05em;
}
.inner {
  width: 92%;
  margin: 0 auto;
}

h3 {
	font-size: 20px;
	margin: 3vw 0 0;
	line-height: 1.7;
	letter-spacing: 0.1em;
	font-feature-settings: inherit;
}
h3 span {
	display: block;
	font-size: 12px;
	margin-left: 0;
}
h4 {
	padding-left: 8vw;
	font-size: 18px;
	margin: 0px 0px 2vw;
	line-height: 1.8;
	letter-spacing: 0.1em;
}
h4:before {
  top: calc(4vw - 1px);
}
.flex_block {
  display: block;
  margin-top: 7vw;
}
.txt p {
	font-size: 16px;
	line-height: 2;
	margin: 0;
}
.txt p + p {
	margin-top: 8vw;
}
.img img {
  width: 100%;
}
.flex_img .img {
  width: 100%;
}
.flex_img .img + .img{
  margin-top: 6.5vw;
}
.flex_img .img span {
  font-size: 12px;
  padding: 1vw 2vw;
}
figcaption {
  font-size: 14px;
  margin-top: 3vw;

}

.btn a {
  font-size: 18px;
  width: 100%;
  height: 60px;
  line-height: 60px;
  margin: 9vw auto 0;
}
.btn a::after{
  right: 7vw;
  width: 8px;
  height: 8px;
}

.sec01 h2 {
	font-size: 22px;
	margin: 7vw 0px 8vw;
	line-height: 1.7;
}
.sec01 h2 figure {
	margin: 1vw 0 0;
}
.sec01 h2 img {
	width: 43%;
}
.sec01 h2 span{
	font-size: 16px;
	margin: 0 0 4vw;
}

.sec01 .block .txt {
	margin-top: 3vw;
}
.sec01 .block .txt p {
	margin-top: 3vw;
}
.sec01 .graph {
  margin-top: 7vw;
}
.sec01 .graph .txt {
  margin-right: 32px;
  width: 100%;
}
.sec01 .graph .img {
	padding: 2.5vw 5vw 5vw;
	margin: 7vw 0 0;
	width: 100%;
}
.sec01 .graph .img img{
	margin-top: 3vw;
  width: 100%;
}
.sec01 .graph .img span {
	font-size: 14px;
}
.sec01 .graph .graph_img span {
	font-size: 12px;
	margin-top: 4.5vw;
	margin-right: 0;
	margin-left: 1em;
	text-indent: -1em;
	line-height: 1.8;
	text-align: left;
}
.sec02 {
	margin-top: 15vw;
}
.sec02 .block{
	margin-top: 3vw;
}
.sec02 .block + .block {
	margin-top: 10.5vw;
}
.sec02 .block + .block .flex_block {
	margin-top: 0vw;
}
.sec02 .block + .block .flex_block figcaption {
    margin-top: 1vw;
}
.sec02 .block + .block .txt{
	margin-top: 5vw;
}

.sec03 {
	margin-top: 13vw;
}
.sec03 .control {
  margin-top: 4vw;
}
.sec03 .control .img{
	font-weight: bold;
	margin: 0;
}
.sec03 .control .txt {
	width: 100%;
	margin-top: 7vw;
}
.sec03 .control + .txt {
	margin-top: 5vw;
}
.sec03 .bg_gray {
	padding: 8.5vw 4vw 7vw;
	margin-top: 18vw;
}
.sec03 .bg_gray h4{
	top: -4vw;
	right: 4vw;
	font-size: 20px;
	letter-spacing: 0.17em;
}
.sec03 .bg_gray h4::before{
	display: none;
}
.sec03 .bg_gray .flex_img {
	margin-top: 0;
}
.sec03 .bg_gray .flex_img .img:first-child {
	width: 100%;
}
.sec03 .bg_gray .flex_img .img:last-child {
	width: 100%;
}
.sec03 .bg_gray .flex_img figcaption {
	margin-top: 2vw;
}
.cv_area {
	padding-top: 1.5vw;
}
.cv_area .txt_area{
	width: 100%;
	margin: 0 auto;
	padding-top: 0;
	margin-top: 6vw;
}
.cv_area .txt_area h4 {
	padding: 0;
	font-size: 20px;
	margin-bottom: 7vw;
}
.cv_area .txt_area h4 span {
	letter-spacing: 0.05em;
	margin-bottom: 2vw;
}
.cv_area .txt_area .txt {
	font-size: 13px;
	letter-spacing: 0.15em;
}
.cv_area .txt_area .txt::before,
.cv_area .txt_area .txt::after {
}
.cv_area .txt_area .txt span {
	padding: 0 4.5vw;
}
.youtube {position: relative;width: 100%;padding-top: 56.25%;margin-top: 4vw;}
.youtube iframe {
position: absolute;
top: 0;
right: 0;
width: 100% !important;
height: 100% !important;
}
footer {
	padding-top: 13vw;
}
footer .footer_logo {
  width: 66%;
  margin: 0 auto;
}
footer .pagetop {
  transform: translateY(1.6vw);
  -webkit-transform: translateY(1.6vw);
  right: 6vw;
  width: 55px;
}
.footer__btm {
  padding: 8vw 0;
  margin-top: 13.5vw;
}
.footer__btm p {
	height: auto;
	line-height: normal;
	margin-top: 0;
	font-size: 15px;
}










} /* END RESPONSIVE 767px */




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




} /* END RESPONSIVE 374px */




@media print {




} /* END PRINT */