@charset "UTF-8";
.home_page .key {
    --min-height: 100vh;
    min-height: var(--min-height);
    max-height: var(--max-height);
    overflow: hidden;
}

.home_page .key:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    background: url(../images/idx-bg-main.png) no-repeat center;
    background-size: cover;
    display: none;
}

.home_page .key .video {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
}

.home_page .key .inner_big {
    position: relative;
    padding-top: 228px;
    min-height: var(--min-height);
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: space-between;
}

.home_page .key .inner_big .box-list-key {
    position: absolute;
    right: 10px;
    bottom: 0;
    background: #fff;
    width: 780px;
    display: flex;
    align-items: center;
    min-height: 60px;
    padding-left: 30px;
}

.home_page .key .inner_big .box-list-key ul {
    padding-bottom: 2px;
    width: calc(100% - 125px);
}

.home_page .key .inner_big .box-list-key ul li a {
    text-decoration: none;
    color: var(--clr1);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    padding-right: 60px;
}

.home_page .key .inner_big .box-list-key ul li a .date {
    font-size: 14px;
    font-family: var(--f-man);
    letter-spacing: 0.01em;
    margin-right: 25px;
    font-weight: 600;
}

.home_page .key .inner_big .box-list-key ul li a .ttl {
    font-size: 14px;
    font-weight: 600;
}

.home_page .key .inner_big .box-list-key .btn-arr {
    height: 60px;
    display: flex;
    flex: 1;
}

.home_page .key .inner_big .box-list-key .btn-arr .slick-arrow {
    width: 64px;
    height: 100%;
    display: flex !important;
    align-items: center;
    justify-content: center;
    transform: none;
    position: relative;
    top: 0;
    background: none;
}

.home_page .key .inner_big .box-list-key .btn-arr .slick-arrow.prev {
    border-right: 1px solid #000;
    border-left: 1px solid #000;
}

.home_page .key .inner_big .box-list-key .btn-arr .slick-arrow.next img {
    transform: rotate(180deg);
}

.home_page .key .inner {
    position: relative;
    height: 100%;
    padding: 0;
}

.home_page .key .key_text {
    position: relative;
    width: 100%;
    height: 100%;
}

.home_page .key .key_text .item {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    height: var(--height);
    min-height: var(--min-height);
    max-height: var(--max-height);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.home_page .key .catch {
    padding: 10px;
    margin: 0px auto;
    max-width: 1100px;
}

.home_page .key .catch .title,
.home_page .key .catch p {
    color: #fff;
    font-weight: 500;
    letter-spacing: 0.1em;
}

.home_page .key .catch .title {
    margin-bottom: 24px;
    font-size: 70px;
    line-height: 1.4em;
    letter-spacing: 0;
}

.home_page .key .catch p {
    font-size: 18px;
    line-height: 1.7em;
    letter-spacing: 0;
}

.home_page .key .catch .txt-animation {
    white-space: nowrap;
    animation: catch_main 0s 0.9s forwards;
    mix-blend-mode: hard-light;
    display: flex;
    position: absolute;
    bottom: -88px;
}

.home_page .key .catch .txt-animation span {
    font-weight: bold;
    color: transparent;
    font-size: 85.6px;
    -webkit-text-stroke: 1px white;
    font-family: var(--f-en);
    letter-spacing: 0;
    animation: txt_scroll 40s linear infinite;
    display: inline-block;
    margin-right: 40px;
}

.home_page .topic_path {
    display: none;
}

.home_page h2 {
    position: relative;
    margin-bottom: 35px;
    color: var(--clr1);
    font-family: var(--f-jp);
    font-size: calc(var(--ttl_size) + 14px);
    font-weight: 500;
    letter-spacing: 0.15em;
}

.home_page h2 .en {
    color: var(--main-color);
    font-weight: 500;
    text-transform: uppercase;
}

.home_page h2.white {
    color: #fff;
}

.home_page h2.white .en {
    color: #fff;
}

.home_page h3 {
    color: var(--clr1);
    font-family: var(--f-jp);
    font-size: calc(var(--ttl_size) + 0px);
}

.home_page .idx-ttl-en {
    font-size: 100px;
    font-family: var(--f-en);
    letter-spacing: 0;
    line-height: 0.7em;
    color: var(--clr2);
    margin-bottom: 6px;
    font-weight: bold;
    white-space: nowrap;
}

.home_page .idx-ttl-jp {
    font-size: 18px;
    letter-spacing: 0.1em;
    font-family: var(--f-zennew);
    font-weight: 600;
    color: #0E0E0E;
    position: relative;
    display: flex;
    align-items: center;
    margin-bottom: 30px;
}

.home_page .idx-ttl-jp:before {
    content: "";
    position: relative;
    width: 40px;
    height: 1px;
    background: var(--clr2);
    margin-right: 7px;
}

.home_page .idx-ttl01 {
    font-size: 30px;
    letter-spacing: 0.1em;
    font-weight: bold;
}

.link-in {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    z-index: 1;
}

.box-key-icon {
    position: absolute;
    bottom: 31px;
    left: 41px;
}

.box-key-icon .txt {
    writing-mode: tb-rl;
    color: #fff;
    font-family: var(--f-en);
    font-weight: 600;
    font-size: 8px;
    letter-spacing: 0;
    padding-bottom: 30px;
    position: relative;
    margin-bottom: 25px;
}

.box-key-icon .txt:before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    bottom: -8px;
    margin: 0 auto;
    height: 30px;
    width: 1px;
    background: #fff;
}

.box-key-icon ul li {
    margin-bottom: 15px;
}

.box-key-icon ul li:last-child {
    margin-bottom: 0;
}

@keyframes catch_main {
    0% {
        overflow: hidden;
    }
    100% {
        overflow: visible;
    }
}

@keyframes txt_scroll {
    0% {
        transform: translateX(200px);
    }
    100% {
        transform: translateX(calc(-100% + 200px));
    }
}

@keyframes txt_scroll2 {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-100%);
    }
}

section {
    background-size: cover;
    background-repeat: no-repeat;
}

.index0 {
    background: url(../images/idx-bg-box01.png) no-repeat center;
    background-size: cover;
    min-height: 720px;
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.index01 {
    position: relative;
}

.index01:before {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    background: url(../images/idx-box01-img02.png) no-repeat right;
    background-size: cover;
    height: 100%;
    width: 65%;
}

.index01 .inner_big {
    position: relative;
    min-height: 814px;
}

.index01-fx {
    display: flex;
    padding-left: 90px;
    padding-top: 126px;
    align-items: center;
}

.index01-fx .box-left {
    padding-left: 10px;
    width: 37%;
    padding-right: 60px;
}

.index01-fx .box-left .txt {
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.9em;
    margin-bottom: 32px;
}

.index01-fx .box-left .idx-ttl01 {
    margin-bottom: 30px;
}

.index01-fx .box-left .idx-ttl-en {
    margin-left: -10px;
}

.index01-fx .box-right {
    position: relative;
    width: 63%;
    text-align: center;
    padding-top: 90px;
    padding-left: 20px;
}

.index01-fx .box-right .box-img {
    position: relative;
}

.index01-fx .box-right .box-img .box01-list-right {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

.index01-fx .box-right .box-img .box01-list-right li {
    display: block;
    width: fit-content;
}

.index01-fx .box-right .box-img .box01-list-right li:nth-child(1) {
    position: absolute;
    right: 60px;
    top: -70px;
}

.index01-fx .box-right .box-img .box01-list-right li:nth-child(2) {
    position: absolute;
    left: 0;
    right: initial;
    top: initial;
    bottom: -18px;
}

.index01-fx .box-right .box-img .box01-list-right li:nth-child(2) .ttl {
    min-width: 285px;
}

.index01-fx .box-right .box-img .box01-list-right li:nth-child(2) .ttl:before {
    bottom: initial;
    top: -76px;
    left: initial;
    right: 70px;
    height: 80px;
    transform: rotate(-30deg);
}

.index01-fx .box-right .box-img .box01-list-right li:nth-child(3) {
    position: absolute;
    bottom: -104px;
    right: 108px;
}

.index01-fx .box-right .box-img .box01-list-right li:nth-child(3) .ttl:before {
    bottom: initial;
    top: -60px;
    left: initial;
    right: 70px;
    height: 70px;
    transform: rotate(-42deg);
}

.index01-fx .box-right .box-img .box01-list-right li .ttl {
    font-size: 30px;
    font-family: var(--f-zennew);
    font-weight: 600;
    color: #fff;
    background: var(--clr2);
    line-height: 1.5em;
    margin-bottom: 0;
    letter-spacing: -0.5px;
    padding: 0px 2px 3px 8px;
    max-width: 285px;
    position: relative;
}

.index01-fx .box-right .box-img .box01-list-right li .ttl:before {
    content: "";
    position: absolute;
    left: 48px;
    bottom: -25px;
    height: 30px;
    width: 1px;
    transform: rotate(25deg);
    border-left: 1px dotted #F6740C;
}

.index01-fx .box-right .box-img .box01-list-right li .sub-ttl {
    color: #fff;
    font-family: var(--f-zennew);
    font-weight: 600;
    font-size: 18px;
    text-align: right;
    line-height: 1em;
    margin-top: 5px;
    padding-right: 12px;
    letter-spacing: 0.05em;
}

.index01-fx .box-right .img {
    position: relative;
}

.index01-fx .box-right .img:before {
    content: "ACE \aMAKE's \a 3S";
    position: absolute;
    font-family: var(--f-en);
    font-weight: 600;
    background: #fff;
    color: var(--clr1);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    padding: 4px 2px 0;
    line-height: 1em;
    min-width: 312px;
    left: 73px;
    top: 94px;
    letter-spacing: 0;
}

.idx-hover {
    position: relative;
}

.idx-hover .item-hover {
    position: relative;
    right: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    cursor: pointer;
}

.transform-gpu {
    transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.index02 {
    background: var(--clr2);
    overflow: hidden;
    position: relative;
}

.index02 .idx-ttl-en,
.index02 .idx-ttl-jp {
    color: #fff;
    position: absolute;
    top: 115px;
    margin-left: 90px;
}

.index02 .idx-ttl-en {
    line-height: 0.95em;
    position: relative;
    overflow: hidden;
}

.index02 .idx-ttl-en span.row {
    display: block;
}

.index02 .idx-ttl-jp {
    top: 304px;
    margin-left: 100px;
}

.index02 .idx-ttl-jp:before {
    background: #fff;
}

.index02 .box-img {
    position: relative;
    text-align: center;
    width: calc(100% + 420px);
    left: calc(50% + 86px);
    transform: translate(-50%);
    top: -219px;
    margin-bottom: -551px;
}

.index02 .box-img .svg {
    position: relative;
    z-index: 1;
    mix-blend-mode: screen;
}

.index02 .box-img .item01 {
    position: relative;
}

.index02 .box-img .item01 .link-in {
    left: 0;
    top: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    clip-path: polygon(0 0, 100% 0, 70% 100%, 30% 100%);
}

.index02 .box-img .box02-list-hover02 {
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    top: 0;
    bottom: 0;
    width: fit-content;
    height: fit-content;
    width: 100%;
    max-width: 470px;
}

.index02 .box-img .box02-list-hover02 li {
    pointer-events: none;
    background: linear-gradient(0deg, rgb(254, 194, 91) 0%, rgba(255, 255, 255, 0) 100%);
    opacity: 0;
    visibility: hidden;
    position: absolute;
    mix-blend-mode: screen;
}

.index02 .box-img .box02-list-hover02 li:first-child {
    width: 730px;
    height: 611px;
    clip-path: polygon(0 0, 100% 0, 59% 100%, 38% 100%);
    transform: translate(-11px, -694px) rotate(24.8deg);
}

.index02 .box-img .box02-list-hover02 li:nth-child(2) {
    width: 714px;
    height: 581px;
    clip-path: polygon(0 0, 100% 0, 60% 100%, 39% 100%);
    transform: translate(228px, -362px) rotate(76.7deg);
}

.index02 .box-img .box02-list-hover02 li:nth-child(3) {
    width: 544px;
    height: 410px;
    clip-path: polygon(0 0, 100% 0, 65% 100%, 37% 100%);
    transform: translate(161px, 46px) rotate(129deg);
}

.index02 .box-img .box02-list-hover02 li:nth-child(4) {
    width: 542px;
    height: 410px;
    clip-path: polygon(0 0, 100% 0, 65% 100%, 37% 100%);
    transform: translate(-119px, 183px) rotate(180.5deg);
}

.index02 .box-img .box02-list-hover02 li:nth-child(5) {
    width: 544px;
    height: 410px;
    clip-path: polygon(0 0, 100% 0, 65% 100%, 37% 100%);
    transform: translate(-405px, 49px) rotate(-128deg);
}

.index02 .box-img .box02-list-hover02 li:nth-child(6) {
    width: 716px;
    height: 580px;
    clip-path: polygon(0 0, 100% 0, 60% 100%, 39% 100%);
    transform: translate(-644px, -367px) rotate(-77.3deg);
}

.index02 .box-img .box02-list-hover02 li:last-child {
    width: 734px;
    height: 611px;
    clip-path: polygon(0 0, 100% 0, 59% 100%, 38% 100%);
    transform: translate(-413px, -699px) rotate(-26.5deg);
}

.index02 .box-img .box02-list-hover02 li.active {
    opacity: 1;
    visibility: visible;
}

.index02 .box-img .box02-list-hover {
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    top: 0;
    bottom: 0;
    width: fit-content;
    height: fit-content;
    width: 100%;
    max-width: 470px;
}

.index02 .box-img .box02-list-hover li {
    background: #3E3E3E;
    max-width: 470px;
    width: 100%;
    position: absolute;
    opacity: 0;
    visibility: hidden;
}

.index02 .box-img .box02-list-hover li.active {
    opacity: 1;
    visibility: visible;
}

.index02 .box-img .box02-list-hover li:nth-child(1) {
    transform: translate(269px, -225px);
}

.index02 .box-img .box02-list-hover li:nth-child(2) {
    transform: translate(310px, -14px);
}

.index02 .box-img .box02-list-hover li:nth-child(3) {
    transform: translate(290px, 126px);
}

.index02 .box-img .box02-list-hover li:nth-child(4) {
    transform: translate(-90px, 212px);
}

.index02 .box-img .box02-list-hover li:nth-child(5) {
    transform: translate(-470px, 136px);
}

.index02 .box-img .box02-list-hover li:nth-child(6) {
    transform: translate(-350px, 16px);
}

.index02 .box-img .box02-list-hover li:nth-child(7) {
    transform: translate(-200px, -174px);
}

.index02 .box-img .box02-list-hover li .fx-cnt {
    display: flex;
    justify-content: space-between;
    min-height: 241px;
}

.index02 .box-img .box02-list-hover li .fx-cnt .img {
    line-height: 0;
    width: 190px;
    flex-shrink: 0;
}

.index02 .box-img .box02-list-hover li .fx-cnt .img img {
    object-fit: cover;
    height: 100%;
    width: 100%;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt {
    color: #fff;
    padding: 25px;
    text-align: left;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt h4 {
    font-size: 16px;
    font-family: var(--f-zennew);
    font-weight: 600;
    color: #fff;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt h4 .stt {
    font-size: 12px;
    font-family: var(--f-en);
    margin-right: 10px;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-ttl-en02 {
    font-size: 10px;
    color: var(--clr2);
    font-weight: 600;
    position: relative;
    padding-bottom: 12px;
    margin-bottom: 11px;
    line-height: 1.5em;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-ttl-en02:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 60px;
    height: 1px;
    background: #fff;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt .txt {
    font-size: 14px;
    letter-spacing: -0.5px;
    line-height: 1.75em;
    margin-bottom: 9px;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-btn a {
    min-width: 150px;
    color: #fff;
    background: var(--clr2);
    min-height: 35px;
    font-size: 14px;
    padding-bottom: 2px;
    border: 0;
}

.index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-btn a:before {
    filter: brightness(0) invert(1);
    right: 10px;
}

.index02 .box-gsap-list {
    position: relative;
    display: flex;
    align-items: center;
    z-index: 1;
    width: 100vw;
    height: calc(100vh - 100px);
    min-height: 600px;
}

.index02 .box-gsap-list ul {
    position: absolute;
    display: flex;
    padding-right: 0;
    padding-left: 102px;
}

.index02 .box-gsap-list ul li {
    height: 31.25vw;
    max-height: 600px;
    position: relative;
    width: 48.438vw !important;
    max-width: 900px;
    flex-shrink: 0;
    margin-right: 27px;
}

.index02 .box-gsap-list ul li:last-child {
    margin-right: 0;
}

.index02 .box-gsap-list ul li a {
    text-decoration: none;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: flex-end;
    position: relative;
}

.index02 .box-gsap-list ul li a:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    background: linear-gradient(0deg, rgb(0, 0, 0) 0%, rgba(255, 255, 255, 0) 100%);
    width: 100%;
    height: 19.688vw;
    max-height: 400px;
    z-index: 1;
    opacity: 0.7;
}

.index02 .box-gsap-list ul li a .cnt-fx .cnt label {
    cursor: default;
    display: block;
}

.index02 .box-gsap-list ul li a .cnt-fx .cnt .ttl {
    display: flex;
    align-items: center;
}

.index02 .box-gsap-list ul li a .cnt-fx .cnt .sub-ttl {
    margin-bottom: 10px;
}

.index02 .box-gsap-list ul li .img {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
    width: 100%;
    height: 100%;
}

.index02 .box-gsap-list ul li .img img {
    width: 100%;
    height: 100%;
}

.index02 .box-gsap-list ul li .cnt-fx {
    position: relative;
    z-index: 1;
    color: #fff;
    display: flex;
    align-items: flex-end;
    height: 100%;
    padding-left: 2.344vw;
    padding-right: 2.344vw;
    padding-bottom: 1.797vw;
}

.index02 .box-gsap-list ul li .cnt-fx .cnt .ttl {
    font-weight: 600;
    font-size: 25px;
    font-family: var(--f-zennew);
    letter-spacing: 0.1em;
    margin-bottom: 2px;
    line-height: 1.5em;
}

.index02 .box-gsap-list ul li .cnt-fx .cnt .ttl .stt {
    letter-spacing: 0;
    margin-right: 10px;
    font-size: 18px;
    font-family: var(--f-en);
    position: relative;
    bottom: -2px;
    line-height: 0;
}

.index02 .box-gsap-list ul li .cnt-fx .cnt .sub-ttl {
    font-size: 14px;
    font-family: var(--f-en);
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1em;
    display: block;
}

.index02 .box-gsap-list ul li .cnt-fx .cnt .txt {
    font-size: 16px;
    line-height: 1.7em;
    letter-spacing: 0;
}

.index02 .box-gsap-list ul li .cnt-fx .iBtn {
    flex-shrink: 0;
    margin-left: 25px;
    position: relative;
    bottom: 7px;
}

.index02-bg {
    position: relative;
    z-index: 1;
    margin-top: -1px;
}

.index02-bg:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 0;
    width: 100%;
    height: 100%;
    background: var(--clr2);
    z-index: -1;
    clip-path: polygon(0 0, 100% 100%, 100% 0);
}

.index02-list-img {
    display: flex;
    justify-content: center;
    position: relative;
}

.index02-list-img li {
    width: 234px;
    height: 310px;
    position: relative;
    overflow: hidden;
}

.index02-list-img li:nth-child(2) {
    margin: 0 35px;
    position: relative;
    width: 642px;
    height: 570px;
    overflow: hidden;
}

.index02-list-img li:last-child {
    display: flex;
    align-items: flex-end;
    margin-top: 260px;
}

.index02-list-img li:last-child .parallax-item {
    height: 130%;
}

.index02-list-img li .parallax-item {
    transform: translateY(0);
    transition: transform 0.3s ease-out;
    height: 110%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
}

.index02-list-img li .parallax-item img {
    height: 100%;
    object-fit: contain;
    width: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 0;
    right: 0;
}

.parallax-item {
    display: block;
    will-change: transform;
    /* Tối ưu hiệu suất */
    transition: transform 0.1s ease-out;
    /* Hiệu ứng mượt */
}


/* Hiệu ứng rung nhẹ */

.shake {
    animation: shake 0.2s infinite alternate;
}

@keyframes shake {
    0% {
        transform: translateY(0) rotate(0deg);
    }
    100% {
        transform: translateY(5px) rotate(2deg);
    }
}

.index03 {
    padding: 124px 0 120px;
}

.index03 .idx-ttl-jp {
    margin-bottom: 41px;
}

.index03 .index03-list {
    display: flex;
    justify-content: center;
    position: relative;
    z-index: 1;
}

.index03 .index03-list:before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    top: 50%;
    min-height: 150px;
    background: #FEF1E6;
    width: 100vw;
    z-index: -1;
}

.index03 .index03-list li {
    width: 33.3333333333%;
    max-width: 343px;
    margin-right: 30px;
    border: 1px solid #F6740C;
    padding: 17px 5px 17px 28px;
    min-height: 240px;
    background: #fff;
    position: relative;
    z-index: 1;
    box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.1);
}

.index03 .index03-list li:before {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: -1;
}

.index03 .index03-list li:first-child:before {
    background: url(../images/idx-box03-ico01.svg) no-repeat center;
    background-size: contain;
    width: 114px;
    height: 135px;
    bottom: 53px;
    right: 29px;
}

.index03 .index03-list li:nth-child(2):before {
    background: url(../images/idx-box03-ico02.svg) no-repeat center;
    background-size: contain;
    width: 180px;
    height: 126px;
    bottom: 53px;
    right: 29px;
}

.index03 .index03-list li:nth-child(3):before {
    background: url(../images/idx-box03-ico03.svg) no-repeat center;
    background-size: contain;
    width: 142px;
    height: 126px;
    bottom: 56px;
    right: 31px;
}

.index03 .index03-list li:last-child {
    margin-right: 0;
}

.index03 .index03-list li .ttl {
    font-size: 23px;
    font-family: var(--f-zennew);
    font-weight: bold;
    color: var(--clr2);
    line-height: 1.5em;
    position: relative;
    margin-bottom: 22px;
}

.index03 .index03-list li .ttl:before {
    content: "";
    position: absolute;
    left: 0;
    top: -17px;
    width: 20px;
    height: 6px;
    background: #F6740C;
}

.index03 .index03-list li .ttl02 {
    font-size: 18px;
    color: #0E0E0E;
    line-height: 1em;
    font-weight: 600;
    margin-bottom: -2px;
}

.index03 .index03-list li .num {
    line-height: 1em;
    font-weight: 600;
    color: var(--clr2);
    font-size: 80px;
    letter-spacing: -3px;
    font-family: var(--f-zennew);
    margin-bottom: 0;
}

.index03 .index03-list li .num span {
    line-height: 1em;
    font-size: 47px;
}

.index03 .index03-list li .sub-num {
    font-size: 12px;
    font-weight: 600;
}

.index04 {
    padding-top: 6.3em;
}

.index04 .index04-box {
    min-height: 800px;
    background: url(../images/idx-bg-box04.png) no-repeat center;
    background-size: cover;
    position: relative;
}

.index04 .index04-box .index04-cnt {
    position: absolute;
    right: 0;
    top: 0;
}

.index04 .index04-box .index04-cnt .index04-ttl {
    writing-mode: tb-rl;
    position: relative;
    padding-right: 58px;
    padding-top: 28px;
    padding-bottom: 53px;
    padding-left: 50px;
}

.index04 .index04-box .index04-cnt .index04-ttl:before {
    content: "";
    position: absolute;
    margin: auto;
    background: #F6740C;
    mix-blend-mode: multiply;
    width: 100%;
    height: 100%;
    right: 0;
    top: 0;
    bottom: 0;
    left: 0;
}

.index04 .index04-box .index04-cnt .index04-ttl .idx-ttl-en {
    color: #fff;
}

.index04 .index04-box .index04-cnt .index04-ttl .idx-ttl-jp {
    color: #fff;
    justify-content: flex-end;
    margin-right: 8px;
    margin-bottom: 10px;
}

.index04 .index04-box .index04-cnt .index04-ttl .idx-ttl-jp:before {
    background: #fff;
    height: 40px;
    width: 1px;
    left: 2px;
    margin-bottom: 12px;
}

.index04 .index04-box .index04-cnt .index04-sub-ttl {
    position: absolute;
    bottom: -50px;
    left: -24px;
    writing-mode: tb-rl;
    background: #fff;
    color: #0E0E0E;
    font-weight: 600;
    font-size: 30px;
    line-height: 1.66em;
}

.index04 .index04-box .iBtn {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -152px;
    margin: 0 auto;
    width: 300px;
    height: 300px;
    border-radius: 50%;
    background: #fff;
    font-size: 35px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    text-align: center;
    line-height: 1.15em;
    padding-bottom: 45px;
}

.index04 .index04-box .iBtn>p {
    text-decoration: none;
    flex-direction: column;
    display: flex;
    color: var(--clr2);
    font-family: var(--f-en);
    align-items: center;
    width: 100%;
    height: 100%;
    justify-content: center;
    line-height: 1em;
}

.index05 {
    padding-top: 120px;
    padding-bottom: 120px;
}

.index05 .inner_big {
    position: relative;
}

.index05 .inner_big:before {
    content: "";
    position: absolute;
    left: 10px;
    top: 101px;
    width: 870px;
    height: calc(100% + 20px);
    background: #F4F4F4;
}

.index05 .index05-fx {
    display: flex;
    position: relative;
    z-index: 1;
    margin-bottom: 68px;
}

.index05 .index05-fx:last-child {
    margin-bottom: 0 !important;
}

.index05 .index05-fx.index05-fx02 .box-cnt {
    order: 2;
    margin-right: 0;
    padding: 0 89px 71px 118px;
}

.index05 .index05-fx.index05-fx02 .box-img {
    order: 1;
    margin-right: -277px;
}

.index05 .index05-fx .box-cnt {
    order: 1;
    min-width: 627px;
    background: #fff;
    margin-top: 250px;
    position: relative;
    z-index: 1;
    margin-right: -277px;
    padding: 0 100px 60px;
}

.index05 .index05-fx .box-cnt .stt {
    font-size: 100px;
    line-height: 1em;
    color: var(--clr2);
    font-family: var(--f-en);
    font-weight: bold;
    margin-bottom: 40px;
    margin-top: -41px;
}

.index05 .index05-fx .box-cnt .box05-ttl {
    font-size: 30px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.4em;
    margin-bottom: 28px;
}

.index05 .index05-fx .box-cnt .txt {
    margin-bottom: 21px;
    letter-spacing: 0;
    font-weight: 500;
}

.index05 .index05-fx .box-img {
    order: 2;
    flex-shrink: 0;
}

.index06 {
    background: url(../images/idx-box06-bg.png) no-repeat center;
    background-size: 100% 100%;
    min-height: 592px;
    padding-top: 123px;
    padding-bottom: 120px;
    position: relative;
}

.index06 .index06-fx {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1180px;
    margin: 0 auto 41px;
    padding-right: 0;
}

.index06-blog .idx-btn a {
    color: #fff;
    min-width: 200px;
}

.index06-blog .idx-btn a:before {
    filter: brightness(0)invert(1);
}

.index06-blog .index06-fx {
    margin-bottom: 25px;
}

.index06-blog ul li {
    margin-bottom: 15px;
}

.index06-blog ul li:last-child {
    margin-bottom: 0;
}

.index06-blog ul li a {
    display: flex;
    align-items: center;
    text-decoration: none;
}

.index06-blog ul li a .img {
    width: 170px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #d4d4d4;
    margin-right: 1em;
    flex-shrink: 0;
    border-radius: 10px;
    overflow: hidden;
}

.index06-blog ul li a .cnt {
    color: #fff;
}

.index06-blog ul li a .cnt .date {
    display: block;
}

.index06-blog ul li a .date {
    font-size: 13px;
    margin-bottom: 5px;
}

.index06-blog ul li a .ttl {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.index06-blog ul li a .txt {
    font-size: 14px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.index06 .index06-fx .idx-ttl-en {
    font-size: 40px;
}

.index06 .index06-fx .insta-info {
    color: #fff;
    font-size: 14px;
    letter-spacing: 0;
    letter-spacing: 0.1em;
    position: relative;
    bottom: 2px;
}

.index06 .index06-fx .insta-info a {
    text-decoration: none;
    color: #fff;
}

.index06 .index06-fx .insta-info .ico {
    margin-right: 20px;
}

.index06 .index06-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.index06-box {
    max-width: 640px;
    margin-right: 5em;
    width: 100%;
    flex-shrink: 0;
}

.index06 .index06-list li {
    width: 33%;
    max-width: 208px;
    height: 208px;
    margin-right: 5px;
    margin-bottom: 5px;
}

.index06 .index06-list li:nth-child(3n) {
    margin-right: 0;
}

.index06 .index06-list li:last-child {
    margin-right: 0;
}

.transform-gpu {
    transform: translate3d(var(--tw-translate-x), var(--tw-translate-y), 0) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.idx-list-btn li:not(:last-child) {
    margin-bottom: 15px;
}

.idx-btn a {
    min-height: 50px;
    min-width: 250px;
    border-radius: 25px;
    border: 1px solid #E4E4E9;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 14px;
    color: var(--clr1);
    font-weight: 600;
    position: relative;
}

.idx-btn a:before {
    content: "";
    position: absolute;
    right: 18px;
    top: 0;
    bottom: 0;
    margin: auto 0;
    background: url(../images/idx-ico-arr.svg) no-repeat center;
    background-size: contain;
    width: 10px;
    height: 10px;
    transform: rotate(180deg);
}

.index07 {
    background: #F6740C;
    position: relative;
    padding-bottom: 120px;
}

.index07 .inner_big {
    position: relative;
}

.index07 .inner_big:before {
    content: "";
    position: absolute;
    left: 10px;
    bottom: -120px;
    background: url(../images/idx-box07-img04.png) no-repeat center;
    background-size: contain;
    width: 220px;
    height: 220px;
}

.index07 .idx-ttl-en {
    font-size: 134px;
    animation: catch_main 0s 0.3s forwards;
    mix-blend-mode: hard-light;
    width: 100vw;
    top: 127px;
    left: 50%;
    transform: translate(-50%);
    display: flex;
    position: absolute;
    z-index: 1;
}

.index07 .idx-ttl-en span {
    -webkit-text-stroke: 1px white;
    display: inline-block;
    color: transparent;
    margin-right: 0;
    -webkit-text-stroke: 1px white;
    display: inline-block;
    color: transparent;
    margin-right: 25px;
    animation: txt_scroll 10s linear infinite;
}

.index07 .idx-ttl-en span.row {
    animation: txt_scroll 20s linear infinite;
}

.index07 .index07-fx {
    display: flex;
    justify-content: space-between;
    padding-right: 50px;
    padding-left: 100px;
}

.index07 .index07-fx .box-img {
    position: relative;
    flex-shrink: 0;
    margin-left: 162px;
}

.index07 .index07-fx .box-img .img,
.index07 .index07-fx .box-img .img02,
.index07 .index07-fx .box-img .img03 {
    margin-bottom: 0;
}

.index07 .index07-fx .box-img .img02 {
    margin-top: -125px;
    margin-left: -125px;
    position: relative;
    z-index: 1;
}

.index07 .index07-fx .box-img .img03 {
    text-align: right;
    position: absolute;
    bottom: -249px;
    right: -50px;
}

.index07 .index07-fx .box-cnt {
    padding-top: 265px;
    height: fit-content;
}

.index07 .index07-fx .box-cnt .idx-ttl01 {
    font-size: 45px;
    letter-spacing: -2px;
    color: #fff;
    margin-bottom: 35px;
}

.index07 .index07-fx .box-cnt .txt {
    color: #fff;
    line-height: 2.8em;
    letter-spacing: 0.08em;
    font-weight: 500;
}

.index07 .idx-btn {
    text-align: center;
    margin-top: 57px;
}

.index07 .idx-btn a {
    min-width: 712px;
    min-height: 120px;
    font-size: 22px;
    border-radius: 60px;
    background: #3E3E3E;
    color: #fff;
    border: 0;
    letter-spacing: 0;
}

.index07 .idx-btn a:before {
    right: 50px;
    background: url(../images/idx-ico-arr02.svg) no-repeat center;
    background-size: contain;
    width: 50px;
    height: 50px;
    transform: none;
}

.index08 {
    padding: 70px 0 100px;
}

.index08 .index08-fx {
    display: flex;
    justify-content: space-between;
    position: relative;
}

.index08 .index08-fx:before {
    content: "";
    position: absolute;
    left: 0;
    top: -150px;
    width: 745px;
    height: calc(100% + 242px);
    background: var(--clr2);
    clip-path: polygon(0 0, 100% 29.2%, 100% 100%, 0 70.8%);
}

.index08 .index08-fx .box-cnt {
    padding-top: 141px;
    padding-left: 100px;
    position: relative;
    color: #fff;
}

.index08 .index08-fx .box-cnt:before {
    content: "GREETING";
    position: absolute;
    writing-mode: tb-rl;
    font-size: 103px;
    left: -50px;
    font-family: var(--f-en);
    font-weight: bold;
    letter-spacing: 0;
    color: #fff;
    top: -66px;
}

.index08 .index08-fx .box-cnt .idx-ttl01 {
    line-height: 1.4em;
    letter-spacing: 0;
    margin-bottom: 36px;
    color: #fff;
}

.index08 .index08-fx .box-cnt .txt {
    line-height: 2.25em;
    margin-bottom: 20px;
}

.index08 .index08-fx .box-cnt .txt-name {
    line-height: 1.55em;
    font-size: 14px;
    margin-bottom: 48px;
}

.index08 .index08-fx .box-cnt .txt-name span {
    display: block;
    font-size: 12px;
}

.index08 .index08-fx .box-cnt .txt-name span label {
    font-weight: 600;
    font-size: 22px;
    cursor: default;
    margin-left: 8px;
}

.index08 .index08-fx .box-cnt .idx-list-btn li a {
    color: #fff;
}

.index08 .index08-fx .box-cnt .idx-list-btn li a:before {
    filter: brightness(0) invert(1);
}

.index08 .index08-fx .box-img {
    position: relative;
    flex-shrink: 0;
}

.index08 .index08-fx .box-img .img,
.index08 .index08-fx .box-img .img02,
.index08 .index08-fx .box-img .img03 {
    margin-bottom: 0;
}

.index08 .index08-fx .box-img .img02 {
    position: absolute;
    left: -159px;
    bottom: -88px;
}

.index08 .index08-fx .box-img .img03 {
    position: absolute;
    right: 0;
    bottom: -353px;
}

.index09 {
    padding: 100px 0;
}

.index09 .idx_row {
    display: flex;
    flex-wrap: wrap;
}

.index09 .idx_row .box {
    width: 100%;
    margin-bottom: 20px;
    background-color: var(--main-color);
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.idx_map {
    height: 450px;
}

.idx_map iframe {
    height: 100%;
}

.index06-box-fx {
    display: flex;
}


/* Hiệu ứng typing (gõ chữ) */

@keyframes typing {
    from {
        width: 0;
    }
    to {
        width: 100%;
    }
}


/* Hiệu ứng slide-in (di chuyển vào từ trái) */

@keyframes slide-in {
    from {
        transform: translateX(-100%);
    }
    to {
        transform: translateX(0);
    }
}


/* Hiệu ứng rung nhẹ */

@keyframes shake {
    0% {
        transform: translateX(0);
    }
    25% {
        transform: translateX(-3px);
    }
    50% {
        transform: translateX(3px);
    }
    75% {
        transform: translateX(-2px);
    }
    100% {
        transform: translateX(2px);
    }
}

@media only screen and (min-width: 769px) and (max-width: 1280px) {
    .box-key-icon {
        left: 31px;
    }
    .home_page .key .inner_big .box-list-key {
        right: 0;
    }
    .index01-fx {
        padding-left: 80px;
    }
    .index01 .inner_big {
        padding-right: 0;
    }
    .index02 .inner_big {
        padding: 0;
    }
    .index02 .box-img {
        margin-bottom: -592px;
    }
    .index03 .inner_sm {
        padding: 0;
    }
    .index03 .idx-ttl-jp {
        padding: 0 10px;
    }
    .index03 .index03-list {
        padding: 0 10px;
    }
    .index04 .inner_big {
        padding: 0;
    }
    .index05 .inner_big {
        padding: 0;
    }
    .index05 .inner_big:before {
        left: 0;
    }
    .index07 .inner_big {
        padding: 0;
    }
    .index07 .inner_big:before {
        left: 0;
    }
    .index08 .inner_big {
        padding: 0;
    }
    .index02-list-img li {
        width: 18.281vw;
        height: 24.219vw;
    }
    .index02-list-img li:nth-child(2) {
        margin: 0 2.734vw;
        width: 50.156vw;
        height: 44.531vw;
    }
    .index02-list-img li:last-child {
        margin-top: 20.313vw;
    }
    .index02-bg:before {
        width: 100%;
        height: 104%;
    }
    .index02-list-img {
        padding-top: 23px;
    }
    .index07 .index07-fx .box-cnt .idx-ttl01 {
        font-size: 3.116vw
    }
    .index07 .index07-fx .box-img {
        margin-left: 12.656vw;
    }
    .home_page .key .catch .txt-animation {
        bottom: -88px;
    }
    .index02-bg {
        margin-top: -71px;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1250px) {
    .index07 .index07-fx {
        padding-right: 50px;
        padding-left: 70px;
    }
    .home_page .key {
        --min-height: 56.25vw;
    }
    .home_page .key .inner_big {
        padding-top: 15vw;
    }
    .home_page .key .inner_big .box-list-key {
        right: 0.781vw;
        width: 60.938vw;
        min-height: 60px;
        padding-left: 2.344vw;
        min-height: 4.688vw;
    }
    .home_page .key .inner_big .box-list-key ul {
        width: calc(100% - 9.766vw);
        padding-right: 2vw;
    }
    .home_page .key .inner_big .box-list-key ul li a {
        padding-right: 2vw;
    }
    .home_page .key .inner_big .box-list-key ul li a .date {
        font-size: 1.094vw;
        margin-right: 1.953vw;
    }
    .home_page .key .inner_big .box-list-key ul li a .ttl {
        font-size: 1.094vw;
    }
    .home_page .key .inner_big .box-list-key .btn-arr {
        height: 4.688vw;
    }
    .home_page .key .inner_big .box-list-key .btn-arr .slick-arrow {
        width: 5vw;
    }
    .home_page .key .catch {
        padding: 10px 30px;
    }
    .home_page .key .catch .title {
        margin-bottom: 1.875vw;
        font-size: 5.469vw;
    }
    .home_page .key .catch p {
        font-size: 1.406vw;
    }
    .home_page .key .catch .txt-animation {
        bottom: -10vw;
    }
    .home_page .key .catch .txt-animation span {
        font-size: 6.687vw;
    }
    .box-key-icon {
        left: 1.422vw;
    }
    .index0 {
        min-height: 450px;
    }
    .index01 .inner_big {
        min-height: 63.594vw;
    }
    .index01-fx {
        padding-left: 1.25vw;
        padding-top: 7.844vw;
        padding-bottom: 9.844vw;
    }
    .index01-fx .box-left {
        padding-left: 0.781vw;
        padding-right: 0;
    }
    .index01-fx .box-left .idx-ttl01 {
        margin-bottom: 2.344vw;
    }
    .index01-fx .box-left .txt {
        font-size: max(1.406vw, 13px);
        margin-bottom: 20px;
    }
    .index01-fx .box-right {
        padding-top: 7.031vw;
        padding-left: 1.563vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li:nth-child(1) {
        right: 4.688vw;
        top: -5.469vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li:nth-child(2) {
        bottom: -1.406vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li:nth-child(2) .ttl {
        min-width: 22.266vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li:nth-child(2) .ttl:before {
        top: -5.538vw;
        right: 3.969vw;
        height: 6.05vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li:nth-child(3) {
        bottom: -8.125vw;
        right: 8.438vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li:nth-child(3) .ttl:before {
        top: -4.688vw;
        right: 6.869vw;
        height: 5.269vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li .ttl {
        font-size: 2.344vw;
        padding: 0px 0.156vw 0.234vw 0.625vw;
        max-width: 22.266vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li .ttl:before {
        left: 2.25vw;
        bottom: -1.953vw;
        height: 2.344vw;
    }
    .index01-fx .box-right .box-img .box01-list-right li .sub-ttl {
        font-size: 1.406vw;
        margin-top: 0.391vw;
        padding-right: 0.938vw;
    }
    .index01-fx .box-right .box-img .img img {
        width: 28.125vw;
        height: 28.75vw;
    }
    .index01-fx .box-right .box-img .img:before {
        font-size: 2.188vw;
        padding: 0.313vw 0.156vw 0;
        min-width: 24.375vw;
        left: 5.703vw;
        top: 7.344vw;
    }
    .home_page .idx-ttl-en {
        font-size: 7.813vw;
    }
    .home_page .idx-ttl01 {
        font-size: 2.344vw;
    }
    .index02 .box-img {
        width: calc(100% + 32.813vw);
        left: calc(50% + 6.719vw);
        top: -1.797vw;
        margin-bottom: -45.422vw;
    }
    .index02 .box-img .box02-list-hover {
        max-width: 36.719vw;
    }
    .index02 .box-img .box02-list-hover li {
        max-width: 36.719vw;
    }
    .index02 .box-img .box02-list-hover li:nth-child(1) {
        transform: translate(21.016vw, -17.578vw);
    }
    .index02 .box-img .box02-list-hover li:nth-child(2) {
        transform: translate(23.906vw, -1.094vw);
    }
    .index02 .box-img .box02-list-hover li:nth-child(3) {
        transform: translate(22.656vw, 9.844vw);
    }
    .index02 .box-img .box02-list-hover li:nth-child(4) {
        transform: translate(-7.031vw, 16.563vw);
    }
    .index02 .box-img .box02-list-hover li:nth-child(5) {
        transform: translate(-36.719vw, 10.625vw);
    }
    .index02 .box-img .box02-list-hover li:nth-child(6) {
        transform: translate(-27.344vw, 1.25vw);
    }
    .index02 .box-img .box02-list-hover li:nth-child(7) {
        transform: translate(-15.625vw, -13.594vw);
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .img {
        width: 14.844vw;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt {
        padding: 1.953vw 1.953vw 2vw;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt h4 {
        font-size: 1.25vw;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt h4 .stt {
        font-size: 0.938vw;
        margin-right: 0.781vw;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-ttl-en02 {
        font-size: 0.781vw;
        padding-bottom: 0.938vw;
        margin-bottom: 0.938vw;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-ttl-en02:before {
        width: 4.688vw;
        height: 1px;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt .txt {
        font-size: 1.094vw;
        margin-bottom: 0.703vw;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-btn a {
        min-width: 11.719vw;
        min-height: 2.734vw;
        font-size: 1.094vw;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt .cnt .idx-btn a:before {
        right: 0.781vw;
        width: 0.781vw;
        height: 0.781vw;
    }
    .index02 .box-img .box02-list-hover02 {
        max-width: 36.719vw;
    }
    .index02 .box-img .box02-list-hover02 li:first-child {
        width: 57.031vw;
        height: 47.734vw;
        transform: translate(-0.859vw, -54.219vw) rotate(24.8deg);
    }
    .index02 .box-img .box02-list-hover02 li:nth-child(2) {
        width: 55.781vw;
        height: 45.156vw;
        transform: translate(17.656vw, -28.5vw) rotate(76.7deg);
    }
    .index02 .box-img .box02-list-hover02 li:nth-child(3) {
        width: 42.5vw;
        height: 32.031vw;
        transform: translate(12.578vw, 3.359vw) rotate(129deg);
    }
    .index02 .box-img .box02-list-hover02 li:nth-child(4) {
        width: 42.344vw;
        height: 32.031vw;
        transform: translate(-9.297vw, 14.297vw) rotate(180.5deg);
    }
    .index02 .box-img .box02-list-hover02 li:nth-child(5) {
        width: 42.5vw;
        height: 32.031vw;
        transform: translate(-31.641vw, 3.828vw) rotate(-128deg);
    }
    .index02 .box-img .box02-list-hover02 li:nth-child(6) {
        width: 55.938vw;
        height: 45.313vw;
        transform: translate(-50.313vw, -28.672vw) rotate(-77.3deg);
    }
    .index02 .box-img .box02-list-hover02 li:last-child {
        width: 57.031vw;
        height: 47.734vw;
        transform: translate(-32.109vw, -54.844vw) rotate(-26.5deg);
    }
    .index02 .box-img .box02-list-hover02 li.active {
        opacity: 1;
        visibility: visible;
    }
    .index02 .idx-ttl-en,
    .index02 .idx-ttl-jp {
        top: 8.984vw;
        margin-left: 7.031vw;
    }
    .index02 .idx-ttl-jp {
        top: 23.75vw;
        margin-left: 7.813vw;
    }
    .index02 .box-gsap-list {
        height: calc(100vh - 7.813vw);
        min-height: 46.875vw;
    }
    .index02 .box-gsap-list ul {
        position: absolute;
        display: flex;
        padding-right: 0;
        padding-left: 7.969vw;
    }
    .index02 .box-gsap-list ul li {
        min-height: 31.25vw;
        width: 48.438vw !important;
        margin-right: 2.109vw;
    }
    .index02 .box-gsap-list ul li .cnt-fx .cnt .ttl {
        font-size: 1.953vw;
    }
    .index02 .box-gsap-list ul li .cnt-fx .cnt .ttl .stt {
        margin-right: 0.781vw;
        font-size: 1.406vw;
        bottom: -1px;
    }
    .index02 .box-gsap-list ul li .cnt-fx .cnt .sub-ttl {
        font-size: 1.094vw;
    }
    .index02 .box-gsap-list ul li .cnt-fx .cnt .txt {
        font-size: 1.25vw;
    }
    .index02 .box-gsap-list ul li .cnt-fx .iBtn {
        margin-left: 1.953vw;
        bottom: 0.547vw;
    }
    .index03 {
        padding: 9.688vw 0 9.688vw;
    }
    .index03 .inner_sm {
        padding: 0 10px;
    }
    .index03 .idx-ttl-jp {
        margin-bottom: 3.203vw;
    }
    .index03 .index03-list:before {
        min-height: 11.719vw;
    }
    .index03 .index03-list li {
        max-width: 36.797vw;
        margin-right: 2.344vw;
        padding: 1.328vw 0.391vw 1.328vw 2.188vw;
        min-height: 18.75vw;
    }
    .index03 .index03-list li:first-child:before {
        width: 8.906vw;
        height: 10.547vw;
        bottom: 4.141vw;
        right: 2.266vw;
    }
    .index03 .index03-list li:nth-child(2):before {
        width: 14.063vw;
        height: 9.844vw;
        bottom: 4.141vw;
        right: 2.266vw;
    }
    .index03 .index03-list li:nth-child(3):before {
        width: 11.094vw;
        height: 9.844vw;
        bottom: 4.375vw;
        right: 2.422vw;
    }
    .index03 .index03-list li:last-child {
        margin-right: 0;
    }
    .index03 .index03-list li .ttl {
        font-size: 1.797vw;
        margin-bottom: 1.719vw;
    }
    .index03 .index03-list li .ttl:before {
        top: -1.328vw;
        width: 1.563vw;
        height: 0.469vw;
    }
    .index03 .index03-list li .ttl02 {
        font-size: 1.406vw;
    }
    .index03 .index03-list li .num {
        font-size: 6.25vw;
        letter-spacing: -0.313vw;
    }
    .index03 .index03-list li .num span {
        font-size: 3.672vw;
    }
    .index03 .index03-list li .sub-num {
        font-size: 0.938vw;
    }
    .index04 .index04-box {
        min-height: 62.5vw;
    }
    .index04 .index04-box .index04-cnt .index04-ttl {
        padding-right: 4.531vw;
        padding-top: 2.188vw;
        padding-bottom: 4.141vw;
        padding-left: 3.906vw;
    }
    .index04 .index04-box .index04-cnt .index04-ttl .idx-ttl-jp {
        margin-right: 0.625vw;
    }
    .index04 .index04-box .index04-cnt .index04-ttl .idx-ttl-jp:before {
        height: 3.125vw;
        width: 1px;
        left: 2px;
    }
    .index04 .index04-box .index04-cnt .index04-sub-ttl {
        bottom: -3.906vw;
        left: -1.875vw;
        font-size: 2.344vw;
    }
    .index04 .index04-box .iBtn {
        bottom: -11.875vw;
        width: 23.438vw;
        height: 23.438vw;
        font-size: 2.734vw;
        padding-bottom: 3.516vw;
    }
    .index05 {
        padding-top: 9.375vw;
        padding-bottom: 9.375vw;
    }
    .index05 .inner_big:before {
        left: 0;
        top: 7.891vw;
        width: 67.969vw;
        height: calc(100% + 1.563vw);
    }
    .index05 .index05-fx {
        margin-bottom: 5.313vw;
    }
    .index05 .index05-fx.index05-fx02 .box-cnt {
        padding: 0 6.953vw 5.547vw 9.219vw;
    }
    .index05 .index05-fx.index05-fx02 .box-img {
        margin-right: -21.641vw;
    }
    .index05 .index05-fx .box-cnt {
        min-width: 48.984vw;
        margin-top: 15.625vw;
        margin-right: -21.641vw;
        padding: 0 7.813vw 5.547vw;
    }
    .index05 .index05-fx .box-cnt .stt {
        font-size: 7.813vw;
        margin-bottom: 3.125vw;
        margin-top: -3.125vw;
    }
    .index05 .index05-fx .box-cnt .box05-ttl {
        font-size: 2.344vw;
        margin-bottom: 2.188vw;
    }
    .index05 .index05-fx .box-cnt .txt {
        margin-bottom: 1.641vw;
        font-size: max(1.25vw, 12px);
    }
    .index05 .index05-fx .box-img .img {
        width: 72.656vw;
        height: 39.063vw;
    }
    .idx-btn a {
        min-height: 3.906vw;
        min-width: 19.531vw;
        font-size: 1.094vw;
    }
    .index06 {
        min-height: 46.25vw;
        padding-top: 9.609vw;
        padding-bottom: 9.375vw;
        position: relative;
    }
    .index06 .index06-list li {
        max-width: 20.859vw;
        height: 20.859vw;
    }
    .index07 {
        padding-bottom: 9.375vw;
    }
    .index07 .inner_big:before {
        left: 0;
        bottom: -9.375vw;
        width: 17.188vw;
        height: 17.188vw;
    }
    .index07 .idx-ttl-en {
        font-size: 10.469vw;
        top: 9.922vw;
    }
    .index07 .idx-btn a {
        min-width: 55.625vw;
        min-height: 9.375vw;
        font-size: 1.719vw;
    }
    .index07 .idx-btn a:before {
        right: 3.906vw;
        width: 3.906vw;
        height: 3.906vw;
    }
    .index07 .index07-fx {
        padding-right: 3.906vw;
        padding-left: 7.813vw;
    }
    .index07 .index07-fx .box-cnt {
        padding-top: 20.703vw;
    }
    .index07 .index07-fx .box-cnt .idx-ttl01 {
        font-size: 3.516vw;
        margin-bottom: 2.734vw;
    }
    .index07 .index07-fx .box-cnt .txt {
        font-size: max(1.25vw, 10px);
    }
    .index07 .index07-fx .box-img {
        margin-left: 12.656vw;
    }
    .index07 .index07-fx .box-img .img img {
        width: 28.125vw;
        height: auto;
    }
    .index07 .index07-fx .box-img .img02 {
        margin-top: -9.766vw;
        margin-left: -9.766vw;
    }
    .index07 .index07-fx .box-img .img02 img {
        width: 28.75vw;
        height: auto;
    }
    .index07 .index07-fx .box-img .img03 {
        bottom: -19.453vw;
        right: -3.906vw;
    }
    .index07 .index07-fx .box-img .img03 img {
        width: 17.188vw;
        height: auto;
    }
    .idx_gallery {
        padding-top: 6.797vw;
    }
    .idx_gallery ul li {
        margin-right: 2.891vw;
    }
    .idx_gallery ul li .img {
        width: 23.438vw;
        height: 23.438vw;
    }
    .idx_gallery ul li .img01 {
        width: 27.344vw;
        height: 20.781vw;
    }
    .idx_gallery ul li .img02 {
        width: 27.344vw;
        height: 15.625vw;
    }
    .idx_gallery ul li .img03 {
        width: 27.344vw;
        height: 27.344vw;
    }
    .idx_gallery ul li .img04 {
        width: 27.344vw;
        height: 15.625vw;
    }
    .idx_gallery ul li .img05 {
        width: 27.344vw;
        height: 15.625vw;
    }
    .idx_gallery ul li .img06 {
        width: 27.344vw;
        height: 27.344vw;
    }
    .idx_gallery ul li .img07 {
        width: 27.344vw;
        height: 15.625vw;
    }
    .idx_gallery ul li .img08 {
        width: 27.344vw;
        height: 20.781vw;
    }
    .index08 {
        padding: 5.469vw 0 7.813vw;
    }
    .index08 .index08-fx:before {
        top: -11.719vw;
        width: 58.203vw;
        height: calc(100% + 25.906vw);
    }
    .index08 .index08-fx .box-cnt {
        padding-top: 11.016vw;
        padding-left: 7.813vw;
    }
    .index08 .index08-fx .box-cnt:before {
        font-size: 8.047vw;
        left: -3.906vw;
        top: -5.156vw;
    }
    .index08 .index08-fx .box-cnt .idx-ttl01 {
        margin-bottom: 2.813vw;
    }
    .index08 .index08-fx .box-cnt .txt {
        margin-bottom: 1.563vw;
    }
    .index08 .index08-fx .box-cnt .txt-name {
        font-size: 1.094vw;
        margin-bottom: 3.75vw;
    }
    .index08 .index08-fx .box-cnt .txt-name span {
        font-size: 0.938vw;
    }
    .index08 .index08-fx .box-cnt .txt-name span label {
        font-size: 1.719vw;
    }
    .index08 .index08-fx .box-img {
        flex-shrink: 0;
    }
    .index08 .index08-fx .box-img .img {
        width: 51.094vw;
        height: 77.188vw;
    }
    .index08 .index08-fx .box-img .img02 {
        left: -12.422vw;
        bottom: -6.875vw;
        width: 28.906vw;
        height: 35.391vw;
    }
    .index08 .index08-fx .box-img .img03 {
        bottom: -27.578vw;
        width: 32.344vw;
        height: 51.641vw;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1180px) {
    .index06-box {
        max-width: 46.61vw;
        margin-right: 4.54vw;
    }
    .index06 .index06-list li {
        width: 32.5%;
        max-width: 15.08vw;
        height: 15.08vw;
        margin-right: 0.42vw;
        margin-bottom: 0.42vw;
    }
    .index06 .index06-fx .idx-ttl-en {
        font-size: 3.39vw;
    }
    .index06-blog .idx-btn a {
        min-width: 16.95vw;
    }
    .index06 .index06-fx .insta-info {
        font-size: 1.19vw;
    }
    .index06 .index06-fx .insta-info .ico {
        margin-right: 1.69vw;
    }
    .index06 .index06-fx .insta-info .ico img {
        width: 2.12vw;
        height: auto
    }
    .index06-blog ul li a .ttl {
        font-size: 1.36vw;
    }
    .index06-blog ul li a .date {
        font-size: 1.1vw;
    }
    .index06-blog ul li a .txt {
        font-size: 1.19vw;
    }
    .index06-blog ul li a .img {
        width: 14.41vw !important;
        height: 10.17vw !important;
    }
}

@media only screen and (min-width: 769px) and (max-width: 1100px) {
    .index02 .box-gsap-list ul li {
        min-height: 41.25vw;
        width: 68.438vw !important;
        margin-right: 2.109vw;
    }
    .index01:before {
        width: 69%;
    }
    .index02 .box-img .box02-list-hover li .fx-cnt {
        min-height: auto;
    }
    .index08 .index08-fx .box-cnt .txt {
        font-size: 12px;
    }
    .f-box01 .f-box01-fx .box-menu .box-menu-fx .f-menu02 .f-menu02-fx ul:last-child li:last-child {
        margin-top: 10px;
    }
}


/*# sourceMappingURL=index_pc.css.map */