@charset "utf-8";
/* CSS Document */

/* HEADER
-----------------------------------------*/
.ec-layoutRole__header {
    justify-content: space-between;
    padding: 0 30px;
    border-bottom: solid 2px #23ac38;
    margin-bottom: 30px;
}

.ec-headerRole {
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-bottom: 15px !important;
}

.ec-headerNaviRole {
    margin: 0 0 0 50px !important;
    padding: 0 !important;
    max-width: 100% !important;
}

.ec-headerNaviRole .ec-headerNaviRole__right {
    flex-wrap: wrap !important;
}

.ec-headerNaviRole__menu {
    width: 100% !important;
    margin: 10px 0 15px 0;
}

.ec-headerNaviRole__menu ul {
    display: flex;
    justify-content: flex-end;
}

.ec-headerNaviRole__menu li a {
    color: var(--bs-body-color);
    font-size: 13px;
    padding: 0 15px;
    border-left: solid 1px var(--bs-body-color);
}

.ec-headerNaviRole__menu li:first-child a {
    border: none;
}

.ec-headerNaviRole__nav {
    margin-right: 4px;
}

.ec-headerNav__item {
    background: #9cc813;
    border-radius: 5px 5px 0 0;
}

.ec-headerNav__item a {
    padding: 0 20px !important;
}

.ec-headerNav .ec-headerNav__itemLink {
    color: #fff;
    height: 38px;
    line-height: 38px;
    font-size: 14px !important;
}

.ec-cartNavi {
    padding: 9px 30px;
    min-width: 140px;
    height: 38px;
    background: #23ac38;
    border-radius: 5px 5px 0 0;
    color: #fff;
    font-size: 14px !important;
    font-weight: bold;
}

.ec-cartNaviIsset::before {
    right: 65px;
}

.ec-cartNavi .ec-cartNavi__badge {
    margin-left: 10px;
    border: solid 2px #fff;
    /* width: 20px !important; */
    min-width: 20px !important;
    height: 20px !important;
}

@media only screen and (max-width: 767px) {
    .ec-layoutRole__header {
        display: block !important;
    }

    .ec-headerRole {
        width: 100%;
    }

    .ec-headerRole .ec-headerRole__title {
        width: 50%;
        margin: 0 auto;
    }

    .ec-headerNaviRole .ec-headerNaviRole__right {
        display: none;
    }

    .ec-drawerRole .ec-headerLinkArea {
        background: #23ac38;
    }

    .ec-drawerRole .ec-headerLinkArea .ec-headerLink__item {
        padding: 10px 20px;
    }
}

@media screen and (min-width:768px) and (max-width:1199px) {
    .ec-headerNaviRole {
        flex-wrap: wrap;
    }

    .ec-headerNaviRole .ec-headerNaviRole__left,
    .ec-headerNaviRole .ec-headerNaviRole__right {
        width: 100% !important;
    }

    .ec-headerNaviRole .ec-headerNaviRole__left {
        margin-top: 10px;
    }
}

.ec-headerSearch .ec-headerSearch__keyword {
    width: 100%;
}


@media only screen and (max-width: 767px) {
    .ec-drawerRole .ec-headerSearch {
        padding: 15px 8px;
    }

    .ec-headerSearch .ec-headerSearch__keyword {
        border-bottom-right-radius: 0;
        border-bottom-left-radius: 0;
    }
}

/* CONTENTS
-----------------------------------------*/

/* ---------- FRAME ---------- */
@media only screen and (min-width: 768px) {
    .ec-layoutRole .ec-layoutRole__contents {
        max-width: 100%;
        justify-content: space-between;
        padding: 0 30px;
    }

    .ec-layoutRole .ec-layoutRole__left,
    .ec-layoutRole .ec-layoutRole__right {
        width: 250px;
    }

    .ec-layoutRole .ec-layoutRole__mainWithColumn {
        width: calc(100% - 330px);
    }
}


/* ---------- SIDEBAR ---------- */

/* --- LOGIN USER --- */
@media only screen and (min-width: 768px) {
    .login_user {
        margin-bottom: 30px;
        padding: 20px;
        border: solid 8px #ecf9b7;
    }

    .login_user p {
        margin: 10px 0 0 0;
        padding-top: 10px;
        border-top: dotted 1px #ddd;
    }

    .login_user dd {
        margin-bottom: 0px;
    }
}


/* --- CATEGORY LIST--- */
@media only screen and (min-width: 768px) {
    .ec-categoryNaviRole {
        padding-left: 0;
        padding-right: 0;
        max-width: 100%;
        margin-top: 10px;
    }

    .ec-itemNav {
        background: #fff !important;
        border-radius: 0 !important;
    }

    .ec-itemNav__nav {
        width: 100% !important;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    .ec-itemNav__nav li ul {
        min-width: 280px;
    }

    .ec-itemNav__nav li a {
        padding-left: 6px !important;
        padding-right: 6px !important;
        font-size: clamp(10px, 1.2vw, 14px) !important;
    }

    .ec-itemNav__nav>li>a {
        line-height: 36px;
        padding: 3px !important;
    }

    .ec-itemNav__nav>li>a img {
        width: 36px;
        margin-right: 8px;
    }

    .ec-itemNav__nav>li:hover>ul,
    .ec-itemNav__nav>li:hover>ul li:hover ul {
        padding: 5px;
        box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.35);
        border-radius: 5px;
        background: #fff;
    }

    .ec-itemNav__nav li ul li a {
        padding-left: 6px !important;
        padding-right: 6px !important;
        font-size: clamp(10px, 1.2vw, 14px) !important;
        background: #fff !important;
        border: none !important;
        color: #333;
    }

    .ec-itemNav__nav li a:hover,
    .ec-itemNav__nav>li:hover>a {
        background: #ecf9b7 !important;
    }

    .ec-itemNav__nav li ul li ul:before {
        color: #23ac38;
    }

    /*.menu-icon-wrapper{
	width: 36px;
	height: 40px;
	position: relative;
	display: inline-block;
	margin-right: 5px;
}

.menu-icon-wrapper .menu-icon{
    display: block;
	width: 100%;
}

li a.left-menu-link{
	display: flex;
	align-items: center;
}*/
}


/* --- MAKER LIST --- */
@media only screen and (min-width: 768px) {

    .maker_list,
    .category_list,
    .other_search,
    .side_banner {
        margin-top: 20px;
        padding-top: 20px;
        border-top: solid 1px #ddd;
    }

    .maker_list dt,
    .other_search dt {
        /* font-size: 16px; */
        margin-bottom: 15px;
    }

    .maker_list li {
        position: relative;
        padding-left: 20px;
        margin-top: 5px;
    }

    .maker_list li:before {
        content: "\f054";
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        font-size: 12px;
        color: #23ac38;
        position: absolute;
        top: 2px;
        right: auto;
        left: 0;
    }

    .maker_list li a {
        color: #2e3233;
    }

    .maker_list li a:hover {
        text-decoration: none;
        color: #23ac38;
    }

    .maker_list p {
        margin-top: 15px;
    }

    .maker_list p a {
        display: block;
        width: 100%;
        background: #23ac38;
        color: #fff;
        padding: 5px 20px;
        text-align: center;
    }

    .maker_list p a:hover {
        text-decoration: none;
    }
}


/* --- SEARCH CONDITION --- */
@media only screen and (min-width: 768px) {
    .other_search label {
        margin-left: 5px;
    }

    .other_search button {
        width: 100%;
        background: #23ac38;
        color: #fff;
        padding: 5px 20px;
        border: none;
        margin-top: 15px;
    }
}

/* --- BANNER --- */
@media only screen and (min-width: 768px) {
    .side_banner li:nth-child(n+2) {
        margin-top: 10px;
    }
}



/* ---------- MAIN CONTENTS ---------- */

/* --- TOP SLIDE --- */
@media only screen and (min-width: 768px) {
    .ec-sliderRole {
        padding-left: 0 !important;
        padding-right: 0 !important;
        max-width: 100% !important;
    }

    .ec-sliderRole {
        margin-bottom: 60px;
    }

    .main_visual .slick-slide {
        margin: 0 10px !important;
    }
}


/* --- TOP CONTENTS --- */
.top_title {
    font-size: 20px;
    margin-bottom: 20px;
}

@media only screen and (min-width: 768px) {
    .ec-shelfRole {
        padding: 0 !important;
        max-width: 100% !important;
    }
}

@media only screen and (max-width: 767px) {
    .top_title {
        font-size: 18px;
    }
}

/* --- PICKUP --- */
.pickup_category,
.pickup_maker {
    margin-top: 30px;
    padding-top: 30px;
    border-top: solid 1px #ddd;
}

.pickup_category {
    margin-top: 0 !important;
}

#pickUpCate.section {
    margin-top: 0 !important;
    padding-top: 0 !important;
    border-top: none !important;
}

#pickUpCate ul {
    display: flex;
    flex-wrap: wrap;
}

#pickUpCate li img {
    width: 120px;
    height: 120px;
    margin-bottom: 10px !important;
}

#pickUpCate li a {
    font-size: 15px;
}

#pickUpCate li a:hover {
    text-decoration: none;
}

@media only screen and (min-width: 768px) {
    #pickUpCate li {
        width: calc((100% - 80px) / 5) !important;
        margin-left: 20px !important;
        margin-top: 20px !important;
        padding: 0 !important;
        text-align: center;
    }

    #pickUpCate li:nth-child(5n+1) {
        margin-left: 0 !important;
    }
}

@media only screen and (max-width: 767px) {
    #pickUpCate li {
        width: calc((100% - 20px) / 2) !important;
        margin-left: 20px !important;
        margin-top: 20px !important;
        padding: 0 !important;
        text-align: center;
    }

    #pickUpCate li:nth-child(2n+1) {
        margin-left: 0 !important;
    }
}

/* --- TOP NEWS --- */
.ec-newsRole {
    margin-top: 30px;
    padding-top: 30px !important;
    border-top: solid 1px #ddd;
}

.ec-newsRole .ec-newsRole__newsItem:not(:last-of-type) {
    border-bottom: none !important;
}

.ec-newsRole .ec-newsRole__newsItem {
    margin-top: 5px;
}

@media only screen and (min-width: 768px) {
    .ec-role {
        padding-left: 0px;
        padding-right: 0px;
        max-width: 100% !important;
    }

    .ec-newsRole .ec-newsRole__news {
        border: none !important;
        padding: 0 !important;
    }

    .ec-newsRole .ec-newsRole__newsItem {
        padding: 0 !important;
    }
}

@media only screen and (max-width: 767px) {
    .ec-newsRole .ec-newsRole__newsItem:last-of-type {
        margin-bottom: 0 !important;
    }

    .ec-newsRole .ec-newsRole__newsDate {
        margin: 0 0 5px 0 !important;
    }

    .ec-newsRole .ec-newsRole__newsTitle {
        margin-bottom: 0 !important;
    }
}



/* --- PRODUCTS LIST --- */
.ec-searchnavRole__actions .ec-select {
    display: flex;
    justify-content: flex-end;
}

.ec-searchnavRole__actions .select {
    display: inline-block;
    position: relative;
    border: 1px solid #333;
    border-radius: 4px;
    vertical-align: middle;
    margin-left: 10px;
    /*padding-right: 20px;*/
}

.ec-searchnavRole__actions .select select {
    appearance: none;
    padding: 5px 30px 5px 15px !important;
    padding-right: 1em;
    border: none;
    outline: 0;
    background: #fff;
    background-image: none;
    box-shadow: none;
    text-indent: 0.01px;
    text-overflow: ellipsis;
    cursor: pointer;
}

.ec-searchnavRole__actions .select::before {
    position: absolute;
    top: 10px;
    right: 15px;
    width: 0;
    height: 0;
    border-width: 6px 5px 0 5px;
    border-style: solid;
    border-color: #333 transparent transparent transparent;
    content: "";
    pointer-events: none;
}


.ec-shelfGrid__item-image {
    position: relative;
    width: 100%;
    height: auto;
    display: flex;
    overflow: hidden;
}

.ec-shelfGrid__item-image:before {
    content: "";
    display: block;
    padding-top: 100%;
}

.ec-shelfGrid__item-image img {
    position: absolute;
    max-width: 100% !important;
    max-height: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: transform .6s ease;
}

.ec-shelfGrid__item-image:hover img {
    transform: scale(1.1) translate(-45%, -45%);
}

.ec-productRole__item-name {
    color: #437ec4 !important;
}

.ec-productRole__priceRegularPrice {
    margin-bottom: 0 !important;
}

.ec-productRole__priceRegularPrice,
.price02-default {
    font-size: 13px;
    color: #c04949;
}

.price02-default {
    margin-bottom: 0.5rem !important;
}

.ec-productRole__priceRegularPrice span,
.price02-default span {
    font-size: 11px !important;
}

.price02-default em {
    font-style: normal;
    font-weight: bold;
}

.ec-numberInput span {
    font-size: 14px;
    margin-right: 5px;
}

@media only screen and (min-width: 1300px) {

    .ec-topicpath,
    .ec-searchnavRole .ec-searchnavRole__counter,
    .ec-pagerRole {
        font-size: 15px !important;
    }

    .ec-pagerRole_top {
        margin-bottom: 30px;
    }

    .ec-shelfGrid {
        margin: 0 !important;
    }

    .ec-shelfGrid .ec-shelfGrid__item {
        width: calc((100% - 150px) / 6);
        padding: 0 !important;
        margin-left: 30px;
    }

    .ec-shelfGrid .ec-shelfGrid__item:nth-child(6n+1) {
        margin-left: 0;
    }

    .ec-searchnavRole {
        padding-left: 0 !important;
        padding-right: 0 !important;
        max-width: 100% !important;
    }

    .ec-searchnavRole .ec-searchnavRole__infos {
        padding-left: 0 !important;
        padding-right: 0 !important;
        max-width: 100% !important;
        margin-bottom: 20px !important;
    }

    .ec-productRole__item-name {
        font-size: 14px !important;
    }

    .ec-productRole__item-name:hover,
    .item_name:hover {
        text-decoration: underline;
    }



    .ec-blockBtn--action {
        height: 42px !important;
        line-height: 42px !important;
    }
}

@media only screen and (min-width: 768px) and (max-width: 1299px) {
    .ec-orderBySaleRole .ec-shelfGrid .ec-shelfGrid__item:nth-child(n+5) {
        margin-top: 30px;
    }
}

@media only screen and (max-width: 767px) {
    .ec-topicpath {
        border-top: none;
        border-bottom: 1px solid #ccc;
        padding: 10px 0;
        margin: 0 20px;
        font-size: 13px;
    }

    .ec-searchnavRole .ec-searchnavRole__topicpath {
        padding-left: 20px;
    }

    .ec-searchnavRole .ec-searchnavRole__infos {
        font-size: 13px;
        margin-bottom: 0;
        padding-top: 10px;
    }

    .ec-select select {
        font-size: 14px;
    }

    .ec-pager {
        margin: 0 20px;
    }
}


/* --- PRODUCTS DETAIL --- */
.item_visual .slide-item {
    position: relative;
    border: solid 1px #ddd;
}

.item_visual .slide-item:before {
    content: "";
    display: block;
    padding-top: 100%;
}

.item_visual .slide-item img {
    position: absolute;
    max-width: 100% !important;
    max-height: 100%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    object-fit: contain;
}

.ec-productRole .ec-productRole__tags {
    margin-top: 0 !important;
    padding-bottom: 10px !important;
    border-bottom: none !important;
}

.ec-productRole .ec-productRole__category {
    padding: 15px 0 !important;
    font-size: 13px;
}

.ec-productRole .ec-productRole__category div {
    margin-bottom: 5px;
}

.ec-productRole__priceRegular .ec-productRole__priceRegularPrice {
    color: #333;
    font-size: 14px;
}

.ec-productRole .ec-productRole__price {
    color: #c04949;
}

.ec-price .ec-price__price {
    padding: 0 !important;
}

.ec-productRole__maker,
.ec-productRole__code {
    font-size: 14px;
}

.ec-productRole__maker {
    padding-top: 15px;
}

.ec-productRole .ec-productRole__code {
    padding: 5px 0 15px 0;
}

.ec-productRole .ec-productRole__actions {
    padding: 20px 0 0 0;
}

.ec-productRole__description {
    margin: 60px 0 0 0 !important;
    font-size: 15px;
    line-height: 1.5;
}

@media only screen and (min-width: 1300px) {
    .ec-grid2 {
        width: 100%;
    }

    .ec-productRole {
        padding-left: 0 !important;
        padding-right: 0 !important;
        max-width: 100% !important;
    }

    .ec-grid2 {
        justify-content: space-between;
    }

    .ec-grid2__cell-image {
        width: 500px !important;
    }

    .ec-grid2__cell-text {
        width: calc(100% - 540px) !important;
    }

    .ec-sliderItemRole {
        padding-left: 0 !important;
        padding-right: 0 !important;
        max-width: 100% !important;
        margin-bottom: 24px;
    }

    .ec-sliderItemRole .slideThumb {
        margin-bottom: 0;
        width: calc((100% - 45px) / 4);
        position: relative;
        height: auto;
        border: solid 1px #ddd;
    }

    .ec-sliderItemRole .slideThumb:nth-child(n+2) {
        margin-left: 15px;
    }

    .ec-sliderItemRole .slideThumb:before {
        content: "";
        display: block;
        padding-top: 100%;
    }

    .ec-sliderItemRole .slideThumb img {
        width: 100%;
        height: auto;
        -o-object-fit: contain;
        object-fit: contain;

        position: absolute;
        max-width: 100% !important;
        max-height: 100%;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    .ec-productRole__profile {
        margin-left: 0 !important;
    }




    .ec-productRole .ec-productRole__btn {
        width: 100%;
        margin: 15px 0;
        font-size: 18px;
    }

    .ec-productRole .ec-productRole__btn button {
        font-size: 18px !important;
    }

    .ec-productRole .ec-productRole__btn .ec-blockBtn--action {
        height: 80px !important;
        line-height: 80px !important;
    }


}

@media only screen and (max-width: 1299px) {
    .ec-productRole .ec-productRole__title .ec-headingTitle {
        font-size: 20px !important;
    }
}

@media only screen and (min-width: 768px) and (max-width: 1299px) {
    .ec-productRole .ec-productRole__btn {
        min-width: auto;
        width: 100%;
        margin: 15px 0;
    }
}

@media only screen and (max-width: 767px) {
    .ec-productRole .ec-productRole__price {
        border-bottom: 1px dotted #ccc;
        padding-bottom: 14px;
    }

    .ec-productRole .ec-productRole__btn {
        margin-top: 10px;
    }
}


/* --- RANKING --- */
.ec-orderBySaleRole {
    padding: 0 0 60px 0 !important;
}

.ec-orderBySaleRole .item_name,
.ec-reccommend .item_name {
    color: #437ec4 !important;
    font-size: 14px !important;
}

.stock-count {
    font-size: 12px !important;
    margin-bottom: 0.5rem !important;
}

.category-link,
.maker_name {
    font-size: 12px;
}

.category-link {
    color: #437ec4 !important;
    margin: 0.3em 0 !important;
}

.maker_name {
    position: relative;
    padding-left: 20px;
    margin: -0.7em 0 0.6em 0 !important;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

.maker_name::before {
    content: "\f54f";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 12px;
    position: absolute;
    top: 0;
    left: 0;
}

.ec-orderBySaleRole .item_price,
.ec-reccommend .item_price {
    font-size: 13px;
    color: #c04949;
}

.ec-orderBySaleRole li {
    position: relative;
}

.ec-orderBySaleRole li::after {
    position: absolute;
    top: -7px;
    left: -9px;
}

.ec-orderBySaleRole li:nth-child(1)::after {
    content: url(../img/common/rank1.png);
}

.ec-orderBySaleRole li:nth-child(2)::after {
    content: url(../img/common/rank2.png);
}

.ec-orderBySaleRole li:nth-child(3)::after {
    content: url(../img/common/rank3.png);
}

.ec-orderBySaleRole li:nth-child(4)::after {
    content: url(../img/common/rank4.png);
}

.ec-orderBySaleRole li:nth-child(5)::after {
    content: url(../img/common/rank5.png);
}

.ec-orderBySaleRole li:nth-child(6)::after {
    content: url(../img/common/rank6.png);
}


/* FOOTER
-----------------------------------------*/
.ec-footerRole {
    background: transparent !important;
    border-top: none !important;
}

.ec-footerCategory {
    background: white;
    padding: 20px;
    margin-bottom: 40px;
}

.ec-footerCategory p {
    font-weight: bold;
    margin-bottom: 10px !important;
}

.ec-footerCategory li {
    margin-top: 5px;
}

.ec-footerCategory li a {
    color: var(--bs-body-color);
}

.ec-footerNavi {
    color: var(--bs-body-color);
}

.ec-footerNavi .ec-footerNavi__link a {
    text-decoration: none !important;
}

.ec-footerTitle {
    color: #23ac38;
    padding: 40px 0 !important;
}

@media only screen and (min-width: 768px) {
    .ec-layoutRole__footer {
        background: url(/html/template/default/assets/img/common/footer_img.jpg) no-repeat top;
        background-size: contain;
        background-color: #e3eec6;
        margin-top: 80px;
    }

    .ec-footerRole {
        margin-top: 8% !important;
    }

    .ec-footerRole .ec-footerRole__inner {
        max-width: 100% !important;
        padding-left: 30px !important;
        padding-right: 30px !important;
    }

    .ec-footerCategory ul {
        display: flex;
        flex-wrap: wrap;
    }

    .ec-footerCategory li a {
        padding: 0 20px;
        border-left: solid 1px var(--bs-body-color);
        font-size: 14px;
    }

    .ec-footerCategory li:last-child a {
        border-right: solid 1px var(--bs-body-color);
    }

    .ec-footerNavi .ec-footerNavi__link a {
        margin: 0 !important;
        padding: 0 20px !important;
        border-right: solid 1px var(--bs-body-color);
    }

    .ec-footerNavi .ec-footerNavi__link:first-child a {
        border-left: solid 1px var(--bs-body-color);
    }

    .ec-footerTitle .ec-footerTitle__copyright {
        font-size: 14px;
    }
}

@media only screen and (max-width: 767px) {
    .ec-layoutRole__footer {
        background: url(/html/template/default/assets/img/common/footer_img_sp.jpg) no-repeat top;
        background-size: contain;
        background-color: #e3eec6;
        margin-top: 40px;
    }

    .ec-footerRole {
        margin-top: 18% !important;
    }

    .ec-footerRole .ec-footerRole__inner {
        margin: 0 20px;
    }

    .ec-footerNavi .ec-footerNavi__link a {
        padding: 8px 0;
        font-size: 13px;
    }

    .ec-footerCategory {
        display: none;
    }
}