@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Noto+Sans+TC:wght@100..900&display=swap');
@font-face {
  font-family: 'IBMPlex_r';
  src: url('https://baji.tw/filestop/IBMPlexSansTC-Regular.ttf') format('truetype');
}

@font-face {
  font-family: 'IBMPlex_b';
  src: url('https://baji.tw/filestop/IBMPlexSansTC-SemiBold.ttf') format('truetype');
}
* {
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
}

a {
      text-decoration: none;
      color: #5C54E6;
      cursor: pointer;
}
h1, h3, h4, h5, h6, p{
  margin: 0;
  padding: 0;
  font-size: inherit;   /* 跟隨父層字體大小 */
  font-weight: normal;  /* 移除粗體 */
}
html{
      overflow-x: hidden;
}
body {
      background-color: #000000;
      font-weight: 400;
      font-size: 14px;
      line-height: 2.1em;
      letter-spacing: 0.1em;
      margin:0;
      overflow-x: hidden;
      font-family: "IBMPlex_r","Noto Sans TC";
      color:white;
}

body::-webkit-scrollbar {
      display: none;
}

.sohoko-nav{
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      position: absolute;
      top: 0;
      left: 0;
      padding: 125px 140px 0;
      z-index: 9999;
}
.sohoko-nav .logo img{
      width: 42px;
}
.sohoko-nav .social{
      display: flex;
      align-items: center;
      justify-content: flex-end;
}
.sohoko-nav .social .social-item{
      margin-left: 45px;
      cursor: pointer;
}

.sohoko-footer{
      width: 100%;
      background-image:url('https://www.sohoko.media/media/i/footer_bg_n.png');
      background-position: center bottom;
      background-size: cover;
      background-repeat: no-repeat;
      padding-bottom: 145px;
      padding-left: 130px;
      padding-right: 130px;
      padding-top: 250px;
}
.sohoko-footer-content{
      width: 100%;
      border-bottom: 1px solid white;
      padding-bottom: 65px;
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
}
.sfc-brand{
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      justify-content: flex-start;
      margin-right: 180px;
}
.sfc-brand-logo img{
      width: 402px;
}
.sfc-brand-social{
      display: flex;
      align-items: center;
      justify-content: flex-start;
      margin-top: 20px;
}
.sfc-brand-social-follow{
      margin-right: 80px;
      font-size: 12px;
      line-height: 1em;
}
.sfc-brand-social-item{
      margin-right: 50px;
      cursor: pointer;
}
.sfc-brand-social-item.fb img{
      width: 22px;
}
.sfc-brand-social-item.ig img{
      width: 21px;
}
.sfc-brand-social-item.line img{
      width: 24px;
}
.sfc-brand-social-item:last-child{
      margin-right: 0px;
}
.sfc-col{
      margin-right: 75px;
}
.sfc-col-title{
      font-size: 26px;
      line-height: 1.7em;
      letter-spacing: 0.1em;
      font-weight: 500;
      margin-bottom: 10px;
}
.sfc-col-item, a.sfc-col-item{
      display: block;
      color: white;
      font-size: 12px;
      font-weight: 700;
      line-height: 2em;
      letter-spacing: 0.1em;
}
.sohoko-footer-bottom{
      margin-top: 20px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      font-size: 12px;
      line-height: 1.5em;
      letter-spacing: 0.1em;
}
a.sfb-item{
      color: white;
      margin-right: 30px;
}

.sohoko-block{
      width: 100%;
}
.vh100{
      height: 100vh;
}
.flexdiv{
      display: flex;
}
.flex-column{
      flex-direction: column;
}

.ai-center{
      align-items: center;
}
.jc-center{
      justify-content: center;
}
.jc-fs{
      justify-content: flex-start;
}

.div-w-100{
      width: 100%;
}
.ta-center{
      text-align: center;
}
.sohoko-title-block{
      /* background-color: coral; */
      overflow: hidden;
}
.sohoko-title{
      font-family: "IBMPlex_b","Noto Sans TC";
      font-size: 36px;
      line-height: 1.5em;
      letter-spacing: 0.15em;
      font-weight: 500;
      background: linear-gradient(to bottom, white 60%, #CFAFFF 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      color: transparent;
      text-align: center;
}
.sohoko-title.tshow{
      transform-origin: 0 0;
      transform: rotate(30deg) translate(100px,100px) ;
      opacity: 0;
      transition: 1s;
}
.sohoko-title.st2row{
      background: linear-gradient(to bottom, white 80%, #CFAFFF 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      color: transparent;
}
.sohoko-title-block.show .sohoko-title.tshow{
      transform: rotate(0deg) translate(0px,0px);
      opacity: 1;
}

@media( max-width:1440px){
      .sohoko-footer{
            width: 100%;
            padding-left: 9%;
            padding-right: 9%;
      }
      .sfc-brand{
            margin-right: 12.5vw;
      }
      .sfc-col{
            margin-right: 5vw;
      }
}
@media( max-width:1200px){
      .sfc-brand{
            margin-right: 5vw;
      }
}
@media( max-width:1000px){
      .sfc-col{
            display: none;
      }
      .sohoko-footer-content{
            /* border-bottom-width: 0px; */
            padding-bottom: 20px;
            display: flex;
            align-items: flex-start;
            justify-content: flex-start;
      }
      .sohoko-footer{
            background-image:url('https://www.sohoko.media/media/i/footer_bgm_n.png');
            padding-bottom: 40px;
            background-size: 100%;
            padding-left: 4vw;
            padding-right: 30px;
      }
      .sfc-brand{
            flex-direction: row;
            justify-content: space-between;
            align-items: flex-end;
            width: 100%;
            margin-right: 0px;
      }
      .sfc-brand-logo img{
            width: 35vw;
      }
      .sfc-brand-social{
            margin-top: 0px;
            justify-content: flex-end;
      }
      .sfc-brand-social-follow{
            display: none;
      }
      .grecaptcha-badge{
            display: none
      }
      
}

@media( max-width:768px){
      .sohoko-footer-bottom{
            flex-direction: column;
            align-items: flex-start;
      }
      a.sfb-item{
            margin-right: 10px;
      }     
      .sfb-copyright{
            margin-top: 15px;
      }
      .sohoko-nav{
            padding: 70px 40px 0 50px;
      }
      .sohoko-nav .social .social-item{
            margin-left: 35px;
      }
      .sohoko-nav .logo img{
            width: 30px;
      }
      .sohoko-nav .social .social-item img{
            height: 23px;
      }
      .sfc-brand-social-item{
            margin-right: 23px;
      }
      .sfc-brand-social-item img{
            height: 16px;
            width: auto;
      }
      .sohoko-title{
            font-size: 16px;
            background: linear-gradient(to bottom, white 85%, #CFAFFF 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
      }
      .sohoko-footer{
            padding-top: 120px;
      }
}