@charset "utf-8";

.gjs-dashed .download-a::before{
  display:none;
}

html { scroll-behavior: smooth;}

body{
  font-size:clamp(0.875rem, 0.792rem + 0.28vw, 1.125rem);
  font-family: "Zen Kaku Gothic New", sans-serif;
  color:#181618;
  font-weight:400;
  /*word-break: auto-phrase;*/
  position:relative;
  background-color: #6E7A66 !important;
}

.accent{
  font-family: "Lato", sans-serif;
}

.h1-font{
  font-family: "Tinos", serif;
}

#root{
  overflow:hidden;
}

strong{
  font-weight: 400;
}

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

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

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: 1180px;
}

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: 3rem;
  flex-wrap: wrap;
  font-size: 14px;
  margin: 100px 0 2.5rem;
  justify-content: center;
  padding:0 5%;
  color:#BFBFBF;
  text-transform:uppercase; 
}

.pankuzu a{
  position: relative;
  color:#BFBFBF;
}

.pankuzu a:hover{
  opacity:0.7;
}

.pankuzu a::before{
  content:"";
  position: absolute;
  width:4px;
  height:4px;
  background:#BFBFBF;
  border-radius:999vh;
  right: -1.5rem;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}

.pankuzu p{
  line-height:1;
}

.main{
  padding-bottom:10rem;
  position:relative;
  z-index: 10;
}

.main::before{
  content:"";
  position:absolute;
  width:40%;
  aspect-ratio:733/300;
  bottom:0;
  left:0;
  z-index: 10;
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611130234608560.png) no-repeat center/contain;
}

.main::after{
  content:"";
  position:fixed;
  inset:-20%;
  pointer-events:none;
  opacity:.08;
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611120033626605.png) repeat;
  background-size:150px;
  animation: noise 1.2s steps(1) infinite;
  z-index: -10;
}

@keyframes noise{
  0%  { transform: translate(0,0); }
  10%  { transform: translate(-0.8%, 0.4%); }
  20%  { transform: translate(0.3%, -0.7%); }
  30%  { transform: translate(0.9%, 0.2%); }
  40%  { transform: translate(-0.4%, -0.9%); }
  50%  { transform: translate(0.6%, 0.8%); }
  60%  { transform: translate(-0.9%, 0.1%); }
  70%  { transform: translate(0.2%, -0.5%); }
  80%  { transform: translate(0.8%, -0.2%); }
  90%  { transform: translate(-0.3%, 0.7%); }
  100% { transform: translate(0,0); }
}

.arrow-btn{
  display:flex;
  align-items:center;
  gap:1rem;
  color:#BFBFBF;
  width:fit-content;
  margin:5rem auto 0;
  text-decoration:none;
}

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

.arrow-btn img{
  width:12px;
  flex-shrink:0;
}

.arrow-btn p{
  position:relative;
  margin:0;
}

/* 下線 */
.arrow-btn p::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-4px;
  width:100%;
  height:1px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s ease;
}

.arrow-btn:hover p::after{
  transform:scaleX(1);
}

/* 通常（左へ消えて右から戻る） */
.arrow-btn:not(.reverse):hover img{
  animation:arrowLoop .6s ease;
}

@keyframes arrowLoop{
  0%{
    transform:translateX(0);
    opacity:1;
  }
  45%{
    transform:translateX(-20px);
    opacity:0;
  }
  46%{
    transform:translateX(20px);
    opacity:0;
  }
  100%{
    transform:translateX(0);
    opacity:1;
  }
}

/* reverse（右へ消えて左から戻る） */
.arrow-btn.reverse:hover img{
  animation:arrowLoopReverse .6s ease;
}

@keyframes arrowLoopReverse{
  0%{
    transform:translateX(0);
    opacity:1;
  }
  45%{
    transform:translateX(20px);
    opacity:0;
  }
  46%{
    transform:translateX(-20px);
    opacity:0;
  }
  100%{
    transform:translateX(0);
    opacity:1;
  }
}

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

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

.lower-fv{
  text-align:center;
  margin-bottom:200px;
}

.lower-fv h1{
  color:#BFBFBF;
  font-size:clamp(3rem, 2.333rem + 2.22vw, 5rem);
  line-height: 1;
  text-transform: uppercase;
}

.cta{
  max-width:1000px;
  width:70%;
  margin:7.5rem auto 0;
  text-align:center;
  padding:4rem 5%;
  color:#BFBFBF;
  display: block;
  aspect-ratio:1008/345;
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611162701695968.png) no-repeat center/contain;
}

.cta h2{
  font-size:clamp(1.5rem, 0.833rem + 2.22vw, 3.5rem);
  margin-bottom:1.5rem;
  color:#BFBFBF;
  text-transform: uppercase;
}

.cta h2 + p{
  font-size:14px;
}

.yellow-btn{
  min-width:360px;
  margin:2rem auto 0;
  padding:1rem;
  background:#181618;
  color:#FFFFFF;
}

.yellow-btn p{
  display:flex;
  align-items:center;
  gap:1.5rem;
  justify-content: center;
}

.yellow-btn p::after{
  content:"";
  display:block;
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611162303978984.png) no-repeat center/contain;
  width:18px;
  height:14px;
  transition:0.3s;
}

.yellow-btn:hover{
  opacity:1;
  background:#C49E37;
  color:#181618 !important;
}

.yellow-btn:hover p::after{
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611162303509256.png) no-repeat center/contain;
}

.cta-bottom{
  max-width:1000px;
  width:70%;
  margin:0 auto;
  padding:3.5rem 0 0;
  position:relative;
}

.cta-bottom::before{
  content:"";
  position:absolute;
  width:9%;
  aspect-ratio:1/2;
  top:-10%;
  right:15%;
  z-index: -1;
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611164417227270.png) no-repeat center/contain;
}

.cta-bottom::after{
  content:"";
  position:absolute;
  width: 30%;
  aspect-ratio: 1 / 1;
  top: -20%;
  right: 4%;
  z-index: -1;
  opacity:0;
  transition:0.3s;
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611164417757852.png) no-repeat center/contain;
}

.cta-bottom.fadeUp::after{
  opacity:1;
}

.cta-bottom a{
  max-width:560px;
  margin:0 auto;
  display:block;
  width:80%;
  position:relative;
}

.cta-bottom a > img{
  transition:0.3s;
}

.cta-bottom a::before{
  content:"";
  position:absolute;
  width: 98%;
  height: 100%;
  top: 0;
  left: 1%;
  background:url(https://bubutan.jp/system_panel/uploads/images/20260611191303164687.png) no-repeat center/contain;
  opacity:0;
  transition:0.3s;
}

.gjs-dashed .cta-bottom a::before {
  display:none;
}


.cta-bottom a:hover{
  opacity:1;
}

.cta-bottom a:hover > img{
  opacity:0;
}

.cta-bottom a:hover::before{
  opacity:1;
}

.lower-title{
  margin-bottom:4rem;
  color:#BFBFBF;
}

.lower-title.black{
  color:#181618;
}

.lower-title h2{
  font-size:1rem;
}

.lower-title p{
  font-size:clamp(1.5rem, 0.833rem + 2.22vw, 3.5rem);
  line-height:1;
  margin-top:8px;
  text-transform: uppercase;
}

.main:has(.bg-green) {
  padding-bottom:0;
}

.bg-green-main{
  padding-bottom: 10rem;
}

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


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

@media screen and (max-width: 1280px) {
  .cta h2{
    margin-bottom: 0.5rem;
  }
}

@media screen and (max-width: 1024px) {
  .cta{
    padding: 3rem 5%;
    aspect-ratio: 537 / 281;
    background:url(https://bubutan.jp/system_panel/uploads/images/20260614163119276790.png) no-repeat center/contain;
  }
  .cta-bottom::before {
    width: 11%;
    top: -7%;
    right: 15%;
  }
  .cta-bottom::after {
    width: 40%;
    top: -15%;
    right: 1%;
    z-index: -1;
  }
  .lower-title {
    margin-bottom: 2rem;
  }
}

@media screen and (max-width: 767px) {
  body{
    font-size:14px;
  }
  .pankuzu{
    margin: 10rem 0 1.5rem;
    font-size: 10px;
    gap: 1.5rem;
  }
  .pankuzu a::before{
    right: -0.9rem;
    width: 3px;
    height: 3px;
  }
  .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;
  }
  .main{
    padding-bottom: 7.5rem;
  }
  .main::before{
    width:80%;
  }
  .arrow-btn{
    margin: 2.5rem auto 0;
  }
  .lower-fv{
    margin-bottom: 3rem;
  }
  .cta-bottom{
    width: 100%;
    max-width: 420px;
  }
  .cta-bottom a{
    width:95%;
  }
  .cta-bottom::before {
    width: 15%;
    top: -6%;
    right: 10%;
  }
  .cta-bottom::after {
    width: 40%;
    top: -6%;
    right: -3%;
  }
  .cta{
    width: 90%;
    padding: 2rem 5%;
    margin: 0 auto;
    max-width: 400px;
    aspect-ratio: 337 / 453;
  }
  .yellow-btn {
    min-width: 280px;
    margin: 2rem auto 0;
  }
  .yellow-btn p{
    gap:1rem;
  }
  .yellow-btn p::after{
    width: 14px;
    height: 10px;
  }
  .cta{
    padding: 7rem 5%;
    background:url(https://bubutan.jp/system_panel/uploads/images/20260614164103643796.png) no-repeat center/contain;
  }
  .cta h2 {
    margin-bottom: 1.5rem;
    font-size: 2rem;
  }
  .bg-green-main{
    padding-bottom: 7.5rem;
  }
}




/*インスタ*/

.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: calc(100% / 3);
  }


}

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

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

}


