@charset "utf-8";

.gjs-dashed .title-anim{
  color: #000;  
}

html { scroll-behavior: smooth;}

body{
  font-size:clamp(0.875rem, 0.784rem + 0.3vw, 1.125rem);
  font-family: "Noto Sans JP", sans-serif;
  color:#fff;
  font-weight: 300;
  /*word-break: auto-phrase;*/
  background:#0B0D10 !important;
  position:relative;
}

body::before{
  content:"";
  position:absolute;
  width:100%;
  top:0;
  left:0;
  z-index:-1;
  aspect-ratio:2048/1021;
  background:url(https://salkan.co.jp/system_panel/uploads/images/20260319184157887868.png) no-repeat center/cover;
}

.accent{
  font-family: "Oswald", sans-serif;
  font-weight: 400;
}

.fv-accent{
  font-family: "Six Caps", sans-serif;
}

#root{
  overflow:hidden;
}

strong{
  font-weight: 400;
}

h1,h2,h3,h4,h5{
  margin:0;
  font-weight:500;
  line-height:1.5;  
}

h1 strong, h2 strong, h3 strong, h4 strong , h5 strong{
  font-weight:500;
}

p{
  margin:0;
  line-height:calc(34/18);
}

.sp{
  display:none;
}

a{
  color: #FFFFFF;
  cursor: pointer;
  display:inline-block;
  transition:0.3s;
}

a:hover{
  color: #FFFFFF;
  text-decoration:none;
  opacity:0.7;
}

a p{
  line-height:1;
}

.container{
  padding:0 !important;
  width: 80%;
  margin: 0 auto;
  max-width: 1535px;
}

img{
  width:100%;
  object-fit: contain;
  display:block;
}

.row{
  margin:0;
}

strong{
  display: inline-block;
}

em{
  display: inline-block !important;
  font-style: normal;
}

.pankuzu{
  display: flex;
  gap: 4rem;
  flex-wrap: wrap;
  font-size: 14px;
  margin: 0 0 5rem;
  justify-content: end;
}

.pankuzu a{
  position: relative;
}

.pankuzu a:hover{
  opacity:0.7;
}

.pankuzu a::before{
  content:">";
  position: absolute;
  right: -2rem;
  top: -3px;
}

.pankuzu p{
  line-height:1;
}

.lower-fv{
  padding: 260px 5% 7.5rem;
}

.lower-fv .label{
  border-bottom:1px solid #5A5A5A;
  margin-bottom:2rem;
  display:flex;
  align-items:center;
  gap:8px;
  padding-bottom: 10px;
}

.lower-fv .label::before{
  content:"";
  background:#FFFFFF;
  width:12px;
  height:12px;
  border-radius:1px;
  display:block;
}

.lower-fv h1{
  font-size:clamp(1.5rem, 0.909rem + 1.97vw, 3.125rem);
}

.arrow-btn{
  width:44px;
  height:44px;
  background:#fff;
  border-radius:5px;
  position:relative;
  display:block;
}

.arrow-btn.right{
  width:56px;
  pointer-events:none;
  height:56px;
}

.arrow-btn::before{
  content:"";
  position:absolute;
  width:1px;
  height:18px;
  background:#0B0D10;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

.arrow-btn.right::before{
  width:24px;
  height:1px;
}

.arrow-btn::after{
  content:"";
  position:absolute;
  width:8px;
  height:8px;
  background:url(https://salkan.co.jp/system_panel/uploads/images/20260323124209322056.png) no-repeat center/contain;
  top: 25px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transition:0.3s;
}

.arrow-btn.right::after{
  width:10px;
  height:10px;
  top: 50%;
  left: 15px;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}

.arrow-btn:hover::after{
  top:10px;
}


.arrow-btn-wrap:hover .arrow-btn.right::after{
  left: 34px;
}

.top-btn{
  display: flex;
  gap: 4px;
  width: fit-content;
  font-weight:400;
}

.top-btn-box{
  width:260px;
  height:56px;
  background:#fff;
  border-radius:5px;
  position:relative;
}

.top-btn-box .text-link{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

.text-link{
  position:relative;
  width: max-content;
  overflow: hidden;
  color: transparent !important;
  display: block;
  text-shadow: 0 1.5em 0 #0B0D10, 0 0 0 #0B0D10;
  transition: text-shadow 0.25s;
  line-height: 1 !important;
  cursor: pointer;
}

.text-link p{
  line-height: 1;
}

.text-inner{
  display: inline-block;
  overflow: hidden;       /* ← 影をはみ出させない */
}

.top-btn:hover {
  opacity:1;
}

.top-btn:hover .text-link{
  text-shadow: 0 0 0 #0B0D10, 0 -1.5em 0 #0B0D10;
}

.animation-2{
  animation-delay:0.3s;
}

.animation-3{
  animation-delay:0.6s;
}


body:has(.contact) .cta,
body:has(.thanks) .cta{
  display:none;
}

.cta{
  margin:7.5rem auto 0;
  width:80%;
  border:1px solid #FFFFFF;
  padding:2.5rem 5% 4.5rem;
  height:328px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.cta h2{
  margin:1.5rem 0 2.5rem;
  font-size:clamp(1.25rem, 0.795rem + 1.52vw, 2.5rem);
}

.cta > div:first-child{
  padding-bottom: 3rem;
}

.cta .accent{
  display:flex;
  gap:8px;
  align-items:center;
}

.cta .accent::before{
  content:"";
  display:block;
  width:12px;
  height:12px;
  border-radius:1px;
  background:#fff;
}


.lower-title{
  display:flex;
  align-items:center;
  gap:1.5rem;
  margin-bottom:3.5rem;
}

.lower-title h2{
  font-size:clamp(1.5rem, 1.167rem + 1.11vw, 2.5rem);
}

.animation-bg{
  background: #000;
  display: block;
  content: "";
  position: fixed;
  z-index: 999;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  animation-duration: 1s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards;
  animation-name: PageAnime-ttb;
}

@keyframes PageAnime-ttb {
  0% {
    transform-origin: top;
    transform: scaleY(0);
  }

  /* 上から伸びる */
  40% {
    transform-origin: top;
    transform: scaleY(1);
  }

  /* しっかり停止（ここが長め） */
  60% {
    transform-origin: top;
    transform: scaleY(1);
  }

  /* 起点切り替え */
  60.001% {
    transform-origin: bottom;
  }

  /* 下に閉じる */
  100% {
    transform-origin: bottom;
    transform: scaleY(0);
  }
}

@media (max-width: 1600px) {
}


@media (max-width: 1400px) {
}

@media screen and (max-width: 1280px) {
}

@media screen and (max-width: 1024px) {
  .cta > div:first-child {
    padding-bottom: 0rem;
  }
  .cta-btn{
    font-size: 1.125rem;
    margin: 2rem 0 0;
  }
  .cta-btn img {
    width: 1.25rem;
  }
  .cta h2{
    margin: 0 0 1rem;
  }
  .cta{
    padding: 2rem 5% 3.5rem;
    height: 250px;
  }
}

@media screen and (max-width: 767px) {
  body{
    font-size:14px;
  }
  .pankuzu{
    margin: 0 0 1.5rem;
    font-size:12px;
    gap: 1rem;
  }
  .pankuzu a::before{
    right: -0.6rem;
  }
  .lower-fv {
    padding: 100px 5% 2.5rem;
  }
  .container{
    width: 90%;
  }
  .sp{
    display:block;
  }
  .pc{
    display:none;
  }
  .col, .col-1, .col-10, .col-11, .col-12, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-auto, .col-lg, .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-auto, .col-md, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-auto, .col-sm, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-auto, .col-xl, .col-xl-1, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-auto{
    padding:0;
  }
  .animation-2,
  .animation-3{
    animation-delay:0s;
  }
  .cta{
    padding: 20px 5% 2rem;
    height: 160px;
    width: 90%;
    border-radius: 5px;
    margin-bottom: 4rem;
  }
  .arrow-btn,
  .arrow-btn.right {
    width: 40px;
    height: 40px;
  }
  .cta > div:first-child{
    width:calc(100% - 3.5rem);
  }
  .cta p{
    line-height:1.5;
  }
  .top-btn-box {
    width: 195px;
    height: 40px;
  }
  .arrow-btn.right::before{
    width:20px;
  }
  .arrow-btn.right::after{
    left:10px;
  }
  .arrow-btn-wrap:hover .arrow-btn.right::after {
    left: 21px;
  }
}




/*インスタ*/

.instaCont section {
  display: flex;
  gap: 1rem 5%;
  flex-wrap:wrap;
  margin: 2rem 0;
  align-items:center;
}

.instaCont article {
  width: 47.5%;
}

.instaCont .imgBx01 {
  position: relative;
  display: block;
  padding: 0 0 100% 0;
}

.instaCont .imgBx01:hover {
  opacity: 0.7;
}

.instaCont .imgBx01 img,
.instaCont .imgBx01 video {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  max-width: 100%;
  width: 100%;
  max-height: 100%;
  height: auto;

}

.instaCont .imgBx01>span {
  position: absolute;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}

.instaCont .imgBx01>img+span,
.instaCont .imgBx01>video+span {
  display: none;
}

.instaCont .webgene-item-main-video {
  display: block;
  width: auto;
  max-width: 100%;
}

.instaCont .webgene-item .dayTxt {
  font-size: .85em;
  color: #FF8238;
}

.instaCont .webgene-item .snsTit {
  font-size: 1em;
  font-weight: normal;
}

@media screen and (min-width:768px) {
  .instaCont section {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2rem 0;
    margin: 2rem 0;
    justify-content: center;
  }
  .instaCont article {
    width: 47.5%;
  }


}

@media screen and (min-width:1200px) {

  .instaCont article {
    width: calc(100% / 4);
  }

}

@media screen and (max-width:767px) {

  .instaCont article .container{
    width:100%;
  }
}

