.template {
  margin: 40px 0;
}
.template p {
  margin: 0 0 20px 0;
}
.template p:last-child {
  margin: 0;
}
.template img {
  width: 100%;
}

.template-img-left,
.template-img-right {
  overflow: hidden;
}
.template-img-left .img {
  float: left;
  width: 280px;
}
.template-img-left .text {
  float: right;
  width: calc(100% - 310px);
}
.template-img-right .img {
  float: right;
  width: 280px;
}
.template-img-right .text {
  float: left;
  width: calc(100% - 310px);
}

.template-col2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.template-col3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.template-col4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.template-col .col {
  text-align: center;
}

.template-table table {
  width: 100%;
}
.template-table th {
  padding: 20px;
  text-align: left;
  vertical-align: top;
}
.template-table td {
  padding: 20px;
  text-align: left;
  vertical-align: top;
}

.template-table .table1 th {
  border-bottom: var(--borderColor) 1px solid;
}
.template-table .table1 td {
  border-bottom: var(--borderColor) 1px solid;
}
.template-table .table2 th {
  background: var(--bgColor);
  border: var(--borderColor) 1px solid;
}
.template-table .table2 td {
  border: var(--borderColor) 1px solid;
}
.template-table .table3 th {
  padding: 10px;
  background: var(--bgColor);
  border: var(--borderColor) 1px solid;
}
.template-table .table3 td {
  padding: 10px;
  border: var(--borderColor) 1px solid;
}
.template-table .table4 th {
  border-right: var(--borderColor) 1px dashed;
  border-bottom: var(--borderColor) 1px dashed;
}
.template-table .table4 td {
  border-bottom: var(--borderColor) 1px dashed;
}
.template-table .table5 tr:nth-child(odd) th {
  background: var(--bgColor);
}
.template-table .table5 tr:nth-child(odd) td {
  background: var(--bgColor);
}

.template-img-left-table,
.template-img-right-table,
.template-text-left-table,
.template-text-right-table {
  overflow: hidden;
}
.template-img-left-table .img,
.template-text-left-table .text {
  float: left;
  width: 280px;
}
.template-img-right-table .img,
.template-text-right-table .text {
  float: right;
  width: 280px;
}
.template-img-left-table .table,
.template-text-left-table .table {
  float: right;
  width: calc(100% - 310px);
}
.template-img-right-table .table,
.template-text-right-table .table {
  float: left;
  width: calc(100% - 310px);
}

.template-dl-row dl dt {
  font-weight: bold;
}
.template-dl-row dl dd {
  margin: 0 0 20px 0;
}
.template-dl-row dl dd:last-child {
  margin: 0;
}

.template-dl-col dl {
  display: flex;
  flex-wrap: wrap;
}
.template-dl-col dl dt {
  width: 20%;
  font-weight: bold;
}
.template-dl-col dl dd {
  margin: 0 0 20px 0;
  padding: 0 0 0 20px;
  width: 80%;
}
.template-dl-col dl dd:last-child {
  margin: 0;
}

.template-backpattern1 {
  padding: 30px;
  background-color: var(--bgColor);
  background-image: repeating-linear-gradient(
    -45deg,
    var(--bodyBgColor) var(--bodyBgColor) 7px,
    transparent 0,
    transparent 14px
  );
  border-radius: 10px;
}
.template-backpattern2 {
  padding: 30px;
  border-top: var(--borderColor) 5px solid;
  box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.1);
}

@media screen and (max-width: 599px) {
  .template-img-left .img,
  .template-img-right .img {
    float: none;
    margin: 0 0 20px 0;
    width: 100%;
  }
  .template-img-left .text,
  .template-img-right .text {
    float: none;
    width: 100%;
  }

  .template-col4 {
    grid-template-columns: repeat(2, 1fr);
  }

  .template-img-left-table .img,
  .template-text-left-table .text,
  .template-img-right-table .img,
  .template-text-right-table .text {
    float: none;
    margin: 0 0 20px 0;
    width: 100%;
  }
  .template-img-left-table .table,
  .template-text-left-table .table,
  .template-img-right-table .table,
  .template-text-right-table .table {
    float: none;
    width: 100%;
  }

  .template-dl-row dl dt {
    font-weight: bold;
  }
  .template-dl-row dl dd {
    margin: 0 0 20px 0;
  }
  .template-dl-row dl dd:last-child {
    margin: 0;
  }

  .template-dl-col dl {
    display: flex;
    flex-wrap: wrap;
  }
  .template-dl-col dl dt {
    width: 20%;
    font-weight: bold;
  }
  .template-dl-col dl dd {
    margin: 0 0 20px 0;
    padding: 0 0 0 20px;
    width: 80%;
  }
  .template-dl-col dl dd:last-child {
    margin: 0;
  }

  .template-backpattern1 {
    padding: 30px;
    background-color: var(--bgColor);
    background-image: repeating-linear-gradient(
      -45deg,
      var(--bodyBgColor) var(--bodyBgColor) 7px,
      transparent 0,
      transparent 14px
    );
    border-radius: 10px;
  }
  .template-backpattern2 {
    padding: 30px;
    border-top: var(--borderColor) 5px solid;
    box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.1);
  }
}

/* 管理画面用のスタイル */
.cke_editable .template {
  padding: 20px;
  background: #eee;
}
.cke_editable .template img {
  width: auto;
  max-width: 100%;
}

/* 商品検索窓のカテゴリー選択のスタイル */
.psc > ul {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 2px;
}
.psc > ul > li {
  position: relative;
}
.psc > ul > li > a {
  display: block;
  height: 44px;
  line-height: 44px;
  text-align: center;
  background: var(--bgColor);
  border-radius: 1px;
}
.psc ul.child {
  visibility: hidden;
  opacity: 0;
  position: absolute;
  top: 120%;
  left: 0;
  padding: 15px;
  width: 100%;
  background: var(--bodyBgColor);
  box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.12);
  transition: all 0.2s ease;
  z-index: 1;
}
.psc ul.child.open {
  visibility: visible;
  opacity: 1;
  top: 100%;
}
.psc ul.child > li > a {
  display: block;
}
.psc ul.child > li > a:before {
  content: "\f105";
  margin: 0 5px 0 0;
  font-family: FontAwesome;
}
.psc ul.child > li > ul {
  padding: 5px 5px 5px 20px;
}
.psc ul.child > li > ul > li > a {
  display: block;
  padding: 3px 0;
  font-size: 1.3rem;
}


/* タグの色設定 20250220 Tanaka */
.ec-productRole__tags li.tag_1{
	background: #ffd900;
}
.ec-productRole__tags li.tag_2{
	background: #ff0000;
}
.ec-productRole__tags li.tag_3{
	background: #ffc0cb;
}
.ec-productRole__tags li.tag_4{
	background: #b2cbe4;
}
.ec-productRole__tags li.tag_5{
	background: #008000;
}
.ec-productRole__tags li.tag_6{
	background: #a260bf;
}
.ec-productRole__tags li.tag_7{
	background: #fd7e00;
}

.product-list-status{
	margin-top: 5px;
	min-height: 1.5em;
	ul.ec-productRole__tags{
		margin-bottom: .5em;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		gap: 3px;
		flex-wrap: wrap;
		li{
			margin: 0;
			font-size: 1rem;
			font-weight: 700;
			padding: 3px 4px;
			line-height: 1;
		}
	}
}

.product-list-freearea{
	margin: .5em 0;
}
.products-list-code{
	font-weight: 700;
	span{
		font-weight: 400;
		margin-right: .5em;
	}
}

.ec-productRole__description{
	margin-bottom: 15px;
    font-size: 0.85rem;
    background-color: #f4f4f4;
    padding: 20px;
    border-radius: 10px;
	table{
		border-collapse:collapse;
		border-spacing:0;
		width:100%;
		margin: 0 0 20px 0;
		font-weight:bold;
		P{
			margin: 0;
		}
		.td_syouhinInfo_anyItem_name {
			padding: 10px;
			font-size: 1.4rem;
			background: #ebf2fe;
			border: #ddd 1px solid;
			font-weight:bold;
		}
		.td_syouhinInfo_anyItem {
			padding: 10px;
			font-size: 1.4rem;
			border: #ddd 1px solid;
			background-color: #fff;
			font-weight:bold;
		}
	}
	P{
		margin-bottom: 0;
	}
}
.rank_exp{
	font-weight: 700;
}

.related_products{
	ul{
		li{
			padding: 0;
			list-style-type: none;
		}
	}
	p{
		margin-bottom: 0;
	}
}

.ec-productRole__code{
	margin-bottom: 10px;
    font-size: 14px;
    padding: 0.5em 1em;
    color: #0058cd;
    border: solid 2px #0058cd;
    border-radius: 10px;
    display: inline-block;
}
.product-code-default {
    font-size: 16px;
    font-weight: bold;
}
.ec-productRole__profile .ec-headingTitle{
	margin-bottom: 10px;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.2;
}
.ec-productRole__price01,
.ec-productRole__price02,
.ec-productRole__price03{
	text-align: right;
	margin-bottom: 10px;
	color:#c31f17;
	font-size: 18px;
	.ec-price__price {
		font-size: 33px;
	}
	.ec-price__yen{
		font-size: 20px;
		font-weight: 400;
	}
	.ec-price__tax{
		font-size: 18px;
		font-weight: 700;
	}
}





















