@charset "UTF-8";

body{	
	background-image:none;
}

h1,
h2,
h3,
h3::after,
h5,
h4{
	background: none;
	border: none;
	box-shadow: none;
}

body{font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;margin:0; padding: 0; font-size: 16px; color: #555;    line-height: 2;}
ul{margin:0; padding: 0;}
li{list-style-type: none;}

#contents{
	width:100%;
	margin:0 auto;
	text-align:left;
	min-height:inherit;
	padding-bottom: 10px;
	min-width: unset;
	color:#555;
}

.flexBox {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
}

.youtube {
    position: relative;
    width: 80%;
    padding: 45% 0 0 0;
    margin: 10px auto 5rem;
}

.youtube iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.center {
	text-align: center;
}

.slidein {
	opacity: 0;
	transform : translateX(-500px);
	transition : all 2s;
	}

.slidein.scrollin {
	opacity: 1;
	transform : translateX(0);
	}

.slidein01 {
	opacity: 0;
	transform : translateX(-1000px);
	transition : all 2s;
	}

.slidein01.scrollin01 {
	opacity: 1;
	transform : translateX(0);
	}

.slidein02 {
	opacity: 0;
	transform : translateX(1000px);
	transition : all 2s;
	}

.slidein02.scrollin02 {
	opacity: 1;
	transform : translateX(0);
	}

.fadein {
  opacity : 0;
  transform : translate(0, 100px);
  transition : all 2s;
}
 
.fadein.active {
  opacity : 1;
  transform : translate(0, 0);
}

#contents section .mb1 {
	margin-bottom: 1rem;
}

#contents section .mb4 {
	margin-bottom: 4rem;
}

h2.title {
    text-align: center;
    position: relative;
    color: #50bcbc;
    font-size: 26px;
    display: inline-block;
	padding: 0 8px 0 8px;
	margin: 0 auto 4rem;
}

h2.title:before {
    background-color: #7ccaca;
    border-radius: 50%;
    content: '';
    position: absolute;
    top: 14%;
    left: -25px;
    width: 20px;
    height: 20px;
}

h2.title span.maru01:before {
    background-color: #fcda9c;
    border-radius: 50%;
    content: '';
    position: absolute;
    top: 19%;
    left: -54px;
    width: 15px;
    height: 15px;
}

h2.title span.maru02:before {
    background-color: #ffa9a9;
    border-radius: 50%;
    content: '';
    position: absolute;
    top: 25%;
    left: -78px;
    width: 10px;
    height: 10px;
}

h2.title:after {
    background-color: #7ccaca;
    border-radius: 50%;
    content: '';
    position: absolute;
    top: 14%;
    right: -25px;
    width: 20px;
    height: 20px;
}

h2.title span.maru01:after {
    background-color: #fcda9c;
    border-radius: 50%;
    content: '';
    position: absolute;
    top: 19%;
    right: -54px;
    width: 15px;
    height: 15px;
}

h2.title span.maru02:after {
    background-color: #ffa9a9;
    border-radius: 50%;
    content: '';
    position: absolute;
    top: 25%;
    right: -78px;
    width: 10px;
    height: 10px;
}

#contents #products h3 {
    margin: 0;
    padding: 0;
    font-size: 300%;
    color: #298d9a;
    width: auto;
}

#contents h4 {
    margin: 0;
    padding: 0.2rem 1rem 0;
    color: #ffffff;
    background: #7ccaca;
    display: inline-block;
    border-radius: 8px 8px 0 0;
}

#comparison li {
    position: relative;
	width: 48%;
}

#comparison li img {
	width: 100%;
}

#comparison li .rorate {
    rotate: -15deg;
    background: #7ccaca;
    color: #fff;
    display: inline-block;
    position: absolute;
    padding: 0.4rem 1.2rem;
    top: 0;
    left: -17px;
    font-size: 110%;
    font-weight: bold;
    text-align: center;
    line-height: 1.2;
}

#comparison li .rorate span {
    display: block;
	font-size: 70%;
	color: #fcda9c;
}

#comparison li .used {
    position: absolute;
    bottom: 10px;
    left: 10px;
    padding: 0px 10px;
    text-align: center;
    border: 2px solid #fff;
    color: #fff;
    font-weight: bold;
}

#comparison li .unused {
	position: absolute;
	bottom:10px;
	right:10px;
	padding: 0px 10px;
    text-align: center;
    border: 2px solid #fff;
    color: #fff;
    font-weight: bold;
}

.bg {
	position: relative;
	padding: 150px 0;
	margin-bottom: 4rem;
}

.bg:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 120%;
    height: 95%;
    margin: 0% -10% 0%;
    background: #ffffe6;
    -webkit-transform-origin: left center;
    -ms-transform-origin: left center;
    transform-origin: left center;
    -webkit-transform: rotate(3deg);
    -ms-transform: rotate(3deg);
    transform: rotate(3deg);
    z-index: -1;
}

.bg:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 120%;
    height: 95%;
    margin: 0 -10% 0;
    background: #7ccaca;
    -webkit-transform-origin: right center;
    -ms-transform-origin: right center;
    transform-origin: right center;
    -webkit-transform: rotate(-3deg);
    -ms-transform: rotate(-3deg);
    transform: rotate(-3deg);
    z-index: -2;
}

#spec div {
    border: 5px solid #7ccaca;
    padding: 2rem;
}



@media screen and  (min-width: 320px) and (max-width: 768px) {
	
	#contents section p {
		margin: 0 0 1rem;
		font-size: 16px;
	}
	
	#contents section li {
		margin: 0;
	}
	
	.inner {
		width:92%;
		margin: 0 auto;
		min-width: 92%;
	}
	
	.pc {
		display: none;
	}
		
	.youtube {
		width: 100%;
		padding: 56.25% 0 0 0;
		margin: 0 auto 2rem;
	}	
			
	#contents section .mb1 {
		margin-bottom: 1rem;
	}

	#contents section .mb4 {
		margin-bottom: 2rem;
	}
	
	#mainPhoto {
		width: 100%;
		margin: 0 auto 2rem;
	}
	
	#mainPhoto img {
		width: 100%;
	}
	
	h2.title {
		font-size: 20px;
		margin: 0 auto 3rem;
		display: block;
	}

	h2.title:before {
		top: 130%;
		left: 0;
		right: 0;
		margin: auto;
		width: 15px;
		height: 15px;
	}

	h2.title span.maru01:before {
		top: 138%;
		left: 42%;
		width: 10px;
		height: 10px;
	}

	h2.title span.maru02:before {
		top: 145%;
		left: 37%;
		width: 7px;
		height: 7px;
	}

	h2.title:after {
		top: 130%;
		left: 0;
		right: 0;
		margin: auto;
		width: 15px;
		height: 15px;
	}

	h2.title span.maru01:after {
		top: 138%;
		right: 42%;
		width: 10px;
		height: 10px;
	}

	h2.title span.maru02:after {
		top: 145%;
		right: 37%;
		width: 7px;
		height: 7px;
	}

	#about,#howto,#products {
		margin-bottom: 1rem;
	}
	
	#point,#comparison,#usage {
		margin-bottom: 2rem;
	}
	
	#about .center {
		text-align: left;
	}
	
	#about .flexBox {
		margin: 1rem auto 0;
		align-items: flex-start;
	}
	
	#about .flexBox li img {
		width: 100%;
		margin-bottom: 0.6rem;
	}
	
	#about .flexBox li p {
		font-size: 15px;
		line-height: 1.6;
	}
	
	#comparison .center,#howto .center {
		text-align: left;
	}
	
	#comparison li {
		width: 100%;
	}
	
	#comparison li:first-child {
		margin-bottom: 2rem;
	}
	
	#comparison li .rorate {
		top: -7px;
		left: -3px;
		font-size: 100%;
	}
	
	#comparison li .used {
		bottom: 0;
	}

	#comparison li .unused {
		bottom:0;
	}
	
	.bg {
		padding: 4rem 0;
		margin-bottom: 0;
	}	
	
	#other .flexBox .photoBox {
		width: 100%;
		margin-bottom: 0.4rem;
	}
	
	#other .flexBox .textBox {
		width: 100%;
		text-align: center;
		margin-bottom: 0.4rem;
	}
	
	#other .flexBox .textBox p {
		font-size: 100%;
	}

	#products .flexBox {
		justify-content: center;
	}
	
	#products .flexBox div:first-child {
		width: 70%;
		text-align: center;
		margin-bottom: 2rem;
	}
	
	#products .flexBox div:first-child img {
		width: 100%;
	}
	
	#products .flexBox div:last-child {
		width: 100%;
		text-align: center;
	}
	
	#contents #products h3 {
		font-size: 160%;
	}
	
	#products .flexBox div:last-child p {
		font-weight: bold;
		font-size: 100%;
		margin-bottom: 2rem;
	}
	
	#contents #products ul.btnList {
		width: 80%;
		margin: 0 auto 2rem;
	}
	
	#contents #products ul.btnList li {
		margin-bottom: 1rem;
	}
	
	#contents #products ul.btnList a {
		background: #298d9a;
		display: block;
		padding: 1rem;
	}	
	
	#spec {
		width: 100%;
		margin: 0 auto 4rem;
	}	
	
	#contents #spec p {
		margin-bottom: 1rem;
	}
	
	#spec div {
		border: 4px solid #7ccaca;
		padding: 1rem;
	}
	
	
	
}




@media screen and  (min-width: 769px) {
	

	#contents section  p,#contents section  li {
		margin: 0;
		font-size: 16px;
		line-height: 1.8;
	}
	
	.sp {
		display: none;
	}
	
	.inner {
		width:94%;
		margin: 0 auto;
	}
	
	#mainPhoto {
		width: 100%;
		max-width: 1280px;
		margin: 0 auto 6rem;
	}
	
	#mainPhoto img {
		width: 100%;
	}
	
	#about,#point,#comparison,#usage,#howto,#products {
		margin-bottom: 6rem;
	}
	
	
	#about .flexBox {
		margin: 4rem auto 0;
		align-items: flex-start;
	}
	
	#about .flexBox li {
		width: 23%;
	}	
	
	#about .flexBox li img {
		width: 100%;
		margin-bottom: 0.6rem;
	}
	
	#about .flexBox li p {
		font-size: 15px;
		line-height: 1.6;
	}
	
	#other .flexBox .photoBox {
		width: 52%;
	}
	
	#other .flexBox .textBox {
		width: 48%;
		text-align: center;
	}
	
	#other .flexBox .textBox p {
		font-weight: bold;
		font-size: 120%;
	}
	
	#other .flexBox:nth-child(odd) {
		flex-flow: row-reverse;
	}
	
	#other .flexBox.no2 {
		margin-top: -20px;
	}
	
	#other .flexBox.no3 {
		margin-top: -20px;
	}	
	
	#other .flexBox.no4{
		margin-top: -20px;
	}
	
	#products .flexBox {
		justify-content: center;
	}
	
	#products .flexBox div:first-child {
		width: 45%;
		text-align: center;
	}
	
	#products .flexBox div:first-child img {
		width: 100%;
	}
	
	#products .flexBox div:last-child {
		width: 45%;
		text-align: center;
	}
	
	#products .flexBox div:last-child p {
		font-weight: bold;
		font-size: 120%;
		margin-bottom: 2rem;
	}
	
	#contents #products ul.btnList {
		width: 75%;
		margin: 0 auto;
	}
	
	#contents #products ul.btnList li {
		margin-bottom: 1.6rem;
	}
	
	#contents #products ul.btnList a {
		background: #298d9a;
		display: block;
		padding: 1rem 2rem;
	}	
	
	#spec {
		width: 80%;
		margin: 0 auto;
	}	
	
	#contents #spec p {
		margin-bottom: 1rem;
	}
	
	
}

@media screen and  (min-width: 1200px) {
	.inner {
		max-width: 1200px;
		width:100%;
		margin: 0 auto;
	}	
	
}




#pageTop {
	display: none;
	position: fixed;
	bottom: 35px;
	right: 20px;
	z-index: 999;
}

#pageTop a {
    color: #fff;
    width: 50px;
    height: 50px;
    padding: 5px;
    background: #50bcbc;
    text-align: center;
    display: inline-block;
    border-radius: 50%;
	text-decoration:none;
}

#pageTop a:hover {
	text-decoration: none;
}

@media screen and  (min-width: 320px) and (max-width: 768px) {
	#pageTop {
		padding: 0;
	}	
	#pageTop a {
		width: 35px;
		height: 35px;
	}	
	

}

@media screen and (max-width: 768px) {
	#pageTop {
		bottom: 10px;
		right: 10px;
		padding: 6px 10px;
		font-size: 70%;
	}
}
