.section-heading { margin-bottom: 60px; }
.section-heading .badge { display: block; font-size: 2.8rem; font-weight: 600; color: var(--clr-black); }
.section-heading .heading { margin-top: 60px; max-width: 75%; font-size: 5.4rem; font-weight: 600; color: var(--clr-black); }
.section-heading .text { margin-top: 40px; font-size: 2rem; }
.section-heading [data-split] { opacity: 0; }
.section-heading [data-split-ready] { opacity: 1; }
.section-heading .sentence { transform: translateY(100%); will-change: transform; }
.section-heading .line { overflow: hidden; display: flex; flex-wrap: nowrap; }
.section-heading .line .word { white-space: nowrap; }
@media screen and (max-width: 1024px) {
    .section-heading { margin-bottom: 40px; }
    .section-heading .badge { font-size: 2rem; }
    .section-heading .heading { margin-top: 34px; max-width: none; font-size: 2.8rem }
    .section-heading .text { margin-top: 20px; font-size: 1.6rem; }
}
@media screen and (max-width: 768px) {
    .section-heading { margin-bottom: 34px; }
    .section-heading .badge { font-size: 1.5rem; }
    .section-heading .heading { margin-top: 20px; font-size: 2rem }
    .section-heading .text { margin-top: 12px; font-size: 1.5rem; }
}

.intro { z-index: 99; position: fixed; top: 0; left: 0; width: 100%; height: 100%; }
.intro .contents { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.intro .contents .heading { font-size: clamp(1.5rem, 4vw, 3.8rem); font-weight: 600; color: #111; white-space: nowrap; visibility: hidden; opacity: 0; }
.intro .logo { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.intro .logo .item { width: 360px; visibility: hidden; opacity: 0; }

.hero { overflow: hidden; z-index: 3; position: relative; height: 100svh; background: #111; }
.hero .hero-slide .swiper-slide { height: calc(var(--vh) * 100); height: 100svh; box-sizing: border-box; transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1); }
.hero .hero-slide .background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; transform: scale(1); }
.hero .hero-slide .background .item { position: absolute; width: 100%; height: 100%; object-fit: cover; will-change: transform; }
.hero .hero-slide .background .item-mobile { display: none; }
.hero .hero-slide .background::before,
.hero .hero-slide .background::after { content: ''; z-index: 2; position: absolute; left: 0; width: 100%; pointer-events: none; }
.hero .hero-slide .background::before { top: 0; height: 50%; background: linear-gradient(180deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 100%); opacity: 0.16; }
.hero .hero-slide .background::after { bottom: 0; height: 50%; background: linear-gradient(0deg, rgba(0, 0, 0, 1) -10%, rgba(0, 0, 0, 0) 100%); opacity: 0.55; }
.hero .hero-slide .contents { display: flex; flex-direction: column; justify-content: flex-end; position: absolute; top: 0; left: 0; right: 0; margin: auto; padding-bottom: 245px; max-width: var(--inner); width: 92%; height: 100%; }
.hero .hero-slide .contents .sentence { transform: translateY(100%); will-change: transform; }
.hero .hero-slide .contents .line { overflow: hidden; }
.hero .hero-slide .contents .heading { line-height: 1.45; font-size: clamp(2.1rem, 3.2vw, 6.8rem); font-weight: 700; color: #fff; }
.hero .hero-slide .contents .text { margin-top: 20px; font-size: clamp(1.4rem, 3.2vw, 2.2rem); font-weight: 600; color: #fff; }
/* .hero .controls { z-index: 2; display: flex; position: absolute; bottom: 60px; left: 0; right: 0; margin-right: auto; margin-left: auto; max-width: var(--inner); width: 92%; }
.hero .controls .toggle { flex-shrink: 0; display: block; position: relative; margin-left: 5px; width: 50px; height: 50px; border-radius: 50%; }
.hero .controls .toggle::before { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: auto; width: 16px; height: 16px; background: url('/common/images/pause-light.svg') no-repeat center / auto 150%; pointer-events: none; }
.hero .controls .toggle[data-state="pause"]::before { background-image: url('/common/images/play-light.svg'); } */
.hero .swiper-pagination { display: flex; align-items: center; justify-content: flex-start; position: relative; bottom: 180px; left: 0; right: 0; margin: auto; width: 92%; max-width: var(--inner); }
.hero .swiper-pagination .swiper-pagination-bullet { display: flex; align-items: center; justify-content: center; position: relative; margin: 0 7px; width: 5px; height: 5px; background: #fff; opacity: 0.6; border-radius: 5px; transition: all ease .35s; user-select: none; }
.hero .swiper-pagination .swiper-pagination-bullet:first-child { margin-left: 0; }
.hero .swiper-pagination .swiper-pagination-bullet:last-child { margin-right: 0; }
.hero .swiper-pagination .swiper-pagination-bullet-active { width: 25px; opacity: 1; }
.hero .swiper-pagination .swiper-pagination-bullet-active .text { transform: none; }
.hero .swiper-pagination .swiper-pagination-bullet-active::before { transform: none; transition-delay: 0.2s; }

.hero .scroll { z-index: 3; position: absolute; bottom: 140px; right: -30px; }
.hero .scroll .text { margin-bottom: 24px; font-family: var(--font-display); font-size: 1.4rem; color: #fff; transform: rotate(-90deg); transform-origin: left; }
.hero .scroll .item { overflow: hidden; position: relative; margin-left: -20px; width: 40px; height: 40px; border: 1px solid rgb(255 255 255 / 100%); border-radius: 50%; }
.hero .scroll .item::after { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: auto; width: 4px; height: 4px; background: #fff; transform-origin: top; animation: hero-scroll ease-in-out 1.65s infinite; }

.hero .floatings { z-index: 3; position: absolute; right: 50px; bottom: 40px; }
.hero .floatings .button { --padding: 0 36px 0 28px; width: 190px; height: 60px; font-size: 1.6rem; font-weight: 500; }
.hero .floatings .button .icon { margin-right: 4px; width: 32px; height: 32px; }

.overview { padding: 140px 0; }
.overview .lists { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; }
.overview .lists .thumbnail { overflow: hidden; background: #000; border-radius: 16px; }
.overview .lists .image { display: block; border-radius: inherit; opacity: 0; transform: scale(1.05); transition-property: opacity, transform; transition-duration: 0.65s, 1.4s; transition-timing-function: ease; }
.overview .buttons { display: flex; align-items: center; position: absolute; top: 114px; right: 0; }
.overview .lists .sr-animate .image { opacity: 1; transform: none; }
.overview .lists .item:nth-child(1) .thumbnail { background: #041c16; }
.overview .lists .item:nth-child(2) .thumbnail { background: #221404; }

.technology { position: relative; height: 300vh; height: 400dvh; color: #fff; }
.technology .technology-wrap { overflow: hidden; position: sticky; top: 0; left: 0; width: 100%; height: 100dvh; clip-path: circle(18% at 50% 50%); }
.technology .background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.technology .background .image { display: block; width: 100%; height: 100%; object-fit: cover; }
.technology .inner { height: 100%; }
.technology .flex { display: flex; justify-content: space-between; }
.technology .flex .side { padding-top: 140px; width: 50.6%; }
.technology .flex .contents { width: 40.2439%; }
.technology .lists { display: grid; gap: 16px; padding: 140px 0; }
.technology .lists .block { display: block; padding: 60px 48px 40px; background: rgb(0 0 0 / 60%); border: 1px solid transparent; border-radius: 8px; transition: all .15s ease; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.technology .lists .badge { font-size: 1.6rem; font-weight: 500; color: var(--clr-primary); }
.technology .lists .title { margin: 20px 0; font-size: 3.8rem; font-weight: 600; }
.technology .lists .text { font-weight: 500; }
.technology .lists .buttons { display: flex; justify-content: flex-end; margin-top: 34px; }
.technology .lists .link { display: inline-flex; align-items: center; justify-content: center; width: 64px; height: 46px; background: var(--clr-primary); border-radius: 46px; opacity: 0; transform: translateY(35px); transition: all .35s ease; }

.story { padding: 140px 0; }
.story .lists { display: grid; grid-template-columns: repeat(3, 1fr); gap: 80px 40px; }
.story .lists .block { display: block; }
.story .lists .thumbnail { overflow: hidden; background: #f5f5f5; border-radius: 16px; transition: background .35s ease; }
.story .lists .thumbnail-wrap { overflow: hidden; border-radius: inherit; aspect-ratio: 1.4444; transition-property: opacity, transform; transition-duration: 0.65s, 0.85s; transition-timing-function: ease; will-change: transform; }
.story .lists .image { display: block; width: 100%; height: 100%; object-fit: cover; border-radius: inherit; opacity: 0; transform: scale(1.1); transition-property: opacity, transform; transition-duration: 0.65s, 1.4s; transition-timing-function: ease; }
.story .lists .contents { text-align: center; }
.story .lists .title { margin-top: 32px; font-size: 2.8rem; font-weight: 600; color: var(--clr-black); }
.story .lists .text { margin-top: 12px; color: #555; }
.story .buttons { display: flex; align-items: center; position: absolute; top: 114px; right: 0; }
.story .lists .sr-animate .image { opacity: 1; transform: none; }

.news { padding: 140px 0; }
.news .buttons { display: flex; align-items: center; position: absolute; top: 114px; right: 0; }
.news .news-slide .item { width: 33.33333%; }
.news .news-slide .block { display: block; }
.news .lists .thumbnail { overflow: hidden; background: #f5f5f5; border-radius: 16px; transition: background .35s ease; }
.news .lists .thumbnail-wrap { overflow: hidden; border-radius: inherit; aspect-ratio: 1.625; transition-property: opacity, transform; transition-duration: 0.65s, 0.85s; transition-timing-function: ease; will-change: transform; }
.news .lists .image { display: block; width: 100%; height: 100%; object-fit: cover; border-radius: inherit; opacity: 0; transform: scale(1.1); transition-property: opacity, transform; transition-duration: 0.65s, 1.4s; transition-timing-function: ease; }
.news .news-slide .title { margin-top: 24px; font-size: 2.4rem; font-weight: 600; color: var(--clr-black); }
.news .news-slide .text { margin-top: 28px; font-size: 1.6rem; color: #555; }
.news .controls { display: flex; align-items: center; margin-top: 60px; }
.news .controls .swiper-pagination { position: static; margin: 0; background: #f2f2f2; }
.news .controls .swiper-button-prev,
.news .controls .swiper-button-next { flex-shrink: 0; position: static; margin-top: 0; margin-left: 16px; width: 50px; height: 50px; color: #333; border: 1px solid #333; border-radius: 50%; transition: all .15s ease; }
.news .controls .swiper-button-prev { margin-left: 40px; }
.news .lists.sr-animate .image { opacity: 1; transform: none; }

.contact { padding: 140px 0; }
.contact .lists { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; }
.contact .lists .block { overflow: hidden; display: block; position: relative; height: 340px; border-radius: 16px; }
.contact .lists .background { overflow: hidden; position: absolute; top: 0; left: 0; display: block; width: 100%; height: 100%; object-fit: cover; background: #000; }
.contact .lists .background .image { display: block; width: 100%; height: 100%; object-fit: cover; opacity: 0; transform: scale(1.1); transition-property: opacity, transform; transition-duration: 0.65s, 1.4s; transition-timing-function: ease; }
.contact .lists .background::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); transition: opacity .65s ease; opacity: 0; }
.contact .lists .contents { position: absolute; top: 0; left: 0; padding: 48px 60px; width: 100%; height: 100%; color: #fff; }
.contact .lists .title { line-height: 1.2; font-size: 4.8rem; font-weight: 600; }
.contact .lists .text { margin-top: 42px; font-size: 2rem; }
.contact .lists .item:nth-child(1) .background { background: #3e587b; }
.contact .lists .item:nth-child(2) .background { background: #737246; }
.contact .lists .sr-animate .image { opacity: 1; transform: none; }
@keyframes hero-scroll {
    0% { transform: translateY(-14px); opacity: 0; }
    10% { opacity: 1; }
    50% { opacity: 1; }
    60% { transform: translateY(14px); opacity: 0; }
    100% { transform: translateY(14px); opacity: 0; }
}
@media (hover: hover) and (pointer: fine) {
	.contact .lists .block:hover .background::after { opacity: 1; }

	.technology .lists .block:hover { border-color: var(--clr-primary); }
	.technology .lists .block:hover .link { opacity: 1; transform: none; }

	.story .lists .block:hover .thumbnail { background: #000; }
	.story .lists .block:hover .thumbnail-wrap { opacity: 0.8; transform: scale(1.1); }

	.news .lists .block:hover .thumbnail { background: #000; }
	.news .lists .block:hover .thumbnail-wrap { opacity: 0.8; transform: scale(1.1); }
	.news .controls .swiper-button-prev:hover,
	.news .controls .swiper-button-next:hover { color: #fff; background: var(--clr-primary); border-color: var(--clr-primary); }
}
@media screen and (min-width: 1025px) {
    .technology .section-heading .badge,
    .technology .section-heading .heading { color: inherit; }
}
@media screen and (max-width: 1024px) {
    .hero .hero-slide .contents .text { margin-top: 16px; }
    .hero .scroll { right: 0; margin-right: -22px; }
    .hero .floatings { right: 4%; }
    .hero .floatings .button { --padding: 0; width: 170px; height: 50px; font-size: 1.5rem; }
    .hero .floatings .button .icon { margin-left: -6px; width: 28px; height: 28px; }

    .overview { padding: 80px 0; }
    .overview .lists { gap: 24px; }
    .overview .lists .thumbnail { border-radius: 10px; }
    .overview .buttons { position: static; margin-top: 30px; }

    .technology { height: auto; color: inherit; }
    .technology .technology-wrap { position: static; height: auto; clip-path: none; }
    .technology .flex { display: block; }
    .technology .flex .side { padding: 0; width: 100%; }
    .technology .flex .contents { width: 100%; }
    .technology .background { display: none; }
    .technology .lists { grid-template-columns: repeat(2, 1fr); padding: 0; }
    .technology .lists .block { display: flex; flex-direction: column; padding: 36px; height: 100%; background: none; border: 1px solid var(--border); }
    .technology .lists .title { margin: 14px 0; font-size: 2.4rem; color: var(--clr-dark); }
    .technology .lists .buttons { justify-content: flex-start; margin-top: auto; }
    .technology .lists .text { margin-bottom: 24px; }
    .technology .lists .link { width: 50px; height: 36px; color: #fff; opacity: 1; transform: none; }
    .technology .lists .badge { font-size: 1.4rem; }

    .story { padding: 80px 0; }
    .story .lists { gap: 42px 24px; }
    .story .lists .thumbnail { border-radius: 10px; }
    .story .lists .title { margin-top: 20px; font-size: 2rem; }
    .story .lists .text { margin-top: 4px; font-size: 1.5rem; }
    .story .buttons { position: static; margin-top: 30px; }

    .news { padding: 0; }
    .news .lists .thumbnail { border-radius: 10px; }
    .news .lists .title { margin-top: 20px; font-size: 2rem; }
    .news .lists .text { margin-top: 10px; font-size: 1.5rem; }
    .news .buttons { position: static; margin-top: 30px; }
    .news .controls { margin-top: 40px; }
    .news .controls .swiper-button-prev,
    .news .controls .swiper-button-next { margin-left: 10px; width: 40px; height: 40px; }

    .contact { padding: 80px 0 120px; }
    .contact .lists { gap: 24px; }
    .contact .lists .block { border-radius: 10px; height: 230px; }
    .contact .lists .contents { padding: 36px; }
    .contact .lists .title { font-size: 3.2rem; }
    .contact .lists .text { margin-top: 14px; font-size: 1.6rem; }
}
@media screen and (max-width: 768px) {
    .hero .hero-slide .contents { padding-bottom: 135px; padding-right: 36px; }
    .hero .swiper-pagination { bottom: 46px; }
    .hero .scroll { bottom: 110px; margin-right: -26px; }
    .hero .scroll .text { margin-bottom: 4px; font-size: 1.2rem; }
    .hero .scroll .item { margin-left: -12px; width: 24px; height: 24px; }
    .hero .floatings .button { width: 140px; height: 45px; font-size: 1.3rem; }

    .overview { padding: 60px 0; }
    .overview .buttons { margin-top: 24px; }

    .technology .lists .block { padding: 24px; }
    .technology .lists .badge { font-size: 1.3rem; }
    .technology .lists .title { margin: 10px 0; font-size: 2rem; }

    .story { padding: 60px 0; }
    .story .lists { grid-template-columns: repeat(2, 1fr); }
    .story .lists .title { margin-top: 20px; font-size: 1.6rem; }
    .story .lists .text { font-size: 1.4rem; }
    .story .buttons { margin-top: 24px; }

    .news { padding: 0; }
    .news .lists .title { margin-top: 20px; font-size: 1.6rem; }
    .news .lists .text { font-size: 1.4rem; }
    .news .controls { margin-top: 24px; }
    .news .buttons { margin-top: 24px; }

    .contact { padding-top: 60px; }
    .contact .lists .title { font-size: 2.4rem; }
    .contact .lists .text { margin-top: 12px; font-size: 1.5rem; }
    .contact .lists .block { height: 180px; }
}
@media screen and (max-width: 480px) {
    .hero .scroll { margin-right: -40px; }

    .overview .lists { grid-template-columns: repeat(1, 1fr); gap: 16px; }

    .technology .lists { grid-template-columns: repeat(1, 1fr); }

    .story .lists { grid-template-columns: repeat(1, 1fr); }

    .contact .lists { grid-template-columns: repeat(1, 1fr); gap: 16px; }
    .contact .lists .block { height: 140px; }
    .contact .lists .contents { padding: 28px; }
}

/* for Global */
@media screen and (min-width: 1025px) {
    [lang="en"] .hero .hero-slide .contents .heading { line-height: 1.2; }
    [lang="en"] .hero .hero-slide .contents .text { margin-top: 30px; }
}
@media screen and (max-width: 1024px) {

}
@media screen and (max-width: 768px) {
	[lang="en"] .hero .floatings .button { width: 120px; }
}
