@charset "utf-8";

:root{
  --color-main: #C76C0D;
  --color-text: #484848;
  --color-white: #FFFFFF;
  --grad-main: linear-gradient(90deg,#C18B1E 0%,#C18B1E 25%,#CB5500 75%,#CB5500 100%);
  --inner-width: 1080px;
}

/* ===============================
SNS FV
=============================== */
.web-design-page {
  background: #fff;
  margin-top: 60px;
overflow-x: hidden;        
}

.web-design-page .sns-fv{
  position:relative;
  overflow:hidden;
  background:#fff;
  padding:120px 0 20px;
  min-height:930px;
}

/* 波の少し下からベース色 */
.web-design-page .sns-fv::before{
  content:"";
  position:absolute;
  top:140px;
  left:0;
  width:100%;
  height: calc(100% - 138px);
  background: #fef9f3;
  z-index:0;
}

.web-design-page .sns-fv > .container{
  position:relative;
  z-index:10;
  max-width:var(--inner-width);
}

.web-design-page .sns-fv .breadcrumb{
  margin-bottom:0px;
}

/* 上段 */
.web-design-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;
}

.web-design-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;
}

.web-design-page .sns-fv__title::before{
  content:"DESIGN";
  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:#fef9f3;
  z-index:-1;
}

.web-design-page .sns-fv__image{
  width:36%;
  position:relative;
  z-index:10;
  margin-top:10px;
}

.web-design-page .sns-fv__image img{
  width:100%;
  max-width:213px;
  display:block;
}

/* 下段 */
.web-design-page .sns-fv__lead{
  margin-top:130px;
  text-align:center;
  position:relative;
  z-index:10;
}

.web-design-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;
}

.web-design-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);
}

.web-design-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;
}

.web-design-page .sns-fv__lead-text{
  margin-top:0px;
}

.web-design-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;    
}

.web-design-page .sns-fv__lead-text p:last-child {
  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: 0px;    
}

.web-design-page .sns-fv__lead-text span{
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.web-design-page .sns-fv__btn{
  margin-top:44px;
}

.web-design-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);
}

.web-design-page .sns-fv__btn a:hover{
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 rgba(0,0,0,0.15);
}
/* wave */
.web-design-page .sns-fv__wave.pc{
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 1;
  pointer-events: none;
}

.web-design-page .sns-fv__wave.pc img{
  width: 1920px;
  max-width: none;
  display: block;
}

/* circle */
.web-design-page .sns-fv__circle{
  position:absolute;
  left:-120px;
  top:-150px;
  width:700px;
  z-index:2;
  pointer-events:none;
}

.web-design-page .sns-fv__circle img{
  width:100%;
  display:block;
  opacity:0.7;
}

/* dot */
.web-design-page .sns-fv__dot{
  position:absolute;
  z-index:3;
  pointer-events:none;
}

.web-design-page .sns-fv__dot img{
  width:100%;
  display:block;
}

.web-design-page .sns-fv__dot--left {
  top: 183px;
  left: 48%;
  width: 330px;
}

.web-design-page .sns-fv__dot--right {
  top: 500px;
  right: 10px;
  width: 120px;
}

/* ===============================
SP
=============================== */
@media (max-width:768px){
    
.web-design-page {
  background: #fff;
  margin-top: 20px;
}    

  .web-design-page .sns-fv{
    padding:80px 0 90px;
    min-height:auto;
    overflow:visible;
    background:#fff;
  }
    
 .web-design-page  .sns-fv::before {
    top: 80px;
    height: calc(100% - 80px);
background: linear-gradient(180deg, #fef9f3 0%, #FFFFFF 100%);     
  }    

 .web-design-page  .sns-fv .breadcrumb{
    margin-bottom:30px;
  }

.web-design-page   .sns-fv__top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
  }

.web-design-page .sns-fv__title{
  width:60%;
  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;
}

.web-design-page .sns-fv__title::before{
  top:50%;
  left:0;
  transform:translateY(-50%);
  font-size:64px;
  line-height:100%;
}

.web-design-page .sns-fv__image{
    width:40%;
    margin-top:50px;
  }

.web-design-page .sns-fv__lead{
    margin-top:28px;
    text-align:center;
    padding: 0 7%;    
  }

.web-design-page   .sns-fv__lead-en{
    font-size:13px;
    line-height:130%;
    letter-spacing:0.15em;
  }

.web-design-page .sns-fv__lead-title{
    margin-top:10px;
    font-size:24px;
    line-height:150%;
    letter-spacing:0;
  }

.web-design-page .sns-fv__lead-title span{
    font-size:24px;
    line-height:140%;
    letter-spacing:0.03em;
  }

.web-design-page .sns-fv__lead-text{
    margin-top:18px;
  }

.web-design-page .sns-fv__lead-text p{
    font-size:16px;
    line-height:200%;
    letter-spacing:0.1em;
    margin-top: 22px;    
  }

.web-design-page .sns-fv__btn{
    margin-top:22px;
  }

.web-design-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);
  }

    
.web-design-page .sns-fv__wave.sp{
  position: absolute;
  top: 80px;
  left: 50%;
  transform: translateX(-50%);
  width: 660px;
  max-width: 1920px;
  z-index: 1;
  pointer-events: none;
}

.web-design-page .sns-fv__wave.sp img{
  width: 660px;
  display: block;
}    

.web-design-page .sns-fv__circle{
    left:-92px;
    top:210px;
    width:330px;
  }

.web-design-page .sns-fv__dot--left{
    top:180px;
    right:88px;
    left:auto;
    width:120px;
  }

.web-design-page .sns-fv__dot--right{
    top:300px;
    right:-18px;
    width:88px;
  }  
    
.web-design-page .sns-fv__image img{
    width: 100%;
    max-width: 116px;
    display: block;
    float: right;
  }  
    
.web-design-page .sns-fv__lead-text p:last-child {
  font-size: 16px;
  line-height: 200%;
  letter-spacing: 10%;
  color: var(--color-text);
  margin-top: 10px;
}     
}


/* ===============================
SNS Problem
=============================== */
.web-design-page .sns-problem{
  position: relative;
  padding: 200px 0 120px;
  background: linear-gradient(180deg, #fef9f3 0%, #FFFFFF 100%);
  overflow: hidden;
}

.web-design-page .sns-problem__bg{
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.web-design-page .sns-problem__bg img{
  width: 100%;
  display: block;
}

.web-design-page .sns-problem__bg--left{
  left: 0;
  top: 40px;
  width: 220px;
}

.web-design-page .sns-problem__bg--right{
  right: 0;
  top: 0;
  width: 460px;
}

.web-design-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;
}

.web-design-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;
}

.web-design-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);
}

.web-design-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;
}

.web-design-page .sns-problem__list{
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 2;
}

.web-design-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);
}

.web-design-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;
}

.web-design-page .sns-problem__list li:last-child{
  border-bottom: none;
}


.web-design-page .sns-problem__image {
  position: absolute;
  right: -23px;
  bottom: -2px;
  z-index: 10;
}

.web-design-page .sns-problem__image img{
  width: 100%;
  display: block;
}

.web-design-page .sns-problem__image.pc{
  max-width: 148px;
}

.web-design-page .sns-problem__message{
  margin-top: 28px;
  text-align: center;
  position: relative;
  z-index: 2;
}

.web-design-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){

  .web-design-page .sns-problem{
    padding: 0 0 80px;
    background: linear-gradient(180deg, #FAF8FF 0%, #FFFFFF 100%);
    overflow: hidden;
  }

  .web-design-page .sns-problem__bg--left{
    left: -20px;
    top: 20px;
    width: 120px;
  }

  .web-design-page .sns-problem__bg--right{
    right: -30px;
    top: 0;
    width: 140px;
  }

  .web-design-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;
  }

  .web-design-page .sns-problem__label{
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0.15em;
  }

  .web-design-page .sns-problem__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .web-design-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;
  }

.web-design-page .sns-problem__list li{
  gap:12px;
  padding: 14px 8px 14px 0;
  font-size: 16px;
  line-height: 160%;
  letter-spacing: 0.03em;
}

.web-design-page .sns-problem__list li::before{
  flex: 0 0 8px;
  width: 8px;
  height: 8px;
}

  .web-design-page .sns-problem__image{
    position: absolute;
    left: 50%;
    bottom: 160px;
    transform: translateX(-50%);
    right: auto;
    z-index: 10;
    pointer-events: none;
  }

  .web-design-page .sns-problem__image.sp {
    max-width: 281px;
    width: 100%;
  }

  .web-design-page .sns-problem__message{
    margin-top: 42px;
    text-align: center;
    position: relative;
    z-index: 2;
  }

  .web-design-page .sns-problem__message span{
    padding: 4px;
    font-size: 18px;
    line-height: 130%;
    letter-spacing: 0.1em;
    width: 86%;
    display: block;
    margin:0 auto;
  }
}

/* ===============================
SNS Strategy × Creative × Analytics
=============================== */
.web-design-page .sns-sca{
  position: relative;
  padding: 120px 0 120px;
  background: var(--color-white);
  overflow: visible;
}

.web-design-page .sns-partner__bg.pc{
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.web-design-page .sns-partner__bg.pc img{
  width: 1920px;
  height: auto;
}

.web-design-page .sns-sca__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.web-design-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;
  padding-bottom: 18px;
}

.web-design-page .sns-sca__title{
  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;
}

.web-design-page .sns-sca__title span{
  color: var(--color-text);
  background: none;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: var(--color-text);
  letter-spacing: 0.05em;
  font-weight: 300;
}

.web-design-page .sns-sca__lead{
  margin-top: 40px;
}

.web-design-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);
}

.web-design-page .sns-sca__lead span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.web-design-page .sns-sca__cards{
  margin-top: 52px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.web-design-page .sns-sca__card{
  border-radius: 32px;
  padding: 54px 28px 44px 28px;
  text-align: center;
}

.web-design-page .sns-sca__card--01{
  background: linear-gradient(135deg, #C2881D 0%, #C57914 100%);
}

.web-design-page .sns-sca__card--02{
  background: linear-gradient(135deg, #C57814 0%, #C8670A 100%);
}

.web-design-page .sns-sca__card--03{
  background: linear-gradient(135deg, #C8670A 0%, #CB5701 100%);
}

.web-design-page .sns-sca__card-icon{
  width: 104px;
  margin: 0 auto 32px;
}

.web-design-page .sns-sca__card-icon img{
  width: 100%;
  display: block;
}

.web-design-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);
}

.web-design-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){

  .web-design-page .sns-sca{
    padding: 0 24px 80px;
    background: var(--color-white);
    overflow: visible;
  }

  .web-design-page .sns-partner__bg{
    position: absolute;
    left: 0;
    top: 0%;
    bottom: auto;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .web-design-page .sns-partner__bg img{
    width: 100%;
    height: auto;
    display: block;
  }

  .web-design-page .sns-sca__inner{
    max-width: none;
    position: relative;
    z-index: 2;
  }

  .web-design-page .sns-sca__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .web-design-page .sns-sca__title{
    margin-top: 16px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-sca__lead{
    margin-top: 24px;
  }

  .web-design-page .sns-sca__lead p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .web-design-page .sns-sca__cards{
    margin-top: 36px;
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .web-design-page .sns-sca__card{
    border-radius: 32px;
    padding: 44px 24px;
    width:90%;
    margin:0 auto;
  }

  .web-design-page .sns-sca__card-icon{
    width: 96px;
    margin: 0 auto 28px;
  }

  .web-design-page .sns-sca__card-title{
    font-size: 20px;
    line-height: 130%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-sca__card-text{
    font-size: 16px;
    line-height: 160%;
    letter-spacing: 0.03em;
    margin: 20px auto 0;
  }

  .web-design-page .sns-sca__card--01{
    background: linear-gradient(180deg, #C2881D 0%, #C57914 100%);
  }

  .web-design-page .sns-sca__card--02{
    background: linear-gradient(180deg, #C57814 0%, #C8670A 100%);
  }

  .web-design-page .sns-sca__card--03{
    background: linear-gradient(180deg, #C8670A 0%, #CB5701 100%);
  }
}

/*=============================== 
SNS Partner 
=============================== */
.web-design-page .sns-partner{
  position: relative;
  overflow: visible;
  background: transparent;
  z-index: 2;
  margin: 120px auto;
}

.web-design-page .sns-partner__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "diagram head"
    "menu head"
    "menu fee";
  column-gap: 56px;
  row-gap: 44px;
  align-items: start;
}

.web-design-page .sns-partner__head{
  grid-area: head;
  text-align: right;
}

.web-design-page .sns-partner__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;
}

.web-design-page .sns-partner__title{
  margin-top: 18px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  color: var(--color-text);
}

.web-design-page .sns-partner__title span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.web-design-page .sns-partner__lead{
  margin-top: 36px;
}

.web-design-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);
}

.web-design-page .sns-partner__lead span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

/* diagram */
.web-design-page .sns-partner__diagram{
  grid-area: diagram;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0px;
  min-height: 260px;
  margin: 40px 0;    
}

.web-design-page .sns-partner__circle {
  width: 293px;
  min-height: 293px;
  border-radius: 50%;
  background: var(--grad-main);
  padding: 60px 25px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  text-align: center;
}
.web-design-page .sns-partner__circle:last-child{
  width: 293px;
  min-height: 293px;
  border-radius: 50%;
  background:#CB5701;
  padding: 60px 25px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  text-align: center;
}

.web-design-page .sns-partner__circle-title{
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 32px;
  line-height: 120%;
  letter-spacing: 0;
  color: var(--color-white);
}

.web-design-page .sns-partner__circle-tags{
  list-style: none;
  margin: 22px auto 0;
  padding: 0;
  display: grid;
  grid-template-columns: max-content max-content;
  justify-content: center;
  column-gap: 8px;
  row-gap: 10px;
  width: fit-content;
}

.web-design-page .sns-partner__circle-tags li{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 0px;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--color-white);
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 100%;
  letter-spacing: 0.03em;
  color: var(--color-main);
}

.web-design-page .sns-partner__circle-tags li:nth-child(3){
  grid-column: 1 / 3;
  justify-self: center;
}

.web-design-page .sns-partner__circle-tags li{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 0px;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--color-white);
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 14px;
  line-height: 100%;
  letter-spacing: 0.03em;
  color: var(--color-main);
}

.web-design-page .sns-partner__line{
  flex: 0 0 30px;
  height: 4px;
  background: #CB5701;
}

/* menu */
.web-design-page .sns-partner__menu{
  grid-area: menu;
}

.web-design-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;
}

.web-design-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;
}

.web-design-page .sns-partner__menu-list{
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
}

.web-design-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);
}

.web-design-page .sns-partner__menu-list li + li{
  margin-top: 22px;
}

.web-design-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%);
}

/* fee */
.web-design-page .sns-partner__fee{
  grid-area: fee;
  text-align: right;
  margin-top: 40px;    
}

.web-design-page .sns-partner__fee .sns-partner__box{
  margin: 0 auto;
}

.web-design-page .sns-partner__price{
  margin-top: 28px;
}

.web-design-page .sns-partner__price-text{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 180%;
  letter-spacing: 0.06em;
  color: var(--color-main);
}

.web-design-page .sns-partner__price-note{
  margin-top: 18px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 170%;
  letter-spacing: 0.08em;
  color: var(--color-text);
}

/* ===============================
SP 
=============================== */

@media (max-width: 768px){
  .web-design-page .sns-partner{
    padding: 0 0 80px;
    margin: 60px auto;
    background: transparent;
    position: relative;
    z-index: 2;
  }

  .web-design-page .sns-partner__inner{
    padding: 0 24px;
    position: relative;
    z-index: 2;
    display: block;
    max-width: none;
  }

  .web-design-page .sns-partner__head{
    text-align: right;
  }

  .web-design-page .sns-partner__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .web-design-page .sns-partner__title{
    margin-top: 14px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-partner__lead{
    margin-top: 15px;
  }

  .web-design-page .sns-partner__lead p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .web-design-page .sns-partner__diagram{
    margin-top: 36px;
    flex-direction: column;
    gap: 0px;
    min-height: auto;
  }

  .web-design-page .sns-partner__circle{
    width: 213px;
    min-height: 213px;
    padding: 28px 10px 24px;
    justify-content: center;
   }   
    
  .web-design-page .sns-partner__circle:last-child{
    width: 213px;
    min-height: 213px;
    padding: 28px 10px 24px;
    justify-content: center;
   }   

  .web-design-page .sns-partner__circle-title{
    font-size: 24px;
    line-height: 100%;
  }

  .web-design-page .sns-partner__circle-tags{
    margin-top: 18px;
    gap: 8px;
  }

  .web-design-page .sns-partner__circle-tags li{
    padding: 4px 6px;
    font-size: 14px;
  }

  .web-design-page .sns-partner__line{
    width: 4px;
    height: 14px;
    flex: 0 0 14px;
  }

  .web-design-page .sns-partner__menu{
    margin-top: 40px;
  }

  .web-design-page .sns-partner__box{
    width: 100%;
    min-height: 48px;
    padding-top: 12px;
    padding-bottom: 12px;
    padding-left: 0;
    padding-right: 0;
  }

  .web-design-page .sns-partner__box-title{
    font-size: 24px;
  }

  .web-design-page .sns-partner__menu-list{
    margin-top: 24px;
  }

  .web-design-page .sns-partner__menu-list li{
    padding-left: 14px;
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0;
  }

  .web-design-page .sns-partner__menu-list li + li{
    margin-top: 16px;
  }

  .web-design-page .sns-partner__menu-list li::before{
    width: 6px;
    height: 6px;
    top: 0.8em;
  }

  .web-design-page .sns-partner__fee{
    margin-top: 40px;
  }

  .web-design-page .sns-partner__price{
    margin-top: 24px;
    text-align: center;
  }

  .web-design-page .sns-partner__price-text{
    font-size: 20px;
    line-height: 170%;
    letter-spacing: 0.04em;
  }

  .web-design-page .sns-partner__price-note{
    margin-top: 14px;
    font-size: 14px;
    line-height: 170%;
    letter-spacing: 0;
  }
}

/* ===============================
SNS Proven Results
=============================== */
.web-design-page .sns-results{
  position: relative;
  overflow: visible;
  background: transparent;
  z-index: 2;
  margin: 200px auto 120px;  
}


.web-design-page .sns-results__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.web-design-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;
}

.web-design-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;
}

.web-design-page .sns-results__cards{
  margin-top: 52px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.web-design-page .sns-results__card{
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.web-design-page .sns-results__image{
  border-radius: 32px;
  overflow: hidden;
}

.web-design-page .sns-results__image img{
  width: 100%;
  display: block;
}

.web-design-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);
}

.web-design-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);
}

.web-design-page .sns-results__text span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.web-design-page .sns-results__message{
  margin-top: 72px;
  text-align: center;
}

.web-design-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);
}

.web-design-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){

  .web-design-page .sns-results{
    padding: 0 24px 80px;
    margin: 60px auto 0;      
  }

  .web-design-page .sns-results__inner{
    max-width: none;
  }

  .web-design-page .sns-results__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .web-design-page .sns-results__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-results__cards{
    margin-top: 32px;
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .web-design-page .sns-results__card{
    gap: 12px;
  }

  .web-design-page .sns-results__image{
    border-radius: 32px;
  }

  .web-design-page .sns-results__category{
    padding: 8px 16px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.05em;
  }

  .web-design-page .sns-results__text{
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0.1em;
  }

  .web-design-page .sns-results__message{
    margin-top: 56px;
  }

  .web-design-page .sns-results__message p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .web-design-page .sns-results__bg{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .web-design-page .sns-results__bg img{
    width: 100%;
    height: auto;
    display: block;
  }

}

/* ===============================
SNS FAQ
=============================== */

.web-design-page .sns-faq{
  padding: 120px 0;
  position: relative;
  z-index: 3; 
}

/* ヘッダ */
.web-design-page .sns-faq__head{
  text-align: center;
}

.web-design-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;
}

.web-design-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;
}

/* リスト */
.web-design-page .sns-faq__list{
  max-width: var(--inner-width);
  margin: 80px auto 0;
}

/* アイテム */
.web-design-page .sns-faq__item{
  padding: 40px 0;
  border-bottom: 1px solid var(--color-main);
}

.web-design-page .sns-faq__item:last-child{
  border-bottom: none;
}

/* Q部分 */
.web-design-page .sns-faq__q{
  display: flex;
  align-items: center;
  gap: 20px;
}

/* Qアイコン */
.web-design-page .sns-faq__q img{
  width: 53px;
  flex: 0 0 53px;
}

/* 質問 */
.web-design-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);
}

/* 回答 */
.web-design-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){

  .web-design-page .sns-faq{
    padding: 60px 20px;
  }

.web-design-page .sns-faq__label{
  font-size: 13px;
  line-height: 130%;
  letter-spacing: 0.15em;
}

.web-design-page .sns-faq__title{
  font-size: 24px;
  line-height: 140%;
  letter-spacing: 0.03em;
}

  .web-design-page .sns-faq__item{
    padding: 32px 0;
    text-align: center;
  }

  /* Q中央 */
  .web-design-page .sns-faq__q{
    flex-direction: column;
    align-items: center;
    gap: 28px;
  }

  .web-design-page .sns-faq__q img{
    width: 52px;
    flex: 0 0 52px;
  }

  .web-design-page .sns-faq__q h3 {
    font-size: 16px;
    line-height: 140%;
    letter-spacing: 2%;
  }

  /* 回答 */
  .web-design-page .sns-faq__a {
    padding-left: 0;
    margin-top: 12px;
    line-height: 180%;
    letter-spacing: 15%;
    text-align: center;
    font-size: 14px;
  }
.web-design-page .sns-faq__list {
  max-width: var(--inner-width);
  margin: 0px auto 0;
}    
    
}


/* ===============================
SNS CAT
=============================== */
.web-design-page .sns-cat{
  padding: 80px 24px;
  background: var(--grad-main);
}

.web-design-page .sns-cat__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}

.web-design-page .sns-cat__content{
  width: 70%;
}

.web-design-page .sns-cat__image{
  width: 30%;
  text-align: center;
}

.web-design-page .sns-cat__image img{
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

.web-design-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);
}

.web-design-page .sns-cat__lead{
  margin-top: 28px;
}

.web-design-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);
}

.web-design-page .sns-cat__btn{
  margin-top: 36px;
}

.web-design-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);
}

.web-design-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;
}

.web-design-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){

  .web-design-page .sns-cat{
    padding: 40px 24px 48px;
  }

  .web-design-page .sns-cat__inner{
    flex-direction: column-reverse;
    gap: 20px;
    text-align: center;
  }

  .web-design-page .sns-cat__content,
  .web-design-page .sns-cat__image{
    width: 100%;
  }

  .web-design-page .sns-cat__image img{
    max-width: 129px;
  }

  .web-design-page .sns-cat__title{
    font-size: 24px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-cat__lead{
    margin-top: 20px;
  }

  .web-design-page .sns-cat__lead p{
    font-weight: 300;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-cat__btn{
    margin-top: 28px;
  }

  .web-design-page .sns-cat__btn a{
    padding: 16px 24px;
    font-size: 18px;
    letter-spacing: 0.03em;
  }
}

/* ===============================
SNS Copy
=============================== */
.web-design-page .sns-copy{
  background: #EFEFEF;
  padding: 30px 100px;
}

.web-design-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){
  .web-design-page .sns-copy{
    padding: 20px 24px;
  }

  .web-design-page .sns-copy__text{
    font-size: 11px;
  }
}



/* ===============================
Designed for Execution
=============================== */
.web-design-page .sns-execution{
  position: relative;
  padding: 120px 0 110px;
  background: #FFFFFF;
  overflow: hidden;
  z-index: 0;    
}

.web-design-page .sns-execution__bg{
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 1080px;
  pointer-events: none;
  z-index: 0;
}

.web-design-page .sns-execution__bg img{
  width: 100%;
  display: block;
}

.web-design-page .sns-execution__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
  text-align: center;
}

.web-design-page .sns-execution__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;
}

.web-design-page .sns-execution__title{
  margin-top: 18px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  color: var(--color-text);
}

.web-design-page .sns-execution__lead{
  margin-top: 34px;
  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);
}

.web-design-page .sns-execution__tags{
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.web-design-page .sns-execution__tag{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  border: 2px solid #C76C0D;
  border-radius: 100px;
  background: #FFFFFF;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.1em;
  color: #C76C0D;
}

.web-design-page .sns-execution__sublead{
  margin-top: 28px;
  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);
}

.web-design-page .sns-execution__points{
  margin-top: 56px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 66px;
}

.web-design-page .sns-execution__point{
  --point-core: #C57914;
  position: relative;
  z-index: 0;
  isolation: isolate;
  width: 252px;
  min-width: 252px;
  height: 252px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  text-align: center;
  color: #FFFFFF;
  background: transparent;
  overflow: visible;

  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 160%;
  letter-spacing: 0.03em;
}

.web-design-page .sns-execution__point::before{
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: 50%;
  background: radial-gradient(
    circle at center,
    var(--point-core) 0%,
    color-mix(in srgb, var(--point-core) 92%, #ffffff 8%) 28%,
    color-mix(in srgb, var(--point-core) 55%, transparent 45%) 55%,
    color-mix(in srgb, var(--point-core) 18%, transparent 82%) 74%,
    transparent 100%
  );
  filter: blur(18px);
  transform: scale(1.12);
  z-index: -1;
}

.web-design-page .sns-execution__point span,
.web-design-page .sns-execution__point p{
  position: relative;
  z-index: 2;
}

.web-design-page .sns-execution__point--01{
  --point-core: #C2881D;
}

.web-design-page .sns-execution__point--02{
  --point-core: #C8670A;
}

.web-design-page .sns-execution__point--03{
  --point-core: #CB5701;
}


.web-design-page .sns-execution__message{
  margin-top: 72px;
  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);
}

.web-design-page .sns-execution__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){

  .web-design-page .sns-execution{
    padding: 80px 24px 80px;
  }

  .web-design-page .sns-execution__bg{
    top: 0;
    max-width: 402px;
  }

  .web-design-page .sns-execution__inner{
    max-width: none;
  }

  .web-design-page .sns-execution__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .web-design-page .sns-execution__title{
    margin-top: 16px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-execution__lead{
    margin-top: 28px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-execution__tags{
    margin-top: 24px;
    gap: 12px;
  }

  .web-design-page .sns-execution__tag{
    padding: 8px 16px;
    border-width: 1px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-execution__sublead{
    margin-top: 20px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-execution__points{
    margin-top: 46px;
    flex-direction: column;
    align-items: center;
    gap: 54px;
  }

  .web-design-page .sns-execution__point{
    width: 194px;
    min-width: 194px;
    height: 194px;
    padding: 20px;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .web-design-page .sns-execution__point::before{
    inset: -8px;
    filter: blur(18px);
    transform: scale(1.1);
  }

  .web-design-page .sns-execution__message{
    margin-top: 54px;
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.03em;
  }
}