@charset "utf-8";

/*
 * File    : sub-brand.css
 * Author  : STUDIO-JT
 *
 * SUMMARY :
 * COMMON
 * BRAND POINT
 * BRAND DETAIL COMPONENT
 * BRAND PRODUCT
 * BRAND CONTACT
 * SOYSAUCE
 * TOFU
 * BEDDINGS
 * UNDERWEAR
 * HOVER
 */

 

/* **************************************** *
 * COMMON
 * **************************************** */
body[class*="page-template-brand-"] .main-container { padding-top: 0; }

/* LAYOUT */
.brand-container { display: flex; flex-direction: column; gap: 260rem; padding-top: 260rem; }

/* VISUAL */
body.page-template-brand-yoghurt-run .article__visual-bg { -webkit-mask-image: url(../images/sub/brand/visual-mask-ellipse.svg); mask-image: url(../images/sub/brand/visual-mask-ellipse.svg); }
body.page-template-brand-sanc-soysauce .article__visual-bg { -webkit-mask-image: url(../images/sub/brand/visual-mask-semicircle.svg); mask-image: url(../images/sub/brand/visual-mask-semicircle.svg); }
body.page-template-brand-sanc-tofu .article__visual-bg { -webkit-mask-image: url(../images/sub/brand/visual-mask-double-ellipse.svg); mask-image: url(../images/sub/brand/visual-mask-double-ellipse.svg); }



/* **************************************** *
 * BRAND POINT
 * **************************************** */
.brand-point__list { display: flex; justify-content: center; gap: 120rem; text-align: center; margin-top: 100rem; }
.brand-point__list-figure { width: 160rem; height: 160rem; margin-left: auto; margin-right: auto; }
.brand-point__list-item b { display: block; margin-top: 16rem; }
.brand-point__list-item span { display: block; color: var(--color-gray-800); margin-top: 4rem;}



/* **************************************** *
 * BRAND DETAIL COMPONENT
 * **************************************** */
.brand-detail__sections { display: flex; flex-direction: column; gap: 16rem; }

/* FIGURE */
.brand-detail__figure { padding-top: 47.36%; border-radius: var(--round-06); }

.brand-detail__figure-parallax:has(.brand-detail__figure.jt-lazyload) { position: relative; width: 100%; padding-top: 47.36%; }
.brand-detail__figure-parallax .brand-detail__figure.jt-lazyload { padding-top: 0; position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex; align-content: center; align-items: center; flex-wrap: wrap; }
.brand-detail__figure-parallax .brand-detail__figure.jt-lazyload img.brand-parallax-motion-y { top: auto; left: auto; }

/* COLUMN GROUP */
.brand-detail__group { display: flex; gap: 16rem; }
.brand-detail__group-item { position: relative; width: 50%; border-radius: var(--round-05); overflow: hidden; }
.brand-detail__group-item figure { padding-top: 95.56%; }
.brand-detail__group-item--circle { border-radius: 50%; }
.brand-detail__group-video { position: relative; width: 100%; padding-top: 95.56%; }
.brand-detail__group-video .jt-background-video__vod video { border-radius: var(--round-05); }
.brand-detail__mask { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.brand-detail__content { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 24rem; width: 100%; height: 100%; background-color: var(--color-point-01); text-align: center; padding: 0 20rem; }
.brand-detail__content span { color: var(--color-primary); }
.brand-detail__content .jt-scramble-txt { display: inline-block; vertical-align: top; height: 1em; position: relative; font-family: var(--font-secondary); font-size: var(--font-size-en-01); font-weight: 600; letter-spacing: var(--letter-spacing); line-height: 1; font-style: normal; text-align: right; }
.brand-detail__content .jt-scramble-txt > * { display: inline-block; vertical-align: top; }
.brand-detail__content .jt-scramble-txt .slotmachine-number-wrap { height: 100%; overflow: hidden; }
.brand-detail__content .jt-scramble-txt .slotmachine-number-wrap > span { display: block; position: relative; top: 0; }

.brand-section__control { text-align: center; margin-top: 60rem; }

/* SLIDER */
.brand-detail__slider-container { position: relative; width: 100%; padding-top: 47.35%; background: var(--color-black); border-radius: var(--round-06); overflow: hidden; }

.brand-detail__slider-content { width: 100%; position: absolute; top: 50%; left: 0; transform: translateY(-50%); z-index: 10; display: flex; justify-content: center; }
.brand-detail__slider-content i { display: block; width: 226rem; }
.brand-detail__slider-content i svg { display: block; width: 100%; height: auto; }
.brand-detail__slider-content i svg path { fill: var(--color-white); }

.brand-detail__slider-visual { width: 100%; height: 100%; position: absolute; top: 0; left: 0; }
.brand-detail__slider-item { transition-timing-function: ease-in-out; }
.brand-detail__slider-bg { position: absolute; top: 0; bottom: 0; left: 0; right: 0; overflow: hidden; }
.brand-detail__slider-bg::after { content: ''; position: absolute; top: 0; bottom: 0; left: 0; right: 0; background: rgba(0, 0, 0, .2); }
.brand-detail__picture { position: relative; width: 100%; height: 100%; background: no-repeat center center; background-size: cover; }

.brand-detail__slider-visual .swiper-wrapper::before { content: ''; position: absolute; display: block; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.3); z-index: 10; }



/* **************************************** *
 * BRAND PRODUCT
 * **************************************** */
.brand-product__list-wrap { margin-left: -52rem; margin-right: -52rem; padding-left: 52rem; padding-right: 52rem; overflow:  hidden; }
.brand-product__list { display: flex; margin-left: -16rem; margin-right: -16rem; overflow: visible; }
.brand-product__list .swiper-wrapper { align-items: stretch; }
.brand-product__list-item { position: relative; width: calc(33.33% - 32rem); height: auto; margin: 0 16rem; text-align: center; background: var(--color-gray-300); border-radius: var(--round-06); overflow: hidden; }
.brand-product__list-inner { width: 100%; height: 100%; padding: 60rem 50rem 50rem; border-radius: var(--round-06); }
.brand-product__list-figure-wrap { position: relative; margin-top: 58rem; }
.brand-product__list-figure-wrap figure { padding-top: 82.64%; border-radius: var(--round-02); font-size: 0; }
.brand-product__list-figure-hover { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; }
.brand-product__list-figure-hover img { display: block; width: 100%; position: absolute; left: 0; top: 0; }
.brand-product__list-desc { margin-top: 16rem; color: var(--color-gray-800); }
.brand-product__list-btn { display: inline-block; font-size: var(--font-size-ko-09); line-height: var(--font-lineheight-ko-09); color: var(--color-black); border-bottom: 1px solid var(--color-black); }
.brand-product__list-bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.brand-product__list-icon { display: block; width: 212rem; margin: 0 auto; }
.brand-product__list-icon figure { padding-top: 72.73%; }
.brand-product__list-item--regular-delivery { height: auto; }
.brand-product__list-item--regular-delivery .brand-product__list-inner { position: relative; display: flex; flex-direction: column; justify-content: center; height: 100%; padding: 0 0 38rem; border-radius: 0; z-index: 1; }
.brand-product__list-item--regular-delivery .brand-product__list-bg { background-image: url(../images/sub/brand/brand-run-product-delivery.jpg); background-repeat: no-repeat; background-size: cover; background-position: center; transition: transform 1.2s cubic-bezier(0.19, 1, 0.22, 1); }
.brand-product__list-item--regular-delivery .brand-product__list-title { color: var(--color-white); margin-top: 8rem; }
.brand-product__list-item--regular-delivery .brand-product__list-desc { color: var(--color-white); }
.brand-product__list-item--regular-delivery .brand-product__list-btn { position: absolute; bottom: 50rem; left: 50%; transform: translateX(-50%); color: var(--color-white); border-color: var(--color-white); }

.brand-product-list--secondary .brand-product__list-item { background: var(--color-white); border: 1px solid var(--color-point-03) }

/* SLIDER */
.brand-product__list:not(.brand-product__list--noswipe) .swiper-navigation { display: block; }
.brand-product__list .swiper-navigation { display: none; }
.brand-product__list .swiper-navigation .swiper-button-prev { left: -8rem; }
.brand-product__list .swiper-navigation .swiper-button-next { right: -8rem; }

/* SECONDARY */
.brand-product__list--secondary .brand-product__list-item:not(.brand-product__list-item--regular-delivery) { padding: 0; background: var(--color-white); }
.brand-product__list--secondary .brand-product__list-figure-wrap { margin-top: 48rem; }



/* **************************************** *
 * BRAND CONTACT
 * **************************************** */
.brand-contact__gallery { margin-left: -52rem; margin-right: -52rem; overflow: hidden; }
.brand-contact__gallery-item { display: inline-block; vertical-align: top; width: 584rem; border-radius: var(--round-05); overflow: hidden; margin-left: 8rem; margin-right: 8rem; }
.brand-contact__gallery-item figure { padding-top: 100%; }



/* **************************************** *
 * YOGURT
 * **************************************** */
.yogurt-content__probiotics .brand-detail__content--row { display: flex; align-items: baseline; gap: 16rem; margin-left: -30rem; }
.yogurt-content__probiotics .jt-scramble-txt + span { position: relative; top: -6rem; }
.yogurt-content__probiotics-subtxt { font-family: var(--font-secondary); font-size: 50rem; line-height: 60rem; font-weight: 600; letter-spacing: -0.01em; }

.yogurt-content__light { background: var(--color-primary); color: var(--color-white); }
.brand-detail__content.yogurt-content__light { gap: 10rem; padding-bottom: 246rem; }
.yogurt-content__light-img-wrap { width: 330rem; position: absolute; bottom: 80rem; left: 50%; translate: -50% 0; }
.brand-detail__content span.yogurt-content__light-cal { color: var(--color-white); }
.brand-detail__group-item figure.yogurt-content__light-img { padding-top: 75.15%; }



/* **************************************** *
 * SOYSAUCE
 * **************************************** */
.soysauce-content__fermentation { position: relative; }
.soysauce-content__fermentation-icon { width: 223rem; height: 223rem; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.soysauce-content__fermentation-icon svg { width: 100%; height: auto; animation: whirlpool-spin 15s linear 0s infinite; }
.soysauce-content__fermentation-line { display: flex; width: 100%; position: absolute; opacity: 0.4; overflow: hidden; }
.soysauce-content__fermentation-line i { display: block; animation: Marquee 60s linear 0s infinite; }
.soysauce-content__fermentation-line i svg { display: block; width: 2090rem; height: auto; overflow: visible; }
.soysauce-content__fermentation-text { position: relative; z-index: 10; display: flex; flex-direction: column; align-items: center; gap: 24rem; }

.soysauce-content__fermentation .brand-detail__content--row { display: flex; align-items: center; gap: 16rem; }
.soysauce-content__fermentation span { color: var(--color-tertiary); }

.soysauce-content__tn { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; }
.soysauce-content__tn span { white-space: nowrap; color: #FFF3E3; }
.soysauce-content__tn .soysauce-content__tn-tag { display: block; width: 100%; padding: 4rem 20rem; border-radius: 999rem; text-align: center; background-color: #BA925A; }




/* **************************************** *
 * TOFU
 * **************************************** */
.tofu-content__haccp { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: 16rem; text-align: center; width: 100%; padding: 0 20rem; }
.tofu-content__haccp span { color: var(--color-white); }

.tofu-content__free { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: 20rem; }
.tofu-content__free i { width: 241rem; height: 251rem; }
.tofu-content__free i svg { width: 100%; height: 100%; }
.tofu-content__free i svg path { fill: var(--color-white) }
.tofu-content__free span { color: var(--color-white); }



/* **************************************** *
 * BEDDING
 * **************************************** */
.bedding-content__madein-wrapper { position: relative; }
.bedding-content__madein { width: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: 16rem; padding: 0 20rem; text-align: center; }
.bedding-content__madein span { color: var(--color-white); }

.bedding-content__pio { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); white-space: nowrap; color: var(--color-white); }

.bedding-content__febric { position: absolute; bottom: 102rem; left: 50%; transform: translate(-50%, 0); white-space: nowrap; color: var(--color-white); }



/* **************************************** *
 * UNDERWEAR
 * **************************************** */
.underwear-content__since { width: auto; left: 50%; transform: translate(-50%,-50%); }
.underwear-content__since span { color: var(--color-white); }
.underwear-content__since-num { position: absolute; right: 100%; bottom: 62rem; }
.underwear-content__since-text { font-size: 300rem; font-weight: 400; letter-spacing: -0.01em; }

.underwear-content__pio { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); white-space: nowrap; color: var(--color-white); }

.underwear-content-wrapper { position: relative; }
.underwear-content__bg { width: 100vw; opacity: .1; position: relative; left: 50%; transform: translateX(-50%); }
.underwear-content__bg svg { width: 100%; height: 100%; }
.underwear-content__list { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 1; display: flex; width: 100vw; height: auto; padding: 0 160rem; }
.underwear-content__item { width: calc(20% + 100rem); }
.underwear-content__item:not(:first-child) { margin-left: -100rem; }
.underwear-content__item figure { padding-top: 100%; border-radius: 50%; margin-bottom: 16rem; }
.underwear-content__text { text-align: center; }

.underwaer-content__anti { position: absolute; bottom: 70rem; left: 50%; transform: translate(-50%, 0); width: 100%; text-align: center; padding: 0 20rem; color: var(--color-white);}
.underwaer-content__anti span { display: block; font-weight: 600; }



/* **************************************** *
 * HOVER
 * **************************************** */
@media (hover: hover) and (pointer: fine) {

    .brand-product__list-btn:hover { border-bottom-style: dashed; }
    .brand-product__list-figure-wrap:hover .brand-product__list-figure-hover { opacity: 1; }

    .brand-product__list-item--regular-delivery:has(.brand-product__list-btn:hover) .brand-product__list-bg { transform: scale(1.1); }
    
}