@charset "utf-8";
/* CSS Document */
html {scroll-behavior: smooth;}
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 ;
  }
  .fB{
	font-weight: bold;
	font-size: 24px;
}
.fsL{
	font-size: 25px;
}
@media (max-width: 760px) {
	.fsL{
		font-size: 23px;
	}
   .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;
	}
	.fB{
		font-weight: bold;
		font-size: 20px;
	}
}
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;
}
.pt20 {
	padding-top: 20px;
}
.mb10 {
	margin-bottom: 10px;
}
.mb20{
	margin-bottom: 20px;
}
.mb60{
	margin-bottom: 60px;
}
img {
	width: 100%;
	margin: 0 auto;
	vertical-align: bottom;
}
.pa{
	padding: 0 2% 2% 2%;
	text-align: center;
}
.un{
	margin-bottom: 10px;
}
.ma{
	margin-bottom: 5%;
}
.maun{
	margin-bottom: 12%;
}
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.5%;
        font-weight: bold;
		font-size: 15px;
		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: #2259c1;
    box-shadow: 0 5px 0 0 #002874;
    text-align: center;
    width: 89px;
    margin: 15px auto;
    position: relative;
    line-height: 1.3;
}
.chart_btn a{
	color: #fff;
	font-size: 11px;
}
.chart02_btn {
    border-radius: 5px;
    padding: 5px;
    background-color: #03af38;
    box-shadow: 0 5px 0 0 #006537;
    text-align: center;
    width: 89px;
    margin: 15px auto;
    position: relative;
    line-height: 1.3;
}
.chart02_btn a{
	color: #fff;
	font-size: 11px;
}
.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;
	}
	.rankTable{
		overflow-x: scroll;
	}
	.rankTable table {
		width: 485px;
	}
	.rankTable td {
		width: 15%;
    max-width: 40px;
    }
}

/*選び方*/
.select_all {
    background: #fff5bd;
	padding: 4% 0 2%;
}
.select_ttl {
    padding: 10px 0 9px 10px;
    font-weight: bold;
	background-color: #c68b0b;
	margin-bottom: 15px;
}
.select_ttl p{
    font-size: 21px;
	color: #fff;
}
.select_content {
    background: #fff;
    margin: 0px 3% 3%;
    padding: 26px 3% 4%;
    border-radius: 20px;
}
.select_content img {
	padding: 4% 0;
}
.arrow_flex{
	display: flex;
	margin: 20px auto 0 auto;
	justify-content: center;
}
.arrow{
	animation: flash 1s linear infinite;

	border-top: 50px solid #F0897F;
	border-right: 50px solid transparent;
	border-left: 50px solid transparent;
	margin: 0 5px 0 5px;
}
@keyframes flash {
	0%,
	100% {
		opacity: 1;
	}

	50% {
		opacity: 0;
	}
}
@media (max-width: 760px) {
	.arrow{
		animation: flash 1s linear infinite;
		border-top: 40px solid #F0897F;
		border-right: 40px solid transparent;
		border-left: 40px solid transparent;
		margin: 0 5px 0 5px;
	}
	.goods_txt li{
		padding-left: 1em;
    	text-indent: -1em;
	}
	.select_ttl {
		padding: 20px 0 15px;
	}
	.select_ttl p{
		font-size: 19px;
		padding: 0 0 0 10px;
	}
	.select_content {
		padding: 4% 3% 6%;
	}
	.select_content img {
		padding: 8% 0;
	}
}

/*商品紹介*/
.product_ttl {
	width: 100%;
	background: #c80000;
	padding: 3% 3px;
	text-align: center;
}
.product_ttl p{
	font-size: 18px;
	color: #fff;
}
.product_ttl a{
	font-size: 25px;
	color: #fff;
}
.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;
		line-height: 1.5;
	}
	.product_ttl a{
		font-size: 23px;
	}
	.product_ttl {
		padding: 5% 3px;
	}
}

/*口コミ*/
.voice_flex{
	display: flex;
}
.voice_content{
	background: #fff;
    margin: 20px 0 0;
    padding: 3% 5%;
    border-radius: 20px;
}
.voice {
    margin: 3% 0;
}
.voice_box{
	position: relative;
	padding: 20px;
	border-radius: 10px;
	background-color: #f3f3f3;
	margin-left: 20px;   
}
.voice_box::before{
	content: '';
	position: absolute;
	display: block;
	width: 0;
	height: 0;
	left: -15px;
	top: 30px;
	border-right: 15px solid #f3f3f3;
	border-top: 15px solid transparent;
	border-bottom: 15px solid transparent;
  }
  
  .voice_box p{
	font-size: small;
  }

.voice_item img{
	width: 110px;
    padding: 0 20px 20px 0;
}

@media (max-width: 760px) {
	.voice_flex {
		display: flex;
		justify-content: center;
	}
	.voice_item img{
		width: 60px;
		padding: 3% 0 10%;
	}
	.voice_content {
		padding: 6% 5%;
	}

	.voice_box::before{
		left: -9px;
		top: 17px;
	  }
}
/*ボタンアニメーション*/
.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: 2%
	}
	.slider .slick-next {
		right: -3%;
	}
}

@media (max-width: 760px){
.rankTable table img {
    max-width: 60%;
    margin: 0 auto;
}
.rankTable table tr th {
    max-width: 48px;
    width: 5%;
	font-size: 10px;
	vertical-align: middle;
    text-align: center;
	line-height: 1.1;
}
	.rankTable table td {
    font-size: 12px;
    line-height: 1.2;
}
	.rankTable a {
    font-size: 12px;
    line-height: 1.2;
}
	.chart_btn {
    padding: 5px;
    width: 80px;
    line-height: 1.2;
}
.chart_btn a{
	font-size: 10px;
}
.chart02_btn {
    padding: 5px;
    width: 80px;
    line-height: 1.2;
}
.chart02_btn a{
	font-size: 10px;
}
}



/* 追加分23.7.21 */
*{
	box-sizing: border-box;
}
.mokuji img{
	width: 35%;
	margin: auto 20px;
}
.mokuji{
    background: #fff;
    margin: 0px 3% 8%;
	padding: 1% 2%;
	display: flex;
	border: inset 3px orange;
	box-shadow: 5px 5px 0px 0 orange;
}
.mokuji ul{
	text-align: left;
	font-size: large;
	margin-top: 20px;
	line-height: 40px;
}
.mokuji a{
	text-decoration: none;
	color: #000000;
	font-weight: bold;
}
.mokuji li{
	border-bottom: 2px solid orange;
	max-width: 350px;
}
.mokuji a:hover{
	color: #949494;
}

@media (max-width: 760px){
	.mokuji img {
    float: none;
    width: 77%;
    margin: auto 35px;
}
	.mokuji {
		display: block;
		padding: 3px 5% 7%;
		margin-bottom: 8%;
		margin: 0 3% 12%;
	}
	.mokuji ul{
		font-size: 17px;
		margin-top: 0;
	}

	p.yoko{
		margin: 0 30px;
	}
}


.yoko{
	margin: 0 90px;
}
.pbox{
	margin: 0 5% 3%;
}

blockquote {
    position: relative;
    padding: 30px 15px 8px 15px;
    box-sizing: border-box;
    font-style: italic;
    background: #efefef;
    color: #555;
}
blockquote:before{
    display: inline-block;
    position: absolute;
    top: 5px;
    left: 3px;
    content: "“";
    font-family: sans-serif;
    color: #cfcfcf;
    font-size: 90px;
    line-height: 1;
}
blockquote p {
    padding: 0;
    margin: 10px 0;
    line-height: 1.7;
}

blockquote cite {
    display: block;
    text-align: right;
    color: #888888;
    font-size: 0.9em;
}