@charset "utf-8";

/* HOME
-------------------------------------------------------------------*/
.btn a{
	display:inline-block;
}

.img{
	line-height:0;
}

.mv .box{
	position:relative;
}

.mv .txt-box{
	padding:80px 20px;
	margin:0 0 0 -80px;
	color:#fff;
	position:relative;
	z-index:2;
	transition: all 0.3s;
}

@media screen and (max-width: 1160px) {
.mv .txt-box{
	margin:0 0 0 10px;
}
}

.mv .txt-box dl dt{
	font-size:38px;
	color:#F5F896;
	font-weight:700;
}

.mv .txt-box dl dd{
	font-size:24px;
	font-weight:700;
}

.mv .txt-box h1{
	padding:50px 0;
}

.mv .txt-box h2{
	font-size:20px;
	font-weight:700;
	line-height:1.8;
}

.mv .img{
	position:absolute;
	right:-150px;
	bottom:0;
}

.experience{
	text-align:center;
	background:url(../img/growth/top/experience-bg.jpg) no-repeat center center;
	background-size:cover;
	padding:80px 0 40px 0;
}

.experience h2{
	font-size:46px;
	font-weight:700;
	padding:0 0 40px 0;
}

.experience h2 span{
	font-size:34px;
	display:block;
	padding:0 0 30px 0;
}

.profit{
	color:#fff;
	padding:100px 20px;
}

.profit h2{
	font-size:54px;
	font-weight:700;
	line-height:1.4;
}

.profit dl dt{
	font-size:40px;
	font-weight:700;
	padding:40px 0;
}

.profit dl dd{
	font-size:30px;
	font-weight:700;
}

.trouble{
	background:#E9EFF7;
	padding:0 0 50px 0;
}

.trouble h2,
.effect h2{
	position: relative;
	padding: 40px;
	text-align:center;
	font-size:46px;
	font-weight:700;
	background-color: #F5F896;
	border-radius: 20px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
	top:-60px;
}

.trouble h2:before,
.effect h2:before{
	content: "";
	position: absolute;
	bottom: -20px;
	left: 50%;
	transform: translateX(-50%);
	border-style: solid;
	border-width: 20px 20px 0 20px;
	border-color: #F5F896 transparent transparent transparent;
	filter: drop-shadow(0 4px 2px rgba(0, 0, 0, 0.3));
}

.trouble ul li{
	padding:0 0 0 75px;
	margin:0 0 40px 0;
	font-size:34px;
	font-weight:700;
	background:url(../img/growth/top/trouble-ico.png) no-repeat 0 11px;
}

.trouble .box-in{
	background:#fff;
	padding:90px;
}

.trouble .box-in h3{
	font-size:46px;
	font-weight:700;
}

.trouble .box-in p{
	padding:50px 0 0 0;
	font-size:20px;
	line-height:1.8;
}

.trouble .box-in p span{
	font-weight:700;
	font-size:24px;
}

.result{
	background:#fff;
	padding:90px 20px;
	text-align:center;
}

.result h2{
	font-size:46px;
	font-weight:700;
}

.result h3{
	position: relative;
	padding: 40px;
	font-size:34px;
	font-weight:700;
	background-color: #F5F896;
	border-radius: 20px;
	margin:50px 0 0 0;
}

.result h3 em{
	display:inline-block;
	padding:0 0 0 20px;
}

.result h3:before {
	content: "";
	position: absolute;
	bottom: -16px;
	left: 50%;
	transform: translateX(-50%);
	border-style: solid;
	border-width: 16px 16px 0 16px;
	border-color: #F5F896 transparent transparent transparent;
}

.result h3 span{
	font-size:20px;
	font-weight:500;
	display:block;
	padding:5px 0 0 0;
}

.result .img{
	padding:50px 0 0 0;
}

.achieve{
	padding:90px 20px;
}

.achieve .box-in{
	background:#fff;
	padding:90px;
	margin:0 0 110px 0;
}

.achieve .box-in h2,
.achieve h3{
	font-size:46px;
	font-weight:700;
}

.achieve .box-in p{
	padding:50px 0 0 0;
	font-size:20px;
	line-height:1.8;
}

.achieve h3{
	color:#fff;
}

.achieve h3 span,
.achieve .txt span{
	color:#F5F896;
}

.achieve .txt{
	color:#fff;
	padding:50px 0 0 0;
	font-size:20px;
	line-height:2;
	font-weight:700;
}

.btn-area{
	padding:80px 20px;
	text-align:center;
	background:#fff;
}

.profile{
	padding:100px 20px;
	background:#E9EFF7;
}

.profile h2{
	font-size:46px;
	font-weight:700;
	padding:30px 0;
	text-align:center;
	border-top:2px solid #001565;
	border-bottom:2px solid #001565;
}

.profile .box-in{
	display:flex;
	justify-content:space-between;
	padding:100px 0;
}

.profile .box-in .txt-box{
	width:600px;
}

.profile .box-in .txt-box h3{
	font-size:34px;
	font-weight:700;
	padding:0 0 30px 0;
}

.profile .box-in .txt-box h3 span{
	font-size:24px;
}

.profile .box-in .txt-box .txt{
	font-size:20px;
	line-height:2;
}

.profile .box-in .txt-box .txt02{
	font-size:24px;
	font-weight:700;
	padding:40px 0;
}

.profile .img-box{
	padding:50px;
	background:#fff;
	text-align:center;
	margin:0 0 40px 0;
}

.profile .img-box h4{
	font-size:34px;
	font-weight:700;
	padding:0 0 40px 0;
}

.profile .img-box .kome{
	font-size:20px;
	padding:20px 0 0 0;
}

.profile h5{
	font-size:24px;
	font-weight:700;
	color:#fff;
	padding:50px;
	background:#001565;
	text-align:center;
}

.effect{
	margin:160px 0 0 0;
	padding:0 0 100px 0;
	background:#E9EFF7;
}

.effect h2{
	top:-100px;
}

.effect ul{
	margin:-80px 0 0 0;
}

.effect ul li{
	display:flex;
	justify-content:space-between;
	padding:60px;
	background:#fff;
	margin:20px 0 0 0;
}

.effect ul li:nth-child(even) .img{
	order:2;
}

.effect ul li .txt-box{
	width:520px;
}

.effect ul li .txt-box .txt{
	font-size:20px;
	line-height:2;
}

.effect ul li .txt-box .txt span{
	color:#0085E6;
}

.effect ul li .txt-box h3{
	font-weight:500;
	padding:40px 0 0 0;
	font-size:16px;
}

.effect ul li .txt-box h3 span{
	padding:0 0 0 10px;
}

@media screen and (max-width: 800px) {
.mv{
	padding:25px 20px;
}
	
.mv .txt-box{
	padding:0;
	margin:0;
}

.mv .txt-box dl dt{
	font-size:7.3vw;
}

.mv .txt-box dl dd{
	font-size:4.1vw;
}

.mv .txt-box h1{
	padding:20px 0 0 0;
}

.mv .txt-box h2{
	font-size:3.3vw;
	padding:35% 0 0 0;
}

.mv .img{
	right:-20%;
	bottom:12%;
	z-index:3;
}

.experience{
	padding:40px 20px;
}

.experience h2{
	font-size: clamp(14px, 6vw, 30px);
	padding:0 0 30px 0;
}

.experience h2 span{
	font-size: clamp(8px, 4vw, 16px);
	padding:0 0 20px 0;
}

.btn{
	max-width:350px;
	margin:0 auto;
}

.profit{
	padding:50px 20px 100px 20px;
}

.profit h2{
	font-size: clamp(14px, 6vw, 30px);
}

.profit dl dt{
	font-size: clamp(14px, 5vw, 24px);
	padding:30px 0;
}

.profit dl dd{
	font-size: clamp(8px, 4vw, 16px);
}

.trouble{
	padding:0 20px 40px 20px;
}

.trouble h2,
.effect h2{
	padding: 35px 0;
	font-size: clamp(14px, 5vw, 24px);
	top:-60px;
}

.trouble h2:before,
.effect h2:before{
	bottom: -15px;
	border-width: 15px 15px 0 15px;
}

.trouble ul{
	margin:-30px 0 15px 0;
}

.trouble ul li{
	padding:0 0 0 30px;
	margin:0 0 15px 0;
	font-size:18px;
	background:url(../img/growth/top/sp/trouble-ico.png) no-repeat 0 6px;
	background-size:20px;
}

.trouble .box-in{
	padding:35px 25px;
}

.trouble .box-in h3{
	font-size: clamp(14px, 6vw, 30px);
}

.trouble .box-in p{
	padding:30px 0 0 0;
	font-size:16px;
}

.trouble .box-in p span{
	font-size:18px;
}

.result{
	padding:40px 20px;
}

.result h2{
	font-size: clamp(14px, 6vw, 30px);
}

.result h3{
	padding: 40px 0;
	font-size: clamp(14px, 5vw, 24px);
	margin:30px 0 0 0;
}

.result h3 em{
	display:block;
	padding:0;
}

.result h3:before {
	bottom: -15px;
	border-width: 15px 15px 0 15px;
}

.result h3 span{
	font-size:14px;
	padding:10px 0 0 0;
}

.result .img{
	padding:30px 0 0 0;
}

.achieve{
	padding:40px 20px;
}

.achieve .box-in{
	padding:35px 25px;
	margin:0 0 40px 0;
}

.achieve .box-in h2,
.achieve h3{
	font-size: clamp(14px, 6vw, 30px);
}

.achieve .box-in p{
	padding:30px 0 0 0;
	font-size:16px;
}

.achieve .txt{
	padding:30px 0 0 0;
	font-size:16px;
}

.btn-area{
	padding:40px 20px;
}

.profile{
	padding:40px 20px;
}

.profile h2{
	font-size: clamp(14px, 5vw, 24px);
	padding:25px 0;
}

.profile .box-in{
	display:block;
	padding:40px 0;
}

.profile .box-in .txt-box{
	width:100%;
}

.profile .box-in .txt-box h3{
	font-size: 24px;
	padding:0 0 20px 0;
}

.profile .box-in .txt-box h3 span{
	font-size:14px;
}

.profile .box-in .txt-box .txt{
	font-size:16px;
	line-height:1.8;
}

.profile .box-in .txt-box .txt02{
	font-size:18px;
	padding:20px 0;
}

.profile .box-in .img{
	max-width:200px;
	margin:0 auto;
	padding:30px 0 0 0;
}

.profile .img-box{
	padding:20px;
	margin:0 0 20px 0;
}

.profile .img-box h4{
	font-size: clamp(14px, 5vw, 24px);
	padding:0 0 20px 0;
}

.profile .img-box .kome{
	font-size:12px;
	padding:20px 0 0 0;
}

.profile h5{
	font-size:16px;
	padding:30px 20px;
	text-align:left;
}

.effect{
	margin:110px 0 0 0;
	padding:0 20px 40px 20px;
}

.effect h2{
	top:-55px;
}

.effect ul{
	margin:-25px 0 0 0;
}

.effect ul li{
	display:block;
	padding:20px;
	margin:20px 0 0 0;
}

.effect ul li .img{
	max-width:200px;
	margin:0 auto;
	padding:0 0 20px 0;
}

.effect ul li .txt-box{
	width:100%;
}

.effect ul li .txt-box .txt{
	font-size:16px;
}

.effect ul li .txt-box h3{
	padding:10px 0 0 0;
	font-size:14px;
}
	
.effect ul li .txt-box h3 span{
	display:block;
	padding:0;
}
}

/* CONTACT
-------------------------------------------------------------------*/
.contact{
	padding:100px 20px;
}

.contact h2{
	font-size:46px;
	font-weight:700;
	text-align:center;
	color:#fff;
	line-height:1.4;
	padding:0 0 80px 0;
}

.contact .box-in{
	background:#fff;
	padding:100px;
}

.form dl{
	padding:0 0 25px 0;
}

.form dl dt{
	font-size: 18px;
	line-height:1.4;
	display:inline-block;
	position:relative;
	margin:0 0 10px 0;
	color:#001565;
}

.form dl dt.hissu:after{
	content:"＊";
	padding:0 0 0 10px;
	color:#0085E6;
}

.form input, .form textarea {
	width: 100%;
	font-size: 16px;
	line-height: 1.6;
	padding: 20px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	background: #fff;
	box-sizing:border-box;
	border: 1px solid #777777;
	border-radius:0;
}

.form ::placeholder {
	color: #777777 !important;
	font-size:18px;
	font-weight:500;
}

.contact .privacy {
    margin: 20px 0 40px 0;
	height:300px;
    box-sizing: border-box;
    padding: 40px 40px 10px 40px;
    overflow: auto;
    font-size: 16px;
	background:#fff;
	border:1px solid #777777;
}

.contact .privacy h3{
    line-height: 1.6;
    font-size: 20px;
	padding:0 0 30px 0;
	font-weight:700;
}

.contact .privacy h4{
    line-height: 1.6;
	font-weight:700;
	padding:0 0 30px 0;
}

.contact .privacy p{
	padding:0 0 30px 0;
    line-height: 1.6;
}

.check{
	text-align:center;
	padding:0 0 40px 0;
}

.check .wpcf7-list-item-label {
	position: relative;
	cursor: pointer;
}

.check input[type=checkbox] {
	display: none;
}

.check input[type=checkbox] + span {
	display: inline-block;
	position: relative;
	padding:0 0 0 28px;
	font-size: 14px;
	line-height: 1.4;
	cursor: pointer;
}

.check input[type=checkbox] + span::before {
	content: "";
	position: absolute;
	width: 18px;
	aspect-ratio: 1/1;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
	margin:0 auto;
	background: #fff;
	border-radius:0;
	border: 1px solid #777777;
}

.check input[type=checkbox] + span::after {
	content: "";
	position: absolute;
	width: 10px;
	aspect-ratio: 1/1;
    top: 50%;
    transform: translateY(-50%);
	left: 4px;
	background: url(../img/growth/common/check-solid.svg) no-repeat center center;
	background-size: contain;
	opacity: 0;
	transition: 0.3s;
}

.check input[type=checkbox]:checked + span::after {
	opacity: 1;
}

.conbtn button[type=submit] ,
.m-btn a{
	line-height: 80px;
	height: 80px;
	border-radius: 40px;
	background: linear-gradient(#1e348d 0%, #00051a 100%);
	width: 100%;
	color: #fff;
	font-size: 24px;
	display: block;
	font-weight:700;
	font-family: "Zen Kaku Gothic New", sans-serif;
	border: none;
	cursor: pointer;
	margin:0 auto;
	width:490px;
}

.wpcf7-not-valid-tip {
    font-size: 12px;
    padding: 5px 0 0 0;
    font-weight: 600;
}

@media screen and (max-width: 800px) {
.contact{
	padding:40px 20px;
}

.contact h2{
	font-size: clamp(8px, 5.7vw, 30px);
	padding:0 0 40px 0;
}

.contact .box-in{
	background:#fff;
	padding:40px 20px;
}

.form dl{
	padding:0 0 20px 0;
}

.form dl dt{
	font-size: 16px;
	margin:0 0 10px 0;
}

.form dl dt.hissu:after{
	padding:0 0 0 5px;
}

.form input, .form textarea {
	padding: 15px;
}

.form ::placeholder {
	font-size:16px;
}

.contact .privacy {
    margin: 0 0 20px 0;
    padding: 30px 20px 10px 20px;
    font-size: 14px;
}

.contact .privacy h3{
    font-size: 18px;
	padding:0 0 20px 0;
}

.contact .privacy h4{
	padding:0 0 20px 0;
}

.contact .privacy p{
	padding:0 0 20px 0;
}

.check{
	text-align:center;
	padding:0 0 20px 0;
}

.conbtn button[type=submit] ,
.m-btn a{
	line-height: 1.6;
	height: auto;
	border-radius: 60px;
	font-size: 20px;
	padding:20px;
	width:100%;
	max-width:400px;
}
}

/* THANKS/404
-------------------------------------------------------------------*/
.thanks_area{
	padding:80px 20px 140px 20px;
	text-align:center;
	background:#fff;
}

.thanks_area h1{
	font-size: clamp(10px, 5vw, 24px);
	line-height:1.6;
	padding:30px 0;
	border-bottom:1px solid #E8EBEC;
	margin:0 auto;
}

.thanks_area .txt{
	font-size: clamp(10px, 3vw, 16px);
	line-height:2em;
	padding:50px 0;
}

.thanks_area .m-btn{
	padding:0 0 20px 0;
}

/* MOVIE
-------------------------------------------------------------------*/
.movie .contents{
	min-height: 400px;
	position:relative;
}

.movie h1{
	text-align:center;
	padding:50px 0;
}

.movie .movie-area{
	padding:0 20px 90px 20px;
	text-align:center;
	transition: opacity 0.8s ease;
}

.movie .contents .box{
	padding:80px 100px;
	background:#fff;
}

.movie .contents h2{
	font-size:46px;
	font-weight:700;
	text-align:center;
	line-height:1.5;
	padding:0 0 50px 0;
}

.movie .movie-area .box .kome{
	font-size:20px;
	padding:50px 0 0 0;
	line-height:1.6;
}

.movie .movie-thanks,
.movie .movie-about{
	display:none;
	opacity:0;
	transition: opacity 0.8s ease;
	padding:0 20px 90px 20px;
	text-align:center;
}

.movie .contents .txt{
	font-size:20px;
	line-height:1.8;
}

.movie .contents .btn{
	margin:60px 0 0 0;
	cursor:pointer;
	display:inline-block;
}

.is-active {
	display: block !important;
	opacity: 1 !important;
}

.is-hide-absolute {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	opacity: 0 !important;
	pointer-events: none;
	z-index: 0;
}

.movie .movie-about .txt-box{
	padding:50px;
	background:#E9EFF7;
	text-align:left;
	margin: 60px 0 0 0;
}

.movie .movie-about .txt-box dl:not(:last-child){
	padding:0 0 30px 0;
}

.movie .movie-about .txt-box dl dt{
	font-size:20px;
	font-weight:700;
}

.movie .movie-about .txt-box dl dd{
	line-height:1.8;
	padding:8px 0 0 0;
}

.movie .movie-about .btn-tit{
	color:#fff;
	padding:100px 0 50px 0;
}

@media screen and (max-width: 800px) {
.movie h1{
	padding:30px 20px 40px 20px;
	max-width:300px;
	margin:0 auto;
}

.movie .movie-area{
	padding:0 20px 60px 20px;
}

.movie .contents .box{
	padding:40px 20px;
}

.movie .contents h2{
	font-size: clamp(8px, 5.7vw, 30px);
	padding:0 0 20px 0;
}

.movie .movie-area .box .kome{
	font-size:14px;
	padding:30px 0 0 0;
}

.movie .movie-thanks,
.movie .movie-about{
	padding:0 20px 60px 20px;
}

.movie .contents .txt{
	font-size: clamp(10px, 4vw, 16px);
}

.movie .contents .btn{
	margin:30px 0 0 0;
}

.movie .movie-about .txt-box{
	padding:25px;
	margin: 30px 0 0 0;
}

.movie .movie-about .txt-box dl:not(:last-child){
	padding:0 0 20px 0;
}

.movie .movie-about .txt-box dl dt{
	font-size:18px;
}

.movie .movie-about .btn-tit{
	padding:60px 0 30px 0;
}
}

/* TOKUSHO
-------------------------------------------------------------------*/
.tokusho h1{
	text-align:center;
	padding:50px 0;
}

.tokusho .txt-area{
	padding:0 20px 100px 20px;
}

.tokusho .txt-area .box{
	padding:80px 100px;
	background:#E9EFF7;
}

.tokusho .txt-area .box dl{
	padding:25px 0;
	border-bottom:1px solid #001565;
}

.tokusho .txt-area .box dl:first-child{
	padding:0 0 25px 0;
}

.tokusho .txt-area .box dl dt{
	font-size:20px;
	font-weight:700;
}

.tokusho .txt-area .box dl dd{
	line-height:1.8;
	padding:8px 0 0 0;
}

@media screen and (max-width: 800px) {
.tokusho h1{
	padding:30px 20px 40px 20px;
	max-width:210px;
	margin:0 auto;
}
	
.tokusho .txt-area{
	padding:0 20px 60px 20px;
}

.tokusho .txt-area .box{
	padding:40px 20px;
}

.tokusho .txt-area .box dl{
	padding:20px 0;
}

.tokusho .txt-area .box dl:first-child{
	padding:0 0 20px 0;
}

.tokusho .txt-area .box dl dt{
	font-size:18px;
	font-weight:700;
}
}