@charset "utf-8";
/* CSS Document */
section {
	max-width: 700px;
    margin: 0 auto;
    background-color: #fff;
    padding: 0 0 5%;
	box-shadow: 0 0 5px #d8d8d8;
}
body{
	font-family: Hiragino Sans, Arial, sans-serif !important;
}
p{
	font-size: 18px;
	font-family: Hiragino Sans, Arial, sans-serif !important;
	color: #000000;
	line-height: 1.5;
}
.pc{
      display: block ;
  }
  .sp{
      display: none ;
  }
@media (max-width: 760px) {
   .all {
	padding: 0 15px 13%;
	}
	.pc{
      display: none !important;
  }
  .sp{
      display: block !important;
  }
	p{
		font-size: 16px;
		font-family: Hiragino Sans, Arial, sans-serif !important;
		line-height: 1.5;
	}
	h2 {
		font-size: 19px !important;
		line-height: 1.4;
	}
}
body {
    margin: 0;
    /*background-color: #F4F4F4;*/
}
b{
    font-weight: bold;
}
.taC{
	text-align: center;
}
.g_k {
	font-size: 10px !important;
	text-align: right;
	margin: 0;
	color: #949494 !important;
}
.y_mark{
	background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%,#f9f92b 0%) repeat scroll 0 0;
}
.fcB{
	color: rgb(0, 102, 204);
}
.fcO{
	color: #fd7701;
}
.fcR{
	color: rgb(255, 0, 0);
}
.fcY{
	color: #f9f92b;
}
.fs19{
	font-size: 19px !important;
}
.fs21{
	font-size: 21px !important;
}
.mtb20{
	margin: 20px 0;
}
.mt20{
	margin-top: 20px;
}
.mb20{
	margin-bottom: 20px;
}
.mb60{
	margin-bottom: 60px;
}
img {
	width: 100%;
	margin: 0 auto;
	vertical-align: bottom;
}
video {
	max-width: 100%;
}
footer {
    display: block;
    font-size: 13px;
    padding: 30px;
    background: rgb(236, 236, 236);
    text-align: center;
    max-width: 700px;
    margin: 0 auto;
    box-shadow: 0 0 5px #d8d8d8;
}
footer a{
	color: #00307e;
}
h2 {
    background: linear-gradient(90deg,#ff7e09 0%,#ffde27 100%);
	padding: 1rem 2rem;
    color: #fff;
    font-weight: bold;
    font-size: 23px;
	line-height: 1.5;
}
/*点滅アニメーション*/
.t_ani{
	animation: flash 1s linear infinite;
}
@keyframes flash {
	0%,
	100% {
		opacity: 1;
	}

	50% {
		opacity: 0;
	}
}

/*三角アニメーション*/
.triangle_ani img{
	width: 80%;
    margin: 0 auto 8%;
}
.triangle_ani{
	animation: move-y .5s infinite alternate ease-in-out;
	display: inline-block;
}
@keyframes move-y {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(10px);
  }
}
@media (max-width: 760px) {
	.triangle_ani img {
		width: 50%;
	}
}

/*比較表*/
.rankTable table {
    width: 94%;
    margin: 0 auto 2%;
    background: #fff;
    border-collapse: collapse;
    color: #222;
    text-align: center;
}
.rankTable table td {
    font-size: 13px;
    padding: 3% 0 3%;
    line-height: 1.5;
    vertical-align: middle;
}
.yellow{
    color: #ffa500;
}
.rankTable table img {
    max-width: 100%;
    margin: 0 auto;
}
.rankTable a {
    color: #00307e;
    text-decoration: none;
    font-weight: bold;
    font-size: 13px;
    line-height: 1.2;
}
.rankTable table tr {
	border-top: 1px solid #cdd4d0;
}
.rankTable table tr th {
        background: #ff7800;
        color: #fff;
        border-radius: 0;
        /*	padding: 0.5% 0;*/
        font-weight: bold;
		font-size: 16px;
		width: 75px;
		line-height: 1.3;
    }
.rankTable {
        border: 10px solid #fff5bd;
        border-top: 10px solid #fff5bd;
        border-width: 10px;
        width: 95%;
        box-sizing: border-box;
        background: #ffffff;
		margin: 3% auto 0;
    }
.rankTable td {
        border-right: 2px dotted #cdd4d0;
        text-align: center;
		width: 30px;
    }
.rankTable td:first-child{
        background: #ffffe1;
    }
.rankTable td:last-child {
        border-right: none;
    }
.rankTable table {
	background: #ffffff;
	width: 100%;
	margin: auto;
	box-sizing: border-box;
	padding: 1%;
	border-radius: 5px;
}

.rankTable table tr:first-child th:last-child,
.rankTable table tr:last-child th:last-child {
	border-right: none;
}
.rankTable td {
	font-size: 13px;
}
.rankTable td.txt_only {
	font-size: 1.5rem;
	color: #333333;
	padding: 2.5% 0;
}
span.ex, span.go, span.so {
	font-weight: normal;
	line-height: 70px;
	font-size: 3rem;
}
span.ex {
	color: #f8525d;
}
span.go {
	color: #7cd0dd;
}
span.so {
	color: #f5c132;
}
span.ex, span.go, span.so, span.bad {
	line-height: 50px;
}
.y_bg {
	background: #feffdf;
}
.r_bg {
	background: rgb(255, 0, 0);
	color: #fff;
}
.p_bg {
	background: #ffdde7;
}
.chart_btn {
    border-radius: 5px;
    padding: 5px;
    background-color: #ff7510;
    box-shadow: 0 5px 0 0 #ce6010;
    text-align: center;
    width: 95px;
    margin: 15px auto;
    position: relative;
    line-height: 1.3;
}
.chart_btn a{
	color: #fff;
	font-size: 12px;
}
.chart02_btn {
    border-radius: 5px;
    padding: 5px;
    background-color: #03af38;
    box-shadow: 0 5px 0 0 #006537;
    text-align: center;
    width: 95px;
    margin: 15px auto;
    position: relative;
    line-height: 1.3;
}
.chart02_btn a{
	color: #fff;
	font-size: 12px;
}
.pa1{
	padding: 1% !important;
}
.pb2 {
    padding: 2% 0 2% !important;
}
.pa2{
	padding: 2% 0 0 !important;
}
.fwB{
	font-weight: bold;
}
@media (max-width: 760px) {
	.rankTable table tr th{
		position: sticky;
		left: 0;
		z-index: 5;
		white-space: nowrap;
		width: 75px;
	}
	.rankTable{
		overflow-x: scroll;
	}
	.rankTable table {
		width: 670px;
	}
	.rankTable td {
		width: 30px;
    }
}

/*選び方*/
.select_all {
    background: #fff5bd;
	padding: 4% 0 2%;
}
.select_ttl {
    padding: 20px 0 5px;
    font-weight: bold;
}
.select_ttl p{
    font-size: 21px;
}
.select_content {
    background: #fff;
    margin: 0px 3% 3%;
    padding: 0 3% 4%;
    border-radius: 20px;
}
.select_content img {
	padding: 4% 0;
}
@media (max-width: 760px) {
	.goods_txt li{
		padding-left: 1em;
    	text-indent: -1em;
	}
	.select_ttl {
		padding: 25px 0 15px;
	}
	.select_ttl p{
		font-size: 19px;
	}
	.select_content {
		padding: 0 3% 6%;
	}
	.select_content img {
		padding: 8% 0;
	}
}

/*商品紹介*/
.product_ttl table{
	width: 100%;
	background: #c80000;
}
.product_ttl table , .product_ttl td, .product_ttl th {
	border: 1px solid #fff;
	border-collapse: collapse;
}
.product_ttl td, .product_ttl th {
	padding: 2% 3px;
    width: 30px;
    height: 25px;
    line-height: 1.2;
    text-align: center;
    color: #fff;
	font-size: 21px;
    width: calc(100% / 2);
}
.s_table table{
	width: 100%;
	background: #fff;
	margin: 5% 0;
}
.s_table table , .s_table td, .s_table th {
	border: 1px solid #565656;
	border-collapse: collapse;
}
.s_table td, .s_table th {
	padding: 2% 3px;
    width: 30px;
    height: 25px;
    line-height: 1.2;
    text-align: center;
    color: #353535;
	font-size: 18px;
    width: calc(100% / 3);
}
.bg_g{
	background: #eee;
}
.goods_all {
	background: #fff;
	padding: 3% 3%;
}
.goods_ttl{
	text-align: center;
    font-weight: bold;
    line-height: 1.5;
    padding: 1rem 2rem;
    font-size: 19px;
    background: #ff7800;
}
.goods_ttl p{
	color: #fff;
}
.goods {
    background: #fff5bd;
    padding: 3% 3% 5%;
}
.goods_txt {
    background: #fff;
    border-radius: 20px;
    padding: 3%;
    margin: 0 0 4%;
	border: 2px solid #ff7800;
}
.s_btn {
    width: 90%;
    text-align: center;
    font-weight: bold;
    line-height: 1.3;
    margin: 15px auto;
    border-radius: 4em;
    box-shadow: 0px 4px 7px 0px #8b8b8b;
    background: linear-gradient(0deg, #02922d 0%, #02b237 22%, #60d95d 50%, #02922d 100%);
    padding: 2%;
    border: 4px solid #02962e;
}
.s_btn p{
	color: #fff;
	font-size: 21px;
	line-height: 1.4;
}
.s_btn a{
	text-decoration: none;
}
.btn {
    width: 90%;
    text-align: center;
    font-weight: bold;
    line-height: 1.3;
    margin: 4% auto;
    border-radius: 4em;
    box-shadow: 0px 4px 7px 0px #8b8b8b;
    background: linear-gradient(0deg, #02922d 0%, #02b237 22%, #60d95d 50%, #02922d 100%);
    padding: 2%;
    border: 4px solid #02962e;
}
.btn p{
	color: #fff;
	font-size: 21px;
	line-height: 1.4;
}
.btn a{
	text-decoration: none;
}
.goods_content {
    border: 2px solid #fd7701;
    padding: 6% 4%;
    background: #fff;
    border-radius: 20px;
}
.goods_content img{
	margin: 20px 0;
}
@media (max-width: 760px) {
	.s_table td, .s_table th {
		padding: 3% 10px;
		font-size: 16px;
	}
	.s_btn p {
		font-size: 18px;
	}
	.btn p {
		font-size: 18px;
	}
	.s_btn {
		width: 100%;
	}
	.product_ttl td, .product_ttl th {
		font-size: 18px;
		padding: 4% 3px;
	}
	.btn {
		width: 100%;
	}
	.goods_txt li{
		padding-left: 1em;
    	text-indent: -1em;
	}
}

/*口コミ*/
.voice_flex{
	display: flex;
	align-items: center;
}
.voice_content{
	background: #fff;
    margin: 20px 0 0;
    padding: 3% 5%;
    border-radius: 20px;
}
.voice {
    margin: 3% 0;
}
.voice_item img{
	width: 150px;
    padding: 0 20px 0 0;
}

@media (max-width: 760px) {
	.voice_flex {
		display: flex;
		align-items: center;
		flex-wrap: wrap;
		justify-content: center;
	}
	.voice_item img{
		width: 150px;
		padding: 3% 0 10%;
	}
	.voice_content {
		padding: 6% 5%;
	}
}
/*ボタンアニメーション*/
.purupuru {
  /*アニメーション名、動きの速さ0.8s（=0.8秒）、動き具合、開始時間5s(=5秒後)、動く回数infinite(=無限 3=3回など)   */
  animation: purupuru 2s linear 0s infinite;
}

@keyframes purupuru {

  /*アニメーションの最初の動き*/
  0% {
    /*skew = 傾斜変形する、1番目の値はX軸、2番目に値がある場合はY軸に傾斜変形する
    　　　　9deg = 9度*/
    transform: skew(9deg);
  }

  10% {
    transform: skew(-8deg);
  }

  20% {
    transform: skew(7deg);
  }

  30% {
    transform: skew(-6deg);
  }

  40% {
    transform: skew(5deg);
  }

  50% {
    transform: skew(-4deg);
  }

  60% {
    transform: skew(3deg);
  }

  70% {
    transform: skew(-2deg);
  }

  80% {
    transform: skew(1deg);
  }

  90% {
    transform: skew(0deg);
  }

  /*アニメーションの最後の動き*/
  100% {
    transform: skew(0deg);
  }
}

/*おすすめの商品は…*/
.result_content{
	padding: 0 3%;
}
.cam{
	background: #f9f92b;
	padding: 3%;
	font-weight: bold;
}

/*スリック*/
.slider .slick-slide{
    margin-right: 1vw!important;
    margin-left: 1vw!important;
}
.slider .slick-prev:before {
	background: url(../img/prev.png) no-repeat center!important;
    background-size: contain!important;
    width: 95% !important;
    height: 95% !important;
}

.slider .slick-next:before {
	background: url(../img/next.png) no-repeat center!important;
    background-size: contain!important;
    width: 95% !important;
    height: 95% !important;
}
.slick-arrow::before {
    content: ""!important;
    width: 100%!important;
    height: 100%!important;
    position: absolute;
    top: 0;
    left: 0;
}
.slick-arrow {
    z-index: 2!important;
    width: 40px!important;
    height: 40px!important;
}
.slider .slick-prev{
	left: 17%
}
.slider .slick-next{
	right: 17%;
}

@media (max-width: 760px) {
	.slider .slick-prev:before {
		background: url(../img/prev.png) no-repeat center!important;
		background-size: contain!important;
		width: 60% !important;
		height: 60% !important;
	}

	.slider .slick-next:before {
		background: url(../img/next.png) no-repeat center!important;
		background-size: contain!important;
		width: 60% !important;
		height: 60% !important;
	}
	.slider .slick-prev{
		left: 17%
	}
	.slider .slick-next {
		right: 12%;
	}
}