.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;
}
/* ======================================
ブログ表示
======================================== */
/*====================PC=====================*/
/*（PC版）ブログ表示改善したい際下記設定を適用*/
.newblog .item {
 	display: block;
}
.newblog .image {
 	width: 370px;
	overflow: hidden;
	background: #fff;
}
.newblog .image img {
 	width: 370px;
	height: 280px;
	object-fit: cover;
	display: block;
	transition-duration: 0.2s;
	object-position: 100% 0%;
}
.newblog .image img:hover {
 	transform: scale(1.3);
	transition-duration: 0.2s;
}
.newblog .text {
 	padding: 0 10px 0 10px;
 	width: calc(100%);
}
/*ここまで*/
/*====================SP=====================*/
/*スマホ表示時の微調整用*/
@media screen and ( max-width:400px ){
	.rich-w100-inner {
		margin: 1em auto 1em;
		width: 360px;
	}
	.rich-qa {
		margin: 0;
	}
	.rich-qa dt, .rich-qa dd {
		padding: 1em 0em 1em 3.3em;
	}
	.rich-column3 ul, .rich-column3b ul {
		grid-template-columns: repeat(1, 1fr);
	}
	.rich-column2 ul, .rich-column2b ul {
		grid-template-columns: repeat(1, 1fr);
	}
	.rich-column3 li, .rich-column3b li, .rich-column2 li, .rich-column2b li {
		margin-bottom: 5rem;
	}
	.deco04:before {
		content: attr(data-en);
		position: absolute;
		top: 3rem;
		left: 50%;
		transform: translateX(-50%);
		color: #f3ecdf;
		font-size: 3rem;
		font-style: normal;
		letter-spacing: 0.15em
	}
		/*（SP版）ブログ表示改善したい際下記設定を適用*/
	.newblog-main ul {
		display: block;
	}
	.newblog .item {
		display: flex;
		max-width: 370px;
		align-items: center;
		margin: 0 0 20px 0;
		padding: 0 0 10px 0;
		border-bottom: 1px solid #c1c1c1;
	}
	.newblog .image {
  		width: 100px;
	}
	.newblog .image img {
 		width: 100px;
		height: 100px;
		object-fit: cover;
	}
	.newblog .text {
		padding: 0 0 0 20px;
		width: calc(100% - 100px);
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
		color: #707070;
	}
	/*ここまで*/

}
