body::-webkit-scrollbar {
	display: none;
}

/* header */
header {
	padding: 55px 60px 23px;
}
header .headBox {
	position: relative;
	padding: 0;
	max-width: 100%;
}
header .headBox h1 {
	margin: 0 auto;
	width: 306px;
}
header .headBox .btnBack {
	position: absolute;
	top: -5px;
	left: 0;
	padding: 0;
}
header .headBox .logo {
	position: absolute;
	bottom: 6px;
	right: 0;
	width: 180px;
}

/* main */
#detailMain {
	padding: 20px 20px 16px;
}

/* 戻るボタン */
.btnBack {
	margin: 0;
	padding: 0 60px;
}
.btnBack a {
	display: block;
	padding: 0 6px 0 0;
	width: 160px;
	height: 40px;
	letter-spacing: 0.05em;
	line-height: 40px;
	font-size: 15px;
	font-weight: bold;
	text-align: center;
	background: #FFFFFF;
	border-radius: 20px;
	box-shadow: 0 4px #E8E7E3;
	transition: all 0.2s;
}
.btnBack a:before {
	content: "";
	position: relative;
	top: 1px;
	display: inline-block;
	margin: 0 14px 0 0;
	width: 8px;
	height: 13px;
	background: url(../img/result/icon_arrow_back.png) no-repeat 50% 50%;
	background-size: contain;
}
.btnBack a:hover {
	box-shadow: 0 0 #E8E7E3;
	transform: translateY(4px);
	transition: all 0.2s;
}

/* footer */
/*
footer {
	position: relative;
	bottom: auto;
	margin: 30px 0 0;
	padding: 0;
	background: none;
	opacity: 1 !important;
	pointer-events: auto !important;
}
footer p {
	float: none;
}
footer > div.lead {
	padding: 0;
	background: #F0F2F8;
}
footer > div.lead p {
	padding: 9px;
	line-height: normal;
	font-family: HiraKakuPro-W3, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック' ,sans-serif;
	font-size: 15px;
	font-weight: bold;
}
footer .footWrap {
	max-width: 100%;
	padding: 0;
	overflow: hidden;
	background-color: #fff;
}
footer .footWrap > img {
	height: 40px;
	width: auto;
	display: block;
	margin: 0 auto;
	text-align: center;
}
*/

/*===================================================
	サイネージ対応
===================================================*/
@media screen and (min-width: 720px) and (max-width: 1080px) and (min-height: 1280px) and (max-height: 1920px) and (orientation: portrait) {
	body {
		display: flex;
		flex-direction: column;
		min-height: 100vh;
		color: #000000;
	}

	/* main */
	#detailMain {
		flex: 1 0 auto;
		padding: 30px 60px 16px;
		font-family: HiraKakuPro-W3, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック' ,sans-serif;
	}
	#detailMain .leftDetail {
		float: none;
		width: auto;
		max-width: 100%;
	}
	#detailMain .leftDetail > div {
		padding: 28px 18px 18px;
		box-shadow: none;
	}
	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 600px;
		border: 2px solid #E1E8EF;
	}
	#detailMain .leftDetail > div:nth-child(2) {
		display: flex;
		justify-content: space-between;
		margin-top: 20px;
		padding: 0;
		background: none;
		border-radius: 0;
	}
	#detailMain .leftDetail > .newArrivals:before,
	#detailMain .leftDetail > .renewArrivals:before {
		top: -9px;
		left: -9px;
		width: 140px;
		height: 140px;
		background: no-repeat 50% 50%;
		background-size: contain;
	}
	#detailMain .leftDetail > .newArrivals:before {
		background-image: url("../img/img_new_band.png");
	}
	#detailMain .leftDetail > .renewArrivals:before {
		background-image: url("../img/img_renew_band.png");
	}

	/* ペット情報 */
	#detailMain .leftDetail .infoLeft {
		margin-bottom: 0;
		width: 360px;
		max-width: 360px;
	}
	#detailMain .leftDetail .infoLeft .photoSelector .selectorLeft,
	#detailMain .leftDetail .infoLeft .photoSelector .selectorRight {
		width: 50px;
		height: 50px;
		background: no-repeat 50% 50%;
		background-size: contain;
	}
	#detailMain .leftDetail .infoLeft .photoSelector .selectorLeft {
		background-image: url(../img/icon_arrow_left.png);
		
	}
	#detailMain .leftDetail .infoLeft .photoSelector .selectorRight {
		background-image: url(../img/icon_arrow_right.png);
	}
	#detailMain .leftDetail .infoLeft p:before,
	#detailMain .leftDetail .infoLeft p:after {
		display: none;
	}
	#detailMain .leftDetail .infoLeft .photoSelector .selector,
	#detailMain .leftDetail .infoLeft .photoSelector .active {
		background-size: 12px auto;
	}
	#detailMain .leftDetail .infoRight {
		margin: 0 0 0 20px;
		width: 540px;
	}
	#detailMain .leftDetail .infoRight dl {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		margin-bottom: 20px;
	}
	#detailMain .leftDetail .infoRight dl dt {
		margin: -3px 0 2px;
		width: 100%;
		font-size: 28px;
		font-weight: bold;
	}
	#detailMain .leftDetail .infoRight dl dd {
		font-size: 15px;
	}
	#detailMain .leftDetail .infoRight dl dd em {
		display: inline-block;
		margin: 0 11px 0 0;
		font-family: 'Roboto', HiraKakuPro-W3, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック' ,sans-serif;
		font-size: 28px;
	}
	#detailMain .leftDetail .infoRight dl dd .txtAttention {
		margin: 4px 0 16px;
		font-size: 15px;
	}
	#detailMain .leftDetail .infoRight dl dd:nth-of-type(1) {
		width: 100%;
	}
	#detailMain .leftDetail .infoRight dl dd:nth-of-type(2) {
		margin: 0 20px 0 0;
		padding: 2px;
		width: 160px;
		color: #FF9C0E;
		text-align: center;
		font-weight: bold;
		border: 2px solid #FF9C0E;
	}
	#detailMain .leftDetail .infoRight dl dd:nth-of-type(2):before {
		content: "";
		position: relative;
		top: 2px;
		display: inline-block;
		margin-right: 5px;
		width: 18px;
		height: 15px;
		background: url(../img/icon_paw.png) no-repeat 50% 50%;
		background-size: contain;
	}
	/* #detailMain .leftDetail .infoRight dl dd:nth-of-type(3) {
		margin: 0 20px 0 10px;
		padding: 2px;
		width: 160px;
		color: #DD6E9F;
		text-align: center;
		font-weight: bold;
		border: 2px solid #DD6E9F;
	}
	#detailMain .leftDetail .infoRight dl dd:nth-of-type(3):before {
		content: "";
		position: relative;
		top: 2px;
		display: inline-block;
		margin-right: 5px;
		width: 15px;
		height: 14px;
		background: url(../img/icon_heart.png) no-repeat 50% 50%;
		background-size: contain;
	} */
	#detailMain .leftDetail .infoRight dl dd:last-child {
		color: #909090;
		background: none;
	}
	#detailMain .leftDetail .infoTable {
		margin-bottom: 7px;
		font-size: 15px;
	}
	#detailMain .leftDetail .infoTable th {
		width: 80px;
		max-width: 80px;
		padding: 6px 5px 6px 10px;
		font-weight: bold;
	}
	#detailMain .leftDetail .infoTable td {
		width: auto;
		padding: 6px 10px;
	}
	#detailMain .leftDetail .infoRight .creatureComment {
		font-size: 15px;
	}
	#detailMain .leftDetail .infoRight ul:empty {
		margin: 0;
	}

	/* ブリーダー詳細 */
	#detailMain .leftDetail .infoShop {
		width: 620px;
		padding: 18px;
		background: #ffffff;
		border: 2px solid #E1E8EF;
		border-radius: 4px;
	}

	#detailMain .leftDetail .infoShop h2 {
		line-height: 40px;
		letter-spacing: 0.1em;
		text-align: center;
		font-weight: bold;
		background: #FCF5F8;
	}

	#detailMain .leftDetail .infoShop h2:before {
		content: "";
		position: relative;
		top: -2px;
		display: inline-block;
		margin: 0 15px 0 0;
		width: 24px;
		height: 24px;
		background: url(../img/detail_icon_store.png) no-repeat 50% 50%;
		background-size: contain;
		vertical-align: middle;
	}
	#detailMain .infoShop .infoTable {
		font-size: 15px;
	}
	#detailMain .infoShop .infoTable th {
		width: 180px;
		padding: 6px 5px 6px 10px;
		font-weight: bold;
	}
	#detailMain .infoShop .infoTable td {
		padding: 6px 10px;
		width: auto;
	}
	#detailMain .shopProfile {
		padding: 17px 20px 10px;
		font-size: 15px;
		border: none;
	}
	#detailMain .shopProfile h3 {
		font-weight: bold;
	}
	#detailMain .shopProfile h3:before {
		top: 0;
		left: -28px;
		width: 19px;
		height: 15px;
		background: url(../img/icon_voice.png) no-repeat 50% 50%;
		background-size: contain;
	}
	#detailMain .shopProfile p {
		min-height: 7.5em;
	}

	/* QRコード */
	#detailMain aside {
		float: none;
		width: 320px;
		max-width: 320px;
		margin-top: 100px;
		padding: 36px 20px 20px;
		background: #EEF5DE;
		border: 2px solid #E1E8EF;
		border-radius: 4px;
	}

	.qrBox > p {
		position: absolute;
		top: -120px;
		left: -15px;
		width: 350px;
	}

	.qrBox .qr {
		margin: 0 auto;
		padding: 21px;
		width: 240px;
		background: #FFFFFF;
	}

	.qrBox dl {
		margin-top: 20px;
	}

	.qrBox dt {
		margin-bottom: 15px;
		font-size: 26px;
		font-weight: bold;
		color: #90C31F;
		text-align: center;
	}

	.qrBox dd {
		font-size: 15px;
	}

	/* gallery */
	#detailMain .gallery {
		margin-top: 20px;
		padding: 18px;
		background: #ffffff;
		border: 2px solid #E1E8EF;
		border-radius: 4px;
	}
	#detailMain .gallery .ttl {
		display: block;
		margin: 0 0 20px;
		padding: 6px 6px 7px;
		letter-spacing: 0.1em;
		font-weight: bold;
		background: #F7F7F7;
	}
	#detailMain .gallery .ttl:before {
		position: relative;
		top:  -2px;
		left: auto;
		display: inline-block;
		margin: 0 19px 0 0;
		width: 34px;
		height: 24px;
		vertical-align: middle;
		background-size: 34px auto;
	}
	#detailMain .gallery .ttl:after {
		position: relative;
		top:  -2px;
		right: auto;
		display: inline-block;
		margin: 0 0 0 19px;
		width: 34px;
		height: 24px;
		vertical-align: middle;
		background-size: 34px auto;
	}
	#detailMain .result > ul .badgeBox,
	.checkCount,
	.infoBox,
	.photoBox div {
		display: none;
	}
	.result {
		height: 215px;
	}
	.result > ul {
		display: flex;
		justify-content: space-between;
		margin: 0;
	}
	.result > ul > li {
		display: block;
		margin: 0;
		width: 215px;
		height: auto;
		box-shadow: none;
	}
	.result > ul > li > a {
		padding: 0;
	}
	.photoBox {
		margin-bottom: 0;
	}
	.photoBox > p {
		margin-bottom: 0;
		height: 215px;
		line-height: 215px;
	}
}

/*===================================================
    720*1280〜1080*1920対応
===================================================*/
@media screen and (min-width: 720px) and (max-width: 1079px) and (min-height: 1280px) and (orientation: portrait) {

	header {
		padding: 30px 20px 15px;
	}
	header .headBox .btnBack {
		top: 0;
	}
	header .headBox .btnBack a {
		padding: 0 6px 0 0;
		width: 110px;
		height: 30px;
		line-height: 30px;
		font-size: 12px;
	}
	.btnBack a:before {
		top: 1px;
		left: 2px;
		margin: 0 10px 0 0;
		width: 6px;
		height: 11px;
		background: url(../img/result/icon_arrow_back.png) no-repeat 50% 50%;
		background-size: contain;
	}
	header .headBox h1 {
		width: 200px;
	}
	header .headBox .logo {
		bottom: 0;
		width: 120px;
	}
	#detailMain {
		padding: 20px 20px 10px;
	}
	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 360px;
		padding: 10px;
	}
	#detailMain .leftDetail .infoLeft {
		width: 30%;
	}
	#detailMain .leftDetail > .newArrivals:before,
	#detailMain .leftDetail > .renewArrivals:before {
		top: -7px;
		left: -7px;
		width: 120px;
		height: 120px;
	}
	#detailMain .leftDetail .infoLeft .photoSelector .selectorLeft,
	#detailMain .leftDetail .infoLeft .photoSelector .selectorRight {
		width: 30px;
		height: 30px;
	}
	#detailMain .leftDetail .infoLeft .photoSelector .selector,
	#detailMain .leftDetail .infoLeft .photoSelector .active {
		background-size: 10px auto;
	}
	#detailMain .leftDetail .infoRight {
		width: 68%;
		margin: 0 0 0 10px;
	}
	#detailMain .leftDetail .infoRight dl {
		margin-bottom: 10px;
	}
	#detailMain .leftDetail .infoRight dl dt {
		font-size: 18px;
	}
	#detailMain .leftDetail .infoRight dl dd em {
		font-size: 18px;
	}
	#detailMain .leftDetail .infoRight dl dd {
		font-size: 11px;
	}
	#detailMain .leftDetail .infoRight dl dd:nth-of-type(2) {
		width: 140px;
		padding: 0;
	}
	#detailMain .leftDetail .infoRight dl dd:nth-of-type(2):before {
		width: 15px;
		height: 11px;
	}
	#detailMain .leftDetail .infoRight dl dd .txtAttention {
		margin: 4px 0 5px;
		font-size: 11px;
	}
	#detailMain .leftDetail .infoTable {
		font-size: 11px;
	}
	#detailMain .leftDetail .infoRight .creatureComment {
		font-size: 11px;
	}

	#detailMain .leftDetail > div:nth-child(2) {
		margin-top: 10px;
	}
	#detailMain .leftDetail .infoShop {
		/*width: 430px;*/
		width: calc(100% - 250px);
		padding: 10px;
	}
	#detailMain .leftDetail .infoShop h2 {
		margin-bottom: 5px;
		padding-left: 40px;
		font-size: 13px;
		line-height: 25px;
	}
	#detailMain .leftDetail .infoShop h2:before {
		top: 0;
		margin: 0 10px 0 0;
		width: 18px;
		height: 18px;
	}
	#detailMain .infoShop .infoTable {
		font-size: 11px;
	}
	#detailMain .infoShop .infoTable th {
		width: 130px;
	}
	#detailMain .shopProfile {
		padding: 5px;
		font-size: 11px;
	}

	#detailMain aside {
		width: 240px;
		margin-top: 90px;
		padding: 25px 10px 10px;
	}
	.qrBox > p {
		top: -90px;
		left: -15px;
		width: 240px;
	}
	.qrBox .qr {
		width: 100%;
		padding: 20px 30px;
	}
	.qrBox dl {
		margin-top: 10px;
	}
	.qrBox dt {
		margin-bottom: 5px;
		font-size: 15px;
	}
	.qrBox dd {
		font-size: 11px;
	}
	#detailMain .gallery {
		margin-top: 10px;
		padding: 10px;
	}
	#detailMain .gallery .ttl {
		margin: 0 0 10px;
		font-size: 15px;
	}
	.result {
		height: 150px;
	}
	.result > ul > li {
		width: 150px;
	}
	.photoBox > p {
		height: 150px;
		line-height: 150px;
	}
	.result > ul > li:hover .photoBox > p:before {
		font-size: 11px;
		line-height: 150px;
	}
	#detailMain + .btnBack {
		padding: 0 20px;
	}
	#detailMain + .btnBack a {
		padding: 0 6px 0 0;
		width: 110px;
		height: 30px;
		line-height: 30px;
		font-size: 12px;
	}
	footer {
		margin: 15px 0 0;
	}
	footer > div.lead p {
		padding: 4px;
		font-size: 12px;
	}
	footer .footWrap > img {
		height: 30px;
	}

}

@media screen and (min-width: 740px) and (max-width: 1079px) and (min-height: 1280px) and (orientation: portrait) {

	header {
		padding: 35px 20px 20px;
	}

	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 380px;
	}

	#detailMain .leftDetail .infoLeft {
		width: 32%;
	}

	#detailMain .leftDetail .infoRight {
		width: 66%;
	}

	#detailMain .leftDetail .infoRight dl dt {
		font-size: 2.5vw;
	}
	#detailMain .leftDetail .infoRight dl dd em {
		font-size: 2.5vw;
	}

	#detailMain .leftDetail .infoRight dl dd {
		font-size: 1.5vw;
	}

	#detailMain .leftDetail .infoRight dl dd .txtAttention {
		font-size: 1.5vw;
	}
	#detailMain .leftDetail .infoTable {
		font-size: 1.5vw;
	}

	#detailMain .infoShop .infoTable th {
		width: 150px;
	}

	#detailMain .leftDetail .infoRight .creatureComment {
		min-height: 80px;
		font-size: 1.5vw;
	}

	#detailMain .leftDetail > div:nth-child(2) {
		margin-top: 20px;
	}

	#detailMain .leftDetail .infoShop h2 {
		font-size: 1.8vw;
	}

	#detailMain .infoShop .infoTable {
		font-size: 1.5vw;
	}

	#detailMain .shopProfile {
		font-size: 1.5vw;
	}

	.qrBox dt {
		font-size: 2.2vw;
	}

	.qrBox dd {
		font-size: 1.5vw;
	}

	#detailMain .shopProfile {
		font-size: 1.5vw;
	}

	#detailMain .gallery {
		margin-top: 20px;
	}

	.result {
		height: 160px;
	}
	.result > ul > li {
		width: 160px;
	}
	.photoBox > p {
		height: 160px;
		line-height: 160px;
	}
	.result > ul > li:hover .photoBox > p:before {
		font-size: 12px;
		line-height: 160px;
	}

}

@media screen and (min-width: 780px) and (max-width: 1079px) and (min-height: 1280px) and (orientation: portrait) {

	header {
		padding: 50px 20px 23px;
	}

	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 400px;
	}

	.result {
		height: 170px;
	}

	.result > ul > li {
		width: 170px;
	}

	.photoBox > p {
		height: 170px;
		line-height: 170px;
	}
	.result > ul > li:hover .photoBox > p:before {
		line-height: 170px;
	}

}

@media screen and (min-width: 800px) and (max-width: 1079px) and (min-height: 1280px) and (orientation: portrait) {

	.btnBack a:before {
		left: -2px;
	}

	header .headBox .btnBack {
		top: -5px;
	}

	header .headBox .btnBack a,
	#detailMain + .btnBack a {
	    width: 130px;
	    height: 40px;
	    line-height: 40px;
	    font-size: 13px;
	}

	header .headBox h1 {
		width: 250px;
	}

	header .headBox .logo {
		width: 140px;
	}

	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 400px;
	}

}

@media screen and (min-width: 830px) and (max-width: 1079px) and (min-height: 1280px) and (orientation: portrait) {

	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 440px;
	}

	#detailMain .leftDetail .infoShop {
		width: calc(100% - 290px);
	}

	#detailMain aside {
		width: 280px;
	}

	.qrBox > p {
		left: 20px;
	}

	.qrBox .qr {
		width: 90%;
		padding-left: 20px;
	}

	.result {
		height: 180px;
	}

	.result > ul > li {
		width: 180px;
	}

	.photoBox > p {
		height: 180px;
		line-height: 180px;
	}
	.result > ul > li:hover .photoBox > p:before {
		line-height: 180px;
	}

}

@media screen and (min-width: 860px) and (max-width: 1079px) and (min-height: 1280px) and (orientation: portrait) {


	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 460px;
	}

	#detailMain .infoShop .infoTable th {
		width: 170px;
	}

	.result {
		height: 190px;
	}

	.result > ul > li {
		width: 190px;
	}

	.photoBox > p {
		height: 190px;
		line-height: 190px;
	}
	.result > ul > li:hover .photoBox > p:before {
		line-height: 190px;
	}

	footer > div.lead p {
		padding: 6px;
		font-size: 14px;
	}

}

@media screen and (min-width: 890px) and (max-width: 1079px) and (min-height: 1280px) {

	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 500px;
	}

}

@media screen and (min-width: 920px) and (max-width: 1079px) and (min-height: 1280px) {

	header .headBox h1 {
		width: 300px;
	}

	header .headBox .logo {
		width: 180px;
	}

	#detailMain .leftDetail > div:nth-child(1) {
		min-height: 530px;
	}

	#detailMain .leftDetail .infoRight .creatureComment {
		font-size: 15px;
	}

	#detailMain .shopProfile p {
		font-size: 15px;
	}

	.qrBox dt {
		margin: 15px 0;
		font-size: 20px;
	}

	#detailMain .gallery {
		padding-left: 20px;
	}

	.result {
		height: 200px;
	}

	.result > ul > li {
		width: 200px;
	}

	.photoBox > p {
		height: 200px;
		line-height: 200px;
	}
	.result > ul > li:hover .photoBox > p:before {
		line-height: 200px;
	}

	footer .footWrap > img {
		height: 40px;
	}

}

@media screen and (min-width: 950px) and (max-width: 1079px) and (min-height: 1280px) {

	#detailMain .leftDetail > div:nth-child(1) {
		padding: 20px 18px 10px;
	}

	#detailMain .leftDetail .infoShop {
		padding: 18px;
	}

}

@media screen and (min-width: 980px) and (max-width: 1079px) and (min-height: 1280px) {

	#detailMain .detailWrap {
		max-width: 100%;
	}

	#detailMain .leftDetail .infoRight dl dd:nth-of-type(2) {
		font-size: 14px;
	}

	#detailMain .infoShop .infoTable th {
		width: 180px;
	}

	#detailMain .gallery .ttl {
		margin: 0 0 20px;
	}

	.result {
		height: 210px;
	}

	.result > ul > li {
		width: 210px;
	}

	.photoBox > p {
		height: 210px;
		line-height: 210px;
	}
	.result > ul > li:hover .photoBox > p:before {
		line-height: 210px;
	}

}

@media screen and (min-width: 1020px) and (max-width: 1079px) and (min-height: 1280px) {

	.result {
		height: 220px;
	}

	.result > ul > li {
		width: 220px;
	}

	.photoBox > p {
		height: 220px;
		line-height: 220px;
	}
	.result > ul > li:hover .photoBox > p:before {
		line-height: 220px;
	}

}
/*===================================================
	SMT対応
===================================================*/
@media only screen and (min-width: 0px) and (max-width: 600px) {
	/* header */
	header {
		padding: 10px;
	}
	header .headBox h1 {
		width: 200px;
	}
	header .headBox .btnBack {
		display: none;
	}
	header .headBox .logo {
		position: relative;
		bottom: auto;
		right: auto;
		margin: 5px 0 0 auto;
		width: 100px;
	}

	#detailMain {
		padding: 20px 10px 16px;
	}

	/* 戻るボタン */
	.btnBack {
		padding: 0 10px;
	}

	/* footer */
	footer {
		margin: 26px 0 0;
	}
	footer > div.lead p {
		padding: 10px;
		font-size: 10px;
	}
}