@charset "utf-8";
/* CSS Document */

:root{
	--main-color:#DCC373;
}

.mt30{
	margin-top: 30px !important;
}

#mainimg {
    position: relative;
}
.mainimg__decoration {
    content: "";
	background-color: #DCC373;
    width: 100%;
	height: 30px;
}

.mainimg__image {
	box-shadow: 0px 5px 10px #00000029;
	background-color: #F0F2F1;
    background-image: url("../images/mainImg.png");
    background-size: contain;
    min-height: 190px;
    background-position: center bottom;
    background-repeat: no-repeat;
		position: relative;
}

.mainimg__image_kusege {background-image: url("/images/mainImg_kusege.png");}
.mainimg__image_aging {background-image: url("/images/mainImg_aging.png");}
.mainimg__image_amino {background-image: url("/images/mainImg_amino.png");}
.mainimg__image_siraga {background-image: url("/images/mainImg_siraga.png");}
.mainimg__image_scalp {background-image: url("/images/mainImg_scalp.png");}

.mainimg__image::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-image: url(/images/fv_new.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}


@media only screen and (min-width: 768px){
	.mainimg__image {
		background-size: contain;
		height: 570px;
		background-position: center center;
	}
}

@media only screen and (max-width: 480px){
	.mainimg__image {
		background-image: url(../images/mainImgSp.png);
		background-size: 100vw 100vw;
		height: 100vw;
	}

	.mainimg__image_kusege {background-image: url("/images/mainImgSp_kusege.png");}
	.mainimg__image_aging {background-image: url("/images/mainImgSp_aging.png");}
	.mainimg__image_amino {background-image: url("/images/mainImgSp_amino.png");}
	.mainimg__image_siraga {background-image: url("/images/mainImgSp_siraga.png");}
	.mainimg__image_scalp {background-image: url("/images/mainImgSp_scalp.png");}

	.mainimg__image::before {
		background-image:  url(/images/fv_new_sp.png);
	}

	#shampoo .mainimg__image {
		background-image: url("../shampoo/images/mainImgSp.png");
	}
	#total .mainimg__image {
		background-image: url("../total/images/mainImgSp.png");
	}
}

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

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

div#container{
    min-width: 1100px;
    width: 1100px;
    margin: 30px auto 0 ;
    content: '';
    overflow: hidden;
    clear: both;
	padding: 0 15px;
	display: flex;
	flex-direction: row-reverse;
}


div#contents {
    width: 100%;
	max-width: 760px;
	padding: 0;
}

@media only screen and (max-width: 1100px){
div#container{
    min-width: 760px;
    width: 100%;
    margin: 30px auto 0 ;
    content: '';
    overflow: hidden;
    clear: both;
	padding: 0 ;
	display: flex;
	flex-direction: row-reverse;
}
#side_menu{
    max-width: 290px;
	width: 100%;
	display: none;
}
}

#side_menu{
    max-width: 290px;
	width: 100%;
}
#side_menu h4 {
	height: 50px;
	line-height: 50px;
	background-color: #DCC373;
	color: white;
	border-radius: 10px 10px 0 0;
	position: relative;
	text-indent: 30px;
}#side_menu h4:before {
  content: " ";
  position: absolute;
  top: 0;
  right: 0;
  width: 70%;
  height: 50px;
    border-radius: 0 10px 0 0;
    border-bottom: solid 50px #ffffff30;
    border-top: solid 0 transparent;
    border-left: solid 30px transparent;
    border-right: solid 0px #ffffff20;
    box-sizing: border-box;
}
.flow_text{
animation : scrollSample01 20s linear infinite;
}
@keyframes scrollSample01{
0% { transform: translateX(0)}
100% { transform: translateX(-100%)}
}

#side_menu ul{
	padding: 0;
	margin-bottom: 30px;
	box-shadow: 0px 5px 10px #00000029;
	border-radius: 0 0 10px 10px;
}#side_menu ul>li{
	padding: 0;
	background-image: url("../images/icon_list.png");
	background-repeat: no-repeat;
	background-position: center left 30px;
}#side_menu ul>li.home{
	background-image: url("../images/icon_home.png")
}#side_menu ul>li.info{
	background-image: url("../images/icon_info.png")
}#side_menu ul>li.privacy{
	background-image: url("../images/icon_privacy.png")
}#side_menu ul>li.rank{
	background-image: url("../images/icon_ranking.png")
}



#side_menu ul>li.menu>a,
#side_menu ul>li>a {
    display: block;
    text-decoration: none;
    color: #CBB46A;
	border-bottom: 2px dotted #DCC373;
}
#side_menu ul>li>a{
	color:#514212;
    line-height: 50px;
	white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0.2em 30px 0 60px;
}
#side_menu ul>li>a:hover{
	background-color: #DCC37350; 
}
#side_menu ul li:last-child a{
	border: none;
	border-radius: 0 0 10px 10px;

}

.menu {
    list-style: none;
    margin-bottom: 0;
    border: none;
}

.menu li {
    border-bottom: none;
    padding: 7px;
}
#sideColumn {
    width: 100%;
    max-width: 580px;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 40px;
    border: 2px #d0b27e solid;
    padding-top: 20px;
    padding-left: 3%;
    padding-right: 3%;
    padding-bottom: 20px;
    box-sizing: border-box;
    border-radius: 0 0 6px 6px;
}

#side_menu #sideColumn .pickup {
    font-size: 20px;
    font-weight: 700;
    color: #000;
    text-align: center;
    margin: 0.5em 0;
    line-height: 1.6;
}

#side_menu #sideColumn img {
	width: 100%;
	max-width: 250px;
    margin: 0 auto;
    line-height: 1.6;
}



#side_menu #sideColumn .pickup a{
    text-decoration: none;
    color: #06c;
}

#side_menu #sideColumn .sideColumn_link {
    font-size: 15px;
    color: #000;
    margin: 0.5em auto;
    line-height: 1.4;
    padding-left: 15px;
    position: relative;
}

#side_menu #sideColumn .sideColumn_link:before {
    position: absolute;
    content: "";
    display: block;
    top: 5px;
    left: 0;
    border: 5px solid transparent;
    border-left: 5px solid #636363;
}
div {
    max-width: 100%;
}
.compareTableImage {
    position: relative;
	margin-top: 30px;
}
.compareTableImage__telop {
    position: absolute;
	left: 0;
    top: -20px;
}


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

h2 {
	width: 100%;
	height: 50px;
	line-height: 50px;
	background-color: #DCC373;
	color: white;
	text-align: center;
	border-radius: 10px 10px 0 0;
}

.productArea {
	width: 100%;
    padding: 30px 50px;
	margin: 30px 0;
	background-color: white;
    border: 5px solid #CBB46A;
	border-radius: 10px;
	box-sizing: border-box;
}.productArea .productName {
	position: relative;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
    width: 100%;
}.productArea .productName p.name {
	width: 100%;
    color: #E8850C;
    font-weight: 700;
    font-size: 24px;
	text-align: center;
    line-height: 50px;
	border-bottom: 5px solid #CBB46A;
	order: -1;
}
.productArea .productName p.name a {
    color: #E8850C;
    text-decoration: none;
}

.productArea .productName img.ranking{
	position: absolute;
    max-width: 180px;
    left: -40px;
    top: -20px;
}.productArea .productName p span{
position: absolute;
    font-size: 0.8em;
    width: 65px;
    height: 40px;
    line-height: 42px;
    background-color: #E8850C;
    color: white;
    left: 0;
    top: 0;
    border-radius: 10px;


}.productArea dl{
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	width: 100%;
	height: 63px;
	color: #61ACE2;
	box-sizing: border-box;
	text-align: center;
	margin-top: 30px;
	order: -1;
	border-top: #61ACE2 2px solid;
}.productArea dl dt{
	width: 25%;
	height: 30px;
	line-height: 30px;
	background-color: #61ACE2;
	color: white ;
	box-sizing: border-box;
	border-right: #fff 2px solid;
}.productArea dl dt:last-of-type{
	border: none;
}.productArea dl dd{
	width: 25%;
	height: 30px;
	line-height: 30px;
	border: 2px #61ACE2 solid;
	border-left: none;
	box-sizing: border-box;
}.productArea dl dd:first-of-type{
	border-left: 2px #61ACE2 solid;
}.productArea dl.lower{
	position: relative;
}.productArea dl.lower::after{
	content: "";
	display: block;
	position: absolute;
	top: -2px;
	left: 0;
	width: 20%;
	height: 2px;
	background-color: #AE742E;
}
.productArea dl.lower dt,
.productArea dl.lower dd{
	width: 20%;
}.productArea dl.lower dt.total{
	background-color: #AE742E;
}.productArea dl.lower dd.total{
	color: #AE742E;
	border: 2px #AE742E solid;
}

.productArea .product {
	margin-top: 30px;
	max-width: 300px;
}.productArea .detail {
	margin-top: 30px;
	max-width: 340px;
}.productArea .point {
	position: relative;
	background: #FFF1E6 0% 0% no-repeat padding-box;
	border-radius: 10px;
	padding: 4em 1em 1em;
}.productArea .point h3{
	position: absolute;
	top: 1em;
	left: -0.5em;
	padding: 0.2em 2em;
	background-color: #E8850C;
	background-image: url("../images/icon_shampoo.png");
	background-repeat: no-repeat;
	background-size: 24px;
	background-position: left;
	color: white;
	min-width: 240px;
}.productArea .point h3:after{
  content: "";
  position:absolute;
  top:-2px;
  right:-2px;
  width:0;
  height:0;
  border-style: solid;
  border-color: transparent #FFF1E6 transparent transparent;
  border-width: 18px 22px 18px 0;
}





.productArea .point li{
	list-style: none;
	background-image: url("../images/icon_list_point.png");
	background-repeat: no-repeat;
	text-indent: 30px;
	line-height: 1.8;
}.productArea .point li span{
	font-size: 0.8em;
}.productArea .point li mark{
	padding: 0 0.2em;
	font-weight: 700;
	background: linear-gradient(#00000000 50%, yellow 50%);
}

.productArea .price{
	font-size: 1.25em;
	font-weight: bold;
	color: #E8850C;
	margin-top: 0.5em;
}.productArea .price mark{
	background: linear-gradient(#00000000 50%, #59ffc9 50%);
    color: unset;
    padding: 0 0.5em;
}.productArea .note{
	font-size: 0.75em;
	color: black;
	margin-bottom: 0.5em;
}
.productArea .btn,
.productArea .sns{
	margin-top: 30px;
}
.btn .land{
	background: linear-gradient(-60deg,#80d349 48%,#a0f369 50%, #80d349 52%);
	background-size: 450% 450%;
	animation: gradient 2.5s ease infinite;
	box-shadow: 0 10px 0 #58be13 !important;
}
@keyframes gradient{
	0% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0 50%;
	}
}
.land:hover{
	box-shadow: 0 7px 0 #58be13 !important;
}
.land:active{
	box-shadow: 0 0px 0 #58be13 !important;
}
.productArea .sns{
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}
.productArea .sns div{
	box-sizing: border-box;
	width: 50%;
	padding: 0 30px 30px;
}
.productArea .sns div p{
	margin-top: 0.5em;
}

.productArea .reviewer h2::before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 240px;
	border-top: solid 50px #ffffff30;
    border-bottom: solid 0 transparent;
    border-left: solid 30px #ffffff30;
    border-right: solid 30px transparent;
    box-sizing: border-box;
	
}
.productArea .reviewer h2{
	border-radius: 0;
	position: relative;
	margin: 36px;
	text-align: left;
	text-indent: 60px;
	line-height: 1.8em;
}.productArea .reviewer h2 span{
	font-size: 0.5em;
	position: absolute;
	top: 32px;
	left: 0;
	line-height: 1em;
}.productArea .reviewer h2 img{
	position: absolute;
	top: -36px;
	right: 60px;
}.productArea .reviewer p{
	margin: 30px;
	max-width: 480px;
}.productArea .reviewer p img{
	margin-bottom: 0.5em;
}.productArea div.reviewer{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}





.productArea .review{
	background: #DCC3731A 0% 0% no-repeat padding-box;
	border: 3px solid #AE742E;
	border-radius: 10px;
	margin-top: 30px;
	margin-bottom: 1.5rem;
}
.productArea .review h3{
	background-color: #AE742E;
	color: white;
	padding: 0.5em 1em;
}
.productArea .review div{
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	height: 140px;
	border-bottom: 1px dashed #AE742E;
}.productArea .review div:last-child{
	border-bottom: none;
}
.productArea .review div .review_icon{
	width: 100px;
    height: 120px;
    background-image: url(../images/icon_review.png);
    background-repeat: no-repeat;
    text-align: center;
    background-position: center;
    padding: 72px 20px 0;
    box-sizing: border-box;
    line-height: 1.2em;
    color: white;
    font-weight: bold;
}.productArea .review div:nth-child(odd) .review_icon{
    background-image: url("../images/icon_review_n.png");
}
.productArea .review div h5,
.productArea .review div p{
	width: calc( 100% - 100px - 0.5em);
	padding: 0.5em 0.5em 0 0;
	color: #CBB46A;
	font-size: 1.2em;
}.productArea .review div p{
	font-size: 0.9em;
		padding: 0em 0.5em 0 0;
	color: black;
}

@media only screen and (max-width: 768px){
	.productArea {
    padding: 15px;
		justify-content: center;
	}
	.productArea .productName {
    justify-content: center;
}
.productArea .productName p.name{
	font-size: 5vw;
}
	.productArea .product {
    margin-top: 0;
		text-align: center;
}
.productArea .product {
	max-width: 75%;
}
	.productArea .productName img.ranking {
    max-width: 110px;
		    max-height: 180px;
				top: -50px;
				left: -15px;
	}
	.productArea dl{
	display: flex;
	flex-wrap: wrap;
	width: 100%;
		height: 120px;
	border: none;
		border-left: 2px #61ACE2 solid;
	color: #61ACE2;
	box-sizing: border-box;
	flex-direction: row;
		margin-top: 15px;
	order: 0;
	}
	.productArea dl dt{
	width: 50%;
	height: 30px;
	line-height: 30px;
	background-color: #61ACE2;
	color: white ;
		border-right: none;
		border-bottom: 2px solid #fff;
	box-sizing: border-box;
	}
	.productArea dl dd{
	width: 50%;
	height: 30px;
	line-height: 30px;
	border: 2px #61ACE2 solid;
		border-top: none;
	box-sizing: border-box;
	}
	.productArea dl dd:first-of-type{
		border-top: 2px solid #61ACE2;
	}.productArea dl.lower{
		height: 150px;
	}.productArea dl.lower::after {
    content: "";
    display: block;
    position: absolute;
    top: 0px;
    left: -2px;
    width: 2px;
    height: 30px;
    background-color: #AE742E;
	}
	.productArea dl.lower dt,
	.productArea dl.lower dd {
		width: 50%;
	}
	.productArea .btn, .productArea .sns {
    margin-top: 20px;
	flex-direction: column;
	align-items: center;
	}.productArea .btn a{
		margin: 12px 0 0;
	}.productArea .sns div {
    width: 100%;
    padding: 15px 15px 0;
	}
	.productArea .review div {
    flex-direction: row;
    height: auto;
	}
	.productArea .reviewer h2{
		text-indent: 10px;
		font-size: 1.2em;
    	line-height: 2em;
	}.productArea .reviewer h2::before{
		width: 160px;
	}
	.productArea .reviewer h2 img {
    top: -20px;
    right: -8px;
    max-width: 96px;
	}
	.productArea .review div p {
		order: 1;
	}
	.productArea .review div h5 {
    width: calc( 100% - 100px - 1em);
    padding: 1em 0 1em 1em;
    color: #CBB46A;
    font-size: 1.2em;
	} .productArea .review div p{
    width: 100%;
    padding: 1em;
	}.productArea .point h3{
		min-width: 170px;
	}
}





.itemIntroduction {
    margin-bottom: 20px;
    background-image: url(../images/introductionBackground.png);
    background-size: cover;
    background-position-x: center;
    background-repeat: no-repeat;
}
.itemIntroduction p.title {
    background: #fff;
    margin-bottom: 0;
}
.itemIntroduction__name {
    margin: 20px auto;
    text-align: center;
    background-color: #fff;
    margin-top: 0;
}

.itemIntroduction__image,
.itemIntroduction__chart {
    display: inline-block;
    width: 48%;
    background: 0 0;
}


footer{
	clear: both;
	background-color: #d0b27e;
	width: 100%;
}
footer ul {
	width: 100%;
	padding: 0.5em 0;
    background-image: url(../images/footer_bg.png);
    background-position: center center;
    background-repeat: repeat;
    text-align: center;
	display: flex;
	justify-content: center;
}
footer ul li{
	list-style: none;
	margin: 0 0.5em;
}footer p{
	text-align: center;
	font-size: 0.8em;
	padding: 0.5em 0;
}



div.search {
	background-color: white;
	border-radius: 10px;
	padding: 0 0 30px ;
	height: 50px;
	box-sizing: border-box;
	box-shadow: 0px 5px 10px #00000029;
	margin: 0 0 10px 0;
}
div.open {
	height: auto;
}
div.search h2{
	position: relative;
	border-radius: 10px;
}
div.search h2:before {
  content: " ";
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 50px;
    border-radius: 0 10px 10px 0;
    border-bottom: solid 50px #ffffff30;
    border-top: solid 0 transparent;
    border-left: solid 30px transparent;
    border-right: solid 30px #ffffff20;
    box-sizing: border-box;
}
div.open h2{
	position: relative;
	border-radius: 10px 10px 0px 0px;
}
div.search h2 span{
	content: "";
	display: block;
	width: 100%;
	height: 50px;
	background-image: url("../images/icon_seach_circle.png");
	background-repeat: no-repeat;
	background-position: center right 12px;
	position: absolute;
	top: 0;
	cursor: pointer;
}div.open h2 span{
	background-image: url("../images/icon_close_circle.png")
}

div.search form {
    width: 100%;
	visibility: hidden;
}
div.open form {
    width: 100%;
	visibility: visible;
}


div.search table{
	width: 100%;
	padding: 30px 50px 0;
	line-height: 2em;
}div.search tr{
	display: flex;
    flex-direction: column;
}div.search th{
	color: #DCC373;
	font-weight: bold;
	width: 100%;
	border-bottom: 	2px dashed #DCC373;
}div.search td{
	margin: 10px 0;
	display: flex;
    flex-wrap: wrap;
}div.search td label{
	margin-right: 10px;
	display: block;
}

div.search_result {
    background-color: white;
    border-radius: 10px;
    padding: 0 0 30px;
    box-sizing: border-box;
    box-shadow: 0px 5px 10px #00000029;
    margin: 0 0 50px 0;
}div.search_result div{
	display: flex;
    flex-wrap: wrap;
    width: 100%;
    padding: 0 50px 0;
    line-height: 3em;
    box-sizing: border-box;
}div.search_result h4 {
    color: #DCC373;
    font-weight: bold;
    width: calc( 100% - 100px);
border-bottom: 2px dashed #DCC373;
    margin: 30px 50px 0;
	box-sizing: border-box;
}div.search_result div span {
	background-color: #dcc373;
    border-radius: 2px;
    padding: 0.5em 0.8em;
    margin: 0.5em 0.8em;
    line-height: 1em;
    color: white;
}

















.btn{
	padding: 0 50px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}
.btn a,
.btn input{
  position: relative;
  display: inline-block;
	width: 90%;
	height: 50px;
	line-height: 50px;
	text-decoration: none;
  color: #FFF;
  background: #DCC373;
	/* background: linear-gradient(-60deg,#80d349 48%,#a0f369 50%, #80d349 52%);
	background-size: 450% 450%;
	animation: gradient 2.5s ease infinite; */
  border: none;
  border-radius: 10px;/*角の丸み*/
  box-shadow: 0 10px 0 #CBB46A;
	bottom: 10px;
  font-weight: bold;
	margin: 10px 15px 0;
	text-align: center;
	cursor: pointer;
}
.btn a:hover,
.btn input:hover{
	  box-shadow: 0 7px 0 #CBB46A;
	bottom: 7px;
}
.btn a:active,
.btn input:active {
	  box-shadow: 0 0px 0 #CBB46A;
	bottom: 0px;
}

.btn a::after{
	position: absolute;
	font-family: 'Font Awesome 5 Free';
	font-weight: bold;
	content: "\f101";
	top: 0;
	right: 1em;
}



@media only screen and (max-width: 768px){
	.btn{
		padding: 0px 0px;
	}
	div#container{
		min-width: 320px;
    width: 96%;
		max-width: 760px;
		/* padding: 0 15px; */
}
	#btn_space input {
		width: 100%;
	}

.thumnail img{
		width: 100%;
	}.productArea table {
    border-collapse: collapse;
    width: 96%;
    margin-top: 20px;
    margin-bottom: 20px;
    margin-left: 2%;
    margin-right: 2%;
    border-left: #d4d4d4 1px dotted;
    border-right: #d4d4d4 1px dotted;
}
	.detailTable table{
display: inline-block;
    overflow-x: auto;	}
	.detailTable tbody{
		display: flex;
	}
	
	.detailTable tr{
		display: flex;
	flex-direction: column;
	}

.detailTable th {
    background-color: #6ca131;
    color: #fff;
    width: 75px;
	margin: 0;
    text-align: left;
    padding: 5px 10px;
    font-weight: 700;
    font-size: 15px;
	border-right: #d4d4d4 1px dotted;
    border-bottom: #d4d4d4 1px dotted;
	height: 50px;
}
.productArea td {
    border-bottom: #d4d4d4 1px dotted;
    text-align: left;
	min-width: 120px;
    padding: 5px 10px;
    line-height: 50px;
	line-height: 1.5;
	height: 50px;
}
	.productArea .review div .review_icon {
    width: 50px;
    height: 90px;
    background-image: url(../images/icon_review.png);
    background-repeat: no-repeat;
    text-align: center;
    background-position: center;
    padding: 52px 0 0;
    box-sizing: border-box;
    line-height: 1.5em;
    color: white;
    font-weight: bold;
    font-size: 50%;
    background-size: 100%;
}
	.productArea .review div h5 {
    width: calc( 100% - 75px - 1em);
    padding: 1em 0 0em 1em;
    color: #CBB46A;
    font-size: 1.1em;
}

.btn a{
	width: 100%;
}

}
@media only screen and (max-width: 480px){
	.btn a{
		font-size: 3.6vw;
	}
}




div.blog{
	
}div.blog h2{
	box-sizing: border-box;
	height: 50px;
	border-radius: 0;
	line-height: 40px;
	border: 5px solid #AE742E;
	border-left-width: 30px;
	background: white;
	color: #AE742E;
	text-align: left;
	padding-left: 0.5em;
}
div.blog h4 {
	font-size: 1.2em;
	padding: 0.5em 0 0.2em;
	color: #AE742E;
  border-bottom: 5px solid #DCC373;
  position: relative;
}div.blog h4:after {
  position: absolute;
  content: " ";
  display: block;
  border-bottom: 5px solid #AE742E;
  bottom: -5px;
  width: 20%;
}div.blog p{
	padding: 0.5em 0;
	line-height: 2em;
}

@media screen and (max-width: 480px){
	div.blog h2{
		font-size: 4vw;
	}
}



.effect-fade {
	opacity: 0;
	width: 0 !important;
	transition-duration:  0.5s;
	transition-timing-function: ease;
	left: -7em;
    position: relative;
}

.effect-fade.effect-scroll {
	opacity : 1;
	width: 100% !important;
	left: 0;
}

/* ---------------------トップテーブル----------------------- */
.topTable_container{
	width: 100%;
	margin: 0 0 2rem;
	padding: 1rem 0 1rem;
	background-color: #fff;
}

.tableH2_ribbon{
	box-sizing: border-box;
	height: 70px;
	margin: 0 auto 2rem;
	position: relative;
	text-align: center;
	vertical-align: middle;
	width: 80%;
}

.tableH2_ribbon::before,
.tableH2_ribbon::after{
	border-color: #ebd451;
	border-style: solid;
	bottom: -20px;
	content: '';
	position: absolute;
	width: 0;
	z-index: 8;
}

.tableH2_ribbon::before{
	border-left-color: transparent;
	border-width: 35px 30px;
	left: -40px;
}

.tableH2_ribbon::after{
	border-right-color: transparent;
	border-width: 35px 30px;
	right: -40px;
}

.tableH2_ribbon h2{
	background: #ffe866;
	color: #333;
	padding: 10px 20px;
	position: relative;
	z-index: 10;
	width: auto;
	font-size: 1.5rem;
	font-weight: bold;
	text-shadow: 2px 2px 0 #fff;
	border-radius: 0;
}

.tableH2_ribbon h2::before,
.tableH2_ribbon h2::after{
	border: none;
	border-bottom: solid 20px transparent;
	content: '';
	position: absolute;
	top: 100%;
	z-index: 9;
}

.tableH2_ribbon h2::before{
	left: 0;
	border-right: solid 20px #c5b03a;
}

.tableH2_ribbon h2::after{
	right: 0;
	border-left: solid 20px #c5b03a;
}

.topTable{
	width: 100%;
	margin: 0 auto;
	border-collapse: separate;
	border-spacing: 0;
}

.topTable th,.topTable td{
	text-align: center;
	vertical-align: middle;
	width: 27%;
	line-height: 1.1em;
	padding: .5em;
}

.topTable th:first-of-type,.topTable td.td_title{
	width: 19%;
}

.topTable th{
	background-color: #ff8d96;
	color: #fff;
	font-weight: bold;
	border-left: solid #fff 3px;
	padding: 1em 0;
}

.topTable td{
	border-left: solid #ff8d96 3px;
	position: relative;
}

.topTable td:not(.td_title){
	/* color: #21a0fa; */
	font-size: 1.5rem;
}

.topTable .small{
	font-size: .7em;
	line-height: 1.1em;
}

.topTable tr:first-child th:first-child{border-left: solid #ff8d96 3px;}
.topTable tr:first-child th:last-child{border-right: solid #ff8d96 3px;}
.topTable tr td:last-child{border-right: solid #ff8d96 3px;}
.topTable tr:first-child th{border-top: solid #ff8d96 3px;}
.topTable tr:last-child td{border-bottom: solid #ff8d96 3px; padding-top: 1.1em;}

.topTable tr:first-child th:first-child{border-radius: 25px 0 0 0;}
.topTable tr:first-child th:last-child{border-radius: 0 25px 0 0;}
.topTable tr:last-child td:first-child{border-radius: 0 0 0 25px;}
.topTable tr:last-child td:last-child{border-radius: 0 0 25px 0;}

.topTable tr:not(:last-child) td::after{
	position: absolute;
	content: "";
	width: 80%;
	height: 2px;
	background-color: #ff8d96;
	left: 10%;
	bottom: 0;
}

.topTable .tr_btn td a{
	display: block;
	background-color: #DCC373;
	color: #fff;
	box-shadow: 0 5px 0 #af9951;
	border-radius: 6px;
	text-decoration: none;
	width: 90%;
	line-height: 3em;
	margin: 0 auto 6px;
	font-size: 1.2rem;
	transition: 0.1s;
	position: relative;
}

.topTable  .tr_btn td:nth-of-type(2) a::before{
	position: absolute;
	content: "＼人気No.1／";
	font-size: 20px;
	line-height: 25px;
	color: #ff3045;
	top: -25px;
	left: 0;
	width: 100%;
	font-weight: bold;
}

.topTable .tr_btn td a:hover{
	box-shadow: 0 2px 0 #af9951;
	transform: translateY(3px);
	transition: 0.1s;
}

.topTable .table_mark{
	font-size: 2rem;
	line-height: 1.2em;
	font-weight: bold;
}

.table_rank::before{
	position: absolute;
	content: "";
	background-size: contain;
	background-repeat: no-repeat;
	width: 35%;
	height: 100px;
	top: -5px;
	right: -5%;
	z-index: 10;
	transform: rotate(5deg);
}

.table_rank_no1::before{background-image: url(../images/table/rank1.png);width: 40%;}
.table_rank_no2::before{background-image: url(../images/table/rank2.png);}
.table_rank_no3::before{background-image: url(../images/table/rank3.png);}

.table_point::before{
	position: absolute;
	content: "";
	background-image: url(../images/table/crown.png);
	background-repeat: no-repeat;
	background-size: contain;
	width: 35%;
	height: 100px;
	top: -20px;
	right: 0;
	z-index: 10;
	transform: rotate(15deg);
}

@media screen and (max-width: 480px){
	.tableH2_ribbon h2{
		font-size: 4vw;
		height: 30px;
		line-height: 30px;
	}

	.tableH2_ribbon h2::before,
	.tableH2_ribbon h2::after{
		border-width: 10px;
	}

	.tableH2_ribbon{
		margin-bottom:1rem;
		height: 50px;
	}

	.tableH2_ribbon::before,
	.tableH2_ribbon::after{
		bottom: -10px;
	}

	.tableH2_ribbon::before{
		border-width: 25px 20px;
		left: -30px;
	}
	
	.tableH2_ribbon::after{
		border-width: 25px 20px;
		right: -30px;
	}

	.topTable th{
		font-size: 3vw;
		padding: 1vw;
	}

	.topTable td:not(.td_title){
		font-size: 3.5vw;
	}

	.topTable .td_title{
		font-size: 3vw;
	}

	.topTable .tr_btn td{
		padding: 4vw 2vw 2vw;
	}

	.topTable .tr_btn td a{
		font-size: 3vw;
		width: 100%;
	}

	.topTable .tr_btn td:nth-of-type(2) a::before{
		font-size: 3vw;
		line-height: 4vw;
		top: -4vw;
	}

	.topTable .tr_img td{
		padding: 1vw;
	}

	.topTable .table_mark{
		font-size: 5vw;
	}

	.topTable tr:first-child th:first-child{border-radius: 4vw 0 0 0;}
	.topTable tr:first-child th:last-child{border-radius: 0 4vw 0 0;}
	.topTable tr:last-child td:first-child{border-radius: 0 0 0 4vw;}
	.topTable tr:last-child td:last-child{border-radius: 0 0 4vw 0;}

	.table_point::before{
		width: 35%;
	}

	.topTable th,.topTable td{
		padding: .5em 0;
	}
}


.summaryH2{
	margin: 7rem 0 0;
	/* background-color: #DE561C; */
	position: relative;
	background: linear-gradient(120deg, #DE561C 50%,#EE662C 50%);
	padding: .5em 0;
	height: auto;
	line-height: 1.2em;
}
.summaryH2::after{
	position: absolute;
	content: "";
	background-image: url(/images/summaryTtl_top.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	height: 5rem;
	width: 100%;
	top: -5.3rem;
	left: 0;
}
/* .summaryH2::before{
	content: " ";
	position: absolute;
	top: 0;
	right: 0;
	width: 50%;
	height: 50px;
	border-radius: 0 10px 10px 0;
	border-bottom: solid 50px #ffffff30;
	border-top: solid 0 transparent;
	border-left: solid 30px transparent;
	border-right: solid 30px #ffffff30;
	box-sizing: border-box;
} */
.summaryArea{
	margin-top: 0;
	border-top-width: 0;
	border-radius: 0 0 10px 10px;
	border-color: #DE561C;
}
.summaryArea a img{
	box-shadow: 0 0 10px #aaa;
	width: 100%;
	transition: .3s;
}
.summaryArea a img:hover{
	opacity: 0.7;
	transition: .3s;
}
.summaryText{
	background: #DCC3731A 0% 0% no-repeat padding-box;
	padding: 1.2em;
	box-shadow: 6px 6px 0px #eee;
	margin: 1rem 0
	;
}
.summaryText p{
	color: #333;
	line-height: 2em;
}
.summaryText p:not(:last-of-type){
	margin-bottom: 1em;
}
.summaryText p .marker{
	background: linear-gradient(#00000000 50%, yellow 50%);
}
@media screen and (max-width: 480px){
	.summaryH2{
		margin-top: 23vw;
	}
	.summaryH2::after{
		height: 15vw;
		top: -16vw;
	}
}


.popup-header span span{
	background: linear-gradient(#00000000 50%, #fe7 50%);
}


/* ------------------トップページ上部コラム----------------- */
.topBlog{
	background-color: #fff;
	margin-bottom: 2rem;
	padding: 1rem;
	color: #555;
	line-height: 2em;
}
.topBlog h4{
	font-size: 1.5em;
	font-weight: bold;
	color: var(--main-color);
	text-shadow: 0 0 5px #eee;
	border-bottom: solid 3px var(--main-color);
	margin: 0 0 .5em;
	padding: .5em;
}
.topBlog p{
	margin-bottom: 1em;
}
.topBlog .red{
	color: #d00;
	font-weight: bold;
	font-size: 1.2em;
}
.topBlog .blue{
	color: #00d;
	font-weight: bold;
}
.topBlog .marker{
	background: linear-gradient(transparent 60%,#fea 60%);
	font-weight: bold;
}
.topBlog .list_container{
	text-align: center;
}
.topBlog ul{
	display: flex;
	flex-wrap: wrap;
	gap: 1em;
	margin: 0 auto 1em;
	border: double 3px var(--main-color);
	border-radius: 5px;
	padding: 1em;
	list-style: none;
	text-align: left;
	width: 50%;
}
.topBlog ul li{
	width: 100%;
	padding-left: .9em;
	text-indent: -.9em;
	line-height: 1.5em;
	font-size: 1.2em;
	font-weight: bold;
}
.topBlog ul li::before{
	font-family: 'Font Awesome 5 Free';
	content: "\f0da";
	color: var(--main-color);
	margin-right: .5em;
}
.topBlog img{
	display: block;
	width: 60%;
	margin:0 auto 1rem;
}
.topBlog h5{
	font-size: 1.5em;
	color: var(--main-color);
	margin-bottom: 1rem;
}
.list_description{
	/* background-color: #faf8ef; */
	background-color: #f6fcff;
	padding: 1rem;
	border-radius: 10px;
	margin-bottom: 1rem;
}
.list_check ul{
	margin-bottom: 8rem;
	position: relative;
}
.list_check ul::before{
	content: "";
	position: absolute;
	width: 45%;
	height: 300px;
	background-image: url(../images/topBlog/img2.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: bottom;
	bottom: -7rem;
	left: -33%;
}
@media screen and (max-width: 480px){
	.topBlog img{
		width: 95%;
	}
	.topBlog ul{
		width: 88%;
		min-width: unset;
		font-size: 3.5vw;
	}
	.topBlog .list_check{
		text-align: right;
	}
	.list_check ul{
		margin-bottom: 27vw;
		width: auto;
	}
	.list_check ul::before{
		width: 37%;
		left: -10%;
		bottom: -27vw;
	}
	.topBlog ul li{
		font-size: 3.5vw;
	}
}


/*------------- 20220405追加分 ------------*/

/* ボタン上部コメント */
.btn_top_comment{
	text-align: center;
	margin: 30px auto -30px;
}

@media (max-width: 480px){
	.btn_top_comment{
		margin: 15px auto -5px;
		font-size: 14px;
	}
}

.marker{
	background: linear-gradient(transparent 50%,#ff5 50%);
	font-weight: bold;
}

.red{
	color: #d00;
	font-weight: bold;
}

/* トップテーブルボタンアニメーション */
.topTable .tr_btn td:nth-child(2) a{
	background: linear-gradient(-60deg,#DCC373 40%,#FCE393 50%,#DCC373 60%,#DCC373 100%);
	background-size: 500% 500%;
	background-position: 500% 50%;
	animation: topTable-btn 2.5s infinite;
}

@keyframes topTable-btn{
	0%,20%,40%,100%{
		transform: translateY(0);
		box-shadow: 0 5px 0 #af9951;
	}
	10%,30%{
		transform: translateY(3px);
		box-shadow: 0 2px 0 #af9951;
	}
	0%,40%{
		background-position: 100% 50%;
	}
	100%{
		background-position: 0 50%;
	}
}

/*------------- 20221020追加分 ------------*/
.topTable .tr_type td{
	font-size: 1.1rem;
	padding: 1.5em 0;
}
.topTable .tr_cospa td:not(.td_title){
	padding: .5em 0;
	vertical-align: top;
}

.topTable caption{
	caption-side: bottom;
	font-size: .7em;
	color: #777;
	text-align: left;
}

@media screen and (max-width : 480px){
	.topTable .tr_type td{
		font-size: 3vw;
	}
}