@charset "UTF-8";

// iPad (portrait and landscape)
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) {
    
}
body {
	max-width: 1000px;
	margin: 0 auto;
}
.scroll {
    margin: auto;
    overflow-x: auto;
}
.uline {
    text-decoration: underline!important;
}
.productTableWrap{
    /* overflow-x: auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch; */
}
.productTableWrap.productTableWrap03{
    width: 1000px;
    height: 800px;
}
.productTableWrap.productTableWrap03.productTableWrap03_01,
.productTableWrap.productTableWrap03.productTableWrap03_02,
.productTableWrap.productTableWrap03.productTableWrap03_03,
.productTableWrap.productTableWrap03.productTableWrap03_04{
    width: auto;
}
.productTableWrap.productTableWrap03.productTableWrap03_01 .productTable.productTable03,
.productTableWrap.productTableWrap03.productTableWrap03_02 .productTable.productTable03{
    width: 1250px;
}
.productTableWrap.productTableWrap03.productTableWrap03_03 .productTable.productTable03{
    width: 330px;
}
.productTableWrap.productTableWrap03.productTableWrap03_04 .productTable.productTable03{
    width: 560px;
}

.productTable{
    font-size: small;
    border-collapse:  collapse; 
    /* width: 2200px; */
}
.productTable.productTable01{
    width: 2800px;
}
.productTable.productTable02{
    width: 1000px;
}
.productTable.productTable03{
    width: 4000px;
}
.productTable.productTable03{
    width: 600px;
}
.productTable.productTable04{
    /* width: 4500px; */
}
.productTable th,
.productTable td{
    border: 1px solid #c1c3c9;
    padding: 1em;
    vertical-align: middle;
}
.productTable.productTable01 th,
.productTable.productTable01 td{
    background: #f4f7f8;
}
.productTable.productTable01 .bw th,
.productTable.productTable01 .bw td{
    background: #fff;
}
.productTable.productTable03 th:nth-child(odd),
.productTable.productTable03 td:nth-child(odd),
.sticky_col:nth-child(odd)::before{
    background: #f4f7f8;
}
.productTable th{
    white-space: nowrap;
    text-align: center;
    background: #cee4e5;
}
.productTable.productTable03 th{
    white-space: nowrap;
    text-align: center;
    background: #cee4e5;
    padding-bottom: calc( 1em + 3em);
}
.productTable th .kotei_topLine{
    display: block;
    border-top:1px solid #c1c3c9;
    margin: ;
    position:absolute;
    bottom: 0;
    right: 0;
    width: 100%;
    height: calc( 1em + 2em);
    padding: 1em;
    box-sizing: border-box;
    line-height: 1em;
}
.productTable .db{
    display: block;
    line-height: 1.4;
    margin: 0 0 0.2em;
}
.productTable .btn{
    display: block;
    background: #6b7272;
    color: #fff;
    width: 80%;
    border-radius: 100px;
    padding: 0.3em 2em;
    margin: 0 auto 0;
    text-align: center;
    box-sizing: border-box;
    white-space: nowrap;
}
.productTable .btn:hover{
    background: #535959;
    color: #fff!important;
    text-decoration: none!important;
}
.productTable td .sizeLink{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  margin: 0;
  padding: 0;
}
.productTable td .sizeLink li{
    width: calc(100% / 2 - 0.25em);
    border: 1px solid #ccc;
    box-sizing: border-box;
    margin: 0 0 0.5em ;
}
.productTable td .sizeLink li a{
    display: block;
    padding: 0.3em;
    background: #fff;
}
.productTable td .sizeLink li a:hover{
    background: #ccc;
    text-decoration: none!important;
}
.sticky_row {
  position: sticky;
  top: 0;
  left: 0;
  background: none;
  border-left: none;
  border-right: none;
  font-weight: bold;
}
.sticky_row::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -1px;
  width: 100%;
  height: 100%;
  border-left: 1px solid #c1c3c9;
  border-right: 1px solid #c1c3c9;
  background: #cee4e5;
  z-index: -1;
  font-weight: bold;
  border-top: 1px solid #c1c3c9;
}
.sticky_col {
  position: sticky;
  top: 0;
  left: 0;
  background: none;
  border-top: none;
  border-bottom: none;
}
.sticky_col::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: 100%;
  border-top: 1px solid #c1c3c9;
  border-bottom: 1px solid #c1c3c9;
  background: #ffffff;
  z-index: -1;
}
.sticky_cross {
  position: sticky;
  top: 0;
  left: 0;
  background: none;
  border-top: none;
  border-bottom: none;
  border-left: none;
  border-right: none;
  z-index: 1;
}
.sticky_cross::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -1px;
  width: 100%;
  height: 100%;
  border: 1px solid #c1c3c9;
  background: #cee4e5;
  z-index: -1;
}
.product-area .sponly {
	display: none;
}

.product-area .item {
	padding: 10px;
	border: 1px solid #C1C3C9;
	margin-bottom: 15px;
	/*display: flex;
	justify-content: space-between;
	flex-wrap: wrap;*/
	font-size: 14px;
	position: relative;
}

.product-area .item .photo {
	width: 30%;
	float: left;
	margin-right: 20px;
}

.product-area .item .photo img {
	width: 100%;
	height: auto;
	padding: 0;
}

.product-area .item .text {
	padding: 10px 0;
	overflow: hidden;
}

.product-area .item .item-content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
	height: 0;
	margin-bottom:10px;
	padding:0 10px;
	box-sizing: border-box;
	overflow: hidden;
}
.product-area .item .toggle {
	display: none;
}
.product-area .item .Label {
	cursor: pointer;
}

.product-area .item .item-content {
	width: 100%;
}

.product-area .item .toggle:checked + .photo + .text + .Label + .item-content {	/*開閉時*/
	height: auto;
	transition: all .3s;
}
.product-area .item .toggle:checked + .photo + .text + .Label::before {
	transform: rotate(-45deg) !important;
}

.product-area .item p {
	margin: 0;
}

.product-area .item .title {
	font-size: 20px;
	font-weight: bold;
	color: #000;
	border: 0;
	margin-bottom: 4px;
}

.product-area .item .caption {
	display: inline-block;
	color: #fff;
	font-weight: bold;
	background-color: #F05F5C;
	border-radius: 30px;
	padding: 4px 16px;
	margin-bottom: 4px;
}

.product-area .item .place {
	margin-bottom: 10px;
	display: flex;
}

.product-area .item .place span.bg {
    color: #fff;
    background-color: #4C8CA5;
    padding: 6px 8px;
    display: flex;
    margin-right: 10px;
    width: 4em;
    align-items: center;
}

.product-area .item .place span {
	width: calc(100% - 4em - 26px);
	padding: 6px 0;
}

.product-area .item .more {
	max-width: 320px;
	overflow: hidden;
}

.product-area .item .more a {
	display: block;
	color: #fff;
	background-color: #6B7272;
	padding: 8px;
	border-radius: 30px;
	text-align: center;
	position: relative;
}
.product-area .item .more a:after {
	content: "";
    width: 0;
    height: 0;
    border-left: 5px solid #fff;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}
.product-area .item .Label {
	position: absolute;
	right: 20px;
	top: 60px;
	z-index: 1;
	font-size: 12px;
	text-align: center;
}
.product-area .item .Label .circle {
	width: 50px;
	height: 50px;
	border-radius: 100%;
	border: 1px solid #6B7272;
	position: relative;
	display: block;
}

.product-area .item .Label .circle:before ,
.product-area .item .Label .circle:after {
	content: "";
	width: 24px;
	height: 1px;
	background-color: #6B7272;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
}
.product-area .item .Label .circle:after {
	transform: rotate(90deg);
	transition: .3s;
}
.product-area .item .toggle:checked + .photo + .text + .Label .circle:after {
	transform: rotate(0deg) !important;
}
.product-area .item .item-content .flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 15px;
}
.product-area .item .item-content .flex dl {
	width: 49%;
}
.product-area .item .item-content .flex dl dt {
	float: left;
	color: #4C8CA5;
	width: 8em;
}
.product-area .item .item-content .flex dl dd {
	padding-left: 8em;
	margin-left: 0;
	padding-bottom: .5em;
	margin-bottom: .5em;
	border-bottom: 1px solid #6B7272;
}
.product-area .item .item-content table {
	width: 100%;
	border-top: 1px solid #C9CBD0;
	border-left: 1px solid #C9CBD0;
}
.product-area .item .item-content table th ,
.product-area .item .item-content table td {
	border-right: 1px solid #C9CBD0;
	border-bottom: 1px solid #C9CBD0;
	text-align: center;
	vertical-align: middle;
	padding: 10px;
}
.product-area .item .item-content table th {
	background-color: #F4F7F8;
	font-weight: bold;
}
.product-area .item .item-content table td a.btn {
    display: block;
    color: #fff;
    background-color: #6B7272;
    padding: 8px;
    border-radius: 30px;
    text-align: center;
    position: relative;
}

@media only screen and (max-width:780px){
	.product-area .sponly {
		display: block;
	}
	.product-area .pconly {
		display: none;
	}

	.product-area .item {
		padding: 10px;
		font-size: 12px;
	}

	.product-area .item .photo {
		margin-right: 10px;
	}
	.product-area .item .text {
		padding: 0;
		overflow: inherit;
	}
	.product-area .item .text .title {
		font-size: 14px;
	}
	.product-area .item .text .caption {
		font-size: 12px;
		text-align: center;
	}
	.product-area .item .Label {
		position: relative;
		right: inherit;
		top: inherit;
		z-index: 1;
		font-size: 12px;
		text-align: left;
		display: flex;
		align-items: center;
		justify-content: center;
		margin-top: 15px;
	}
	.product-area .item .Label .circle {
		margin-right: 10px;
	}
	.product-area .item .item-content {
		padding: 0;
		width: calc(100% + 20px);
        margin-left: -10px;
        margin-right: -10px;
	}
	.product-area .item .item-content .flex {
		margin-top: 15px;
		padding: 0 10px;
	}
	.product-area .item .item-content .flex dl {
		width: 100%;
		margin: 0
	}
	.product-area .item .item-content table th, .product-area .item .item-content table td {
		padding: 4px;
	}
	.product-area .item .more {
		width: 100%;
		max-width: 100%;
	}
}