@charset "utf-8";

#highspeccontact {
	display: block;
	font-family: "ヒラギノ角ゴ Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Noto Sans JP", "メイリオ", Meiryo, "メイリオ", Meiryo, "ＭＳ ゴシック", "MS Gothic", sans-serif;
	margin: 0 auto;
	width: 100%;
	max-width: 755px;
}

#highspeccontact .header_area {
	position: relative;
}

#highspeccontact .header_area img {
	width: 100%;
}

.cp_box *, .cp_box *:before, .cp_box *:after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.cp_box {
	position: relative;
	padding:30px 20px;
	border:solid 2px #334884;
	font-size: min(2.9vw, 16px);
	margin:10px 0;
}
.cp_title {
	color:#334884;
	font-weight:600;
	border-bottom:solid 2px #334884;
	margin-bottom:10px;
	text-align:center;
}
.cp_box label {
	position: absolute;
	z-index: 1;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 86px; 
	cursor: pointer;
	text-align: center;
	background: linear-gradient(to bottom, rgba(250, 252, 252, 0) 0%,rgba(250, 252, 252, 0.95) 40%, rgba(250, 252, 252, 0.95) 90%);
}
.cp_box input:checked + label {
	background: inherit; 
}
.cp_box label:after {
	line-height: 2.8rem;
	position: absolute;
	z-index: 2;
	bottom: 20px;
	left: 50%;
	width: 16rem;
	content:' 続きをよむ';
	transform: translate(-50%, 0);
	letter-spacing: 0.05em;
	color: #334884;
	border-radius: 20px;
	border:solid 2px #334884;
}
.cp_box input {
	display: none;
}
.cp_box .cp_container {
	overflow: hidden;
	height: 200px; 
	transition: all 0.5s;
}
.cp_box .cp_container ul {
	padding:10px 15px 0;
	color:#334884;
}
.cp_box .cp_container ul li a {
	color:#334884;
}
.cp_box input:checked + label {
}
.cp_box input:checked + label:after {
	content:' 閉じる';
}
.cp_box input:checked ~ .cp_container {
	height: auto;
	padding-bottom: 50px; 
	transition: all 0.5s;
}

#highspeccontact .lead_area {
	position: relative;
	width: 100%;
}

#highspeccontact .lead_ttl {
	position: relative;
}

#highspeccontact .lead_ttl img {
	width: 100%;
}

#highspeccontact .lead_area .text01 {
	position: absolute;
	top: 15%;
	left: 10%;
	width: 80%;
}

#highspeccontact .lead_area .text02 {
	position: absolute;
	bottom: 21.7%;
	left: 10%;
	top: auto;
	width: 80%;
}

#highspeccontact .lead_area .text01 li {
	margin: 0 0 2% 0;
	padding: 0 0 0 14%;
	width: 100%;
	background-image: url(/special/highspeccontact/img/sp_head_lead_check.png);
	background-position: left;
	background-size: 6%;
	background-repeat: no-repeat;
	font-size: min(2.9vw, 16px); 
	line-height: 1.8;
	letter-spacing: 1.5px;
}

#highspeccontact .lead_area .text02 li {
	margin: 0 6% 2% 0;
	padding: 0 0 0 10%;
	background-image: url(/special/highspeccontact/img/sp_head_lead_check.png);
	background-position: left top 10%;
	background-size: 6%;
	background-repeat: no-repeat;
	font-size: min(2.9vw, 16px); 
	line-height: 1.4;
	letter-spacing: 1.5px;
}

#highspeccontact .explanation_area {
	position: relative;
	padding: 3%;
	background-color: #E6E3D8;
}

#highspeccontact .explanation_area .inner_box {
	padding: 3%;
	background-color: #FFFFFF;
	border-right: 0 solid #E6E4D8;
	border-bottom: 0 solid #E6E4D8;
	border-left: 0 solid #E6E4D8;
	border-top: 0 solid #E6E4D8;
}

#highspeccontact .explanation_area:before {
	content: "";
	display: block;
	position: absolute;
	top: -8px;
	left: 0;
	width: 100%;
	padding: 5% 0;
	background-image: url(/special/highspeccontact/img/sp_clip.png);
	background-position: center center;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}


#highspeccontact .explanation_ttl img {
	width: 100%;
}

#highspeccontact .explanation_area .row {
	display: block;
	width: 100%;
	margin: 0 0 20px 0;
}

#highspeccontact .explanation_area .row:first-child {
	margin-bottom: 30px;
}

#highspeccontact .explanation_area .row2 {
	display: flex;
	width: 100%;
}

#highspeccontact .explanation_area .col {
	display: block;
}

#highspeccontact .explanation_area .col:first-child {
	padding: 0 20px 0 0;
	width: auto;
}

#highspeccontact .explanation_area .text strong {
	background: linear-gradient(transparent 60%, #ffff66 60%);
}

#highspeccontact .explanation_area .sub_ttl {
	margin: 0 0 10px 0;
	color: #ff7315;
	font-weight: bold;
	font-size: min(3.6vw, 20px);
}

#highspeccontact .explanation_area .text {
	font-size: min(2.9vw, 16px);
	line-height: 1.7;
	letter-spacing: 1px;
}

#highspeccontact .explanation_area .sub_text {
	margin: 8px 0 0 0;
	font-size: min(2.2vw, 12px);
	line-height: 1.7;
	letter-spacing: 1px;
}

#highspeccontact .explanation_area .sub_text_box {
	margin: 10px 0 0 0;
	padding: 15px;
	background-color: #F5F5F5;
	font-size: min(2.2vw, 12px);
}

#highspeccontact .explanation_area .figure_box {
	border: 1px solid #94C367;
	width: auto;
}

#highspeccontact .explanation_area .figure_ttl {
	padding: 5px 0 3px;
	background-color: #94C367;
	color: #FFFFFF;
	font-weight: bold;
	font-size: min(3.3vw, 18px);
	text-align: center;
	letter-spacing: 1px;
}

#highspeccontact .explanation_area figure {
	text-align: center;
}

#highspeccontact .explanation_area figure img {
	margin: 15px 0;
	width: 256px;
}

#highspeccontact .explanation_area figure figcaption {
	padding: 0 15px 10px;
	text-align: left;
}

#highspeccontact .lineup_area {
	margin: 0 0 50px 0;
}

#highspeccontact .lineup_ttl img {
	width: 100%;
}

#highspeccontact .rank_tb {
	overflow-x:scroll;
}

#highspeccontact .rank_tb table {
	width: 580px;
	border-collapse: collapse;
	font-size: min(2.6vw, 14px);
	background-color:#fff;
}

#highspeccontact .rank_tb table th {
	border:1px solid #ccc;
	padding:10px 5px;
}

#highspeccontact .rank_tb table td {
	border:1px solid #ccc;
	padding:10px 5px;
	vertical-align:middle;
	position: relative;
}

#highspeccontact .rank_tb table .name {
	width:160px;
}

#highspeccontact .rank_tb table .img {
	width:90px;
}

#highspeccontact .rank_tb table td img {
	width: 80px;
    vertical-align: bottom;
    display: block;
    margin: 0 auto;
}

#highspeccontact .rank_tb table td a {
	color: #000000;
}

#highspeccontact .rank_tb table .rnk {
	position: absolute;
	top:2px;
	left: 2px;
	border-radius: 50%;
	width: 18px;
	height: 18px;
	font-size: min(1.6vw, 9px);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index:2;
}

#highspeccontact .rank_tb table .rnk.rnk01 {
	background-color: #dbbf00;
}

#highspeccontact .rank_tb table .rnk.rnk02 {
	background-color: #ababab;
}

#highspeccontact .rank_tb table .rnk.rnk03 {
	background-color: #d1871d;
}

#highspeccontact .rank_tb table .rnk.rnk04 {
	background-color: #545454;
}

#highspeccontact .rank_tb table td.center {
	text-align:center;
}

#highspeccontact .rank_tb table .top3_btn {
	margin-bottom:0;
}

#highspeccontact .rank_tb table .top3_btn a {
	font-size: min(2.4vw, 13px);
	text-align:center;
	color:#fff;
}

#highspeccontact .top3_area {
	padding: 8% 3% 3%;
	margin: 0 auto 4%;
}

#highspeccontact .top3_ttl {
	margin: 0 auto 8px;
	font-size: min(5.1vw, 28px);
	letter-spacing: 4px;
	font-weight: bold;
	color: #444444;
	text-align: center;
}

#highspeccontact .top3_ttl_aka {
	margin: 0 auto 24px;
	font-size: min(6.2vw, 34px);
	letter-spacing: 4px;
	font-weight: bold;
	color: #fa5454;
	text-align: center;
	position: relative;
}

#highspeccontact .top3_ttl_aka:before,
#highspeccontact .top3_ttl_aka:after {
	content: '';
	position: absolute;
	top: 42%;
	display: inline-block;
	width: 10%;
	height: 2px;
	background-color: #fa5454;
}

#highspeccontact .top3_ttl_aka:before {
	left: 10%;
}

#highspeccontact .top3_ttl_aka:after {
	right: 10%;
}


#highspeccontact .top3_main a {
	text-decoration: none;
	color: #444444;
}

#highspeccontact.top3_main ul {
	width: 100%;
	margin: 0 auto;
}

#highspeccontact .top3_main li {
	width: 100%;
	background: #FFF;
	text-align: center;
	display: flex;
	margin-bottom: 10px;
}

#highspeccontact .top3_rankttl {
	position: relative;
	padding: 10px 0;
	margin-right: 10px;
	width: 30px;
}

#highspeccontact .top3_rankttl img {
	width: 80%;
}

#highspeccontact .rankstyle01 {
	background-color: #dbbf00;
}

#highspeccontact .day1 {
	background-color: #fa5454;
}

#highspeccontact .week2 {
	background-color: #46c7de;
}

#highspeccontact .rashi {
	background-color: #FCB352;
}

#highspeccontact .enkin {
	background-color: #a4dd53;
}

#highspeccontact .color {
	background-color: #e97dea;
}

#highspeccontact .rankstyle02 {
	background-color: #ababab;
}

#highspeccontact .rankstyle03 {
	background-color: #d1871d;
}

#highspeccontact .top3_main li .top3_p_info > a {
	width: 120px;
	height: 60px;
}

#highspeccontact .top3_main li .top3_p_info > a img {
	width: 120px;
	height: 60px;
	object-fit: contain;
}

#highspeccontact .top3_syouhin {
	font-size: min(3.3vw, 18px);
	font-weight: bold;
	color: #444;
	margin-top: 10px;
	margin-bottom: 10px;
	line-height: 1.6;
	text-align:left;
}

#highspeccontact .top3_info {
	flex: 1;
}

#highspeccontact .top3_p_info {
	display: flex;
	align-items: center;
}

#highspeccontact .top3_lens {
	font-size: min(2.9vw, 16px);
	font-weight: bold;
	color: #444;
	margin: 8px auto;
}

#highspeccontact .top3_spec01 {
	font-size: min(2.6vw, 14px);
	font-weight: bold;
	margin-bottom: 5px;
	color: #444;
	margin-top: 5px;
}

#highspeccontact .top3_spec {
	font-size: min(2.6vw, 14px);
	font-weight: bold;
	margin-bottom: 10px;
	color: #444;
}

#highspeccontact .top3_btn {
	width:100%;
	margin-bottom: 10px;
}

#highspeccontact .top3_btn_yaji {
	font-size: min(1.8vw, 10px);
	vertical-align: middle;
	margin-left: 10px;
}

#highspeccontact .top3_btn a {
	text-decoration: none;
	display: block;
	border-radius: 5px;
	padding: 5% 5%;
	vertical-align: middle;
	position: relative;
	color: #fff;
	width: 80%;
	margin: 0 auto;
	font-size: min(2.6vw, 14px); 
	letter-spacing: 1px;
}

#highspeccontact .top3_btn a:after {
	display: none;
}

#highspeccontact .top3_btn a:hover {
	opacity: 0.7;
}

#highspeccontact .lineup_area .product_box {
	margin: 0 0 20px 0;
	padding: 3%;
	background-position: left top;
	background-repeat: repeat;
	-webkit-background-size: 4px auto;
	background-size: 4px auto;
}

#highspeccontact .lineup_area .inner_box {
	padding: 4%;
	border-width: 4px 0 0 0;
	border-style: solid;
	background-color: #FFFFFF;
	position: relative;
}

#highspeccontact .left_ttl_1day {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0px 10px 5px;
	background: #e34646;
	width: 20%;
	text-align: center;
}

#highspeccontact .left_ttl_2w {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0px 10px 5px;
	background: #3dafc3;
	width: 22%;
	text-align: center;
}

#highspeccontact .left_ttl_tr {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0px 10px 5px;
	background: #E3A246;
	width: 33%;
	text-align: center;
}

#highspeccontact .left_ttl_mf {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0px 10px 5px;
	background: #8dbf46;
	width: 35%;
	text-align: center;
}

#highspeccontact .left_ttl_cl {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0px 10px 5px;
	background: #c33db2;
	width: 35%;
	text-align: center;
}

#highspeccontact .lineup_area .p_name {
	padding: 10% 0 7%;
	font-weight: bold;
	font-size: min(4.6vw, 25px); 
	line-height: 1.5;
	text-align: center;
}

#highspeccontact .lineup_area .p_name .icon {
	width:40px;
	vertical-align:top;
	margin-right:10px;
}

#highspeccontact .lineup_area .p_photo {
	margin: 0 auto 12%;
	text-align: center;
	width: 80%;
	max-width: 480px;
}

#highspeccontact .lineup_area .p_cmt_1day {
	position: relative;
	margin: 0 0 5% 0;
	padding: 9% 5% 5%;
	border: 2px solid #fa5454;
	font-size: min(2.9vw, 16px); 
	line-height: 1.6;
	letter-spacing: 1px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}

#highspeccontact .lineup_area .p_cmt_1day:before {
	content: "";
	display: block;
	position: absolute;
	top: -8%;
	left: -2%;
	width: 50%;
	padding: 5%;
	background-image: url(/special/highspeccontact/img/sp_product_cmt_ttl_red.png);
	background-position: left top;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}

#highspeccontact .lineup_area .p_cmt_1day em {
	color: #ff0000;
	font-style: normal;
}

#highspeccontact .lineup_area .p_cmt_2w {
	position: relative;
	margin: 0 0 5% 0;
	padding: 9% 5% 5%;
	border: 2px solid #46c7de;
	font-size: min(2.9vw, 16px);
	line-height: 1.6;
	letter-spacing: 1px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}

#highspeccontact .lineup_area .p_cmt_2w:before {
	content: "";
	display: block;
	position: absolute;
	top: -8%;
	left: -2%;
	width: 50%;
	padding: 5%;
	background-image: url(/special/highspeccontact/img/sp_product_cmt_ttl_blue.png);
	background-position: left top;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}

#highspeccontact .lineup_area .p_cmt_2w em {
	color: #ff0000;
	font-style: normal;
}

#highspeccontact .lineup_area .p_cmt_tr {
	position: relative;
	margin: 0 0 5% 0;
	padding: 9% 5% 5%;
	border: 2px solid #FCB352;
	font-size: min(2.9vw, 16px);
	line-height: 1.6;
	letter-spacing: 1px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}

#highspeccontact .lineup_area .p_cmt_tr:before {
	content: "";
	display: block;
	position: absolute;
	top: -8%;
	left: -2%;
	width: 50%;
	padding: 5%;
	background-image: url(/special/highspeccontact/img/sp_product_cmt_ttl_yellow.png);
	background-position: left top;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}

#highspeccontact .lineup_area .p_cmt_tr em {
	color: #ff0000;
	font-style: normal;
}

#highspeccontact .lineup_area .p_cmt_mf {
	position: relative;
	margin: 0 0 5% 0;
	padding: 9% 5% 5%;
	border: 2px solid #a4dd53;
	font-size: min(2.9vw, 16px);
	line-height: 1.6;
	letter-spacing: 1px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}

#highspeccontact .lineup_area .p_cmt_mf:before {
	content: "";
	display: block;
	position: absolute;
	top: -8%;
	left: -2%;
	width: 50%;
	padding: 5%;
	background-image: url(/special/highspeccontact/img/sp_product_cmt_ttl.png);
	background-position: left top;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}

#highspeccontact .lineup_area .p_cmt_mf em {
	color: #ff0000;
	font-style: normal;
}

#highspeccontact .lineup_area .p_cmt_cl {
	position: relative;
	margin: 0 0 5% 0;
	padding: 9% 5% 5%;
	border: 2px solid #e97dea;
	font-size: min(2.9vw, 16px);
	line-height: 1.6;
	letter-spacing: 1px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}

#highspeccontact .lineup_area .p_cmt_cl:before {
	content: "";
	display: block;
	position: absolute;
	top: -8%;
	left: -2%;
	width: 50%;
	padding: 5%;
	background-image: url(/special/highspeccontact/img/sp_product_cmt_ttl_violet.png);
	background-position: left top;
	background-repeat: no-repeat;
	-webkit-background-size: contain;
	background-size: contain;
}

#highspeccontact .lineup_area .p_cmt_cl em {
	color: #ff0000;
	font-style: normal;
}

#highspeccontact .lineup_area .p_spec {
	margin: 0 0 10px 0;
	width: 100%;
	border-collapse: separate;
	border-spacing: 2px;
	font-size: min(2.6vw, 14px);
	line-height: 1.4;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#highspeccontact .lineup_area .p_spec .tr {
	margin: 0 1px;
	flex-shrink: 1;
	width: 49%;
}

#highspeccontact .lineup_area .p_spec .tr.long {
	flex-shrink: .8;
}

#highspeccontact .lineup_area .p_spec .th {
	padding: 2% 0;
	background-color: #EFEADC;
	font-weight: normal;
	text-align: center;
}

#highspeccontact .lineup_area .p_spec .td {
	padding: 2%;
	text-align: left;
	margin-bottom: 10%;
}

#highspeccontact .lineup_area .detail_btn a {
	width: 100%;
	margin: 5% auto;
}

#highspeccontact .lineup_area .detail_btn img {
	display: block;
	width: 50%;
	margin: 0 auto;
}

#highspeccontact .lineup_area .detail_btn a:before {
	display: none;
}

#highspeccontact .lineup_area .box_style01 {
	background-image: url(/special/highspeccontact/img/dot_bg01.jpg);
}

#highspeccontact .lineup_area .box_style02 {
	background-image: url(/special/highspeccontact/img/dot_bg02.jpg);
}

#highspeccontact .lineup_area .box_style03 {
	background-image: url(/special/highspeccontact/img/dot_bg03.jpg);
}

#highspeccontact .lineup_area .box_style04 {
	background-image: url(/special/highspeccontact/img/dot_bg04.jpg);
}

#highspeccontact .lineup_area .box_style05 {
	background-image: url(/special/highspeccontact/img/dot_bg05.jpg);
}

#highspeccontact .lineup_area .box_style01 .inner_box {
	border-color: #e34646;
	margin: 6% auto;
}

#highspeccontact .lineup_area .box_style02 .inner_box {
	border-color: #3dafc3;
	margin: 6% auto;
}

#highspeccontact .lineup_area .box_style03 .inner_box {
	border-color: #E3A246;
	margin: 6% auto;
}

#highspeccontact .lineup_area .box_style04 .inner_box {
	border-color: #8dbf46;
	margin: 6% auto;
}

#highspeccontact .lineup_area .box_style05 .inner_box {
	border-color: #c33db2;
	margin: 6% auto;
}

#highspeccontact .lineup_area .box_style01 .p_name {
	color: #e34646;
}

#highspeccontact .lineup_area .box_style02 .p_name {
	color: #3dafc3;
}

#highspeccontact .lineup_area .box_style03 .p_name {
	color: #E3A246;
}

#highspeccontact .lineup_area .box_style04 .p_name {
	color: #8dbf46;
}

#highspeccontact .lineup_area .box_style05 .p_name {
	color: #c33db2;
}

#highspeccontact .other_menu_area {
	margin: 0 auto 5%;
	max-width: 600px;
	padding: 0 1%;
}

#highspeccontact .other_menu_area .other_menu_area_title {
	text-align:center;
	margin-bottom:20px;
	font-size: min(3.3vw, 18px);
	font-weight:600;
	color: #3e5d68;
}

#highspeccontact .other_menu_area .other_menu_ttl {
	margin: 0 auto 3%;
	width: 90%;
	text-align: center;
}

#highspeccontact .other_menu_area .other_menu_ttl img {
	margin: 0 auto 3%;
	width: 100%;
	text-align: center;
}

#highspeccontact .other_menu_area ul {
	display: flex;
	justify-content: space-between;
	border-spacing: 7px;
	flex-wrap:wrap;
}

#highspeccontact .other_menu_area ul li {
	display: block;
	width: calc(100% / 3 - 5px);
}
#highspeccontact .other_menu_area ul li:nth-child(1) {
	width: 49%;
}
#highspeccontact .other_menu_area ul li:nth-child(2) {
	width: 49%;
}

#highspeccontact .other_menu_area ul.col3 {
	display: flex;
	justify-content: space-between;
	border-spacing: 7px
}

#highspeccontact .other_menu_area ul.col3 li {
	display: block;
	width: 100%;
}

#highspeccontact .other_menu_area li span:after {
	display: none;
}

#highspeccontact .bnr_area {
	margin: 0 0 10% 0;
}

#highspeccontact .bnr_area p {
	margin: 0 0 10px 0;
	padding: 0 10px;
	text-align: center;
}

#highspeccontact .btn {
	display: block;
	position: relative;
	width: 100%;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	position: relative;
	z-index: 0;
	width: auto;
	height: auto;
	margin: 0 0 10px 0;
}

#highspeccontact .btn span {
	display: block;
	position: relative;
	top: -3px;
	left: 0;
	width: 100%;
	margin: 0 auto;
	padding: 22px 0;
	color: #ffffff;
	font-weight: bold;
	font-size: min(3.3vw, 18px);
	line-height: 1;
	text-align: center;
	text-decoration: none;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	-webkit-transition: all 0.1s ease;
	-o-transition: all 0.1s ease;
	transition: all 0.1s ease;
}

#highspeccontact .btn:hover span {
	margin: 0 auto 0;
	transform: translate3d(0, 3px, 0);
	-webkit-transform: translate3d(0, 3px, 0);
	-ms-transform: translate3d(0, 3px, 0);
	-o-transform: translate3d(0, 3px, 0);
	transform: translate3d(0, 3px, 0);
}

#highspeccontact .rank-btn {
	display: block;
	position: relative;
	width: 100%;
	padding: 5% 0;
	vertical-align: middle;
	background-color: #334884;
	font-weight: bold;
	letter-spacing: 1px;
	font-size: min(4.6vw, 20px); 
	color: #fff;
	height: auto;
	text-align: center;
	text-decoration: none;
	overflow: hidden;
	line-height: inherit;
}

#highspeccontact .rank-btn:hover {
	text-decoration: none;
	color: #fff;
	opacity: 0.7;
}

#highspeccontact .rank-btn::before {

	position: absolute;
	content: '';
	display: inline-block;
	top: -180px;
	left: 0;
	width: 30px;
	height: 100%;
	background-color: #fff;
	animation: rank-btn 3s ease-in-out infinite;
}

@-webkit-keyframes rank-btn {
	0% {
		-webkit-transform: scale(0) rotate(45deg);
		opacity: 0;
	}

	80% {
		-webkit-transform: scale(0) rotate(45deg);
		opacity: 0.5;
	}

	81% {
		-webkit-transform: scale(4) rotate(45deg);
		opacity: 1;
	}

	100% {
		-webkit-transform: scale(50) rotate(45deg);
		opacity: 0;
	}
}

#highspeccontact .btn_style01_1 {
	background-color: #e34646;
}

#highspeccontact .btn_style01_1 span {
	background-color: #fa5454;
}

#highspeccontact .btn_style01_1:hover span {
	background-color: #f23b3f;
}

#highspeccontact .btn_style01_2 {
	background-color: #3dafc3;
}

#highspeccontact .btn_style01_2 span {
	background-color: #46c7de;
}

#highspeccontact .btn_style01_2:hover span {
	background-color: #42bbd1;
}

#highspeccontact .btn_style01_3 {
	background-color: #E3A246;
}

#highspeccontact .btn_style01_3 span {
	background-color: #FCB352;
}

#highspeccontact .btn_style01_3:hover span {
	background-color: #F2A73B;
}

#highspeccontact .btn_style01_4 {
	background-color: #8dbf46;
}

#highspeccontact .btn_style01_4 span {
	background-color: #a4dd53;
}

#highspeccontact .btn_style01_4:hover span {
	background-color: #97cd4b;
}

#highspeccontact .btn_style01_5 {
	background-color: #c33db2;
}

#highspeccontact .btn_style01_5 span {
	background-color: #e97dea;
}

#highspeccontact .btn_style01_5:hover span {
	background-color: #df4fcd;
}

#highspeccontact .btn_style02 {
	background-color: #6DADB8;
}

#highspeccontact .btn_style02 span {
	background-color: #87CDD9;
	color:#fff;
	font-weight:bold;
}

#highspeccontact .btn_style02:hover span {
	background-color: #66b5c3;
}

#highspeccontact .btn_style_1day {
	background-color: #e34646;
}

#highspeccontact .btn_style_1day span {
	background-color: #fa5454;
}

#highspeccontact .btn_style_1day:hover span {
	background-color: #f23b3f;
}

#highspeccontact .btn_style_2w {
	background-color: #3dafc3;
}

#highspeccontact .btn_style_2w span {
	background-color: #46c7de;
}

#highspeccontact .btn_style_2w:hover span {
	background-color: #42bbd1;
}

#highspeccontact .btn_style_tr {
	background-color: #E3A246;
}

#highspeccontact .btn_style_tr span {
	background-color: #FCB352;
}

#highspeccontact .btn_style_tr:hover span {
	background-color: #F2A73B;
}

#highspeccontact .btn_style_mf {
	background-color: #8dbf46;
}

#highspeccontact .btn_style_mf span {
	background-color: #a4dd53;
}

#highspeccontact .btn_style_mf:hover span {
	background-color: #97cd4b;
}

#highspeccontact .btn_style_cl {
	background-color: #c33db2;
}

#highspeccontact .btn_style_cl span {
	background-color: #e97dea;
}

#highspeccontact .btn_style_cl:hover span {
	background-color: #df4fcd;
}

#highspeccontact .rank_ttl {
	margin: 5% auto 4%;
	text-align: center;
	font-size: min(5.8vw, 32px); 
	font-weight: bold;
	color: #3e5d68;
	letter-spacing: 1px;
}

#highspeccontact .rank_ttl_1day {
	color: #e34646;
}

#highspeccontact .rank_ttl_2w {
	color: #3dafc3;
}

#highspeccontact .rank_ttl_tr {
	color: #E3A246;
}

#highspeccontact .rank_ttl_mf {
	color: #8dbf46;
}

#highspeccontact .rank_ttl_cl {
	color: #c33db2;
}

#highspeccontact .product_box .price_box {
	text-align: center;
	margin: 0 auto 20px auto;
	display: flex;
	justify-content: center;
	align-items: baseline;
	width: 63%;
}

#highspeccontact .product_box .price_box .price_ttl {
	display: inline-block;
	color: #717171;
	font-size: min(3.1vw, 17px);
	margin-right: 16px;
	white-space: nowrap;
}

#highspeccontact .product_box .price_box .price_txt {
	display: inline-block;
	color: #fa5454;
	font-size: min(6.6vw, 36px);
	font-weight: bold;
}

#highspeccontact .box_style01 .btn_box .btn_1day {
	display: block;
	color: #ffffff;
	font-size: min(5vw, 24px);
	font-weight: bold;
	text-align: center;
	background-color: #fa5454;
	width: 80%;
	padding: 5% 5% 4%;
	margin: 8% auto;
	position: relative;
	border-radius: 50px;
	text-decoration: none;
}

#highspeccontact .box_style02 .btn_box .btn_2w {
	display: block;
	color: #ffffff;
	font-size: min(5vw, 24px);
	font-weight: bold;
	text-align: center;
	background-color: #46c7de;
	width: 80%;
	padding: 5% 5% 4%;
	margin: 8% auto;
	position: relative;
	border-radius: 50px;
	text-decoration: none;
}

#highspeccontact .box_style03 .btn_box .btn_tr {
	display: block;
	color: #ffffff;
	font-size: min(5vw, 24px);
	font-weight: bold;
	text-align: center;
	background-color: #fcb352;
	width: 80%;
	padding: 5% 5% 4%;
	margin: 8% auto;
	position: relative;
	border-radius: 50px;
	text-decoration: none;
}

#highspeccontact .box_style04 .btn_box .btn_mf {
	display: block;
	color: #ffffff;
	font-size: min(5vw, 24px);
	font-weight: bold;
	text-align: center;
	background-color: #95ce43;
	width: 80%;
	padding: 5% 5% 4%;
	margin: 8% auto;
	position: relative;
	border-radius: 50px;
	text-decoration: none;
}

#highspeccontact .box_style05 .btn_box .btn_cl {
	display: block;
	color: #ffffff;
	font-size: min(5vw, 24px);
	font-weight: bold;
	text-align: center;
	background-color: #e97dea;
	width: 80%;
	padding: 5% 5% 4%;
	margin: 8% auto;
	position: relative;
	border-radius: 50px;
	text-decoration: none;
}


#highspeccontact .btn_1day:hover {
	opacity: 0.9;
}

#highspeccontact .btn_2w:hover {
	opacity: 0.9;
}

#highspeccontact .btn_tr:hover {
	opacity: 0.9;
}

#highspeccontact .btn_mf:hover {
	opacity: 0.9;
}

#highspeccontact .btn_cl:hover {
	opacity: 0.9;
}

#highspeccontact .btn::before {
	display: none;
}

#highspeccontact .btn::after {
	display: none;
}

#highspeccontact .bnr_area_pagebotm {
	width: 95%;
	margin: 0 auto 5%;
}

#highspeccontact .bnr_area_pagebotm img {
	display: block;
	margin-inline: auto;
	width: 100%;
	max-width: 100%;
}

#highspeccontact .bnr_area_pagebotm_ttl {
	text-align: center;
	font-weight: 700;
}

#highspeccontact .bnr_area_pagebotm_link {
	display: block;
	font-size: min(4.7vw, 1.6rem);
	color: #000;
}

@media screen and (max-width: 959px) {

	#highspeccontact .explanation_ttl {
		margin: 0 0 15px 0;
	}

	#highspeccontact .explanation_area .sub_ttl {
		margin-bottom: 1%;
		font-size: min(4.6vw, 25.2px);
		letter-spacing: 1px;
	}

	#highspeccontact .explanation_area .text {
		font-size: min(4vw, 21.9px);
		line-height: 1.7;
		letter-spacing: 1px;
	}

	#highspeccontact .explanation_area .sub_text {
		font-size: min(4vw, 21.9px);
		letter-spacing: 1px;
		margin: 3% auto 4%;

	}

	#highspeccontact .explanation_area .sub_text_box {
		margin: 3% 0 5% 0;
		padding: 4%;
		line-height: 1.6;
		letter-spacing: 1px;
		font-size: min(3.8vw, 20.8px);
	}

	#highspeccontact .explanation_area .figure_ttl {
		padding: 2% 0 1%;
		font-size: min(5.8vw, 31.8px);
		letter-spacing: 1px;
	}

	#highspeccontact .explanation_area figure {
		border-bottom: 1px solid #94C367;
		border-right: 1px solid #94C367;
		border-left: 1px solid #94C367;
	}

	#highspeccontact .explanation_area figure img {
		margin: 5% auto;
		width: 100%;
	}

	#highspeccontact .explanation_area figure figcaption {
		padding: 0 4% 5%;
		font-size: min(3.6vw, 19.7px);
		letter-spacing: 1px;
	}

	#highspeccontact .lineup_area {
		margin: 0 0 8% 0;
	}

	#highspeccontact .top3_ttl {
		margin: 0 auto 1%;
		font-size: min(4.4vw, 24.1px);
		letter-spacing: 1px;
	}

	#highspeccontact .top3_ttl_aka {
		margin: 0 auto 5%;
		font-size: min(6vw, 32.9px);
		letter-spacing: 1px;
	}

	#highspeccontact .syouhin_img {
		width: 76%;
	}

	#highspeccontact .mhper {
		margin: 0 2.5%;
	}

	#highspeccontact .top3_rankttl {
		position: relative;
		padding: 3% 0;
	}

	#highspeccontact .top3_rankttl img {
		vertical-align: middle;
	}

	#highspeccontact .top3_main li > a {
		width: 100px;
	}

	#highspeccontact .top3_syouhin {
		font-size: min(3.4vw, 18.6px);
	}

	#highspeccontact .top3_lens {
		font-size: min(3.2vw, 17.5px);
		margin: 4% auto;
	}

	#highspeccontact .top3_spec {
		font-size: min(3vw, 16.5px);
	}

	#highspeccontact .top3_btn a {
		font-size: min(2.9vw, 15.9px);
	}

	#highspeccontact .lineup_area .p_name {
		font-size: min(4.6vw, 25.2px);
	}

	#highspeccontact .lineup_area .p_cmt_1day {
		font-size: min(3.8vw, 20.8px);
	}
	#highspeccontact .lineup_area .p_cmt_2w {
		font-size: min(3.8vw, 20.8px);
	}
	#highspeccontact .lineup_area .p_cmt_tr {
		font-size: min(3.8vw, 20.8px);
	}
	#highspeccontact .lineup_area .p_cmt_mf {
		font-size: min(3.8vw, 20.8px);
	}
	#highspeccontact .lineup_area .p_cmt_cl {
		font-size: min(3.8vw, 20.8px);
	}

	#highspeccontact .lineup_area .p_spec .th {
		font-size: min(4.4vw, 24.1px);
	}

	#highspeccontact .lineup_area .p_spec .td {
		font-size: min(4.2vw, 23px);
	}

	#highspeccontact .other_menu_area li span {
		padding: 13px 0;
	}

	#highspeccontact .other_menu_area li a img {
		width: 50%;
		vertical-align: middle;
	}

	#highspeccontact .btn_style_1day img {
		width: 50%;
	}

	#highspeccontact .btn_style_2w img {
		width: 50%;
	}
	
	#highspeccontact .rank-btn {
		font-size: min(4vw, 21.9px);
	}

	#highspeccontact .left_long {
		width: 39%;
	}

#highspeccontact .rank_ttl {
		font-size: min(5.8vw, 31.8px);
	}

	#highspeccontact .rank_tb table .t_name {
		width:160px;
	}

	#highspeccontact .rank_tb table .t_name a {
		display: block;
		overflow: hidden;
		display: -webkit-box;
		text-overflow: ellipsis;
		-webkit-box-orient: vertical;
		width:160px;
		-webkit-line-clamp: 2;
	}

	#highspeccontact .rank_tb table .top3_btn a {
		font-size:min(2.4vw, 13px);
	}

	#highspeccontact .product_box .price_box .price_ttl {
		font-size: min(3.1vw, 17px);
	}

	#highspeccontact .product_box .price_box .price_txt {
		font-size: min(6.6vw, 36px);
	}

	#highspeccontact .box_style01 .btn_box .btn_1day {
		font-size: min(5vw, 24px);
	}

	#highspeccontact .box_style02 .btn_box .btn_2w {
		font-size: min(5vw, 24px);
	}

	#highspeccontact .box_style03 .btn_box .btn_tr {
		font-size: min(5vw, 24px);
	}

	#highspeccontact .box_style04 .btn_box .btn_mf {
		font-size: min(5vw, 24px);
	}

	#highspeccontact .box_style05 .btn_box .btn_cl {
		font-size: min(5vw, 24px);
	}
}

@media screen and (max-width: 959px) {
	#highspeccontact .bnr_area_pagebotm {
		width: 95%;
		margin: 0 auto 5%;
	}

	#highspeccontact .bnr_area_pagebotm img {
		display: block;
		margin-inline: auto;
		width: 100%;
		max-width: 100%;
	}

	#highspeccontact .bnr_area_pagebotm_ttl {
		text-align: center;
		font-weight: 700;
	}

	#highspeccontact .bnr_area_pagebotm_link {
		display: block;
		font-size: min(4.7vw, 1.6rem);
		color: #000;
	}
}