@charset "utf-8";

:root{
  --color-main: #7151D9;
  --color-text: #484848;
  --color-white: #FFFFFF;
  --grad-main: linear-gradient(90deg,#C483F2 0%,#C483F2 25%,#7151D9 75%,#7151D9 100%);
  --inner-width: 1080px;
}

/* ===============================
SNS FV
=============================== */
.sns-page {
  background: #fff;
  margin-top: 60px;
overflow-x: hidden;    
}

.sns-page .sns-fv{
  position:relative;
  overflow:hidden;
  background:#fff;
  padding:120px 0 20px;
  min-height:930px;
}

/* 波の少し下からベース色 */
.sns-page .sns-fv::before{
  content:"";
  position:absolute;
  top:140px;
  left:0;
  width:100%;
  height: calc(100% - 138px);
  background:#FAF8FF;
  z-index:0;
}

.sns-page .sns-fv > .container{
  position:relative;
  z-index:10;
  max-width:var(--inner-width);
}

.sns-page .sns-fv .breadcrumb{
  margin-bottom:0px;
}

/* 上段 */
.sns-page .sns-fv__top{
  max-width:var(--inner-width);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  position:relative;
  z-index:10;
}

.sns-page .sns-fv__title{
  width:48%;
  margin-top:55px;
  font-family:"Hiragino Kaku Gothic ProN", sans-serif;
  font-weight:600;
  font-size:44px;
  line-height:100%;
  letter-spacing:0.03em;
  color:var(--color-main);
  position:relative;
  z-index:2;
}

.sns-page .sns-fv__title::before{
  content:"SNS";
  position:absolute;
  top:50%;
  left:0;
  transform:translateY(-50%);
  font-family:"Karla", sans-serif;
  font-weight:700;
  font-size:123px;
  line-height:100%;
  letter-spacing:0;
  color:#FAF8FF;
  z-index:-1;
}

.sns-page .sns-fv__image{
  width:36%;
  position:relative;
  z-index:10;
  margin-top:10px;
}

.sns-page .sns-fv__image img{
  width:100%;
  max-width:311px;
  display:block;
}

/* 下段 */
.sns-page .sns-fv__lead{
  margin-top:130px;
  text-align:center;
  position:relative;
  z-index:10;
}

.sns-page .sns-fv__lead-en{
  font-family:"Karla", sans-serif;
  font-weight:600;
  font-size:20px;
  line-height:100%;
  letter-spacing:0.15em;
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.sns-page .sns-fv__lead-title{
  margin-top:18px;
  font-family:"Hiragino Kaku Gothic ProN", sans-serif;
  font-weight:600;
  font-size:44px;
  line-height:140%;
  letter-spacing:0.03em;
  color:var(--color-text);
}

.sns-page .sns-fv__lead-title span{
  font-size:44px;
  line-height:150%;
  letter-spacing:0;
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.sns-page .sns-fv__lead-text{
  margin-top:0px;
}

.sns-page .sns-fv__lead-text p{
  font-family:"Hiragino Kaku Gothic ProN", sans-serif;
  font-weight:600;
  font-size:20px;
  line-height:200%;
  letter-spacing:0.1em;
  color:var(--color-text);
  margin-top: 40px;    
}

.sns-page .sns-fv__lead-text span{
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.sns-page .sns-fv__btn{
  margin-top:44px;
}

.sns-page .sns-fv__btn a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:16px 40px;
  border-radius:100px;
  background: var(--grad-main);
  box-shadow: 4px 4px 0 rgba(0,0,0,0.15);
  text-decoration:none;
  font-family:"Hiragino Kaku Gothic ProN", sans-serif;
  font-weight:600;
  font-size:18px;
  line-height:100%;
  letter-spacing:0.09em;
  color:var(--color-white);
  transition:transform 1s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 1s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.sns-page .sns-fv__btn a:hover{
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 rgba(0,0,0,0.15);
}
/* wave */
.sns-page .sns-fv__wave.pc{
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  width: 1920px;
  max-width: none;
  z-index: 1;
  pointer-events: none;
}

.sns-page .sns-fv__wave.pc img{
  width: 1920px;
  max-width: none;
  display: block;
}

/* circle */
.sns-page .sns-fv__circle{
  position:absolute;
  left:-120px;
  top:-180px;
  width:700px;
  z-index:2;
  pointer-events:none;
}

.sns-page .sns-fv__circle img{
  width:100%;
  display:block;
  opacity:0.7;
}

/* dot */
.sns-page .sns-fv__dot{
  position:absolute;
  z-index:3;
  pointer-events:none;
}

.sns-page .sns-fv__dot img{
  width:100%;
  display:block;
}

.sns-page .sns-fv__dot--left {
  top: 183px;
  left: 48%;
  width: 330px;
}

.sns-page .sns-fv__dot--right {
  top: 500px;
  right: 10px;
  width: 120px;
}

/* ===============================
SP
=============================== */
@media (max-width:768px){
    
.sns-page {
  background: #fff;
  margin-top: 20px;
}    

  .sns-page .sns-fv{
    padding:80px 0 90px;
    min-height:auto;
    overflow:visible;
    background:#fff;
  }
    
 .sns-page  .sns-fv::before {
    top: 80px;
    height: calc(100% - 80px);
    background: #FAF8FF;
  }    

 .sns-page  .sns-fv .breadcrumb{
    margin-bottom:30px;
  }

.sns-page   .sns-fv__top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
  }

.sns-page .sns-fv__title{
  width:44%;
  margin-top:10px;
  font-family:"Hiragino Kaku Gothic ProN", sans-serif;
  font-weight:600;
  font-size:28px;
  line-height:100%;
  letter-spacing:0.03em;
  color:var(--color-main);
  position:relative;
}

.sns-page .sns-fv__title::before{
  top:50%;
  left:0;
  transform:translateY(-50%);
  font-size:64px;
  line-height:100%;
}

.sns-page .sns-fv__image{
    width:50%;
    margin-top:50px;
  }

.sns-page .sns-fv__lead{
    margin-top:28px;
    text-align:center;
  }

.sns-page   .sns-fv__lead-en{
    font-size:13px;
    line-height:130%;
    letter-spacing:0.15em;
  }

.sns-page .sns-fv__lead-title{
    margin-top:10px;
    font-size:24px;
    line-height:150%;
    letter-spacing:0;
  }

.sns-page .sns-fv__lead-title span{
    font-size:24px;
    line-height:140%;
    letter-spacing:0.03em;
  }

.sns-page .sns-fv__lead-text{
    margin-top:18px;
  }

.sns-page .sns-fv__lead-text p{
    font-size:16px;
    line-height:200%;
    letter-spacing:0.1em;
    margin-top: 22px;    
  }

.sns-page .sns-fv__btn{
    margin-top:22px;
  }

.sns-page .sns-fv__btn a{
    padding:9px 17px;
    font-size:16px;
    line-height:100%;
    letter-spacing:0.09em;
    box-shadow:2px 2px 0 rgba(0, 0, 0, 0.25);
  }


.sns-page .sns-fv__wave.pc{
  position: absolute;
  top:80px;
  left: 50%;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 1;
  pointer-events: none;
}

.sns-page .sns-fv__wave.pc img{
  width: 660px;
  max-width: none;
  display: block;
}

.sns-page .sns-fv__wave.sp{
  position: absolute;
  top: 80px;
  left: 50%;
  transform: translateX(-50%);
  width: 660px;
  z-index: 1;
  pointer-events: none;
}

.sns-page .sns-fv__wave.sp img{
  width: 100%;
  display: block;
}


.sns-page .sns-fv__circle{
    left:-92px;
    top:210px;
    width:330px;
  }

.sns-page .sns-fv__dot--left{
    top:180px;
    right:88px;
    left:auto;
    width:120px;
  }

.sns-page .sns-fv__dot--right{
    top:300px;
    right:-18px;
    width:88px;
  }  
    
   
    
}


/* ===============================
SNS Problem
=============================== */
.sns-page .sns-problem{
  position: relative;
  padding: 200px 0 120px;
  background: linear-gradient(180deg, #FAF8FF 0%, #FFFFFF 100%);
  overflow: hidden;
}

.sns-page .sns-problem__bg{
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.sns-page .sns-problem__bg img{
  width: 100%;
  display: block;
}

.sns-page .sns-problem__bg--left{
  left: 0;
  top: 40px;
  width: 220px;
}

.sns-page .sns-problem__bg--right{
  right: 0;
  top: 0;
  width: 420px;
}

.sns-page .sns-problem__outer{
  max-width: var(--inner-width);
  margin: 0 auto;
  padding: 60px;
  border: 1px solid var(--color-main);
  border-radius: 40px;
  background: var(--color-white);
  position: relative;
  z-index: 2;
}

.sns-page .sns-problem__label{
  text-align: center;
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-problem__title{
  margin-top: 16px;
  text-align: center;
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  color: var(--color-text);
}

.sns-page .sns-problem__inner{
  max-width: 960px;
  margin: 38px auto 0;
  padding: 16px 44px;
  border: 1px solid var(--color-main);
  border-radius: 25px;
  background: var(--color-white);
  position: relative;
  z-index: 2;
}

.sns-page .sns-problem__list{
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 2;
}

.sns-page .sns-problem__list li{
  display:flex;
  align-items:center;
  gap:16px;
  position: relative;
  padding: 16px 180px 16px 0;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 150%;
  letter-spacing: 0.03em;
  color:var(--color-main);
  border-bottom: 1px solid var(--color-main);
}

.sns-page .sns-problem__list li::before{
  content: "";
  flex: 0 0 12px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--color-main);
  position: static;
  transform: none;
}

.sns-page .sns-problem__list li:last-child{
  border-bottom: none;
}


.sns-page .sns-problem__image {
  position: absolute;
  right: -23px;
  bottom: -2px;
  z-index: 10;
}

.sns-page .sns-problem__image img{
  width: 100%;
  display: block;
}

.sns-page .sns-problem__image.pc{
  max-width: 148px;
}

.sns-page .sns-problem__message{
  margin-top: 28px;
  text-align: center;
  position: relative;
  z-index: 2;
}

.sns-page .sns-problem__message span{
  display: inline-block;
  padding: 8px;
  background: var(--grad-main);
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 130%;
  letter-spacing: 0.1em;
  color: var(--color-white);
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .sns-page .sns-problem{
    padding: 0 0 80px;
    background: linear-gradient(180deg, #FAF8FF 0%, #FFFFFF 100%);
    overflow: hidden;
  }

  .sns-page .sns-problem__bg--left{
    left: -20px;
    top: 20px;
    width: 120px;
  }

  .sns-page .sns-problem__bg--right{
    right: -30px;
    top: 0;
    width: 140px;
  }

  .sns-page .sns-problem__outer{
    max-width: none;
    padding: 60px 24px;
    border-top: 1px solid var(--color-main);
    border-right: none;
    border-bottom: 1px solid var(--color-main);
    border-left: none;
    border-radius: 0;
    background: var(--color-white);
    position: relative;
    z-index: 2;
  }

  .sns-page .sns-problem__label{
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0.15em;
  }

  .sns-page .sns-problem__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .sns-page .sns-problem__inner{
    max-width: 354px;
    margin: 34px auto 0;
    padding: 12px;
    border: 1px solid var(--color-main);
    border-radius: 16px;
    background: var(--color-white);
    position: relative;
    z-index: 2;
    overflow: hidden;
  }

.sns-page .sns-problem__list li{
  gap:12px;
  padding: 14px 8px 14px 0;
  font-size: 16px;
  line-height: 160%;
  letter-spacing: 0.03em;
}

.sns-page .sns-problem__list li::before{
  flex: 0 0 8px;
  width: 8px;
  height: 8px;
}

  .sns-page .sns-problem__image{
    position: absolute;
    left: 50%;
    bottom: 114px;
    transform: translateX(-50%);
    right: auto;
    z-index: 10;
    pointer-events: none;
  }

  .sns-page .sns-problem__image.sp {
    max-width: 281px;
    width: 100%;
  }

  .sns-page .sns-problem__message{
    margin-top: 42px;
    text-align: center;
    position: relative;
    z-index: 2;
  }

  .sns-page .sns-problem__message span{
    padding: 4px;
    font-size: 18px;
    line-height: 130%;
    letter-spacing: 0.1em;
    width: 80%;
  }
}

/* ===============================
SNS Strategy × Creative × Analytics
=============================== */
.sns-page .sns-sca{
  padding: 120px 0 120px;
  background: var(--color-white);
}

.sns-page .sns-sca__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
}

.sns-page .sns-sca__label{
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-sca__title{
  margin-top: 18px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  background: linear-gradient(90deg, #A570E9 0%, #8B61E1 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-sca__title span{
  color: var(--color-text);
  background: none;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: var(--color-text);
  letter-spacing: 5%;
}

.sns-page .sns-sca__lead{
  margin-top: 40px;
}

.sns-page .sns-sca__lead p{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 200%;
  letter-spacing: 0.1em;
  color: var(--color-text);
}

.sns-page .sns-sca__lead span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-sca__cards{
  margin-top: 52px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.sns-page .sns-sca__card{
  border-radius: 32px;
  padding: 54px 28px 44px 28px;
  text-align: center;
}

.sns-page .sns-sca__card--01{
  background: linear-gradient(135deg, #C282F1 0%, #A470E8 100%);
}

.sns-page .sns-sca__card--02{
  background: linear-gradient(135deg, #A570E9 0%, #8B61E1 100%);
}

.sns-page .sns-sca__card--03{
  background: linear-gradient(135deg, #8860E0 0%, #7251D9 100%);
}

.sns-page .sns-sca__card-icon{
  width: 104px;
  margin: 0 auto 32px;
}

.sns-page .sns-sca__card-icon img{
  width: 100%;
  display: block;
}

.sns-page .sns-sca__card-title{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 100%;
  letter-spacing: 0.04em;
  color: var(--color-white);
}

.sns-page .sns-sca__card-text{
  margin-top: 28px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 170%;
  letter-spacing: 0.1em;
  color: var(--color-white);
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .sns-page .sns-sca{
    padding: 0 24px 80px;
    background: var(--color-white);
  }

  .sns-page .sns-sca__inner{
    max-width: none;
  }

  .sns-page .sns-sca__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .sns-page .sns-sca__title{
    margin-top: 16px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .sns-page .sns-sca__lead{
    margin-top: 24px;
  }

  .sns-page .sns-sca__lead p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .sns-page .sns-sca__cards{
    margin-top: 36px;
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .sns-page .sns-sca__card{
    border-radius: 32px;
    padding: 44px 24px;
    width: 90%;
    margin: 0 auto;
  }

  .sns-page .sns-sca__card-icon{
    width: 96px;
    margin: 0 auto 28px;
  }

  .sns-page .sns-sca__card-title{
    font-size: 20px;
    line-height: 130%;
    letter-spacing: 0.03em;
  }

  .sns-page .sns-sca__card-text{
    margin-top: 20px;
    font-size: 16px;
    line-height: 160%;
    letter-spacing: 0.03em;
  }
    
.sns-page .sns-sca__card--01{
  background: linear-gradient(180deg, #C282F1 0%, #A470E8 100%);
}

.sns-page .sns-sca__card--02{
  background: linear-gradient(180deg, #A570E9 0%, #8B61E1 100%);
}

.sns-page .sns-sca__card--03{
  background: linear-gradient(180deg, #8860E0 0%, #7251D9 100%);
}    
}

/* ===============================
SNS Partner
=============================== */
.sns-page .sns-partner{
  position: relative;
  overflow: visible;
  background: var(--color-white);
  z-index: 1;
  margin: 120px auto;
}


.sns-page .sns-partner__bg.pc{
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.sns-page .sns-partner__bg.pc img{
  width: 1920px;
  max-width: none;
  height: auto;
  display: block;
}

.sns-page .sns-partner__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.sns-page .sns-partner__label{
  text-align: center;
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-partner__title{
  margin-top: 18px;
  text-align: center;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  color: var(--color-text);
}

.sns-page .sns-partner__title span{
  background: linear-gradient(90deg, #A570E9 0%, #8B61E1 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-partner__lead{
  margin-top: 36px;
  text-align: center;
}

.sns-page .sns-partner__lead p{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 200%;
  letter-spacing: 0.1em;
  color: var(--color-text);
}

.sns-page .sns-partner__lead span{
  background: linear-gradient(90deg, #A570E9 0%, #8B61E1 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-partner__content{
  margin-top: 54px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
}

.sns-page .sns-partner__left{
  width: 58%;
}

.sns-page .sns-partner__right{
  width: 32%;
}

.sns-page .sns-partner__box{
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding-right: 148px;
  padding-left: 148px;
  min-height: 52px;
  background: var(--color-white);
  border: 2px solid transparent;
  border-radius: 999px;
  background-image:
  linear-gradient(#FFFFFF, #FFFFFF),
  var(--grad-main);
  background-origin: border-box;
  background-clip: padding-box, border-box;
}

.sns-page .sns-partner__box-title{
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 30px;
  line-height: 100%;
  letter-spacing: 0;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-partner__menu-list{
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
}

.sns-page .sns-partner__menu-list li{
  position: relative;
  padding-left: 24px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color:var(--color-main);
}

.sns-page .sns-partner__menu-list li + li{
  margin-top: 22px;
}

.sns-page .sns-partner__menu-list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--color-main);
  transform: translateY(-50%);
}

.sns-page .sns-partner__box--fee{
  margin-top: 44px;
}

.sns-page .sns-partner__price{
  margin-top: 28px;
}

.sns-page .sns-partner__price-main{
  display: flex;
  align-items: flex-end;
  gap: 14px;
  flex-wrap: wrap;
}

.sns-page .sns-partner__price-label{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 100%;
  letter-spacing: 0;
  color:var(--color-main);
}

.sns-page .sns-partner__price-label:first-child{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 100%;
  letter-spacing: 0;
  color:var(--color-main);
  background-color: #EFEFEF;
  padding: 8px 12px;
  border-radius: 100px;
}

.sns-page .sns-partner__price-num{
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 40px;
  line-height: 100%;
  letter-spacing: -0.02em;
  color:var(--color-main);
}

.sns-page .sns-partner__price-tax{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 100%;
  letter-spacing: 0;
  color:var(--color-main);
}

.sns-page .sns-partner__price-note{
  margin-top: 18px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 100%;
  letter-spacing: 0.1em;
  color: var(--color-text);
}

.sns-page .sns-partner__mockup{
  max-width: 343px;
  margin: 32px auto 0;
}

.sns-page .sns-partner__mockup img{
  width: 100%;
  display: block;
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .sns-page .sns-partner{
    padding: 0 0 80px;
    margin: 60px auto;      
  }

  .sns-page .sns-partner__inner{
    padding: 0 24px;
  }

  .sns-page .sns-partner__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .sns-page .sns-partner__title{
    margin-top: 14px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .sns-page .sns-partner__lead{
    margin-top: 28px;
  }

  .sns-page .sns-partner__lead p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .sns-page .sns-partner__content{
    margin-top: 32px;
    display: flex;
    flex-direction: column-reverse;
    gap: 28px;
  }

  .sns-page .sns-partner__left,
  .sns-page .sns-partner__right{
    width: 100%;
  }

  .sns-page .sns-partner__mockup{
    max-width: 178px;
    margin: 0 auto;
  }

  .sns-page .sns-partner__box{
    width: 100%;
    min-height: 48px;
    padding-top: 12px;
    padding-bottom: 12px;
    padding-left: 0;
    padding-right: 0;
  }

  .sns-page .sns-partner__box-title{
    font-size: 24px;
  }

  .sns-page .sns-partner__menu-list{
    margin-top: 24px;
  }

  .sns-page .sns-partner__menu-list li{
    padding-left: 14px;
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0;
  }

  .sns-page .sns-partner__menu-list li + li{
    margin-top: 16px;
  }

  .sns-page .sns-partner__menu-list li::before{
    width: 6px;
    height: 6px;
    top: 0.8em;
  }

  .sns-page .sns-partner__box--fee{
    margin-top: 34px;
  }

  .sns-page .sns-partner__price{
    margin-top: 24px;
    text-align: center;
  }

  .sns-page .sns-partner__price-main{
    justify-content: center;
    gap: 8px;
  }

  .sns-page .sns-partner__price-label{
    font-size: 16px;
  }

  .sns-page .sns-partner__price-num{
    font-size: 32px;
  }

  .sns-page .sns-partner__price-tax{
    font-size: 16px;
  }

  .sns-page .sns-partner__price-note{
    margin-top: 14px;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0;
  }

  .sns-page .sns-partner__bg{
    position: absolute;
    left: 0;
    top: auto;
    bottom: 0;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .sns-page .sns-partner__bg img{
    width: 100%;
    height: auto;
    display: block;
  }
}
/* ===============================
SNS Proven Results
=============================== */
.sns-page .sns-results{
  position: relative;
  overflow: visible;
  background: transparent;
  z-index: 2;
  margin: 200px auto 120px;  
}


.sns-page .sns-results__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.sns-page .sns-results__label{
  text-align: center;
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-results__title{
  margin-top: 16px;
  text-align: center;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-results__cards{
  margin-top: 52px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.sns-page .sns-results__card{
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.sns-page .sns-results__image{
  border-radius: 32px;
  overflow: hidden;
}

.sns-page .sns-results__image img{
  width: 100%;
  display: block;
}

.sns-page .sns-results__category{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  padding: 8px 16px;
  border-radius: 100px;
  background: var(--grad-main);
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 100%;
  letter-spacing: 0.05em;
  color: var(--color-white);
}

.sns-page .sns-results__text{
  text-align: left;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 170%;
  letter-spacing: 0.1em;
  color: var(--color-text);
}

.sns-page .sns-results__text span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-results__message{
  margin-top: 72px;
  text-align: center;
}

.sns-page .sns-results__message p{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 200%;
  letter-spacing: 0.1em;
  color: var(--color-text);
}

.sns-page .sns-results__message span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .sns-page .sns-results{
    padding: 0 24px 80px;
    margin: 60px auto 0;      
  }

  .sns-page .sns-results__inner{
    max-width: none;
  }

  .sns-page .sns-results__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .sns-page .sns-results__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .sns-page .sns-results__cards{
    margin-top: 32px;
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .sns-page .sns-results__card{
    gap: 12px;
  }

  .sns-page .sns-results__image{
    border-radius: 32px;
  }

  .sns-page .sns-results__category{
    padding: 8px 16px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.05em;
  }

  .sns-page .sns-results__text{
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0.1em;
  }

  .sns-page .sns-results__message{
    margin-top: 56px;
  }

  .sns-page .sns-results__message p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .sns-page .sns-results__bg{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .sns-page .sns-results__bg img{
    width: 100%;
    height: auto;
    display: block;
  }

}

/* ===============================
SNS FAQ
=============================== */

.sns-page .sns-faq{
  padding: 120px 0;
  position: relative;
  z-index: 3; 
}

/* ヘッダ */
.sns-page .sns-faq__head{
  text-align: center;
}

.sns-page .sns-faq__label{
  text-align: center;
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-faq__title{
  margin-top: 16px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 36px;
  font-weight: 600;
  line-height: 150%;
  letter-spacing: 0;
  background-color: var(--color-text);
  background-clip: text;
  color: transparent;
}

/* リスト */
.sns-page .sns-faq__list{
  max-width: var(--inner-width);
  margin: 80px auto 0;
}

/* アイテム */
.sns-page .sns-faq__item{
  padding: 40px 0;
  border-bottom: 1px solid var(--color-main);
}

.sns-page .sns-faq__item:last-child{
  border-bottom: none;
}

/* Q部分 */
.sns-page .sns-faq__q{
  display: flex;
  align-items: center;
  gap: 20px;
}

/* Qアイコン */
.sns-page .sns-faq__q img{
  width: 53px;
  flex: 0 0 53px;
}

/* 質問 */
.sns-page .sns-faq__q h3{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 0.05em;
  color:var(--color-main);
}

/* 回答 */
.sns-page .sns-faq__a{
  margin-top: 16px;
  padding-left: 73px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 200%;
  letter-spacing: 0.07em;
  color: var(--color-text);
}

/* ===============================
SP
=============================== */

@media (max-width:768px){

  .sns-page .sns-faq{
    padding: 60px 20px;
  }

.sns-page .sns-faq__label{
  font-size: 13px;
  line-height: 130%;
  letter-spacing: 0.15em;
}

.sns-page .sns-faq__title{
  font-size: 24px;
  line-height: 140%;
  letter-spacing: 0.03em;
}

  .sns-page .sns-faq__item{
    padding: 32px 0;
    text-align: center;
  }

  /* Q中央 */
  .sns-page .sns-faq__q{
    flex-direction: column;
    align-items: center;
    gap: 28px;
  }

  .sns-page .sns-faq__q img{
    width: 52px;
    flex: 0 0 52px;
  }

  .sns-page .sns-faq__q h3 {
    font-size: 16px;
    line-height: 140%;
    letter-spacing: 2%;
  }

  /* 回答 */
  .sns-page .sns-faq__a {
    padding-left: 0;
    margin-top: 12px;
    line-height: 180%;
    letter-spacing: 15%;
    text-align: center;
    font-size: 14px;
  }
.sns-page .sns-faq__list {
  max-width: var(--inner-width);
  margin: 0px auto 0;
}    
    
}


/* ===============================
SNS CAT
=============================== */
.sns-page .sns-cat{
  padding: 80px 24px;
  background: var(--grad-main);
}

.sns-page .sns-cat__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}

.sns-page .sns-cat__content{
  width: 70%;
}

.sns-page .sns-cat__image{
  width: 30%;
  text-align: center;
}

.sns-page .sns-cat__image img{
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

.sns-page .sns-cat__title{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  color: var(--color-white);
}

.sns-page .sns-cat__lead{
  margin-top: 28px;
}

.sns-page .sns-cat__lead p{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 200%;
  letter-spacing: 0.1em;
  color: var(--color-white);
}

.sns-page .sns-cat__btn{
  margin-top: 36px;
}

.sns-page .sns-cat__btn a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 40px;
  border-radius: 100px;
  background: var(--color-white);
  box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.25);
  text-decoration: none;
  transition: transform 1s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 1s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.sns-page .sns-cat__btn a span{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 100%;
  letter-spacing: 0.09em;
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.sns-page .sns-cat__btn a:hover{
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.25);
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .sns-page .sns-cat{
    padding: 40px 24px 48px;
  }

  .sns-page .sns-cat__inner{
    flex-direction: column-reverse;
    gap: 20px;
    text-align: center;
  }

  .sns-page .sns-cat__content,
  .sns-page .sns-cat__image{
    width: 100%;
  }

  .sns-page .sns-cat__image img{
    max-width: 129px;
  }

  .sns-page .sns-cat__title{
    font-size: 24px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .sns-page .sns-cat__lead{
    margin-top: 20px;
  }

  .sns-page .sns-cat__lead p{
    font-weight: 300;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .sns-page .sns-cat__btn{
    margin-top: 28px;
  }

  .sns-page .sns-cat__btn a{
    padding: 16px 24px;
    font-size: 18px;
    letter-spacing: 0.03em;
  }
}

/* ===============================
SNS Copy
=============================== */
.sns-page .sns-copy{
  background: #EFEFEF;
  padding: 30px 100px;
}

.sns-page .sns-copy__text{
  font-family: "Karla", sans-serif;
  font-weight: 300;
  font-size: 12px;
  line-height: 100%;
  letter-spacing: 0.1em;
  color: var(--color-text);
  text-align: center;
}

@media (max-width:768px){
  .sns-page .sns-copy{
    padding: 20px 24px;
  }

  .sns-page .sns-copy__text{
    font-size: 11px;
  }
}
