html{-webkit-text-size-adjust:100%; scroll-padding-top: 70px;}
body{margin:0;font-size:14px;background:#fff;color:#333;font-family:"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;font-weight:400;line-height:1.875}

hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}
pre{font-family:monospace,monospace;font-size:1em}
a{background-color:transparent}
a{color:#4078c0;text-decoration:none}
a:focus{outline:none}

b,strong{font-weight:bold}
small{font-size:80%}
sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
sub{bottom:-0.25em}
sup{top:-0.5em}

img{border-style:none}
img{max-width:100%;border:0;height:auto;vertical-align:top}

button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}
button,input{overflow:visible}
[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}
[type=button],[type=reset],[type=submit],button{border-style:none;padding:0}
[type=button],[type=reset],[type=submit],button{outline:1px dotted ButtonText}
[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}

[hidden]{display:none}
*{box-sizing:border-box;-webkit-box-sizing:border-box}
*::before,*::after{box-sizing:border-box;-webkit-box-sizing:border-box}
p,li,dt,dd,th,td,pre{overflow-wrap:break-word;word-wrap:break-all}
h1,h2,h3,h4,h5,h6,strong,em{font-size:100%;font-weight:700}
ol,ul{list-style:none}
.anchor {
    display: block;
    padding-top: 70px;
    margin-top: -70px;
}

.pc { display: block; }
.sp { display: none; }

/* PC */
/* header */
header {
  align-content: center;
  align-items: center;
  background: #FFFFFF;
  flex-direction: row;
  flex-wrap: nowrap;
  height: auto;
  justify-content: space-between;
  left: 0;
  margin: 0 0 0 0;
  padding: 24px 32px 20px;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 5;
  max-width: 100%;
		display: flex;
}

.logo {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  padding: 0px;
		flex: none;
		height: auto;
		width: 200px;
		max-width: 100%;
}

@media (max-width: 1200px){
  header {
    height: 60px;
  }
  
  .logo {
    width: 140px;
    max-width: 100%;
}
  
}

nav {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  padding: 0px;
		display: flex;
		margin-left: auto;
    width: calc(100% - 350px);
}
nav ul {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  padding: 0px;
		display: flex;
}
nav ul li {
	align-content: flex-start;
	align-items: flex-start;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: center;
	margin: 0px 12px 0px 0px;
	padding: 0px;
	max-width: calc(100% - 12px);
	font-size: 14px;
	font-weight: 700;
	height: auto;
	letter-spacing: 0.03em;
	line-height: 1.4;
	margin: 0px 0px 0px 0px;
	padding: 8px 16px 6px 16px;
	text-align: center;
	width: auto;
	max-width: 100%;
	justify-content: center;
}
nav ul li a{ color: #333;}

.footer{
  align-content: center;
  align-items: center;
  background: #23252b;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  padding: 20px 0;
		margin: 0;
  width: 100%;
  max-width: 100%;
		float: left;
		clear: both;
}
.endcre{
  align-content: center;
  align-items: center;
  background: #f8f9fc;
  flex: none;
  flex-direction: row;
  flex-wrap: nowrap;
  height: auto;
  justify-content: center;
  margin: 0px 0px 0px;
  padding: 20px 0px 20px 0px;
  width: 100%;
  max-width: 100%;
		float: left;
		clear: both;
}
.w1080 {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  height: auto;
  justify-content: space-between;
  margin: 0px auto;
  padding: 0px;
  width: 1080px;
  max-width: calc(100% - 160px);
		display: flex;
}
.w1080-02 {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  height: auto;
  justify-content: space-between;
  margin: 0px auto;
  padding: 0px;
  width: 1080px;
  max-width: calc(100% - 160px);
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-start;
}



.w1080nf {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  height: auto;
  justify-content: space-between;
  margin: 0px auto;
  padding: 0px;
  width: 1080px;
  max-width: calc(100% - 160px);
}

.endcre {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  padding: 0px;
		margin: 0 0 50px 0;
}
.endcre ul{
		display: flex;
}
.endcre ul li{
	font-size: 14px;
	font-weight: 700;
	height: auto;
	letter-spacing: 0.03em;
	line-height: 1.4;
	margin: 0px 0px 0px 0px;
	padding: 8px 16px 6px 16px;
}
.endcre ul li a{
	color: #333;
}
address {
	text-align: right;
	font-size: 12px;
	font-weight: 700;
}
.footerlogo {
	flex: none;
	height: auto;
	width: 224px;
	max-width: 100%;
	float: left;
}
.footer ul {
	float: left;
}
.footer ul li {
	font-size: 16px;
	font-weight: 700;
	float: left;
	padding: 0 16px;
}
.footer ul li a{
	color: #FFF;
}

.main-header {
	width: 100%;
	background: #E5E5E5;
}
.w1440{
	width: 1440px;
	margin: 0 auto;
}

.about {
	width: 100%;
	padding: 50px 0;
}
.about h1,
.about h2{
  color: #333;
  font-size: 36px;
  font-weight: 700;
  height: auto;
  letter-spacing: 0.03em;
  line-height: 1.6;
  width: auto;
  max-width: 100%;
		text-align: center;
		flex: none;
}
.about img {
margin: 0;
padding: 0;
}
.about .text {
font-size: 18px;
font-weight: 400;
letter-spacing: 0.03em;
line-height: 2.0;
margin: 0 0 0 2%;
padding: 0;
text-align: left;
width: auto;
max-width: 100%;
vertical-align: top;
}
.about p {
font-size: 20px;
font-weight: 600;
letter-spacing: 0.03em;
line-height: 2.0;
margin: 0;
padding: 0;
text-align: center;
width: auto;
max-width: 100%;
vertical-align: top;
}

.problems,
.earnings {
	width: 100%;
	padding: 50px 0;
	background: #f8f9fc;
}
.problems h2,
.earnings h2{
  color: #333;
  font-size: 36px;
  font-weight: 700;
  height: auto;
  letter-spacing: 0.03em;
  line-height: 1.6;
  text-align: left;
  width: auto;
  max-width: 100%;
  justify-content: flex-start;
		text-align: center;
}
.problems .text {
font-size: 18px;
font-weight: 400;
letter-spacing: 0.03em;
line-height: 2.0;
margin: 0 2% 0 0;
padding: 0;
text-align: left;
width: auto;
max-width: 100%;
vertical-align: top;
}
.problems img {
margin: 0;
padding: 0;
width: 50%;
}
.earnings p {
	text-align: center;
	font-size: 20px;
	font-weight: 600;
}
.earnings p span{
	color: #C3105B;
}
.about h3 {
	text-align: center;
	font-size: 36px;
	line-height: 36px;
	font-weight: 600;
	margin: 20px 0 0 0;
	padding: 0;
}
.about h3 span{
	color: #C3105B;
}
.mtop100 { margin:50px 0 0 0; padding:50px 0; border-top: 2px dotted; text-align: center; }
.rightBox {
	width: 60%;
	margin: 0;
	padding: 0;
}
.rightBox img{
	margin: 0;
	padding: 0;
}
.rightBox p{
	text-align: left;
	font-size: 20px;
	line-height: 28px;
}
.abtest {
	width: 36%;
	float: right;
	background: #E1E2E3;
	padding: 2%;
}
.abtest h3{
	width: 100%;
	font-size: 32px;
}
.abtest h4{
	width: 100%;
	font-size: 20px;
	text-align: center;
	line-height: 20px;
	padding: 20px 0 10px 0;
	margin: 0;
}
.abtest p{
	width: 100%;
	font-size: 16px;
	text-align: left;
	line-height: 26px;
}
.footer-cat {
  position: fixed;
  left: 0px;
  right: 0px;
  bottom: 0px;
  background: #C3105B;
  padding: 6px 0 0px;
  text-align: center;
  z-index: 99999;
		height: 50px;
}

.flowNo {
  position: relative;
  display: inline-block;
  margin: 0;
  padding: 0 5px;
  width: 90px;
  height: 90px;
  line-height: 90px;
  text-align: center;
  color: #FFF;
  font-size: 40px;
  font-weight: bold;
  background: #C3105B;
  border-radius: 50%;
  box-sizing: border-box;
}

.flowNo:before {
  content: "";
  position: absolute;
  bottom: -25px;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 15px solid #C3105B;
  z-index: 0;
}
.flowBox {
	background: #FFF;
	width: 31%;
	padding: 2%;
	text-align: center;
	margin: 0 0 50px 0;
	height: 460px;
	}
.flowBox h3{
	font-size: 20px;
	line-height: 24px;
}
.flowBox p{
	font-size: 16px;
	line-height: 26px;
	text-align: left;
	font-feature-settings: "palt";
}
.flowBox .img{
	font-size: 80px;
	line-height: 80px;
	color:#C3105B;
}
.problems p.cap {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.03em;
  line-height: 2.0;
  margin: 0;
  padding: 0;
  text-align: center;
  width: auto;
  max-width: 100%;
  vertical-align: top;
}

.contact {
  margin: 50px 10%;
  padding: 5px;
  text-align: left;
  font-size: 1.2rem;
  line-height: 1.8rem;
  display: block;
		width: 80%;
		float: left;
		clear: both;
}

.contact h1 {
  margin: 0px 0 0;
  padding: 0 0 50px 0;
  font-size: 48px;
  text-align: center;
  font-family: "M PLUS Rounded 1c";
  font-weight: 600;
  color: #C3105B;
}
.contact p {
  font-size: 16px;
  padding: 0 0 50px 0;
  margin: 0;
  font-weight: 600;
  text-align: center;
}
.item {
  width: 100%;
  margin: 0;
  float: left;
  clear: both;
}
.item h4 {
  width: 100%;
  margin: 20px 0 20px 0;
  padding: 0 0 5px 0;
  float: left;
  clear: both;
  text-align: left;
  border-bottom: solid 3px #D95886;
  position: relative;
}
.item h4::after {
  position: absolute;
  content: " ";
  display: block;
  border-bottom: solid 3px #7BA3C3;
  bottom: -3px;
  width: 25%;
}
select, textarea, input[type="number"], input[type="text"] {
  width: 100%;
  padding: 10px 15px;
  font-size: 14px;
  font-size: 1.4rem;
  border: 1px solid #ccc;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  -ms-border-radius: 4px;
  border-radius: 4px;
}

.btn02 {
  text-align: center;
  margin: 20px auto;
  padding: 10px 20px;
}

#submit, .btn02-02 {
  text-align: center;
  margin: 20px auto;
  padding: 10px 40px;
  border-radius: 5px;
  background: #CCC;
  font-weight: 600;
}
.btn02-02-02 {
  text-align: center;
  margin: 20px auto;
  padding: 10px 40px;
  border-radius: 5px;
  background: #FFF;
}


/* 1363 */
@media (max-width: 1363px){

.w1440 {
  width: 100%;
  margin: 20px auto 0;
}

}/* 1363--end */ 



/* 991 */
@media (max-width: 991px){

.pc { display: none; }
.sp { display: block; }

header {
  padding: 12px 16px 10px;
}

.logo {
		width: 140px;
		max-width: 100%;
}

.hamburger {
    position: absolute;
    right: 15px;
    top: 8px;
    width: 40px;
    height: 40px;
    cursor: pointer;
    z-index: 300;
}

nav ul {
  align-content: center;
  align-items: center;
  flex-direction: row;
  flex-wrap: nowrap;
  padding: 0px;
		display: block;
}


.about {
  width: 90%;
  margin: 0px 5%;
}

.w1080 {
  margin: 20px 0;
  padding: 0px;
  width: 100%;
		max-width: 100%;
		display:block;
}
.w1080nf {
  margin: 0px 0;
  padding: 0px;
  width: 100%;
		max-width: 100%;
		display:block;
}
.w1080 img{
  width: 100%;
}
.about .text {
  margin: 20px 0 0 0;
}
.problems, .earnings {
  width: 100%;
  padding: 40px 5%;
  background: #f8f9fc;
}
.problems h2, .earnings h2 {
  font-size: 36px;
  line-height: 1.6;
}
.problems .text {
  margin: 0;
}
.problems img {
  margin: 20px 0 0 0;
}
.about h3 {
  text-align: center;
  font-size: 36px;
  line-height: 46px;
}
.rightBox {
  width: 100%;
}
.abtest {
  width: 100%;
		margin: 20px 0 0 0;
}

#flow {
	float: left;
	clear: both;
	margin: 50px 0 0 0;
}

.w1080-02 {
  width: 100%;
  max-width: 100%;
  display: block;
}
.flowBox {
  width: 100%;
  margin: 0 0 50px 0;
		height: auto;
}


.footerlogo {
		width: 40%;
		margin: 0 30%;
}

address {
  text-align: center;
}
.endcre {
  margin: 0 0 120px 0;
		text-align: center;
}
.footer-cat {
  height: 120px;
}


}/* 991--end */ 




/* 740 */
@media (max-width: 740px){
.pc { display: none; }
.sp { display: block; }
header {
  padding: 12px 16px 10px;
}

.logo {
		width: 140px;
		max-width: 100%;
}
.about {
    width: 90%;
    padding: 20px 5%;
				float: left;
				clear: both;
}
.about h1{
  font-size: 24px;
		margin: 0;
		padding: 20px 0 0 0;
}
.about h2 {
  font-size: 24px;
		margin: 0px 0 0 0;
		padding: 20px 0 0 0;
}

.w1080 {
  margin: 20px 0;
  padding: 0px;
  width: 100%;
		max-width: 100%;
		display:block;
}
.w1080nf {
  margin: 0px 0;
  padding: 0px;
  width: 100%;
		max-width: 100%;
		display:block;
}

.w1080 img{
  width: 100%;
}
.about .text {
  margin: 20px 0 0 0;
}

.problems, .earnings {
  width: 100%;
  padding: 40px 5%;
  background: #f8f9fc;
				float: left;
				clear: both;

}
.problems h2, .earnings h2 {
  font-size: 24px;
  line-height: 1.4;
}
.problems .text {
  margin: 0;
}
.problems img {
  margin: 20px 0 0 0;
}
.about p {
  font-size: 16px;
  line-height: 1.8;
}

.earnings img {
		width: 100%;
}
.earnings p {
  font-size: 16px;
		text-align: left;
}
.about h3 {
  text-align: center;
  font-size: 28px;
  line-height: 32px;
}
#merit {
 margin: 0px 5% 0;
	width: 90%;
}
.rightBox {
  width: 100%;
}
.abtest {
  width: 100%;
		margin: 20px 0 0 0;
}

#flow {
	float: left;
	clear: both;
	margin: 50px 0 0 0;
}

.w1080-02 {
  width: 100%;
  max-width: 100%;
  display: block;
}
.flowBox {
  width: 100%;
  margin: 0 0 50px 0;
		height: auto;
}

.problems p.cap {
  font-size: 16px;
  line-height: 1.8;
		text-align: left;
}

.footerlogo {
		width: 40%;
		margin: 0 30%;
}

address {
  text-align: center;
}
.endcre {
  margin: 0 0 120px 0;
		text-align: center;
}
.footer-cat {
  height: 120px;
}


}/* 740--end */ 



/* 472 */
@media (max-width: 472px){

header {
  padding: 12px 16px 10px;
}

.logo {
		width: 140px;
		max-width: 100%;
}

.w1440 {
    width: 100%;
    margin: 50px auto 0;
				float: left;
				clear: both;
}
.about h1 {
    font-size: 22px;
    margin: 0;
    padding: 0px 0 20px;
				float: left;
				clear: both;
}
.about {
    width: 90%;
    margin: 30px 5% 0px;
				padding: 0 0 20px 0;
				float: left;
				clear: both;
}
.mT20 { margin-top: 20px; float: left; clear: both; }
.problems h2, .earnings h2 {
    font-size: 20px;
    line-height: 1.4;
				margin: 0;
				padding: 0;
}
.about h2 {
    font-size: 20px;
    margin: 0px 0 0 0;
    padding: 0px 0 0 0;
				float: left;
				clear: both;
}
.about p {
    font-size: 16px;
    line-height: 1.8;
				text-align: left;
				padding: 0 0 20px 0;
}

.problems, .earnings {
				float: left;
				clear: both;
}

#merit {
    margin: 0px 5% 0;
    width: 90%;
				float: left;
				clear: both;
}
.about h3 {
    text-align: center;
    font-size: 26px;
    line-height: 30px;
}

#merit h2{
				font-size: 20px;
    margin: 0px 0 0 0;
    padding: 20px 0 0 0;
}
.pd40 {
			padding: 0 0 40px 0;
}
.abtest h4 {
    font-size: 18px;
}
.w1080-02 {
    width: 100%;
    max-width: 100%;
    display: block;
				margin: 0;
				float: left;
				clear: both;
}

.flowBox {
			padding: 5%;
}
.problems p.cap {
    font-size: 16px;
    line-height: 1.8;
    text-align: left;
				float: left;
				clear: both;
				margin: 0;
				padding: 0;
}


}/* 472--end */ 
