/*
Theme Name:Gravity Child
Theme URI:
Description:WordPressテーマGravity「Gravity」の子テーマ。
Template:gravity_tcd111
Author:
Version:1.1.0
*/
@charset "utf-8";
.p-cb{
	margin-top:0 !important;
}
.p-cb-free-content img{max-width: 100%;vertical-align: top;margin: 0 auto;}
.p-cb-free-content ul{ list-style: none; list-style-type: none;}
.p-cb-free-content a{ color: inherit; text-decoration: none; }
.p-cb-free-content a:hover{ opacity: 0.7; }


.p-cb-free-content{
  font-size:16px;
  line-height: 1.7;
  background: #E7F5DB;
  color:#4C4C4C;
  -webkit-text-size-adjust: 100%;
}


/* common */
.p-cb-free-content h2{
  margin-bottom:40px;
  text-align: center;
  font-weight: bold;
  font-size:1.3em;
}
.p-cb-free-content h2 .text{
  margin-top:30px;
}
.p-cb-free-content h3{
  display: flex;
  align-items: center;
  text-align: left;
  font-size:1.4em;
  font-weight: bold;
  margin-bottom:20px;
}
.p-cb-free-content h3 img{
  margin-right:25px;
}
.center {
	text-align: center;
}

.wrap-900 {
	width: 900px;
	margin: 0 auto;
}

.wrap-1000 {
	width: 1000px;
	max-width: 100%;
	margin: 0 auto;
}

.bg-gray {
	background-color: #F2F2F2;
	padding: 60px 0 40px 0;
}

.bg-yellow {
	background-color: #8DCF56;
	padding: 40px 0;
}

.bg-yellow .wrap-900 {
	text-align: center;
}

.bg-pop {
	background-image: url("./img/bg_01.png");
	background-size: cover;
	background-position: center;
	text-align: center;
	padding: 100px 40px;
}

.bg-pop2 {
	background-color: #fff;
	background-image: url("./img/bg_02.png");
	background-size: cover;
	background-position: center;
	text-align: center;
	padding: 100px 40px;
}

.bg-white {
	padding: 100px 0;
	background-color: #fff;
}

#voice {
	background-color: #fff;
	background-image: url("./img/bg_03.png");
	background-size: cover;
	background-position: center;
	text-align: center;
	padding: 100px 40px;
}

.bg-point {
	background-image: url("./img/bg_02_pc.png");
	background-size: cover;
	background-position: center;
	text-align: center;
	padding: 50px 0;
}


/* header */
header {
	background-image: url("./img/bg_00.png");
	background-size: cover;
	background-position: center;
	text-align: center;
}

.header-band {
	background-color: #fff;
	box-shadow: 0 0 5px #15720D;
}

.header-wrap {
	width: 100%;
	min-width: 1000px;
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.header_btn {
	background-color: #35C012;
	padding: 10px 20px;
}

.header-main {
	text-align: center;
	justify-content: center;
}

.header-img {
	padding: 0px 0;
}

.header-line {
	position: fixed;
	width: 100%;
	display: block;
	box-sizing: border-box;
	bottom: 0;
	left: 0;
	text-align: center;
	background-color: #8DCF56;
	padding: 10px;
}

.header-line:after {
	position: absolute;
	top: 0;
	right: 50%;
	content: "";
	width: 96px;
	height: 96px;
	transform: translate(370px, -40px);
	display: inline-block;
	background-repeat: no-repeat;
	background-size: cover;
	background-image: url(./img/line_btn_after.png);
}


/* about */
.bg-about {
	background-color: #fff;
	position: relative;
	padding: 40px 0;
}

.bg-about:before {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	margin-left: -50px;
	border: 50px solid transparent;
	border-top: 45px solid #fff;
}

.bg-about h2 {
	margin-bottom: 20px;
}

.bg-about .text {
	font-weight: bold;
	margin-top: 0px;
}

.bg-pop img{
	margin: 20px auto 0;
}


/* howto */
#howto {
	background-image: url("./img/bg_04_pc.png");
	background-size: cover;
	background-position: center;
	text-align: center;
	padding: 40px;
}

#howto .wrap-900 {
	background-color: #fff;
	padding: 20px;
	margin: 40px auto;
}


/* message */
#message .wrap-900 {
	display: flex;
	align-items: flex-end;
	padding: 60px 0;
}

#message h2 {
	text-align: left;
	color: #FF8400;
	margin-bottom: 20px;
}

.message-img {
	padding-bottom: 40px;
	margin: 0 30px;
}

#message .text {
	width: 60%;
	font-weight: bold;
	line-height: 2;
	font-size: 1.2em;
}


/* qa */
#qa {
	background-color: #fff;
	padding: 40px 0 50px 0;
}

.qa-list li {
	position: relative;
	padding: 1rem;
	margin-top: 10px;
	border: 3px solid #98D467;
	border-radius: 15px;
	background-color: #fff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.qa-list h4 {
	text-indent: -2.4em;
	width: 100%;
	color: #5CBA0D;
	box-sizing: border-box;
	margin: 0;
	padding: 1rem 4rem 1rem 3rem;
	display: block;
	position: relative;
	border: 0;
	background-color: transparent;
	cursor: pointer;
	-webkit-transition: color .25s ease;
	transition: color .25s ease;
}

.qa-list h4:before {
	content: "Q";
	color: #5CBA0D;
	font-size: 2em;
	font-weight: 500;
	font-family: 'Roboto', sans-serif;
	margin-right: 0.9rem;
}

.qa-list h4:after {
	content: '+';
	color: #98D467;
	text-align: center;
	font-family: 'Roboto', sans-serif;
	font-size: 2.5em;
	font-weight: 400;
	width: 10px;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	position: absolute;
	right: 1rem;
	top: 50%;
}

.qa-list li.active h4:after {
	content: '-';
	font-size: 2.5em;
}

.qa-list p {
	display: none;
	overflow: hidden;
	font-size: 16px;
	padding: 1rem 2rem 1rem 3rem;
	border-top: 2px dashed #98D467;
	text-indent: -2.4em;
}

.qa-list p:before {
	content: "A";
	color: #FFB10D;
	font-size: 2em;
	font-weight: 500;
	font-family: 'Roboto', sans-serif;
	margin-right: 0.9rem;
}

@media screen and (max-width: 780px) {
	.qa-list li {
		psdding: 0.5rem;
	}

	.qa-list h4 {
		padding: 1rem 2rem 1rem 1.5rem;
		text-indent: -1.5em;
	}

	.qa-list h4:before {
		font-size: 1.5rem;
		margin-right: 0.5rem;
	}

	.qa-list h4:after {
		right: 0rem;
	}

	.qa-list p {
		padding: 1rem 0.5rem 1rem 1.5rem;
		text-indent: -1.5em;
	}

	.qa-list p:before {
		font-size: 1.5rem;
		margin-right: 0.5rem;
	}
}


/* voice */
#voice {
	padding: 120px 0;
}

.voice-list {
	display: flex;

}

.voice-list div {
	margin: 25px;
	text-align: left;
	font-size: 0.9em;
	font-weight: 400;
}

.voice-list li .border {
	border-bottom: 1px dotted #aaa;
}

.voice-list li {
	background-color: #fff;
	padding: 20px 0 0 0;
	width: 32%;
	box-sizing: border-box;
}

.voice-list li:nth-child(1),
.voice-list li:nth-child(2) {
	margin-right: 2%;
}

@media screen and (min-width: 1001px) {
	.sp {
		display: none;
	}

	.pc {
		display: block;
	}
}


@media screen and (max-width: 1000px) {
	.sp {
		display: block;
	}

	.pc {
		display: none;
	}

	.wrap-900,
	.wrap-1000,
	.header-wrap,
	.reason-list,
	.footer-wrap {
		width: 94%;
		margin: 0 auto;
	}

	nav {
		display: none;
	}

	.system-flex {
		display: block;
	}

	.header-band {
		position: fixed;
		top: 0;
		left: 0;
		z-index: 9999;
		width: 100%;
	}

	.header-main {
		padding-top: 70px;
	}

	.header-wrap {
		min-width: 100%;
		align-items: stretch;
	}

	.header-logo {
		width: 60%;
		text-align: left;
		display: flex;
		align-items: center;
		margin-left: 10px;
	}

	.header_btn {
		width: 30%;
		text-align: right;
		padding: 0px;
		display: flex;
		align-items: center;
		justify-content: flex-end;
		background-color: transparent;
	}

	.header-line:after {
		width: 0;
		height: 0;
	}

	.header-line .wrap-900 {
		margin-top: -20px;
	}

	.bg-about .text {
		font-size: 0.9em;
	}


	.bg-pop {
		height: auto;
		padding: 30px 0;
		background-color: transparent;
		background-image: none;
		margin-bottom: 30px;
	}

	.bg-pop .wrap-1000 {
		padding: 0;
		width: 100%;
	}

	.bg-pop2 {
		padding: 50px 2%;
	}

	.bg-white {
		padding: 50px 2%;
	}

	.arrow {
		width: 40%;
		margin: 40px auto;
	}

	.system-flex>div:first-child {
		width: 50%;
		margin: 0 auto;
	}

	.system-flex .text {
		width: 100%;
		margin: 0 auto;
		box-sizing: border-box;
		line-height: 2;
		padding: 30px 0 0 0;
	}

	.system-img {
		margin-bottom: 30px;
	}

	.bg-point {
		background-size: 100% auto;
		background-color: #FFDC3F;
		padding: 30px 3%;
	}

	#reason {
		padding-left: 3%;
		padding-right: 3%;
	}

	.reason-list li:nth-of-type(n+2):nth-of-type(-n+5) {
		width: 100%;
	}

	.answer {
		font-weight: normal;
	}

	#voice {
		padding: 60px 0;
		background-image: url(./img/bg_sp.png);
	}

	#voice h2 {
		font-size: 0.9em;
		margin-bottom: 20px;
	}

	.voice-list {
		display: block;
	}

	.voice-list li img {
		width: 30%;
		display: block;
		margin: 20px auto;
	}

	.voice-list li img.pc{
		display: none;
	}

	.voice-list li {
		width: 100%;
		box-sizing: border-box;
		margin: 20px 0;
		padding: 10px;
	}

	#howto {
		padding: 40px 3%;
	}

	#howto .wrap-900 {
		box-sizing: border-box;
		padding: 20px 30px 20px 20px;
		margin: 0 auto;
	}

	.message-img {
		display: none;
	}

	#message .text {
		width: 100%;
	}

	#message h2 {
		text-align: center;
	}

	#message .text p {
		font-size: 0.8em;
	}

	.reason-list li {
		padding: 25px 20px 20px 20px;
	}

	.reason-list .text {
		font-size: 0.9em;
		padding: 10px;
	}
	
}


.cp_arrows *, .cp_arrows *:before, .cp_arrows *:after {
	-webkit-box-sizing: border-box;
	        box-sizing: border-box;
}
.cp_arrows {
	position: relative;
	display: flex;
	height: 200px;/*画面いっぱいにする場合100vh*/
	margin: 2em auto;
	justify-content: center;
	align-items: center;
}
.cp_arrows .cp_arrow {
	position: absolute;
	top: 65%;/*着地点（サンプルは[class:cp_arrows]height300pxの50%）*/
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	        transform: translate(-50%, -50%);
	-webkit-transform-origin: 50% 50%;
	        transform-origin: 50% 50%;
	opacity: 0;
}
.cp_arrows .cp_arrowfirst {
	-webkit-animation: arrow-move08 2s ease-in-out infinite;
	        animation: arrow-move08 2s ease-in-out infinite;
}
.cp_arrows .cp_arrowsecond {
	-webkit-animation: arrow-move08 2s 1s ease-in-out infinite;
	        animation: arrow-move08 2s 1s ease-in-out infinite;
}

@-webkit-keyframes arrow-move08 {
	0% {
		top: 40%;/*スタート地点（サンプルは[class:cp_arrows]height300pxの35%）*/
		opacity: 0;
	}
	70% {
		opacity: 1;
	}
	100% {
		opacity: 0;
	}
}
@keyframes arrow-move08 {
	0% {
		top: 40%;/*スタート地点（サンプルは[class:cp_arrows]height300pxの35%）*/
		opacity: 0;
	}
	70% {
		opacity: 1;
	}
	100% {
		opacity: 0;
	}
}
@media screen and (max-width: 1000px) {
  .cp_arrows{ height:66px; }
  .cp_arrows .cp_arrow { top: 75%;}
	.sp-50{ max-width:50%; }
}
