@charset "utf-8";

.wrap{
  overflow: hidden;
}
body{
    background-color: #fff;
}

/* ----- section-kv ----- */
#kv{
    width: 100%;

}

.kv-upper{
   width: 100%;
   height: 40%;
   text-align: right;
    background-image: url(/wp-content/uploads/2024/12/bg01.webp);
    background-color: #fff; /* 初期状態を白に設定 */
    background-position: center;
    background-size: cover;
    position: relative;
    transform: translateX(-100%); /* 初期位置を画面外に設定 */
	z-index: 2;
}
img.kv-copy01 {
    width: min(80vw, 1200px);
    position: absolute;
    left: 1.666vw;
    bottom: 2px;
}  
.deco01{
    font-size:min(34vw,360px);
    line-height: 1;
    margin: 80px 0 0 0;
    display: inline-block;
    font-family: 'Anton', sans-serif;
      color: transparent;
  -webkit-text-stroke: 1px #FFE7A5;
  text-stroke: 1px #FFE7A5;
}
.kv-lower{
    background-color: #000;
    background-color: #000; /* 黒背景 */
    position: relative;
    display: flex;
    padding-bottom: min(6.666vw, 80px);
    transform: translateX(100%); /* 初期位置を画面右外に設定 */
}
#top h1{
    font-size: clamp(14px, 1.666vw, 20px);
    line-height: 1.6;
    color: #F3BE00;
    text-align: left;
    font-feature-settings: initial;
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    margin-top: min(6.666vw, 80px);
    margin-left: min(6.666vw, 80px);
}
img.kv-copy03{
    width: 6.4vw;
}
img.kv-copy02{
    width: 78vw;
    position: absolute;
    right: 1.666vw;
    bottom: -7.4vw;

}
.kv-lower-left{
    width: 20vw;
    display: inline-block;

}
.kv-lower-right{
    width: calc(100% - 20vw);
    text-align: right;

}
img.top01{
    width:100%;
    margin: 20% 0 0 0;

}

@media screen and (max-width: 600px) {
#top h1{
    margin-top: 50px;
    margin-left: 14px;
}
.kv-lower-left{
    width: 25vw;

}
.kv-lower-right{
    width: calc(100% - 25vw);

}
}

/* ----- section section01 ----- */
#section01{
    width: 100%;
    padding-top: min(10vw,120px);
    padding-bottom: min(10vw,120px);
        background-image: url(/wp-content/uploads/2024/12/bg01.webp);
    background-position: center;
    background-size: cover;
}
h2.common-h2{
     font-size: clamp(60px, 9.2vw, 130px);
    line-height: 1.2;
    font-weight: 400;
    color: #fff;
    font-family: 'Anton', sans-serif;
    display: inline-block;
    position: relative;
    white-space: nowrap;
}
#h2-wrap span {
    display: inline-block;
    opacity: 0; /* 初期状態は非表示 */
}

.orange{
    color: #F3BE00;
}

.h2-jp{
    font-size:clamp(16px, 1.6vw,20px);
    font-weight: 500;
    display: block;
   font-family: "Noto Sans CJK JP", "Noto Sans JP", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;

}
.h2-en{
   font-family: 'Austin Pen', serif;
   position: absolute;
   left: clamp(80px, 11vw, 150px);
   top: clamp(54px, 8.2vw, 110px);
   width: clamp(160px, 24vw, 350px);

}

#section01 p.title-lead{
    margin: 60px 0 0 0;
    color: #000;

}



.title-wrap{
    display: flex;
	text-align: left;
}

p.title-lead{
    color: #fff;
    width:  clamp(200px, 30vw, 360px);
    position: relative;
    font-size: clamp(13px, 1.25vw, 15px);
    font-weight: 500;
}
#section01 p.title-lead{
    margin: 60px 0 0 14vw;
    margin-top: min(5vw, 60px);
    margin-left: min(7.5vw, 90px);

}
.sec01-upper{
    margin: 50px 0 0 0;
    display: flex;
    flex-wrap: wrap;
    text-align: left;
}
.sec01-upper-left{
    width: 35%;

}
.sec01-upper-right{
    width: 65%;
}
.sec01-upper-inner{
    display: flex;
    justify-content: center;
    align-items: center;
    height: calc(100% - clamp(60px, 10vw, 120px));
    padding: 10px 0;
}
.text-heading{
    font-size:clamp(16px, 1.6vw,20px);
    font-weight: 500;
    color: #000;
}
.sec01-upper-text{
    color: #000;
    width: min(25vw, 300px);
    font-size: clamp(13px, 1.25vw, 15px);
    margin-top:  clamp(8px, 1vw, 12px);
}
img.top04{
    width: clamp(200px,25vw, 300px);
        margin-top:clamp(20px, 3.333vw, 40px);
}
.btn04{
    position: relative;
    width:90%;
    height: clamp(60px, 10vw, 120px);
    display: inline-block;
    background-color: #000;
}

img.top02{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.sec01-number{
    line-height: 1;
        position: absolute;
    font-family: 'Anton', sans-serif;
    letter-spacing: 0.05em;
    color: transparent;
     top: 50%;
        transform: translateY(-50%);
  -webkit-text-stroke: 0.11vw #F3BE00;
  text-stroke: 0.11vw #F3BE00;
}
.num01{
    letter-spacing: 0.1em;
     font-size: clamp(42px, 8vw,96px);
     left: clamp(20px, 3vw,50px);
}
.num02{
     font-size: clamp(34px,5.333vw,64px);
     left: clamp(16px, 2.5vw,30px);
}

.sec01-menu01{
    left: clamp(80px, 12vw, 160px);
    line-height: 1.2;
    font-size: clamp(24px, 2.666vw, 32px);
    position: absolute;
    top: 50%;
    color: #F3BE00;
    transform: translateY(-55%);
}

.sec01-menu01 span{
    font-size: clamp(12px, 1.166vw, 14px);
    line-height: 1;
}
.sec01-menu02{
    left: clamp(70px, 10vw, 120px);
    font-size: clamp(14px, 1.5vw,18px);
    position: absolute;
    top: 50%;
    color: #F3BE00;
    transform: translateY(-50%);
}
img.arrow01{
    width: clamp(12px, 1.833vw,22px);
    max-width: 20px;
    position: absolute;
    top: 50%;
    right:2vw;
    transform: translateY(-50%);
}

#section01 ul{
    display: flex;
    flex-wrap: wrap;
    margin-top: min(8.333vw, 100px);
    gap: 5%;
}
#section01 li{
    width: 30%;
}
img.top03{
    width: 100%;
}
.btn05{
    width: 100%;
    height: clamp(40px, 6.666vw,80px);;
    display: inline-block;
    background-color: #000;
    position: relative;
    text-align: left;
}
@media screen and (max-width: 600px) {
.title-wrap{
    flex-direction: column;
}
.menu-img{
     width: 100%;
     border: 0;
    border-top: 1px solid #F3BE00;
    border-left: 0;
}
.sec01-upper-left{
    width: 100%;

}
.sec01-upper-right{
    width: 100%;
    margin-top: 10px;
}

.sec01-upper-inner{
    width: 80%;
    margin-left: 10%;
}
.sec01-upper-text{
    width: 100%;
}
#section01 ul {
    justify-content: center;
    row-gap: 16px;
}
#section01 li {
    width: 70%;
}
}
/* ----- section section02 ----- */
#section02{
    width: 100%;
    padding: 12% 0;
    background-image: url(/wp-content/uploads/2024/12/top10.webp);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}

#section02 p.title-lead{
    margin: 60px 0 0 14vw;
}

.overlay01{
    position: absolute;
    margin: -12% 0 0 0;
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: .5;
}
.overlay02{
    position: absolute;
    margin: -12% 0 0 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0) 100%);
    opacity: .7;
}
.sec02-wrap{
    display: flex;
    margin: 50px 0 0 0;
}
li.slide-item{
    width: 25%;
    position: relative;
    border: 1px solid #F3BE00;
}

img.top-slide{
    width: 100%;
}
#section02 h3{
    font-size: clamp(13px, 1.25vw, 15px);
    font-weight: 500;
    color: #000;
    position: absolute;
    padding: 1px 8px;
    background-color: #F3BE00;
    top: 0;
    right: 0;
}
.btn01{
    width: clamp(180px, 20vw, 240px);
    height: clamp(40px, 4.166vw, 50px);
    background-color: #000;
    font-size: clamp(12px, 1.166vw, 14px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #F3BE00;
    position: relative;
    border: 1px solid #F3BE00;
}
.btn01:hover{
    background-color: #F3BE00;
    color: #000;
    border: 1px solid #000;
}

#section02 .btn01{
    margin-top: clamp(30px, 4.166vw, 50px);
}
.btn-border{
    border-top: 1px solid #F3BE00;
    width: clamp(30px, 3.333vw, 40px);
    position: absolute;
    right: clamp(-15px, -1.6663vw, -20px);
}
.btn01:hover .btn-border {
    border-top: 1px solid #000;
}
.slick-dots li.slick-active button:before {
    opacity: 1!important;
    color: #fff!important;
}
.slick-dots li button:before {
    opacity: .5!important;
    color: #fff!important;
}
.slick-next:before {
    content: '▶︎'!important;
}
.slick-prev:before {
    content: '◀︎'!important;
}
@media screen and (max-width: 480px) {
.sec02-wrap{
    width: 80%;
    margin: 30px 10% 0 10%;
}
}
/* ----- section section03 ----- */
#section03{
    padding: 9% 0;
    width: 100%;
    background-image: url(/wp-content/uploads/2024/12/bg01.webp);
    background-position: center;
    background-size: cover;
    position: relative;
}
.sec03-wrap{
    display: flex;
}

.sec03-left{
    width: 50%;
    text-align: left;
}
#section03 .btn01{
    margin: 40px 0 0 0;
}
.sec03-right{
        width: 50%;
    text-align: right;
}
#section03 .img-wrap{
    width: 90%;
    max-width: 480px;
    display: inline-flex;
    flex-wrap: wrap;
}
img.sec03-img{
    width: 50%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    object-position: center;
}


#section03 .btn-border{
    border-top: 1px solid #FFD94E;
}
/* ----- section section04 ----- */
#section04{
    width: 100%;
    background-image: url(/wp-content/uploads/2024/12/top15.webp);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
}
#section04 .content{
    text-align: left;
}
.sec04-wrap{
    width: clamp(270px, 60vw, 800px);
    padding: 18% 6vw;
    background-color: #211F27;
    text-align: left;
    display: inline-block;
}

#section04 p.title-lead{
    margin: 60px 0 0 0;
}
#section04 .btn01{
    margin: 40px 0 0 0;
}
.btn01-wrap{
    width: 100%;
    text-align: center;
}

/* ----- section section05 ----- */

.sec05-upper{
    background-color: #000;
    padding: 7% 0;
}
.deco02{

    font-size:clamp(80px, 11.666vw, 140px);
    line-height: 1;
    font-family: 'Anton', sans-serif;
    letter-spacing: 0.05em;
    color: transparent;
  -webkit-text-stroke: 0.11vw #999;
  text-stroke: 0.11vw #999;

}
.scroll{
  display: flex;
  list-style: none;
  padding-inline: 0;
  margin-inline: 0;
  gap: 0;
  overflow: hidden;
}
.scroll li {
  white-space: nowrap;
  padding: 0 1em 0 0;
  margin: 0;
  animation: marquee-left 32s linear infinite;
}
@keyframes marquee-left {
  100% {
    transform: translateX(-100%);
  }
}
.sec05-lower{
    padding: 0 0 8% 0;
    background-image: url(/wp-content/uploads/2024/12/bg01.webp);
    background-position: center;
    background-size: cover;
    background-color: #000;
}
.cta-wrap{
    display: flex;
    width: min(90vw,960px);
    margin-left: auto;
    margin-right: auto;
}
.cta-item{
    width: 100%;
    aspect-ratio: 9 / 7;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    position: relative;
    margin: -14% 0 0 0;
}
.recruit{
    background-image: url(/wp-content/uploads/2024/12/top16.webp);
}
.contact{
    background-image: url(/wp-content/uploads/2024/12/top17.webp);
}
.overlay03{
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: .2;
}

#section05 h2{
    font-size: clamp(40px, 6.4vw,68px);
    line-height: 1.2;
    font-weight: 900;
    color: #fff;
    margin: 20px 0 0 20px;
    display: block;
  font-family: "Noto Sans CJK JP", "Noto Sans JP", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}
#section05 .cta-en{
    font-size: clamp(14px, 1.6vw,18px); 
    font-family: 'Anton', sans-serif;
    display: block;
    margin: 0.8% 0 0 0;
    font-weight: 400;
}
#section05 .btn01{
    position: absolute;
    right: 30px;
    bottom: 20px;
}
@media screen and (max-width: 600px) {
.deco02 {
    -webkit-text-stroke: 1px #999;
    text-stroke: 1px #999;
}
.cta-wrap{
    flex-wrap: wrap;
        margin: -10% 0 0 0;
        display: inline-flex;
        width: 80%;
}
.cta-item{
        margin: 0;

}
.sec05-lower{
    padding: 0 0 8% 0;
    background-repeat: no-repeat;
    background-position-y: 120px;
    text-align: ;
}

}
/* ----- section section05 ----- */

#footer{
    background-color: #211F27;
    padding-top: min(6.666vw,80px);
    padding-bottom: min(6.666vw,80px);
    position: relative;
    z-index: 2;
}
.footer-wrap{
    display: flex;
    flex-wrap: wrap;
    position: relative;
}
.footer-left{
    text-align: left;
    width: 50%;

}
#footer p{
    font-size: 12px;
    color: #fff;
    margin: 16px 0 0 0;
}
.copyright{
    font-size: 12px;
    position: absolute;
    left: 0;
    bottom: 0;
    color: #fff;
}
.footer-right{
    text-align: right;
    width: 50%;
}
.f-menu-wrap{
    display: inline-flex;
}
.f-column{
    text-align: left;
    margin-left: min(4.1666vw, 50px);
}
.f-menu-parent{
    color: #fff;
    font-size: clamp(12px, 1.3333vw, 15px);
    margin: 0 0 8px 0;
    display: inline-block;
}
.f-menu-child{
    color: #aaa;
    font-size: clamp(12px, 1.1666vw, 14px);
    margin: 0 0 8px;
    display: inline-block;
}
.f-menu-child span{
    border-top: 1px solid #aaa;
    width: 10px;
    vertical-align: middle;
    margin: 0 4px 0 0 ;
    display: inline-block;
}
img.f-logo{
    height: 30px;
}
@media screen and (max-width: 600px) {
.footer-left{
    width: 100%;
    margin-bottom: 20px;
}
.footer-right{
    width: 100%;
        margin-bottom: 40px;
}
img.f-logo{
    height: 28px;
}
}