@charset "utf-8";

/*
 * File    : jt-strap.css
 * Author  : STUDIO-JT (KMS)
 *
 * SUMMARY :
 * A11Y
 * TYPOGRAPHY
 * JT GUIDE
 * BUTTON
 * LAZYLOAD
 * SHARE
 * VIDEO
 * SWIPER
 * MEDIA POPUP
 * JT ACCORDION LIST
 * HOVER
 */



/* **************************************** *
 * A11Y
 * **************************************** */
.sr-only { position: absolute; clip: rect(1px, 1px, 1px, 1px); -webkit-clip-path: inset(0px 0px 99.9% 99.9%); clip-path: inset(0px 0px 99.9% 99.9%); overflow: hidden; height: 1px; width: 1px; padding: 0; border: 0; }

#skip a { width: 1rem; height: 1rem; position: absolute; left: -10000rem; top: auto; overflow: hidden; }
#skip a:focus { display: block; width: 100%; height: 54rem; padding: 0 24rem; position: fixed; top: 0; left: 0; font-size: var(--font-size-en-10); line-height: 54rem; text-align: center; font-weight: bold; color: var(--color-primary); background: var(--color-black); z-index: 999; border-bottom: 1px solid var(--color-primary); }

.use-mouse, .use-mouse :is(select, input[type=text], input[type=tel], input[type=email], input[type=password], input[type=url], input[type=number], input[type=search], textarea, input[type=submit], input[type=button], button, a:focus) { outline: none; }



/* **************************************** *
 * TYPOGRAPHY
 * **************************************** */
.jt-typo--01 { font-size: var(--font-size-en-01); line-height: var(--font-lineheight-en-01); font-weight: 600; letter-spacing: var(--letter-spacing); }
.jt-typo--02 { font-size: var(--font-size-en-02); line-height: var(--font-lineheight-en-02); font-weight: 600; letter-spacing: var(--letter-spacing); }
.jt-typo--03 { font-size: var(--font-size-en-03); line-height: var(--font-lineheight-en-03); font-weight: 600; letter-spacing: var(--letter-spacing); }
.jt-typo--04 { font-size: var(--font-size-en-04); line-height: var(--font-lineheight-en-04); font-weight: 600; letter-spacing: var(--letter-spacing); }
.jt-typo--05 { font-size: var(--font-size-en-05); line-height: var(--font-lineheight-en-05); font-weight: 700; letter-spacing: var(--letter-spacing); }
.jt-typo--06 { font-size: var(--font-size-en-06); line-height: var(--font-lineheight-en-06); font-weight: 700; letter-spacing: var(--letter-spacing); }
.jt-typo--07 { font-size: var(--font-size-en-07); line-height: var(--font-lineheight-en-07); font-weight: 700; letter-spacing: var(--letter-spacing); }
.jt-typo--08 { font-size: var(--font-size-en-08); line-height: var(--font-lineheight-en-08); font-weight: 600; letter-spacing: var(--letter-spacing); }
.jt-typo--09 { font-size: var(--font-size-en-09); line-height: var(--font-lineheight-en-09); font-weight: 400; letter-spacing: var(--letter-spacing); }
.jt-typo--10 { font-size: var(--font-size-en-10); line-height: var(--font-lineheight-en-10); font-weight: 500; letter-spacing: var(--letter-spacing); }
.jt-typo--11 { font-size: var(--font-size-en-11); line-height: var(--font-lineheight-en-11); font-weight: 700; letter-spacing: var(--letter-spacing); }
.jt-typo--12 { font-size: var(--font-size-en-11); line-height: var(--font-lineheight-en-11); font-weight: 500; letter-spacing: var(--letter-spacing); }
.jt-typo--13 { font-size: var(--font-size-en-12); line-height: var(--font-lineheight-en-12); font-weight: 500; letter-spacing: var(--letter-spacing); }
.jt-typo--14 { font-size: var(--font-size-en-13); line-height: var(--font-lineheight-en-13); font-weight: 500; letter-spacing: var(--letter-spacing); }



/* **************************************** *
 * JT GUIDE
 * **************************************** */
/* ICON */
.jt-icon { display: block; }
.jt-icon svg { display: block; width: 100%; height: auto; }
.jt-icon svg path { fill: var(--color-primary); transition: fill .3s; }



/* **************************************** *
 * BUTTON
 * **************************************** */
.jt-btn__icon { display: inline-flex; align-items: center; gap: 8rem; padding: 8rem 20rem; position: relative; color: var(--color-primary); background: transparent; border: none; outline: none; cursor: pointer; }
.jt-btn__icon:after { content: ''; width: calc(100% - 40rem); height: 2rem; position: absolute; left: 20rem; bottom: 8rem; background: var(--color-primary); transform-origin: 100% 50%; transform: scale3d(0, 1, 1); transition: transform .3s; }
.jt-btn__icon .jt-icon { width: 24rem; margin-right: -6rem; }

.jt-btn__icon.jt-btn--type-02 { color: var(--color-black); }
.jt-btn__icon.jt-btn--type-02:after { background: var(--color-black); }
.jt-btn__icon.jt-btn--type-02 .jt-icon svg path { fill: var(--color-black); }



/* **************************************** *
 * LAZYLOAD
 * **************************************** */
img[data-unveil] { opacity: 0; transition: opacity .3s; }
.jt-lazyload--loaded img[data-unveil], img[data-unveil].jt-lazyload--loaded { opacity: 1 }

.jt-lazyload { position: relative; overflow: hidden; }
.jt-lazyload img { display: block; width: 100%; position: absolute; left: 0; top: 0; }
.jt-lazyload.jt-lazyload--loaded img, .jt-lazyload img.jt-lazyload--loaded { height: auto; }

/* COLOR PREVIEW */
.jt-lazyload__color-preview { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: var(--color-gray-900); opacity: 0.2; }
.jt-lazyload.jt-lazyload--loaded .jt-lazyload__color-preview { background: transparent; transition: background-color .1s; transition-delay: .3s }

/* CAPTION */
.jt-lazyload--caption:after { content: ''; position: absolute; left: 0; right: 0; top: 0; bottom: 0; background: linear-gradient(180deg, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.2) 100%); z-index: 1; }
.jt-lazyload--caption figcaption { position: absolute; width: 100%; padding: 40rem; left: 0; bottom: 0; color: var(--color-white); z-index: 2; box-sizing: border-box; }

/* MOTION */
.jt-lazyload__zoom { position: absolute; top: 0; bottom: 0; left: 0; right: 0; overflow: hidden; }
.jt-lazyload__zoom img { transform: scale(1.2); }



/* **************************************** *
 * SHARE
 * **************************************** */
/* CLIPBOARD */
.jt-share__tooltip { position: absolute; left: 100%; top: 50%; translate: 0 -50%; z-index: 501; opacity: 0; visibility: hidden; }
.jt-share__tooltip p { white-space: pre; }



/* **************************************** *
 * VIDEO
 * **************************************** */
/* EMBED VIDEO */
.jt-embed-video { margin-left: auto; margin-right: auto; position: relative; } 
.jt-embed-video__inner { position: relative; width: 100%; padding-top: 46.91%; overflow: hidden; }
.jt-embed-video__inner iframe { width: calc(100% - 2px); height: calc(100% - 2px); position: absolute; top: 1px; left: 1px; box-sizing: content-box; background: #000 url(../images/layout/spin.png) no-repeat center center; background-size: 32rem 32rem; }
.jt-embed-video__poster { width: 100%; height: 100%; position: absolute; top: 0; left: 0; cursor: pointer; z-index: 1; }
.jt-embed-video__poster .jt-embed-video__img { display: block; width: 100%; height: 100%; object-fit: cover; }
.jt-embed-video__poster:after { content: ''; position: absolute; top: 0; bottom: 0; left: 0; right: 0; background: rgba(0, 0, 0, .3); opacity: 0; transition: opacity .3s; z-index: 1; }
.jt-embed-video__overlay { display: block; width: 100%; height: 100%; position: absolute; top: 0; left: 0; background: rgba(0, 0, 0, .2); z-index: 2; }
.jt-embed-video__overlay-btn { display: block; width: 64rem; height: 64rem; margin-top: -32rem; margin-left: -32rem; position: absolute; top: 50%; left: 50%; }
.jt-embed-video__overlay-btn svg { display: block; width: 100%; height: auto; }
.jt-embed-video__overlay-btn svg path { fill: var(--color-white); }



/* **************************************** *
 * SWIPER
 * **************************************** */
.swiper { height: 100%; }

/* NAVIGATION */
.swiper-navigation .swiper-button { width: 64rem; height: 64rem; margin: 0; padding: 0; margin-top: -32rem; background: transparent; border: 2rem solid var(--color-primary); border-radius: 50%; transition: background-color .3s; }
.swiper-navigation .swiper-button:after { display: none; }
.swiper-navigation .swiper-button-prev { left: -128rem; }
.swiper-navigation .swiper-button-next { right: -128rem; }
.swiper-navigation .swiper-button .jt-icon { width: 32rem; position: absolute; top: 50%; left: 50%; translate: -50% -50%; }

/* PAGINATION */
.swiper-control { display: none; }



/* **************************************** *
 * MEDIA POPUP
 * **************************************** */
.jt-mdp { background-color: rgba(0, 0, 0, 0.9); overflow: hidden; }
.jt-mdp__content > img { border: 12rem solid var(--color-primary); }

.jt-mdp__close { width: 40rem; height: 40rem; position: absolute; top: 0; background: transparent; border-radius: 0; }
.jt-mdp__close, html.win .jt-mdp__close { right: -64rem; }
.jt-mdp__close > i { width: 100%; }
.jt-mdp__close > i > svg > path { fill: var(--color-primary); }

body.open-jt-mdp { overflow-y: auto; }



/* **************************************** *
 * JT ACCORDION LIST
 * **************************************** */
.jt-accordion__item { width: 100%; border-bottom: 1px solid var(--color-primary); }

.jt-accordion__head { padding: 20rem 60rem 20rem 0; position: relative; cursor: pointer; }
.jt-accordion__control { width: 20rem; height: 20rem; position: absolute; top: 28rem; right: 16rem; transition: rotate .3s; }
.jt-accordion__control .jt-icon { width: 12rem; position: absolute; top: 50%; left: 50%; translate: -50% -50%; }

.jt-accordion__content { overflow: hidden; }
.jt-accordion__content-inner { padding: 20rem 0; border-top: 1px solid var(--color-primary); }
.jt-accordion__content-inner p ~ p { margin-top: 15rem; }

.jt-accordion .jt-accordion__item:not(:first-child) .jt-accordion__content .jt-accordion__content-inner { display: none; }

/* ACTIVE */
.jt-accordion__item.jt-accordion--active .jt-accordion__control { rotate: -180deg; }



/* **************************************** *
 * HOVER
 * **************************************** */
@media (hover: hover) and (pointer: fine) {

    /* BUTTON */
    .jt-btn__icon:hover:after { transform-origin: 0% 50%; transform: scale3d(1, 1, 1); }

    /* SWIPER */
    .swiper-navigation .swiper-button:hover { background: var(--color-primary); }
    .swiper-navigation .swiper-button:hover .jt-icon svg path { fill: var(--color-black); }

    /* VIDEO */
    .jt-embed-video__poster:hover:after { opacity: 1; }

}