/*
Theme Name:
Theme URI: NA
Author: T.Oka
Author URI: NA
Description: NA
Version: 1.0.0
   font-family: 'Akshar', sans-serif;

*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
@charset "UTF-8";

.grecaptcha-badge {
	visibility: hidden;
}

.body {
	font-family: 'Noto Sans JP', sans-serif;
	background: #000000;
}
.wrapper {
	width: 100%;
	height: auto;
}
.heading {
	padding-top: 100px;
}
.pc {
	display: block;
}
.sp {
	display: none;
}
.mb-40 {
	margin-bottom: 40px;
}
.mb-70 {
	margin-bottom: 70px;
}
.mb-80 {
	margin-bottom: 80px;
}
.mb-100 {
	margin-bottom: 100px;
}
h1 {
	text-align: center;
	font: normal normal normal 16px/29px Anton;
	letter-spacing: 1.28px;
	color: #00DB01;
	text-transform: uppercase;
	margin: 0;
}
h2 {
	text-align: center;
	font: normal normal bold 40px/60px Noto Sans JP;
	letter-spacing: 0px;
	color: #FAFAFA;
	margin: 0;
}
a:hover {
	opacity: 0.8;
}
@media screen and (max-width: 1365px) {
	.sp {
		display: block;
	}
	.pc {
		display: none;
	}
	.wrapper {
		padding: 0 20px;
	}
	h1 {
		font: normal normal normal 14px/29px Anton;
	}
	h2 {
		font: normal normal bold 32px/40px Noto Sans JP;
	}
	.mb-100 {
		margin-bottom: 80px;
	}
}
/* header */
.header {
	position: absolute;
	justify-content: space-between;
	width: 100%;
	height: 80px;
	display: flex;
	z-index: 999;
}
img.logo {
	width: 100px;
	height: 80px;
	margin: 0 30px;
}
.menu {
	display: flex;
	line-height: 40px;
}
.menu li a {
	text-align: left;
	text-decoration: none;
	font: normal normal bold 14px/145px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	text-shadow: 0px 0px 10px #00000080;
	margin-right: 16px;
	line-height: 40px;
}
.menu li img {
	width: 150px;
	height: 40px;
}
.block1 {
	position: relative;
	top: 0;
}
.kv {
	width: 100%;
	height: auto;
}
/* strength */
#strength {
}
.content {
	width: 100%;
	display: flex;
	padding-bottom: 80px;
}
.content h3 {
	text-align: left;
	font: normal normal bold 40px/50px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
}
span {
	color: #00DB01;
}
.content .contentimg {
	width: 48.53%;
	height: auto;
}
.content .contentimg img {
	max-width: 100%;
	height: auto;
}
.content .specifically {
	width: 51.47%;
	height: auto;
	padding-right: 9.736vw;
	padding-left: 40px;
}
.content .specifically p {
	text-align: left;
	font: normal normal normal 18px/32px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin: 0;
}
.swap .contentimg{
	order: 2;
}
.swap .specifically{
	order: 1;
	padding-left: 9.736vw;
	padding-right: 40px;
}
@media screen and (max-width: 1365px) {
	.content {
		display: block;
		padding-bottom: 80px;
	}
	.content .contentimg {
		width: 100%;
		height: auto;
	}
	.content .specifically {
		width: 100%;
		height: auto;
		padding-right: 0;
		padding-left: 0;
	}
	.content h3 {
		font: normal normal bold 26px/33px Noto Sans JP;
	}
}
/* problem cta1 example */
#problem img {
	width: 66.76%;
	height: auto;
}
.img_wrapper {
	width: 100%;
	display: flex;
	justify-content: center;
	position: relative;
}
img.cta1 {
	width: 100%;
}
img.cta_btn2 {
	position: absolute;
	bottom: 17.87878%;
	left: 48.9%;
	width: 17.7%;
	height: auto;
}
.example {
	width: 100%;
	display: flex;
	justify-content: center;
}
.example a {
	width: 28%;
}
.example a img {
	width: 100%;
}
#flow {
	display: flex;
	justify-content: center;
}
#flow img,
#voice img {
	width: 80.527%;
}
.plan_wrapper {
	width: 100%;
	text-align: center;
}
#plan img {
	width: 77.6%;
}
.plan_wrapper p {
	text-align: center;
	font: normal normal normal 14px/21px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin: 24px 0 0 0;
}
@media screen and (max-width: 1365px) {
	#problem img,
	#voice img {
		width: 100%;
	}
	#flow img {
		width: 100%;
		margin-top: 40px;
	}
	#plan img {
		width: 100%;
		height: auto;
	}
	.scroll {
		width: 100%;
		overflow-x: scroll;
	}
	.plan_wrapper p {
		text-align: left;
		font: normal normal normal 14px/21px Noto Sans JP;
	}
	#plan .heading p {
		text-align: center;
		font: normal normal bold 16px/21px Noto Sans JP;
		letter-spacing: 0px;
		color: #FFFFFF;
	}
	.example {
		display: block;
	}
	.example a {
		width: 100%;
	}
	img.cta_btn2 {
		position: absolute;
		bottom: 8.23%;
		left: 19%;
		width: 62%;
		height: auto;
	}
}
@media screen and (max-width: 960px) {
	#plan img {
		width: 960px;
		height: auto;
	}
}
/* qa */
.h2_wrapper {
	width: 100%;
	display: flex;
	justify-content: center;
}
.qa_area {
	display: flex;
	justify-content: center;
}
.qa_wrapper {
	width: 80.527%;
	margin-top: 80px;
	border-radius: 10px;
}
.qa_wrapper img {
	width: 40px;
	height: 40px;
}
.accordion {
	max-width: 100%;
	border-bottom: 1px solid #1D1D1D;
}
.accordion summary {
	display: flex;
	position: relative;
	cursor: pointer;
	padding: 29px 0;
	line-height: 40px;
}
.accordion summary span {
	text-align: left;
	font: normal normal bold 18px/27px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin-left: 10px;
	line-height: 40px;
}
.accordion summary::-webkit-details-marker {
	display: none;
}
.accordion summary::after {
	content: '';
	transform: translateY(-25%) rotate(45deg);
	width: 12px;
	height: 12px;
	border-bottom: 2px solid #C7C7C7;
	border-right: 2px solid #C7C7C7;
	transition: transform .4s;
	top: 45%;
	right: 10px;
	position: absolute;
}
.accordion[open] summary::after {
	transform: rotate(225deg);
}
.accordion h4 {
	transform: translateY(-10px);
	opacity: 0;
	margin: 0 0 0 10px;
	text-align: left;
	font: normal normal normal 15px/24px Noto Sans JP;
	letter-spacing: 0px;
	color: #333333;
	transition: transform .5s, opacity .5s;
	line-height: 40px;
}
.accordion p {
	text-align: left;
	font: normal normal normal 16px/28px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin: 0 0 0 10px;
}
.accordion[open] p {
	transform: none;
	opacity: 1;
}
.accordion ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.accordion li {
	text-align: left;
	margin-left: 50px;
}
.last_accordion {
	border-bottom: none;
}
.answer_wrapper {
	padding-bottom: 30px;
}
.accordion a {
	text-align: left;
	text-decoration: underline;
	font: normal normal normal 15px/18px Noto Sans JP;
	letter-spacing: 0px;
	color: #18874E;
}
.answer {
	display: flex;
	line-height: 40px;
}

@media screen and (max-width: 1365px) {
	.qa_wrapper {
		width: 100%;
		padding: 30px 16px;
		margin-top: 24px;
	}
	.qa_wrapper img {
		width: 30px;
		height: 30px;
	}
	.accordion summary {
		line-height: 30px;
	}
	.accordion summary span {
		width: 75%;
		line-height: 20px;
	}
	.accordion p {
		line-height: 30px;
	}
	.accordion li {
		text-align: left;
		margin-left: 40px;
	}
	.answer_wrapper {
		padding-bottom: 30px;
	}
	.answer {
		line-height: 30px;
	}
}
/* contact */
#contact_top img,
#contact_bottom img {
	width: 100%;
	height: auto;
}
#contact {
	background: #006E01;
}
.form {
	width: 80.527%;
	height: auto;
	padding: 40px 0;
}
.contact_wrapper {
	display: flex;
	justify-content: center;
}
.form form {
	width: 100%;
}
p.contact_text {
	text-align: center;
	font: normal normal bold 16px/24px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin: 0;
}
p.contact_text span {
	color: #BCA03F;
}
.contact-items__wrap {
	display: flex;
	width: 100%;
	justify-content: center;
	margin-bottom: 32px;
}
.contact-items__title {
	width: 18.181818%;
	text-align: left;
	font: normal normal bold 18px/24px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	line-height: 1;
	padding: 10px 0;
}
.contact-items__editor {
	width: 36.36363636%;
}
span.required {
	text-align: left;
	border: 1px solid #FFF500;
	font: normal normal bold 14px/24px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFF500;
	margin-left: 10px;
	line-height: 1;
	padding: 2px 10px;
}
.button_wrapper {
	display: flex;
	justify-content: center;
}
button.btn-success {
	width: 22%;
	background: none;
	border: none;
	padding: 0;
	fit-content: contain;
}
button.btn-success img {
	width: 100%;
	height: auto;
}
input.form-control {
	background: #FFFFFF 0% 0% no-repeat padding-box;
	border-radius: 5px;
	border: 1px solid #A9A9A9;
	height: 50px;
	width: 400px;
}
textarea.form-control {
	background: #FFFFFF 0% 0% no-repeat padding-box;
	border-radius: 5px;
	border: 1px solid #A9A9A9;
	height: 200px !important;
	width: 400px;
}
.privacy_wrapper {
	width: 54.545454%;
}
.privacy_wrapper p {
	text-align: center;
	font: normal normal normal 14px/21px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin: 8px 0 16px 0;
}
.privacy_wrapper p a {
	text-decoration: underline;
	letter-spacing: 0px;
	color: #FFFFFF;
	font: normal normal bold 14px/21px Noto Sans JP;
}
.consent_wrapper {
	display: flex;
	justify-content: center;
}
.consent {
	display: flex;
	width: 43.3333%;
	height: 70px;
	background:rgba(255,255,255,0.2);
	border-radius: 5px;
	padding: 0 20px;
	align-items: center;
}
.consent label {
	margin: 0;
}
p.consent_text {
	text-align: left;
	font: normal normal bold 16px/20px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	padding-left: 10px;
}
input[type="checkbox"] {
	background: #FFFFFF 0% 0% no-repeat padding-box;
	border-radius: 2px;
	width: 18px;
	height: 18px;
}
.checkbox {
	position: relative;
}
.validation-block  {
	color: #fff !important;
}
#consent-error {
	position: absolute;
	left: 50%;
	margin-top: 100px;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	color: #fff;
	font-weight: normal;
	font-size: 16px;
}
@media screen and (max-width: 1365px) {
	.form {
		width: 100%;
	}
	.contact-items__wrap {
		display: block;
	}
	p.contact_text {
		margin: 0 0 10px 0;
	}
	.contact-items__title {
		width: 100%;
		padding: 10px 0;
	}
	.contact-items__editor {
		width: 100%;
	}
	button.btn-success {
		width: 78.46%;
	}
	span.required {
		margin-left: 8px;
	}
	input.form-control {
		width: 100%;
	}
	textarea.form-control {
		width: 100%;
	}
	.privacy_wrapper {
		width: 100%;
	}
	.consent {
		width: 75%;
	}
	#contact_top img {
		margin-bottom: -1px;
	}
	#contact_bottom img {
		margin-top: -1px;
	}

}
@media screen and (max-width: 389px) {
	.consent {
		width: 90%;
	}
}
/* footer */
.footer {
	width: 100%;
	display: flex;
	justify-content: center;
}
.footer_wrapper {
	text-align: center;
	width: 54.5454%;
	height: auto;
	padding: 60px 0;
}
img.footer_logo {
	width: 100px;
	height: 80px;
	margin-bottom: 20px;
}
.footer_menu {
	display: flex;
	justify-content: center;
	margin-bottom: 20px;
}
.footer_menu a {
	text-align: center;
	text-decoration: underline;
	font: normal normal normal 14px/20px Noto Sans JP;
	letter-spacing: 0px;
	color: #414141;
}
.mr-24 {
	margin-right: 24px;
}
.copy {
	text-align: center;
	font: normal normal normal 14px/20px Noto Sans JP;
	letter-spacing: 0px;
	color: #414141;
	text-decoration: none;
}
@media screen and (max-width: 1365px) {
	.footer_wrapper {
		width: 100%;
	}
	.cta_fixed {
		position: fixed;
		background:rgba(0,0,0,0.6);
		width: 100%;
		height: 50px;
		bottom: 0;
	}
	.cta_fixed_wrapper {
		display: flex;
		justify-content: center;
		text-align: center;
		line-height: 50px;
	}
	.cta_fixed_wrapper img {
		width: 206px;
		height: 40px;
	}
}
/* privacy */
#privacy,
#thanks {
	padding: 50px 133px;
}
#privacy h3 {
	position: relative;
	text-align: left;
	font: normal normal bold 22px/33px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	padding-left: 14px;
	margin: 0 0 24px 0;
}
#privacy h3::before {
	content:"";
	position:absolute;
	background: #00DB01 0% 0% no-repeat padding-box;
	width: 4px;
	height: 32px;
	left: 0;
	top: 0;
}
#privacy p,
#privacy a {
	text-align: left;
	text-decoration: none;
	font: normal normal normal 16px/28px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin: 0 0 56px 0;
} {
	text-align: left;
	font: normal normal normal 16px/28px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
	margin: 0 0 56px 0;
}
@media screen and (max-width: 1365px) {
	#privacy,
	#thanks {
		padding: 32px 20px;
	}
}
/* thanks */
main.page02 {
	width: 100%;
	height: 75vh;
	background: #000;
}
.page02 p,
.page02 a {
	font: normal normal normal 16px/28px Noto Sans JP;
	letter-spacing: 0px;
	color: #FFFFFF;
}
.thanks_wrapper {
	display: flex;
	justify-content: center;
}
.btn01 .btn {
	background: #004096;
	border-radius: 25px;
	border: none;
	width: 120px;
	color: #fff;
	padding: 4px;
	margin-left: 20px;
}
.modal-dialog {
	margin: 20% auto 0;
	max-width: 600px;
	width: calc(100% - 40px);
}
.modal-body {
	position: relative;
	padding: 15px;
}
.modal-footer {
	padding: 15px;
	text-align: right;
	border-top: 1px solid #e5e5e5;
	display: flex;
	justify-content: center;
}
button.btn-default {
	width: 80px;
	border-radius: 25px;
	margin: 0;
	padding: 2px;
}
.modal-footer .btn + .btn {
	margin-left: 5px;
	margin-bottom: 0;
	margin: 0 auto;
}
@media screen and (max-width: 1365px) {
}
