/* カスタマイズ用CSS */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&family=Noto+Serif+Display:ital,wght@0,100..900;1,100..900&display=swap');

html {
    overflow-y: scroll;
    font-size: 62.5%;
}

/*** タブレット 768x ~ 1300px***/
@media screen and (min-width: 768px) and (max-width: 1200px) {
    html {
        font-size: 0.833vw;
    }
}

/*** スマホ 320px ~ 767px***/
@media screen and (max-width: 767px) {
    html {
        font-size: 62.5%;
    }
}

a,
button {
	color: #333;
}

*,
*:before,
*:after {
	box-sizing: border-box;
}

@media screen and (min-width: 960px) {
   /* a[href^="tel:"] {
        cursor: default;
        pointer-events:none;
    }*/

    .has-hover {
    	transition: opacity .7s;
    }

    .has-hover:hover {
    	opacity: .7;
    	transition: opacity .7s;
    }
}

@media screen and (min-width: 768px) {
  .is-pc {
      display: block;
  }

  .is-sp {
      display: none!important;
  }
}

/*** スマホ 320px ~ 767px***/
@media screen and (max-width: 767px) {
    .is-pc {
        display: none!important;
    }

    .is-sp {
        display: block!important;
    }

}

body {
    font-family: "Noto Serif JP", serif;
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: 400;
    color: #333;
    -webkit-text-size-adjust: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.ec-role {
    padding: 0 5rem;
    font-size: 1.6rem;
    line-height: 1.5;
    color: #333;
    max-width: 110rem;
}

.ec-blockTopBtn {
	display: none !important;
}

@media screen and (max-width: 767px) {
	.ec-role {
	    padding: 0 2.5rem;
	}
}

.ec-input input, .ec-birth input, .ec-select input, .ec-telInput input, .ec-zipInput input, .ec-numberInput input, .ec-halfInput input {
  font-size: 1.6rem;
}
.ec-input select, .ec-birth select, .ec-select select, .ec-telInput select, .ec-zipInput select, .ec-numberInput select, .ec-halfInput select {
  font-size: 1.6rem;
}
.ec-input textarea, .ec-birth textarea, .ec-select textarea, .ec-telInput textarea, .ec-zipInput textarea, .ec-numberInput textarea, .ec-halfInput textarea {
  font-size: 1.6rem;
}

input#coupon_use_coupon_cd {
  height: 40px;
  margin-bottom: 0.8rem;
  font-size: 1.4rem;
}

.ec-checkbox input[type=checkbox] {
  width: 1.5rem;
  height: 1.5rem;
  background: url(../img/common/icon_checkbox_no.svg) center center no-repeat;
  background-size: 100% 100%;
  appearance: none;
  margin: 0;
  border-radius: 0;
  margin-right: .9rem;
}

.ec-checkbox .narrowDown-check input[type=radio] {
  width: 1.5rem;
  height: 1.5rem;
  background: url(../img/common/icon_radio_no.svg) center center no-repeat;
  background-size: 100% 100%;
  appearance: none;
  margin: 0;
  border-radius: 0;
  margin-right: .9rem;
}

.ec-checkbox input[type=checkbox]:checked {
  background-image: url(../img/common/icon_checkbox_on.svg);
}

.ec-checkbox .narrowDown-check input[type=radio]:checked{
  background-image: url(../img/common/icon_radio_on.svg);
}

@media screen and (max-width: 767px) {
  .ec-checkbox input[type=checkbox] {
    margin-right: .75rem;
  }
}

/***  Button ***/
.ec-inlineBtn {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #00744B;
  background-color: #F5F7F8;
  border-color: #ccc;
  border-radius: .5rem;
}
.ec-inlineBtn:focus, .ec-inlineBtn.focus, .ec-inlineBtn:active:focus, .ec-inlineBtn:active.focus, .ec-inlineBtn.active:focus, .ec-inlineBtn.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-inlineBtn:hover, .ec-inlineBtn:focus, .ec-inlineBtn.focus {
  color: #00744B;
}
.ec-inlineBtn:hover {
  color: #fff;
  background-color: #F5F7F8;
  border-color: #F5F7F8;
}
.btn-check:focus + .ec-inlineBtn, .ec-inlineBtn:focus {
  color: #fff;
  background-color: #F5F7F8;
  border-color: #F5F7F8;
}
.btn-check:checked + .ec-inlineBtn, .btn-check:active + .ec-inlineBtn, .ec-inlineBtn:active, .ec-inlineBtn.active, .show > .ec-inlineBtn.dropdown-toggle {
  color: #fff;
  background-color: #F5F7F8;
  border-color: #F5F7F8;
}
.ec-inlineBtn:disabled, .ec-inlineBtn.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}
.ec-inlineBtn--primary {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
  border-radius: .5rem;
}
.ec-inlineBtn--primary:focus, .ec-inlineBtn--primary.focus, .ec-inlineBtn--primary:active:focus, .ec-inlineBtn--primary:active.focus, .ec-inlineBtn--primary.active:focus, .ec-inlineBtn--primary.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-inlineBtn--primary:hover, .ec-inlineBtn--primary:focus, .ec-inlineBtn--primary.focus {
  color: #00744B;
}
.ec-inlineBtn--primary:hover {
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
}
.btn-check:focus + .ec-inlineBtn--primary, .ec-inlineBtn--primary:focus {
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
}
.btn-check:checked + .ec-inlineBtn--primary, .btn-check:active + .ec-inlineBtn--primary, .ec-inlineBtn--primary:active, .ec-inlineBtn--primary.active, .show > .ec-inlineBtn--primary.dropdown-toggle {
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
}
.ec-inlineBtn--primary:disabled, .ec-inlineBtn--primary.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}
.ec-inlineBtn--action {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
  border-radius: .5rem;
}
.ec-inlineBtn--action:focus, .ec-inlineBtn--action.focus, .ec-inlineBtn--action:active:focus, .ec-inlineBtn--action:active.focus, .ec-inlineBtn--action.active:focus, .ec-inlineBtn--action.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-inlineBtn--action:hover, .ec-inlineBtn--action:focus, .ec-inlineBtn--action.focus {
  color: #00744B;
}
.ec-inlineBtn--action:hover {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.btn-check:focus + .ec-inlineBtn--action, .ec-inlineBtn--action:focus {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.btn-check:checked + .ec-inlineBtn--action, .btn-check:active + .ec-inlineBtn--action, .ec-inlineBtn--action:active, .ec-inlineBtn--action.active, .show > .ec-inlineBtn--action.dropdown-toggle {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.ec-inlineBtn--action:disabled, .ec-inlineBtn--action.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}
.ec-inlineBtn--cancel {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
  border-radius: .5rem;
}
.ec-inlineBtn--cancel:focus, .ec-inlineBtn--cancel.focus, .ec-inlineBtn--cancel:active:focus, .ec-inlineBtn--cancel:active.focus, .ec-inlineBtn--cancel.active:focus, .ec-inlineBtn--cancel.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-inlineBtn--cancel:hover, .ec-inlineBtn--cancel:focus, .ec-inlineBtn--cancel.focus {
  color: #00744B;
}
.ec-inlineBtn--cancel:hover {
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
}
.btn-check:focus + .ec-inlineBtn--cancel, .ec-inlineBtn--cancel:focus {
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
}
.btn-check:checked + .ec-inlineBtn--cancel, .btn-check:active + .ec-inlineBtn--cancel, .ec-inlineBtn--cancel:active, .ec-inlineBtn--cancel.active, .show > .ec-inlineBtn--cancel.dropdown-toggle {
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
}
.ec-inlineBtn--cancel:disabled, .ec-inlineBtn--cancel.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}

.ec-blockBtn {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
  height: 6rem;
  line-height: 4rem;
  border-radius: .5rem;
}
.ec-blockBtn:focus, .ec-blockBtn.focus, .ec-blockBtn:active:focus, .ec-blockBtn:active.focus, .ec-blockBtn.active:focus, .ec-blockBtn.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-blockBtn:hover, .ec-blockBtn:focus, .ec-blockBtn.focus {
  color: #fff;
}
.ec-blockBtn:hover {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.btn-check:focus + .ec-blockBtn, .ec-blockBtn:focus {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.btn-check:checked + .ec-blockBtn, .btn-check:active + .ec-blockBtn, .ec-blockBtn:active, .ec-blockBtn.active, .show > .ec-blockBtn.dropdown-toggle {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.ec-blockBtn:disabled, .ec-blockBtn.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}
.ec-blockBtn--primary {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
  height: 6rem;
  line-height: 4rem;
  border-radius: .5rem;
}
.ec-blockBtn--primary:focus, .ec-blockBtn--primary.focus, .ec-blockBtn--primary:active:focus, .ec-blockBtn--primary:active.focus, .ec-blockBtn--primary.active:focus, .ec-blockBtn--primary.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-blockBtn--primary:hover {
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
}
.btn-check:focus + .ec-blockBtn--primary, .ec-blockBtn--primary:focus {
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
}
.btn-check:checked + .ec-blockBtn--primary, .btn-check:active + .ec-blockBtn--primary, .ec-blockBtn--primary:active, .ec-blockBtn--primary.active, .show > .ec-blockBtn--primary.dropdown-toggle {
  color: #fff;
  background-color: #5CB1B1;
  border-color: #5CB1B1;
}
.ec-blockBtn--primary:disabled, .ec-blockBtn--primary.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}
.ec-blockBtn--action {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
  height: 6rem;
  line-height: 4rem;
  border-radius: .5rem;
}
.ec-blockBtn--action:focus, .ec-blockBtn--action.focus, .ec-blockBtn--action:active:focus, .ec-blockBtn--action:active.focus, .ec-blockBtn--action.active:focus, .ec-blockBtn--action.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-blockBtn--action:hover, .ec-blockBtn--action:focus, .ec-blockBtn--action.focus {
  color: #00744B;
}
.ec-blockBtn--action:hover {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.btn-check:focus + .ec-blockBtn--action, .ec-blockBtn--action:focus {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.btn-check:checked + .ec-blockBtn--action, .btn-check:active + .ec-blockBtn--action, .ec-blockBtn--action:active, .ec-blockBtn--action.active, .show > .ec-blockBtn--action.dropdown-toggle {
  color: #fff;
  background-color: #F07675;
  border-color: #F07675;
}
.ec-blockBtn--action:disabled, .ec-blockBtn--action.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}
.ec-blockBtn--cancel {
  border: .1rem solid transparent;
  font-size: 1.5rem;
  padding: 1rem 1.6rem;
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
  height: 6rem;
  line-height: 4rem;
  border-radius: .5rem;
}
.ec-blockBtn--cancel:focus, .ec-blockBtn--cancel.focus, .ec-blockBtn--cancel:active:focus, .ec-blockBtn--cancel:active.focus, .ec-blockBtn--cancel.active:focus, .ec-blockBtn--cancel.active.focus {
  outline: 0;
  outline-offset: 0;
}
.ec-blockBtn--cancel:hover, .ec-blockBtn--cancel:focus, .ec-blockBtn--cancel.focus {
  color: #00744B;
}
.ec-blockBtn--cancel:hover {
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
}
.btn-check:focus + .ec-blockBtn--cancel, .ec-blockBtn--cancel:focus {
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
}
.btn-check:checked + .ec-blockBtn--cancel, .btn-check:active + .ec-blockBtn--cancel, .ec-blockBtn--cancel:active, .ec-blockBtn--cancel.active, .show > .ec-blockBtn--cancel.dropdown-toggle {
  color: #fff;
  background-color: #00744B;
  border-color: #00744B;
}
.ec-blockBtn--cancel:disabled, .ec-blockBtn--cancel.disabled {
  color: #fff;
  background-color: #ddd;
  border-color: #ddd;
}

.ec-blockBtn--action.disabled, .ec-blockBtn--action[disabled], fieldset[disabled] .ec-blockBtn--action {
    filter: alpha(opacity = 100);
    opacity: 1;
}

/*Header*/

.ec-headerNaviRole {
	padding: 2.5rem 5.5rem 2.5rem 12rem;
    font-size: 1.6rem;
    line-height: 1.5;
    color: #333;
    width: 100%;
    max-width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.ec-headerNaviRole:after {
	display: none;
}

.ec-headerNaviRole .ec-headerNaviRole__left {
	width: auto;
}

.ec-headerRole {
	padding: 0;
    font-size: 1.6rem;
    line-height: 1.5;
    color: #333;
    width: auto;
    max-width: 100%;
}

.ec-headerRole h1 {
	margin: 0;
}

.ec-headerRole h1 a {
	display: block;
	line-height: 1;
	position: relative;
}

.ec-headerNaviRole .ec-headerNaviRole__right {
	width: auto;
  position: fixed;
  right: 5.5rem;
  top: 2.5rem;
  z-index: 10000;
}

.ec-headerNaviRole .ec-headerSearch {
	width: 30rem;
}

.ec-headerSearch .ec-headerSearch__keyword {
    color: #333;
    border: .1rem solid #F0F0F0;
    background: rgba(255, 255, 255, .5);
    border-radius: .5rem;
}

.ec-headerSearch .ec-headerSearch__keyword input[type=search] {
  height: 4rem;
  font-size: 1rem;
  padding: 0 5rem 0 2rem;
  font-weight: 700;
  appearance: none;
border-radius: 0;
}

.ec-headerSearch .ec-headerSearch__keyword input[type=search]::-webkit-input-placeholder { 
	color: #00744B; 
} 
.ec-headerSearch .ec-headerSearch__keyword input[type=search]:-moz-placeholder { 
	color: #00744B; 
} 
.ec-headerSearch .ec-headerSearch__keyword input[type=search]::-moz-placeholder { 
	color: #00744B; 
} 
.ec-headerSearch .ec-headerSearch__keyword input[type=search]:-ms-input-placeholder { 
	color: #00744B; 
}

.ec-headerSearch .ec-headerSearch__keywordBtn {
    right: 1.5rem;
    transform: translateY(-50%);
    margin: 0;
    padding: 0;
}

.ec-headerSearch .ec-headerSearch__keyword .ec-icon {
    width: 3rem;
    height: 3rem;
}

.ec-headerNaviRole .ec-headerNaviRole__nav {
	display: block;
  margin: 0;
}

.ec-headerNaviRole .ec-headerNaviRole__nav .ec-headerNav {
  display: flex;
  align-items: center;
}

.ec-headerNav .ec-headerNav__item {
	display: block;
	font-size: 0;
  margin-right: 1rem;
}

.ec-headerNav .ec-headerNav__itemLink {
    margin-right: 0;
    font-size: 0;
    width: 4rem;
    height: 4rem;
    border-radius: .5rem;
    background-position: center center;
    background-repeat: no-repeat;
    background-color: #00744B;
    background-size: 2rem auto;
    box-shadow: 0 1rem 1rem rgba(51, 51, 51, .1);
}

.ec-headerNav .ec-headerNav__itemLink.is-login {
    background-image: url(../img/common/icon_login_wh.svg);
}

.ec-headerNav .ec-headerNav__itemLink.is-mypage {
    background-image: url(../img/common/icon_user.svg);
}

.ec-cartNavi .ec-cartNavi__badge {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    border-radius: 0;
    padding: 0 0 .1rem;
    width: 2.1rem;
    height: 2.3rem;
    font-size: 1rem;
    line-height: 1.5;
    color: #fff;
    text-align: center;
    background: url(../img/common/icon_cart_badge.svg) center center no-repeat;
    background-size: cover;
    position: relative;
    left: 0;
    top: 0;
    font-weight: 900;
    margin-right: .5rem;
}

.ec-cartNaviNull::before {
  right: 3rem;
}

.ec-cartNaviNull .ec-cartNaviNull__message {
  font-size: 12px;
  background: #F07675;
}

.ec-headerNavSP {
    border-radius: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: 2.5rem;
    height: 4rem;
    font-size: 0;
    background: none;
    position: relative;
    top: 0;
    left: 0;
    padding: 0;
}

.ec-headerNavSP .line {
	display: block;
	width: 100%;
	height: .2rem;
	background: #00744B;
	border-radius: .1rem;
  transition: all 1s;
}

.ec-headerNavSP .line + .line {
	margin-top: .6rem;
}

.ec-layoutRole.is_active .ec-headerNavSP .line:nth-child(1){
  transform: translateY(.8rem) rotate(30deg);
  transition: all 1s;
}

.ec-layoutRole.is_active .ec-headerNavSP .line:nth-child(2){
  opacity: 0;
  transition: all 1s;
}

.ec-layoutRole.is_active .ec-headerNavSP .line:nth-child(3){
  transform: translateY(-.8rem) rotate(-30deg);
  transition: all 1s;
}

@media screen and (min-width: 768px) {
    .ec-headerNaviRole .ec-headerNaviRole__search {
		margin-top: 0;
		margin-right: 1rem;
	}

	.ec-headerSearch .ec-headerSearch__category {
		display: none;
	}

	.ec-headerSearch .ec-headerSearch__keyword {
	    float: none;
	    width: 100%;
	    border-radius: .5rem;
	}

	.ec-headerSearch .ec-headerSearch__keyword input[type=search] {
	    font-size: 1rem;
	}

	.ec-headerNav .ec-headerNav__itemLink {
	    display: block;
	}

	.ec-headerRole__cart {
		margin-right: 1rem;
	}

  .ec-cartNaviIsset {
      max-height: 80vh;
      overflow: scroll;
  }

	.ec-cartNavi {
	    border-radius: .5rem;
	    padding: 0 1rem;
	    width: auto;
	    min-width: 8rem;
	    height: 4rem;
	    background: #00744B;
	    align-items: center;
	    justify-content: center;
	}

	.ec-cartNavi .ec-cartNavi__price {
	    display: block;
	    font-size: 1.3rem;
	    font-weight: 700;
	    color: #fff;
	    border-bottom: .1rem solid #fff;
	}

	.ec-headerNavSP {
	    display: flex;
	}

	.ec-headerRole__searchSP {
		display: none;
	}

	.ec-headerMenuSp {
		display: none;
	}
}

@media screen and (max-width: 767px) {
	.ec-headerNaviRole {
		padding: 2rem 1.5rem;
    height: 7.25rem;
	}

	.ec-headerRole h1 {
		width: 13rem;
	}

  .ec-headerNaviRole .ec-headerNaviRole__right {
    right: 1.5rem;
    top: 2rem;
  }

	.ec-headerNaviRole .ec-headerNaviRole__nav {
		display: none;
	}

	.ec-headerRole__cart {
		display: none;
	}

	.ec-cartNavi {
		display: flex;
	    border-radius: .5rem;
	    padding: 0 1rem;
	    width: auto;
	    min-width: 8rem;
	    height: 4rem;
	    background: #00744B;
	    align-items: center;
	    justify-content: center;
	}

	.ec-cartNavi .ec-cartNavi__price {
	    display: block;
	    font-size: 1.3rem;
	    font-weight: 700;
	    color: #fff;
	    border-bottom: .1rem solid #fff;
	}

	.ec-headerNavSP {
	    width: 3rem;
	    height: 3.25rem;
	}

	.ec-headerNavSP .line {
		height: .15rem;
		border-radius: .075rem;
	}

	.ec-headerNavSP .line + .line {
		margin-top: .525rem;
	}

	.ec-headerRole__searchSP {
		display: block;
		margin-right: 1rem;
	}

	.ec-headerRole__searchSP a {
		display: block;
	    width: 3.25rem;
	    height: 3.25rem;
	    border-radius: .25rem;
	    background: url(../img/common/btn_search_wh.svg) center center no-repeat #00744B;
	    background-size: 1.2rem auto;
	    box-shadow: 0 .5rem .5rem rgba(51, 51, 51, .1);
	    text-indent: -999rem;
	    text-align: left;
	}

	.ec-headerMenuSp {
		display: flex;
		position: fixed;
		z-index: 1000;
		left: 0;
		bottom: 0;
		align-items: center;
		width: 100%;
		border-top: .1rem solid #00744B;
		background: #fff;
    box-shadow: 0 -.4rem 1rem rgba(0, 0, 0, .25);
	}

	.ec-headerMenuSp > * {
		flex: 1;
	}

	.ec-headerMenuSp .ec-headerMenuSp__tel a {
		background: #00744B;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		width: 100%;
		height: 6.5rem;
		font-size: 1.25rem;
		line-height: 1.44;
		color: #fff;
		font-weight: 700;
	}

	.ec-headerMenuSp .ec-headerMenuSp__tel a img {
		width: 2.75rem;
		margin-bottom: .55rem;
	}

	.ec-headerMenuSp .ec-headerMenuSp__login,
  .ec-headerMenuSp .ec-headerMenuSp__mypage {
		border-left: .1rem solid #00744B;
	}

	.ec-headerMenuSp .ec-headerMenuSp__login a,
  .ec-headerMenuSp .ec-headerMenuSp__mypage a {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		width: 100%;
		height: 6.5rem;
		font-size: 1.25rem;
		line-height: 1.44;
		color: #00744B;
		font-weight: 700;
		background: #fff;
	}

	.ec-headerMenuSp .ec-headerMenuSp__login a img,
  .ec-headerMenuSp .ec-headerMenuSp__mypage a img {
		width: 2rem;
		margin-bottom: .55rem;
	}

	.ec-headerMenuSp .ec-headerMenuSp__cart {
		border-left: .1rem solid #00744B;
	}

	.ec-headerMenuSp .ec-headerMenuSp__cart .ec-cartNavi {
		flex-direction: column;
		width: 100%;
		max-width: 100%;
		height: 6.5rem;
		font-size: 1.25rem;
		line-height: 1.44;
		color: #00744B;
		font-weight: 700;
		border-radius: 0;
		background: #fff;
	}

	.ec-headerMenuSp .ec-headerMenuSp__cart .ec-cartNavi .ec-cartNavi__badge {
	    padding: 0 0 0.2rem;
	    width: 2.2rem;
	    height: 2.55rem;
	    color: #00744B;
	    background: url(../img/common/icon_cart_badge_green.svg) center center no-repeat;
	    background-size: cover;
	    font-weight: 400;
	    margin: 0 0 0.5rem;
	}

	.ec-headerMenuSp .ec-headerMenuSp__cart .ec-cartNavi .ec-cartNavi__price {
	    font-size: 1.25rem;
		line-height: 1.44;
	    color: #00744B;
	    border-bottom: 0.1rem solid #00744B;
	    display: flex;
	    justify-content: center;
	    align-items: center;
	}

	.ec-headerMenuSp .ec-headerMenuSp__cart .ec-cartNavi .ec-cartNavi__price:before {
	    display: block;
	    content: '合計：';
	    font-size: 1.25rem;
		line-height: 1.44;
	}

  .ec-headerNaviRole .ec-headerNaviRole__search {
    display: block;
    position: fixed;
    left: 0;
    top: 6.36rem;
    width: 100%;
    z-index: 999;
    background: #fff;
    padding: 2rem 2.5rem;
    opacity: 0;
    visibility: hidden;
    transition: opacity .5s;
  }

  .ec-headerNaviRole .ec-headerNaviRole__search.is-show {
    opacity: 1;
    visibility: visible;
    transition: opacity .5s;
  }

  .ec-headerNaviRole .ec-headerNaviRole__search .ec-headerSearch {
    width: 100%;
  }

  .ec-headerSearch .ec-headerSearch__keyword input[type=search] {
    height: 5.5rem;
    padding-left: 1rem;
    font-size: 1.1rem;
  }
}

.ec-footerRole {
    border-top: 0;
    margin-top: 8rem;
    background: #00744B;
}

.ec-footerRole .ec-role:after {
	display: none;
}

.ec-footerRole .ec-breadcrumb {
	display: none;
}

.ec-footerRole__menu {
	padding: 8rem 0 5rem;
}

.ec-footerMenu {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(3, 1fr);
	padding: 0;
	margin: 0;
}

.ec-footerMenu li {
	list-style: none;
}

.ec-footerMenu li a {
	display: flex;
	width: 100%;
	height: 9rem;
	align-items: center;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #003722;
	background: #fff;
	padding: 0 18%;
	transition: opacity .5s;
}

.ec-footerMenu li a:hover {
	opacity: .7;
	transition: opacity .5s;
}

.ec-footerMenu li a img {
	width: 6rem;
	margin-right: 1rem;
}

.ec-footerRole__contact {
	border-top: .1rem solid #fff;
}

.ec-footerRole__contact .ec-role {
	display: flex;
	justify-content: space-between;
	color: #fff;
}

.ec-footerTel {
	width: 67.4rem;
	padding: 3.8rem 0 5.4rem;
}

.ec-footerTel .ec-footerTel__title {
	font-size: 2rem;
	line-height: 1.437;
	margin-bottom: .8rem;
}

.ec-footerTel .ec-footerTel__phone {
	display: flex;
	align-items: center;
}

.ec-footerTel .ec-footerTel__phone a {
	display: block;
	padding-left: 6.9rem;
	background: url(../img/common/icon_phone_call.svg) left center no-repeat;
	background-size: 4.1rem auto;
	font-size: 3.6rem;
	font-weight: 500;
	font-family: "Noto Serif Display", serif;
	line-height: 1.13889;
	color: #fff;
}

.ec-footerTel .ec-footerTel__phone span {
	display: block;
	font-size: 1.2rem;
	line-height: 1.5;
	margin-left: 1.8rem;
}

.ec-footerContact {
	width: calc(100% - 67.4rem);
	border-left: .1rem solid rgba(255,255,255,.2);
	display: flex;
	align-items: center;
}

.ec-footerContact .ec-footerContact__list {
	width: 100%;
	padding: 0;
	margin: 0;
}

.ec-footerContact .ec-footerContact__list li {
	list-style: none;
}

.ec-footerContact .ec-footerContact__list li a {
	display: block;
	max-width: 27.5rem;
	position: relative;
	padding: 1.2rem 1rem 1.2rem 4.1rem;
	background: url(../img/common/icon_link_wh.svg) right center no-repeat;
	background-size: .6rem auto;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 500;
	width: 100%;
  font-family: "Noto Serif Display", serif;
}

.ec-footerContact .ec-footerContact__list li a .line {
  background: linear-gradient(#fff,#fff) left bottom no-repeat;
  background-size: 0 .1rem;
}

.ec-footerContact .ec-footerContact__list li a:before {
	position: absolute;
	left: -.1rem;
	top: 50%;transform: translateY(-50%);
	z-index: 1;
	content: '';
	width: .1rem;
	height: 2rem;
	background: #fff;
}

.ec-footerRole__info {
	padding: 4rem 0 6rem;
	border-top: .1rem solid #fff;
	color: #fff;
}

.ec-footerRole__info a {
  color: #fff;
}

.ec-footerSns {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ec-footerSns .ec-footerSns__title {
	font-size: 1.6rem;
	line-height: 1.5;
	color: #fff;
}

.ec-footerSns .ec-footerSns__list {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 0;
}

.ec-footerSns .ec-footerSns__list li {
	margin-left: 2.3rem;
	list-style: none;
}

.ec-footerSns .ec-footerSns__list li a {
	display: block;
	width: 4.6rem;
	transition: opacity .5s;
}

.ec-footerSns .ec-footerSns__list li:first-child a {
	width: 17.4rem;
}

.ec-footerSns .ec-footerSns__list li a:hover {
	opacity: .7;
}

.ec-footerCompany {
	text-align: center;
	margin-top: 8rem;
}

.ec-footerCompany .ec-footerCompany__logo {
	display: block;
	margin: 0 auto;
	width: 25.5rem;
}

.ec-footerCompany .ec-footerCompany__address {
	display: block;
	margin-top: 2rem;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #fff;
}


.ec-footerRole .ec-footerRole__inner {
	padding: 5rem 0;
	border-top: .1rem solid #fff;
	font-size: 1.6rem;
    line-height: 1.5;
    color: #fff;
    max-width: 100%;
}

.ec-footerNavi {
	display: flex;
	justify-content: center;
	align-items: center;
}

.ec-footerNavi .ec-footerNavi__link a {
    display: block;
    border-bottom: 0;
    padding: 0 1.5rem;
    font-size: 1.4rem;
    color: #fff;
    text-decoration: none;
}

.ec-footerTitle {
	margin: 2rem 0 0;
	padding: 0;
}

.ec-footerTitle .ec-footerTitle__copyright {
	font-size: 1.2rem;
	font-family: "Noto Sans JP", serif;
}

@media screen and (min-width: 768px) {
	.ec-footerRole {
		padding-top: 0;
		margin-top: 8rem;
	}

  .ec-footerContact .ec-footerContact__list li a:hover .line {
    background-size: 100% .1rem;
  }

	.ec-footerNavi .ec-footerNavi__link {
		display: block;
	    margin: 0 1.5rem;
	}

	.ec-footerNavi .ec-footerNavi__link a {
	    display: block;
	    margin: 0;
	    padding: 0;
	    text-decoration: none;
	}

	.ec-footerTitle {
		padding: 0;
	}

	.ec-footerTitle .ec-footerTitle__copyright {
		font-size: 1.2rem;
	}
}

@media screen and (max-width: 767px) {
	.ec-footerRole {
	    margin-top: 6.5rem;
	}

	.ec-footerRole .ec-breadcrumb {
		display: block;
	}

	.ec-footerRole__menu {
		padding: 5.5rem 0 4rem;
	}

	.ec-footerMenu {
		gap: 1.2rem;
		grid-template-columns: repeat(1, 1fr);
	}

	.ec-footerMenu li a {
		height: 6rem;
		justify-content: center;
		font-size: 1.1rem;
		padding: 0;
	}

	.ec-footerMenu li a:hover {
		opacity: 1;
	}

	.ec-footerMenu li a img {
		width: 3.5rem;
		margin-right: 1rem;
	}

	.ec-footerRole__contact .ec-role {
		display: block;
	}

	.ec-footerTel {
		width: 100%;
		padding: 4rem 0;
	}

	.ec-footerTel .ec-footerTel__title {
		font-size: 1.5rem;
		margin-bottom: 2.2rem;
		text-align: center;
	}

	.ec-footerTel .ec-footerTel__phone {
		display: block;
		text-align: center;
	}

	.ec-footerTel .ec-footerTel__phone a {
		display: inline-block;
		padding-left: 3.5rem;
		background-size: 3rem auto;
		font-size: 3rem;
		line-height: 1;
	}

	.ec-footerTel .ec-footerTel__phone span {
		display: block;
		font-size: 1rem;
		margin: .3rem 0 0;
	}

	.ec-footerContact {
		width: calc(100% + 5rem);
		margin: 0 -2.5rem;
		border-left: 0;
		border-top: .1rem solid #fff;
		display: block;
		padding: 1.5rem 2.5rem;
		position: relative;
	}

	.ec-footerContact:before {
		width: .1rem;
		height: 100%;
		background: rgba(255,255,255,.2);
		position: absolute;
		left: 2.5rem;
		top: 0;
		z-index: 1;
		content: '';
	}

	.ec-footerContact .ec-footerContact__list li a {
		display: block;
		max-width: 18.5rem;
		padding: 1rem 1rem 1rem 1.5rem;
		background: url(../img/common/icon_link_wh.svg) right center no-repeat;
		background-size: .5rem auto;
		font-size: 1.3rem;
	}

	.ec-footerContact .ec-footerContact__list li a:before {
		left: 0;
		height: 1.75rem;
	}

	.ec-footerRole__info {
	    padding: 5.5rem 0 3.5rem;
	}

	.ec-footerSns {
		display: block;
	}

	.ec-footerSns .ec-footerSns__title {
		font-size: 1.5rem;
		text-align: center;
		margin-bottom: 2rem;
	}

	.ec-footerSns .ec-footerSns__list li {
		margin-left: 1.6rem;
	}

	.ec-footerSns .ec-footerSns__list li a {
		width: 3.3rem;
	}

	.ec-footerSns .ec-footerSns__list li:first-child {
		margin-left: 0;
	}

	.ec-footerSns .ec-footerSns__list li:first-child a {
		width: 12.5rem;
	}

	.ec-footerSns .ec-footerSns__list li a:hover {
		opacity: 1;
	}

	.ec-footerCompany {
		margin-top: 5rem;
	}

	.ec-footerCompany .ec-footerCompany__logo {
		display: block;
		width: 17rem;
	}

	.ec-footerCompany .ec-footerCompany__address {
		margin-top: 4rem;
		font-size: 1rem;
	}


	.ec-footerRole .ec-footerRole__inner {
		padding: 4rem 0 10.5rem;
	}

	.ec-footerNavi {
		display: block;
		text-align: center;
	}

	.ec-footerNavi .ec-footerNavi__link + .ec-footerNavi__link {
		margin-top: 1.5rem;
	}

	.ec-footerNavi .ec-footerNavi__link a {
	    padding: 0;
	    font-size: 1.3rem;
	}

	.ec-footerTitle {
		margin: 5rem 0 0;
	}

	.ec-footerTitle .ec-footerTitle__copyright {
		font-size: 1.1rem;
	}
}

.ec-drawerRole {
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    background: #fff;
    width: 100%;
    height: 100vh;
    transform: translateX(0);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100000;
	opacity: 0;
	visibility: hidden;
    transition: opacity .5s;
}

.ec-drawerRole.is_active {
	opacity: 1;
	visibility: visible;
    transition: opacity .5s;
}

.ec-drawerRoleClose{
    border-radius: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: 2.5rem;
    height: 4rem;
    font-size: 0;
    background: none;
    position: fixed;
    top: 2.5rem;
    left: unset;
    right: 5.5rem;
    padding: 0;
    z-index: 100001;
    opacity: 0;
    visibility: hidden;
    transition: opacity .5s;
}

.ec-drawerRoleClose .line {
  display: block;
  width: 100%;
  height: .2rem;
  background: #00744B;
  border-radius: .1rem;
  transition: all 1s;
}

.ec-drawerRoleClose .line + .line {
  margin-top: .6rem;
}

.ec-drawerRoleClose.is_active .line:nth-child(1){
  transform: translateY(.8rem) rotate(30deg);
  transition: all 1s;
}

.ec-drawerRoleClose.is_active .line:nth-child(2){
  opacity: 0;
  transition: all 1s;
}

.ec-drawerRoleClose.is_active .line:nth-child(3){
  transform: translateY(-.8rem) rotate(-30deg);
  transition: all 1s;
}

.ec-drawerRole .ec-drawerRole__logo {
	padding: 4rem;
	text-align: center;
}

.ec-drawerRole__head {
  display: flex;
	gap: 2rem;
  gap: .7rem;
	margin-bottom: 3rem;
}

.ec-drawerRole__head > * {
  width: 100%;
}

.ec-drawerRole .ec-headerSearch {
	padding: 0;
	background: none;
	color: #333;
}

.ec-drawerRole .ec-headerSearch .ec-headerSearch__keyword input[type=search] {
	height: 7rem;
	font-size: 1.2rem;
}

.ec-drawerLogin a,
.ec-drawerMypage a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 7rem;
	background: #00744B;
	border-radius: .5rem;
	color: #fff;
	font-size: 1.5rem;
	line-height: 1.5;
	font-weight: 500;
}

.ec-drawerLogin a:before {
	display: block;
	width: 1.8rem;
	height: 2.3rem;
	background: url(../img/common/icon_login_wh.svg) center center no-repeat;
	background-size: cover;
	margin-right: 1rem;
	content: '';
}

.ec-drawerLogin.login-mypage a:before {
  background: url(../img/common/icon_user.svg) center center no-repeat;
  background-size: contain;
}

.ec-drawerMypage a:before {
  display: block;
  width: 1.997rem;
  height: 2.137rem;
  background: url(../img/common/icon_user.svg) center center no-repeat;
  background-size: cover;
  margin-right: 2rem;
  content: '';
}

.ec-drawerRole .ec-headerCategoryArea {
	margin-bottom: 3rem;
}

.ec-drawerRole .ec-headerCategoryArea .ec-headerCategoryArea__heading {
    border: 0;
    padding: 0;
    font-size: 1.6rem;
    font-weight: 400;
    color: #00744B;
    background: none;
    margin-bottom: 2rem;
}

.ec-drawerRole .ec-headerCategoryArea p {
	position: relative;
	padding-left: 1.4rem;
}

.ec-drawerRole .ec-headerCategoryArea p:before {
	width: .3rem;
	height: 1.5rem;
	background: #00744B;
	position: absolute;
	left: 0;
	top: .55rem;
	z-index: 1;
	content: '';
}

.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav li a {
    display: flex;
    align-items: center;
    padding: 0 4rem 0 2.7rem;
    height: 7rem;
    color: #333;
    font-size: 1.3rem;
    font-weight: 500;
    line-height: 1.5;
    background: #fff;
    border: .1rem solid #D9D9D9;
    border-radius: .5rem;
    position: relative;
    overflow: hidden;
}

.ec-drawerRole .ec-headerCategoryArea.ec-searchPurpose .ec-itemNav__nav li a {
    height: 5rem;
}

.ec-drawerRole .ec-headerCategoryArea.ec-searchPurpose .ec-itemNav__nav li:nth-child(2n) a {
	background: #F8F8F8;
}

.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav li a img {
	width: 3rem;
	margin-right: 1rem;
}

.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav li a:before {
	position: absolute;
	right: 2.7rem;
	top: 50%;
	margin-top: -.6rem;
	width: .9rem;
	height: 1.2rem;
	background: url(../img/common/icon_link_black.svg) center center no-repeat;
	background-size: cover;
	content: '';
	transition: all .5s;
}

.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav > li:hover > a {
	background: inherit;
}

.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav > li:hover > a:before {
	transition: all .5s;
	transform: translateX(100%);
}

.ec-drawerRole__body {
	display: flex;
	justify-content: space-between;
	margin-bottom: 4rem;
}

.ec-drawerRole__body .ec-drawerContent {
	width: 30%;
}

.ec-drawerContent .ec-drawerContent__heading {
	margin-bottom: 1.5rem;
}

.ec-drawerContent .ec-drawerContent__heading p {
	display: flex;
	align-items: center;
	font-size: 1.6rem;
	line-height: 1.25;
	color: #00744B;
}

.ec-drawerContent .ec-drawerContent__heading p:before {
	width: 2.6rem;
	height: 2rem;
	display: block;
	content: '';
	background: url(../img/common/icon_book.svg) center center no-repeat;
	background-size: cover;
	margin-right: 1rem;
}

.ec-drawerContent .ec-drawerContent__body .ec-contentList {
	padding: 0;
	margin: 0;
}

.ec-drawerContent .ec-drawerContent__body .ec-contentList li {
	list-style: none;
}

.ec-drawerContent .ec-drawerContent__body .ec-contentList li a {
	color: #333;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #333333;
	position: relative;
	padding: .7rem 1rem .7rem 0;
	display: block;
	max-width: 21rem;
	width: 100%;
}

.ec-drawerContent .ec-drawerContent__body .ec-contentList li a:after {
	position: absolute;
	right: .7rem;
	top: 0;
	width: .7rem;
	height: 100%;
	background: url(../img/common/icon_link_black_small.svg) center center no-repeat;
	background-size: 100% auto;
	content: '';
	transition: all .5s;
}

.ec-drawerContent .ec-drawerContent__body .ec-contentList li:hover a:after {
	transition: all .5s;
	transform: translateX(100%);
}

.ec-drawerRole__body .ec-drawerGuide {
	width: 66.5%;
}

.ec-drawerGuide .ec-drawerGuide__heading {
	margin-bottom: 2rem;
}

.ec-drawerGuide .ec-drawerGuide__heading p {
	display: flex;
	align-items: center;
	font-size: 1.6rem;
	line-height: 1.375;
	color: #00744B;
}

.ec-drawerGuide .ec-drawerGuide__heading p:before {
	width: 1.8rem;
	height: 2.2rem;
	display: block;
	content: '';
	background: url(../img/common/icon_guide.svg) center center no-repeat;
	background-size: cover;
	margin-right: 1.4rem;
}

.ec-drawerGuide .ec-itemNav__nav li a {
    display: flex;
    align-items: center;
    border: 0;
    padding: 0 4rem 0 2.7rem;
    height: 7rem;
    color: #333;
    font-size: 1.3rem;
    font-weight: 500;
    line-height: 1.5;
    background: #fff;
    border: .1rem solid #D9D9D9;
    border-radius: .5rem;
    position: relative;
    overflow: hidden;
}

.ec-drawerGuide .ec-itemNav__nav li a img {
	width: 3rem;
	margin-right: 1rem;
}

.ec-drawerGuide .ec-itemNav__nav li a:before {
	position: absolute;
	right: 2.7rem;
	top: 50%;
	margin-top: -.6rem;
	width: .9rem;
	height: 1.2rem;
	background: url(../img/common/icon_link_black.svg) center center no-repeat;
	background-size: cover;
	content: '';
	transition: all .5s;
}

.ec-drawerGuide .ec-itemNav__nav > li:hover > a {
	background: inherit;
}

.ec-drawerGuide .ec-itemNav__nav > li:hover > a:before {
	transition: all .5s;
	transform: translateX(100%);
}

.ec-drawerContact {
	border: .1rem solid #00744B;
	border-radius: .5rem;
	padding: 3rem 12.4rem 3rem 6rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ec-drawerContact .ec-drawerContact__title {
	font-size: 1.7rem;
	line-height: 1.5;
	color: #00744B;
}

.ec-drawerContact .ec-drawerContact__title span {
	display: block;
	font-size: 1rem;
}

.ec-drawerContact .ec-drawerContact__phone a {
	font-family: "Noto Serif Display", serif;
	font-size: 4rem;
	line-height: 1.025;
	display: flex;
	align-items: center;
	color: #00744B;
	font-weight: 500;
}

.ec-drawerContact .ec-drawerContact__phone a:before {
	width: 4.1rem;
	height: 4.1rem;
	background: url(../img/common/icon_phone_green.svg) center center no-repeat;
	background-size: cover;
	content: '';
	display: block;
	margin-right: 2rem;
}

.ec-drawerRole__foot {
	padding: 1.4rem 6.2rem 6rem;
}

.ec-drawerNavi,
.ec-drawerSns__list {
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ec-drawerNavi li {
	list-style: none;
	padding: 0 3.4rem;
	position: relative;
}

.ec-drawerNavi li + li:before {
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: .1rem;
	height: 1.25rem;
	background: #333;
	content: '';
}

.ec-drawerNavi li a {
	display: block;
	font-size: 1rem;
	line-height: 1.5;
	color: #333;
}

.ec-drawerSns__list {
	margin-top: 3rem;
}

.ec-drawerSns__list li {
	list-style: none;
	padding: 0 .8rem;
}

.ec-drawerSns__list li a {
	transition: all .5s;
}

.ec-drawerSns__list li a:hover {
	opacity: .7;
	transition: all .5s;
}

.ec-drawerSns__list li img {
	width: 3.68rem;
}

.ec-drawerSns__list li:first-child img {
	width: 13.647rem;
}

.ec-drawerSns__title {
	display: none;
}


@media screen and (min-width: 768px) {
	.ec-drawerRole,
	.ec-drawerRole.is_active {
    display: block;
  }
	.ec-drawerRoleClose.is_active {
    display: flex;
    opacity: 1;
    visibility: visible;
    transition: opacity .5s;
	}

	.ec-drawerCart .ec-cartNavi {
	    width: 100%;
	    height: 7rem;
	    color: #fff;
	}

	.ec-drawerCart .ec-cartNavi .ec-cartNavi__title {
		font-size: 1.5rem;
		line-height: 1.5;
		margin-right: 2rem;
	}

	.ec-drawerCart .ec-cartNavi .ec-cartNavi__label .ec-cartNavi__price {
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.ec-drawerCart .ec-cartNavi .ec-cartNavi__label .ec-cartNavi__price:before {
		display: block;
		content: '合計：';
		font-size: 1.3rem;
		line-height: 1.5;
	}

	.ec-itemNav__nav {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: .7rem;
	}

	.ec-searchPurpose .ec-itemNav__nav {
		grid-template-columns: repeat(3, 1fr);
		gap: .5rem;
	}

	.ec-drawerGuide .ec-itemNav__nav {
		grid-template-columns: repeat(2, 1fr);
		gap: .7rem .5rem;
	}

	.ec-itemNav__nav li {
		float: none;
	}

	.ec-drawerRole .toggle_button {
		display: none;
	}
}

@media screen and (max-width: 767px) {
	.have_curtain .ec-overlayRole {
		background: #fff;
	}

	.ec-drawerRoleClose {
	    width: 3rem;
	    height: 3.25rem;
	    top: 2rem;
	    right: 1.5rem;
	}

  .ec-drawerRoleClose.is_active {
      display: flex;
      opacity: 1;
      visibility: visible;
      transition: opacity .5s;
  }

	.ec-drawerRole .ec-drawerRole__logo {
		padding: 2rem 1.5rem 3rem;
		text-align: left;
	}

	.ec-drawerRole .ec-drawerRole__logo a {
		display: inline-flex;
		height: 3.25rem;
		align-items: center;
		line-height: 1;
	}

	.ec-drawerRole .ec-drawerRole__logo img {
		width: 13rem;
	}

  .ec-drawerRole__head {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 1rem;
  }
  
	.ec-drawerRole .ec-headerSearch {
		padding: 0;
		background: none;
		color: #333;
	}

	.ec-drawerRole .ec-headerSearch .ec-headerSearch__keyword input[type=search] {
		height: 5.5rem;
		font-size: 1.1rem;
		padding-left: 1rem;
	}

	.ec-drawerLogin a,
  .ec-drawerMypage a {
		height: 5.5rem;
		font-size: 1.2rem;
	}

	.ec-drawerLogin a:before {
		width: 1.6rem;
		height: 2.04rem;
		margin-right: .94rem;
	}

   .ec-drawerMypage a:before {
    width: 1.61rem;
    height: 1.7225rem;
    margin-right: 1rem;
  }

	.ec-drawerCart .ec-cartNavi {
	    height: 5.5rem;
	}

	.ec-drawerCart .ec-cartNavi .ec-cartNavi__title {
		font-size: 1.2rem;
		line-height: 1.5;
		margin-right: 3rem;
		color: #fff;
	}

	.ec-drawerCart .ec-cartNavi .ec-cartNavi__label .ec-cartNavi__price {
		display: flex;
		justify-content: center;
		align-items: center;
	}

	.ec-drawerCart .ec-cartNavi .ec-cartNavi__label .ec-cartNavi__price:before {
		display: block;
		content: '合計：';
		font-size: 1.3rem;
		line-height: 1.5;
	}

	.ec-drawerRole .ec-headerCategoryArea {
		width: calc(100% + 5rem);
		padding: 1rem 2.5rem;
		margin: 0 -2.5rem;
		border-top: .1rem solid #D9D9D9;
	}

	.ec-drawerRole .ec-headerCategoryArea .ec-headerCategoryArea__heading {
	    font-size: 1.4rem;
	    margin-bottom: 0;
	    padding: 1rem 0;
	    cursor: pointer;
	    position: relative;
	}

	.ec-drawerRole .toggle_button {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		background: url(../img/common/icon_dropdown_black.svg) right center no-repeat;
		background-size: 1.1rem auto;
		z-index: 2;
		cursor: pointer;
		display: block;
		transition: all .5s;
	}

	.ec-drawerRole .toggle_button.is-active {
		transform: scaleY(-1);
		transition: all .5s;
	}

	.ec-drawerRole .ec-headerCategoryArea p {
		padding-left: .9rem;
	}

	.ec-drawerRole .ec-headerCategoryArea p:before {
		width: .25rem;
		height: 1.4rem;
		top: .45rem;
	}

	.ec-drawerRole .ec-headerCategoryArea .ec-itemNav {
		padding-bottom: 1.5rem;
		display: none;
	}

	.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav {
		display: grid;
		grid-template-columns: repeat(1, 1fr);
		gap: .5rem;
	}

	.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav li a {
	    padding: 0 3rem 0 2rem;
	    height: 6rem;
	    font-size: 1.15rem;
	}

	.ec-drawerRole .ec-headerCategoryArea.ec-searchPurpose .ec-itemNav__nav li a {
	    height: 4.5rem;
	}

	.ec-drawerRole .ec-headerCategoryArea.ec-searchPurpose .ec-itemNav__nav li:nth-child(2n) a {
		background: #F8F8F8;
	}

	.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav li a img {
		width: 3.5rem;
	}

	.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav li a:before {
		right: 2rem;
		margin-top: -.5rem;
		width: .6rem;
		height: 1rem;
	}

	.ec-drawerRole .ec-headerCategoryArea .ec-itemNav__nav > li:hover > a:before {
		transform: translateX(0);
	}

	.ec-drawerRole__body {
		display: block;
		margin-bottom: 3rem;
	}

	.ec-drawerRole__body .ec-drawerContent {
		width: calc(100% + 5rem);
		padding: 1rem 2.5rem;
		margin: 0 -2.5rem;
		border-top: .1rem solid #D9D9D9;
	}

	.ec-drawerContent .ec-drawerContent__heading {
		font-size: 1.4rem;
	    margin-bottom: 0;
	    padding: 1rem 0;
	    cursor: pointer;
	    position: relative;
	}

	.ec-drawerContent .ec-drawerContent__heading p {
		font-size: 1.4rem;
		line-height: 1.5;
	}

	.ec-drawerContent .ec-drawerContent__heading p:before {
		width: 1.85rem;
		height: 1.4rem;
		margin-right: .6rem;
	}

	.ec-drawerContent .ec-drawerContent__body {
		display: none;
	}

	.ec-drawerContent .ec-drawerContent__body .ec-contentList li a {
		font-size: 1.1rem;
		padding: .9rem 1rem .9rem 0;
		max-width: 100%;
	}

	.ec-drawerContent .ec-drawerContent__body .ec-contentList li a:after {
		right: 0;
		width: .5rem;
	}

	.ec-drawerContent .ec-drawerContent__body .ec-contentList li:hover a:after {
		transform: translateX(0);
	}

	.ec-drawerRole__body .ec-drawerGuide {
		width: calc(100% + 5rem);
		padding: 1rem 2.5rem;
		margin: 0 -2.5rem;
		border-top: .1rem solid #D9D9D9;
	}

	.ec-drawerGuide .ec-drawerGuide__heading {
		font-size: 1.4rem;
	    margin-bottom: 0;
	    padding: 1rem 0;
	    cursor: pointer;
	    position: relative;
	}

	.ec-drawerGuide .ec-drawerGuide__heading p {
		font-size: 1.4rem;
		line-height: 1.5;
	}

	.ec-drawerGuide .ec-drawerGuide__heading p:before {
		width: 1.6rem;
		height: 2rem;
		margin-right: .5rem;
	}

	.ec-drawerRole .ec-drawerGuide .ec-itemNav {
		display: none;
	}

	.ec-drawerRole .ec-drawerGuide .ec-itemNav__nav {
		display: grid;
	    grid-template-columns: repeat(1, 1fr);
	    gap: 0.5rem;
	    margin-top: 1.5rem;
	}

	.ec-drawerGuide .ec-itemNav__nav li a {
	    padding: 0 3rem 0 2rem;
	    height: 6rem;
	    color: #333;
	    font-size: 1.1rem;
	    font-weight: 400;
	}

	.ec-drawerGuide .ec-itemNav__nav li a:before {
		right: 2rem;
		margin-top: -.5rem;
		width: .6rem;
		height: 1rem;
	}

	.ec-drawerGuide .ec-itemNav__nav > li:hover > a:before {
		transform: translateX(0);
	}

	.ec-drawerContact {
		border: .1rem solid #003722;
		border-radius: 1rem;
		padding: 2.5rem 0;
		flex-direction: column;
	}

	.ec-drawerContact .ec-drawerContact__title {
		font-size: 1.35rem;
		color: #003722;
		text-align: center;
		margin-bottom: 2rem;
	}

	.ec-drawerContact .ec-drawerContact__title span {
		font-size: 1.1rem;
	}

	.ec-drawerContact .ec-drawerContact__phone a {
		font-size: 3rem;
		line-height: 1;
		color: #003722;
	}

	.ec-drawerContact .ec-drawerContact__phone a:before {
		width: 2.75rem;
		height: 2.75rem;
		background: url(../img/common/icon_phone_green_sp.svg) center center no-repeat;
		background-size: cover;
		margin-right: 1rem;
	}

	.ec-drawerRole__foot {
		padding: 2.25rem 3.4rem;
	}

	.ec-drawerNavi {
		display: none;
	}

	.ec-drawerSns__list {
		margin-top: 1.15rem;
	}

	.ec-drawerSns__list li {
		list-style: none;
		padding: 0 .7rem;
	}

	.ec-drawerSns__list li a:hover {
		opacity: 1;
	}

	.ec-drawerSns__list li img {
		width: 3rem;
	}

	.ec-drawerSns__list li:first-child img {
		width: 11rem;
	}

	.ec-drawerSns__title {
		font-size: 1.1rem;
		line-height: 1.5;
		text-align: center;
		display: block;
	}
}

.ec-breadcrumb {
	width: 100%;
	background: #F8F8F8;
	padding: .6rem 0;
}

.ec-breadcrumb ul {
	width: 100%;
	max-width: 110rem;
	padding: 0 6rem;
	margin: 0 auto;
	list-style: none;
	display: flex;
	align-items: center;
}

.ec-breadcrumb ul li {
	list-style: none;
	font-size: 1.2rem;
	line-height: 1.5;
	padding-right: 1.5em;
	position: relative;
}

.ec-breadcrumb ul li:before {
	position: absolute;
	right: 0;
	top: 0;
	width: 1.5em;
	font-size: 1.2rem;
	line-height: 1.5;
	content: '-';
	text-align: center;
}

.ec-breadcrumb ul li:last-child:before {
	content: '';
}

.ec-breadcrumb ul li a {
	color: #333333;
}

@media screen and (max-width: 767px) {
	.ec-breadcrumb.is-sp {
		padding: 0;
    position: relative;
	}

	.ec-breadcrumb.is-sp ul {
		padding: 0 2.5rem;
    position: absolute;
    top: 5.5rem;
    background: #F8F8F8;
	}

	.ec-breadcrumb.is-sp ul li {
		font-size: 1.1rem;
	}

	.ec-breadcrumb.is-sp ul li:before {
		font-size: 1.1rem;
	}
}

.ec-layoutRole .ec-layoutRole__contents {
    max-width: 100%;
    position: relative;
}

.ec-searchnavRole__topicpath h2 {
	margin: 0;
	padding: 0;
	text-align: center;
	font-size: 3rem;
	line-height: 1.5;
	padding: 2.8rem 0;
}

.ec-searchnavRole .ec-searchnavRole__infos {
	padding: 0 5rem;
    font-size: 1.6rem;
    line-height: 1.5;
    color: #333;
    max-width: 110rem;
    margin-bottom: 4rem;
}

.ec-searchnavRole .ec-searchnavRole__counter {
	font-size: 1.3rem;
}

.ec-searchnavRole .ec-searchnavRole__counter span {
	font-size: 2rem;
	font-weight: 400;
}

.ec-searchnavRole .ec-searchnavRole__actions {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.ec-searchnavRole .ec-searchnavRole__actions .ec-narrowDown {
	margin-left: 2rem;
}

.ec-searchnavRole .ec-searchnavRole__actions .ec-narrowDown button {
	width: 12rem;
	font-size: 1.3rem;
	line-height: 1;
	padding: .1rem 0 1.1rem;
	border: 0;
	border-bottom: .1rem solid #ddd;
	text-align: left;
	background: url(../img/common/icon_narrow_down.svg) right top no-repeat #fff;
	background-size: 1.7rem auto;
	cursor: pointer;
	border-radius: 0;
}

.ec-searchnavRole .ec-searchnavRole__actions .ec-select {
	margin-bottom: 0;
	margin-left: 2rem;
}

.ec-searchnavRole .ec-searchnavRole__actions .ec-select select {
	appearance: none;
	border-radius: 0;
	background: url(../img/common/icon_orderby.svg) right top no-repeat #fff;
	background-size: 1.7rem auto;
	width: 12rem;
	font-size: 1.3rem;
	line-height: 1;
	padding: .1rem 0 1.1rem;
	border: 0;
	border-bottom: .1rem solid #ddd;
	text-align: left;
	cursor: pointer;
}

.ec-searchnavRole .ec-searchnavRole__actions .ec-select select::-ms-expand {
	display: none;
}

.ec-shelfRole {
	padding: 0 5rem;
    box-sizing: border-box;
    font-size: 1.6rem;
    line-height: 1.5;
    color: #333;
    max-width: 110rem;
}

.ec-shelfGrid .ec-shelfGrid__item {
	margin-bottom: 2rem;
}

.ec-products {
	margin: 0;
	position: relative;
	width: 100%;
	display: block;
	height: 100%;
	padding: 2rem 1.8rem;
	color: #333;
	background: #fff;
	box-shadow: 0 .5rem 2.5rem rgba(69, 69, 69, .06);
	transition: all .5s;
}

.ec-products .ec-products__image {
	margin-bottom: 1.6rem;
	width: 100%;
	padding-top: 100%;
	position: relative;
}

.ec-products.has-squeeze .ec-products__image:after {
	width: 4rem;
	height: 4rem;
	position: absolute;
	right: 1rem;
	bottom: .7rem;
	background: url(../img/products/icon_first_squeeze.svg) center center no-repeat;
	background-size: cover;
	content: '';
	z-index: 1;
}

.ec-products .ec-products__image img {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
}

.ec-products .ec-products__category {
	width: 100%;
	text-align: center;
	font-size: 1rem;
	line-height: 1.5;
	color: #999999;
	margin-bottom: .6rem;
}

.ec-products .ec-products__title {
	width: 100%;
	text-align: center;
	font-size: 1.4rem;
	line-height: 1.5;
	color: #333;
}

.ec-products .ec-products__price {
	width: 100%;
	text-align: center;
	font-size: 1rem;
	line-height: 1.5;
	color: #333;
	margin-top: .7rem;
}

.ec-products .ec-products__price .price-default {
	font-size: 1.6rem;
	font-weight: 500;
	margin-right: .2rem;
}

.ec-products .ec-products__tags {
	position: absolute;
	left: 2.5rem;
	top: 0;
	z-index: 2;
	display: flex;
	align-items: flex-start;
}

.ec-products .ec-products__tags span {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	display: block;
	margin-left: .5rem;
	font-size: 1rem;
	line-height: 1.3;
	letter-spacing: .4em;
	background: #E9E3CC;
	font-weight: 700;
	padding: 1rem .4rem;
  color: #333;
}

@media screen and (min-width: 768px) {
	.ec-searchnavRole {
		padding: 0 5rem;
	    font-size: 1.6rem;
	    line-height: 1.5;
	    color: #333;
	    max-width: 110rem;
	}

	.ec-searchnavRole .ec-searchnavRole__infos {
		padding: 0;
	    border-top: 0;
	    padding-top: 0;
	}

	.ec-shelfGrid {
		margin: 0 -1rem;
	}

	.ec-shelfGrid .ec-shelfGrid__item:nth-child(odd),
	.ec-shelfGrid .ec-shelfGrid__item:nth-child(even) {
	    padding: 0 1rem;
	}

	.ec-products:hover {
		box-shadow: 0 0 0 rgba(69, 69, 69, .06);
		transition: all .5s;
	}
}

@media screen and (max-width: 767px) {
	.ec-searchnavRole__topicpath h2 {
		font-size: 2.6rem;
		line-height: 1.5;
		padding: 2.5rem 0;
	}

	.ec-searchnavRole .ec-searchnavRole__infos {
		padding: 0 2.5rem;
	    margin-bottom: 3rem;
	}

	.ec-searchnavRole .ec-searchnavRole__actions {
		padding-top: 2rem;
		width: 100%;
		justify-content: space-between;
	}

	.ec-searchnavRole .ec-searchnavRole__actions .ec-narrowDown {
		margin-left: 0;
		width: calc(50% - .625rem);
	}

	.ec-searchnavRole .ec-searchnavRole__actions .ec-narrowDown button {
		width: 100%;
		line-height: 1.53;
		padding: 0 0 .65rem;
		background-size: 2rem auto;
	}

	.ec-searchnavRole .ec-searchnavRole__actions .ec-select {
		margin-left: 0;
		width: calc(50% - .625rem);
	}

	.ec-searchnavRole .ec-searchnavRole__actions .ec-select select {
		background-size: 2rem auto;
		width: 100%;
		font-size: 1.3rem;
		line-height: 1.53;
		padding: 0 0 .65rem;
	}

	.ec-searchnavRole .ec-searchnavRole__actions .ec-select select::-ms-expand {
		display: none;
	}
	.ec-shelfRole {
		padding: 0 2.5rem;
	}

	.ec-shelfGrid {
		margin: 0 -.65rem;
	}

	.ec-shelfGrid .ec-shelfGrid__item {
		margin-bottom: 1.25rem;
	}

	.ec-shelfGrid .ec-shelfGrid__item:nth-child(odd),
	.ec-shelfGrid .ec-shelfGrid__item:nth-child(even) {
	    padding: 0 .65rem;
	}

	.ec-products {
		margin-bottom: 0;
		padding: 1.3rem 1.15rem 2rem;
		box-shadow: 0 .25rem 1.25rem rgba(69, 69, 69, .06);
	}

	.ec-products:hover {
		opacity: 1;
	}

	.ec-products.has-squeeze .ec-products__image:after {
		right: -.5rem;
		bottom: -1rem;
	}

	.ec-products .ec-products__category {
		margin-bottom: .6rem;
	}

	.ec-products .ec-products__title {
		font-size: 1.2rem;
	}

  .ec-products .ec-products__price {
    margin-top: .35rem;
  }

  .ec-products .ec-products__price .price-default {
    font-size: 1.4rem;
  }

	.ec-products .ec-products__tags {
		left: .6rem;
	}

	.ec-products .ec-products__tags span {
		margin-left: .25rem;
		padding: .6rem .2rem;
	}
}

.ec-pager {
	padding: 4rem 0 0;
	display: flex;
	justify-content: center;
	align-items: center;
}

.ec-pager .ec-pager__item, 
.ec-pager .ec-pager__item--active {
    min-width: 2.7rem;
    padding: 0;
    margin: 0 1.2rem;
    display: inline-block;
    font-size: 1.2rem;
    line-height: 1.5;
}

.ec-pager .ec-pager__item--active,
.ec-pager .ec-pager__item:hover {
	background: none;
}

.ec-pager .ec-pager__item a, 
.ec-pager .ec-pager__item--active a {
    line-height: 1.5;
    padding: 0;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 2.7rem;
    height: 2.7rem;
    font-size: 1.2rem;
    border-radius: 100%;
}

.ec-pager .ec-pager__item--active a {
	background: #F3FEFA;
	color: #00744B;
}

.ec-pager .ec-pager__item a:hover {
	color: #00744B;
}

.ec-pager .ec-pager__item.ec-pager__first a,
.ec-pager .ec-pager__item.ec-pager__last a,
.ec-pager .ec-pager__item.ec-pager__prev a,
.ec-pager .ec-pager__item.ec-pager__next a {
	display: block;
	text-align: left;
	text-indent: -9999px;
	background-position: center center;
	background-repeat: no-repeat;
}

.ec-pager .ec-pager__item.ec-pager__next a {
	background-image: url(../img/common/icon_pages_next.svg);
	background-size: .6rem auto;
}

.ec-pager .ec-pager__item.ec-pager__prev a {
	background-image: url(../img/common/icon_pages_prev.svg);
	background-size: .6rem auto;
}

.ec-pager .ec-pager__item.ec-pager__last a {
	background-image: url(../img/common/icon_pages_last.svg);
	background-size: .9rem auto;
}

.ec-pager .ec-pager__item.ec-pager__first a {
	background-image: url(../img/common/icon_pages_first.svg);
	background-size: .9rem auto;
}


@media screen and (max-width: 767px) {
	.ec-pager {
		padding-top: 2.75rem;
	}
	.ec-pager .ec-pager__item, 
	.ec-pager .ec-pager__item--active {
	    min-width: 1.4rem;
	    margin: 0 1rem;
	}

	.ec-pager .ec-pager__item a, 
	.ec-pager .ec-pager__item--active a {
	    width: 1.4rem;
	    height: 1.75rem;
	}

	.ec-pager .ec-pager__item--active a {
		background: #F3FEFA;
		color: #00744B;
	}

	.ec-pager .ec-pager__item a:hover {
		background: none;
		color: #333;
	}
}

.ec-narrowDownModel {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 10000;
	text-align: left;
	opacity: 0;
	visibility: hidden;
	transition: opacity .5s;
}

.ec-narrowDownModel.is-open {
	opacity: 1;
	visibility: visible;
	transition: opacity .5s;
}

.ec-narrowDownModel .ec-narrowDownModel__overlay {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .4;
	z-index: 1;
}

.ec-narrowDownModel .ec-narrowDownModel__body {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	z-index: 2;
	background: #fff;
	box-shadow: 0 .4rem 2.5rem rgba(0,0,0,.2);
	max-width: 35rem;
	width: calc(100% - 4rem);
	border-radius: .5rem;
	padding: 3.6rem 2rem 5rem;
	overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    max-height: calc(100% - 4rem);
}

.ec-narrowDownModel .ec-narrowDownModel__close {
	width: 2rem;
	height: 2rem;
	background: url(../img/common/icon_close_black.svg) center center no-repeat;
	background-size: 100% auto;
	position: absolute;
	right: 2rem;
	top: 3.8rem;
	z-index: 3;
	cursor: pointer;
}

.ec-narrowDownModel .ec-narrowDown__head {
	margin-bottom: 3rem;
}

.ec-narrowDownModel .ec-narrowDown__head h2 {
	margin: 0;
	font-size: 1.8rem;
	font-weight: 600;
	line-height: 1.5;
}

.ec-narrowDownModel .ec-narrowDown__head h3 {
	margin: 0;
	font-size: 1.3rem;
	font-weight: 600;
	line-height: 1.5;
	padding: 0 0 1.2rem 1rem;
	border-bottom: .1rem solid #DDDDDD;
	position: relative;
}

.ec-narrowDownModel .ec-narrowDown__head h3:before {
	position: absolute;
	left: 0;
	top: .5rem;
	width: .2rem;
	height: 1.2rem;
	background: #00744B;
	content: '';
	z-index: 1;
}

.ec-narrowDownModel .ec-narrowDown__item {
	margin-bottom: 2rem;
}

.ec-narrowDownModel .ec-narrowDown__item  .ec-narrowDown__head {
	margin-bottom: 1.25rem;
}

.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0 2rem;
}

.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox.full {
	grid-template-columns: repeat(1, 1fr);
}

.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox .narrowDown-check,
.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox .form-check {
	display: flex;
	align-items: flex-start;
	padding: .75rem 0;
}

.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox .narrowDown-check .form-check{
  min-height: unset;
  padding-left: 0;
  margin-bottom: 0;
  width: 100%;
}


.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox .form-check .form-check-input{
  border-width: 0px;
}

.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox .narrowDown-check-label,
.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox label {
  display: block;
	font-size: 1.2rem;
	font-weight: 600;
	line-height: 1.25;
}

.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox label span{
  font-weight: 600;
}

.ec-narrowDownModel .ec-narrowDown__button {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.ec-narrowDownModel .ec-narrowDown__button input + input {
	margin-top: 1rem;
}

.ec-narrowDownModel .ec-narrowDown__button input[type=reset] {
	width: 22rem;
	height: 3.5rem;
	border: .1rem solid #333;
	border-radius: 1.75rem;
	background: #fff;
	font-size: 1.3rem;
	font-weight: 500;
	color: #333;
}

.ec-narrowDownModel .ec-narrowDown__button input[type=submit] {
	width: 100%;
	height: 6rem;
	border: .1rem solid #00744B;
	border-radius: .5rem;
	background: #00744B;
	font-size: 1.5rem;
	font-weight: 700;
	color: #fff;
	cursor: pointer;
	transition: all .5s;
}

.ec-narrowDownModel .ec-narrowDown__button input[type=submit]:hover {
	transition: all .5s;
	opacity: .7;
}

@media screen and (max-width: 767px) {

	.ec-narrowDownModel .ec-narrowDownModel__body {
		box-shadow: 0 .2rem 1.25rem rgba(0,0,0,.2);
		border-radius: .25rem;
		padding: 3.5rem 2rem 4rem;
	}

	.ec-narrowDownModel .ec-narrowDownModel__close {
		width: 1.5rem;
		height: 1.5rem;
		top: 3.6rem;
	}

	.ec-narrowDownModel .ec-narrowDown__head {
		margin-bottom: 2rem;
	}

	.ec-narrowDownModel .ec-narrowDown__head h2 {
		font-size: 1.5rem;
	}

	.ec-narrowDownModel .ec-narrowDown__head h3 {
		font-size: 1.2rem;
		padding: 0 0 1.2rem .85rem;
	}

	.ec-narrowDownModel .ec-narrowDown__head h3:before {
		top: .4rem;
		width: .2rem;
		height: 1.1rem;
	}

	.ec-narrowDownModel .ec-narrowDown__item {
		margin-bottom: 2rem;
	}

	.ec-narrowDownModel .ec-narrowDown__item  .ec-narrowDown__head {
		margin-bottom: .875rem;
	}

	.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox .narrowDown-check {
		display: flex;
		align-items: flex-start;
		padding: .625rem 0;
	}

	.ec-narrowDownModel .ec-narrowDown__checkbox .ec-checkbox .narrowDown-check-label {
		font-size: 1.1rem;
		line-height: 1.36;
	}

	.ec-narrowDownModel .ec-narrowDown__button input + input {
		margin-top: 1.5rem;
	}

	.ec-narrowDownModel .ec-narrowDown__button input[type=reset] {
		width: 20rem;
		height: 3.25rem;
		border-radius: 1.625rem;
		font-size: 1.2rem;
	}

	.ec-narrowDownModel .ec-narrowDown__button input[type=submit] {
		height: 5rem;
		border-radius: .25rem;
		font-size: 1.4rem;
	}

	.ec-narrowDownModel .ec-narrowDown__button input[type=submit]:hover {
		opacity: 1;
	}
}

#page_homepage .ec-layoutRole__header {
	width: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 10;
}

#page_homepage .ec-headerRole h1 a:before {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	z-index: 2;
	content: '';
	background: url(../img/common/logo_wh.svg) center center no-repeat;
	background-size: cover;
}

#page_homepage .ec-headerRole h1 a img {
	opacity: 0;
}

#page_homepage .ec-footerRole {
	margin-top: 0;
}

@media screen and (max-width: 767px) {
	#page_homepage .ec-footerRole .ec-breadcrumb {
		display: none;
	}
}

.ec-sliderRole {
	padding: 0;
    box-sizing: border-box;
    font-size: 1.6rem;
    line-height: 1.5;
    color: #333;
    max-width: 100%;
    margin-bottom: 0;
    position: relative;
}

.main_visual_title {
	position: absolute;
	left: 0;
	top: 0;
	z-index: 5;
	pointer-events: none;
	width: 100%;
	height: 100%;
	justify-content: center;
	align-items: center;
	display: flex;
	font-size: 3rem;
	line-height: 1.4;
	font-weight: 500;
	letter-spacing: .2em;
	color: #fff;
	text-align: center;
}

.main_visual .swiper-slide {
	width: 100%;
	height: 63rem;
	position: relative;
}

.main_visual .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.main_visual .swiper-controller {
	width: 100%;
	max-width: 122.4rem;
	padding: 0 5rem;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 3.6rem;
	z-index: 10;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.main_visual .swiper-controller .swiper-pagination-progressbar {
	position: relative;
	left: 0;
	top: 0;
	width: calc(100% - 13rem);
	height: .1rem;
	background: rgba(255,255,255,.2);
}

.main_visual .swiper-controller .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
	height: .1rem;
	background: #fff;
}

.main_visual .swiper-controller .swiper-controller-button {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 10rem;
}

.main_visual .swiper-controller .swiper-button-next, 
.main_visual .swiper-controller .swiper-button-prev {
	position: relative;
	left: 0;
	top: 0;
	right: 0;
	width: 2.5rem;
	height: 2rem;
	margin: 0;
}

.main_visual .swiper-controller .swiper-button-next {
	background: url(../img/common/icon_slider_next.svg) center center no-repeat;
	background-size: 100% auto;
	margin-left: 1.5rem;
}

.main_visual .swiper-controller .swiper-button-prev {
	background: url(../img/common/icon_slider_prev.svg) center center no-repeat;
	background-size: 100% auto;
}

.main_visual .swiper-controller .swiper-button-next:after, 
.main_visual .swiper-controller .swiper-button-prev:after {
	display: none;
}

.main_visual .swiper-controller .swiper-pause {
	width: 2rem;
	height: 2rem;
	margin-left: 1.5rem;
	border: .1rem solid #fff;
	border-radius: 100%;
	position: relative;
	cursor: pointer;
}

.main_visual .swiper-controller .swiper-pause:before {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	width: .5rem;
	height: .8rem;
	border-left: .1rem solid #fff;
	border-right: .1rem solid #fff;
	z-index: 2;
	content: '';
	opacity: 1;
	transition: opacity .5s;
}

.main_visual .swiper-controller .swiper-pause.is-stop:before {
	opacity: 0;
	transition: opacity .5s;
}

.main_visual .swiper-controller .swiper-pause:after {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	width: .6rem;
	height: .8rem;
	background: #fff;
	margin-left: .1rem;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	z-index: 2;
	content: '';
	opacity: 0;
	transition: opacity .5s;
}

.main_visual .swiper-controller .swiper-pause.is-stop:after {
	opacity: 1;
	transition: opacity .5s;
}

@media screen and (max-width: 767px) {
	.main_visual_title {
		font-size: 2.5rem;
		line-height: 1.6;
	}

	.main_visual .swiper-slide {
		height: 100vh;
	}

	.main_visual .swiper-controller {
		width: 100%;
		padding: 0 2rem;
		bottom: 2rem;
		display: block;
	}

	.main_visual .swiper-controller .swiper-pagination-progressbar {
		width: 100%;
	}

	.main_visual .swiper-controller .swiper-controller-button {
		justify-content: flex-end;
		width: 100%;
		margin-top: 2rem;
	}

	.main_visual .swiper-controller .swiper-button-next, 
	.main_visual .swiper-controller .swiper-button-prev {
		width: 3rem;
	}

	.main_visual .swiper-controller .swiper-button-next {
		margin-left: 2rem;
	}

	.main_visual .swiper-controller .swiper-pause {
		margin-left: 2rem;
	}
}

/*バナー*/
.ec-bannerRole {
	width: 100%;
	background: #FBF7F6;
}

.ec-bannerRole .ec-bannerSlider {
	width: 100%;
	overflow: hidden;
	padding: 6rem 0;
}

.ec-bannerRole .ec-bannerSlider .swiper {
	overflow: visible;
}

.ec-bannerRole .ec-bannerSlider .swiper-pagination {
	width: 100%;
	max-width: 50rem;
	left: 50%;
	transform: translateX(-50%);
	bottom: -2.6rem;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ec-bannerRole .ec-bannerSlider .swiper-pagination .swiper-pagination-bullet {
	flex: 1;
	width: 100%;
	height: .1rem;
	background: rgba(221, 221, 221, 0.3);
	border-radius: 0;
	margin: 0;
	padding: 0;
}

.ec-bannerRole .ec-bannerSlider .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background: #D9D9D9;
}


@media screen and (max-width: 767px) {

	.ec-bannerRole .ec-bannerSlider {
		padding: 3rem 0 2.5rem;
	}

	.ec-bannerRole .ec-bannerSlider .swiper-wrapper {
		flex-direction: column;
	}


	.ec-bannerRole .ec-bannerSlider .swiper-wrapper .swiper-slide + .swiper-slide {
		margin-top: 1rem;
	}
	
}


/*年末年始休業のお知らせ*/
.ec-noticeRole {
	margin: 3rem 0 0;
	border: .1rem solid #DDDDDD;
	border-radius: 1rem;
	padding: 2.8rem;
	text-align: center;
}

.ec-noticeRole h2 {
	margin: 0;
	padding: 0;
	font-size: 1.8rem;
	line-height: 1.5;
	color: #00744B;
	font-weight: 500;
	letter-spacing: .01em;
	margin-bottom: 2rem;
}

.ec-noticeRole p {
	font-size: 1.3rem;
	line-height: 1.5;
	letter-spacing: .02em;
}

@media screen and (max-width: 767px) {
	.ec-noticeRole {
		margin: 2.5rem 0 0;
		border-radius: .5rem;
		padding: 2.4rem 2rem;
		text-align: left;
	}

	.ec-noticeRole h2 {
		font-size: 1.7rem;
		line-height: 1.47;
		text-align: center;
		margin-bottom: 1.6rem;
	}

	.ec-noticeRole p {
		font-size: 1.15rem;
		line-height: 1.6;
	}
}

/*heading*/
.ec-secHeading {
	margin: 0;
	color: #333;
	position: relative;
}

.ec-secHeading .ec-secHeading__link {
	position: absolute;
	right: 0;
	top: 0;
	z-index: 2;
}

.ec-secHeading h2 {
	margin: 0;
	padding: 0;
	font-size: 2.6rem;
	line-height: 1.5;
	text-align: center;
	font-weight: 500;
	letter-spacing: .08em;
	margin-bottom: 3rem;
}

.ec-secHeading h3 {
	margin: 0;
	padding: 0 0 0 1.3rem;
	font-size: 2rem;
	line-height: 1.45;
	font-weight: 500;
	margin-bottom: 2.5rem;
	position: relative;
}

.ec-secHeading h3:before {
	position: absolute;
	left: 0;
	top: .45rem;
	width: .3rem;
	height: 2rem;
	background: #E78C93;
	content: '';
}

@media screen and (max-width: 767px) {
	.ec-secHeading h2 {
		font-size: 2.4rem;
		margin-bottom: 2rem;
	}

	.ec-secHeading h3 {
		padding: 0 0 0 .65rem;
		font-size: 1.7rem;
		line-height: 1.44;
		margin-bottom: 1.25rem;
	}

	.ec-secHeading h3:before {
		top: .375rem;
		width: .15rem;
		height: 1.6rem;
	}
}

/*リンク*/
.ec-link {
	display: inline-block;
	padding-right: 2.1rem;
	background: url(../img/common/icon_link_black.svg) right center no-repeat;
	background-size: .6rem auto;
	font-size: 1.4rem;
	line-height: 1.5;
	font-weight: 500;
	color: #333;
}
.ec-link .line {
	display: inline;
	background: linear-gradient(#333,#333) left bottom no-repeat;
	background-size: 0 .1rem;
	transition: all .5s;
}

.ec-link-q {
	display: inline-block;
	padding-left: 2.3rem;
	background: url(../img/common/icon_question.svg) left center no-repeat;
	background-size: 1.6rem auto;
	font-size: 1.3rem;
	line-height: 1.5;
	font-weight: 500;
	color: #333;
}
.ec-link-q .line {
	display: inline;
	background: linear-gradient(#333,#333) left bottom no-repeat;
	background-size: 0 .1rem;
	transition: all .5s;
}

.ec-inlineLink {
	text-decoration: underline;
}

.ec-button {
	display: inline-block;
	width: 100%;
	max-width: 35.5rem;
	border: .1rem solid #333;
	border-radius: .5rem;
	padding: 1.5rem 4rem 1.5rem 3rem;
	background: url(../img/common/icon_link_black.svg) right 3rem center no-repeat;
	background-size: .8rem auto;
	font-size: 1.4rem;
	line-height: 1.5;
	color: #333;
	font-weight: 500;
	transition: all .5s;
}

@media screen and (min-width: 768px) {
	.ec-link:hover,
	.ec-link-q:hover {
		color: #333;
	}

	.ec-link:hover .line,
	.ec-link-q:hover .line {
		background-size: 100% .1rem;
		transition: all .5s;
	}

	.ec-button:hover {
		color: #333;
		opacity: .7;
		transition: all .5s;
	}
}

@media screen and (max-width: 767px) {
	.ec-link {
		padding-right: 1.6rem;
		font-size: 1.2rem;
	}
	.ec-link .line {
		background-size: 100% .1rem;
	}

  .ec-link-q {
    padding-left: 2rem;
    background-size: 1.5rem auto;
    font-size: 1.15rem;
  }
  .ec-link-q .line {
    background-size: 100% .1rem;
  }
  .ec-button {
    max-width: 100%;
    padding: 2.1rem 3.5rem 2.1rem 2rem;
    background: url(../img/common/icon_link_black.svg) right 2.5rem center no-repeat;
    background-size: .8rem auto;
    font-size: 1.2rem;
  }
}

/*ベストセラー*/
.ec-bestsellerRole {
	padding-top: 4rem;
}

.ec-bestsellerRole__list .ec-shelfGrid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	margin: 0;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item {
	padding: 0;
	margin: 0;
	width: 100%;
}

.ec-bestsellerRole__list .ec-products.has-squeeze .ec-products__image:after {
	right: -1rem;
	bottom: -1rem;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child {
	grid-column-start: 1;
    grid-column-end: 3;
    grid-row-start: 1;
    grid-row-end: 3;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products {
    padding: 4rem;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__image {
    margin-bottom: 5rem;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products.has-squeeze .ec-products__image:after {
	width: 6rem;
	height: 6rem;
	right: -1.5rem;
	bottom: -1.5rem;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__category {
    font-size: 1.4rem;
    line-height: 1.875;
    margin-bottom: 1.3rem;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__title {
    font-size: 2.2rem;
    line-height: 1.45;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__tags {
	left: 5rem;
}

.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__tags span {
	margin-left: 1rem;
	font-size: 1.4rem;
	padding: 1.5rem .8rem;
}


@media screen and (max-width: 767px) {
	.ec-bestsellerRole {
		padding-top: 2rem;
	}

	.ec-bestsellerRole__list .ec-shelfGrid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.25rem;
	}

	.ec-bestsellerRole__list .ec-products.has-squeeze .ec-products__image:after {
		right: -.5rem;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child {
		grid-column-start: 1;
	    grid-column-end: 3;
	    grid-row-start: 1;
	    grid-row-end: 3;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products {
	    padding: 2.5rem;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__image {
	    margin-bottom: 2.5rem;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products.has-squeeze .ec-products__image:after {
		width: 4rem;
		height: 4rem;
		right: -1rem;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__category {
	    font-size: 1.2rem;
	    line-height: 1.375;
	    margin-bottom: .6rem;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__title {
	    font-size: 1.7rem;
	    line-height: 1.437;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__tags {
		left: 0;
	}

	.ec-bestsellerRole__list .ec-shelfGrid .ec-shelfGrid__item:first-child .ec-products .ec-products__tags span {
		font-size: 1.2rem;
		padding: 1rem .5rem;
	}
}

.ec-featureRole {
	padding: 8rem 0 0;
	overflow: hidden;
}

.ec-featureRole .ec-featureRole__item {
	margin-bottom: 6rem;
	position: relative;
}

.ec-featureRole .ec-featureRole__item .ec-featureList {
	position: relative;
}

.ec-featureRole .ec-featureRole__item .ec-featureList:before,
.ec-featureRole .ec-featureRole__item .ec-featureList:after {
	position: absolute;
	top: -2rem;
	width: 21rem;
	height: calc(100% + 2rem);
	background: url(../img/top/shadow_white.png) left center no-repeat;
	background-size: 100% 100%;
	content: '';
	z-index: 2;
	pointer-events: none;
}
.ec-featureRole .ec-featureRole__item .ec-featureList:before {
	transform: scaleX(-1) translateX(50vw);
	left: 50%;
}
.ec-featureRole .ec-featureRole__item .ec-featureList:after {
	right: 50%;
	transform: translateX(50vw);
}

.ec-featureList .swiper {
	overflow: visible;
}

.ec-featureList .ec-products {
	width: 21rem;
}

.ec-featureList .swiper-slide {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
}

.ec-featureList .ec-products .ec-products__tags {
	top: -1rem;
	left: 1rem;
}

.ec-featureList .ec-products.has-squeeze .ec-products__image:after {
	right: -1.3rem;
	bottom: -1.3rem;
}

.ec-featureRole .ec-featureLinks {
	position: absolute;
	right: 0;
	top: 0;
	z-index: 2;
}

@media screen and (max-width: 1420px) {
	.ec-featureRole .ec-featureRole__item .ec-featureList:before,
	.ec-featureRole .ec-featureRole__item .ec-featureList:after {
		width: clamp(5rem, 4.545vw, 21rem);
	}
}


@media screen and (max-width: 767px) {
	.ec-featureRole {
		padding: 4rem 0 0;
	}

	.ec-featureRole .ec-featureRole__item {
		margin-bottom: 3rem;
	}

	.ec-featureRole .ec-featureRole__item .ec-featureList:before,
	.ec-featureRole .ec-featureRole__item .ec-featureList:after {
		display: none;
	}

	.ec-featureList .ec-products {
		width: 18.5rem;
	}

	.ec-featureList .ec-products .ec-products__tags {
		top: 0;
		left: .5rem;
	}

	.ec-featureList .ec-products.has-squeeze .ec-products__image:after {
		right: -1rem;
		bottom: -1.75rem;
	}

	.ec-featureRole .ec-featureLinks {
		position: relative;
		text-align: right;
		margin-top: 1.5rem;
	}
}

.ec-purposeRole {
	padding: 0 0 6rem;
}

.ec-purposeRole__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.2rem;
}

.ec-purposeRole__list .ec-purposeRole__listItem a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 8rem;
	font-size: 1.8rem;
	line-height: 1.5;
	border-radius: .5rem;
	background: #fff;
	border: .1rem solid #EFEEEA;
	transition: opacity .5s;
}

.ec-purposeRole__list .ec-purposeRole__listItem a:hover {
	color: #333;
	opacity: .7;
	transition: opacity .5s;
}

.ec-purposeRole__list .ec-purposeRole__listItem:nth-child(even) a {
	background: #F8F8F8;
	border-color: #F8F8F8;
}


@media screen and (max-width: 767px) {
	.ec-purposeRole {
		padding: 3rem 0 4rem;
	}

	.ec-purposeRole__list {
		display: grid;
		grid-template-columns: repeat(1, 1fr);
		gap: 0;
	}

	.ec-purposeRole__list .ec-purposeRole__listItem a {
		height: 7rem;
		font-size: 1.4rem;
		border-radius: 0;
		border: 0;
	}

	.ec-purposeRole__list .ec-purposeRole__listItem a:hover {
		opacity: 1;
	}
}

.ec-newsRole {
	padding: 4rem 0 0;
	background: #F8F8F8;
}

.ec-newsRole .ec-newsRole__newsItem:first-child {
    border-top: .1rem solid #D9D9D9;
}

.ec-newsRole .ec-newsRole__newsItem,
.ec-newsRole .ec-newsRole__newsItem:not(:last-of-type) {
    border-bottom: .1rem solid #D9D9D9;
}

.ec-newsRole .ec-newsRole__newsDate {
    margin: 0;
    font-size: 1.4rem;
    line-height: 1.5;
}

.ec-newsRole .ec-newsRole__newsTitle {
    display: block;
    margin-bottom: 0;
    width: 100%;
    font-size: 1.4rem;
    font-weight: 400;
    color: #333;
    line-height: 1.5;
    overflow : hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}

/* .ec-newsRole__newsItem.is_active .ec-newsRole__newsDescription {
	margin: 0;
} */

.ec-newsRole__button {
	text-align: center;
	margin-top: 4rem;
}

.ec-newsRole__button a {
	display: inline-flex;
	width: 100%;
	max-width: 30rem;
	height: 5rem;
	justify-content: center;
	align-items: center;
	font-size: 1.2rem;
	line-height: 1.5;
	background: #fff;
	border-radius: 2.5rem;
	border: .1rem solid #D9D9D9;
	transition: opacity .5s;
}

.ec-newsRole__button a:hover {
	color: #333;
	opacity: .7;
	transition: opacity .5s;
}


@media screen and (min-width: 768px) {
	.ec-newsRole {
		padding: 6rem 0 3rem;
	}

	.ec-newsRole .ec-newsRole__news {
	    border: 0;
	    padding: 0;
	}

	.ec-newsRole .ec-newsRole__newsDate {
		max-width: 12.5rem;
		font-size: 1.4rem;
		display: block;
	}

	.ec-newsRole .ec-newsRole__newsColumn {
	    display: block;
	    min-width: calc(100% - 12.5rem);
	}

	.ec-newsRole .ec-newsRole__newsTitle {
	    line-height: 1.5;
	}

  .ec-newsRole .ec-newsRole__newsHeading:not(:has(+ .ec-newsRole__newsDescription))  {
    cursor: default;
  }

	/* .ec-newsRole__newsItem.is_active .ec-newsRole__newsDescription {
		margin: 0;
	} */
}


@media screen and (max-width: 767px) {
	.ec-newsRole {
		padding: 4rem 0 5rem;
	}

	.ec-newsRole .ec-newsRole__newsHeading {
		padding: 1.5rem 0 2rem;
	}

	.ec-newsRole .ec-newsRole__newsDate {
	    font-size: 1.2rem;
	}

	.ec-newsRole .ec-newsRole__newsTitle {
	    font-size: 1.2rem;
	    margin-top: .65rem;
	}

	.ec-newsRole__button {
		margin-top: 3rem;
	}

	.ec-newsRole__button a {
		max-width: 100%;
		height: 3.75rem;
		font-size: 1.1rem;
		border-radius: 1.875rem;
	}

	.ec-newsRole__button a:hover {
		opacity: 1;
	}
}


.ec-fixedButton {
	position: fixed;
	z-index: 1000;
	right: 5rem;
	bottom: 5rem;
	width: 19rem;
}

.ec-fixedButton .ec-fixedButton__close {
	position: absolute;
	z-index: 2;
	right: 1rem;
	top: 1.3rem;
	width: 3.2rem;
	cursor: pointer;
}

@media screen and (max-width: 767px) {
	.ec-fixedButton {
		display: none;
	}
}


.ec-productRole {
	padding: 5rem 5rem 0;
  font-size: 1.6rem;
  line-height: 1.5;
  color: #333;
  max-width: 110rem;
}

@media screen and (max-width: 767px) {
  .ec-productRole {
    padding: 1.5rem 2.5rem 0;
  }
}

.ec-sliderItemRole {
	padding: 0 5rem 0 0;
  font-size: 1.6rem;
  line-height: 1.5;
  color: #333;
  max-width: 100%;
  margin-bottom: 0;
  position: sticky;
  top: 1.6rem;
}

.ec-sliderItemRole .slick-slider {
	margin-bottom: 1.5rem;
}

.ec-sliderItemRole .slide-item img {
	border-radius: 1.5rem;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.ec-sliderItemRole .item_nav {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1.2rem;
}

.ec-sliderItemRole .slideThumb {
  margin-bottom: 0;
  width: 100%;
  opacity: 1;
  border: .1rem solid #DDDDDD;
  border-radius: .5rem;
  padding-top: 100%;
  position: relative;
  overflow: hidden;
}

.ec-sliderItemRole .slideThumb.is-active {
    border-color: #00744B;
}

.ec-sliderItemRole .slideThumb img {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1;
	object-fit: contain;
}

.ec-sliderItemRole .ec-productRole__tags {
    margin-top: 0;
    padding: 0;
    border-bottom: 0;
    position: absolute;
    left:0;
    top: -1.6rem;
    z-index: 10;
    display: flex;
    align-items: flex-start;
}

.ec-sliderItemRole .ec-productRole__tags li {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
    display: block;
    margin-left: .8rem;
    font-size: 1.4rem;
    line-height: 1.5;
    letter-spacing: .4em;
    background: #E9E3CC;
    font-weight: 600;
    padding: 1.6rem .3rem;
}

.ec-sliderItemRole .ec-productRole__icon {
    position: absolute;
    right: 14rem;
    top: 37rem;
    z-index: 10;
    width: 6rem;
    height: 6rem;
    border-radius: 100%;
}

.ec-productRole .ec-productRole__favorite {
    width: 6rem;
    height: 6rem;
    position: absolute;
    top: 37rem;
    right: 7rem;
    z-index: 10;
    border-radius: 100%;
    overflow: hidden;
}

.ec-productRole .ec-productRole__cool {
  margin-bottom: 1rem;
}
.ec-productRole .ec-productRole__cool span {
  display: inline-block;
  padding: 0.8rem 0.8rem 0.8rem 2.4rem;
  background: url("../img/cart/icon_truck.svg") no-repeat 0.8rem center #E9F5FF;
  border: 1px solid #0073FF;
  border-radius: 2px;
  line-height: 1;
  color: #0073FF;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
}

.ec-sliderItemRole .ec-productRole__favorite .ec-productRole__btn {
    width: 100%;
    height: 100%;
    margin-bottom: 0;
    min-width: 100%;
}

.ec-sliderItemRole .ec-productRole__favorite .ec-productRole__btn .ec-blockBtn--cancel {
  width: 100%;
  height: 100%;
    background: url(../img/products/icon_heart_no.svg) center center no-repeat;
    background-size: cover;
    font-size: 0;
    padding: 0;
    line-height: 1;
    border: 0;
}

.ec-sliderItemRole .ec-productRole__favorite .ec-productRole__btn .ec-blockBtn--cancel.active {
    background: url(../img/products/icon_heart_on.svg) center center no-repeat;
    background-size: cover;
}

@media screen and (max-width: 767px) {
  .ec-sliderItemRole {
    padding: 0;
    position: relative;
    top: 0;
  }

  .ec-sliderItemRole .slick-slider {
    margin-bottom: 2rem;
  }

  .ec-sliderItemRole .slick-slide > div {
    line-height: 0;
  }

  .ec-sliderItemRole .slide-item img {
    border-radius: .75rem;
  }

  .ec-sliderItemRole .item_nav {
    margin: 0 auto;
    width: 100%;
    max-width: 24.5rem;
    gap: .5rem;
  }

  .ec-sliderItemRole .slideThumb {
    border-radius: .25rem;
  }

  .ec-sliderItemRole .ec-productRole__tags {
    top: -1rem;
    left: 1.5rem;
  }

  .ec-sliderItemRole .ec-productRole__tags li {
    margin-left: .7rem;
    padding: 1rem .2rem .6rem;
  }

  .ec-sliderItemRole .ec-productRole__icon {
    position: absolute;
    right: 6.5rem;
    bottom: calc(12vw + 3rem);
    top: unset;
    width: 5rem;
    height: 5rem;
  }

  .ec-productRole .ec-productRole__favorite {
    width: 5rem;
    height: 5rem;
    bottom: calc(12vw + 3rem);
    top: unset;
    right: .5rem;
  }
}

.ec-productRole .ec-productRole__profile {
    margin-left: 0;
}

.ec-productRole .ec-productRole__campaign {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
}

.ec-productRole .ec-productRole__campaign li {
	list-style: none;
  display: block;
  margin: 0 1rem 1rem 0;
  font-size: 1.2rem;
  line-height: 1.5;
  letter-spacing: .04em;
  background: #FFF0EF;
  font-weight: 700;
  color: #F07675;
  padding: .35rem 2rem;
}

@media screen and (max-width: 767px) {
  .ec-productRole .ec-productRole__profile {
    padding: 3rem 0 6.5rem;
  }

  .ec-productRole .ec-productRole__campaign {
    margin-bottom: .6rem;
  }

  .ec-productRole .ec-productRole__campaign li {
    font-size: 1.1rem;
    letter-spacing: .05em;
    padding: .575rem 1.5rem;
  }
} 

.ec-productRole .ec-productRole__title .ec-headingTitle {
	font-size: 2.6rem;
	line-height: 1.46;
	letter-spacing: .01em;
	margin: 0 0 1rem;
	color: #333;
}

@media screen and (max-width: 767px) {
  .ec-productRole .ec-productRole__title .ec-headingTitle {
    font-size: 2.4rem;
    line-height: 1.46;
    margin: 0 0 1.6rem;
  }
}

.ec-productRole__reviews {
	margin-bottom: 3rem;
	display: flex;
	align-items: center;
}

.ec-productRole__reviews .ec-productRole__reviewsStars {
	width: 13rem;
	margin-right: .8rem;
  line-height: 0;
	position: relative;
}

.ec-productRole__reviews .ec-link {
	font-size: 1.3rem;
}

@media screen and (max-width: 767px) {
  .ec-productRole__reviews {
    margin-bottom: 2.25rem;
  }

  .ec-productRole__reviews .ec-productRole__reviewsStars {
    width: 11.375rem;
    margin-right: 1rem;
  }

  .ec-productRole__reviews .ec-link {
    font-size: 1.15rem;
  }
}

.ec-productRole__type {
	margin-bottom: 3.5rem;
}

.ec-productRole__type .ec-productRole__typeSizes {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	margin: 0;
	padding: 0;
}

.ec-productRole__type .ec-productRole__typeSizes li {
	list-style: none;
}

.ec-productRole__type .ec-productRole__typeSizes li a {
	display: flex;
	align-items: center;
	width: 100%;
	height: 100%;
	border: .15rem solid #ddd;
	border-radius: .5rem;
	background: #fff;
	padding: 1.75rem 2rem;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: .08em;
	color: #999;
}

.ec-productRole__type .ec-productRole__typeSizes li.is-active a {
	border-color: #00744B;
	background: #F3FEFA;
	color: #333;
}

@media screen and (max-width: 767px) {
  .ec-productRole__type {
    margin-bottom: 2.5rem;
  }

  .ec-productRole__type .ec-productRole__typeSizes {
    gap: 1rem;
  }

  .ec-productRole__type .ec-productRole__typeSizes li a {
    padding: 1.05rem 2rem;
    font-size: 1.1rem;
    letter-spacing: .06em;
  }
}

.ec-productRole .ec-productRole__price {
    color: #333;
    font-size: 1.6rem;
    line-height: 1.5;
    border-bottom: 0;
    padding: 0 0 4rem;
}

.ec-productRole .ec-productRole__price .ec-productRole__priceItem + .ec-productRole__priceItem {
	margin-top: 3.5rem;
}

.ec-productRole .ec-productRole__price .ec-productRole__priceItem .ec-secHeading h3 {
	margin-bottom: .8rem;
}

.ec-productRole .ec-productRole__price .ec-productRole__priceBox {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-end;
}

.ec-price .ec-price__price {
	font-size: 1.4rem;
	line-height: 1.5;
	font-weight: 500;
	padding: 0;
}

.ec-price .ec-price__price .price-default {
	font-size: 3rem;
	font-weight: 600;
	line-height: 1.5;
	color: #F07675;
	margin-right: .8rem;
}

.ec-price .ec-price__tax {
	font-size: 1.4rem;
	line-height: 1.5;
	display: inline-block;
}

.ec-priceNotes {
	font-size: 1.2rem;
	line-height: 1.5;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
}

.ec-priceNotes .notes-default {
	font-weight: 700;
	color: #F07675;
}

.ec-productRole .ec-productRole__price .ec-productRole__priceBox .ec-priceNotes {
	padding-bottom: .6rem;
}

.ec-productRole .ec-productRole__actions {
	padding: 0;
	margin-top: 1.5rem;
	display: flex;
	align-items: center;
}

.ec-productRole .ec-productRole__actions .ec-numberInput {
	width: 13rem;
	height: 6rem;
	margin-right: 2rem;
	border: .1rem solid #ddd;
	border-radius: .5rem;
	position: relative;
	overflow: hidden;
}

.ec-productRole .ec-productRole__actions .ec-numberInput span {
	position: absolute;
	top: 0;
	z-index: 2;
	width: 4rem;
	height: 100%;
	cursor: pointer;
	font-size: 1.2rem;
	display: flex;
	justify-content: center;
	align-items: center;
}

.ec-productRole .ec-productRole__actions .ec-numberInput .ec-numberInput__minus {
	left: 0;
	border-right: .1rem solid #ddd;
}

.ec-productRole .ec-productRole__actions .ec-numberInput .ec-numberInput__add {
	right: 0;
	border-left: .1rem solid #ddd;
}

.ec-productRole .ec-productRole__actions .ec-numberInput .ec-numberInput__minus.is-disabled,
.ec-productRole .ec-productRole__actions .ec-numberInput .ec-numberInput__add.is-disabled {
	opacity: .7;
	pointer-events: none;
}

.ec-productRole .ec-productRole__actions .ec-numberInput input[type=text],
.ec-productRole .ec-productRole__actions .ec-numberInput input[type=number] {
	width: 100%;
	height: 6rem;
	border: 0;
	appearance: none;
	text-align: center;
	padding: 0 4rem;
	display: block;
	max-width: 100%;
	font-size: 1.6rem;
  -moz-appearance:textfield;
}

.ec-productRole .ec-productRole__actions .ec-numberInput input[type=number]:disabled,
.ec-productRole .ec-productRole__actions .ec-numberInput input[type=number][readonly]{
  background-color: #fff;
}

.ec-productRole .ec-productRole__actions .ec-numberInput input[type="number"]::-webkit-outer-spin-button, 
.ec-productRole .ec-productRole__actions .ec-numberInput input[type="number"]::-webkit-inner-spin-button { 
  -webkit-appearance: none; 
  margin: 0;
} 

.ec-productRole .ec-productRole__actions .ec-productRole__btn {
	width: calc(100% - 15rem);
	margin-bottom: 0;
  min-width: 0;
}

.ec-productRole .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action {
	display: inline-flex;
	justify-content: center;
	align-items: center;
    border: 0;
    padding: 1rem;
    font-size: 1.5rem;
    border-radius: .5rem;
    background-color: #F07675;
    border-color: #F07675;
    height: 6rem;
    line-height: 1.5;
}

.ec-productRole .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action:before {
	width: 1.6rem;
	height: 1.8rem;
	background: url(../img/common/icon_badge_wh.svg) center center no-repeat;
    background-size: cover;
    content: '';
    display: block;
    margin-right: 1rem;
}

.ec-productRole .ec-productRole__price .ec-productRole__priceItem.priceRegular .ec-secHeading h3:before {
	background: #00744B;
}

.ec-productRole .ec-productRole__priceItem.priceRegular  .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action {
	background: #00744B;
  border-color: #00744B;
}

.ec-productRole .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action:disabled,
.ec-productRole .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action.disabled,
.ec-productRole .ec-productRole__priceItem.priceRegular  .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action:disabled,
.ec-productRole .ec-productRole__priceItem.priceRegular  .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action.disabled {
  background: #ddd;
  border-color: #ddd;
}

.ec-productRole__priceTags {
	display: flex;
	flex-wrap: wrap;
	font-family: 'Noto Sans JP', sans-serif;
}

.ec-productRole__priceTags .priceTags-campaign {
	display: block;
	margin-right: 1rem;
	font-size: 1.2rem;
	line-height: 2.25;
	padding: 0 2rem;
	background: #FFF0EF;
	color: #F07675;
	font-weight: 700;
  margin-top: 1rem;
}

.ec-productRole__priceTags .priceTags-price {
	display: block;
	margin-right: 1rem;
	font-size: 1.2rem;
	line-height: 2.25;
	padding: 0 2rem;
	background: #fff;
	border: .1rem solid #333333;
	border-radius: .3rem;
	font-weight: 700;
  margin-top: 1rem;
}

.ec-productRole__priceTags .priceTags-price .priceTags-default {
	color: #F07675;
}

.bg-load-overlay {
  display: none;
}

@media screen and (max-width: 767px) {
  .ec-productRole .ec-productRole__price {
    padding: 0 0 3rem;
  }

  .ec-productRole .ec-productRole__price .ec-productRole__priceItem + .ec-productRole__priceItem {
    margin-top: 2.5rem;
  }

  .ec-productRole .ec-productRole__price .ec-productRole__priceItem .ec-secHeading h3 {
    margin-bottom: .2rem;
  }

  .ec-productRole .ec-productRole__price .ec-productRole__priceBox {
    display: block;
  }

  .ec-price .ec-price__price {
    font-size: 1.2rem;
  }

  .ec-price .ec-price__price .price-default {
    font-size: 2.5rem;
    margin-right: .4rem;
  }

  .ec-price .ec-price__tax {
    font-size: 1.2rem;
  }

  .ec-priceNotes {
    font-size: 1.1rem;
  }

  .ec-productRole .ec-productRole__price .ec-productRole__priceBox .ec-priceNotes {
    padding-bottom: 0;
  }

  .ec-productRole .ec-productRole__actions {
    margin-top: 1.2rem;
  }

  .ec-productRole .ec-productRole__actions .ec-numberInput {
    width: 6.5rem;
    height: 3.5rem;
    margin-right: 1rem;
    border-radius: .25rem;
  }

  .ec-productRole .ec-productRole__actions .ec-numberInput span {
    display: none;
  }

  .ec-productRole .ec-productRole__actions .ec-numberInput input[type=text] {
    height: 3.5rem;
    padding: 0 2rem;
    font-size: 1.5rem;
  }

  .ec-productRole .ec-productRole__actions .ec-select {
    width: 6.5rem;
    height: 3.5rem;
    margin-right: 1rem;
    border-radius: .25rem;
    border: .1rem solid #ddd;
    position: relative;
    overflow: hidden;
    margin-bottom: 0;
  }

  .ec-productRole .ec-productRole__actions .ec-select select {
    width: 100%;
    height: 3.5rem;
    border: 0;
    appearance: none;
    text-align: center;
    padding: 0 2rem;
    display: block;
    max-width: 100%;
    font-size: 1.5rem;
    margin-bottom: 0;
    background: url(../img/common/icon_dropdown_black.svg) right .75rem center no-repeat #fff;
    background-size: 1rem auto;
  }

  .ec-productRole .ec-productRole__actions .ec-productRole__btn {
    width: calc(100% - 7.5rem);
  }

  .ec-productRole .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action {
    font-size: 1.4rem;
    border-radius: .25rem;
    height: 4.5rem;
  }

  .ec-productRole .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action:before {
    width: 1.3rem;
    height: 1.4rem;
    margin-right: .7rem;
  }

  .ec-productRole__priceWrap {
    display: flex;
    flex-direction: column-reverse;
  }

  .ec-productRole__priceTags .priceTags-campaign {
    margin-right: .8rem;
    font-size: 1.1rem;
    line-height: 2.545;
    padding: 0 1rem;
  }

  .ec-productRole__priceTags .priceTags-price {
    margin-right: .8rem;
    font-size: 1.1rem;
    line-height: 2.545;
    padding: 0 1rem;
    border-radius: .15rem;
  }
}

.ec-productRole__box .ec-productRole__boxItem {
	border-top: .1rem solid #ddd;
	padding: 3.3rem 0 4.5rem;
}

.ec-productRole__box .ec-productRole__boxItem.js-toggle {
	padding: 3.3rem 0 1.3rem;
}

.ec-productRole__box .ec-productRole__boxItem .ec-secHeading h2 {
	text-align: left;
	margin-bottom: 2rem;
}

.ec-productRole__box .ec-productRole__boxItem .ec-secHeading.js-toggle-target {
	cursor: pointer;
	position: relative;
}

.ec-productRole__box .ec-productRole__boxItem .ec-secHeading.js-toggle-target:after {
	background: url(../img/common/icon_dropdown_black.svg) center center no-repeat;
	background-size: 100% auto;
	width: 1.6rem;
	height: 100%;
	content: '';
	position: absolute;
	right: 0;
	top: 0;
	z-index: 2;
	transition: all .5s;
}

.ec-productRole__box .ec-productRole__boxItem .ec-secHeading.js-toggle-target.is-active:after {
	transform: scaleY(-1);
}

@media screen and (max-width: 767px) {
  .ec-productRole__box .ec-productRole__boxItem {
    padding: 2.7rem 0 3.5rem;
  }

  .ec-productRole__box .ec-productRole__boxItem.js-toggle {
    padding: 3.3rem 0 1.8rem;
  }

  .ec-productRole__box .ec-productRole__boxItem .ec-secHeading h2 {
    margin-bottom: 1.7rem;
    font-size: 2.1rem;
  }

  .ec-productRole__box .ec-productRole__boxItem .ec-secHeading.js-toggle-target:after {
    width: 1.1rem;
  }
}

.ec-product__information {
	display: none;
	padding-bottom: 3.2rem;
}

.ec-product__information .ec-product__informationItem {
	display: flex;
	align-items: center;
  margin-bottom: .5rem;
}

.ec-product__information .ec-product__informationItem dt {
	width: 12rem;
	background: #F8F8F8;
	padding: 1rem;
	font-size: 1.4rem;
	line-height: 1.5;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #333;
	font-weight: 400;
}

.ec-product__information .ec-product__informationItem dd {
	width: calc(100% - 12rem);
	background: #fff;
	padding: 1rem;
	font-size: 1.4rem;
	line-height: 1.5;
	letter-spacing: .05em;
	color: #333;
  margin-bottom: 0;
}

@media screen and (max-width: 767px) {
  .ec-product__information {
    padding-bottom: 2rem;
  }

  .ec-product__information .ec-product__informationItem dt {
    width: 8rem;
    padding: .75rem 0;
    font-size: 1.2rem;
  }

  .ec-product__information .ec-product__informationItem dd {
    width: calc(100% - 8rem);
    padding: .75rem 1rem;
    font-size: 1.2rem;
  }
}

.ec-textureRole {
	display: flex;
	align-items: center;
	font-size: 1rem;
	line-height: 1.5;
}

.ec-textureRole .ec-textureRole__process {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 2;
	padding: 0 1rem;
}

.ec-textureRole .ec-textureRole__process:before {
	position: absolute;
	height: .1rem;
	background: #00744B;
	left: 1.5rem;
	right: 1.5rem;
	top: 50%;
	transform: translateY(-50%);
	z-index: -1;
	content: '';
}

.ec-textureRole .ec-textureRole__process .process-item {
	width: 1.5rem;
	height: 1.5rem;
	border-radius: 100%;
	border: .1rem solid #00744B;
	background: #fff;
}

.ec-textureRole .ec-textureRole__process .process-item.is-active {
	background: #00744B;
}

.ec-textureRole .ec-textureRole__process .process-item + .process-item {
	margin-left: 3.4rem;
}

.ec-product__information .ec-product__informationTags {
	margin: 0;
	padding: 0;
	margin-top: 1.5rem;
	display: flex;
	flex-wrap: wrap;
}

.ec-product__information .ec-product__informationTags li {
	border: .1rem solid #00744B;
	border-radius: .5rem;
	background: #fff;
	padding: 1.1rem 3.8rem;
	font-size: 1.4rem;
	font-weight: 600;
	line-height: 1.5;
	color: #00744B;
	list-style: none;
	margin-right: 1rem;
  margin-top: .5rem;
}

@media screen and (max-width: 767px) {

  .ec-textureRole .ec-textureRole__process {
    padding: 0 .75rem;
  }

  .ec-textureRole .ec-textureRole__process .process-item {
    width: 1rem;
    height: 1rem;
  }


  .ec-textureRole .ec-textureRole__process .process-item + .process-item {
    margin-left: 2rem;
  }

  .ec-product__information .ec-product__informationTags li {
    padding: .9rem 2rem;
    font-size: 1.2rem;
  }
}


.ec-productRole__box .ec-shelfGrid {
	margin: 0 -.5rem;
}


.ec-productRole__box .ec-shelfGrid .ec-shelfGrid__item {
	padding: 0 .5rem;
	margin-bottom: 1rem;
	width: 50%;
}

.ec-productRole__box .ec-shelfGrid .ec-shelfGrid__item .ec-products {
	border-radius: .3rem;
	padding: 3rem 2.75rem;
}

@media screen and (max-width: 767px) {

  .ec-productRole__box .ec-shelfGrid {
    margin: 0 -.3rem;
  }


  .ec-productRole__box .ec-shelfGrid .ec-shelfGrid__item {
    padding: 0 .3rem;
    margin-bottom: 1.25rem;
  }

  .ec-productRole__box .ec-shelfGrid .ec-shelfGrid__item .ec-products {
    border-radius: .1rem;
    padding: 1.3rem 1.15rem;
  }
}

.ec-product__guide {
	padding-bottom: 3.2rem;
	display: none;
}

.ec-product__guide .ec-product__guideList {
	padding: 0;
	margin: 0;
}

.ec-product__guide .ec-product__guideList li {
	padding: 0;
	margin: 0;
	list-style: none;
	border: .1rem solid #ddd;
	border-radius: 1rem;
	background: #fff;
	padding: 1.5rem 2rem 1.5rem 7.7rem;
	position: relative;
	font-size: 1.8rem;
	line-height: 1.5;
	color: #333;
	font-weight: 500;
}

.ec-product__guide .ec-product__guideList li + li {
	margin-top: .5rem;
}

.ec-product__guide .ec-product__guideList li small {
	font-size: 1.4rem;
	margin-left: 1rem;
}

.ec-product__guide .ec-product__guideList .guide-number {
	width: 3.7rem;
	height: 3.7rem;
	border-radius: 100%;
	border: .1rem solid #333;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 500;
	position: absolute;
	left: 2rem;
	top: 50%;
  transform: translateY(-50%);
	z-index: 2;
}

.ec-product__guide .ec-product__guideList li:nth-child(even) {
	border-color: #FBF7F6;
	background: #FBF7F6;
}

.ec-product__guide .ec-product__guideButton {
	margin-top: 3rem;
}

@media screen and (max-width: 767px) {
  .ec-product__guide {
    padding-bottom: 1.7rem;
  }

  .ec-product__guide .ec-product__guideList li {
    padding: 1rem 1.5rem 1rem 5.4rem;
    font-size: 1.3rem;
    min-height: 5.2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .ec-product__guide .ec-product__guideList li small {
    font-size: 1.1rem;
    margin: 0;
    display: block;
  }

  .ec-product__guide .ec-product__guideList .guide-number {
    width: 3.2rem;
    height: 3.2rem;
    font-size: 1.3rem;
    left: 1.5rem;
  }
}

.ec-product__faq .ec-product__faqItem,
.ec-product__faq .Content__faq dl {
	border: .1rem solid #ddd;
	border-radius: 2rem;
	padding: 2.4rem 3rem;
}

.ec-product__faq .ec-product__faqItem + .ec-product__faqItem,
.ec-product__faq .Content__faq dl + dl {
	margin-top: 1.5rem;
}

.ec-product__faq .ec-product__faqItem dt {
	position: relative;
	font-size: 1.6rem;
	line-height: 1.5;
	color: #00744B;
	font-weight: 500;
	letter-spacing: .05em;
}

.ec-product__faq .Content__faq dl dt {
	position: relative;
  display: flex;
	padding-left: 0;
	font-size: 1.6rem;
	line-height: 1.5;
	color: #00744B;
	font-weight: 500;
	letter-spacing: .05em;
}

.ec-product__faq .Content__faq dl dt .ques,
.ec-product__faq .Content__faq dl dd .ans {
	margin-right: 0.7rem;;
}
.ec-product__faq .Content__faq dl dt .ques::after,
.ec-product__faq .Content__faq dl dd .ans::after {
	content: ".";
}

.ec-product__faq .ec-product__faqItem dt:before {
	position: absolute;
	left: 0;
	top: 0;
	font-size: 1.6rem;
	line-height: 1.5;
	color: #00744B;
	letter-spacing: .05em;
	z-index: 1;
	content: 'Q.';
}

.ec-product__faq .ec-product__faqItem dd {
	position: relative;
	padding-left: 2.3rem;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #333;
	font-weight: 500;
	letter-spacing: .08em;
	margin-top: 1rem;
}

.ec-product__faq .Content__faq dl dd {
	position: relative;
  display: flex;
	padding-left: 0;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #333;
	font-weight: 500;
	letter-spacing: .08em;
	margin-top: 1rem;
}

.ec-product__faq .ec-product__faqItem dd:before {
	position: absolute;
	left: 0;
	top: -.3rem;
	font-size: 1.6rem;
	line-height: 1.5;
	color: #00744B;
	letter-spacing: .05em;
	z-index: 1;
	content: 'A.';
}

.ec-product__faq .Content__faq dl dd .ans {
	font-size: 1.6rem;
	line-height: 1.1;
	color: #00744B;
	letter-spacing: .05em;
	z-index: 1;
}

@media screen and (max-width: 767px) {
  .ec-product__faq .ec-product__faqItem,
  .ec-product__faq .Content__faq dl {
    border: 0;
    border-bottom: .1rem solid #ddd;
    border-radius: 0;
    padding: 0 0 2rem;
  }

  .ec-product__faq .ec-product__faqItem + .ec-product__faqItem,
  .ec-product__faq .Content__faq dl + dl {
    margin-top: 1.5rem;
  }

  .ec-product__faq .ec-product__faqItem:last-child,
  .ec-product__faq .Content__faq dl:last-child{
    padding-bottom: 0;
    border-bottom: 0;
  }

  .ec-product__faq .ec-product__faqItem dt,
  .ec-product__faq .Content__faq dl dt {
    position: relative;
    padding-left: 3rem;
    font-size: 1.4rem;
  }

  .ec-product__faq .ec-product__faqItem dt:before,
  .ec-product__faq .Content__faq dl dt .ques {
    font-size: 1.4rem;
  }

  .ec-product__faq .ec-product__faqItem dd,
  .ec-product__faq .Content__faq dl dd {
    padding-left: 3rem;
    font-size: 1.1rem;
    margin-top: 1.5rem;
  }

  .ec-product__faq .ec-product__faqItem dd:before,
  .ec-product__faq .Content__faq dl dd .ans {
    top: -.15rem;
    font-size: 1.4rem;
  }
}

.ec-product__charm .ec-product__charmItem + .ec-product__charmItem {
	margin-top: 4.3rem;
}

.ec-product__charm .ec-product__charmItem .charm-title {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: .1em;
}

.ec-product__charm .ec-product__charmItem .charm-text {
	margin-top: 1rem;
	font-size: 1.4rem;
	line-height: 1.5;
	letter-spacing: .08em;
}

.ec-product__charm .ec-product__charmItem .charm-image {
	margin-top: 1.5rem;
	border-radius: 1rem;
	overflow: hidden;
}

.ec-product__charm .ec-product__charmItem .charm-image img {
	width: 100%;
}

@media screen and (max-width: 767px) {
  .ec-product__charm .ec-product__charmItem + .ec-product__charmItem {
    margin-top: 3rem;
  }

  .ec-product__charm .ec-product__charmItem .charm-title {
    font-size: 1.5rem;
  }

  .ec-product__charm .ec-product__charmItem .charm-text {
    margin-top: 1.5rem;
    font-size: 1.2rem;
  }

  .ec-product__charm .ec-product__charmItem .charm-image {
    margin-top: 1.5rem;
    border-radius: .5rem;
  }
}

.ec-product__description .description-title {
	font-size: 1.8rem;
	font-weight: 600;
	line-height: 1.5;
	letter-spacing: .1em;
	color: #00744B;
} 

.ec-product__description .description-text {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.5;
	letter-spacing: .1em;
	margin-top: 3rem;
} 

.ec-product__description .description-image {
	margin-top: 3rem;
}

.ec-product__description .description-image figure {
  border-radius: 1rem;
  overflow: hidden;
  border: .1rem solid #ddd;
  padding: 0;
  margin: 0;
}

.ec-product__description .description-image figure + figure {
  margin-top: 3rem;
}

.ec-product__description .description-image img {
	width: 100%;
}

@media screen and (max-width: 767px) {
  .ec-product__description .description-title {
    font-size: 1.5rem;
  } 

  .ec-product__description .description-text {
    font-size: 1.2rem;
    margin-top: 1.5rem;
  } 

  .ec-product__description .description-image {
    margin-top: 1.5rem;
  }

  .ec-product__description .description-image figure {
    border-radius: .5rem;
  }

  .ec-product__description .description-image figure + figure {
    margin-top: 1.5rem;
  }
}

.ec-product__recommend {
  border: .1rem solid #ddd;
  padding: 4rem 5rem 5rem;
  border-radius: .5rem;
}

.ec-product__recommend .ec-product__recommendList {
	margin: 0;
	padding: 0;
}

.ec-product__recommend .ec-product__recommendList li {
	padding-left: 3.65rem;
	font-size: 1.4rem;
	line-height: 1.5;
	font-weight: 500;
	list-style: none;
	position: relative;
}

.ec-product__recommend .ec-product__recommendList li:before {
	width: 2.15rem;
	height: 2rem;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	content: '';
}

.ec-product__recommend .ec-product__recommendList li + li {
	margin-top: 2.5rem;
}

.ec-product__recommend .ec-product__recommendList li:nth-child(odd):before {
	background: url(../img/common/icon_checkbox_pink.svg) center center no-repeat;
	background-size: cover;
}

.ec-product__recommend .ec-product__recommendList li:nth-child(even):before {
	background: url(../img/common/icon_checkbox_green.svg) center center no-repeat;
	background-size: cover;
}

.ec-product__recommend .ec-product__recommendList li:nth-child(odd) .line {
	background: linear-gradient(#F4CCCC,#F4CCCC) left bottom no-repeat;
	background-size: 100% 1rem;
}

.ec-product__recommend .ec-product__recommendList li:nth-child(even) .line {
	background: linear-gradient(#C4DBD3,#C4DBD3) left bottom no-repeat;
	background-size: 100% 1rem;
}

@media screen and (max-width: 767px) {
  .ec-product__recommend {
    padding: 2rem 2.5rem 2.2rem;
    border-radius: .25rem;
  }

  .ec-product__recommend .ec-product__recommendList li {
    padding-left: 1.9rem;
    font-size: 1.2rem;
  }

  .ec-product__recommend .ec-product__recommendList li:before {
    width: 1.6rem;
    height: 1.5rem;
  }

  .ec-product__recommend .ec-product__recommendList li + li {
    margin-top: 2rem;
  }
}

.ec-product__stepList .ec-product__stepItem {
	border: .1rem solid #ddd;
	border-radius: 1rem;
	padding: 2rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ec-product__stepList .ec-product__stepItem + .ec-product__stepItem {
	margin-top: 1rem;
}

.ec-product__stepList .ec-product__stepItem .step-info {
	display: flex;
	align-items: center;
}

.ec-product__stepList .ec-product__stepItem .step-info .step-info__number {
	width: 4.2rem;
	margin-right: 1.8rem;
}

.ec-product__stepList .ec-product__stepItem .step-info .step-info__number .number {
	width: 4.2rem;
	height: 4.2rem;
	display: flex;
	justify-content: center;
	align-items: center;
	border: .1rem solid #333;
	border-radius: 100%;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 500;
}

.ec-product__stepList .ec-product__stepItem .step-info .step-info__number .caption {
	font-size: 1.1rem;
	line-height: 1.5;
	text-align: center;
	margin-top: .4rem;
	white-space: nowrap;
}

.ec-product__stepList .ec-product__stepItem .step-info .step-info__title {
	font-size: 1.5rem;
	line-height: 1.5;
	font-weight: 500;
	letter-spacing: .08em;
}

.ec-product__stepList .ec-product__stepItem .step-products {
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
}

.ec-product__stepList .ec-product__stepItem .step-products li {
	list-style: none;
	width: 7rem;
	margin-left: 1.8rem;
}

.ec-product__stepList .ec-product__stepItem .step-products li a {
	display: block;
	width: 100%;
	padding-top: 100%;
	border: .1rem solid #ddd;
	border-radius: .5rem;
	overflow: hidden;
	position: relative;
}

.ec-product__stepList .ec-product__stepItem .step-products li a img {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1;
	object-fit: contain;
}

.ec-product__stepList .ec-product__stepItem.is-active {
	border: .15rem solid #00744B;
	color: #00744B;
}

.ec-product__stepList .ec-product__stepItem.is-active .step-info .step-info__number .number {
	border-color: #00744B;
	background: #F3FEFA;
}

.ec-product__stepButton {
	margin-top: 3rem;
}

.ec-product__stepButton .ec-blockBtn--action {
	display: flex;
	justify-content: center;
	align-items: center;
}

.ec-product__stepButton .ec-blockBtn--action:before {
	width: 1.6rem;
	height: 1.8rem;
	content: '';
	background: url(../img/common/icon_badge_wh.svg) center center no-repeat;
	background-size: cover;
	margin-right: 1rem;
}

@media screen and (max-width: 767px) {
  .ec-product__stepList .ec-product__stepItem {
    padding: 1rem 1.5rem;
  }

  .ec-product__stepList .ec-product__stepItem + .ec-product__stepItem {
    margin-top: .5rem;
  }

  .ec-product__stepList .ec-product__stepItem .step-info {
    align-items: flex-start;
  }

  .ec-product__stepList .ec-product__stepItem .step-info .step-info__number {
    width: 3.2rem;
    margin-right: 1.2rem;
    display: flex;
    flex-direction: column;
    height: 7rem;
    align-items: center;
    justify-content: center;
  }

  .ec-product__stepList .ec-product__stepItem .step-info .step-info__number .number {
    width: 3.2rem;
    height: 3.2rem;
    font-size: 1.3rem;
  }

  .ec-product__stepList .ec-product__stepItem .step-info .step-info__number .caption {
    font-size: 1rem;
    margin-top: 0;
  }

  .ec-product__stepList .ec-product__stepItem .step-info .step-info__title {
    font-size: 1.3rem;
  }

  .ec-product__stepList .ec-product__stepItem .step-info .step-info__title p {
    display: flex;
    height: 7rem;
    align-items: center;
  }

  .ec-product__stepList .ec-product__stepItem .step-info .step-info__title p + p {
    margin-top: .5rem;
  }


  .ec-product__stepList .ec-product__stepItem .step-products {
    flex-direction: column;
  }

  .ec-product__stepList .ec-product__stepItem .step-products li {
    margin-left: 0;
  }

  .ec-product__stepList .ec-product__stepItem .step-products li + li {
    margin-top: .5rem;
  }

  .ec-product__stepButton {
    margin-top: 2rem;
  }

  .ec-product__stepButton .ec-blockBtn--action {
    font-size: 1.25rem;
  }

  .ec-product__stepButton .ec-blockBtn--action:before {
    width: 1.25rem;
    height: 1.4rem;
  }
}

#product_review_area {
    border: 0;
    margin: 0;
}

#product_review_area .ec-role {
  padding: 0;
}

#product_review_area .ec-rectHeading {
    cursor: none;
    margin: 3rem 0;
}

#product_review_area .ec-rectHeading h4 {
  padding: 0;
  margin: 0;
  background: none;
  display: flex;
  align-items: flex-end;
}

#product_review_area .ec-rectHeading h4 span {
  font-size: 1.1rem;
  line-height: 1;
  font-weight: 500;
  letter-spacing: .05em;
}

#product_review_area .ec-rectHeading h4 .recommend_average {
  display: flex;
  align-items: flex-end;
  color: #333;
  font-size: 1.6rem;
  line-height: 1;
  margin: 0 .5em 0 0;
}

#product_review_area .ec-rectHeading h4 .recommend_average img {
  width: 16.5rem;
  margin-right: .3rem;
}

#reviewPost .ec-button {
  max-width: 100%;
  margin-bottom: 2.5rem;
}

#product_review_area #reviewContent {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  max-height: 50rem;
  padding-right: 2rem;
}

#product_review_area #reviewContent::-webkit-scrollbar {
  width: .2rem;
}
#product_review_area #reviewContent::-webkit-scrollbar-track {
  margin: 0 1rem 0 0;
  background: #F8F8F8;
  border-radius: .1rem;
}
#product_review_area #reviewContent::-webkit-scrollbar-thumb {
  border-radius: .1rem;
  background: #00744B;
}

#product_review_area .review_list {
    padding-left: 0;
}

#product_review_area .review_list li {
    margin-bottom: 2.5rem;
    padding: 0 0 2.5rem;
    list-style: none;
    border-bottom: .1rem solid #ddd;
}

#product_review_area .review_list li:last-child {
  border-bottom: 0;
  margin-bottom: 0;
}

#product_review_area .review_list p {
  font-size: 1.3rem;
  line-height: 1.5;
  font-weight: 500;
}

#product_review_area .review_list .review_date {
    font-weight: 500;
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center;
    padding-left: 9.2rem;
    position: relative;
    font-size: 1.1rem;
    line-height: 1.5;
    color: #D9D9D9;
    letter-spacing: .05em;
    margin-bottom: 1.3rem;
}

#product_review_area .recommend_average {
    margin-left: 0;
    color: #333;
}

#product_review_area .review_list .recommend_level {
    margin-left: 0;
    color: #333;
    position: absolute;
    left: 0;
    top: .6rem;
    width: 8.5rem;
    z-index: 1;
    line-height: 0;
}

#product_review_area .review_list .recommend_level img {
  width: 100%;
}

#product_review_area .review_list .recommend_name {
    margin-left: 0;
    display: flex;
    align-items: center;
}

#product_review_area .review_list .recommend_name .name {
    font-size: 1.4rem;
    margin-right: 3rem;
    color: #333;
}

#product_review_area .review_list strong {
  font-size: 1.6rem;
  line-height: 1.5;
  font-weight: 500;
  margin-bottom: 1rem;
  display: block;
}

@media screen and (max-width: 767px) {
  #product_review_area .ec-rectHeading {
      margin: 2rem 0 3rem;
  }

  #product_review_area .ec-rectHeading h4 .recommend_average {
    font-size: 1.5rem;
  }

  #product_review_area .ec-rectHeading h4 .recommend_average img {
    width: 12.25rem;
    margin-right: .5rem;
  }

  #reviewPost .ec-button {
    margin-bottom: 3rem;
  }

  #product_review_area #reviewContent {
    max-height: 55rem;
    padding-right: 1rem;
  }

  #product_review_area .review_list li {
      margin-bottom: 2rem;
      padding: 0 0 2rem;
  }

  #product_review_area .review_list p {
    font-size: 1.15rem;
  }

  #product_review_area .review_list .review_date {
    align-items: flex-end;
    padding: 2.5rem 0 0 0;
    font-size: 1rem;
    margin-bottom: 1.5rem;
  }

  #product_review_area .review_list .recommend_level {
      top: 0;
      width: 10rem;
  }

  #product_review_area .review_list .recommend_name {
      margin-left: 0;
      display: flex;
      align-items: center;
  }

  #product_review_area .review_list .recommend_name .name {
    font-size: 1.2rem;
    margin-right: 0;
    position: absolute;
    left: 10.5rem;
    top: 0;
    z-index: 2;
  }

  #product_review_area .review_list strong {
    font-size: 1.3rem;
  }
}

.ec-productRole .ec-productRole__fixed {
  position: fixed;
  left: 0;
  bottom: 3rem;
  width: 66rem;
  max-width: calc(50vw - 5rem);
  padding: 3rem 6rem;
  background: #fff;
  box-shadow: 0 1rem 2.4rem rgba(0, 0, 0, .05);
  border-radius: 0 3rem 3rem 0;
  transform: translateY(calc(100% + 10rem));
  transition: transform .5s;
  z-index: 999;
}

.ec-productRole .ec-productRole__fixed.is-scroll {
  transform: translateY(0);
  transition: transform .5s;
}

.ec-productRole .ec-productRole__fixed.is-scroll-stop {
  position: absolute;
  bottom: -5rem;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__type {
  margin-bottom: 2rem;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__type .ec-productRole__typeSizes li a {
  height: 100%;
  padding: 1.6rem;
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__price {
  padding-bottom: 0;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceWrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceSelect {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceSelect .ec-select {
  margin: 0 0 0 1rem;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceSelect .ec-select select {
  width: 100%;
  height: 4rem;
  border: .1rem solid #DDDDDD;
  border-radius: .5rem;
  background: url(../img/common/icon_dropdown_black.svg) right 1rem center no-repeat #fff;
  background-size: 1.1rem auto;
  padding: 0 2.7rem 0 1.5rem;
  appearance: none;
  font-size: 1.4rem;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceItem {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  align-items: center;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceItem + .ec-productRole__priceItem {
  margin-top: 2rem;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceItem .ec-secHeading h3 {
  margin-bottom: 0;
  font-size: 1.4rem;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__priceItem .ec-secHeading h3:before {
  height: 1.35rem;
  top: .35rem;
}

.ec-productRole .ec-productRole__fixed .ec-price .ec-price__price {
  font-size: 1rem;
}

.ec-productRole .ec-productRole__fixed .ec-price .ec-price__price,
.ec-productRole .ec-productRole__fixed .ec-price .ec-price__tax {
  font-size: 1rem;
}

.ec-productRole .ec-productRole__fixed .ec-price .ec-price__price .price-default {
  margin-right: .1rem;
  font-size: 2.4rem;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__actions {
  margin-top: 0;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__actions .ec-productRole__btn {
  width: 100%;
  min-width: unset;
}

.ec-productRole .ec-productRole__fixed .ec-productRole__actions .ec-productRole__btn .ec-blockBtn--action {
  height: 5rem;
}

@media screen and (max-width: 767px) {
  .ec-productRole .ec-productRole__fixed {
    bottom: 6.5rem;
    width: 100%;
    max-width: 100%;
    padding: 1.5rem 2.5rem;
    box-shadow: 0 -.5rem 1rem rgba(0, 0, 0, .05);
    border-radius: 2rem 2rem 0 0;
  }

  .ec-productRole .ec-productRole__fixed.is-scroll-stop {
    bottom: -5rem;
  }

  .ec-productRole .ec-productRole__fixed .ec-productRole__type {
    display: none;
  }

  .ec-productRole .ec-productRole__fixed .ec-productRole__price {
    padding-bottom: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .5rem;
  }
  .ec-productRole .ec-productRole__fixed .ec-productRole__priceItem {
    display: block;
  }

  .ec-productRole .ec-productRole__fixed .ec-productRole__priceItem + .ec-productRole__priceItem {
    margin-top: 0;
  }

  .ec-productRole .ec-productRole__fixed .ec-productRole__priceWrap {
    display: none;
  }

  .ec-productRole .ec-productRole__fixed .ec-productRole__actions {
    margin-top: 0;
  }

  .ec-productRole .ec-productRole__fixed .ec-productRole__btn .ec-blockBtn--action {
    font-size: 1.1rem;
  }
}

.ec-productRole__select {
  margin-top: 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}

.ec-productRole__fixed .ec-productRole__select {
  margin: 0 0 1rem;
}

.ec-productRole__select .ec-select {
  width: calc(50% - 1rem);
  margin-bottom: 0;
}

.ec-productRole__select .ec-select label {
  display: block;
  font-size: 1.4rem;
  line-height: 1.5;
  font-weight: 500;
}

.ec-productRole__select .ec-select select {
  width: 100%;
  height: 3.3rem;
  border: .1rem solid #DDDDDD;
  border-radius: .5rem;
  background: url(../img/common/icon_dropdown_black.svg) right 1.7rem center no-repeat #fff;
  background-size: 1.1rem auto;
  padding: 0 3.5rem 0 2rem;
  appearance: none;
  font-size: 1.4rem;
}

.ec-productRole__select .ec-select select::-ms-expand {
  display: none;
}

@media screen and (max-width: 767px) {
  .ec-productRole__select {
    margin-top: 1.3rem;
  }

  .ec-productRole__fixed .ec-productRole__select {
    display: none;
  }

  .ec-productRole__select .ec-select {
    width: calc(50% - .4rem);
  }

  .ec-productRole__select .ec-select label {
    font-size: 1.2rem;
  }

  .ec-productRole__select .ec-select select {
    height: 3.5rem;
    background: url(../img/common/icon_dropdown_black.svg) right 1.4rem center no-repeat #fff;
    background-size: 1rem auto;
    padding: 0 2.5rem 0 1.5rem;
    font-size: 1.1rem;
  }

  .ec-modal .ec-modal-box .ec-inlineBtn--cancel,
  .ec-modal .ec-modal-box .ec-inlineBtn--action {
    font-size: 1.2rem;
  }
}



/*20240403*/

/*cart.html*/
.ec-pageHeader h1, .ec-pageHeader .h1 {
  margin: 2rem 0 2.4rem;
  border-bottom: 1px dotted #ddd;
  border-top: 1px solid #ddd;
  padding: 1.5rem 0;
  font-size: 1.2rem;
  font-weight: 600;
}

.ec-cartRole {
  margin: 0 auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box;
  font-size: 16px;
  line-height: 1.4;
  color: #525263;
  -webkit-text-size-adjust: 100%;
  width: 100%;
  max-width: 88rem;
  display: flex;
  flex-wrap: wrap; 
}
.ec-cartRole form {
  padding: 0;
}

.ec-cartRole .ec-cartRole__progress {
    width: 100%;
    text-align: center;
}
.ec-progress {
  margin: 0 auto;
  padding: 0 0 4rem;
  display: table;
  table-layout: fixed;
  width: 100%;
  max-width: 60rem;
  list-style: none;
}

.ec-progress .ec-progress__item {
    display: table-cell;
    position: relative;
    text-align: center;
    font-weight: bold;
    z-index: 10;
} 
.ec-progress .ec-progress__item:after {
    content: "";
    position: absolute;
    display: block;
    background: #525263;
    width: 1.85rem;
    height: 0.1rem;
    top: 2rem;
    left: 100%;
    transform: translateX(-50%);
    z-index: -1;
}
.ec-progress .ec-progress__item:last-child:after {
  display: none;
}
.ec-progress .ec-progress__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  background: #f8f8f8;
  margin-bottom: 5px;
  border: 1px solid #333;
  top: 0;
  left: 18px;
  text-align: center;
  vertical-align: middle;
  border-radius: 50%;
  color:#333;
  font-size: 1.3rem;
}
.ec-progress .is-complete .ec-progress__number {
    background: #00744B;
    border-color: #00744B;
    color: #fff;
}
.ec-progress .ec-progress__label {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.1rem;
}
.ec-progress .is-complete .ec-progress__label {
    color: #00744B;
}

.ec-cartRole .ec-cartRole__totalText {
  margin: 0;
  padding: 0 0 1rem;
  width: 100%;
  letter-spacing: 0.1em;
  text-align: center;
  color: #00744B;
  font-weight: 600;
  font-size: 1.5rem;
}

.ec-cartRole .ec-cartRole__cart {
    margin: 0;
    width: 100%;
}

.ec-cartTable {
    width: 100%; 
  border-top: 0;
}
.ec-cartHeader {
    display: none;
    margin-bottom: 0;
    padding: 1.6rem;
    width: 100%;
    background: #F4F3F0;
}
.ec-cartHeader .ec-cartHeader__label {
  display: table-cell;
  text-align: center;
  background: #F4F3F0;
  overflow-x: hidden;
  font-weight: bold;
  padding: 0;
  font-size: 1.6rem;
}
.ec-cartHeader .wid1 {
    width: 6%;
}
.ec-cartHeader .wid2 {
    width: 64%;
}
.ec-cartHeader .wid3 {
    width: 22%;
}
.ec-cartHeader .wid4 {
    width: 10%;
}

.ec-cartTr {
    padding: 30px 0;
    width: 100%;
    border-bottom: 1px dotted #ccc;
}
.ec-cartRow {
  display: flex;
  padding: 0;
  margin: 0;
  list-style: none;
}
.ec-cartRow .ec-cartRow__delColumn {
  padding: 2.5rem 0;
  width: 3rem;
  border-bottom: 0;
}
.ec-cartRow .ec-cartRow__delColumn .ec-icon img {
    width: 1.5rem;
    height: 1.5rem;
}
.ec-cartRow .ec-cartRow__contentColumn {
    display: flex;
    justify-content: space-between;
    width: calc(100% - 3rem);
  padding: 0;
  border-bottom: 0;
}
.ec-cartRow .ec-cartRow__img {
    max-width: 85px;
    vertical-align: middle;
    padding-right: 10px;
}
.ec-cartRow .ec-cartRow__summary {
    vertical-align: middle;
    width: calc(100% - 85px);
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__shopname {
    margin: 0 0 1rem;
    letter-spacing: 0.1em;
    color: #00744B;
    font-size: 1.4rem;
    font-weight: 700;
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__cool {
    margin-bottom: 1rem;
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__cool span {
    display: inline-block;
    padding: 0.8rem 0.8rem 0.8rem 2.4rem;
    background: url("../img/cart/icon_truck.svg") no-repeat 0.8rem center #E9F5FF;
    border: 1px solid #0073FF;
    border-radius: 2px;
    line-height: 1;
    color: #0073FF;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__discount {
    margin-bottom: 1rem;
    font-size: 1.2rem;
    font-weight: 600;
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__unitPrice {
    font-size: 1.8rem;
    font-weight: 700;
}

.ec-cartRow .ec-cartRow__amountColumn { 
  border-bottom: 0;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amount {
  display: flex;
  align-items: center;
  margin-bottom:0.5rem;
  font-size: 1.6rem;
}
.ec-cartRow__amount .num-jian, 
.ec-cartRow__amount .num-jia {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(100%/3); 
    height: 4rem;
    border: 1px solid #DDDDDD;
    border-radius: 5px;
    text-align: center;
    font-size: 1.2rem;
}

.ec-cartRow__amount a{
    width: calc(100%/3); 
}

.ec-cartRow__amount a .num-jian, 
.ec-cartRow__amount a .num-jia {
    width: 100%; 
}


.ec-cartRow__amount .is-disable {
  pointer-events: none;
}
.ec-cartRow__amount .input-num {
  width: calc(100%/3); 
  background: transparent;
  border: 0;
  outline: none;
  text-align: center;
}
.ec-cartRow__amount .input-num:focus {
  outline: none;
}
.ec-cartRow .ec-cartRow__subtotalColumn .ec-cartRow__sutbtotal {
  font-weight: 700;
  font-size: 1.5rem;
}

.ec-cartRow .ec-cartRow__subtotalColumn {
  display: block;
  margin-top: 0;
  border-bottom: 0;
  width: 100%;
  text-align:left;
}

.ec-blockBtn--check {
    margin-left: auto;
    width: calc(100% - 3rem);
}
.ec-blockBtn--check a {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    height: 4rem;
    border-radius: 0.5rem;
    color: #fff;
    font-size: 1.1rem;
    font-weight: 700;
}
.ec-blockBtn--check .ec-blockBtn--types {
    background: linear-gradient(to left, #086846, #1D9B6E);
}
.ec-blockBtn--check .ec-blockBtn--courses {
    background: linear-gradient(to left, #F07675, #FFC1B0);
}

.ec-cartRole .ec-cartRole__actions {
    width: 100%;
}
.ec-cartRole .ec-cartRole__total {
    padding: 30px 0 36px;
    text-align: right;
    font-weight: bold;
    font-size: 1.3rem;
}
.ec-cartRole .ec-cartRole__totalNum {
    margin-left: 3.8rem;
    font-size: 1.5rem;
}
.ec-cartRole .ec-cartRole__totalAmount {
    margin-left: 4.2rem;
    color: #F07675;
    font-size: 2.2rem;
}
.ec-cartRole__actions a {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    max-width: 27.5rem;
    height: 5rem;
    font-size: 1.2rem;
}
.ec-cartRole .ec-blockBtn--action {
    margin-bottom: 1rem;
}
.ec-cartRole .ec-cartRole__actions .ec-blockBtn--cancel {
    background: none;
    border: .1rem solid #333; 
    color: #333;
}

.ec-cartRole__cart img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.ec-cartRole__convert {
    margin: 2.8rem auto 0;
}
.ec-cartRole__convert a {
    display: block;
    overflow: hidden;
    border-radius: 1rem;
}

/* pc */
@media screen and (min-width: 768px) {
  .ec-pageHeader h1, .ec-pageHeader .h1 {
    border-top: 0;
    border-bottom: 0;
    padding: 0;
    margin: 8rem 0 3.8rem;
    text-align: center;
    font-size: 3rem;
    font-weight: normal;
  }
   
  .ec-progress {
    margin-bottom: 6.2rem;
    padding: 0;
    max-width: 48rem;
  }
  .ec-progress .ec-progress__number {
    font-size: 1.4rem;
  }
  
  .ec-cartRole .ec-cartRole__totalText {
    margin-bottom: 30px;
    padding: 0;
    font-size: 1.8rem;
  }
  
  .ec-cartRole .ec-cartRole__cart {
    margin: 0 auto;
  }
  
  .ec-cartTable {
    border-top: none;
  }
  .ec-cartHeader {
    display: flex;
  }
  
  .ec-cartRow .ec-cartRow__delColumn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    width: 8%;
  }
  .ec-cartRow .ec-cartRow__delColumn .ec-icon img {
    width: 1.6rem;
    height: 1.6rem;
  } 
  .ec-cartRow .ec-cartRow__contentColumn {
    display: grid;
    grid-template-columns: 10rem calc(100% - 12.5rem);
    gap: 2.5rem;
    width: 92%;
  }
  .ec-cartRow .ec-cartRow__img {
    width: 10rem;
    max-width: 10rem;
    padding-right: 0;
  }
  .ec-cartRow .ec-cartRow__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-left: 0;
    width: 100%;
  }
  .ec-cartRow .ec-cartRow__summaryColumn {
    width: 60%;
  }
  .ec-cartRow .ec-cartRow__summary .ec-cartRow__shopname {
    margin: 0 0 1rem;
    font-size: 1.8rem;
  }
  .ec-cartRow .ec-cartRow__summary .ec-cartRow__cool span {
    display: inline-block;
    padding: 0.6rem 1rem 0.6rem 2.8rem;
    font-size: 1.3rem;
  }
  .ec-cartRow .ec-cartRow__summary .ec-cartRow__discount {
    font-size: 1.3rem;
  }
  
  .ec-cartRow .ec-cartRow__amountColumn {
    width: 24%;
    border-bottom: 0;
  }
  .ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amount {
    justify-content: center;
  }
  .ec-cartRow__amount .num-jian, 
  .ec-cartRow__amount .num-jia,
  .ec-cartRow__amount a, 
  .ec-cartRow__amount a {
    width: 4rem;
    height: 5rem;
  }
  
  .ec-cartRow .ec-cartRow__subtotalColumn {
    margin-top: 0;
    width: 15%;
    text-align: right;
  }
  .ec-cartRow .ec-cartRow__subtotalColumn .ec-cartRow__sutbtotal {
    font-size: 1.6rem;
  }
  
  .ec-blockBtn--check {
    width: 28rem;
  }
  
  .ec-cartRole .ec-cartRole__actions {
    margin: 0 auto;
    text-align: center;
  }
  .ec-cartRole .ec-cartRole__totalAmount {
    font-size: 2.4rem;
  } 
  .ec-cartRole .ec-cartRole__actions .btns {
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
  }
  .ec-cartRole__actions a {
    margin: 0;
    max-width: 30rem;
    height: 5.6rem;
    font-size: 1.4rem;
  }
  .ec-cartRole .ec-cartRole__actions .ec-blockBtn--action {
    margin: 0 0 0 4rem;
  }
  
  .ec-cartRole__convert a:hover{
    box-shadow: 0rem 3rem 4rem 0rem rgba(69, 69, 69, 0.15);
  } 
  
  
}



/* campaign.html */
.ec-campaignRole__hdL {
  margin: 0 0 2.4rem;
  text-align: center;
  color: #9C9C9C;
	font-family: "Noto Sans JP", serif;
  font-weight: 700;
  font-size: 2.8rem;
}

.ec-campaignRole__LimiteTime {
  position: fixed;
  right: 9.5rem;
  top: 18rem;
  z-index: 9;
}
.ec-campaignRole__LimiteTime a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 12.5rem;
  height: 12.5rem;
  background: linear-gradient(0deg, rgba(246, 178, 183, 1.00) 0%, rgba(255, 108, 119, 1.00) 100%);
  border-radius: 50%; 
  box-shadow: 0rem 0.4rem 1rem 0rem rgba(0, 0, 0, 0.10); 
  line-height: 1.3;
  color: #fff;
}
.ec-campaignRole__LimiteTime .date {
  display: flex;
  align-items: center;
  font-size: 3.4rem;
}
.ec-campaignRole__LimiteTime .date .suffix {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.5rem;
  width: 2.8rem;
  height: 2.8rem;
  background: #fff;
  border-radius: 50%; 
  color: #F07675;
  font-size: 2rem;
}

.ec-campaignRole__thisMonth {
  padding: 5rem 0 8rem;
  background: url("../img/campaign/bg_thismonth.png")no-repeat center top;
  background-size: cover; 
}
.ec-campaignRole__thisMonth .ec-role {
  max-width: 104rem;
}
.ec-campaignRole__thisMonth h2 {
  padding: 1.2rem 2.4rem;
  margin: 0 auto 6rem;
  max-width: 57.5rem;
  background: url("../img/campaign/hd_bg.svg")no-repeat center;
  background-size: 100% 100%;
  text-align: center;
  letter-spacing: 0.1em;
  color: #fff;
  font-size: 3rem;
  font-weight: normal;
}
.ec-campaignRole__thisMonth h2 img {
  max-width: 57.6rem;
}
.ec-campaignRole__anchors ul {
  display: flex; 
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0 -1rem;
}
.ec-campaignRole__anchors li {
  margin: 0 1rem 2rem;
  width: calc(25% - 2rem); 
}
.ec-campaignRole__anchors li a {
  display: block;
  overflow:hidden;
  transform: all 0.5s;
  padding: 0.5rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 0 1.4rem rgba(0,0,0,0.14);
  text-align: center;
  letter-spacing: 0.08em;
}
.ec-campaignRole__anchors li .img {
  display: flex;
  align-items: center;
  justify-content: center;
}
.ec-campaignRole__anchors li .tit {
  padding: 1.4rem 0;
  font-weight: 500;
  font-size: 1.3rem;
}
.ec-campaignRole__anchors li .foucs {
  font-weight: 700;
}
.ec-campaignRole__anchors li .detail {
  display: block;
  transition: all 0.5s;
  padding: 1rem;
  background-image: linear-gradient(90deg, rgba(236, 255, 255, 1.00), rgba(248, 228, 255, 1.00), rgba(236, 255, 255, 1.00));
  background-position: 0 50%;
  background-size:200%; 
  border-radius: 0rem 0rem 1rem 1rem;
  font-size: 1.3rem;
}
.ec-campaignRole__anchors li.type2 .detail {
  background-image: linear-gradient(90deg, #FBF5D3, #FAE0C9, #FBF5D3);
}
.ec-campaignRole__anchors li.type3 .detail {
  background-image: linear-gradient(90deg, #EAF4FE, #E9E0FB, #EAF4FE);
}
.ec-campaignRole__anchors li.type4 .detail {
  background-image: linear-gradient(90deg, #FEE9E8, #FEE2F9, #FEE9E8);
}
.ec-campaignRole__anchors li .detail:after {
  content: "";
  display: block;
  margin-top: 1rem;
  height: 1rem;
  background: url("../img/common/icon_arr_down.svg") no-repeat center;
  background-size: 1.1rem;
}

.ec-campaignRole__campaignIntrod {
  padding: 6rem 0;
  background: #FFF6FE;
}
.ec-campaignRole__campaignIntrod.type2 {
  background: #FFF7EB;
}
.ec-campaignRole__campaignIntrod.type3 {
  background: #F6F4FC;
}
.ec-campaignRole__campaignIntrod.type4 {
  background: #FFF0F1;
}
.ec-campaignRole__campaignIntrod .ec-role {
  max-width: 90rem;
}
.ec-campaignRole__campaignIntrod .box {
  padding: 4rem 5rem;
  background: #fff;
  border-radius: 2rem;
}
.ec-campaignRole__campaignIntrod .banner {
  margin-bottom: 2.8rem;
}
.ec-campaignRole__campaignIntrod .hd01 {
  margin: 0 0 1.2rem;
  text-align: center;
  line-height: 1.6;
}
.ec-campaignRole__campaignIntrod .hd01 .hot {
  display: inline-block;
  transform: translateY(-50%);
  padding: 0.5rem 2.2rem;
  background: #F07675;
  border-radius: 3rem;
  color: #fff;
  font-family: "Noto Sans JP", serif;
  font-size: 1.2rem;
}
.ec-campaignRole__campaignIntrod .hd01 .jap {
  font-weight: 600;
  font-size: 1.6rem;
}
.ec-campaignRole__campaignIntrod .limitedThis {
  position: relative;
  z-index: 2;
  margin-bottom: 2rem;
  padding: 0 2rem 2rem;
  background: linear-gradient(to left,#F8E4FF,#E2FFFF);
  border-radius: 1rem;
} 
.ec-campaignRole__campaignIntrod .limitedThis:before {
  content:"";
  position: absolute;
  left: 0.4rem;
  right: 0.4rem;
  bottom: 0.4rem;
  top: 0.4rem;
  z-index: -1;
  background: #fff; 
  border-radius: 1rem;
}
.ec-campaignRole__campaignIntrod .limitedThis .title {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  padding-bottom: 1.2rem;
  border-bottom: 0.1rem dashed #DDD;
}
.ec-campaignRole__campaignIntrod .limitedThis .title .tit {
  max-width: 40%;
  text-align: center;
}
.ec-campaignRole__campaignIntrod .limitedThis .title .tit.full {
  width: 100%;
  max-width: inherit;
}
.ec-campaignRole__campaignIntrod .limitedThis .title .txt {
  padding-left: 1.6rem;
  width: calc(100% - 11rem);
  max-width: 70%;
  line-height: 1.4;
  font-size: 1.2rem;
}
.ec-campaignRole__campaignIntrod .limitedThis ul {
  display: flex;
  justify-content: center;
  padding: 0;
  margin: 0 -1rem;
}
.ec-campaignRole__campaignIntrod .limitedThis li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 1rem;
  width: 100%;
}
.ec-campaignRole__campaignIntrod .limitedThis .col03 li {
  max-width: 35%;
  min-width: 26%;
}
.ec-campaignRole__campaignIntrod .limitedThis .col02 li {
  width: auto; 
  min-width: 35%;
  max-width: 50%;
}
.ec-campaignRole__campaignIntrod .limitedThis .img {
  position: relative;
  width: 8rem;
}
.ec-campaignRole__campaignIntrod .limitedThis .img .bor {
  object-fit: cover;
}
.ec-campaignRole__campaignIntrod .limitedThis .img .pic {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
}
.ec-campaignRole__campaignIntrod .limitedThis .info {
  width: calc(100% - 9rem);
}
.ec-campaignRole__campaignIntrod .limitedThis .tit {
  letter-spacing: 0.02em;
  font-family: "Noto Sans JP", serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #F07675;
}

.ec-campaignRole__btn {
  text-align: center;
}
.ec-campaignRole__btn a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: all 0.5s;
  height: 5rem;
  width: 100%;
  max-width: 40rem;
  background: #00744B;
  border-radius: 0.5rem;
  letter-spacing: 0.08em;
  color: #fff;
}
.ec-campaignRole__btn a:after {
  content: "";
  position: absolute;
  right: 2rem;
  top: 0;
  width: 0.6rem;
  height: 100%;
  background: url("../img/common/icon_link_wh.svg")no-repeat center;
  background-size: 100%;
}
.ec-campaignRole__campaignIntrod .notes {
  padding: 1.5rem 2rem;
  margin: 2rem 0 0;
  background: #F8F8F8;
  border: 0.1rem solid #D9D9D9;
  border-radius: 0.5rem;
}
.ec-campaignRole__campaignIntrod .notes li {
  list-style: none;
  padding: 0.3rem 0 0.3rem 1em;
  text-indent: -1em;
  line-height: 1.2;
  letter-spacing: 0.08em;
  font-size: 1.2rem;
}
.ec-campaignRole__campaignIntrod .notes li:before {
  content: "•";
  margin-right: 0.8rem;
}
.ec-campaignRole__campaignIntrod .productDisplay {
  display: flex;
  justify-content: space-between;
}
.ec-campaignRole__campaignIntrod .productDisplay .productImg {
  width: 25rem;
}
.ec-campaignRole__campaignIntrod .productDisplay .productInfo {
  width: calc(100% - 30rem);
}
.ec-campaignRole__campaignIntrod .productDisplay .eligibleProducts .click {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.4rem; 
  border: 1px solid #F07675;
  border-radius: 0.2rem;
  line-height: 2.3rem;
  letter-spacing: 0.05em;
  color: #F07675;
  font-family: "Noto Sans JP", serif;
  font-size: 1.2rem;
  font-weight: 700;
}
.ec-campaignRole__campaignIntrod .productDisplay .eligibleProducts ul {
  margin: 0;
  padding: 0;
}
.ec-campaignRole__campaignIntrod .productDisplay .eligibleProducts li {
  position: relative;
  padding-left: 1rem;
  margin-bottom: 1rem;
  letter-spacing: 0.05em;
  list-style: none;
  font-weight: 500;
}
.ec-campaignRole__campaignIntrod .productDisplay .eligibleProducts li:before {
  content: "";
  display:block;
  position: absolute;
  left:0;
  top: 0.4rem;
  bottom: 0.4rem;
  width: 0.2rem;
  background: #F07675;
  border-radius: 1rem;
}
.ec-campaignRole__campaignIntrod.type2 .limitedThis {
  background: linear-gradient(to left, #FBF5D3, #FAE0C9);
}
.ec-campaignRole__campaignIntrod.type3 .limitedThis {
  background: linear-gradient(to left, #EAF4FE, #E9E0FB);
}
.ec-campaignRole__campaignIntrod.type4 .limitedThis {
  background-image: linear-gradient(to left, #FEE9E8, #FEE2F9);
}
.ec-campaignRole__campaignIntrod .productDisplay .limitedThis {
  margin: 2.8rem 0 0;
} 
.ec-campaignRole__campaignIntrod .productDisplay .hd01 {
  margin: 0;
}
.ec-campaignRole__campaignIntrod .productDisplay .limitedThis .info {
  letter-spacing: 0.06em;
  font-size: 1.4rem;
}
.ec-campaignRole__campaignIntrod .productDisplay .limitedThis .tit {
  letter-spacing: 0.06em;
  font-size: 2.6rem;
}

.ec-campaignRole__campaignIntrod .producrList {
  padding: 0;
  margin: 3.5rem 0 0;
}
.ec-campaignRole__campaignIntrod .producrList li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}
.ec-campaignRole__campaignIntrod .producrList .display {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 60%;
}
.ec-campaignRole__campaignIntrod .producrList .display .img {
  overflow: hidden;
  width: 6rem;
  height: 6rem;
  border-radius: 0.5rem;
}
.ec-campaignRole__campaignIntrod .producrList .display .info {
  width: calc(100% - 7.5rem);
}
.ec-campaignRole__campaignIntrod .producrList .display .tit {
  letter-spacing: 0.05em;
  font-size: 1.4rem;
  font-weight: 500;
}
.ec-campaignRole__campaignIntrod .producrList .data {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}
.ec-campaignRole__campaignIntrod .producrList .price {
  margin-right: 2rem;
  color: #00744B;
  font-weight: 600;
  font-size: 1.2rem;
}
.ec-campaignRole__campaignIntrod .producrList .price .num {
  margin-right: 1rem;
  font-size: 3rem;
}
.ec-campaignRole__campaignIntrod .producrList .price .discount {
  display: inline-block;
  vertical-align: middle; 
  margin: -1.6rem 1rem 0 0;
  padding: 0.4rem 1rem;
  background: #F07675;
  border-radius: 3rem;
  letter-spacing: 0.05em;
  color: #fff;
  font-family: "Noto Sans JP", serif;
  font-size: 1rem;
}
.ec-campaignRole__campaignIntrod .producrList .ec-campaignRole__btn a {
  justify-content:flex-start;
  padding: 0 2rem;
  width: 17.6rem;
  height: 4rem;
  font-size: 1.2rem;
}

.ec-campaignRole__notes {
  padding: 6rem 0 1rem;
}
.ec-campaignRole__notes .ec-role {
  max-width: 100rem;
}
.ec-campaignRole__notes .ec-role .box {
  padding: 2.6rem 3rem;
  margin: 0;
  border: 0.1rem solid #333;
  border-radius: 0.5rem;
  line-height: 1.3;
  letter-spacing: 0.08em;
  font-size: 1.2rem;
}



/* sp */ 
@media screen and (min-width: 768px) {
  .ec-campaignRole__anchors li a:hover {
    color: #333;
  }
  .ec-campaignRole__anchors li a:hover .detail {
    background-position: 100% 50%;
  }
  
  .ec-campaignRole__btn a{
    background-image: linear-gradient(268.97deg, rgba(8, 104, 70, 1) 0%, rgba(29, 155, 110, 1.00) 60%);
    background-position: 100% 50%;
    background-size: 200%;
  }
  .ec-campaignRole__btn a:hover {
    background-position: 50% 50%;
  } 
  
}

@media screen and (max-width: 767px) { 
  .ec-campaignRole__hdL {
    margin-bottom: 3.2rem;
    font-size: 2.3rem;
  }
  
  .ec-campaignRole__LimiteTime { 
    right: 1.5rem;
    top: auto;
    bottom: 8rem; 
  }
  .ec-campaignRole__LimiteTime a { 
    width: 10rem;
    height: 10rem; 
  }
  .ec-campaignRole__LimiteTime .date {
    font-size: 2.7rem;
  }
  .ec-campaignRole__LimiteTime .date .suffix {
    margin-left: 0.5rem;
    width: 2.2rem;
    height: 2.2rem;
    font-size: 1.3rem;
  } 
  
  .ec-campaignRole__thisMonth {
    padding: 2.5rem 0 3.5rem;
  }
  .ec-campaignRole__thisMonth h2 {
    padding: 0.6rem 2.4rem;
    margin-bottom: 4rem;
    background-image: url(../img/campaign/hd_bg_sp.svg);
    font-size: 2.5rem;
  }  
  .ec-campaignRole__anchors ul {
    margin: 0 -0.6rem;
  }
  .ec-campaignRole__anchors li {
    margin: 0 0.6rem 2rem;
    width: calc(50% - 1.2rem);
  }
  
  .ec-campaignRole__campaignIntrod {
    padding: 4.5rem 0;
  }
  .ec-campaignRole__campaignIntrod .box {
    padding: 4rem 2rem 2.4rem; 
    border-radius: 1rem;
  } 
  .ec-campaignRole__campaignIntrod .limitedThis {
    margin-bottom: 2.5rem;
  }
  .ec-campaignRole__campaignIntrod .limitedThis ul {
    display: block;
    margin: 0 -0.5rem;
  }
  .ec-campaignRole__campaignIntrod .limitedThis li {
    margin: 0 0 1rem;
  }
  .ec-campaignRole__campaignIntrod .limitedThis .col03 li,
  .ec-campaignRole__campaignIntrod .limitedThis .col02 li {
    max-width: none;
    min-width:inherit;
  }
  .ec-campaignRole__campaignIntrod .limitedThis .img {
    width: 6.5rem;
  }
  .ec-campaignRole__campaignIntrod .limitedThis .info {
    width: calc(100% - 7.5rem);
  }
  .ec-campaignRole__campaignIntrod .limitedThis .tit {
    font-size: 1.3rem;
  }
  .ec-campaignRole__campaignIntrod .limitedThis .title {
    margin-bottom: 1.2rem;
  }
  .ec-campaignRole__campaignIntrod .limitedThis .title .tit {
    font-size: 1.8rem;
  }
  .ec-campaignRole__campaignIntrod .limitedThis .title .txt { 
    padding-left: 0.6rem;
    width: calc(100% - 7rem); 
    font-size: 1rem;
  }
  
  .ec-campaignRole__btn a {
    height: 4rem;
    font-size: 1.1rem;
  }
  .ec-campaignRole__btn a:after {
    right: 1.5rem;
    width: 0.5rem;
  }
  
  .ec-campaignRole__campaignIntrod .notes {
    margin-top: 2.5rem;
  }
  
  .ec-campaignRole__campaignIntrod .productDisplay {
    display: block;
  }
  .ec-campaignRole__campaignIntrod .productDisplay .productImg {
    margin-bottom: 2rem;
    width: auto;
    text-align: center;
  }
  .ec-campaignRole__campaignIntrod .productDisplay .productInfo {
    width: auto;
  }
  .ec-campaignRole__campaignIntrod .productDisplay .eligibleProducts .click {
    margin-bottom: 1.2rem;
    line-height: 2.6rem; 
    font-size: 1.1rem; 
  }
  .ec-campaignRole__campaignIntrod .productDisplay .eligibleProducts li {
    padding-left: 0.6rem;
    font-size: 1.5rem;
  }
  
  .ec-campaignRole__campaignIntrod .productDisplay .limitedThis .info {
    letter-spacing: 0.08em;
    font-size: 1rem;
  }
  .ec-campaignRole__campaignIntrod .productDisplay .limitedThis .tit {
    font-size: 1.5rem;
  }
  .ec-campaignRole__campaignIntrod .producrList li {
    display: block;
    margin-bottom: 2.5rem;
  }
  .ec-campaignRole__campaignIntrod .producrList .display {
    width: auto;
  }
  .ec-campaignRole__campaignIntrod .producrList .price {
    margin-right: 0;
    text-align: right;
  }
  .ec-campaignRole__campaignIntrod .producrList .price .num {
    margin-right: 0.6rem;
    font-size: 2.5rem;
  }
  .ec-campaignRole__campaignIntrod .producrList .ec-campaignRole__btn {
    width: 100%;
  }
  .ec-campaignRole__campaignIntrod .producrList .ec-campaignRole__btn a {
    justify-content: center;
    width: 100%; 
    font-size: 1.1rem;
  }
  
  .ec-campaignRole__campaignIntrod .producrList .display .info {
    width: calc(100% - 7rem);
  }
  .ec-campaignRole__campaignIntrod .producrList .display .tit {
    font-size: 1.2rem;
  }
  .ec-campaignRole__campaignIntrod .producrList .data {
    margin-top: 1rem;
  }
  
  .ec-campaignRole__notes {
    padding: 4rem 0 1rem;
  }
  .ec-campaignRole__notes .ec-role .box {
    padding: 3rem 2.5rem;
    font-size: 1.1rem;
  }
  
}


/* guide.html */ 
.ec-commonRole__hdL {
  margin: 0 0 3.2rem;
  text-align: center;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-size: 3rem;
}
.ec-commonRole__hdM {
  margin: 0 0 2.4rem;
  letter-spacing: 0.08em;
  font-weight: 400;
  font-size: 2.2rem;
}
.ec-commonRole__hdS {
  position: relative;
  margin: 0 0 1.6rem;
  padding: 1.6rem 1rem 1.6rem 1.3rem;
  background: #F8F8F8;
  letter-spacing: 0.1em;
  color: #00744B;
  font-weight: 600;
  font-size: 1.8rem;
}
.ec-commonRole__hdS:before {
  content: "";
  position: absolute;
  left: 0;
  top: 2rem;
  bottom: 2rem;
  min-height: 1.5rem;
  border-left: 0.3rem solid #00744B;
}
.ec-commonRole__hdP {
  margin: 0 0 4rem;
  padding: 0.9rem 2rem 1.1rem 5rem;
  background: url("../img/service/icon_park.svg") no-repeat 2rem center #F3FEFA;
  font-size: 1.5rem;
  font-weight: 600;
}
.ec-commonRole__hdP .big {
  font-size: 2.5rem;
}
.ec-commonRole__hd01 {
  margin: 0 0 1.6rem;
  letter-spacing: 0.1em;
  line-height: 1.7;
  font-weight: 600; 
  font-size: 1.6rem;
} 
.ec-commonRole__hd02 {
  padding: 0.4rem 2rem;
  margin: 0 0 2rem; 
  background: #F8F8F8;
  font-weight: 600; 
  font-size: 1.5rem;
} 
.ec-commonRole__sub {
  margin-bottom: 3.2rem;
  text-align: center;
  letter-spacing: 0.08em;
  line-height: 1.6;
  font-size: 1.4rem;
}
.ec-commonRole__sub p {
  margin: 0 0 2.4rem;
}

.ec-commonRole__detailStyle p {
  line-height: 1.4;
  letter-spacing: 0.1em;
  font-size: 1.3rem;
}
.ec-commonRole__detailStyle figure {
  margin: 0 auto 5rem;
}
.ec-commonRole__detailStyle .note {
  margin-top: 2rem;
  font-size: 1rem;
}

 
.ec-guideRole__notes li {
  list-style: none;
  margin-bottom: 0.5rem;
  text-indent: -1em;
  line-height: 1.4;
  letter-spacing: 0.1em;
  font-size: 1.3rem;
}
.ec-guideRole__notes li:before {
  content: "•";
  margin-right: 0.65rem;
}
.ec-guideRole__notes a {
  text-decoration: underline;
}
.ec-guideRole__notes a:hover {
  text-decoration: none;
}

.ec-guideRole__shopping {
  padding: 7rem 0 2rem;
} 

.ec-guideRole__telBox {
  display: flex;
  justify-content: center;
  padding: 2.5rem 3rem;
  border: 1px solid #ddd;
  border-radius: 1rem;
}
.ec-guideRole__telBox .th {
  display: flex;
  align-items: center;
  padding-right: 3rem;
  letter-spacing: 0.08em;
  font-size: 1.2rem;
}
.ec-guideRole__telBox .td {
  display: flex;
  align-items: center;
  padding-left: 3rem;
  border-left: 1px solid #ddd;
  color: #00744B;
  font-size: 1.2rem;
}
.ec-guideRole__telBox .tel {
  margin-right: 1.2rem;
  padding-left: 4.8rem;
  background: url("../img/common/icon_tel_gre.svg")no-repeat left center;
  letter-spacing: 0.02em;
  line-height: 1.4;
  color: inherit;
  font-weight: 500;
  font-size: 3.6rem;
}

.ec-guideRole__contentBox {
  display: flex;
  padding: 3.6rem 0;
  margin-top: 2rem;
  background: #F8F8F8;
}
.ec-guideRole__contentBox .item {
  position: relative;
  width: 50%;
  text-align: center;
}
.ec-guideRole__contentBox .item + .item:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 1rem;
  height: 5rem;
  border-left: 1px solid #D9D9D9;
}
.ec-guideRole__contentBox .tit {
  margin-bottom: 1.6rem;
  letter-spacing: 0.06em;
}
.ec-guideRole__contentBox .tit span {
  border-bottom: 1px solid;
}
.ec-guideRole__contentBox .ec-campaignRole__btn a {
  max-width: 30.3rem;
  height: 4.6rem;
  font-size: 1.5rem;
}

.ec-guideRole__detailPart {
  margin-top: 5rem;
}
.ec-guideRole__shopping .part {
  margin-bottom: 3.2rem;
}


.ec-commonRole__anchorarea {
  position: relative;
}
.ec-commonRole__anchorarea .anchor{
  position: absolute;
  top: -7.5rem;
}
.ec-commonRole__anchors {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  padding: 0;
  margin: 0;
}
.ec-commonRole__anchors li {
  list-style: none;
}
.ec-commonRole__anchors li a {
  display: flex;
  align-items: center;
  transition: opacity .5s;
  padding: 0 2rem;
  width: 100%;
  height: 5rem;
  background: url("../img/common/icon_arr_down.svg")no-repeat right 2rem center;
  background-size: 1.1rem; 
  border-radius: .5rem; 
  border: .1rem solid #D9D9D9;
  font-size: 1.3rem;
}
.ec-commonRole__anchors li:nth-child(even) a {
  background-color: #F8F8F8; 
}
.ec-commonRole__anchors li a:hover {
  color: #333;
}

.ec-guideRole__shopping .shoppingCon {
  padding: 3rem;
  margin: 1.5rem 0;
  background: #F8F8F8;
  border: 0.1rem solid #DDDDDD;
}
.ec-guideRole__shopping .shippingCost {
  margin: 0 auto;
  max-width: 70rem;
}
.ec-guideRole__shopping .table01 {
  position: relative;
  border-radius: 0.4rem;
}
.ec-guideRole__shopping .table01:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border: 0.1rem solid #333;
  border-radius: 0.4rem;
}
.ec-guideRole__shopping .table01 table {
  width: 100%;
  text-align: center;
}
.ec-guideRole__shopping .table01 th {
  height: 8rem;
  background: #749886;
  letter-spacing: 0.1em;
  line-height: 1.4;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 400;
}
.ec-guideRole__shopping .table01 th + th {
  border-left: 0.1rem solid #333;
}
.ec-guideRole__shopping .table01 tbody th {
  background: #F3FEFA;
  color: #333;
}
.ec-guideRole__shopping .table01 td {
  border: 0.1rem solid #333;
  border-right: 0;
  border-bottom: 0;
  letter-spacing: 0.02em;
  font-size: 1.5rem;
}
.ec-guideRole__shopping .table01 thead th:first-child {
  border-top-left-radius: 0.4rem;
}
.ec-guideRole__shopping .table01 thead th:last-child {
  border-top-right-radius: 0.4rem;
}
.ec-guideRole__shopping .table01 tbody tr:last-child th {
  border-top: 0.1rem solid #333;
  border-bottom-left-radius: 0.4rem;
}
.ec-guideRole__shopping .table01 td:last-child {
  border-bottom-right-radius: 0.4rem;
}
.ec-guideRole__shopping .table01 .free {
  background: #FFF5F4;
  color: #F07675;
}
.ec-guideRole__shopping .table01 .big {
  font-size: 1.8rem;
}
.ec-guideRole__shopping .shippingCost .note {
  margin-top: 1rem; 
  font-size: 1.2rem;
}
.ec-guideRole__shopping .logos {
  text-align: center;
}
.ec-guideRole__shopping .logos .pay {
  max-width: 30rem;  
}
.ec-guideRole__shopping .logos .pay2 {
  max-width: 70rem;  
}
.ec-guideRole__shopping .logos .pay3 {
  max-width: 62rem;  
}

.ec-orderDelivery__actions .is-hide{
  display: none;
}


/*  sp  */
@media screen and (max-width: 767px) { 
  .ec-commonRole__hdL {
    margin-bottom: 3.6rem; 
    letter-spacing: 0.08em; 
    font-size: 2.6rem;
  }
  .ec-commonRole__hdM { 
    letter-spacing: 0.05em; 
    font-size: 1.8rem;
  }
  .ec-commonRole__hdS {
    margin-bottom: 2.5rem;
    padding: 1.2rem 1rem 1.2rem 0.8rem; 
    letter-spacing: 0.1em; 
    font-size: 1.5rem;
  }
  .ec-commonRole__hdS:before { 
    top: 1.3rem;
    bottom: 1.3rem;
    min-height: 1.25rem; 
  }
  .ec-commonRole__hdP {
    margin: 0 0 2rem;
    padding: 0.9rem 2rem 1.1rem 4.2rem;
    background-position: 1.5rem center;
    font-size: 1.1rem; 
  }
  .ec-commonRole__hdP .big {
    font-size: 2rem;
  }
  .ec-commonRole__hd01 { 
    font-size: 1.4rem;
  }
  .ec-commonRole__hd02 {
    padding: 1rem; 
    font-size: 1.2rem;
  }
  .ec-commonRole__sub {
    margin-bottom: 2.8rem;
    font-size: 1.2rem;
  }
  
  .ec-guideRole__shopping {
    padding: 5rem 0 1rem;
  }
  .ec-guideRole__telBox {
    display: block;
    padding: 2.5rem 1rem;
    text-align: center;
  }
  .ec-guideRole__telBox .th {
    display: block;
    padding: 0 0 1rem;
    letter-spacing: 0.05em;
    font-size: 1.35rem;
  }
  .ec-guideRole__telBox .td {
    display: block; 
    padding-left: 0;
    border-left: 0;
    font-size: 1.2rem;
  }
  .ec-guideRole__telBox .tel {
    margin: 0;
    padding-left: 3.8rem; 
    background-size: 2.8rem;
    letter-spacing: 0.03em;
    line-height: 1.4;
    font-size: 3rem;
  }
  .ec-guideRole__telBox .time {
    display: block;
    margin-top: 1rem;
  }
  .ec-guideRole__contentBox {
    display: block;
    padding: 2rem 3rem;
    margin-top: 1.5rem;
  }
  .ec-guideRole__contentBox .item { 
    padding: 1.8rem 0;
    margin: 0 auto;
    width: 25rem; 
  }
  .ec-guideRole__contentBox .item + .item:before {
    content: none;
  }
  .ec-guideRole__contentBox .tit {
    margin-bottom: 1rem;
    font-size: 1.3rem;
  }
  .ec-guideRole__contentBox .ec-campaignRole__btn a { 
    justify-content: flex-start;
    padding: 0 2.2rem;
    height: 4.5rem; 
    font-weight: 500;
    font-size: 1.25rem;
  }
  
  .ec-commonRole__anchors {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 0.75rem 0;
  }
  .ec-commonRole__anchors li a {
    height: 4.4rem;
    font-size: 1rem;
  }
  
  .ec-guideRole__detailPart {
    margin-top: 4rem;
  }
  
  .ec-commonRole__detailStyle p {
    line-height: 1.8; 
    font-size: 1.1rem;
  }
  .ec-guideRole__notes li { 
    margin-bottom: 0; 
    line-height: 1.8;
    font-size: 1.1rem;
  }
  .ec-guideRole__shopping .shoppingCon {
    padding: 2.5rem;
    margin: 1.2rem -2.5rem;
    border: 0;
  }
  
  .ec-guideRole__shopping .table01 th {
    height: 5rem;
    letter-spacing: 0.02em;
    font-size: 0.9rem;
  }
  .ec-guideRole__shopping .table01 td {
    font-size: 0.9rem;
  } 
  .ec-guideRole__shopping .table01 .big {
    font-size: 1.2rem;
  }
  
  .ec-guideRole__shopping .logos .pay {
    max-width: 29.5rem;
  } 
}
 

/* firstuser.html */ 
.ec-firstuserRole {
  padding: 7rem 0 2rem;
}

.ec-firstuserRole .ec-commonRole__sub {
  margin-bottom: 3.2rem;
  letter-spacing: 0.1em;
  line-height: 2.1;
  font-size: 1.5rem;
}
.ec-firstuserRole .ec-commonRole__detailStyle p {
  line-height: 1.8;
}
.ec-firstuserRole .bnr {
  margin: 1.6rem 0 0;
  max-width: 49rem;
}
.ec-firstuserRole .ec-footerMenu {
  margin-top: 1.6rem;
}
.ec-firstuserRole .ec-footerMenu li {
  border: 1px solid #003722;
}
.ec-firstuserRole .ec-footerMenu li a {
    transition: all 0.3s;
}


/* faq.html */
.ec-faqRole {
  padding: 8rem 0 1rem;
}

.ec-faqRole .ec-commonRole__hd01 {
  margin-bottom: 2.2rem;
  font-weight: 400;
}
.ec-faqRole_list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ec-faqRole_list > li {
  margin-bottom: 1.5rem;
  letter-spacing: 0.1em;
}
.ec-faqRole_list .quest {
  cursor: pointer;
  position: relative;
  padding: 1.7rem 4rem 1.7rem 6rem;
  background: #F8F8F8;
  line-height: 1.437;
  color: #00744B;
  font-size: 1.8rem;
}
.ec-faqRole_list .quest:after {
  content: "";
  position: absolute;
  right: 2rem;
  top: 0;
  height: 100%;
  width: 1.2rem;
  background: url("../img/common/icon_arr_down.svg")no-repeat center;
  background-size: 100%;
}
.ec-faqRole_list .is-active:after {
  transform: rotate(180deg);
}
.ec-faqRole_list .answer {
  display: none;
  position: relative;
  padding: 1.6rem 0 3rem 7rem;
  line-height: 1.4;
  font-size: 1.3rem;
}
.ec-faqRole_list .answer ul.notes {
  padding: 0;
}
.ec-faqRole_list .answer .notes li {
  margin-bottom: 0;
  list-style: none;
  line-height: 1.4;
}
.ec-faqRole_list .answer .notes li:before {
  content: "●"; 
}
.ec-faqRole_list .quest:before,
.ec-faqRole_list .answer:before,
.ec-faqRole_list .answer .tit:before{
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 2rem;
  padding: 0 0 0.2rem;
  width: 3rem;
  height: 3rem;
  border-radius: 100%;
  border: 1px solid #00744B;
  font-size: 1.4rem;
}
.ec-faqRole_list .quest:before {
  content:"Q";
  top: 50%;
  transform: translateY(-50%);
  background: #00744B;
  color: #fff;
}
.ec-faqRole_list .answer:before {
  content:"A"; 
  color: #00744B;
}
.ec-faqRole_list .answer .tit:before {
  color: #00744B;
}
.ec-faqRole_list .answer p {
  margin-bottom: 2rem;
}
.ec-faqRole_list .answer a {
  border-bottom: 1px dashed;
}

/*service.html*/
.ec-serviceRole {
  padding: 8rem 0 1rem;
}

.ec-serviceRole .ec-commonRole__hdS {
  margin-bottom: 3rem;
}
.ec-serviceRole .ec-commonRole__sub {
  line-height: 2.1;
  letter-spacing: 0.1em;
  font-size: 1.5rem;
}

.ec-serviceRole__regularCourses > ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  list-style: none;
  padding: 0;
  margin: 2rem 0 0;
}
.ec-serviceRole__regularCourses > ul > li {
  padding: 2rem 10rem 2rem 4rem;
  background: no-repeat right 2.8rem center;
  background-size: 4.8rem;
  border-radius: 0.5rem;
  border: 0.1rem solid #D9D9D9;
  box-shadow: 0 0.3rem 1rem rgba(51,51,51,0.04);
  letter-spacing: 0.05em;
  font-size: 1.3rem;
}
.ec-serviceRole__regularCourses .benefit01 {
  background-image: url("../img/service/icon_money_gre.svg");
}
.ec-serviceRole__regularCourses .benefit02 {
  background-image: url("../img/service/icon_gift_gre.svg");
}
.ec-serviceRole__regularCourses .benefit03 {
  background-image: url("../img/service/icon_truck_gre.svg");
}
.ec-serviceRole__regularCourses .benefit04 {
  background-image: url("../img/service/icon_calendar_gre.svg");
}
.ec-serviceRole__regularCourses .benefit {
  margin-bottom: 1rem;
}
.ec-serviceRole__regularCourses .benefit span {
  display: inline-block;
  padding: 0.5rem 2rem;
  background: #00744B;
  border-radius: 2rem;
  color: #fff;
  font-size: 1.3rem;
}
.ec-serviceRole__regularCourses .tit {
  margin: 0.3rem 0 0;
  line-height: 1.4375;
  font-weight: 600;
}
.ec-serviceRole__regularCourses .tit .focus {
  color: #CE6E75;
  font-size: 1.6rem;
}
.ec-serviceRole__regularCourses .tit2 {
  font-size: 1.8rem;
}
.ec-serviceRole__regularCourses .tit3 {
  margin-bottom: 1rem;
  text-align: center;
  font-size: 1.6rem;
}
.ec-serviceRole__regularCourses .focus2 {
  color: #00744B;
  font-size: 2.2rem;
}
.ec-serviceRole__regularCourses .note {
  font-size: 1rem;
}

.ec-serviceRole__regularCourses .col02 {
  grid-template-columns: repeat(2, 1fr);
}
.ec-serviceRole__regularCourses .col02 > li {
  padding: 2rem 2rem 2rem 4rem;
  background-position: right 4rem top 3rem;
}
.ec-serviceRole__regularCourses .hotStyle .tit {
  margin:0;
  font-size: 2.6rem;
  font-weight: 400;
}
.ec-serviceRole__regularCourses .hotStyle .focus {
  font-size: 3.6rem;
}

.ec-serviceRole__subscription {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  list-style: none;
  padding: 0;
}
.ec-serviceRole__subscription li {
  display: flex;
  align-items: center;
  padding: 2rem 4rem;
  min-height: 8rem;
  background: #FBF7F6;
  border: 1px solid #CE6E75;
  border-radius: 0.5rem;
  letter-spacing: 0.05em;
  font-size: 1.8rem;
}
.ec-serviceRole__subscription li:nth-of-type(3n+1) {
  background: #F3FEFA;
  border-color: #00744B;
}

.ec-serviceRole__productList .part {
  margin-bottom: 2rem;
}

.ec-serviceRole__orderFlow .part {
  margin-bottom: 3.6rem;
}
.ec-serviceRole__orderFlow .tit {
  margin: 0 0 1.6rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
  font-size: 1.3rem;
}
.ec-serviceRole__orderFlow .img {
  padding: 3rem;
  margin-top: 1.6rem;
  background: #F8F8F8;
  border: 1px solid #ddd;
  text-align: center;
}
.ec-serviceRole__orderFlow .img img {
  max-width: 70rem;
  border-radius: 1rem;
}
.ec-serviceRole__orderFlow .note {
  padding: 0 2rem;
  line-height: 1.3;
  font-size: 1rem;
}

.ec-faqRole_list .ec-serviceRole__regularCourses .col02 > li {
  padding: 2rem;
}
.ec-faqRole_list .ec-serviceRole__regularCourses .focus2 { 
  font-size: 1.6rem;
}
.ec-faqRole_list .answer .ec-serviceRole__regularCourses p {
  margin-bottom: 0.5rem;
}


@media screen and (min-width: 768px) {  
  .ec-firstuserRole .ec-footerMenu li a:hover {
    opacity: 1;
    background: #F3FEFA;
  }
}
@media screen and (max-width: 767px) { 
  .ec-firstuserRole .ec-commonRole__sub {
    margin-bottom: 3.2rem;
    letter-spacing: 0.14em;
    line-height: 1.8;
    text-align: left;
  }
  
  .ec-commonRole__detailStyle figure {
    margin-bottom: 4.5rem;
  }
  
  .ec-firstuserRole .ec-footerMenu {
    gap: 2.5rem;
    margin-top: 2.2rem;
  }
  
  
  .ec-faqRole {
    padding: 5rem 0 1rem;
  }
  
  .ec-faqRole .ec-commonRole__hd01 {
    font-size: 1.8rem;
  }
  
  .ec-faqRole_list .quest { 
    padding: 1.6rem 3.3rem 1.6rem 4.2rem;
    font-size: 1.3rem;
  }
  .ec-faqRole_list .quest:after {
    right: 1.5rem;
    width: 1rem;
  }
  .ec-faqRole_list .answer {
    padding: 1.5rem 1.5rem 1rem;
    line-height: 1.4;
    font-size: 1.1rem;
  }
  .ec-faqRole_list .quest:before, 
  .ec-faqRole_list .answer:before,
  .ec-faqRole_list .answer .tit:before {
    left: 1.5rem;
    padding: 0 0 0.3rem;
    width: 2rem;
    height: 2rem;
    font-size: 1.2rem;
  }
  .ec-faqRole_list .answer:before {
    content: none;
  }
  .ec-faqRole_list .answer .tit:before {
    content: "A";
    display: inline-flex;
    position: static;
    margin-right: 0.8rem;
    padding: 0 0 0.1rem;
    color: #00744B;
  } 
  
  
  .ec-serviceRole {
    padding: 5rem 0 1rem;
  }
  .ec-serviceRole .ec-commonRole__sub {
    line-height: 1.6;
    letter-spacing: 0.08em;
    font-size: 1.3rem;
  }
  
  .ec-serviceRole__regularCourses ul,
  .ec-serviceRole__regularCourses .col02{ 
    grid-template-columns: repeat(1, 1fr); 
  }
  .ec-serviceRole__regularCourses > ul > li,
  .ec-serviceRole__regularCourses .col02 > li {
    padding: 2rem 1.8rem;
    background-position: right 2rem top 2rem;
  }
  .ec-serviceRole__regularCourses .benefit {
    margin-bottom: 1.8rem;
  }
  .ec-serviceRole__regularCourses .benefit span {
    padding: 0.5rem 2.7rem; 
    font-size: 1.2rem;
  }
  .ec-serviceRole__regularCourses .tit {
    margin: 0.2rem 0;
    font-weight: 400;
  }
  .ec-serviceRole__regularCourses .tit2 {
    font-size: 1.3rem;
  }
  .ec-serviceRole__regularCourses .tit3 {
    margin-bottom: 1.6rem; 
    text-align: left;
    font-size: 1.8rem;
  }
  .ec-serviceRole__regularCourses .tit .focus {
    font-size: 2.7rem;
  }
  .ec-serviceRole__regularCourses .focus2 { 
    font-size: 2.5rem;
  }
  
  .ec-serviceRole__regularCourses .hotStyle .tit {
    font-size: 1.8rem;
  }
  .ec-serviceRole__regularCourses .hotStyle .focus {
    font-size: 3.2rem;
  }
  
  .ec-serviceRole__subscription { 
    grid-template-columns: repeat(1, 1fr);
  }
  .ec-serviceRole__subscription li {
    justify-content: center;
    padding: 2rem 0.5rem;
    min-height: 7rem;
    border-radius: 0.5rem;
    letter-spacing: 0.04em;
    text-align: center;
    font-size: 1.4rem;
  }
  .ec-serviceRole__subscription li:nth-of-type(3n+1) {
    background: #FBF7F6;
    border-color: #CE6E75;
  }
  .ec-serviceRole__subscription li:nth-of-type(odd) {
    background: #F3FEFA;
    border-color: #00744B;
  }
  
  .ec-serviceRole__orderFlow .img {
    margin: 1.6rem -2.5rem 0;
    border: 0;
  }
   
}



/* about */
.ec-aboutRole {
  padding: 8rem 0 1rem;
}
.ec-aboutRole .ec-commonRole__sub {
  line-height: 2;
  letter-spacing: 0.1em;
  font-size: 1.5rem;
}

.ec-aboutRole .ec-serviceRole__regularCourses {
  margin-top: 2rem;
}
.ec-aboutRole .ec-serviceRole__regularCourses li {
  padding: 2rem 3rem;
}
.ec-aboutRole .ec-serviceRole__regularCourses .benefit05 {
  background-image: url("../img/service/icon_parks.png");
  background-position: right 3.6rem bottom 2.8rem;
  background-size: 6.5rem;
}
.ec-aboutRole .ec-serviceRole__regularCourses .benefit {
    margin-bottom: 1.6rem;
}
.ec-serviceRole__regularCourses .col01 {
  grid-template-columns: repeat(1, 1fr);
}
.ec-serviceRole__regularCourses .flexStyle {
  display: flex;
  align-items: center; 
}
.ec-serviceRole__regularCourses .flexStyle .tit {
  margin: 0 1rem 0.8rem 0;
}

.ec-aboutRole .table01 {
  position: relative;
  margin: 1.6rem 0;
}
.ec-aboutRole .table01 table:before {
  content: "";
  pointer-events: none;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border: 1px solid #333;
  border-radius: 0.4rem;
}
.ec-aboutRole .table01 table{
  position: relative;
  width: 100%;
  text-align: center;
}
.ec-aboutRole .table01 .type1 {
  background: #EBF3F5;
}
.ec-aboutRole .table01 .type2 {
  background: #EBF5ED;
}
.ec-aboutRole .table01 .type3 {
  background: #F6F9E6;
}
.ec-aboutRole .table01 th {
  padding: 1rem 0;
  font-weight: normal;
}
.ec-aboutRole .table01 thead th {
  border-width: 0 1px 1px 1px;
  border-style: solid;
  font-size: 1.5rem;
}
.ec-aboutRole .table01 thead th:first-child {
  border-left: 0;
}
.ec-aboutRole .table01 thead th:last-child {
  border-right: 0;
}
.ec-aboutRole .table01 tbody th {
  width: 14rem;
  font-size: 1.4rem;
}
.ec-aboutRole .table01 td{
  border-left: 1px solid;
  font-size: 1.8rem;
}
.ec-aboutRole .table01 .big {
  font-size: 2.2rem;
}
.ec-aboutRole .table01 .sign {
  display: inline-block;
  vertical-align: middle;
  margin: 0 0.5rem;
  width: 2.2rem;
}

.ec-color-green {
  color: #00744B;
}

.ec-aboutRole .ec-guideRole__notes {
  margin: 2.4rem 0 0;
}


.ec-aboutpointRole {
  padding: 8rem 0 1rem;
}
.ec-serviceRole__regularCourses .also {
  display: flex;
  padding: 1rem 0 2.4rem;
}
.ec-serviceRole__regularCourses .also p {
  padding: 0.1rem 2rem 0.1rem 2.6rem;
  background: no-repeat left center;
  background-size: 2rem;
  letter-spacing: 0.05em;
  font-size: 1.6rem;
}
.ec-serviceRole__regularCourses .also span {
  display: inline-block;
  margin-right: 0.6rem;
  padding: 0 0.7rem;
  border-radius: 2rem;
  font-size: 1.4rem;
}
.ec-serviceRole__regularCourses .also .gre {
  background-image: url("../img/common/icon_user_green.svg");
}
.ec-serviceRole__regularCourses .also .red {
  background-image: url("../img/common/icon_user_red.svg");
}
.ec-serviceRole__regularCourses .also .gre span {
  background: #DEF4EC;
}
.ec-serviceRole__regularCourses .also .red span {
  background: #FBECE8;
}

.ec-serviceRole__regularCourses .display {
  display: flex;
  justify-content: center;
  align-items: center;
}
.ec-serviceRole__regularCourses .display .img {
  margin-right: 2.6rem;
  width: 10rem;
}
.ec-serviceRole__regularCourses .bnrLink {
  margin: 2rem auto;
  max-width: 49rem;
  transition: all .5s;
}

.ec-commonRole__noteSerial {
  margin-bottom: 2rem;
}
.ec-commonRole__noteSerial li {
  line-height: 1.4;
  letter-spacing: 0.1em;
  font-size: 1.3rem;
}

.ec-serviceRole__regularCourses .ec-aboutRole__getPoints { 
  margin: 1.8rem 0;
}
.ec-serviceRole__regularCourses .ec-aboutRole__getPoints.gird2 {
  grid-template-columns: 1fr 2fr;
}
.ec-serviceRole__regularCourses .ec-aboutRole__getPoints li {
  padding: 2rem 2.8rem;
  box-shadow: 0 0 0;
} 
.ec-serviceRole__regularCourses .ec-aboutRole__getPoints li p {
  letter-spacing: 0.05em;
}
 
.ec-serviceRole__regularCourses .ec-aboutRole__getPoints .note {
  margin-top: 1.8rem;
}

.ec-friendsRole__userflow {
  margin: 3rem 0 0;
}
.ec-friendsRole__userflow .item {
  display: flex;
  align-items: center;
  margin: 1.6rem 0;
}
.ec-friendsRole__userflow .user {
  width: 7rem;
  padding: 2.4rem 0 0;
  background: no-repeat center top;
  background-size: 2rem;
  text-align: center;
  font-size: 1.3rem;
}
.ec-friendsRole__userflow .introder .user {
  background-image: url("../img/common/icon_user_red.svg");
} 
.ec-friendsRole__userflow .firend .user {
  background-image: url("../img/common/icon_user_green.svg");
}
.ec-friendsRole__userflow .flow {
  position: relative;
  padding: 0.2rem;
  margin-left: 1rem;
  width: calc(100% - 10rem);
  border-radius: 3rem;
  text-align: center;
  font-size: 1.6rem;
}
.ec-friendsRole__userflow .introder .flow{
  background: #FBECE8;
}
.ec-friendsRole__userflow .firend .flow{
  background: #DEF4EC;
}
.ec-friendsRole__userflow .item + .item .flow:before {
  content: "";
  position: absolute;
  left: 50%;
  top: -2rem;
  transform: translateX(-50%);
  width: 1.2rem;
  height: 0.6rem;
  background: url("../img/common/icon_arr_down.svg")no-repeat center;
  background-size: 100%;
}

.ec-friendsRole__plusflow {
  margin-top: 1.6rem;
}
.ec-friendsRole__plusflow .item {
  position: relative;
}
.ec-friendsRole__plusflow .item + .item {
  margin-top: 4.5rem;
}
.ec-friendsRole__plusflow .item + .item:before {
  content: "";
  position: absolute;
  left: 50%;
  top: -3.5rem; 
  transform: translateX(-50%);
  height: 2rem;
  width: 2rem;
  background: url("../img/about/icon_circle_plus.svg")no-repeat center;
  background-size: 100%;
}
.ec-serviceRole__regularCourses .ec-friendsRole__plusflow .before .point {
  margin-right: 1.2rem;
  text-align: center;
  font-size: 1.1rem;
}
.ec-serviceRole__regularCourses .ec-friendsRole__plusflow .hotStyle .tit {
  font-size: 2.2rem;
}
.ec-serviceRole__regularCourses .ec-friendsRole__plusflow .display .img {
  margin-right: 2rem;
  width: 5rem;
}
.ec-serviceRole__regularCourses .ec-friendsRole__plusflow .display .info {
  width: calc(100% - 7rem);
}
.ec-serviceRole__regularCourses .ec-friendsRole__plusflow .focus2 { 
  font-size: 2rem;
}

.ec-friendsRole__plusflow.rowStyle {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.ec-friendsRole__plusflow.rowStyle .item {
  width: 46%;
}
.ec-friendsRole__plusflow.rowStyle .item + .item {
    margin-top: 0;
}
.ec-friendsRole__plusflow.rowStyle .item + .item:before {
  left: -5rem;
  top: 50%;
  transform: translateY(-50%);
}
.ec-serviceRole__regularCourses .ec-friendsRole__plusflow.rowStyle .before .display {
  display: block;
}
.ec-serviceRole__regularCourses .ec-friendsRole__plusflow.rowStyle .before .point {
  text-align: left;
}


/*  sp  */
@media screen and (min-width: 768px) { 
  .ec-serviceRole__regularCourses .bnrLink:hover {
    opacity: 0.7;
  }
    
  .ec-faqRole_list .answer a:hover {
    color: #333;
    border-bottom: 0;
  }
}
@media screen and (max-width: 767px) { 
  .ec-aboutRole {
    padding: 5rem 0 1rem;
  }
  
  .ec-aboutRole .ec-commonRole__sub {
    font-size: 1.3rem;
  }
  
  .ec-aboutRole .ec-serviceRole__regularCourses li {
    padding: 2rem;
    overflow:hidden;
  }
  .ec-aboutRole .ec-serviceRole__regularCourses .benefit05 {
    background-position: right 2rem top 2rem;
    background-size: 5rem;
  }
  
  .ec-aboutRole .table01 {
    overflow-x: scroll;
    width: 100%;
  }
  .ec-aboutRole .table01 table {
    min-width: 82rem;
  }
  .ec-aboutRole .table01 thead th{
    font-size: 1.4rem;
  }
  .ec-aboutRole .table01 tbody th {
    width: 14rem;
    font-size: 1.5rem;
  }
  .ec-aboutRole .table01 td {
    font-size: 1.5rem;
  }
  .ec-aboutRole .table01 .big {
    font-size: 3rem;
  }
  
  .ec-serviceRole__regularCourses .flexStyle {
    display: block;
  }
  
  
  .ec-aboutpointRole {
    padding: 5rem 0 1rem;
  }
  .ec-serviceRole__regularCourses .ec-aboutRole__getPoints.gird2 {
    grid-template-columns: 1fr;
  }
  .ec-serviceRole__regularCourses .also {
    padding: 0 0 1.6rem;
  }
  .ec-serviceRole__regularCourses .also p {
    padding: 0.1rem 1.5rem 0.1rem 2.2rem;
    background-size: 1.7rem;
    font-size: 1.3rem;
  }
  .ec-serviceRole__regularCourses .also span {
    font-size: 1.2rem;
  }
  .ec-serviceRole__regularCourses .display .img {
    margin-right: 1rem;
    width: 9rem;
  }
  
  .ec-commonRole__noteSerial li {
    line-height: 1.8; 
    font-size: 1.1rem;
  }
  
  
  .ec-friendsRole__plusflow {
    margin: 1.2rem -1rem 0;
  }
  .ec-serviceRole__regularCourses .ec-friendsRole__plusflow .before .point {
    margin-right: 0.6rem; 
  }
  .ec-serviceRole__regularCourses .ec-friendsRole__plusflow .display .img {
    margin-right: 1rem;
    width: 6rem;
  }
  
  .ec-friendsRole__plusflow.rowStyle {
    display: block;
  }
  .ec-friendsRole__plusflow.rowStyle .item {
    width: auto;
  }
  .ec-friendsRole__plusflow.rowStyle .item + .item {
    margin-top: 4.5rem;
  }
  .ec-friendsRole__plusflow.rowStyle .item + .item:before {
    left: 50%;
    top: -3.5rem;
    transform: translateX(-50%);
  }
  .ec-serviceRole__regularCourses .ec-friendsRole__plusflow.rowStyle .before .display {
    display: flex;
  }
  .ec-serviceRole__regularCourses .ec-friendsRole__plusflow .hotStyle .tit {
    font-size: 1.8rem;
  }
  
  .mt-5 {
    margin-top: 1.5rem !important;
  }
  
}



/* 9/26 LPフォームエリア修正 */

#page_feature_detail .ec-checkbox input[type=checkbox] {
  width: 2rem;
  height: 2rem;
}
.ec-numberInput{
  display: table-cell;
  vertical-align: middle;
  padding-left: 5px;
}

#page_feature_detail .ec-checkbox input[type=checkbox]{
  background-image: url(../img/common/icon_checkbox_no_green.svg);
}
#page_feature_detail .ec-checkbox input[type=checkbox]:checked {
  background-image: url(../img/common/icon_checkbox_on_green.svg);
}